23 using namespace std::placeholders;
25 using namespace gtsam;
47 const double angle = 2.5;
49 SO3 R = SO3::AxisAngle(axis, angle);
56 M << 0.79067393, 0.6051136, -0.0930814,
57 0.4155925, -0.64214347, -0.64324489,
58 -0.44948549, 0.47046326, -0.75917576;
61 expected << 0.790687, 0.605096, -0.0931312,
62 0.415746, -0.642355, -0.643844,
63 -0.449411, 0.47036, -0.759468;
65 auto actual = SO3::ClosestTo(3 *
M);
94 auto X1 = SOn::Hat(z_axis),
X2 = SOn::Hat(
v2),
X3 = SOn::Hat(
v3);
130 EXPECT(check_group_invariants(
id,
id));
131 EXPECT(check_group_invariants(
id,
R1));
132 EXPECT(check_group_invariants(
R2,
id));
135 EXPECT(check_manifold_invariants(
id,
id));
136 EXPECT(check_manifold_invariants(
id,
R1));
137 EXPECT(check_manifold_invariants(
R2,
id));
160 double angle = 3.14 / 4.0;
162 expected << 0.707388, 0, 0.706825, 0, 1, 0, -0.706825, 0, 0.707388;
165 so3::ExpmapFunctor
f1(axis, angle);
166 SO3 actual1 =
f1.expmap();
170 so3::ExpmapFunctor
f2(axis, angle - 2*
M_PI);
171 SO3 actual2 =
f2.expmap();
175 so3::ExpmapFunctor
f3(axis * angle);
176 SO3 actual3 =
f3.expmap();
180 so3::ExpmapFunctor
f4(axis * (angle - 2*
M_PI));
181 SO3 actual4 =
f4.expmap();
187 static const Vector3 w(0.1, 0.27, -0.2);
200 const Matrix actualDexpL = SO3::ExpmapDerivative(
w);
201 const Matrix expectedDexpL =
202 numericalDerivative11<Vector3, Vector3>(
testDexpL, Vector3::Zero(), 1
e-2);
205 const Matrix actualDexpInvL = SO3::LogmapDerivative(
w);
211 const Vector3 theta(0.1, 0, 0.1);
212 const Matrix Jexpected = numericalDerivative11<SO3, Vector3>(
213 std::bind(&
SO3::Expmap, std::placeholders::_1,
nullptr), theta);
217 SO3::ExpmapDerivative(-theta)));
222 const Vector3 theta(10, 20, 30);
223 const Matrix Jexpected = numericalDerivative11<SO3, Vector3>(
224 std::bind(&
SO3::Expmap, std::placeholders::_1,
nullptr), theta);
228 SO3::ExpmapDerivative(-theta)));
247 auto w_dot = [](
double t) {
return Vector3(2,
cos(
t), 8 *
t); };
252 for (
double t = -2.0;
t < 2.0;
t += 0.3) {
254 const Matrix actual = SO3::ExpmapDerivative(
w(
t)) * w_dot(
t);
262 auto w_dot = [](
double t) {
return Vector3(2,
cos(
t), 8 *
t); };
268 for (
double t = -2.0;
t < 2.0;
t += 0.3) {
270 const Matrix actual = SO3::ExpmapDerivative(
w(
t)) * w_dot(
t);
277 const Vector3 thetahat(0.1, 0, 0.1);
278 const Matrix Jexpected = numericalDerivative11<SO3, Vector3>(
279 std::bind(&
SO3::Expmap, std::placeholders::_1,
nullptr), thetahat);
287 const Vector3 thetahat(0.1, 0, 0.1);
289 const Matrix Jexpected = numericalDerivative11<Vector, SO3>(
290 std::bind(&SO3::Logmap, std::placeholders::_1,
nullptr),
R);
291 const Matrix3 Jactual = SO3::LogmapDerivative(thetahat);
297 const Vector3 thetahat(0.1, 0, 0.1);
299 const Matrix Jexpected = numericalDerivative11<Vector, SO3>(
300 std::bind(&SO3::Logmap, std::placeholders::_1,
nullptr),
R);
302 SO3::Logmap(
R, Jactual);
308 std::vector<Vector3>
small{{0, 0, 0},
309 {1
e-5, 0, 0}, {0, 1
e-5, 0}, {0, 0, 1
e-5},
310 {1
e-4, 0, 0}, {0, 1
e-4, 0}, {0, 0, 1
e-4}};
311 std::vector<Vector3>
large{
312 {0, 0, 0}, {1, 0, 0}, {0, 1, 0}, {0, 0, 1}, {0.1, 0.2, 0.3}};
314 std::vector<Vector3>
vs{{1, 0, 0}, {0, 1, 0}, {0, 0, 1}, {0.4, 0.3, 0.2}};
320 for (
bool nearZero : {
true,
false}) {
322 so3::DexpFunctor local(
omega, nearZero);
323 EXPECT(assert_equal<Matrix3>(local.rightJacobian().inverse(),
324 local.rightJacobianInverse()));
325 EXPECT(assert_equal<Matrix3>(local.leftJacobian().inverse(),
326 local.leftJacobianInverse()));
334 for (
bool nearZero : {
true,
false}) {
337 return so3::DexpFunctor(
omega, nearZero).crossB(
v);
340 so3::DexpFunctor local(
omega, nearZero);
342 local.crossB(
v, aH1);
352 for (
bool nearZero : {
true,
false}) {
355 return so3::DexpFunctor(
omega, nearZero).doubleCrossC(
v);
358 so3::DexpFunctor local(
omega, nearZero);
360 local.doubleCrossC(
v, aH1);
370 for (
bool nearZero : {
true,
false}) {
373 return so3::DexpFunctor(
omega, nearZero).applyDexp(
v);
376 so3::DexpFunctor local(
omega, nearZero);
379 local.applyDexp(
v, aH1, aH2)));
391 for (
bool nearZero : {
true,
false}) {
394 return so3::DexpFunctor(
omega, nearZero).applyInvDexp(
v);
397 so3::DexpFunctor local(
omega, nearZero);
398 Matrix invJr = local.rightJacobianInverse();
413 for (
bool nearZero : {
true,
false}) {
416 return so3::DexpFunctor(
omega, nearZero).applyLeftJacobian(
v);
419 so3::DexpFunctor local(
omega, nearZero);
422 local.applyLeftJacobian(
v, aH1, aH2)));
434 for (
bool nearZero : {
true,
false}) {
437 return so3::DexpFunctor(
omega, nearZero).applyLeftJacobianInverse(
v);
440 so3::DexpFunctor local(
omega, nearZero);
441 Matrix invJl = local.leftJacobianInverse();
444 local.applyLeftJacobianInverse(
v, aH1, aH2)));
457 const Vector9 actual =
R2.
vec(actualH);
459 std::function<Vector9(
const SO3&)>
f = [](
const SO3&
Q) {
return Q.vec(); };
467 M << 1, 2, 3, 4, 5, 6, 7, 8, 9;
473 std::function<Matrix3(
const Matrix3&)>
f = [
R](
const Matrix3&
M) {