-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathQueue.py
More file actions
96 lines (72 loc) · 2.49 KB
/
Queue.py
File metadata and controls
96 lines (72 loc) · 2.49 KB
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
class Queue:
def __init__(self, name: str):
self.name = name
self.servers = 0
self.capacity = 0
self.states = {}
self.clients = 0
self.losses = 0
self.min_arrival = 0
self.max_arrival = 0
self.min_service = 0
self.max_service = 0
self.output = {}
def set_name(self, name):
self.name = name
def set_servers(self, servers):
self.servers = servers
def set_capacity(self, capacity):
self.capacity = capacity
def set_state(self, state, time):
if state not in self.states:
self.states[state] = time
else:
self.states[state] += time
def set_clients(self, clients):
if clients < 0:
clients = 0
self.clients = clients
def set_losses(self, losses):
self.losses = losses
def set_min_arrival(self, min_arrival):
self.min_arrival = min_arrival
def set_max_arrival(self, max_arrival):
self.max_arrival = max_arrival
def set_min_service(self, min_service):
self.min_service = min_service
def set_max_service(self, max_service):
self.max_service = max_service
def set_output(self, destQueue, probability):
self.output[destQueue] = probability
def get_name(self):
return self.name
def get_servers(self):
return self.servers
def get_capacity(self):
return self.capacity
def get_states(self):
return self.states
def get_clients(self):
return self.clients
def get_losses(self):
return self.losses
def get_min_arrival(self):
return self.min_arrival
def get_max_arrival(self):
return self.max_arrival
def get_min_service(self):
return self.min_service
def get_max_service(self):
return self.max_service
def get_output(self):
return self.output
def calculate_output(self, rand):
if self.output == {}:
return "OUT"
currProb = 0
for destQueue in self.output:
currProb += self.output[destQueue]
if rand <= currProb:
return destQueue
def printQ(self):
return f"Name: {self.name}\n Servers: {self.servers}\n Capacity: {self.capacity}\n States: {self.states}\n Clients: {self.clients}\n Min Arrival: {self.min_arrival}\n Max Arrival: {self.max_arrival}\n Min Service: {self.min_service}\n Max Service: {self.max_service}\n Output: {self.output}"