![]() |
0.3.0
|
Broadcasted ephemeris message data. More...
Public Member Functions | |
Corrections | calcClockCorrections (const InsTime &recvTime, double dist, const Frequency &freq) const final |
Calculates clock bias and drift of the satellite. | |
double | calcSatellitePositionVariance () const final |
Calculates the Variance of the satellite position in [m^2]. | |
bool | isHealthy () const final |
Checks whether the signal is healthy. | |
QZSSEphemeris & | operator= (const QZSSEphemeris &)=delete |
Copy assignment operator. | |
QZSSEphemeris & | operator= (QZSSEphemeris &&)=delete |
Move assignment operator. | |
QZSSEphemeris (const InsTime &toc, const InsTime &toe, const size_t &IODE, const size_t &IODC, const std::array< double, 3 > &a, const double &sqrt_A, const double &e, const double &i_0, const double &Omega_0, const double &omega, const double &M_0, const double &delta_n, const double &Omega_dot, const double &i_dot, const double &Cus, const double &Cuc, const double &Cis, const double &Cic, const double &Crs, const double &Crc, const double &svAccuracy, uint8_t svHealth, uint8_t L2ChannelCodes, bool L2DataFlagPCode, const double &T_GD, bool fitIntervalFlag) | |
Constructor. | |
QZSSEphemeris (const QZSSEphemeris &)=default | |
Copy Constructor. | |
QZSSEphemeris (QZSSEphemeris &&)=default | |
Move Constructor. | |
~QZSSEphemeris () final=default | |
Destructor. | |
![]() | |
SatNavData & | operator= (const SatNavData &)=delete |
Copy assignment operator. | |
SatNavData & | operator= (SatNavData &&)=delete |
Move assignment operator. | |
SatNavData (const SatNavData &)=default | |
Copy constructor. | |
SatNavData (SatNavData &&)=default | |
Move constructor. | |
SatNavData (Type type, const InsTime &refTime) | |
Constructor. | |
~SatNavData () override=default | |
Destructor. | |
![]() | |
Clock ()=default | |
Default Constructor. | |
Clock (Clock &&)=default | |
Move constructor. | |
Clock (const Clock &)=default | |
Copy constructor. | |
Clock & | operator= (Clock &&)=delete |
Move assignment operator. | |
Clock & | operator= (const Clock &)=delete |
Copy assignment operator. | |
virtual | ~Clock ()=default |
Destructor. | |
![]() | |
Pos | calcSatellitePos (const InsTime &transTime) const |
Calculates position of the satellite at transmission time. | |
PosVel | calcSatellitePosVel (const InsTime &transTime) const |
Calculates position and velocity of the satellite at transmission time. | |
PosVelAccel | calcSatellitePosVelAccel (const InsTime &transTime) const |
Calculates position, velocity and acceleration of the satellite at transmission time. | |
Orbit & | operator= (const Orbit &)=delete |
Copy assignment operator. | |
Orbit & | operator= (Orbit &&)=delete |
Move assignment operator. | |
Orbit ()=default | |
Default Constructor. | |
Orbit (const Orbit &)=default | |
Copy constructor. | |
Orbit (Orbit &&)=default | |
Move constructor. | |
virtual | ~Orbit ()=default |
Destructor. | |
Public Attributes | |
const std::array< double, 3 > | a |
const double | Cic |
Amplitude of the cosine harmonic correction term to the angle of inclination [rad]. | |
const double | Cis |
Amplitude of the sine harmonic correction term to the angle of inclination [rad]. | |
const double | Crc |
Amplitude of the cosine harmonic correction term to the orbit radius [m]. | |
const double | Crs |
Amplitude of the sine harmonic correction term to the orbit radius [m]. | |
const double | Cuc |
Amplitude of the cosine harmonic correction term to the argument of latitude [rad]. | |
const double | Cus |
Amplitude of the sine harmonic correction term to the argument of latitude [rad]. | |
const double | delta_n |
Mean motion difference from computed value [rad/s]. | |
const double | e |
Eccentricity [-]. | |
const bool | fitIntervalFlag |
Fit Interval period of the ephemeris. | |
const double | i_0 |
Inclination angle at reference time [rad]. | |
const double | i_dot |
Rate of inclination angle [rad/s]. | |
const size_t | IODC |
Issue of Data, Clock. | |
const size_t | IODE |
Issue of Data, Ephemeris. | |
const uint8_t | L2ChannelCodes |
Indicate which code(s) is (are) commanded ON for the in-phase component of the L2 channel. | |
const bool | L2DataFlagPCode |
Data Flag for L2 P-Code. | |
const double | M_0 |
Mean anomaly at reference time [rad]. | |
const double | omega |
Argument of perigee [rad]. | |
const double | Omega_0 |
Longitude of the ascending node at reference time [rad]. | |
const double | Omega_dot |
Rate of right ascension [rad/s]. | |
const double | sqrt_A |
Square root of the semi-major axis [m^1/2]. | |
const double | svAccuracy |
SV accuracy [m]. | |
const std::bitset< 6 > | svHealth |
SV health. | |
const double | T_GD |
Group delay between SV clock and L1C/A [s]. | |
const InsTime | toc |
Time of Clock. | |
const InsTime | toe |
Time of Ephemeris. | |
![]() | |
InsTime | refTime |
Reference time of the information. | |
const Type | type |
Child type (for down-casting) | |
Private Member Functions | |
PosVelAccel | calcSatelliteData (const InsTime &transTime, Orbit::Calc calc) const final |
Calculates position, velocity and acceleration of the satellite at transmission time. | |
Additional Inherited Members | |
![]() | |
enum | Type : uint8_t { GPSEphemeris , GalileoEphemeris , GLONASSEphemeris , BeiDouEphemeris , QZSSEphemeris , IRNSSEphemeris , SBASEphemeris } |
Child type. More... | |
![]() | |
enum | Calc : uint8_t { Calc_None , Calc_Position , Calc_Velocity , Calc_Acceleration } |
Calculation flags. More... | |
![]() |
Broadcasted ephemeris message data.
NAV::QZSSEphemeris::QZSSEphemeris | ( | const InsTime & | toc, |
const InsTime & | toe, | ||
const size_t & | IODE, | ||
const size_t & | IODC, | ||
const std::array< double, 3 > & | a, | ||
const double & | sqrt_A, | ||
const double & | e, | ||
const double & | i_0, | ||
const double & | Omega_0, | ||
const double & | omega, | ||
const double & | M_0, | ||
const double & | delta_n, | ||
const double & | Omega_dot, | ||
const double & | i_dot, | ||
const double & | Cus, | ||
const double & | Cuc, | ||
const double & | Cis, | ||
const double & | Cic, | ||
const double & | Crs, | ||
const double & | Crc, | ||
const double & | svAccuracy, | ||
uint8_t | svHealth, | ||
uint8_t | L2ChannelCodes, | ||
bool | L2DataFlagPCode, | ||
const double & | T_GD, | ||
bool | fitIntervalFlag ) |
Constructor.
[in] | toc | Time the Clock information is calculated (Time of Clock) |
[in] | toe | Time the Orbit information is calculated (Time of Ephemeris) |
[in] | IODE | Issue of Data, Ephemeris |
[in] | IODC | Issue of Data, Clock |
[in] | a | Polynomial coefficients for clock correction (a0 bias [s], a1 drift [s/s], a2 drift rate (aging) [s/s^2]) |
[in] | sqrt_A | Square root of the semi-major axis [m^1/2] |
[in] | e | Eccentricity [-] |
[in] | i_0 | Inclination angle at reference time [rad] |
[in] | Omega_0 | Longitude of the ascending node at reference time [rad] |
[in] | omega | Argument of perigee [rad] |
[in] | M_0 | Mean anomaly at reference time [rad] |
[in] | delta_n | Mean motion difference from computed value [rad/s] |
[in] | Omega_dot | Rate of change of right ascension [rad/s] |
[in] | i_dot | Rate of change of inclination [rad/s] |
[in] | Cus | Amplitude of the sine harmonic correction term to the argument of latitude [rad] |
[in] | Cuc | Amplitude of the cosine harmonic correction term to the argument of latitude [rad] |
[in] | Cis | Amplitude of the sine harmonic correction term to the angle of inclination [rad] |
[in] | Cic | Amplitude of the cosine harmonic correction term to the angle of inclination [rad] |
[in] | Crs | Amplitude of the sine harmonic correction term to the orbit radius [m] |
[in] | Crc | Amplitude of the cosine harmonic correction term to the orbit radius [m] |
[in] | svAccuracy | SV accuracy [m] |
[in] | svHealth | SV Health |
[in] | L2ChannelCodes | Indicate which code(s) is (are) commanded ON for the in-phase component of the L2 channel |
[in] | L2DataFlagPCode | Data Flag for L2 P-Code (fixed to '1') |
[in] | T_GD | Group delay between SV clock and L1C/A [s] |
[in] | fitIntervalFlag | Fit Interval period of the ephemeris |
|
nodiscardfinalvirtual |
Calculates clock bias and drift of the satellite.
[in] | recvTime | Receive time of the signal |
[in] | dist | Distance between receiver and satellite (normally the pseudorange) [m] |
[in] | freq | Signal Frequency |
Implements NAV::Clock.
|
nodiscardfinalprivatevirtual |
Calculates position, velocity and acceleration of the satellite at transmission time.
[in] | transTime | Transmit time of the signal |
[in] | calc | Flags which determine what should be calculated and returned |
Implements NAV::Orbit.
|
nodiscardfinalvirtual |
Calculates the Variance of the satellite position in [m^2].
Implements NAV::Orbit.
|
nodiscardfinalvirtual |
Checks whether the signal is healthy.
Implements NAV::SatNavData.
const std::array<double, 3> NAV::QZSSEphemeris::a |
Polynomial coefficients for clock correction
const bool NAV::QZSSEphemeris::fitIntervalFlag |
Fit Interval period of the ephemeris.
"0": 2 hours "1": Greater than 2 hours
For QZSS always fixed to "0", since fit interval period of the ephemeris is 2 hours (see Table 4.1.1-2.).
const size_t NAV::QZSSEphemeris::IODC |
const size_t NAV::QZSSEphemeris::IODE |
Issue of Data, Ephemeris.
Users can detect the update of the ephemeris parameter by IODE
const uint8_t NAV::QZSSEphemeris::L2ChannelCodes |
const bool NAV::QZSSEphemeris::L2DataFlagPCode |
Data Flag for L2 P-Code.
Fixed to '1' since QZSS does not track L2P.
const double NAV::QZSSEphemeris::svAccuracy |
const std::bitset<6> NAV::QZSSEphemeris::svHealth |
SV health.
This consists of the 1MSB health and the 5LSBs health
1st bit (MSB) | L1C/A Health | L1C/A 2nd bit | L2 Health | L2C 3rd bit | L5 Health | L5 4th bit | L1C Health | L1C
The 5-bit health parameter is defined differently from GPS. For details, see [22] IS QZSS, ch. 4.1.2.7, p.61
const double NAV::QZSSEphemeris::T_GD |
Group delay between SV clock and L1C/A [s].