35 Base(model, key), p_(
Rot3::Logmap(P)), z_(
Rot3::Logmap(Z)) {
39 virtual gtsam::NonlinearFactor::shared_ptr
clone()
const {
40 return boost::static_pointer_cast<gtsam::NonlinearFactor>(
41 gtsam::NonlinearFactor::shared_ptr(
new This(*
this))); }
44 virtual void print(
const std::string& s =
"",
45 const KeyFormatter& keyFormatter = DefaultKeyFormatter)
const {
47 std::cout <<
"RotateFactor:]\n";
48 std::cout <<
"p: " << p_.transpose() << std::endl;
49 std::cout <<
"z: " << z_.transpose() << std::endl;
54 boost::optional<Matrix&> H = boost::none)
const {
58 return (Vector(3) << q.
x()-p_.
x(), q.
y()-p_.
y(), q.
z()-p_.
z()).finished();
79 Base(model, key), i_p_(i_p), c_z_(c_z) {
84 gtsam::Quaternion iRc;
91 virtual gtsam::NonlinearFactor::shared_ptr
clone()
const {
92 return boost::static_pointer_cast<gtsam::NonlinearFactor>(
93 gtsam::NonlinearFactor::shared_ptr(
new This(*
this))); }
96 virtual void print(
const std::string& s =
"",
97 const KeyFormatter& keyFormatter = DefaultKeyFormatter)
const {
99 std::cout <<
"RotateDirectionsFactor:" << std::endl;
106 Unit3 i_q = iRc * c_z_;
Vector evaluateError(const Rot3 &iRc, boost::optional< Matrix & > H=boost::none) const
vector of errors returns 2D vector
Definition: RotateFactor.h:105
This is the base class for all factor types.
Definition: Factor.h:54
double x() const
get x
Definition: Point3.h:108
virtual void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const
Print.
Definition: NonlinearFactor.cpp:63
Vector3 unitVector(OptionalJacobian< 3, 2 > H=boost::none) const
Return unit-norm Vector.
Definition: Unit3.cpp:149
std::uint64_t Key
Integer nonlinear key type.
Definition: types.h:57
virtual void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const
print
Definition: RotateFactor.h:44
virtual gtsam::NonlinearFactor::shared_ptr clone() const
Definition: RotateFactor.h:91
void print(const std::string &s=std::string()) const
The print fuction.
Definition: Unit3.cpp:162
Point3 rotate(const Point3 &p, OptionalJacobian< 3, 3 > H1=boost::none, OptionalJacobian< 3, 3 > H2=boost::none) const
rotate point from rotated coordinate frame to world
Definition: Rot3M.cpp:120
Vector2 error(const Unit3 &q, OptionalJacobian< 2, 2 > H_q=boost::none) const
Signed, vector-valued error between two directions.
Definition: Unit3.cpp:197
Factor on unknown rotation iRc that relates two directions c Directions provide less constraints than...
Definition: RotateFactor.h:67
boost::function< std::string(Key)> KeyFormatter
Typedef for a function to format a key, i.e. to convert it to a string.
Definition: Key.h:33
A convenient base class for creating your own NoiseModelFactor with 1 variable.
Definition: NonlinearFactor.h:276
static Rot3 Initialize(const Unit3 &i_p, const Unit3 &c_z)
Initialize rotation iRc such that i_p = iRc * c_z.
Definition: RotateFactor.h:83
RotateFactor(Key key, const Rot3 &P, const Rot3 &Z, const SharedNoiseModel &model)
Constructor.
Definition: RotateFactor.h:33
RotateDirectionsFactor(Key key, const Unit3 &i_p, const Unit3 &c_z, const SharedNoiseModel &model)
Constructor.
Definition: RotateFactor.h:77
virtual gtsam::NonlinearFactor::shared_ptr clone() const
Definition: RotateFactor.h:39
Represents a 3D point on a unit sphere.
Definition: Unit3.h:42
Factor on unknown rotation iRC that relates two incremental rotations c1Rc2 = iRc' * i1Ri2 * iRc Whic...
Definition: RotateFactor.h:23
Non-linear factor base classes.
3D rotation represented as a rotation matrix or quaternion
Vector evaluateError(const Rot3 &R, boost::optional< Matrix & > H=boost::none) const
vector of errors returns 2D vector
Definition: RotateFactor.h:53
Global functions in a separate testing namespace.
Definition: chartTesting.h:28
virtual void print(const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const
print
Definition: RotateFactor.h:96
noiseModel::Base::shared_ptr SharedNoiseModel
Note, deliberately not in noiseModel namespace.
Definition: NoiseModel.h:1072
double y() const
get y
Definition: Point3.h:111
virtual double error(const Values &c) const
Calculate the error of the factor.
Definition: NonlinearFactor.cpp:97
double z() const
get z
Definition: Point3.h:114