3 inline dgemat1
inv(
const dgemat1& A)
22 inline double det(
const dgemat2& A)
24 return A(0,0)*A(1,1)-A(0,1)*A(1,0);
29 inline dgemat2
inv(
const dgemat2& A)
31 const double Adet(
det(A) );
33 Ainv(0,0)= A(1,1)/Adet; Ainv(0,1)=-A(0,1)/Adet;
34 Ainv(1,0)=-A(1,0)/Adet; Ainv(1,1)= A(0,0)/Adet;
40 inline dgemat2
rotate(
const dgemat2& m,
const double& theta)
43 double c(std::cos(theta)), s(std::sin(theta));
44 double cc(c*c), cs(c*s), ss(s*s);
46 mat(0,0) =m(0,0)*cc -(m(0,1)+m(1,0))*cs +m(1,1)*ss;
47 mat(0,1) =m(0,1)*cc +(m(0,0)-m(1,1))*cs -m(1,0)*ss;
48 mat(1,0) =m(1,0)*cc +(m(0,0)-m(1,1))*cs -m(0,1)*ss;
49 mat(1,1) =m(1,1)*cc +(m(0,1)+m(1,0))*cs +m(0,0)*ss;
55 inline dgemat2
t2m(
const double& theta)
58 R(0,0)=std::cos(theta); R(0,1)=-std::sin(theta);
59 R(1,0)=std::sin(theta); R(1,1)= std::cos(theta);
75 inline double det(
const dgemat3& A)
78 +A(0,0)*A(1,1)*A(2,2) -A(0,0)*A(1,2)*A(2,1)
79 +A(0,1)*A(1,2)*A(2,0) -A(0,1)*A(1,0)*A(2,2)
80 +A(0,2)*A(1,0)*A(2,1) -A(0,2)*A(1,1)*A(2,0);
85 inline double II(
const dgemat3& A)
88 +A(0,0)*A(1,1) +A(1,1)*A(2,2) +A(2,2)*A(0,0)
89 -A(0,1)*A(1,0) -A(1,2)*A(2,1) -A(2,0)*A(0,2);
94 inline dgemat3
inv(
const dgemat3& A)
96 const double Adet(
det(A) );
98 Ainv(0,0) =(A(1,1)*A(2,2)-A(1,2)*A(2,1))/Adet;
99 Ainv(0,1) =(A(0,2)*A(2,1)-A(0,1)*A(2,2))/Adet;
100 Ainv(0,2) =(A(0,1)*A(1,2)-A(0,2)*A(1,1))/Adet;
101 Ainv(1,0) =(A(1,2)*A(2,0)-A(1,0)*A(2,2))/Adet;
102 Ainv(1,1) =(A(0,0)*A(2,2)-A(0,2)*A(2,0))/Adet;
103 Ainv(1,2) =(A(0,2)*A(1,0)-A(0,0)*A(1,2))/Adet;
104 Ainv(2,0) =(A(1,0)*A(2,1)-A(1,1)*A(2,0))/Adet;
105 Ainv(2,1) =(A(0,1)*A(2,0)-A(0,0)*A(2,1))/Adet;
106 Ainv(2,2) =(A(0,0)*A(1,1)-A(0,1)*A(1,0))/Adet;
112 inline dgemat3
rotate(
const dgemat3& m,
const dquater& q)
113 {CPPL_VERBOSE_REPORT;
120 inline dquater
m2q(
const dgemat3& m)
121 {CPPL_VERBOSE_REPORT;
122 dcovec3 v( m(2,1)-m(1,2), m(0,2)-m(2,0), m(1,0)-m(0,1) );
123 double t( std::acos(0.5*(m(0,0)+m(1,1)+m(2,2)-1.)) );
139 inline double det(
const dgemat4& A)
140 {CPPL_VERBOSE_REPORT;
142 ((A(0,0)*A(1,1)-A(0,1)*A(1,0))*A(2,2)+(A(0,2)*A(1,0)-A(0,0)*A(1,2))*A(2,1)+(A(0,1)*A(1,2)-A(0,2)*A(1,1))*A(2,0))*A(3,3)
143 +((A(0,1)*A(1,0)-A(0,0)*A(1,1))*A(2,3)+(A(0,0)*A(1,3)-A(0,3)*A(1,0))*A(2,1)+(A(0,3)*A(1,1)-A(0,1)*A(1,3))*A(2,0))*A(3,2)
144 +((A(0,0)*A(1,2)-A(0,2)*A(1,0))*A(2,3)+(A(0,3)*A(1,0)-A(0,0)*A(1,3))*A(2,2)+(A(0,2)*A(1,3)-A(0,3)*A(1,2))*A(2,0))*A(3,1)
145 +((A(0,2)*A(1,1)-A(0,1)*A(1,2))*A(2,3)+(A(0,1)*A(1,3)-A(0,3)*A(1,1))*A(2,2)+(A(0,3)*A(1,2)-A(0,2)*A(1,3))*A(2,1))*A(3,0);
150 inline dgemat4
inv(
const dgemat4& A)
151 {CPPL_VERBOSE_REPORT;
152 const double Adet =
det(A);
155 Ainv(0,0) =(A(1,1)*A(2,2)-A(1,2)*A(2,1))*A(3,3)+(A(1,3)*A(2,1)-A(1,1)*A(2,3))*A(3,2)+(A(1,2)*A(2,3)-A(1,3)*A(2,2))*A(3,1);
156 Ainv(0,1) =(A(0,2)*A(2,1)-A(0,1)*A(2,2))*A(3,3)+(A(0,1)*A(2,3)-A(0,3)*A(2,1))*A(3,2)+(A(0,3)*A(2,2)-A(0,2)*A(2,3))*A(3,1);
157 Ainv(0,2) =(A(0,1)*A(1,2)-A(0,2)*A(1,1))*A(3,3)+(A(0,3)*A(1,1)-A(0,1)*A(1,3))*A(3,2)+(A(0,2)*A(1,3)-A(0,3)*A(1,2))*A(3,1);
158 Ainv(0,3) =(A(0,2)*A(1,1)-A(0,1)*A(1,2))*A(2,3)+(A(0,1)*A(1,3)-A(0,3)*A(1,1))*A(2,2)+(A(0,3)*A(1,2)-A(0,2)*A(1,3))*A(2,1);
159 Ainv(1,0) =(A(1,2)*A(2,0)-A(1,0)*A(2,2))*A(3,3)+(A(1,0)*A(2,3)-A(1,3)*A(2,0))*A(3,2)+(A(1,3)*A(2,2)-A(1,2)*A(2,3))*A(3,0);
160 Ainv(1,1) =(A(0,0)*A(2,2)-A(0,2)*A(2,0))*A(3,3)+(A(0,3)*A(2,0)-A(0,0)*A(2,3))*A(3,2)+(A(0,2)*A(2,3)-A(0,3)*A(2,2))*A(3,0);
161 Ainv(1,2) =(A(0,2)*A(1,0)-A(0,0)*A(1,2))*A(3,3)+(A(0,0)*A(1,3)-A(0,3)*A(1,0))*A(3,2)+(A(0,3)*A(1,2)-A(0,2)*A(1,3))*A(3,0);
162 Ainv(1,3) =(A(0,0)*A(1,2)-A(0,2)*A(1,0))*A(2,3)+(A(0,3)*A(1,0)-A(0,0)*A(1,3))*A(2,2)+(A(0,2)*A(1,3)-A(0,3)*A(1,2))*A(2,0);
163 Ainv(2,0) =(A(1,0)*A(2,1)-A(1,1)*A(2,0))*A(3,3)+(A(1,3)*A(2,0)-A(1,0)*A(2,3))*A(3,1)+(A(1,1)*A(2,3)-A(1,3)*A(2,1))*A(3,0);
164 Ainv(2,1) =(A(0,1)*A(2,0)-A(0,0)*A(2,1))*A(3,3)+(A(0,0)*A(2,3)-A(0,3)*A(2,0))*A(3,1)+(A(0,3)*A(2,1)-A(0,1)*A(2,3))*A(3,0);
165 Ainv(2,2) =(A(0,0)*A(1,1)-A(0,1)*A(1,0))*A(3,3)+(A(0,3)*A(1,0)-A(0,0)*A(1,3))*A(3,1)+(A(0,1)*A(1,3)-A(0,3)*A(1,1))*A(3,0);
166 Ainv(2,3) =(A(0,1)*A(1,0)-A(0,0)*A(1,1))*A(2,3)+(A(0,0)*A(1,3)-A(0,3)*A(1,0))*A(2,1)+(A(0,3)*A(1,1)-A(0,1)*A(1,3))*A(2,0);
167 Ainv(3,0) =(A(1,1)*A(2,0)-A(1,0)*A(2,1))*A(3,2)+(A(1,0)*A(2,2)-A(1,2)*A(2,0))*A(3,1)+(A(1,2)*A(2,1)-A(1,1)*A(2,2))*A(3,0);
168 Ainv(3,1) =(A(0,0)*A(2,1)-A(0,1)*A(2,0))*A(3,2)+(A(0,2)*A(2,0)-A(0,0)*A(2,2))*A(3,1)+(A(0,1)*A(2,2)-A(0,2)*A(2,1))*A(3,0);
169 Ainv(3,2) =(A(0,1)*A(1,0)-A(0,0)*A(1,1))*A(3,2)+(A(0,0)*A(1,2)-A(0,2)*A(1,0))*A(3,1)+(A(0,2)*A(1,1)-A(0,1)*A(1,2))*A(3,0);
170 Ainv(3,3) =(A(0,0)*A(1,1)-A(0,1)*A(1,0))*A(2,2)+(A(0,2)*A(1,0)-A(0,0)*A(1,2))*A(2,1)+(A(0,1)*A(1,2)-A(0,2)*A(1,1))*A(2,0);
dgemat2 t2m(const double &theta)
double det(const dgemat2 &A)
dquater m2q(const dgemat3 &m)
dquater vt2q(const dcovec3 &v, const double &theta)
dgemat3 q2m(const dquater &q)
double II(const dgemat3 &A)
drovector t(const _dcovector &covec)
dgemat2 rotate(const dgemat2 &m, const double &theta)
dgemat1 inv(const dgemat1 &A)