12 #include <gtsam/geometry/concepts.h> 25 typedef typename POSE::Translation Translation;
26 typedef typename POSE::Rotation Rotation;
31 GTSAM_CONCEPT_POSE_TYPE(Pose)
32 GTSAM_CONCEPT_GROUP_TYPE(Pose)
33 GTSAM_CONCEPT_LIE_TYPE(Rotation)
50 : Base(model, key), measured_(rot_z) {}
54 : Base(model, key), measured_(pose_z.rotation()) {}
59 gtsam::NonlinearFactor::shared_ptr
clone()
const override {
61 gtsam::NonlinearFactor::shared_ptr(
new This(*
this))); }
64 const Rotation& measured()
const {
return measured_; }
70 const This *e =
dynamic_cast<const This*
> (&expected);
71 return e !=
nullptr &&
Base::equals(*e, tol) && measured_.equals(e->measured_, tol);
75 void print(
const std::string& s=
"",
const KeyFormatter& keyFormatter = DefaultKeyFormatter)
const override {
77 measured_.print(
"Measured Rotation");
82 const Rotation& newR = pose.rotation();
84 *H = Matrix::Zero(rDim, xDim);
85 std::pair<size_t, size_t> rotInterval = POSE::rotationInterval();
86 (*H).middleCols(rotInterval.first, rDim).setIdentity(rDim, rDim);
89 return measured_.localCoordinates(newR);
94 #ifdef GTSAM_ENABLE_BOOST_SERIALIZATION 96 friend class boost::serialization::access;
97 template<
class ARCHIVE>
98 void serialize(ARCHIVE & ar,
const unsigned int ) {
100 ar & boost::serialization::make_nvp(
"NoiseModelFactor1",
101 boost::serialization::base_object<Base>(*
this));
102 ar & BOOST_SERIALIZATION_NVP(measured_);
Definition: NonlinearFactor.h:431
void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override
Definition: PoseRotationPrior.h:75
bool equals(const NonlinearFactor &f, double tol=1e-9) const override
gtsam::NonlinearFactor::shared_ptr clone() const override
Definition: PoseRotationPrior.h:59
std::string serialize(const T &input)
serializes to a string
Definition: serialization.h:113
PoseRotationPrior(Key key, const Rotation &rot_z, const SharedNoiseModel &model)
Definition: PoseRotationPrior.h:49
virtual Vector evaluateError(const ValueTypes &... x, OptionalMatrixTypeT< ValueTypes >... H) const=0
Give fixed size dimension of a type, fails at compile time if dynamic.
Definition: Manifold.h:161
Key key() const
Definition: NonlinearFactor.h:582
Definition: NonlinearFactor.h:68
PoseRotationPrior(Key key, const POSE &pose_z, const SharedNoiseModel &model)
Definition: PoseRotationPrior.h:53
bool equals(const NonlinearFactor &expected, double tol=1e-9) const override
Definition: PoseRotationPrior.h:69
PoseRotationPrior()
Definition: PoseRotationPrior.h:46
Matrix * OptionalMatrixType
Definition: NonlinearFactor.h:55
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
Vector evaluateError(const Pose &pose, OptionalMatrixType H) const override
Definition: PoseRotationPrior.h:81
Definition: chartTesting.h:28
void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override
Non-linear factor base classes.
Definition: PoseRotationPrior.h:19
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:102
noiseModel::Base::shared_ptr SharedNoiseModel
Definition: NoiseModel.h:741