import numpy as np

from typing import Optional

from shapely import Point

from loguru import logger

from molecule_movement.envs.MoleculeEnvironment import MoleculeEnvironment
from molecule_movement import Molecule, Goal, Matching, VerticalAction
from molecule_movement.parsing import PickleDataParser, LateralMoleculeDataProcessor
from molecule_movement.shapes import FePc

class TestingMeasurementsEnv(MoleculeEnvironment):
    def __init__(
            self,
            **kwargs
            ):
        super().__init__(**kwargs)

    def _parse_molecule_data(self):
        self.data_processor = LateralMoleculeDataProcessor(PickleDataParser(self.orientation_map),
                                                           dimensions_x=(-2.1, 2.1),
                                                           dimensions_y=(-2.1, 2.1),
                                                           step_x=0.3,
                                                           step_y=0.3,
                                                           dimensions_dest_x=(-2.1, 2.1),
                                                           dimensions_dest_y=(-2.1, 2.1),
                                                           step_dest_x=0.3,
                                                           step_dest_y=0.3,
                                                           dimensions_z=(0.55,0.6),
                                                           dimensions_V=(-500, 500),
                                                           step_z=0.05,
                                                           step_V=250)
        self.molecule_transition_data = self.data_processor.get_molecular_data()

    def _create_initial_distribution(self, seed: Optional[int] = None):
        self.initial_pos = Point(15,15)
        self.molecules = [Molecule(self.initial_pos, FePc, 0, self.molecule_transition_data, self.num_sensors, name=self._sample_random_name())]

    def _set_goals(self, seed: Optional[int] = None) -> None:
        self.goals = [Goal(Point(10,10), Point(0,0).buffer(1.5), 0), Goal(Point(15,15), Point(0,0).buffer(1.5), 0)]

    def _set_obstacles(self, seed: Optional[int] = None) -> None:
        self.obstacles = list()

    def _get_matching(self, options: Optional[dict] = None, seed: Optional[int] = None):
        m = self.molecules[0]
        self.matching = [Matching(m, self.goals[0]), Matching(m, self.goals[1])]
