mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-23 15:36:58 +00:00
Log ISM data
This commit is contained in:
parent
de6f991811
commit
f6f58fd45e
@ -1332,7 +1332,7 @@ int32_t Galileo_Inav_Message::page_jk_decoder(const char* data_jk)
|
|||||||
gal_ism.set_ism_service_level_id(ism_service_level_id);
|
gal_ism.set_ism_service_level_id(ism_service_level_id);
|
||||||
if (ism_constellation_id == 0)
|
if (ism_constellation_id == 0)
|
||||||
{
|
{
|
||||||
DLOG(INFO) << "I/NAV ARAIM Integrity Support Message in Test";
|
LOG(INFO) << "I/NAV ARAIM Integrity Support Message in Test";
|
||||||
}
|
}
|
||||||
if (ism_constellation_id == 1)
|
if (ism_constellation_id == 1)
|
||||||
{
|
{
|
||||||
@ -1348,6 +1348,17 @@ int32_t Galileo_Inav_Message::page_jk_decoder(const char* data_jk)
|
|||||||
gal_ism.set_ism_ure(read_octet_unsigned(data_jk_bits, ISM_URE_BIT));
|
gal_ism.set_ism_ure(read_octet_unsigned(data_jk_bits, ISM_URE_BIT));
|
||||||
gal_ism.set_ism_bnom(read_octet_unsigned(data_jk_bits, ISM_BNOM_BIT));
|
gal_ism.set_ism_bnom(read_octet_unsigned(data_jk_bits, ISM_BNOM_BIT));
|
||||||
gal_ism.set_ism_Tvalidity(read_octet_unsigned(data_jk_bits, ISM_TVALIDITY_BIT));
|
gal_ism.set_ism_Tvalidity(read_octet_unsigned(data_jk_bits, ISM_TVALIDITY_BIT));
|
||||||
|
LOG(INFO) << "I/NAV ARAIM Integrity Support Message: "
|
||||||
|
<< "WN_ISM=" << static_cast<uint32_t>(gal_ism.get_WN_ISM()) << ", "
|
||||||
|
<< "t0_ISM=" << static_cast<uint32_t>(gal_ism.get_t0_ISM()) << ", "
|
||||||
|
<< "Mask_MSB_ISM=" << static_cast<uint32_t>(gal_ism.get_ism_mask_msb()) << ", "
|
||||||
|
<< "Mask_ISM=" << gal_ism.get_mask_ISM() << ", "
|
||||||
|
<< "Pconst=" << gal_ism.get_pconst_value() << ", "
|
||||||
|
<< "Psat=" << gal_ism.get_psat_value() << ", "
|
||||||
|
<< "URA=" << gal_ism.get_ura_m() << " [m], "
|
||||||
|
<< "URE=" << gal_ism.get_ure_m() << " [m], "
|
||||||
|
<< "Bnom=" << gal_ism.get_bnom_m() << " [m], "
|
||||||
|
<< "Tvalidity=" << static_cast<uint32_t>(gal_ism.get_Tvalidity_hours()) << " [h]";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -129,6 +129,12 @@ double Galileo_ISM::get_psat_value() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool Galileo_ISM::get_ism_mask_msb() const
|
||||||
|
{
|
||||||
|
return ism_mask_msb;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
float Galileo_ISM::get_ura_m() const
|
float Galileo_ISM::get_ura_m() const
|
||||||
{
|
{
|
||||||
auto it = ISM_URA_MAP.find(this->ism_ura);
|
auto it = ISM_URA_MAP.find(this->ism_ura);
|
||||||
@ -151,6 +157,12 @@ float Galileo_ISM::get_ure_m() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
uint32_t Galileo_ISM::get_mask_ISM() const
|
||||||
|
{
|
||||||
|
return ism_mask;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
float Galileo_ISM::get_bnom_m() const
|
float Galileo_ISM::get_bnom_m() const
|
||||||
{
|
{
|
||||||
auto it = ISM_BNOM_MAP.find(this->ism_bnom);
|
auto it = ISM_BNOM_MAP.find(this->ism_bnom);
|
||||||
@ -175,7 +187,7 @@ uint16_t Galileo_ISM::get_Tvalidity_hours() const
|
|||||||
|
|
||||||
bool Galileo_ISM::check_ism_crc(const std::bitset<GALILEO_DATA_JK_BITS>& bits)
|
bool Galileo_ISM::check_ism_crc(const std::bitset<GALILEO_DATA_JK_BITS>& bits)
|
||||||
{
|
{
|
||||||
std::bitset<96> extracted;
|
std::bitset<GALILEO_ISM_CRC_DATA_BITS> extracted;
|
||||||
for (int32_t i = 0; i < GALILEO_ISM_CRC_DATA_BITS; ++i)
|
for (int32_t i = 0; i < GALILEO_ISM_CRC_DATA_BITS; ++i)
|
||||||
{
|
{
|
||||||
extracted[i] = bits[i + 32];
|
extracted[i] = bits[i + 32];
|
||||||
@ -208,6 +220,5 @@ bool Galileo_ISM::check_ism_crc(const std::bitset<GALILEO_DATA_JK_BITS>& bits)
|
|||||||
uint32_t Galileo_ISM::compute_crc(const std::vector<uint8_t>& data)
|
uint32_t Galileo_ISM::compute_crc(const std::vector<uint8_t>& data)
|
||||||
{
|
{
|
||||||
crc32_ism.process_bytes(data.data(), data.size());
|
crc32_ism.process_bytes(data.data(), data.size());
|
||||||
uint32_t result = crc32_ism.checksum();
|
return crc32_ism.checksum();
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
|
@ -66,13 +66,15 @@ public:
|
|||||||
float get_ura_m() const;
|
float get_ura_m() const;
|
||||||
float get_ure_m() const;
|
float get_ure_m() const;
|
||||||
float get_bnom_m() const;
|
float get_bnom_m() const;
|
||||||
|
uint32_t get_mask_ISM() const;
|
||||||
uint16_t get_WN_ISM() const;
|
uint16_t get_WN_ISM() const;
|
||||||
uint16_t get_t0_ISM() const;
|
uint16_t get_t0_ISM() const;
|
||||||
uint16_t get_Tvalidity_hours() const;
|
uint16_t get_Tvalidity_hours() const;
|
||||||
|
bool get_ism_mask_msb() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
boost::crc_basic<32> crc32_ism;
|
|
||||||
uint32_t compute_crc(const std::vector<uint8_t>& data);
|
uint32_t compute_crc(const std::vector<uint8_t>& data);
|
||||||
|
boost::crc_basic<32> crc32_ism;
|
||||||
|
|
||||||
// ICD 2.1 Table 97
|
// ICD 2.1 Table 97
|
||||||
std::unordered_map<uint8_t, double> ISM_PCONST_MAP = {
|
std::unordered_map<uint8_t, double> ISM_PCONST_MAP = {
|
||||||
|
Loading…
Reference in New Issue
Block a user