Misplaced Pages

Finite & Deterministic Discrete Event System Specification

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from FD-DEVS)
This article may be too technical for most readers to understand. Please help improve it to make it understandable to non-experts, without removing the technical details. (January 2019) (Learn how and when to remove this message)

FD-DEVS (Finite & Deterministic Discrete Event System Specification) is a formalism for modeling and analyzing discrete event dynamic systems in both simulation and verification ways. FD-DEVS also provides modular and hierarchical modeling features which have been inherited from Classic DEVS.

History

FD-DEVS was originally named as "Schedule-Controllable DEVS" and designed to support verification analysis of its networks which had been an open problem of DEVS formalism for 30 years. In addition, it was also designated to resolve the so-called "OPNA" problem of SP-DEVS. From the viewpoint of Classic DEVS, FD-DEVS has three restrictions

  1. finiteness of event sets and state set,
  2. the lifespan of a state can be scheduled by a rational number or infinity, and
  3. the internal schedule can be either preserved or updated by an input event.

The third restriction can be also seen as a relaxation from SP-DEVS where the schedule is always preserved by any input events. Due to this relaxation there is no longer OPNA problem, but there is also one limitation that a time-line abstraction which can be used for abstracting elapsed times of SP-DEVS networks is no longer useful for FD-DEVS network . But another time abstraction method which was invented by Prof. D. Dill can be applicable to obtain a finite-vertex reachability graph for FD-DEVS networks.

Examples

Ping-pong game

Fig. 1: FD-DEVS coupled diagram for ping-pong game

Consider a single ping-pong match in which there are two players. Each player can be modeled by FD-DEVS such that the player model has an input event ?receive and an output event !send, and it has two states: Send and Wait. Once the player gets into "Send", it will generates "!send" and go back to "Wait" after the sending time which is 0.1 time unit. When staying at "Wait" and if it gets "?receive", it changes into "Send" again. In other words, the player model stays at "Wait" forever unless it gets "?receive".

To make a complete ping-pong match, one player starts as an offender whose initial state is "Send" and the other starts as a defender whose initial state is "Wait". Thus in Fig. 1. Player A is the initial offender and Player B is the initial defender. In addition, to make the game continue, each player's "?send" event should be coupled to the other player's "?receive" as shown in Fig. 1.

Two-slot toaster

Fig. 2: (a) Two-slot toaster (b) FD-DEVS coupled diagram for two-slot toaster

Consider a toaster in which there are two slots that have their own start knobs as shown in Fig. 2(a). Each slot has the identical functionality except their toasting time. Initially, the knob is not pushed, but if one pushes the knob, the associated slot starts toasting for its toasting time: 20 seconds for the left slot, 40 seconds for the right slot. After the toasting time, each slot and its knobs pop up. Notice that even though one tries to push a knob when its associated slot is toasting, nothing happens.

One can model it with FD-DEVS as shown in Fig. 2(b). Two slots are modeled as atomic FD-DEVS whose input event is "?push" and output event is "!pop", states are "Idle" (I) and "Toast" (T) with the initial state is "idle". When it is "Idle" and receives "?push" (because one pushes the knob), its state changes to "Toast". In other words, it stays at "Idle" forever unless it receives "?push" event. 20 (res. 40) seconds later the left (res. right) slot returns to "Idle".

Atomic FD-DEVS

Formal Definition

M =< X , Y , S , s 0 , τ , δ x , δ y > {\displaystyle M=<X,Y,S,s_{0},\tau ,\delta _{x},\delta _{y}>}

