mirror of
https://github.com/a-b-street/abstreet.git
synced 2024-12-25 07:25:47 +03:00
Cap all roads in the Python experiment. Right now, this'll unintentionally merge adjacent zones with the same cap into zones.
This commit is contained in:
parent
c2ef091fb4
commit
f951b296f7
@ -24,6 +24,7 @@ def main():
|
|||||||
parser.add_argument('--hours', type=int, default=24)
|
parser.add_argument('--hours', type=int, default=24)
|
||||||
parser.add_argument('--cap_pct', type=int, default=80)
|
parser.add_argument('--cap_pct', type=int, default=80)
|
||||||
parser.add_argument('--rounds', type=int, default=10)
|
parser.add_argument('--rounds', type=int, default=10)
|
||||||
|
parser.add_argument('--cap_all_roads', type=bool, default=True)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
print('Simulating {} hours of data/system/scenarios/{}/weekday.bin'.format(args.hours, args.map_name))
|
print('Simulating {} hours of data/system/scenarios/{}/weekday.bin'.format(args.hours, args.map_name))
|
||||||
|
|
||||||
@ -32,20 +33,27 @@ def main():
|
|||||||
|
|
||||||
for _ in range(args.rounds):
|
for _ in range(args.rounds):
|
||||||
print('')
|
print('')
|
||||||
print('{} roads have a {}% cap'.format(
|
print('{} roads have a cap'.format(len(edits['commands'])))
|
||||||
len(edits['commands']), args.cap_pct))
|
|
||||||
experiment = abst_helpers.run_sim(args, edits=edits)
|
experiment = abst_helpers.run_sim(args, edits=edits)
|
||||||
baseline.compare(experiment)
|
baseline.compare(experiment)
|
||||||
print('{:,} trips changed due to the caps'.format(
|
print('{:,} trips changed due to the caps'.format(
|
||||||
len(experiment.capped_trips)))
|
len(experiment.capped_trips)))
|
||||||
|
|
||||||
# Cap the busiest road
|
if args.cap_all_roads:
|
||||||
busiest_road, thruput = find_busiest_road(args)
|
edits['commands'] = cap_all_roads(args)
|
||||||
cmd = get(args, '/map/get-edit-road-command',
|
else:
|
||||||
params={'id': busiest_road}).json()
|
# Cap the busiest road
|
||||||
cmd['ChangeRoad']['new']['access_restrictions']['cap_vehicles_per_hour'] = int(
|
busiest_road, thruput = find_busiest_road(args)
|
||||||
(args.cap_pct / 100.0) * thruput)
|
cmd = get(args, '/map/get-edit-road-command',
|
||||||
edits['commands'].append(cmd)
|
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)
|
||||||
|
|
||||||
|
# Write the final edits
|
||||||
|
f = open('cap_edits.json', 'w')
|
||||||
|
f.write(get(args, '/map/get-edits').text)
|
||||||
|
f.close()
|
||||||
|
|
||||||
|
|
||||||
# Find the road with the most car traffic in any one hour period
|
# Find the road with the most car traffic in any one hour period
|
||||||
@ -64,5 +72,26 @@ def find_busiest_road(args):
|
|||||||
return (max_key[0], max_value)
|
return (max_key[0], max_value)
|
||||||
|
|
||||||
|
|
||||||
|
# Cap all roads to some percent of their max throughput over any one hour period
|
||||||
|
def cap_all_roads(args):
|
||||||
|
thruput = get(
|
||||||
|
args, '/data/get-road-thruput').json()['counts']
|
||||||
|
max_per_road = {}
|
||||||
|
for r, agent, hr, count in thruput:
|
||||||
|
if agent == 'Car':
|
||||||
|
if r not in max_per_road or count > max_per_road[r]:
|
||||||
|
max_per_road[r] = count
|
||||||
|
commands = []
|
||||||
|
for r, count in max_per_road.items():
|
||||||
|
cap = int((args.cap_pct / 100.0) * count)
|
||||||
|
# Don't go too low
|
||||||
|
if cap > 10:
|
||||||
|
cmd = get(args, '/map/get-edit-road-command',
|
||||||
|
params={'id': r}).json()
|
||||||
|
cmd['ChangeRoad']['new']['access_restrictions']['cap_vehicles_per_hour'] = cap
|
||||||
|
commands.append(cmd)
|
||||||
|
return commands
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
Loading…
Reference in New Issue
Block a user