MoleculeFlavour.py 2.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. from intelligine.core.exceptions import NoTypeInMolecule, NoCategoryInMolecule
  2. from intelligine.simulation.molecule.Molecule import Molecule
  3. class MoleculeFlavour():
  4. @classmethod
  5. def new_from_raw_data(cls, raw_data):
  6. flavour = {}
  7. for category in raw_data:
  8. molecules_by_category = raw_data[category]
  9. for type in molecules_by_category:
  10. distance, intensity = molecules_by_category[type]
  11. if category not in flavour:
  12. flavour[category] = {}
  13. flavour[category][type] = Molecule(category, type, distance, intensity)
  14. return cls(flavour)
  15. def get_raw_data(self):
  16. raw_data = {}
  17. for category in self._flavour:
  18. molecules_by_category = self._flavour[category]
  19. for type in molecules_by_category:
  20. molecule = molecules_by_category[type]
  21. if category not in raw_data:
  22. raw_data[category] = {}
  23. raw_data[category][type] = (molecule.get_distance(), molecule.get_intensity())
  24. return raw_data
  25. def __init__(self, flavour):
  26. self._flavour = flavour
  27. def get_molecule(self, category, type):
  28. types = self.get_types(category)
  29. if type not in types:
  30. raise NoTypeInMolecule()
  31. return types[type]
  32. def get_molecules(self, category):
  33. """
  34. :param category:
  35. :return: Molecules dict or empty dict of no molecules
  36. """
  37. try:
  38. return self.get_types(category)
  39. except NoCategoryInMolecule:
  40. return {}
  41. def get_types(self, category):
  42. if category not in self._flavour:
  43. raise NoCategoryInMolecule()
  44. return self._flavour[category]
  45. def set_molecule(self, molecule):
  46. category = molecule.get_category()
  47. type = molecule.get_type()
  48. if category not in self._flavour:
  49. self._flavour[category] = {}
  50. self._flavour[category][type] = molecule