530 likes | 541 Views
Elements of Queuing Theory. The queuing model Core components; Notation; Parameters and performance measures Characteristics; Markov Process Discrete-time Markov chain; Continuous-time Markov chain; Birth-death process; Some typical and often-used distributions Exponential Distribution;
E N D
Elements of Queuing Theory • The queuing model • Core components; • Notation; • Parameters and performance measures • Characteristics; • Markov Process • Discrete-time Markov chain; • Continuous-time Markov chain; • Birth-death process; • Some typical and often-used distributions • Exponential Distribution; • Poisson Distribution; • M/M/1 • Little’s Law • Brief review of M/M/s, M/G/1, M/D/1 • Some additional discussions.
Queuing Systems • Core components of the model • Arrival process • Buffer (the so-called queue) • Infinite or finite; • Service process • single or parallel servers • Service discipline (FIFO, random)
Kendall Notation for Queuing Systems(1951) a/b/s/e/p/d • a, specifies the arrival process • b, specifies the service process • s, is the number of parallel servers in the system • e, (usually ) is buffer size (i.e. maximum number of customers allowed in system) • p, (usually ) is size of customer population • d, is the service discipline (FIFO, LIFO, etc.)
Queuing model parameters = average rate of customer arrivals (no. of customers/unit time) = average rate of customer service by a server (no. of customers/unit time) (1/ = average service time) s = number of servers (channels) in the system If > s , then . . . If < s , then . . . The queuing systems is in steady state when the rate of departures from the system equals the rate of arrivals.
Queuing Performance measures Lq = average number of customers in queue Wq = average waiting time in queue (until service starts) L = average number of customers in system = Lq + (averagenumber being served) W = average time a customer spends in system = Wq + 1/ = utilization factor = /(s ) = busy time per unit time for each server = fraction of time a server is busy (on average) Pn = the probability (or fraction of time) that exactly n customers are in the system Pzn = the probability (or fraction of time) that at least n customers are in the system PW = Pzs = the probability that a customer must wait for service (or the fraction of customers who must wait at least some time in the queue)
Customer Arrival Characteristics • Size of the Customer Population • infinite or finite • assume infinite when rate of customer arrival unaffected by number of customers in system • if potential number of customers are limited (e.g. Xerox machines), then if all machines are broken, no more new customer arrivals • Composition of the Customer Population • homogeneous or heterogeneous (e.g., the d.s. of interarrivals) • Customer behaviour • well-behaved (waits until serviced after joining queue) • balk (leaves queue without joining) • renege (joins queue, but leaves before service when wait too long)
Customer Arrival Process • Interarrival times - the times between successive customer arrivals. • A large majority of the arrival patterns in real queuing systems appear to be generated by what is called a Poisson Process, in which the time between successive arrivals is exponentially distributed.
Service Characteristics • For each category of customer it is necessary to describe the service process. This is usually expressed as a probability distribution for service times. • System configuration • number, type and configuration of servers • queue capacity • Queue Discipline • FIFO (first in, first out) • LIFO (last in, first out) • priority • random
Markov Process The probabilistic future of the process depends only on the current state and not upon the history of the process. In other words, the entire history of the process is summarized in the current state. Markov chain: A Markov process with discrete state space discrete-time Markov chain and continuous-time Markov chain: focus of our further discussions.
Discrete-Time Markov chain (cont’d) A matrix that satisfies the above properties is called a stochastic matrix.
Discrete-Time Markov chain (cont’d) The Chapman-Kolomogorov Equation:
Discrete-Time Markov chain (cont’d) The matrix form: Apparently,
Discrete-Time Markov chain (cont’d) Therefore, by solving the system of linear equations defined by: Where: We get the system invariant measure or stable d.f. It is not discussed in this course the conditions under which the above results hold. For ones who are interested, pls. refer to corresponding papers or books where detailed discussions or analysis are made.
1 1/4 0 1 2 1/4 1 1/2 Discrete-Time Markov chain (cont’d) The example: one-step transition matrix: The equilibrium equation in matrix notation: The transition diagram: The invariant measure:
Continuous-time Markov chain The Chapman-Kolmgorov Equation for C-M.C.:
Where: Continuous-time Markov chain(cont’d)
Continuous-time Markov chain(cont’d) By solving the following system of equations, we can get the invariant measure:
Continuous-time Markov chain(cont’d) It is not discussed in this course the conditions under which the above results hold. For ones who are interested, pls. refer to corresponding papers or books where detailed discussions or analysis are made.
1 1 0 1 2 2 1 Continuous-time Markov chain (cont’d) The example: the Q matrix: The equilibrium equation in matrix notation: The transition diagram: The invariant measure:
Birth-Death Process (cont’d) Then we get the differential equation:
Birth-Death Process (cont’d) Then we get: Or equivalently: The equilibrium equations or the balance equations of a birth and death process
Birth-Death Process (cont’d) The computation of p0 relies on the fact: C<infinite
Density function: for t > 0 CDF: for t 0 = 0 for t < 0 Exp. Value of T Variance of T Exponential Distribution (Continuous random variable)
Exponential Distribution Memoryless Property (Continuous random variable)
Poisson distribution (Discrete random variable) X {0, 1, 2, 3, ….} X= 0, 1, 2, ….. parameter, e = 2.718 Expected value of X = , Variance of X =
Poisson Process (cont’d) The counting process Proof:
Poisson Process (cont’d) Proof (cont’d): For n>0, we have:
Poisson Process (cont’d) Proof (cont’d): By noting the initial condition Pk(0) = 0, k>0, solving the differential equation recursively yields the desired results. This says, in particular, the mean number of events per time unit, or equivalently, the rate at which events occur, is given by E[N(t)]/ t = λ. This is why λ is called the rate of the Poisson process.
Poisson Process (cont’d) Proof:
Poisson Process (cont’d) Additional properties of Poisson Process: The inverse is also valid.
Catalogue of Queues • Single server, Poisson arrivals • M/G/1 • M/M/1 • M/D/1 • Multiple servers, Poisson arrivals • M/G/s • M/M/s • etc, etc,
M/M/1 • In summary: • Arrival process is Poisson Process; • Departure process is Poisson Process; • Service discipline is FCFS;
M/M/1 (cont’d) The transition diagram: This parameter is often called the utilization level of the system because it tells the average load status of the system.
M/M/1 (cont’d) Ls = Lq + Ws = Wq + 1/
1. • Consider one customer: • wait in queue for • how many people arrive during this time? • = inter-arrival time 2. where is the average service time Little’s Law • Relationship between the performance measures for any queue.
3. For each server, expected # customers in service For s servers, exp. # in services 4. Little’s Law
MultiServer Systems with Exponential Service Times (M/M/s Systems) = /(s) Pn = Lq = [(/ )sP0]/[s!(1- )2] Ls = Lq + / Wq = Lq / Ws = Wq + 1/
Queuing Example • Purchase two facsimile transmission (fax) machine for use of two departments. • For each dept:
Example: Two separate queues • Modelled as two separate M/M/1 queues, we get the following performance measures:
Example: Common pool • 36/day from Design + 36/day from sales = 72items/day = • M/M/2 system with = 72 items per day and =48 items per day.
Benefits of Pooling Servers • The result for example 2 holds in general: If customers are homogeneous, then there will be less customer waiting on average if servers are pooled into one queuing system. • Notice that in both systems the utilization rates are the same, so the servers do not work any harder or longer in one configuration versus the other. • Instead, they work more effectively in a pooled system by coordinating their idle time so that a server is never idle while other servers have queues. • As long as customers can choose which queue to enter and can switch among queues, system with s queues should behave no differently than a system with one queue.
M/G/1 Systems • the variance of the service time = 2
M/D/1 Systems • When the service times are a constant, so that 2=0, we say that the service distribution is deterministic. • Everything else being equal, the more variation in service times, the longer queues will be on average and the longer customers will wait on average.
Role of Variance in Queuing Systems Everything else being equal, the greater the randomness in arrival times and/or services times, the larger the average queue lengths and waiting times. • Therefore, anything we can do to reduce variation will help to reduce customer waiting. • Pacing of customer arrivals reduces waiting • The psychology of queues • making the waiting time interesting (Disneyland?)