import numpy as np

def estimate_rt(view):
    # Angle definitions in radians
    deg = np.pi / 180
    angles = {
        "right_45": -45 * deg,
        "right_90": -90 * deg,
        "right_135": -135 * deg,
        "right_180": -180 * deg,
        "left_45": 45 * deg,
        "left_90": 90 * deg,
        "left_135": 135 * deg,
    }

    # Rotation matrix around Y-axis
    def rot_y(theta):
        return np.array([
            [np.cos(theta), 0, -np.sin(theta)],
            [0,             1, 0            ],
            [np.sin(theta), 0,  np.cos(theta)]
        ])

    # Compute matrices
    # R = {name: rot_y(theta) for name, theta in angles.items()}
    R =  rot_y(angles[view])
    T =  np.array([0,0,0])
    
    return R 

def camera_info(dataset_name,est_rt=False):
    if dataset_name=='waymo':
        if est_rt:
            cam_front   =   {'translation':
                                        [0.0,0.0,0.0],
                            'rotation':[
                                        [1,0,0],[0,1,0],[0,0,1]
                                        ], 
                            'intrinsic':[
                                        [1266.417203046554, 0.0             , 816.2670197447984 ],
                                        [0.0              , 1266.41720046554, 491.50706579294757], 
                                        [0.0              , 0.0             , 1.0               ],
                                        ]
                            }

            cam_front_left={'translation':
                                        [0.0,0.0,0.0],
                            'rotation': estimate_rt('left_45'),
                            'intrinsic':[
                                        [2.08801186e+03,0.00000000e+00, 9.91347793e+02],
                                        [0.00000000e+00, 2.08801186e+03,6.33073151e+02],
                                        [0.00000000e+00,0.00000000e+00,1.00000000e+00],
                                        ]
                            }

            cam_front_right={'translation':
                                        [0.0,0.0,0.0],
                            'rotation': estimate_rt('right_45'),
                            'intrinsic':[
                                        [2.07187719e+03, 0.00000000e+00, 9.30682008e+02],
                                        [0.00000000e+00 ,2.07187719e+03 ,6.58357039e+02],
                                        [0.00000000e+00 ,0.00000000e+00 ,1.00000000e+00],
                                        ]
                            }
            
            cam_right   =   {'translation':
                                        [0.0,0.0,0.0],
                            'rotation': estimate_rt('right_90'),
                            'intrinsic':[
                                        [2.08341268e+03, 0.00000000e+00, 9.84348884e+02],
                                        [0.00000000e+00, 2.08341268e+03, 2.43580460e+02],
                                        [0.00000000e+00, 0.00000000e+00, 1.00000000e+00],
                                        ]
                            }

            cam_left    =   {'translation':
                                        [0.0,0.0,0.0],
                            'rotation': estimate_rt('left_90'),
                            'intrinsic':[
                                        [2.06870225e+03, 0.00000000e+00, 9.71749447e+02],
                                        [0.00000000e+00, 2.06870225e+03, 2.44661654e+02],
                                        [0.00000000e+00, 0.00000000e+00, 1.00000000e+00],
                                        ]
                            } 

        else:
            cam_front   =   {'translation':
                                        [0.0,0.0,0.0],
                            'rotation':[
                                        [1,0,0],[0,1,0],[0,0,1]
                                        ], 
                            'intrinsic':[
                                        [1266.417203046554, 0.0             , 816.2670197447984 ],
                                        [0.0              , 1266.41720046554, 491.50706579294757], 
                                        [0.0              , 0.0             , 1.0               ],
                                        ]
                            }

            cam_front_left={'translation':
                                        [-0.11896732 -0.00040229 -0.04630205],
                            'rotation':[
                                        [7.16970297e-01,-6.94457836e-03,-6.97069126e-01],
                                        [ 4.67290532e-03,9.99975790e-01 ,-5.15598207e-03],
                                        [ 6.97088056e-01,4.39347967e-04,7.16985390e-01],
                                    ],
                            'intrinsic':[
                                        [2.08801186e+03,0.00000000e+00, 9.91347793e+02],
                                        [0.00000000e+00, 2.08801186e+03,6.33073151e+02],
                                        [0.00000000e+00,0.00000000e+00,1.00000000e+00],
                                        ]
                            }

            cam_front_right={'translation':
                                        [ 0.07287421,-0.00038297,-0.05043296],
                            'rotation':[
                                        [ 0.71038679, 0.00572885,  0.70378817],
                                        [-0.01006372 , 0.99994732,  0.00201848],
                                        [-0.70373953 ,-0.00851663, 0.71040702],
                                    ],
                            'intrinsic':[
                                        [2.07187719e+03, 0.00000000e+00, 9.30682008e+02],
                                        [0.00000000e+00 ,2.07187719e+03 ,6.58357039e+02],
                                        [0.00000000e+00 ,0.00000000e+00 ,1.00000000e+00],
                                        ]
                            }
            
            cam_right   =   {'translation':
                                        [ 0.09132805 ,-0.00089907 ,-0.11567328],
                            'rotation':[
                                        [-0.01205774,  0.00393158,  0.99991957],
                                        [-0.00826293,  0.99995774, -0.00403137],
                                        [-0.99989316, -0.00831087, -0.01202474],
                                    ],
                            'intrinsic':[
                                        [2.08341268e+03, 0.00000000e+00, 9.84348884e+02],
                                        [0.00000000e+00, 2.08341268e+03, 2.43580460e+02],
                                        [0.00000000e+00, 0.00000000e+00, 1.00000000e+00],
                                        ]
                            }

            cam_left    =   {'translation':
                                        [-0.14021228, -0.00092238, -0.11068754],
                            'rotation':[
                                        [ 0.00648425, 0.00181362 ,-0.99997733],
                                        [ 0.00880722,  0.99995947,  0.0018707],
                                        [ 0.99994019,-0.00881915 ,0.00646802],
                                    ],
                            'intrinsic':[
                                        [2.06870225e+03, 0.00000000e+00, 9.71749447e+02],
                                        [0.00000000e+00, 2.06870225e+03, 2.44661654e+02],
                                        [0.00000000e+00, 0.00000000e+00, 1.00000000e+00],
                                        ]
                            } 
        cams=[cam_front,cam_front_left,cam_left,cam_front_right,cam_right] 
        return cams
    
    elif dataset_name=='nuscenes':
        if est_rt:
            cam_front={'translation':[0.0,0.0,0.0],'rotation':[[1,0,0],[0,1,0],[0,0,1]], 'intrinsic': [[1266.417203046554, 0.0, 816.2670197447984], [0.0, 1266.41720046554, 491.50706579294757], [0.0, 0.0, 1.0]]}
            cam_front_right={'translation':[0.0,0.0,0.0],'rotation':estimate_rt('right_45'),'intrinsic': [[1260.8474446004698, 0.0, 807.968244525554], [0.0, 1260.8474446004698, 495.3344268742088], [0.0, 0.0, 1.0]]}
            cam_fron_left={'translation':[0.0,0.0,0.0], 'rotation':estimate_rt('left_45'),'intrinsic': [[1272.5979470598488, 0.0, 826.6154927353808], [0.0, 1272.5979470598488, 479.75165386361925], [0.0, 0.0, 1.0]]}
            cam_back={'translation':[0.0,0.0,0.0],'rotation':estimate_rt('right_180'), 'intrinsic': [[809.2209905677063, 0.0, 829.2196003259838], [0.0, 809.2209905677063, 481.77842384512485], [0.0, 0.0, 1.0]]}
            cam_back_right={'translation':[0.0,0.0,0.0],'rotation':estimate_rt('right_135'),'intrinsic': [[1259.5137405846733, 0.0, 807.2529053838625], [0.0, 1259.5137405846733, 501.19579884916527], [0.0, 0.0, 1.0]]}
            cam_back_left={'translation':[0.0,0.0,0.0], 'rotation':estimate_rt('left_135'),'intrinsic': [[1256.7414812095406, 0.0, 792.1125740759628], [0.0, 1256.7414812095406, 492.7757465151356], [0.0, 0.0, 1.0]]}
        else:
            import numpy as np
            theta1=np.pi/180*55
            theta2=np.pi/180*110
            cam_front={'translation':[0.0,0.0,0.0],'rotation':[[1,0,0],[0,1,0],[0,0,1]], 'intrinsic': [[1266.417203046554, 0.0, 816.2670197447984], [0.0, 1266.41720046554, 491.50706579294757], [0.0, 0.0, 1.0]]}
            cam_front_right={'translation':[0.5,0.0,-0.15],'rotation':[[np.cos(theta1),0,np.sin(theta1)],[0,1,0],[-np.sin(theta1),0,np.cos(theta1)]],'intrinsic': [[1260.8474446004698, 0.0, 807.968244525554], [0.0, 1260.8474446004698, 495.3344268742088], [0.0, 0.0, 1.0]]}
            cam_fron_left={'translation':[-0.5,0.0,-0.15], 'rotation':[[np.cos(theta1),0,-np.sin(theta1)],[0,1,0],[np.sin(theta1),0,np.cos(theta1)]],'intrinsic': [[1272.5979470598488, 0.0, 826.6154927353808], [0.0, 1272.5979470598488, 479.75165386361925], [0.0, 0.0, 1.0]]}
            cam_back={'translation':[0.0,0.0,-1.7],'rotation':[[-1,0,0],[0,1,0],[0,0,-1]], 'intrinsic': [[809.2209905677063, 0.0, 829.2196003259838], [0.0, 809.2209905677063, 481.77842384512485], [0.0, 0.0, 1.0]]}
            cam_back_right={'translation':[0.5,0.0,-0.7],'rotation':[[np.cos(theta2),0,np.sin(theta2)],[0,1,0],[-np.sin(theta2),0,np.cos(theta2)]],'intrinsic': [[1259.5137405846733, 0.0, 807.2529053838625], [0.0, 1259.5137405846733, 501.19579884916527], [0.0, 0.0, 1.0]]}
            cam_back_left={'translation':[-0.5,0.0,-0.7], 'rotation':[[np.cos(theta2),0,-np.sin(theta2)],[0,1,0],[np.sin(theta2),0,np.cos(theta2)]],'intrinsic': [[1256.7414812095406, 0.0, 792.1125740759628], [0.0, 1256.7414812095406, 492.7757465151356], [0.0, 0.0, 1.0]]}
        cams=[cam_fron_left,cam_front,cam_front_right,cam_back_right,cam_back,cam_back_left]
        return cams
    elif dataset_name=="argoverse":
        if est_rt:
            ring_front_center = {"translation": 
                                            [0.0, 0.0, 0.0], 
                                "rotation": [[1,0,0],[0,1,0],[0,0,1]], 
                                "intrinsic":[
                                            [1396.4780455444688, 0.0, 973.7884052095219, 0.0], 
                                            [0.0, 1396.4780455444688, 596.6618092086251, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                } 
            ring_front_right =  {"translation": 
                                            [0.0, 0.0, 0.0], 
                                "rotation": estimate_rt('right_45'), 
                                "intrinsic":[
                                            [1389.4820804557041, 0.0, 960.0521984760414, 0.0], 
                                            [0.0, 1389.4820804557041, 611.7776088166885, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }
                                
            ring_side_right =   {"translation": 
                                            [0,0,0], 
                                "rotation": estimate_rt('right_90'), 
                                "intrinsic": [
                                            [1395.3217430168975, 0.0, 974.9235130160218, 0.0], 
                                            [0.0, 1395.3217430168975, 626.7213927750596, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }
                                

            ring_rear_right =   {"translation": 
                                            [0.0,0.0,0.0], 
                                "rotation": estimate_rt('right_135'), 
                                "intrinsic":[
                                            [1392.0734192879336, 0.0, 974.1784784772683, 0.0], 
                                            [0.0, 1392.0734192879336, 614.8398539849807, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                } 
                                
            
            ring_rear_left =    {"translation": 
                                            [0.0,0.0,0.0], 
                                "rotation": estimate_rt('left_135'), 
                                "intrinsic":[
                                            [1396.941782972577, 0.0, 962.1200664567048, 0.0], 
                                            [0.0, 1396.941782972577, 614.294368145857, 0.0],
                                            [0.0, 0.0, 1.0, 0.0]]
                                } 
            
            ring_side_left =    {"translation": 
                                            [0.0,0.0,0.0], 
                                "rotation": estimate_rt('left_90'), 
                                "intrinsic": [
                                            [1392.7534568403978, 0.0, 972.5424383109819, 0.0], 
                                            [0.0, 1392.7534568403978, 614.8945088753147, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }
                                

            ring_front_left =   {"translation": 
                                            [0.0,0.0,0.0], 
                                "rotation": estimate_rt('left_45'), 
                                "intrinsic": [
                                            [1394.0385317869682, 0.0, 947.2067428107222, 0.0], 
                                            [0.0, 1394.0385317869682, 612.9345314490953, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }
            
        else:
            ring_front_center = {"translation": 
                                            [8.538092108323347e-19, 0.0, 2.220446049250313e-16], 
                                "rotation": [
                                            [1.0, -1.5992955460364113e-20, 5.696671025294352e-19], 
                                            [-1.3400666376736554e-20, 0.9999999999999999, 1.6907184030744188e-19], 
                                            [-1.5231409232337952e-18, -8.608699394517891e-19, 1.0]], 
                                "intrinsic":[
                                            [1396.4780455444688, 0.0, 973.7884052095219, 0.0], 
                                            [0.0, 1396.4780455444688, 596.6618092086251, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                } 
            ring_front_right =  {"translation": 
                                            [0.8880829607993003, 0.006563859416049533, -0.4091903391875993], 
                                "rotation": [
                                            [0.7026066231887795, 0.0024464391068602484, 0.7115742743993467], 
                                            [-0.0075503817646324, 0.9999634258983999, 0.004017287734719871], 
                                            [-0.7115384211597212, -0.008195230395275532, 0.702599397531979]], 
                                "intrinsic":[
                                            [1389.4820804557041, 0.0, 960.0521984760414, 0.0], 
                                            [0.0, 1389.4820804557041, 611.7776088166885, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }
                                
            ring_side_right =   {"translation": 
                                            [1.321209822498849, 0.009203447622076366, -1.612554347790831], 
                                "rotation": [
                                            [-0.17406005241030229, 0.00011636738028305851, 0.9847350326933411], 
                                            [-0.0055712288693552416, 0.9999838723470066, -0.0011029300842171897], 
                                            [-0.9847192795735281, -0.005678160311070341, -0.17405659692086856]], 
                                "intrinsic": [
                                            [1395.3217430168975, 0.0, 974.9235130160218, 0.0], 
                                            [0.0, 1395.3217430168975, 626.7213927750596, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }
                                

            ring_rear_right =   {"translation": 
                                            [0.7489654637143409, 0.015281975686485483, -2.491565002355695], 
                                "rotation": [
                                            [-0.8681327650103777, -0.00842300661959426, 0.4962605719528018], 
                                            [-0.006378958774942917, 0.999962756541394, 0.005813296404276611], 
                                            [-0.49629105492682757, 0.0018810873511530862, -0.8681541627556673]], 
                                "intrinsic":[
                                            [1392.0734192879336, 0.0, 974.1784784772683, 0.0], 
                                            [0.0, 1392.0734192879336, 614.8398539849807, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                } 
                                
            
            ring_rear_left =    {"translation": 
                                            [-0.7432681314831028, 0.018639751924971915, -2.497407127824919], 
                                "rotation": [
                                            [-0.8684969732105399, 0.013422774701276442, -0.4955127007892427], 
                                            [0.012832254381448766, 0.9999071064755826, 0.004594743422408061], 
                                            [0.49552834507384197, -0.0023680242707258526, -0.8685885399252242]], 
                                "intrinsic":[
                                            [1396.941782972577, 0.0, 962.1200664567048, 0.0], 
                                            [0.0, 1396.941782972577, 614.294368145857, 0.0],
                                            [0.0, 0.0, 1.0, 0.0]]
                                } 
            
            ring_side_left =    {"translation": 
                                        [-1.3306500365105898, 0.0040698916579231526, -1.616752850653092], 
                                "rotation": [
                                            [-0.17357104616033608, 0.0016008559205448359, -0.9848200491435622], 
                                            [0.010894692141341566, 0.9999406076490733, -0.0002947160457097151], 
                                            [0.9847610865676772, -0.010780465422414037, -0.17357817820026883]], 
                                "intrinsic": [
                                            [1392.7534568403978, 0.0, 972.5424383109819, 0.0], 
                                            [0.0, 1392.7534568403978, 614.8945088753147, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }
                                

            ring_front_left =   {"translation": 
                                            [-0.8902859699891708, 0.008413309699530247, -0.4084496875286332], 
                                "rotation": [
                                            [0.7104694406360069, -0.0026305518146927556, -0.7037231374052648], 
                                            [0.008284100259321699, 0.9999549875768682, 0.004625635419966095], 
                                            [0.7036792931479886, -0.009116085634478948, 0.7104592524398933]], 
                                "intrinsic": [
                                            [1394.0385317869682, 0.0, 947.2067428107222, 0.0], 
                                            [0.0, 1394.0385317869682, 612.9345314490953, 0.0], 
                                            [0.0, 0.0, 1.0, 0.0]]
                                }

        cams =  [
                ring_front_left, ring_front_center,ring_front_right,
                ring_side_right, ring_rear_right,ring_rear_left,ring_side_left,
                ]

        return cams
        
                            
