@@ -503,7 +503,7 @@ between the effects of a drug versus a placebo::
503503
504504Simulation of arrival times and service deliveries for a multiserver queue::
505505
506- from heapq import heappush, heappop
506+ from heapq import heapify, heapreplace
507507 from random import expovariate, gauss
508508 from statistics import mean, quantiles
509509
@@ -515,14 +515,15 @@ Simulation of arrival times and service deliveries for a multiserver queue::
515515 waits = []
516516 arrival_time = 0.0
517517 servers = [0.0] * num_servers # time when each server becomes available
518- for i in range(100_000):
518+ heapify(servers)
519+ for i in range(1_000_000):
519520 arrival_time += expovariate(1.0 / average_arrival_interval)
520- next_server_available = heappop( servers)
521+ next_server_available = servers[0]
521522 wait = max(0.0, next_server_available - arrival_time)
522523 waits.append(wait)
523- service_duration = gauss(average_service_time, stdev_service_time)
524+ service_duration = max(0.0, gauss(average_service_time, stdev_service_time) )
524525 service_completed = arrival_time + wait + service_duration
525- heappush (servers, service_completed)
526+ heapreplace (servers, service_completed)
526527
527528 print(f'Mean wait: {mean(waits):.1f} Max wait: {max(waits):.1f}')
528529 print('Quartiles:', [round(q, 1) for q in quantiles(waits)])
0 commit comments