-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsegmentpaths.py
74 lines (67 loc) · 2.21 KB
/
segmentpaths.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
import json
import os
pathlensum = 0
pathsum = 0
POSTIME = True
def getTime(ping):
if POSTIME:
return ping[3]
return ping[2]
# only segments of len 10 and up are accepted.
def tryAppend(output, segment, limit=15):
global pathlensum, pathsum
if len(segment) > limit:
output.append(segment)
pathlensum += len(segment)
pathsum += 1
return 1
return 0
# slice plane paths when there is a sufficiently long interrupt.
root = "data_perplane/"
outdir = "data_segmented-paths/"
blacklist = ["A234C0.json"]
for file in os.listdir(root):
if file in blacklist:
continue
with open(root + file) as f:
path = json.load(f)
output = []
current_segment = []
segmentsAccepted = 0
pathsegments = []
# sort paths by time
path = sorted(path, key=getTime)
for i, obj in enumerate(path[:-1]):
if POSTIME:
current_segment.append(obj[:2] + [obj[3]])
else:
current_segment.append(obj[:3])
t1 = getTime(obj)
t2 = getTime(path[i+1])
if t2 - t1 > 60 * 1000: # over 60 seconds
segmentsAccepted += tryAppend(output, current_segment)
pathsegments.append(current_segment)
current_segment = []
# also break up if time length of path is over one hour
elif len(current_segment) > 1:
if t2 - current_segment[0][2] > 30 * 60 * 1000:
segmentsAccepted += tryAppend(output, current_segment)
pathsegments.append(current_segment)
current_segment = []
current_segment.append(path[-1])
segmentsAccepted += tryAppend(output, current_segment)
pathsegments.append(current_segment)
# if no segments, append longest
if segmentsAccepted == 0:
maxseg = None
maxlen = 0
for seg in pathsegments:
if len(seg) > maxlen:
maxlen = len(seg)
maxseg = seg
output.append(maxseg);
print("Path length: {0}. Segments: {1}".format(len(path), len(output)))
with open(outdir + file, "w") as f:
json.dump(output, f)
print("Average segment length: %.1f" % (pathlensum / pathsum))
print("Number of segments: %d" % (pathsum))