-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmm1k.c
168 lines (156 loc) · 7.33 KB
/
mm1k.c
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
/*******************************************************************************
* M/M/1/k Queue Simulator
********************************************************************************
* Notes: Nothing remarkable
*------------------------------------------------------------------------------*
* Build Command:
* gcc -o mm1k mm1k.c -lm
*------------------------------------------------------------------------------*
* Execute command:
* ./mm1k
*------------------------------------------------------------------------------*
* Author: Lucas German Wals Ochoa
*******************************************************************************/
/*******************************************************************************
* Includes
*******************************************************************************/
#include <stdio.h> // Needed for printf()
#include <stdlib.h> // Needed for exit() and rand()
#include <unistd.h> // Needed for getopts()
#include "utils.h" // Needed for expntl()
/*******************************************************************************
* Defined constants and variables
* NOTE: All TIME constants are defined in seconds!
*******************************************************************************/
#define SIM_TIME 1.0e9 // Simulation time
#define ARR_TIME 90.00 // Mean time between arrivals
#define SERV_TIME 60.00 // Mean service time
#define CAPACITY 10 // Maximum amount of customers in the system
/*******************************************************************************
* Function Prototypes
*******************************************************************************/
static void show_usage(char *name);
/*******************************************************************************
* Main Function
*******************************************************************************/
int main(int argc, char **argv)
{
int opt; // Hold the options passed as argument
double endTime = SIM_TIME; // Total time to do Simulation
double arrTime = ARR_TIME; // Mean time between arrivals
double departTime = SERV_TIME; // Mean service time
int k = CAPACITY; // Capacity of system
double time = 0.0; // Current Simulation time
double nextArrival = 0.0; // Time for next arrival
double nextDeparture = SIM_TIME; // Time for next departure
unsigned int n = 0; // Actual number of customers in the system
unsigned int departures = 0; // Total number of customers served
double busyTime = 0.0; // Total busy time
double s = 0.0; // Area of number of customers in system
double lastEventTime = time; // Variable for "last event time"
double lastBusyTime; // Variable for "last start of busy time"
double x; // Throughput rate
double u; // Utilization of system
double l; // Average number of customers in system
double w; // Average Sojourn time
if (argc > 1)
{
while ( (opt = getopt(argc, argv, "a:d:s:k:")) != -1 )
{
switch (opt) {
case 'a':
arrTime = atof(optarg);
break;
case 'd':
departTime = atof(optarg);
break;
case 's':
endTime = atof(optarg);
break;
case 'k':
k = atoi(optarg);
break;
default: // '?' unknown option
show_usage( argv[0] );
}
}
}
// Simulation loop
while (time < endTime)
{
// Arrival occurred
if (nextArrival < nextDeparture)
{
time = nextArrival;
if (n < k) // Actual number of customers is less than system's capacity
{
s = s + n * (time - lastEventTime); // Update area under "s" curve
n++; // Customers in system increase
if (n == 1)
{
lastBusyTime = time; // Set "last start of busy time"
nextDeparture = time + expntl(departTime);
}
}
lastEventTime = time; // "last event time" for next event
nextArrival = time + expntl(arrTime);
}
// Departure occurred
else
{
time = nextDeparture;
s = s + n * (time - lastEventTime); // Update area under "s" curve
n--; // Customers in system decrease
lastEventTime = time; // "last event time" for next event
departures++; // Increment number of completions
if (n > 0)
nextDeparture = time + expntl(departTime);
else
{
nextDeparture = SIM_TIME;
// Update busy time sum when no customers
busyTime = busyTime + time - lastBusyTime;
}
}
}
// Compute outputs
x = departures / time; // Compute throughput rate
u = busyTime / time; // Compute server utilization
l = s / time; // Avg number of customers in the system
w = l / x; // Avg Sojourn time
// Output results
printf("<-------------------------------------------------------------> \n");
printf("< *** Results for M/M/1/%d simulation *** > \n", k);
printf("<-------------------------------------------------------------> \n");
printf("- INPUTS: \n");
printf("- Total simulation time = %.4f sec \n", endTime);
printf("- Mean time between arrivals = %.4f sec \n", arrTime);
printf("- Mean service time = %.4f sec \n", departTime);
printf("- System capacity = %d sec \n", k);
printf("<-------------------------------------------------------------> \n");
printf("- OUTPUTS: \n");
printf("- # of Customers served = %u cust \n", departures);
printf("- Throughput rate = %f cust/sec \n", x);
printf("- Server utilization = %f %% \n", 100.0 * u);
printf("- Avg # of cust. in system = %f cust \n", l);
printf("- Mean Sojourn time = %f sec \n", w);
printf("<-------------------------------------------------------------> \n");
}
/*******************************************************************************
* show_usage(char *name)
********************************************************************************
* Function that return a message of how to use this program
* - Input: name (the name of the executable)
*******************************************************************************/
static void show_usage(char *name)
{
printf("\nUsage: \n");
printf("%s [option] value \n", name);
printf("\n");
printf("Options: \n");
printf("\t-a\tMean time between arrivals (in seconds) \n");
printf("\t-d\tMean service time (in seconds) \n");
printf("\t-s\tTotal simulation time (in seconds) \n");
printf("\t-k\tTotal capacity of the system (in # of customers) \n");
exit(EXIT_SUCCESS);
}