11 #include <gtsam/geometry/Unit3.h> 35 return Vector3(p.x(), p.y(), 1);
47 R_(aRb), t_(aTb), E_(t_.skew() * R_.
matrix()) {
60 template<
typename Engine>
73 GTSAM_EXPORT
void print(
const std::string& s =
"")
const;
77 return R_.
equals(other.R_, tol)
78 && t_.
equals(other.t_, tol);
85 enum { dimension = 5 };
86 inline static size_t Dim() {
return dimension;}
87 inline size_t dim()
const {
return dimension;}
163 GTSAM_EXPORT
double error(
const Vector3& vA,
const Vector3& vB,
183 #ifdef GTSAM_ENABLE_BOOST_SERIALIZATION 185 friend class boost::serialization::access;
186 template<
class ARCHIVE>
187 void serialize(ARCHIVE & ar,
const unsigned int ) {
188 ar & BOOST_SERIALIZATION_NVP(R_);
189 ar & BOOST_SERIALIZATION_NVP(t_);
191 ar & boost::serialization::make_nvp(
"E11", E_(0, 0));
192 ar & boost::serialization::make_nvp(
"E12", E_(0, 1));
193 ar & boost::serialization::make_nvp(
"E13", E_(0, 2));
194 ar & boost::serialization::make_nvp(
"E21", E_(1, 0));
195 ar & boost::serialization::make_nvp(
"E22", E_(1, 1));
196 ar & boost::serialization::make_nvp(
"E23", E_(1, 2));
197 ar & boost::serialization::make_nvp(
"E31", E_(2, 0));
198 ar & boost::serialization::make_nvp(
"E32", E_(2, 1));
199 ar & boost::serialization::make_nvp(
"E33", E_(2, 2));
EssentialMatrix(const Rot3 &aRb, const Unit3 &aTb)
Construct from rotation and translation.
Definition: EssentialMatrix.h:46
GTSAM_EXPORT Point3 transformTo(const Point3 &p, OptionalJacobian< 3, 5 > DE={}, OptionalJacobian< 3, 3 > Dpoint={}) const
takes point in world coordinates and transforms it to pose with |t|==1
Both ManifoldTraits and Testable.
Definition: Manifold.h:117
bool equals(const EssentialMatrix &other, double tol=1e-8) const
assert equality up to a tolerance
Definition: EssentialMatrix.h:76
GTSAM_EXPORT EssentialMatrix rotate(const Rot3 &cRb, OptionalJacobian< 5, 5 > HE={}, OptionalJacobian< 5, 3 > HR={}) const
static EssentialMatrix Random(Engine &rng)
Random, using Rot3::Random and Unit3::Random.
Definition: EssentialMatrix.h:61
std::string serialize(const T &input)
serializes to a string
Definition: serialization.h:113
const Unit3 & direction() const
Direction.
Definition: EssentialMatrix.h:115
bool equals(const Rot3 &p, double tol=1e-9) const
Vector2 Point2
Definition: Point2.h:32
bool equals(const Unit3 &s, double tol=1e-9) const
The equals function with tolerance.
Definition: Unit3.h:114
const Unit3 & epipole_a() const
Return epipole in image_a , as Unit3 to allow for infinity.
Definition: EssentialMatrix.h:125
static GTSAM_EXPORT EssentialMatrix FromRotationAndDirection(const Rot3 &aRb, const Unit3 &aTb, OptionalJacobian< 5, 3 > H1={}, OptionalJacobian< 5, 2 > H2={})
Named constructor with derivatives.
Unit3 epipole_b() const
Return epipole in image_b, as Unit3 to allow for infinity.
Definition: EssentialMatrix.h:130
Vector2 localCoordinates(const Unit3 &s) const
The local coordinates function.
Rot3 is a 3D rotation represented as a rotation matrix if the preprocessor symbol GTSAM_USE_QUATERNIO...
Definition: Rot3.h:58
static Vector3 Homogeneous(const Point2 &p)
Static function to convert Point2 to homogeneous coordinates.
Definition: EssentialMatrix.h:34
static Rot3 Random(std::mt19937 &rng)
TangentVector localCoordinates(const Class &g) const
localCoordinates as required by manifold concept: finds tangent vector between *this and g ...
Definition: Lie.h:136
EssentialMatrix retract(const Vector5 &xi) const
Retract delta to manifold.
Definition: EssentialMatrix.h:92
Represents a 3D point on a unit sphere.
Definition: Unit3.h:42
GTSAM_EXPORT void print(const std::string &s="") const
print with optional string
static Unit3 Random(std::mt19937 &rng)
GTSAM_EXPORT friend std::istream & operator>>(std::istream &is, EssentialMatrix &E)
stream from stream
Point3 unrotate(const Point3 &p, OptionalJacobian< 3, 3 > H1={}, OptionalJacobian< 3, 3 > H2={}) const
rotate point from world to rotated frame
Base class and basic functions for Manifold types.
Vector5 localCoordinates(const EssentialMatrix &other) const
Compute the coordinates in the tangent space.
Definition: EssentialMatrix.h:97
const Rot3 & rotation() const
Rotation.
Definition: EssentialMatrix.h:110
GTSAM_EXPORT friend std::ostream & operator<<(std::ostream &os, const EssentialMatrix &E)
stream to stream
Definition: chartTesting.h:28
Definition: EssentialMatrix.h:26
Definition: OptionalJacobian.h:38
Class retract(const TangentVector &v) const
retract as required by manifold concept: applies v at *this
Definition: Lie.h:131
const Matrix3 & matrix() const
Return 3*3 matrix representation.
Definition: EssentialMatrix.h:120
friend EssentialMatrix operator*(const Rot3 &cRb, const EssentialMatrix &E)
Definition: EssentialMatrix.h:158
Unit3 retract(const Vector2 &v, OptionalJacobian< 2, 2 > H={}) const
The retract function.
static GTSAM_EXPORT EssentialMatrix FromPose3(const Pose3 &_1P2_, OptionalJacobian< 5, 6 > H={})
Named constructor converting a Pose3 with scale to EssentialMatrix (no scale)
#define GTSAM_MAKE_ALIGNED_OPERATOR_NEW
Definition: types.h:284
Vector3 Point3
Definition: Point3.h:38
GTSAM_EXPORT double error(const Vector3 &vA, const Vector3 &vB, OptionalJacobian< 1, 5 > H={}) const
epipolar error, algebraic
EssentialMatrix()
Default constructor.
Definition: EssentialMatrix.h:42