-
Notifications
You must be signed in to change notification settings - Fork 0
/
aprsreducer_dedupe.py
executable file
·65 lines (59 loc) · 2.12 KB
/
aprsreducer_dedupe.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
#!/usr/bin/python
import sys
import json
"""
Haddop reducer for aprs-is logs reduced by aprspig.py.
Input: firsthop,from_call,latitude,longitude\t(nothing)
Output: {"f": firsthop, "p": [[from,lat,lon]...]}
Assumes hadoop partitioner was used to partition all keys for the same firsthop
to the same reducer.
"""
__author__="Alan Crosswell <[email protected]>"
"""
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
Copyright (c) 2013 Alan Crosswell
"""
def main():
incounts = outcounts = 0
curhop = None
for l in sys.stdin:
if incounts%1000 == 0:
sys.stderr.write("aprsReduceDedupe: %d input %d output...\n"%(incounts,outcounts))
incounts += 1
splits = l.split('\t')
s = splits[0].rstrip().split(',')
if len(s) != 4:
sys.stderr.write("aprsReduceDedupe: key tuple not length 4 (%d): %s.\n"%(len(s),s))
else:
firsthop,call,lat,lon = s
if firsthop != curhop:
if curhop != None:
print ']}'
curhop = firsthop
lastpos = None
first = True
print '{"f":"%s","p":['%(firsthop),
if lastpos != (call,float(lat),float(lon)):
if not first:
print ",",
print '["%s",%f,%f]'%(call,float(lat),float(lon)),
outcounts += 1
lastpos = (call,float(lat),float(lon))
first = False
if curhop != None:
print ']}'
sys.stderr.write("aprsReduceDedupe: %d input %d output.\n"%(incounts,outcounts))
if __name__ == '__main__':
try:
main()
except:
sys.stderr.write("aprsReduceDedupe: Exception %s\n"%(sys.exc_info()[0]))