-
Notifications
You must be signed in to change notification settings - Fork 53
/
navparse.hh
98 lines (77 loc) · 2.48 KB
/
navparse.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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#pragma once
#include "navmon.hh"
#include "galileo.hh"
#include "gps.hh"
#include "beidou.hh"
#include "glonass.hh"
#include <map>
#include "tle.hh"
#include "sbas.hh"
#include "ephemeris.hh"
#include "rtcm.hh"
using namespace std; // XXX
struct SVPerRecv
{
int el{-1}, azi{-1}, db{-1};
time_t deltaHzTime{-1};
double deltaHz{-1};
double prres{-1};
int used{-1}; // -1 = unknown
int qi{-1}; // quality indicator, -1 = unknown
time_t t; // last seen
};
class InfluxPusher;
struct SVStat
{
int gnss;
GPSState gpsmsg; // continuously being updated
GPSState gpsmsg2, gpsmsg3; // new ephemeris being assembled here
GPSState ephgpsmsg, oldephgpsmsg; // always has a consistent ephemeris
GPSAlmanac gpsalma;
int wn() const; // gets from the 'live' message
int tow() const; // same
TLERepo::Match tleMatch;
double lastTLELookupX{0};
// live, ephemeris
BeidouMessage beidoumsg, ephBeidoumsg, oldephBeidoumsg;
// internal
BeidouMessage lastBeidouMessage1, lastBeidouMessage2;
// new galileo
// consistent, live
GalileoMessage ephgalmsg, galmsg, oldephgalmsg;
// internal
map<int, GalileoMessage> galmsgTyped;
bool osnma{false};
time_t osnmaTime{0};
bool impinav{false};
time_t impinavTime{0};
// Glonass
GlonassMessage ephglomsg, glonassMessage, oldephglomsg;
pair<uint32_t, GlonassMessage> glonassAlmaEven;
map<uint64_t, SVPerRecv> perrecv;
double latestDisco{-1}, latestDiscoAge{-1}, timeDisco{-1000};
map<int, SBASCombo> sbas;
RTCMMessage::EphemerisDelta rtcmEphDelta;
RTCMMessage::ClockDelta rtcmClockDelta;
const GPSLikeEphemeris& liveIOD() const;
const GPSLikeEphemeris& prevIOD() const;
bool completeIOD() const;
double getCoordinates(double tow, Point* p, bool quiet=true) const;
double getOldEphCoordinates(double tow, Point* p, bool quiet=true) const;
void getSpeed(double tow, Vector* v) const;
DopplerData doDoppler(double tow, const Point& us, double freq) const;
void reportNewEphemeris(const SatID& id, InfluxPusher& idb);
};
typedef std::map<SatID, SVStat> svstats_t;
// a vector of pairs of latidude,vector<longitude,numsats>
typedef vector<pair<double,vector<tuple<double, int, int, int, double, double, double, double, double, double, double, double, double> > > > covmap_t;
covmap_t emitCoverage(const vector<Point>& sats);
struct xDOP
{
double gdop{-1};
double pdop{-1};
double tdop{-1};
double hdop{-1};
double vdop{-1};
};
xDOP getDOP(Point& us, vector<Point> sats);