AntBrain.py 3.8KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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 MOVE_MODE, MOVE_MODE_EXPLO, MOVE_MODE_GOHOME, PHEROMON_DIR_HOME, PHEROMON_DIR_EXPLO, \
  5. BRAIN_PART_TAKE, BRAIN_PART_PUT, MOVE_MODE_NURSE, PHEROMON_DIR_NONE, BRAIN_PART_ATTACK, MOVE_MODE_HOME, SMELL_FOOD
  6. from intelligine.cst import MOLECULE_SEARCHING
  7. from intelligine.cst import BRAIN_PART_MOVE
  8. from intelligine.simulation.object.brain.part.transport.AntPutBrainPart import AntPutBrainPart
  9. from intelligine.simulation.object.brain.part.transport.AntTakeBrainPart import AntTakeBrainPart
  10. from intelligine.synergy.object.Food import Food
  11. from synergine.core.exceptions import NotFound
  12. class AntBrain(Brain):
  13. # TODO: methode __init_ pour la classe ? Pour surcharger ici.
  14. _brain_parts = {
  15. BRAIN_PART_MOVE: AntMoveBrainPart,
  16. BRAIN_PART_TAKE: AntTakeBrainPart,
  17. BRAIN_PART_PUT: AntPutBrainPart,
  18. BRAIN_PART_ATTACK: AttackBrainPart
  19. }
  20. _taken_smell_matches = {
  21. Food: SMELL_FOOD
  22. }
  23. """ Correspondance entre ce qui est ramassé et où ce doit être stocké """
  24. def __init__(self, context, host):
  25. super().__init__(context, host)
  26. self._movement_mode = MOVE_MODE_HOME
  27. self._distance_from_objective = 0 # TODO rename: distance_since_objective
  28. self._molecule_searching = PHEROMON_DIR_EXPLO
  29. def switch_to_mode(self, mode):
  30. # TODO: Mode explo: reinit exploration vector
  31. self._movement_mode = mode
  32. self._update_molecule_gland(mode)
  33. self._context.metas.value.set(MOVE_MODE, self._host.get_id(), mode)
  34. self._update_molecule_searching(mode)
  35. def _update_molecule_gland(self, mode):
  36. if mode == MOVE_MODE_EXPLO:
  37. molecule_direction_type = PHEROMON_DIR_HOME
  38. elif mode == MOVE_MODE_GOHOME:
  39. molecule_direction_type = PHEROMON_DIR_EXPLO
  40. self._distance_from_objective = 0
  41. elif mode == MOVE_MODE_NURSE:
  42. molecule_direction_type = None
  43. elif mode == MOVE_MODE_HOME:
  44. molecule_direction_type = PHEROMON_DIR_EXPLO
  45. else:
  46. raise NotImplementedError()
  47. if molecule_direction_type:
  48. self._host.get_movement_molecule_gland().set_molecule_type(molecule_direction_type)
  49. self._host.get_movement_molecule_gland().enable()
  50. else:
  51. self._host.get_movement_molecule_gland().disable()
  52. def _update_molecule_searching(self, mode):
  53. if mode == MOVE_MODE_EXPLO:
  54. molecule_searching = PHEROMON_DIR_EXPLO
  55. elif mode == MOVE_MODE_GOHOME:
  56. # TODO: Plus rien ici (path integration)
  57. molecule_searching = PHEROMON_DIR_HOME
  58. elif mode == MOVE_MODE_NURSE:
  59. molecule_searching = PHEROMON_DIR_NONE
  60. elif mode == MOVE_MODE_HOME:
  61. molecule_searching = self.get_part(BRAIN_PART_TAKE).get_smell_target()
  62. else:
  63. raise NotImplementedError()
  64. self._molecule_searching = molecule_searching
  65. self._context.metas.value.set(MOLECULE_SEARCHING, self._host.get_id(), molecule_searching)
  66. def get_movement_mode(self):
  67. return self._movement_mode
  68. def host_moved(self, distance=1):
  69. self._distance_from_objective += 1
  70. def set_distance_from_objective(self, distance):
  71. self._distance_from_objective = distance
  72. def get_distance_from_objective(self):
  73. return self._distance_from_objective
  74. def get_smell_for_object_taken(self, obj):
  75. for take_class in self._taken_smell_matches:
  76. if isinstance(obj, take_class):
  77. return self._taken_smell_matches[take_class]
  78. raise NotFound()