StereoVOExample.cpp
Go to the documentation of this file.
1 /* ----------------------------------------------------------------------------
2 
3  * GTSAM Copyright 2010, Georgia Tech Research Corporation,
4  * Atlanta, Georgia 30332-0415
5  * All Rights Reserved
6  * Authors: Frank Dellaert, et al. (see THANKS for the full author list)
7 
8  * See LICENSE for the license information
9 
10  * -------------------------------------------------------------------------- */
11 
26 #include <gtsam/geometry/Pose3.h>
28 #include <gtsam/nonlinear/Values.h>
33 
34 using namespace std;
35 using namespace gtsam;
36 
37 int main(int argc, char** argv) {
38  // create graph object, add first pose at origin with key '1'
40  Pose3 first_pose;
42 
43  // create factor noise model with 3 sigmas of value 1
44  const auto model = noiseModel::Isotropic::Sigma(3, 1);
45  // create stereo camera calibration object with .2m between cameras
47  new Cal3_S2Stereo(1000, 1000, 0, 320, 240, 0.2));
48 
49  //create and add stereo factors between first pose (key value 1) and the three landmarks
53 
54  //create and add stereo factors between second pose and the three landmarks
58 
59  // create Values object to contain initial estimates of camera poses and
60  // landmark locations
61  Values initial_estimate;
62 
63  // create and add iniital estimates
64  initial_estimate.insert(1, first_pose);
65  initial_estimate.insert(2, Pose3(Rot3(), Point3(0.1, -0.1, 1.1)));
66  initial_estimate.insert(3, Point3(1, 1, 5));
67  initial_estimate.insert(4, Point3(-1, 1, 5));
68  initial_estimate.insert(5, Point3(0, -0.5, 5));
69 
70  // create Levenberg-Marquardt optimizer for resulting factor graph, optimize
71  LevenbergMarquardtOptimizer optimizer(graph, initial_estimate);
72  Values result = optimizer.optimize();
73 
74  result.print("Final result:\n");
75 
76  return 0;
77 }
gtsam::NonlinearOptimizer::optimize
virtual const Values & optimize()
Definition: NonlinearOptimizer.h:98
LevenbergMarquardtOptimizer.h
A nonlinear optimizer that uses the Levenberg-Marquardt trust-region scheme.
main
int main(int argc, char **argv)
Definition: StereoVOExample.cpp:37
gtsam::GenericStereoFactor
Definition: StereoFactor.h:32
result
Values result
Definition: OdometryOptimize.cpp:8
gtsam::NonlinearEquality
Definition: NonlinearEquality.h:43
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
StereoFactor.h
A non-linear factor for stereo measurements.
gtsam::NonlinearFactorGraph
Definition: NonlinearFactorGraph.h:55
gtsam::LevenbergMarquardtOptimizer
Definition: LevenbergMarquardtOptimizer.h:35
gtsam::Cal3_S2Stereo::shared_ptr
std::shared_ptr< Cal3_S2Stereo > shared_ptr
Definition: Cal3_S2Stereo.h:38
Cal3_S2Stereo.h
The most common 5DOF 3D->2D calibration + Stereo baseline.
NonlinearEquality.h
model
noiseModel::Diagonal::shared_ptr model
Definition: doc/Code/Pose2SLAMExample.cpp:7
gtsam::Values::print
void print(const std::string &str="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const
Definition: Values.cpp:67
gtsam
traits
Definition: SFMdata.h:40
gtsam::Cal3_S2Stereo
The most common 5DOF 3D->2D calibration, stereo version.
Definition: Cal3_S2Stereo.h:30
K
#define K
Definition: igam.h:8
NonlinearFactorGraph.h
Factor Graph consisting of non-linear factors.
gtsam::Values
Definition: Values.h:65
gtsam::StereoPoint2
Definition: StereoPoint2.h:34
std
Definition: BFloat16.h:88
gtsam::Point3
Vector3 Point3
Definition: Point3.h:38
graph
NonlinearFactorGraph graph
Definition: doc/Code/OdometryExample.cpp:2
Values.h
A non-templated config holding any types of Manifold-group elements.
Pose3.h
3D Pose manifold SO(3) x R^3 and group SE(3)
gtsam::FactorGraph::emplace_shared
IsDerived< DERIVEDFACTOR > emplace_shared(Args &&... args)
Emplace a shared pointer to factor of given type.
Definition: FactorGraph.h:153


gtsam
Author(s):
autogenerated on Wed Jan 1 2025 04:04:00