-
Notifications
You must be signed in to change notification settings - Fork 53
/
Copy pathsbas.hh
83 lines (65 loc) · 2.23 KB
/
sbas.hh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#pragma once
#include <cstdint>
#include <string>
#include <map>
#include "navmon.hh"
#include <vector>
#include "minivec.hh"
// 0 do not use
// 1 PRN mask
// 2-5 fast corrections
// 7 Fast correction degradation factor
// 10 Degradation parameters
// 18 Ionospheric grid point masks
// 24 Mixed fastllong-term satellite error corrections
// 25 half-message
// 26 Ionospheric delay corrections
// 27 SBAS service message
// GSA HQ Prague
const Point c_egnosCenter{3970085, 1021937, 4869792};
// Somewhere in Minnesota, Dakota, Canada border
const Point c_waasCenter{-510062, -4166466, 4786089};
struct SBASState
{
struct FastCorrection
{
SatID id;
double correction;
int udrei;
time_t lastUpdate{-1};
};
struct LongTermCorrection
{
SatID id;
int iod8;
int toa;
int iodp;
double dx, dy, dz, dai;
double ddx{0}, ddy{0}, ddz{0}, ddai{0};
bool velocity{false};
time_t lastUpdate{-1};
};
std::pair<std::vector<SBASState::FastCorrection>, std::vector<SBASState::LongTermCorrection>> parse(const std::basic_string<uint8_t>& sbas, time_t now);
void parse0(const std::basic_string<uint8_t>& message, time_t now);
// updates slot2prn mapping
void parse1(const std::basic_string<uint8_t>& message, time_t now);
std::vector<FastCorrection> parse2_5(const std::basic_string<uint8_t>& message, time_t now);
std::vector<FastCorrection> parse6(const std::basic_string<uint8_t>& message, time_t now);
void parse7(const std::basic_string<uint8_t>& message, time_t now);
std::pair<std::vector<FastCorrection>, std::vector<LongTermCorrection>> parse24(const std::basic_string<uint8_t>& message, time_t now);
std::vector<LongTermCorrection> parse25(const std::basic_string<uint8_t>& message, time_t now);
int getSBASNumber(int slot) const;
SatID getSBASSatID(int slot) const;
std::map<SatID, FastCorrection> d_fast;
std::map<SatID, LongTermCorrection> d_longterm;
time_t d_lastDNU{-1};
std::map<int,int> d_slot2prn;
int d_latency = -1;
time_t d_lastSeen{-1};
void parse25H(const std::basic_string<uint8_t>& sbas, time_t t, int offset, std::vector<LongTermCorrection>& ret);
};
struct SBASCombo
{
SBASState::FastCorrection fast;
SBASState::LongTermCorrection longterm;
};