forked from HSLdevcom/OTPQA
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgen_requests.py
67 lines (51 loc) · 2.53 KB
/
gen_requests.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
import csv
import json
def generateRequestsFromEndpoints(endpoints,TEST_ALL_MODES=True,random=False):
json_out = {}
# Initialize the otpprofiler DB 'requests' table with query parameters.
# Note that on-street modes are not walk-limited, so we don't want to vary the max walk param there.
# another way to do this would be to store the various values in tables, and construct this
# view as a constrained product of all the other tables (probably eliminating the synthetic keys).
# (time, arriveBy)
times = [ ("08:50:00", False ),
("14:00:00", True ),
("18:00:00", False),
("23:45:00", True) ]
if TEST_ALL_MODES:
# (mode, walk, min)
# OTP clamps walk distance to max 15km
modes = [ ("WALK,TRANSIT", 2000, "QUICK"), ("WALK,TRANSIT", 2000, "QUICK") ] # More WALK, TRANSIT
modes.append( ("BICYCLE,TRANSIT", 15000, "QUICK") )
modes.append( ("WALK", 15000, "QUICK") )
modes.append( ("BICYCLE", 15000, "SAFE") )
else:
# (mode, walk, min)
modes = [ ("WALK,TRANSIT", 2000, "QUICK") ]
all_params = [(time, walk, mode, minimize, arriveBy)
for (time, arriveBy) in times
for (mode, walk, minimize) in modes]
requests_json = []
for i, params in enumerate( all_params ) :
# NOTE the use of double quotes to force case-sensitivity for column names. These columns
# represent query parameters that will be substituted directly into URLs, and URLs are defined
# to be case-sensitive.
time,maxWalkDist,mode,min,arriveBy = params
typical = (time=="08:50:00" and maxWalkDist == 2000 and "BICYCLE" not in mode)
requests_json.append( dict(zip(('time','maxWalkDistance','mode','min','arriveBy','typical','id'),params+(typical,i))) )
json_out['requests'] = requests_json
# Initialize the otpprofiler DB with random endpoints and user-defined endpoints
import csv
endpoints_json = []
for i, rec in enumerate( endpoints ):
endpoint_rec = {'id':i, 'random':random, 'lon':float(rec['lon']), 'lat':float(rec['lat']), 'name':rec['name'], 'notes':None}
endpoints_json.append( endpoint_rec )
json_out['endpoints'] = endpoints_json
return json_out
if __name__ == '__main__':
endpoints = open("hsl_clustered_test.csv")
reader = csv.DictReader(endpoints)
endpoints = list(reader)
json_out = generateRequestsFromEndpoints(endpoints)
fpout = open("requests.json","w")
json.dump(json_out, fpout, indent=2 )
fpout.close()