data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Simulation Algorithms for Coupled DEVS
Encyclopedia
Given a coupled DEVS model, simulation algorithms are methods to generate the model's legal behaviors, which are a set of trajectories not to reach illegal states. (see behavior of a Coupled DEVS
model.) [Zeigler84] originally introduced the algorithms that handle time variables related to lifespan
and elapsed time
by introducing two other time variables, last event time,
, and next event time
with the following relations: data:image/s3,"s3://crabby-images/2cd9e/2cd9e59d5937363b17f359aac8682e8357ffecd0" alt=""
and
data:image/s3,"s3://crabby-images/e83b2/e83b20e418dcc151923f060d565f53c3c9412b83" alt=""
where
denotes the current time. And the remaining time,
data:image/s3,"s3://crabby-images/d88de/d88dec70a7429025a49d49ac9f17781f4a431316" alt=""
is equivalently computed as
data:image/s3,"s3://crabby-images/f6590/f6590ceb96d1bb9652518c4b4329883d40b41b60" alt=""
, apparently
.
Based on these relationships, the algorithms to simulate the behavior of a given Coupled DEVS are written as follows.
Variables:
parent // parent coordinator
: // time of last event
: // time of next event
// the associated Coupled DEVS model
when receive init-message(Time t)
for each
do
send init-message(t) to childdata:image/s3,"s3://crabby-images/c5d44/c5d44ff5562df706bf999d9394d044219ce838b9" alt=""
;
;
when receive star-message(Time t)
if
then
error: bad synchronization;
data:image/s3,"s3://crabby-images/fa23a/fa23ab0f83f028ba68974a94b42071ae981d4293" alt=""
send star-message(t)todata:image/s3,"s3://crabby-images/5600a/5600a648f087706dcb397f12b814ef22ac5868a5" alt=""
;
;
when receive x-message(
, Time t)
if
and
false then
error: bad synchronization;
for each
do
send x-message(
,t) to child data:image/s3,"s3://crabby-images/54efd/54efd67d36c25ad34e5f20f73e5ca96e8c7e96bd" alt=""
;
;
when receive y-message(
, Time t)
for each
do
send x-message(
,t) to child data:image/s3,"s3://crabby-images/af5a9/af5a90e4e7c7aa34ffc7aa20671501ed5ad2c801" alt=""
if
then
send y-message(
, t) to parent;
;
;
See also
Behavior of Coupled DEVS
DEVS is closed under coupling [Zeigper84] [ZPK00]. In other words, given a coupled DEVS model N , its behavior is described as an atomic DEVS model M...
model.) [Zeigler84] originally introduced the algorithms that handle time variables related to lifespan
data:image/s3,"s3://crabby-images/32de6/32de6bff6f5c41668734e0989281992bd0f2f8de" alt=""
data:image/s3,"s3://crabby-images/f9c1f/f9c1fb51f0540c590b4a8acc0f02a72667b8f0bf" alt=""
data:image/s3,"s3://crabby-images/fbe86/fbe867be95a7f4780aa5d54a5acad44c0509bff5" alt=""
data:image/s3,"s3://crabby-images/3f5ce/3f5ce8751dbbb0f6fe0b57f4418eaf61f5e62a8a" alt=""
data:image/s3,"s3://crabby-images/2cd9e/2cd9e59d5937363b17f359aac8682e8357ffecd0" alt=""
and
data:image/s3,"s3://crabby-images/e83b2/e83b20e418dcc151923f060d565f53c3c9412b83" alt=""
where
data:image/s3,"s3://crabby-images/67c1f/67c1f4e6416d81c6f3031bf5cc6007eea3fc5440" alt=""
data:image/s3,"s3://crabby-images/d88de/d88dec70a7429025a49d49ac9f17781f4a431316" alt=""
data:image/s3,"s3://crabby-images/f6590/f6590ceb96d1bb9652518c4b4329883d40b41b60" alt=""
data:image/s3,"s3://crabby-images/4298d/4298d56504f51f1bce4b4fd50b30226b4501a18e" alt=""
Based on these relationships, the algorithms to simulate the behavior of a given Coupled DEVS are written as follows.
Algorithms
DEVS-coordinatorVariables:
parent // parent coordinator
data:image/s3,"s3://crabby-images/65331/65331ef5bbbdd04483fa1184e23d82d1ab87c527" alt=""
data:image/s3,"s3://crabby-images/ee2fd/ee2fd54571997c10a16ed3d57c61fdd1344df0e1" alt=""
data:image/s3,"s3://crabby-images/3ed6a/3ed6a55dc6f67d19cb71af6690f6d925f284e303" alt=""
when receive init-message(Time t)
for each
data:image/s3,"s3://crabby-images/06eab/06eabf04cb6c69f13f648d697a2af99c22266c76" alt=""
send init-message(t) to child
data:image/s3,"s3://crabby-images/c5d44/c5d44ff5562df706bf999d9394d044219ce838b9" alt=""
data:image/s3,"s3://crabby-images/a1780/a178062a5149c47ff68b41b913f36136e9367a4a" alt=""
data:image/s3,"s3://crabby-images/b0a26/b0a26791a1c9b46b6c860d159ec40e480d84a0d8" alt=""
when receive star-message(Time t)
if
data:image/s3,"s3://crabby-images/c1bde/c1bdeeac749903517a26166485c14fa8ee3938dd" alt=""
error: bad synchronization;
data:image/s3,"s3://crabby-images/fa23a/fa23ab0f83f028ba68974a94b42071ae981d4293" alt=""
send star-message(t)to
data:image/s3,"s3://crabby-images/5600a/5600a648f087706dcb397f12b814ef22ac5868a5" alt=""
data:image/s3,"s3://crabby-images/ecaf1/ecaf161af22d398e1f0376afda7622bd1f798d03" alt=""
data:image/s3,"s3://crabby-images/71750/71750b1be3683139f3a6031339e975e7f76360b8" alt=""
when receive x-message(
data:image/s3,"s3://crabby-images/844c0/844c09037212434be4c7e2afe1ade7d6c647c573" alt=""
if
data:image/s3,"s3://crabby-images/83630/836301961293131233e5ecdf0cd2ba2f3a47b54b" alt=""
data:image/s3,"s3://crabby-images/01e26/01e26d1d929b494e10acd152b37718659c330ba1" alt=""
error: bad synchronization;
for each
data:image/s3,"s3://crabby-images/eb67b/eb67b1bc2b86ef26b64268d568823aa5139cda42" alt=""
send x-message(
data:image/s3,"s3://crabby-images/c7224/c72243b3b057b99a5e5d3683fb0dbf8020c6cba7" alt=""
data:image/s3,"s3://crabby-images/54efd/54efd67d36c25ad34e5f20f73e5ca96e8c7e96bd" alt=""
data:image/s3,"s3://crabby-images/2feaf/2feafda7c62a44455c74be527e5aa8f6b3108b58" alt=""
data:image/s3,"s3://crabby-images/e85be/e85beb531d9b9b75a17fd5877b2891f2cffd0569" alt=""
when receive y-message(
data:image/s3,"s3://crabby-images/cdadb/cdadb2ea602807326554176689bb9dd19f343fa9" alt=""
for each
data:image/s3,"s3://crabby-images/fabef/fabef231dc8ff6882d36cb4d2a55bb1816f2398e" alt=""
send x-message(
data:image/s3,"s3://crabby-images/fe0f4/fe0f4f8a5ada595404da71f5123d8caecc310835" alt=""
data:image/s3,"s3://crabby-images/af5a9/af5a90e4e7c7aa34ffc7aa20671501ed5ad2c801" alt=""
if
data:image/s3,"s3://crabby-images/b04d8/b04d8e6726e2579792727819d2ea4edf172e4e73" alt=""
send y-message(
data:image/s3,"s3://crabby-images/09749/09749214931847f880e5442786407baa925334b4" alt=""
data:image/s3,"s3://crabby-images/6e055/6e055604ab8371335282d669453a628853d70a08" alt=""
data:image/s3,"s3://crabby-images/f271e/f271e4bcad486b19ad34747bd9e52f8f03eb9faf" alt=""
See also
- Coupled DEVS
- Behavior of Coupled DEVSBehavior of Coupled DEVSDEVS is closed under coupling [Zeigper84] [ZPK00]. In other words, given a coupled DEVS model N , its behavior is described as an atomic DEVS model M...
- Simulation Algorithms for Atomic DEVSSimulation Algorithms for Atomic DEVSGiven an atomic DEVS model, simulation algorithms are methods to generate the model's legal behaviors which are trajectories not to reach to illegal states....