AntBrain.py 3.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. from intelligine.simulation.object.brain.Brain import Brain
  2. from intelligine.simulation.object.brain.part.attack.AttackBrainPart import AttackBrainPart
  3. from intelligine.simulation.object.brain.part.move.AntMoveBrainPart import AntMoveBrainPart
  4. from intelligine.cst import MODE, MODE_EXPLO, MODE_GOHOME, PHEROMON_DIR_EXPLO, \
  5. BRAIN_PART_TAKE, BRAIN_PART_PUT, MODE_NURSE, PHEROMON_DIR_NONE, BRAIN_PART_ATTACK, MODE_HOME, \
  6. SMELL_FOOD, SMELL_EGG
  7. from intelligine.cst import MOLECULE_SEARCHING
  8. from intelligine.cst import BRAIN_PART_MOVE
  9. from intelligine.simulation.object.brain.part.transport.AntPutBrainPart import AntPutBrainPart
  10. from intelligine.simulation.object.brain.part.transport.AntTakeBrainPart import AntTakeBrainPart
  11. from intelligine.synergy.object.Food import Food
  12. from intelligine.synergy.object.ant.Egg import Egg
  13. from synergine.core.exceptions import NotFound
  14. class AntBrain(Brain):
  15. _brain_parts = Brain._brain_parts.copy()
  16. _brain_parts.update({
  17. BRAIN_PART_MOVE: AntMoveBrainPart,
  18. BRAIN_PART_TAKE: AntTakeBrainPart,
  19. BRAIN_PART_PUT: AntPutBrainPart,
  20. BRAIN_PART_ATTACK: AttackBrainPart
  21. })
  22. _taken_smell_matches = {
  23. Food: SMELL_FOOD,
  24. Egg: SMELL_EGG
  25. }
  26. """ Correspondance entre ce qui est ramassé et où ce doit être stocké """
  27. def __init__(self, context, host):
  28. super().__init__(context, host)
  29. self._movement_mode = MODE_HOME
  30. self._distance_from_objective = 0
  31. self._molecule_searching = PHEROMON_DIR_EXPLO
  32. def switch_to_mode(self, mode):
  33. self._movement_mode = mode
  34. self._update_molecule_gland(mode)
  35. self._context.metas.value.set(MODE, self._host.get_id(), mode)
  36. self._update_molecule_searching(mode)
  37. def _update_molecule_gland(self, mode):
  38. if mode == MODE_EXPLO:
  39. molecule_direction_type = None
  40. elif mode == MODE_GOHOME:
  41. molecule_direction_type = PHEROMON_DIR_EXPLO
  42. self._distance_from_objective = 0
  43. elif mode == MODE_NURSE:
  44. molecule_direction_type = None
  45. elif mode == MODE_HOME:
  46. molecule_direction_type = PHEROMON_DIR_EXPLO
  47. else:
  48. raise NotImplementedError()
  49. if molecule_direction_type:
  50. self._host.get_movement_molecule_gland().set_molecule_type(molecule_direction_type)
  51. self._host.get_movement_molecule_gland().enable()
  52. else:
  53. self._host.get_movement_molecule_gland().disable()
  54. def _update_molecule_searching(self, mode):
  55. if mode == MODE_EXPLO:
  56. molecule_searching = PHEROMON_DIR_EXPLO
  57. elif mode == MODE_GOHOME:
  58. molecule_searching = PHEROMON_DIR_NONE
  59. elif mode == MODE_NURSE:
  60. molecule_searching = PHEROMON_DIR_NONE
  61. elif mode == MODE_HOME:
  62. # TODO: Ca depend de ce que fait la fourmis, si s'occupe des oeufs, etc
  63. molecule_searching = self.get_part(BRAIN_PART_TAKE).get_smell_target()
  64. else:
  65. raise NotImplementedError()
  66. self._molecule_searching = molecule_searching
  67. self._context.metas.value.set(MOLECULE_SEARCHING, self._host.get_id(), molecule_searching)
  68. def get_movement_mode(self):
  69. return self._movement_mode
  70. def host_moved(self, distance=1):
  71. self._distance_from_objective += distance
  72. def set_distance_from_objective(self, distance):
  73. self._distance_from_objective = distance
  74. def get_distance_from_objective(self):
  75. return self._distance_from_objective
  76. def get_smell_for_object_taken(self, obj):
  77. for take_class in self._taken_smell_matches:
  78. if isinstance(obj, take_class):
  79. return self._taken_smell_matches[take_class]
  80. raise NotFound()
  81. @classmethod
  82. def get_home_smells(cls):
  83. """
  84. Note: Actually return all know smells. Not really HOME smells.
  85. :return:
  86. """
  87. return cls._taken_smell_matches.values()