Go to the documentation of this file.
21 using namespace gtsam;
43 double theta =
atan2(ray.y(), ray.x());
44 double phi =
atan2(ray.z(),
sqrt(ray.x()*ray.x()+ray.y()*ray.y()));
45 double rho = 1./ray.norm();
90 Point3 world_landmarkBefore(0,0,0);
93 double theta = landmarkBefore(0), phi = landmarkBefore(1), rho = landmarkBefore(2);
94 world_landmarkBefore = referencePoint +
Point3(
cos(theta)*
cos(phi)/rho,
sin(theta)*
cos(phi)/rho,
sin(phi)/rho);
96 Point3 world_landmarkAfter(0,0,0);
99 double theta = landmarkAfter(0), phi = landmarkAfter(1), rho = landmarkAfter(2);
100 world_landmarkAfter = referencePoint +
Point3(
cos(theta)*
cos(phi)/rho,
sin(theta)*
cos(phi)/rho,
sin(phi)/rho);
static int runAllTests(TestResult &result)
std::shared_ptr< This > shared_ptr
PinholeCamera< Cal3_S2 > camera1(pose1, *sharedCal)
virtual const Values & optimize()
Array< double, 1, 3 > e(1./3., 0.5, 2.)
Jet< T, N > sin(const Jet< T, N > &f)
#define EXPECT(condition)
int optimize(const SfmData &db, const NonlinearFactorGraph &graph, const Values &initial, bool separateCalibration=false)
The most common 5DOF 3D->2D calibration.
A nonlinear optimizer that uses the Levenberg-Marquardt trust-region scheme.
TEST(InvDepthFactorVariant2, optimize)
static const SmartProjectionParams params
Point2 project(const Point3 &pw, OptionalJacobian< 2, 6 > Dpose={}, OptionalJacobian< 2, 3 > Dpoint={}, OptionalJacobian< 2, DimK > Dcal={}) const
project a 3D point from world coordinates into the image
Jet< T, N > cos(const Jet< T, N > &f)
static const double sigma
const ValueType at(Key j) const
Inverse Depth Factor based on Civera09tro, Montiel06rss. Landmarks are parameterized as (theta,...
const Point3 & translation(OptionalJacobian< 3, 6 > Hself={}) const
get translation
static Point3 landmark(0, 0, 5)
Base class for all pinhole cameras.
void insert(Key j, const Vector &value)
noiseModel::Base::shared_ptr SharedNoiseModel
std::shared_ptr< Cal3_S2 > shared_ptr
AnnoyingScalar atan2(const AnnoyingScalar &y, const AnnoyingScalar &x)
static Key poseKey2(X(2))
static const Pose3 pose1(Rot3(), Point3(0, 1, 0.5))
Factor Graph consisting of non-linear factors.
IsDerived< DERIVEDFACTOR > push_back(std::shared_ptr< DERIVEDFACTOR > factor)
Add a factor directly using a shared_ptr.
bool assert_equal(const Matrix &expected, const Matrix &actual, double tol)
The most common 5DOF 3D->2D calibration.
Class retract(const TangentVector &v) const
retract as required by manifold concept: applies v at *this
static Key poseKey1(X(1))
NonlinearFactorGraph graph
std::uint64_t Key
Integer nonlinear key type.
static const Camera2 camera2(pose1, K2)
Eigen::Matrix< double, Eigen::Dynamic, 1 > Vector
Jet< T, N > sqrt(const Jet< T, N > &f)
3D Pose manifold SO(3) x R^3 and group SE(3)
gtsam
Author(s):
autogenerated on Wed Jan 1 2025 04:06:33