Simulator and Entities are the core of Discrete Event Simulation. Entities are the actors in the system – they request resources, communicate with other entities and so on. Simulator is the backbone that provides the necessary framework, including the notion of simulated clock. The basics of discrete event simulation are discussed in Introduction to SIM.JS.
The SIM.JS library provides a global class variable Sim, an instance of which defines one simulation process.
The steps in creating a simulation run are quite simple:
Creates an instance of discrete event simulator.
Adds an entity in the simulation environment. The entity object inherits from the entityPrototype object. The simulator also adds several other API function in the prototype. See Entity for further details.
Starts the simulation. duration is the time until which the simulation runs.
Assigns a function that will be called by the simulator when logging messages.
Logs a message using a logger function defined in setLogger().
Entities are the actors in the simulation. SIM.JS uses the JavaScript’s prototype inheritance concept to differentiate between the behavior representation (similar to class in C++ or Java) and the runtime representation (similar to objects in C++ or Java).
As programmers, we create an Entity Prototype JavaScript object. This is like any other JavaScript object, except for the following constraints:
An example of a very simple Entity Prototype object could be:
var EntityPrototype = {
start: function() {
// This function is necessary!
// This function is called by simulator when simulation starts.
document.write("the simulation has started!").
}
};
Think of Entity Prototype objects as classes in languages like C++ or Java. This class will be used to create objects, which are the runtime representation of entities. We call these runtime objects as Entity Objects, which are instances of Entity Prototypes.
The Entity Objects are created by the Sim.addEntity() function:
// Create entity object from the entity prototype object
var entityObject = sim.addEntity(EntityPrototype);
// More than one entity objects can be created by same entity prototype object
var anotherEntityObject = sim.addEntity(EntityPrototype);
The Sim.addEntity() function performs three actions:
The entire process is illustrated in the diagram below:
The input to the Sim.addEntity() function is Entity Prototype object. This is an object that we have written to model the components of system for our discrete simulation problem.
The simulator adds other useful functions and attributes (see below for complete list) to the Entity Prototype object. We call this object as Extended Entity Prototype.
The simulator then creates an object (the Entity Object) which inherits from the Extended Entity Prototype object (for example, via the Object.create function on platforms where it is supported).
This new Entity Object is returned to the user program.
As noted earlier, the Entity Prototype object must define start() function. This function is called by the simulator when the simulation starts. It is this function where the entities initialize their state and schedule future events in the simulator.
The prototype object may optionally have a finalize() function. This function is called when the simulation terminates.
The prototype object may optionally have a onMessage() function. This function is called when some other entity has sent a Message.
The SIM.JS library adds following functions and attributes to the Entity Prototype object.
Note
The function and attribute names listed below should be treated as “reserved keywords” when writing the Entity Prototype code.
These functions and attributes are added when Sim.addEntity() function is called. For example,
var EntityPrototype = {
start: function() {
var now = this.time(); // Where did we get this time() function from? See below..
document.write("The time now is " + now);
}
};
assert(EntityPrototype.time === undefined); // the object does not have a time method (yet)!
var obj = sim.addEntity(EntityPrototype); // create an object from prototype
// EntityPrototype object has been "extended".
// For example, the time() function is added
assert(EntityPrototype.time instanceof Function);
// Since obj inherits from the extended prototype object, it will have methods
// defined in EntityPrototype as well as those added by the simulator.
assert(obj.start instanceof Function);
assert(obj.time instanceof Function);
The unique id of the entity. The id will be unique for entity objects even if they are derived from same prototype.
Returns the current simulation time.
Sets an internal timer that expires after delay duration. This function returns a Request object.
See also
Waits on the event Event. This function returns a Request object.
The difference between waitEvent() and queueEvent() is that when the event triggers (or fires), all waiting entities are notified, and only one queued entity (the one at the head of the queue) is notified.
See also
Queue for the event Event. The function returns a Request object.
The difference between waitEvent() and queueEvent() is that when the event triggers (or fires), all waiting entities are notified, and only one (the one at the head of the queue) is notified.
See also
Sends the message to other entities after a delay. entities can be:
This function does not return any value.
See also
Request to use the facility for duration duration. This function returns a Request object.
See also
Request to put amount quantity of tokens in the buffer. This function returns a Request object.
See also
Request to retrieve amount quantity of tokens from the buffer. This function returns a Request object.
See also
Request to store object in the store. object can be any JavaScript value (numbers, strings, functions, objects, arrays etc). This function returns a Request object.
See also
Request to retrieve object from the store. If the filter function is supplied then the first object (in FIFO order) that matches the filter is retrieved; otherwise the first object in FIFO order is retrieved. The retrieved object can be accessed via the this.callbackMessage attribute in the callback function. This returns a Request object.
See also