Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 54a4e1b

Browse files
authored
Improve multiserver queue recipe (GH-29012)
1 parent b3f0cea commit 54a4e1b

1 file changed

Lines changed: 6 additions & 5 deletions

File tree

Doc/library/random.rst

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -503,7 +503,7 @@ between the effects of a drug versus a placebo::
503503

504504
Simulation 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

Comments
 (0)