forked from tridge/pyUblox
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsatelliteData.py
140 lines (119 loc) · 4.85 KB
/
satelliteData.py
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
import util, ephemeris, prSmooth
class rawPseudoRange:
"""class to hold raw range information from a receiver"""
def __init__(self, gps_week, time_of_week):
# time of week in seconds, including fractions of a second
self.time_of_week = time_of_week
self.gps_week = gps_week
self.gps_time = util.gpsTimeToTime(gps_week, time_of_week)
self.prMeasured = {}
self.cpMeasured = {}
self.quality = {}
self.lli = {}
self.cno = {}
def add(self, svid, prMes, cpMes, quality, lli, cno):
"""add a pseudo range for a given svid"""
self.prMeasured[svid] = prMes
self.cpMeasured[svid] = cpMes * (util.speedOfLight / 1.57542e9)
self.quality[svid] = quality
self.lli[svid] = lli # loss of lock indicator, rinex defintion
self.cno[svid] = cno
class SatelliteData:
"""class to hold satellite data from AID_EPH, RXM_SFRB and RXM_RAW messages plus calculated
positions and error terms"""
def __init__(self):
self.azimuth = {}
self.elevation = {}
self.lastpos = util.PosVector(0, 0, 0)
self.receiver_clock_error = 0
self.rtcm_bits = None
self.reset()
self.average_position = None
self.position_sum = util.PosVector(0, 0, 0)
self.position_count = 0
# the reference position given by the user, if any
self.reference_position = None
# the position reported by the reference receiver
self.receiver_position = None
# the position reported by the corrected rover
self.recv2_position = None
# the position reported by the uncorrected rover
self.recv3_position = None
# the position calculated from the reference receivers raw data
# and the generated RTCM data.
self.rtcm_position = None
# the last position calculated from smoothed pseudo ranges
self.position_estimate = None
self.ephemeris = util.loadObject('ephemeris.dat')
if self.ephemeris is None:
self.ephemeris = {}
self.ionospheric = util.loadObject('ionospheric.dat')
if self.ionospheric is None:
self.ionospheric = {}
self.min_elevation = 5.0
self.min_quality = 6
self.smooth = prSmooth.prSmooth()
def reset(self):
self.satpos = {}
self.prMeasured = {}
self.prSmoothed = {}
self.ionospheric_correction = {}
self.tropospheric_correction = {}
self.satellite_clock_error = {}
self.satellite_group_delay = {}
self.prCorrected = {}
self.geometricRange = {}
def valid(self, svid):
"""return true if we have all data for a given svid"""
if svid not in self.ephemeris:
# print("no eph")
return False
return True
def add_AID_EPH(self, msg):
"""add some AID_EPH ephemeris data"""
eph = ephemeris.EphemerisData(msg)
if eph.valid:
if eph.svid in self.ephemeris:
old_eph = self.ephemeris[eph.svid]
else:
old_eph = None
self.ephemeris[eph.svid] = eph
if old_eph is None or old_eph != eph:
self.smooth.reset(eph.svid)
util.saveObject('ephemeris.dat', self.ephemeris)
def add_RXM_SFRB(self, msg):
"""add some RXM_SFRB subframe data"""
ion = ephemeris.IonosphericData(msg)
if ion.valid:
if msg.svid in self.ionospheric:
old_ion = self.ionospheric[msg.svid]
else:
old_ion = None
self.ionospheric[msg.svid] = ion
if old_ion is None or old_ion != ion:
util.saveObject('ionospheric.dat', self.ionospheric)
def add_RXM_RAW(self, msg):
"""add some RXM_RAW pseudo range data"""
self.raw = rawPseudoRange(msg.week, msg.iTOW*1.0e-3)
for i in range(msg.numSV):
self.raw.add(msg.recs[i].sv,
msg.recs[i].prMes,
msg.recs[i].cpMes,
msg.recs[i].mesQI,
msg.recs[i].lli,
msg.recs[i].cno)
# step the smoothed pseudo-ranges
self.smooth.step(self.raw)
def add_NAV_POSECEF(self, msg):
"""add a NAV_POSECEF message"""
self.receiver_position = util.PosVector(msg.ecefX*0.01, msg.ecefY*0.01, msg.ecefZ*0.01)
def add_message(self, msg):
"""add information from ublox messages"""
if msg.name() == 'AID_EPH':
self.add_AID_EPH(msg)
elif msg.name() == 'RXM_SFRB':
self.add_RXM_SFRB(msg)
elif msg.name() == 'RXM_RAW':
self.add_RXM_RAW(msg)
elif msg.name() == 'NAV_POSECEF':
self.add_NAV_POSECEF(msg)