# STATE UNIVERSITY OF NEW YORK AT 

STONY BROOK

## CEAS TECHNICAL REPORT 597

BOUNDS FOR A PETRI NET MODEL OF A COMPLEX MULTIPROCESSOR

## R.-X. NI AND T.G. ROBERTAZZI

March 8, 1991

# Bounds for a Petri Net Model of a Complex Multiprocessor 

THOMAS G. ROBERTAZZI and RONG-XIANG NI<br>Department of Electrical Engineering State University of New York at Stony Brook Stony Brook, NY 11794


#### Abstract

In this paper we establish upper and lower bounds for a Petri network model of a multiprocessor with multiple memories. Most of the principles in this paper are based on those of our prior paper [4].


## I Introduction

Petri network models have been used successfully to model multiprocessor systems [1]. Such models may or may not have product form solution [3]. In this correspondence, models which can generate upper and lower bounds for important performance measures of a canonical and practical dual processor model are presented.

The system of interest is shown in figure 1. It contains two common memories, $M_{1}$ and $M_{2}$, and two processors, $P_{1}$ and $P_{2}$. A stochastic Petri Net model is illustrated in figure 2. The model consists of four sequences of events called tasks. The underlying statistical assumptions are Markovian. When internally ACTIVE, (that is, externally idle,) $P_{1}\left(P_{2}\right)$ can request the use of $M_{1}\left(M_{2}\right)$ with the rate of $q^{30}\left(q^{40}\right)$ and the use of $M_{2}\left(M_{1}\right)$ with the rate of $q^{10}\left(q^{20}\right)$. Once a task sequence is in either the GLOBAL BUS REQUEST place or the LOCAL BUS(MB ${ }_{1}$ ) REQUEST place, it can access the bus at rate $q^{11}, q^{12}, q^{21}$, $q^{22}, q^{31}$ and $q^{41}$, as shown in figure 2, if the bus is free. That is, contention arises as only one processor may access the bus at one time. We assume that $P_{1}$ needs an average of $1 / q^{32}$ memory access time for $M_{1}$ and $1 / q^{13}$ for $M_{2}$, and that $P_{2}$ needs an average of $1 / q^{42}$ memory access time for $M_{2}$ and $1 / q^{23}$ for $M_{2}$. We also assume that all the transition rates are exponentially distributed.

The state transition diagram of this model is shown in figure 3. This model has no product form solution since the transitions do not all belong to integral building blocks [2]. The equilibrium state probabilities of this model can be obtained by solving the linear global balance equations. In practice, it may not be necessary to obtain equilibrium state probabilities. A quick estimation of the range of some specified performance measures may be enough. In this paper, we will use a bounding methodology, which has been described by [ 4 ], for the model in figure 1.

The organization of this paper is as follows. In section II, we will develop the upper bound and the lower bound for memory utilization. In section III, we will do the same for the blocking probability.

## II Memory Utilization

Memory utilization, $U$, is the fraction of time that any one of the memories is being accessed by either of the processors. It corresponds to the states $(-2,-2)$, $(-2,-1),(-2,0),(-2,1),(-2,2),(-1,3),(0,3),(1,3)(3,1),(3,0),(3,-1),(2,-2),(1,-2)$, $(0,-2)$ and $(-1,-2)$ in figure 3.

1. Lower Bound Model

We modify the model in figure 2 as follows. Whenever a processor wishes to move from being ACTIVE to a BUS REQUEST, it may only do so if the corresponding memory is free. If the memory is busy at that time, then the request is lost. Since some of the requests are lost, there are fewer requests per unit time in this model. Therefore, this model can provide a lower bound for the memory utilization for the model in figure 2. The transition diagram of the modified model is like that of figure 3 except that the transitions from state ( 0,2 ) to state $(1,2)$, from state $(0,3)$ to state $(1,3)$, from state $(0,3)$ to state $(-1,3)$, from
state $(2,0)$ to state $(2,1)$, from state $(3,0)$ to state $(3,1)$, from state $(3,0)$ to state $(3,-1)$, from state $(-2,0)$ to state $(-2,1)$, from state $(-2,1)$ to state $(-2,2)$, from state $(0,-2)$ to state $(1,-2)$ and from state $(1,-2)$ to state $(2,-2)$ are taken out. The resultant model is a product form model as the state transition diagram consists of integral building blocks. The equilibrium state probabilities are given by:

