mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-06 07:20:34 +00:00
Give more natural, consistent names to ephemeris / iono / utc parameters exposed outside the receiver via XML files
Create a base class for GPS, Galileo and BeiDou ephemeris, allowing to remove some duplicated code Use BOOST_SERIALIZATION_NVP macro, less error prone than boost::serialization::make_nvp Update .xsd files
This commit is contained in:
parent
c0796f416d
commit
7971565a0d
@ -42,6 +42,9 @@ SPDX-FileCopyrightText: 2011-2021 Carles Fernandez-Prades <carles.fernandez@cttc
|
||||
- Do not apply clang-tidy fixes to protobuf-generated headers.
|
||||
- Refactored private implementation of flow graph connection and disconnection
|
||||
for improved source code readability.
|
||||
- Added a base class for GNSS ephemeris, saving some duplicated code and
|
||||
providing a common nomenclature for ephemeris' parameters. New generated XML
|
||||
files make use of the new parameters' name.
|
||||
|
||||
### Improvements in Usability:
|
||||
|
||||
|
@ -6,7 +6,7 @@ SPDX-License-Identifier: GPL-3.0-or-later
|
||||
)
|
||||
|
||||
[comment]: # (
|
||||
SPDX-FileCopyrightText: 2011-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es>
|
||||
SPDX-FileCopyrightText: 2011-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es>
|
||||
)
|
||||
<!-- prettier-ignore-end -->
|
||||
|
||||
@ -33,6 +33,8 @@ elements in an XML document.
|
||||
|
||||
- [cnav_ephemeris_map.xsd](./cnav_ephemeris_map.xsd) - GPS CNAV message
|
||||
ephemeris parameters.
|
||||
- [cnav_utc_model.xsd](./cnav_utc_model.xsd) - GPS CNAV message UTC model
|
||||
parameters.
|
||||
|
||||
## Galileo
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
@ -16,35 +16,43 @@
|
||||
<xs:element name="second">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:byte" name="i_satellite_PRN"/>
|
||||
<xs:element type="xs:int" name="d_TOW"/>
|
||||
<xs:element type="xs:float" name="d_Crs"/>
|
||||
<xs:element type="xs:float" name="d_M_0"/>
|
||||
<xs:element type="xs:float" name="d_Cuc"/>
|
||||
<xs:element type="xs:float" name="d_e_eccentricity"/>
|
||||
<xs:element type="xs:float" name="d_Cus"/>
|
||||
<xs:element type="xs:int" name="d_Toe1"/>
|
||||
<xs:element type="xs:int" name="d_Toe2"/>
|
||||
<xs:element type="xs:byte" name="d_Toc"/>
|
||||
<xs:element type="xs:float" name="d_Cic"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA0"/>
|
||||
<xs:element type="xs:float" name="d_Cis"/>
|
||||
<xs:element type="xs:float" name="d_i_0"/>
|
||||
<xs:element type="xs:float" name="d_Crc"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA"/>
|
||||
<xs:element type="xs:float" name="d_IDOT"/>
|
||||
<xs:element type="xs:short" name="i_GPS_week"/>
|
||||
<xs:element type="xs:float" name="d_TGD"/>
|
||||
<xs:element type="xs:float" name="d_ISCL1"/>
|
||||
<xs:element type="xs:float" name="d_ISCL2"/>
|
||||
<xs:element type="xs:float" name="d_ISCL5I"/>
|
||||
<xs:element type="xs:float" name="d_ISCL5Q"/>
|
||||
<xs:element type="xs:float" name="d_DELTA_A"/>
|
||||
<xs:element type="xs:float" name="d_A_DOT"/>
|
||||
<xs:element type="xs:float" name="d_DELTA_OMEGA_DOT"/>
|
||||
<xs:element type="xs:float" name="d_A_f0"/>
|
||||
<xs:element type="xs:float" name="d_A_f1"/>
|
||||
<xs:element type="xs:float" name="d_A_f2"/>
|
||||
<xs:element type="xs:byte" name="PRN"/>
|
||||
<xs:element type="xs:float" name="M_0"/>
|
||||
<xs:element type="xs:float" name="delta_n"/>
|
||||
<xs:element type="xs:float" name="ecc"/>
|
||||
<xs:element type="xs:float" name="sqrtA"/>
|
||||
<xs:element type="xs:float" name="OMEGA_0"/>
|
||||
<xs:element type="xs:float" name="i_0"/>
|
||||
<xs:element type="xs:float" name="omega"/>
|
||||
<xs:element type="xs:float" name="OMEGAdot"/>
|
||||
<xs:element type="xs:float" name="idot"/>
|
||||
<xs:element type="xs:float" name="Cuc"/>
|
||||
<xs:element type="xs:float" name="Cus"/>
|
||||
<xs:element type="xs:float" name="Crc"/>
|
||||
<xs:element type="xs:float" name="Crs"/>
|
||||
<xs:element type="xs:float" name="Cic"/>
|
||||
<xs:element type="xs:float" name="Cis"/>
|
||||
<xs:element type="xs:int" name="toe"/>
|
||||
<xs:element type="xs:int" name="toc"/>
|
||||
<xs:element type="xs:float" name="af0"/>
|
||||
<xs:element type="xs:float" name="af1"/>
|
||||
<xs:element type="xs:float" name="af2"/>
|
||||
<xs:element type="xs:short" name="WN"/>
|
||||
<xs:element type="xs:int" name="tow"/>
|
||||
<xs:element type="xs:float" name="satClkDrift"/>
|
||||
<xs:element type="xs:float" name="dtr"/>
|
||||
<xs:element type="xs:byte" name="IODE_SF2"/>
|
||||
<xs:element type="xs:byte" name="IODE_SF3"/>
|
||||
<xs:element type="xs:byte" name="code_on_L2"/>
|
||||
<xs:element type="xs:byte" name="L2_P_data_flag"/>
|
||||
<xs:element type="xs:byte" name="SV_accuracy"/>
|
||||
<xs:element type="xs:byte" name="SV_health"/>
|
||||
<xs:element type="xs:float" name="TGD"/>
|
||||
<xs:element type="xs:byte" name="IODC"/>
|
||||
<xs:element type="xs:short" name="AODO"/>
|
||||
<xs:element type="xs:byte" name="b_fit_interval_flag"/>
|
||||
<xs:element type="xs:float" name="d_spare1"/>
|
||||
<xs:element type="xs:float" name="d_spare2"/>
|
||||
<xs:element type="xs:byte" name="b_integrity_status_flag"/>
|
||||
<xs:element type="xs:byte" name="b_alert_flag"/>
|
||||
<xs:element type="xs:byte" name="b_antispoofing_flag"/>
|
||||
|
30
docs/xml-schemas/cnav_utc_model.xsd
Normal file
30
docs/xml-schemas/cnav_utc_model.xsd
Normal file
@ -0,0 +1,30 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element name="GNSS-SDR_cnav_utc_model">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:float" name="A1"/>
|
||||
<xs:element type="xs:float" name="A0"/>
|
||||
<xs:element type="xs:int" name="tot"/>
|
||||
<xs:element type="xs:short" name="WN_T"/>
|
||||
<xs:element type="xs:byte" name="DeltaT_LS"/>
|
||||
<xs:element type="xs:short" name="WN_LSF"/>
|
||||
<xs:element type="xs:byte" name="DN"/>
|
||||
<xs:element type="xs:byte" name="DeltaT_LSF"/>
|
||||
<xs:element type="xs:byte" name="valid"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:byte" name="class_id"/>
|
||||
<xs:attribute type="xs:byte" name="tracking_level"/>
|
||||
<xs:attribute type="xs:byte" name="version"/>
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:string" name="signature"/>
|
||||
<xs:attribute type="xs:byte" name="version"/>
|
||||
</xs:complexType>
|
||||
</xs:element>
|
||||
</xs:schema>
|
@ -1,6 +1,6 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
IODE_SF<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
@ -16,41 +16,41 @@
|
||||
<xs:element name="second">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:byte" name="i_satellite_PRN"/>
|
||||
<xs:element type="xs:int" name="d_TOW"/>
|
||||
<xs:element type="xs:byte" name="d_IODE_SF2"/>
|
||||
<xs:element type="xs:byte" name="d_IODE_SF3"/>
|
||||
<xs:element type="xs:float" name="d_Crs"/>
|
||||
<xs:element type="xs:float" name="d_Delta_n"/>
|
||||
<xs:element type="xs:float" name="d_M_0"/>
|
||||
<xs:element type="xs:float" name="d_Cuc"/>
|
||||
<xs:element type="xs:float" name="d_e_eccentricity"/>
|
||||
<xs:element type="xs:float" name="d_Cus"/>
|
||||
<xs:element type="xs:float" name="d_sqrt_A"/>
|
||||
<xs:element type="xs:int" name="d_Toe"/>
|
||||
<xs:element type="xs:int" name="d_Toc"/>
|
||||
<xs:element type="xs:float" name="d_Cic"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA0"/>
|
||||
<xs:element type="xs:float" name="d_Cis"/>
|
||||
<xs:element type="xs:float" name="d_i_0"/>
|
||||
<xs:element type="xs:float" name="d_Crc"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA_DOT"/>
|
||||
<xs:element type="xs:float" name="d_IDOT"/>
|
||||
<xs:element type="xs:byte" name="i_code_on_L2"/>
|
||||
<xs:element type="xs:short" name="i_GPS_week"/>
|
||||
<xs:element type="xs:byte" name="b_L2_P_data_flag"/>
|
||||
<xs:element type="xs:byte" name="i_SV_accuracy"/>
|
||||
<xs:element type="xs:byte" name="i_SV_health"/>
|
||||
<xs:element type="xs:byte" name="PRN"/>
|
||||
<xs:element type="xs:int" name="tow"/>
|
||||
<xs:element type="xs:byte" name="IODE_SF2"/>
|
||||
<xs:element type="xs:byte" name="IODE_SF3"/>
|
||||
<xs:element type="xs:float" name="Crs"/>
|
||||
<xs:element type="xs:float" name="delta_n"/>
|
||||
<xs:element type="xs:float" name="M_0"/>
|
||||
<xs:element type="xs:float" name="Cuc"/>
|
||||
<xs:element type="xs:float" name="ecc"/>
|
||||
<xs:element type="xs:float" name="Cus"/>
|
||||
<xs:element type="xs:float" name="sqrtA"/>
|
||||
<xs:element type="xs:int" name="toe"/>
|
||||
<xs:element type="xs:int" name="toc"/>
|
||||
<xs:element type="xs:float" name="Cic"/>
|
||||
<xs:element type="xs:float" name="OMEGA_0"/>
|
||||
<xs:element type="xs:float" name="Cis"/>
|
||||
<xs:element type="xs:float" name="i_0"/>
|
||||
<xs:element type="xs:float" name="Crc"/>
|
||||
<xs:element type="xs:float" name="omega"/>
|
||||
<xs:element type="xs:float" name="OMEGAdot"/>
|
||||
<xs:element type="xs:float" name="idot"/>
|
||||
<xs:element type="xs:byte" name="code_on_L2"/>
|
||||
<xs:element type="xs:short" name="WN"/>
|
||||
<xs:element type="xs:byte" name="L2_P_data_flag"/>
|
||||
<xs:element type="xs:byte" name="SV_accuracy"/>
|
||||
<xs:element type="xs:byte" name="SV_health"/>
|
||||
<xs:element type="xs:float" name="d_TGD"/>
|
||||
<xs:element type="xs:byte" name="d_IODC"/>
|
||||
<xs:element type="xs:short" name="i_AODO"/>
|
||||
<xs:element type="xs:byte" name="IODC"/>
|
||||
<xs:element type="xs:short" name="AODO"/>
|
||||
<xs:element type="xs:byte" name="b_fit_interval_flag"/>
|
||||
<xs:element type="xs:float" name="d_spare1"/>
|
||||
<xs:element type="xs:float" name="d_spare2"/>
|
||||
<xs:element type="xs:float" name="d_A_f0"/>
|
||||
<xs:element type="xs:float" name="d_A_f1"/>
|
||||
<xs:element type="xs:float" name="d_A_f2"/>
|
||||
<xs:element type="xs:float" name="af0"/>
|
||||
<xs:element type="xs:float" name="af1"/>
|
||||
<xs:element type="xs:float" name="af2"/>
|
||||
<xs:element type="xs:byte" name="b_integrity_status_flag"/>
|
||||
<xs:element type="xs:byte" name="b_alert_flag"/>
|
||||
<xs:element type="xs:byte" name="b_antispoofing_flag"/>
|
||||
|
@ -1,6 +1,6 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
@ -16,19 +16,19 @@
|
||||
<xs:element name="second">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:byte" name="i_satellite_PRN"/>
|
||||
<xs:element type="xs:int" name="i_Toa"/>
|
||||
<xs:element type="xs:byte" name="i_WNa"/>
|
||||
<xs:element type="xs:byte" name="i_IODa"/>
|
||||
<xs:element type="xs:float" name="d_Delta_i"/>
|
||||
<xs:element type="xs:float" name="d_M_0"/>
|
||||
<xs:element type="xs:float" name="d_e_eccentricity"/>
|
||||
<xs:element type="xs:float" name="d_Delta_sqrt_A"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA0"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA_DOT"/>
|
||||
<xs:element type="xs:float" name="d_A_f0"/>
|
||||
<xs:element type="xs:float" name="d_A_f1"/>
|
||||
<xs:element type="xs:byte" name="PRN"/>
|
||||
<xs:element type="xs:int" name="toa"/>
|
||||
<xs:element type="xs:byte" name="WNa"/>
|
||||
<xs:element type="xs:byte" name="IODa"/>
|
||||
<xs:element type="xs:float" name="delta_i"/>
|
||||
<xs:element type="xs:float" name="M_0"/>
|
||||
<xs:element type="xs:float" name="ecc"/>
|
||||
<xs:element type="xs:float" name="delta_sqrtA"/>
|
||||
<xs:element type="xs:float" name="OMEGA_0"/>
|
||||
<xs:element type="xs:float" name="omega"/>
|
||||
<xs:element type="xs:float" name="OMEGAdot"/>
|
||||
<xs:element type="xs:float" name="af0"/>
|
||||
<xs:element type="xs:float" name="af1"/>
|
||||
<xs:element type="xs:byte" name="E5b_HS"/>
|
||||
<xs:element type="xs:byte" name="E1B_HS"/>
|
||||
<xs:element type="xs:byte" name="E5a_HS"/>
|
||||
|
@ -1,6 +1,6 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
@ -16,43 +16,42 @@
|
||||
<xs:element name="second">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:byte" name="i_satellite_PRN"/>
|
||||
<xs:element type="xs:float" name="M0_1"/>
|
||||
<xs:element type="xs:float" name="delta_n_3"/>
|
||||
<xs:element type="xs:float" name="e_1"/>
|
||||
<xs:element type="xs:float" name="A_1"/>
|
||||
<xs:element type="xs:float" name="OMEGA_0_2"/>
|
||||
<xs:element type="xs:float" name="i_0_2"/>
|
||||
<xs:element type="xs:float" name="omega_2"/>
|
||||
<xs:element type="xs:float" name="OMEGA_dot_3"/>
|
||||
<xs:element type="xs:float" name="iDot_2"/>
|
||||
<xs:element type="xs:float" name="C_uc_3"/>
|
||||
<xs:element type="xs:float" name="C_us_3"/>
|
||||
<xs:element type="xs:float" name="C_rc_3"/>
|
||||
<xs:element type="xs:float" name="C_rs_3"/>
|
||||
<xs:element type="xs:float" name="C_ic_4"/>
|
||||
<xs:element type="xs:float" name="C_is_4"/>
|
||||
<xs:element type="xs:int" name="t0e_1"/>
|
||||
<xs:element type="xs:int" name="t0c_4"/>
|
||||
<xs:element type="xs:float" name="af0_4"/>
|
||||
<xs:element type="xs:float" name="af1_4"/>
|
||||
<xs:element type="xs:float" name="af2_4"/>
|
||||
<xs:element type="xs:short" name="WN_5"/>
|
||||
<xs:element type="xs:int" name="TOW_5"/>
|
||||
<xs:element type="xs:float" name="Galileo_satClkDrift"/>
|
||||
<xs:element type="xs:float" name="Galileo_dtr"/>
|
||||
|
||||
<xs:element type="xs:byte" name="PRN"/>
|
||||
<xs:element type="xs:float" name="M_0"/>
|
||||
<xs:element type="xs:float" name="delta_n"/>
|
||||
<xs:element type="xs:float" name="ecc"/>
|
||||
<xs:element type="xs:float" name="sqrtA"/>
|
||||
<xs:element type="xs:float" name="OMEGA_0"/>
|
||||
<xs:element type="xs:float" name="i_0"/>
|
||||
<xs:element type="xs:float" name="omega"/>
|
||||
<xs:element type="xs:float" name="OMEGAdot"/>
|
||||
<xs:element type="xs:float" name="idot"/>
|
||||
<xs:element type="xs:float" name="Cuc"/>
|
||||
<xs:element type="xs:float" name="Cus"/>
|
||||
<xs:element type="xs:float" name="Crc"/>
|
||||
<xs:element type="xs:float" name="Crs"/>
|
||||
<xs:element type="xs:float" name="Cic"/>
|
||||
<xs:element type="xs:float" name="Cis"/>
|
||||
<xs:element type="xs:int" name="toe"/>
|
||||
<xs:element type="xs:int" name="toc"/>
|
||||
<xs:element type="xs:float" name="af0"/>
|
||||
<xs:element type="xs:float" name="af1"/>
|
||||
<xs:element type="xs:float" name="af2"/>
|
||||
<xs:element type="xs:short" name="WN"/>
|
||||
<xs:element type="xs:int" name="tow"/>
|
||||
<xs:element type="xs:float" name="satClkDrift"/>
|
||||
<xs:element type="xs:float" name="dtr"/>
|
||||
<xs:element type="xs:byte" name="IOD_ephemeris"/>
|
||||
<xs:element type="xs:byte" name="IOD_nav_1"/>
|
||||
<xs:element type="xs:byte" name="SISA_3"/>
|
||||
<xs:element type="xs:byte" name="IOD_nav"/>
|
||||
<xs:element type="xs:byte" name="SISA"/>
|
||||
<xs:element type="xs:byte" name="E5a_HS"/>
|
||||
<xs:element type="xs:byte" name="E5b_HS_5"/>
|
||||
<xs:element type="xs:byte" name="E1B_HS_5"/>
|
||||
<xs:element type="xs:byte" name="E5b_HS"/>
|
||||
<xs:element type="xs:byte" name="E1B_HS"/>
|
||||
<xs:element type="xs:byte" name="E5a_DVS"/>
|
||||
<xs:element type="xs:byte" name="E5b_DVS_5"/>
|
||||
<xs:element type="xs:byte" name="E1B_DVS_5"/>
|
||||
<xs:element type="xs:float" name="BGD_E1E5a_5"/>
|
||||
<xs:element type="xs:float" name="BGD_E1E5b_5"/>
|
||||
<xs:element type="xs:byte" name="E5b_DVS"/>
|
||||
<xs:element type="xs:byte" name="E1B_DVS"/>
|
||||
<xs:element type="xs:float" name="BGD_E1E5a"/>
|
||||
<xs:element type="xs:float" name="BGD_E1E5b"/>
|
||||
<xs:element type="xs:byte" name="flag_all_ephemeris"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:byte" name="class_id" use="optional"/>
|
||||
|
@ -1,22 +1,22 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element name="GNSS-SDR_gal_iono_model">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:float" name="ai0_5"/>
|
||||
<xs:element type="xs:float" name="ai1_5"/>
|
||||
<xs:element type="xs:float" name="ai2_5"/>
|
||||
<xs:element type="xs:int" name="TOW_5"/>
|
||||
<xs:element type="xs:short" name="WN_5"/>
|
||||
<xs:element type="xs:byte" name="Region1_flag_5"/>
|
||||
<xs:element type="xs:byte" name="Region2_flag_5"/>
|
||||
<xs:element type="xs:byte" name="Region3_flag_5"/>
|
||||
<xs:element type="xs:byte" name="Region4_flag_5"/>
|
||||
<xs:element type="xs:byte" name="Region5_flag_5"/>
|
||||
<xs:element type="xs:float" name="ai0"/>
|
||||
<xs:element type="xs:float" name="ai1"/>
|
||||
<xs:element type="xs:float" name="ai2"/>
|
||||
<xs:element type="xs:int" name="tow"/>
|
||||
<xs:element type="xs:short" name="WN"/>
|
||||
<xs:element type="xs:byte" name="Region1_flag"/>
|
||||
<xs:element type="xs:byte" name="Region2_flag"/>
|
||||
<xs:element type="xs:byte" name="Region3_flag"/>
|
||||
<xs:element type="xs:byte" name="Region4_flag"/>
|
||||
<xs:element type="xs:byte" name="Region5_flag"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:byte" name="class_id"/>
|
||||
<xs:attribute type="xs:byte" name="tracking_level"/>
|
||||
|
@ -1,20 +1,20 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element name="GNSS-SDR_gal_utc_model">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:float" name="A0_6"/>
|
||||
<xs:element type="xs:float" name="A1_6"/>
|
||||
<xs:element type="xs:byte" name="Delta_tLS_6"/>
|
||||
<xs:element type="xs:int" name="t0t_6"/>
|
||||
<xs:element type="xs:short" name="WNot_6"/>
|
||||
<xs:element type="xs:short" name="WN_LSF_6"/>
|
||||
<xs:element type="xs:byte" name="DN_6"/>
|
||||
<xs:element type="xs:byte" name="Delta_tLSF_6"/>
|
||||
<xs:element type="xs:float" name="A0"/>
|
||||
<xs:element type="xs:float" name="A1"/>
|
||||
<xs:element type="xs:byte" name="Delta_tLS"/>
|
||||
<xs:element type="xs:int" name="tot"/>
|
||||
<xs:element type="xs:short" name="WNot"/>
|
||||
<xs:element type="xs:short" name="WN_LSF"/>
|
||||
<xs:element type="xs:byte" name="DN"/>
|
||||
<xs:element type="xs:byte" name="Delta_tLSF"/>
|
||||
<xs:element type="xs:byte" name="flag_utc_model"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:byte" name="class_id"/>
|
||||
|
@ -1,6 +1,6 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
@ -16,20 +16,20 @@
|
||||
<xs:element name="second">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:byte" name="i_satellite_PRN"/>
|
||||
<xs:element type="xs:float" name="d_Delta_i"/>
|
||||
<xs:element type="xs:byte" name="i_Toa"/>
|
||||
<xs:element type="xs:byte" name="i_WNa"/>
|
||||
<xs:element type="xs:float" name="d_M_0"/>
|
||||
<xs:element type="xs:float" name="d_e_eccentricity"/>
|
||||
<xs:element type="xs:float" name="d_sqrt_A"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA0"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA"/>
|
||||
<xs:element type="xs:float" name="d_OMEGA_DOT"/>
|
||||
<xs:element type="xs:byte" name="i_SV_health"/>
|
||||
<xs:element type="xs:byte" name="i_AS_status"/>
|
||||
<xs:element type="xs:float" name="d_A_f0"/>
|
||||
<xs:element type="xs:float" name="d_A_f1"/>
|
||||
<xs:element type="xs:byte" name="PRN"/>
|
||||
<xs:element type="xs:float" name="delta_i"/>
|
||||
<xs:element type="xs:byte" name="toa"/>
|
||||
<xs:element type="xs:byte" name="WNa"/>
|
||||
<xs:element type="xs:float" name="M_0"/>
|
||||
<xs:element type="xs:float" name="ecc"/>
|
||||
<xs:element type="xs:float" name="sqrtA"/>
|
||||
<xs:element type="xs:float" name="OMEGA_0"/>
|
||||
<xs:element type="xs:float" name="omega"/>
|
||||
<xs:element type="xs:float" name="OMEGAdot"/>
|
||||
<xs:element type="xs:byte" name="SV_health"/>
|
||||
<xs:element type="xs:byte" name="AS_status"/>
|
||||
<xs:element type="xs:float" name="af0"/>
|
||||
<xs:element type="xs:float" name="af1"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:byte" name="class_id" use="optional"/>
|
||||
<xs:attribute type="xs:byte" name="tracking_level" use="optional"/>
|
||||
|
@ -1,20 +1,20 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element name="GNSS-SDR_iono_model">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:float" name="d_alpha0"/>
|
||||
<xs:element type="xs:float" name="d_alpha1"/>
|
||||
<xs:element type="xs:float" name="d_alpha2"/>
|
||||
<xs:element type="xs:float" name="d_alpha3"/>
|
||||
<xs:element type="xs:float" name="d_beta0"/>
|
||||
<xs:element type="xs:float" name="d_beta1"/>
|
||||
<xs:element type="xs:float" name="d_beta2"/>
|
||||
<xs:element type="xs:float" name="d_beta3"/>
|
||||
<xs:element type="xs:float" name="alpha0"/>
|
||||
<xs:element type="xs:float" name="alpha1"/>
|
||||
<xs:element type="xs:float" name="alpha2"/>
|
||||
<xs:element type="xs:float" name="alpha3"/>
|
||||
<xs:element type="xs:float" name="beta0"/>
|
||||
<xs:element type="xs:float" name="beta1"/>
|
||||
<xs:element type="xs:float" name="beta2"/>
|
||||
<xs:element type="xs:float" name="beta3"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:byte" name="class_id"/>
|
||||
<xs:attribute type="xs:byte" name="tracking_level"/>
|
||||
|
@ -1,20 +1,20 @@
|
||||
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
|
||||
<!-- SPDX-License-Identifier: BSD-3-Clause -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2020 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<!-- SPDX-FileCopyrightText: 2018-2021 Carles Fernandez-Prades <carles.fernandez@cttc.es> -->
|
||||
<xs:element name="boost_serialization">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element name="GNSS-SDR_utc_model">
|
||||
<xs:complexType>
|
||||
<xs:sequence>
|
||||
<xs:element type="xs:float" name="d_A1"/>
|
||||
<xs:element type="xs:float" name="d_A0"/>
|
||||
<xs:element type="xs:int" name="d_t_OT"/>
|
||||
<xs:element type="xs:short" name="i_WN_T"/>
|
||||
<xs:element type="xs:byte" name="d_DeltaT_LS"/>
|
||||
<xs:element type="xs:short" name="i_WN_LSF"/>
|
||||
<xs:element type="xs:byte" name="i_DN"/>
|
||||
<xs:element type="xs:byte" name="d_DeltaT_LSF"/>
|
||||
<xs:element type="xs:float" name="A1"/>
|
||||
<xs:element type="xs:float" name="A0"/>
|
||||
<xs:element type="xs:int" name="tot"/>
|
||||
<xs:element type="xs:short" name="WN_T"/>
|
||||
<xs:element type="xs:byte" name="DeltaT_LS"/>
|
||||
<xs:element type="xs:short" name="WN_LSF"/>
|
||||
<xs:element type="xs:byte" name="DN"/>
|
||||
<xs:element type="xs:byte" name="DeltaT_LSF"/>
|
||||
<xs:element type="xs:byte" name="valid"/>
|
||||
</xs:sequence>
|
||||
<xs:attribute type="xs:byte" name="class_id"/>
|
||||
|
@ -667,7 +667,7 @@ rtklib_pvt_gs::~rtklib_pvt_gs()
|
||||
|
||||
// Save Galileo UTC model parameters
|
||||
file_name = d_xml_base_path + "gal_utc_model.xml";
|
||||
if (d_internal_pvt_solver->galileo_utc_model.Delta_tLS_6 != 0.0)
|
||||
if (d_internal_pvt_solver->galileo_utc_model.Delta_tLS != 0.0)
|
||||
{
|
||||
std::ofstream ofs;
|
||||
try
|
||||
@ -757,7 +757,7 @@ rtklib_pvt_gs::~rtklib_pvt_gs()
|
||||
|
||||
// Save Galileo iono parameters
|
||||
file_name = d_xml_base_path + "gal_iono.xml";
|
||||
if (d_internal_pvt_solver->galileo_iono.ai0_5 != 0.0)
|
||||
if (d_internal_pvt_solver->galileo_iono.ai0 != 0.0)
|
||||
{
|
||||
std::ofstream ofs;
|
||||
try
|
||||
@ -1074,10 +1074,10 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
// ### GPS EPHEMERIS ###
|
||||
const auto gps_eph = boost::any_cast<std::shared_ptr<Gps_Ephemeris>>(pmt::any_ref(msg));
|
||||
DLOG(INFO) << "Ephemeris record has arrived from SAT ID "
|
||||
<< gps_eph->i_satellite_PRN << " (Block "
|
||||
<< gps_eph->satelliteBlock[gps_eph->i_satellite_PRN] << ")"
|
||||
<< "inserted with Toe=" << gps_eph->d_Toe << " and GPS Week="
|
||||
<< gps_eph->i_GPS_week;
|
||||
<< gps_eph->PRN << " (Block "
|
||||
<< gps_eph->satelliteBlock[gps_eph->PRN] << ")"
|
||||
<< "inserted with Toe=" << gps_eph->toe << " and GPS Week="
|
||||
<< gps_eph->WN;
|
||||
|
||||
// todo: Send only new sets of ephemeris (new TOE), not sent to the client
|
||||
// send the new eph to the eph monitor (if enabled)
|
||||
@ -1089,13 +1089,13 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
if (d_rinex_output_enabled && d_rp->is_rinex_header_written()) // The header is already written, we can now log the navigation message data
|
||||
{
|
||||
bool new_annotation = false;
|
||||
if (d_internal_pvt_solver->gps_ephemeris_map.find(gps_eph->i_satellite_PRN) == d_internal_pvt_solver->gps_ephemeris_map.cend())
|
||||
if (d_internal_pvt_solver->gps_ephemeris_map.find(gps_eph->PRN) == d_internal_pvt_solver->gps_ephemeris_map.cend())
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (d_internal_pvt_solver->gps_ephemeris_map[gps_eph->i_satellite_PRN].d_Toe != gps_eph->d_Toe)
|
||||
if (d_internal_pvt_solver->gps_ephemeris_map[gps_eph->PRN].toe != gps_eph->toe)
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
@ -1104,14 +1104,14 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
{
|
||||
// New record!
|
||||
std::map<int32_t, Gps_Ephemeris> new_eph;
|
||||
new_eph[gps_eph->i_satellite_PRN] = *gps_eph;
|
||||
new_eph[gps_eph->PRN] = *gps_eph;
|
||||
d_rp->log_rinex_nav_gps_nav(d_type_of_rx, new_eph);
|
||||
}
|
||||
}
|
||||
d_internal_pvt_solver->gps_ephemeris_map[gps_eph->i_satellite_PRN] = *gps_eph;
|
||||
d_internal_pvt_solver->gps_ephemeris_map[gps_eph->PRN] = *gps_eph;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->gps_ephemeris_map[gps_eph->i_satellite_PRN] = *gps_eph;
|
||||
d_user_pvt_solver->gps_ephemeris_map[gps_eph->PRN] = *gps_eph;
|
||||
}
|
||||
}
|
||||
else if (msg_type_hash_code == d_gps_iono_sptr_type_hash_code)
|
||||
@ -1144,13 +1144,13 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
if (d_rinex_output_enabled && d_rp->is_rinex_header_written()) // The header is already written, we can now log the navigation message data
|
||||
{
|
||||
bool new_annotation = false;
|
||||
if (d_internal_pvt_solver->gps_cnav_ephemeris_map.find(gps_cnav_ephemeris->i_satellite_PRN) == d_internal_pvt_solver->gps_cnav_ephemeris_map.cend())
|
||||
if (d_internal_pvt_solver->gps_cnav_ephemeris_map.find(gps_cnav_ephemeris->PRN) == d_internal_pvt_solver->gps_cnav_ephemeris_map.cend())
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (d_internal_pvt_solver->gps_cnav_ephemeris_map[gps_cnav_ephemeris->i_satellite_PRN].d_Toe1 != gps_cnav_ephemeris->d_Toe1)
|
||||
if (d_internal_pvt_solver->gps_cnav_ephemeris_map[gps_cnav_ephemeris->PRN].toe1 != gps_cnav_ephemeris->toe1)
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
@ -1159,14 +1159,14 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
{
|
||||
// New record!
|
||||
std::map<int32_t, Gps_CNAV_Ephemeris> new_cnav_eph;
|
||||
new_cnav_eph[gps_cnav_ephemeris->i_satellite_PRN] = *gps_cnav_ephemeris;
|
||||
new_cnav_eph[gps_cnav_ephemeris->PRN] = *gps_cnav_ephemeris;
|
||||
d_rp->log_rinex_nav_gps_cnav(d_type_of_rx, new_cnav_eph);
|
||||
}
|
||||
}
|
||||
d_internal_pvt_solver->gps_cnav_ephemeris_map[gps_cnav_ephemeris->i_satellite_PRN] = *gps_cnav_ephemeris;
|
||||
d_internal_pvt_solver->gps_cnav_ephemeris_map[gps_cnav_ephemeris->PRN] = *gps_cnav_ephemeris;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->gps_cnav_ephemeris_map[gps_cnav_ephemeris->i_satellite_PRN] = *gps_cnav_ephemeris;
|
||||
d_user_pvt_solver->gps_cnav_ephemeris_map[gps_cnav_ephemeris->PRN] = *gps_cnav_ephemeris;
|
||||
}
|
||||
DLOG(INFO) << "New GPS CNAV ephemeris record has arrived ";
|
||||
}
|
||||
@ -1196,10 +1196,10 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
{
|
||||
// ### GPS ALMANAC ###
|
||||
const auto gps_almanac = boost::any_cast<std::shared_ptr<Gps_Almanac>>(pmt::any_ref(msg));
|
||||
d_internal_pvt_solver->gps_almanac_map[gps_almanac->i_satellite_PRN] = *gps_almanac;
|
||||
d_internal_pvt_solver->gps_almanac_map[gps_almanac->PRN] = *gps_almanac;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->gps_almanac_map[gps_almanac->i_satellite_PRN] = *gps_almanac;
|
||||
d_user_pvt_solver->gps_almanac_map[gps_almanac->PRN] = *gps_almanac;
|
||||
}
|
||||
DLOG(INFO) << "New GPS almanac record has arrived ";
|
||||
}
|
||||
@ -1210,8 +1210,8 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
// ### Galileo EPHEMERIS ###
|
||||
const auto galileo_eph = boost::any_cast<std::shared_ptr<Galileo_Ephemeris>>(pmt::any_ref(msg));
|
||||
// insert new ephemeris record
|
||||
DLOG(INFO) << "Galileo New Ephemeris record inserted in global map with TOW =" << galileo_eph->TOW_5
|
||||
<< ", GALILEO Week Number =" << galileo_eph->WN_5
|
||||
DLOG(INFO) << "Galileo New Ephemeris record inserted in global map with TOW =" << galileo_eph->tow
|
||||
<< ", GALILEO Week Number =" << galileo_eph->WN
|
||||
<< " and Ephemeris IOD = " << galileo_eph->IOD_ephemeris;
|
||||
// todo: Send only new sets of ephemeris (new TOE), not sent to the client
|
||||
// send the new eph to the eph monitor (if enabled)
|
||||
@ -1223,13 +1223,13 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
if (d_rinex_output_enabled && d_rp->is_rinex_header_written()) // The header is already written, we can now log the navigation message data
|
||||
{
|
||||
bool new_annotation = false;
|
||||
if (d_internal_pvt_solver->galileo_ephemeris_map.find(galileo_eph->i_satellite_PRN) == d_internal_pvt_solver->galileo_ephemeris_map.cend())
|
||||
if (d_internal_pvt_solver->galileo_ephemeris_map.find(galileo_eph->PRN) == d_internal_pvt_solver->galileo_ephemeris_map.cend())
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (d_internal_pvt_solver->galileo_ephemeris_map[galileo_eph->i_satellite_PRN].t0e_1 != galileo_eph->t0e_1)
|
||||
if (d_internal_pvt_solver->galileo_ephemeris_map[galileo_eph->PRN].toe != galileo_eph->toe)
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
@ -1238,14 +1238,14 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
{
|
||||
// New record!
|
||||
std::map<int32_t, Galileo_Ephemeris> new_gal_eph;
|
||||
new_gal_eph[galileo_eph->i_satellite_PRN] = *galileo_eph;
|
||||
new_gal_eph[galileo_eph->PRN] = *galileo_eph;
|
||||
d_rp->log_rinex_nav_gal_nav(d_type_of_rx, new_gal_eph);
|
||||
}
|
||||
}
|
||||
d_internal_pvt_solver->galileo_ephemeris_map[galileo_eph->i_satellite_PRN] = *galileo_eph;
|
||||
d_internal_pvt_solver->galileo_ephemeris_map[galileo_eph->PRN] = *galileo_eph;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->galileo_ephemeris_map[galileo_eph->i_satellite_PRN] = *galileo_eph;
|
||||
d_user_pvt_solver->galileo_ephemeris_map[galileo_eph->PRN] = *galileo_eph;
|
||||
}
|
||||
}
|
||||
else if (msg_type_hash_code == d_galileo_iono_sptr_type_hash_code)
|
||||
@ -1278,28 +1278,28 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
const Galileo_Almanac sv2 = galileo_almanac_helper->get_almanac(2);
|
||||
const Galileo_Almanac sv3 = galileo_almanac_helper->get_almanac(3);
|
||||
|
||||
if (sv1.i_satellite_PRN != 0)
|
||||
if (sv1.PRN != 0)
|
||||
{
|
||||
d_internal_pvt_solver->galileo_almanac_map[sv1.i_satellite_PRN] = sv1;
|
||||
d_internal_pvt_solver->galileo_almanac_map[sv1.PRN] = sv1;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->galileo_almanac_map[sv1.i_satellite_PRN] = sv1;
|
||||
d_user_pvt_solver->galileo_almanac_map[sv1.PRN] = sv1;
|
||||
}
|
||||
}
|
||||
if (sv2.i_satellite_PRN != 0)
|
||||
if (sv2.PRN != 0)
|
||||
{
|
||||
d_internal_pvt_solver->galileo_almanac_map[sv2.i_satellite_PRN] = sv2;
|
||||
d_internal_pvt_solver->galileo_almanac_map[sv2.PRN] = sv2;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->galileo_almanac_map[sv2.i_satellite_PRN] = sv2;
|
||||
d_user_pvt_solver->galileo_almanac_map[sv2.PRN] = sv2;
|
||||
}
|
||||
}
|
||||
if (sv3.i_satellite_PRN != 0)
|
||||
if (sv3.PRN != 0)
|
||||
{
|
||||
d_internal_pvt_solver->galileo_almanac_map[sv3.i_satellite_PRN] = sv3;
|
||||
d_internal_pvt_solver->galileo_almanac_map[sv3.PRN] = sv3;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->galileo_almanac_map[sv3.i_satellite_PRN] = sv3;
|
||||
d_user_pvt_solver->galileo_almanac_map[sv3.PRN] = sv3;
|
||||
}
|
||||
}
|
||||
DLOG(INFO) << "New Galileo Almanac data have arrived ";
|
||||
@ -1309,10 +1309,10 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
// ### Galileo Almanac ###
|
||||
const auto galileo_alm = boost::any_cast<std::shared_ptr<Galileo_Almanac>>(pmt::any_ref(msg));
|
||||
// update/insert new almanac record to the global almanac map
|
||||
d_internal_pvt_solver->galileo_almanac_map[galileo_alm->i_satellite_PRN] = *galileo_alm;
|
||||
d_internal_pvt_solver->galileo_almanac_map[galileo_alm->PRN] = *galileo_alm;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->galileo_almanac_map[galileo_alm->i_satellite_PRN] = *galileo_alm;
|
||||
d_user_pvt_solver->galileo_almanac_map[galileo_alm->PRN] = *galileo_alm;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1331,13 +1331,13 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
if (d_rinex_output_enabled && d_rp->is_rinex_header_written()) // The header is already written, we can now log the navigation message data
|
||||
{
|
||||
bool new_annotation = false;
|
||||
if (d_internal_pvt_solver->glonass_gnav_ephemeris_map.find(glonass_gnav_eph->i_satellite_PRN) == d_internal_pvt_solver->glonass_gnav_ephemeris_map.cend())
|
||||
if (d_internal_pvt_solver->glonass_gnav_ephemeris_map.find(glonass_gnav_eph->PRN) == d_internal_pvt_solver->glonass_gnav_ephemeris_map.cend())
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (d_internal_pvt_solver->glonass_gnav_ephemeris_map[glonass_gnav_eph->i_satellite_PRN].d_t_b != glonass_gnav_eph->d_t_b)
|
||||
if (d_internal_pvt_solver->glonass_gnav_ephemeris_map[glonass_gnav_eph->PRN].d_t_b != glonass_gnav_eph->d_t_b)
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
@ -1346,14 +1346,14 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
{
|
||||
// New record!
|
||||
std::map<int32_t, Glonass_Gnav_Ephemeris> new_glo_eph;
|
||||
new_glo_eph[glonass_gnav_eph->i_satellite_PRN] = *glonass_gnav_eph;
|
||||
new_glo_eph[glonass_gnav_eph->PRN] = *glonass_gnav_eph;
|
||||
d_rp->log_rinex_nav_glo_gnav(d_type_of_rx, new_glo_eph);
|
||||
}
|
||||
}
|
||||
d_internal_pvt_solver->glonass_gnav_ephemeris_map[glonass_gnav_eph->i_satellite_PRN] = *glonass_gnav_eph;
|
||||
d_internal_pvt_solver->glonass_gnav_ephemeris_map[glonass_gnav_eph->PRN] = *glonass_gnav_eph;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->glonass_gnav_ephemeris_map[glonass_gnav_eph->i_satellite_PRN] = *glonass_gnav_eph;
|
||||
d_user_pvt_solver->glonass_gnav_ephemeris_map[glonass_gnav_eph->PRN] = *glonass_gnav_eph;
|
||||
}
|
||||
}
|
||||
else if (msg_type_hash_code == d_glonass_gnav_utc_model_sptr_type_hash_code)
|
||||
@ -1386,21 +1386,21 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
// ### Beidou EPHEMERIS ###
|
||||
const auto bds_dnav_eph = boost::any_cast<std::shared_ptr<Beidou_Dnav_Ephemeris>>(pmt::any_ref(msg));
|
||||
DLOG(INFO) << "Ephemeris record has arrived from SAT ID "
|
||||
<< bds_dnav_eph->i_satellite_PRN << " (Block "
|
||||
<< bds_dnav_eph->satelliteBlock[bds_dnav_eph->i_satellite_PRN] << ")"
|
||||
<< "inserted with Toe=" << bds_dnav_eph->d_Toe << " and BDS Week="
|
||||
<< bds_dnav_eph->i_BEIDOU_week;
|
||||
<< bds_dnav_eph->PRN << " (Block "
|
||||
<< bds_dnav_eph->satelliteBlock[bds_dnav_eph->PRN] << ")"
|
||||
<< "inserted with Toe=" << bds_dnav_eph->toe << " and BDS Week="
|
||||
<< bds_dnav_eph->WN;
|
||||
// update/insert new ephemeris record to the global ephemeris map
|
||||
if (d_rinex_output_enabled && d_rp->is_rinex_header_written()) // The header is already written, we can now log the navigation message data
|
||||
{
|
||||
bool new_annotation = false;
|
||||
if (d_internal_pvt_solver->beidou_dnav_ephemeris_map.find(bds_dnav_eph->i_satellite_PRN) == d_internal_pvt_solver->beidou_dnav_ephemeris_map.cend())
|
||||
if (d_internal_pvt_solver->beidou_dnav_ephemeris_map.find(bds_dnav_eph->PRN) == d_internal_pvt_solver->beidou_dnav_ephemeris_map.cend())
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (d_internal_pvt_solver->beidou_dnav_ephemeris_map[bds_dnav_eph->i_satellite_PRN].d_Toc != bds_dnav_eph->d_Toc)
|
||||
if (d_internal_pvt_solver->beidou_dnav_ephemeris_map[bds_dnav_eph->PRN].toc != bds_dnav_eph->toc)
|
||||
{
|
||||
new_annotation = true;
|
||||
}
|
||||
@ -1409,14 +1409,14 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
{
|
||||
// New record!
|
||||
std::map<int32_t, Beidou_Dnav_Ephemeris> new_bds_eph;
|
||||
new_bds_eph[bds_dnav_eph->i_satellite_PRN] = *bds_dnav_eph;
|
||||
new_bds_eph[bds_dnav_eph->PRN] = *bds_dnav_eph;
|
||||
d_rp->log_rinex_nav_bds_dnav(d_type_of_rx, new_bds_eph);
|
||||
}
|
||||
}
|
||||
d_internal_pvt_solver->beidou_dnav_ephemeris_map[bds_dnav_eph->i_satellite_PRN] = *bds_dnav_eph;
|
||||
d_internal_pvt_solver->beidou_dnav_ephemeris_map[bds_dnav_eph->PRN] = *bds_dnav_eph;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->beidou_dnav_ephemeris_map[bds_dnav_eph->i_satellite_PRN] = *bds_dnav_eph;
|
||||
d_user_pvt_solver->beidou_dnav_ephemeris_map[bds_dnav_eph->PRN] = *bds_dnav_eph;
|
||||
}
|
||||
}
|
||||
else if (msg_type_hash_code == d_beidou_dnav_iono_sptr_type_hash_code)
|
||||
@ -1445,10 +1445,10 @@ void rtklib_pvt_gs::msg_handler_telemetry(const pmt::pmt_t& msg)
|
||||
{
|
||||
// ### BeiDou ALMANAC ###
|
||||
const auto bds_dnav_almanac = boost::any_cast<std::shared_ptr<Beidou_Dnav_Almanac>>(pmt::any_ref(msg));
|
||||
d_internal_pvt_solver->beidou_dnav_almanac_map[bds_dnav_almanac->i_satellite_PRN] = *bds_dnav_almanac;
|
||||
d_internal_pvt_solver->beidou_dnav_almanac_map[bds_dnav_almanac->PRN] = *bds_dnav_almanac;
|
||||
if (d_enable_rx_clock_correction == true)
|
||||
{
|
||||
d_user_pvt_solver->beidou_dnav_almanac_map[bds_dnav_almanac->i_satellite_PRN] = *bds_dnav_almanac;
|
||||
d_user_pvt_solver->beidou_dnav_almanac_map[bds_dnav_almanac->PRN] = *bds_dnav_almanac;
|
||||
}
|
||||
DLOG(INFO) << "New BeiDou DNAV almanac record has arrived ";
|
||||
}
|
||||
@ -1834,7 +1834,7 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item
|
||||
|
||||
if (tmp_eph_iter_gps != d_internal_pvt_solver->gps_ephemeris_map.cend())
|
||||
{
|
||||
const uint32_t prn_aux = tmp_eph_iter_gps->second.i_satellite_PRN;
|
||||
const uint32_t prn_aux = tmp_eph_iter_gps->second.PRN;
|
||||
if ((prn_aux == in[i][epoch].PRN) and (std::string(in[i][epoch].Signal) == "1C"))
|
||||
{
|
||||
store_valid_observable = true;
|
||||
@ -1842,7 +1842,7 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item
|
||||
}
|
||||
if (tmp_eph_iter_gal != d_internal_pvt_solver->galileo_ephemeris_map.cend())
|
||||
{
|
||||
const uint32_t prn_aux = tmp_eph_iter_gal->second.i_satellite_PRN;
|
||||
const uint32_t prn_aux = tmp_eph_iter_gal->second.PRN;
|
||||
if ((prn_aux == in[i][epoch].PRN) and ((std::string(in[i][epoch].Signal) == "1B") or (std::string(in[i][epoch].Signal) == "5X") or (std::string(in[i][epoch].Signal) == "7X")))
|
||||
{
|
||||
store_valid_observable = true;
|
||||
@ -1850,7 +1850,7 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item
|
||||
}
|
||||
if (tmp_eph_iter_cnav != d_internal_pvt_solver->gps_cnav_ephemeris_map.cend())
|
||||
{
|
||||
const uint32_t prn_aux = tmp_eph_iter_cnav->second.i_satellite_PRN;
|
||||
const uint32_t prn_aux = tmp_eph_iter_cnav->second.PRN;
|
||||
if ((prn_aux == in[i][epoch].PRN) and ((std::string(in[i][epoch].Signal) == "2S") or (std::string(in[i][epoch].Signal) == "L5")))
|
||||
{
|
||||
store_valid_observable = true;
|
||||
@ -1858,7 +1858,7 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item
|
||||
}
|
||||
if (tmp_eph_iter_glo_gnav != d_internal_pvt_solver->glonass_gnav_ephemeris_map.cend())
|
||||
{
|
||||
const uint32_t prn_aux = tmp_eph_iter_glo_gnav->second.i_satellite_PRN;
|
||||
const uint32_t prn_aux = tmp_eph_iter_glo_gnav->second.PRN;
|
||||
if ((prn_aux == in[i][epoch].PRN) and ((std::string(in[i][epoch].Signal) == "1G") or (std::string(in[i][epoch].Signal) == "2G")))
|
||||
{
|
||||
store_valid_observable = true;
|
||||
@ -1866,7 +1866,7 @@ int rtklib_pvt_gs::work(int noutput_items, gr_vector_const_void_star& input_item
|
||||
}
|
||||
if (tmp_eph_iter_bds_dnav != d_internal_pvt_solver->beidou_dnav_ephemeris_map.cend())
|
||||
{
|
||||
const uint32_t prn_aux = tmp_eph_iter_bds_dnav->second.i_satellite_PRN;
|
||||
const uint32_t prn_aux = tmp_eph_iter_bds_dnav->second.PRN;
|
||||
if ((prn_aux == in[i][epoch].PRN) and ((std::string(in[i][epoch].Signal) == "B1") or (std::string(in[i][epoch].Signal) == "B3")))
|
||||
{
|
||||
store_valid_observable = true;
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -1625,92 +1625,92 @@ int32_t Rtcm::read_MT1019(const std::string& message, Gps_Ephemeris& gps_eph) co
|
||||
}
|
||||
|
||||
// Fill Gps Ephemeris with message data content
|
||||
gps_eph.i_satellite_PRN = static_cast<uint32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 6)));
|
||||
gps_eph.PRN = static_cast<uint32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 6)));
|
||||
index += 6;
|
||||
|
||||
gps_eph.i_GPS_week = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 10)));
|
||||
gps_eph.WN = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 10)));
|
||||
index += 10;
|
||||
|
||||
gps_eph.i_SV_accuracy = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 4)));
|
||||
gps_eph.SV_accuracy = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 4)));
|
||||
index += 4;
|
||||
|
||||
gps_eph.i_code_on_L2 = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 2)));
|
||||
gps_eph.code_on_L2 = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 2)));
|
||||
index += 2;
|
||||
|
||||
gps_eph.d_IDOT = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 14))) * I_DOT_LSB;
|
||||
gps_eph.idot = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 14))) * I_DOT_LSB;
|
||||
index += 14;
|
||||
|
||||
gps_eph.d_IODE_SF2 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 8)));
|
||||
gps_eph.d_IODE_SF3 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 8)));
|
||||
gps_eph.IODE_SF2 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 8)));
|
||||
gps_eph.IODE_SF3 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 8)));
|
||||
index += 8;
|
||||
|
||||
gps_eph.d_Toc = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 16))) * T_OC_LSB;
|
||||
gps_eph.toc = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 16))) * T_OC_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_A_f2 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 8))) * A_F2_LSB;
|
||||
gps_eph.af2 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 8))) * A_F2_LSB;
|
||||
index += 8;
|
||||
|
||||
gps_eph.d_A_f1 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * A_F1_LSB;
|
||||
gps_eph.af1 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * A_F1_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_A_f0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 22))) * A_F0_LSB;
|
||||
gps_eph.af0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 22))) * A_F0_LSB;
|
||||
index += 22;
|
||||
|
||||
gps_eph.d_IODC = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 10)));
|
||||
gps_eph.IODC = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 10)));
|
||||
index += 10;
|
||||
|
||||
gps_eph.d_Crs = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RS_LSB;
|
||||
gps_eph.Crs = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RS_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_Delta_n = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * DELTA_N_LSB;
|
||||
gps_eph.delta_n = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * DELTA_N_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_M_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * M_0_LSB;
|
||||
gps_eph.M_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * M_0_LSB;
|
||||
index += 32;
|
||||
|
||||
gps_eph.d_Cuc = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_UC_LSB;
|
||||
gps_eph.Cuc = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_UC_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_e_eccentricity = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * ECCENTRICITY_LSB;
|
||||
gps_eph.ecc = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * ECCENTRICITY_LSB;
|
||||
index += 32;
|
||||
|
||||
gps_eph.d_Cus = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_US_LSB;
|
||||
gps_eph.Cus = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_US_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_sqrt_A = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * SQRT_A_LSB;
|
||||
gps_eph.sqrtA = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * SQRT_A_LSB;
|
||||
index += 32;
|
||||
|
||||
gps_eph.d_Toe = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 16))) * T_OE_LSB;
|
||||
gps_eph.toe = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 16))) * T_OE_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_Cic = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IC_LSB;
|
||||
gps_eph.Cic = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IC_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_OMEGA0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_0_LSB;
|
||||
gps_eph.OMEGA_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_0_LSB;
|
||||
index += 32;
|
||||
|
||||
gps_eph.d_Cis = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IS_LSB;
|
||||
gps_eph.Cis = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IS_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_i_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * I_0_LSB;
|
||||
gps_eph.i_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * I_0_LSB;
|
||||
index += 32;
|
||||
|
||||
gps_eph.d_Crc = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RC_LSB;
|
||||
gps_eph.Crc = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RC_LSB;
|
||||
index += 16;
|
||||
|
||||
gps_eph.d_OMEGA = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_LSB;
|
||||
gps_eph.omega = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_LSB;
|
||||
index += 32;
|
||||
|
||||
gps_eph.d_OMEGA_DOT = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 24))) * OMEGA_DOT_LSB;
|
||||
gps_eph.OMEGAdot = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 24))) * OMEGA_DOT_LSB;
|
||||
index += 24;
|
||||
|
||||
gps_eph.d_TGD = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 8))) * T_GD_LSB;
|
||||
gps_eph.TGD = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 8))) * T_GD_LSB;
|
||||
index += 8;
|
||||
|
||||
gps_eph.i_SV_health = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 6)));
|
||||
gps_eph.SV_health = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 6)));
|
||||
index += 6;
|
||||
|
||||
gps_eph.b_L2_P_data_flag = static_cast<bool>(Rtcm::bin_to_uint(message_bin.substr(index, 1)));
|
||||
gps_eph.L2_P_data_flag = static_cast<bool>(Rtcm::bin_to_uint(message_bin.substr(index, 1)));
|
||||
index += 1;
|
||||
|
||||
gps_eph.b_fit_interval_flag = static_cast<bool>(Rtcm::bin_to_uint(message_bin.substr(index, 1)));
|
||||
@ -2162,79 +2162,79 @@ int32_t Rtcm::read_MT1045(const std::string& message, Galileo_Ephemeris& gal_eph
|
||||
}
|
||||
|
||||
// Fill Galileo Ephemeris with message data content
|
||||
gal_eph.i_satellite_PRN = static_cast<uint32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 6)));
|
||||
gal_eph.PRN = static_cast<uint32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 6)));
|
||||
index += 6;
|
||||
|
||||
gal_eph.WN_5 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 12)));
|
||||
gal_eph.WN = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 12)));
|
||||
index += 12;
|
||||
|
||||
gal_eph.IOD_nav_1 = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 10)));
|
||||
gal_eph.IOD_nav = static_cast<int32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 10)));
|
||||
index += 10;
|
||||
|
||||
gal_eph.SISA_3 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 8)));
|
||||
gal_eph.SISA = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 8)));
|
||||
index += 8;
|
||||
|
||||
gal_eph.iDot_2 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 14))) * I_DOT_2_LSB;
|
||||
gal_eph.idot = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 14))) * I_DOT_2_LSB;
|
||||
index += 14;
|
||||
|
||||
gal_eph.t0c_4 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 14))) * T0C_4_LSB;
|
||||
gal_eph.toc = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 14))) * T0C_4_LSB;
|
||||
index += 14;
|
||||
|
||||
gal_eph.af2_4 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 6))) * AF2_4_LSB;
|
||||
gal_eph.af2 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 6))) * AF2_4_LSB;
|
||||
index += 6;
|
||||
|
||||
gal_eph.af1_4 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 21))) * AF1_4_LSB;
|
||||
gal_eph.af1 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 21))) * AF1_4_LSB;
|
||||
index += 21;
|
||||
|
||||
gal_eph.af0_4 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 31))) * AF0_4_LSB;
|
||||
gal_eph.af0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 31))) * AF0_4_LSB;
|
||||
index += 31;
|
||||
|
||||
gal_eph.C_rs_3 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RS_3_LSB;
|
||||
gal_eph.Crs = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RS_3_LSB;
|
||||
index += 16;
|
||||
|
||||
gal_eph.delta_n_3 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * DELTA_N_3_LSB;
|
||||
gal_eph.delta_n = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * DELTA_N_3_LSB;
|
||||
index += 16;
|
||||
|
||||
gal_eph.M0_1 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * M0_1_LSB;
|
||||
gal_eph.M_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * M0_1_LSB;
|
||||
index += 32;
|
||||
|
||||
gal_eph.C_uc_3 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_UC_3_LSB;
|
||||
gal_eph.Cuc = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_UC_3_LSB;
|
||||
index += 16;
|
||||
|
||||
gal_eph.e_1 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * E_1_LSB;
|
||||
gal_eph.ecc = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * E_1_LSB;
|
||||
index += 32;
|
||||
|
||||
gal_eph.C_us_3 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_US_3_LSB;
|
||||
gal_eph.Cus = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_US_3_LSB;
|
||||
index += 16;
|
||||
|
||||
gal_eph.A_1 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * A_1_LSB_GAL;
|
||||
gal_eph.sqrtA = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 32))) * A_1_LSB_GAL;
|
||||
index += 32;
|
||||
|
||||
gal_eph.t0e_1 = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 14))) * T0E_1_LSB;
|
||||
gal_eph.toe = static_cast<double>(Rtcm::bin_to_uint(message_bin.substr(index, 14))) * T0E_1_LSB;
|
||||
index += 14;
|
||||
|
||||
gal_eph.C_ic_4 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IC_4_LSB;
|
||||
gal_eph.Cic = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IC_4_LSB;
|
||||
index += 16;
|
||||
|
||||
gal_eph.OMEGA_0_2 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_0_2_LSB;
|
||||
gal_eph.OMEGA_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_0_2_LSB;
|
||||
index += 32;
|
||||
|
||||
gal_eph.C_is_4 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IS_4_LSB;
|
||||
gal_eph.Cis = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_IS_4_LSB;
|
||||
index += 16;
|
||||
|
||||
gal_eph.i_0_2 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * I_0_2_LSB;
|
||||
gal_eph.i_0 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * I_0_2_LSB;
|
||||
index += 32;
|
||||
|
||||
gal_eph.C_rc_3 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RC_3_LSB;
|
||||
gal_eph.Crc = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 16))) * C_RC_3_LSB;
|
||||
index += 16;
|
||||
|
||||
gal_eph.omega_2 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_2_LSB;
|
||||
gal_eph.omega = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 32))) * OMEGA_2_LSB;
|
||||
index += 32;
|
||||
|
||||
gal_eph.OMEGA_dot_3 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 24))) * OMEGA_DOT_3_LSB;
|
||||
gal_eph.OMEGAdot = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 24))) * OMEGA_DOT_3_LSB;
|
||||
index += 24;
|
||||
|
||||
gal_eph.BGD_E1E5a_5 = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 10)));
|
||||
gal_eph.BGD_E1E5a = static_cast<double>(Rtcm::bin_to_int(message_bin.substr(index, 10)));
|
||||
index += 10;
|
||||
|
||||
gal_eph.E5a_HS = static_cast<uint32_t>(Rtcm::bin_to_uint(message_bin.substr(index, 2)));
|
||||
@ -2266,23 +2266,23 @@ std::string Rtcm::print_MSM_1(const Gps_Ephemeris& gps_eph,
|
||||
bool more_messages)
|
||||
{
|
||||
uint32_t msg_number = 0;
|
||||
if (gps_eph.i_satellite_PRN != 0)
|
||||
if (gps_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1071;
|
||||
}
|
||||
if (gps_cnav_eph.i_satellite_PRN != 0)
|
||||
if (gps_cnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1071;
|
||||
}
|
||||
if (glo_gnav_eph.i_satellite_PRN != 0)
|
||||
if (glo_gnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1081;
|
||||
}
|
||||
if (gal_eph.i_satellite_PRN != 0)
|
||||
if (gal_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1091;
|
||||
}
|
||||
if (((gps_eph.i_satellite_PRN != 0) || (gps_cnav_eph.i_satellite_PRN != 0)) && (gal_eph.i_satellite_PRN != 0) && (glo_gnav_eph.i_satellite_PRN != 0))
|
||||
if (((gps_eph.PRN != 0) || (gps_cnav_eph.PRN != 0)) && (gal_eph.PRN != 0) && (glo_gnav_eph.PRN != 0))
|
||||
{
|
||||
LOG(WARNING) << "MSM messages for observables from different systems are not defined"; // print two messages?
|
||||
}
|
||||
@ -2463,23 +2463,23 @@ std::string Rtcm::print_MSM_2(const Gps_Ephemeris& gps_eph,
|
||||
bool more_messages)
|
||||
{
|
||||
uint32_t msg_number = 0;
|
||||
if (gps_eph.i_satellite_PRN != 0)
|
||||
if (gps_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1072;
|
||||
}
|
||||
if (gps_cnav_eph.i_satellite_PRN != 0)
|
||||
if (gps_cnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1072;
|
||||
}
|
||||
if (glo_gnav_eph.i_satellite_PRN != 0)
|
||||
if (glo_gnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1082;
|
||||
}
|
||||
if (gal_eph.i_satellite_PRN != 0)
|
||||
if (gal_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1092;
|
||||
}
|
||||
if (((gps_eph.i_satellite_PRN != 0) || (gps_cnav_eph.i_satellite_PRN != 0)) && (gal_eph.i_satellite_PRN != 0) && (glo_gnav_eph.i_satellite_PRN != 0))
|
||||
if (((gps_eph.PRN != 0) || (gps_cnav_eph.PRN != 0)) && (gal_eph.PRN != 0) && (glo_gnav_eph.PRN != 0))
|
||||
{
|
||||
LOG(WARNING) << "MSM messages for observables from different systems are not defined"; // print two messages?
|
||||
}
|
||||
@ -2577,23 +2577,23 @@ std::string Rtcm::print_MSM_3(const Gps_Ephemeris& gps_eph,
|
||||
bool more_messages)
|
||||
{
|
||||
uint32_t msg_number = 0;
|
||||
if (gps_eph.i_satellite_PRN != 0)
|
||||
if (gps_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1073;
|
||||
}
|
||||
if (gps_cnav_eph.i_satellite_PRN != 0)
|
||||
if (gps_cnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1073;
|
||||
}
|
||||
if (glo_gnav_eph.i_satellite_PRN != 0)
|
||||
if (glo_gnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1083;
|
||||
}
|
||||
if (gal_eph.i_satellite_PRN != 0)
|
||||
if (gal_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1093;
|
||||
}
|
||||
if (((gps_eph.i_satellite_PRN != 0) || (gps_cnav_eph.i_satellite_PRN != 0)) && (gal_eph.i_satellite_PRN != 0) && (glo_gnav_eph.i_satellite_PRN != 0))
|
||||
if (((gps_eph.PRN != 0) || (gps_cnav_eph.PRN != 0)) && (gal_eph.PRN != 0) && (glo_gnav_eph.PRN != 0))
|
||||
{
|
||||
LOG(WARNING) << "MSM messages for observables from different systems are not defined"; // print two messages?
|
||||
}
|
||||
@ -2694,23 +2694,23 @@ std::string Rtcm::print_MSM_4(const Gps_Ephemeris& gps_eph,
|
||||
bool more_messages)
|
||||
{
|
||||
uint32_t msg_number = 0;
|
||||
if (gps_eph.i_satellite_PRN != 0)
|
||||
if (gps_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1074;
|
||||
}
|
||||
if (gps_cnav_eph.i_satellite_PRN != 0)
|
||||
if (gps_cnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1074;
|
||||
}
|
||||
if (glo_gnav_eph.i_satellite_PRN != 0)
|
||||
if (glo_gnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1084;
|
||||
}
|
||||
if (gal_eph.i_satellite_PRN != 0)
|
||||
if (gal_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1094;
|
||||
}
|
||||
if (((gps_eph.i_satellite_PRN != 0) || (gps_cnav_eph.i_satellite_PRN != 0)) && (gal_eph.i_satellite_PRN != 0) && (glo_gnav_eph.i_satellite_PRN != 0))
|
||||
if (((gps_eph.PRN != 0) || (gps_cnav_eph.PRN != 0)) && (gal_eph.PRN != 0) && (glo_gnav_eph.PRN != 0))
|
||||
{
|
||||
LOG(WARNING) << "MSM messages for observables from different systems are not defined"; // print two messages?
|
||||
}
|
||||
@ -2857,23 +2857,23 @@ std::string Rtcm::print_MSM_5(const Gps_Ephemeris& gps_eph,
|
||||
bool more_messages)
|
||||
{
|
||||
uint32_t msg_number = 0;
|
||||
if (gps_eph.i_satellite_PRN != 0)
|
||||
if (gps_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1075;
|
||||
}
|
||||
if (gps_cnav_eph.i_satellite_PRN != 0)
|
||||
if (gps_cnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1075;
|
||||
}
|
||||
if (glo_gnav_eph.i_satellite_PRN != 0)
|
||||
if (glo_gnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1085;
|
||||
}
|
||||
if (gal_eph.i_satellite_PRN != 0)
|
||||
if (gal_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1095;
|
||||
}
|
||||
if (((gps_eph.i_satellite_PRN != 0) || (gps_cnav_eph.i_satellite_PRN != 0)) && (gal_eph.i_satellite_PRN != 0) && (glo_gnav_eph.i_satellite_PRN != 0))
|
||||
if (((gps_eph.PRN != 0) || (gps_cnav_eph.PRN != 0)) && (gal_eph.PRN != 0) && (glo_gnav_eph.PRN != 0))
|
||||
{
|
||||
LOG(WARNING) << "MSM messages for observables from different systems are not defined"; // print two messages?
|
||||
}
|
||||
@ -3029,23 +3029,23 @@ std::string Rtcm::print_MSM_6(const Gps_Ephemeris& gps_eph,
|
||||
bool more_messages)
|
||||
{
|
||||
uint32_t msg_number = 0;
|
||||
if (gps_eph.i_satellite_PRN != 0)
|
||||
if (gps_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1076;
|
||||
}
|
||||
if (gps_cnav_eph.i_satellite_PRN != 0)
|
||||
if (gps_cnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1076;
|
||||
}
|
||||
if (glo_gnav_eph.i_satellite_PRN != 0)
|
||||
if (glo_gnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1086;
|
||||
}
|
||||
if (gal_eph.i_satellite_PRN != 0)
|
||||
if (gal_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1096;
|
||||
}
|
||||
if (((gps_eph.i_satellite_PRN != 0) || (gps_cnav_eph.i_satellite_PRN != 0)) && (gal_eph.i_satellite_PRN != 0) && (glo_gnav_eph.i_satellite_PRN != 0))
|
||||
if (((gps_eph.PRN != 0) || (gps_cnav_eph.PRN != 0)) && (gal_eph.PRN != 0) && (glo_gnav_eph.PRN != 0))
|
||||
{
|
||||
LOG(WARNING) << "MSM messages for observables from different systems are not defined"; // print two messages?
|
||||
}
|
||||
@ -3149,23 +3149,23 @@ std::string Rtcm::print_MSM_7(const Gps_Ephemeris& gps_eph,
|
||||
bool more_messages)
|
||||
{
|
||||
uint32_t msg_number = 0;
|
||||
if (gps_eph.i_satellite_PRN != 0)
|
||||
if (gps_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1077;
|
||||
}
|
||||
if (gps_cnav_eph.i_satellite_PRN != 0)
|
||||
if (gps_cnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1077;
|
||||
}
|
||||
if (glo_gnav_eph.i_satellite_PRN != 0)
|
||||
if (glo_gnav_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1087;
|
||||
}
|
||||
if (gal_eph.i_satellite_PRN != 0)
|
||||
if (gal_eph.PRN != 0)
|
||||
{
|
||||
msg_number = 1097;
|
||||
}
|
||||
if (((gps_eph.i_satellite_PRN != 0) || (gps_cnav_eph.i_satellite_PRN != 0)) && (glo_gnav_eph.i_satellite_PRN != 0) && (gal_eph.i_satellite_PRN != 0))
|
||||
if (((gps_eph.PRN != 0) || (gps_cnav_eph.PRN != 0)) && (glo_gnav_eph.PRN != 0) && (gal_eph.PRN != 0))
|
||||
{
|
||||
LOG(WARNING) << "MSM messages for observables from different systems are not defined"; // print two messages?
|
||||
}
|
||||
@ -3391,9 +3391,9 @@ std::map<std::string, int> Rtcm::galileo_signal_map = [] {
|
||||
boost::posix_time::ptime Rtcm::compute_GPS_time(const Gps_Ephemeris& eph, double obs_time) const
|
||||
{
|
||||
const double gps_t = obs_time;
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<long>((gps_t + 604800 * static_cast<double>(eph.i_GPS_week)) * 1000)); // NOLINT(google-runtime-int)
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<long>((gps_t + 604800 * static_cast<double>(eph.WN)) * 1000)); // NOLINT(google-runtime-int)
|
||||
|
||||
if (eph.i_GPS_week < 512)
|
||||
if (eph.WN < 512)
|
||||
{
|
||||
boost::posix_time::ptime p_time(boost::gregorian::date(2019, 4, 7), t_duration);
|
||||
return p_time;
|
||||
@ -3407,7 +3407,7 @@ boost::posix_time::ptime Rtcm::compute_GPS_time(const Gps_Ephemeris& eph, double
|
||||
boost::posix_time::ptime Rtcm::compute_GPS_time(const Gps_CNAV_Ephemeris& eph, double obs_time) const
|
||||
{
|
||||
const double gps_t = obs_time;
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<long>((gps_t + 604800 * static_cast<double>(eph.i_GPS_week)) * 1000)); // NOLINT(google-runtime-int)
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<long>((gps_t + 604800 * static_cast<double>(eph.WN)) * 1000)); // NOLINT(google-runtime-int)
|
||||
boost::posix_time::ptime p_time(boost::gregorian::date(1999, 8, 22), t_duration);
|
||||
return p_time;
|
||||
}
|
||||
@ -3416,7 +3416,7 @@ boost::posix_time::ptime Rtcm::compute_GPS_time(const Gps_CNAV_Ephemeris& eph, d
|
||||
boost::posix_time::ptime Rtcm::compute_Galileo_time(const Galileo_Ephemeris& eph, double obs_time) const
|
||||
{
|
||||
const double galileo_t = obs_time;
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<long>((galileo_t + 604800 * static_cast<double>(eph.WN_5)) * 1000)); // NOLINT(google-runtime-int)
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<long>((galileo_t + 604800 * static_cast<double>(eph.WN)) * 1000)); // NOLINT(google-runtime-int)
|
||||
boost::posix_time::ptime p_time(boost::gregorian::date(1999, 8, 22), t_duration);
|
||||
return p_time;
|
||||
}
|
||||
@ -3778,7 +3778,7 @@ int32_t Rtcm::set_DF009(const Gnss_Synchro& gnss_synchro)
|
||||
|
||||
int32_t Rtcm::set_DF009(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const uint32_t prn_ = gps_eph.i_satellite_PRN;
|
||||
const uint32_t prn_ = gps_eph.PRN;
|
||||
if (prn_ > 32)
|
||||
{
|
||||
LOG(WARNING) << "GPS satellite ID must be between 1 and 32, but PRN " << prn_ << " was found";
|
||||
@ -4201,9 +4201,9 @@ int32_t Rtcm::set_DF050(const Gnss_Synchro& gnss_synchro)
|
||||
int32_t Rtcm::set_DF051(const Gps_Ephemeris& gps_eph, double obs_time)
|
||||
{
|
||||
const double gps_t = obs_time;
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<int64_t>((gps_t + 604800 * static_cast<double>(gps_eph.i_GPS_week)) * 1000));
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<int64_t>((gps_t + 604800 * static_cast<double>(gps_eph.WN)) * 1000));
|
||||
std::string now_ptime;
|
||||
if (gps_eph.i_GPS_week < 512)
|
||||
if (gps_eph.WN < 512)
|
||||
{
|
||||
boost::posix_time::ptime p_time(boost::gregorian::date(2019, 4, 7), t_duration);
|
||||
now_ptime = to_iso_string(p_time);
|
||||
@ -4224,9 +4224,9 @@ int32_t Rtcm::set_DF051(const Gps_Ephemeris& gps_eph, double obs_time)
|
||||
int32_t Rtcm::set_DF052(const Gps_Ephemeris& gps_eph, double obs_time)
|
||||
{
|
||||
const double gps_t = obs_time;
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<int64_t>((gps_t + 604800 * static_cast<double>(gps_eph.i_GPS_week)) * 1000));
|
||||
const boost::posix_time::time_duration t_duration = boost::posix_time::milliseconds(static_cast<int64_t>((gps_t + 604800 * static_cast<double>(gps_eph.WN)) * 1000));
|
||||
std::string now_ptime;
|
||||
if (gps_eph.i_GPS_week < 512)
|
||||
if (gps_eph.WN < 512)
|
||||
{
|
||||
boost::posix_time::ptime p_time(boost::gregorian::date(2019, 4, 7), t_duration);
|
||||
now_ptime = to_iso_string(p_time);
|
||||
@ -4248,7 +4248,7 @@ int32_t Rtcm::set_DF052(const Gps_Ephemeris& gps_eph, double obs_time)
|
||||
|
||||
int32_t Rtcm::set_DF071(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto iode = static_cast<uint32_t>(gps_eph.d_IODE_SF2);
|
||||
const auto iode = static_cast<uint32_t>(gps_eph.IODE_SF2);
|
||||
DF071 = std::bitset<8>(iode);
|
||||
return 0;
|
||||
}
|
||||
@ -4256,7 +4256,7 @@ int32_t Rtcm::set_DF071(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF076(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto week_number = static_cast<uint32_t>(gps_eph.i_GPS_week);
|
||||
const auto week_number = static_cast<uint32_t>(gps_eph.WN);
|
||||
DF076 = std::bitset<10>(week_number);
|
||||
return 0;
|
||||
}
|
||||
@ -4264,7 +4264,7 @@ int32_t Rtcm::set_DF076(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF077(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto ura = static_cast<uint16_t>(gps_eph.i_SV_accuracy);
|
||||
const auto ura = static_cast<uint16_t>(gps_eph.SV_accuracy);
|
||||
DF077 = std::bitset<4>(ura);
|
||||
return 0;
|
||||
}
|
||||
@ -4272,7 +4272,7 @@ int32_t Rtcm::set_DF077(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF078(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto code_on_L2 = static_cast<uint16_t>(gps_eph.i_code_on_L2);
|
||||
const auto code_on_L2 = static_cast<uint16_t>(gps_eph.code_on_L2);
|
||||
DF078 = std::bitset<2>(code_on_L2);
|
||||
return 0;
|
||||
}
|
||||
@ -4280,7 +4280,7 @@ int32_t Rtcm::set_DF078(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF079(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto idot = static_cast<uint32_t>(std::round(gps_eph.d_IDOT / I_DOT_LSB));
|
||||
const auto idot = static_cast<uint32_t>(std::round(gps_eph.idot / I_DOT_LSB));
|
||||
DF079 = std::bitset<14>(idot);
|
||||
return 0;
|
||||
}
|
||||
@ -4288,7 +4288,7 @@ int32_t Rtcm::set_DF079(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF080(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto iode = static_cast<uint16_t>(gps_eph.d_IODE_SF2);
|
||||
const auto iode = static_cast<uint16_t>(gps_eph.IODE_SF2);
|
||||
DF080 = std::bitset<8>(iode);
|
||||
return 0;
|
||||
}
|
||||
@ -4296,7 +4296,7 @@ int32_t Rtcm::set_DF080(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF081(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto toc = static_cast<uint32_t>(std::round(gps_eph.d_Toc / T_OC_LSB));
|
||||
const auto toc = static_cast<uint32_t>(std::round(gps_eph.toc / T_OC_LSB));
|
||||
DF081 = std::bitset<16>(toc);
|
||||
return 0;
|
||||
}
|
||||
@ -4304,7 +4304,7 @@ int32_t Rtcm::set_DF081(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF082(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto af2 = static_cast<int16_t>(std::round(gps_eph.d_A_f2 / A_F2_LSB));
|
||||
const auto af2 = static_cast<int16_t>(std::round(gps_eph.af2 / A_F2_LSB));
|
||||
DF082 = std::bitset<8>(af2);
|
||||
return 0;
|
||||
}
|
||||
@ -4312,7 +4312,7 @@ int32_t Rtcm::set_DF082(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF083(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto af1 = static_cast<int32_t>(std::round(gps_eph.d_A_f1 / A_F1_LSB));
|
||||
const auto af1 = static_cast<int32_t>(std::round(gps_eph.af1 / A_F1_LSB));
|
||||
DF083 = std::bitset<16>(af1);
|
||||
return 0;
|
||||
}
|
||||
@ -4320,7 +4320,7 @@ int32_t Rtcm::set_DF083(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF084(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto af0 = static_cast<int64_t>(std::round(gps_eph.d_A_f0 / A_F0_LSB));
|
||||
const auto af0 = static_cast<int64_t>(std::round(gps_eph.af0 / A_F0_LSB));
|
||||
DF084 = std::bitset<22>(af0);
|
||||
return 0;
|
||||
}
|
||||
@ -4328,7 +4328,7 @@ int32_t Rtcm::set_DF084(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF085(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto iodc = static_cast<uint32_t>(gps_eph.d_IODC);
|
||||
const auto iodc = static_cast<uint32_t>(gps_eph.IODC);
|
||||
DF085 = std::bitset<10>(iodc);
|
||||
return 0;
|
||||
}
|
||||
@ -4336,7 +4336,7 @@ int32_t Rtcm::set_DF085(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF086(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto crs = static_cast<int32_t>(std::round(gps_eph.d_Crs / C_RS_LSB));
|
||||
const auto crs = static_cast<int32_t>(std::round(gps_eph.Crs / C_RS_LSB));
|
||||
DF086 = std::bitset<16>(crs);
|
||||
return 0;
|
||||
}
|
||||
@ -4344,7 +4344,7 @@ int32_t Rtcm::set_DF086(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF087(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto delta_n = static_cast<int32_t>(std::round(gps_eph.d_Delta_n / DELTA_N_LSB));
|
||||
const auto delta_n = static_cast<int32_t>(std::round(gps_eph.delta_n / DELTA_N_LSB));
|
||||
DF087 = std::bitset<16>(delta_n);
|
||||
return 0;
|
||||
}
|
||||
@ -4352,7 +4352,7 @@ int32_t Rtcm::set_DF087(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF088(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto m0 = static_cast<int64_t>(std::round(gps_eph.d_M_0 / M_0_LSB));
|
||||
const auto m0 = static_cast<int64_t>(std::round(gps_eph.M_0 / M_0_LSB));
|
||||
DF088 = std::bitset<32>(m0);
|
||||
return 0;
|
||||
}
|
||||
@ -4360,14 +4360,14 @@ int32_t Rtcm::set_DF088(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF089(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto cuc = static_cast<int32_t>(std::round(gps_eph.d_Cuc / C_UC_LSB));
|
||||
const auto cuc = static_cast<int32_t>(std::round(gps_eph.Cuc / C_UC_LSB));
|
||||
DF089 = std::bitset<16>(cuc);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int32_t Rtcm::set_DF090(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto ecc = static_cast<uint64_t>(std::round(gps_eph.d_e_eccentricity / ECCENTRICITY_LSB));
|
||||
const auto ecc = static_cast<uint64_t>(std::round(gps_eph.ecc / ECCENTRICITY_LSB));
|
||||
DF090 = std::bitset<32>(ecc);
|
||||
return 0;
|
||||
}
|
||||
@ -4375,7 +4375,7 @@ int32_t Rtcm::set_DF090(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF091(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto cus = static_cast<int32_t>(std::round(gps_eph.d_Cus / C_US_LSB));
|
||||
const auto cus = static_cast<int32_t>(std::round(gps_eph.Cus / C_US_LSB));
|
||||
DF091 = std::bitset<16>(cus);
|
||||
return 0;
|
||||
}
|
||||
@ -4383,7 +4383,7 @@ int32_t Rtcm::set_DF091(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF092(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto sqr_a = static_cast<uint64_t>(std::round(gps_eph.d_sqrt_A / SQRT_A_LSB));
|
||||
const auto sqr_a = static_cast<uint64_t>(std::round(gps_eph.sqrtA / SQRT_A_LSB));
|
||||
DF092 = std::bitset<32>(sqr_a);
|
||||
return 0;
|
||||
}
|
||||
@ -4391,7 +4391,7 @@ int32_t Rtcm::set_DF092(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF093(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto toe = static_cast<uint32_t>(std::round(gps_eph.d_Toe / T_OE_LSB));
|
||||
const auto toe = static_cast<uint32_t>(std::round(gps_eph.toe / T_OE_LSB));
|
||||
DF093 = std::bitset<16>(toe);
|
||||
return 0;
|
||||
}
|
||||
@ -4399,7 +4399,7 @@ int32_t Rtcm::set_DF093(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF094(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto cic = static_cast<int32_t>(std::round(gps_eph.d_Cic / C_IC_LSB));
|
||||
const auto cic = static_cast<int32_t>(std::round(gps_eph.Cic / C_IC_LSB));
|
||||
DF094 = std::bitset<16>(cic);
|
||||
return 0;
|
||||
}
|
||||
@ -4407,7 +4407,7 @@ int32_t Rtcm::set_DF094(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF095(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto Omega0 = static_cast<int64_t>(std::round(gps_eph.d_OMEGA0 / OMEGA_0_LSB));
|
||||
const auto Omega0 = static_cast<int64_t>(std::round(gps_eph.OMEGA_0 / OMEGA_0_LSB));
|
||||
DF095 = std::bitset<32>(Omega0);
|
||||
return 0;
|
||||
}
|
||||
@ -4415,7 +4415,7 @@ int32_t Rtcm::set_DF095(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF096(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto cis = static_cast<int32_t>(std::round(gps_eph.d_Cis / C_IS_LSB));
|
||||
const auto cis = static_cast<int32_t>(std::round(gps_eph.Cis / C_IS_LSB));
|
||||
DF096 = std::bitset<16>(cis);
|
||||
return 0;
|
||||
}
|
||||
@ -4423,7 +4423,7 @@ int32_t Rtcm::set_DF096(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF097(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto i0 = static_cast<int64_t>(std::round(gps_eph.d_i_0 / I_0_LSB));
|
||||
const auto i0 = static_cast<int64_t>(std::round(gps_eph.i_0 / I_0_LSB));
|
||||
DF097 = std::bitset<32>(i0);
|
||||
return 0;
|
||||
}
|
||||
@ -4431,7 +4431,7 @@ int32_t Rtcm::set_DF097(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF098(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto crc = static_cast<int32_t>(std::round(gps_eph.d_Crc / C_RC_LSB));
|
||||
const auto crc = static_cast<int32_t>(std::round(gps_eph.Crc / C_RC_LSB));
|
||||
DF098 = std::bitset<16>(crc);
|
||||
return 0;
|
||||
}
|
||||
@ -4439,7 +4439,7 @@ int32_t Rtcm::set_DF098(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF099(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto omega = static_cast<int64_t>(std::round(gps_eph.d_OMEGA / OMEGA_LSB));
|
||||
const auto omega = static_cast<int64_t>(std::round(gps_eph.omega / OMEGA_LSB));
|
||||
DF099 = std::bitset<32>(omega);
|
||||
return 0;
|
||||
}
|
||||
@ -4447,7 +4447,7 @@ int32_t Rtcm::set_DF099(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF100(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto omegadot = static_cast<int64_t>(std::round(gps_eph.d_OMEGA_DOT / OMEGA_DOT_LSB));
|
||||
const auto omegadot = static_cast<int64_t>(std::round(gps_eph.OMEGAdot / OMEGA_DOT_LSB));
|
||||
DF100 = std::bitset<24>(omegadot);
|
||||
return 0;
|
||||
}
|
||||
@ -4455,7 +4455,7 @@ int32_t Rtcm::set_DF100(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF101(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto tgd = static_cast<int16_t>(std::round(gps_eph.d_TGD / T_GD_LSB));
|
||||
const auto tgd = static_cast<int16_t>(std::round(gps_eph.TGD / T_GD_LSB));
|
||||
DF101 = std::bitset<8>(tgd);
|
||||
return 0;
|
||||
}
|
||||
@ -4463,7 +4463,7 @@ int32_t Rtcm::set_DF101(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF102(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
const auto sv_heath = static_cast<uint16_t>(gps_eph.i_SV_health);
|
||||
const auto sv_heath = static_cast<uint16_t>(gps_eph.SV_health);
|
||||
DF102 = std::bitset<6>(sv_heath);
|
||||
return 0;
|
||||
}
|
||||
@ -4471,7 +4471,7 @@ int32_t Rtcm::set_DF102(const Gps_Ephemeris& gps_eph)
|
||||
|
||||
int32_t Rtcm::set_DF103(const Gps_Ephemeris& gps_eph)
|
||||
{
|
||||
DF103 = std::bitset<1>(gps_eph.b_L2_P_data_flag);
|
||||
DF103 = std::bitset<1>(gps_eph.L2_P_data_flag);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -4810,7 +4810,7 @@ int32_t Rtcm::set_DF248(double obs_time)
|
||||
|
||||
int32_t Rtcm::set_DF252(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const uint32_t prn_ = gal_eph.i_satellite_PRN;
|
||||
const uint32_t prn_ = gal_eph.PRN;
|
||||
if (prn_ > 63)
|
||||
{
|
||||
LOG(WARNING) << "Galileo satellite ID must be between 0 and 63, but PRN " << prn_ << " was found";
|
||||
@ -4822,7 +4822,7 @@ int32_t Rtcm::set_DF252(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF289(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto galileo_week_number = static_cast<uint32_t>(gal_eph.WN_5);
|
||||
const auto galileo_week_number = static_cast<uint32_t>(gal_eph.WN);
|
||||
if (galileo_week_number > 4095)
|
||||
{
|
||||
LOG(WARNING) << "Error decoding Galileo week number (it has a 4096 roll-off, but " << galileo_week_number << " was detected)";
|
||||
@ -4834,7 +4834,7 @@ int32_t Rtcm::set_DF289(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF290(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto iod_nav = static_cast<uint32_t>(gal_eph.IOD_nav_1);
|
||||
const auto iod_nav = static_cast<uint32_t>(gal_eph.IOD_nav);
|
||||
if (iod_nav > 1023)
|
||||
{
|
||||
LOG(WARNING) << "Error decoding Galileo IODnav (it has a max of 1023, but " << iod_nav << " was detected)";
|
||||
@ -4846,7 +4846,7 @@ int32_t Rtcm::set_DF290(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF291(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto SISA = static_cast<uint16_t>(gal_eph.SISA_3);
|
||||
const auto SISA = static_cast<uint16_t>(gal_eph.SISA);
|
||||
// SISA = 0; // SIS Accuracy, data content definition not given in Galileo OS SIS ICD, Issue 1.1, Sept 2010
|
||||
DF291 = std::bitset<8>(SISA);
|
||||
return 0;
|
||||
@ -4855,7 +4855,7 @@ int32_t Rtcm::set_DF291(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF292(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto idot = static_cast<int32_t>(std::round(gal_eph.iDot_2 / FNAV_IDOT_2_LSB));
|
||||
const auto idot = static_cast<int32_t>(std::round(gal_eph.idot / FNAV_IDOT_2_LSB));
|
||||
DF292 = std::bitset<14>(idot);
|
||||
return 0;
|
||||
}
|
||||
@ -4863,7 +4863,7 @@ int32_t Rtcm::set_DF292(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF293(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto toc = static_cast<uint32_t>(gal_eph.t0c_4);
|
||||
const auto toc = static_cast<uint32_t>(gal_eph.toc);
|
||||
if (toc > 604740)
|
||||
{
|
||||
LOG(WARNING) << "Error decoding Galileo ephemeris time (max of 604740, but " << toc << " was detected)";
|
||||
@ -4875,7 +4875,7 @@ int32_t Rtcm::set_DF293(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF294(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto af2 = static_cast<int16_t>(std::round(gal_eph.af2_4 / FNAV_AF2_1_LSB));
|
||||
const auto af2 = static_cast<int16_t>(std::round(gal_eph.af2 / FNAV_AF2_1_LSB));
|
||||
DF294 = std::bitset<6>(af2);
|
||||
return 0;
|
||||
}
|
||||
@ -4883,7 +4883,7 @@ int32_t Rtcm::set_DF294(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF295(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto af1 = static_cast<int64_t>(std::round(gal_eph.af1_4 / FNAV_AF1_1_LSB));
|
||||
const auto af1 = static_cast<int64_t>(std::round(gal_eph.af1 / FNAV_AF1_1_LSB));
|
||||
DF295 = std::bitset<21>(af1);
|
||||
return 0;
|
||||
}
|
||||
@ -4891,7 +4891,7 @@ int32_t Rtcm::set_DF295(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF296(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const int64_t af0 = static_cast<uint32_t>(std::round(gal_eph.af0_4 / FNAV_AF0_1_LSB));
|
||||
const int64_t af0 = static_cast<uint32_t>(std::round(gal_eph.af0 / FNAV_AF0_1_LSB));
|
||||
DF296 = std::bitset<31>(af0);
|
||||
return 0;
|
||||
}
|
||||
@ -4899,7 +4899,7 @@ int32_t Rtcm::set_DF296(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF297(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto crs = static_cast<int32_t>(std::round(gal_eph.C_rs_3 / FNAV_CRS_3_LSB));
|
||||
const auto crs = static_cast<int32_t>(std::round(gal_eph.Crs / FNAV_CRS_3_LSB));
|
||||
DF297 = std::bitset<16>(crs);
|
||||
return 0;
|
||||
}
|
||||
@ -4907,7 +4907,7 @@ int32_t Rtcm::set_DF297(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF298(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto delta_n = static_cast<int32_t>(std::round(gal_eph.delta_n_3 / FNAV_DELTAN_3_LSB));
|
||||
const auto delta_n = static_cast<int32_t>(std::round(gal_eph.delta_n / FNAV_DELTAN_3_LSB));
|
||||
DF298 = std::bitset<16>(delta_n);
|
||||
return 0;
|
||||
}
|
||||
@ -4915,7 +4915,7 @@ int32_t Rtcm::set_DF298(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF299(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto m0 = static_cast<int64_t>(std::round(gal_eph.M0_1 / FNAV_M0_2_LSB));
|
||||
const auto m0 = static_cast<int64_t>(std::round(gal_eph.M_0 / FNAV_M0_2_LSB));
|
||||
DF299 = std::bitset<32>(m0);
|
||||
return 0;
|
||||
}
|
||||
@ -4923,7 +4923,7 @@ int32_t Rtcm::set_DF299(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF300(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const int32_t cuc = static_cast<uint32_t>(std::round(gal_eph.C_uc_3 / FNAV_CUC_3_LSB));
|
||||
const int32_t cuc = static_cast<uint32_t>(std::round(gal_eph.Cuc / FNAV_CUC_3_LSB));
|
||||
DF300 = std::bitset<16>(cuc);
|
||||
return 0;
|
||||
}
|
||||
@ -4931,7 +4931,7 @@ int32_t Rtcm::set_DF300(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF301(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto ecc = static_cast<uint64_t>(std::round(gal_eph.e_1 / FNAV_E_2_LSB));
|
||||
const auto ecc = static_cast<uint64_t>(std::round(gal_eph.ecc / FNAV_E_2_LSB));
|
||||
DF301 = std::bitset<32>(ecc);
|
||||
return 0;
|
||||
}
|
||||
@ -4939,7 +4939,7 @@ int32_t Rtcm::set_DF301(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF302(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto cus = static_cast<int32_t>(std::round(gal_eph.C_us_3 / FNAV_CUS_3_LSB));
|
||||
const auto cus = static_cast<int32_t>(std::round(gal_eph.Cus / FNAV_CUS_3_LSB));
|
||||
DF302 = std::bitset<16>(cus);
|
||||
return 0;
|
||||
}
|
||||
@ -4947,7 +4947,7 @@ int32_t Rtcm::set_DF302(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF303(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto sqr_a = static_cast<uint64_t>(std::round(gal_eph.A_1 / FNAV_A12_2_LSB));
|
||||
const auto sqr_a = static_cast<uint64_t>(std::round(gal_eph.sqrtA / FNAV_A12_2_LSB));
|
||||
DF303 = std::bitset<32>(sqr_a);
|
||||
return 0;
|
||||
}
|
||||
@ -4955,7 +4955,7 @@ int32_t Rtcm::set_DF303(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF304(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto toe = static_cast<uint32_t>(std::round(gal_eph.t0e_1 / FNAV_T0E_3_LSB));
|
||||
const auto toe = static_cast<uint32_t>(std::round(gal_eph.toe / FNAV_T0E_3_LSB));
|
||||
DF304 = std::bitset<14>(toe);
|
||||
return 0;
|
||||
}
|
||||
@ -4963,7 +4963,7 @@ int32_t Rtcm::set_DF304(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF305(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto cic = static_cast<int32_t>(std::round(gal_eph.C_ic_4 / FNAV_CIC_4_LSB));
|
||||
const auto cic = static_cast<int32_t>(std::round(gal_eph.Cic / FNAV_CIC_4_LSB));
|
||||
DF305 = std::bitset<16>(cic);
|
||||
return 0;
|
||||
}
|
||||
@ -4971,7 +4971,7 @@ int32_t Rtcm::set_DF305(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF306(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto Omega0 = static_cast<int64_t>(std::round(gal_eph.OMEGA_0_2 / FNAV_OMEGA0_2_LSB));
|
||||
const auto Omega0 = static_cast<int64_t>(std::round(gal_eph.OMEGA_0 / FNAV_OMEGA0_2_LSB));
|
||||
DF306 = std::bitset<32>(Omega0);
|
||||
return 0;
|
||||
}
|
||||
@ -4979,7 +4979,7 @@ int32_t Rtcm::set_DF306(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF307(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto cis = static_cast<int32_t>(std::round(gal_eph.C_is_4 / FNAV_CIS_4_LSB));
|
||||
const auto cis = static_cast<int32_t>(std::round(gal_eph.Cis / FNAV_CIS_4_LSB));
|
||||
DF307 = std::bitset<16>(cis);
|
||||
return 0;
|
||||
}
|
||||
@ -4987,7 +4987,7 @@ int32_t Rtcm::set_DF307(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF308(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto i0 = static_cast<int64_t>(std::round(gal_eph.i_0_2 / FNAV_I0_3_LSB));
|
||||
const auto i0 = static_cast<int64_t>(std::round(gal_eph.i_0 / FNAV_I0_3_LSB));
|
||||
DF308 = std::bitset<32>(i0);
|
||||
return 0;
|
||||
}
|
||||
@ -4995,7 +4995,7 @@ int32_t Rtcm::set_DF308(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF309(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const int32_t crc = static_cast<uint32_t>(std::round(gal_eph.C_rc_3 / FNAV_CRC_3_LSB));
|
||||
const int32_t crc = static_cast<uint32_t>(std::round(gal_eph.Crc / FNAV_CRC_3_LSB));
|
||||
DF309 = std::bitset<16>(crc);
|
||||
return 0;
|
||||
}
|
||||
@ -5003,7 +5003,7 @@ int32_t Rtcm::set_DF309(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF310(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto omega = static_cast<int32_t>(std::round(gal_eph.omega_2 / FNAV_OMEGA0_2_LSB));
|
||||
const auto omega = static_cast<int32_t>(std::round(gal_eph.omega / FNAV_OMEGA0_2_LSB));
|
||||
DF310 = std::bitset<32>(omega);
|
||||
return 0;
|
||||
}
|
||||
@ -5011,7 +5011,7 @@ int32_t Rtcm::set_DF310(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF311(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto Omegadot = static_cast<int64_t>(std::round(gal_eph.OMEGA_dot_3 / FNAV_OMEGADOT_2_LSB));
|
||||
const auto Omegadot = static_cast<int64_t>(std::round(gal_eph.OMEGAdot / FNAV_OMEGADOT_2_LSB));
|
||||
DF311 = std::bitset<24>(Omegadot);
|
||||
return 0;
|
||||
}
|
||||
@ -5019,7 +5019,7 @@ int32_t Rtcm::set_DF311(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF312(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto bdg_E1_E5a = static_cast<int32_t>(std::round(gal_eph.BGD_E1E5a_5 / FNAV_BGD_1_LSB));
|
||||
const auto bdg_E1_E5a = static_cast<int32_t>(std::round(gal_eph.BGD_E1E5a / FNAV_BGD_1_LSB));
|
||||
DF312 = std::bitset<10>(bdg_E1_E5a);
|
||||
return 0;
|
||||
}
|
||||
@ -5027,7 +5027,7 @@ int32_t Rtcm::set_DF312(const Galileo_Ephemeris& gal_eph)
|
||||
|
||||
int32_t Rtcm::set_DF313(const Galileo_Ephemeris& gal_eph)
|
||||
{
|
||||
const auto bdg_E5b_E1 = static_cast<uint32_t>(std::round(gal_eph.BGD_E1E5b_5));
|
||||
const auto bdg_E5b_E1 = static_cast<uint32_t>(std::round(gal_eph.BGD_E1E5b));
|
||||
// bdg_E5b_E1 = 0; // reserved
|
||||
DF313 = std::bitset<10>(bdg_E5b_E1);
|
||||
return 0;
|
||||
|
@ -457,7 +457,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
obsd_t newobs{};
|
||||
obs_data[valid_obs + glo_valid_obs] = insert_obs_to_rtklib(newobs,
|
||||
gnss_observables_iter->second,
|
||||
galileo_ephemeris_iter->second.WN_5,
|
||||
galileo_ephemeris_iter->second.WN,
|
||||
0);
|
||||
valid_obs++;
|
||||
}
|
||||
@ -481,7 +481,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
{
|
||||
obs_data[i + glo_valid_obs] = insert_obs_to_rtklib(obs_data[i + glo_valid_obs],
|
||||
gnss_observables_iter->second,
|
||||
galileo_ephemeris_iter->second.WN_5,
|
||||
galileo_ephemeris_iter->second.WN,
|
||||
2); // Band 3 (L5/E5)
|
||||
found_E1_obs = true;
|
||||
break;
|
||||
@ -499,7 +499,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
{}, {0.0, 0.0, 0.0}, {}};
|
||||
obs_data[valid_obs + glo_valid_obs] = insert_obs_to_rtklib(newobs,
|
||||
gnss_observables_iter->second,
|
||||
galileo_ephemeris_iter->second.WN_5,
|
||||
galileo_ephemeris_iter->second.WN,
|
||||
2); // Band 3 (L5/E5)
|
||||
valid_obs++;
|
||||
}
|
||||
@ -527,7 +527,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
obsd_t newobs{};
|
||||
obs_data[valid_obs + glo_valid_obs] = insert_obs_to_rtklib(newobs,
|
||||
gnss_observables_iter->second,
|
||||
gps_ephemeris_iter->second.i_GPS_week,
|
||||
gps_ephemeris_iter->second.WN,
|
||||
0,
|
||||
this->is_pre_2009());
|
||||
valid_obs++;
|
||||
@ -576,7 +576,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
{}, {0.0, 0.0, 0.0}, {}};
|
||||
obs_data[valid_obs + glo_valid_obs] = insert_obs_to_rtklib(newobs,
|
||||
gnss_observables_iter->second,
|
||||
gps_cnav_ephemeris_iter->second.i_GPS_week,
|
||||
gps_cnav_ephemeris_iter->second.WN,
|
||||
1); // Band 2 (L2)
|
||||
valid_obs++;
|
||||
}
|
||||
@ -605,7 +605,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
eph_data[i] = eph_to_rtklib(gps_cnav_ephemeris_iter->second);
|
||||
obs_data[i + glo_valid_obs] = insert_obs_to_rtklib(obs_data[i],
|
||||
gnss_observables_iter->second,
|
||||
gps_cnav_ephemeris_iter->second.i_GPS_week,
|
||||
gps_cnav_ephemeris_iter->second.WN,
|
||||
2); // Band 3 (L5)
|
||||
break;
|
||||
}
|
||||
@ -623,7 +623,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
{}, {0.0, 0.0, 0.0}, {}};
|
||||
obs_data[valid_obs + glo_valid_obs] = insert_obs_to_rtklib(newobs,
|
||||
gnss_observables_iter->second,
|
||||
gps_cnav_ephemeris_iter->second.i_GPS_week,
|
||||
gps_cnav_ephemeris_iter->second.WN,
|
||||
2); // Band 3 (L5)
|
||||
valid_obs++;
|
||||
}
|
||||
@ -717,7 +717,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
obsd_t newobs{};
|
||||
obs_data[valid_obs + glo_valid_obs] = insert_obs_to_rtklib(newobs,
|
||||
gnss_observables_iter->second,
|
||||
beidou_ephemeris_iter->second.i_BEIDOU_week + BEIDOU_DNAV_BDT2GPST_WEEK_NUM_OFFSET,
|
||||
beidou_ephemeris_iter->second.WN + BEIDOU_DNAV_BDT2GPST_WEEK_NUM_OFFSET,
|
||||
0);
|
||||
valid_obs++;
|
||||
}
|
||||
@ -739,7 +739,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
{
|
||||
obs_data[i + glo_valid_obs] = insert_obs_to_rtklib(obs_data[i + glo_valid_obs],
|
||||
gnss_observables_iter->second,
|
||||
beidou_ephemeris_iter->second.i_BEIDOU_week + BEIDOU_DNAV_BDT2GPST_WEEK_NUM_OFFSET,
|
||||
beidou_ephemeris_iter->second.WN + BEIDOU_DNAV_BDT2GPST_WEEK_NUM_OFFSET,
|
||||
2); // Band 3 (L2/G2/B3)
|
||||
found_B1I_obs = true;
|
||||
break;
|
||||
@ -757,7 +757,7 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
{}, {0.0, 0.0, 0.0}, {}};
|
||||
obs_data[valid_obs + glo_valid_obs] = insert_obs_to_rtklib(newobs,
|
||||
gnss_observables_iter->second,
|
||||
beidou_ephemeris_iter->second.i_BEIDOU_week + BEIDOU_DNAV_BDT2GPST_WEEK_NUM_OFFSET,
|
||||
beidou_ephemeris_iter->second.WN + BEIDOU_DNAV_BDT2GPST_WEEK_NUM_OFFSET,
|
||||
2); // Band 2 (L2/G2)
|
||||
valid_obs++;
|
||||
}
|
||||
@ -791,59 +791,59 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
nav_data.ng = glo_valid_obs;
|
||||
if (gps_iono.valid)
|
||||
{
|
||||
nav_data.ion_gps[0] = gps_iono.d_alpha0;
|
||||
nav_data.ion_gps[1] = gps_iono.d_alpha1;
|
||||
nav_data.ion_gps[2] = gps_iono.d_alpha2;
|
||||
nav_data.ion_gps[3] = gps_iono.d_alpha3;
|
||||
nav_data.ion_gps[4] = gps_iono.d_beta0;
|
||||
nav_data.ion_gps[5] = gps_iono.d_beta1;
|
||||
nav_data.ion_gps[6] = gps_iono.d_beta2;
|
||||
nav_data.ion_gps[7] = gps_iono.d_beta3;
|
||||
nav_data.ion_gps[0] = gps_iono.alpha0;
|
||||
nav_data.ion_gps[1] = gps_iono.alpha1;
|
||||
nav_data.ion_gps[2] = gps_iono.alpha2;
|
||||
nav_data.ion_gps[3] = gps_iono.alpha3;
|
||||
nav_data.ion_gps[4] = gps_iono.beta0;
|
||||
nav_data.ion_gps[5] = gps_iono.beta1;
|
||||
nav_data.ion_gps[6] = gps_iono.beta2;
|
||||
nav_data.ion_gps[7] = gps_iono.beta3;
|
||||
}
|
||||
if (!(gps_iono.valid) and gps_cnav_iono.valid)
|
||||
{
|
||||
nav_data.ion_gps[0] = gps_cnav_iono.d_alpha0;
|
||||
nav_data.ion_gps[1] = gps_cnav_iono.d_alpha1;
|
||||
nav_data.ion_gps[2] = gps_cnav_iono.d_alpha2;
|
||||
nav_data.ion_gps[3] = gps_cnav_iono.d_alpha3;
|
||||
nav_data.ion_gps[4] = gps_cnav_iono.d_beta0;
|
||||
nav_data.ion_gps[5] = gps_cnav_iono.d_beta1;
|
||||
nav_data.ion_gps[6] = gps_cnav_iono.d_beta2;
|
||||
nav_data.ion_gps[7] = gps_cnav_iono.d_beta3;
|
||||
nav_data.ion_gps[0] = gps_cnav_iono.alpha0;
|
||||
nav_data.ion_gps[1] = gps_cnav_iono.alpha1;
|
||||
nav_data.ion_gps[2] = gps_cnav_iono.alpha2;
|
||||
nav_data.ion_gps[3] = gps_cnav_iono.alpha3;
|
||||
nav_data.ion_gps[4] = gps_cnav_iono.beta0;
|
||||
nav_data.ion_gps[5] = gps_cnav_iono.beta1;
|
||||
nav_data.ion_gps[6] = gps_cnav_iono.beta2;
|
||||
nav_data.ion_gps[7] = gps_cnav_iono.beta3;
|
||||
}
|
||||
if (galileo_iono.ai0_5 != 0.0)
|
||||
if (galileo_iono.ai0 != 0.0)
|
||||
{
|
||||
nav_data.ion_gal[0] = galileo_iono.ai0_5;
|
||||
nav_data.ion_gal[1] = galileo_iono.ai1_5;
|
||||
nav_data.ion_gal[2] = galileo_iono.ai2_5;
|
||||
nav_data.ion_gal[0] = galileo_iono.ai0;
|
||||
nav_data.ion_gal[1] = galileo_iono.ai1;
|
||||
nav_data.ion_gal[2] = galileo_iono.ai2;
|
||||
nav_data.ion_gal[3] = 0.0;
|
||||
}
|
||||
if (beidou_dnav_iono.valid)
|
||||
{
|
||||
nav_data.ion_cmp[0] = beidou_dnav_iono.d_alpha0;
|
||||
nav_data.ion_cmp[1] = beidou_dnav_iono.d_alpha1;
|
||||
nav_data.ion_cmp[2] = beidou_dnav_iono.d_alpha2;
|
||||
nav_data.ion_cmp[3] = beidou_dnav_iono.d_alpha3;
|
||||
nav_data.ion_cmp[4] = beidou_dnav_iono.d_beta0;
|
||||
nav_data.ion_cmp[5] = beidou_dnav_iono.d_beta0;
|
||||
nav_data.ion_cmp[6] = beidou_dnav_iono.d_beta0;
|
||||
nav_data.ion_cmp[7] = beidou_dnav_iono.d_beta3;
|
||||
nav_data.ion_cmp[0] = beidou_dnav_iono.alpha0;
|
||||
nav_data.ion_cmp[1] = beidou_dnav_iono.alpha1;
|
||||
nav_data.ion_cmp[2] = beidou_dnav_iono.alpha2;
|
||||
nav_data.ion_cmp[3] = beidou_dnav_iono.alpha3;
|
||||
nav_data.ion_cmp[4] = beidou_dnav_iono.beta0;
|
||||
nav_data.ion_cmp[5] = beidou_dnav_iono.beta0;
|
||||
nav_data.ion_cmp[6] = beidou_dnav_iono.beta0;
|
||||
nav_data.ion_cmp[7] = beidou_dnav_iono.beta3;
|
||||
}
|
||||
if (gps_utc_model.valid)
|
||||
{
|
||||
nav_data.utc_gps[0] = gps_utc_model.d_A0;
|
||||
nav_data.utc_gps[1] = gps_utc_model.d_A1;
|
||||
nav_data.utc_gps[2] = gps_utc_model.d_t_OT;
|
||||
nav_data.utc_gps[3] = gps_utc_model.i_WN_T;
|
||||
nav_data.leaps = gps_utc_model.d_DeltaT_LS;
|
||||
nav_data.utc_gps[0] = gps_utc_model.A0;
|
||||
nav_data.utc_gps[1] = gps_utc_model.A1;
|
||||
nav_data.utc_gps[2] = gps_utc_model.tot;
|
||||
nav_data.utc_gps[3] = gps_utc_model.WN_T;
|
||||
nav_data.leaps = gps_utc_model.DeltaT_LS;
|
||||
}
|
||||
if (!(gps_utc_model.valid) and gps_cnav_utc_model.valid)
|
||||
{
|
||||
nav_data.utc_gps[0] = gps_cnav_utc_model.d_A0;
|
||||
nav_data.utc_gps[1] = gps_cnav_utc_model.d_A1;
|
||||
nav_data.utc_gps[2] = gps_cnav_utc_model.d_t_OT;
|
||||
nav_data.utc_gps[3] = gps_cnav_utc_model.i_WN_T;
|
||||
nav_data.leaps = gps_cnav_utc_model.d_DeltaT_LS;
|
||||
nav_data.utc_gps[0] = gps_cnav_utc_model.A0;
|
||||
nav_data.utc_gps[1] = gps_cnav_utc_model.A1;
|
||||
nav_data.utc_gps[2] = gps_cnav_utc_model.tot;
|
||||
nav_data.utc_gps[3] = gps_cnav_utc_model.WN_T;
|
||||
nav_data.leaps = gps_cnav_utc_model.DeltaT_LS;
|
||||
}
|
||||
if (glonass_gnav_utc_model.valid)
|
||||
{
|
||||
@ -852,21 +852,21 @@ bool Rtklib_Solver::get_PVT(const std::map<int, Gnss_Synchro> &gnss_observables_
|
||||
nav_data.utc_glo[2] = 0.0; // ??
|
||||
nav_data.utc_glo[3] = 0.0; // ??
|
||||
}
|
||||
if (galileo_utc_model.A0_6 != 0.0)
|
||||
if (galileo_utc_model.A0 != 0.0)
|
||||
{
|
||||
nav_data.utc_gal[0] = galileo_utc_model.A0_6;
|
||||
nav_data.utc_gal[1] = galileo_utc_model.A1_6;
|
||||
nav_data.utc_gal[2] = galileo_utc_model.t0t_6;
|
||||
nav_data.utc_gal[3] = galileo_utc_model.WNot_6;
|
||||
nav_data.leaps = galileo_utc_model.Delta_tLS_6;
|
||||
nav_data.utc_gal[0] = galileo_utc_model.A0;
|
||||
nav_data.utc_gal[1] = galileo_utc_model.A1;
|
||||
nav_data.utc_gal[2] = galileo_utc_model.tot;
|
||||
nav_data.utc_gal[3] = galileo_utc_model.WNot;
|
||||
nav_data.leaps = galileo_utc_model.Delta_tLS;
|
||||
}
|
||||
if (beidou_dnav_utc_model.valid)
|
||||
{
|
||||
nav_data.utc_cmp[0] = beidou_dnav_utc_model.d_A0_UTC;
|
||||
nav_data.utc_cmp[1] = beidou_dnav_utc_model.d_A1_UTC;
|
||||
nav_data.utc_cmp[0] = beidou_dnav_utc_model.A0_UTC;
|
||||
nav_data.utc_cmp[1] = beidou_dnav_utc_model.A1_UTC;
|
||||
nav_data.utc_cmp[2] = 0.0; // ??
|
||||
nav_data.utc_cmp[3] = 0.0; // ??
|
||||
nav_data.leaps = beidou_dnav_utc_model.i_DeltaT_LS;
|
||||
nav_data.leaps = beidou_dnav_utc_model.DeltaT_LS;
|
||||
}
|
||||
|
||||
/* update carrier wave length using native function call in RTKlib */
|
||||
|
@ -80,50 +80,50 @@ public:
|
||||
|
||||
std::string data;
|
||||
|
||||
monitor_.set_i_satellite_prn(monitor->i_satellite_PRN);
|
||||
monitor_.set_i_satellite_prn(monitor->PRN);
|
||||
monitor_.set_iod_ephemeris(monitor->IOD_ephemeris);
|
||||
monitor_.set_iod_nav_1(monitor->IOD_nav_1);
|
||||
monitor_.set_m0_1(monitor->M0_1); //!< Mean anomaly at reference time [semi-circles]
|
||||
monitor_.set_delta_n_3(monitor->delta_n_3); //!< Mean motion difference from computed value [semi-circles/sec]
|
||||
monitor_.set_e_1(monitor->e_1); //!< Eccentricity
|
||||
monitor_.set_a_1(monitor->A_1); //!< Square root of the semi-major axis [meters^1/2]
|
||||
monitor_.set_omega_0_2(monitor->OMEGA_0_2); //!< Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
monitor_.set_i_0_2(monitor->i_0_2); //!< Inclination angle at reference time [semi-circles]
|
||||
monitor_.set_omega_2(monitor->omega_2); //!< Argument of perigee [semi-circles]
|
||||
monitor_.set_omega_dot_3(monitor->OMEGA_dot_3); //!< Rate of right ascension [semi-circles/sec]
|
||||
monitor_.set_idot_2(monitor->iDot_2); //!< Rate of inclination angle [semi-circles/sec]
|
||||
monitor_.set_c_uc_3(monitor->C_uc_3); //!< Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
monitor_.set_c_us_3(monitor->C_us_3); //!< Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
monitor_.set_c_rc_3(monitor->C_rc_3); //!< Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
monitor_.set_c_rs_3(monitor->C_rs_3); //!< Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
monitor_.set_c_ic_4(monitor->C_ic_4); //!< Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
monitor_.set_c_is_4(monitor->C_is_4); //!< Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
monitor_.set_d_toe(monitor->t0e_1); // Ephemeris reference time
|
||||
monitor_.set_iod_nav_1(monitor->IOD_nav);
|
||||
monitor_.set_m0_1(monitor->M_0); //!< Mean anomaly at reference time [semi-circles]
|
||||
monitor_.set_delta_n_3(monitor->delta_n); //!< Mean motion difference from computed value [semi-circles/sec]
|
||||
monitor_.set_e_1(monitor->ecc); //!< Eccentricity
|
||||
monitor_.set_a_1(monitor->sqrtA); //!< Square root of the semi-major axis [meters^1/2]
|
||||
monitor_.set_omega_0_2(monitor->OMEGA_0); //!< Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
monitor_.set_i_0_2(monitor->i_0); //!< Inclination angle at reference time [semi-circles]
|
||||
monitor_.set_omega_2(monitor->omega); //!< Argument of perigee [semi-circles]
|
||||
monitor_.set_omega_dot_3(monitor->OMEGAdot); //!< Rate of right ascension [semi-circles/sec]
|
||||
monitor_.set_idot_2(monitor->idot); //!< Rate of inclination angle [semi-circles/sec]
|
||||
monitor_.set_c_uc_3(monitor->Cuc); //!< Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
monitor_.set_c_us_3(monitor->Cus); //!< Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
monitor_.set_c_rc_3(monitor->Crc); //!< Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
monitor_.set_c_rs_3(monitor->Crs); //!< Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
monitor_.set_c_ic_4(monitor->Cic); //!< Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
monitor_.set_c_is_4(monitor->Cis); //!< Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
monitor_.set_d_toe(monitor->toe); //!< Ephemeris reference time
|
||||
|
||||
/*Clock correction parameters*/
|
||||
monitor_.set_d_toc(monitor->t0c_4); // Clock correction data reference Time of Week
|
||||
monitor_.set_af0_4(monitor->af0_4); //!< SV clock bias correction coefficient [s]
|
||||
monitor_.set_af1_4(monitor->af1_4); //!< SV clock drift correction coefficient [s/s]
|
||||
monitor_.set_af2_4(monitor->af2_4); //!< SV clock drift rate correction coefficient [s/s^2]
|
||||
monitor_.set_d_toc(monitor->toc); //!< Clock correction data reference Time of Week
|
||||
monitor_.set_af0_4(monitor->af0); //!< SV clock bias correction coefficient [s]
|
||||
monitor_.set_af1_4(monitor->af1); //!< SV clock drift correction coefficient [s/s]
|
||||
monitor_.set_af2_4(monitor->af2); //!< SV clock drift rate correction coefficient [s/s^2]
|
||||
|
||||
/*GST*/
|
||||
// Not belong to ephemeris set (page 1 to 4)
|
||||
monitor_.set_wn_5(monitor->WN_5); //!< Week number
|
||||
monitor_.set_tow_5(monitor->TOW_5); //!< Time of Week
|
||||
monitor_.set_galileo_satclkdrift(monitor->Galileo_satClkDrift);
|
||||
monitor_.set_galileo_dtr(monitor->Galileo_dtr); //!< relativistic clock correction term
|
||||
monitor_.set_wn_5(monitor->WN); //!< Week number
|
||||
monitor_.set_tow_5(monitor->tow); //!< Time of Week
|
||||
monitor_.set_galileo_satclkdrift(monitor->satClkDrift);
|
||||
monitor_.set_galileo_dtr(monitor->dtr); //!< relativistic clock correction term
|
||||
|
||||
// SV status
|
||||
monitor_.set_sisa_3(monitor->SISA_3);
|
||||
monitor_.set_e5a_hs(monitor->E5a_HS); //!< E5a Signal Health Status
|
||||
monitor_.set_e5b_hs_5(monitor->E5b_HS_5); //!< E5b Signal Health Status
|
||||
monitor_.set_e1b_hs_5(monitor->E1B_HS_5); //!< E1B Signal Health Status
|
||||
monitor_.set_e5a_dvs(monitor->E5a_DVS); //!< E5a Data Validity Status
|
||||
monitor_.set_e5b_dvs_5(monitor->E5b_DVS_5); //!< E5b Data Validity Status
|
||||
monitor_.set_e1b_dvs_5(monitor->E1B_DVS_5); //!< E1B Data Validity Status
|
||||
monitor_.set_sisa_3(monitor->SISA);
|
||||
monitor_.set_e5a_hs(monitor->E5a_HS); //!< E5a Signal Health Status
|
||||
monitor_.set_e5b_hs_5(monitor->E5b_HS); //!< E5b Signal Health Status
|
||||
monitor_.set_e1b_hs_5(monitor->E1B_HS); //!< E1B Signal Health Status
|
||||
monitor_.set_e5a_dvs(monitor->E5a_DVS); //!< E5a Data Validity Status
|
||||
monitor_.set_e5b_dvs_5(monitor->E5b_DVS); //!< E5b Data Validity Status
|
||||
monitor_.set_e1b_dvs_5(monitor->E1B_DVS); //!< E1B Data Validity Status
|
||||
|
||||
monitor_.set_bgd_e1e5a_5(monitor->BGD_E1E5a_5); //!< E1-E5a Broadcast Group Delay [s]
|
||||
monitor_.set_bgd_e1e5b_5(monitor->BGD_E1E5b_5); //!< E1-E5b Broadcast Group Delay [s]
|
||||
monitor_.set_bgd_e1e5a_5(monitor->BGD_E1E5a); //!< E1-E5a Broadcast Group Delay [s]
|
||||
monitor_.set_bgd_e1e5b_5(monitor->BGD_E1E5b); //!< E1-E5b Broadcast Group Delay [s]
|
||||
|
||||
monitor_.SerializeToString(&data);
|
||||
return data;
|
||||
@ -133,51 +133,51 @@ public:
|
||||
{
|
||||
Galileo_Ephemeris monitor;
|
||||
|
||||
monitor.i_satellite_PRN = mon.i_satellite_prn();
|
||||
monitor.PRN = mon.i_satellite_prn();
|
||||
|
||||
monitor.IOD_ephemeris = mon.iod_ephemeris();
|
||||
monitor.IOD_nav_1 = mon.iod_nav_1();
|
||||
monitor.M0_1 = mon.m0_1(); //!< Mean anomaly at reference time [semi-circles]
|
||||
monitor.delta_n_3 = mon.delta_n_3(); //!< Mean motion difference from computed value [semi-circles/sec]
|
||||
monitor.e_1 = mon.e_1(); //!< Eccentricity
|
||||
monitor.A_1 = mon.a_1(); //!< Square root of the semi-major axis [meters^1/2]
|
||||
monitor.OMEGA_0_2 = mon.omega_0_2(); //!< Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
monitor.i_0_2 = mon.i_0_2(); //!< Inclination angle at reference time [semi-circles]
|
||||
monitor.omega_2 = mon.omega_2(); //!< Argument of perigee [semi-circles]
|
||||
monitor.OMEGA_dot_3 = mon.omega_dot_3(); //!< Rate of right ascension [semi-circles/sec]
|
||||
monitor.iDot_2 = mon.idot_2(); //!< Rate of inclination angle [semi-circles/sec]
|
||||
monitor.C_uc_3 = mon.c_uc_3(); //!< Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
monitor.C_us_3 = mon.c_us_3(); //!< Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
monitor.C_rc_3 = mon.c_rc_3(); //!< Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
monitor.C_rs_3 = mon.c_rs_3(); //!< Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
monitor.C_ic_4 = mon.c_ic_4(); //!< Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
monitor.C_is_4 = mon.c_is_4(); //!< Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
monitor.t0e_1 = mon.d_toe(); // Ephemeris reference time
|
||||
monitor.IOD_nav = mon.iod_nav_1();
|
||||
monitor.M_0 = mon.m0_1(); //!< Mean anomaly at reference time [semi-circles]
|
||||
monitor.delta_n = mon.delta_n_3(); //!< Mean motion difference from computed value [semi-circles/sec]
|
||||
monitor.ecc = mon.e_1(); //!< Eccentricity
|
||||
monitor.sqrtA = mon.a_1(); //!< Square root of the semi-major axis [meters^1/2]
|
||||
monitor.OMEGA_0 = mon.omega_0_2(); //!< Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
monitor.i_0 = mon.i_0_2(); //!< Inclination angle at reference time [semi-circles]
|
||||
monitor.omega = mon.omega_2(); //!< Argument of perigee [semi-circles]
|
||||
monitor.OMEGAdot = mon.omega_dot_3(); //!< Rate of right ascension [semi-circles/sec]
|
||||
monitor.idot = mon.idot_2(); //!< Rate of inclination angle [semi-circles/sec]
|
||||
monitor.Cuc = mon.c_uc_3(); //!< Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
monitor.Cus = mon.c_us_3(); //!< Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
monitor.Crc = mon.c_rc_3(); //!< Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
monitor.Crs = mon.c_rs_3(); //!< Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
monitor.Cic = mon.c_ic_4(); //!< Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
monitor.Cis = mon.c_is_4(); //!< Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
monitor.toe = mon.d_toe(); // Ephemeris reference time
|
||||
|
||||
/*Clock correction parameters*/
|
||||
monitor.t0c_4 = mon.d_toc(); // Clock correction data reference Time of Week
|
||||
monitor.af0_4 = mon.af0_4(); //!< SV clock bias correction coefficient [s]
|
||||
monitor.af1_4 = mon.af1_4(); //!< SV clock drift correction coefficient [s/s]
|
||||
monitor.af2_4 = mon.af2_4(); //!< SV clock drift rate correction coefficient [s/s^2]
|
||||
monitor.toc = mon.d_toc(); // Clock correction data reference Time of Week
|
||||
monitor.af0 = mon.af0_4(); //!< SV clock bias correction coefficient [s]
|
||||
monitor.af1 = mon.af1_4(); //!< SV clock drift correction coefficient [s/s]
|
||||
monitor.af2 = mon.af2_4(); //!< SV clock drift rate correction coefficient [s/s^2]
|
||||
|
||||
/*GST*/
|
||||
// Not belong to ephemeris set (page 1 to 4)
|
||||
monitor.WN_5 = mon.wn_5(); //!< Week number
|
||||
monitor.TOW_5 = mon.tow_5(); //!< Time of Week
|
||||
monitor.Galileo_satClkDrift = mon.galileo_satclkdrift();
|
||||
monitor.Galileo_dtr = mon.galileo_dtr(); //!< relativistic clock correction term
|
||||
monitor.WN = mon.wn_5(); //!< Week number
|
||||
monitor.tow = mon.tow_5(); //!< Time of Week
|
||||
monitor.satClkDrift = mon.galileo_satclkdrift();
|
||||
monitor.dtr = mon.galileo_dtr(); //!< relativistic clock correction term
|
||||
|
||||
// SV status
|
||||
monitor.SISA_3 = mon.sisa_3();
|
||||
monitor.E5a_HS = mon.e5a_hs(); //!< E5a Signal Health Status
|
||||
monitor.E5b_HS_5 = mon.e5b_hs_5(); //!< E5b Signal Health Status
|
||||
monitor.E1B_HS_5 = mon.e1b_hs_5(); //!< E1B Signal Health Status
|
||||
monitor.E5a_DVS = mon.e5a_dvs(); //!< E5a Data Validity Status
|
||||
monitor.E5b_DVS_5 = mon.e5b_dvs_5(); //!< E5b Data Validity Status
|
||||
monitor.E1B_DVS_5 = mon.e1b_dvs_5(); //!< E1B Data Validity Status
|
||||
monitor.SISA = mon.sisa_3();
|
||||
monitor.E5a_HS = mon.e5a_hs(); //!< E5a Signal Health Status
|
||||
monitor.E5b_HS = mon.e5b_hs_5(); //!< E5b Signal Health Status
|
||||
monitor.E1B_HS = mon.e1b_hs_5(); //!< E1B Signal Health Status
|
||||
monitor.E5a_DVS = mon.e5a_dvs(); //!< E5a Data Validity Status
|
||||
monitor.E5b_DVS = mon.e5b_dvs_5(); //!< E5b Data Validity Status
|
||||
monitor.E1B_DVS = mon.e1b_dvs_5(); //!< E1B Data Validity Status
|
||||
|
||||
monitor.BGD_E1E5a_5 = mon.bgd_e1e5a_5(); //!< E1-E5a Broadcast Group Delay [s]
|
||||
monitor.BGD_E1E5b_5 = mon.bgd_e1e5b_5(); //!< E1-E5b Broadcast Group Delay [s]
|
||||
monitor.BGD_E1E5a = mon.bgd_e1e5a_5(); //!< E1-E5a Broadcast Group Delay [s]
|
||||
monitor.BGD_E1E5b = mon.bgd_e1e5b_5(); //!< E1-E5b Broadcast Group Delay [s]
|
||||
|
||||
return monitor;
|
||||
}
|
||||
|
@ -78,47 +78,47 @@ public:
|
||||
{
|
||||
monitor_.Clear();
|
||||
std::string data;
|
||||
monitor_.set_i_satellite_prn(monitor->i_satellite_PRN); // SV PRN NUMBER
|
||||
monitor_.set_d_tow(monitor->d_TOW); //!< time of gps week of the ephemeris set (taken from subframes tow) [s]
|
||||
monitor_.set_d_crs(monitor->d_Crs); //!< amplitude of the sine harmonic correction term to the orbit radius [m]
|
||||
monitor_.set_d_delta_n(monitor->d_Delta_n); //!< mean motion difference from computed value [semi-circles/s]
|
||||
monitor_.set_d_m_0(monitor->d_M_0); //!< mean anomaly at reference time [semi-circles]
|
||||
monitor_.set_d_cuc(monitor->d_Cuc); //!< amplitude of the cosine harmonic correction term to the argument of latitude [rad]
|
||||
monitor_.set_d_e_eccentricity(monitor->d_e_eccentricity); //!< eccentricity [dimensionless]
|
||||
monitor_.set_d_cus(monitor->d_Cus); //!< amplitude of the sine harmonic correction term to the argument of latitude [rad]
|
||||
monitor_.set_d_sqrt_a(monitor->d_sqrt_A); //!< square root of the semi-major axis [sqrt(m)]
|
||||
monitor_.set_d_toe(monitor->d_Toe); //!< ephemeris data reference time of week (ref. 20.3.3.4.3 is-gps-200k) [s]
|
||||
monitor_.set_d_toc(monitor->d_Toc); //!< clock data reference time (ref. 20.3.3.3.3.1 is-gps-200k) [s]
|
||||
monitor_.set_d_cic(monitor->d_Cic); //!< amplitude of the cosine harmonic correction term to the angle of inclination [rad]
|
||||
monitor_.set_d_omega0(monitor->d_OMEGA0); //!< longitude of ascending node of orbit plane at weekly epoch [semi-circles]
|
||||
monitor_.set_d_cis(monitor->d_Cis); //!< amplitude of the sine harmonic correction term to the angle of inclination [rad]
|
||||
monitor_.set_d_i_0(monitor->d_i_0); //!< inclination angle at reference time [semi-circles]
|
||||
monitor_.set_d_crc(monitor->d_Crc); //!< amplitude of the cosine harmonic correction term to the orbit radius [m]
|
||||
monitor_.set_d_omega(monitor->d_OMEGA); //!< argument of perigee [semi-cicles]
|
||||
monitor_.set_d_omega_dot(monitor->d_OMEGA_DOT); //!< rate of right ascension [semi-circles/s]
|
||||
monitor_.set_d_idot(monitor->d_IDOT); //!< rate of inclination angle [semi-circles/s]
|
||||
monitor_.set_i_code_on_l2(monitor->i_code_on_L2); //!< if 1, p code on in l2; if 2, c/a code on in l2;
|
||||
monitor_.set_i_gps_week(monitor->i_GPS_week); //!< gps week number, aka wn [week]
|
||||
monitor_.set_b_l2_p_data_flag(monitor->b_L2_P_data_flag); //!< when true, indicates that the nav data stream was commanded off on the p-code of the l2 channel
|
||||
monitor_.set_i_sv_accuracy(monitor->i_SV_accuracy); //!< user range accuracy (ura) index of the sv (reference paragraph 6.2.1) for the standard positioning service user (ref 20.3.3.3.1.3 is-gps-200k)
|
||||
monitor_.set_i_sv_health(monitor->i_SV_health);
|
||||
monitor_.set_d_tgd(monitor->d_TGD); //!< estimated group delay differential: l1-l2 correction term only for the benefit of "l1 p(y)" or "l2 p(y)" s users [s]
|
||||
monitor_.set_d_iodc(monitor->d_IODC); //!< issue of data, clock
|
||||
monitor_.set_d_iode_sf2(monitor->d_IODE_SF2); //!< issue of data, ephemeris (iode), subframe 2
|
||||
monitor_.set_d_iode_sf3(monitor->d_IODE_SF3); //!< issue of data, ephemeris(iode), subframe 3
|
||||
monitor_.set_i_aodo(monitor->i_AODO); //!< age of data offset (aodo) term for the navigation message correction table (nmct) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
monitor_.set_i_satellite_prn(monitor->PRN); //!< SV PRN NUMBER
|
||||
monitor_.set_d_tow(monitor->tow); //!< time of gps week of the ephemeris set (taken from subframes tow) [s]
|
||||
monitor_.set_d_crs(monitor->Crs); //!< amplitude of the sine harmonic correction term to the orbit radius [m]
|
||||
monitor_.set_d_delta_n(monitor->delta_n); //!< mean motion difference from computed value [semi-circles/s]
|
||||
monitor_.set_d_m_0(monitor->M_0); //!< mean anomaly at reference time [semi-circles]
|
||||
monitor_.set_d_cuc(monitor->Cuc); //!< amplitude of the cosine harmonic correction term to the argument of latitude [rad]
|
||||
monitor_.set_d_e_eccentricity(monitor->ecc); //!< eccentricity [dimensionless]
|
||||
monitor_.set_d_cus(monitor->Cus); //!< amplitude of the sine harmonic correction term to the argument of latitude [rad]
|
||||
monitor_.set_d_sqrt_a(monitor->sqrtA); //!< square root of the semi-major axis [sqrt(m)]
|
||||
monitor_.set_d_toe(monitor->toe); //!< ephemeris data reference time of week (ref. 20.3.3.4.3 is-gps-200k) [s]
|
||||
monitor_.set_d_toc(monitor->toc); //!< clock data reference time (ref. 20.3.3.3.3.1 is-gps-200k) [s]
|
||||
monitor_.set_d_cic(monitor->Cic); //!< amplitude of the cosine harmonic correction term to the angle of inclination [rad]
|
||||
monitor_.set_d_omega0(monitor->OMEGA_0); //!< longitude of ascending node of orbit plane at weekly epoch [semi-circles]
|
||||
monitor_.set_d_cis(monitor->Cis); //!< amplitude of the sine harmonic correction term to the angle of inclination [rad]
|
||||
monitor_.set_d_i_0(monitor->i_0); //!< inclination angle at reference time [semi-circles]
|
||||
monitor_.set_d_crc(monitor->Crc); //!< amplitude of the cosine harmonic correction term to the orbit radius [m]
|
||||
monitor_.set_d_omega(monitor->omega); //!< argument of perigee [semi-cicles]
|
||||
monitor_.set_d_omega_dot(monitor->OMEGAdot); //!< rate of right ascension [semi-circles/s]
|
||||
monitor_.set_d_idot(monitor->idot); //!< rate of inclination angle [semi-circles/s]
|
||||
monitor_.set_i_code_on_l2(monitor->code_on_L2); //!< if 1, p code on in l2; if 2, c/a code on in l2;
|
||||
monitor_.set_i_gps_week(monitor->WN); //!< gps week number, aka wn [week]
|
||||
monitor_.set_b_l2_p_data_flag(monitor->L2_P_data_flag); //!< when true, indicates that the nav data stream was commanded off on the p-code of the l2 channel
|
||||
monitor_.set_i_sv_accuracy(monitor->SV_accuracy); //!< user range accuracy (ura) index of the sv (reference paragraph 6.2.1) for the standard positioning service user (ref 20.3.3.3.1.3 is-gps-200k)
|
||||
monitor_.set_i_sv_health(monitor->SV_health);
|
||||
monitor_.set_d_tgd(monitor->TGD); //!< estimated group delay differential: l1-l2 correction term only for the benefit of "l1 p(y)" or "l2 p(y)" s users [s]
|
||||
monitor_.set_d_iodc(monitor->IODC); //!< issue of data, clock
|
||||
monitor_.set_d_iode_sf2(monitor->IODE_SF2); //!< issue of data, ephemeris (iode), subframe 2
|
||||
monitor_.set_d_iode_sf3(monitor->IODE_SF3); //!< issue of data, ephemeris(iode), subframe 3
|
||||
monitor_.set_i_aodo(monitor->AODO); //!< age of data offset (aodo) term for the navigation message correction table (nmct) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
|
||||
monitor_.set_b_fit_interval_flag(monitor->b_fit_interval_flag); //!< indicates the curve-fit interval used by the cs (block ii/iia/iir/iir-m/iif) and ss (block iiia) in determining the ephemeris parameters, as follows: 0 = 4 hours, 1 = greater than 4 hours.
|
||||
monitor_.set_d_spare1(monitor->d_spare1);
|
||||
monitor_.set_d_spare2(monitor->d_spare2);
|
||||
|
||||
monitor_.set_d_a_f0(monitor->d_A_f0); //!< coefficient 0 of code phase offset model [s]
|
||||
monitor_.set_d_a_f1(monitor->d_A_f1); //!< coefficient 1 of code phase offset model [s/s]
|
||||
monitor_.set_d_a_f2(monitor->d_A_f2); //!< coefficient 2 of code phase offset model [s/s^2]
|
||||
monitor_.set_d_a_f0(monitor->af0); //!< coefficient 0 of code phase offset model [s]
|
||||
monitor_.set_d_a_f1(monitor->af1); //!< coefficient 1 of code phase offset model [s/s]
|
||||
monitor_.set_d_a_f2(monitor->af2); //!< coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
monitor_.set_b_integrity_status_flag(monitor->b_integrity_status_flag);
|
||||
monitor_.set_b_alert_flag(monitor->b_alert_flag); //!< if true, indicates that the sv ura may be worse than indicated in d_sv_accuracy, use that sv at our own risk.
|
||||
monitor_.set_b_antispoofing_flag(monitor->b_antispoofing_flag); //!< if true, the antispoofing mode is on in that sv
|
||||
monitor_.set_b_alert_flag(monitor->b_alert_flag); //!< if true, indicates that the sv ura may be worse than indicated in d_sv_accuracy, use that sv at our own risk.
|
||||
monitor_.set_b_antispoofing_flag(monitor->b_antispoofing_flag); //!< if true, the antispoofing mode is on in that sv
|
||||
|
||||
monitor_.SerializeToString(&data);
|
||||
return data;
|
||||
@ -128,47 +128,47 @@ public:
|
||||
{
|
||||
Gps_Ephemeris monitor;
|
||||
|
||||
monitor.i_satellite_PRN = mon.i_satellite_prn(); // SV PRN NUMBER
|
||||
monitor.d_TOW = mon.d_tow(); //!< time of gps week of the ephemeris set (taken from subframes tow) [s]
|
||||
monitor.d_Crs = mon.d_crs(); //!< amplitude of the sine harmonic correction term to the orbit radius [m]
|
||||
monitor.d_Delta_n = mon.d_delta_n(); //!< mean motion difference from computed value [semi-circles/s]
|
||||
monitor.d_M_0 = mon.d_m_0(); //!< mean anomaly at reference time [semi-circles]
|
||||
monitor.d_Cuc = mon.d_cuc(); //!< amplitude of the cosine harmonic correction term to the argument of latitude [rad]
|
||||
monitor.d_e_eccentricity = mon.d_e_eccentricity(); //!< eccentricity [dimensionless]
|
||||
monitor.d_Cus = mon.d_cus(); //!< amplitude of the sine harmonic correction term to the argument of latitude [rad]
|
||||
monitor.d_sqrt_A = mon.d_sqrt_a(); //!< square root of the semi-major axis [sqrt(m)]
|
||||
monitor.d_Toe = mon.d_toe(); //!< ephemeris data reference time of week (ref. 20.3.3.4.3 is-gps-200k) [s]
|
||||
monitor.d_Toc = mon.d_toc(); //!< clock data reference time (ref. 20.3.3.3.3.1 is-gps-200k) [s]
|
||||
monitor.d_Cic = mon.d_cic(); //!< amplitude of the cosine harmonic correction term to the angle of inclination [rad]
|
||||
monitor.d_OMEGA0 = mon.d_omega0(); //!< longitude of ascending node of orbit plane at weekly epoch [semi-circles]
|
||||
monitor.d_Cis = mon.d_cis(); //!< amplitude of the sine harmonic correction term to the angle of inclination [rad]
|
||||
monitor.d_i_0 = mon.d_i_0(); //!< inclination angle at reference time [semi-circles]
|
||||
monitor.d_Crc = mon.d_crc(); //!< amplitude of the cosine harmonic correction term to the orbit radius [m]
|
||||
monitor.d_OMEGA = mon.d_omega(); //!< argument of perigee [semi-cicles]
|
||||
monitor.d_OMEGA_DOT = mon.d_omega_dot(); //!< rate of right ascension [semi-circles/s]
|
||||
monitor.d_IDOT = mon.d_idot(); //!< rate of inclination angle [semi-circles/s]
|
||||
monitor.i_code_on_L2 = mon.i_code_on_l2(); //!< if 1, p code on in l2; if 2, c/a code on in l2;
|
||||
monitor.i_GPS_week = mon.i_gps_week(); //!< gps week number, aka wn [week]
|
||||
monitor.b_L2_P_data_flag = mon.b_l2_p_data_flag(); //!< when true, indicates that the nav data stream was commanded off on the p-code of the l2 channel
|
||||
monitor.i_SV_accuracy = mon.i_sv_accuracy(); //!< user range accuracy (ura) index of the sv (reference paragraph 6.2.1) for the standard positioning service user (ref 20.3.3.3.1.3 is-gps-200k)
|
||||
monitor.i_SV_health = mon.i_sv_health();
|
||||
monitor.d_TGD = mon.d_tgd(); //!< estimated group delay differential: l1-l2 correction term only for the benefit of "l1 p(y)" or "l2 p(y)" s users [s]
|
||||
monitor.d_IODC = mon.d_iodc(); //!< issue of data, clock
|
||||
monitor.d_IODE_SF2 = mon.d_iode_sf2(); //!< issue of data, ephemeris (iode), subframe 2
|
||||
monitor.d_IODE_SF3 = mon.d_iode_sf3(); //!< issue of data, ephemeris(iode), subframe 3
|
||||
monitor.i_AODO = mon.i_aodo(); //!< age of data offset (aodo) term for the navigation message correction table (nmct) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
monitor.PRN = mon.i_satellite_prn(); //!< SV PRN NUMBER
|
||||
monitor.tow = mon.d_tow(); //!< time of gps week of the ephemeris set (taken from subframes tow) [s]
|
||||
monitor.Crs = mon.d_crs(); //!< amplitude of the sine harmonic correction term to the orbit radius [m]
|
||||
monitor.delta_n = mon.d_delta_n(); //!< mean motion difference from computed value [semi-circles/s]
|
||||
monitor.M_0 = mon.d_m_0(); //!< mean anomaly at reference time [semi-circles]
|
||||
monitor.Cuc = mon.d_cuc(); //!< amplitude of the cosine harmonic correction term to the argument of latitude [rad]
|
||||
monitor.ecc = mon.d_e_eccentricity(); //!< eccentricity [dimensionless]
|
||||
monitor.Cus = mon.d_cus(); //!< amplitude of the sine harmonic correction term to the argument of latitude [rad]
|
||||
monitor.sqrtA = mon.d_sqrt_a(); //!< square root of the semi-major axis [sqrt(m)]
|
||||
monitor.toe = mon.d_toe(); //!< ephemeris data reference time of week (ref. 20.3.3.4.3 is-gps-200k) [s]
|
||||
monitor.toc = mon.d_toc(); //!< clock data reference time (ref. 20.3.3.3.3.1 is-gps-200k) [s]
|
||||
monitor.Cic = mon.d_cic(); //!< amplitude of the cosine harmonic correction term to the angle of inclination [rad]
|
||||
monitor.OMEGA_0 = mon.d_omega0(); //!< longitude of ascending node of orbit plane at weekly epoch [semi-circles]
|
||||
monitor.Cis = mon.d_cis(); //!< amplitude of the sine harmonic correction term to the angle of inclination [rad]
|
||||
monitor.i_0 = mon.d_i_0(); //!< inclination angle at reference time [semi-circles]
|
||||
monitor.Crc = mon.d_crc(); //!< amplitude of the cosine harmonic correction term to the orbit radius [m]
|
||||
monitor.omega = mon.d_omega(); //!< argument of perigee [semi-cicles]
|
||||
monitor.OMEGAdot = mon.d_omega_dot(); //!< rate of right ascension [semi-circles/s]
|
||||
monitor.idot = mon.d_idot(); //!< rate of inclination angle [semi-circles/s]
|
||||
monitor.code_on_L2 = mon.i_code_on_l2(); //!< if 1, p code on in l2; if 2, c/a code on in l2;
|
||||
monitor.WN = mon.i_gps_week(); //!< gps week number, aka wn [week]
|
||||
monitor.L2_P_data_flag = mon.b_l2_p_data_flag(); //!< when true, indicates that the nav data stream was commanded off on the p-code of the l2 channel
|
||||
monitor.SV_accuracy = mon.i_sv_accuracy(); //!< user range accuracy (ura) index of the sv (reference paragraph 6.2.1) for the standard positioning service user (ref 20.3.3.3.1.3 is-gps-200k)
|
||||
monitor.SV_health = mon.i_sv_health();
|
||||
monitor.TGD = mon.d_tgd(); //!< estimated group delay differential: l1-l2 correction term only for the benefit of "l1 p(y)" or "l2 p(y)" s users [s]
|
||||
monitor.IODC = mon.d_iodc(); //!< issue of data, clock
|
||||
monitor.IODE_SF2 = mon.d_iode_sf2(); //!< issue of data, ephemeris (iode), subframe 2
|
||||
monitor.IODE_SF3 = mon.d_iode_sf3(); //!< issue of data, ephemeris(iode), subframe 3
|
||||
monitor.AODO = mon.i_aodo(); //!< age of data offset (aodo) term for the navigation message correction table (nmct) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
|
||||
monitor.b_fit_interval_flag = mon.b_fit_interval_flag(); //!< indicates the curve-fit interval used by the cs (block ii/iia/iir/iir-m/iif) and ss (block iiia) in determining the ephemeris parameters, as follows: 0 = 4 hours, 1 = greater than 4 hours.
|
||||
monitor.d_spare1 = mon.d_spare1();
|
||||
monitor.d_spare2 = mon.d_spare2();
|
||||
|
||||
monitor.d_A_f0 = mon.d_a_f0(); //!< coefficient 0 of code phase offset model [s]
|
||||
monitor.d_A_f1 = mon.d_a_f1(); //!< coefficient 1 of code phase offset model [s/s]
|
||||
monitor.d_A_f2 = mon.d_a_f2(); //!< coefficient 2 of code phase offset model [s/s^2]
|
||||
monitor.af0 = mon.d_a_f0(); //!< coefficient 0 of code phase offset model [s]
|
||||
monitor.af1 = mon.d_a_f1(); //!< coefficient 1 of code phase offset model [s/s]
|
||||
monitor.af2 = mon.d_a_f2(); //!< coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
monitor.b_integrity_status_flag = mon.b_integrity_status_flag();
|
||||
monitor.b_alert_flag = mon.b_alert_flag(); //!< if true, indicates that the sv ura may be worse than indicated in d_sv_accuracy, use that sv at our own risk.
|
||||
monitor.b_antispoofing_flag = mon.b_antispoofing_flag(); //!< if true, the antispoofing mode is on in that sv
|
||||
monitor.b_alert_flag = mon.b_alert_flag(); //!< if true, indicates that the sv ura may be worse than indicated in d_sv_accuracy, use that sv at our own risk.
|
||||
monitor.b_antispoofing_flag = mon.b_antispoofing_flag(); //!< if true, the antispoofing mode is on in that sv
|
||||
|
||||
return monitor;
|
||||
}
|
||||
|
@ -162,13 +162,13 @@ void pcps_assisted_acquisition_cc::get_assistance()
|
||||
// TODO: use the LO tolerance here
|
||||
if (gps_acq_assisistance.dopplerUncertainty >= 1000)
|
||||
{
|
||||
d_doppler_max = gps_acq_assisistance.d_Doppler0 + gps_acq_assisistance.dopplerUncertainty * 2;
|
||||
d_doppler_min = gps_acq_assisistance.d_Doppler0 - gps_acq_assisistance.dopplerUncertainty * 2;
|
||||
d_doppler_max = gps_acq_assisistance.Doppler0 + gps_acq_assisistance.dopplerUncertainty * 2;
|
||||
d_doppler_min = gps_acq_assisistance.Doppler0 - gps_acq_assisistance.dopplerUncertainty * 2;
|
||||
}
|
||||
else
|
||||
{
|
||||
d_doppler_max = gps_acq_assisistance.d_Doppler0 + 1000;
|
||||
d_doppler_min = gps_acq_assisistance.d_Doppler0 - 1000;
|
||||
d_doppler_max = gps_acq_assisistance.Doppler0 + 1000;
|
||||
d_doppler_min = gps_acq_assisistance.Doppler0 - 1000;
|
||||
}
|
||||
this->d_disable_assist = false;
|
||||
std::cout << "Acq assist ENABLED for GPS SV " << this->d_gnss_synchro->PRN << " (Doppler max,Doppler min)=("
|
||||
|
@ -168,36 +168,36 @@ eph_t eph_to_rtklib(const Galileo_Ephemeris& gal_eph)
|
||||
eph_t rtklib_sat = {0, 0, 0, 0, 0, 0, 0, 0, {0, 0}, {0, 0}, {0, 0}, 0.0, 0.0, 0.0, 0.0, 0.0,
|
||||
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, {}, {}, 0.0, 0.0};
|
||||
// Galileo is the third satellite system for RTKLIB, so, add the required offset to discriminate Galileo ephemeris
|
||||
rtklib_sat.sat = gal_eph.i_satellite_PRN + NSATGPS + NSATGLO;
|
||||
rtklib_sat.A = gal_eph.A_1 * gal_eph.A_1;
|
||||
rtklib_sat.M0 = gal_eph.M0_1;
|
||||
rtklib_sat.deln = gal_eph.delta_n_3;
|
||||
rtklib_sat.OMG0 = gal_eph.OMEGA_0_2;
|
||||
rtklib_sat.OMGd = gal_eph.OMEGA_dot_3;
|
||||
rtklib_sat.omg = gal_eph.omega_2;
|
||||
rtklib_sat.i0 = gal_eph.i_0_2;
|
||||
rtklib_sat.idot = gal_eph.iDot_2;
|
||||
rtklib_sat.e = gal_eph.e_1;
|
||||
rtklib_sat.sat = gal_eph.PRN + NSATGPS + NSATGLO;
|
||||
rtklib_sat.A = gal_eph.sqrtA * gal_eph.sqrtA;
|
||||
rtklib_sat.M0 = gal_eph.M_0;
|
||||
rtklib_sat.deln = gal_eph.delta_n;
|
||||
rtklib_sat.OMG0 = gal_eph.OMEGA_0;
|
||||
rtklib_sat.OMGd = gal_eph.OMEGAdot;
|
||||
rtklib_sat.omg = gal_eph.omega;
|
||||
rtklib_sat.i0 = gal_eph.i_0;
|
||||
rtklib_sat.idot = gal_eph.idot;
|
||||
rtklib_sat.e = gal_eph.ecc;
|
||||
rtklib_sat.Adot = 0; // only in CNAV;
|
||||
rtklib_sat.ndot = 0; // only in CNAV;
|
||||
|
||||
rtklib_sat.week = gal_eph.WN_5 + 1024; /* week of tow in GPS (not mod-1024) week scale */
|
||||
rtklib_sat.cic = gal_eph.C_ic_4;
|
||||
rtklib_sat.cis = gal_eph.C_is_4;
|
||||
rtklib_sat.cuc = gal_eph.C_uc_3;
|
||||
rtklib_sat.cus = gal_eph.C_us_3;
|
||||
rtklib_sat.crc = gal_eph.C_rc_3;
|
||||
rtklib_sat.crs = gal_eph.C_rs_3;
|
||||
rtklib_sat.f0 = gal_eph.af0_4;
|
||||
rtklib_sat.f1 = gal_eph.af1_4;
|
||||
rtklib_sat.f2 = gal_eph.af2_4;
|
||||
rtklib_sat.tgd[0] = gal_eph.BGD_E1E5a_5;
|
||||
rtklib_sat.tgd[1] = gal_eph.BGD_E1E5b_5;
|
||||
rtklib_sat.week = gal_eph.WN + 1024; /* week of tow in GPS (not mod-1024) week scale */
|
||||
rtklib_sat.cic = gal_eph.Cic;
|
||||
rtklib_sat.cis = gal_eph.Cis;
|
||||
rtklib_sat.cuc = gal_eph.Cuc;
|
||||
rtklib_sat.cus = gal_eph.Cus;
|
||||
rtklib_sat.crc = gal_eph.Crc;
|
||||
rtklib_sat.crs = gal_eph.Crs;
|
||||
rtklib_sat.f0 = gal_eph.af0;
|
||||
rtklib_sat.f1 = gal_eph.af1;
|
||||
rtklib_sat.f2 = gal_eph.af2;
|
||||
rtklib_sat.tgd[0] = gal_eph.BGD_E1E5a;
|
||||
rtklib_sat.tgd[1] = gal_eph.BGD_E1E5b;
|
||||
rtklib_sat.tgd[2] = 0;
|
||||
rtklib_sat.tgd[3] = 0;
|
||||
rtklib_sat.toes = gal_eph.t0e_1;
|
||||
rtklib_sat.toc = gpst2time(rtklib_sat.week, gal_eph.t0c_4);
|
||||
rtklib_sat.ttr = gpst2time(rtklib_sat.week, gal_eph.TOW_5);
|
||||
rtklib_sat.toes = gal_eph.toe;
|
||||
rtklib_sat.toc = gpst2time(rtklib_sat.week, gal_eph.toc);
|
||||
rtklib_sat.ttr = gpst2time(rtklib_sat.week, gal_eph.tow);
|
||||
|
||||
/* adjustment for week handover */
|
||||
double tow;
|
||||
@ -226,36 +226,36 @@ eph_t eph_to_rtklib(const Gps_Ephemeris& gps_eph, bool pre_2009_file)
|
||||
{
|
||||
eph_t rtklib_sat = {0, 0, 0, 0, 0, 0, 0, 0, {0, 0}, {0, 0}, {0, 0}, 0.0, 0.0, 0.0, 0.0, 0.0,
|
||||
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, {}, {}, 0.0, 0.0};
|
||||
rtklib_sat.sat = gps_eph.i_satellite_PRN;
|
||||
rtklib_sat.A = gps_eph.d_sqrt_A * gps_eph.d_sqrt_A;
|
||||
rtklib_sat.M0 = gps_eph.d_M_0;
|
||||
rtklib_sat.deln = gps_eph.d_Delta_n;
|
||||
rtklib_sat.OMG0 = gps_eph.d_OMEGA0;
|
||||
rtklib_sat.OMGd = gps_eph.d_OMEGA_DOT;
|
||||
rtklib_sat.omg = gps_eph.d_OMEGA;
|
||||
rtklib_sat.i0 = gps_eph.d_i_0;
|
||||
rtklib_sat.idot = gps_eph.d_IDOT;
|
||||
rtklib_sat.e = gps_eph.d_e_eccentricity;
|
||||
rtklib_sat.sat = gps_eph.PRN;
|
||||
rtklib_sat.A = gps_eph.sqrtA * gps_eph.sqrtA;
|
||||
rtklib_sat.M0 = gps_eph.M_0;
|
||||
rtklib_sat.deln = gps_eph.delta_n;
|
||||
rtklib_sat.OMG0 = gps_eph.OMEGA_0;
|
||||
rtklib_sat.OMGd = gps_eph.OMEGAdot;
|
||||
rtklib_sat.omg = gps_eph.omega;
|
||||
rtklib_sat.i0 = gps_eph.i_0;
|
||||
rtklib_sat.idot = gps_eph.idot;
|
||||
rtklib_sat.e = gps_eph.ecc;
|
||||
rtklib_sat.Adot = 0; // only in CNAV;
|
||||
rtklib_sat.ndot = 0; // only in CNAV;
|
||||
|
||||
rtklib_sat.week = adjgpsweek(gps_eph.i_GPS_week, pre_2009_file); /* week of tow */
|
||||
rtklib_sat.cic = gps_eph.d_Cic;
|
||||
rtklib_sat.cis = gps_eph.d_Cis;
|
||||
rtklib_sat.cuc = gps_eph.d_Cuc;
|
||||
rtklib_sat.cus = gps_eph.d_Cus;
|
||||
rtklib_sat.crc = gps_eph.d_Crc;
|
||||
rtklib_sat.crs = gps_eph.d_Crs;
|
||||
rtklib_sat.f0 = gps_eph.d_A_f0;
|
||||
rtklib_sat.f1 = gps_eph.d_A_f1;
|
||||
rtklib_sat.f2 = gps_eph.d_A_f2;
|
||||
rtklib_sat.tgd[0] = gps_eph.d_TGD;
|
||||
rtklib_sat.week = adjgpsweek(gps_eph.WN, pre_2009_file); /* week of tow */
|
||||
rtklib_sat.cic = gps_eph.Cic;
|
||||
rtklib_sat.cis = gps_eph.Cis;
|
||||
rtklib_sat.cuc = gps_eph.Cuc;
|
||||
rtklib_sat.cus = gps_eph.Cus;
|
||||
rtklib_sat.crc = gps_eph.Crc;
|
||||
rtklib_sat.crs = gps_eph.Crs;
|
||||
rtklib_sat.f0 = gps_eph.af0;
|
||||
rtklib_sat.f1 = gps_eph.af1;
|
||||
rtklib_sat.f2 = gps_eph.af2;
|
||||
rtklib_sat.tgd[0] = gps_eph.TGD;
|
||||
rtklib_sat.tgd[1] = 0.0;
|
||||
rtklib_sat.tgd[2] = 0.0;
|
||||
rtklib_sat.tgd[3] = 0.0;
|
||||
rtklib_sat.toes = gps_eph.d_Toe;
|
||||
rtklib_sat.toc = gpst2time(rtklib_sat.week, gps_eph.d_Toc);
|
||||
rtklib_sat.ttr = gpst2time(rtklib_sat.week, gps_eph.d_TOW);
|
||||
rtklib_sat.toes = gps_eph.toe;
|
||||
rtklib_sat.toc = gpst2time(rtklib_sat.week, gps_eph.toc);
|
||||
rtklib_sat.ttr = gpst2time(rtklib_sat.week, gps_eph.tow);
|
||||
|
||||
/* adjustment for week handover */
|
||||
double tow;
|
||||
@ -284,45 +284,45 @@ eph_t eph_to_rtklib(const Beidou_Dnav_Ephemeris& bei_eph)
|
||||
{
|
||||
eph_t rtklib_sat = {0, 0, 0, 0, 0, 0, 0, 0, {0, 0}, {0, 0}, {0, 0}, 0.0, 0.0, 0.0, 0.0, 0.0,
|
||||
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, {}, {}, 0.0, 0.0};
|
||||
rtklib_sat.sat = bei_eph.i_satellite_PRN + NSATGPS + NSATGLO + NSATGAL + NSATQZS;
|
||||
rtklib_sat.A = bei_eph.d_sqrt_A * bei_eph.d_sqrt_A;
|
||||
rtklib_sat.M0 = bei_eph.d_M_0;
|
||||
rtklib_sat.deln = bei_eph.d_Delta_n;
|
||||
rtklib_sat.OMG0 = bei_eph.d_OMEGA0;
|
||||
rtklib_sat.OMGd = bei_eph.d_OMEGA_DOT;
|
||||
rtklib_sat.omg = bei_eph.d_OMEGA;
|
||||
rtklib_sat.i0 = bei_eph.d_i_0;
|
||||
rtklib_sat.idot = bei_eph.d_IDOT;
|
||||
rtklib_sat.e = bei_eph.d_eccentricity;
|
||||
rtklib_sat.sat = bei_eph.PRN + NSATGPS + NSATGLO + NSATGAL + NSATQZS;
|
||||
rtklib_sat.A = bei_eph.sqrtA * bei_eph.sqrtA;
|
||||
rtklib_sat.M0 = bei_eph.M_0;
|
||||
rtklib_sat.deln = bei_eph.delta_n;
|
||||
rtklib_sat.OMG0 = bei_eph.OMEGA_0;
|
||||
rtklib_sat.OMGd = bei_eph.OMEGAdot;
|
||||
rtklib_sat.omg = bei_eph.omega;
|
||||
rtklib_sat.i0 = bei_eph.i_0;
|
||||
rtklib_sat.idot = bei_eph.idot;
|
||||
rtklib_sat.e = bei_eph.ecc;
|
||||
rtklib_sat.Adot = 0; // only in CNAV;
|
||||
rtklib_sat.ndot = 0; // only in CNAV;
|
||||
|
||||
rtklib_sat.svh = bei_eph.i_SV_health;
|
||||
rtklib_sat.sva = bei_eph.i_SV_accuracy;
|
||||
rtklib_sat.svh = bei_eph.SV_health;
|
||||
rtklib_sat.sva = bei_eph.SV_accuracy;
|
||||
|
||||
rtklib_sat.code = bei_eph.i_sig_type; /* B1I data */
|
||||
rtklib_sat.flag = bei_eph.i_nav_type; /* MEO/IGSO satellite */
|
||||
rtklib_sat.iode = static_cast<int32_t>(bei_eph.d_AODE); /* AODE */
|
||||
rtklib_sat.iodc = static_cast<int32_t>(bei_eph.d_AODC); /* AODC */
|
||||
|
||||
rtklib_sat.week = bei_eph.i_BEIDOU_week; /* week of tow */
|
||||
rtklib_sat.cic = bei_eph.d_Cic;
|
||||
rtklib_sat.cis = bei_eph.d_Cis;
|
||||
rtklib_sat.cuc = bei_eph.d_Cuc;
|
||||
rtklib_sat.cus = bei_eph.d_Cus;
|
||||
rtklib_sat.crc = bei_eph.d_Crc;
|
||||
rtklib_sat.crs = bei_eph.d_Crs;
|
||||
rtklib_sat.f0 = bei_eph.d_A_f0;
|
||||
rtklib_sat.f1 = bei_eph.d_A_f1;
|
||||
rtklib_sat.f2 = bei_eph.d_A_f2;
|
||||
rtklib_sat.week = bei_eph.WN; /* week of tow */
|
||||
rtklib_sat.cic = bei_eph.Cic;
|
||||
rtklib_sat.cis = bei_eph.Cis;
|
||||
rtklib_sat.cuc = bei_eph.Cuc;
|
||||
rtklib_sat.cus = bei_eph.Cus;
|
||||
rtklib_sat.crc = bei_eph.Crc;
|
||||
rtklib_sat.crs = bei_eph.Crs;
|
||||
rtklib_sat.f0 = bei_eph.af0;
|
||||
rtklib_sat.f1 = bei_eph.af1;
|
||||
rtklib_sat.f2 = bei_eph.af2;
|
||||
rtklib_sat.tgd[0] = bei_eph.d_TGD1;
|
||||
rtklib_sat.tgd[1] = bei_eph.d_TGD2;
|
||||
rtklib_sat.tgd[2] = 0.0;
|
||||
rtklib_sat.tgd[3] = 0.0;
|
||||
rtklib_sat.toes = bei_eph.d_Toe;
|
||||
rtklib_sat.toe = bdt2gpst(bdt2time(rtklib_sat.week, bei_eph.d_Toe));
|
||||
rtklib_sat.toc = bdt2gpst(bdt2time(rtklib_sat.week, bei_eph.d_Toc));
|
||||
rtklib_sat.ttr = bdt2gpst(bdt2time(rtklib_sat.week, bei_eph.d_TOW));
|
||||
rtklib_sat.toes = bei_eph.toe;
|
||||
rtklib_sat.toe = bdt2gpst(bdt2time(rtklib_sat.week, bei_eph.toe));
|
||||
rtklib_sat.toc = bdt2gpst(bdt2time(rtklib_sat.week, bei_eph.toc));
|
||||
rtklib_sat.ttr = bdt2gpst(bdt2time(rtklib_sat.week, bei_eph.tow));
|
||||
/* adjustment for week handover */
|
||||
double tow;
|
||||
double toc;
|
||||
@ -353,44 +353,40 @@ eph_t eph_to_rtklib(const Gps_CNAV_Ephemeris& gps_cnav_eph)
|
||||
{
|
||||
eph_t rtklib_sat = {0, 0, 0, 0, 0, 0, 0, 0, {0, 0}, {0, 0}, {0, 0}, 0.0, 0.0, 0.0, 0.0, 0.0,
|
||||
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, {}, {}, 0.0, 0.0};
|
||||
rtklib_sat.sat = gps_cnav_eph.i_satellite_PRN;
|
||||
const double A_REF = 26559710.0; // See IS-GPS-200L, pp. 161
|
||||
rtklib_sat.A = A_REF + gps_cnav_eph.d_DELTA_A;
|
||||
rtklib_sat.M0 = gps_cnav_eph.d_M_0;
|
||||
rtklib_sat.deln = gps_cnav_eph.d_Delta_n;
|
||||
rtklib_sat.OMG0 = gps_cnav_eph.d_OMEGA0;
|
||||
// Compute the angle between the ascending node and the Greenwich meridian
|
||||
const double OMEGA_DOT_REF = -2.6e-9; // semicircles / s, see IS-GPS-200L pp. 160
|
||||
double d_OMEGA_DOT = OMEGA_DOT_REF * GNSS_PI + gps_cnav_eph.d_DELTA_OMEGA_DOT;
|
||||
rtklib_sat.OMGd = d_OMEGA_DOT;
|
||||
rtklib_sat.omg = gps_cnav_eph.d_OMEGA;
|
||||
rtklib_sat.i0 = gps_cnav_eph.d_i_0;
|
||||
rtklib_sat.idot = gps_cnav_eph.d_IDOT;
|
||||
rtklib_sat.e = gps_cnav_eph.d_e_eccentricity;
|
||||
rtklib_sat.Adot = gps_cnav_eph.d_A_DOT; // only in CNAV;
|
||||
rtklib_sat.ndot = gps_cnav_eph.d_DELTA_DOT_N; // only in CNAV;
|
||||
rtklib_sat.sat = gps_cnav_eph.PRN;
|
||||
rtklib_sat.A = gps_cnav_eph.sqrtA * gps_cnav_eph.sqrtA;
|
||||
rtklib_sat.M0 = gps_cnav_eph.M_0;
|
||||
rtklib_sat.deln = gps_cnav_eph.delta_n;
|
||||
rtklib_sat.OMG0 = gps_cnav_eph.OMEGA_0;
|
||||
rtklib_sat.OMGd = gps_cnav_eph.OMEGAdot;
|
||||
rtklib_sat.omg = gps_cnav_eph.omega;
|
||||
rtklib_sat.i0 = gps_cnav_eph.i_0;
|
||||
rtklib_sat.idot = gps_cnav_eph.idot;
|
||||
rtklib_sat.e = gps_cnav_eph.ecc;
|
||||
rtklib_sat.Adot = gps_cnav_eph.Adot; // only in CNAV;
|
||||
rtklib_sat.ndot = gps_cnav_eph.delta_ndot; // only in CNAV;
|
||||
|
||||
rtklib_sat.week = adjgpsweek(gps_cnav_eph.i_GPS_week); /* week of tow */
|
||||
rtklib_sat.cic = gps_cnav_eph.d_Cic;
|
||||
rtklib_sat.cis = gps_cnav_eph.d_Cis;
|
||||
rtklib_sat.cuc = gps_cnav_eph.d_Cuc;
|
||||
rtklib_sat.cus = gps_cnav_eph.d_Cus;
|
||||
rtklib_sat.crc = gps_cnav_eph.d_Crc;
|
||||
rtklib_sat.crs = gps_cnav_eph.d_Crs;
|
||||
rtklib_sat.f0 = gps_cnav_eph.d_A_f0;
|
||||
rtklib_sat.f1 = gps_cnav_eph.d_A_f1;
|
||||
rtklib_sat.f2 = gps_cnav_eph.d_A_f2;
|
||||
rtklib_sat.tgd[0] = gps_cnav_eph.d_TGD;
|
||||
rtklib_sat.week = adjgpsweek(gps_cnav_eph.WN); /* week of tow */
|
||||
rtklib_sat.cic = gps_cnav_eph.Cic;
|
||||
rtklib_sat.cis = gps_cnav_eph.Cis;
|
||||
rtklib_sat.cuc = gps_cnav_eph.Cuc;
|
||||
rtklib_sat.cus = gps_cnav_eph.Cus;
|
||||
rtklib_sat.crc = gps_cnav_eph.Crc;
|
||||
rtklib_sat.crs = gps_cnav_eph.Crs;
|
||||
rtklib_sat.f0 = gps_cnav_eph.af0;
|
||||
rtklib_sat.f1 = gps_cnav_eph.af1;
|
||||
rtklib_sat.f2 = gps_cnav_eph.af2;
|
||||
rtklib_sat.tgd[0] = gps_cnav_eph.TGD;
|
||||
rtklib_sat.tgd[1] = 0.0;
|
||||
rtklib_sat.tgd[2] = 0.0;
|
||||
rtklib_sat.tgd[3] = 0.0;
|
||||
rtklib_sat.isc[0] = gps_cnav_eph.d_ISCL1;
|
||||
rtklib_sat.isc[1] = gps_cnav_eph.d_ISCL2;
|
||||
rtklib_sat.isc[2] = gps_cnav_eph.d_ISCL5I;
|
||||
rtklib_sat.isc[3] = gps_cnav_eph.d_ISCL5Q;
|
||||
rtklib_sat.toes = gps_cnav_eph.d_Toe1;
|
||||
rtklib_sat.toc = gpst2time(rtklib_sat.week, gps_cnav_eph.d_Toc);
|
||||
rtklib_sat.ttr = gpst2time(rtklib_sat.week, gps_cnav_eph.d_TOW);
|
||||
rtklib_sat.isc[0] = gps_cnav_eph.ISCL1;
|
||||
rtklib_sat.isc[1] = gps_cnav_eph.ISCL2;
|
||||
rtklib_sat.isc[2] = gps_cnav_eph.ISCL5I;
|
||||
rtklib_sat.isc[3] = gps_cnav_eph.ISCL5Q;
|
||||
rtklib_sat.toes = gps_cnav_eph.toe1;
|
||||
rtklib_sat.toc = gpst2time(rtklib_sat.week, gps_cnav_eph.toc);
|
||||
rtklib_sat.ttr = gpst2time(rtklib_sat.week, gps_cnav_eph.tow);
|
||||
|
||||
/* adjustment for week handover */
|
||||
double tow;
|
||||
@ -421,24 +417,24 @@ alm_t alm_to_rtklib(const Gps_Almanac& gps_alm)
|
||||
|
||||
rtklib_alm = {0, 0, 0, 0, {0, 0}, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
|
||||
|
||||
rtklib_alm.sat = gps_alm.i_satellite_PRN;
|
||||
rtklib_alm.svh = gps_alm.i_SV_health;
|
||||
rtklib_alm.svconf = gps_alm.i_AS_status;
|
||||
rtklib_alm.week = gps_alm.i_WNa;
|
||||
rtklib_alm.sat = gps_alm.PRN;
|
||||
rtklib_alm.svh = gps_alm.SV_health;
|
||||
rtklib_alm.svconf = gps_alm.AS_status;
|
||||
rtklib_alm.week = gps_alm.WNa;
|
||||
gtime_t toa;
|
||||
toa.time = gps_alm.i_Toa;
|
||||
toa.time = gps_alm.toa;
|
||||
toa.sec = 0.0;
|
||||
rtklib_alm.toa = toa;
|
||||
rtklib_alm.A = gps_alm.d_sqrt_A * gps_alm.d_sqrt_A;
|
||||
rtklib_alm.e = gps_alm.d_e_eccentricity;
|
||||
rtklib_alm.i0 = (gps_alm.d_Delta_i + 0.3) * GNSS_PI;
|
||||
rtklib_alm.OMG0 = gps_alm.d_OMEGA0 * GNSS_PI;
|
||||
rtklib_alm.OMGd = gps_alm.d_OMEGA_DOT * GNSS_PI;
|
||||
rtklib_alm.omg = gps_alm.d_OMEGA * GNSS_PI;
|
||||
rtklib_alm.M0 = gps_alm.d_M_0 * GNSS_PI;
|
||||
rtklib_alm.f0 = gps_alm.d_A_f0;
|
||||
rtklib_alm.f1 = gps_alm.d_A_f1;
|
||||
rtklib_alm.toas = gps_alm.i_Toa;
|
||||
rtklib_alm.A = gps_alm.sqrtA * gps_alm.sqrtA;
|
||||
rtklib_alm.e = gps_alm.ecc;
|
||||
rtklib_alm.i0 = (gps_alm.delta_i + 0.3) * GNSS_PI;
|
||||
rtklib_alm.OMG0 = gps_alm.OMEGA_0 * GNSS_PI;
|
||||
rtklib_alm.OMGd = gps_alm.OMEGAdot * GNSS_PI;
|
||||
rtklib_alm.omg = gps_alm.omega * GNSS_PI;
|
||||
rtklib_alm.M0 = gps_alm.M_0 * GNSS_PI;
|
||||
rtklib_alm.f0 = gps_alm.af0;
|
||||
rtklib_alm.f1 = gps_alm.af1;
|
||||
rtklib_alm.toas = gps_alm.toa;
|
||||
|
||||
return rtklib_alm;
|
||||
}
|
||||
@ -450,25 +446,25 @@ alm_t alm_to_rtklib(const Galileo_Almanac& gal_alm)
|
||||
|
||||
rtklib_alm = {0, 0, 0, 0, {0, 0}, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
|
||||
|
||||
rtklib_alm.sat = gal_alm.i_satellite_PRN + NSATGPS + NSATGLO;
|
||||
rtklib_alm.sat = gal_alm.PRN + NSATGPS + NSATGLO;
|
||||
rtklib_alm.svh = gal_alm.E1B_HS;
|
||||
rtklib_alm.svconf = gal_alm.E1B_HS;
|
||||
rtklib_alm.week = gal_alm.i_WNa;
|
||||
rtklib_alm.week = gal_alm.WNa;
|
||||
gtime_t toa;
|
||||
toa.time = gal_alm.i_Toa;
|
||||
toa.time = gal_alm.toa;
|
||||
toa.sec = 0.0;
|
||||
rtklib_alm.toa = toa;
|
||||
rtklib_alm.A = 5440.588203494 + gal_alm.d_Delta_sqrt_A;
|
||||
rtklib_alm.A = 5440.588203494 + gal_alm.delta_sqrtA;
|
||||
rtklib_alm.A = rtklib_alm.A * rtklib_alm.A;
|
||||
rtklib_alm.e = gal_alm.d_e_eccentricity;
|
||||
rtklib_alm.i0 = (gal_alm.d_Delta_i + 56.0 / 180.0) * GNSS_PI;
|
||||
rtklib_alm.OMG0 = gal_alm.d_OMEGA0 * GNSS_PI;
|
||||
rtklib_alm.OMGd = gal_alm.d_OMEGA_DOT * GNSS_PI;
|
||||
rtklib_alm.omg = gal_alm.d_OMEGA * GNSS_PI;
|
||||
rtklib_alm.M0 = gal_alm.d_M_0 * GNSS_PI;
|
||||
rtklib_alm.f0 = gal_alm.d_A_f0;
|
||||
rtklib_alm.f1 = gal_alm.d_A_f1;
|
||||
rtklib_alm.toas = gal_alm.i_Toa;
|
||||
rtklib_alm.e = gal_alm.ecc;
|
||||
rtklib_alm.i0 = (gal_alm.delta_i + 56.0 / 180.0) * GNSS_PI;
|
||||
rtklib_alm.OMG0 = gal_alm.OMEGA_0 * GNSS_PI;
|
||||
rtklib_alm.OMGd = gal_alm.OMEGAdot * GNSS_PI;
|
||||
rtklib_alm.omg = gal_alm.omega * GNSS_PI;
|
||||
rtklib_alm.M0 = gal_alm.M_0 * GNSS_PI;
|
||||
rtklib_alm.f0 = gal_alm.af0;
|
||||
rtklib_alm.f1 = gal_alm.af1;
|
||||
rtklib_alm.toas = gal_alm.toa;
|
||||
|
||||
return rtklib_alm;
|
||||
}
|
||||
|
@ -381,7 +381,7 @@ void galileo_telemetry_decoder_gs::decode_INAV_word(float *page_part_symbols, in
|
||||
std::cout << TEXT_BLUE << "New Galileo E5b I/NAV message received in channel " << d_channel << ": UTC model parameters from satellite " << d_satellite << TEXT_RESET << '\n';
|
||||
}
|
||||
this->message_port_pub(pmt::mp("telemetry"), pmt::make_any(tmp_obj));
|
||||
d_delta_t = tmp_obj->A_0G_10 + tmp_obj->A_1G_10 * (static_cast<double>(d_TOW_at_current_symbol_ms) / 1000.0 - tmp_obj->t_0G_10 + 604800 * (std::fmod(static_cast<float>(d_inav_nav.get_Galileo_week() - tmp_obj->WN_0G_10), 64.0)));
|
||||
d_delta_t = tmp_obj->A_0G + tmp_obj->A_1G * (static_cast<double>(d_TOW_at_current_symbol_ms) / 1000.0 - tmp_obj->t_0G + 604800 * (std::fmod(static_cast<float>(d_inav_nav.get_Galileo_week() - tmp_obj->WN_0G), 64.0)));
|
||||
DLOG(INFO) << "delta_t=" << d_delta_t << "[s]";
|
||||
}
|
||||
if (d_inav_nav.have_new_almanac() == true)
|
||||
|
@ -411,7 +411,7 @@ int glonass_l1_ca_telemetry_decoder_gs::general_work(int noutput_items __attribu
|
||||
|
||||
// if(d_nav.flag_GGTO_1 == true and d_nav.flag_GGTO_2 == true and d_nav.flag_GGTO_3 == true and d_nav.flag_GGTO_4 == true) // all GGTO parameters arrived
|
||||
// {
|
||||
// delta_t = d_nav.A_0G_10 + d_nav.A_1G_10 * (d_TOW_at_current_symbol - d_nav.t_0G_10 + 604800.0 * (fmod((d_nav.WN_0 - d_nav.WN_0G_10), 64)));
|
||||
// delta_t = d_nav.A_0G + d_nav.A_1G * (d_TOW_at_current_symbol - d_nav.t_0G + 604800.0 * (fmod((d_nav.WN_0 - d_nav.WN_0G), 64)));
|
||||
// }
|
||||
|
||||
if (d_flag_frame_sync == true and d_nav.is_flag_TOW_set() == true)
|
||||
|
@ -410,7 +410,7 @@ int glonass_l2_ca_telemetry_decoder_gs::general_work(int noutput_items __attribu
|
||||
|
||||
// if(d_nav.flag_GGTO_1 == true and d_nav.flag_GGTO_2 == true and d_nav.flag_GGTO_3 == true and d_nav.flag_GGTO_4 == true) // all GGTO parameters arrived
|
||||
// {
|
||||
// delta_t = d_nav.A_0G_10 + d_nav.A_1G_10 * (d_TOW_at_current_symbol - d_nav.t_0G_10 + 604800.0 * (fmod((d_nav.WN_0 - d_nav.WN_0G_10), 64)));
|
||||
// delta_t = d_nav.A_0G + d_nav.A_1G * (d_TOW_at_current_symbol - d_nav.t_0G + 604800.0 * (fmod((d_nav.WN_0 - d_nav.WN_0G), 64)));
|
||||
// }
|
||||
|
||||
if (d_flag_frame_sync == true and d_nav.is_flag_TOW_set() == true)
|
||||
|
@ -200,7 +200,7 @@ void Gnss_Sdr_Supl_Client::read_supl_data()
|
||||
if (assist.set & SUPL_RRLP_ASSIST_REFTIME)
|
||||
{
|
||||
/* TS 44.031: GPSTOW, range 0-604799.92, resolution 0.08 sec, 23-bit presentation */
|
||||
gps_time.d_TOW = static_cast<double>(assist.time.gps_tow) * 0.08;
|
||||
gps_time.tow = static_cast<double>(assist.time.gps_tow) * 0.08;
|
||||
gps_time.d_Week = static_cast<double>(assist.time.gps_week);
|
||||
gps_time.d_tv_sec = static_cast<double>(assist.time.stamp.tv_sec);
|
||||
gps_time.d_tv_usec = static_cast<double>(assist.time.stamp.tv_usec);
|
||||
@ -210,29 +210,29 @@ void Gnss_Sdr_Supl_Client::read_supl_data()
|
||||
// READ UTC MODEL
|
||||
if (assist.set & SUPL_RRLP_ASSIST_UTC)
|
||||
{
|
||||
gps_utc.d_A0 = static_cast<double>(assist.utc.a0) * pow(2.0, -30);
|
||||
gps_utc.d_A1 = static_cast<double>(assist.utc.a1) * pow(2.0, -50);
|
||||
gps_utc.d_DeltaT_LS = static_cast<int32_t>(assist.utc.delta_tls);
|
||||
gps_utc.d_DeltaT_LSF = static_cast<int32_t>(assist.utc.delta_tlsf);
|
||||
gps_utc.d_t_OT = static_cast<int32_t>(assist.utc.tot) * pow(2.0, 12);
|
||||
gps_utc.i_DN = static_cast<int32_t>(assist.utc.dn);
|
||||
gps_utc.i_WN_T = static_cast<int32_t>(assist.utc.wnt);
|
||||
gps_utc.i_WN_LSF = static_cast<int32_t>(assist.utc.wnlsf);
|
||||
gps_utc.A0 = static_cast<double>(assist.utc.a0) * pow(2.0, -30);
|
||||
gps_utc.A1 = static_cast<double>(assist.utc.a1) * pow(2.0, -50);
|
||||
gps_utc.DeltaT_LS = static_cast<int32_t>(assist.utc.delta_tls);
|
||||
gps_utc.DeltaT_LSF = static_cast<int32_t>(assist.utc.delta_tlsf);
|
||||
gps_utc.tot = static_cast<int32_t>(assist.utc.tot) * pow(2.0, 12);
|
||||
gps_utc.DN = static_cast<int32_t>(assist.utc.dn);
|
||||
gps_utc.WN_T = static_cast<int32_t>(assist.utc.wnt);
|
||||
gps_utc.WN_LSF = static_cast<int32_t>(assist.utc.wnlsf);
|
||||
gps_utc.valid = true;
|
||||
}
|
||||
|
||||
// READ IONOSPHERIC MODEL
|
||||
if (assist.set & SUPL_RRLP_ASSIST_IONO)
|
||||
{
|
||||
gps_iono.d_alpha0 = static_cast<double>(assist.iono.a0) * ALPHA_0_LSB;
|
||||
gps_iono.d_alpha1 = static_cast<double>(assist.iono.a1) * ALPHA_1_LSB;
|
||||
gps_iono.d_alpha2 = static_cast<double>(assist.iono.a2) * ALPHA_2_LSB;
|
||||
gps_iono.d_alpha3 = static_cast<double>(assist.iono.a3) * ALPHA_3_LSB;
|
||||
gps_iono.alpha0 = static_cast<double>(assist.iono.a0) * ALPHA_0_LSB;
|
||||
gps_iono.alpha1 = static_cast<double>(assist.iono.a1) * ALPHA_1_LSB;
|
||||
gps_iono.alpha2 = static_cast<double>(assist.iono.a2) * ALPHA_2_LSB;
|
||||
gps_iono.alpha3 = static_cast<double>(assist.iono.a3) * ALPHA_3_LSB;
|
||||
|
||||
gps_iono.d_beta0 = static_cast<double>(assist.iono.b0) * BETA_0_LSB;
|
||||
gps_iono.d_beta1 = static_cast<double>(assist.iono.b1) * BETA_1_LSB;
|
||||
gps_iono.d_beta2 = static_cast<double>(assist.iono.b2) * BETA_2_LSB;
|
||||
gps_iono.d_beta3 = static_cast<double>(assist.iono.b3) * BETA_3_LSB;
|
||||
gps_iono.beta0 = static_cast<double>(assist.iono.b0) * BETA_0_LSB;
|
||||
gps_iono.beta1 = static_cast<double>(assist.iono.b1) * BETA_1_LSB;
|
||||
gps_iono.beta2 = static_cast<double>(assist.iono.b2) * BETA_2_LSB;
|
||||
gps_iono.beta3 = static_cast<double>(assist.iono.b3) * BETA_3_LSB;
|
||||
gps_iono.valid = true;
|
||||
}
|
||||
|
||||
@ -252,17 +252,17 @@ void Gnss_Sdr_Supl_Client::read_supl_data()
|
||||
gps_almanac_map.insert(std::pair<int, Gps_Almanac>(a->prn, gps_almanac_entry));
|
||||
gps_almanac_iterator = this->gps_almanac_map.find(a->prn);
|
||||
}
|
||||
gps_almanac_iterator->second.i_satellite_PRN = a->prn;
|
||||
gps_almanac_iterator->second.d_A_f0 = static_cast<double>(a->AF0) * pow(2.0, -20);
|
||||
gps_almanac_iterator->second.d_A_f1 = static_cast<double>(a->AF1) * pow(2.0, -38);
|
||||
gps_almanac_iterator->second.d_Delta_i = static_cast<double>(a->Ksii) * pow(2.0, -19);
|
||||
gps_almanac_iterator->second.d_OMEGA = static_cast<double>(a->w) * pow(2.0, -23);
|
||||
gps_almanac_iterator->second.d_OMEGA0 = static_cast<double>(a->OMEGA_0) * pow(2.0, -23);
|
||||
gps_almanac_iterator->second.d_sqrt_A = static_cast<double>(a->A_sqrt) * pow(2.0, -11);
|
||||
gps_almanac_iterator->second.d_OMEGA_DOT = static_cast<double>(a->OMEGA_dot) * pow(2.0, -38);
|
||||
gps_almanac_iterator->second.i_Toa = static_cast<int32_t>(a->toa * pow(2.0, 12));
|
||||
gps_almanac_iterator->second.d_e_eccentricity = static_cast<double>(a->e) * pow(2.0, -21);
|
||||
gps_almanac_iterator->second.d_M_0 = static_cast<double>(a->M0) * pow(2.0, -23);
|
||||
gps_almanac_iterator->second.PRN = a->prn;
|
||||
gps_almanac_iterator->second.af0 = static_cast<double>(a->AF0) * pow(2.0, -20);
|
||||
gps_almanac_iterator->second.af1 = static_cast<double>(a->AF1) * pow(2.0, -38);
|
||||
gps_almanac_iterator->second.delta_i = static_cast<double>(a->Ksii) * pow(2.0, -19);
|
||||
gps_almanac_iterator->second.omega = static_cast<double>(a->w) * pow(2.0, -23);
|
||||
gps_almanac_iterator->second.OMEGA_0 = static_cast<double>(a->OMEGA_0) * pow(2.0, -23);
|
||||
gps_almanac_iterator->second.sqrtA = static_cast<double>(a->A_sqrt) * pow(2.0, -11);
|
||||
gps_almanac_iterator->second.OMEGAdot = static_cast<double>(a->OMEGA_dot) * pow(2.0, -38);
|
||||
gps_almanac_iterator->second.toa = static_cast<int32_t>(a->toa * pow(2.0, 12));
|
||||
gps_almanac_iterator->second.ecc = static_cast<double>(a->e) * pow(2.0, -21);
|
||||
gps_almanac_iterator->second.M_0 = static_cast<double>(a->M0) * pow(2.0, -23);
|
||||
}
|
||||
}
|
||||
|
||||
@ -284,46 +284,46 @@ void Gnss_Sdr_Supl_Client::read_supl_data()
|
||||
}
|
||||
if (gps_time.valid)
|
||||
{
|
||||
gps_eph_iterator->second.i_GPS_week = assist.time.gps_week;
|
||||
gps_eph_iterator->second.WN = assist.time.gps_week;
|
||||
/* TS 44.031: GPSTOW, range 0-604799.92, resolution 0.08 sec, 23-bit presentation */
|
||||
gps_eph_iterator->second.d_TOW = static_cast<double>(assist.time.gps_tow) * 0.08;
|
||||
gps_eph_iterator->second.tow = static_cast<double>(assist.time.gps_tow) * 0.08;
|
||||
}
|
||||
else
|
||||
{
|
||||
gps_eph_iterator->second.i_GPS_week = 0;
|
||||
gps_eph_iterator->second.d_TOW = 0;
|
||||
gps_eph_iterator->second.WN = 0;
|
||||
gps_eph_iterator->second.tow = 0;
|
||||
}
|
||||
gps_eph_iterator->second.i_satellite_PRN = e->prn;
|
||||
gps_eph_iterator->second.PRN = e->prn;
|
||||
// SV navigation model
|
||||
gps_eph_iterator->second.i_code_on_L2 = e->bits;
|
||||
gps_eph_iterator->second.i_SV_accuracy = e->ura; // User Range Accuracy (URA)
|
||||
gps_eph_iterator->second.i_SV_health = e->health;
|
||||
gps_eph_iterator->second.d_IODC = static_cast<double>(e->IODC);
|
||||
gps_eph_iterator->second.code_on_L2 = e->bits;
|
||||
gps_eph_iterator->second.SV_accuracy = e->ura; // User Range Accuracy (URA)
|
||||
gps_eph_iterator->second.SV_health = e->health;
|
||||
gps_eph_iterator->second.IODC = static_cast<double>(e->IODC);
|
||||
// miss P flag (1 bit)
|
||||
// miss SF1 Reserved (87 bits)
|
||||
gps_eph_iterator->second.d_TGD = static_cast<double>(e->tgd) * T_GD_LSB;
|
||||
gps_eph_iterator->second.d_Toc = static_cast<double>(e->toc) * T_OC_LSB;
|
||||
gps_eph_iterator->second.d_A_f0 = static_cast<double>(e->AF0) * A_F0_LSB;
|
||||
gps_eph_iterator->second.d_A_f1 = static_cast<double>(e->AF1) * A_F1_LSB;
|
||||
gps_eph_iterator->second.d_A_f2 = static_cast<double>(e->AF2) * A_F2_LSB;
|
||||
gps_eph_iterator->second.d_Crc = static_cast<double>(e->Crc) * C_RC_LSB;
|
||||
gps_eph_iterator->second.d_Delta_n = static_cast<double>(e->delta_n) * DELTA_N_LSB;
|
||||
gps_eph_iterator->second.d_M_0 = static_cast<double>(e->M0) * M_0_LSB;
|
||||
gps_eph_iterator->second.d_Cuc = static_cast<double>(e->Cuc) * C_UC_LSB;
|
||||
gps_eph_iterator->second.d_e_eccentricity = static_cast<double>(e->e) * ECCENTRICITY_LSB;
|
||||
gps_eph_iterator->second.d_Cus = static_cast<double>(e->Cus) * C_US_LSB;
|
||||
gps_eph_iterator->second.d_sqrt_A = static_cast<double>(e->A_sqrt) * SQRT_A_LSB;
|
||||
gps_eph_iterator->second.d_Toe = static_cast<double>(e->toe) * T_OE_LSB;
|
||||
gps_eph_iterator->second.TGD = static_cast<double>(e->tgd) * T_GD_LSB;
|
||||
gps_eph_iterator->second.toc = static_cast<double>(e->toc) * T_OC_LSB;
|
||||
gps_eph_iterator->second.af0 = static_cast<double>(e->AF0) * A_F0_LSB;
|
||||
gps_eph_iterator->second.af1 = static_cast<double>(e->AF1) * A_F1_LSB;
|
||||
gps_eph_iterator->second.af2 = static_cast<double>(e->AF2) * A_F2_LSB;
|
||||
gps_eph_iterator->second.Crc = static_cast<double>(e->Crc) * C_RC_LSB;
|
||||
gps_eph_iterator->second.delta_n = static_cast<double>(e->delta_n) * DELTA_N_LSB;
|
||||
gps_eph_iterator->second.M_0 = static_cast<double>(e->M0) * M_0_LSB;
|
||||
gps_eph_iterator->second.Cuc = static_cast<double>(e->Cuc) * C_UC_LSB;
|
||||
gps_eph_iterator->second.ecc = static_cast<double>(e->e) * ECCENTRICITY_LSB;
|
||||
gps_eph_iterator->second.Cus = static_cast<double>(e->Cus) * C_US_LSB;
|
||||
gps_eph_iterator->second.sqrtA = static_cast<double>(e->A_sqrt) * SQRT_A_LSB;
|
||||
gps_eph_iterator->second.toe = static_cast<double>(e->toe) * T_OE_LSB;
|
||||
// miss fit interval flag (1 bit)
|
||||
gps_eph_iterator->second.i_AODO = e->AODA * AODO_LSB;
|
||||
gps_eph_iterator->second.d_Cic = static_cast<double>(e->Cic) * C_IC_LSB;
|
||||
gps_eph_iterator->second.d_OMEGA0 = static_cast<double>(e->OMEGA_0) * OMEGA_0_LSB;
|
||||
gps_eph_iterator->second.d_Cis = static_cast<double>(e->Cis) * C_IS_LSB;
|
||||
gps_eph_iterator->second.d_i_0 = static_cast<double>(e->i0) * I_0_LSB;
|
||||
gps_eph_iterator->second.d_Crs = static_cast<double>(e->Crs) * C_RS_LSB;
|
||||
gps_eph_iterator->second.d_OMEGA = static_cast<double>(e->w) * OMEGA_LSB;
|
||||
gps_eph_iterator->second.d_OMEGA_DOT = static_cast<double>(e->OMEGA_dot) * OMEGA_DOT_LSB;
|
||||
gps_eph_iterator->second.d_IDOT = static_cast<double>(e->i_dot) * I_DOT_LSB;
|
||||
gps_eph_iterator->second.AODO = e->AODA * AODO_LSB;
|
||||
gps_eph_iterator->second.Cic = static_cast<double>(e->Cic) * C_IC_LSB;
|
||||
gps_eph_iterator->second.OMEGA_0 = static_cast<double>(e->OMEGA_0) * OMEGA_0_LSB;
|
||||
gps_eph_iterator->second.Cis = static_cast<double>(e->Cis) * C_IS_LSB;
|
||||
gps_eph_iterator->second.i_0 = static_cast<double>(e->i0) * I_0_LSB;
|
||||
gps_eph_iterator->second.Crs = static_cast<double>(e->Crs) * C_RS_LSB;
|
||||
gps_eph_iterator->second.omega = static_cast<double>(e->w) * OMEGA_LSB;
|
||||
gps_eph_iterator->second.OMEGAdot = static_cast<double>(e->OMEGA_dot) * OMEGA_DOT_LSB;
|
||||
gps_eph_iterator->second.idot = static_cast<double>(e->i_dot) * I_DOT_LSB;
|
||||
}
|
||||
}
|
||||
|
||||
@ -345,10 +345,10 @@ void Gnss_Sdr_Supl_Client::read_supl_data()
|
||||
gps_acq_iterator = this->gps_acq_map.find(e->prn);
|
||||
}
|
||||
// fill the acquisition assistance structure
|
||||
gps_acq_iterator->second.i_satellite_PRN = e->prn;
|
||||
gps_acq_iterator->second.d_TOW = static_cast<double>(assist.acq_time);
|
||||
gps_acq_iterator->second.d_Doppler0 = static_cast<double>(e->doppler0);
|
||||
gps_acq_iterator->second.d_Doppler1 = static_cast<double>(e->doppler1);
|
||||
gps_acq_iterator->second.PRN = e->prn;
|
||||
gps_acq_iterator->second.tow = static_cast<double>(assist.acq_time);
|
||||
gps_acq_iterator->second.Doppler0 = static_cast<double>(e->doppler0);
|
||||
gps_acq_iterator->second.Doppler1 = static_cast<double>(e->doppler1);
|
||||
gps_acq_iterator->second.dopplerUncertainty = static_cast<double>(e->d_win);
|
||||
gps_acq_iterator->second.Code_Phase = static_cast<double>(e->code_ph);
|
||||
gps_acq_iterator->second.Code_Phase_int = static_cast<double>(e->code_ph_int);
|
||||
@ -754,7 +754,7 @@ bool Gnss_Sdr_Supl_Client::load_gal_iono_xml(const std::string& file_name)
|
||||
|
||||
bool Gnss_Sdr_Supl_Client::save_gal_iono_xml(const std::string& file_name, Galileo_Iono& iono)
|
||||
{
|
||||
if (iono.ai0_5 != 0.0)
|
||||
if (iono.ai0 != 0.0)
|
||||
{
|
||||
std::ofstream ofs;
|
||||
try
|
||||
@ -864,19 +864,19 @@ bool Gnss_Sdr_Supl_Client::read_gal_almanac_from_gsa(const std::string& file_nam
|
||||
try
|
||||
{
|
||||
uint32_t prn = static_cast<uint32_t>(std::stoi(almanac.child_value("SVID")));
|
||||
gal_alm.i_satellite_PRN = prn;
|
||||
gal_alm.i_Toa = std::stoi(almanac.child("almanac").child_value("t0a"));
|
||||
gal_alm.i_WNa = std::stoi(almanac.child("almanac").child_value("wna"));
|
||||
gal_alm.i_IODa = std::stoi(almanac.child("almanac").child_value("iod"));
|
||||
gal_alm.d_Delta_i = std::stod(almanac.child("almanac").child_value("deltai"));
|
||||
gal_alm.d_M_0 = std::stod(almanac.child("almanac").child_value("m0"));
|
||||
gal_alm.d_e_eccentricity = std::stod(almanac.child("almanac").child_value("ecc"));
|
||||
gal_alm.d_Delta_sqrt_A = std::stod(almanac.child("almanac").child_value("aSqRoot"));
|
||||
gal_alm.d_OMEGA0 = std::stod(almanac.child("almanac").child_value("omega0"));
|
||||
gal_alm.d_OMEGA = std::stod(almanac.child("almanac").child_value("w"));
|
||||
gal_alm.d_OMEGA_DOT = std::stod(almanac.child("almanac").child_value("omegaDot"));
|
||||
gal_alm.d_A_f0 = std::stod(almanac.child("almanac").child_value("af0"));
|
||||
gal_alm.d_A_f1 = std::stod(almanac.child("almanac").child_value("af1"));
|
||||
gal_alm.PRN = prn;
|
||||
gal_alm.toa = std::stoi(almanac.child("almanac").child_value("t0a"));
|
||||
gal_alm.WNa = std::stoi(almanac.child("almanac").child_value("wna"));
|
||||
gal_alm.IODa = std::stoi(almanac.child("almanac").child_value("iod"));
|
||||
gal_alm.delta_i = std::stod(almanac.child("almanac").child_value("deltai"));
|
||||
gal_alm.M_0 = std::stod(almanac.child("almanac").child_value("m0"));
|
||||
gal_alm.ecc = std::stod(almanac.child("almanac").child_value("ecc"));
|
||||
gal_alm.delta_sqrtA = std::stod(almanac.child("almanac").child_value("aSqRoot"));
|
||||
gal_alm.OMEGA_0 = std::stod(almanac.child("almanac").child_value("omega0"));
|
||||
gal_alm.omega = std::stod(almanac.child("almanac").child_value("w"));
|
||||
gal_alm.OMEGAdot = std::stod(almanac.child("almanac").child_value("omegaDot"));
|
||||
gal_alm.af0 = std::stod(almanac.child("almanac").child_value("af0"));
|
||||
gal_alm.af1 = std::stod(almanac.child("almanac").child_value("af1"));
|
||||
gal_alm.E5b_HS = std::stoi(almanac.child("svINavSignalStatus").child_value("statusE5b"));
|
||||
gal_alm.E1B_HS = std::stoi(almanac.child("svINavSignalStatus").child_value("statusE1B"));
|
||||
gal_alm.E5a_HS = std::stoi(almanac.child("svFNavSignalStatus").child_value("statusE5a"));
|
||||
|
@ -496,7 +496,7 @@ bool ControlThread::read_assistance_from_XML()
|
||||
gps_eph_iter != supl_client_ephemeris_.gps_ephemeris_map.cend();
|
||||
gps_eph_iter++)
|
||||
{
|
||||
std::cout << "From XML file: Read NAV ephemeris for satellite " << Gnss_Satellite("GPS", gps_eph_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "From XML file: Read NAV ephemeris for satellite " << Gnss_Satellite("GPS", gps_eph_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Gps_Ephemeris> tmp_obj = std::make_shared<Gps_Ephemeris>(gps_eph_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -526,7 +526,7 @@ bool ControlThread::read_assistance_from_XML()
|
||||
gps_alm_iter != supl_client_ephemeris_.gps_almanac_map.cend();
|
||||
gps_alm_iter++)
|
||||
{
|
||||
std::cout << "From XML file: Read GPS almanac for satellite " << Gnss_Satellite("GPS", gps_alm_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "From XML file: Read GPS almanac for satellite " << Gnss_Satellite("GPS", gps_alm_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Gps_Almanac> tmp_obj = std::make_shared<Gps_Almanac>(gps_alm_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -543,7 +543,7 @@ bool ControlThread::read_assistance_from_XML()
|
||||
gal_eph_iter != supl_client_ephemeris_.gal_ephemeris_map.cend();
|
||||
gal_eph_iter++)
|
||||
{
|
||||
std::cout << "From XML file: Read ephemeris for satellite " << Gnss_Satellite("Galileo", gal_eph_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "From XML file: Read ephemeris for satellite " << Gnss_Satellite("Galileo", gal_eph_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Galileo_Ephemeris> tmp_obj = std::make_shared<Galileo_Ephemeris>(gal_eph_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -573,7 +573,7 @@ bool ControlThread::read_assistance_from_XML()
|
||||
gal_alm_iter != supl_client_ephemeris_.gal_almanac_map.cend();
|
||||
gal_alm_iter++)
|
||||
{
|
||||
std::cout << "From XML file: Read Galileo almanac for satellite " << Gnss_Satellite("Galileo", gal_alm_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "From XML file: Read Galileo almanac for satellite " << Gnss_Satellite("Galileo", gal_alm_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Galileo_Almanac> tmp_obj = std::make_shared<Galileo_Almanac>(gal_alm_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -590,7 +590,7 @@ bool ControlThread::read_assistance_from_XML()
|
||||
gps_cnav_eph_iter != supl_client_ephemeris_.gps_cnav_ephemeris_map.cend();
|
||||
gps_cnav_eph_iter++)
|
||||
{
|
||||
std::cout << "From XML file: Read CNAV ephemeris for satellite " << Gnss_Satellite("GPS", gps_cnav_eph_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "From XML file: Read CNAV ephemeris for satellite " << Gnss_Satellite("GPS", gps_cnav_eph_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Gps_CNAV_Ephemeris> tmp_obj = std::make_shared<Gps_CNAV_Ephemeris>(gps_cnav_eph_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -615,7 +615,7 @@ bool ControlThread::read_assistance_from_XML()
|
||||
glo_gnav_eph_iter != supl_client_ephemeris_.glonass_gnav_ephemeris_map.cend();
|
||||
glo_gnav_eph_iter++)
|
||||
{
|
||||
std::cout << "From XML file: Read GLONASS GNAV ephemeris for satellite " << Gnss_Satellite("GLONASS", glo_gnav_eph_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "From XML file: Read GLONASS GNAV ephemeris for satellite " << Gnss_Satellite("GLONASS", glo_gnav_eph_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Glonass_Gnav_Ephemeris> tmp_obj = std::make_shared<Glonass_Gnav_Ephemeris>(glo_gnav_eph_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -744,7 +744,7 @@ void ControlThread::assist_GNSS()
|
||||
gps_eph_iter != supl_client_ephemeris_.gps_ephemeris_map.cend();
|
||||
gps_eph_iter++)
|
||||
{
|
||||
std::cout << "SUPL: Received ephemeris data for satellite " << Gnss_Satellite("GPS", gps_eph_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "SUPL: Received ephemeris data for satellite " << Gnss_Satellite("GPS", gps_eph_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Gps_Ephemeris> tmp_obj = std::make_shared<Gps_Ephemeris>(gps_eph_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -781,7 +781,7 @@ void ControlThread::assist_GNSS()
|
||||
gps_alm_iter != supl_client_ephemeris_.gps_almanac_map.cend();
|
||||
gps_alm_iter++)
|
||||
{
|
||||
std::cout << "SUPL: Received almanac data for satellite " << Gnss_Satellite("GPS", gps_alm_iter->second.i_satellite_PRN) << '\n';
|
||||
std::cout << "SUPL: Received almanac data for satellite " << Gnss_Satellite("GPS", gps_alm_iter->second.PRN) << '\n';
|
||||
const std::shared_ptr<Gps_Almanac> tmp_obj = std::make_shared<Gps_Almanac>(gps_alm_iter->second);
|
||||
flowgraph_->send_telemetry_msg(pmt::make_any(tmp_obj));
|
||||
}
|
||||
@ -835,8 +835,8 @@ void ControlThread::assist_GNSS()
|
||||
gps_acq_iter != supl_client_acquisition_.gps_acq_map.cend();
|
||||
gps_acq_iter++)
|
||||
{
|
||||
std::cout << "SUPL: Received acquisition assistance data for satellite " << Gnss_Satellite("GPS", gps_acq_iter->second.i_satellite_PRN) << '\n';
|
||||
global_gps_acq_assist_map.write(gps_acq_iter->second.i_satellite_PRN, gps_acq_iter->second);
|
||||
std::cout << "SUPL: Received acquisition assistance data for satellite " << Gnss_Satellite("GPS", gps_acq_iter->second.PRN) << '\n';
|
||||
global_gps_acq_assist_map.write(gps_acq_iter->second.PRN, gps_acq_iter->second);
|
||||
}
|
||||
if (supl_client_acquisition_.gps_ref_loc.valid == true)
|
||||
{
|
||||
@ -1006,10 +1006,10 @@ std::vector<std::pair<int, Gnss_Satellite>> ControlThread::get_visible_sats(time
|
||||
// push sat
|
||||
if (El > 0)
|
||||
{
|
||||
std::cout << "Using GPS Ephemeris: Sat " << it.second.i_satellite_PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
std::cout << "Using GPS Ephemeris: Sat " << it.second.PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
available_satellites.emplace_back(floor(El),
|
||||
(Gnss_Satellite(std::string("GPS"), it.second.i_satellite_PRN)));
|
||||
visible_gps.push_back(it.second.i_satellite_PRN);
|
||||
(Gnss_Satellite(std::string("GPS"), it.second.PRN)));
|
||||
visible_gps.push_back(it.second.PRN);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1031,10 +1031,10 @@ std::vector<std::pair<int, Gnss_Satellite>> ControlThread::get_visible_sats(time
|
||||
// push sat
|
||||
if (El > 0)
|
||||
{
|
||||
std::cout << "Using Galileo Ephemeris: Sat " << it.second.i_satellite_PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
std::cout << "Using Galileo Ephemeris: Sat " << it.second.PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
available_satellites.emplace_back(floor(El),
|
||||
(Gnss_Satellite(std::string("Galileo"), it.second.i_satellite_PRN)));
|
||||
visible_gal.push_back(it.second.i_satellite_PRN);
|
||||
(Gnss_Satellite(std::string("Galileo"), it.second.PRN)));
|
||||
visible_gal.push_back(it.second.PRN);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1058,12 +1058,12 @@ std::vector<std::pair<int, Gnss_Satellite>> ControlThread::get_visible_sats(time
|
||||
std::vector<unsigned int>::iterator it2;
|
||||
if (El > 0)
|
||||
{
|
||||
it2 = std::find(visible_gps.begin(), visible_gps.end(), it.second.i_satellite_PRN);
|
||||
it2 = std::find(visible_gps.begin(), visible_gps.end(), it.second.PRN);
|
||||
if (it2 == visible_gps.end())
|
||||
{
|
||||
std::cout << "Using GPS Almanac: Sat " << it.second.i_satellite_PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
std::cout << "Using GPS Almanac: Sat " << it.second.PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
available_satellites.emplace_back(floor(El),
|
||||
(Gnss_Satellite(std::string("GPS"), it.second.i_satellite_PRN)));
|
||||
(Gnss_Satellite(std::string("GPS"), it.second.PRN)));
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1088,12 +1088,12 @@ std::vector<std::pair<int, Gnss_Satellite>> ControlThread::get_visible_sats(time
|
||||
std::vector<unsigned int>::iterator it2;
|
||||
if (El > 0)
|
||||
{
|
||||
it2 = std::find(visible_gal.begin(), visible_gal.end(), it.second.i_satellite_PRN);
|
||||
it2 = std::find(visible_gal.begin(), visible_gal.end(), it.second.PRN);
|
||||
if (it2 == visible_gal.end())
|
||||
{
|
||||
std::cout << "Using Galileo Almanac: Sat " << it.second.i_satellite_PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
std::cout << "Using Galileo Almanac: Sat " << it.second.PRN << " Az: " << Az << " El: " << El << '\n';
|
||||
available_satellites.emplace_back(floor(El),
|
||||
(Gnss_Satellite(std::string("Galileo"), it.second.i_satellite_PRN)));
|
||||
(Gnss_Satellite(std::string("Galileo"), it.second.PRN)));
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1116,28 +1116,28 @@ void ControlThread::gps_acq_assist_data_collector() const
|
||||
while (stop_ == false)
|
||||
{
|
||||
global_gps_acq_assist_queue.wait_and_pop(gps_acq);
|
||||
if (gps_acq.i_satellite_PRN == 0)
|
||||
if (gps_acq.PRN == 0)
|
||||
{
|
||||
break;
|
||||
}
|
||||
|
||||
// DEBUG MESSAGE
|
||||
std::cout << "Acquisition assistance record has arrived from SAT ID "
|
||||
<< gps_acq.i_satellite_PRN
|
||||
<< gps_acq.PRN
|
||||
<< " with Doppler "
|
||||
<< gps_acq.d_Doppler0
|
||||
<< gps_acq.Doppler0
|
||||
<< " [Hz]\n";
|
||||
// insert new acq record to the global ephemeris map
|
||||
if (global_gps_acq_assist_map.read(gps_acq.i_satellite_PRN, gps_acq_old))
|
||||
if (global_gps_acq_assist_map.read(gps_acq.PRN, gps_acq_old))
|
||||
{
|
||||
std::cout << "Acquisition assistance record updated\n";
|
||||
global_gps_acq_assist_map.write(gps_acq.i_satellite_PRN, gps_acq);
|
||||
global_gps_acq_assist_map.write(gps_acq.PRN, gps_acq);
|
||||
}
|
||||
else
|
||||
{
|
||||
// insert new acq record
|
||||
LOG(INFO) << "New acq assist record inserted";
|
||||
global_gps_acq_assist_map.write(gps_acq.i_satellite_PRN, gps_acq);
|
||||
global_gps_acq_assist_map.write(gps_acq.PRN, gps_acq);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -6,6 +6,7 @@
|
||||
|
||||
|
||||
set(SYSTEM_PARAMETERS_SOURCES
|
||||
gnss_ephemeris.cc
|
||||
gnss_satellite.cc
|
||||
gnss_signal.cc
|
||||
gps_navigation_message.cc
|
||||
@ -19,7 +20,6 @@ set(SYSTEM_PARAMETERS_SOURCES
|
||||
beidou_dnav_navigation_message.cc
|
||||
beidou_dnav_ephemeris.cc
|
||||
sbas_ephemeris.cc
|
||||
gps_cnav_ephemeris.cc
|
||||
gps_cnav_navigation_message.cc
|
||||
glonass_gnav_ephemeris.cc
|
||||
glonass_gnav_utc_model.cc
|
||||
@ -27,6 +27,7 @@ set(SYSTEM_PARAMETERS_SOURCES
|
||||
)
|
||||
|
||||
set(SYSTEM_PARAMETERS_HEADERS
|
||||
gnss_ephemeris.h
|
||||
gnss_satellite.h
|
||||
gnss_signal.h
|
||||
gps_navigation_message.h
|
||||
|
@ -159,6 +159,8 @@ constexpr int32_t CNAV_DN_LSB = 1;
|
||||
const std::vector<std::pair<int32_t, int32_t> > CNAV_DELTA_TLSF({{218, 8}});
|
||||
constexpr int32_t CNAV_DELTA_TLSF_LSB = 1;
|
||||
|
||||
constexpr double CNAV_A_REF = 26559710.0; // See IS-GPS-200L, pp. 161
|
||||
constexpr double CNAV_OMEGA_DOT_REF = -2.6e-9; // semicircles / s, see IS-GPS-200L pp. 160
|
||||
|
||||
// TODO: Add more frames (Almanac, etc...)
|
||||
|
||||
|
@ -46,7 +46,8 @@ public:
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the Ref location on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the Ref location on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
@ -54,10 +55,10 @@ public:
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("lat", lat);
|
||||
archive& make_nvp("lon", lon);
|
||||
archive& make_nvp("uncertainty", uncertainty);
|
||||
archive& make_nvp("valid", valid);
|
||||
archive& BOOST_SERIALIZATION_NVP(lat);
|
||||
archive& BOOST_SERIALIZATION_NVP(lon);
|
||||
archive& BOOST_SERIALIZATION_NVP(uncertainty);
|
||||
archive& BOOST_SERIALIZATION_NVP(valid);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -38,7 +38,7 @@ public:
|
||||
*/
|
||||
Agnss_Ref_Time() = default;
|
||||
|
||||
double d_TOW{};
|
||||
double tow{};
|
||||
double d_Week{};
|
||||
double d_tv_sec{};
|
||||
double d_tv_usec{};
|
||||
@ -47,19 +47,19 @@ public:
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ref time data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ref time data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("d_TOW", d_TOW);
|
||||
archive& make_nvp("d_Week", d_Week);
|
||||
archive& make_nvp("d_tv_sec", d_tv_sec);
|
||||
archive& make_nvp("d_tv_usec", d_tv_usec);
|
||||
archive& make_nvp("valid", valid);
|
||||
archive& BOOST_SERIALIZATION_NVP(tow);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Week);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_tv_sec);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_tv_usec);
|
||||
archive& BOOST_SERIALIZATION_NVP(valid);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -37,18 +37,18 @@ public:
|
||||
*/
|
||||
Beidou_Dnav_Almanac() = default;
|
||||
|
||||
unsigned int i_satellite_PRN{}; //!< SV PRN NUMBER
|
||||
double d_Delta_i{};
|
||||
double d_Toa{}; //!< Almanac data reference time of week [s]
|
||||
double d_M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double d_e_eccentricity{}; //!< Eccentricity [dimensionless]
|
||||
double d_sqrt_A{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
double d_OMEGA0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double d_OMEGA{}; //!< Argument of Perigee [semi-cicles]
|
||||
double d_OMEGA_DOT{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
int i_SV_health{}; //!< SV Health
|
||||
double d_A_f0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double d_A_f1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
unsigned int PRN{}; //!< SV PRN NUMBER
|
||||
double delta_i{};
|
||||
double toa{}; //!< Almanac data reference time of week [s]
|
||||
double M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double ecc{}; //!< Eccentricity [dimensionless]
|
||||
double sqrtA{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
double OMEGA_0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double omega{}; //!< Argument of Perigee [semi-cicles]
|
||||
double OMEGAdot{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
int SV_health{}; //!< SV Health
|
||||
double af0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double af1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
|
||||
template <class Archive>
|
||||
|
||||
@ -57,20 +57,20 @@ public:
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
ar& BOOST_SERIALIZATION_NVP(i_satellite_PRN);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_Delta_i);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_Toa);
|
||||
// ar& BOOST_SERIALIZATION_NVP(i_WNa);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_M_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_e_eccentricity);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_sqrt_A);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA_DOT);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_SV_health);
|
||||
// ar& BOOST_SERIALIZATION_NVP(i_AS_status);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_A_f0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_A_f1);
|
||||
ar& BOOST_SERIALIZATION_NVP(PRN);
|
||||
ar& BOOST_SERIALIZATION_NVP(delta_i);
|
||||
ar& BOOST_SERIALIZATION_NVP(toa);
|
||||
// ar& BOOST_SERIALIZATION_NVP(WNa);
|
||||
ar& BOOST_SERIALIZATION_NVP(M_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(ecc);
|
||||
ar& BOOST_SERIALIZATION_NVP(sqrtA);
|
||||
ar& BOOST_SERIALIZATION_NVP(OMEGA_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(omega);
|
||||
ar& BOOST_SERIALIZATION_NVP(OMEGAdot);
|
||||
ar& BOOST_SERIALIZATION_NVP(SV_health);
|
||||
// ar& BOOST_SERIALIZATION_NVP(AS_status);
|
||||
ar& BOOST_SERIALIZATION_NVP(af0);
|
||||
ar& BOOST_SERIALIZATION_NVP(af1);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -15,10 +15,8 @@
|
||||
*/
|
||||
|
||||
#include "beidou_dnav_ephemeris.h"
|
||||
#include "Beidou_DNAV.h"
|
||||
#include "gnss_satellite.h"
|
||||
#include <cmath>
|
||||
|
||||
#include <string>
|
||||
|
||||
Beidou_Dnav_Ephemeris::Beidou_Dnav_Ephemeris()
|
||||
{
|
||||
@ -28,191 +26,5 @@ Beidou_Dnav_Ephemeris::Beidou_Dnav_Ephemeris()
|
||||
{
|
||||
satelliteBlock[i] = gnss_sat.what_block(_system, i);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
double Beidou_Dnav_Ephemeris::check_t(double time)
|
||||
{
|
||||
const double half_week = 302400.0; // seconds
|
||||
double corrTime = time;
|
||||
if (time > half_week)
|
||||
{
|
||||
corrTime = time - 2.0 * half_week;
|
||||
}
|
||||
else if (time < -half_week)
|
||||
{
|
||||
corrTime = time + 2.0 * half_week;
|
||||
}
|
||||
return corrTime;
|
||||
}
|
||||
|
||||
|
||||
double Beidou_Dnav_Ephemeris::sv_clock_drift(double transmitTime)
|
||||
{
|
||||
double dt = check_t(transmitTime - d_Toc);
|
||||
|
||||
for (int i = 0; i < 2; i++)
|
||||
{
|
||||
dt -= d_A_f0 + d_A_f1 * dt + d_A_f2 * (dt * dt);
|
||||
}
|
||||
d_satClkDrift = d_A_f0 + d_A_f1 * dt + d_A_f2 * (dt * dt);
|
||||
|
||||
return d_satClkDrift;
|
||||
}
|
||||
|
||||
|
||||
// compute the relativistic correction term
|
||||
double Beidou_Dnav_Ephemeris::sv_clock_relativistic_term(double transmitTime)
|
||||
{
|
||||
// Restore semi-major axis
|
||||
const double a = d_sqrt_A * d_sqrt_A;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
const double tk = check_t(transmitTime - d_Toe);
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(BEIDOU_GM / (a * a * a));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + d_Delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
double M = d_M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + d_eccentricity * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Compute relativistic correction term
|
||||
d_dtr = BEIDOU_F * d_eccentricity * d_sqrt_A * sin(E);
|
||||
return d_dtr;
|
||||
}
|
||||
|
||||
|
||||
double Beidou_Dnav_Ephemeris::satellitePosition(double transmitTime)
|
||||
{
|
||||
// Find satellite's position -----------------------------------------------
|
||||
// Restore semi-major axis
|
||||
const double a = d_sqrt_A * d_sqrt_A;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
double tk = check_t(transmitTime - d_Toe);
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(BEIDOU_GM / (a * a * a));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + d_Delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
double M = d_M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + d_eccentricity * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Compute the true anomaly
|
||||
const double sek = sin(E);
|
||||
const double cek = cos(E);
|
||||
const double OneMinusecosE = 1.0 - d_eccentricity * cek;
|
||||
const double ekdot = n / OneMinusecosE;
|
||||
|
||||
// Compute the true anomaly
|
||||
const double sq1e2 = sqrt(1.0 - d_eccentricity * d_eccentricity);
|
||||
const double tmp_Y = sq1e2 * sek;
|
||||
const double tmp_X = cek - d_eccentricity;
|
||||
const double nu = atan2(tmp_Y, tmp_X);
|
||||
|
||||
// Compute angle phi (argument of Latitude)
|
||||
const double phi = nu + d_OMEGA;
|
||||
double pkdot = sq1e2 * ekdot / OneMinusecosE;
|
||||
|
||||
// Reduce phi to between 0 and 2*pi rad
|
||||
// phi = fmod((phi), (2.0 * GNSS_PI));
|
||||
const double s2pk = sin(2.0 * phi);
|
||||
const double c2pk = cos(2.0 * phi);
|
||||
|
||||
// Correct argument of latitude
|
||||
const double u = phi + d_Cuc * c2pk + d_Cus * s2pk;
|
||||
const double cuk = cos(u);
|
||||
const double suk = sin(u);
|
||||
const double ukdot = pkdot * (1.0 + 2.0 * (d_Cus * c2pk - d_Cuc * s2pk));
|
||||
|
||||
// Correct radius
|
||||
const double r = a * (1.0 - d_eccentricity * cek) + d_Crc * c2pk + d_Crs * s2pk;
|
||||
|
||||
const double rkdot = a * d_eccentricity * sek * ekdot + 2.0 * pkdot * (d_Crs * c2pk - d_Crc * s2pk);
|
||||
|
||||
// Correct inclination
|
||||
const double i = d_i_0 + d_IDOT * tk + d_Cic * c2pk + d_Cis * s2pk;
|
||||
const double sik = sin(i);
|
||||
const double cik = cos(i);
|
||||
const double ikdot = d_IDOT + 2.0 * pkdot * (d_Cis * c2pk - d_Cic * s2pk);
|
||||
|
||||
// Compute the angle between the ascending node and the Greenwich meridian
|
||||
const double Omega = d_OMEGA0 + (d_OMEGA_DOT - BEIDOU_OMEGA_EARTH_DOT) * tk - BEIDOU_OMEGA_EARTH_DOT * d_Toe;
|
||||
const double sok = sin(Omega);
|
||||
const double cok = cos(Omega);
|
||||
|
||||
// --- Compute satellite coordinates in Earth-fixed coordinates
|
||||
const double xprime = r * cuk;
|
||||
const double yprime = r * suk;
|
||||
d_satpos_X = xprime * cok - yprime * cik * sok;
|
||||
d_satpos_Y = xprime * sok + yprime * cik * cok;
|
||||
d_satpos_Z = yprime * sik;
|
||||
|
||||
// Satellite's velocity. Can be useful for Vector Tracking loops
|
||||
const double Omega_dot = d_OMEGA_DOT - BEIDOU_OMEGA_EARTH_DOT;
|
||||
|
||||
const double xpkdot = rkdot * cuk - yprime * ukdot;
|
||||
const double ypkdot = rkdot * suk + xprime * ukdot;
|
||||
const double tmp = ypkdot * cik - d_satpos_Z * ikdot;
|
||||
|
||||
d_satvel_X = -Omega_dot * d_satpos_Y + xpkdot * cok - tmp * sok;
|
||||
d_satvel_Y = Omega_dot * d_satpos_X + xpkdot * sok + tmp * cok;
|
||||
d_satvel_Z = yprime * cik * ikdot + ypkdot * sik;
|
||||
|
||||
// Time from ephemeris reference clock
|
||||
tk = check_t(transmitTime - d_Toc);
|
||||
|
||||
double dtr_s = d_A_f0 + d_A_f1 * tk + d_A_f2 * tk * tk;
|
||||
|
||||
/* relativity correction */
|
||||
dtr_s -= 2.0 * sqrt(BEIDOU_GM * a) * d_eccentricity * sek / (SPEED_OF_LIGHT_M_S * SPEED_OF_LIGHT_M_S);
|
||||
|
||||
return dtr_s;
|
||||
this->System = 'B';
|
||||
}
|
||||
|
@ -18,6 +18,7 @@
|
||||
#ifndef GNSS_SDR_BEIDOU_DNAV_EPHEMERIS_H
|
||||
#define GNSS_SDR_BEIDOU_DNAV_EPHEMERIS_H
|
||||
|
||||
#include "gnss_ephemeris.h"
|
||||
#include <boost/serialization/nvp.hpp>
|
||||
#include <map>
|
||||
#include <string>
|
||||
@ -29,13 +30,13 @@
|
||||
|
||||
|
||||
/*!
|
||||
* \brief This class is a storage and orbital model functions for the GPS SV ephemeris data as described in
|
||||
* \brief This is a storage class for the Beidou SV ephemeris data as described in
|
||||
* BeiDou Navigation Satellite System Signal In Space Interface Control Document
|
||||
* Open Service Signal B1I (Version 3.0)
|
||||
*
|
||||
* See http://en.beidou.gov.cn/SYSTEMS/Officialdocument/201902/P020190227601370045731.pdf
|
||||
*/
|
||||
class Beidou_Dnav_Ephemeris
|
||||
class Beidou_Dnav_Ephemeris : public Gnss_Ephemeris
|
||||
{
|
||||
public:
|
||||
/*!
|
||||
@ -43,99 +44,45 @@ public:
|
||||
*/
|
||||
Beidou_Dnav_Ephemeris();
|
||||
|
||||
/*!
|
||||
* \brief Compute the ECEF SV coordinates and ECEF velocity
|
||||
* Implementation of Table 20-IV (IS-GPS-200L)
|
||||
* and compute the clock bias term including relativistic effect (return value)
|
||||
*/
|
||||
double satellitePosition(double transmitTime);
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a d_satClkDrift)and returns the clock drift in seconds according to the User Algorithm for SV Clock Correction
|
||||
* (IS-GPS-200L, 20.3.3.3.3.1)
|
||||
*/
|
||||
double sv_clock_drift(double transmitTime);
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a d_dtr) and returns the clock relativistic correction term in seconds according to the User Algorithm for SV Clock Correction
|
||||
* (IS-GPS-200L, 20.3.3.3.3.1)
|
||||
*/
|
||||
double sv_clock_relativistic_term(double transmitTime);
|
||||
|
||||
unsigned int i_satellite_PRN{}; //!< SV PRN NUMBER
|
||||
double d_TOW{}; //!< Time of BEIDOU Week of the ephemeris set (taken from subframes TOW) [s]
|
||||
double d_Crs{}; //!< Amplitude of the Sine Harmonic Correction Term to the Orbit Radius [m]
|
||||
double d_Delta_n{}; //!< Mean Motion Difference From Computed Value [semi-circles/s]
|
||||
double d_M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double d_Cuc{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
double d_eccentricity{}; //!< Eccentricity [dimensionless]
|
||||
double d_Cus{}; //!< Amplitude of the Sine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
double d_sqrt_A{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
double d_Toe{}; //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
double d_Toc{}; //!< clock data reference time (Ref. 20.3.3.3.3.1 IS-GPS-200L) [s]
|
||||
double d_Cic{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
double d_OMEGA0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double d_Cis{}; //!< Amplitude of the Sine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
double d_i_0{}; //!< Inclination Angle at Reference Time [semi-circles]
|
||||
double d_Crc{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Orbit Radius [m]
|
||||
double d_OMEGA{}; //!< Argument of Perigee [semi-cicles]
|
||||
double d_OMEGA_DOT{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
double d_IDOT{}; //!< Rate of Inclination Angle [semi-circles/s]
|
||||
int i_BEIDOU_week{}; //!< BEIDOU week number, aka WN [week]
|
||||
int i_SV_accuracy{}; //!< User Range Accuracy (URA) index of the SV (reference paragraph 6.2.1) for the standard positioning service user (Ref 20.3.3.3.1.3 IS-GPS-200L)
|
||||
int i_SV_health{};
|
||||
int SV_accuracy{}; //!< User Range Accuracy (URA) index of the SV (reference paragraph 6.2.1) for the standard positioning service user (Ref 20.3.3.3.1.3 IS-GPS-200L)
|
||||
int SV_health{};
|
||||
double d_TGD1{}; //!< Estimated Group Delay Differential on B1I [s]
|
||||
double d_TGD2{}; //!< Estimated Group Delay Differential on B2I [s]
|
||||
double d_AODC{}; //!< Age of Data, Clock
|
||||
double d_AODE{}; //!< Age of Data, Ephemeris
|
||||
int i_AODO{}; //!< Age of Data Offset (AODO) term for the navigation message correction table (NMCT) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
int AODO{}; //!< Age of Data Offset (AODO) term for the navigation message correction table (NMCT) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
|
||||
int i_sig_type{}; //!< BDS: data source (0:unknown,1:B1I,2:B1Q,3:B2I,4:B2Q,5:B3I,6:B3Q) */
|
||||
int i_nav_type{}; //!< BDS: nav type (0:unknown,1:IGSO/MEO,2:GEO) */
|
||||
|
||||
bool b_fit_interval_flag{}; //!< indicates the curve-fit interval used by the CS (Block II/IIA/IIR/IIR-M/IIF) and SS (Block IIIA) in determining the ephemeris parameters, as follows: 0 = 4 hours, 1 = greater than 4 hours.
|
||||
bool b_fit_interval_flag{}; //!< Curve-fit interval used by the CS (Block II/IIA/IIR/IIR-M/IIF) and SS (Block IIIA) in determining the ephemeris parameters, as follows: 0 = 4 hours, 1 = greater than 4 hours.
|
||||
double d_spare1{};
|
||||
double d_spare2{};
|
||||
|
||||
double d_A_f0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double d_A_f1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
double d_A_f2{}; //!< Coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
/*! \brief If true, enhanced level of integrity assurance.
|
||||
*
|
||||
* If false, indicates that the conveying signal is provided with the legacy level of integrity assurance.
|
||||
* That is, the probability that the instantaneous URE of the conveying signal exceeds 4.42 times the upper bound
|
||||
* value of the current broadcast URA index, for more than 5.2 seconds, without an accompanying alert, is less
|
||||
* than 1E-5 per hour. If true, indicates that the conveying signal is provided with an enhanced level of
|
||||
* integrity assurance. That is, the probability that the instantaneous URE of the conveying signal exceeds 5.73
|
||||
* times the upper bound value of the current broadcast URA index, for more than 5.2 seconds, without an
|
||||
* accompanying alert, is less than 1E-8 per hour.
|
||||
* If false, indicates that the conveying signal is provided with the
|
||||
* legacy level of integrity assurance. That is, the probability that the
|
||||
* instantaneous URE of the conveying signal exceeds 4.42 times the upper
|
||||
* bound value of the current broadcast URA index, for more than 5.2
|
||||
* seconds, without an accompanying alert, is less than 1E-5 per hour. If
|
||||
* true, indicates that the conveying signal is provided with an enhanced
|
||||
* level of integrity assurance. That is, the probability that the
|
||||
* instantaneous URE of the conveying signal exceeds 5.73 times the upper
|
||||
* bound value of the current broadcast URA index, for more than 5.2
|
||||
* seconds, without an accompanying alert, is less than 1E-8 per hour.
|
||||
*/
|
||||
bool b_integrity_status_flag{};
|
||||
bool b_alert_flag{}; //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
bool b_antispoofing_flag{}; //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
|
||||
// clock terms derived from ephemeris data
|
||||
double d_satClkDrift{}; //!< GPS clock error
|
||||
double d_dtr{}; //!< relativistic clock correction term
|
||||
|
||||
// satellite positions
|
||||
double d_satpos_X{}; //!< Earth-fixed coordinate x of the satellite [m]. Intersection of the IERS Reference Meridian (IRM) and the plane passing through the origin and normal to the Z-axis.
|
||||
double d_satpos_Y{}; //!< Earth-fixed coordinate y of the satellite [m]. Completes a right-handed, Earth-Centered, Earth-Fixed orthogonal coordinate system.
|
||||
double d_satpos_Z{}; //!< Earth-fixed coordinate z of the satellite [m]. The direction of the IERS (International Earth Rotation and Reference Systems Service) Reference Pole (IRP).
|
||||
|
||||
// Satellite velocity
|
||||
double d_satvel_X{}; //!< Earth-fixed velocity coordinate x of the satellite [m]
|
||||
double d_satvel_Y{}; //!< Earth-fixed velocity coordinate y of the satellite [m]
|
||||
double d_satvel_Z{}; //!< Earth-fixed velocity coordinate z of the satellite [m]
|
||||
bool b_alert_flag{}; //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
bool b_antispoofing_flag{}; //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
|
||||
std::map<int, std::string> satelliteBlock; //!< Map that stores to which block the PRN belongs
|
||||
|
||||
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
@ -144,56 +91,46 @@ public:
|
||||
{
|
||||
};
|
||||
|
||||
archive& make_nvp("i_satellite_PRN", i_satellite_PRN); // SV PRN NUMBER
|
||||
archive& make_nvp("d_TOW", d_TOW); //!< Time of GPS Week of the ephemeris set (taken from subframes TOW) [s]
|
||||
archive& make_nvp("d_AODE", d_AODE);
|
||||
archive& make_nvp("d_Crs", d_Crs); //!< Amplitude of the Sine Harmonic Correction Term to the Orbit Radius [m]
|
||||
archive& make_nvp("d_Delta_n", d_Delta_n); //!< Mean Motion Difference From Computed Value [semi-circles/s]
|
||||
archive& make_nvp("d_M_0", d_M_0); //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
archive& make_nvp("d_Cuc", d_Cuc); //!< Amplitude of the Cosine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
archive& make_nvp("d_e_eccentricity", d_eccentricity); //!< Eccentricity [dimensionless]
|
||||
archive& make_nvp("d_Cus", d_Cus); //!< Amplitude of the Sine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
archive& make_nvp("d_sqrt_A", d_sqrt_A); //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
archive& make_nvp("d_Toe", d_Toe); //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
archive& make_nvp("d_Toc", d_Toe); //!< clock data reference time (Ref. 20.3.3.3.3.1 IS-GPS-200L) [s]
|
||||
archive& make_nvp("d_Cic", d_Cic); //!< Amplitude of the Cosine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
archive& make_nvp("d_OMEGA0", d_OMEGA0); //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
archive& make_nvp("d_Cis", d_Cis); //!< Amplitude of the Sine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
archive& make_nvp("d_i_0", d_i_0); //!< Inclination Angle at Reference Time [semi-circles]
|
||||
archive& make_nvp("d_Crc", d_Crc); //!< Amplitude of the Cosine Harmonic Correction Term to the Orbit Radius [m]
|
||||
archive& make_nvp("d_OMEGA", d_OMEGA); //!< Argument of Perigee [semi-cicles]
|
||||
archive& make_nvp("d_OMEGA_DOT", d_OMEGA_DOT); //!< Rate of Right Ascension [semi-circles/s]
|
||||
archive& make_nvp("d_IDOT", d_IDOT); //!< Rate of Inclination Angle [semi-circles/s]
|
||||
archive& make_nvp("i_BEIDOU_week", i_BEIDOU_week); //!< GPS week number, aka WN [week]
|
||||
archive& make_nvp("i_SV_accuracy", i_SV_accuracy); //!< User Range Accuracy (URA) index of the SV (reference paragraph 6.2.1) for the standard positioning service user (Ref 20.3.3.3.1.3 IS-GPS-200L)
|
||||
archive& make_nvp("i_SV_health", i_SV_health);
|
||||
archive& make_nvp("d_AODC", d_AODC); //!< Issue of Data, Clock
|
||||
archive& make_nvp("d_TGD1", d_TGD1); //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& make_nvp("d_TGD2", d_TGD2); //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& make_nvp("i_AODO", i_AODO); //!< Age of Data Offset (AODO) term for the navigation message correction table (NMCT) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
archive& BOOST_SERIALIZATION_NVP(PRN);
|
||||
archive& BOOST_SERIALIZATION_NVP(M_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(delta_n);
|
||||
archive& BOOST_SERIALIZATION_NVP(ecc);
|
||||
archive& BOOST_SERIALIZATION_NVP(sqrtA);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGA_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(omega);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGAdot);
|
||||
archive& BOOST_SERIALIZATION_NVP(idot);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cuc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cus);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crs);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cic);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cis);
|
||||
archive& BOOST_SERIALIZATION_NVP(toe);
|
||||
archive& BOOST_SERIALIZATION_NVP(toc);
|
||||
archive& BOOST_SERIALIZATION_NVP(af0);
|
||||
archive& BOOST_SERIALIZATION_NVP(af1);
|
||||
archive& BOOST_SERIALIZATION_NVP(af2);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN);
|
||||
archive& BOOST_SERIALIZATION_NVP(tow);
|
||||
archive& BOOST_SERIALIZATION_NVP(satClkDrift);
|
||||
archive& BOOST_SERIALIZATION_NVP(dtr);
|
||||
|
||||
archive& make_nvp("b_fit_interval_flag", b_fit_interval_flag); //!< indicates the curve-fit interval used by the CS (Block II/IIA/IIR/IIR-M/IIF) and SS (Block IIIA) in determining the ephemeris parameters, as follows: 0 = 4 hours, 1 = greater than 4 hours.
|
||||
archive& make_nvp("d_spare1", d_spare1);
|
||||
archive& make_nvp("d_spare2", d_spare2);
|
||||
|
||||
archive& make_nvp("d_A_f0", d_A_f0); //!< Coefficient 0 of code phase offset model [s]
|
||||
archive& make_nvp("d_A_f1", d_A_f1); //!< Coefficient 1 of code phase offset model [s/s]
|
||||
archive& make_nvp("d_A_f2", d_A_f2); //!< Coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
archive& make_nvp("b_integrity_status_flag", b_integrity_status_flag);
|
||||
archive& make_nvp("b_alert_flag", b_alert_flag); //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
archive& make_nvp("b_antispoofing_flag", b_antispoofing_flag); //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
archive& BOOST_SERIALIZATION_NVP(d_AODE);
|
||||
archive& BOOST_SERIALIZATION_NVP(SV_accuracy);
|
||||
archive& BOOST_SERIALIZATION_NVP(SV_health);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_AODC);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_TGD1);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_TGD2);
|
||||
archive& BOOST_SERIALIZATION_NVP(AODO);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_fit_interval_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_spare1);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_spare2);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_integrity_status_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_alert_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_antispoofing_flag);
|
||||
}
|
||||
|
||||
private:
|
||||
/*
|
||||
* Accounts for the beginning or end of week crossover
|
||||
*
|
||||
* See paragraph 20.3.3.3.3.1 (IS-GPS-200L)
|
||||
* \param[in] - time in seconds
|
||||
* \param[out] - corrected time, in seconds
|
||||
*/
|
||||
double check_t(double time);
|
||||
};
|
||||
|
||||
|
||||
|
@ -36,14 +36,14 @@ public:
|
||||
Beidou_Dnav_Iono() = default; //!< Default constructor
|
||||
|
||||
// Ionospheric parameters
|
||||
double d_alpha0{}; //!< Coefficient 0 of a cubic equation representing the amplitude of the vertical delay [s]
|
||||
double d_alpha1{}; //!< Coefficient 1 of a cubic equation representing the amplitude of the vertical delay [s/semi-circle]
|
||||
double d_alpha2{}; //!< Coefficient 2 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^2]
|
||||
double d_alpha3{}; //!< Coefficient 3 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^3]
|
||||
double d_beta0{}; //!< Coefficient 0 of a cubic equation representing the period of the model [s]
|
||||
double d_beta1{}; //!< Coefficient 1 of a cubic equation representing the period of the model [s/semi-circle]
|
||||
double d_beta2{}; //!< Coefficient 2 of a cubic equation representing the period of the model [s(semi-circle)^2]
|
||||
double d_beta3{}; //!< Coefficient 3 of a cubic equation representing the period of the model [s(semi-circle)^3]
|
||||
double alpha0{}; //!< Coefficient 0 of a cubic equation representing the amplitude of the vertical delay [s]
|
||||
double alpha1{}; //!< Coefficient 1 of a cubic equation representing the amplitude of the vertical delay [s/semi-circle]
|
||||
double alpha2{}; //!< Coefficient 2 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^2]
|
||||
double alpha3{}; //!< Coefficient 3 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^3]
|
||||
double beta0{}; //!< Coefficient 0 of a cubic equation representing the period of the model [s]
|
||||
double beta1{}; //!< Coefficient 1 of a cubic equation representing the period of the model [s/semi-circle]
|
||||
double beta2{}; //!< Coefficient 2 of a cubic equation representing the period of the model [s(semi-circle)^2]
|
||||
double beta3{}; //!< Coefficient 3 of a cubic equation representing the period of the model [s(semi-circle)^3]
|
||||
|
||||
bool valid{}; //!< Valid flag
|
||||
|
||||
@ -54,18 +54,17 @@ public:
|
||||
*/
|
||||
void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("d_alpha0", d_alpha0);
|
||||
archive& make_nvp("d_alpha1", d_alpha1);
|
||||
archive& make_nvp("d_alpha2", d_alpha2);
|
||||
archive& make_nvp("d_alpha3", d_alpha3);
|
||||
archive& make_nvp("d_beta0", d_beta0);
|
||||
archive& make_nvp("d_beta1", d_beta1);
|
||||
archive& make_nvp("d_beta2", d_beta2);
|
||||
archive& make_nvp("d_beta3", d_beta3);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha0);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha1);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha2);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha3);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta0);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta1);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta2);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta3);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -116,111 +116,6 @@ int64_t Beidou_Dnav_Navigation_Message::read_navigation_signed(
|
||||
}
|
||||
|
||||
|
||||
double Beidou_Dnav_Navigation_Message::check_t(double time)
|
||||
{
|
||||
const double half_week = 302400; // seconds
|
||||
double corrTime = time;
|
||||
if (time > half_week)
|
||||
{
|
||||
corrTime = time - 2 * half_week;
|
||||
}
|
||||
else if (time < -half_week)
|
||||
{
|
||||
corrTime = time + 2 * half_week;
|
||||
}
|
||||
return corrTime;
|
||||
}
|
||||
|
||||
|
||||
double Beidou_Dnav_Navigation_Message::sv_clock_correction(double transmitTime)
|
||||
{
|
||||
const double dt = check_t(transmitTime - d_Toc);
|
||||
d_satClkCorr = (d_A_f2 * dt + d_A_f1) * dt + d_A_f0 + d_dtr;
|
||||
double correctedTime = transmitTime - d_satClkCorr;
|
||||
return correctedTime;
|
||||
}
|
||||
|
||||
|
||||
void Beidou_Dnav_Navigation_Message::satellitePosition(double transmitTime)
|
||||
{
|
||||
// Find satellite's position -----------------------------------------------
|
||||
// Restore semi-major axis
|
||||
const double a = d_sqrt_A * d_sqrt_A;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
const double tk = check_t(transmitTime - d_Toe_sf2);
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(BEIDOU_GM / (a * a * a));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + d_Delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
double M = d_M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
M = fmod((M + 2 * GNSS_PI), (2 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + d_eccentricity * sin(E);
|
||||
dE = fmod(E - E_old, 2 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Compute relativistic correction term
|
||||
d_dtr = BEIDOU_F * d_eccentricity * d_sqrt_A * sin(E);
|
||||
|
||||
// Compute the true anomaly
|
||||
const double tmp_Y = sqrt(1.0 - d_eccentricity * d_eccentricity) * sin(E);
|
||||
const double tmp_X = cos(E) - d_eccentricity;
|
||||
const double nu = atan2(tmp_Y, tmp_X);
|
||||
|
||||
// Compute angle phi (argument of Latitude)
|
||||
double phi = nu + d_OMEGA;
|
||||
|
||||
// Reduce phi to between 0 and 2*pi rad
|
||||
phi = fmod((phi), (2 * GNSS_PI));
|
||||
|
||||
// Correct argument of latitude
|
||||
const double u = phi + d_Cuc * cos(2 * phi) + d_Cus * sin(2 * phi);
|
||||
|
||||
// Correct radius
|
||||
const double r = a * (1 - d_eccentricity * cos(E)) + d_Crc * cos(2 * phi) + d_Crs * sin(2 * phi);
|
||||
|
||||
// Correct inclination
|
||||
const double i = d_i_0 + d_IDOT * tk + d_Cic * cos(2 * phi) + d_Cis * sin(2 * phi);
|
||||
|
||||
// Compute the angle between the ascending node and the Greenwich meridian
|
||||
double Omega = d_OMEGA0 + (d_OMEGA_DOT - BEIDOU_OMEGA_EARTH_DOT) * tk - BEIDOU_OMEGA_EARTH_DOT * d_Toe_sf2;
|
||||
|
||||
// Reduce to between 0 and 2*pi rad
|
||||
Omega = fmod((Omega + 2 * GNSS_PI), (2 * GNSS_PI));
|
||||
|
||||
// --- Compute satellite coordinates in Earth-fixed coordinates
|
||||
d_satpos_X = cos(u) * r * cos(Omega) - sin(u) * r * cos(i) * sin(Omega);
|
||||
d_satpos_Y = cos(u) * r * sin(Omega) + sin(u) * r * cos(i) * cos(Omega);
|
||||
d_satpos_Z = sin(u) * r * sin(i);
|
||||
|
||||
// Satellite's velocity. Can be useful for Vector Tracking loops
|
||||
const double Omega_dot = d_OMEGA_DOT - BEIDOU_OMEGA_EARTH_DOT;
|
||||
d_satvel_X = -Omega_dot * (cos(u) * r + sin(u) * r * cos(i)) + d_satpos_X * cos(Omega) - d_satpos_Y * cos(i) * sin(Omega);
|
||||
d_satvel_Y = Omega_dot * (cos(u) * r * cos(Omega) - sin(u) * r * cos(i) * sin(Omega)) + d_satpos_X * sin(Omega) + d_satpos_Y * cos(i) * cos(Omega);
|
||||
d_satvel_Z = d_satpos_Y * sin(i);
|
||||
}
|
||||
|
||||
|
||||
int32_t Beidou_Dnav_Navigation_Message::d1_subframe_decoder(std::string const& subframe)
|
||||
{
|
||||
const std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS> subframe_bits(subframe);
|
||||
@ -757,85 +652,85 @@ Beidou_Dnav_Ephemeris Beidou_Dnav_Navigation_Message::get_ephemeris() const
|
||||
std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS> subframe_bits;
|
||||
|
||||
// Order as given by eph_t in rtklib
|
||||
eph.i_satellite_PRN = i_satellite_PRN;
|
||||
eph.PRN = i_satellite_PRN;
|
||||
eph.d_AODC = d_AODC;
|
||||
eph.d_AODE = d_AODE;
|
||||
eph.i_SV_accuracy = i_SV_accuracy;
|
||||
eph.i_SV_health = i_SV_health;
|
||||
eph.i_BEIDOU_week = i_BEIDOU_week;
|
||||
eph.SV_accuracy = i_SV_accuracy;
|
||||
eph.SV_health = i_SV_health;
|
||||
eph.WN = i_BEIDOU_week;
|
||||
eph.i_sig_type = i_signal_type;
|
||||
eph.i_nav_type = 2;
|
||||
|
||||
eph.d_TOW = d_SOW;
|
||||
eph.d_Toe = d_Toe;
|
||||
eph.d_Toc = d_Toc;
|
||||
eph.tow = d_SOW;
|
||||
eph.toe = d_Toe;
|
||||
eph.toc = d_Toc;
|
||||
|
||||
eph.d_sqrt_A = d_sqrt_A;
|
||||
eph.d_eccentricity = static_cast<double>((d_eccentricity_msb + d_eccentricity_lsb)) * D1_E_LSB;
|
||||
eph.sqrtA = d_sqrt_A;
|
||||
eph.ecc = static_cast<double>((d_eccentricity_msb + d_eccentricity_lsb)) * D1_E_LSB;
|
||||
subframe_bits = std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS>(d_i_0_msb_bits + d_i_0_lsb_bits);
|
||||
eph.d_i_0 = static_cast<double>(read_navigation_signed(subframe_bits, D2_I0)) * D1_I0_LSB;
|
||||
eph.d_OMEGA0 = d_OMEGA0;
|
||||
eph.i_0 = static_cast<double>(read_navigation_signed(subframe_bits, D2_I0)) * D1_I0_LSB;
|
||||
eph.OMEGA_0 = d_OMEGA0;
|
||||
subframe_bits = std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS>(d_OMEGA_msb_bits + d_OMEGA_lsb_bits);
|
||||
eph.d_OMEGA = static_cast<double>(read_navigation_signed(subframe_bits, D2_OMEGA)) * D1_OMEGA_LSB;
|
||||
eph.d_M_0 = d_M_0;
|
||||
eph.d_Delta_n = d_Delta_n;
|
||||
eph.omega = static_cast<double>(read_navigation_signed(subframe_bits, D2_OMEGA)) * D1_OMEGA_LSB;
|
||||
eph.M_0 = d_M_0;
|
||||
eph.delta_n = d_Delta_n;
|
||||
|
||||
subframe_bits = std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS>(d_OMEGA_DOT_msb_bits + d_OMEGA_DOT_lsb_bits);
|
||||
eph.d_OMEGA_DOT = static_cast<double>(read_navigation_signed(subframe_bits, D2_OMEGA_DOT)) * D1_OMEGA_DOT_LSB;
|
||||
eph.d_IDOT = d_IDOT;
|
||||
eph.OMEGAdot = static_cast<double>(read_navigation_signed(subframe_bits, D2_OMEGA_DOT)) * D1_OMEGA_DOT_LSB;
|
||||
eph.idot = d_IDOT;
|
||||
|
||||
eph.d_Crc = d_Crc;
|
||||
eph.d_Crs = d_Crs;
|
||||
eph.Crc = d_Crc;
|
||||
eph.Crs = d_Crs;
|
||||
subframe_bits = std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS>(d_Cuc_msb_bits + d_Cuc_lsb_bits);
|
||||
eph.d_Cuc = static_cast<double>(read_navigation_signed(subframe_bits, D2_CUC)) * D1_CUC_LSB;
|
||||
eph.d_Cus = d_Cus;
|
||||
eph.Cuc = static_cast<double>(read_navigation_signed(subframe_bits, D2_CUC)) * D1_CUC_LSB;
|
||||
eph.Cus = d_Cus;
|
||||
subframe_bits = std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS>(d_Cic_msb_bits + d_Cic_lsb_bits);
|
||||
eph.d_Cic = static_cast<double>(read_navigation_signed(subframe_bits, D2_CIC)) * D1_CIC_LSB;
|
||||
eph.d_Cis = d_Cis;
|
||||
eph.Cic = static_cast<double>(read_navigation_signed(subframe_bits, D2_CIC)) * D1_CIC_LSB;
|
||||
eph.Cis = d_Cis;
|
||||
|
||||
eph.d_A_f0 = d_A_f0;
|
||||
eph.af0 = d_A_f0;
|
||||
subframe_bits = std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS>(d_A_f1_msb_bits + d_A_f1_lsb_bits);
|
||||
eph.d_A_f1 = static_cast<double>(read_navigation_signed(subframe_bits, D2_A1)) * D1_A1_LSB;
|
||||
eph.d_A_f2 = d_A_f2;
|
||||
eph.af1 = static_cast<double>(read_navigation_signed(subframe_bits, D2_A1)) * D1_A1_LSB;
|
||||
eph.af2 = d_A_f2;
|
||||
|
||||
eph.d_TGD1 = d_TGD1;
|
||||
eph.d_TGD2 = d_TGD2;
|
||||
}
|
||||
else
|
||||
{
|
||||
eph.i_satellite_PRN = i_satellite_PRN;
|
||||
eph.PRN = i_satellite_PRN;
|
||||
eph.d_AODC = d_AODC;
|
||||
eph.d_AODE = d_AODE;
|
||||
eph.i_SV_accuracy = i_SV_accuracy;
|
||||
eph.i_SV_health = i_SV_health;
|
||||
eph.i_BEIDOU_week = i_BEIDOU_week;
|
||||
eph.SV_accuracy = i_SV_accuracy;
|
||||
eph.SV_health = i_SV_health;
|
||||
eph.WN = i_BEIDOU_week;
|
||||
eph.i_sig_type = i_signal_type;
|
||||
eph.i_nav_type = 1; // MEO/IGSO
|
||||
|
||||
eph.d_TOW = d_SOW;
|
||||
eph.d_Toe = ((d_Toe_sf2 + d_Toe_sf3) * D1_TOE_LSB);
|
||||
eph.d_Toc = d_Toc;
|
||||
eph.tow = d_SOW;
|
||||
eph.toe = ((d_Toe_sf2 + d_Toe_sf3) * D1_TOE_LSB);
|
||||
eph.toc = d_Toc;
|
||||
|
||||
eph.d_sqrt_A = d_sqrt_A;
|
||||
eph.d_eccentricity = d_eccentricity;
|
||||
eph.d_i_0 = d_i_0;
|
||||
eph.d_OMEGA0 = d_OMEGA0;
|
||||
eph.d_OMEGA = d_OMEGA;
|
||||
eph.d_M_0 = d_M_0;
|
||||
eph.d_Delta_n = d_Delta_n;
|
||||
eph.d_OMEGA_DOT = d_OMEGA_DOT;
|
||||
eph.d_IDOT = d_IDOT;
|
||||
eph.sqrtA = d_sqrt_A;
|
||||
eph.ecc = d_eccentricity;
|
||||
eph.i_0 = d_i_0;
|
||||
eph.OMEGA_0 = d_OMEGA0;
|
||||
eph.omega = d_OMEGA;
|
||||
eph.M_0 = d_M_0;
|
||||
eph.delta_n = d_Delta_n;
|
||||
eph.OMEGAdot = d_OMEGA_DOT;
|
||||
eph.idot = d_IDOT;
|
||||
|
||||
eph.d_Crc = d_Crc;
|
||||
eph.d_Crs = d_Crs;
|
||||
eph.d_Cuc = d_Cuc;
|
||||
eph.d_Cus = d_Cus;
|
||||
eph.d_Cic = d_Cic;
|
||||
eph.d_Cis = d_Cis;
|
||||
eph.Crc = d_Crc;
|
||||
eph.Crs = d_Crs;
|
||||
eph.Cuc = d_Cuc;
|
||||
eph.Cus = d_Cus;
|
||||
eph.Cic = d_Cic;
|
||||
eph.Cis = d_Cis;
|
||||
|
||||
eph.d_A_f0 = d_A_f0;
|
||||
eph.d_A_f1 = d_A_f1;
|
||||
eph.d_A_f2 = d_A_f2;
|
||||
eph.af0 = d_A_f0;
|
||||
eph.af1 = d_A_f1;
|
||||
eph.af2 = d_A_f2;
|
||||
|
||||
eph.d_TGD1 = d_TGD1;
|
||||
eph.d_TGD2 = d_TGD2;
|
||||
@ -848,14 +743,14 @@ Beidou_Dnav_Ephemeris Beidou_Dnav_Navigation_Message::get_ephemeris() const
|
||||
Beidou_Dnav_Iono Beidou_Dnav_Navigation_Message::get_iono()
|
||||
{
|
||||
Beidou_Dnav_Iono iono;
|
||||
iono.d_alpha0 = d_alpha0;
|
||||
iono.d_alpha1 = d_alpha1;
|
||||
iono.d_alpha2 = d_alpha2;
|
||||
iono.d_alpha3 = d_alpha3;
|
||||
iono.d_beta0 = d_beta0;
|
||||
iono.d_beta1 = d_beta1;
|
||||
iono.d_beta2 = d_beta2;
|
||||
iono.d_beta3 = d_beta3;
|
||||
iono.alpha0 = d_alpha0;
|
||||
iono.alpha1 = d_alpha1;
|
||||
iono.alpha2 = d_alpha2;
|
||||
iono.alpha3 = d_alpha3;
|
||||
iono.beta0 = d_beta0;
|
||||
iono.beta1 = d_beta1;
|
||||
iono.beta2 = d_beta2;
|
||||
iono.beta3 = d_beta3;
|
||||
iono.valid = flag_iono_valid;
|
||||
// WARNING: We clear flag_utc_model_valid in order to not re-send the same information to the ionospheric parameters queue
|
||||
flag_iono_valid = false;
|
||||
@ -868,19 +763,19 @@ Beidou_Dnav_Utc_Model Beidou_Dnav_Navigation_Message::get_utc_model()
|
||||
Beidou_Dnav_Utc_Model utc_model;
|
||||
utc_model.valid = flag_utc_model_valid;
|
||||
// UTC parameters
|
||||
utc_model.d_A1_UTC = d_A1UTC;
|
||||
utc_model.d_A0_UTC = d_A0UTC;
|
||||
utc_model.i_DeltaT_LS = i_DeltaT_LS;
|
||||
utc_model.i_WN_LSF = i_WN_LSF;
|
||||
utc_model.i_DN = i_DN;
|
||||
utc_model.d_DeltaT_LSF = d_DeltaT_LSF;
|
||||
utc_model.A1_UTC = d_A1UTC;
|
||||
utc_model.A0_UTC = d_A0UTC;
|
||||
utc_model.DeltaT_LS = i_DeltaT_LS;
|
||||
utc_model.WN_LSF = i_WN_LSF;
|
||||
utc_model.DN = i_DN;
|
||||
utc_model.DeltaT_LSF = d_DeltaT_LSF;
|
||||
|
||||
utc_model.d_A0_GPS = d_A0GPS;
|
||||
utc_model.d_A1_GPS = d_A1GPS;
|
||||
utc_model.d_A0_GAL = d_A0GAL;
|
||||
utc_model.d_A1_GAL = d_A1GAL;
|
||||
utc_model.d_A0_GLO = d_A0GLO;
|
||||
utc_model.d_A1_GLO = d_A1GLO;
|
||||
utc_model.A0_GPS = d_A0GPS;
|
||||
utc_model.A1_GPS = d_A1GPS;
|
||||
utc_model.A0_GAL = d_A0GAL;
|
||||
utc_model.A1_GAL = d_A1GAL;
|
||||
utc_model.A0_GLO = d_A0GLO;
|
||||
utc_model.A1_GLO = d_A1GLO;
|
||||
|
||||
// warning: We clear flag_utc_model_valid in order to not re-send the same information to the ionospheric parameters queue
|
||||
flag_utc_model_valid = false;
|
||||
|
@ -76,17 +76,6 @@ public:
|
||||
*/
|
||||
int32_t d2_subframe_decoder(std::string const& subframe);
|
||||
|
||||
/*!
|
||||
* \brief Computes the position of the satellite
|
||||
*/
|
||||
void satellitePosition(double transmitTime);
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a d_satClkCorr) according to the User Algorithm for SV Clock Correction
|
||||
* and returns the corrected clock
|
||||
*/
|
||||
double sv_clock_correction(double transmitTime);
|
||||
|
||||
/*!
|
||||
* \brief Computes the Coordinated Universal Time (UTC) and
|
||||
* returns it in [s]
|
||||
@ -154,14 +143,6 @@ private:
|
||||
bool read_navigation_bool(std::bitset<BEIDOU_DNAV_SUBFRAME_DATA_BITS> bits, const std::vector<std::pair<int32_t, int32_t>>& parameter) const;
|
||||
void print_beidou_word_bytes(uint32_t BEIDOU_word) const;
|
||||
|
||||
/*
|
||||
* Accounts for the beginning or end of week crossover
|
||||
*
|
||||
* \param[in] - time in seconds
|
||||
* \param[out] - corrected time, in seconds
|
||||
*/
|
||||
double check_t(double time);
|
||||
|
||||
// broadcast orbit 1
|
||||
double d_SOW{}; // Time of BeiDou Week of the ephemeris set (taken from subframes SOW) [s]
|
||||
double d_SOW_SF1{}; // Time of BeiDou Week from HOW word of Subframe 1 [s]
|
||||
@ -243,15 +224,6 @@ private:
|
||||
|
||||
std::map<int32_t, std::string> satelliteBlock; // Map that stores to which block the PRN belongs
|
||||
|
||||
// clock terms
|
||||
double d_satClkCorr{}; // GPS clock error
|
||||
double d_dtr{}; // relativistic clock correction term
|
||||
|
||||
// satellite positions
|
||||
double d_satpos_X{}; // Earth-fixed coordinate x of the satellite [m]. Intersection of the IERS Reference Meridian (IRM) and the plane passing through the origin and normal to the Z-axis.
|
||||
double d_satpos_Y{}; // Earth-fixed coordinate y of the satellite [m]. Completes a right-handed, Earth-Centered, Earth-Fixed orthogonal coordinate system.
|
||||
double d_satpos_Z{}; // Earth-fixed coordinate z of the satellite [m]. The direction of the IERS (International Earth Rotation and Reference Systems Service) Reference Pole (IRP).
|
||||
|
||||
// satellite identification info
|
||||
int32_t i_signal_type{}; // BDS: data source (0:unknown,1:B1I,2:B1Q,3:B2I,4:B2Q,5:B3I,6:B3Q)
|
||||
uint32_t i_satellite_PRN{};
|
||||
@ -293,11 +265,6 @@ private:
|
||||
int32_t almanac_WN{};
|
||||
double d_toa2{};
|
||||
|
||||
// Satellite velocity
|
||||
double d_satvel_X{}; // Earth-fixed velocity coordinate x of the satellite [m]
|
||||
double d_satvel_Y{}; // Earth-fixed velocity coordinate y of the satellite [m]
|
||||
double d_satvel_Z{}; // Earth-fixed velocity coordinate z of the satellite [m]
|
||||
|
||||
// System flags for data processing
|
||||
bool flag_eph_valid{};
|
||||
bool flag_utc_model_valid{};
|
||||
|
@ -38,50 +38,50 @@ public:
|
||||
Beidou_Dnav_Utc_Model() = default;
|
||||
|
||||
// BeiDou UTC parameters
|
||||
double d_A0_UTC{}; //!< BDT clock bias relative to UTC [s]
|
||||
double d_A1_UTC{}; //!< BDT clock rate relative to UTC [s/s]
|
||||
int i_DeltaT_LS{}; //!< Delta time due to leap seconds before the new leap second effective
|
||||
int i_WN_LSF{}; //!< Week number of the new leap second
|
||||
int i_DN{}; //!< Day number of week of the new leap second
|
||||
double d_DeltaT_LSF{}; //!< Delta time due to leap seconds after the new leap second effective [s]
|
||||
double A0_UTC{}; //!< BDT clock bias relative to UTC [s]
|
||||
double A1_UTC{}; //!< BDT clock rate relative to UTC [s/s]
|
||||
int DeltaT_LS{}; //!< Delta time due to leap seconds before the new leap second effective
|
||||
int WN_LSF{}; //!< Week number of the new leap second
|
||||
int DN{}; //!< Day number of week of the new leap second
|
||||
double DeltaT_LSF{}; //!< Delta time due to leap seconds after the new leap second effective [s]
|
||||
|
||||
// BeiDou to GPS time corrections
|
||||
double d_A0_GPS{}; //!< BDT clock bias relative to GPS time [s]
|
||||
double d_A1_GPS{}; //!< BDT clock rate relative to GPS time [s/s]
|
||||
double A0_GPS{}; //!< BDT clock bias relative to GPS time [s]
|
||||
double A1_GPS{}; //!< BDT clock rate relative to GPS time [s/s]
|
||||
|
||||
// BeiDou to Galileo time corrections
|
||||
double d_A0_GAL{}; //!< BDT clock bias relative to GAL time [s]
|
||||
double d_A1_GAL{}; //!< BDT clock rate relative to GAL time [s/s]
|
||||
double A0_GAL{}; //!< BDT clock bias relative to GAL time [s]
|
||||
double A1_GAL{}; //!< BDT clock rate relative to GAL time [s/s]
|
||||
|
||||
// BeiDou to GLONASS time corrections
|
||||
double d_A0_GLO{}; //!< BDT clock bias relative to GLO time [s]
|
||||
double d_A1_GLO{}; //!< BDT clock rate relative to GLO time [s/s]
|
||||
double A0_GLO{}; //!< BDT clock bias relative to GLO time [s]
|
||||
double A1_GLO{}; //!< BDT clock rate relative to GLO time [s/s]
|
||||
|
||||
bool valid{};
|
||||
|
||||
template <class Archive>
|
||||
/*
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("d_A1", d_A1_UTC);
|
||||
archive& make_nvp("d_A0", d_A0_UTC);
|
||||
archive& make_nvp("i_DeltaT_LS", i_DeltaT_LS);
|
||||
archive& make_nvp("i_WN_LSF", i_WN_LSF);
|
||||
archive& make_nvp("i_DN", i_DN);
|
||||
archive& make_nvp("d_DeltaT_LSF", d_DeltaT_LSF);
|
||||
archive& make_nvp("d_A0_GPS", d_A0_GPS);
|
||||
archive& make_nvp("d_A0_GPS", d_A1_GPS);
|
||||
archive& make_nvp("d_A0_GPS", d_A0_GAL);
|
||||
archive& make_nvp("d_A0_GPS", d_A1_GAL);
|
||||
archive& make_nvp("d_A0_GPS", d_A0_GLO);
|
||||
archive& make_nvp("d_A0_GPS", d_A1_GLO);
|
||||
archive& make_nvp("valid", valid);
|
||||
archive& BOOST_SERIALIZATION_NVP(A1_UTC);
|
||||
archive& BOOST_SERIALIZATION_NVP(A0_UTC);
|
||||
archive& BOOST_SERIALIZATION_NVP(DeltaT_LS);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN_LSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(DN);
|
||||
archive& BOOST_SERIALIZATION_NVP(DeltaT_LSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(A0_GPS);
|
||||
archive& BOOST_SERIALIZATION_NVP(A1_GPS);
|
||||
archive& BOOST_SERIALIZATION_NVP(A0_GAL);
|
||||
archive& BOOST_SERIALIZATION_NVP(A1_GAL);
|
||||
archive& BOOST_SERIALIZATION_NVP(A0_GLO);
|
||||
archive& BOOST_SERIALIZATION_NVP(A1_GLO);
|
||||
archive& BOOST_SERIALIZATION_NVP(valid);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -38,19 +38,19 @@ public:
|
||||
*/
|
||||
Galileo_Almanac() = default;
|
||||
|
||||
uint32_t i_satellite_PRN{}; //!< SV PRN NUMBER
|
||||
int32_t i_Toa{};
|
||||
int32_t i_WNa{};
|
||||
int32_t i_IODa{};
|
||||
double d_Delta_i{}; //!< Inclination at reference time relative to i0 = 56º [semi-circles]
|
||||
double d_M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double d_e_eccentricity{}; //!< Eccentricity [dimensionless]
|
||||
double d_Delta_sqrt_A{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
double d_OMEGA0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double d_OMEGA{}; //!< Argument of Perigee [semi-cicles]
|
||||
double d_OMEGA_DOT{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
double d_A_f0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double d_A_f1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
uint32_t PRN{}; //!< SV PRN NUMBER
|
||||
int32_t toa{};
|
||||
int32_t WNa{};
|
||||
int32_t IODa{};
|
||||
double delta_i{}; //!< Inclination at reference time relative to i0 = 56º [semi-circles]
|
||||
double M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double ecc{}; //!< Eccentricity [dimensionless]
|
||||
double delta_sqrtA{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
double OMEGA_0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double omega{}; //!< Argument of Perigee [semi-cicles]
|
||||
double OMEGAdot{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
double af0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double af1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
int32_t E5b_HS{};
|
||||
int32_t E1B_HS{};
|
||||
int32_t E5a_HS{};
|
||||
@ -62,19 +62,19 @@ public:
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
ar& BOOST_SERIALIZATION_NVP(i_satellite_PRN);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_Toa);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_WNa);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_IODa);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_Delta_i);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_M_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_e_eccentricity);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_Delta_sqrt_A);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA_DOT);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_A_f0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_A_f1);
|
||||
ar& BOOST_SERIALIZATION_NVP(PRN);
|
||||
ar& BOOST_SERIALIZATION_NVP(toa);
|
||||
ar& BOOST_SERIALIZATION_NVP(WNa);
|
||||
ar& BOOST_SERIALIZATION_NVP(IODa);
|
||||
ar& BOOST_SERIALIZATION_NVP(delta_i);
|
||||
ar& BOOST_SERIALIZATION_NVP(M_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(ecc);
|
||||
ar& BOOST_SERIALIZATION_NVP(delta_sqrtA);
|
||||
ar& BOOST_SERIALIZATION_NVP(OMEGA_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(omega);
|
||||
ar& BOOST_SERIALIZATION_NVP(OMEGAdot);
|
||||
ar& BOOST_SERIALIZATION_NVP(af0);
|
||||
ar& BOOST_SERIALIZATION_NVP(af1);
|
||||
ar& BOOST_SERIALIZATION_NVP(E5b_HS);
|
||||
ar& BOOST_SERIALIZATION_NVP(E1B_HS);
|
||||
ar& BOOST_SERIALIZATION_NVP(E5a_HS);
|
||||
|
@ -22,56 +22,56 @@ Galileo_Almanac Galileo_Almanac_Helper::get_almanac(int i) const
|
||||
switch (i)
|
||||
{
|
||||
case 1:
|
||||
galileo_almanac.i_satellite_PRN = this->SVID1_7;
|
||||
galileo_almanac.i_Toa = this->t0a_7;
|
||||
galileo_almanac.i_WNa = this->WN_a_7;
|
||||
galileo_almanac.i_IODa = this->IOD_a_7;
|
||||
galileo_almanac.d_Delta_i = this->delta_i_7;
|
||||
galileo_almanac.d_M_0 = this->M0_7;
|
||||
galileo_almanac.d_e_eccentricity = this->e_7;
|
||||
galileo_almanac.d_Delta_sqrt_A = this->DELTA_A_7;
|
||||
galileo_almanac.d_OMEGA0 = this->Omega0_7;
|
||||
galileo_almanac.d_OMEGA = this->omega_7;
|
||||
galileo_almanac.d_OMEGA_DOT = this->Omega_dot_7;
|
||||
galileo_almanac.d_A_f0 = this->af0_8;
|
||||
galileo_almanac.d_A_f1 = this->af1_8;
|
||||
galileo_almanac.PRN = this->SVID1_7;
|
||||
galileo_almanac.toa = this->t0a_7;
|
||||
galileo_almanac.WNa = this->WN_a_7;
|
||||
galileo_almanac.IODa = this->IOD_a_7;
|
||||
galileo_almanac.delta_i = this->delta_i_7;
|
||||
galileo_almanac.M_0 = this->M0_7;
|
||||
galileo_almanac.ecc = this->e_7;
|
||||
galileo_almanac.delta_sqrtA = this->DELTA_A_7;
|
||||
galileo_almanac.OMEGA_0 = this->Omega0_7;
|
||||
galileo_almanac.omega = this->omega_7;
|
||||
galileo_almanac.OMEGAdot = this->Omega_dot_7;
|
||||
galileo_almanac.af0 = this->af0_8;
|
||||
galileo_almanac.af1 = this->af1_8;
|
||||
galileo_almanac.E5b_HS = this->E5b_HS_8;
|
||||
galileo_almanac.E1B_HS = this->E1B_HS_8;
|
||||
galileo_almanac.E5a_HS = this->E5a_HS_8;
|
||||
break;
|
||||
|
||||
case 2:
|
||||
galileo_almanac.i_satellite_PRN = this->SVID2_8;
|
||||
galileo_almanac.i_Toa = this->t0a_9;
|
||||
galileo_almanac.i_WNa = this->WN_a_9;
|
||||
galileo_almanac.i_IODa = this->IOD_a_9;
|
||||
galileo_almanac.d_Delta_i = this->delta_i_8;
|
||||
galileo_almanac.d_M_0 = this->M0_9;
|
||||
galileo_almanac.d_e_eccentricity = this->e_8;
|
||||
galileo_almanac.d_Delta_sqrt_A = this->DELTA_A_8;
|
||||
galileo_almanac.d_OMEGA0 = this->Omega0_8;
|
||||
galileo_almanac.d_OMEGA = this->omega_8;
|
||||
galileo_almanac.d_OMEGA_DOT = this->Omega_dot_8;
|
||||
galileo_almanac.d_A_f0 = this->af0_9;
|
||||
galileo_almanac.d_A_f1 = this->af1_9;
|
||||
galileo_almanac.PRN = this->SVID2_8;
|
||||
galileo_almanac.toa = this->t0a_9;
|
||||
galileo_almanac.WNa = this->WN_a_9;
|
||||
galileo_almanac.IODa = this->IOD_a_9;
|
||||
galileo_almanac.delta_i = this->delta_i_8;
|
||||
galileo_almanac.M_0 = this->M0_9;
|
||||
galileo_almanac.ecc = this->e_8;
|
||||
galileo_almanac.delta_sqrtA = this->DELTA_A_8;
|
||||
galileo_almanac.OMEGA_0 = this->Omega0_8;
|
||||
galileo_almanac.omega = this->omega_8;
|
||||
galileo_almanac.OMEGAdot = this->Omega_dot_8;
|
||||
galileo_almanac.af0 = this->af0_9;
|
||||
galileo_almanac.af1 = this->af1_9;
|
||||
galileo_almanac.E1B_HS = this->E1B_HS_9;
|
||||
galileo_almanac.E5a_HS = this->E5a_HS_9;
|
||||
break;
|
||||
|
||||
case 3:
|
||||
galileo_almanac.i_satellite_PRN = this->SVID3_9;
|
||||
galileo_almanac.i_Toa = this->t0a_9;
|
||||
galileo_almanac.i_WNa = this->WN_a_9;
|
||||
galileo_almanac.i_IODa = this->IOD_a_10;
|
||||
galileo_almanac.d_Delta_i = this->delta_i_9;
|
||||
galileo_almanac.d_M_0 = this->M0_10;
|
||||
galileo_almanac.d_e_eccentricity = this->e_9;
|
||||
galileo_almanac.d_Delta_sqrt_A = this->DELTA_A_9;
|
||||
galileo_almanac.d_OMEGA0 = this->Omega0_10;
|
||||
galileo_almanac.d_OMEGA = this->omega_9;
|
||||
galileo_almanac.d_OMEGA_DOT = this->Omega_dot_10;
|
||||
galileo_almanac.d_A_f0 = this->af0_10;
|
||||
galileo_almanac.d_A_f1 = this->af1_10;
|
||||
galileo_almanac.PRN = this->SVID3_9;
|
||||
galileo_almanac.toa = this->t0a_9;
|
||||
galileo_almanac.WNa = this->WN_a_9;
|
||||
galileo_almanac.IODa = this->IOD_a_10;
|
||||
galileo_almanac.delta_i = this->delta_i_9;
|
||||
galileo_almanac.M_0 = this->M0_10;
|
||||
galileo_almanac.ecc = this->e_9;
|
||||
galileo_almanac.delta_sqrtA = this->DELTA_A_9;
|
||||
galileo_almanac.OMEGA_0 = this->Omega0_10;
|
||||
galileo_almanac.omega = this->omega_9;
|
||||
galileo_almanac.OMEGAdot = this->Omega_dot_10;
|
||||
galileo_almanac.af0 = this->af0_10;
|
||||
galileo_almanac.af1 = this->af1_10;
|
||||
galileo_almanac.E5b_HS = this->E5b_HS_10;
|
||||
galileo_almanac.E1B_HS = this->E1B_HS_10;
|
||||
galileo_almanac.E5a_HS = this->E5a_HS_10;
|
||||
|
@ -17,216 +17,46 @@
|
||||
*/
|
||||
|
||||
#include "galileo_ephemeris.h"
|
||||
#include "MATH_CONSTANTS.h"
|
||||
#include <cmath>
|
||||
|
||||
|
||||
double Galileo_Ephemeris::Galileo_System_Time(double WN, double TOW)
|
||||
double Galileo_Ephemeris::Galileo_System_Time(double week_number, double TOW)
|
||||
{
|
||||
/* GALILEO SYSTEM TIME, ICD 5.1.2
|
||||
*
|
||||
* input parameter:
|
||||
* WN: The Week Number is an integer counter that gives the sequential week number
|
||||
from the origin of the Galileo time. It covers 4096 weeks (about 78 years).
|
||||
Then the counter is reset to zero to cover additional period modulo 4096
|
||||
|
||||
TOW: The Time of Week is defined as the number of seconds that have occurred since
|
||||
the transition from the previous week. The TOW covers an entire week from 0 to
|
||||
604799 seconds and is reset to zero at the end of each week
|
||||
|
||||
WN and TOW are received in page 5
|
||||
|
||||
output:
|
||||
t: it is the transmitted time in Galileo System Time (expressed in seconds)
|
||||
|
||||
The GST start epoch shall be 00:00 UT on Sunday 22nd August 1999 (midnight between 21st and 22nd August).
|
||||
At the start epoch, GST shall be ahead of UTC by thirteen (13)
|
||||
leap seconds. Since the next leap second was inserted at 01.01.2006, this implies that
|
||||
as of 01.01.2006 GST is ahead of UTC by fourteen (14) leap seconds.
|
||||
|
||||
The epoch denoted in the navigation messages by TOW and WN
|
||||
will be measured relative to the leading edge of the first chip of the
|
||||
first code sequence of the first page symbol. The transmission timing of the navigation
|
||||
message provided through the TOW is synchronised to each satellite’s version of Galileo System Time (GST).
|
||||
*
|
||||
* week_number: The Week Number is an integer counter that gives the
|
||||
* sequential week number from the origin of the Galileo time. It covers
|
||||
* 4096 weeks (about 78 years). Then the counter is reset to zero to cover
|
||||
* additional period modulo 4096
|
||||
*
|
||||
* TOW: The Time of Week is defined as the number of seconds that have
|
||||
* occurred since the transition from the previous week. The TOW covers an
|
||||
* entire week from 0 to 604799 seconds and is reset to zero at the end of
|
||||
* each week
|
||||
*
|
||||
* week_number and TOW are received in page 5
|
||||
*
|
||||
* output:
|
||||
*
|
||||
* t: it is the transmitted time in Galileo System Time (expressed
|
||||
* in seconds)
|
||||
*
|
||||
* The GST start epoch shall be 00:00 UT on Sunday 22nd August 1999
|
||||
* (midnight between 21st and 22nd August). At the start epoch, GST shall be
|
||||
* ahead of UTC by thirteen (13) leap seconds. Since the next leap second
|
||||
* was inserted at 01.01.2006, this implies that as of 01.01.2006 GST is
|
||||
* ahead of UTC by fourteen (14) leap seconds.
|
||||
*
|
||||
* The epoch denoted in the navigation messages by TOW and week_number will
|
||||
* be measured relative to the leading edge of the first chip of the first
|
||||
* code sequence of the first page symbol. The transmission timing of the
|
||||
* navigation message provided through the TOW is synchronised to each
|
||||
* satellite’s version of Galileo System Time (GST).
|
||||
*
|
||||
*/
|
||||
const double sec_in_day = 86400;
|
||||
const double day_in_week = 7;
|
||||
double t = WN * sec_in_day * day_in_week + TOW; // second from the origin of the Galileo time
|
||||
double t = week_number * sec_in_day * day_in_week + TOW; // second from the origin of the Galileo time
|
||||
return t;
|
||||
}
|
||||
|
||||
|
||||
double Galileo_Ephemeris::sv_clock_drift(double transmitTime)
|
||||
{
|
||||
// Satellite Time Correction Algorithm, ICD 5.1.4
|
||||
const double dt = transmitTime - t0c_4;
|
||||
Galileo_satClkDrift = af0_4 + af1_4 * dt + af2_4 * (dt * dt) + sv_clock_relativistic_term(transmitTime); // +Galileo_dtr;
|
||||
return Galileo_satClkDrift;
|
||||
}
|
||||
|
||||
|
||||
// compute the relativistic correction term
|
||||
double Galileo_Ephemeris::sv_clock_relativistic_term(double transmitTime) // Satellite Time Correction Algorithm, ICD 5.1.4
|
||||
{
|
||||
// Restore semi-major axis
|
||||
const double a = A_1 * A_1;
|
||||
|
||||
const double n0 = sqrt(GALILEO_GM / (a * a * a));
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
// t = WN_5*86400*7 + TOW_5; //WN_5*86400*7 are the second from the origin of the Galileo time
|
||||
const double tk = check_t(transmitTime - static_cast<double>(t0e_1));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + delta_n_3;
|
||||
|
||||
// Mean anomaly
|
||||
double M = M0_1 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
|
||||
// --- Iteratively compute eccentric anomaly ----------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + e_1 * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Compute relativistic correction term
|
||||
Galileo_dtr = GALILEO_F * e_1 * A_1 * sin(E);
|
||||
return Galileo_dtr;
|
||||
}
|
||||
|
||||
|
||||
void Galileo_Ephemeris::satellitePosition(double transmitTime)
|
||||
{
|
||||
// when this function in used, the input must be the transmitted time (t) in
|
||||
// seconds computed by Galileo_System_Time (above function)
|
||||
|
||||
// Find Galileo satellite's position ---------------------------------------
|
||||
|
||||
// Restore semi-major axis
|
||||
const double a = A_1 * A_1;
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(GALILEO_GM / (a * a * a));
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
const double tk = check_t(transmitTime - static_cast<double>(t0e_1));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + delta_n_3;
|
||||
|
||||
// Mean anomaly
|
||||
double M = M0_1 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + e_1 * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
const double sek = sin(E);
|
||||
const double cek = cos(E);
|
||||
const double OneMinusecosE = 1.0 - e_1 * cek;
|
||||
const double sq1e2 = sqrt(1.0 - e_1 * e_1);
|
||||
const double ekdot = n / OneMinusecosE;
|
||||
|
||||
// Compute the true anomaly
|
||||
const double tmp_Y = sq1e2 * sek;
|
||||
const double tmp_X = cek - e_1;
|
||||
const double nu = atan2(tmp_Y, tmp_X);
|
||||
|
||||
// Compute angle phi (argument of Latitude)
|
||||
double phi = nu + omega_2;
|
||||
|
||||
// Reduce phi to between 0 and 2*pi rad
|
||||
phi = fmod((phi), (2.0 * GNSS_PI));
|
||||
const double s2pk = sin(2.0 * phi);
|
||||
const double c2pk = cos(2.0 * phi);
|
||||
const double pkdot = sq1e2 * ekdot / OneMinusecosE;
|
||||
|
||||
// Correct argument of latitude
|
||||
const double u = phi + C_uc_3 * c2pk + C_us_3 * s2pk;
|
||||
const double suk = sin(u);
|
||||
const double cuk = cos(u);
|
||||
const double ukdot = pkdot * (1.0 + 2.0 * (C_us_3 * c2pk - C_uc_3 * s2pk));
|
||||
|
||||
// Correct radius
|
||||
const double r = a * OneMinusecosE + C_rc_3 * c2pk + C_rs_3 * s2pk;
|
||||
const double rkdot = a * e_1 * sek * ekdot + 2.0 * pkdot * (C_rs_3 * c2pk - C_rc_3 * s2pk);
|
||||
|
||||
// Correct inclination
|
||||
const double i = i_0_2 + iDot_2 * tk + C_ic_4 * c2pk + C_is_4 * s2pk;
|
||||
const double sik = sin(i);
|
||||
const double cik = cos(i);
|
||||
const double ikdot = iDot_2 + 2.0 * pkdot * (C_is_4 * c2pk - C_ic_4 * s2pk);
|
||||
|
||||
// Compute the angle between the ascending node and the Greenwich meridian
|
||||
const double Omega_dot = OMEGA_dot_3 - GNSS_OMEGA_EARTH_DOT;
|
||||
double Omega = OMEGA_0_2 + Omega_dot * tk - GNSS_OMEGA_EARTH_DOT * static_cast<double>(t0e_1);
|
||||
|
||||
// Reduce to between 0 and 2*pi rad
|
||||
Omega = fmod((Omega + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
const double sok = sin(Omega);
|
||||
const double cok = cos(Omega);
|
||||
|
||||
// --- Compute satellite coordinates in Earth-fixed coordinates
|
||||
const double xprime = r * cuk;
|
||||
const double yprime = r * suk;
|
||||
d_satpos_X = xprime * cok - yprime * cik * sok;
|
||||
d_satpos_Y = xprime * sok + yprime * cik * cok; // ********NOTE: in GALILEO ICD this expression is not correct because it has minus (- sin(u) * r * cos(i) * cos(Omega)) instead of plus
|
||||
d_satpos_Z = yprime * sik;
|
||||
|
||||
// Satellite's velocity. Can be useful for Vector Tracking loops
|
||||
const double xpkdot = rkdot * cuk - yprime * ukdot;
|
||||
const double ypkdot = rkdot * suk + xprime * ukdot;
|
||||
const double tmp = ypkdot * cik - d_satpos_Z * ikdot;
|
||||
|
||||
d_satvel_X = -Omega_dot * d_satpos_Y + xpkdot * cok - tmp * sok;
|
||||
d_satvel_Y = Omega_dot * d_satpos_X + xpkdot * sok + tmp * cok;
|
||||
d_satvel_Z = yprime * cik * ikdot + ypkdot * sik;
|
||||
}
|
||||
|
||||
|
||||
double Galileo_Ephemeris::check_t(double time)
|
||||
{
|
||||
const double half_week = 302400.0; // seconds
|
||||
double corrTime = time;
|
||||
if (time > half_week)
|
||||
{
|
||||
corrTime = time - 2.0 * half_week;
|
||||
}
|
||||
else if (time < -half_week)
|
||||
{
|
||||
corrTime = time + 2.0 * half_week;
|
||||
}
|
||||
return corrTime;
|
||||
}
|
||||
|
@ -19,6 +19,7 @@
|
||||
#ifndef GNSS_SDR_GALILEO_EPHEMERIS_H
|
||||
#define GNSS_SDR_GALILEO_EPHEMERIS_H
|
||||
|
||||
#include "gnss_ephemeris.h"
|
||||
#include <boost/serialization/nvp.hpp>
|
||||
#include <cstdint>
|
||||
|
||||
@ -29,84 +30,43 @@
|
||||
|
||||
|
||||
/*!
|
||||
* \brief This class is a storage and orbital model functions for the Galileo SV ephemeris data as described in Galileo ICD paragraph 5.1.1
|
||||
* \brief This class is a storage and orbital model functions for the Galileo SV
|
||||
* ephemeris data as described in Galileo ICD paragraph 5.1.1
|
||||
*
|
||||
* (See https://www.gsc-europa.eu/sites/default/files/sites/all/files/Galileo_OS_SIS_ICD_v2.0.pdf )
|
||||
*
|
||||
*/
|
||||
class Galileo_Ephemeris
|
||||
class Galileo_Ephemeris : public Gnss_Ephemeris
|
||||
{
|
||||
public:
|
||||
Galileo_Ephemeris() = default;
|
||||
Galileo_Ephemeris()
|
||||
{
|
||||
this->System = 'E';
|
||||
}
|
||||
|
||||
void satellitePosition(double transmitTime); //!< Computes the ECEF SV coordinates and ECEF velocity
|
||||
double Galileo_System_Time(double WN, double TOW); //!< Galileo System Time (GST), ICD paragraph 5.1.2
|
||||
double sv_clock_drift(double transmitTime); //!< Satellite Time Correction Algorithm, ICD 5.1.4
|
||||
double sv_clock_relativistic_term(double transmitTime); //!< Satellite Time Correction Algorithm, ICD 5.1.4
|
||||
double Galileo_System_Time(double week_number, double TOW); //!< Galileo System Time (GST), ICD paragraph 5.1.2
|
||||
|
||||
/* Galileo ephemeris are 16 parameters and here are reported following the ICD order, paragraph 5.1.1.
|
||||
The number in the name after underscore (_1, _2, _3 and so on) refers to the page were we can find that parameter */
|
||||
int32_t IOD_ephemeris{};
|
||||
int32_t IOD_nav_1{};
|
||||
int32_t SV_ID_PRN_4{};
|
||||
double M0_1{}; //!< Mean anomaly at reference time [semi-circles]
|
||||
double delta_n_3{}; //!< Mean motion difference from computed value [semi-circles/sec]
|
||||
double e_1{}; //!< Eccentricity
|
||||
double A_1{}; //!< Square root of the semi-major axis [meters^1/2]
|
||||
double OMEGA_0_2{}; //!< Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
double i_0_2{}; //!< Inclination angle at reference time [semi-circles]
|
||||
double omega_2{}; //!< Argument of perigee [semi-circles]
|
||||
double OMEGA_dot_3{}; //!< Rate of right ascension [semi-circles/sec]
|
||||
double iDot_2{}; //!< Rate of inclination angle [semi-circles/sec]
|
||||
double C_uc_3{}; //!< Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
double C_us_3{}; //!< Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
double C_rc_3{}; //!< Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
double C_rs_3{}; //!< Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
double C_ic_4{}; //!< Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
double C_is_4{}; //!< Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
int32_t t0e_1{}; //!< Ephemeris reference time [s]
|
||||
|
||||
/* Clock correction parameters */
|
||||
int32_t t0c_4{}; //!< Clock correction data reference Time of Week [sec]
|
||||
double af0_4{}; //!< SV clock bias correction coefficient [s]
|
||||
double af1_4{}; //!< SV clock drift correction coefficient [s/s]
|
||||
double af2_4{}; //!< SV clock drift rate correction coefficient [s/s^2]
|
||||
|
||||
/* GST */
|
||||
// Not belong to ephemeris set (page 1 to 4)
|
||||
int32_t WN_5{}; //!< Week number
|
||||
int32_t TOW_5{}; //!< Time of Week
|
||||
double Galileo_satClkDrift{};
|
||||
double Galileo_dtr{}; //!< relativistic clock correction term
|
||||
int32_t IOD_nav{};
|
||||
|
||||
// SV status
|
||||
int32_t SISA_3{};
|
||||
int32_t E5a_HS{}; //!< E5a Signal Health Status
|
||||
int32_t E5b_HS_5{}; //!< E5b Signal Health Status
|
||||
int32_t E1B_HS_5{}; //!< E1B Signal Health Status
|
||||
bool E5a_DVS{}; //!< E5a Data Validity Status
|
||||
bool E5b_DVS_5{}; //!< E5b Data Validity Status
|
||||
bool E1B_DVS_5{}; //!< E1B Data Validity Status
|
||||
double BGD_E1E5a_5{}; //!< E1-E5a Broadcast Group Delay [s]
|
||||
double BGD_E1E5b_5{}; //!< E1-E5b Broadcast Group Delay [s]
|
||||
|
||||
// satellite positions
|
||||
double d_satpos_X{}; //!< Earth-fixed coordinate x of the satellite [m]. Intersection of the IERS Reference Meridian (IRM) and the plane passing through the origin and normal to the Z-axis.
|
||||
double d_satpos_Y{}; //!< Earth-fixed coordinate y of the satellite [m]. Completes a right-handed, Earth-Centered, Earth-Fixed orthogonal coordinate system.
|
||||
double d_satpos_Z{}; //!< Earth-fixed coordinate z of the satellite [m]. The direction of the IERS (International Earth Rotation and Reference Systems Service) Reference Pole (IRP).
|
||||
|
||||
// Satellite velocity
|
||||
double d_satvel_X{}; //!< Earth-fixed velocity coordinate x of the satellite [m]
|
||||
double d_satvel_Y{}; //!< Earth-fixed velocity coordinate y of the satellite [m]
|
||||
double d_satvel_Z{}; //!< Earth-fixed velocity coordinate z of the satellite [m]
|
||||
|
||||
uint32_t i_satellite_PRN{}; //!< SV PRN NUMBER
|
||||
int32_t SISA{}; //!< Signal in space accuracy index
|
||||
int32_t E5a_HS{}; //!< E5a Signal Health Status
|
||||
int32_t E5b_HS{}; //!< E5b Signal Health Status
|
||||
int32_t E1B_HS{}; //!< E1B Signal Health Status
|
||||
bool E5a_DVS{}; //!< E5a Data Validity Status
|
||||
bool E5b_DVS{}; //!< E5b Data Validity Status
|
||||
bool E1B_DVS{}; //!< E1B Data Validity Status
|
||||
double BGD_E1E5a{}; //!< E1-E5a Broadcast Group Delay [s]
|
||||
double BGD_E1E5b{}; //!< E1-E5b Broadcast Group Delay [s]
|
||||
|
||||
bool flag_all_ephemeris{};
|
||||
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
@ -114,60 +74,45 @@ public:
|
||||
{
|
||||
};
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(i_satellite_PRN);
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(M0_1);
|
||||
archive& BOOST_SERIALIZATION_NVP(delta_n_3);
|
||||
archive& BOOST_SERIALIZATION_NVP(e_1);
|
||||
archive& BOOST_SERIALIZATION_NVP(A_1);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGA_0_2);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_0_2);
|
||||
archive& BOOST_SERIALIZATION_NVP(omega_2);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGA_dot_3);
|
||||
archive& BOOST_SERIALIZATION_NVP(iDot_2);
|
||||
archive& BOOST_SERIALIZATION_NVP(C_uc_3);
|
||||
archive& BOOST_SERIALIZATION_NVP(C_us_3);
|
||||
archive& BOOST_SERIALIZATION_NVP(C_rc_3);
|
||||
archive& BOOST_SERIALIZATION_NVP(C_rs_3);
|
||||
archive& BOOST_SERIALIZATION_NVP(C_ic_4);
|
||||
archive& BOOST_SERIALIZATION_NVP(C_is_4);
|
||||
archive& BOOST_SERIALIZATION_NVP(t0e_1);
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(t0c_4);
|
||||
archive& BOOST_SERIALIZATION_NVP(af0_4);
|
||||
archive& BOOST_SERIALIZATION_NVP(af1_4);
|
||||
archive& BOOST_SERIALIZATION_NVP(af2_4);
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(WN_5);
|
||||
archive& BOOST_SERIALIZATION_NVP(TOW_5);
|
||||
archive& BOOST_SERIALIZATION_NVP(Galileo_satClkDrift);
|
||||
archive& BOOST_SERIALIZATION_NVP(Galileo_dtr);
|
||||
archive& BOOST_SERIALIZATION_NVP(PRN);
|
||||
archive& BOOST_SERIALIZATION_NVP(M_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(delta_n);
|
||||
archive& BOOST_SERIALIZATION_NVP(ecc);
|
||||
archive& BOOST_SERIALIZATION_NVP(sqrtA);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGA_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(omega);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGAdot);
|
||||
archive& BOOST_SERIALIZATION_NVP(idot);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cuc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cus);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crs);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cic);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cis);
|
||||
archive& BOOST_SERIALIZATION_NVP(toe);
|
||||
archive& BOOST_SERIALIZATION_NVP(toc);
|
||||
archive& BOOST_SERIALIZATION_NVP(af0);
|
||||
archive& BOOST_SERIALIZATION_NVP(af1);
|
||||
archive& BOOST_SERIALIZATION_NVP(af2);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN);
|
||||
archive& BOOST_SERIALIZATION_NVP(tow);
|
||||
archive& BOOST_SERIALIZATION_NVP(satClkDrift);
|
||||
archive& BOOST_SERIALIZATION_NVP(dtr);
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(IOD_ephemeris);
|
||||
archive& BOOST_SERIALIZATION_NVP(IOD_nav_1);
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(SISA_3);
|
||||
archive& BOOST_SERIALIZATION_NVP(IOD_nav);
|
||||
archive& BOOST_SERIALIZATION_NVP(SISA);
|
||||
archive& BOOST_SERIALIZATION_NVP(E5a_HS);
|
||||
archive& BOOST_SERIALIZATION_NVP(E5b_HS_5);
|
||||
archive& BOOST_SERIALIZATION_NVP(E1B_HS_5);
|
||||
archive& BOOST_SERIALIZATION_NVP(E5b_HS);
|
||||
archive& BOOST_SERIALIZATION_NVP(E1B_HS);
|
||||
archive& BOOST_SERIALIZATION_NVP(E5a_DVS);
|
||||
archive& BOOST_SERIALIZATION_NVP(E5b_DVS_5);
|
||||
archive& BOOST_SERIALIZATION_NVP(E1B_DVS_5);
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(BGD_E1E5a_5);
|
||||
archive& BOOST_SERIALIZATION_NVP(BGD_E1E5b_5);
|
||||
|
||||
archive& BOOST_SERIALIZATION_NVP(E5b_DVS);
|
||||
archive& BOOST_SERIALIZATION_NVP(E1B_DVS);
|
||||
archive& BOOST_SERIALIZATION_NVP(BGD_E1E5a);
|
||||
archive& BOOST_SERIALIZATION_NVP(BGD_E1E5b);
|
||||
archive& BOOST_SERIALIZATION_NVP(flag_all_ephemeris);
|
||||
}
|
||||
|
||||
private:
|
||||
/*
|
||||
* Accounts for the beginning or end of week crossover
|
||||
*
|
||||
* \param[in] - time in seconds
|
||||
* \param[out] - corrected time, in seconds
|
||||
*/
|
||||
double check_t(double time);
|
||||
};
|
||||
|
||||
|
||||
|
@ -400,34 +400,33 @@ Galileo_Ephemeris Galileo_Fnav_Message::get_ephemeris() const
|
||||
Galileo_Ephemeris ephemeris;
|
||||
ephemeris.flag_all_ephemeris = flag_all_ephemeris;
|
||||
ephemeris.IOD_ephemeris = IOD_ephemeris;
|
||||
ephemeris.SV_ID_PRN_4 = FNAV_SV_ID_PRN_1;
|
||||
ephemeris.i_satellite_PRN = FNAV_SV_ID_PRN_1;
|
||||
ephemeris.M0_1 = FNAV_M0_2; // Mean anomaly at reference time [semi-circles]
|
||||
ephemeris.delta_n_3 = FNAV_deltan_3; // Mean motion difference from computed value [semi-circles/sec]
|
||||
ephemeris.e_1 = FNAV_e_2; // Eccentricity
|
||||
ephemeris.A_1 = FNAV_a12_2; // Square root of the semi-major axis [meters^1/2]
|
||||
ephemeris.OMEGA_0_2 = FNAV_omega0_2; // Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
ephemeris.i_0_2 = FNAV_i0_3; // Inclination angle at reference time [semi-circles]
|
||||
ephemeris.omega_2 = FNAV_w_3; // Argument of perigee [semi-circles]
|
||||
ephemeris.OMEGA_dot_3 = FNAV_omegadot_2; // Rate of right ascension [semi-circles/sec]
|
||||
ephemeris.iDot_2 = FNAV_idot_2; // Rate of inclination angle [semi-circles/sec]
|
||||
ephemeris.C_uc_3 = FNAV_Cuc_3; // Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.C_us_3 = FNAV_Cus_3; // Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.C_rc_3 = FNAV_Crc_3; // Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.C_rs_3 = FNAV_Crs_3; // Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.C_ic_4 = FNAV_Cic_4; // Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.C_is_4 = FNAV_Cis_4; // Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.t0e_1 = FNAV_t0e_3; // Ephemeris reference time [s]
|
||||
ephemeris.PRN = FNAV_SV_ID_PRN_1;
|
||||
ephemeris.M_0 = FNAV_M0_2; // Mean anomaly at reference time [semi-circles]
|
||||
ephemeris.delta_n = FNAV_deltan_3; // Mean motion difference from computed value [semi-circles/sec]
|
||||
ephemeris.ecc = FNAV_e_2; // Eccentricity
|
||||
ephemeris.sqrtA = FNAV_a12_2; // Square root of the semi-major axis [meters^1/2]
|
||||
ephemeris.OMEGA_0 = FNAV_omega0_2; // Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
ephemeris.i_0 = FNAV_i0_3; // Inclination angle at reference time [semi-circles]
|
||||
ephemeris.omega = FNAV_w_3; // Argument of perigee [semi-circles]
|
||||
ephemeris.OMEGAdot = FNAV_omegadot_2; // Rate of right ascension [semi-circles/sec]
|
||||
ephemeris.idot = FNAV_idot_2; // Rate of inclination angle [semi-circles/sec]
|
||||
ephemeris.Cuc = FNAV_Cuc_3; // Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.Cus = FNAV_Cus_3; // Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.Crc = FNAV_Crc_3; // Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.Crs = FNAV_Crs_3; // Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.Cic = FNAV_Cic_4; // Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.Cis = FNAV_Cis_4; // Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.toe = FNAV_t0e_3; // Ephemeris reference time [s]
|
||||
|
||||
// Clock correction parameters
|
||||
ephemeris.t0c_4 = FNAV_t0c_1; // Clock correction data reference Time of Week [sec]
|
||||
ephemeris.af0_4 = FNAV_af0_1; // SV clock bias correction coefficient [s]
|
||||
ephemeris.af1_4 = FNAV_af1_1; // SV clock drift correction coefficient [s/s]
|
||||
ephemeris.af2_4 = FNAV_af2_1; // SV clock drift rate correction coefficient [s/s^2]
|
||||
ephemeris.toc = FNAV_t0c_1; // Clock correction data reference Time of Week [sec]
|
||||
ephemeris.af0 = FNAV_af0_1; // SV clock bias correction coefficient [s]
|
||||
ephemeris.af1 = FNAV_af1_1; // SV clock drift correction coefficient [s/s]
|
||||
ephemeris.af2 = FNAV_af2_1; // SV clock drift rate correction coefficient [s/s^2]
|
||||
|
||||
// GST
|
||||
ephemeris.WN_5 = FNAV_WN_3; // Week number
|
||||
ephemeris.TOW_5 = FNAV_TOW_3; // Time of Week
|
||||
ephemeris.WN = FNAV_WN_3; // Week number
|
||||
ephemeris.tow = FNAV_TOW_3; // Time of Week
|
||||
|
||||
// Health status
|
||||
ephemeris.E5a_HS = FNAV_E5ahs_1;
|
||||
@ -440,20 +439,20 @@ Galileo_Iono Galileo_Fnav_Message::get_iono() const
|
||||
{
|
||||
Galileo_Iono iono;
|
||||
// Ionospheric correction
|
||||
iono.ai0_5 = FNAV_ai0_1; // Effective Ionisation Level 1st order parameter [sfu]
|
||||
iono.ai1_5 = FNAV_ai1_1; // Effective Ionisation Level 2st order parameter [sfu/degree]
|
||||
iono.ai2_5 = FNAV_ai2_1; // Effective Ionisation Level 3st order parameter [sfu/degree]
|
||||
iono.ai0 = FNAV_ai0_1; // Effective Ionisation Level 1st order parameter [sfu]
|
||||
iono.ai1 = FNAV_ai1_1; // Effective Ionisation Level 2st order parameter [sfu/degree]
|
||||
iono.ai2 = FNAV_ai2_1; // Effective Ionisation Level 3st order parameter [sfu/degree]
|
||||
|
||||
// Ionospheric disturbance flag
|
||||
iono.Region1_flag_5 = FNAV_region1_1; // Ionospheric Disturbance Flag for region 1
|
||||
iono.Region2_flag_5 = FNAV_region2_1; // Ionospheric Disturbance Flag for region 2
|
||||
iono.Region3_flag_5 = FNAV_region3_1; // Ionospheric Disturbance Flag for region 3
|
||||
iono.Region4_flag_5 = FNAV_region4_1; // Ionospheric Disturbance Flag for region 4
|
||||
iono.Region5_flag_5 = FNAV_region5_1; // Ionospheric Disturbance Flag for region 5
|
||||
iono.Region1_flag = FNAV_region1_1; // Ionospheric Disturbance Flag for region 1
|
||||
iono.Region2_flag = FNAV_region2_1; // Ionospheric Disturbance Flag for region 2
|
||||
iono.Region3_flag = FNAV_region3_1; // Ionospheric Disturbance Flag for region 3
|
||||
iono.Region4_flag = FNAV_region4_1; // Ionospheric Disturbance Flag for region 4
|
||||
iono.Region5_flag = FNAV_region5_1; // Ionospheric Disturbance Flag for region 5
|
||||
|
||||
// GST
|
||||
iono.TOW_5 = FNAV_TOW_1;
|
||||
iono.WN_5 = FNAV_WN_1;
|
||||
iono.tow = FNAV_TOW_1;
|
||||
iono.WN = FNAV_WN_1;
|
||||
return iono;
|
||||
}
|
||||
|
||||
@ -462,18 +461,15 @@ Galileo_Utc_Model Galileo_Fnav_Message::get_utc_model() const
|
||||
{
|
||||
Galileo_Utc_Model utc_model;
|
||||
// Word type 6: GST-UTC conversion parameters
|
||||
utc_model.A0_6 = FNAV_A0_4;
|
||||
utc_model.A1_6 = FNAV_A1_4;
|
||||
utc_model.Delta_tLS_6 = FNAV_deltatls_4;
|
||||
utc_model.t0t_6 = FNAV_t0t_4;
|
||||
utc_model.WNot_6 = FNAV_WNot_4;
|
||||
utc_model.WN_LSF_6 = FNAV_WNlsf_4;
|
||||
utc_model.DN_6 = FNAV_DN_4;
|
||||
utc_model.Delta_tLSF_6 = FNAV_deltatlsf_4;
|
||||
utc_model.A0 = FNAV_A0_4;
|
||||
utc_model.A1 = FNAV_A1_4;
|
||||
utc_model.Delta_tLS = FNAV_deltatls_4;
|
||||
utc_model.tot = FNAV_t0t_4;
|
||||
utc_model.WNot = FNAV_WNot_4;
|
||||
utc_model.WN_LSF = FNAV_WNlsf_4;
|
||||
utc_model.DN = FNAV_DN_4;
|
||||
utc_model.Delta_tLSF = FNAV_deltatlsf_4;
|
||||
utc_model.flag_utc_model = flag_utc_model;
|
||||
// GST
|
||||
// utc_model.WN_5 = WN_5; //Week number
|
||||
// utc_model.TOW_5 = WN_5; //Time of Week
|
||||
return utc_model;
|
||||
}
|
||||
|
||||
|
@ -267,45 +267,45 @@ Galileo_Ephemeris Galileo_Inav_Message::get_ephemeris() const
|
||||
Galileo_Ephemeris ephemeris;
|
||||
ephemeris.flag_all_ephemeris = flag_all_ephemeris;
|
||||
ephemeris.IOD_ephemeris = IOD_ephemeris;
|
||||
ephemeris.SV_ID_PRN_4 = SV_ID_PRN_4;
|
||||
ephemeris.i_satellite_PRN = SV_ID_PRN_4;
|
||||
ephemeris.M0_1 = M0_1; // Mean anomaly at reference time [semi-circles]
|
||||
ephemeris.delta_n_3 = delta_n_3; // Mean motion difference from computed value [semi-circles/sec]
|
||||
ephemeris.e_1 = e_1; // Eccentricity
|
||||
ephemeris.A_1 = A_1; // Square root of the semi-major axis [meters^1/2]
|
||||
ephemeris.OMEGA_0_2 = OMEGA_0_2; // Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
ephemeris.i_0_2 = i_0_2; // Inclination angle at reference time [semi-circles]
|
||||
ephemeris.omega_2 = omega_2; // Argument of perigee [semi-circles]
|
||||
ephemeris.OMEGA_dot_3 = OMEGA_dot_3; // Rate of right ascension [semi-circles/sec]
|
||||
ephemeris.iDot_2 = iDot_2; // Rate of inclination angle [semi-circles/sec]
|
||||
ephemeris.C_uc_3 = C_uc_3; // Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.C_us_3 = C_us_3; // Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.C_rc_3 = C_rc_3; // Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.C_rs_3 = C_rs_3; // Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.C_ic_4 = C_ic_4; // Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.C_is_4 = C_is_4; // Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.t0e_1 = t0e_1; // Ephemeris reference time [s]
|
||||
ephemeris.IOD_nav = IOD_nav_1;
|
||||
ephemeris.PRN = SV_ID_PRN_4;
|
||||
ephemeris.M_0 = M0_1; // Mean anomaly at reference time [semi-circles]
|
||||
ephemeris.delta_n = delta_n_3; // Mean motion difference from computed value [semi-circles/sec]
|
||||
ephemeris.ecc = e_1; // Eccentricity
|
||||
ephemeris.sqrtA = A_1; // Square root of the semi-major axis [meters^1/2]
|
||||
ephemeris.OMEGA_0 = OMEGA_0_2; // Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
ephemeris.i_0 = i_0_2; // Inclination angle at reference time [semi-circles]
|
||||
ephemeris.omega = omega_2; // Argument of perigee [semi-circles]
|
||||
ephemeris.OMEGAdot = OMEGA_dot_3; // Rate of right ascension [semi-circles/sec]
|
||||
ephemeris.idot = iDot_2; // Rate of inclination angle [semi-circles/sec]
|
||||
ephemeris.Cuc = C_uc_3; // Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.Cus = C_us_3; // Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
ephemeris.Crc = C_rc_3; // Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.Crs = C_rs_3; // Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
ephemeris.Cic = C_ic_4; // Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.Cis = C_is_4; // Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
ephemeris.toe = t0e_1; // Ephemeris reference time [s]
|
||||
|
||||
// Clock correction parameters
|
||||
ephemeris.t0c_4 = t0c_4; // Clock correction data reference Time of Week [sec]
|
||||
ephemeris.af0_4 = af0_4; // SV clock bias correction coefficient [s]
|
||||
ephemeris.af1_4 = af1_4; // SV clock drift correction coefficient [s/s]
|
||||
ephemeris.af2_4 = af2_4; // SV clock drift rate correction coefficient [s/s^2]
|
||||
ephemeris.toc = t0c_4; // Clock correction data reference Time of Week [sec]
|
||||
ephemeris.af0 = af0_4; // SV clock bias correction coefficient [s]
|
||||
ephemeris.af1 = af1_4; // SV clock drift correction coefficient [s/s]
|
||||
ephemeris.af2 = af2_4; // SV clock drift rate correction coefficient [s/s^2]
|
||||
|
||||
// GST
|
||||
ephemeris.WN_5 = WN_5; // Week number
|
||||
ephemeris.TOW_5 = TOW_5; // Time of Week
|
||||
ephemeris.WN = WN_5; // Week number
|
||||
ephemeris.tow = TOW_5; // Time of Week
|
||||
|
||||
ephemeris.SISA_3 = SISA_3;
|
||||
ephemeris.E5b_HS_5 = E5b_HS_5; // E5b Signal Health Status
|
||||
ephemeris.E1B_HS_5 = E1B_HS_5; // E1B Signal Health Status
|
||||
ephemeris.E5b_DVS_5 = E5b_DVS_5; // E5b Data Validity Status
|
||||
ephemeris.E1B_DVS_5 = E1B_DVS_5; // E1B Data Validity Status
|
||||
ephemeris.SISA = SISA_3;
|
||||
ephemeris.E5b_HS = E5b_HS_5; // E5b Signal Health Status
|
||||
ephemeris.E1B_HS = E1B_HS_5; // E1B Signal Health Status
|
||||
ephemeris.E5b_DVS = E5b_DVS_5; // E5b Data Validity Status
|
||||
ephemeris.E1B_DVS = E1B_DVS_5; // E1B Data Validity Status
|
||||
|
||||
ephemeris.BGD_E1E5a_5 = BGD_E1E5a_5; // E1-E5a Broadcast Group Delay [s]
|
||||
ephemeris.BGD_E1E5b_5 = BGD_E1E5b_5; // E1-E5b Broadcast Group Delay [s]
|
||||
ephemeris.BGD_E1E5a = BGD_E1E5a_5; // E1-E5a Broadcast Group Delay [s]
|
||||
ephemeris.BGD_E1E5b = BGD_E1E5b_5; // E1-E5b Broadcast Group Delay [s]
|
||||
|
||||
ephemeris.Galileo_satClkDrift = Galileo_satClkDrift;
|
||||
ephemeris.satClkDrift = Galileo_satClkDrift;
|
||||
|
||||
return ephemeris;
|
||||
}
|
||||
@ -315,21 +315,21 @@ Galileo_Iono Galileo_Inav_Message::get_iono() const
|
||||
{
|
||||
Galileo_Iono iono;
|
||||
// Ionospheric correction
|
||||
iono.ai0_5 = ai0_5; // Effective Ionisation Level 1st order parameter [sfu]
|
||||
iono.ai1_5 = ai1_5; // Effective Ionisation Level 2st order parameter [sfu/degree]
|
||||
iono.ai2_5 = ai2_5; // Effective Ionisation Level 3st order parameter [sfu/degree]
|
||||
iono.ai0 = ai0_5; // Effective Ionisation Level 1st order parameter [sfu]
|
||||
iono.ai1 = ai1_5; // Effective Ionisation Level 2st order parameter [sfu/degree]
|
||||
iono.ai2 = ai2_5; // Effective Ionisation Level 3st order parameter [sfu/degree]
|
||||
|
||||
// GST
|
||||
// This is the ONLY page containing the Week Number (WN)
|
||||
iono.TOW_5 = TOW_5;
|
||||
iono.WN_5 = WN_5;
|
||||
iono.tow = TOW_5;
|
||||
iono.WN = WN_5;
|
||||
|
||||
// Ionospheric disturbance flag
|
||||
iono.Region1_flag_5 = Region1_flag_5; // Ionospheric Disturbance Flag for region 1
|
||||
iono.Region2_flag_5 = Region2_flag_5; // Ionospheric Disturbance Flag for region 2
|
||||
iono.Region3_flag_5 = Region3_flag_5; // Ionospheric Disturbance Flag for region 3
|
||||
iono.Region4_flag_5 = Region4_flag_5; // Ionospheric Disturbance Flag for region 4
|
||||
iono.Region5_flag_5 = Region5_flag_5; // Ionospheric Disturbance Flag for region 5
|
||||
iono.Region1_flag = Region1_flag_5; // Ionospheric Disturbance Flag for region 1
|
||||
iono.Region2_flag = Region2_flag_5; // Ionospheric Disturbance Flag for region 2
|
||||
iono.Region3_flag = Region3_flag_5; // Ionospheric Disturbance Flag for region 3
|
||||
iono.Region4_flag = Region4_flag_5; // Ionospheric Disturbance Flag for region 4
|
||||
iono.Region5_flag = Region5_flag_5; // Ionospheric Disturbance Flag for region 5
|
||||
|
||||
return iono;
|
||||
}
|
||||
@ -339,20 +339,20 @@ Galileo_Utc_Model Galileo_Inav_Message::get_utc_model() const
|
||||
{
|
||||
Galileo_Utc_Model utc_model;
|
||||
// Word type 6: GST-UTC conversion parameters
|
||||
utc_model.A0_6 = A0_6;
|
||||
utc_model.A1_6 = A1_6;
|
||||
utc_model.Delta_tLS_6 = Delta_tLS_6;
|
||||
utc_model.t0t_6 = t0t_6;
|
||||
utc_model.WNot_6 = WNot_6;
|
||||
utc_model.WN_LSF_6 = WN_LSF_6;
|
||||
utc_model.DN_6 = DN_6;
|
||||
utc_model.Delta_tLSF_6 = Delta_tLSF_6;
|
||||
utc_model.A0 = A0_6;
|
||||
utc_model.A1 = A1_6;
|
||||
utc_model.Delta_tLS = Delta_tLS_6;
|
||||
utc_model.tot = t0t_6;
|
||||
utc_model.WNot = WNot_6;
|
||||
utc_model.WN_LSF = WN_LSF_6;
|
||||
utc_model.DN = DN_6;
|
||||
utc_model.Delta_tLSF = Delta_tLSF_6;
|
||||
utc_model.flag_utc_model = flag_utc_model;
|
||||
// GPS to Galileo GST conversion parameters
|
||||
utc_model.A_0G_10 = A_0G_10;
|
||||
utc_model.A_1G_10 = A_1G_10;
|
||||
utc_model.t_0G_10 = t_0G_10;
|
||||
utc_model.WN_0G_10 = WN_0G_10;
|
||||
utc_model.A_0G = A_0G_10;
|
||||
utc_model.A_1G = A_1G_10;
|
||||
utc_model.t_0G = t_0G_10;
|
||||
utc_model.WN_0G = WN_0G_10;
|
||||
return utc_model;
|
||||
}
|
||||
|
||||
|
@ -29,7 +29,8 @@
|
||||
|
||||
|
||||
/*!
|
||||
* \brief This class is a storage for the GALILEO IONOSPHERIC data as described in Galileo ICD paragraph 5.1.6
|
||||
* \brief This class is a storage for the GALILEO IONOSPHERIC data as described
|
||||
* in Galileo ICD paragraph 5.1.6
|
||||
*
|
||||
* See https://www.gsc-europa.eu/sites/default/files/sites/all/files/Galileo_OS_SIS_ICD_v2.0.pdf
|
||||
*/
|
||||
@ -42,20 +43,20 @@ public:
|
||||
Galileo_Iono() = default;
|
||||
|
||||
// Ionospheric correction
|
||||
double ai0_5{}; //!< Effective Ionisation Level 1st order parameter [sfu]
|
||||
double ai1_5{}; //!< Effective Ionisation Level 2st order parameter [sfu/degree]
|
||||
double ai2_5{}; //!< Effective Ionisation Level 3st order parameter [sfu/degree]
|
||||
double ai0{}; //!< Effective Ionisation Level 1st order parameter [sfu]
|
||||
double ai1{}; //!< Effective Ionisation Level 2st order parameter [sfu/degree]
|
||||
double ai2{}; //!< Effective Ionisation Level 3st order parameter [sfu/degree]
|
||||
|
||||
// from page 5 (UTC) to have a timestamp
|
||||
int32_t TOW_5{}; //!< UTC data reference Time of Week [s]
|
||||
int32_t WN_5{}; //!< UTC data reference Week number [week]
|
||||
int32_t tow{}; //!< UTC data reference Time of Week [s]
|
||||
int32_t WN{}; //!< UTC data reference Week number [week]
|
||||
|
||||
// Ionospheric disturbance flag
|
||||
bool Region1_flag_5{}; //!< Ionospheric Disturbance Flag for region 1
|
||||
bool Region2_flag_5{}; //!< Ionospheric Disturbance Flag for region 2
|
||||
bool Region3_flag_5{}; //!< Ionospheric Disturbance Flag for region 3
|
||||
bool Region4_flag_5{}; //!< Ionospheric Disturbance Flag for region 4
|
||||
bool Region5_flag_5{}; //!< Ionospheric Disturbance Flag for region 5
|
||||
bool Region1_flag{}; //!< Ionospheric Disturbance Flag for region 1
|
||||
bool Region2_flag{}; //!< Ionospheric Disturbance Flag for region 2
|
||||
bool Region3_flag{}; //!< Ionospheric Disturbance Flag for region 3
|
||||
bool Region4_flag{}; //!< Ionospheric Disturbance Flag for region 4
|
||||
bool Region5_flag{}; //!< Ionospheric Disturbance Flag for region 5
|
||||
|
||||
template <class Archive>
|
||||
|
||||
@ -65,20 +66,19 @@ public:
|
||||
*/
|
||||
inline void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("ai0_5", ai0_5);
|
||||
archive& make_nvp("ai1_5", ai1_5);
|
||||
archive& make_nvp("ai2_5", ai2_5);
|
||||
archive& make_nvp("TOW_5", TOW_5);
|
||||
archive& make_nvp("WN_5", WN_5);
|
||||
archive& make_nvp("Region1_flag_5", Region1_flag_5);
|
||||
archive& make_nvp("Region2_flag_5", Region2_flag_5);
|
||||
archive& make_nvp("Region3_flag_5", Region3_flag_5);
|
||||
archive& make_nvp("Region4_flag_5", Region4_flag_5);
|
||||
archive& make_nvp("Region5_flag_5", Region5_flag_5);
|
||||
archive& BOOST_SERIALIZATION_NVP(ai0);
|
||||
archive& BOOST_SERIALIZATION_NVP(ai1);
|
||||
archive& BOOST_SERIALIZATION_NVP(ai2);
|
||||
archive& BOOST_SERIALIZATION_NVP(tow);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN);
|
||||
archive& BOOST_SERIALIZATION_NVP(Region1_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(Region2_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(Region3_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(Region4_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(Region5_flag);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -24,12 +24,12 @@ double Galileo_Utc_Model::GST_to_UTC_time(double t_e, int32_t WN) const
|
||||
double t_Utc_daytime;
|
||||
double Delta_t_Utc = 0;
|
||||
// Determine if the effectivity time of the leap second event is in the past
|
||||
const int32_t weeksToLeapSecondEvent = WN_LSF_6 - (WN % 256);
|
||||
const int32_t weeksToLeapSecondEvent = WN_LSF - (WN % 256);
|
||||
|
||||
if ((weeksToLeapSecondEvent) >= 0) // is not in the past
|
||||
{
|
||||
// Detect if the effectivity time and user's time is within six hours = 6 * 60 *60 = 21600 s
|
||||
const int secondOfLeapSecondEvent = DN_6 * 24 * 60 * 60;
|
||||
const int secondOfLeapSecondEvent = DN * 24 * 60 * 60;
|
||||
if (std::abs(t_e - secondOfLeapSecondEvent) > 21600)
|
||||
{
|
||||
/* 5.1.7a GST->UTC case a
|
||||
@ -39,7 +39,7 @@ double Galileo_Utc_Model::GST_to_UTC_time(double t_e, int32_t WN) const
|
||||
* to the effective time and ends at six hours after the effective time,
|
||||
* the GST/Utc relationship is given by
|
||||
*/
|
||||
Delta_t_Utc = Delta_tLS_6 + A0_6 + A1_6 * (t_e - t0t_6 + 604800 * static_cast<double>((WN % 256) - WNot_6));
|
||||
Delta_t_Utc = Delta_tLS + A0 + A1 * (t_e - tot + 604800 * static_cast<double>((WN % 256) - WNot));
|
||||
t_Utc_daytime = fmod(t_e - Delta_t_Utc, 86400);
|
||||
}
|
||||
else
|
||||
@ -49,9 +49,9 @@ double Galileo_Utc_Model::GST_to_UTC_time(double t_e, int32_t WN) const
|
||||
* prior to the leap second adjustment to six hours after the adjustment time,
|
||||
* the effective time is computed according to the following equations:
|
||||
*/
|
||||
Delta_t_Utc = Delta_tLS_6 + A0_6 + A1_6 * (t_e - t0t_6 + 604800 * static_cast<double>((WN % 256) - WNot_6));
|
||||
Delta_t_Utc = Delta_tLS + A0 + A1 * (t_e - tot + 604800 * static_cast<double>((WN % 256) - WNot));
|
||||
const double W = fmod(t_e - Delta_t_Utc - 43200, 86400) + 43200;
|
||||
t_Utc_daytime = fmod(W, 86400 + Delta_tLSF_6 - Delta_tLS_6);
|
||||
t_Utc_daytime = fmod(W, 86400 + Delta_tLSF - Delta_tLS);
|
||||
// implement something to handle a leap second event!
|
||||
}
|
||||
}
|
||||
@ -64,7 +64,7 @@ double Galileo_Utc_Model::GST_to_UTC_time(double t_e, int32_t WN) const
|
||||
* ends six hours after the adjustment time, the effective time is computed according to
|
||||
* the following equation:
|
||||
*/
|
||||
Delta_t_Utc = Delta_tLSF_6 + A0_6 + A1_6 * (t_e - t0t_6 + 604800 * static_cast<double>((WN % 256) - WNot_6));
|
||||
Delta_t_Utc = Delta_tLSF + A0 + A1 * (t_e - tot + 604800 * static_cast<double>((WN % 256) - WNot));
|
||||
t_Utc_daytime = fmod(t_e - Delta_t_Utc, 86400);
|
||||
}
|
||||
|
||||
|
@ -41,24 +41,24 @@ public:
|
||||
*/
|
||||
Galileo_Utc_Model() = default;
|
||||
|
||||
// double TOW_6;
|
||||
// double TOW;
|
||||
double GST_to_UTC_time(double t_e, int32_t WN) const; //!< GST-UTC Conversion Algorithm and Parameters
|
||||
|
||||
// Word type 6: GST-UTC conversion parameters
|
||||
double A0_6{};
|
||||
double A1_6{};
|
||||
int32_t Delta_tLS_6{};
|
||||
int32_t t0t_6{}; //!< UTC data reference Time of Week [s]
|
||||
int32_t WNot_6{}; //!< UTC data reference Week number [week]
|
||||
int32_t WN_LSF_6{};
|
||||
int32_t DN_6{};
|
||||
int32_t Delta_tLSF_6{};
|
||||
double A0{};
|
||||
double A1{};
|
||||
int32_t Delta_tLS{};
|
||||
int32_t tot{}; //!< UTC data reference Time of Week [s]
|
||||
int32_t WNot{}; //!< UTC data reference Week number [week]
|
||||
int32_t WN_LSF{};
|
||||
int32_t DN{};
|
||||
int32_t Delta_tLSF{};
|
||||
|
||||
// GPS to Galileo GST conversion parameters
|
||||
double A_0G_10{};
|
||||
double A_1G_10{};
|
||||
int32_t t_0G_10{};
|
||||
int32_t WN_0G_10{};
|
||||
double A_0G{};
|
||||
double A_1G{};
|
||||
int32_t t_0G{};
|
||||
int32_t WN_0G{};
|
||||
|
||||
bool flag_utc_model{};
|
||||
|
||||
@ -70,19 +70,18 @@ public:
|
||||
*/
|
||||
inline void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("A0_6", A0_6);
|
||||
archive& make_nvp("A1_6", A1_6);
|
||||
archive& make_nvp("Delta_tLS_6", Delta_tLS_6);
|
||||
archive& make_nvp("t0t_6", t0t_6);
|
||||
archive& make_nvp("WNot_6", WNot_6);
|
||||
archive& make_nvp("WN_LSF_6", WN_LSF_6);
|
||||
archive& make_nvp("DN_6", DN_6);
|
||||
archive& make_nvp("Delta_tLSF_6", Delta_tLSF_6);
|
||||
archive& make_nvp("flag_utc_model", flag_utc_model);
|
||||
archive& BOOST_SERIALIZATION_NVP(A0);
|
||||
archive& BOOST_SERIALIZATION_NVP(A1);
|
||||
archive& BOOST_SERIALIZATION_NVP(Delta_tLS);
|
||||
archive& BOOST_SERIALIZATION_NVP(tot);
|
||||
archive& BOOST_SERIALIZATION_NVP(WNot);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN_LSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(DN);
|
||||
archive& BOOST_SERIALIZATION_NVP(Delta_tLSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(flag_utc_model);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -59,37 +59,37 @@ public:
|
||||
|
||||
// Satellite Identification Information
|
||||
int32_t i_satellite_freq_channel{}; //!< SV Frequency Channel Number
|
||||
uint32_t i_satellite_PRN{}; //!< SV PRN Number, equivalent to slot number for compatibility with GPS
|
||||
uint32_t PRN{}; //!< SV PRN Number, equivalent to slot number for compatibility with GPS
|
||||
uint32_t i_satellite_slot_number{}; //!< SV Slot Number
|
||||
|
||||
template <class Archive>
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the almanac data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the almanac data on disk file.
|
||||
*/
|
||||
void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
|
||||
archive& make_nvp("i_satellite_freq_channel", i_satellite_freq_channel);
|
||||
archive& make_nvp("i_satellite_PRN", i_satellite_PRN);
|
||||
archive& make_nvp("i_satellite_slot_number", i_satellite_slot_number);
|
||||
archive& make_nvp("d_n_A", d_n_A);
|
||||
archive& make_nvp("d_H_n_A", d_H_n_A);
|
||||
archive& make_nvp("d_lambda_n_A", d_lambda_n_A);
|
||||
archive& make_nvp("d_t_lambda_n_A", d_t_lambda_n_A);
|
||||
archive& make_nvp("d_Delta_i_n_A", d_Delta_i_n_A);
|
||||
archive& make_nvp("d_Delta_T_n_A", d_Delta_T_n_A);
|
||||
archive& make_nvp("d_Delta_T_n_A_dot", d_Delta_T_n_A_dot);
|
||||
archive& make_nvp("d_epsilon_n_A", d_epsilon_n_A);
|
||||
archive& make_nvp("d_omega_n_A", d_omega_n_A);
|
||||
archive& make_nvp("d_M_n_A", d_M_n_A);
|
||||
archive& make_nvp("d_KP", d_KP);
|
||||
archive& make_nvp("d_tau_n_A", d_tau_n_A);
|
||||
archive& make_nvp("d_C_n", d_C_n);
|
||||
archive& make_nvp("d_l_n", d_l_n);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_satellite_freq_channel);
|
||||
archive& BOOST_SERIALIZATION_NVP(PRN);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_satellite_slot_number);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_H_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_lambda_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_t_lambda_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Delta_i_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Delta_T_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Delta_T_n_A_dot);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_epsilon_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_omega_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_M_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_KP);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_tau_n_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_C_n);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_l_n);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -77,7 +77,7 @@ public:
|
||||
// Immediate deliverables of ephemeris information
|
||||
// Satellite Identification Information
|
||||
int32_t i_satellite_freq_channel{}; //!< SV Frequency Channel Number
|
||||
uint32_t i_satellite_PRN{}; //!< SV PRN Number, equivalent to slot number for compatibility with GPS
|
||||
uint32_t PRN{}; //!< SV PRN Number, equivalent to slot number for compatibility with GPS
|
||||
uint32_t i_satellite_slot_number{}; //!< SV Slot Number
|
||||
double d_yr = 1972.0; //!< Current year
|
||||
double d_satClkDrift{}; //!< GLONASS clock error
|
||||
@ -123,46 +123,46 @@ public:
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
|
||||
archive& make_nvp("i_satellite_freq_channel", i_satellite_freq_channel); //!< SV PRN frequency channel number
|
||||
archive& make_nvp("i_satellite_PRN", i_satellite_PRN);
|
||||
archive& make_nvp("i_satellite_slot_number", i_satellite_slot_number);
|
||||
archive& make_nvp("d_m", d_m); //!< String number within frame [dimensionless]
|
||||
archive& make_nvp("d_t_k", d_t_k); //!< Time referenced to the beginning of the frame within the current day [hours, minutes, seconds]
|
||||
archive& make_nvp("d_t_b", d_t_b); //!< Index of a time interval within current day according to UTC(SU) + 03 hours 00 min. [minutes]
|
||||
archive& make_nvp("d_M", d_M); //!< Type of satellite transmitting navigation signal [dimensionless]
|
||||
archive& make_nvp("d_gamma_n", d_gamma_n); //!< Relative deviation of predicted carrier frequency value of n- satellite from nominal value at the instant tb [dimensionless]
|
||||
archive& make_nvp("d_tau_n", d_tau_n); //!< Correction to the nth satellite time (tn) relative to GLONASS time (te)
|
||||
archive& make_nvp("d_Xn", d_Xn); //!< Earth-fixed coordinate x of the satellite in PZ-90.02 coordinate system [km].
|
||||
archive& make_nvp("d_Yn", d_Yn); //!< Earth-fixed coordinate y of the satellite in PZ-90.02 coordinate system [km]
|
||||
archive& make_nvp("d_Zn", d_Zn); //!< Earth-fixed coordinate z of the satellite in PZ-90.02 coordinate system [km]
|
||||
archive& make_nvp("d_VXn", d_VXn); //!< Earth-fixed velocity coordinate x of the satellite in PZ-90.02 coordinate system [km/s]
|
||||
archive& make_nvp("d_VYn", d_VYn); //!< Earth-fixed velocity coordinate y of the satellite in PZ-90.02 coordinate system [km/s]
|
||||
archive& make_nvp("d_VZn", d_VZn); //!< Earth-fixed velocity coordinate z of the satellite in PZ-90.02 coordinate system [km/s]
|
||||
archive& make_nvp("d_AXn", d_AXn); //!< Earth-fixed acceleration coordinate x of the satellite in PZ-90.02 coordinate system [km/s^2]
|
||||
archive& make_nvp("d_AYn", d_AYn); //!< Earth-fixed acceleration coordinate y of the satellite in PZ-90.02 coordinate system [km/s^2]
|
||||
archive& make_nvp("d_AZn", d_AZn); //!< Earth-fixed acceleration coordinate z of the satellite in PZ-90.02 coordinate system [km/s^2]
|
||||
archive& make_nvp("d_B_n", d_B_n); //!< Health flag [dimensionless]
|
||||
archive& make_nvp("d_P", d_P); //!< Technological parameter of control segment, indication the satellite operation mode in respect of time parameters [dimensionless]
|
||||
archive& make_nvp("d_N_T", d_N_T); //!< Current date, calendar number of day within four-year interval starting from the 1-st of January in a leap year [days]
|
||||
archive& make_nvp("d_F_T", d_F_T); //!< Parameter that provides the predicted satellite user range accuracy at time tb [dimensionless]
|
||||
archive& make_nvp("d_n", d_n); //!< Index of the satellite transmitting given navigation signal. It corresponds to a slot number within GLONASS constellation
|
||||
archive& make_nvp("d_Delta_tau_n", d_Delta_tau_n); //!< Time difference between navigation RF signal transmitted in L2 sub- band and aviation RF signal transmitted in L1 sub-band by nth satellite. [dimensionless]
|
||||
archive& make_nvp("d_E_n", d_E_n); //!< Characterises "age" of a current information [days]
|
||||
archive& make_nvp("d_P_1", d_P_1); //!< Flag of the immediate data updating.
|
||||
archive& make_nvp("d_P_2", d_P_2); //!< Flag of oddness ("1") or evenness ("0") of the value of (tb) [dimensionless]
|
||||
archive& make_nvp("d_P_3", d_P_3); //!< Flag indicating a number of satellites for which almanac is transmitted within given frame: "1" corresponds to 5 satellites and "0" corresponds to 4 satellites [dimensionless]
|
||||
archive& make_nvp("d_P_4", d_P_4); //!< Flag to show that ephemeris parameters are present. "1" indicates that updated ephemeris or frequency/time parameters have been uploaded by the control segment [dimensionless]
|
||||
archive& make_nvp("d_l3rd_n", d_l3rd_n); //!< Health flag for nth satellite; ln = 0 indicates the n-th satellite is helthy, ln = 1 indicates malfunction of this nth satellite [dimensionless]
|
||||
archive& make_nvp("d_l5th_n", d_l5th_n); //!< Health flag for nth satellite; ln = 0 indicates the n-th satellite is helthy, ln = 1 indicates malfunction of this nth satellite [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(i_satellite_freq_channel); //!< SV PRN frequency channel number
|
||||
archive& BOOST_SERIALIZATION_NVP(PRN);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_satellite_slot_number);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_m); //!< String number within frame [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_t_k); //!< Time referenced to the beginning of the frame within the current day [hours, minutes, seconds]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_t_b); //!< Index of a time interval within current day according to UTC(SU) + 03 hours 00 min. [minutes]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_M); //!< Type of satellite transmitting navigation signal [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_gamma_n); //!< Relative deviation of predicted carrier frequency value of n- satellite from nominal value at the instant tb [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_tau_n); //!< Correction to the nth satellite time (tn) relative to GLONASS time (te)
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Xn); //!< Earth-fixed coordinate x of the satellite in PZ-90.02 coordinate system [km].
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Yn); //!< Earth-fixed coordinate y of the satellite in PZ-90.02 coordinate system [km]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Zn); //!< Earth-fixed coordinate z of the satellite in PZ-90.02 coordinate system [km]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_VXn); //!< Earth-fixed velocity coordinate x of the satellite in PZ-90.02 coordinate system [km/s]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_VYn); //!< Earth-fixed velocity coordinate y of the satellite in PZ-90.02 coordinate system [km/s]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_VZn); //!< Earth-fixed velocity coordinate z of the satellite in PZ-90.02 coordinate system [km/s]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_AXn); //!< Earth-fixed acceleration coordinate x of the satellite in PZ-90.02 coordinate system [km/s^2]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_AYn); //!< Earth-fixed acceleration coordinate y of the satellite in PZ-90.02 coordinate system [km/s^2]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_AZn); //!< Earth-fixed acceleration coordinate z of the satellite in PZ-90.02 coordinate system [km/s^2]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_B_n); //!< Health flag [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_P); //!< Technological parameter of control segment, indication the satellite operation mode in respect of time parameters [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_N_T); //!< Current date, calendar number of day within four-year interval starting from the 1-st of January in a leap year [days]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_F_T); //!< Parameter that provides the predicted satellite user range accuracy at time tb [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_n); //!< Index of the satellite transmitting given navigation signal. It corresponds to a slot number within GLONASS constellation
|
||||
archive& BOOST_SERIALIZATION_NVP(d_Delta_tau_n); //!< Time difference between navigation RF signal transmitted in L2 sub- band and aviation RF signal transmitted in L1 sub-band by nth satellite. [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_E_n); //!< Characterises "age" of a current information [days]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_P_1); //!< Flag of the immediate data updating.
|
||||
archive& BOOST_SERIALIZATION_NVP(d_P_2); //!< Flag of oddness ("1") or evenness ("0") of the value of (tb) [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_P_3); //!< Flag indicating a number of satellites for which almanac is transmitted within given frame: "1" corresponds to 5 satellites and "0" corresponds to 4 satellites [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_P_4); //!< Flag to show that ephemeris parameters are present. "1" indicates that updated ephemeris or frequency/time parameters have been uploaded by the control segment [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_l3rd_n); //!< Health flag for nth satellite; ln = 0 indicates the n-th satellite is helthy, ln = 1 indicates malfunction of this nth satellite [dimensionless]
|
||||
archive& BOOST_SERIALIZATION_NVP(d_l5th_n); //!< Health flag for nth satellite; ln = 0 indicates the n-th satellite is helthy, ln = 1 indicates malfunction of this nth satellite [dimensionless]
|
||||
}
|
||||
|
||||
private:
|
||||
|
@ -314,7 +314,7 @@ int32_t Glonass_Gnav_Navigation_Message::string_decoder(const std::string& frame
|
||||
// Fill in ephemeris deliverables in the code
|
||||
flag_update_slot_number = true;
|
||||
gnav_ephemeris.i_satellite_slot_number = static_cast<uint32_t>(gnav_ephemeris.d_n);
|
||||
gnav_ephemeris.i_satellite_PRN = static_cast<uint32_t>(gnav_ephemeris.d_n);
|
||||
gnav_ephemeris.PRN = static_cast<uint32_t>(gnav_ephemeris.d_n);
|
||||
|
||||
flag_ephemeris_str_4 = true;
|
||||
}
|
||||
@ -408,7 +408,7 @@ int32_t Glonass_Gnav_Navigation_Message::string_decoder(const std::string& frame
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_freq_channel = gnav_almanac[i_alm_satellite_slot_number - 1].d_H_n_A - 32.0;
|
||||
}
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_slot_number = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
|
||||
if (i_alm_satellite_slot_number == gnav_ephemeris.i_satellite_slot_number)
|
||||
{
|
||||
@ -458,7 +458,7 @@ int32_t Glonass_Gnav_Navigation_Message::string_decoder(const std::string& frame
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_freq_channel = gnav_almanac[i_alm_satellite_slot_number - 1].d_H_n_A - 32.0;
|
||||
}
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_slot_number = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
|
||||
flag_almanac_str_9 = true;
|
||||
}
|
||||
@ -503,7 +503,7 @@ int32_t Glonass_Gnav_Navigation_Message::string_decoder(const std::string& frame
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_freq_channel = gnav_almanac[i_alm_satellite_slot_number - 1].d_H_n_A - 32.0;
|
||||
}
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_slot_number = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
|
||||
flag_almanac_str_11 = true;
|
||||
}
|
||||
@ -547,7 +547,7 @@ int32_t Glonass_Gnav_Navigation_Message::string_decoder(const std::string& frame
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_freq_channel = gnav_almanac[i_alm_satellite_slot_number - 1].d_H_n_A - 32.0;
|
||||
}
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_slot_number = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
|
||||
flag_almanac_str_13 = true;
|
||||
}
|
||||
@ -598,7 +598,7 @@ int32_t Glonass_Gnav_Navigation_Message::string_decoder(const std::string& frame
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_freq_channel = gnav_almanac[i_alm_satellite_slot_number - 1].d_H_n_A - 32.0;
|
||||
}
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_slot_number = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].i_satellite_PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
gnav_almanac[i_alm_satellite_slot_number - 1].PRN = gnav_almanac[i_alm_satellite_slot_number - 1].d_n_A;
|
||||
|
||||
flag_almanac_str_15 = true;
|
||||
}
|
||||
|
@ -59,21 +59,21 @@ public:
|
||||
|
||||
template <class Archive>
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the almanac data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the almanac data on disk file.
|
||||
*/
|
||||
void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("valid", valid);
|
||||
archive& make_nvp("d_tau_c", d_tau_c);
|
||||
archive& make_nvp("d_tau_gps", d_tau_gps);
|
||||
archive& make_nvp("d_N_4", d_N_4);
|
||||
archive& make_nvp("d_N_A", d_N_A);
|
||||
archive& make_nvp("d_B1", d_B1);
|
||||
archive& make_nvp("d_B2", d_B2);
|
||||
archive& BOOST_SERIALIZATION_NVP(valid);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_tau_c);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_tau_gps);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_N_4);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_N_A);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_B1);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_B2);
|
||||
}
|
||||
};
|
||||
|
||||
|
253
src/core/system_parameters/gnss_ephemeris.cc
Normal file
253
src/core/system_parameters/gnss_ephemeris.cc
Normal file
@ -0,0 +1,253 @@
|
||||
/*!
|
||||
* \file gnss_ephemeris.cc
|
||||
* \brief Base class for GNSS Ephemeris
|
||||
* \author Carles Fernandez, 2021. cfernandez(at)cttc.es
|
||||
*
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*
|
||||
* GNSS-SDR is a Global Navigation Satellite System software-defined receiver.
|
||||
* This file is part of GNSS-SDR.
|
||||
*
|
||||
* Copyright (C) 2010-2021 (see AUTHORS file for a list of contributors)
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#include "gnss_ephemeris.h"
|
||||
#include "MATH_CONSTANTS.h"
|
||||
#include <cmath>
|
||||
|
||||
|
||||
void Gnss_Ephemeris::satellitePosition(double transmitTime)
|
||||
{
|
||||
// Restore semi-major axis
|
||||
const double a = this->sqrtA * this->sqrtA;
|
||||
|
||||
// Computed mean motion
|
||||
double n0;
|
||||
if (this->System == 'E')
|
||||
{
|
||||
n0 = sqrt(GALILEO_GM / (a * a * a));
|
||||
}
|
||||
else if (this->System == 'B')
|
||||
{
|
||||
n0 = sqrt(BEIDOU_GM / (a * a * a));
|
||||
}
|
||||
else
|
||||
{
|
||||
n0 = sqrt(GPS_GM / (a * a * a));
|
||||
}
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
double tk = check_t(transmitTime - static_cast<double>(this->toe));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + this->delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
double M = this->M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + this->ecc * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
const double sek = sin(E);
|
||||
const double cek = cos(E);
|
||||
const double OneMinusecosE = 1.0 - this->ecc * cek;
|
||||
const double sq1e2 = sqrt(1.0 - this->ecc * this->ecc);
|
||||
const double ekdot = n / OneMinusecosE;
|
||||
|
||||
// Compute the true anomaly
|
||||
const double tmp_Y = sq1e2 * sek;
|
||||
const double tmp_X = cek - this->ecc;
|
||||
const double nu = atan2(tmp_Y, tmp_X);
|
||||
|
||||
// Compute angle phi (argument of Latitude)
|
||||
double phi = nu + this->omega;
|
||||
|
||||
// Reduce phi to between 0 and 2*pi rad
|
||||
phi = fmod((phi), (2.0 * GNSS_PI));
|
||||
const double s2pk = sin(2.0 * phi);
|
||||
const double c2pk = cos(2.0 * phi);
|
||||
const double pkdot = sq1e2 * ekdot / OneMinusecosE;
|
||||
|
||||
// Correct argument of latitude
|
||||
const double u = phi + this->Cuc * c2pk + this->Cus * s2pk;
|
||||
const double suk = sin(u);
|
||||
const double cuk = cos(u);
|
||||
const double ukdot = pkdot * (1.0 + 2.0 * (this->Cus * c2pk - this->Cuc * s2pk));
|
||||
|
||||
// Correct radius
|
||||
const double r = a * OneMinusecosE + this->Crc * c2pk + this->Crs * s2pk;
|
||||
const double rkdot = a * this->ecc * sek * ekdot + 2.0 * pkdot * (this->Crs * c2pk - this->Crc * s2pk);
|
||||
|
||||
// Correct inclination
|
||||
const double i = this->i_0 + this->idot * tk + this->Cic * c2pk + this->Cis * s2pk;
|
||||
const double sik = sin(i);
|
||||
const double cik = cos(i);
|
||||
const double ikdot = this->idot + 2.0 * pkdot * (this->Cis * c2pk - this->Cic * s2pk);
|
||||
|
||||
// Compute the angle between the ascending node and the Greenwich meridian
|
||||
double Omega;
|
||||
double Omega_dot;
|
||||
if (this->System == 'B')
|
||||
{
|
||||
Omega_dot = this->OMEGAdot - BEIDOU_OMEGA_EARTH_DOT;
|
||||
Omega = this->OMEGA_0 + Omega_dot * tk - BEIDOU_OMEGA_EARTH_DOT * static_cast<double>(this->toe);
|
||||
}
|
||||
else
|
||||
{
|
||||
Omega_dot = this->OMEGAdot - GNSS_OMEGA_EARTH_DOT;
|
||||
Omega = this->OMEGA_0 + Omega_dot * tk - GNSS_OMEGA_EARTH_DOT * static_cast<double>(this->toe);
|
||||
}
|
||||
|
||||
// Reduce to between 0 and 2*pi rad
|
||||
Omega = fmod((Omega + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
const double sok = sin(Omega);
|
||||
const double cok = cos(Omega);
|
||||
|
||||
// --- Compute satellite coordinates in Earth-fixed coordinates
|
||||
const double xprime = r * cuk;
|
||||
const double yprime = r * suk;
|
||||
this->satpos_X = xprime * cok - yprime * cik * sok;
|
||||
this->satpos_Y = xprime * sok + yprime * cik * cok; // ********NOTE: in GALILEO ICD this expression is not correct because it has minus (- sin(u) * r * cos(i) * cos(Omega)) instead of plus
|
||||
this->satpos_Z = yprime * sik;
|
||||
|
||||
// Satellite's velocity. Can be useful for Vector Tracking loops
|
||||
const double xpkdot = rkdot * cuk - yprime * ukdot;
|
||||
const double ypkdot = rkdot * suk + xprime * ukdot;
|
||||
const double tmp = ypkdot * cik - this->satpos_Z * ikdot;
|
||||
|
||||
this->satvel_X = -Omega_dot * this->satpos_Y + xpkdot * cok - tmp * sok;
|
||||
this->satvel_Y = Omega_dot * this->satpos_X + xpkdot * sok + tmp * cok;
|
||||
this->satvel_Z = yprime * cik * ikdot + ypkdot * sik;
|
||||
|
||||
// Time from ephemeris reference clock
|
||||
tk = check_t(transmitTime - this->toc);
|
||||
|
||||
this->dtr = this->af0 + this->af1 * tk + this->af2 * tk * tk;
|
||||
|
||||
if (this->System == 'E')
|
||||
{
|
||||
this->dtr -= 2.0 * sqrt(GALILEO_GM * a) * this->ecc * sek / (SPEED_OF_LIGHT_M_S * SPEED_OF_LIGHT_M_S);
|
||||
}
|
||||
else if (this->System == 'B')
|
||||
{
|
||||
this->dtr -= 2.0 * sqrt(BEIDOU_GM * a) * this->ecc * sek / (SPEED_OF_LIGHT_M_S * SPEED_OF_LIGHT_M_S);
|
||||
}
|
||||
else
|
||||
{
|
||||
this->dtr -= 2.0 * sqrt(GPS_GM * a) * this->ecc * sek / (SPEED_OF_LIGHT_M_S * SPEED_OF_LIGHT_M_S);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
double Gnss_Ephemeris::sv_clock_drift(double transmitTime)
|
||||
{
|
||||
const double dt = check_t(transmitTime - this->toc);
|
||||
this->dtr = sv_clock_relativistic_term(transmitTime);
|
||||
this->satClkDrift = this->af0 + this->af1 * dt + this->af2 * (dt * dt) + this->dtr;
|
||||
return this->satClkDrift;
|
||||
}
|
||||
|
||||
|
||||
double Gnss_Ephemeris::sv_clock_relativistic_term(double transmitTime) const
|
||||
{
|
||||
// Restore semi-major axis
|
||||
const double a = this->sqrtA * this->sqrtA;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
const double tk = check_t(transmitTime - this->toe);
|
||||
|
||||
// Computed mean motion
|
||||
double n0;
|
||||
if (this->System == 'E')
|
||||
{
|
||||
n0 = sqrt(GALILEO_GM / (a * a * a));
|
||||
}
|
||||
if (this->System == 'E')
|
||||
{
|
||||
n0 = sqrt(BEIDOU_GM / (a * a * a));
|
||||
}
|
||||
else
|
||||
{
|
||||
n0 = sqrt(GPS_GM / (a * a * a));
|
||||
}
|
||||
// Corrected mean motion
|
||||
const double n = n0 + this->delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
const double M = this->M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
// M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
// --- Iteratively compute eccentric anomaly ----------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + this->ecc * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
const double sek = sin(E);
|
||||
|
||||
// Compute relativistic correction term
|
||||
double dtr_;
|
||||
if (this->System == 'E')
|
||||
{
|
||||
dtr_ = GALILEO_F * this->ecc * this->sqrtA * sek;
|
||||
}
|
||||
if (this->System == 'B')
|
||||
{
|
||||
dtr_ = BEIDOU_F * this->ecc * this->sqrtA * sek;
|
||||
}
|
||||
else
|
||||
{
|
||||
dtr_ = GPS_F * this->ecc * this->sqrtA * sek;
|
||||
}
|
||||
return dtr_;
|
||||
}
|
||||
|
||||
|
||||
double Gnss_Ephemeris::check_t(double time) const
|
||||
{
|
||||
const double half_week = 302400.0; // seconds
|
||||
double corrTime = time;
|
||||
if (time > half_week)
|
||||
{
|
||||
corrTime = time - 2.0 * half_week;
|
||||
}
|
||||
else if (time < -half_week)
|
||||
{
|
||||
corrTime = time + 2.0 * half_week;
|
||||
}
|
||||
return corrTime;
|
||||
}
|
90
src/core/system_parameters/gnss_ephemeris.h
Normal file
90
src/core/system_parameters/gnss_ephemeris.h
Normal file
@ -0,0 +1,90 @@
|
||||
/*!
|
||||
* \file gnss_ephemeris.h
|
||||
* \brief Base class for GNSS Ephemeris
|
||||
* \author Carles Fernandez, 2021. cfernandez(at)cttc.es
|
||||
*
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*
|
||||
* GNSS-SDR is a Global Navigation Satellite System software-defined receiver.
|
||||
* This file is part of GNSS-SDR.
|
||||
*
|
||||
* Copyright (C) 2010-2021 (see AUTHORS file for a list of contributors)
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
|
||||
#ifndef GNSS_SDR_GNSS_EPHEMERIS_H
|
||||
#define GNSS_SDR_GNSS_EPHEMERIS_H
|
||||
|
||||
#include <cstdint>
|
||||
|
||||
/*!
|
||||
* \brief Base class for GNSS ephemeris storage
|
||||
*/
|
||||
class Gnss_Ephemeris
|
||||
{
|
||||
public:
|
||||
Gnss_Ephemeris() = default;
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a satClkDrift) and (\a dtr), and returns the clock drift in
|
||||
* seconds according to the User Algorithm for SV Clock Correction
|
||||
* (IS-GPS-200L, 20.3.3.3.3.1, and Galileo OS SIS ICD, 5.1.4).
|
||||
*/
|
||||
double sv_clock_drift(double transmitTime);
|
||||
|
||||
void satellitePosition(double transmitTime); //!< Computes the ECEF SV coordinates and ECEF velocity
|
||||
|
||||
uint32_t PRN{}; //!< SV ID
|
||||
double M_0{}; //!< Mean anomaly at reference time [semi-circles]
|
||||
double delta_n{}; //!< Mean motion difference from computed value [semi-circles/sec]
|
||||
double ecc{}; //!< Eccentricity
|
||||
double sqrtA{}; //!< Square root of the semi-major axis [meters^1/2]
|
||||
double OMEGA_0{}; //!< Longitude of ascending node of orbital plane at weekly epoch [semi-circles]
|
||||
double i_0{}; //!< Inclination angle at reference time [semi-circles]
|
||||
double omega{}; //!< Argument of perigee [semi-circles]
|
||||
double OMEGAdot{}; //!< Rate of right ascension [semi-circles/sec]
|
||||
double idot{}; //!< Rate of inclination angle [semi-circles/sec]
|
||||
double Cuc{}; //!< Amplitude of the cosine harmonic correction term to the argument of latitude [radians]
|
||||
double Cus{}; //!< Amplitude of the sine harmonic correction term to the argument of latitude [radians]
|
||||
double Crc{}; //!< Amplitude of the cosine harmonic correction term to the orbit radius [meters]
|
||||
double Crs{}; //!< Amplitude of the sine harmonic correction term to the orbit radius [meters]
|
||||
double Cic{}; //!< Amplitude of the cosine harmonic correction term to the angle of inclination [radians]
|
||||
double Cis{}; //!< Amplitude of the sine harmonic correction term to the angle of inclination [radians]
|
||||
int32_t toe{}; //!< Ephemeris reference time [s]
|
||||
|
||||
// Clock correction parameters
|
||||
int32_t toc{}; //!< Clock correction data reference Time of Week [sec]
|
||||
double af0{}; //!< SV clock bias correction coefficient [s]
|
||||
double af1{}; //!< SV clock drift correction coefficient [s/s]
|
||||
double af2{}; //!< SV clock drift rate correction coefficient [s/s^2]
|
||||
|
||||
double satClkDrift{}; //!< SV clock drift
|
||||
double dtr{}; //!< Relativistic clock correction term
|
||||
|
||||
// Time
|
||||
int32_t WN{}; //!< Week number
|
||||
int32_t tow{}; //!< Time of Week
|
||||
|
||||
// satellite positions
|
||||
double satpos_X{}; //!< Earth-fixed coordinate x of the satellite [m]. Intersection of the IERS Reference Meridian (IRM) and the plane passing through the origin and normal to the Z-axis.
|
||||
double satpos_Y{}; //!< Earth-fixed coordinate y of the satellite [m]. Completes a right-handed, Earth-Centered, Earth-Fixed orthogonal coordinate system.
|
||||
double satpos_Z{}; //!< Earth-fixed coordinate z of the satellite [m]. The direction of the IERS (International Earth Rotation and Reference Systems Service) Reference Pole (IRP).
|
||||
|
||||
// Satellite velocity
|
||||
double satvel_X{}; //!< Earth-fixed velocity coordinate x of the satellite [m]
|
||||
double satvel_Y{}; //!< Earth-fixed velocity coordinate y of the satellite [m]
|
||||
double satvel_Z{}; //!< Earth-fixed velocity coordinate z of the satellite [m]
|
||||
|
||||
protected:
|
||||
char System{}; //!< Character ID of the GNSS system. 'G': GPS. 'E': Galileo. 'B': BeiDou
|
||||
|
||||
private:
|
||||
double check_t(double time) const;
|
||||
double sv_clock_relativistic_term(double transmitTime) const;
|
||||
};
|
||||
|
||||
#endif // GNSS_SDR_GNSS_EPHEMERIS_H
|
@ -42,10 +42,10 @@ public:
|
||||
*/
|
||||
Gps_Acq_Assist() = default;
|
||||
|
||||
uint32_t i_satellite_PRN{}; //!< SV PRN NUMBER
|
||||
double d_TOW{}; //!< Time Of Week assigned to the acquisition data
|
||||
double d_Doppler0{}; //!< Doppler (0 order term) [Hz]
|
||||
double d_Doppler1{}; //!< Doppler (1 order term) [Hz]
|
||||
uint32_t PRN{}; //!< SV PRN NUMBER
|
||||
double tow{}; //!< Time Of Week assigned to the acquisition data
|
||||
double Doppler0{}; //!< Doppler (0 order term) [Hz]
|
||||
double Doppler1{}; //!< Doppler (1 order term) [Hz]
|
||||
double dopplerUncertainty{}; //!< Doppler Uncertainty [Hz]
|
||||
double Code_Phase{}; //!< Code phase [chips]
|
||||
double Code_Phase_int{}; //!< Integer Code Phase [1 C/A code period]
|
||||
|
@ -40,20 +40,20 @@ public:
|
||||
*/
|
||||
Gps_Almanac() = default;
|
||||
|
||||
uint32_t i_satellite_PRN{}; //!< SV PRN NUMBER
|
||||
double d_Delta_i{}; //!< Inclination Angle at Reference Time (relative to i_0 = 0.30 semi-circles)
|
||||
int32_t i_Toa{}; //!< Almanac data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
int32_t i_WNa{}; //!< Almanac week number
|
||||
double d_M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double d_e_eccentricity{}; //!< Eccentricity [dimensionless]
|
||||
double d_sqrt_A{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
double d_OMEGA0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double d_OMEGA{}; //!< Argument of Perigee [semi-cicles]
|
||||
double d_OMEGA_DOT{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
int32_t i_SV_health{}; //!< SV Health
|
||||
int32_t i_AS_status{}; //!< Anti-Spoofing Flags and SV Configuration
|
||||
double d_A_f0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double d_A_f1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
uint32_t PRN{}; //!< SV PRN NUMBER
|
||||
double delta_i{}; //!< Inclination Angle at Reference Time (relative to i_0 = 0.30 semi-circles)
|
||||
int32_t toa{}; //!< Almanac data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
int32_t WNa{}; //!< Almanac week number
|
||||
double M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double ecc{}; //!< Eccentricity [dimensionless]
|
||||
double sqrtA{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
double OMEGA_0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double omega{}; //!< Argument of Perigee [semi-cicles]
|
||||
double OMEGAdot{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
int32_t SV_health{}; //!< SV Health
|
||||
int32_t AS_status{}; //!< Anti-Spoofing Flags and SV Configuration
|
||||
double af0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double af1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
|
||||
template <class Archive>
|
||||
|
||||
@ -62,20 +62,20 @@ public:
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
ar& BOOST_SERIALIZATION_NVP(i_satellite_PRN);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_Delta_i);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_Toa);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_WNa);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_M_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_e_eccentricity);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_sqrt_A);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_OMEGA_DOT);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_SV_health);
|
||||
ar& BOOST_SERIALIZATION_NVP(i_AS_status);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_A_f0);
|
||||
ar& BOOST_SERIALIZATION_NVP(d_A_f1);
|
||||
ar& BOOST_SERIALIZATION_NVP(PRN);
|
||||
ar& BOOST_SERIALIZATION_NVP(delta_i);
|
||||
ar& BOOST_SERIALIZATION_NVP(toa);
|
||||
ar& BOOST_SERIALIZATION_NVP(WNa);
|
||||
ar& BOOST_SERIALIZATION_NVP(M_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(ecc);
|
||||
ar& BOOST_SERIALIZATION_NVP(sqrtA);
|
||||
ar& BOOST_SERIALIZATION_NVP(OMEGA_0);
|
||||
ar& BOOST_SERIALIZATION_NVP(omega);
|
||||
ar& BOOST_SERIALIZATION_NVP(OMEGAdot);
|
||||
ar& BOOST_SERIALIZATION_NVP(SV_health);
|
||||
ar& BOOST_SERIALIZATION_NVP(AS_status);
|
||||
ar& BOOST_SERIALIZATION_NVP(af0);
|
||||
ar& BOOST_SERIALIZATION_NVP(af1);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -1,218 +0,0 @@
|
||||
/*!
|
||||
* \file gps_cnav_ephemeris.cc
|
||||
* \brief Interface of a GPS CNAV EPHEMERIS storage and orbital model functions
|
||||
*
|
||||
* See https://www.gps.gov/technical/icwg/IS-GPS-200L.pdf Appendix III
|
||||
* \author Javier Arribas, 2015. jarribas(at)cttc.es
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*
|
||||
* GNSS-SDR is a Global Navigation Satellite System software-defined receiver.
|
||||
* This file is part of GNSS-SDR.
|
||||
*
|
||||
* Copyright (C) 2010-2020 (see AUTHORS file for a list of contributors)
|
||||
* SPDX-License-Identifier: GPL-3.0-or-later
|
||||
*
|
||||
* -----------------------------------------------------------------------------
|
||||
*/
|
||||
|
||||
#include "gps_cnav_ephemeris.h"
|
||||
#include "MATH_CONSTANTS.h" // for GNSS_PI, SPEED_OF_LIGHT_M_S, F, GPS_GM
|
||||
#include <cmath>
|
||||
|
||||
|
||||
double Gps_CNAV_Ephemeris::check_t(double time)
|
||||
{
|
||||
const double half_week = 302400.0; // seconds
|
||||
double corrTime = time;
|
||||
if (time > half_week)
|
||||
{
|
||||
corrTime = time - 2.0 * half_week;
|
||||
}
|
||||
else if (time < -half_week)
|
||||
{
|
||||
corrTime = time + 2.0 * half_week;
|
||||
}
|
||||
return corrTime;
|
||||
}
|
||||
|
||||
|
||||
// 20.3.3.3.3.1 User Algorithm for SV Clock Correction.
|
||||
double Gps_CNAV_Ephemeris::sv_clock_drift(double transmitTime)
|
||||
{
|
||||
const double dt = check_t(transmitTime - d_Toc);
|
||||
d_satClkDrift = d_A_f0 + d_A_f1 * dt + d_A_f2 * (dt * dt) + sv_clock_relativistic_term(transmitTime);
|
||||
|
||||
// Correct satellite group delay
|
||||
d_satClkDrift -= d_TGD;
|
||||
|
||||
return d_satClkDrift;
|
||||
}
|
||||
|
||||
|
||||
// compute the relativistic correction term
|
||||
double Gps_CNAV_Ephemeris::sv_clock_relativistic_term(double transmitTime)
|
||||
{
|
||||
const double A_REF = 26559710.0; // See IS-GPS-200L, pp. 161
|
||||
const double d_sqrt_A = sqrt(A_REF + d_DELTA_A);
|
||||
|
||||
// Restore semi-major axis
|
||||
const double a = d_sqrt_A * d_sqrt_A;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
const double tk = check_t(transmitTime - d_Toe1);
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(GPS_GM / (a * a * a));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + d_Delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
const double M = d_M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
// M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + d_e_eccentricity * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Compute relativistic correction term
|
||||
d_dtr = GPS_F * d_e_eccentricity * d_sqrt_A * sin(E);
|
||||
return d_dtr;
|
||||
}
|
||||
|
||||
|
||||
double Gps_CNAV_Ephemeris::satellitePosition(double transmitTime)
|
||||
{
|
||||
const double A_REF = 26559710.0; // See IS-GPS-200L, pp. 161
|
||||
const double OMEGA_DOT_REF = -2.6e-9; // semicircles / s, see IS-GPS-200L pp. 160
|
||||
|
||||
const double d_sqrt_A = sqrt(A_REF + d_DELTA_A);
|
||||
|
||||
// Find satellite's position -----------------------------------------------
|
||||
|
||||
// Restore semi-major axis
|
||||
const double a = d_sqrt_A * d_sqrt_A;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
double tk = check_t(transmitTime - d_Toe1);
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(GPS_GM / (a * a * a));
|
||||
|
||||
// Mean motion difference from computed value
|
||||
const double delta_n_a = d_Delta_n + 0.5 * d_DELTA_DOT_N * tk;
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + delta_n_a;
|
||||
|
||||
// Mean anomaly
|
||||
const double M = d_M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
// M = fmod((M + 2 * GNSS_PI), (2 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + d_e_eccentricity * sin(E);
|
||||
dE = fmod(E - E_old, 2 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
const double sek = sin(E);
|
||||
const double cek = cos(E);
|
||||
const double OneMinusecosE = 1.0 - d_e_eccentricity * cek;
|
||||
const double ekdot = n / OneMinusecosE;
|
||||
|
||||
// Compute the true anomaly
|
||||
const double sq1e2 = sqrt(1.0 - d_e_eccentricity * d_e_eccentricity);
|
||||
const double tmp_Y = sq1e2 * sek;
|
||||
const double tmp_X = cek - d_e_eccentricity;
|
||||
const double nu = atan2(tmp_Y, tmp_X);
|
||||
|
||||
// Compute angle phi (argument of Latitude)
|
||||
const double phi = nu + d_OMEGA;
|
||||
double pkdot = sq1e2 * ekdot / OneMinusecosE;
|
||||
|
||||
// Reduce phi to between 0 and 2*pi rad
|
||||
// phi = fmod((phi), (2.0 * GNSS_PI));
|
||||
const double s2pk = sin(2.0 * phi);
|
||||
const double c2pk = cos(2.0 * phi);
|
||||
|
||||
// Correct argument of latitude
|
||||
const double u = phi + d_Cuc * c2pk + d_Cus * s2pk;
|
||||
const double cuk = cos(u);
|
||||
const double suk = sin(u);
|
||||
const double ukdot = pkdot * (1.0 + 2.0 * (d_Cus * c2pk - d_Cuc * s2pk));
|
||||
|
||||
// Correct radius
|
||||
const double r = a * (1.0 - d_e_eccentricity * cek) + d_Crc * c2pk + d_Crs * s2pk;
|
||||
|
||||
const double rkdot = a * d_e_eccentricity * sek * ekdot + 2.0 * pkdot * (d_Crs * c2pk - d_Crc * s2pk);
|
||||
|
||||
// Correct inclination
|
||||
const double i = d_i_0 + d_IDOT * tk + d_Cic * c2pk + d_Cis * s2pk;
|
||||
const double sik = sin(i);
|
||||
const double cik = cos(i);
|
||||
const double ikdot = d_IDOT + 2.0 * pkdot * (d_Cis * c2pk - d_Cic * s2pk);
|
||||
|
||||
// Compute the angle between the ascending node and the Greenwich meridian
|
||||
const double d_OMEGA_DOT = OMEGA_DOT_REF * GNSS_PI + d_DELTA_OMEGA_DOT;
|
||||
const double Omega = d_OMEGA0 + (d_OMEGA_DOT - GNSS_OMEGA_EARTH_DOT) * tk - GNSS_OMEGA_EARTH_DOT * d_Toe1;
|
||||
const double sok = sin(Omega);
|
||||
const double cok = cos(Omega);
|
||||
|
||||
// Compute satellite coordinates in Earth-fixed coordinates
|
||||
const double xprime = r * cuk;
|
||||
const double yprime = r * suk;
|
||||
d_satpos_X = xprime * cok - yprime * cik * sok;
|
||||
d_satpos_Y = xprime * sok + yprime * cik * cok;
|
||||
d_satpos_Z = yprime * sik;
|
||||
|
||||
// Satellite's velocity. Can be useful for Vector Tracking loops
|
||||
const double Omega_dot = d_OMEGA_DOT - GNSS_OMEGA_EARTH_DOT;
|
||||
|
||||
const double xpkdot = rkdot * cuk - yprime * ukdot;
|
||||
const double ypkdot = rkdot * suk + xprime * ukdot;
|
||||
const double tmp = ypkdot * cik - d_satpos_Z * ikdot;
|
||||
|
||||
d_satvel_X = -Omega_dot * d_satpos_Y + xpkdot * cok - tmp * sok;
|
||||
d_satvel_Y = Omega_dot * d_satpos_X + xpkdot * sok + tmp * cok;
|
||||
d_satvel_Z = yprime * cik * ikdot + ypkdot * sik;
|
||||
|
||||
// Time from ephemeris reference clock
|
||||
tk = check_t(transmitTime - d_Toc);
|
||||
|
||||
double dtr_s = d_A_f0 + d_A_f1 * tk + d_A_f2 * tk * tk;
|
||||
|
||||
/* relativity correction */
|
||||
dtr_s -= 2.0 * sqrt(GPS_GM * a) * d_e_eccentricity * sek / (SPEED_OF_LIGHT_M_S * SPEED_OF_LIGHT_M_S);
|
||||
|
||||
return dtr_s;
|
||||
}
|
@ -18,6 +18,7 @@
|
||||
#ifndef GNSS_SDR_GPS_CNAV_EPHEMERIS_H
|
||||
#define GNSS_SDR_GPS_CNAV_EPHEMERIS_H
|
||||
|
||||
#include "gnss_ephemeris.h"
|
||||
#include <boost/serialization/nvp.hpp>
|
||||
#include <cstdint>
|
||||
|
||||
@ -28,115 +29,66 @@
|
||||
|
||||
|
||||
/*!
|
||||
* \brief This class is a storage and orbital model functions for the GPS SV ephemeris data as described in IS-GPS-200L
|
||||
* \brief This is a storage class for the GPS CNAV ephemeris data as described
|
||||
* in IS-GPS-200L
|
||||
*
|
||||
* See https://www.gps.gov/technical/icwg/IS-GPS-200L.pdf Appendix III
|
||||
*/
|
||||
class Gps_CNAV_Ephemeris
|
||||
class Gps_CNAV_Ephemeris : public Gnss_Ephemeris
|
||||
{
|
||||
public:
|
||||
/*!
|
||||
* Default constructor
|
||||
* Constructor
|
||||
*/
|
||||
Gps_CNAV_Ephemeris() = default;
|
||||
Gps_CNAV_Ephemeris()
|
||||
{
|
||||
this->System = 'G';
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Compute the ECEF SV coordinates and ECEF velocity
|
||||
* Implementation of Table 20-IV (IS-GPS-200L)
|
||||
*/
|
||||
double satellitePosition(double transmitTime);
|
||||
double deltaA{}; //!< Semi-major axis difference at reference time
|
||||
double Adot{}; //!< Change rate in semi-major axis
|
||||
double delta_ndot{}; //!< Rate of mean motion difference from computed value
|
||||
double delta_OMEGAdot{}; //!< Rate of Right Ascension difference [semi-circles/s]
|
||||
int32_t toe1{}; //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
int32_t toe2{}; //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
int32_t signal_health{}; //!< Signal health (L1/L2/L5)
|
||||
int32_t top{}; //!< Data predict time of week
|
||||
int32_t URA{}; //!< ED Accuracy Index
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a d_satClkDrift)and returns the clock drift in seconds according to the User Algorithm for SV Clock Correction
|
||||
* (IS-GPS-200L, 20.3.3.3.3.1)
|
||||
*/
|
||||
double sv_clock_drift(double transmitTime);
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a d_dtr) and returns the clock relativistic correction term in seconds according to the User Algorithm for SV Clock Correction
|
||||
* (IS-GPS-200L, 20.3.3.3.3.1)
|
||||
*/
|
||||
double sv_clock_relativistic_term(double transmitTime);
|
||||
|
||||
uint32_t i_satellite_PRN{}; // SV PRN NUMBER
|
||||
|
||||
// Message Types 10 and 11 Parameters (1 of 2)
|
||||
int32_t i_GPS_week{}; //!< GPS week number, aka WN [week]
|
||||
int32_t i_URA{}; //!< ED Accuracy Index
|
||||
int32_t i_signal_health{}; //!< Signal health (L1/L2/L5)
|
||||
int32_t d_Top{}; //!< Data predict time of week
|
||||
double d_DELTA_A{}; //!< Semi-major axis difference at reference time
|
||||
double d_A_DOT{}; //!< Change rate in semi-major axis
|
||||
double d_Delta_n{}; //!< Mean Motion Difference From Computed Value [semi-circles/s]
|
||||
double d_DELTA_DOT_N{}; //!< Rate of mean motion difference from computed value
|
||||
double d_M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double d_e_eccentricity{}; //!< Eccentricity
|
||||
double d_OMEGA{}; //!< Argument of Perigee [semi-cicles]
|
||||
double d_OMEGA0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-cicles]
|
||||
int32_t d_Toe1{}; //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
int32_t d_Toe2{}; //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
double d_DELTA_OMEGA_DOT{}; //!< Rate of Right Ascension difference [semi-circles/s]
|
||||
double d_i_0{}; //!< Inclination Angle at Reference Time [semi-circles]
|
||||
double d_IDOT{}; //!< Rate of Inclination Angle [semi-circles/s]
|
||||
double d_Cis{}; //!< Amplitude of the Sine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
double d_Cic{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
double d_Crs{}; //!< Amplitude of the Sine Harmonic Correction Term to the Orbit Radius [m]
|
||||
double d_Crc{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Orbit Radius [m]
|
||||
double d_Cus{}; //!< Amplitude of the Sine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
double d_Cuc{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
|
||||
// Clock Correction and Accuracy Parameters
|
||||
int32_t d_Toc{}; //!< clock data reference time (Ref. 20.3.3.3.3.1 IS-GPS-200L) [s]
|
||||
double d_A_f0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double d_A_f1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
double d_A_f2{}; //!< Coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
double d_URA0{}; //!< NED Accuracy Index
|
||||
double d_URA1{}; //!< NED Accuracy Change Index
|
||||
double d_URA2{}; //!< NED Accuracy Change Rate Index
|
||||
double URA0{}; //!< NED Accuracy Index
|
||||
double URA1{}; //!< NED Accuracy Change Index
|
||||
double URA2{}; //!< NED Accuracy Change Rate Index
|
||||
|
||||
// Group Delay Differential Parameters
|
||||
double d_TGD{}; //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
double d_ISCL1{};
|
||||
double d_ISCL2{};
|
||||
double d_ISCL5I{};
|
||||
double d_ISCL5Q{};
|
||||
|
||||
int32_t d_TOW{}; //!< Time of GPS Week of the ephemeris set (taken from subframes TOW) [s]
|
||||
|
||||
// clock terms derived from ephemeris data
|
||||
double d_satClkDrift{}; //!< GPS clock error
|
||||
double d_dtr{}; //!< relativistic clock correction term
|
||||
|
||||
// satellite positions
|
||||
double d_satpos_X{}; //!< Earth-fixed coordinate x of the satellite [m]. Intersection of the IERS Reference Meridian (IRM) and the plane passing through the origin and normal to the Z-axis.
|
||||
double d_satpos_Y{}; //!< Earth-fixed coordinate y of the satellite [m]. Completes a right-handed, Earth-Centered, Earth-Fixed orthogonal coordinate system.
|
||||
double d_satpos_Z{}; //!< Earth-fixed coordinate z of the satellite [m]. The direction of the IERS (International Earth Rotation and Reference Systems Service) Reference Pole (IRP).
|
||||
|
||||
// Satellite velocity
|
||||
double d_satvel_X{}; //!< Earth-fixed velocity coordinate x of the satellite [m]
|
||||
double d_satvel_Y{}; //!< Earth-fixed velocity coordinate y of the satellite [m]
|
||||
double d_satvel_Z{}; //!< Earth-fixed velocity coordinate z of the satellite [m]
|
||||
double TGD{}; //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
double ISCL1{};
|
||||
double ISCL2{};
|
||||
double ISCL5I{};
|
||||
double ISCL5Q{};
|
||||
|
||||
/*! \brief If true, enhanced level of integrity assurance.
|
||||
*
|
||||
* If false, indicates that the conveying signal is provided with the legacy level of integrity assurance.
|
||||
* That is, the probability that the instantaneous URE of the conveying signal exceeds 4.42 times the upper bound
|
||||
* value of the current broadcast URA index, for more than 5.2 seconds, without an accompanying alert, is less
|
||||
* than 1E-5 per hour. If true, indicates that the conveying signal is provided with an enhanced level of
|
||||
* integrity assurance. That is, the probability that the instantaneous URE of the conveying signal exceeds 5.73
|
||||
* times the upper bound value of the current broadcast URA index, for more than 5.2 seconds, without an
|
||||
* accompanying alert, is less than 1E-8 per hour.
|
||||
* If false, indicates that the conveying signal is provided with the
|
||||
* legacy level of integrity assurance. That is, the probability that the
|
||||
* instantaneous URE of the conveying signal exceeds 4.42 times the upper
|
||||
* bound value of the current broadcast URA index, for more than 5.2
|
||||
* seconds, without an accompanying alert, is less than 1E-5 per hour. If
|
||||
* true, indicates that the conveying signal is provided with an enhanced
|
||||
* level of integrity assurance. That is, the probability that the
|
||||
* instantaneous URE of the conveying signal exceeds 5.73 times the upper
|
||||
* bound value of the current broadcast URA index, for more than 5.2
|
||||
* seconds, without an accompanying alert, is less than 1E-8 per hour.
|
||||
*/
|
||||
bool b_integrity_status_flag{};
|
||||
bool b_l2c_phasing_flag{};
|
||||
bool b_alert_flag{}; //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
bool b_antispoofing_flag{}; //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
bool b_alert_flag{}; //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
bool b_antispoofing_flag{}; //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
@ -145,44 +97,46 @@ public:
|
||||
{
|
||||
};
|
||||
|
||||
archive& make_nvp("i_satellite_PRN", i_satellite_PRN); // SV PRN NUMBER
|
||||
archive& make_nvp("d_TOW", d_TOW); //!< Time of GPS Week of the ephemeris set (taken from subframes TOW) [s]
|
||||
archive& make_nvp("d_Crs", d_Crs); //!< Amplitude of the Sine Harmonic Correction Term to the Orbit Radius [m]
|
||||
archive& make_nvp("d_M_0", d_M_0); //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
archive& make_nvp("d_Cuc", d_Cuc); //!< Amplitude of the Cosine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
archive& make_nvp("d_e_eccentricity", d_e_eccentricity); //!< Eccentricity [dimensionless]
|
||||
archive& make_nvp("d_Cus", d_Cus); //!< Amplitude of the Sine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
archive& make_nvp("d_Toe1", d_Toe1); //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
archive& make_nvp("d_Toe2", d_Toe2); //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
archive& make_nvp("d_Toc", d_Toc); //!< clock data reference time (Ref. 20.3.3.3.3.1 IS-GPS-200L) [s]
|
||||
archive& make_nvp("d_Cic", d_Cic); //!< Amplitude of the Cosine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
archive& make_nvp("d_OMEGA0", d_OMEGA0); //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
archive& make_nvp("d_Cis", d_Cis); //!< Amplitude of the Sine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
archive& make_nvp("d_i_0", d_i_0); //!< Inclination Angle at Reference Time [semi-circles]
|
||||
archive& make_nvp("d_Crc", d_Crc); //!< Amplitude of the Cosine Harmonic Correction Term to the Orbit Radius [m]
|
||||
archive& make_nvp("d_OMEGA", d_OMEGA); //!< Argument of Perigee [semi-cicles]
|
||||
archive& make_nvp("d_IDOT", d_IDOT); //!< Rate of Inclination Angle [semi-circles/s]
|
||||
archive& make_nvp("i_GPS_week", i_GPS_week); //!< GPS week number, aka WN [week]
|
||||
archive& make_nvp("d_TGD", d_TGD); //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& make_nvp("d_ISCL1", d_ISCL1); //!< Estimated Group Delay Differential: L1P(Y)-L1C/A correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& make_nvp("d_ISCL2", d_ISCL2); //!< Estimated Group Delay Differential: L1P(Y)-L2C correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& make_nvp("d_ISCL5I", d_ISCL5I); //!< Estimated Group Delay Differential: L1P(Y)-L5i correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& make_nvp("d_ISCL5Q", d_ISCL5Q); //!< Estimated Group Delay Differential: L1P(Y)-L5q correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& BOOST_SERIALIZATION_NVP(PRN);
|
||||
archive& BOOST_SERIALIZATION_NVP(M_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(delta_n);
|
||||
archive& BOOST_SERIALIZATION_NVP(ecc);
|
||||
archive& BOOST_SERIALIZATION_NVP(sqrtA);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGA_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(omega);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGAdot);
|
||||
archive& BOOST_SERIALIZATION_NVP(idot);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cuc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cus);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crs);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cic);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cis);
|
||||
archive& BOOST_SERIALIZATION_NVP(toe);
|
||||
archive& BOOST_SERIALIZATION_NVP(toc);
|
||||
archive& BOOST_SERIALIZATION_NVP(af0);
|
||||
archive& BOOST_SERIALIZATION_NVP(af1);
|
||||
archive& BOOST_SERIALIZATION_NVP(af2);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN);
|
||||
archive& BOOST_SERIALIZATION_NVP(tow);
|
||||
archive& BOOST_SERIALIZATION_NVP(satClkDrift);
|
||||
archive& BOOST_SERIALIZATION_NVP(dtr);
|
||||
|
||||
archive& make_nvp("d_DELTA_A", d_DELTA_A); //!< Semi-major axis difference at reference time [m]
|
||||
archive& make_nvp("d_A_DOT", d_A_DOT); //!< Change rate in semi-major axis [m/s]
|
||||
archive& make_nvp("d_DELTA_OMEGA_DOT", d_DELTA_OMEGA_DOT); //!< Rate of Right Ascension difference [semi-circles/s]
|
||||
archive& make_nvp("d_A_f0", d_A_f0); //!< Coefficient 0 of code phase offset model [s]
|
||||
archive& make_nvp("d_A_f1", d_A_f1); //!< Coefficient 1 of code phase offset model [s/s]
|
||||
archive& make_nvp("d_A_f2", d_A_f2); //!< Coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
archive& make_nvp("b_integrity_status_flag", b_integrity_status_flag);
|
||||
archive& make_nvp("b_alert_flag", b_alert_flag); //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
archive& make_nvp("b_antispoofing_flag", b_antispoofing_flag); //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
archive& BOOST_SERIALIZATION_NVP(toe1);
|
||||
archive& BOOST_SERIALIZATION_NVP(toe2);
|
||||
archive& BOOST_SERIALIZATION_NVP(TGD);
|
||||
archive& BOOST_SERIALIZATION_NVP(ISCL1);
|
||||
archive& BOOST_SERIALIZATION_NVP(ISCL2);
|
||||
archive& BOOST_SERIALIZATION_NVP(ISCL5I);
|
||||
archive& BOOST_SERIALIZATION_NVP(ISCL5Q);
|
||||
archive& BOOST_SERIALIZATION_NVP(deltaA);
|
||||
archive& BOOST_SERIALIZATION_NVP(Adot);
|
||||
archive& BOOST_SERIALIZATION_NVP(delta_OMEGAdot);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_integrity_status_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_alert_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_antispoofing_flag);
|
||||
}
|
||||
|
||||
private:
|
||||
double check_t(double time);
|
||||
};
|
||||
|
||||
|
||||
|
@ -38,35 +38,35 @@ public:
|
||||
Gps_CNAV_Iono() = default; //!< Default constructor
|
||||
|
||||
// Ionospheric parameters
|
||||
double d_alpha0{}; //!< Coefficient 0 of a cubic equation representing the amplitude of the vertical delay [s]
|
||||
double d_alpha1{}; //!< Coefficient 1 of a cubic equation representing the amplitude of the vertical delay [s/semi-circle]
|
||||
double d_alpha2{}; //!< Coefficient 2 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^2]
|
||||
double d_alpha3{}; //!< Coefficient 3 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^3]
|
||||
double d_beta0{}; //!< Coefficient 0 of a cubic equation representing the period of the model [s]
|
||||
double d_beta1{}; //!< Coefficient 1 of a cubic equation representing the period of the model [s/semi-circle]
|
||||
double d_beta2{}; //!< Coefficient 2 of a cubic equation representing the period of the model [s(semi-circle)^2]
|
||||
double d_beta3{}; //!< Coefficient 3 of a cubic equation representing the period of the model [s(semi-circle)^3]
|
||||
bool valid{}; //!< Valid flag
|
||||
double alpha0{}; //!< Coefficient 0 of a cubic equation representing the amplitude of the vertical delay [s]
|
||||
double alpha1{}; //!< Coefficient 1 of a cubic equation representing the amplitude of the vertical delay [s/semi-circle]
|
||||
double alpha2{}; //!< Coefficient 2 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^2]
|
||||
double alpha3{}; //!< Coefficient 3 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^3]
|
||||
double beta0{}; //!< Coefficient 0 of a cubic equation representing the period of the model [s]
|
||||
double beta1{}; //!< Coefficient 1 of a cubic equation representing the period of the model [s/semi-circle]
|
||||
double beta2{}; //!< Coefficient 2 of a cubic equation representing the period of the model [s(semi-circle)^2]
|
||||
double beta3{}; //!< Coefficient 3 of a cubic equation representing the period of the model [s(semi-circle)^3]
|
||||
bool valid{}; //!< Valid flag
|
||||
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const unsigned int version) const
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("d_alpha0", d_alpha0);
|
||||
archive& make_nvp("d_alpha1", d_alpha1);
|
||||
archive& make_nvp("d_alpha2", d_alpha2);
|
||||
archive& make_nvp("d_alpha3", d_alpha3);
|
||||
archive& make_nvp("d_beta0", d_beta0);
|
||||
archive& make_nvp("d_beta1", d_beta1);
|
||||
archive& make_nvp("d_beta2", d_beta2);
|
||||
archive& make_nvp("d_beta3", d_beta3);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha0);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha1);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha2);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha3);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta0);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta1);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta2);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta3);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -106,41 +106,43 @@ void Gps_CNAV_Navigation_Message::decode_page(std::bitset<GPS_CNAV_DATA_PAGE_BIT
|
||||
|
||||
// common to all messages
|
||||
const auto PRN = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_PRN));
|
||||
ephemeris_record.i_satellite_PRN = PRN;
|
||||
ephemeris_record.PRN = PRN;
|
||||
|
||||
d_TOW = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOW));
|
||||
d_TOW *= CNAV_TOW_LSB;
|
||||
ephemeris_record.d_TOW = d_TOW;
|
||||
ephemeris_record.tow = d_TOW;
|
||||
|
||||
alert_flag = static_cast<bool>(read_navigation_bool(data_bits, CNAV_ALERT_FLAG));
|
||||
ephemeris_record.b_alert_flag = alert_flag;
|
||||
|
||||
page_type = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_MSG_TYPE));
|
||||
|
||||
|
||||
switch (page_type)
|
||||
{
|
||||
case 10: // Ephemeris 1/2
|
||||
ephemeris_record.i_GPS_week = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_WN));
|
||||
ephemeris_record.i_signal_health = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_HEALTH));
|
||||
ephemeris_record.d_Top = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOP1));
|
||||
ephemeris_record.d_Top *= CNAV_TOP1_LSB;
|
||||
ephemeris_record.d_URA0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_URA));
|
||||
ephemeris_record.d_Toe1 = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOE1));
|
||||
ephemeris_record.d_Toe1 *= CNAV_TOE1_LSB;
|
||||
ephemeris_record.d_DELTA_A = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_A));
|
||||
ephemeris_record.d_DELTA_A *= CNAV_DELTA_A_LSB;
|
||||
ephemeris_record.d_A_DOT = static_cast<double>(read_navigation_signed(data_bits, CNAV_A_DOT));
|
||||
ephemeris_record.d_A_DOT *= CNAV_A_DOT_LSB;
|
||||
ephemeris_record.d_Delta_n = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_N0));
|
||||
ephemeris_record.d_Delta_n *= CNAV_DELTA_N0_LSB;
|
||||
ephemeris_record.d_DELTA_DOT_N = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_N0_DOT));
|
||||
ephemeris_record.d_DELTA_DOT_N *= CNAV_DELTA_N0_DOT_LSB;
|
||||
ephemeris_record.d_M_0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_M0));
|
||||
ephemeris_record.d_M_0 *= CNAV_M0_LSB;
|
||||
ephemeris_record.d_e_eccentricity = static_cast<double>(read_navigation_unsigned(data_bits, CNAV_E_ECCENTRICITY));
|
||||
ephemeris_record.d_e_eccentricity *= CNAV_E_ECCENTRICITY_LSB;
|
||||
ephemeris_record.d_OMEGA = static_cast<double>(read_navigation_signed(data_bits, CNAV_OMEGA));
|
||||
ephemeris_record.d_OMEGA *= CNAV_OMEGA_LSB;
|
||||
ephemeris_record.WN = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_WN));
|
||||
ephemeris_record.signal_health = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_HEALTH));
|
||||
ephemeris_record.top = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOP1));
|
||||
ephemeris_record.top *= CNAV_TOP1_LSB;
|
||||
ephemeris_record.URA0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_URA));
|
||||
ephemeris_record.toe1 = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOE1));
|
||||
ephemeris_record.toe1 *= CNAV_TOE1_LSB;
|
||||
ephemeris_record.deltaA = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_A));
|
||||
ephemeris_record.deltaA *= CNAV_DELTA_A_LSB;
|
||||
ephemeris_record.Adot = static_cast<double>(read_navigation_signed(data_bits, CNAV_A_DOT));
|
||||
ephemeris_record.Adot *= CNAV_A_DOT_LSB;
|
||||
ephemeris_record.sqrtA = sqrt(CNAV_A_REF + ephemeris_record.deltaA);
|
||||
ephemeris_record.delta_n = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_N0));
|
||||
ephemeris_record.delta_n *= CNAV_DELTA_N0_LSB;
|
||||
ephemeris_record.delta_ndot = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_N0_DOT));
|
||||
ephemeris_record.delta_ndot *= CNAV_DELTA_N0_DOT_LSB;
|
||||
ephemeris_record.M_0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_M0));
|
||||
ephemeris_record.M_0 *= CNAV_M0_LSB;
|
||||
ephemeris_record.ecc = static_cast<double>(read_navigation_unsigned(data_bits, CNAV_E_ECCENTRICITY));
|
||||
ephemeris_record.ecc *= CNAV_E_ECCENTRICITY_LSB;
|
||||
ephemeris_record.omega = static_cast<double>(read_navigation_signed(data_bits, CNAV_OMEGA));
|
||||
ephemeris_record.omega *= CNAV_OMEGA_LSB;
|
||||
|
||||
ephemeris_record.b_integrity_status_flag = static_cast<bool>(read_navigation_bool(data_bits, CNAV_INTEGRITY_FLAG));
|
||||
ephemeris_record.b_l2c_phasing_flag = static_cast<bool>(read_navigation_bool(data_bits, CNAV_L2_PHASING_FLAG));
|
||||
@ -148,135 +150,136 @@ void Gps_CNAV_Navigation_Message::decode_page(std::bitset<GPS_CNAV_DATA_PAGE_BIT
|
||||
b_flag_ephemeris_1 = true;
|
||||
break;
|
||||
case 11: // Ephemeris 2/2
|
||||
ephemeris_record.d_Toe2 = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOE2));
|
||||
ephemeris_record.d_Toe2 *= CNAV_TOE2_LSB;
|
||||
ephemeris_record.d_OMEGA0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_OMEGA0));
|
||||
ephemeris_record.d_OMEGA0 *= CNAV_OMEGA0_LSB;
|
||||
ephemeris_record.d_DELTA_OMEGA_DOT = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_OMEGA_DOT));
|
||||
ephemeris_record.d_DELTA_OMEGA_DOT *= CNAV_DELTA_OMEGA_DOT_LSB;
|
||||
ephemeris_record.d_i_0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_I0));
|
||||
ephemeris_record.d_i_0 *= CNAV_I0_LSB;
|
||||
ephemeris_record.d_IDOT = static_cast<double>(read_navigation_signed(data_bits, CNAV_I0_DOT));
|
||||
ephemeris_record.d_IDOT *= CNAV_I0_DOT_LSB;
|
||||
ephemeris_record.d_Cis = static_cast<double>(read_navigation_signed(data_bits, CNAV_CIS));
|
||||
ephemeris_record.d_Cis *= CNAV_CIS_LSB;
|
||||
ephemeris_record.d_Cic = static_cast<double>(read_navigation_signed(data_bits, CNAV_CIC));
|
||||
ephemeris_record.d_Cic *= CNAV_CIC_LSB;
|
||||
ephemeris_record.d_Crs = static_cast<double>(read_navigation_signed(data_bits, CNAV_CRS));
|
||||
ephemeris_record.d_Crs *= CNAV_CRS_LSB;
|
||||
ephemeris_record.d_Crc = static_cast<double>(read_navigation_signed(data_bits, CNAV_CRC));
|
||||
ephemeris_record.d_Crc *= CNAV_CRC_LSB;
|
||||
ephemeris_record.d_Cus = static_cast<double>(read_navigation_signed(data_bits, CNAV_CUS));
|
||||
ephemeris_record.d_Cus *= CNAV_CUS_LSB;
|
||||
ephemeris_record.d_Cuc = static_cast<double>(read_navigation_signed(data_bits, CNAV_CUC));
|
||||
ephemeris_record.d_Cuc *= CNAV_CUC_LSB;
|
||||
ephemeris_record.toe2 = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOE2));
|
||||
ephemeris_record.toe2 *= CNAV_TOE2_LSB;
|
||||
ephemeris_record.OMEGA_0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_OMEGA0));
|
||||
ephemeris_record.OMEGA_0 *= CNAV_OMEGA0_LSB;
|
||||
ephemeris_record.delta_OMEGAdot = static_cast<double>(read_navigation_signed(data_bits, CNAV_DELTA_OMEGA_DOT));
|
||||
ephemeris_record.delta_OMEGAdot *= CNAV_DELTA_OMEGA_DOT_LSB;
|
||||
ephemeris_record.OMEGAdot = CNAV_OMEGA_DOT_REF * GNSS_PI + ephemeris_record.delta_OMEGAdot;
|
||||
ephemeris_record.i_0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_I0));
|
||||
ephemeris_record.i_0 *= CNAV_I0_LSB;
|
||||
ephemeris_record.idot = static_cast<double>(read_navigation_signed(data_bits, CNAV_I0_DOT));
|
||||
ephemeris_record.idot *= CNAV_I0_DOT_LSB;
|
||||
ephemeris_record.Cis = static_cast<double>(read_navigation_signed(data_bits, CNAV_CIS));
|
||||
ephemeris_record.Cis *= CNAV_CIS_LSB;
|
||||
ephemeris_record.Cic = static_cast<double>(read_navigation_signed(data_bits, CNAV_CIC));
|
||||
ephemeris_record.Cic *= CNAV_CIC_LSB;
|
||||
ephemeris_record.Crs = static_cast<double>(read_navigation_signed(data_bits, CNAV_CRS));
|
||||
ephemeris_record.Crs *= CNAV_CRS_LSB;
|
||||
ephemeris_record.Crc = static_cast<double>(read_navigation_signed(data_bits, CNAV_CRC));
|
||||
ephemeris_record.Crc *= CNAV_CRC_LSB;
|
||||
ephemeris_record.Cus = static_cast<double>(read_navigation_signed(data_bits, CNAV_CUS));
|
||||
ephemeris_record.Cus *= CNAV_CUS_LSB;
|
||||
ephemeris_record.Cuc = static_cast<double>(read_navigation_signed(data_bits, CNAV_CUC));
|
||||
ephemeris_record.Cuc *= CNAV_CUC_LSB;
|
||||
b_flag_ephemeris_2 = true;
|
||||
break;
|
||||
case 30: // (CLOCK, IONO, GRUP DELAY)
|
||||
// clock
|
||||
ephemeris_record.d_Toc = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOC));
|
||||
ephemeris_record.d_Toc *= CNAV_TOC_LSB;
|
||||
ephemeris_record.d_URA0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_URA_NED0));
|
||||
ephemeris_record.d_URA1 = static_cast<double>(read_navigation_unsigned(data_bits, CNAV_URA_NED1));
|
||||
ephemeris_record.d_URA2 = static_cast<double>(read_navigation_unsigned(data_bits, CNAV_URA_NED2));
|
||||
ephemeris_record.d_A_f0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF0));
|
||||
ephemeris_record.d_A_f0 *= CNAV_AF0_LSB;
|
||||
ephemeris_record.d_A_f1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF1));
|
||||
ephemeris_record.d_A_f1 *= CNAV_AF1_LSB;
|
||||
ephemeris_record.d_A_f2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF2));
|
||||
ephemeris_record.d_A_f2 *= CNAV_AF2_LSB;
|
||||
ephemeris_record.toc = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOC));
|
||||
ephemeris_record.toc *= CNAV_TOC_LSB;
|
||||
ephemeris_record.URA0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_URA_NED0));
|
||||
ephemeris_record.URA1 = static_cast<double>(read_navigation_unsigned(data_bits, CNAV_URA_NED1));
|
||||
ephemeris_record.URA2 = static_cast<double>(read_navigation_unsigned(data_bits, CNAV_URA_NED2));
|
||||
ephemeris_record.af0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF0));
|
||||
ephemeris_record.af0 *= CNAV_AF0_LSB;
|
||||
ephemeris_record.af1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF1));
|
||||
ephemeris_record.af1 *= CNAV_AF1_LSB;
|
||||
ephemeris_record.af2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF2));
|
||||
ephemeris_record.af2 *= CNAV_AF2_LSB;
|
||||
// group delays
|
||||
// Check if the grup delay values are not available. See IS-GPS-200, Table 30-IV.
|
||||
// Bit string "1000000000000" is -4096 in 2 complement
|
||||
ephemeris_record.d_TGD = static_cast<double>(read_navigation_signed(data_bits, CNAV_TGD));
|
||||
if (ephemeris_record.d_TGD < -4095.9)
|
||||
ephemeris_record.TGD = static_cast<double>(read_navigation_signed(data_bits, CNAV_TGD));
|
||||
if (ephemeris_record.TGD < -4095.9)
|
||||
{
|
||||
ephemeris_record.d_TGD = 0.0;
|
||||
ephemeris_record.TGD = 0.0;
|
||||
}
|
||||
ephemeris_record.d_TGD *= CNAV_TGD_LSB;
|
||||
ephemeris_record.TGD *= CNAV_TGD_LSB;
|
||||
|
||||
ephemeris_record.d_ISCL1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL1));
|
||||
if (ephemeris_record.d_ISCL1 < -4095.9)
|
||||
ephemeris_record.ISCL1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL1));
|
||||
if (ephemeris_record.ISCL1 < -4095.9)
|
||||
{
|
||||
ephemeris_record.d_ISCL1 = 0.0;
|
||||
ephemeris_record.ISCL1 = 0.0;
|
||||
}
|
||||
ephemeris_record.d_ISCL1 *= CNAV_ISCL1_LSB;
|
||||
ephemeris_record.ISCL1 *= CNAV_ISCL1_LSB;
|
||||
|
||||
ephemeris_record.d_ISCL2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL2));
|
||||
if (ephemeris_record.d_ISCL2 < -4095.9)
|
||||
ephemeris_record.ISCL2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL2));
|
||||
if (ephemeris_record.ISCL2 < -4095.9)
|
||||
{
|
||||
ephemeris_record.d_ISCL2 = 0.0;
|
||||
ephemeris_record.ISCL2 = 0.0;
|
||||
}
|
||||
ephemeris_record.d_ISCL2 *= CNAV_ISCL2_LSB;
|
||||
ephemeris_record.ISCL2 *= CNAV_ISCL2_LSB;
|
||||
|
||||
ephemeris_record.d_ISCL5I = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL5I));
|
||||
if (ephemeris_record.d_ISCL5I < -4095.9)
|
||||
ephemeris_record.ISCL5I = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL5I));
|
||||
if (ephemeris_record.ISCL5I < -4095.9)
|
||||
{
|
||||
ephemeris_record.d_ISCL5I = 0.0;
|
||||
ephemeris_record.ISCL5I = 0.0;
|
||||
}
|
||||
ephemeris_record.d_ISCL5I *= CNAV_ISCL5I_LSB;
|
||||
ephemeris_record.ISCL5I *= CNAV_ISCL5I_LSB;
|
||||
|
||||
ephemeris_record.d_ISCL5Q = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL5Q));
|
||||
if (ephemeris_record.d_ISCL5Q < -4095.9)
|
||||
ephemeris_record.ISCL5Q = static_cast<double>(read_navigation_signed(data_bits, CNAV_ISCL5Q));
|
||||
if (ephemeris_record.ISCL5Q < -4095.9)
|
||||
{
|
||||
ephemeris_record.d_ISCL5Q = 0.0;
|
||||
ephemeris_record.ISCL5Q = 0.0;
|
||||
}
|
||||
ephemeris_record.d_ISCL5Q *= CNAV_ISCL5Q_LSB;
|
||||
ephemeris_record.ISCL5Q *= CNAV_ISCL5Q_LSB;
|
||||
// iono
|
||||
iono_record.d_alpha0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA0));
|
||||
iono_record.d_alpha0 = iono_record.d_alpha0 * CNAV_ALPHA0_LSB;
|
||||
iono_record.d_alpha1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA1));
|
||||
iono_record.d_alpha1 = iono_record.d_alpha1 * CNAV_ALPHA1_LSB;
|
||||
iono_record.d_alpha2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA2));
|
||||
iono_record.d_alpha2 = iono_record.d_alpha2 * CNAV_ALPHA2_LSB;
|
||||
iono_record.d_alpha3 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA3));
|
||||
iono_record.d_alpha3 = iono_record.d_alpha3 * CNAV_ALPHA3_LSB;
|
||||
iono_record.d_beta0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA0));
|
||||
iono_record.d_beta0 = iono_record.d_beta0 * CNAV_BETA0_LSB;
|
||||
iono_record.d_beta1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA1));
|
||||
iono_record.d_beta1 = iono_record.d_beta1 * CNAV_BETA1_LSB;
|
||||
iono_record.d_beta2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA2));
|
||||
iono_record.d_beta2 = iono_record.d_beta2 * CNAV_BETA2_LSB;
|
||||
iono_record.d_beta3 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA3));
|
||||
iono_record.d_beta3 = iono_record.d_beta3 * CNAV_BETA3_LSB;
|
||||
iono_record.alpha0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA0));
|
||||
iono_record.alpha0 = iono_record.alpha0 * CNAV_ALPHA0_LSB;
|
||||
iono_record.alpha1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA1));
|
||||
iono_record.alpha1 = iono_record.alpha1 * CNAV_ALPHA1_LSB;
|
||||
iono_record.alpha2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA2));
|
||||
iono_record.alpha2 = iono_record.alpha2 * CNAV_ALPHA2_LSB;
|
||||
iono_record.alpha3 = static_cast<double>(read_navigation_signed(data_bits, CNAV_ALPHA3));
|
||||
iono_record.alpha3 = iono_record.alpha3 * CNAV_ALPHA3_LSB;
|
||||
iono_record.beta0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA0));
|
||||
iono_record.beta0 = iono_record.beta0 * CNAV_BETA0_LSB;
|
||||
iono_record.beta1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA1));
|
||||
iono_record.beta1 = iono_record.beta1 * CNAV_BETA1_LSB;
|
||||
iono_record.beta2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA2));
|
||||
iono_record.beta2 = iono_record.beta2 * CNAV_BETA2_LSB;
|
||||
iono_record.beta3 = static_cast<double>(read_navigation_signed(data_bits, CNAV_BETA3));
|
||||
iono_record.beta3 = iono_record.beta3 * CNAV_BETA3_LSB;
|
||||
b_flag_iono_valid = true;
|
||||
break;
|
||||
case 33: // (CLOCK & UTC)
|
||||
ephemeris_record.d_Top = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOP1));
|
||||
ephemeris_record.d_Top = ephemeris_record.d_Top * CNAV_TOP1_LSB;
|
||||
ephemeris_record.d_Toc = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOC));
|
||||
ephemeris_record.d_Toc = ephemeris_record.d_Toc * CNAV_TOC_LSB;
|
||||
ephemeris_record.d_A_f0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF0));
|
||||
ephemeris_record.d_A_f0 = ephemeris_record.d_A_f0 * CNAV_AF0_LSB;
|
||||
ephemeris_record.d_A_f1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF1));
|
||||
ephemeris_record.d_A_f1 = ephemeris_record.d_A_f1 * CNAV_AF1_LSB;
|
||||
ephemeris_record.d_A_f2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF2));
|
||||
ephemeris_record.d_A_f2 = ephemeris_record.d_A_f2 * CNAV_AF2_LSB;
|
||||
ephemeris_record.top = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOP1));
|
||||
ephemeris_record.top = ephemeris_record.top * CNAV_TOP1_LSB;
|
||||
ephemeris_record.toc = static_cast<int32_t>(read_navigation_unsigned(data_bits, CNAV_TOC));
|
||||
ephemeris_record.toc = ephemeris_record.toc * CNAV_TOC_LSB;
|
||||
ephemeris_record.af0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF0));
|
||||
ephemeris_record.af0 = ephemeris_record.af0 * CNAV_AF0_LSB;
|
||||
ephemeris_record.af1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF1));
|
||||
ephemeris_record.af1 = ephemeris_record.af1 * CNAV_AF1_LSB;
|
||||
ephemeris_record.af2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_AF2));
|
||||
ephemeris_record.af2 = ephemeris_record.af2 * CNAV_AF2_LSB;
|
||||
|
||||
utc_model_record.d_A0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_A0));
|
||||
utc_model_record.d_A0 = utc_model_record.d_A0 * CNAV_A0_LSB;
|
||||
utc_model_record.d_A1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_A1));
|
||||
utc_model_record.d_A1 = utc_model_record.d_A1 * CNAV_A1_LSB;
|
||||
utc_model_record.d_A2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_A2));
|
||||
utc_model_record.d_A2 = utc_model_record.d_A2 * CNAV_A2_LSB;
|
||||
utc_model_record.A0 = static_cast<double>(read_navigation_signed(data_bits, CNAV_A0));
|
||||
utc_model_record.A0 = utc_model_record.A0 * CNAV_A0_LSB;
|
||||
utc_model_record.A1 = static_cast<double>(read_navigation_signed(data_bits, CNAV_A1));
|
||||
utc_model_record.A1 = utc_model_record.A1 * CNAV_A1_LSB;
|
||||
utc_model_record.A2 = static_cast<double>(read_navigation_signed(data_bits, CNAV_A2));
|
||||
utc_model_record.A2 = utc_model_record.A2 * CNAV_A2_LSB;
|
||||
|
||||
utc_model_record.d_DeltaT_LS = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_DELTA_TLS));
|
||||
utc_model_record.d_DeltaT_LS = utc_model_record.d_DeltaT_LS * CNAV_DELTA_TLS_LSB;
|
||||
utc_model_record.DeltaT_LS = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_DELTA_TLS));
|
||||
utc_model_record.DeltaT_LS = utc_model_record.DeltaT_LS * CNAV_DELTA_TLS_LSB;
|
||||
|
||||
utc_model_record.d_t_OT = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_TOT));
|
||||
utc_model_record.d_t_OT = utc_model_record.d_t_OT * CNAV_TOT_LSB;
|
||||
utc_model_record.tot = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_TOT));
|
||||
utc_model_record.tot = utc_model_record.tot * CNAV_TOT_LSB;
|
||||
|
||||
utc_model_record.i_WN_T = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_WN_OT));
|
||||
utc_model_record.i_WN_T = utc_model_record.i_WN_T * CNAV_WN_OT_LSB;
|
||||
utc_model_record.WN_T = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_WN_OT));
|
||||
utc_model_record.WN_T = utc_model_record.WN_T * CNAV_WN_OT_LSB;
|
||||
|
||||
utc_model_record.i_WN_LSF = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_WN_LSF));
|
||||
utc_model_record.i_WN_LSF = utc_model_record.i_WN_LSF * CNAV_WN_LSF_LSB;
|
||||
utc_model_record.WN_LSF = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_WN_LSF));
|
||||
utc_model_record.WN_LSF = utc_model_record.WN_LSF * CNAV_WN_LSF_LSB;
|
||||
|
||||
utc_model_record.i_DN = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_DN));
|
||||
utc_model_record.i_DN = utc_model_record.i_DN * CNAV_DN_LSB;
|
||||
utc_model_record.DN = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_DN));
|
||||
utc_model_record.DN = utc_model_record.DN * CNAV_DN_LSB;
|
||||
|
||||
utc_model_record.d_DeltaT_LSF = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_DELTA_TLSF));
|
||||
utc_model_record.d_DeltaT_LSF = utc_model_record.d_DeltaT_LSF * CNAV_DELTA_TLSF_LSB;
|
||||
utc_model_record.DeltaT_LSF = static_cast<int32_t>(read_navigation_signed(data_bits, CNAV_DELTA_TLSF));
|
||||
utc_model_record.DeltaT_LSF = utc_model_record.DeltaT_LSF * CNAV_DELTA_TLSF_LSB;
|
||||
b_flag_utc_valid = true;
|
||||
break;
|
||||
default:
|
||||
@ -289,7 +292,7 @@ bool Gps_CNAV_Navigation_Message::have_new_ephemeris() // Check if we have a ne
|
||||
{
|
||||
if (b_flag_ephemeris_1 == true and b_flag_ephemeris_2 == true)
|
||||
{
|
||||
if (ephemeris_record.d_Toe1 == ephemeris_record.d_Toe2) // and ephemeris_record.d_Toe1==ephemeris_record.d_Toc)
|
||||
if (ephemeris_record.toe1 == ephemeris_record.toe2) // and ephemeris_record.toe1==ephemeris_record.d_Toc)
|
||||
{
|
||||
// if all ephemeris pages have the same TOE, then they belong to the same block
|
||||
// std::cout << "Ephemeris (1, 2) have been received and belong to the same batch\n";
|
||||
|
@ -41,36 +41,36 @@ public:
|
||||
Gps_CNAV_Utc_Model() = default;
|
||||
|
||||
// UTC parameters
|
||||
double d_A2{}; //!< 2nd order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
double d_A1{}; //!< 1st order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
double d_A0{}; //!< Constant of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
int32_t d_t_OT{}; //!< Reference time for UTC data (reference 20.3.4.5 and 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
int32_t i_WN_T{}; //!< UTC reference week number [weeks]
|
||||
int32_t d_DeltaT_LS{}; //!< delta time due to leap seconds [s]. Number of leap seconds since 6-Jan-1980 as transmitted by the GPS almanac.
|
||||
int32_t i_WN_LSF{}; //!< Week number at the end of which the leap second becomes effective [weeks]
|
||||
int32_t i_DN{}; //!< Day number (DN) at the end of which the leap second becomes effective [days]
|
||||
int32_t d_DeltaT_LSF{}; //!< Scheduled future or recent past (relative to NAV message upload) value of the delta time due to leap seconds [s]
|
||||
double A2{}; //!< 2nd order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
double A1{}; //!< 1st order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
double A0{}; //!< Constant of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
int32_t tot{}; //!< Reference time for UTC data (reference 20.3.4.5 and 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
int32_t WN_T{}; //!< UTC reference week number [weeks]
|
||||
int32_t DeltaT_LS{}; //!< Delta time due to leap seconds [s]. Number of leap seconds since 6-Jan-1980 as transmitted by the GPS almanac.
|
||||
int32_t WN_LSF{}; //!< Week number at the end of which the leap second becomes effective [weeks]
|
||||
int32_t DN{}; //!< Day number (DN) at the end of which the leap second becomes effective [days]
|
||||
int32_t DeltaT_LSF{}; //!< Scheduled future or recent past (relative to NAV message upload) value of the delta time due to leap seconds [s]
|
||||
bool valid{};
|
||||
|
||||
template <class Archive>
|
||||
/*
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("d_A1", d_A1);
|
||||
archive& make_nvp("d_A0", d_A0);
|
||||
archive& make_nvp("d_t_OT", d_t_OT);
|
||||
archive& make_nvp("i_WN_T", i_WN_T);
|
||||
archive& make_nvp("d_DeltaT_LS", d_DeltaT_LS);
|
||||
archive& make_nvp("i_WN_LSF", i_WN_LSF);
|
||||
archive& make_nvp("i_DN", i_DN);
|
||||
archive& make_nvp("d_DeltaT_LSF", d_DeltaT_LSF);
|
||||
archive& make_nvp("valid", valid);
|
||||
archive& BOOST_SERIALIZATION_NVP(A1);
|
||||
archive& BOOST_SERIALIZATION_NVP(A0);
|
||||
archive& BOOST_SERIALIZATION_NVP(tot);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN_T);
|
||||
archive& BOOST_SERIALIZATION_NVP(DeltaT_LS);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN_LSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(DN);
|
||||
archive& BOOST_SERIALIZATION_NVP(DeltaT_LSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(valid);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -17,9 +17,8 @@
|
||||
*/
|
||||
|
||||
#include "gps_ephemeris.h"
|
||||
#include "GPS_L1_CA.h"
|
||||
#include "gnss_satellite.h"
|
||||
#include <cmath>
|
||||
#include <string>
|
||||
|
||||
|
||||
Gps_Ephemeris::Gps_Ephemeris()
|
||||
@ -30,195 +29,5 @@ Gps_Ephemeris::Gps_Ephemeris()
|
||||
{
|
||||
satelliteBlock[i] = gnss_sat.what_block(_system, i);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
double Gps_Ephemeris::check_t(double time)
|
||||
{
|
||||
const double half_week = 302400.0; // seconds
|
||||
double corrTime = time;
|
||||
if (time > half_week)
|
||||
{
|
||||
corrTime = time - 2.0 * half_week;
|
||||
}
|
||||
else if (time < -half_week)
|
||||
{
|
||||
corrTime = time + 2.0 * half_week;
|
||||
}
|
||||
return corrTime;
|
||||
}
|
||||
|
||||
|
||||
// 20.3.3.3.3.1 User Algorithm for SV Clock Correction.
|
||||
double Gps_Ephemeris::sv_clock_drift(double transmitTime)
|
||||
{
|
||||
// double dt;
|
||||
// dt = check_t(transmitTime - d_Toc);
|
||||
//
|
||||
// for (int32_t i = 0; i < 2; i++)
|
||||
// {
|
||||
// dt -= d_A_f0 + d_A_f1 * dt + d_A_f2 * (dt * dt);
|
||||
// }
|
||||
// d_satClkDrift = d_A_f0 + d_A_f1 * dt + d_A_f2 * (dt * dt);
|
||||
|
||||
const double dt = check_t(transmitTime - d_Toc);
|
||||
d_satClkDrift = d_A_f0 + d_A_f1 * dt + d_A_f2 * (dt * dt) + sv_clock_relativistic_term(transmitTime);
|
||||
// Correct satellite group delay
|
||||
d_satClkDrift -= d_TGD;
|
||||
|
||||
return d_satClkDrift;
|
||||
}
|
||||
|
||||
|
||||
// compute the relativistic correction term
|
||||
double Gps_Ephemeris::sv_clock_relativistic_term(double transmitTime)
|
||||
{
|
||||
// Restore semi-major axis
|
||||
const double a = d_sqrt_A * d_sqrt_A;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
const double tk = check_t(transmitTime - d_Toe);
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(GPS_GM / (a * a * a));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + d_Delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
const double M = d_M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
// M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
// --- Iteratively compute eccentric anomaly ----------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + d_e_eccentricity * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Compute relativistic correction term
|
||||
d_dtr = GPS_F * d_e_eccentricity * d_sqrt_A * sin(E);
|
||||
return d_dtr;
|
||||
}
|
||||
|
||||
|
||||
double Gps_Ephemeris::satellitePosition(double transmitTime)
|
||||
{
|
||||
// Find satellite's position -----------------------------------------------
|
||||
// Restore semi-major axis
|
||||
const double a = d_sqrt_A * d_sqrt_A;
|
||||
|
||||
// Time from ephemeris reference epoch
|
||||
double tk = check_t(transmitTime - d_Toe);
|
||||
|
||||
// Computed mean motion
|
||||
const double n0 = sqrt(GPS_GM / (a * a * a));
|
||||
|
||||
// Corrected mean motion
|
||||
const double n = n0 + d_Delta_n;
|
||||
|
||||
// Mean anomaly
|
||||
const double M = d_M_0 + n * tk;
|
||||
|
||||
// Reduce mean anomaly to between 0 and 2pi
|
||||
// M = fmod((M + 2.0 * GNSS_PI), (2.0 * GNSS_PI));
|
||||
|
||||
// Initial guess of eccentric anomaly
|
||||
double E = M;
|
||||
double E_old;
|
||||
double dE;
|
||||
// --- Iteratively compute eccentric anomaly -------------------------------
|
||||
for (int32_t ii = 1; ii < 20; ii++)
|
||||
{
|
||||
E_old = E;
|
||||
E = M + d_e_eccentricity * sin(E);
|
||||
dE = fmod(E - E_old, 2.0 * GNSS_PI);
|
||||
if (fabs(dE) < 1e-12)
|
||||
{
|
||||
// Necessary precision is reached, exit from the loop
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
const double sek = sin(E);
|
||||
const double cek = cos(E);
|
||||
const double OneMinusecosE = 1.0 - d_e_eccentricity * cek;
|
||||
const double ekdot = n / OneMinusecosE;
|
||||
|
||||
// Compute the true anomaly
|
||||
const double sq1e2 = sqrt(1.0 - d_e_eccentricity * d_e_eccentricity);
|
||||
const double tmp_Y = sq1e2 * sek;
|
||||
const double tmp_X = cek - d_e_eccentricity;
|
||||
const double nu = atan2(tmp_Y, tmp_X);
|
||||
|
||||
// Compute angle phi (argument of Latitude)
|
||||
const double phi = nu + d_OMEGA;
|
||||
double pkdot = sq1e2 * ekdot / OneMinusecosE;
|
||||
|
||||
// Reduce phi to between 0 and 2*pi rad
|
||||
// phi = fmod((phi), (2.0 * GNSS_PI));
|
||||
const double s2pk = sin(2.0 * phi);
|
||||
const double c2pk = cos(2.0 * phi);
|
||||
|
||||
// Correct argument of latitude
|
||||
const double u = phi + d_Cuc * c2pk + d_Cus * s2pk;
|
||||
const double cuk = cos(u);
|
||||
const double suk = sin(u);
|
||||
const double ukdot = pkdot * (1.0 + 2.0 * (d_Cus * c2pk - d_Cuc * s2pk));
|
||||
|
||||
// Correct radius
|
||||
const double r = a * (1.0 - d_e_eccentricity * cek) + d_Crc * c2pk + d_Crs * s2pk;
|
||||
|
||||
const double rkdot = a * d_e_eccentricity * sek * ekdot + 2.0 * pkdot * (d_Crs * c2pk - d_Crc * s2pk);
|
||||
|
||||
// Correct inclination
|
||||
const double i = d_i_0 + d_IDOT * tk + d_Cic * c2pk + d_Cis * s2pk;
|
||||
const double sik = sin(i);
|
||||
const double cik = cos(i);
|
||||
const double ikdot = d_IDOT + 2.0 * pkdot * (d_Cis * c2pk - d_Cic * s2pk);
|
||||
|
||||
// Compute the angle between the ascending node and the Greenwich meridian
|
||||
const double Omega = d_OMEGA0 + (d_OMEGA_DOT - GNSS_OMEGA_EARTH_DOT) * tk - GNSS_OMEGA_EARTH_DOT * d_Toe;
|
||||
const double sok = sin(Omega);
|
||||
const double cok = cos(Omega);
|
||||
|
||||
// --- Compute satellite coordinates in Earth-fixed coordinates
|
||||
const double xprime = r * cuk;
|
||||
const double yprime = r * suk;
|
||||
d_satpos_X = xprime * cok - yprime * cik * sok;
|
||||
d_satpos_Y = xprime * sok + yprime * cik * cok;
|
||||
d_satpos_Z = yprime * sik;
|
||||
|
||||
// Satellite's velocity. Can be useful for Vector Tracking loops
|
||||
const double Omega_dot = d_OMEGA_DOT - GNSS_OMEGA_EARTH_DOT;
|
||||
|
||||
const double xpkdot = rkdot * cuk - yprime * ukdot;
|
||||
const double ypkdot = rkdot * suk + xprime * ukdot;
|
||||
const double tmp = ypkdot * cik - d_satpos_Z * ikdot;
|
||||
|
||||
d_satvel_X = -Omega_dot * d_satpos_Y + xpkdot * cok - tmp * sok;
|
||||
d_satvel_Y = Omega_dot * d_satpos_X + xpkdot * sok + tmp * cok;
|
||||
d_satvel_Z = yprime * cik * ikdot + ypkdot * sik;
|
||||
|
||||
// Time from ephemeris reference clock
|
||||
tk = check_t(transmitTime - d_Toc);
|
||||
|
||||
double dtr_s = d_A_f0 + d_A_f1 * tk + d_A_f2 * tk * tk;
|
||||
|
||||
/* relativity correction */
|
||||
dtr_s -= 2.0 * sqrt(GPS_GM * a) * d_e_eccentricity * sek / (SPEED_OF_LIGHT_M_S * SPEED_OF_LIGHT_M_S);
|
||||
|
||||
return dtr_s;
|
||||
this->System = 'G';
|
||||
}
|
||||
|
@ -19,6 +19,7 @@
|
||||
#define GNSS_SDR_GPS_EPHEMERIS_H
|
||||
|
||||
|
||||
#include "gnss_ephemeris.h"
|
||||
#include <boost/serialization/nvp.hpp>
|
||||
#include <cstdint>
|
||||
#include <map>
|
||||
@ -31,11 +32,12 @@
|
||||
|
||||
|
||||
/*!
|
||||
* \brief This class is a storage and orbital model functions for the GPS SV ephemeris data as described in IS-GPS-200L
|
||||
* \brief This class is a storage and orbital model functions for the GPS SV
|
||||
* ephemeris data as described in IS-GPS-200L
|
||||
*
|
||||
* See https://www.gps.gov/technical/icwg/IS-GPS-200L.pdf Appendix II
|
||||
*/
|
||||
class Gps_Ephemeris
|
||||
class Gps_Ephemeris : public Gnss_Ephemeris
|
||||
{
|
||||
public:
|
||||
/*!
|
||||
@ -43,63 +45,20 @@ public:
|
||||
*/
|
||||
Gps_Ephemeris();
|
||||
|
||||
/*!
|
||||
* \brief Compute the ECEF SV coordinates and ECEF velocity
|
||||
* Implementation of Table 20-IV (IS-GPS-200L)
|
||||
* and compute the clock bias term including relativistic effect (return value)
|
||||
*/
|
||||
double satellitePosition(double transmitTime);
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a d_satClkDrift)and returns the clock drift in seconds according to the User Algorithm for SV Clock Correction
|
||||
* (IS-GPS-200L, 20.3.3.3.3.1)
|
||||
*/
|
||||
double sv_clock_drift(double transmitTime);
|
||||
|
||||
/*!
|
||||
* \brief Sets (\a d_dtr) and returns the clock relativistic correction term in seconds according to the User Algorithm for SV Clock Correction
|
||||
* (IS-GPS-200L, 20.3.3.3.3.1)
|
||||
*/
|
||||
double sv_clock_relativistic_term(double transmitTime);
|
||||
|
||||
uint32_t i_satellite_PRN{}; // SV PRN NUMBER
|
||||
int32_t d_TOW{}; //!< Time of GPS Week of the ephemeris set (taken from subframes TOW) [s]
|
||||
double d_Crs{}; //!< Amplitude of the Sine Harmonic Correction Term to the Orbit Radius [m]
|
||||
double d_Delta_n{}; //!< Mean Motion Difference From Computed Value [semi-circles/s]
|
||||
double d_M_0{}; //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
double d_Cuc{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
double d_e_eccentricity{}; //!< Eccentricity [dimensionless]
|
||||
double d_Cus{}; //!< Amplitude of the Sine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
double d_sqrt_A{}; //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
int32_t d_Toe{}; //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
int32_t d_Toc{}; //!< clock data reference time (Ref. 20.3.3.3.3.1 IS-GPS-200L) [s]
|
||||
double d_Cic{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
double d_OMEGA0{}; //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
double d_Cis{}; //!< Amplitude of the Sine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
double d_i_0{}; //!< Inclination Angle at Reference Time [semi-circles]
|
||||
double d_Crc{}; //!< Amplitude of the Cosine Harmonic Correction Term to the Orbit Radius [m]
|
||||
double d_OMEGA{}; //!< Argument of Perigee [semi-cicles]
|
||||
double d_OMEGA_DOT{}; //!< Rate of Right Ascension [semi-circles/s]
|
||||
double d_IDOT{}; //!< Rate of Inclination Angle [semi-circles/s]
|
||||
int32_t i_code_on_L2{}; //!< If 1, P code ON in L2; if 2, C/A code ON in L2;
|
||||
int32_t i_GPS_week{}; //!< GPS week number, aka WN [week]
|
||||
bool b_L2_P_data_flag{}; //!< When true, indicates that the NAV data stream was commanded OFF on the P-code of the L2 channel
|
||||
int32_t i_SV_accuracy{}; //!< User Range Accuracy (URA) index of the SV (reference paragraph 6.2.1) for the standard positioning service user (Ref 20.3.3.3.1.3 IS-GPS-200L)
|
||||
int32_t i_SV_health{};
|
||||
double d_TGD{}; //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
int32_t d_IODC{}; //!< Issue of Data, Clock
|
||||
int32_t d_IODE_SF2{}; //!< Issue of Data, Ephemeris (IODE), subframe 2
|
||||
int32_t d_IODE_SF3{}; //!< Issue of Data, Ephemeris(IODE), subframe 3
|
||||
int32_t i_AODO{}; //!< Age of Data Offset (AODO) term for the navigation message correction table (NMCT) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
int32_t code_on_L2{}; //!< If 1, P code ON in L2; if 2, C/A code ON in L2;
|
||||
bool L2_P_data_flag{}; //!< When true, indicates that the NAV data stream was commanded OFF on the P-code of the L2 channel
|
||||
int32_t SV_accuracy{}; //!< User Range Accuracy (URA) index of the SV (reference paragraph 6.2.1) for the standard positioning service user (Ref 20.3.3.3.1.3 IS-GPS-200L)
|
||||
int32_t SV_health{}; //!< Satellite heath status
|
||||
double TGD{}; //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
int32_t IODC{}; //!< Issue of Data, Clock
|
||||
int32_t IODE_SF2{}; //!< Issue of Data, Ephemeris (IODE), subframe 2
|
||||
int32_t IODE_SF3{}; //!< Issue of Data, Ephemeris (IODE), subframe 3
|
||||
int32_t AODO{}; //!< Age of Data Offset (AODO) term for the navigation message correction table (NMCT) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
|
||||
bool b_fit_interval_flag{}; //!< indicates the curve-fit interval used by the CS (Block II/IIA/IIR/IIR-M/IIF) and SS (Block IIIA) in determining the ephemeris parameters, as follows: 0 = 4 hours, 1 = greater than 4 hours.
|
||||
double d_spare1{};
|
||||
double d_spare2{};
|
||||
|
||||
double d_A_f0{}; //!< Coefficient 0 of code phase offset model [s]
|
||||
double d_A_f1{}; //!< Coefficient 1 of code phase offset model [s/s]
|
||||
double d_A_f2{}; //!< Coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
// Flags
|
||||
|
||||
/*! \brief If true, enhanced level of integrity assurance.
|
||||
@ -113,29 +72,16 @@ public:
|
||||
* accompanying alert, is less than 1E-8 per hour.
|
||||
*/
|
||||
bool b_integrity_status_flag{};
|
||||
bool b_alert_flag{}; //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
bool b_alert_flag{}; //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
bool b_antispoofing_flag{}; //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
|
||||
// clock terms derived from ephemeris data
|
||||
double d_satClkDrift{}; //!< GPS clock error
|
||||
double d_dtr{}; //!< relativistic clock correction term
|
||||
|
||||
// satellite positions
|
||||
double d_satpos_X{}; //!< Earth-fixed coordinate x of the satellite [m]. Intersection of the IERS Reference Meridian (IRM) and the plane passing through the origin and normal to the Z-axis.
|
||||
double d_satpos_Y{}; //!< Earth-fixed coordinate y of the satellite [m]. Completes a right-handed, Earth-Centered, Earth-Fixed orthogonal coordinate system.
|
||||
double d_satpos_Z{}; //!< Earth-fixed coordinate z of the satellite [m]. The direction of the IERS (International Earth Rotation and Reference Systems Service) Reference Pole (IRP).
|
||||
|
||||
// Satellite velocity
|
||||
double d_satvel_X{}; //!< Earth-fixed velocity coordinate x of the satellite [m]
|
||||
double d_satvel_Y{}; //!< Earth-fixed velocity coordinate y of the satellite [m]
|
||||
double d_satvel_Z{}; //!< Earth-fixed velocity coordinate z of the satellite [m]
|
||||
|
||||
std::map<int, std::string> satelliteBlock; //!< Map that stores to which block the PRN belongs https://www.navcen.uscg.gov/?Do=constellationStatus
|
||||
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
@ -144,58 +90,48 @@ public:
|
||||
{
|
||||
};
|
||||
|
||||
archive& make_nvp("i_satellite_PRN", i_satellite_PRN); // SV PRN NUMBER
|
||||
archive& make_nvp("d_TOW", d_TOW); //!< Time of GPS Week of the ephemeris set (taken from subframes TOW) [s]
|
||||
archive& make_nvp("d_IODE_SF2", d_IODE_SF2);
|
||||
archive& make_nvp("d_IODE_SF3", d_IODE_SF3);
|
||||
archive& make_nvp("d_Crs", d_Crs); //!< Amplitude of the Sine Harmonic Correction Term to the Orbit Radius [m]
|
||||
archive& make_nvp("d_Delta_n", d_Delta_n); //!< Mean Motion Difference From Computed Value [semi-circles/s]
|
||||
archive& make_nvp("d_M_0", d_M_0); //!< Mean Anomaly at Reference Time [semi-circles]
|
||||
archive& make_nvp("d_Cuc", d_Cuc); //!< Amplitude of the Cosine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
archive& make_nvp("d_e_eccentricity", d_e_eccentricity); //!< Eccentricity [dimensionless]
|
||||
archive& make_nvp("d_Cus", d_Cus); //!< Amplitude of the Sine Harmonic Correction Term to the Argument of Latitude [rad]
|
||||
archive& make_nvp("d_sqrt_A", d_sqrt_A); //!< Square Root of the Semi-Major Axis [sqrt(m)]
|
||||
archive& make_nvp("d_Toe", d_Toe); //!< Ephemeris data reference time of week (Ref. 20.3.3.4.3 IS-GPS-200L) [s]
|
||||
archive& make_nvp("d_Toc", d_Toc); //!< clock data reference time (Ref. 20.3.3.3.3.1 IS-GPS-200L) [s]
|
||||
archive& make_nvp("d_Cic", d_Cic); //!< Amplitude of the Cosine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
archive& make_nvp("d_OMEGA0", d_OMEGA0); //!< Longitude of Ascending Node of Orbit Plane at Weekly Epoch [semi-circles]
|
||||
archive& make_nvp("d_Cis", d_Cis); //!< Amplitude of the Sine Harmonic Correction Term to the Angle of Inclination [rad]
|
||||
archive& make_nvp("d_i_0", d_i_0); //!< Inclination Angle at Reference Time [semi-circles]
|
||||
archive& make_nvp("d_Crc", d_Crc); //!< Amplitude of the Cosine Harmonic Correction Term to the Orbit Radius [m]
|
||||
archive& make_nvp("d_OMEGA", d_OMEGA); //!< Argument of Perigee [semi-cicles]
|
||||
archive& make_nvp("d_OMEGA_DOT", d_OMEGA_DOT); //!< Rate of Right Ascension [semi-circles/s]
|
||||
archive& make_nvp("d_IDOT", d_IDOT); //!< Rate of Inclination Angle [semi-circles/s]
|
||||
archive& make_nvp("i_code_on_L2", i_code_on_L2); //!< If 1, P code ON in L2; if 2, C/A code ON in L2;
|
||||
archive& make_nvp("i_GPS_week", i_GPS_week); //!< GPS week number, aka WN [week]
|
||||
archive& make_nvp("b_L2_P_data_flag", b_L2_P_data_flag); //!< When true, indicates that the NAV data stream was commanded OFF on the P-code of the L2 channel
|
||||
archive& make_nvp("i_SV_accuracy", i_SV_accuracy); //!< User Range Accuracy (URA) index of the SV (reference paragraph 6.2.1) for the standard positioning service user (Ref 20.3.3.3.1.3 IS-GPS-200L)
|
||||
archive& make_nvp("i_SV_health", i_SV_health);
|
||||
archive& make_nvp("d_TGD", d_TGD); //!< Estimated Group Delay Differential: L1-L2 correction term only for the benefit of "L1 P(Y)" or "L2 P(Y)" s users [s]
|
||||
archive& make_nvp("d_IODC", d_IODC); //!< Issue of Data, Clock
|
||||
archive& make_nvp("i_AODO", i_AODO); //!< Age of Data Offset (AODO) term for the navigation message correction table (NMCT) contained in subframe 4 (reference paragraph 20.3.3.5.1.9) [s]
|
||||
archive& BOOST_SERIALIZATION_NVP(PRN);
|
||||
archive& BOOST_SERIALIZATION_NVP(M_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(delta_n);
|
||||
archive& BOOST_SERIALIZATION_NVP(ecc);
|
||||
archive& BOOST_SERIALIZATION_NVP(sqrtA);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGA_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(i_0);
|
||||
archive& BOOST_SERIALIZATION_NVP(omega);
|
||||
archive& BOOST_SERIALIZATION_NVP(OMEGAdot);
|
||||
archive& BOOST_SERIALIZATION_NVP(idot);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cuc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cus);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crc);
|
||||
archive& BOOST_SERIALIZATION_NVP(Crs);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cic);
|
||||
archive& BOOST_SERIALIZATION_NVP(Cis);
|
||||
archive& BOOST_SERIALIZATION_NVP(toe);
|
||||
archive& BOOST_SERIALIZATION_NVP(toc);
|
||||
archive& BOOST_SERIALIZATION_NVP(af0);
|
||||
archive& BOOST_SERIALIZATION_NVP(af1);
|
||||
archive& BOOST_SERIALIZATION_NVP(af2);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN);
|
||||
archive& BOOST_SERIALIZATION_NVP(tow);
|
||||
archive& BOOST_SERIALIZATION_NVP(satClkDrift);
|
||||
archive& BOOST_SERIALIZATION_NVP(dtr);
|
||||
|
||||
archive& make_nvp("b_fit_interval_flag", b_fit_interval_flag); //!< Indicates the curve-fit interval used by the CS (Block II/IIA/IIR/IIR-M/IIF) and SS (Block IIIA) in determining the ephemeris parameters, as follows: 0 = 4 hours, 1 = greater than 4 hours.
|
||||
archive& make_nvp("d_spare1", d_spare1);
|
||||
archive& make_nvp("d_spare2", d_spare2);
|
||||
|
||||
archive& make_nvp("d_A_f0", d_A_f0); //!< Coefficient 0 of code phase offset model [s]
|
||||
archive& make_nvp("d_A_f1", d_A_f1); //!< Coefficient 1 of code phase offset model [s/s]
|
||||
archive& make_nvp("d_A_f2", d_A_f2); //!< Coefficient 2 of code phase offset model [s/s^2]
|
||||
|
||||
archive& make_nvp("b_integrity_status_flag", b_integrity_status_flag);
|
||||
archive& make_nvp("b_alert_flag", b_alert_flag); //!< If true, indicates that the SV URA may be worse than indicated in d_SV_accuracy, use that SV at our own risk.
|
||||
archive& make_nvp("b_antispoofing_flag", b_antispoofing_flag); //!< If true, the AntiSpoofing mode is ON in that SV
|
||||
archive& BOOST_SERIALIZATION_NVP(IODE_SF2);
|
||||
archive& BOOST_SERIALIZATION_NVP(IODE_SF3);
|
||||
archive& BOOST_SERIALIZATION_NVP(code_on_L2);
|
||||
archive& BOOST_SERIALIZATION_NVP(L2_P_data_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(SV_accuracy);
|
||||
archive& BOOST_SERIALIZATION_NVP(SV_health);
|
||||
archive& BOOST_SERIALIZATION_NVP(TGD);
|
||||
archive& BOOST_SERIALIZATION_NVP(IODC);
|
||||
archive& BOOST_SERIALIZATION_NVP(AODO);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_fit_interval_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_spare1);
|
||||
archive& BOOST_SERIALIZATION_NVP(d_spare2);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_integrity_status_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_alert_flag);
|
||||
archive& BOOST_SERIALIZATION_NVP(b_antispoofing_flag);
|
||||
}
|
||||
|
||||
private:
|
||||
/*
|
||||
* Accounts for the beginning or end of week crossover
|
||||
*
|
||||
* See paragraph 20.3.3.3.3.1 (IS-GPS-200L)
|
||||
* \param[in] - time in seconds
|
||||
* \param[out] - corrected time, in seconds
|
||||
*/
|
||||
double check_t(double time);
|
||||
};
|
||||
|
||||
|
||||
|
@ -37,36 +37,36 @@ class Gps_Iono
|
||||
public:
|
||||
bool valid{}; //!< Valid flag
|
||||
// Ionospheric parameters
|
||||
double d_alpha0{}; //!< Coefficient 0 of a cubic equation representing the amplitude of the vertical delay [s]
|
||||
double d_alpha1{}; //!< Coefficient 1 of a cubic equation representing the amplitude of the vertical delay [s/semi-circle]
|
||||
double d_alpha2{}; //!< Coefficient 2 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^2]
|
||||
double d_alpha3{}; //!< Coefficient 3 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^3]
|
||||
double d_beta0{}; //!< Coefficient 0 of a cubic equation representing the period of the model [s]
|
||||
double d_beta1{}; //!< Coefficient 1 of a cubic equation representing the period of the model [s/semi-circle]
|
||||
double d_beta2{}; //!< Coefficient 2 of a cubic equation representing the period of the model [s(semi-circle)^2]
|
||||
double d_beta3{}; //!< Coefficient 3 of a cubic equation representing the period of the model [s(semi-circle)^3]
|
||||
double alpha0{}; //!< Coefficient 0 of a cubic equation representing the amplitude of the vertical delay [s]
|
||||
double alpha1{}; //!< Coefficient 1 of a cubic equation representing the amplitude of the vertical delay [s/semi-circle]
|
||||
double alpha2{}; //!< Coefficient 2 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^2]
|
||||
double alpha3{}; //!< Coefficient 3 of a cubic equation representing the amplitude of the vertical delay [s(semi-circle)^3]
|
||||
double beta0{}; //!< Coefficient 0 of a cubic equation representing the period of the model [s]
|
||||
double beta1{}; //!< Coefficient 1 of a cubic equation representing the period of the model [s/semi-circle]
|
||||
double beta2{}; //!< Coefficient 2 of a cubic equation representing the period of the model [s(semi-circle)^2]
|
||||
double beta3{}; //!< Coefficient 3 of a cubic equation representing the period of the model [s(semi-circle)^3]
|
||||
|
||||
Gps_Iono() = default; //!< Default constructor
|
||||
|
||||
template <class Archive>
|
||||
|
||||
/*!
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const unsigned int version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("d_alpha0", d_alpha0);
|
||||
archive& make_nvp("d_alpha1", d_alpha1);
|
||||
archive& make_nvp("d_alpha2", d_alpha2);
|
||||
archive& make_nvp("d_alpha3", d_alpha3);
|
||||
archive& make_nvp("d_beta0", d_beta0);
|
||||
archive& make_nvp("d_beta1", d_beta1);
|
||||
archive& make_nvp("d_beta2", d_beta2);
|
||||
archive& make_nvp("d_beta3", d_beta3);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha0);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha1);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha2);
|
||||
archive& BOOST_SERIALIZATION_NVP(alpha3);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta0);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta1);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta2);
|
||||
archive& BOOST_SERIALIZATION_NVP(beta3);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -426,52 +426,56 @@ double Gps_Navigation_Message::utc_time(const double gpstime_corrected) const
|
||||
Gps_Ephemeris Gps_Navigation_Message::get_ephemeris() const
|
||||
{
|
||||
Gps_Ephemeris ephemeris;
|
||||
ephemeris.i_satellite_PRN = i_satellite_PRN;
|
||||
ephemeris.d_TOW = d_TOW;
|
||||
ephemeris.d_Crs = d_Crs;
|
||||
ephemeris.d_Delta_n = d_Delta_n;
|
||||
ephemeris.d_M_0 = d_M_0;
|
||||
ephemeris.d_Cuc = d_Cuc;
|
||||
ephemeris.d_e_eccentricity = d_e_eccentricity;
|
||||
ephemeris.d_Cus = d_Cus;
|
||||
ephemeris.d_sqrt_A = d_sqrt_A;
|
||||
ephemeris.d_Toe = d_Toe;
|
||||
ephemeris.d_Toc = d_Toc;
|
||||
ephemeris.d_Cic = d_Cic;
|
||||
ephemeris.d_OMEGA0 = d_OMEGA0;
|
||||
ephemeris.d_Cis = d_Cis;
|
||||
ephemeris.d_i_0 = d_i_0;
|
||||
ephemeris.d_Crc = d_Crc;
|
||||
ephemeris.d_OMEGA = d_OMEGA;
|
||||
ephemeris.d_OMEGA_DOT = d_OMEGA_DOT;
|
||||
ephemeris.d_IDOT = d_IDOT;
|
||||
ephemeris.i_code_on_L2 = i_code_on_L2;
|
||||
ephemeris.i_GPS_week = i_GPS_week;
|
||||
ephemeris.b_L2_P_data_flag = b_L2_P_data_flag;
|
||||
ephemeris.i_SV_accuracy = i_SV_accuracy;
|
||||
ephemeris.i_SV_health = i_SV_health;
|
||||
ephemeris.d_TGD = d_TGD;
|
||||
ephemeris.d_IODC = d_IODC;
|
||||
ephemeris.d_IODE_SF2 = d_IODE_SF2;
|
||||
ephemeris.d_IODE_SF3 = d_IODE_SF3;
|
||||
ephemeris.i_AODO = i_AODO;
|
||||
ephemeris.PRN = i_satellite_PRN;
|
||||
ephemeris.tow = d_TOW;
|
||||
ephemeris.Crs = d_Crs;
|
||||
ephemeris.delta_n = d_Delta_n;
|
||||
ephemeris.M_0 = d_M_0;
|
||||
ephemeris.Cuc = d_Cuc;
|
||||
ephemeris.ecc = d_e_eccentricity;
|
||||
ephemeris.Cus = d_Cus;
|
||||
ephemeris.sqrtA = d_sqrt_A;
|
||||
ephemeris.toe = d_Toe;
|
||||
ephemeris.toc = d_Toc;
|
||||
ephemeris.Cic = d_Cic;
|
||||
ephemeris.OMEGA_0 = d_OMEGA0;
|
||||
ephemeris.Cis = d_Cis;
|
||||
ephemeris.i_0 = d_i_0;
|
||||
ephemeris.Crc = d_Crc;
|
||||
ephemeris.omega = d_OMEGA;
|
||||
ephemeris.OMEGAdot = d_OMEGA_DOT;
|
||||
ephemeris.idot = d_IDOT;
|
||||
ephemeris.code_on_L2 = i_code_on_L2;
|
||||
ephemeris.WN = i_GPS_week;
|
||||
ephemeris.L2_P_data_flag = b_L2_P_data_flag;
|
||||
ephemeris.SV_accuracy = i_SV_accuracy;
|
||||
ephemeris.SV_health = i_SV_health;
|
||||
ephemeris.TGD = d_TGD;
|
||||
ephemeris.IODC = d_IODC;
|
||||
ephemeris.IODE_SF2 = d_IODE_SF2;
|
||||
ephemeris.IODE_SF3 = d_IODE_SF3;
|
||||
ephemeris.AODO = i_AODO;
|
||||
ephemeris.b_fit_interval_flag = b_fit_interval_flag;
|
||||
ephemeris.d_spare1 = d_spare1;
|
||||
ephemeris.d_spare2 = d_spare2;
|
||||
ephemeris.d_A_f0 = d_A_f0;
|
||||
ephemeris.d_A_f1 = d_A_f1;
|
||||
ephemeris.d_A_f2 = d_A_f2;
|
||||
ephemeris.af0 = d_A_f0;
|
||||
ephemeris.af1 = d_A_f1;
|
||||
ephemeris.af2 = d_A_f2;
|
||||
ephemeris.b_integrity_status_flag = b_integrity_status_flag;
|
||||
ephemeris.b_alert_flag = b_alert_flag;
|
||||
ephemeris.b_antispoofing_flag = b_antispoofing_flag;
|
||||
ephemeris.d_satClkDrift = d_satClkDrift;
|
||||
ephemeris.d_dtr = d_dtr;
|
||||
ephemeris.d_satpos_X = d_satpos_X;
|
||||
ephemeris.d_satpos_Y = d_satpos_Y;
|
||||
ephemeris.d_satpos_Z = d_satpos_Z;
|
||||
ephemeris.d_satvel_X = d_satvel_X;
|
||||
ephemeris.d_satvel_Y = d_satvel_Y;
|
||||
ephemeris.d_satvel_Z = d_satvel_Z;
|
||||
|
||||
// These parameters are empty; can be computed later with
|
||||
// ephemeris.sv_clock_drift(double transmitTime);
|
||||
// ephemeris.satellitePosition(double transmitTime);
|
||||
ephemeris.satClkDrift = d_satClkDrift;
|
||||
ephemeris.dtr = d_dtr;
|
||||
ephemeris.satpos_X = d_satpos_X;
|
||||
ephemeris.satpos_Y = d_satpos_Y;
|
||||
ephemeris.satpos_Z = d_satpos_Z;
|
||||
ephemeris.satvel_X = d_satvel_X;
|
||||
ephemeris.satvel_Y = d_satvel_Y;
|
||||
ephemeris.satvel_Z = d_satvel_Z;
|
||||
|
||||
return ephemeris;
|
||||
}
|
||||
@ -480,14 +484,14 @@ Gps_Ephemeris Gps_Navigation_Message::get_ephemeris() const
|
||||
Gps_Iono Gps_Navigation_Message::get_iono()
|
||||
{
|
||||
Gps_Iono iono;
|
||||
iono.d_alpha0 = d_alpha0;
|
||||
iono.d_alpha1 = d_alpha1;
|
||||
iono.d_alpha2 = d_alpha2;
|
||||
iono.d_alpha3 = d_alpha3;
|
||||
iono.d_beta0 = d_beta0;
|
||||
iono.d_beta1 = d_beta1;
|
||||
iono.d_beta2 = d_beta2;
|
||||
iono.d_beta3 = d_beta3;
|
||||
iono.alpha0 = d_alpha0;
|
||||
iono.alpha1 = d_alpha1;
|
||||
iono.alpha2 = d_alpha2;
|
||||
iono.alpha3 = d_alpha3;
|
||||
iono.beta0 = d_beta0;
|
||||
iono.beta1 = d_beta1;
|
||||
iono.beta2 = d_beta2;
|
||||
iono.beta3 = d_beta3;
|
||||
iono.valid = flag_iono_valid;
|
||||
// WARNING: We clear flag_utc_model_valid in order to not re-send the same information to the ionospheric parameters queue
|
||||
flag_iono_valid = false;
|
||||
@ -500,14 +504,14 @@ Gps_Utc_Model Gps_Navigation_Message::get_utc_model()
|
||||
Gps_Utc_Model utc_model;
|
||||
utc_model.valid = flag_utc_model_valid;
|
||||
// UTC parameters
|
||||
utc_model.d_A1 = d_A1;
|
||||
utc_model.d_A0 = d_A0;
|
||||
utc_model.d_t_OT = d_t_OT;
|
||||
utc_model.i_WN_T = i_WN_T;
|
||||
utc_model.d_DeltaT_LS = d_DeltaT_LS;
|
||||
utc_model.i_WN_LSF = i_WN_LSF;
|
||||
utc_model.i_DN = i_DN;
|
||||
utc_model.d_DeltaT_LSF = d_DeltaT_LSF;
|
||||
utc_model.A1 = d_A1;
|
||||
utc_model.A0 = d_A0;
|
||||
utc_model.tot = d_t_OT;
|
||||
utc_model.WN_T = i_WN_T;
|
||||
utc_model.DeltaT_LS = d_DeltaT_LS;
|
||||
utc_model.WN_LSF = i_WN_LSF;
|
||||
utc_model.DN = i_DN;
|
||||
utc_model.DeltaT_LSF = d_DeltaT_LSF;
|
||||
// warning: We clear flag_utc_model_valid in order to not re-send the same information to the ionospheric parameters queue
|
||||
flag_utc_model_valid = false;
|
||||
return utc_model;
|
||||
|
@ -41,37 +41,37 @@ public:
|
||||
Gps_Utc_Model() = default;
|
||||
|
||||
// UTC parameters
|
||||
double d_A0{}; //!< Constant of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
double d_A1{}; //!< 1st order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
double d_A2{}; //!< 2nd order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
int32_t d_t_OT{}; //!< Reference time for UTC data (reference 20.3.4.5 and 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
int32_t i_WN_T{}; //!< UTC reference week number [weeks]
|
||||
int32_t d_DeltaT_LS{}; //!< delta time due to leap seconds [s]. Number of leap seconds since 6-Jan-1980 as transmitted by the GPS almanac.
|
||||
int32_t i_WN_LSF{}; //!< Week number at the end of which the leap second becomes effective [weeks]
|
||||
int32_t i_DN{}; //!< Day number (DN) at the end of which the leap second becomes effective [days]
|
||||
int32_t d_DeltaT_LSF{}; //!< Scheduled future or recent past (relative to NAV message upload) value of the delta time due to leap seconds [s]
|
||||
double A0{}; //!< Constant of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
double A1{}; //!< 1st order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
double A2{}; //!< 2nd order term of a model that relates GPS and UTC time (ref. 20.3.3.5.2.4 IS-GPS-200L) [s/s]
|
||||
int32_t tot{}; //!< Reference time for UTC data (reference 20.3.4.5 and 20.3.3.5.2.4 IS-GPS-200L) [s]
|
||||
int32_t WN_T{}; //!< UTC reference week number [weeks]
|
||||
int32_t DeltaT_LS{}; //!< Delta time due to leap seconds [s]. Number of leap seconds since 6-Jan-1980 as transmitted by the GPS almanac.
|
||||
int32_t WN_LSF{}; //!< Week number at the end of which the leap second becomes effective [weeks]
|
||||
int32_t DN{}; //!< Day number (DN) at the end of which the leap second becomes effective [days]
|
||||
int32_t DeltaT_LSF{}; //!< Scheduled future or recent past (relative to NAV message upload) value of the delta time due to leap seconds [s]
|
||||
|
||||
bool valid{};
|
||||
|
||||
template <class Archive>
|
||||
/*
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML serialization. Here is used to save the ephemeris data on disk file.
|
||||
* \brief Serialize is a boost standard method to be called by the boost XML
|
||||
* serialization. Here is used to save the ephemeris data on disk file.
|
||||
*/
|
||||
inline void serialize(Archive& archive, const uint32_t version)
|
||||
{
|
||||
using boost::serialization::make_nvp;
|
||||
if (version)
|
||||
{
|
||||
};
|
||||
archive& make_nvp("d_A1", d_A1);
|
||||
archive& make_nvp("d_A0", d_A0);
|
||||
archive& make_nvp("d_t_OT", d_t_OT);
|
||||
archive& make_nvp("i_WN_T", i_WN_T);
|
||||
archive& make_nvp("d_DeltaT_LS", d_DeltaT_LS);
|
||||
archive& make_nvp("i_WN_LSF", i_WN_LSF);
|
||||
archive& make_nvp("i_DN", i_DN);
|
||||
archive& make_nvp("d_DeltaT_LSF", d_DeltaT_LSF);
|
||||
archive& make_nvp("valid", valid);
|
||||
archive& BOOST_SERIALIZATION_NVP(A1);
|
||||
archive& BOOST_SERIALIZATION_NVP(A0);
|
||||
archive& BOOST_SERIALIZATION_NVP(tot);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN_T);
|
||||
archive& BOOST_SERIALIZATION_NVP(DeltaT_LS);
|
||||
archive& BOOST_SERIALIZATION_NVP(WN_LSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(DN);
|
||||
archive& BOOST_SERIALIZATION_NVP(DeltaT_LSF);
|
||||
archive& BOOST_SERIALIZATION_NVP(valid);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -143,7 +143,7 @@ TEST_F(RinexPrinterTest, GalileoObsHeader)
|
||||
{
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
auto eph = Galileo_Ephemeris();
|
||||
eph.i_satellite_PRN = 1;
|
||||
eph.PRN = 1;
|
||||
pvt_solution->galileo_ephemeris_map[1] = eph;
|
||||
|
||||
std::map<int, Gnss_Synchro> gnss_observables_map;
|
||||
@ -229,7 +229,7 @@ TEST_F(RinexPrinterTest, GlonassObsHeader)
|
||||
{
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
auto eph = Glonass_Gnav_Ephemeris();
|
||||
eph.i_satellite_PRN = 1;
|
||||
eph.PRN = 1;
|
||||
pvt_solution->glonass_gnav_ephemeris_map[1] = eph;
|
||||
|
||||
std::map<int, Gnss_Synchro> gnss_observables_map;
|
||||
@ -285,8 +285,8 @@ TEST_F(RinexPrinterTest, MixedObsHeader)
|
||||
bool no_more_finds = false;
|
||||
auto eph_gal = Galileo_Ephemeris();
|
||||
auto eph_gps = Gps_Ephemeris();
|
||||
eph_gal.i_satellite_PRN = 1;
|
||||
eph_gps.i_satellite_PRN = 1;
|
||||
eph_gal.PRN = 1;
|
||||
eph_gps.PRN = 1;
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
pvt_solution->galileo_ephemeris_map[1] = eph_gal;
|
||||
|
||||
@ -355,8 +355,8 @@ TEST_F(RinexPrinterTest, MixedObsHeaderGpsGlo)
|
||||
bool no_more_finds = false;
|
||||
auto eph_glo = Glonass_Gnav_Ephemeris();
|
||||
auto eph_gps = Gps_Ephemeris();
|
||||
eph_glo.i_satellite_PRN = 1;
|
||||
eph_gps.i_satellite_PRN = 1;
|
||||
eph_glo.PRN = 1;
|
||||
eph_gps.PRN = 1;
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
pvt_solution->glonass_gnav_ephemeris_map[1] = eph_glo;
|
||||
|
||||
@ -423,7 +423,7 @@ TEST_F(RinexPrinterTest, GalileoObsLog)
|
||||
std::string line_str;
|
||||
bool no_more_finds = false;
|
||||
auto eph = Galileo_Ephemeris();
|
||||
eph.i_satellite_PRN = 1;
|
||||
eph.PRN = 1;
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
pvt_solution->galileo_ephemeris_map[1] = eph;
|
||||
std::map<int, Gnss_Synchro> gnss_observables_map;
|
||||
@ -503,7 +503,7 @@ TEST_F(RinexPrinterTest, GlonassObsLog)
|
||||
std::string line_str;
|
||||
bool no_more_finds = false;
|
||||
auto eph = Glonass_Gnav_Ephemeris();
|
||||
eph.i_satellite_PRN = 22;
|
||||
eph.PRN = 22;
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
pvt_solution->glonass_gnav_ephemeris_map[1] = eph;
|
||||
std::map<int, Gnss_Synchro> gnss_observables_map;
|
||||
@ -584,8 +584,8 @@ TEST_F(RinexPrinterTest, GpsObsLogDualBand)
|
||||
bool no_more_finds = false;
|
||||
auto eph = Gps_Ephemeris();
|
||||
auto eph_cnav = Gps_CNAV_Ephemeris();
|
||||
eph.i_satellite_PRN = 1;
|
||||
eph_cnav.i_satellite_PRN = 1;
|
||||
eph.PRN = 1;
|
||||
eph_cnav.PRN = 1;
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
pvt_solution->gps_ephemeris_map[1] = eph;
|
||||
pvt_solution->gps_cnav_ephemeris_map[1] = eph_cnav;
|
||||
@ -676,7 +676,7 @@ TEST_F(RinexPrinterTest, GalileoObsLogDualBand)
|
||||
{
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
auto eph = Galileo_Ephemeris();
|
||||
eph.i_satellite_PRN = 1;
|
||||
eph.PRN = 1;
|
||||
pvt_solution->galileo_ephemeris_map[1] = eph;
|
||||
|
||||
std::map<int, Gnss_Synchro> gnss_observables_map;
|
||||
@ -772,8 +772,8 @@ TEST_F(RinexPrinterTest, MixedObsLog)
|
||||
bool no_more_finds = false;
|
||||
auto eph_gps = Gps_Ephemeris();
|
||||
auto eph_gal = Galileo_Ephemeris();
|
||||
eph_gps.i_satellite_PRN = 1;
|
||||
eph_gal.i_satellite_PRN = 1;
|
||||
eph_gps.PRN = 1;
|
||||
eph_gal.PRN = 1;
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
pvt_solution->gps_ephemeris_map[1] = eph_gps;
|
||||
pvt_solution->galileo_ephemeris_map[1] = eph_gal;
|
||||
@ -896,8 +896,8 @@ TEST_F(RinexPrinterTest, MixedObsLogGpsGlo)
|
||||
bool no_more_finds = false;
|
||||
auto eph_gps = Gps_Ephemeris();
|
||||
auto eph_glo = Glonass_Gnav_Ephemeris();
|
||||
eph_gps.i_satellite_PRN = 1;
|
||||
eph_glo.i_satellite_PRN = 1;
|
||||
eph_gps.PRN = 1;
|
||||
eph_glo.PRN = 1;
|
||||
auto pvt_solution = std::make_shared<Rtklib_Solver>(rtk, 12, "filename", false, false);
|
||||
pvt_solution->gps_ephemeris_map[1] = eph_gps;
|
||||
pvt_solution->glonass_gnav_ephemeris_map[1] = eph_glo;
|
||||
|
@ -247,16 +247,16 @@ TEST(RtcmTest, MT1019)
|
||||
Gps_Ephemeris gps_eph = Gps_Ephemeris();
|
||||
Gps_Ephemeris gps_eph_read = Gps_Ephemeris();
|
||||
|
||||
gps_eph.i_satellite_PRN = 3;
|
||||
gps_eph.d_IODC = 4;
|
||||
gps_eph.d_e_eccentricity = 2.0 * ECCENTRICITY_LSB;
|
||||
gps_eph.PRN = 3;
|
||||
gps_eph.IODC = 4;
|
||||
gps_eph.ecc = 2.0 * ECCENTRICITY_LSB;
|
||||
gps_eph.b_fit_interval_flag = true;
|
||||
std::string tx_msg = rtcm->print_MT1019(gps_eph);
|
||||
|
||||
EXPECT_EQ(0, rtcm->read_MT1019(tx_msg, gps_eph_read));
|
||||
EXPECT_EQ(static_cast<unsigned int>(3), gps_eph_read.i_satellite_PRN);
|
||||
EXPECT_DOUBLE_EQ(4, gps_eph_read.d_IODC);
|
||||
EXPECT_DOUBLE_EQ(2.0 * ECCENTRICITY_LSB, gps_eph_read.d_e_eccentricity);
|
||||
EXPECT_EQ(static_cast<unsigned int>(3), gps_eph_read.PRN);
|
||||
EXPECT_DOUBLE_EQ(4, gps_eph_read.IODC);
|
||||
EXPECT_DOUBLE_EQ(2.0 * ECCENTRICITY_LSB, gps_eph_read.ecc);
|
||||
EXPECT_EQ(expected_true, gps_eph_read.b_fit_interval_flag);
|
||||
EXPECT_EQ(1, rtcm->read_MT1019(rtcm->bin_to_binary_data(rtcm->hex_to_bin("FFFFFFFFFFF")), gps_eph_read));
|
||||
}
|
||||
@ -322,16 +322,16 @@ TEST(RtcmTest, MT1045)
|
||||
Galileo_Ephemeris gal_eph = Galileo_Ephemeris();
|
||||
Galileo_Ephemeris gal_eph_read = Galileo_Ephemeris();
|
||||
|
||||
gal_eph.i_satellite_PRN = 5;
|
||||
gal_eph.OMEGA_dot_3 = 53.0 * OMEGA_DOT_3_LSB;
|
||||
gal_eph.PRN = 5;
|
||||
gal_eph.OMEGAdot = 53.0 * OMEGA_DOT_3_LSB;
|
||||
gal_eph.E5a_DVS = true;
|
||||
|
||||
std::string tx_msg = rtcm->print_MT1045(gal_eph);
|
||||
|
||||
EXPECT_EQ(0, rtcm->read_MT1045(tx_msg, gal_eph_read));
|
||||
EXPECT_EQ(expected_true, gal_eph_read.E5a_DVS);
|
||||
EXPECT_DOUBLE_EQ(53.0 * OMEGA_DOT_3_LSB, gal_eph_read.OMEGA_dot_3);
|
||||
EXPECT_EQ(static_cast<unsigned int>(5), gal_eph_read.i_satellite_PRN);
|
||||
EXPECT_DOUBLE_EQ(53.0 * OMEGA_DOT_3_LSB, gal_eph_read.OMEGAdot);
|
||||
EXPECT_EQ(static_cast<unsigned int>(5), gal_eph_read.PRN);
|
||||
EXPECT_EQ(1, rtcm->read_MT1045(rtcm->bin_to_binary_data(rtcm->hex_to_bin("FFFFFFFFFFF")), gal_eph_read));
|
||||
}
|
||||
|
||||
@ -402,9 +402,9 @@ TEST(RtcmTest, MSMCell)
|
||||
bool more_messages = false;
|
||||
double obs_time = 25.0;
|
||||
|
||||
gps_eph.i_satellite_PRN = gnss_synchro2.PRN;
|
||||
gal_eph.i_satellite_PRN = gnss_synchro.PRN;
|
||||
// glo_gnav_eph.i_satellite_PRN = gnss_synchro.PRN;
|
||||
gps_eph.PRN = gnss_synchro2.PRN;
|
||||
gal_eph.PRN = gnss_synchro.PRN;
|
||||
// glo_gnav_eph.PRN = gnss_synchro.PRN;
|
||||
|
||||
std::string MSM1 = rtcm->print_MSM_1(gps_eph,
|
||||
{},
|
||||
@ -529,7 +529,7 @@ TEST(RtcmTest, MSM1)
|
||||
bool more_messages = false;
|
||||
double obs_time = 25.0;
|
||||
|
||||
gps_eph.i_satellite_PRN = gnss_synchro.PRN;
|
||||
gps_eph.PRN = gnss_synchro.PRN;
|
||||
|
||||
std::string MSM1 = rtcm->print_MSM_1(gps_eph,
|
||||
{}, {}, {},
|
||||
|
@ -56,8 +56,8 @@ bool FrontEndCal::read_assistance_from_XML()
|
||||
{
|
||||
std::cout << "SUPL: Read XML Ephemeris for GPS SV " << gps_eph_iter->first << '\n';
|
||||
LOG(INFO) << "SUPL: Read XML Ephemeris for GPS SV " << gps_eph_iter->first;
|
||||
LOG(INFO) << "New Ephemeris record inserted with Toe=" << gps_eph_iter->second.d_Toe << " and GPS Week=" << gps_eph_iter->second.i_GPS_week;
|
||||
global_gps_ephemeris_map.write(gps_eph_iter->second.i_satellite_PRN, gps_eph_iter->second);
|
||||
LOG(INFO) << "New Ephemeris record inserted with Toe=" << gps_eph_iter->second.toe << " and GPS Week=" << gps_eph_iter->second.WN;
|
||||
global_gps_ephemeris_map.write(gps_eph_iter->second.PRN, gps_eph_iter->second);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
@ -134,8 +134,8 @@ int FrontEndCal::Get_SUPL_Assist()
|
||||
{
|
||||
LOG(INFO) << "SUPL: Received Ephemeris for GPS SV " << gps_eph_iter->first;
|
||||
std::cout << "SUPL: Received Ephemeris for GPS SV " << gps_eph_iter->first << '\n';
|
||||
LOG(INFO) << "New Ephemeris record inserted with Toe=" << gps_eph_iter->second.d_Toe << " and GPS Week=" << gps_eph_iter->second.i_GPS_week;
|
||||
global_gps_ephemeris_map.write(gps_eph_iter->second.i_satellite_PRN, gps_eph_iter->second);
|
||||
LOG(INFO) << "New Ephemeris record inserted with Toe=" << gps_eph_iter->second.toe << " and GPS Week=" << gps_eph_iter->second.WN;
|
||||
global_gps_ephemeris_map.write(gps_eph_iter->second.PRN, gps_eph_iter->second);
|
||||
}
|
||||
// Save ephemeris to XML file
|
||||
std::string eph_xml_filename = configuration_->property("GNSS-SDR.SUPL_gps_ephemeris_xml", eph_default_xml_filename);
|
||||
@ -200,7 +200,7 @@ int FrontEndCal::Get_SUPL_Assist()
|
||||
LOG(INFO) << "SUPL: Received Acquisition assistance for GPS SV " << gps_acq_iter->first;
|
||||
std::cout << "SUPL: Received Acquisition assistance for GPS SV " << gps_acq_iter->first << '\n';
|
||||
LOG(INFO) << "New acq assist record inserted";
|
||||
global_gps_acq_assist_map.write(gps_acq_iter->second.i_satellite_PRN, gps_acq_iter->second);
|
||||
global_gps_acq_assist_map.write(gps_acq_iter->second.PRN, gps_acq_iter->second);
|
||||
}
|
||||
}
|
||||
else
|
||||
@ -323,9 +323,9 @@ double FrontEndCal::estimate_doppler_from_eph(unsigned int PRN, double tow, doub
|
||||
for (int i = 0; i < n_points; i++)
|
||||
{
|
||||
eph_it->second.satellitePosition(obs_time);
|
||||
SV_pos_ecef(0) = eph_it->second.d_satpos_X;
|
||||
SV_pos_ecef(1) = eph_it->second.d_satpos_Y;
|
||||
SV_pos_ecef(2) = eph_it->second.d_satpos_Z;
|
||||
SV_pos_ecef(0) = eph_it->second.satpos_X;
|
||||
SV_pos_ecef(1) = eph_it->second.satpos_Y;
|
||||
SV_pos_ecef(2) = eph_it->second.satpos_Z;
|
||||
// SV distances to observer (true range)
|
||||
ranges(i) = arma::norm(SV_pos_ecef - obs_ecef, 2);
|
||||
obs_time += step_secs;
|
||||
|
@ -495,12 +495,12 @@ int main(int argc, char** argv)
|
||||
{
|
||||
std::map<int, Gps_Ephemeris> Eph_map;
|
||||
Eph_map = global_gps_ephemeris_map.get_map_copy();
|
||||
current_TOW = Eph_map.begin()->second.d_TOW;
|
||||
current_TOW = Eph_map.begin()->second.tow;
|
||||
|
||||
time_t t = utc_time(Eph_map.begin()->second.i_GPS_week, static_cast<int64_t>(current_TOW));
|
||||
time_t t = utc_time(Eph_map.begin()->second.WN, static_cast<int64_t>(current_TOW));
|
||||
|
||||
std::cout << "Reference Time:\n";
|
||||
std::cout << " GPS Week: " << Eph_map.begin()->second.i_GPS_week << '\n';
|
||||
std::cout << " GPS Week: " << Eph_map.begin()->second.WN << '\n';
|
||||
std::cout << " GPS TOW: " << static_cast<int64_t>(current_TOW) << " " << static_cast<int64_t>(current_TOW) * 0.08 << '\n';
|
||||
std::cout << " ~ UTC: " << ctime(&t) << '\n';
|
||||
std::cout << "Current TOW obtained from SUPL assistance = " << current_TOW << '\n';
|
||||
|
@ -174,47 +174,47 @@ int main(int argc, char** argv)
|
||||
if (hdr.fileSys == "G: (GPS)" || hdr.fileSys == "MIXED")
|
||||
{
|
||||
gps_utc_model.valid = (hdr.valid > 2147483648) ? true : false;
|
||||
gps_utc_model.d_A1 = hdr.mapTimeCorr["GPUT"].A0;
|
||||
gps_utc_model.d_A0 = hdr.mapTimeCorr["GPUT"].A1;
|
||||
gps_utc_model.d_t_OT = hdr.mapTimeCorr["GPUT"].refSOW;
|
||||
gps_utc_model.i_WN_T = hdr.mapTimeCorr["GPUT"].refWeek;
|
||||
gps_utc_model.d_DeltaT_LS = hdr.leapSeconds;
|
||||
gps_utc_model.i_WN_LSF = hdr.leapWeek;
|
||||
gps_utc_model.i_DN = hdr.leapDay;
|
||||
gps_utc_model.d_DeltaT_LSF = hdr.leapDelta;
|
||||
gps_utc_model.A1 = hdr.mapTimeCorr["GPUT"].A0;
|
||||
gps_utc_model.A0 = hdr.mapTimeCorr["GPUT"].A1;
|
||||
gps_utc_model.tot = hdr.mapTimeCorr["GPUT"].refSOW;
|
||||
gps_utc_model.WN_T = hdr.mapTimeCorr["GPUT"].refWeek;
|
||||
gps_utc_model.DeltaT_LS = hdr.leapSeconds;
|
||||
gps_utc_model.WN_LSF = hdr.leapWeek;
|
||||
gps_utc_model.DN = hdr.leapDay;
|
||||
gps_utc_model.DeltaT_LSF = hdr.leapDelta;
|
||||
|
||||
// Collect iono parameters from RINEX header
|
||||
gps_iono.valid = (hdr.mapIonoCorr["GPSA"].param[0] == 0) ? false : true;
|
||||
gps_iono.d_alpha0 = hdr.mapIonoCorr["GPSA"].param[0];
|
||||
gps_iono.d_alpha1 = hdr.mapIonoCorr["GPSA"].param[1];
|
||||
gps_iono.d_alpha2 = hdr.mapIonoCorr["GPSA"].param[2];
|
||||
gps_iono.d_alpha3 = hdr.mapIonoCorr["GPSA"].param[3];
|
||||
gps_iono.d_beta0 = hdr.mapIonoCorr["GPSB"].param[0];
|
||||
gps_iono.d_beta1 = hdr.mapIonoCorr["GPSB"].param[1];
|
||||
gps_iono.d_beta2 = hdr.mapIonoCorr["GPSB"].param[2];
|
||||
gps_iono.d_beta3 = hdr.mapIonoCorr["GPSB"].param[3];
|
||||
gps_iono.alpha0 = hdr.mapIonoCorr["GPSA"].param[0];
|
||||
gps_iono.alpha1 = hdr.mapIonoCorr["GPSA"].param[1];
|
||||
gps_iono.alpha2 = hdr.mapIonoCorr["GPSA"].param[2];
|
||||
gps_iono.alpha3 = hdr.mapIonoCorr["GPSA"].param[3];
|
||||
gps_iono.beta0 = hdr.mapIonoCorr["GPSB"].param[0];
|
||||
gps_iono.beta1 = hdr.mapIonoCorr["GPSB"].param[1];
|
||||
gps_iono.beta2 = hdr.mapIonoCorr["GPSB"].param[2];
|
||||
gps_iono.beta3 = hdr.mapIonoCorr["GPSB"].param[3];
|
||||
}
|
||||
if (hdr.fileSys == "E: (GAL)" || hdr.fileSys == "MIXED")
|
||||
{
|
||||
gal_utc_model.A0_6 = hdr.mapTimeCorr["GAUT"].A0;
|
||||
gal_utc_model.A1_6 = hdr.mapTimeCorr["GAUT"].A1;
|
||||
gal_utc_model.Delta_tLS_6 = hdr.leapSeconds;
|
||||
gal_utc_model.t0t_6 = hdr.mapTimeCorr["GAUT"].refSOW;
|
||||
gal_utc_model.WNot_6 = hdr.mapTimeCorr["GAUT"].refWeek;
|
||||
gal_utc_model.WN_LSF_6 = hdr.leapWeek;
|
||||
gal_utc_model.DN_6 = hdr.leapDay;
|
||||
gal_utc_model.Delta_tLSF_6 = hdr.leapDelta;
|
||||
gal_utc_model.A0 = hdr.mapTimeCorr["GAUT"].A0;
|
||||
gal_utc_model.A1 = hdr.mapTimeCorr["GAUT"].A1;
|
||||
gal_utc_model.Delta_tLS = hdr.leapSeconds;
|
||||
gal_utc_model.tot = hdr.mapTimeCorr["GAUT"].refSOW;
|
||||
gal_utc_model.WNot = hdr.mapTimeCorr["GAUT"].refWeek;
|
||||
gal_utc_model.WN_LSF = hdr.leapWeek;
|
||||
gal_utc_model.DN = hdr.leapDay;
|
||||
gal_utc_model.Delta_tLSF = hdr.leapDelta;
|
||||
gal_utc_model.flag_utc_model = (hdr.mapTimeCorr["GAUT"].A0 == 0.0);
|
||||
gal_iono.ai0_5 = hdr.mapIonoCorr["GAL"].param[0];
|
||||
gal_iono.ai1_5 = hdr.mapIonoCorr["GAL"].param[1];
|
||||
gal_iono.ai2_5 = hdr.mapIonoCorr["GAL"].param[2];
|
||||
gal_iono.Region1_flag_5 = false;
|
||||
gal_iono.Region2_flag_5 = false;
|
||||
gal_iono.Region3_flag_5 = false;
|
||||
gal_iono.Region4_flag_5 = false;
|
||||
gal_iono.Region5_flag_5 = false;
|
||||
gal_iono.TOW_5 = 0.0;
|
||||
gal_iono.WN_5 = 0.0;
|
||||
gal_iono.ai0 = hdr.mapIonoCorr["GAL"].param[0];
|
||||
gal_iono.ai1 = hdr.mapIonoCorr["GAL"].param[1];
|
||||
gal_iono.ai2 = hdr.mapIonoCorr["GAL"].param[2];
|
||||
gal_iono.Region1_flag = false;
|
||||
gal_iono.Region2_flag = false;
|
||||
gal_iono.Region3_flag = false;
|
||||
gal_iono.Region4_flag = false;
|
||||
gal_iono.Region5_flag = false;
|
||||
gal_iono.tow = 0.0;
|
||||
gal_iono.WN = 0.0;
|
||||
}
|
||||
|
||||
// Read navigation data
|
||||
@ -224,41 +224,41 @@ int main(int argc, char** argv)
|
||||
{
|
||||
// Fill GPS ephemeris object
|
||||
Gps_Ephemeris eph;
|
||||
eph.i_satellite_PRN = rne.PRNID;
|
||||
eph.d_TOW = rne.xmitTime;
|
||||
eph.d_IODE_SF2 = rne.IODE;
|
||||
eph.d_IODE_SF3 = rne.IODE;
|
||||
eph.d_Crs = rne.Crs;
|
||||
eph.d_Delta_n = rne.dn;
|
||||
eph.d_M_0 = rne.M0;
|
||||
eph.d_Cuc = rne.Cuc;
|
||||
eph.d_e_eccentricity = rne.ecc;
|
||||
eph.d_Cus = rne.Cus;
|
||||
eph.d_sqrt_A = rne.Ahalf;
|
||||
eph.d_Toe = rne.Toe;
|
||||
eph.d_Toc = rne.Toc;
|
||||
eph.d_Cic = rne.Cic;
|
||||
eph.d_OMEGA0 = rne.OMEGA0;
|
||||
eph.d_Cis = rne.Cis;
|
||||
eph.d_i_0 = rne.i0;
|
||||
eph.d_Crc = rne.Crc;
|
||||
eph.d_OMEGA = rne.w;
|
||||
eph.d_OMEGA_DOT = rne.OMEGAdot;
|
||||
eph.d_IDOT = rne.idot;
|
||||
eph.i_code_on_L2 = rne.codeflgs; //
|
||||
eph.i_GPS_week = rne.weeknum;
|
||||
eph.b_L2_P_data_flag = rne.L2Pdata;
|
||||
eph.i_SV_accuracy = rne.accuracy;
|
||||
eph.i_SV_health = rne.health;
|
||||
eph.d_TGD = rne.Tgd;
|
||||
eph.d_IODC = rne.IODC;
|
||||
eph.i_AODO = 0; //
|
||||
eph.PRN = rne.PRNID;
|
||||
eph.tow = rne.xmitTime;
|
||||
eph.IODE_SF2 = rne.IODE;
|
||||
eph.IODE_SF3 = rne.IODE;
|
||||
eph.Crs = rne.Crs;
|
||||
eph.delta_n = rne.dn;
|
||||
eph.M_0 = rne.M0;
|
||||
eph.Cuc = rne.Cuc;
|
||||
eph.ecc = rne.ecc;
|
||||
eph.Cus = rne.Cus;
|
||||
eph.sqrtA = rne.Ahalf;
|
||||
eph.toe = rne.Toe;
|
||||
eph.toc = rne.Toc;
|
||||
eph.Cic = rne.Cic;
|
||||
eph.OMEGA_0 = rne.OMEGA0;
|
||||
eph.Cis = rne.Cis;
|
||||
eph.i_0 = rne.i0;
|
||||
eph.Crc = rne.Crc;
|
||||
eph.omega = rne.w;
|
||||
eph.OMEGAdot = rne.OMEGAdot;
|
||||
eph.idot = rne.idot;
|
||||
eph.code_on_L2 = rne.codeflgs; //
|
||||
eph.WN = rne.weeknum;
|
||||
eph.L2_P_data_flag = rne.L2Pdata;
|
||||
eph.SV_accuracy = rne.accuracy;
|
||||
eph.SV_health = rne.health;
|
||||
eph.TGD = rne.Tgd;
|
||||
eph.IODC = rne.IODC;
|
||||
eph.AODO = 0; //
|
||||
eph.b_fit_interval_flag = (rne.fitint > 4) ? true : false;
|
||||
eph.d_spare1 = 0.0;
|
||||
eph.d_spare2 = 0.0;
|
||||
eph.d_A_f0 = rne.af0;
|
||||
eph.d_A_f1 = rne.af1;
|
||||
eph.d_A_f2 = rne.af2;
|
||||
eph.af0 = rne.af0;
|
||||
eph.af1 = rne.af1;
|
||||
eph.af2 = rne.af2;
|
||||
eph.b_integrity_status_flag = false; //
|
||||
eph.b_alert_flag = false; //
|
||||
eph.b_antispoofing_flag = false; //
|
||||
@ -269,28 +269,28 @@ int main(int argc, char** argv)
|
||||
{
|
||||
// Fill Galileo ephemeris object
|
||||
Galileo_Ephemeris eph;
|
||||
eph.i_satellite_PRN = rne.PRNID;
|
||||
eph.M0_1 = rne.M0;
|
||||
eph.e_1 = rne.ecc;
|
||||
eph.A_1 = rne.Ahalf;
|
||||
eph.OMEGA_0_2 = rne.OMEGA0;
|
||||
eph.i_0_2 = rne.i0;
|
||||
eph.omega_2 = rne.w;
|
||||
eph.OMEGA_dot_3 = rne.OMEGAdot;
|
||||
eph.delta_n_3 = rne.dn;
|
||||
eph.iDot_2 = rne.idot;
|
||||
eph.C_uc_3 = rne.Cuc;
|
||||
eph.C_us_3 = rne.Cus;
|
||||
eph.C_rc_3 = rne.Crc;
|
||||
eph.C_rs_3 = rne.Crs;
|
||||
eph.C_ic_4 = rne.Cic;
|
||||
eph.C_is_4 = rne.Cis;
|
||||
eph.t0e_1 = rne.Toe;
|
||||
eph.t0c_4 = rne.Toc;
|
||||
eph.af0_4 = rne.af0;
|
||||
eph.af1_4 = rne.af1;
|
||||
eph.af2_4 = rne.af2;
|
||||
eph.WN_5 = rne.weeknum;
|
||||
eph.PRN = rne.PRNID;
|
||||
eph.M_0 = rne.M0;
|
||||
eph.ecc = rne.ecc;
|
||||
eph.sqrtA = rne.Ahalf;
|
||||
eph.OMEGA_0 = rne.OMEGA0;
|
||||
eph.i_0 = rne.i0;
|
||||
eph.omega = rne.w;
|
||||
eph.OMEGAdot = rne.OMEGAdot;
|
||||
eph.delta_n = rne.dn;
|
||||
eph.idot = rne.idot;
|
||||
eph.Cuc = rne.Cuc;
|
||||
eph.Cus = rne.Cus;
|
||||
eph.Crc = rne.Crc;
|
||||
eph.Crs = rne.Crs;
|
||||
eph.Cic = rne.Cic;
|
||||
eph.Cis = rne.Cis;
|
||||
eph.toe = rne.Toe;
|
||||
eph.toc = rne.Toc;
|
||||
eph.af0 = rne.af0;
|
||||
eph.af1 = rne.af1;
|
||||
eph.af2 = rne.af2;
|
||||
eph.WN = rne.weeknum;
|
||||
eph_gal_map[j] = eph;
|
||||
j++;
|
||||
}
|
||||
@ -392,7 +392,7 @@ int main(int argc, char** argv)
|
||||
std::cout << "Generated file: " << xml_filename << '\n';
|
||||
}
|
||||
|
||||
if (gal_utc_model.A0_6 != 0)
|
||||
if (gal_utc_model.A0 != 0)
|
||||
{
|
||||
std::ofstream ofs5;
|
||||
xml_filename = "gal_utc_model.xml";
|
||||
@ -410,7 +410,7 @@ int main(int argc, char** argv)
|
||||
}
|
||||
std::cout << "Generated file: " << xml_filename << '\n';
|
||||
}
|
||||
if (gal_iono.ai0_5 != 0)
|
||||
if (gal_iono.ai0 != 0)
|
||||
{
|
||||
std::ofstream ofs7;
|
||||
xml_filename = "gal_iono.xml";
|
||||
|
Loading…
Reference in New Issue
Block a user