]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Improve multiserver queue recipe (GH-29012) (GH-29014)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Mon, 18 Oct 2021 05:24:51 +0000 (22:24 -0700)
committerGitHub <noreply@github.com>
Mon, 18 Oct 2021 05:24:51 +0000 (00:24 -0500)
Doc/library/random.rst

index f2d6749422a15a5bd86dfcce119bb3db254ceaa3..758d1292086e5d7c426cae8cd972ce60b0b87d9c 100644 (file)
@@ -502,7 +502,7 @@ between the effects of a drug versus a placebo::
 
 Simulation of arrival times and service deliveries for a multiserver queue::
 
-    from heapq import heappush, heappop
+    from heapq import heapify, heapreplace
     from random import expovariate, gauss
     from statistics import mean, median, stdev
 
@@ -514,14 +514,15 @@ Simulation of arrival times and service deliveries for a multiserver queue::
     waits = []
     arrival_time = 0.0
     servers = [0.0] * num_servers  # time when each server becomes available
-    for i in range(100_000):
+    heapify(servers)
+    for i in range(1_000_000):
         arrival_time += expovariate(1.0 / average_arrival_interval)
-        next_server_available = heappop(servers)
+        next_server_available = servers[0]
         wait = max(0.0, next_server_available - arrival_time)
         waits.append(wait)
-        service_duration = gauss(average_service_time, stdev_service_time)
+        service_duration = max(0.0, gauss(average_service_time, stdev_service_time))
         service_completed = arrival_time + wait + service_duration
-        heappush(servers, service_completed)
+        heapreplace(servers, service_completed)
 
     print(f'Mean wait: {mean(waits):.1f}.  Stdev wait: {stdev(waits):.1f}.')
     print(f'Median wait: {median(waits):.1f}.  Max wait: {max(waits):.1f}.')