$$
\begin{aligned}
& P_{l}(i, j)=\frac{q^{10}}{q^{1 i}} \frac{q^{20}}{q^{2 j}} P_{l}(0,0) \\
& P_{l}(-i, j)=\frac{q^{30}}{q^{3 i}} \frac{q^{20}}{q^{2 j}} P_{l}(0,0) \\
& P_{l}(-i,-j)=\frac{q^{30}}{q^{3 i}} \frac{q^{40}}{q^{4 j}} P_{l}(0,0) \\
& P_{l}(i,-j)=\frac{q^{10}}{q^{1 i}} \frac{q^{40}}{q^{4 j}} P_{l}(0,0)
\end{aligned}
$$

The lower bound of the memory utilization, $U_{l}$, is correspond to the same states.

## 2. Upper Bound Model

For the upper bound model, we assume that there is always a request from each processor, that is, $q^{10}=\infty, q^{11}=\infty, q^{20}=\infty, q^{21}=\infty, q^{30}=\infty$ and $q^{40}=\infty$. This model is shown in figure 4. Naturally, there are more requests per unit time in this model. Therefore, this model can provide an upper bound for the memory utilization for the model in figure 2. The transition diagram of this upper bound model is shown in figure 5. The upper bound model is also a product form model as the state transition diagram consists of integral building blocks. The equilibrium state probabilities are the same as the lower bound's except that the initial transition rates, i.e., $q^{10}$ is replaced by $q^{12}, q^{20}$ is replaced by $q^{22}, q^{30}$ is replaced by $q^{31}$ and $q^{40}$ is replaced by $q^{41}$. The upper bound of the memory utilization, $U_{u}$, is corresponds to the states $(-2,-2),(-2,-1),(-2,0)$, $(-1,-2),(0,-2),(-1,1),(0,1),(1,1),(1,0)$ and $(1,-1)$.

## III Blocking Probability

Blocking probability, $P_{b}$, is the fraction of times that the bus requests are blocked. For the model in figure 2, it is corresponds to states $(-2,0),(-2,1),(-2,2)$, $(-1,3),(0,3),(0,2),(1,2),(1,3),(2,0),(2,1),(3,0),(3,1),(3,-1),(0,-2),(1,-2)$ and $(2,-2)$. Its lower bound model can be adapted from the the lower bound model of the memory utilization. Since some of the requests are lost, this model has less requests for using the memories and hence the probability of being blocked will be smaller. The lower bound for the blocking probability, $P_{b l}$, corresponds to the same states.

We note that it appears to be difficult to generate an upper bound model for blocking probability. We have been unsuccessful in our attempts to do this.

## IV Conclusion

We have introduced bounding methodology to a complicated stochastic Petri Net model of a multiprocessor systems. We feel that this method is convenience
in the study of non-product form systems.

## Acknowledgements

The research in this paper was supported in part by the National Science Foundation under Grant no. NCR-8703689 and by the SDIO/IST and managed by the U.S. Office of Naval Research under Grant no. N00014-85-K0610.

## References

1. Ajmone Marsan, M., Balbo, G. and Conte, G., "Performance Models of Multiprocessors Systems", The MIT Press, London, 1988.
2. Lazar, A. A. and Robertazzi, T. G., "The Geometry of Lattices for Multiclass Markovian Queueing Network", Proceedings of the 1984 Conference on Information Sciences and Systems, Princeton, March 1984, pp. 164-168.
3. Lazar, A. A. and Robertazzi, T. G., "Markovian Petri Net Protocols with Product Form Solution", IEEE INFOCOM'87, San Francisco, CA., March, 1987.
4. Ni, R. and Robertazzi, T. G., "Bounds for a Petri Net Model of a Multiprocessors", submitted to IEEE Transition on Computer.
5. Van Dijk, N., "A Simple Methodology for Non-Product-Form Finite Capacity queueing Systems", Proceedings of the First International Workshop Queueing Networks with Blocking", North Carolina State University, May 1988, Elsevier North-Holland, H. G. Perrors and T. Altiok, ed., 1989.

Figure 1.



Figure 3


Figure 4


Figure 5

