17#include <Eigen/src/Core/Matrix.h>
27 [[nodiscard]]
static std::string
type()
34 [[nodiscard]] std::string
getType()
const override {
return type(); }
50 desc.emplace_back(
"Velocity norm [m/s]");
51 desc.emplace_back(
"X velocity ECEF [m/s]");
52 desc.emplace_back(
"Y velocity ECEF [m/s]");
53 desc.emplace_back(
"Z velocity ECEF [m/s]");
54 desc.emplace_back(
"North velocity [m/s]");
55 desc.emplace_back(
"East velocity [m/s]");
56 desc.emplace_back(
"Down velocity [m/s]");
57 desc.emplace_back(
"X velocity ECEF StDev [m/s]");
58 desc.emplace_back(
"Y velocity ECEF StDev [m/s]");
59 desc.emplace_back(
"Z velocity ECEF StDev [m/s]");
60 desc.emplace_back(
"XY velocity StDev [m]");
61 desc.emplace_back(
"XZ velocity StDev [m]");
62 desc.emplace_back(
"YZ velocity StDev [m]");
63 desc.emplace_back(
"North velocity StDev [m/s]");
64 desc.emplace_back(
"East velocity StDev [m/s]");
65 desc.emplace_back(
"Down velocity StDev [m/s]");
66 desc.emplace_back(
"NE velocity StDev [m]");
67 desc.emplace_back(
"ND velocity StDev [m]");
68 desc.emplace_back(
"ED velocity StDev [m]");
84 [[nodiscard]] std::optional<double>
getValueAt(
size_t idx)
const override
150 [[nodiscard]]
bool setValueAt(
size_t idx,
double value)
override
257 template<
typename Derived>
266 template<
typename Derived>
276 template<
typename Derived,
typename Derived2>
287 template<
typename Derived,
typename Derived2>
298 template<
typename Derived>
312 (*_n_covarianceMatrix)(all, all).setZero();
320 template<
typename Derived>
334 (*_e_covarianceMatrix)(all, all).setZero();
345 Eigen::Vector3d
_e_velocity{ std::nan(
""), std::nan(
""), std::nan(
"") };
347 Eigen::Vector3d
_n_velocity{ std::nan(
""), std::nan(
""), std::nan(
"") };
#define INS_ASSERT(_EXPR)
Assert function wrapper.
Definition Assert.h:19
#define INS_ASSERT_USER_ERROR(_EXP, _MSG)
Assert function with message.
Definition Assert.h:21
Dynamic sized KeyedMatrix.
Definition KeyedMatrix.hpp:2055
Position, Velocity and Attitude Storage Class.
Definition PosVel.hpp:23
static constexpr size_t GetStaticDescriptorCount()
Get the amount of descriptors.
Definition PosVel.hpp:73
static std::vector< std::string > parentTypes()
Returns the parent types of the data class.
Definition PosVel.hpp:38
const Eigen::Vector3d & n_velocity() const
Returns the velocity in [m/s], in navigation coordinates.
Definition PosVel.hpp:237
bool setValueAt(size_t idx, double value) override
Set the value at the index.
Definition PosVel.hpp:150
std::optional< std::reference_wrapper< const Eigen::Vector3d > > e_velocityStdev() const
Returns the standard deviation of the velocity in [m/s], in earth coordinates.
Definition PosVel.hpp:240
std::string getType() const override
Returns the type of the data class.
Definition PosVel.hpp:34
static std::vector< std::string > GetStaticDataDescriptors()
Returns a vector of data descriptors.
Definition PosVel.hpp:46
std::vector< std::string > staticDataDescriptors() const override
Returns a vector of data descriptors.
Definition PosVel.hpp:76
static std::string type()
Returns the type of the data class.
Definition PosVel.hpp:27
std::optional< std::reference_wrapper< const Eigen::Vector3d > > n_velocityStdev() const
Returns the standard deviation of the velocity in [m/s], in navigation coordinates.
Definition PosVel.hpp:243
size_t staticDescriptorCount() const override
Get the amount of descriptors.
Definition PosVel.hpp:79
void setPosVelCovarianceMatrix_e(const Eigen::MatrixBase< Derived > &e_covarianceMatrix)
Set the Covariance matrix in ECEF coordinates.
Definition PosVel.hpp:299
std::optional< KeyedMatrixXd< States::StateKeys, States::StateKeys > > _n_covarianceMatrix
Covariance matrix in local navigation coordinates.
Definition PosVel.hpp:358
std::optional< Eigen::Vector3d > _n_velocityStdev
Standard deviation of Velocity in navigation coordinates [m/s].
Definition PosVel.hpp:352
std::optional< KeyedMatrixXd< States::StateKeys, States::StateKeys > > _e_covarianceMatrix
Covariance matrix in ECEF coordinates.
Definition PosVel.hpp:355
std::optional< std::reference_wrapper< const KeyedMatrixXd< States::StateKeys, States::StateKeys > > > e_CovarianceMatrix() const
Returns the Covariance matrix in ECEF frame.
Definition PosVel.hpp:246
Eigen::Vector3d _e_velocity
Velocity in earth coordinates [m/s].
Definition PosVel.hpp:345
void setVelocityAndStdDev_n(const Eigen::MatrixBase< Derived > &n_velocity, const Eigen::MatrixBase< Derived2 > &n_velocityCovarianceMatrix)
Set the Velocity in NED coordinates and its standard deviation.
Definition PosVel.hpp:288
Eigen::Vector3d _n_velocity
Velocity in navigation coordinates [m/s].
Definition PosVel.hpp:347
const Eigen::Vector3d & e_velocity() const
Returns the velocity in [m/s], in earth coordinates.
Definition PosVel.hpp:234
std::optional< std::reference_wrapper< const KeyedMatrixXd< States::StateKeys, States::StateKeys > > > n_CovarianceMatrix() const
Returns the Covariance matrix in local navigation frame.
Definition PosVel.hpp:249
std::optional< double > getValueAt(size_t idx) const override
Get the value at the index.
Definition PosVel.hpp:84
void setVelocityAndStdDev_e(const Eigen::MatrixBase< Derived > &e_velocity, const Eigen::MatrixBase< Derived2 > &e_velocityCovarianceMatrix)
Set the Velocity in ECEF coordinates and its standard deviation.
Definition PosVel.hpp:277
std::optional< Eigen::Vector3d > _e_velocityStdev
Standard deviation of Velocity in earth coordinates [m/s].
Definition PosVel.hpp:350
void setVelocity_n(const Eigen::MatrixBase< Derived > &n_velocity)
Set the Velocity in the NED frame.
Definition PosVel.hpp:267
void setVelocity_e(const Eigen::MatrixBase< Derived > &e_velocity)
Set the Velocity in the earth frame.
Definition PosVel.hpp:258
void setPosVelCovarianceMatrix_n(const Eigen::MatrixBase< Derived > &n_covarianceMatrix)
Set the Covariance matrix in NED coordinates.
Definition PosVel.hpp:321
Position, Velocity and Attitude Storage Class.
Definition Pos.hpp:30
std::optional< double > getValueAt(size_t idx) const override
Get the value at the index.
Definition Pos.hpp:89
static std::vector< std::string > GetStaticDataDescriptors()
Returns a vector of data descriptors.
Definition Pos.hpp:51
static constexpr size_t GetStaticDescriptorCount()
Get the amount of descriptors.
Definition Pos.hpp:78
bool setValueAt(size_t idx, double value) override
Set the value at the index.
Definition Pos.hpp:156
const double & latitude() const
Returns the latitude 𝜙 in [rad].
Definition Pos.hpp:256
static std::vector< std::string > parentTypes()
Returns the parent types of the data class.
Definition Pos.hpp:45
Eigen::Quaterniond e_Quat_n() const
Returns the Quaternion from navigation to Earth-fixed frame.
Definition Pos.hpp:218
static std::string type()
Returns the type of the data class.
Definition Pos.hpp:34
Eigen::Quaterniond n_Quat_e() const
Returns the Quaternion from Earth-fixed frame to navigation.
Definition Pos.hpp:225
const double & longitude() const
Returns the longitude λ in [rad].
Definition Pos.hpp:259
States.
Definition PosVel.hpp:209
StateKeys
State Keys.
Definition PosVel.hpp:215
@ States_COUNT
Count.
Definition PosVel.hpp:222
@ PosY
Position ECEF_Y [m].
Definition PosVel.hpp:217
@ PosZ
Position ECEF_Z [m].
Definition PosVel.hpp:218
@ PosX
Position ECEF_X [m].
Definition PosVel.hpp:216
@ VelY
Velocity ECEF_Y [m/s].
Definition PosVel.hpp:220
@ VelZ
Velocity ECEF_Z [m/s].
Definition PosVel.hpp:221
@ VelX
Velocity ECEF_X [m/s].
Definition PosVel.hpp:219
States()=delete
Constructor.
static const std::vector< StateKeys > PosVel
Vector with all position and velocity state keys.
Definition PosVel.hpp:229
static const std::vector< StateKeys > Vel
All velocity keys.
Definition PosVel.hpp:227
static const std::vector< StateKeys > Pos
All position keys.
Definition PosVel.hpp:225