where

  • X {\displaystyle X} is a finite set of input events;
  • Y {\displaystyle Y} is a finite set of output events;
  • S {\displaystyle S} is a finite set of states;
  • s 0 S {\displaystyle s_{0}\in S} is the initial state;
  • τ : S Q [ 0 , ] {\displaystyle \tau :S\rightarrow \mathbb {Q} _{}} is the time advance function which defines the lifespan of a state where Q [ 0 , ] {\displaystyle \mathbb {Q} _{}} is the set of non-negative rational numbers plus infinity.
  • δ x : S × X S × { 0 , 1 } {\displaystyle \delta _{x}:S\times X\rightarrow S\times \{0,1\}} is the external transition function which defines how an input event changes the schedule as well as a state of the system. The internal schedule of a state s S {\displaystyle s\in S} is updated by τ ( s ) {\displaystyle \tau (s')} if δ x ( s ) = ( s , 1 ) {\displaystyle \delta _{x}(s)=(s',1)} , otherwise(i.e., δ x ( s ) = ( s , 0 ) {\displaystyle \delta _{x}(s)=(s',0)} ), the schedule is preserved.
  • δ y : S Y ϕ × S {\displaystyle \delta _{y}:S\rightarrow Y^{\phi }\times S} is the output and internal transition function where Y ϕ = Y { ϕ } {\displaystyle Y^{\phi }=Y\cup \{\phi \}} and ϕ Y {\displaystyle \phi \notin Y} denotes the silent event. The output and internal transition function defines how a state generates an output event, at the same time, how the state changes internally.
Formal Representation of Ping-Pong Player

The formal representation of the player in the ping-pong example shown in Fig. 1 can be given as follows. M =< X , Y , S , s 0 , τ , δ x , δ y > {\displaystyle M=<X,Y,S,s_{0},\tau ,\delta _{x},\delta _{y}>} where X {\displaystyle X} ={?receive}; Y {\displaystyle Y} ={!send}; S {\displaystyle S} ={Send, Wait}; s 0 {\displaystyle s_{0}} =Send for Player A, Wait for Player B; τ {\displaystyle \tau } (Send)=0.1, τ {\displaystyle \tau } (Wait)= {\displaystyle \infty } ; δ x {\displaystyle \delta _{x}} (Wait,?receive)=(Send,1), δ x {\displaystyle \delta _{x}} (Send,?receive)=(Send,0); δ y {\displaystyle \delta _{y}} (Send)=(!send, Wait), δ y {\displaystyle \delta _{y}} (Wait)=( ϕ {\displaystyle \phi } , Wait).

Formal Representation of One Slot Toaster

The formal representation of the slot of Two-slot Toaster Fig. 2(a) and (b) can be given as follows. M =< X , Y , S , s 0 , τ , δ x , δ y > {\displaystyle M=<X,Y,S,s_{0},\tau ,\delta _{x},\delta _{y}>} where X {\displaystyle X} ={?push}; Y {\displaystyle Y} ={!pop}; S {\displaystyle S} ={I, T}; s 0 {\displaystyle s_{0}} =I; τ {\displaystyle \tau } (T)=20 for the left slot, 40 for the right slot, τ {\displaystyle \tau } (I)= {\displaystyle \infty } ; δ x {\displaystyle \delta _{x}} (I, ?push)=(T,1), δ x {\displaystyle \delta _{x}} (T,?push)=(T,0); δ y {\displaystyle \delta _{y}} (T)=(!pop, I), δ y {\displaystyle \delta _{y}} (I)=( ϕ {\displaystyle \phi } , I).

Formal Representation of Crosswalk Light Controller

As mentioned above, FD-DEVS is an relaxation of SP-DEVS. That means, FD-DEVS is a supper class of SP-DEVS. We would give a model of FD-DEVS of a crosswalk light controller which is used for SP-DEVS in this Misplaced Pages. M =< X , Y , S , s 0 , τ , δ x , δ y > {\displaystyle M=<X,Y,S,s_{0},\tau ,\delta _{x},\delta _{y}>} where X {\displaystyle X} ={?p}; Y {\displaystyle Y} ={!g:0, !g:1, !w:0, !w:1}; S {\displaystyle S} ={BG, BW, G, GR, R, W, D}; s 0 {\displaystyle s_{0}} =BG, τ {\displaystyle \tau } (BG)=0.5, τ {\displaystyle \tau } (BW)=0.5, τ {\displaystyle \tau } (G)=30, τ {\displaystyle \tau } (GR)=30, τ {\displaystyle \tau } (R)=2, τ {\displaystyle \tau } (W)=26, τ {\displaystyle \tau } (D)=2; δ x {\displaystyle \delta _{x}} (G,?p)=(GR,0), δ x {\displaystyle \delta _{x}} (s,?p)=(s,0) if s {\displaystyle \neq } G; δ y {\displaystyle \delta _{y}} (BG)=(!g:1, BW), δ y {\displaystyle \delta _{y}} (BW)=(!w:0, G), δ y {\displaystyle \delta _{y}} (G)=( ϕ {\displaystyle \phi } , G), δ y {\displaystyle \delta _{y}} (GR)=(!g:0, R), δ y {\displaystyle \delta _{y}} (R)=(!w:1, W), δ y {\displaystyle \delta _{y}} (W)=(!w:0, D), δ y {\displaystyle \delta _{y}} (D)=(!g:1, G);

Behaviors of FD-DEVS Models

Fig. 3. an Event Segment and a State Trajectory of Player A
FD-DEVS is a sub-class of DEVS

A FD-DEVS model, M =< X , Y , S , s 0 , τ , δ x , δ y > {\displaystyle M=<X,Y,S,s_{0},\tau ,\delta _{x},\delta _{y}>} is DEVS M =< X , Y , S , s 0 , t a , δ e x t , δ i n t , λ > {\displaystyle {\mathcal {M}}=<X,Y,S',s_{0}',ta,\delta _{ext},\delta _{int},\lambda >} where

  • X , Y {\displaystyle X,Y} of M {\displaystyle {\mathcal {M}}} are the same as those of M {\displaystyle M} .
  • S = { ( s , t s ) : s S , t s T } {\displaystyle S'=\{(s,t_{s}):s\in S,t_{s}\in \mathbb {T} ^{\infty }\}}
  • s 0 = ( s 0 , τ ( s 0 ) ) {\displaystyle s_{0}'=(s_{0},\tau (s_{0}))}
  • Given a state ( s , t s ) S {\displaystyle (s,t_{s})\in S'} , t a ( s , t s ) = t s . {\displaystyle ta(s,t_{s})=t_{s}.}
  • Given a state ( s , t s ) S {\displaystyle (s,t_{s})\in S'} and an input event x X {\displaystyle x\in X} ,

δ e x t ( s , t s , t e , x ) = { ( s , t s t e ) if  δ x ( s , x ) = ( s , 0 ) ( s , τ ( s ) ) if  δ x ( s , x ) = ( s , 1 ) {\displaystyle \delta _{ext}(s,t_{s},t_{e},x)={\begin{cases}(s',t_{s}-t_{e})&{\text{if }}\delta _{x}(s,x)=(s',0)\\(s',\tau (s'))&{\text{if }}\delta _{x}(s,x)=(s',1)\\\end{cases}}}

  • Given a state ( s , t s ) S {\displaystyle (s,t_{s})\in S'} , δ i n t ( s , t s ) = ( s , τ ( s ) ) {\displaystyle \delta _{int}(s,t_{s})=(s',\tau (s'))} if δ y ( s ) = ( y , s ) . {\displaystyle \delta _{y}(s)=(y,s').}
  • Given a state ( s , t s ) S {\displaystyle (s,t_{s})\in S'} , λ ( s , t s ) = y {\displaystyle \lambda (s,t_{s})=y} if δ y ( s ) = ( y , s ) . {\displaystyle \delta _{y}(s)=(y,s').}

For details of DEVS behavior, the readers can refer to Behavior of Atomic DEVS

Behavior of Ping-Pong Player A

Fig. 3. shows an event segment (top) and the associated state trajectory (bottom) of Player A who plays the ping-pong game introduced in Fig. 1. In Fig. 3. the status of Player A is described as (state, lifespan, elapsed time)=( s , t s , t e {\displaystyle s,t_{s},t_{e}} ) and the line segment of the bottom of Fig. 3. denotes the value of the elapsed time. Since the initial state of Player A is "Send" and its lifetime is 0.1 seconds, the height of (Send, 0.1, t e {\displaystyle t_{e}} ) is 0.1 which is the value of t s {\displaystyle t_{s}} . After changing into (Wait, inf, 0) when t e {\displaystyle t_{e}} is reset by 0, Player A doesn't know when t e {\displaystyle t_{e}} becomes 0 again. However, since Player B sends back the ball to Player A 0.1 second later, Player A gets back to (Send, 0.1 0) at time 0.2. From that time, 0.1 seconds later when Player A's status becomes (Send, 0.1, 0.1), Player A sends back the ball to Player B and gets into (Wait, inf, 0). Thus, this cyclic state transitions which move "Send" to "Wait" back and forth will go forever.

Fig. 4. an Event Segment and a State Trajectory of a Toaster
Behavior of a Toaster

Fig. 4. shows an event segment (top) and the associated state trajectory (bottom) of the left slot of the two-slot toaster introduced in Fig. 2. Like Fig.3, the status of the left slot is described as (state, lifespan, elapsed time)=( s , t s , t e {\displaystyle s,t_{s},t_{e}} ) in Fig. 4. Since the initial state of the toaster is "I" and its lifetime is infinity, the height of (Wait, inf, t e {\displaystyle t_{e}} ) can be determined by when ?push occurs. Fig. 4. illustrates the case ?push happens at time 40 and the toaster changes into (T, 20, 0). From that time, 20 seconds later when its status becomes (T, 20, 20), the toaster gets back to (Wait, inf, 0) where we don't know when it gets back to "Toast" again. Fig. 4. shows the case that ?push occurs at time 90 so the toaster get into (T,20,0). Notice that even though there someone push again at time 97, that status (T, 20, 7) doesn't change at all because δ x {\displaystyle \delta _{x}} (T,?push)=(T,1).

Advantages

Fig. 5. Reachability Graph of Two-slot Toaster

Applicability of Time-Zone Abstraction

The property of non-negative rational-valued lifespans which can be preserved or changed by input events along with finite numbers of states and events guarantees that the behavior of FD-DEVS networks can be abstracted as an equivalent finite-vertex reachability graph by abstracting the infinitely-many values of the elapsed times using the time abstracting technique introduced by Prof. D. Dill . An algorithm generating a finite-vertex reachability graph (RG)has been introduced in , .

Reachability Graph

Fig. 5. shows the reachability graph of two-slot toaster which was shown in Fig. 2. In the reachability graph, each vertex has its own discrete state and time zone which are ranges of t e 1 , t e 2 {\displaystyle t_{e1},t_{e2}} and t e 1 t e 2 {\displaystyle t_{e1}-t_{e2}} . For example, for node (6) of Fig. 5, discrete state information is ((E, {\displaystyle \infty } ),(T,40)), and time zone is 0 t e 1 40 , 0 t e 2 40 , 20 t e 1 t 21 0 {\displaystyle 0\leq t_{e1}\leq 40,0\leq t_{e2}\leq 40,-20\leq t_{e1}-t_{21}\leq 0} . Each directed arch shows how its source vertex changes into the destination vertex along with an associated event and a set of reset models. For example, the transition arc (6) to (5) is triggered by push1 event. At that time, the set {1} of the arc denotes that elapsed time of 1 (that is t e 1 {\displaystyle t_{e1}} is reset by 0 when transition (6) to (5) occurs. For more detailed information, the reader can refer to .

Decidability of Safety

As a qualitative property, safety of a FD-DEVS network is decidable by (1) generating RG of the given network and (2) checking whether some bad states are reachable or not .

Decidability of Liveness

As a qualitative property, liveness of a FD-DEVS network is decidable by (1) generating RG of the given network, (2) from RG, generating kernel directed acyclic graph (KDAG) in which a vertex is strongly connected component, and (3) checking if a vertex of KDAG contains a state transition cycle which contains a set of liveness states.

Disadvantages

Weak Expressiveness for describing nondeterminism

The features that all characteristic functions, τ , δ x , δ y {\displaystyle \tau ,\delta _{x},\delta _{y}} of FD-DEVS are deterministic can be seen as somehow a limitation to model the system that has non-deterministic behaviors. For example, if a player of the ping-pong game shown in Fig. 1. has a stochastic lifespan at "Send" state, FD-DEVS doesn't capture the non-determinism effectively.

Tool

For Verification

There are two open source libraries DEVS# written in C# at http://xsy-csharp.sourceforge.net/DEVSsharp/ and XSY written in Python at https://code.google.com/p/x-s-y/ that support some reachability graph-based verification algorithms for finding safeness and liveness.

For Simulation via XML

For standardization of DEVS, especially using FDDEVS, Dr. Saurabh Mittal together with co-workers has worked on defining of XML format of FDDEVS. We can find an article at http://www.duniptechnologies.com/research/xfddevs/. This standard XML format was used for UML execution .

Footnotes

  1. δ x {\displaystyle \delta _{x}} can be divided into two functions: ρ : S × X { 0 , 1 } {\displaystyle \rho :S\times X\rightarrow \{0,1\}} and δ x : S × X S {\displaystyle \delta _{x}:S\times X\rightarrow S} as in .
  2. δ y {\displaystyle \delta _{y}} can be divided into two functions: λ : S Y ϕ {\displaystyle \lambda :S\rightarrow Y^{\phi }} and δ i n t : S S {\displaystyle \delta _{int}:S\rightarrow S} as in .
  3. inf in Fig 3. means {\displaystyle \infty } .

References

Category:
Finite & Deterministic Discrete Event System Specification Add topic