import numpy as np

from typing import Optional

from itertools import product

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

class DDNBMockUpData(MockUpData):
    def __init__(self, **kwargs):
        assert kwargs["dimensions_x"] == (-2.1, 2.1)
        assert kwargs["dimensions_y"] == (-2.1, 2.1)
        assert kwargs["step_x"] == 0.3
        assert kwargs["step_y"] == 0.3
        super().__init__(name="DDNBMockUp", **kwargs)
        self.assign_translation_means()
        self.assign_translation_covs()
        self.assign_rotation_dists()

    def assign_translation_means(self):
        self.translation_means = 2.0* 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
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  2.1 1
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  1.8 2
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  1.5 3
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[-0.3,-0.3],[-0.7,-0.3],[-0.3,-0.3],[-0.3,-0.3],[-0.3,-0.3],[-0.3,-0.3],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  1.2 4
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[-0.4,-0.2],[-0.8,-0.3],[-0.8,-0.3],[-0.4,-0.4],[-0.1,-0.3],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  0.9 5
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[-0.1,-0.3],[-0.1,-0.3],[-0.3,-0.3],[-0.3,-0.3],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  0.6 6
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.2,-0.1],[-0.2,-0.1],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  0.3 7
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.2,-0.2],[-0.2,-0.2],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], #  0.0 8
                [[ 0.0, 0.0],[-0.1, 0.1],[-0.1, 0.1],[-0.0, 0.0],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.1,-0.1],[-0.2,-0.2],[-0.2,-0.2],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], # -0.3 9
                [[ 0.0, 0.0],[ 0.0, 0.0],[-0.5, 0.5],[-0.4, 0.4],[-0.1, 0.1],[ 0.0, 0.1],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0,-0.3],[ 0.0,-0.3],[ 0.1,-0.2],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], # -0.6 10
                [[ 0.0, 0.0],[ 0.0, 0.0],[-0.8, 0.8],[-0.8, 0.8],[-0.3, 0.3],[ 0.1, 0.3],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.2,-0.1],[ 0.3,-0.2],[ 0.1,-0.1],[ 0.1,-0.2],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], # -0.9 11
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[-0.1, 0.4],[-0.1, 0.3],[ 0.1, 0.4],[ 0.1, 0.2],[ 0.3, 0.1],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], # -1.2 12
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[-0.1, 0.1],[ 0.0, 0.2],[ 0.0, 0.0],[ 0.1, 0.2],[ 0.1, 0.1],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], # -1.5 13
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.2],[ 0.0, 0.3],[ 0.1, 0.1],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]], # -1.8 14
                [[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0],[ 0.0, 0.0]]]).transpose(1,0,2) # -2.1 15

    def assign_translation_covs(self):
        self.translation_covs = np.array([[.0,0.0],[0.0,0.]])

    def get_translation_cov(self, x: int, y: int):
        cov = np.array([[0.075,0.0],[0.0,0.075]])
        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   =    [1.0, 0.0 , 0.0 , 0.0 , 0.0 , 0.0]
        cw  =    [0.9, 0.1, 0.0 , 0.00, 0.0 , 0.0]
        ccw =    [0.9, 0.0 , 0.1, 0.0 , 0.00, 0.0]

        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
