gtsam 4.2
gtsam
Loading...
Searching...
No Matches
RelativeElevationFactor.h
Go to the documentation of this file.
1
9
10#pragma once
11
12#include <gtsam_unstable/dllexport.h>
15
16namespace gtsam {
17
28class GTSAM_UNSTABLE_EXPORT RelativeElevationFactor: public NoiseModelFactorN<Pose3, Point3> {
29private:
30
31 double measured_;
32
33 typedef RelativeElevationFactor This;
35
36public:
37
38 RelativeElevationFactor() : measured_(0.0) {} /* Default constructor */
39
40 RelativeElevationFactor(Key poseKey, Key pointKey, double measured,
41 const SharedNoiseModel& model);
42
43 ~RelativeElevationFactor() override {}
44
46 gtsam::NonlinearFactor::shared_ptr clone() const override {
47 return boost::static_pointer_cast<gtsam::NonlinearFactor>(
48 gtsam::NonlinearFactor::shared_ptr(new This(*this))); }
49
51 Vector evaluateError(const Pose3& pose, const Point3& point,
52 boost::optional<Matrix&> H1 = boost::none, boost::optional<Matrix&> H2 = boost::none) const override;
53
55 inline double measured() const { return measured_; }
56
58 bool equals(const NonlinearFactor& expected, double tol=1e-9) const override;
59
61 void print(const std::string& s="", const KeyFormatter& keyFormatter = DefaultKeyFormatter) const override;
62
63private:
64
66 friend class boost::serialization::access;
67 template<class ARCHIVE>
68 void serialize(ARCHIVE & ar, const unsigned int /*version*/) {
69 // NoiseModelFactor2 instead of NoiseModelFactorN for backward compatibility
70 ar & boost::serialization::make_nvp("NoiseModelFactor2",
71 boost::serialization::base_object<Base>(*this));
72 ar & BOOST_SERIALIZATION_NVP(measured_);
73 }
74}; // RelativeElevationFactor
75
76
77} // \namespace gtsam
78
79
3D Pose
Non-linear factor base classes.
Global functions in a separate testing namespace.
Definition chartTesting.h:28
void print(const Matrix &A, const string &s, ostream &stream)
print without optional string, must specify cout yourself
Definition Matrix.cpp:156
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
Vector3 Point3
As of GTSAM 4, in order to make GTSAM more lean, it is now possible to just typedef Point3 to Vector3...
Definition Point3.h:36
noiseModel::Base::shared_ptr SharedNoiseModel
Aliases.
Definition NoiseModel.h:724
std::uint64_t Key
Integer nonlinear key type.
Definition types.h:100
Template to create a binary predicate.
Definition Testable.h:111
A 3D pose (R,t) : (Rot3,Point3).
Definition Pose3.h:37
Nonlinear factor base class.
Definition NonlinearFactor.h:42
NoiseModelFactorN()
Definition NonlinearFactor.h:469
double measured() const
return the measured
Definition RelativeElevationFactor.h:55
gtsam::NonlinearFactor::shared_ptr clone() const override
Definition RelativeElevationFactor.h:46