42 void reset(
const std::vector<SatelliteSystem>& satelliteSystems);
59 void predict(
const double& dt,
const Eigen::Vector3d& lla_pos,
const std::string& nameId);
67 void update(
const std::vector<Meas::MeasKeyTypes>& measKeys,
71 const std::string& nameId);
85 bool ShowGuiWidgets(
const char*
id,
bool useDoppler,
bool multiConstellation,
bool estimateInterFrequencyBiases,
float itemWidth,
float unitWidth);
92 [[nodiscard]]
const std::vector<SPP::States::StateKeyType>&
getStateKeys()
const;
105 const std::vector<SPP::States::StateKeyType>&
VelKey = Keys::Vel<SPP::States::StateKeyType>;
107 const std::vector<SPP::States::StateKeyType>&
PosVelKey = Keys::PosVel<SPP::States::StateKeyType>;
nlohmann::json json
json namespace
Definition FlowManager.hpp:21
The class is responsible for all time-related tasks.
Inter Frequency Bias System Model.
Kalman Filter with keyed states.
Keys for the SPP algorithm for use inside the KeyedMatrices.
Receiver Clock System Model.
Structs identifying a unique satellite.
SystemModelCalcAlgorithm
Algorithms to calculate the system model with.
Definition SystemModel.hpp:23
Frequency definition for different satellite systems.
Definition Frequency.hpp:59
static constexpr double C
Speed of light [m/s].
Definition Constants.hpp:34
Inter Frequency Bias System Model.
Definition InterFrequencyBiasModel.hpp:48
Keyed Kalman Filter class.
Definition KeyedKalmanFilter.hpp:38
Dynamic sized KeyedMatrix.
Definition KeyedMatrix.hpp:2055
Dynamic sized KeyedVector.
Definition KeyedMatrix.hpp:1569
Motion System Model.
Definition MotionModel.hpp:66
Receiver Clock System Model.
Definition ReceiverClockModel.hpp:59
The Spp Kalman Filter related options.
Definition KalmanFilter.hpp:38
MotionModel< SPP::States::StateKeyType > _motionModel
Motion Model.
Definition KalmanFilter.hpp:116
InitCovarianceClockDriftUnits _gui_initCovarianceClockDriftUnit
Gui selection for the Unit of the P matrix initialization clock drift uncertainty.
Definition KalmanFilter.hpp:147
void deinitialize()
Deinitialize the KF (can be used to reinitialize the Filter when results seem strange)
void setClockBiasErrorCovariance(double clkPhaseDrift)
Set the P matrix entry for the covariance of the clock phase drift.
const std::vector< SPP::States::StateKeyType > & getStateKeys() const
Get the States in the Kalman Filter.
void reset(const std::vector< SatelliteSystem > &satelliteSystems)
Resets the filter.
void predict(const double &dt, const Eigen::Vector3d &lla_pos, const std::string &nameId)
Does the Kalman Filter prediction.
void update(const std::vector< Meas::MeasKeyTypes > &measKeys, const KeyedMatrixXd< Meas::MeasKeyTypes, States::StateKeyType > &H, const KeyedMatrixXd< Meas::MeasKeyTypes, Meas::MeasKeyTypes > &R, const KeyedVectorXd< Meas::MeasKeyTypes > &dz, const std::string &nameId)
Does the Kalman Filter update.
InitCovarianceVelocityUnits
Possible Units for the P matrix initialization velocity uncertainty.
Definition KalmanFilter.hpp:124
ReceiverClockModel< SPP::States::StateKeyType > _receiverClockModel
Receiver clock Model.
Definition KalmanFilter.hpp:117
double _initCovarianceClockDrift
Covariance of the P matrix initialization clock drift uncertainty [m²/s²].
Definition KalmanFilter.hpp:152
void initialize(const KeyedVectorXd< States::StateKeyType > &states, const KeyedMatrixXd< States::StateKeyType, States::StateKeyType > &variance)
Initialize the filter.
double _initCovarianceInterSysClockDrift
Covariance of the P matrix initialization inter system clock drift uncertainty [m²/s²].
Definition KalmanFilter.hpp:162
void addInterFrequencyBias(const Frequency &freq)
Adds the frequency as inter-frequency bias state.
InitCovarianceClockDriftUnits _gui_initCovarianceInterSysClockDriftUnit
Gui selection for the Unit of the P matrix initialization inter system clock drift uncertainty.
Definition KalmanFilter.hpp:157
SystemModelCalcAlgorithm _systemModelCalcAlgorithm
Algorithm to calculate the system models with.
Definition KalmanFilter.hpp:115
friend void to_json(json &j, const KalmanFilter &data)
Converts the provided data into a json object.
InterFrequencyBiasModel< SPP::States::StateKeyType > _interFrequencyBiasModel
Inter-frequency bias Model.
Definition KalmanFilter.hpp:118
const KeyedVectorXd< States::StateKeyType > & getState() const
Returns the State vector x̂
InitCovarianceVelocityUnits _gui_initCovarianceVelocityUnit
Gui selection for the Unit of the P matrix initialization velocity uncertainty.
Definition KalmanFilter.hpp:129
double _gui_initCovarianceVelocity
GUI selection for the P matrix initialization velocity uncertainty.
Definition KalmanFilter.hpp:132
KeyedKalmanFilterD< SPP::States::StateKeyType, SPP::Meas::MeasKeyTypes > _kalmanFilter
Kalman Filter representation.
Definition KalmanFilter.hpp:110
friend void from_json(const json &j, KalmanFilter &data)
Converts the provided json object into the data object.
double _gui_initCovarianceClockDrift
GUI selection for the P matrix initialization clock drift uncertainty.
Definition KalmanFilter.hpp:150
double _initCovarianceVelocity
Covariance of the P matrix initialization velocity uncertainty [m²/s²].
Definition KalmanFilter.hpp:134
bool _initialized
Boolean that determines, if Kalman Filter is initialized (from weighted LSE solution)
Definition KalmanFilter.hpp:113
const std::vector< SPP::States::StateKeyType > & PosVelKey
All position and velocity keys.
Definition KalmanFilter.hpp:107
double _gui_initCovarianceInterSysClockDrift
GUI selection for the P matrix initialization inter system clock drift uncertainty.
Definition KalmanFilter.hpp:160
bool ShowGuiWidgets(const char *id, bool useDoppler, bool multiConstellation, bool estimateInterFrequencyBiases, float itemWidth, float unitWidth)
Shows the GUI input to select the options.
InitCovarianceClockDriftUnits
Possible Units for the P matrix initialization clock drift uncertainty.
Definition KalmanFilter.hpp:140
bool isInitialized() const
Checks wether the Kalman filter is initialized.
Definition KalmanFilter.hpp:53
const std::vector< SPP::States::StateKeyType > & VelKey
All velocity keys.
Definition KalmanFilter.hpp:105
const KeyedMatrixXd< States::StateKeyType, States::StateKeyType > & getErrorCovarianceMatrix() const
Returns the Error covariance matrix 𝐏