-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathtest_code_for_qnv_2.py
88 lines (75 loc) · 2.28 KB
/
test_code_for_qnv_2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import qnv
import unittest
import numpy as np
from ddt import ddt,file_data,unpack,data
@ddt
class Testquatrotate(unittest.TestCase):
@file_data("test-data/test_quatRotate.json")
@unpack
def test_quatrotate(self,value):
v = np.asarray(value[0])
q = np.asarray(value[1])
vr = np.asarray(value[2])
A = qnv.quatRotate(q,v)
self.assertTrue(np.allclose(A,vr))
@ddt
class Testquatder(unittest.TestCase):
@file_data("test-data/test_quatder.json")
@unpack
def test_quatDerBI(self,value):
w = np.asarray(value[1])
q = np.asarray(value[0])
wdot = np.asarray(value[2])
A = qnv.quatDerBI(q,w)
self.assertTrue(np.allclose(A,wdot))
@ddt
class TestquatDerBO(unittest.TestCase):
@file_data("test-data/test_quatDerBO.json")
@unpack
def test_quatDerBO(self,value):
w1 = np.asarray(value[1])
q = np.asarray(value[0])
qdot = np.asarray(value[2])
A = qnv.quatDerBO(q,w1)
self.assertTrue(np.allclose(A,qdot))
@ddt
class Testrotmquat(unittest.TestCase):
@file_data("test-data/test_rotmquat.json")
@unpack
def test_rotm2quat(self,value):
q = np.asarray(value[3])
m1 = np.asarray(value[0])
m2 = np.asarray(value[1])
m3 = np.asarray(value[2])
A = np.vstack([m1, m2, m3])
qo = qnv.rotm2quat(A)
self.assertTrue(np.allclose(qo,q))
@ddt
class TestQuat2Euler(unittest.TestCase):
def test_zero_euler(self):
q = np.array([0.,0.,0., 1.0])
expected = np.array([0.,0.,0.])
result = qnv.quat2euler(q)
self.assertTrue(np.allclose(result,expected))
@file_data('test-data/test_quat2euler.json')
@unpack
def test_quat2euler(self,value):
q = np.asarray(value[0])
expected = np.asarray(value[1])
result = qnv.quat2euler(q)
self.assertTrue(np.allclose(result,expected))
@ddt
class Testquatrotm(unittest.TestCase):
@file_data('test-data/test_quatrotm.json')
@unpack
def test_quat2rotm(self,value):
q = np.asarray(value[0])
m1 = np.asarray(value[1])
m2 = np.asarray(value[2])
m3 = np.asarray(value[3])
A = qnv.quat2rotm(q)
self.assertTrue(np.allclose(A[0,:],m1))
self.assertTrue(np.allclose(A[1,:],m2))
self.assertTrue(np.allclose(A[2,:],m3))
if __name__=='__main__':
unittest.main(verbosity=1)