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