16#include <unordered_map>
34 [[nodiscard]]
static std::string
type()
44 return m_satellites.at(satId).calcSatellitePos(transTime);
51 return m_satellites.at(satId).calcSatellitePosVel(transTime);
58 return m_satellites.at(satId).calcSatellitePosVelAccel(transTime);
68 return m_satellites.at(satId).calcClockCorrections(recvTime, dist, freq);
76 return m_satellites.at(satId).calcSatellitePositionVariance(recvTime);
102 auto satNavData =
m_satellites.at(satId).searchNavigationData(recvTime);
103 if (satNavData ==
nullptr)
105 [[maybe_unused]]
auto printNavData = [&]() {
107 for (
const auto& navData :
m_satellites.at(satId).getNavigationData())
109 ret += fmt::format(
"[{} - diff {:.0f}s], ", navData->refTime.toYMDHMS(
GPST),
110 static_cast<double>(std::abs((navData->refTime - recvTime).count())));
112 return ret.substr(0, ret.length() - 2);
115 LOG_TRACE(
"[{}][{}]: No navigation data found. Available data are at time: {}", satId, recvTime.
toYMDHMS(
GPST), printNavData());
152 double a0 = std::nan(
"");
153 double a1 = std::nan(
"");
Ionospheric Correction data.
Utility class for logging to console and file.
#define LOG_TRACE
Detailled info to trace the execution of the program. Should not be called on functions which receive...
Definition Logger.hpp:65
Utility functions for std::pair.
Structs identifying a unique satellite.
@ SatSys_None
No Satellite system.
Definition SatelliteSystem.hpp:32
Calculations and data related to satellite orbit, clock, ...
@ GPST
GPS Time.
Definition TimeSystem.hpp:30
Frequency definition for different satellite systems.
Definition Frequency.hpp:59
GNSS Navigation message information.
Definition GnssNavInfo.hpp:30
Orbit::Pos calcSatellitePos(const SatId &satId, const InsTime &transTime) const
Calculates position, velocity and acceleration of the satellite at transmission time.
Definition GnssNavInfo.hpp:42
size_t nSatellites() const
Returns the amount of satellites contained in this message.
Definition GnssNavInfo.hpp:122
void addSatelliteNavData(const SatId &satId, const std::shared_ptr< SatNavData > &satNavData)
Adds the provided satellite navigation data to the satellite.
Definition GnssNavInfo.hpp:90
double calcSatellitePositionVariance(const SatId &satId, const InsTime &recvTime) const
Calculates the Variance of the satellite position in [m].
Definition GnssNavInfo.hpp:74
static std::string type()
Returns the type of the data class.
Definition GnssNavInfo.hpp:34
std::unordered_map< std::pair< TimeSystem, TimeSystem >, TimeSystemCorrections > timeSysCorr
Time system correction parameters. Difference between GNSS system time and UTC or other time systems.
Definition GnssNavInfo.hpp:158
const auto & satellites() const
Get the satellites.
Definition GnssNavInfo.hpp:129
Clock::Corrections calcSatelliteClockCorrections(const SatId &satId, const InsTime &recvTime, double dist, const Frequency &freq) const
Calculates clock bias and drift of the satellite.
Definition GnssNavInfo.hpp:66
std::shared_ptr< NAV::SatNavData > searchNavigationData(const SatId &satId, const InsTime &recvTime) const
Checks whether the satellite is included in the internal data.
Definition GnssNavInfo.hpp:98
bool isHealthy(const SatId &satId, const InsTime &recvTime) const
Checks whether the signal is healthy.
Definition GnssNavInfo.hpp:82
void reset()
Resets the data by clearing the member variables.
Definition GnssNavInfo.hpp:135
std::unordered_map< SatId, Satellite > m_satellites
Map of satellites containing the navigation message data.
Definition GnssNavInfo.hpp:162
Orbit::PosVel calcSatellitePosVel(const SatId &satId, const InsTime &transTime) const
Calculates position, velocity and acceleration of the satellite at transmission time.
Definition GnssNavInfo.hpp:49
Orbit::PosVelAccel calcSatellitePosVelAccel(const SatId &satId, const InsTime &transTime) const
Calculates position, velocity and acceleration of the satellite at transmission time.
Definition GnssNavInfo.hpp:56
IonosphericCorrections ionosphericCorrections
Ionospheric correction values.
Definition GnssNavInfo.hpp:147
SatelliteSystem satelliteSystems
Satellite Systems available.
Definition GnssNavInfo.hpp:144
The class is responsible for all time-related tasks.
Definition InsTime.hpp:668
constexpr InsTime_YMDHMS toYMDHMS(TimeSystem timesys=UTC, int digits=-1) const
Converts this time object into a different format.
Definition InsTime.hpp:829
Ionospheric Corrections.
Definition IonosphericCorrections.hpp:31
void clear()
Empties the data.
Definition IonosphericCorrections.hpp:112
Satellite clock corrections.
Definition Clock.hpp:28
Time system correction parameters.
Definition GnssNavInfo.hpp:151
double a0
a0 / tau_c Coefficient of linear polynomial [s] Δt = a0 + a1 * (t - t_ref)
Definition GnssNavInfo.hpp:152
double a1
a1 Coefficient of linear polynomial [s/s]
Definition GnssNavInfo.hpp:153
Satellite Position, Velocity and Acceleration.
Definition Orbit.hpp:40
Satellite Position and Velocity.
Definition Orbit.hpp:34
Satellite Position.
Definition Orbit.hpp:29
Identifies a satellite (satellite system and number)
Definition SatelliteIdentifier.hpp:34
Satellite System type.
Definition SatelliteSystem.hpp:44