forked from salabim/salabim
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathExample - bank, 3 clerks x.py
60 lines (49 loc) · 1.49 KB
/
Example - bank, 3 clerks x.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
# Example - bank, 3 clerks.py
import salabim as sim
class ResetNow(sim.Component):
def process(self):
while True:
yield self.hold(5)
env.reset_now()
class CustomerGenerator(sim.Component):
def process(self):
while True:
Customer()
yield self.hold(sim.Uniform(5, 15).sample())
class Customer(sim.Component):
def process(self):
self.enter(waitingline)
for clerk in clerks:
if clerk.ispassive():
clerk.activate()
break # activate only one clerk
yield self.passivate()
class Clerk(sim.Component):
def process(self):
while True:
while len(waitingline) == 0:
yield self.passivate()
self.customer = waitingline.pop()
yield self.hold(30)
self.customer.activate()
env = sim.Environment(trace=False)
ResetNow()
CustomerGenerator(name='customergenerator')
clerks = sim.Queue('clerks')
for i in range(3):
Clerk().enter(clerks)
waitingline = sim.Queue('waitingline')
env.trace(True)
env.run(till=2000)
waitingline.length.print_histogram(30, 0, 1)
print()
waitingline.print_info()
waitingline.print_statistics()
waitingline.length.print_histogram(30, 0, 1)
print()
waitingline.length_of_stay.print_histogram(30, 0, 10)
waitingline.length_of_stay.print_statistics()
waitingline.length.print_statistics()
waitingline.print_info()
for c in waitingline:
print(c.name(),c.creation_time(),c.mode_time())