testLine3.cpp
Go to the documentation of this file.
2 #include <gtsam/base/Testable.h>
4 #include <gtsam/geometry/Line3.h>
9 
10 using namespace gtsam;
11 
14 
15 static const Line3 l(Rot3(), 1, 1);
16 
17 // Testing getters
18 TEST(Line3, getMethods) {
19  const double a = 5, b = 10;
20  const Rot3 R = Rot3::Expmap(Vector3(0.1, 0.2, 0.3));
21  const Line3 line(R, a, b);
22  EXPECT_DOUBLES_EQUAL(a, line.a(), 1e-8);
23  EXPECT_DOUBLES_EQUAL(b, line.b(), 1e-8);
24  EXPECT(assert_equal(R, line.R(), 1e-8));
25 }
26 
27 // Testing equals function of Line3
29  Line3 l_same = l;
30  EXPECT(l.equals(l_same));
31  Line3 l2(Rot3(), 1, 2);
32  EXPECT(!l.equals(l2));
33 }
34 
35 // testing localCoordinates along 4 dimensions
36 TEST(Line3, localCoordinates) {
37  // l1 and l differ only in a_
38  Line3 l1(Rot3(), 2, 1);
39  Vector4 v1(0, 0, -1, 0);
40  CHECK(assert_equal(l1.localCoordinates(l), v1));
41 
42  // l2 and l differ only in b_
43  Line3 l2(Rot3(), 1, 2);
44  Vector4 v2(0, 0, 0, -1);
45  CHECK(assert_equal(l2.localCoordinates(l), v2));
46 
47  // l3 and l differ in R_x
48  Rot3 r3 = Rot3::Expmap(Vector3(M_PI / 4, 0, 0));
49  Line3 l3(r3, 1, 1);
50  Vector4 v3(-M_PI / 4, 0, 0, 0);
51  CHECK(assert_equal(l3.localCoordinates(l), v3));
52 
53  // l4 and l differ in R_y
54  Rot3 r4 = Rot3::Expmap(Vector3(0, M_PI / 4, 0));
55  Line3 l4(r4, 1, 1);
56  Vector4 v4(0, -M_PI / 4, 0, 0);
57  CHECK(assert_equal(l4.localCoordinates(l), v4));
58 
59  // Jacobians
60  Line3 l5(Rot3::Expmap(Vector3(M_PI / 3, -M_PI / 4, 0)), -0.8, 2);
61  Values val;
62  val.insert(1, l);
63  val.insert(2, l5);
64  Line3_ l_(1);
65  Line3_ l5_(2);
67  Vector4_ local_(l5_, &Line3::localCoordinates, l_);
69  EXPECT_CORRECT_FACTOR_JACOBIANS(f, val, 1e-5, 1e-7);
70 }
71 
72 // testing retract along 4 dimensions
74  // l1 and l differ only in a_
75  Vector4 v1(0, 0, 0, 1);
76  Line3 l1(Rot3(), 1, 2);
77  EXPECT(l1.equals(l.retract(v1)));
78 
79  // l2 and l differ only in b_
80  Vector4 v2(0, 0, 1, 0);
81  Line3 l2(Rot3(), 2, 1);
82  EXPECT(l2.equals(l.retract(v2)));
83 
84  // l3 and l differ in R_x
85  Vector4 v3(M_PI / 4, 0, 0, 0);
86  Rot3 r3;
87  r3 = r3.Expmap(Vector3(M_PI / 4, 0, 0));
88  Line3 l3(r3, 1, 1);
89  EXPECT(l3.equals(l.retract(v3)));
90 
91  // l4 and l differ in R_y
92  Vector4 v4(0, M_PI / 4, 0, 0);
93  Rot3 r4 = Rot3::Expmap(Vector3(0, M_PI / 4, 0));
94  Line3 l4(r4, 1, 1);
95  EXPECT(l4.equals(l.retract(v4)));
96 
97  // Jacobians
98  Vector4 v5(M_PI / 3, -M_PI / 4, -0.4, 1.2); // arbitrary vector
99  Values val;
100  val.insert(1, l);
101  val.insert(2, v5);
102  Line3_ l_(1);
103  Vector4_ v5_(2);
105  Line3_ retract_(l_, &Line3::retract, v5_);
106  ExpressionFactor<Line3> f(model, l.retract(v5), retract_);
107  EXPECT_CORRECT_FACTOR_JACOBIANS(f, val, 1e-5, 1e-7);
108 }
109 
110 // testing manifold property - Retract(p, Local(p,q)) == q
111 TEST(Line3, retractOfLocalCoordinates) {
112  Rot3 r2 = Rot3::Expmap(Vector3(M_PI / 4, M_PI / 3, 0));
113  Line3 l2(r2, 5, 9);
115 }
116 
117 // testing manifold property - Local(p, Retract(p, v)) == v
118 TEST(Line3, localCoordinatesOfRetract) {
119  Vector4 r2(2.3, 0.987, -3, 4);
121 }
122 
123 // transform from world to camera test
124 TEST(Line3, transformToExpressionJacobians) {
125  Rot3 r = Rot3::Expmap(Vector3(0, M_PI / 3, 0));
126  Vector3 t(-2.0, 2.0, 3.0);
127  Pose3 p(r, t);
128 
129  Line3 l_c(r.inverse(), 3, -1);
130  Line3 l_w(Rot3(), 1, 1);
131  EXPECT(l_c.equals(transformTo(p, l_w)));
132 
133  Line3_ l_(1);
134  Pose3_ p_(2);
135  Values val;
136  val.insert(1, l_w);
137  val.insert(2, p);
138 
141  EXPECT_CORRECT_FACTOR_JACOBIANS(f, val, 1e-5, 1e-7);
142 }
143 
144 // projection in camera frame test
146  Rot3 r = Rot3::Expmap(Vector3(0, 0, 0));
147  Line3 wL(r, 1, 1);
148 
149  Unit3 expected = Unit3::FromPoint3(Point3(-1, 1, 0));
150  EXPECT(expected.equals(wL.project()));
151 
152  Values val;
153  val.insert(1, wL);
154  Line3_ wL_(1);
155 
157  Unit3_ projected_(wL_, &Line3::project);
158  ExpressionFactor<Unit3> f(model, expected, projected_);
159  EXPECT_CORRECT_FACTOR_JACOBIANS(f, val, 1e-5, 1e-5);
160 }
161 
162 int main() {
163  TestResult tr;
164  return TestRegistry::runAllTests(tr);
165 }
TestRegistry::runAllTests
static int runAllTests(TestResult &result)
Definition: TestRegistry.cpp:27
l3
Point3 l3(2, 2, 0)
EXPECT_CORRECT_FACTOR_JACOBIANS
#define EXPECT_CORRECT_FACTOR_JACOBIANS(factor, values, numerical_derivative_step, tolerance)
Check the Jacobians produced by a factor against finite differences.
Definition: factorTesting.h:114
gtsam::Line3::R
Rot3 R() const
Definition: Line3.h:123
e
Array< double, 1, 3 > e(1./3., 0.5, 2.)
GTSAM_CONCEPT_TESTABLE_INST
#define GTSAM_CONCEPT_TESTABLE_INST(T)
Definition: Testable.h:176
Testable.h
Concept check for values that can be used in unit tests.
EXPECT
#define EXPECT(condition)
Definition: Test.h:150
l2
gtsam::Key l2
Definition: testLinearContainerFactor.cpp:24
TestHarness.h
r2
static const double r2
Definition: testSmartRangeFactor.cpp:32
gtsam::Line3::a
double a() const
Definition: Line3.h:130
gtsam::Line3::equals
bool equals(const Line3 &l2, double tol=10e-9) const
Definition: Line3.cpp:55
tree::projection
Expression< Point2 > projection(f, p_cam)
gtsam::utils.numerical_derivative.retract
def retract(a, np.ndarray xi)
Definition: numerical_derivative.py:44
gtsam::Line3::b
double b() const
Definition: Line3.h:137
gtsam::Vector3
Eigen::Vector3d Vector3
Definition: Vector.h:44
gtsam::Expression
Definition: Expression.h:47
numericalDerivative.h
Some functions to compute numerical derivatives.
gtsam::transformTo
Line3 transformTo(const Pose3 &wTc, const Line3 &wL, OptionalJacobian< 4, 6 > Dpose, OptionalJacobian< 4, 4 > Dline)
Definition: Line3.cpp:94
gtsam::Rot3
Rot3 is a 3D rotation represented as a rotation matrix if the preprocessor symbol GTSAM_USE_QUATERNIO...
Definition: Rot3.h:58
gtsam::Pose3
Definition: Pose3.h:37
l
static const Line3 l(Rot3(), 1, 1)
cholesky::expected
Matrix expected
Definition: testMatrix.cpp:971
l4
Point3 l4(1, 4,-4)
r3
static const double r3
Definition: testSmartRangeFactor.cpp:32
main
int main()
Definition: testLine3.cpp:162
gtsam::SharedNoiseModel
noiseModel::Base::shared_ptr SharedNoiseModel
Definition: NoiseModel.h:762
gtsam::Line3::localCoordinates
Vector4 localCoordinates(const Line3 &q, OptionalJacobian< 4, 4 > Dp={}, OptionalJacobian< 4, 4 > Dq={}) const
Definition: Line3.cpp:27
gtsam::Line3::project
Unit3 project(OptionalJacobian< 2, 4 > Dline={}) const
Definition: Line3.cpp:61
model
noiseModel::Diagonal::shared_ptr model
Definition: doc/Code/Pose2SLAMExample.cpp:7
EXPECT_DOUBLES_EQUAL
#define EXPECT_DOUBLES_EQUAL(expected, actual, threshold)
Definition: Test.h:161
gtsam::Rot3::inverse
Rot3 inverse() const
inverse of a rotation
Definition: Rot3.h:312
gtsam::equals
Definition: Testable.h:112
TestResult
Definition: TestResult.h:26
expressionTesting.h
Test harness methods for expressions.
tree::f
Point2(* f)(const Point3 &, OptionalJacobian< 2, 3 >)
Definition: testExpression.cpp:218
gtsam::b
const G & b
Definition: Group.h:79
a
ArrayXXi a
Definition: Array_initializer_list_23_cxx11.cpp:1
Line3.h
4 dimensional manifold of 3D lines
gtsam
traits
Definition: SFMdata.h:40
gtsam::TEST
TEST(SmartFactorBase, Pinhole)
Definition: testSmartFactorBase.cpp:38
PriorFactor.h
gtsam::Line3
Definition: Line3.h:44
gtsam::Line3::retract
Line3 retract(const Vector4 &v, OptionalJacobian< 4, 4 > Dp={}, OptionalJacobian< 4, 4 > Dv={}) const
Definition: Line3.cpp:5
gtsam::Values
Definition: Values.h:65
expressions.h
Common expressions for solving geometry/slam/sfm problems.
CHECK
#define CHECK(condition)
Definition: Test.h:108
l1
gtsam::Key l1
Definition: testLinearContainerFactor.cpp:24
gtsam::Rot3::Expmap
static Rot3 Expmap(const Vector3 &v, OptionalJacobian< 3, 3 > H={})
Definition: Rot3.h:378
p
float * p
Definition: Tutorial_Map_using.cpp:9
v2
Vector v2
Definition: testSerializationBase.cpp:39
gtsam::Values::insert
void insert(Key j, const Value &val)
Definition: Values.cpp:156
gtsam::assert_equal
bool assert_equal(const Matrix &expected, const Matrix &actual, double tol)
Definition: Matrix.cpp:41
GTSAM_CONCEPT_MANIFOLD_INST
#define GTSAM_CONCEPT_MANIFOLD_INST(T)
‍**
Definition: Manifold.h:177
ExpressionFactor.h
gtsam::Point3
Vector3 Point3
Definition: Point3.h:38
gtsam::noiseModel::Isotropic::Sigma
static shared_ptr Sigma(size_t dim, double sigma, bool smart=true)
Definition: NoiseModel.cpp:625
gtsam::Unit3
Represents a 3D point on a unit sphere.
Definition: Unit3.h:42
v3
Vector v3
Definition: testSerializationBase.cpp:40
M_PI
#define M_PI
Definition: mconf.h:117
align_3::t
Point2 t(10, 10)
gtsam::Unit3::FromPoint3
static Unit3 FromPoint3(const Point3 &point, OptionalJacobian< 2, 3 > H={})
Named constructor from Point3 with optional Jacobian.
Definition: Unit3.cpp:44
R
Rot2 R(Rot2::fromAngle(0.1))
gtsam::ExpressionFactor
Definition: Expression.h:36
v1
Vector v1
Definition: testSerializationBase.cpp:38


gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:07:39