abstreet/headless/examples/cap_experiment.py

66 lines
2.2 KiB
Python
Raw Normal View History

#!/usr/bin/python3
# This example runs a scenario, finds roads with high driver throughput, then
# establishes a per-hour cap.
#
# Before running this script, start the API server:
#
# > cargo run --release --bin headless -- --port=1234 --alerts=silence
#
# You may need to install https://requests.readthedocs.io
# Keep this script formatted with autopep8 -i
import abst_helpers
import argparse
import requests
import sys
import time
def main():
parser = argparse.ArgumentParser()
parser.add_argument('--api', default='http://localhost:1234')
parser.add_argument('--map_name', default='montlake')
parser.add_argument('--hours', type=int, default=24)
parser.add_argument('--cap_pct', type=int, default=80)
parser.add_argument('--rounds', type=int, default=10)
args = parser.parse_args()
print('Simulating {} hours of data/system/scenarios/{}/weekday.bin'.format(args.hours, args.map_name))
baseline = abst_helpers.run_sim(args)
edits = requests.get(args.api + '/map/get-edits').json()
for _ in range(args.rounds):
print('')
print('{} roads have a {}% cap'.format(
len(edits['commands']), args.cap_pct))
experiment = abst_helpers.run_sim(args, edits=edits)
baseline.compare(experiment)
# Cap the busiest road
busiest_road, thruput = find_busiest_road(args)
cmd = requests.get(args.api + '/map/get-edit-road-command',
params={'id': busiest_road}).json()
cmd['ChangeRoad']['new']['access_restrictions']['cap_vehicles_per_hour'] = int(
(args.cap_pct / 100.0) * thruput)
edits['commands'].append(cmd)
# Find the road with the most car traffic in any one hour period
def find_busiest_road(args):
thruput = requests.get(
args.api + '/data/get-road-thruput').json()['counts']
max_key = None
max_value = 0
for r, agent, hr, count in thruput:
if agent == 'Car':
if count > max_value:
max_key = (r, hr)
max_value = count
print('Busiest road is #{}, with {} cars crossing during hour {}'.format(
max_key[0], max_value, max_key[1]))
return (max_key[0], max_value)
if __name__ == '__main__':
main()