-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain.py
189 lines (128 loc) · 5.88 KB
/
main.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
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
import argparse
import os
from planespotting import utils
from planespotting.decoder import decode
from planespotting import multilateration
samplerate = 2000000 # of the recorded IQ date with 2MHz for each I and Q
samplerate_avrmlat = 12000000 # AVR, freerunning 48-bit timestamp @ 12MHz
def load_dump1090_file(file):
'''
The json from the input file is loaded here.
A new empty json structure gets initialised here and the raw data from the
input file is plugged into this new json.
What is this new json structure: It contains all the keys to all possible data that
can be extracted using the decoder script. The decoder.py files
fills up the keys in them.
:param file: JSON input file
:type file: File Object
:return: JSON
:rtype: dictionary
'''
dump1090_msg = []
json_data = utils.const_frame()
json_data["meta"]["file"] = file.split(os.sep)[-1]
json_data["meta"]["mlat_mode"] = "avrmlat"
if os.path.exists(file) and utils.is_binary(file) is False:
with open(file, 'r') as infile:
id = 0
payload = []
for line in infile:
line = line.rstrip()
if line.startswith("@") and line.endswith(";"):
data = utils.const_frame_data()['data']
data['id'] = id
data['raw'] = line
data['SamplePos'] = int(line[1:13], 16) // (samplerate_avrmlat // samplerate) - (112 + 8) * 2
data['adsb_msg'] = line[13:-1]
payload.append(data)
id += 1
json_data["data"] = payload
return json_data
def main(filename, output, latitude, longitude, altitude, timestart, timeend, gs_id):
'''
The expected inputs to the filename parameter: Path to a file, path to a folder.
:param filename: The path to the folder/file which cotains the RAW ADS-B.
:param output: Output path
:param latitude: Latitude coordinate of the ground station
:param longitude: Longitude coordinate of the ground station
'''
path = "data" + os.sep + "adsb"
if output is not None:
if output.find(os.sep, 0) != len(output) - 1:
path = output + os.sep + "data" + os.sep + "adsb"
else:
path = output + "data" + os.sep + "adsb"
if os.path.isdir(filename):
print("loading in all files in folder:", filename)
processing_files = utils.get_all_files(filename)
elif os.path.isfile(filename):
print("loading in this file:", filename)
processing_files = utils.get_one_file(filename)
else:
print("neither file, nor folder. ending programme.")
return
if len(processing_files) == 0:
exit("No input files found in the directory. Quitting")
print("processing", len(processing_files))
print("")
for file in processing_files:
print("processing", file)
data = load_dump1090_file(file)
# storing meta data
data["meta"]["gs_rec_timestamp_start"] = timestart
data["meta"]["gs_rec_timestamp_end"] = timeend
data["meta"]["gs_id"] = gs_id
if data["meta"]["gs_lat"] is None and data["meta"]["gs_lon"] is None and \
latitude is not None and longitude is not None:
# if the gs location is already set, we don't need the inputs.
# if they are set, we take them from the loaded data structure.
data["meta"]["gs_lat"] = float(latitude)
data["meta"]["gs_lon"] = float(longitude)
data["meta"]["gs_alt"] = float(altitude)
print("input lat & long:", data["meta"]["gs_lat"], data["meta"]["gs_lon"])
data = decode(data)
print("storing adsb-data")
if "gzip" == "gzip":
# standard output
utils.store_file_jsonGzip(path, file, data)
else:
utils.store_file(path, file, data)
print("doing mlat stuff from here on...")
multilateration.main(path)
def getArgs():
'''
defining the input parameters by the arguments.
src: https://pymotw.com/2/argparse/
:return: args
:rtype: argparse.Namespace
'''
parser = argparse.ArgumentParser()
parser.add_argument('-f', '--from', action='store', default="input"+os.sep,
dest='file',
help='load in the file or folder')
parser.add_argument('--lat', action='store', default=None,
dest='latitude',
help='sets the groundstation latitude')
parser.add_argument('--lon', action='store', default=None,
dest='longitude',
help='sets the groundstation longitude')
parser.add_argument('--alt', action='store', default=0.0,
dest='altitude',
help='sets the groundstation longitude')
parser.add_argument('-o', '--output', action='store', default=None,
dest='output',
help='Path to output file')
parser.add_argument('--timestart', action='store', default=0.0,
dest='timestart',
help='timestamp of start of the recoding')
parser.add_argument('--timeend', action='store', default=None,
dest='timeend',
help='timestamp of end of the recoding')
parser.add_argument('--gsid', action='store', default=None,
dest='gs_id',
help='groundstation id')
#parser.add_argument('--version', action='version', version='0.0') keeping this comment for future reminder
return parser.parse_args()
if __name__ == '__main__':
args = getArgs()
main(args.file, args.output, args.latitude, args.longitude, args.altitude, args.timestart, args.timeend, args.gs_id)