20#ifndef GNSS_SDR_GALILEO_CNAV_H
21#define GNSS_SDR_GALILEO_CNAV_H
26#include <unordered_map>
35constexpr size_t HAS_MSG_NSYS_LENGTH = 4;
36constexpr size_t HAS_MSG_ID_MASK_LENGTH = 4;
37constexpr size_t HAS_MSG_SATELLITE_MASK_LENGTH = 40;
38constexpr size_t HAS_MSG_SIGNAL_MASK_LENGTH = 16;
39constexpr size_t HAS_MSG_NAV_MESSAGE_LENGTH = 3;
40constexpr size_t HAS_MSG_MASK_RESERVED_LENGTH = 6;
41constexpr size_t HAS_MSG_VALIDITY_INDEX_LENGTH = 4;
42constexpr size_t HAS_MSG_IOD_GPS_LENGTH = 8;
43constexpr size_t HAS_MSG_IOD_GAL_LENGTH = 10;
44constexpr size_t HAS_MSG_DELTA_RADIAL_LENGTH = 13;
45constexpr size_t HAS_MSG_DELTA_IN_TRACK_LENGTH = 12;
46constexpr size_t HAS_MSG_DELTA_CROSS_TRACK_LENGTH = 12;
47constexpr size_t HAS_MSG_DELTA_CLOCK_MULTIPLIER_LENGTH = 2;
48constexpr size_t HAS_MSG_DELTA_CLOCK_CORRECTION_LENGTH = 13;
49constexpr size_t HAS_MSG_NSYS_SUB_LENGTH = 4;
50constexpr size_t HAS_MSG_ID_CLOCK_SUBSET_LENGTH = 4;
51constexpr size_t HAS_MSG_DELTA_CLOCK_MULTIPLIER_SUBSET_LENGTH = 2;
52constexpr size_t HAS_MSG_DELTA_CLOCK_CORRECTION_SUBSET_LENGTH = 13;
53constexpr size_t HAS_MSG_CODE_BIAS_LENGTH = 11;
54constexpr size_t HAS_MSG_PHASE_BIAS_LENGTH = 11;
55constexpr size_t HAS_MSG_PHASE_DISCONTINUITY_INDICATOR_LENGTH = 2;
57constexpr uint64_t MAX_SECONDS_REMEMBERING_MID = 150;
60constexpr int32_t GALILEO_CNAV_SYMBOLS_PER_PAGE = 1000;
61constexpr int32_t GALILEO_CNAV_PREAMBLE_PERIOD_SYMBOLS = 1000;
62constexpr int32_t GALILEO_CNAV_PAGE_MS = 1;
63constexpr int32_t GALILEO_CNAV_INTERLEAVER_ROWS = 8;
64constexpr int32_t GALILEO_CNAV_INTERLEAVER_COLS = 123;
65constexpr int32_t GALILEO_CNAV_TELEMETRY_RATE_BITS_SECOND = 1000;
66constexpr int32_t GALILEO_CNAV_HAS_PAGE_DATA_BITS = 448;
67constexpr int32_t GALILEO_CNAV_PAGE_RESERVED_BITS = 14;
68constexpr int32_t GALILEO_CNAV_BYTES_FOR_CRC = 58;
69constexpr int32_t GALILEO_CNAV_CRC_LENGTH = 24;
70constexpr int32_t GALILEO_CNAV_MESSAGE_BITS_PER_PAGE = 424;
71constexpr int32_t GALILEO_CNAV_PAGE_HEADER_BITS = 24;
72constexpr int32_t GALILEO_CNAV_PREAMBLE_LENGTH_BITS = 16;
73constexpr int32_t GALILEO_CNAV_MAX_NUMBER_SYMBOLS_ENCODED_BLOCK = 255;
74constexpr int32_t GALILEO_CNAV_MT1_HEADER_BITS = 32;
75constexpr int32_t GALILEO_CNAV_OCTETS_IN_SUBPAGE = 53;
76constexpr int32_t GALILEO_CNAV_INFORMATION_VECTOR_LENGTH = 32;
78constexpr int32_t GALILEO_CNAV_BITS_FOR_CRC = GALILEO_CNAV_HAS_PAGE_DATA_BITS + GALILEO_CNAV_PAGE_RESERVED_BITS;
80constexpr int32_t HAS_MSG_NUMBER_MASK_IDS = 32;
81constexpr int32_t HAS_MSG_NUMBER_GNSS_IDS = 16;
82constexpr int32_t HAS_MSG_NUMBER_MESSAGE_IDS = 32;
83constexpr int32_t HAS_MSG_NUMBER_SATELLITE_IDS = 40;
84constexpr int32_t HAS_MSG_NUMBER_SIGNAL_MASKS = 16;
86constexpr float HAS_MSG_DELTA_RADIAL_SCALE_FACTOR = 0.0025;
87constexpr float HAS_MSG_DELTA_IN_TRACK_SCALE_FACTOR = 0.008;
88constexpr float HAS_MSG_DELTA_CROSS_TRACK_SCALE_FACTOR = 0.008;
89constexpr float HAS_MSG_DELTA_CLOCK_SCALE_FACTOR = 0.0025;
90constexpr float HAS_MSG_CODE_BIAS_SCALE_FACTOR = 0.02;
91constexpr float HAS_MSG_PHASE_BIAS_SCALE_FACTOR = 0.01;
93constexpr uint16_t HAS_MSG_NUMBER_MAX_TOH = 3599;
95constexpr uint8_t HAS_MSG_GPS_SYSTEM = 0;
96constexpr uint8_t HAS_MSG_GALILEO_SYSTEM = 2;
97constexpr uint8_t HAS_MSG_WRONG_SYSTEM = 255;
99constexpr char GALILEO_CNAV_PREAMBLE[17] =
"1011011101110000";
102const std::pair<int32_t, int32_t> GALILEO_HAS_STATUS({1, 2});
103const std::pair<int32_t, int32_t> GALILEO_HAS_RESERVED({3, 2});
104const std::pair<int32_t, int32_t> GALILEO_HAS_MESSAGE_TYPE({5, 2});
105const std::pair<int32_t, int32_t> GALILEO_HAS_MESSAGE_ID({7, 5});
106const std::pair<int32_t, int32_t> GALILEO_HAS_MESSAGE_SIZE({12, 5});
107const std::pair<int32_t, int32_t> GALILEO_HAS_MESSAGE_PAGE_ID({17, 8});
110const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_TOH({1, 12});
111const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_MASK_FLAG({13, 1});
112const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_ORBIT_CORRECTION_FLAG({14, 1});
113const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_CLOCK_FULLSET_FLAG({15, 1});
114const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_CLOCK_SUBSET_FLAG({16, 1});
115const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_CODE_BIAS_FLAG({17, 1});
116const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_PHASE_BIAS_FLAG({18, 1});
117const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_RESERVED({19, 4});
118const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_MASK_ID({23, 5});
119const std::pair<int32_t, int32_t> GALILEO_MT1_HEADER_IOD_SET_ID({28, 5});
122const std::unordered_map<uint8_t, std::unordered_map<uint8_t, std::string>> HAS_SIGNAL_INDEX_TABLE = {
142 {0,
"E1-B I/NAV OS"},
145 {3,
"E5a-I F/NAV OS"},
148 {6,
"E5b-I I/NAV OS"},
154 {12,
"E6-B C/NAV HAS"},
161const std::unordered_map<uint8_t, uint16_t> HAS_VALIDITY_INTERVALS = {