import numpy as np
from typing import Optional

from itertools import product

from .MoleculeTransitionData import MoleculeActionSpace, Min, Max, StepSize
from .MockUpData import VerticalMockUpData

class CircularMockUpData(VerticalMockUpData):
    def __init__(self, **kwargs):
        super().__init__(name="CircMockUp", **kwargs)
        x_space = self.action_space.x_space
        y_space = self.action_space.y_space
        translation_means = np.zeros((len(x_space),len(y_space),2), dtype=float)
        max_distance = np.sqrt(2*self.action_space.a_max**2)
        multiplier = lambda x : 20 * (np.sin(x+4.3)/(x+3))**2
        for x, y in product(range(len(x_space)), range(len(y_space))):
            x_offset = x_space[x]
            y_offset = y_space[y]
            distance = np.linalg.norm(np.array([x_offset, y_offset]))
            vector = np.array([round(multiplier(distance) * -x_offset, 1), round(multiplier(distance) * -y_offset, 1)])
            translation_means[x][y] = vector

        self.translation_means = translation_means
        self.assign_rotation_dists()

    def get_translation_cov(self, x: int, y: int):
        cov = np.array([[0.025,0.0],[0.0,0.025]])
        if np.any(self.translation_means[x][y] != [0.0,0.0]):
            return cov
        else:
            return np.array([[0.0,0.0],[0.0,0.0]])

    def assign_rotation_dists(self):
        #z   =    [0.75, 0.05 , 0.05 , 0.05 , 0.05 , 0.05]
        z   =    [1.00, 0.0 , 0.0, 0.0, 0.0, 0.0]
        cw = ccw = z

        self.rotation_dists = np.array([
         #      -2.1  -1.8  -1.5  -1.2  -0.9  -0.6   -0.3   0.0   0.3   0.6   0.9   1.2   1.5   1.8   2.1
          [    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z], #  2.1 1
          [    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z], #  1.8 2
          [    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z], #  1.5 3
          [    z,    z,    z,    z,   cw,   cw,   cw,   cw,   cw,   cw,    z,    z,    z,    z,    z], #  1.2 4
          [    z,    z,    z,    z,   cw,   cw,   cw,   cw,   cw,    z,    z,    z,    z,    z,    z], #  0.9 5
          [    z,    z,    z,    z,   cw,   cw,   cw,   cw,    z,    z,    z,    z,    z,    z,    z], #  0.6 6
          [    z,    z,    z,   cw,   cw,   cw,   cw,   cw,   cw,   cw,   cw,    z,    z,    z,    z], #  0.3 7
          [    z,    z,    z,  ccw,  ccw,  ccw,  ccw,  ccw,   cw,   cw,   cw,    z,    z,    z,    z], #  0.0 8
          [    z,    z,  ccw,  ccw,    z,  ccw,  ccw,  ccw,   cw,   cw,   cw,   cw,    z,    z,    z], # -0.3 9
          [    z,    z,  ccw,  ccw,  ccw,  ccw,    z,    z,    z,   cw,   cw,   cw,    z,    z,    z], # -0.6 10
          [    z,    z,  ccw,  ccw,  ccw,  ccw,    z,    z,   cw,   cw,   cw,   cw,    z,    z,    z], # -0.9 11
          [    z,    z,    z,  ccw,  ccw,  ccw,  ccw,  ccw,    z,    z,    z,    z,    z,    z,    z], # -1.2 12
          [    z,    z,    z,  ccw,  ccw,    z,  ccw,  ccw,    z,    z,    z,    z,    z,    z,    z], # -1.5 13
          [    z,    z,    z,    z,  ccw,  ccw,  ccw,    z,    z,    z,    z,    z,    z,    z,    z], # -1.8 14
          [    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z,    z]]) # -2.1 15

