From e116123ea58323b893d1a93041ec0dae15e6b892 Mon Sep 17 00:00:00 2001 From: Easton Potokar Date: Mon, 27 May 2024 13:31:43 -0400 Subject: [PATCH 1/2] Add a few functions to python wrapper --- gtsam/geometry/geometry.i | 10 ++++++++++ gtsam/navigation/navigation.i | 2 +- gtsam/nonlinear/nonlinear.i | 3 +++ gtsam/slam/slam.i | 3 ++- 4 files changed, 16 insertions(+), 2 deletions(-) diff --git a/gtsam/geometry/geometry.i b/gtsam/geometry/geometry.i index 01161817b3..3cf78989ca 100644 --- a/gtsam/geometry/geometry.i +++ b/gtsam/geometry/geometry.i @@ -69,6 +69,7 @@ class StereoPoint2 { // Standard Constructors StereoPoint2(); StereoPoint2(double uL, double uR, double v); + StereoPoint2(const gtsam::Vector3 &v); // Testable void print(string s = "") const; @@ -836,6 +837,12 @@ class Cal3_S2Stereo { Cal3_S2Stereo(double fx, double fy, double s, double u0, double v0, double b); Cal3_S2Stereo(Vector v); + // Manifold + static size_t Dim(); + size_t dim() const; + gtsam::Cal3_S2Stereo retract(Vector v) const; + Vector localCoordinates(const gtsam::Cal3_S2Stereo& c) const; + // Testable void print(string s = "") const; bool equals(const gtsam::Cal3_S2Stereo& K, double tol) const; @@ -846,8 +853,11 @@ class Cal3_S2Stereo { double skew() const; double px() const; double py() const; + Matrix K() const; gtsam::Point2 principalPoint() const; double baseline() const; + Vector6 vector() const; + Matrix inverse() const; }; #include diff --git a/gtsam/navigation/navigation.i b/gtsam/navigation/navigation.i index 92864c18a0..aad6f98514 100644 --- a/gtsam/navigation/navigation.i +++ b/gtsam/navigation/navigation.i @@ -200,7 +200,7 @@ class PreintegratedCombinedMeasurements { const gtsam::imuBias::ConstantBias& bias) const; }; -virtual class CombinedImuFactor: gtsam::NonlinearFactor { +virtual class CombinedImuFactor: gtsam::NoiseModelFactor { CombinedImuFactor(size_t pose_i, size_t vel_i, size_t pose_j, size_t vel_j, size_t bias_i, size_t bias_j, const gtsam::PreintegratedCombinedMeasurements& CombinedPreintegratedMeasurements); diff --git a/gtsam/nonlinear/nonlinear.i b/gtsam/nonlinear/nonlinear.i index 3f5fb1dd54..c39cfd22a8 100644 --- a/gtsam/nonlinear/nonlinear.i +++ b/gtsam/nonlinear/nonlinear.i @@ -130,6 +130,7 @@ virtual class NonlinearFactor : gtsam::Factor { virtual class NoiseModelFactor : gtsam::NonlinearFactor { bool equals(const gtsam::NoiseModelFactor& other, double tol) const; gtsam::noiseModel::Base* noiseModel() const; + gtsam::NoiseModelFactor* cloneWithNewNoiseModel(gtsam::noiseModel::Base* newNoise) const; Vector unwhitenedError(const gtsam::Values& x) const; Vector whitenedError(const gtsam::Values& x) const; }; @@ -320,6 +321,8 @@ virtual class GncParams { enum Verbosity { SILENT, SUMMARY, + MU, + WEIGHTS, VALUES }; }; diff --git a/gtsam/slam/slam.i b/gtsam/slam/slam.i index 64977a2a5f..8dc10e51c2 100644 --- a/gtsam/slam/slam.i +++ b/gtsam/slam/slam.i @@ -170,7 +170,8 @@ template virtual class GenericStereoFactor : gtsam::NoiseModelFactor { GenericStereoFactor(const gtsam::StereoPoint2& measured, const gtsam::noiseModel::Base* noiseModel, size_t poseKey, - size_t landmarkKey, const gtsam::Cal3_S2Stereo* K); + size_t landmarkKey, const gtsam::Cal3_S2Stereo* K, + POSE body_P_sensor); gtsam::StereoPoint2 measured() const; gtsam::Cal3_S2Stereo* calibration() const; From d7e2e1cdf6e74cbf4e92b199713e797f084c8a2e Mon Sep 17 00:00:00 2001 From: Easton Potokar Date: Mon, 27 May 2024 15:58:05 -0400 Subject: [PATCH 2/2] Expanded stereofactor python constructor --- gtsam/slam/StereoFactor.h | 5 +++++ gtsam/slam/slam.i | 13 +++++++++++++ 2 files changed, 18 insertions(+) diff --git a/gtsam/slam/StereoFactor.h b/gtsam/slam/StereoFactor.h index a2d428d111..5adafcf3a8 100644 --- a/gtsam/slam/StereoFactor.h +++ b/gtsam/slam/StereoFactor.h @@ -169,6 +169,11 @@ class GenericStereoFactor: public NoiseModelFactorN { /** return flag for throwing cheirality exceptions */ inline bool throwCheirality() const { return throwCheirality_; } + /** return the (optional) sensor pose with respect to the vehicle frame */ + const std::optional& body_P_sensor() const { + return body_P_sensor_; + } + private: #ifdef GTSAM_ENABLE_BOOST_SERIALIZATION /** Serialization function */ diff --git a/gtsam/slam/slam.i b/gtsam/slam/slam.i index 8dc10e51c2..97b198b2f4 100644 --- a/gtsam/slam/slam.i +++ b/gtsam/slam/slam.i @@ -168,9 +168,22 @@ typedef gtsam::SmartProjectionPoseFactor #include template virtual class GenericStereoFactor : gtsam::NoiseModelFactor { + GenericStereoFactor(const gtsam::StereoPoint2& measured, + const gtsam::noiseModel::Base* noiseModel, size_t poseKey, + size_t landmarkKey, const gtsam::Cal3_S2Stereo* K); + GenericStereoFactor(const gtsam::StereoPoint2& measured, + const gtsam::noiseModel::Base* noiseModel, size_t poseKey, + size_t landmarkKey, const gtsam::Cal3_S2Stereo* K, + POSE body_P_sensor); + + GenericStereoFactor(const gtsam::StereoPoint2& measured, + const gtsam::noiseModel::Base* noiseModel, size_t poseKey, + size_t landmarkKey, const gtsam::Cal3_S2Stereo* K, + bool throwCheirality, bool verboseCheirality); GenericStereoFactor(const gtsam::StereoPoint2& measured, const gtsam::noiseModel::Base* noiseModel, size_t poseKey, size_t landmarkKey, const gtsam::Cal3_S2Stereo* K, + bool throwCheirality, bool verboseCheirality, POSE body_P_sensor); gtsam::StereoPoint2 measured() const; gtsam::Cal3_S2Stereo* calibration() const;