Discrete event simulation specification (DEVS) is a formalism designed to describe both discrete state and continuous state systems. It is a powerful abstract mathematical notation. However, until recently it lacked proper graphical representation, which made computer simulation of DEVS models a challenging issue. Unified modeling language (UML) is a multipurpose graphical modeling language, a de-facto industrial modeling standard. There exist several commercial and open-source UML editors and code generators. Most of them can save UML models in XML-based XMI files ready for further automated processing. In this paper, we propose a mapping of DEVS models onto UML state and component diagrams. This mapping may lead to an eventual unification of the two modeling formalisms, combining the abstractness of DEVS and expressive power and "computer friendliness" of the UML.
INTRODUCTION
Discrete event simulation specification (DEVS [11] - [13] ) is a powerful formalism for describing discrete event state systems. Various flavors of this formalism have been developed. In this paper, we are using classic DEVS with ports, which we call, simply, DEVS.
Being hierarchical and encapsulated, the DEVS formalism can be naturally implemented in an object-oriented language, such as Java [9] . However, Java-based simulation environments have never been standardized (unlike the DEVS formalism).
An important drawback of the DEVS formalism is the lack of a standardized graphics representation. In [2] , an attempt has been undertaken to develop DCharts, a graphics language for DEVS models. DCharts is a UML-based language; however, it does not strictly follow any UML standard. Moreover, the DEVS-to-DCharts transformation proposed in [2] collapses all DEVS states into one DCharts state, essentially eliminating the discrete state nature of DEVS models.
In [5] , it is proposed that atomic DEVS models be represented with the help of UML sequence diagrams. However, the sequence diagrams show actual, rather than potential, flow of events. Because of this, a sequence diagram is limited to a particular scenario and cannot unambiguously describe the behavior of a system in its entirety.
An excellent mapping between DEVS models and UML state charts has been introduced in [10] . However, the paper does not suggest a formal mathematical way of constructing the state charts, and thus avoids the issue of the structural clash between DEVS continuous states and UML finite states.
It also relies on the older versions of the UML (< 2.0), which did not have an explicit notion of time.
In this paper, we propose a consistent DEVS-to-UML mapping that takes care of all issues mentioned above. Further restricting the mapping to the executable UML (which is a proper subset of UML [7] ) would make a seamless connection between a DEVS model and an UML simulation process, but this topic is beyond the scope of this paper.
DEVS FORMALISM
DEVS supports two complementary models of describing discrete systems: an atomic model that specifies the behavior of an elementary system, and a coupled model that allows us to form more complex models by structurally interconnecting atomic and other coupled models.
A DEVS atomic model is a state machine with input ports IP = {π in i } and output ports OP = {π out i }. Events are associated with input and output ports (they happen at input ports and are generated at output ports). In general, states, unlike events, are not discrete.
Atomic Models
Atomic DEVS model Ma is a tuple of nine values Ma = {IP, OP, X, Σ, Y, δin, δext, λ, ta}. Here, IP and OP are sets of input and output ports.
Σ is a set of states {σi}. A DEVS state σi is uniquely identified with a set of state variables γi = {γij |σi = σ k ⇔ ∃j : γij = γ kj }.
X is a set of input events {xi = π in i , vi }, where π in i ∈ IP is the port name, and vi is the event value. Every event has an associated timestamp, or scheduled time-the time when the event is triggered.
Y is a set of output events {yi = π out i
, vi }, where π out i ∈ OP is the port name, or the event type, and vi is the event value. δint (σi) : Σ → Σ is the internal transition function. δext (σi, ei, xj) : (Σ × R × IP) → Σ is the external transition function, where ei is the elapsed time in state σi. λ (σi) : Σ → Y is the output function. ta (σi) : Σ → R is the time advance function.
The semantics of the model are as follows: the system stays in state σi for ta (σi) time units (until a timeout event) or until an external event happens, whatever comes first. In the case of an external event xj, the system changes its state to δext (σi, ei, xj). In the case of a timeout, the system changes its state to δint (σi) and generates an event of type λ (σi). In either case, the simulation time is implicitly advanced to the timestamp of the event that triggered the transition. The initial state of the model is not defined explicitly. ∈ IP is the port name, and vi is the event value, and Y is a set of output events yi = π out i
, vi , where π out i ∈ OP is the port name, and vi is the event value. D = {di} is a set of references to the coupled components (atomic models or other coupled models), and M = {M d |d ∈ D} is a set of the coupled components. 
external output coupling that connects components' output ports OP d to the external output ports of the coupled model.
OPai ∈ OPa, IP bj ∈ IP b } is internal coupling that interconnects output and input ports of the components. Finally, S : {ǫ d |d ∈ D} → ǫ d is a selection function that resolves potential scheduling conflicts, when more than one event in different components has the same scheduled time.
Under the principle of closure, a coupled model looks externally like an atomic model and can be used anywhere in place of an atomic model.
A coupled model is simulated as an ensemble of its DEVS components. Output events generated by each individual component are propagated to the input ports of other coupled components or to the output ports of the model, according to the functions IC and EOC. In the former case, they are also converted into appropriate input events. Input events received by the model are propagated to the input ports of its components, according to the function EIC.
Classic DEVS formalism does not permit feedback loops:
UML FORMALISM
The Unified Modeling Language (UML [1] ), a de-facto industrial modeling standard, seems to be a natural choice for a visual representation of DEVS. Besides being widely supported by both proprietary and open-source tools (such as Rose [6] and Poseidon [3] ), it also has an associated XMLbased representation, XMI, that makes it possible to process UML diagrams by application programs.
Of particular interest for us are UML state and component diagrams, which will be discussed in detail.
State Diagrams
A UML state diagram (also known as a statechart, Figure 2) is a visual representation of a finite state automaton with history. Many of the features of state diagrams, such as "do" activities, history states, junction and choice states, concurrent and composite states, are not essential for DEVSto-UML mappings and will not be considered.
P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E d iti o P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E d iti o P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E d iti P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E d it P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E d P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E d P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity E P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity P o se id o n fo r U M L , C o m m u n ity E d iti o n P o se id o n fo r U M L , C o m m u n ity
• , S ⊙ , P, T }. Here S = {si = (Gi, wi, qi)} is a set of finite states. UML finite states are enumerated using state variable G, such that si = sj ⇔ Gi = Gj. wi(x) : any → None is an "entry" action. This action is executed just after changing the current state of the model to si. qi(x) : any → None is an "exit" action. This action is executed just before changing the current state of the model from si to some other state.
A set of possibly continuous pseudostate variables H = {h k } (|H| ≥ 0) extends the definition of a UML state. The pseudostate variables may or may not have different values in different states. They cannot be used to distinguish UML states in a state diagram. An optional class diagram of the UML system can be used to record these variables in the model ( Figure 3 ).
P o s e id o n fo r U M L , C o m m u n it y E d it io n P P o s e id o n fo r U M L , C o m m u n it y E d it io n P P o s e id o n fo r U M L , C o m m u n it y E d it io n P P o s e id o n fo r U M L , C o m m u n it y E d it io n P o s e id o n fo r U M L , C o m m u n it y E d it io n P o s e id o n fo r U M L , C o m m u n it y E d it io n
AtomicModel + gamma_1 :int + gamma_2 :double Because DEVS formalism does not specify the initial state of the system, we will assume that in general S • = ∅. S ⊙ = {si ∈ S} is the set final (terminal) states of the diagram. Because the final state of a DEVS system is not defined, we will assume that in general S ⊙ = ∅. P = {pj} is a set of discrete events. Each event pj has the associated scheduled time τj and a possibly empty set of other attributes.
Finally, T = {s bi , sei, pi, gi, ai|s bi , sei ∈ S, pi ∈ P, gi (x) : range(x) → {True, False}, ai(y) : any → None} is a set of transitions. In UML notation, a transition from state s bi to state sei on event pi with guard condition gi is denoted as pi [gi] /ai. Action ai is executed just before the completion of the transition. The action is not allowed to change the UML state of the system.
The semantics of a UML state diagram prescribes that in the course of transition ti from state sj to state s k the "exit" action qj is executed first, followed by the transition action ai, followed by the "entry" action w k .
Component Diagrams
UML component diagrams have evolved substantially from version 1.x of the language to the current 2.0 [1] , [8] . The direction of the evolution has favored the DEVS-to-UML mapping we are about to propose.
In the latest version of the language, deployment, object, and component diagrams have been merged into a single class of deployment/object/component (DOC) diagrams. These new DOC diagrams have a rich language suitable for elaborated models, but for the purpose of this paper we need to mention only components, interfaces, and ports. = {pij = (tij, ifij , dij)} of externally visible ports. A UML port p has a type. The type of the port specifies the names of the signals (events) that are acceptable through this port. For the purpose of this paper, we assume that the type t of the port is the same as its name. A port can be unidirectional (input or output) or bidirectional. The direction of the port dir(pij) is defined by the type(s) of its interfaces. Since DEVS formalism does not support bidirectional ports, we will not consider them and consider only one interface K = (n, d) per port, where n is the name of the interface and d = {required|provided} is its type. Required interfaces ("antennas") define output ports, and provided interfaces ("lollipops") define input ports.
C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on , C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on , C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on or U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on Po se id on fo r U M L, C om m un ity Ed iti on
<< component >> A << component >> M1E3In:E3In IRcv E1Out :E1Out ISend E4Out :E4Out ISend << component >> M2 E2Out :E2Out ISend E4In:E4In RIcv E3In:E3In IRcv E1Out :E1Out ISend E2Out :E2Out
ISend
A UML component represents either another UML component diagram, or a UML state diagram.
Set 
u } are called top-level components. The set:
is the external coupling that connects external ports of the component to the subcomponents' ports using UML delegation connectors. External ports must be connected to the internal ports of the same direction. The set:
is the internal coupling that interconnects ports of the subcomponents of the same component using UML assembly connectors. Internal ports must be connected to the internal ports of the opposite direction. Graphically, this is accomplished by matching "antennas" and "lollipops".
A simple UML component diagram (strictly speaking, a DOC diagram) is shown in Figure 4 . It depicts two components M1 and M2. These components are in turn subcomponents of component A. Component A has two output ports E1Out and E2Out with interface ISend and one input port E3In with interface IRcv. The output ports of subcomponents M1 and M2 are connected to the corresponding output ports of the component A, the input port of A is connected to the input port of subcomponent M1. Finally, the output port E4Out of component M1 with interface ISend is connected to the input port E4In of component M2 with interface IRcv.
Composite structure diagrams, which only recently have become a part of the UML 2.0 proposal [4] , offer even better mapping between DEVS models and UML models. However, the discussion of these diagrams is beyond the scope of this paper.
ATOMIC DEVS AND UML STATE DI-AGRAMS
To map an atomic DEVS model into an UML state diagram, we need to map states, ports, transitions, and outputs.
States
In general, DEVS states are neither discrete nor finite, while UML states are always discrete and finite. To map a DEVS system onto an UML system, the DEVS state must be discretized. This can be done by rearranging and grouping DEVS state variables γ = {γj } according to their kind. Discrete and finite variables can be collected in one subgroup, and countable and continuous variables-into another subgroup:
Let's call the first group finite DEVS state variables, and the other group free DEVS state variables.
For any feasible combination of values of finite DEVS state variables {γi|1 ≤ i ≤ m}, a UML finite state can be constructed by simply enumerating this combination: Gj = m i=1 γi, where the details of the function are not important as long as it always maps distinct combinations of finite DEVS state variables onto distinct UML states.
All remaining DEVS free state variables {γi|m < i ≤ n} are mapped to UML pseudostate variables H = {hi|1 ≤ i < n − m} one-to-one. They become attributes of finite states and will be manipulated during DEVS state transitions.
In the case of m = 0 a DEVS model has no finite state variables, and partitioning (3) is not possible. The UML state diagram will have only one final state. This case is presented in [2] .
On the other hand, when m = n, the DEVS model has no free variables. Every feasible combination of the DEVS state variables maps onto a UML finite state, and the UML model has no pseudostate variables.
Not being a dynamic simulation language, UML does not enforce an explicit notion of time in all types of diagrams. In particular, UML state diagrams do not have explicit time. The simulation time has to be maintained implicitly, with model-wide variable tcurr denoting the current simulation time.
For the purpose of computing state transitions, many DEVS models depend on the time ei spent by the model in state σi. To accommodate this need, we introduce another model-wide variable te-the time of the most recent state transition. An "entry" action wi can be added to every UML finite state that records the value of te:
At any given time, the value of ei can be now computed as:
4.2. Ports DEVS input and output ports are mapped to UML events one-to-one:
Input and output events are not distinguished in UML state diagrams.
DEVS formalism does not specify whether the same port can be used as an input port and an output port (whether IP ∩ OP = ∅). We will assume that the DEVS ports are indeed unidirectional. This means that an event of a certain type can be only consumed or produced by a state diagram, but not both.
External Transitions
The heterogeneous structure of DEVS states and UML states produces heterogeneous structures of DEVS and UML state transitions. Among other things, a single DEVS external transition function δext (σi, ei, xj) = (π in j , νj) has to generate both proper UML state transitions and their associated guard conditions and actions.
The total state ST i of a UML model is defined by the current UML finite state and the values of the pseudostate variables:
The total state Σi of a DEVS model is defined by the values of all DEVS state variables:
To reflect a transition from a DEVS state σi to another state σj, the corresponding UML model has to change from a UML state si = f (γi) to another UML state sj = f (σj ) and also update the values of the pseudostate variables: Hj = f (γj). Here, f (χ) : DEVS objects → UML objects is the polymorphic mapping function from the universe of DEVS objects to the universe of UML objects which has been partially defined above.
Action a e l associated with a possible UML transition t l=(ijk) = {si, sj, p k , g 
This function may be undefined for some or all values of H, ν, and e = ei. A condition for a possible UML transition is set C e l constructed in the following way:
The UML transition exists if and only if the corresponding condition is not an empty set:
Note that multiple transitions from si to sj may exist for different events x k . In general, si can be the same state as sj (loopback transitions are possible). This function may be undefined for some or all values of H. A condition for a possible internal UML transition is set C i l constructed in the following way:
The internal UML transition exists if and only if the corresponding condition is not an empty set:
In general, si can be the same state as sj (internal loopback transitions are possible).
The guard condition g k is a functional representation of the condition set C i l :
The time spent in DEVS state σi before the transition is scheduled, is given by the function ta (σi).
It is tempting to use the send/after apparatus to schedule the transition in the future. However, a transition is not an event and cannot be scheduled using "after" and "send". Instead, we declare new timeout event ei and schedule it at time tcurr + ta((si, Hi)) be redefining the entry action wi of state si.
Event ei becomes the trigger for the internal transition from state si.
A situation may occur when a timeout event has been scheduled, and an external transition is triggered by another (input) event. In this case, the pending timeout must be canceled. UML2.0 does not allow to recall scheduled events. Instead, a guard condition can be changed to make sure that obsolete timeouts do not trigger internal transitions.
Let every UML state si have local variable yi initialized to the reference to the most recently scheduled timeout event ei in the entry action:
If the value of yi and the reference to the scheduled timeout ei differ, the timeout event must be ignored.
To summarize, an internal transition from state si is scheduled when ei occurs and if (yi == ref(ei)) ∧ g i l (H) is true.
COUPLED DEVS AND UML COMPO-NENT DIAGRAMS
DEVS coupled models and UML component diagrams have a very similar structure, which makes mapping DEVS models onto UML component diagrams rather straightforward.
Components
A DEVS coupled model N has only one top-level component and only one level of nesting. This corresponds to a UML component diagram N u with TN = {T0} and such that ∀Mi ∈ M u \ TN , ∀Mj ∈ M u : (Mi, Mj ) ∈ Q u . The top-level component T0, therefore, represents the DEVS coupled model itself, and for each DEVS component
Ports
Both input ports IP and output ports OP of N are mapped to the corresponding UML ports of the top-level component T0 with externally visible ports P u 0 . Let port pi ∈ IP carry input events of type xi ∈ X. Then for this port ∃p
Let port pj ∈ OP carry output events of type yj ∈ Y . Then for this port ∃p
Notice that input and output events are mapped to the port names implicitly.
Connectors
External DEVS coupling corresponds to external (delegation) UML connectors. External input coupling of input port pi ∈ IP to an input port p u j = f (pi) of component M d ∈ M is mapped to a delegation connector from the corresponding port of T u 0 to the corresponding port of M
Respectively, external output coupling of an output port p 
Internal DEVS coupling corresponds to internal (assembly) UML connectors. Internal coupling of port p 
Selection function
There is no feasible way of mapping the DEVS selection function to a UML model. Fortunately, parallel DEVS models do not use this function at all.
CONCLUSION AND FUTURE WORK
In the paper, we proposed a mapping of discrete event specification (DEVS) models onto Unified Modeling language (UML) state and component diagrams. This diagrams are designed and optimized for computerized processing and are highly expressive, competitive, and widely used both in academia and industry. Successful automated DEVS-to-UML mapping techniques would enable seamless integration of the legacy of DEVS models into existing and emerging UML models.
As the future step, we plan to consider UML2.0 composite structure diagrams as more suitable representations of DEVS coupled models. An automated translator from the DEVS domain into the UML domain would substantially simplify the transformation. Limiting the output to the Executable UML is also considered. 
