ProjectionFactor.h
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 
21 #pragma once
22 
25 #include <gtsam/geometry/Pose3.h>
26 #include <gtsam/geometry/Point3.h>
27 #include <gtsam/geometry/Cal3_S2.h>
28 #include <optional>
29 
30 namespace gtsam {
31 
38  template <class POSE = Pose3, class LANDMARK = Point3,
39  class CALIBRATION = Cal3_S2>
40  class GenericProjectionFactor: public NoiseModelFactorN<POSE, LANDMARK> {
41  protected:
42 
43  // Keep a copy of measurement and calibration for I/O
45  std::shared_ptr<CALIBRATION> K_;
46  std::optional<POSE> body_P_sensor_;
47 
48  // verbosity handling for Cheirality Exceptions
51 
52  public:
53 
56 
57  // Provide access to the Matrix& version of evaluateError:
58  using Base::evaluateError;
59 
62 
64  typedef std::shared_ptr<This> shared_ptr;
65 
68  measured_(0, 0), throwCheirality_(false), verboseCheirality_(false) {
69  }
70 
82  Key poseKey, Key pointKey, const std::shared_ptr<CALIBRATION>& K,
83  std::optional<POSE> body_P_sensor = {}) :
85  throwCheirality_(false), verboseCheirality_(false) {}
86 
100  Key poseKey, Key pointKey, const std::shared_ptr<CALIBRATION>& K,
102  std::optional<POSE> body_P_sensor = {}) :
105 
108 
111  return std::static_pointer_cast<gtsam::NonlinearFactor>(
113 
119  void print(const std::string& s = "", const KeyFormatter& keyFormatter = DefaultKeyFormatter) const override {
120  std::cout << s << "GenericProjectionFactor, z = ";
122  if(this->body_P_sensor_)
123  this->body_P_sensor_->print(" sensor pose in body frame: ");
124  Base::print("", keyFormatter);
125  }
126 
128  bool equals(const NonlinearFactor& p, double tol = 1e-9) const override {
129  const This *e = dynamic_cast<const This*>(&p);
130  return e
131  && Base::equals(p, tol)
132  && traits<Point2>::Equals(this->measured_, e->measured_, tol)
133  && this->K_->equals(*e->K_, tol)
134  && ((!body_P_sensor_ && !e->body_P_sensor_) || (body_P_sensor_ && e->body_P_sensor_ && body_P_sensor_->equals(*e->body_P_sensor_)));
135  }
136 
139  OptionalMatrixType H1, OptionalMatrixType H2) const override {
140  try {
141  if(body_P_sensor_) {
142  if(H1) {
143  gtsam::Matrix H0;
145  Point2 reprojectionError(camera.project(point, H1, H2, {}) - measured_);
146  *H1 = *H1 * H0;
147  return reprojectionError;
148  } else {
150  return camera.project(point, H1, H2, {}) - measured_;
151  }
152  } else {
154  return camera.project(point, H1, H2, {}) - measured_;
155  }
156  } catch( CheiralityException& e) {
157  if (H1) *H1 = Matrix::Zero(2,6);
158  if (H2) *H2 = Matrix::Zero(2,3);
159  if (verboseCheirality_)
160  std::cout << e.what() << ": Landmark "<< DefaultKeyFormatter(this->key2()) <<
161  " moved behind camera " << DefaultKeyFormatter(this->key1()) << std::endl;
162  if (throwCheirality_)
163  throw CheiralityException(this->key2());
164  }
165  return Vector2::Constant(2.0 * K_->fx());
166  }
167 
169  const Point2& measured() const {
170  return measured_;
171  }
172 
174  const std::shared_ptr<CALIBRATION> calibration() const {
175  return K_;
176  }
177 
179  const std::optional<POSE>& body_P_sensor() const {
180  return body_P_sensor_;
181  }
182 
184  inline bool verboseCheirality() const { return verboseCheirality_; }
185 
187  inline bool throwCheirality() const { return throwCheirality_; }
188 
189  private:
190 
191 #if GTSAM_ENABLE_BOOST_SERIALIZATION
192  friend class boost::serialization::access;
194  template<class ARCHIVE>
195  void serialize(ARCHIVE & ar, const unsigned int /*version*/) {
196  ar & BOOST_SERIALIZATION_BASE_OBJECT_NVP(Base);
197  ar & BOOST_SERIALIZATION_NVP(measured_);
198  ar & BOOST_SERIALIZATION_NVP(K_);
199  ar & BOOST_SERIALIZATION_NVP(body_P_sensor_);
200  ar & BOOST_SERIALIZATION_NVP(throwCheirality_);
201  ar & BOOST_SERIALIZATION_NVP(verboseCheirality_);
202  }
203 #endif
204 
205  public:
207 };
208 
210  template<class POSE, class LANDMARK, class CALIBRATION>
211  struct traits<GenericProjectionFactor<POSE, LANDMARK, CALIBRATION> > :
212  public Testable<GenericProjectionFactor<POSE, LANDMARK, CALIBRATION> > {
213  };
214 
215 } // \ namespace gtsam
gtsam::NonlinearFactor::shared_ptr
std::shared_ptr< This > shared_ptr
Definition: NonlinearFactor.h:79
gtsam::GenericProjectionFactor::clone
gtsam::NonlinearFactor::shared_ptr clone() const override
Definition: ProjectionFactor.h:110
gtsam::GenericProjectionFactor::calibration
const std::shared_ptr< CALIBRATION > calibration() const
Definition: ProjectionFactor.h:174
pose
static const Pose3 pose(Rot3(Vector3(1, -1, -1).asDiagonal()), Point3(0, 0, 0.5))
pointKey
const gtsam::Key pointKey
Definition: testRelativeElevationFactor.cpp:25
s
RealScalar s
Definition: level1_cplx_impl.h:126
e
Array< double, 1, 3 > e(1./3., 0.5, 2.)
Cal3_S2.h
The most common 5DOF 3D->2D calibration.
gtsam::NoiseModelFactorN< POSE, LANDMARK >::evaluateError
virtual Vector evaluateError(const ValueTypes &... x, OptionalMatrixTypeT< ValueTypes >... H) const=0
gtsam::GenericProjectionFactor::throwCheirality
bool throwCheirality() const
Definition: ProjectionFactor.h:187
gtsam::GenericProjectionFactor::GenericProjectionFactor
GenericProjectionFactor(const Point2 &measured, const SharedNoiseModel &model, Key poseKey, Key pointKey, const std::shared_ptr< CALIBRATION > &K, std::optional< POSE > body_P_sensor={})
Definition: ProjectionFactor.h:81
gtsam::Matrix
Eigen::MatrixXd Matrix
Definition: base/Matrix.h:39
gtsam::Factor
Definition: Factor.h:70
Point3.h
3D Point
gtsam::GenericProjectionFactor::GenericProjectionFactor
GenericProjectionFactor()
Default constructor.
Definition: ProjectionFactor.h:67
gtsam::Vector
Eigen::VectorXd Vector
Definition: Vector.h:39
gtsam::GenericProjectionFactor::shared_ptr
std::shared_ptr< This > shared_ptr
shorthand for a smart pointer to a factor
Definition: ProjectionFactor.h:64
gtsam::GenericProjectionFactor::GenericProjectionFactor
GenericProjectionFactor(const Point2 &measured, const SharedNoiseModel &model, Key poseKey, Key pointKey, const std::shared_ptr< CALIBRATION > &K, bool throwCheirality, bool verboseCheirality, std::optional< POSE > body_P_sensor={})
Definition: ProjectionFactor.h:99
poseKey
const gtsam::Key poseKey
Definition: testPoseRotationPrior.cpp:29
gtsam::GenericProjectionFactor::verboseCheirality_
bool verboseCheirality_
If true, prints text for Cheirality exceptions (default: false)
Definition: ProjectionFactor.h:50
gtsam::DefaultKeyFormatter
KeyFormatter DefaultKeyFormatter
Assign default key formatter.
Definition: Key.cpp:30
gtsam::CheiralityException
Definition: CalibratedCamera.h:34
gtsam::GenericProjectionFactor::evaluateError
Vector evaluateError(const Pose3 &pose, const Point3 &point, OptionalMatrixType H1, OptionalMatrixType H2) const override
Evaluate error h(x)-z and optionally derivatives.
Definition: ProjectionFactor.h:138
gtsam_unstable.tests.test_ProjectionFactorRollingShutter.point
point
Definition: test_ProjectionFactorRollingShutter.py:25
gtsam::GenericProjectionFactor::print
void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override
Definition: ProjectionFactor.h:119
gtsam::KeyFormatter
std::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
Definition: Key.h:35
gtsam::Pose3
Definition: Pose3.h:37
gtsam::PinholeCamera
Definition: PinholeCamera.h:33
gtsam::NoiseModelFactorN
Definition: NonlinearFactor.h:432
gtsam::NoiseModelFactor::print
void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override
Definition: NonlinearFactor.cpp:74
gtsam::GenericProjectionFactor
Definition: ProjectionFactor.h:40
PinholeCamera.h
Base class for all pinhole cameras.
gtsam::NoiseModelFactor::equals
bool equals(const NonlinearFactor &f, double tol=1e-9) const override
Definition: NonlinearFactor.cpp:82
gtsam::Point2
Vector2 Point2
Definition: Point2.h:32
gtsam::GenericProjectionFactor::~GenericProjectionFactor
~GenericProjectionFactor() override
Definition: ProjectionFactor.h:107
gtsam::SharedNoiseModel
noiseModel::Base::shared_ptr SharedNoiseModel
Definition: NoiseModel.h:762
gtsam::GenericProjectionFactor::Base
NoiseModelFactorN< POSE, LANDMARK > Base
shorthand for base class type
Definition: ProjectionFactor.h:55
gtsam::NoiseModelFactorN< Pose3, Point3 >::key1
Key key1() const
Definition: NonlinearFactor.h:732
gtsam::GenericProjectionFactor::body_P_sensor_
std::optional< POSE > body_P_sensor_
The pose of the sensor in the body frame.
Definition: ProjectionFactor.h:46
model
noiseModel::Diagonal::shared_ptr model
Definition: doc/Code/Pose2SLAMExample.cpp:7
gtsam::GenericProjectionFactor::throwCheirality_
bool throwCheirality_
If true, rethrows Cheirality exceptions (default: false)
Definition: ProjectionFactor.h:49
gtsam::GenericProjectionFactor::This
GenericProjectionFactor< POSE, LANDMARK, CALIBRATION > This
shorthand for this class
Definition: ProjectionFactor.h:61
NonlinearFactor.h
Non-linear factor base classes.
gtsam::NoiseModelFactorN< Pose3, Point3 >::key2
Key key2() const
Definition: NonlinearFactor.h:736
gtsam
traits
Definition: SFMdata.h:40
gtsam::Testable
Definition: Testable.h:152
gtsam::GenericProjectionFactor::measured_
Point2 measured_
2D measurement
Definition: ProjectionFactor.h:44
gtsam::traits
Definition: Group.h:36
K
#define K
Definition: igam.h:8
gtsam::NonlinearFactor
Definition: NonlinearFactor.h:69
p
float * p
Definition: Tutorial_Map_using.cpp:9
gtsam::Print
void Print(const CONTAINER &keys, const string &s, const KeyFormatter &keyFormatter)
Definition: Key.cpp:65
gtsam::GenericProjectionFactor::measured
const Point2 & measured() const
Definition: ProjectionFactor.h:169
gtsam::tol
const G double tol
Definition: Group.h:79
gtsam::Point3
Vector3 Point3
Definition: Point3.h:38
gtsam::GenericProjectionFactor::K_
std::shared_ptr< CALIBRATION > K_
shared pointer to calibration object
Definition: ProjectionFactor.h:45
gtsam::OptionalMatrixType
Matrix * OptionalMatrixType
Definition: NonlinearFactor.h:56
gtsam::GenericProjectionFactor::verboseCheirality
bool verboseCheirality() const
Definition: ProjectionFactor.h:184
camera
static const CalibratedCamera camera(kDefaultPose)
gtsam::GenericProjectionFactor::body_P_sensor
const std::optional< POSE > & body_P_sensor() const
Definition: ProjectionFactor.h:179
Base
Definition: test_virtual_functions.cpp:156
gtsam::Key
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:97
Pose3
Definition: testDependencies.h:3
GTSAM_MAKE_ALIGNED_OPERATOR_NEW
#define GTSAM_MAKE_ALIGNED_OPERATOR_NEW
Definition: types.h:279
Pose3.h
3D Pose manifold SO(3) x R^3 and group SE(3)
gtsam::GenericProjectionFactor::equals
bool equals(const NonlinearFactor &p, double tol=1e-9) const override
equals
Definition: ProjectionFactor.h:128


gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:03:48