Select Git revision
-
Carmelo Magnafico authoredCarmelo Magnafico authored
test_cahvor_mixin.py 3.44 KiB
import unittest
from unittest.mock import PropertyMock, patch
import pytest
import pvl
import numpy as np
import ale
from ale.base.type_sensor import Cahvor
def cahvor_camera_dict():
camera_dict = {}
camera_dict['C'] = np.array([6.831825e-01, 5.243722e-01, -1.955875e+00])
camera_dict['A'] = np.array([-3.655151e-01, 5.396012e-01, 7.584387e-01])
camera_dict['H'] = np.array([-1.156881e+04, -7.518712e+03, 6.618359e+02])
camera_dict['V'] = np.array([5.843885e+03, -8.213856e+03, 9.438374e+03])
return camera_dict
class test_cahvor_sensor(unittest.TestCase):
def setUp(self):
self.driver = Cahvor()
self.driver.focal_length = 100
self.driver.ikid = -76220
self.driver.sensor_frame_id = -76562
self.driver.target_frame_id = 10014
self.driver.center_ephemeris_time = 0
self.driver.ephemeris_time = [0]
@patch("ale.base.type_sensor.Cahvor.cahvor_camera_dict", new_callable=PropertyMock, return_value=cahvor_camera_dict())
def test_compute_functions(self, cahvor_camera_dict):
np.testing.assert_almost_equal(self.driver.compute_h_s(), 13796.844341513603)
np.testing.assert_almost_equal(self.driver.compute_h_c(), 673.4306859859296)
np.testing.assert_almost_equal(self.driver.compute_v_s(), 13796.847423351614)
np.testing.assert_almost_equal(self.driver.compute_v_c(), 590.1933422831007)
@patch("ale.base.type_sensor.Cahvor.cahvor_camera_dict", new_callable=PropertyMock, return_value=cahvor_camera_dict())
def test_cahvor_model_elements(self, cahvor_camera_dict):
cahvor_matrix = self.driver.cahvor_rotation_matrix
np.testing.assert_allclose(cahvor_matrix, [[-0.42447558, -0.7572992, -0.49630475],
[ 0.73821222, 0.02793007, -0.67399009],
[ 0.52427398, -0.65247056, 0.54719189]])
@patch('ale.transformation.FrameChain.from_spice', return_value=ale.transformation.FrameChain())
@patch("ale.base.type_sensor.Cahvor.cahvor_camera_dict", new_callable=PropertyMock, return_value=cahvor_camera_dict())
def test_cahvor_frame_chain(self, cahvor_camera_dict, from_spice):
frame_chain = self.driver.frame_chain
assert len(frame_chain.nodes()) == 2
assert -76220 in frame_chain.nodes()
assert -76562 in frame_chain.nodes()
from_spice.assert_called_with(center_ephemeris_time=0, ephemeris_times=[0], sensor_frame=-76220, target_frame=10014, nadir=False, exact_ck_times=False)
np.testing.assert_allclose(frame_chain[-76562][-76220]['rotation'].quat, [0.0100307131, -0.4757136116, 0.6970899144, 0.5363409323])
@patch("ale.base.type_sensor.Cahvor.cahvor_camera_dict", new_callable=PropertyMock, return_value=cahvor_camera_dict())
def test_cahvor_detector_center_line(self, cahvor_camera_dict):
np.testing.assert_almost_equal(self.driver.detector_center_line, 590.1933422831007)
@patch("ale.base.type_sensor.Cahvor.cahvor_camera_dict", new_callable=PropertyMock, return_value=cahvor_camera_dict())
def test_cahvor_detector_center_sample(self, cahvor_camera_dict):
np.testing.assert_almost_equal(self.driver.detector_center_sample, 673.4306859859296)
@patch("ale.base.type_sensor.Cahvor.cahvor_camera_dict", new_callable=PropertyMock, return_value=cahvor_camera_dict())
def test_cahvor_pixel_size(self, cahvor_camera_dict):
assert self.driver.pixel_size == 0.007248034226138798