template<class POSE>
class gtsam::IMUFactor< POSE >
Class that represents integrating IMU measurements over time for dynamic systems Templated to allow for different key types, but variables all assumed to be PoseRTV.
|
| | IMUFactor (const Vector3 &accel, const Vector3 &gyro, double dt, const Key &key1, const Key &key2, const SharedNoiseModel &model) |
| | time between measurements
|
|
| IMUFactor (const Vector6 &imu_vector, double dt, const Key &key1, const Key &key2, const SharedNoiseModel &model) |
| | Full IMU vector specification.
|
| gtsam::NonlinearFactor::shared_ptr | clone () const override |
| bool | equals (const NonlinearFactor &e, double tol=1e-9) const override |
| | Check if two factors are equal.
|
| void | print (const std::string &s="", const gtsam::KeyFormatter &formatter=gtsam::DefaultKeyFormatter) const override |
| | print
|
|
const Vector3 & | gyro () const |
|
const Vector3 & | accel () const |
|
Vector6 | z () const |
|
Vector | evaluateError (const PoseRTV &x1, const PoseRTV &x2, boost::optional< Matrix & > H1=boost::none, boost::optional< Matrix & > H2=boost::none) const override |
| | Error evaluation with optional derivatives - calculates z - h(x1,x2).
|
|
virtual Vector | evaluateError (const Pose3 &x1, const Pose3 &x2, boost::optional< Matrix & > H1=boost::none, boost::optional< Matrix & > H2=boost::none) const |
| | dummy version that fails for non-dynamic poses
|
| Key | key () const |
| | Returns a key.
|
|
| NoiseModelFactorN () |
| | Default Constructor for I/O.
|
| | NoiseModelFactorN (const SharedNoiseModel &noiseModel, KeyType< ValueTypes >... keys) |
| | Constructor.
|
| | NoiseModelFactorN (const SharedNoiseModel &noiseModel, CONTAINER keys) |
| | Constructor.
|
| Vector | unwhitenedError (const Values &x, boost::optional< std::vector< Matrix > & > H=boost::none) const override |
| | This implements the unwhitenedError virtual function by calling the n-key specific version of evaluateError, which is pure virtual so must be implemented in the derived class.
|
| virtual Vector | evaluateError (const ValueTypes &... x, OptionalMatrix< ValueTypes >... H) const=0 |
| | Override evaluateError to finish implementing an n-way factor.
|
| Vector | evaluateError (const ValueTypes &... x) const |
| | No-Jacobians requested function overload.
|
| Vector | evaluateError (const ValueTypes &... x, OptionalJacArgs &&... H) const |
| | Some (but not all) optional Jacobians are omitted (function overload).
|
|
Key | key1 () const |
|
Key | key2 () const |
|
Key | key3 () const |
|
Key | key4 () const |
|
Key | key5 () const |
|
Key | key6 () const |
|
| NoiseModelFactor () |
| | Default constructor for I/O only.
|
|
| ~NoiseModelFactor () override |
| | Destructor.
|
|
template<typename CONTAINER> |
| | NoiseModelFactor (const SharedNoiseModel &noiseModel, const CONTAINER &keys) |
| | Constructor.
|
| void | print (const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override |
| | Print.
|
| bool | equals (const NonlinearFactor &f, double tol=1e-9) const override |
| | Check if two factors are equal.
|
| size_t | dim () const override |
| | get the dimension of the factor (number of rows on linearization)
|
|
const SharedNoiseModel & | noiseModel () const |
| | access to the noise model
|
| Vector | whitenedError (const Values &c) const |
| | Vector of errors, whitened This is the raw error, i.e., i.e.
|
|
Vector | unweightedWhitenedError (const Values &c) const |
| | Vector of errors, whitened, but unweighted by any loss function.
|
|
double | weight (const Values &c) const |
| | Compute the effective weight of the factor from the noise model.
|
| double | error (const Values &c) const override |
| | Calculate the error of the factor.
|
| boost::shared_ptr< GaussianFactor > | linearize (const Values &x) const override |
| | Linearize a non-linearFactorN to get a GaussianFactor, \( Ax-b \approx h(x+\delta x)-z = h(x) + A \delta x - z \) Hence \( b = z - h(x) = - \mathtt{error\_vector}(x) \).
|
|
shared_ptr | cloneWithNewNoiseModel (const SharedNoiseModel newNoise) const |
| | Creates a shared_ptr clone of the factor with a new noise model.
|
|
| NonlinearFactor () |
| | Default constructor for I/O only.
|
|
template<typename CONTAINER> |
| | NonlinearFactor (const CONTAINER &keys) |
| | Constructor from a collection of the keys involved in this factor.
|
| void | print (const std::string &s="", const KeyFormatter &keyFormatter=DefaultKeyFormatter) const override |
| | print
|
|
virtual | ~NonlinearFactor () |
| | Destructor.
|
| double | error (const HybridValues &c) const override |
| | All factor types need to implement an error function.
|
| virtual bool | active (const Values &) const |
| | Checks whether a factor should be used based on a set of values.
|
| virtual shared_ptr | rekey (const std::map< Key, Key > &rekey_mapping) const |
| | Creates a shared_ptr clone of the factor with different keys using a map from old->new keys.
|
| virtual shared_ptr | rekey (const KeyVector &new_keys) const |
| | Clones a factor and fully replaces its keys.
|
| virtual bool | sendable () const |
| | Should the factor be evaluated in the same thread as the caller This is to enable factors that has shared states (like the Python GIL lock).
|
|
virtual | ~Factor ()=default |
| | Default destructor.
|
|
bool | empty () const |
| | Whether the factor is empty (involves zero variables).
|
|
Key | front () const |
| | First key.
|
|
Key | back () const |
| | Last key.
|
|
const_iterator | find (Key key) const |
| | find
|
|
const KeyVector & | keys () const |
| | Access the factor's involved variable keys.
|
|
const_iterator | begin () const |
| | Iterator at beginning of involved variable keys.
|
|
const_iterator | end () const |
| | Iterator at end of involved variable keys.
|
| size_t | size () const |
| virtual void | printKeys (const std::string &s="Factor", const KeyFormatter &formatter=DefaultKeyFormatter) const |
| | print only keys
|
|
bool | equals (const This &other, double tol=1e-9) const |
| | check equality
|
| KeyVector & | keys () |
|
iterator | begin () |
| | Iterator at beginning of involved variable keys.
|
|
iterator | end () |
| | Iterator at end of involved variable keys.
|