Simio Reference Guide PDF
Simio Reference Guide PDF
Simio Reference Guide PDF
W elcome
Refer to the Appendix for the License Agreement, and Academic and Runtime Use Policies. There are links on the bottom of each page that allow
you to send us feedback about the content. This book accompanies Simio software version 8.139.13727.0
1 / 815
Simio Reference Guide
C ontents of Documentation
Welcome
Simio Product Family
Getting Started
User Interface
Simio C oncepts
Object Hierarchy
Object Types
Processes
Projects and Models
Queues
Tokens and Entities
Learning Aids
SimBits
Modeling in Simio
Navigation
Project Window
Model Windows
The Facility Window
The Processes Window
Steps
The Definitions Window
Elements,Properties,States,Events,Lists,Tokens,ExternalC onsole
The Data Window
Tables,Schedules,C hangeovers
The Results Window
Interactive Verses Experiment,Pivot Table,Reports,Exporting
Standard Object Library
Project Library
Assigning States
Secondary Resources
Add-on Process Triggers
Reliability
C reating New Objects
Animation
Expression Editor, Functions and Distributions
Running the Model
Experiments
C ontrols orResponses and C onstraints
Analysis - Experiment Properties
Experiment Response C hart (SMORE Plot)
OptQuest Add-In
Scenario Subset Selection
Select Best Scenario Using KN Add-In
An Example Model with an Experiment
Model Summary Report
C ustom Simio Extensions (i.e. C ustom Steps and Elements)
Dynamic Selection Rules
Protection
Appendix
System Requirements
Installation Instructions
C heck For Updates
Academic Use Policy
Run Time C apability
End User License Agreement
2 / 815
Simio Reference Guide
Simio P roduct Family
Simio is a family of products that includes the Design, Team and Enterprise Editions. Models built with all three Editions are fully compatible both
up and down the product family. All three products provide the same powerful 3D object-based modeling environment.
Simio Design Edition
Simio Design is our standard product and includes the Standard Library for getting started with Simio, but adds a unique and powerful capability
(patent pending) that allows you to modify the logic of your objects using add-on process-oriented logic. This version of the software also
provides you with the ability to create and distribute your own custom modeling libraries. Simio Design is the ideal product for professional
modelers that want to have full control over complex process logic or want to develop new modeling libraries focused on specific applications
areas.
Simio Team Edition
Simio Team has the same functionality provided by Simio Design, but also lets you build and distribute models using the freely available Simio
Personal Edition as a runtime platform. Models built with the Team Edition will run and generate results with the Simio Personal Edition. Simio
Team is ideal for consultants that want to deliver a running model to their customer without requiring them to purchase Simio. The Team Edition
also provides support for sharing the Simio software using a floating license.
Simio Enterprise Edition
Simio Enterprise adds a powerful set of patent-pending features to extend the Team Edition capabilities into daily operational support. Extend the
use and lifespan of your previously built Simio models or build and execute new models for Risk-based Planning and Scheduling(RPS). C ustom
tailor reports, graphs, and tables for use by schedulers. Reduce your risk and costs by analyzing your schedules in ways never before possible.
Simio Product Matrix
4 / 815
Simio Reference Guide
G etting Started
Understanding the Simio Modeling Approach
Before you begin to build your first model with the instructions below, you might want to first familiarize yourself with the basic Simio
C oncepts since modeling in Simio is based on an object orientated approach, which might be different than other modeling software
programs you have used in the past.
Your next step is to connect the objects. The diamond shapes on the objects are called Nodes. They represent places that Entities can
enter and leave. Although we won’t be changing anything now, to review or change Node properties, you may click on the diamond shape
and you will see its properties appear in the Properties Window in the bottom right side of the interface. Node properties are used to
specify Entity destination and Transporter selection logic. Selecting a node in the Facility Window is a bit different from other objects
because there are three modes of selection. The first two are common to most objects, the third is unique:
• C lick – Selects Node and displays its properties
• C lick and drag – Moves the Node to a different screen location. Note that it is still “attached” to it associated object if any (for example, a
Server), and if that associated object is moved, the Node position will also change.
• C trl+Shift+C lick and move – Initiates the creation of a Link between Nodes. The Link type may be preselected in the library panel (as
described in third paragraph below)or it will be prompted for when the Link is terminated by clicking on a Node (as described immediately
below).
We will now connect the objects with Paths. Press and hold the C trl and Shift buttons on the keyboard while clicking the left mouse button
on the Transfer Node of Source1. Move the cursor to the left Node of Server1, and click the left mouse button again. A menu will appear to
select the Link type, select Path.
Selecting the Path option after drawing a Link between two objects
5 / 815
Now press the C trl+Shift buttons and click the left mouse button on the right Node of Server1. You may place mid-points for the
connection by clicking various places in the Facility Window, or you can finish the connection by clicking on the Node of Sink1. If you
change your mind about where you are placing the line before finishing the connection and want to remove the connection altogether, then
click on the right mouse button. A menu will appear for you to select the Link type, select Path.
There is another method to use if you want to place Links. C lick on the Link type of your choice in the Standard Library and then you can
left click on the Nodes of your choice. See the circled items in the following screen shot:
Link items in the Standard Library
Double clicking on an object, such as a Path, will put you in a mode to apply that action multiple times sequentially. For example, double
clicking on the Path will allow you to connect the Source to the Server and then the Server to the Sink without selecting it again from the
library. This is the case with all of the Standard Library objects, as well as many other items in the user interface.
C ongratulations, you have built your first Simio model! If you would like to save your model/project, click on the File tab at the top left
corner of the main Simio window. Then select the Save As item from the Backstage view. Use the Windows Explorer window to complete
the saving of your file. Note: There is an alternative way to add a standard Source, Server and Sink into the Facility Window. It was
important to teach you the manual steps as a learning process, but as a time saver for the future, you can simply select the
Source/Server/Sink option from the Select Add-Ins icon on the Project Home tab. This will add these three objects all connected by Paths.
6 / 815
Now you can click on the Run button located on the Project Home tab to run your model.
See the User Interface help topic for additional information on how to navigate through Simio's User Interface.
Queues in Simio
Queues can be found in many different places throughout Simio. Some queues are animated by default, such as the Station queues
associated with the Standard Library objects, but others are not. To learn more about which queues exist in Simio and how to animate a
queue, visit the Queues help page.
Adding Plots, Gauges, Stacked Bars or Status Labels to View During an Interactive Run
Plots, Gauges, Stacked Bars or Status Labels can be added to a model so the user can have a dynamic view of how the object's state
changes over time. The C onsole Window is where the user can place displays that will report the status of an object during the run. These
objects can also be placed in the Facility window and the External panel and attached to objects in the Facility window.
Debugging Tools
There are a number of different tools that are helpful for verification and debugging. Simio has a Trace Window that shows the logic being
executed by the objects and tokens in the model. There is also a Watch Window that displays the current values of States, Properties,
Functions and Elements during the interactive run. A user can also put a Breakpoint on any object in the Facility Window or on any Step in
the Processes Window and the model will pause when it hits that object or Step. For more information, see Debugging the Model.
7 / 815
Simio Reference Guide
User Interface
The Ribbon
The Ribbon contains multiple ribbon tabs and within each tab there are groupings of icons, or panels. The ribbon tabs that are visible vary
depending on which window the user is viewing in the main part of the application. Below are a few of the ribbon menus.
Some of the Available Ribbon Menus
8 / 815
The Project Model Windows
The default window that appears in a new project is the Facility Window. Project Window Tabs are used to select between multiple windows that
are associated with the active model or experiment. The windows that are available depend on the object class of the selected model.
Project Model Tabs
9 / 815
The Navigation Window
The Navigation window, which is located in the top right hand side of the interface, is used to switch between the different models that exist within
the project. To switch between models, simply click on the desired model. The model which is highlighted is the model that is currently active, or
in other words, the model for which the model tabs are associated.
The Navigation Window
When the Project is selected and highlighted, the Project window is displayed. This window lists all the models that exist within this project. By
clicking on the panels on the left side of this window, the user can view the Experiments, the Symbols, the Textures and the Path Decorators that
exist within this project.
The Properties Window: Viewing and Changing the Properties of an Object
To view the properties of a particular object in the Facility window, click on the object and you will see the object's specific properties in the
Properties window. Each object has properties that control its behavior; e.g. the Source has an inter-arrival time, the Path has a property to
control entity passing, and the Server has a processing time.
Simio provides a Show Commonly Used Properties Only checkbox at the top of the Properties window.
When this mode is enabled (the default), the display is limited to the key set of properties that defines the core behavior of each object. Many
standard features such as failures, state assignments, secondary resource allocations, financials, and custom add-on process logic that are
provided by the Standard Library objects are not displayed. This mode allows the beginner to focus on the key concepts for each object without
viewing the additional complexities. When this option is disabled (unchecked) the full set of properties for each object is exposed. Note that this
mode does not directly affect model behavior or results. It is just hiding/un-hiding properties but not changing property values. This mode is
typically used when first learning Simio and then disabled once the basic concepts are mastered.
We recommend leaving this mode checked at least while you are learning Simio. After you are more comfortable with the basic options or when
you need to access more advanced features, you can uncheck this option to all display the full set of properties for each object.
The Properties Window: Viewing and Changing the Properties of a Model
The properties of a model can be accessed by selecting the appropriate model within the Navigation window, right clicking and choosing Model
Properties. Project properties can be viewed in a similar way when the project is selected within the Navigation window.
Model Properties
10 / 815
Right Clicking in The Facility Window
Right clicking on an object in the Facility Window brings up a small menu allowing the user to add a Breakpoint to the object or to open the
C onsole window for that object. Right clicking on a Vehicle object allows the user to make this vehicle the default entity. Right clicking on a Link
object brings up a different small menu that allows the user to either add a Breakpoint, add or remove this link from a network or convert this
link to a different type of link. The link can be added to any networks that currently exist or the user can create a new network from this menu.
Allowing the user to convert the link to a different type of link with a simple right click allows the user the ability to change the model logic quickly
and easily.
Right Clicking on a Link in the Facility Window
In addition to being able to set breakpoints and watch objects through the Right-click menu, the options to make the object 'Externally Visible', as
well as to 'Resize to Graphic Size' are also available for selection. When an object is 'Externally Visible'('on' as a default), it is visible within the
External window and will be seen if this object is used in hierarchy. The 'Resize to Graphic Size' is available when the graphic for the object has
been changed from its original size. The 'Resize to Graphic Size' can be used to resize the object graphic(s) to the original size(s). This is useful in
hiearchical models as well, as if an object in hierarchy has been changed such that the External view of the object is different, any models with
that object in it will be sized based on the original object. The 'Resize to Graphic Size' can be then used to restore objects to their original sizes.
Right Clicking on a Sized Object in the Facility Window
11 / 815
If an object's symbol has been changed from its default symbol to another graphic symbol, the option to 'Apply External View Symbol' is made
available through the right click menu. This will change the new symbol back to the original symbol as defined through the External View of the
object.
Right Clicking on an Object with a Modified Symbol in the Facility Window
12 / 815
Multi-Select
Simio supports Multi-select in the Facility window, as well as the C onsole and External windows of the Definitions tab. Multi-select allows users to
select multiple objects for the purpose of moving, copying and/or deleting them. C trl+click and drag in free space will do a box select, meaning it
will select all objects within the box. C trl+click on any object adds (or removes) it to the selection set. While multiple objects are selected, they
may be moved, copied or deleted.
Multi-select is also very useful for editing similar properties of objects within the above specified windows. Multi-select is also available within the
Processes window for selecting Steps for the purpose of property editing. You can select multiple objects and the intersection of their set of
properties will appear in the Properties window. If the objects share values for a property, the value will show up, otherwise the value will be
blank. This feature is useful for editing multiple items, such as selecting multiple conveyors and changing the desired speed, selecting multiple
links and changing them to bidirectional or selecting several transfer nodes and changing the transport logic to ride on a given vehicle. The
Properties Spreadsheet Window is also useful for making edits to multiple objects and is available for the Facility window objects, as well as for
the Processes window processes and steps.
Selecting Multiple Items in the Facility Window
13 / 815
Cut / Copy / Paste
Simio supports C trl-X (C ut), C trl-C (C opy) and C trl-V (Paste) for all of the items within the Definitions and Data windows. This includes the
Elements, Properties, States, Events, Lists, Tokens, External Nodes (in the External Window) in the Definitions Window, as well as the Tables,
Function Tables, Rate Tables, Schedules and C hangeovers in the Data Window. To copy an item, simply highlight the item and use C trl-C . To
paste the item, use C trl-V and an identical copy of the item and any properties will be defined with a unique name, based on the original name
and a unique number. The copy can then be renamed, if desired.
Copying and Pasting in Definitions and Data Windows
Simio also supports C trl-X (C ut), C trl-C (C opy) and C trl-V (Paste) for all of the items on the Drawing and Animation Ribbon tabs, as well items
within the Facility and Process Windows. C trl-D (Delete) is currently supported only within the Facility window.
Copying and Pasting in the Facility Window
14 / 815
Undo / Redo
Simio supports comprehensive undo and redo capability across the product to make it easier to safely explore and to recover from any accidents.
The Undo and Redo buttons are located on the quick access toolbar on the upper left. C trl-Z and C trl-Y also work.
Undo and Redo Buttons on the Quick Access Toolbar
15 / 815
Filtering Drop Down Lists
Some of the drop down lists you'll find throughout the product will allow you to filter the list to narrow your choices. The example below shows the
filter area where you can type in text to start the filtering of the list. This is extremely helpful in large models when the full list might be large and
overwhelming.
Filtering a Drop Down List
17 / 815
Simio Reference Guide
Search W indow
When you type something into the Search window’s text box, the window will display everything that it finds that contains that text. There are four
columns in the search results:
“Value” is the actual piece of text containing the search string, with the search string highlighted.
“Item” is the name for this piece of text; i.e. “Name” if it is the name of some object, or “Time To Repair” for a property.
“Object Name” is the object containing the piece of text.
“Project Item Name” is the top-level model containing the object.
Double-clicking on a row in the results will take the user to the window containing the item where the text is found, select the item, and then (if
possible) select the property where the text is found. If the text found is a property value and that value is currently switched out, the user is
simply taken to the item that contains that value. C urrently, the Search window will search “Simio property” values (that is, property values on
Steps, Elements, Processes, Object Instances), and Object names (where “Object” refers to any of the things a user names, such as
aforementioned, but also the object in the Definitions, and Data windows). Search is not yet supported in Schedule item text, C hangeover
matrices, or Lookup / Rate table values.
The columns within the Search window can be manipulated to sort and rearrange, as well as to filter them. To use this, click the filter glyph in a
column header, and select an option from it.
When filtering, only those rows matching the filter criteria are displayed, and a filter bar appears the bottom.
The user may also right click on a column to sort, group or filter items in the column.
18 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
19 / 815
Simio Reference Guide
P roperties Spreadsheet W indow
When the Properties Spreadsheet window is first opened, the 'C lick here to select an object type' button in the top right may be used to select
from a list of objects currently in the Facility window, Process names within the Processes window or Steps within the Processes window.
Within the Facility window, for example, if the model has a Source, two Servers and a Sink, connected by multiple Paths, the list of objects will
include Source, Server, Sink, BasicNode, TransferNode and Path. C lick on the object type to view a list of those particular objects in a
spreadsheet format. Alternatively, if you have a particular object highlighted within the Facility window (i.e., such as a Server), if you right click
on that highlighted object you will see the option to 'Open properties spreadsheet view for all objects of this type...' which will present those
objects in the window.
Similarly, within the Processes window, if the model has multiple steps, the list of possible steps may be accessed using the 'C lick here to select
an object type' and selecting the particular step type desired. Alternatively, right-clicking on a particular type of step, for example an Assign step,
will open the properties spreadsheet for all Assign steps in the model for editing. C trl-click of multiple steps in the Processes window also allows
editing of similar properties of those steps through the Properties window on the right.
20 / 815
Within the Properties Spreadsheet window, you can edit single property entries for a given object or copy/paste values into multiple columns. To
select multiple entry rows, you may click a row, then use C trl-click to highlight additional rows – editing of multiple rows simultaneously can
continue to be done within the Properties window on the right.
The columns within the Properties Spreadsheet window can be manipulated to sort as well as to filter them. To filter, click the filter glyph in a
column header, and select an option from it.
When filtering, only those rows matching the filter criteria are displayed, and a filter bar appears the bottom.
21 / 815
The user may also right click on a column to see the sort arrow for displaying items in the column alphabetically.
Right-clicking on a particular object's row (i.e., such as Server2 in a list of Servers) will highlight and allow you to 'navigate to' that particular
object within the Facility or Processes window.
22 / 815
Simio Reference Guide
Simio C oncepts
Even though each object within the standard library has its own Processes, Elements, Properties, States, and Events, the user cannot see those
components of the object. Simio hides these details to prevent the user from making any changes to the logic of the standard objects. The
standard objects were built to provide standard functionality that will meet most basic modeling needs, so hiding the details of these objects
brings simplicity. If the user would like to see the Processes, Elements, Properties, States, and Events of an object, they would need to subclass
the object from the standard library into their own Project Library. Once the object is in the Project Library, the model windows of that object can
now be viewed by making it the active model in the project, which is done by selecting the model in the Navigation window. This is where the user
could see the Processes of any standard object (from the Processes Window) or the States and Properties of each object (from the Definitions
Window). Now that the object is part of the Project Library, it can be modified (i.e. new properties, new states, new tables, etc). If the user would
like to modify a Process, they first need to select the Process from within the Processes Window and click on the Override button in the Ribbon.
By overriding a Process and making changes, the user is changing the logic that Simio put into this object to make it work as it does in our
Standard Library.
View the Object Hierarchy
Read about the different Object Types that exist in Simio and examples of each
Read about Processes, what they are and how they can be used in your model.
Read about Projects and Models and the difference between the two.
Read about Queues and see where they exist in the product.
Read about Tokens and Entities and how they differ.
23 / 815
Simio Reference Guide
O bject Hierarchy
What is an Object?
Simio employs an object approach to modeling, whereby models are built by combining objects that represent the physical components of the
systems. An object is a self-contained modeling construct that defines that construct's characteristics, data, behavior, user interface, and
animation. Objects are the most common constructs used to build models. You've already used objects each time you built a model using the
Standard Library --- the general-purpose set of objects that comes standard with Simio.
An object has its own custom behavior that responds to events in the system as defined by its internal model. For example, a production-line
model is built by placing objects that represent machines, conveyors, forklift trucks, and aisles, while a hospital might be modeled using objects
that represent staff, patient rooms, beds, treatment devices, and operating rooms. In addition to building your models using the Standard Object
Library objects, you can also build your own libraries of objects that are customized for specific application areas. And you can modify and extend
the Standard Library object behavior using process logic. Refer to Simio C oncepts for additional information on the specifics of an object.
Object Hierarachy
One of the important and unique internal design features of Simio is the use of a three tier object structure that separates an object into an
object definition, object instance, and object realization.
Object Hierarchy
Object Definition
An object definition is a Library Object that is supplied by Simio or created by the Modeler. An object definition is just that - a definition of how
the object is to act by making use of specific Processes, Events, States, and Properties that work together to define how the object interacts with
Entities and other Objects. An object definition specifies the behavior of that object and is shared by all instances of the object in all models in
which it is used. Object definitions reside in a library, either the Standard Library, a custom library, or a project library. New object definitions can
be made by selecting New Model and selecting the class of model to be built. Alternatively, a new object definition can be generated by ‘sub-
classing’ an object from an existing library object.
Vehicle Definition (Processes)
24 / 815
Vehicle Definition (Properties)
Object Instance
An Object Instance is simply an occurrence of an Object Definition within a parent object, such as a model or another object definition. This is
what you get when you place a definition into the Facility window.
25 / 815
In the SimBit example below, the ‘model’ (which is an object definition), contains a number of object instances within the Facility window. Each
Server (Server1, Server2, and Server3) is an Instance of the Object Definition named ‘Server’. Similarly, Source1, Sink1, all Paths, Vehicle1, and
all Input/output Nodes are all Instances of Source, Server, Path, Vehicle, BasicNode, and TransferNode Object Definitions.
Each instance of an Object Definition is differentiated by customizing property values and/or creating Add-On processes within the Instance. In
this example, each Server has a different Processing Time property value. Also, some TransferNodes have Ride on Transporter set to True while
others are set to False. This instance data is in turn shared by all object realizations.
SimBit 'DynamicallyCreatingVehicles'
26 / 815
In summary, the Vehicle Object Definition is the “Model” supplied with the Simio Standard Library. It is the collection of all the Properties, States,
Event, Processes, Elements, etc. that make a Vehicle act the way the standard Vehicle acts in your model.
The Vehicle Object Instance is Vehicle1 that is shown in the bottom left hand corner of the Facility window. This is where the properties such as
Desired Speed, Initial Ride C apacity, Task Selection Strategy, etc. are specified. These property values further shape this Vehicle’s behavior to
represent the behavior of the vehicle the user is trying to represent.
When you run the model, it will create a static runspace (or realization) to represent the states common to all Vehicle1s (such as
Population.NumberInSystem). It will also create a dynamic runspace for each of the three vehicles that are in the system. Each one of these
vehicles has different values for Location, Heading, Pitch, NumberRiders, TimeC reated, etc. that differentiates that Vehicle from the others. These
can be then referenced by Vehicle1[1], Vehicle1[2], and Vehicle1[3].
27 / 815
Simio Reference Guide
O bject T ypes
Node Intelligent
Object Adds behaviors for modeling fixed objects that are intersection points between link objects or the entry/exit points for
visiting an object. Entities may be picked up/dropped off by a transporter at a node. Users can extend/customize the
crossing logic through a node to model network flow and entity pickup/dropoff points. Examples of Node models include
the BasicNode and TransferNode in the Standard Library.
A Node defines a point in space -- it may constrain movement but it does not represent any physical space itself. So, for
example, a transporter that stops at a node physically remains with its full length on the incoming link until it leaves the
node. The Standard Library object nodes have an associated parking area, but by default this also does not represent a
physical location. Internally parking is represented as a station, so it may have constrained capacity and may be
animated.
The following key strokes can be used to manipulate Nodes within the Facility Window:
C lick – Selects node and displays properties in the Property window.
C lick and drag – Moves the Node to a different screen location. Note that it is still “attached” to it associated
28 / 815
object if any (for example, a Server), and if that associated object is moved, the Node position will also change.
C trl+Shift+C lick and move – Initiates the creation of a Link between Nodes. The Link type may be preselected in
the library panel or it will be prompted for when the Link is terminated by clicking on a Node.
A node with its Crossing Capacity property set to 'Infinite' is not seized or released and therefore cannot be queried for
C apacity.Allocated.
29 / 815
Simio Reference Guide
P rocesses
A Process in Simio is comprised of Steps, Elements, and Tokens. A Process is sequence of actions (e.g. assign state, delay by time, seize a
resource, etc.) that may span time and change the state of the model. Tokens flow through a Process executing Steps that alter the state of one
or more Elements. Simio provides an auto-layout function creating Process flows. Processes are created and modified in the Processes Window,
found by clicking on the Processes tab. Note: A process cannot be modified while the model is running.
A Process is either enabled or disabled. The process property InitiallyEnabled allows the user to specify whether a process is enabled when the
system is initialized. A process has a state called Enabled that indicates whether the process is currently enabled. A disabled process ignores any
attempt to execute the process. A process can be enabled by using an Assign step to set the state ProcessName.Enabled, where ProcessName is
the name of the process, to 1. A process can be disabled by using an Assign step to set the state ProcessName.Enabled to 0. Any attempt to
execute a disabled process (e.g., Execute step) will be ignored. Any triggering events for the process are canceled when it is disabled. However,
when a process is disabled, if there are active tokens currently running in the process, then those tokens will continue and finish their processing.
A disabled process (or a process that has no logic) is going to simply return its ReturnValue if asked (e.g., if an OnEvaluatingXXXX process is
asked for a value by the engine). ReturnValue is a state associated with a process that returns the default token return value for the process.
There are certain processes within the standard Simio objects that are known as Decision Processes. They are referred to as Decision processes
because the execution engine needs to ask the model for some value and it runs this particular process to find the answer. These process can
only contain Assign, Decide, Search and Execute steps. If the execution engine encounters any other kind of Step when running a Decision
Process, it issues a runtime error. If a Decision Process contains an Execute step, any additional processes that are called must also contain only
Assign, Decide, Search and Execute steps. Since a Decision Process must run to completion without any interruption, it ignores Breakpoints,
process suspensions, and single-stepping when it is run. Decision processes within Simio are OnEvaluatingAllocation, OnEvaluatingRiderAtPickup,
OnEvaluatingRide, and OnEvaluatingRiderReservation.
Processes
Processes are used to either customize the behavior of an existing object, or to create new object definitions. If the user would like slightly
different behavior from what is provided with the Standard Library objects, the modification of the object behavior is done with Simio Processes.
The second major role for process modeling in Simio is for creating new object definitions. An object definition is simply a model for how
instances of that object should behave.
There are several types of Processes in Simio. Standard Processes are automatically run by Simio at specific points in the logic. Decision
processes are 0-time Standard Processes that compute a return value used for making a decision. Event-triggered Processes are executed
whenever a user-specified Event occurs. Add-on Processes may be inserted into an object at selected points in the logic and are discussed below.
Standard Processes
There are eight (8) standard processes that are available for a given object/model. Within the Processes window, any of these may be selected
for logic to be added. These processes include:
OnC apacityAllocated - This is executed when a resource's capacity is allocated (seized). The token executing the process will be
associated with the object that seized the capacity. This process is used within Standard library objects such as Resource, Worker and
Vehicle.
OnC apacityC hanged - This is executed when a resource's capacity has changed. The token executing the process will be associated with
the object that changed the capacity.
OnC apacityReleased - This is executed when a resource's capacity is released. The token executing the process will be associated with the
object that released the capacity. This process is used within Standard library objects such as Resource, Worker and Vehicle.
OnC apacityReservationC ancelled - This is executed when a capacity reservation for a resource has been cancelled, either due to a
reservation timeout or because the entity owning the reservation was destroyed. The token executing the process will be associated with
the object that cancelled the reservation. This process is used within Standard library objects such as Resource, Worker and Vehicle.
OnEnteredFreeSpace - This is executed when an entity object transfers from a non-free space location into free space. This process is
used within the ModelEntity, Worker and Vehicle objects.
OnEvaluatingAllocation - This is executed when determining whether or not the object's capacity should be allocated (seized). The token
executing the process will be associated with the object that is trying to seize the capacity. This process is used within many of the
Standard library objects.
OnRunEnding - If running in interactive mode, then this is executed when the Stop or Reset button action occurs. If in experiment mode,
then when the ending time has been reached or calendar events have been exhausted such that the model run is now ending and final
statistics about to be reported. Additional events can be put onto the event calendar, but they will not be processed. For example, if you
place a Delay step in this process, the delay will be scheduled, but the run will end before the end of the delay. The delay will not extend
the run time. Similarly, if you have an Execute Step in this process and the Action property is set to 'WaitUntilC ompleted', anything after
that step will not be processed. This is because the "WaitUntilC ompleted" action schedules another event on the event calendar and the
event calendar is not revisited.
OnRunInitialized - This is executed when this object/model is first initialized.
OnRunWarmUpEnding - If running in experiment mode, if a warm-up period has been specified and is ending, this is executed right before
all statistics are cleared. Typical uses of this process may be to do some custom warm-up statistics clearing. For example, you may want
to clear a state variable’s value that is being used as a custom statistic or take a snapshot of some statistic values at the end of the warm-
up period before Simio clears them. See "OnRunEnding" description above for more information about how the event calendar works with
this Process.
Add-On Processes
When you place an object from the Standard Library into your Facility Window, you can have the object run Add-On Processes at specific points in
the logic. An Add-On Process is simply a logical Process that you have created to perform some specific action such as assigning a state variable,
seizing a resource, referencing information in a table, etc.
Process Scope
In general a process can only reference items that are at its own scope. Specifically, an object does not “know” anything about the model in
which it is placed, so any processes defined inside that object have the same limitation. For example, a process defined inside a Server object
can only reference things that have been defined within that Server object. One way objects and their process can interact with the other objects
is by the object defining properties which are used to pass in information from outside the object. For example, Server has a Property called
Process Time which may reference or “pass in” things like tables and functions that are defined outside of Server.
Add-on processes may appear that they are being defined at the scope of the referencing object (e.g. a Server), but they are not. An add-on
process is actually part of the containing model and has that scope. So for example, if the Processing add-on process is defined for Server1 that
is placed in model Brewery, the scope of that add-on process is Brewery. This is important to note because if the same code that is defined in an
add-on process is later moved into the object definition, it may no longer work because the scope would change from the containing model to that
of the object definition itself.
Simplifying Logic within Processes
30 / 815
A process can be structured such that all the logic that is to be done at a given point in the simulation is done within that particular process.
However, users may find that some of the logic at different points in the model is similar to other areas of logic. The Execute step may be used to
move from one given process into another process. When the Execute step is used, a new token enters that process and continues through the
steps. Within the original process (where the Execute step is called), the original token may continue or it may wait for the executing process to
be completed. See the Execute step for additional information.
If you use a custom token with custom states, the states of the receiving token in the called process get set to match, much like passing function
arguments. If you set the ReturnValue of the token in the executed process, that value will be set (returned) to the token that started the
execute, much like a function return value. This allows the user to pass information between the processes, much like you would with a function.
See the Tokens page for more infomation.
31 / 815
Simio Reference Guide
C osting
Costing in Simio
Activity-based costing (ABC ) is a method of assigning costs to products or services based on the resources that they consume. ABC identifies
activities within the business and records the cost required to fulfill each activity. An activity cost driver is any factor that affects the costs
associated with an activity including capital costs, resource consumption costs, and waiting or inventory holding costs. Activity-based costing
allows managers to determine the costs to perform an activity as well as non-allocated costs such as those associated with unallocated (idle)
resource time.
Simio’s costing capability includes the ABC features described above plus the ability to specify costs in many different currencies and use a user-
specified exchange rate to express cost statistics in the currency of choice.
Cost Centers & Cost Hierarchy
C ost centers are used to define identifiable areas of responsibility where costs are incurred or allocated. C ost centers may be linked in a
hierarchical structure for cost accounting and reporting purposes, whereby costs are automatically rolled up through the cost center hierarchy. For
example 'MechanicLabor' and 'ElectricianLabor' may both be allocated to the 'MaintenanceLabor' cost center. In turn costs associated with the
'MaintenanceLabor' cost center may be combined with costs in the 'MaintenanceSupplies' cost enter and allocated to the 'MaintenanceTotal' cost
center.
Each Standard Library object that supports costing has a Parent Cost Center property that can be specified. If none is specified, the costs
associated with that object will be allocated to the parent object (which may be the base ‘model’) containing the object. C ost centers may also be
defined within the Elements panel of the Definitions window. A cost center may have an initial cost value in addition to an initial cost rate.
When cost hierarchy is used, it is important to note what each cost center represents to avoid double counting specific costs. To continue the
above example, it would be inappropriate to add together the costs from 'MaintenanceLabor' and 'MaintenanceTotal' because that would be double
counting the 'MaintenanceLabor' costs.
Cost Drivers
C apital C osts
C apital costs are the initial one-time setup costs of adding an object to a system. C apital costs are included in the following Standard Library
objects: Source, Sink, Server, C ombiner, Separator, Workstation, Resource, Vehicle, Worker, and C onveyor.
For Vehicles and Workers, the capital cost is incurred for each object in the population that is added to the system. For example, if the Vehicle
named ForkTruck has an Initial Number in System of ‘2’, capital cost will be incurred for each of the two ForkTruck vehicles.
For statistics reporting, capital costs are allocated to both the object and the parent cost center associated with the object. They are shown on the
Results page under the C ategory ‘C osts’ and Data Item ‘C apital C osts’. In the example shown below, capital costs are specified for four objects,
including Source, Server, Sink and Resource, each with its own cost value. As you can see, each object itself incurs the capital cost, and then all
costs are ‘rolled up’ to the parent cost center, which is the Model.
Buffer C osts
Buffer costs are the costs associated with holding an entity in an input or output buffer at a given object, such as a Server. The Standard Library
objects that include buffer costs are Source (output buffer costs only), Sink (input buffer costs only), Server / Separator / C ombiner /
Workstation (both input and output buffer costs).
Buffer costs include both a C ost per Use and Holding C ost Rate.
Cost per use for a buffer is the cost to hold an entity in a buffer, irrespective of the waiting time. It is important to note that this cost will be
incurred at the associated object each time an entity passes through the buffer, even if there is no waiting time. C ost per use is allocated to the
entity moving through the buffer, the buffer’s associated location and the Parent C ost C enter.
Holding cost rate for a buffer is the cost per unit time to hold an entity in the buffer. The holding cost is then allocated to the associated object, as
well as to the Parent C ost C enter. Holding costs are also allocated to the entity that is in the buffer.
For statistics reporting, buffer costs are shown on the Results page under the C ategory ‘C osts’ and Data Item ‘C ostPerItem’ for the associated
DataSource ‘InputBuffer’ or ‘OutputBuffer’ (or ‘Population’ for Entities). In the example shown below, buffer costs are specified for three objects,
including Source, Server, and Sink, each with its own buffer cost data. C ost per use was specified for all objects, and holding cost rate was
specified for the input buffer of the Server. As you can see, each object itself incurs the buffer costs, the entities that go through the system incur
the cost (which will be different for each entity, given the waiting times at the buffers are different) and then all costs are ‘rolled up’ to the parent
cost center, which is the Model.
32 / 815
Resource C osts
Resource costs are the costs associated with utilizing a resource. Resource costs in Simio are included in the Server / C ombiner / Separator /
Workstation fixed objects, as well as the Resource / Worker / Vehicle objects.
These costs are broken down into three categories: C ost per Use, Idle C ost Rate, and Usage C ost Rate (see paragraph below with specifics on
workstation rates).
A resource cost per use is incurred with each entity that utilizes the resource. Reporting the resource usage cost could be confusing though. It is
important to understand that a resource is a cost driver and its usage costs are charged, or accrued, to the cost of the users/owners of the
resource (i.e., charged to the tasks using the resource and then rolled up at those locations where the task is performed).
So, for example, if an entity goes into a Server and utilizes a Worker as a secondary resource during processing, then the Server will incur costs
of its internal resource (shown as Data Item ‘UsageC ostsC harged’ under the DataSource ‘Resource’). Additionally, a ‘C ostPerItem’ for the
DataSource ‘Processing’ includes the cost per use of the Server resource, as well as the Worker resource. These costs are then rolled up to the
parent cost center’s Total C ost as well. C osts are incurred to the entity that ‘owned’ the resources as well, as shown below.
Idle cost rate for resources is cost per unit time that is charged to the cost of the parent object for each unutilized (idle) scheduled capacity unit.
This cost is also allocated to the cost of the parent cost center. This cost is NOT allocated to any entities in the system.
Usage cost rate for resources is the cost per unit time to use the resource. This cost rate will apply only during the time that the resource is in a
utilized state and will be charged to the cost of the entity using the resource. This cost will also be charged to the resource and included in the
‘UsageC ostC harged’ (along with the C ostPerUse value). As all other costs, this is also ‘rolled up’ to the parent cost center’s Total C ost.
In the example below, there was only Idle C ost Rate and Usage C ost Rate, both of 1 USD per hour. The Server was used for 6 minutes of the
hour (10%). Notice how the Server incurs both the IdleC ost and UsageC ostC harged under the ‘Resource’ Data Source. However, only the usage
costs are incurred to the cost per item of both the entity and processing area of the Server. The Server’s total cost (both idle and usage) are then
rolled up to the parent cost center.
33 / 815
In the above example, the UsageC ostC harged for the resource is allocated to the Server because the resource is utilized within the Server
object. The UsageC ostC harged is the cost charged to the users of the resource, not directly to the resource. Only idle costs are charged directly
to the resource. Usage costs are not charged in the resource’s reported total cost unless the entity is actually located inside the resource (such as
a Server) causing the costs to be rolled up into the Server’s costs.
It is important to keep in mind that for Workers and Vehicles that are ‘moving’ resources, the usage costs (both cost per use and usage cost
rate) are only incurred for ‘non-transport’ tasks. For these objects, an additional category of costs, Transport C osts, is used for transport tasks,
as described below.
Workstation Usage C ost Rate - For workstations, the usage cost rate is broken down into three separate cost rates, including Setup C ost Rate,
Processing C ost Rate and Teardown C ost Rate, based on which delay the entity is incurring.
Transport C osts
Transport costs are included with the Worker and Vehicle objects. Both a C ost Per Rider and Transport C ost Rate may be specified.
Cost per rider is the cost to load and transport an entity using a transporter of this type, irrespective of the transportation time. This cost is
allocated to an entity when it is loaded onto the transporter.
Transport cost rate is the cost per unit time to transport an entity using a transporter of this type. This includes only the time when the entity is on
the vehicle and does not include any time when the vehicle is moving to the entity’s location for pickup.
Both cost per rider and transport cost rate are incurred to the worker / vehicle, as well as to the entity. Total cost of the vehicle includes all of the
‘C ostPerItem’ values and is then rolled up to the parent cost center.
In the below example, two entities have required transport from one object to another. The worker has both a cost per rider (1 USD) and a
transport cost rate (10 USD per minute). Note that the ‘C ostPerItem’ of the worker is shown under the ‘RideStation’ Data Source. Total cost is
then calculated and ‘rolled up’ to the parent cost center (Model).
Material C osts
Material costs are specified with the Material element and include the C ost Per Unit. This cost per unit of material is charged if a quantity of the
material is consumed.
There is no material cost directly specified within the Financials section of any of the Standard Library objects. The Workstation object includes
the option to specify material consumption. If materials are consumed at the workstation and the cost per unit property is specified for the
material (via the Material element), then that cost will be associated with the workstation.
In the below example, the workstation includes a capital cost and consumes material that has an associated C ost Per Unit. The entity using the
material incurs a ‘C ostPerItem’ charge. The ‘C ostPerItem’ shown under the Processing C osts for the Workstation also include those material
costs. C apital cost is then allocated to the workstation, along with the material cost for a TotalC ost of the object. This cost is then ‘rolled up’ to the
parent cost center. Note that within the parent cost center, the TotalC ost for the object (Model) is displayed, as well as the MaterialC ostC harged.
Material costs are included in the TotalC ost.
34 / 815
Currency Support
Simio’s costing features includes a default currency which can be specified in any number of country’s currency units. The default is USD (United
States dollars). Exchange rates can also be specified between two countries’ currency units. More information about default currency and
exchange rates can be found on the Financials page of the help.
35 / 815
Simio Reference Guide
P rojects And Models
Projects
A Project can contain just one Model or mutliple Models. When a new project is created, a default model (of object class type Fixed) will be
automatically added to the project. Only one single project may be open in Simio at a time. A project may be saved to a project file, and that file
will contain all of the elements in the project. Thus, a user will be able to distribute an entire project by distributing a single project file.
A project containing models can be opened in two ways. First, a project may be opened as a project file where all models can be edited. Second,
a project can be opened a read-only library that provides definitions used in placing objects into the model. The Load Library button on the
Project Home tab will open a given project *.spf file as a library. The project and all models within the project will then appear in a library on the
left side of the Simio window with the Standard Libary.
By right-clicking on the project name, the project can be renamed and the properties of the project can be modified. There is a CSV Separator
property that can be specified for the project. A specific character may be entered, but the preferred method is to leave it at its default value of
blank, and Simio will use the "List Separator" character defined in Windows' regional settings. To set this character in Windows, open C ontrol
Panel, and then depending on your operating system, look for something similar to "Date, Time, Language, and Regional Options", "C hange the
format of numbers, dates, and times", "Regional and Language Options", "C lock, Language, and Region", "Region and Language", "C hange the
date, time, or number format", and change the "List Separator" value. Basically, if the value for the CSV Separator is blank, Simio will use the
character defined in Windows regional settings.
Models
A model describes the logic, external interfaces, data structure, and presentation/animation for a class of objects. A model may be added to a
library and then instances of that model embedded in another model. Thus, a user will be able to easily create a library that is a collection of
models developed for some particular application domain or modeling effort.
The first model in your project is typically your main model. When you create your main model Simio also creates a default model entity with no
logic, and a corresponding default entity object. This default entity object is created but not yet placed. The first entity object that you place in
your model is this default entity object. You can use this entity model across multiple models, or add additional entity models as needed. You can
also add custom logic to the entity model.
You can create sub-models by adding additional models to your project. You can then add logic to your sub-model, define the user view,
properties, processes, and then drag objects for this model into your main model.
You can also subclass versions of the standard library models. This allows you to start with a standard library object and then make changes to
customize the logic for your own needs. To add additional models to your project, select the Project in the Navigation window to open the Project
window. You can then add a new models to your project either from scratch, by subclassing another model, or by copying a model from a library.
See the Project window help page for additional information on how to add models. You can then add to or modify the logic of your sub-classed
model to create your own custom version of the model. When you select your main model back in the Navigation window, you'll see the new
models in your Project Library on the bottom left side of the UI, and you can then drag these objects into your main model.
36 / 815
Simio Reference Guide
Q ueues
Queues in Simio
Queues, or lines of entities waiting to be processed, can be found in many different places around Simio. This provides tremendous flexibility in
allowing the user to queue entities up at different points throughout the model. It also creates ease in modeling blocking. When placed in the
Facility Window, the standard library objects all have their Input Buffer queue, their Processing queue and their Output Buffer queue automatically
animated.
Entities can be removed from certain queues with the use of the Remove Step.
Animating Queues in Simio
You can animate a queue in Simio with either a Detached Queue that is not tied to any particular object, or animate with a Queue that is attached
an object. An Attached Queue will move around the window with the object. The icon used to animate a detached queue is found on the Animation
Tab of the ribbon.
To draw a detached queue, do not have any object selected and select the Detached Queue icon in the Animation Tab of the ribbon. Left click in
the Facility Window to add the vertices of the queue and right click to add the final vertex.
To draw an attached queue, first select the object that you wish to attach the queue with and then select the Queue icon from the ribbon of the
Symbols Tab. Left click in the Facility Window to add the vertices of the queue and right click to add the final vertex. Once the Queue is drawn in
the Facility Window, when the Queue is still selected, choose the appropriate Queue State in the Properties Window, found in the Definitions Tab.
The Queue States are listed alphabetically by the Object they are associated with.
When animating an attached queue, Simio provides a short cut. When the object is selected, instead of clicking on the center of the Queue icon in
the ribbon, select the down arrow to display the Quick C reate drop down. This menu provides some appropriate queue choices for the user to
select for animating this queue. The choices are the queues that are available for the selected object. If the user selects something from this
Quick C reate menu, and then draws the queue in the Window, the properties of the queue are automatically populated. For example, if the user
selects InputBuffer.C ontents from the drop down shown below and then draws a queue in the Window, the Attached To property will be the name
of the object that was selected and the Queue State property will be InputBuffer.C ontents and this will animate the entities that are currently in
the InputBuffer of the selected object.
Queue Quick Create Menu
37 / 815
Animating Queues on Nodes, such as Parking Queues
When a node is placed in Simio, its Parking Queue is automatically animated, even though nothing is visible within the Facility window. This is
helpful when using Transporters and eliminates the need for the user to draw a Parking Queue in order to see the Vehicle when parked. If you
select a node (even Input and Output nodes attached to standard objects), you will see the Parking Queue icon highlighted in the ribbon. If you
click on this icon, it will turn off the automatic animation of the Parking queue for this node. Simio still provides the Draw Queue option, which
allows the user to draw an attached queue for this selected node, including a Parking Queue, if the user does not like the default location of the
automatic Parking Queue.
Node Queue Animation
38 / 815
Queues that can be found in Simio:
Network Element
VisitRequestQueue – An entity is inserted into this queue of the model’s ‘Global’ network (by the Ride Step) when it is waiting to reserve a ride on
a Transporter in the system. When a Transporter (i.e., the standard library Vehicle object) becomes idle, it searches the ‘Global’ network’s
VisitRequestQueue (using the PlanVisit Step) to possibly select a reservation request from that queue. This queue on any other network element
is not currently used.
Entity Object
VisitRequestQueue - This queue is on the Entity object but is currently only used by a Transporter object (which is a sub-class of entity). This
queue is holding all the entity objects whose pickup reservations the Transporter has selected and accepted to perform. Visit requests are
initiated from either a Ride or Move step. Thus, when a Transporter object selects a pickup reservation request from the ‘Global’ network’s
VisitRequestQueue using the PlanVisit Step, that request is moved from the network VisitRequestQueue to the individual Transporter object’s
VisitRequestQueue. The Transporter then can actually set its destination to one of the pickup reservations in its VisitRequestQueue using the
SelectVisit Step. Examples include: Vehicle1.VisitRequestQueue
Details on the Network's VisitRequestQueue and a Transporter's VisitRequestQueue
BatchQueue - If an Entity is the parent of a batch, then all of its batch members are held in this queue owned by the Entity. Examples include:
DefaultEntity.BatchQueue
Any Object That Is Declared As A Resource Object
AllocationQueue - Objects that are waiting to seize the Object wait in this queue. This queue’s static ranking rule as well as the resource object’s
dynamic selection rule determine the next object to seize the object. Examples include: Server1.AllocationQueue,
[email protected], Resource1.AllocationQueue
Station Element
EntryQueue - Entities waiting to enter the Station, if capacity is not available, wait in this queue owned by the Station element. Examples include:
Server1.Processing.EntryQueue
39 / 815
Note: Entities will never go into the EntryQueue of the ParkingStation of a node, because a node’s ParkingStation always has a capacity of
‘Infinity'. Note: Entities will never go into the EntryQueue of the RideStation of a Transporter, because the Pickup step used by the Transporter
doesn’t initiate a transfer into the Ride station unless ride capacity is available.
Contents - Where entities exist while they are in the Station. This queue is owned by the Station element. Examples include:
Server1.Processing.C ontents, Vehicle1.RideStation.C ontents
Material Element
AllocationQueue - Objects waiting to consume a quantity of the material wait in this queue owned by the Material Element.
Node Object
RidePickupQueue - Entities waiting to get picked up by a Transporter at this location wait in this queue. Thus, if the ReservationMethod on the Ride
Step was not ‘FirstAvailableAtLocation’, then an entity is going to be in two queues at once while waiting for a ride pickup, as a reservation
request in a network/transporter VisitRequestQueue and as a location-specific pickup request in a node RidePickupQueue. Examples include:
[email protected], TransferNode1.RidePickupQueue
BatchLogic Element
ParentQueue - Entities wait here to collect a batch of members. This queue is owned by the BatchLogic element.
MemberQueue - The queue of entities waiting to be added as a member of a batch. This queue is owned by the BatchLogic element.
RoutingGroup Element
RouteRequestQueue - Entities waiting to be routed to a destination in the routing group wait in this queue. It is owned by the routing group
element.
Storage Element
Queue - Objects in the Storage are held and ranked in this queue owned by the Storage Element.
Note: C urrently, the Insert and Remove steps can only be used to insert/remove objects from a storage element queue. Examples include:
Storage1.Queue
Link Object
EntryQueue - Entities waiting to enter the Link wait in this queue, which is owned by the Link object. Examples include: C onveyor1.EntryQueue
Contents - Entities that are physically located on the link. Entities are ranked in the queue based on the order of entry onto the link (* It is
important to note that on paths that allow passing and entities with varying speeds, this may not indicate the order of those entities currently on
the link, but only how they entered the link). Examples include: C onveyor1.C ontents
40 / 815
Simio Reference Guide
T okens and Entities
Tokens
A Token executes the Steps in a process flow. A Token may have one or more user-defined States that carry information from Step to Step. A
Token may also reference an associated object such as an Entity that is visiting the parent object. A Token lives inside of a process - it is created
at the beginning of a process and it is destroyed at the end of that same process. Therefore, a Token is created whenever a process is first
executed. A new Token is also created out of the C reate segment of a C reate Step and out of the Found segment of a Search Step. The type of
Token that is created inside of that process is determined by the Token Class Name property of the Process.
Simio provides you with a default Token named 'Token' that you can use for most of your processes. You only need to add a new Token if you
require a Token with one or more custom states. See the Tokens page for more information.
Entities
In Simio, Entities are part of an object model and can have their own intelligent behavior. They can make decisions, reject request, decide to take
a rest, etc. Entities have object definitions just like the other objects in the model. Entity objects can be dynamically created and destroyed, move
across a network of Links and Nodes, move through 3D space, and move into and out of Fixed objects. Examples of Entity objects include
customers, parts or work pieces. Entities do not flow through processes, as Tokens do. The movement of Entities into and out of objects may
trigger an event, which might execute a process. When the process is executed, a Token is created that flows through the steps of a process.
Entities have a physical location within the Facility Window and they can reside in either Free Space, in a Station, on a Link or at a Node. When
talking about the location type of an Entity, we are referring to the location of the Entity's leading edge. Examples of Stations within Simio are: a
Parking Station of a Node (TransferNode1.ParkingStation), the Inputbuffer of a Server object (Server1.InputBuffer), Processing Station of a
Workstation object (Workstation1.Processing).
Examples of the Different Roles of an Entity and a Token
Example 1 - Processes via Server with Add On Processes
Standard Server Object with Two Add On Processes
If we walk through the simple example of an entity that enters a standard Server object, we can demonstrate the role of an Entity and a Token
within Simio. In this first example, there are processes that are executed by both the Processing and After Processing Add On Process triggers of
the Server object. The Entity instance that exists within the Facility Window arrives to the Input Node of a Server object. It exits the link, crosses
the Input Node and then immediately is transfered into the InputBuffer station of the Server, assuming there is capacity available in the Input
Buffer. If there is available capacity in the Server, the capacity is allocated and then the Processing trigger executes the Process1 process. A
Token that is associated with the entity is created in Process1, which flows through the Assign step. After the Process1 is complete, the Entity
object moves to the Processing station of the Server. When the Server finishes its processing time delay, but before the capacity of the Server is
released, the Process2 process is executed. The Entity object remains in the Processing station of the Server object and a new Token is created
within the Process2 process. This Token flows through the Assign Step that exists within this process. The Token finishes its job when it reaches
the End of the Process2 process. At this point, the Entity then moves from the Processing station of the Server to the OutputBuffer station of the
Server, assuming there is capacity available in the Output Buffer. And finally, the Entity is transfered to the Output Node of the Server object
where it is routed out with the routing out logic of the Output node. As you can see, the Entity travels physically in the Facility Window between
stations and nodes and the Tokens that are associated with the entity are created to flow through the Processes and perform the logic of the
Steps.
It is important to note that within the Server logic, an Execute step is used for each of the Add On Process Trigger processes. Within each Execute
step, the Action is 'WaitUntilC ompleted'. Thus, when the token associated with the entity is created within a process, the entity will remain
41 / 815
step, the Action is 'WaitUntilC ompleted'. Thus, when the token associated with the entity is created within a process, the entity will remain
physically where it is for the entire process, even when delay steps are involved.
Example 2 - Processes via Triggering Event
Token via Triggering Event Process
In this second example, the process will be triggered using a Triggering Event. Triggering events may be a user defined Event or Timer.Event, or
may be related to an action within an object, such as [email protected] or [email protected]. If the process is triggered by a user
defined event (i.e., Event1) or monitor event (i.e., Monitor1.Event), the token going through the process is associated with the 'model' and not a
specific entity. Therefore, as long as the model is running, the token will continue through all the steps in the process. If, however, the triggering
event is based on an entity entering or exiting another object (i.e., [email protected]), the token going through the process is associated
with a particular entity. If that associated entity is destroyed for whatever reason while the token is still in the process (i.e., in a Delay step), the
token will also be destroyed and will not continue through the remaining process steps.
This example shows the happenings of the entity and associated token with a small example of Source, Server, Sink. Entities are created at
Source1, move to Server1 and are processed, then move to Sink1 and are destroyed. Suppose when an entity exits Server1, you would like to
have a token delay for a period of time and then increase a state variable. As shown above, Process1 is triggered by an entity leaving the Server.
The Triggering Event is '[email protected]'. Therefore, the token that goes through Process1 is associated with the entity that exited and not
the model. When the entity leaves Server1 and moves to Sink1, it is then destroyed. If the token is still in the process's Delay step when its
associated entity is destroyed, it will also be destroyed by default. If you would like to have the token continue processing, enter the Advanced
Options section and click on the '+' sign of Token Actions. The On Associated Object Destroyed property allows users to specify what happens to
the token when an associated entity is destroyed. By default, the value for this property is 'EndProcess'. However, by changing this value to
'C ontinueProcess', the token will not be destroyed when its associated entity is and will instead continue its process until the end.
42 / 815
Simio Reference Guide
Associated Vs P arent O bject
Example 1
This example shown below details the process named ‘OnEnteredProcessing’. The process is triggered when an Entity is transferred into the
Processing Station of a Server. At the same time as the Entity enters the Station, a Token is created at the Begin endpoint shown below in the
process. It acts on behalf of the Entity. Next, the Token moves to the first process Step and and performs some action or logic. In this example,
the first Step is a Decide Step. Tokens travel from Step to Step in zero time.
Token flows through 'OnEnteredProcessing' Process of Standard Server
43 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
44 / 815
Simio Reference Guide
Learning Aids and Support
A Sample SimBit Solution is a small Simio model which provides an example of how to use certain features of the software. Each SimBit .spfx
file has a matching .pdf file that provides a detailed description of the model. The files can be found in [public documents]\Simio\SimBits. The
SimBits help page provides a list of all the available SimBits in various categories. SimBits can be searched by clicking on the Sample SimBit
Solutions button in the Support ribbon of the Simio software, which will take you to a page where Basic and Advanced searches may be
performed.
There are a number of Example models that are available with the installation of the software. Example models can be found in [public
documents]\Simio\Examples. See the Examples page for a listing of each and accompanying documentation. The Examples button in the Support
ribbon opens a dialog for selecting one of our example models.
The Books button provides options for opening one of multiple books available for learning Simio. Rapid Modeling Solutions: Introduction to
Simulation and Simio is an introduction to the concepts of simulation and basics of Simio. The Planning and Scheduling with Simio book introduces
the use of Simio Enterprise Edition and Simio Scheduling Edition for planning and scheduling. The Process Improvement Principles book
introduces 25 process improvement principles that can be applied by managers to improve design and operation of production systems. We have
examples associated with this book included in the Examples section. The Reference Guide is a printable guide that explains each Simio feature in
detail. The API Reference Guide is an advanced guide to explain the details of Simio's Application Programming Interface. There are also a
number of publications and textbooks that are listed on-line.
Simio features and concepts are demonstrated in a number of Videos found on the Simio website. The Introduction to Simio is an eight hour
video series that introduces the basics of Simio. A matching e-book is also available under the Books button. Additionally, a number of short
training videos are available for a range of topics, from building a simple model and modeling material handling systems to running experiments
and viewing results.
The Training icon provides a link to our training course schedule. Simio offers public training classes through our worldwide network of training
partners, as well as customized and on-site training.
The Expression Reference Guide button opens an html document which will be opened in the default browser. This document lists the Simio
built-in functions and keywords, states and elements. It also lists the functions, states, events and elements for those objects that have been
placed in your model.
The My Software section of the Support ribbon contains information specifically related to your Simio license. It includes the Version of Simio
which you are currently running, in the format Simio 5.80.****. The License Type displays the type of license within our Simio Product Family
you are currently running. Finally, the Expiration date displays the date of maintenance agreement expiration.
The Release Notes icon opens the Simio Release Notes.pdf file (found in in the install folder (by default \Program Files\Simio)). This file provides
information regarding new features in each sprint release.
The Compatability Notes icon opens the Simio C ompatability Notes.pdf file (also found in in the install folder (by default \Program Files\Simio)).
This file lists any known problems and work-arounds as well as any compatability issues converting between releases.
The Shared Items link opens the SI Shared Items area of the Simio User Forum at http://www.simio.com/forums/viewforum.php?f=36. This
area of the forum provides access to objects, libraries and other items that users have shared.
The Simio Home Page link opens the http://www.simio.com/index.html. Start here to find out anything about Simio.
The Help icon provides a link to the searchabel help on all aspects of Simio.
The User Forum icon takes the user to the Simio User Forum where you may search the various forums for answers, post problems and
suggestions and interract with Simio employees and the world-wide Simio user base. The direct link to the Simio User forum can be found at
http://www.simio.com/forums/. Users can become a Simio Insider to have full access to the User Forums where other users share information
about how they use the software and the models they are creating. This is an opportunity for the global Simio community to communicate and
collaborate.
The Email button allows you to Email a Question to Simio Support, Email This Project to Simio Support or Email Sales for additional
product information.
45 / 815
Simio Reference Guide
SimBits
51 / 815
Simio Reference Guide
AddAndR emoveServerC apacity - SimBit
Problem:
I would like to make an additional server “active” whenever the current servers have a certain number of entities waiting. In other words, there
are multiple servers and if any server with capacity reaches a “maximum input buffer level”, I want to “open” a new server.
Categories:
Buffering, Decision Logic -- Processing
Key Concepts:
AssociatedStationLoad, Active Symbol, Add-On Process, Assign Step, C ondition Based, C ontents, C urrent C apacity, Decide Step, InProcess,
InputBuffer, Load, Monitor, NodeList, On Exited, Processing, Status Label
Assumption:
Assume that capacity can be added instantaneously with no set-up/transition time.
Technical Approach:
We want the maximum number of entities in a server’s input buffer to be six. When a seventh entity arrives, a new server should come on-line or
be activated. There are monitors that watch all the Server Input Buffers and when the seventh entity arrives, an event is fired that triggers a
process to change the server capacities. When the server has completed processing, capacity is reduced to zero again until it is needed in the
future.
Details for Building the Model:
Simple System Setup
Place a Source, 6 Servers in parallel, and a Sink in the Facility Window.
Name the Servers: a1 through a6.
C onnect the Source to each Server and each Server to the Sink with Paths.
Setting Up the Selection Logic
From within the Definitions window, create a Node List that contains the Input Nodes for all 6 Servers.
In the Output@Source1 node, change the Entity Destination Type property to ‘Select From List’ and select the Node list that was just
created.
Set the Selection Goal to ‘Smallest Value’ and use the default Selection Expression ‘C andidate.Node.AssociatedStationLoad’. This
expression will select the least congested possible destination. Please refer to the documentation for more details on the
AssociatedStationLoad function.
Set the Selection Condition property to ‘C andidate.Server.C urrentC apacity > 0’. This ensures that Entities do not get routed to a Server
with a capacity of zero.
C reating the Monitor Elements:
In the Definitions window, select the Elements panel and add 5 Monitor elements (we do not need to monitor server a6).
Set up the properties of each Monitor Elements as follows:
Monitor Type is ‘C rossingStateC hange’
State Variable Name is ‘a1.InputBuffer.InProcess’ (or a2, a3,a4, a5)
Threshold Value is ‘6’
Crossing Direction is ‘Positive’
This means that when the Input Buffer threshold value of 6 is crossed in the positive direction (going from 6-7) the Monitor will be
triggered. (If the C rossing Direction would be ‘Negative’ it would be triggered when it went from 6-5, which is not what we want to have
happen.)
Increasing Server C apacities:
From within the Processes window, create a new Process (C reate Process ribbon button) and rename it ‘UpdateServerC apacities’
Place a single Assign step. Open the Repeating Property Editor in Assignments (More).
For the first assignment, set the State Variable Name to ‘a6.C urrentC apacity’ and the New Value to
‘([email protected] > 0 || ((a1.C apacity > 0) && (a2.C apacity > 0) && (a3.C apacity > 0) && (a4.C apacity > 0) &&
(a5.C apacity > 0)))’
Add another assignment: State Variable Name is ‘a5.C urrentC apacity’ and New Value is ‘([email protected] > 0 ||
((a1.C apacity > 0) && (a2.C apacity > 0) && (a3.C apacity > 0) && (a4.C apacity > 0)))’
Similarly, add: State Variable Name ‘a4.C urrentC apacity’ with New Value ‘([email protected] > 0 || ((a1.C apacity >
0) && (a2.C apacity > 0) && (a3.C apacity > 0)))’
And finally: State Variable Name ‘a3.C urrentC apacity’ and New Value ‘([email protected] > 0 || ((a1.C apacity > 0)
&& (a2.C apacity > 0)))’
These expressions are checking 2 things: (1) If it is processing an Entity, an Entity is waiting to be processed, or an Entity is routing to be
processed, then let it remain operating OR (2) all the Servers before that one are working. Because we used a logical expression it will return a 1
if true, and a 0 if false – which is what we want to set our capacities to.
Note: It is important that these expressions are in this exact order - descending order. Otherwise, the logic will not evaluate correctly.
Now that the Process has been created, we have to trigger it – this is done back in the Monitor Element. From the Definitions window, set
the On Change Detected Process to ‘UpdateServerC apacities’ for each Monitor element. Therefore, once the Monitor is triggered (i.e. when
the seventh Entity arrives) it will fire this process, which checks all of the conditions and then sets the capacities accordingly.
Decreasing C apacities:
From within the Facility window, create a process in a3’s Exited Add-On Process Trigger
From the Processes window, place a Decide step in this new process. Set Decide Type to ‘C onditionBased’ and Expression to
‘[email protected] == 0’.
52 / 815
On the True segment, place an Assign step. Set the State Variable Name to ‘a3.C urrentC apacity’ and leave the New Value ‘0.0’.
This process will check to see if there are any entities processing, waiting to be processed, and routing to the server for processing. If
there are not, then it assigns the Server’s capacity to 0.
Repeat this for Servers a4, a5, and a6.
53 / 815
Simio Reference Guide
AnimatedP eople - SimBit
Problem:
I would like to use animated people (i.e. walking people) and change the animation of the person in the model.
Categories:
Animation, Entity C haracteristics
Key Concepts:
Active Symbol, Assign Step, C urrent Animation Index
Assumption:
This model assumes the user is using the animated people symbols that are available in the Simio Project Symbol library available with the Simio
installation (Library\People\Animated).
Technical Approach:
This model demonstrates how to use the animation features available with some of the animated symbols provided in the Simio Symbol Library.
Once an animated symbol is placed in the Facility window, right click onto the symbol and select List Animations of Active Symbol to see what
options are available for animation of this symbol.
When an entity is selected, there are two properties on the entity which control the animation for the symbol. The Current Animation Index
returns the numeric index or string name of the current animation of the current active symbol. By default, the value of this property is
‘ModelEntity.Animation’, which is a String State on the ModelEntity object.
The other property on the ModelEntity that controls animation is the Default Animation Action property. This indicates if and how Simio will
animate objects that don’t have an explicit animation set via the Current Animation Index expression. The possible values for this property are
None, Moving and MovingAndIdle. ‘None’ means that no action will be taken. ‘Moving’ indicates actively moving entities will be animated with any
available forward movement animations from the active symbol. ‘MovingAndIdle’ indicates actively moving entity and idle objects will be
animated with any available forward movement or idle animations from the active symbol.
Details for Building the Model:
Simple System Setup
Place four Source objects and four Sink objects. C onnect the first three Source objects to the first three Sink objects with a Path.
Place a TransferNode between Source4 and Sink4 and connect Source4 to the TransferNode with a Path and connect the TransferNode to
Sink4 with a Path.
Randomly Assign Animation Example (Source1)
Drag an entity into the Facility window from the Project Library. Rename this entity ‘Person1’.
With this entity selected, select one of the Male icons from the Project Symbols drop down menu in the ribbon (under
Library\People\Animated).
With the male entity selected, right click and select List Animations of Active Symbol to see what options are available for animation of this
symbol. Notice the options for “Walk” and “Run”. C lick OK to close the window.
Select Source1 and open the Before Exiting Repeat Property Editor window. C lick Add and enter the State Variable Name,
‘ModelEntity.Animation’. Set the New Value to ‘Random.Discrete(“Walk”, .6, “Run”, 1) so that 60% of the entities will walk and the other
40% will run.
Assign Numeric Value to C urrent Animation Index Property Example (Source2)
Place another entity into the Facility window from the Project Library. Rename this entity ‘Person2’.
With this entity selected, select one of the Female icons from the Project Symbols drop down menu in the ribbon.
With the Female entity selected, right click and select List Animations of Active Symbol to see what options are available for animation of
this symbol. Notice that number 5 is “Scared_Walk”. C lick OK to close the window.
With the Female entity selected, expand the Animation property category and find the Current Animation Index property. This property will
accept either an expression that returns the numeric index or string name of the current animation of the active symbol. Put the value of
'5' into this property so that the entities will “Scared_Walk”.
C lick onto Source2 and change the Entity Type property to ‘Person2’ so that it produces this new entity type.
Simio Determines Animation Based on Speed Example (Source3)
Place an entity into the Facility window from the Project Library. Rename this entity ‘Person3’.
With this entity selected, select a Male from the Project Symbols drop down menu in the ribbon.
C lick onto Source2 and change the Entity Type property to ‘Person3’ so that it produces this new entity type.
With Source3 selected, open the Before Exiting Repeat Property Editor window. C lick Add and enter the State Variable Name,
‘ModelEntity.DesiredSpeed’. Set the New Value to ‘Random.Uniform(.1,3)’ and Units to ‘Meters per Second’ so that some entities travel slow
and others fast. Simio will determine which animation to use, based on the speed. Notice that some entities will walk, while others will run.
C hange the Allow Passing property on the path between the Source and Sink to be 'False', so that slower walking people cause others to
slow down as well.
C hange Animation in Logic Example (Source4)
Select Source4 and open the Before Exiting Repeat Property Editor window. C lick Add and enter the State Variable Name,
‘ModelEntity.Animation’. Set the New Value to ‘Random.Discrete(“Run”, .5, “Jump”, 1) so that 50% of the entities will run and the other 50%
will jump.
C lick onto TransferNode1 and create a new Add-On Process in the Entered Add On Process trigger (select ‘C reate New’ from the drop of
the Entered property).
In the Processes window, place an Assign step in this new process. Set the State Variable Name to ‘ModelEntity.Animation’ and the New
Value to “Walk”. When the entity enters this TransferNode, it will change from its current animation of “Jump” or “Run” to “Walk”.
Embellishments:
C hange the active animation to try different options, such as a swimming female symbol or a male symbol that is attack kicking.
54 / 815
*IMPORTANT NOTE: Animation options, such as “Walk”, “Run”, “Jump”, etc. are case-sensitive.
55 / 815
Simio Reference Guide
AnimateP athDensity - SimBit
Problem:
I would like to animate the travel density of each path by changing the width of each path so that the width is equal to the percentage of travelers
that have traveled this path.
Categories:
Add-On Process Logic, Animation, Building New Objects/Heirarchy
Key Concepts:
Add-On Process, Assign Step, C ustom Object, NumberEntered, On Entered, Size.Width, State Assignments
Technical Approach:
The model demonstrates how to animate the travel density of a path by changing the width so that the width is equal to the percentage of
travelers that have traveled this path. The model demonstrates how to do this using the standard Path object and an Add On Process and also by
customizing the Path object and using this subclassed Path to accomplish the same goal.
The first demonstration contains three standard paths connecting a Source and a Sink object. Each path has a different value set for its Selection
Weight property, indicating the percentage of entities that should travel on each path. Upon entering each path, the Path.Size.Width state is set to
the percentage of travelers that have entered into this Path divided by the total traffic in the system.
The second demonstration is the same as the first, except that a custom path object is used that contains the width update inside its own logic
instead of having the width updated with an Add On Process in the model.
Enhanced Technical Approach:
Facility Window:
Place a Source object and a Sink object and connect them with three standard Paths.
In the properties window for Path1, under Routing Logic, set Selection Weight to ‘6’.
In the properties window for Path2, under Routing Logic, set Selection Weight to ‘1’.
In the properties window for Path3, under Routing Logic, set Selection Weight to ‘3’.
Definitions Window:
Go to the States panel and create a new Real State named TotalTraffic_Example1.
Processes Window:
C reate a new process and name it Path_Entered.
Place an Assign Step and set the State Variable Name to ‘TotalTraffic_Example1’ and the New Value to ‘TotalTraffic_Example1 + 1’
Place another Assign Step. Set the State Variable Name to ‘Path1.Size.Width’ and the New Value to
‘Path1.NumberTravelers.Entered/TotalTraffic_Example1’
Add two more assignments to this Assign Step, assigning the same values to Path2 and Path3. For example: Path2.Size.Width
should be set to ‘Path2.NumberTravelers.Entered/TotalTraffic_Example1’
Facility Window:
Select each Path (hold C TRL and click onto each Path). Under the Add-On Process Triggers property category, enter the name of the
process (Path_Entered) into the Entered property. Therefore, each time a Modelentity enters any path, this new process is executed.
To create a custom Path object (functionality not available with Simio Express Edition):
Go to the Definitions Window and create a second Real State, named ‘TotalTraffic_Example2’
In the Facility window, right click onto the Path in the Standard Library and select Subclass.
C lick onto the new Path object in the Navigation Window.
Go into the Definitions window of the MyPath object. Go to the Properties panel and create a new State Property by selecting this
from the Standard Property drop down in the Ribbon. Name this new property ‘TotalTraffic’.
Go into the Processes window of the MyPath object
Find the OnEntered process and with this selected, click onto Override in the Ribbon to override the default logic.
Place an Assign Step after the EntityMovementRate Assign Step and before the IfPassingAllowed Decide step. Set the State Variable
Name to ‘TotalTraffic’ and the New Value property to ‘TotalTraffic + 1’
Place another Assign Step after this. Set the State Variable Name to ‘Size.Width’ and the New Value property to
‘NumberTravelers.Entered/TotalTraffic’
When you use this new MyPath object in the main model to build the second example, you will need to put the name of the state variable
‘TotalTraffic_Example2’ into the State Property on each instance of the MyPath that you place into the Facility window. This will tell this
object which State Variable to update in order to keep track of the total traffic in this system.
56 / 815
Simio Reference Guide
AnimatingQ ueuesW ithVehiclesAndW orkers - SimBit
Problem:
I would like to show entities in different queues based on an expression and match the animation speed of an animated entity in an attached
queue with the Vehicle/Worker.
Categories:
Animation, Data Tables, Entity C haracteristics, People, Vehicle, Worker
Key Concepts:
Animated Symbol, Before C reating Entities, Bidirectional Path, Data Table, Entity Property, Initial Desired Speed, Initial Node (Home), Match
Attached Animation Speed , ModelEntity, Queue, Queue State, Priority, RandomRow, Real Property, Ride On Transporter, RideStation.C ontents
Queue, Sink, Source, Symbol, Table Reference Assignment, Vehicle, Visibility Expression, Worker
Technical Approach:
The Vehicle picks up multiple entities and they are shown in different queues based on the Visibility Expression on the queues. A Worker
transports an animated entity, and the animation speed is automatically set to match the Worker’s speed.
Details for Building the Model:
Top Model
Place a Source (Source1), Sink (Sink1), and Vehicle (Vehicle1) on the Facility window.
Use a Path to connect Source1 to Sink1, and use a second path to connect Sink1 to Source1.
Place two ModelEntity instances from the Project Library on the bottom left into the Facility window.
Select DefaultEntity and change its Initial Priority to ‘2’. Leave the other Entity’s Initial Priority as ‘1.0’.
Double click DefaultEntity and change its name it to ‘Red’. C hange the other Entity’s name to ‘Blue’.
Select the Red Entity, open the C olor dropdown on the Symbol Ribbon and select the Red box. Then click the top of the Red ModelEntity.
C lick the Red box in the C olor dropdown again and select the side of the Red ModelEntity (must be in 3D mode to view side - press ‘3’
key). C hange the Blue entity’s symbol color to blue.
Open the Data Tab and click Add Data Table (Table1). Add an Entity Property C olumn (Object Reference dropdown) and a Real Property
C olumn (Standard Property dropdown). C hange the column Name to ‘WhichType’ and ‘HowMuch’, respectively.
In column Which Type input ‘Blue’, ‘Red’ and in column How Much input ‘60’, ‘40’.
On Source1, set Entity Type to ‘Table1.WhichType’. Under Table Reference Assignments: Before C reating Entities set Table Name to
‘Table1’ and Row Number to ‘Table1.HowMuch.RandomRow’.
On Output@Source1, set Ride On Transporter to ‘True’ and Transporter Name to ‘Vehicle1’.
Select Vehicle1 and change its Initial Ride Capacity to ‘4’, Initial Desired Speed to ‘.5 meters per second’, and Initial Node (Home) to
‘Input@Sink1’.
Select the Vehicle1 RideStation.C ontents queue. Set the Visibility Expression to ‘C andidate.ModelEntity.Priority == 1’.
Select Vehicle1. In the Draw Queue dropdown (in the Symbols Ribbon) select RideStation.C ontents. To draw the queue, click and release
in the model space just below the right side of Vehicle1, click and release in the space jest below the left side of Vehicle1, and then right
click to stop drawing the queue.
Select that queue and set the Visibility Expression to ‘C andidate.ModelEntity.Priority == 2’.
To move the queue, first press the ‘3’ key to go to 3D mode. Then select the queue and hold the ‘Shift’ key to move the queue vertically.
Move the queues so both are directly above the vehicle. Press ‘2’ to go back to 2D mode.
Bottom Model
Place a Source (Source2), Sink (Sink2), Worker (Worker1), and ModelEntity on the Facility window.
C onnect the Source to the Sink using a Path and set its Type to ‘Bidirectional’.
Select the ModelEntity, then click Apply Symbol in the Symbols Ribbon. Scroll down to the ‘Animated’ categories and select a person.
Double click the ModelEntity and rename it to ‘Person’.
On Source2, set Entity Type to ‘Person’ and Interarrival Time to ‘Random.Exponential(3)’.
On Output@Source2, set Ride On Transporter to ‘True’ and Transporter Name to ‘Worker1’.
On Worker1, set Initial Desired Speed to ‘.2 meters per second’ and Initial Node (Home) to ‘Input@Sink2’.
Select Worker1 and click Apply Symbol in the Symbols Ribbon. Scroll down to the ‘Animated’ categories and select a person.
Select Worker1’s RideStation.C ontents queue. Hold the Shift key to lower the queue. Then press the ‘2’ key to switch to 2D mode. Use the
green circle ends of the queue to adjust its placement. By default, the queue option for Match Attached Animation Speed is turned on. This
will cause the entity in the queue to be animated (walking) with the worker instead of gliding.
57 / 815
Simio Reference Guide
AppointmentArrivals - SimBit
Problem:
I would like to model arrivals that occur at a specific time, such as scheduled appointments.
Categories:
Arrival Logic
Key Concepts:
Arrival Mode, Arrival Table, Arrival Time Deviation, Data Table, Floor Label, Status Plot
Technical Approach:
Scheduled arrivals are put into a Data Table in a DateTime property column. In this example, appointments are scheduled every 15 minutes from
8:00am until 4:30pm. The Source object reads the arrival data table to see when to create an entity. However, since the Source’s Arrival Time
Deviation property has a non-zero value, there will be some deviation from when the entities are actually created from the time listed in the
table. This simulates that some people arrive early to their appointment and some people arrive late. Because the Source’s Arrival No-Show
property is set to .05, there is a 5% chance of each arrival being a no-show, which simulates the scenario when someone doesn’t show up at all
for their scheduled appointment. The plots and floor labels show how the status of the Average Number of entities waiting to be served and the
Average Time that each entity waits to be served.
Details for Building the Model:
Simple System Setup
In the Data window, create a new Data Table by clicking on Add Data Table in the Table ribbon and name this new table
DailyAppointments. C reate a Date Time column by selecting DateTime in the Standard Property drop down in the Table ribbon. Name this
new column AppointmentTime.
Enter data into the table, beginning at 8:00am on the day the simulation begins and every 15 minutes for the rest of the day, with
the last appointment occurring at 4:30pm.
Place a Source, Server and Sink into the Facility window and connect them with Paths. Alternatively, go to the Project Home ribbon and
select Place Source, Server, Sink from the Select Add-In drop down.
Select the Source object and set the following properties:
Arrival Mode to ‘Arrival Table’
ArrivalTimeProperty to ‘DailyAppointments.AppointmentTime’ – pointing to the DateTime column you created.
ArrivalTimeDeviation to ‘Random.Uniform(-5,5)’ and the Units to ‘Minutes’
Arrival No-Show Probability to ‘.05’
Select the Server object and set the Processing Time property to ‘Random.Triangular(10, 16, 22)’
C lick onto the Run ribbon and change the starting time of the simulation run to be 8:00am and the ending time to be 5:00pm on the same
day. The date should match the date that was entered into the Data Table.
Embellishments:
Place a Status Plot that displays statistics of interest, such as the expression ‘Server1.InputBuffer.C ontents.AverageNumberWaiting’ or
‘Server1.InputBuffer.C ontents.AverageTimeWaiting’.
Arrival Tables can also use a numeric property column that lists the amount of time the arrival should occur after the start of the simulation run.
For example, if the Arrival table had a Numeric column and had the entries of .25, .5, an arrival would be generated at .25 hours after the start of
the simulation run and again at .5 hours after the start of the simulation run. This is just an alternate way to model scheduled arrivals.
58 / 815
Simio Reference Guide
BidirectionalP aths - SimBit
Problem:
I have bidirectional links in my system, but my entities get stuck at a node trying to get from one link to the other in opposite directions.
Categories:
Decision Logic -- Paths
Key Concepts:
Allow Passing, BasicNode, Bidirectional Path, Deadlock, Path, Prefer Desired Direction, Traffic Direction Rule
Assumptions:
Entities are able to pass each other at ‘bypass’ areas along various bidirectional paths.
Technical Approach:
The path network is set up with multiple bidirectional paths. The paths are separated at various points along the path with a small triangle of
unidirectional paths so that entities may sit/wait for passing in the opposite direction to occur.
Details for Building the Model:
Simple System Setup
Place a Source (Source1) and Sink (Sink1) at the left and right sides, respectively, of the Facility window.
Then, place a second Source (Source2) at the right side, below Sink1. Place a second Sink (Sink2) on the left, below Source1.
Place two ModelEntity objects. C hange the names to 'Red' and 'Green' and change the symbol color of Red to match the name. C hange
Entity Type of Source1 to ‘Green’ and Entity Type of Source2 to ‘Red’.
Specifying the Destination Locations
Within Source1’s output node (Output@Source1), change the Entity Destination Type to ‘Specific’ and the Node Name to ‘Input@Sink1’.
Similarly, within Source2’s output node (Output@Source2), change the Entity Destination Type to ‘Specific’ and the Node Name to
‘Input@Sink2’. These destinations need to be specified because with the network of paths, the option ‘C ontinue’ for Entity Destination Type
could cause entities to continually loop around the paths.
Adding Nodes, Paths and a Bidirectional Path
Place a BasicNode1 to the right of Source1/Sink1. Place a second BasicNode2 to the left of Source2/Sink2.
Using Paths, connect Source1 to BasicNode1 and Source2 to BasicNode2. Then connect BasicNode1 to Sink1 and BasicNode2 to Sink2. For
the Paths connecting the Sources to the BasicNodes, set Allow Passing to ‘False’.
Add a path connecting BasicNode1 and BasicNode2. C hange the path’s Type to ‘Bidirectional’, Allow Passing to ‘False’ and Speed Limit to
‘.1’.
Positioning the Nodes
Place 6 basic nodes in the middle of the Facility window between the Source1/Sink2 and Sink1/Source2. BasicNode1 and BasicNode2 are
closest to the Sources/Sinks, while two are near each other about 1/3 of the way between BasicNode1 and BasicNode2. The other two are
near each other about 2/3 of the way between BaasicNode1 and BasicNode2. See the diagram below for placement.
60 / 815
Simio Reference Guide
C hangingQ ueuesW henServerFails - SimBit
Problem:
When a server failure occurs, entities waiting to get processed should be transferred to another server and also identified separately.
Categories:
Add-On Process Logic, Decision Logic - Paths
Key Concepts:
Add-On Process, Assign Step, Failure, Processing C ount Based, Search Step, Transfer Step
Technical Approach:
Simple process logic is defined at the trigger of a failure of a server. The process logic searches for entities in the queue; assigns them a different
picture and sends them to another server by using a Transfer step.
Details for Building the Model:
Simple System Setup
Add a Source, two Servers, and a Sink from the Standard Library. C onnect the Source to each of the Servers and the Servers to the Sink
using Paths. Place a BasicNode next to each Server. C onnect the BasicNode at Server1 to the input node at Server2 and the BasicNode at
Server2 to the input node at Server1 using Paths.
Select Server1 and under Add-On Process Triggers, add a process for Failed. Under Reliability Logic, set Failure Type as ‘Processing C ount
Based’, Count Between Failures to ‘Random.Uniform(20,30)’ and Time To Repair to ‘Random.Uniform(5,10)’ with Units of ‘Minutes’.
Do the same for Server2, but with the Count Between Failures to ‘Random.Uniform(30,45)’ and Time To Repair to
‘Random.Triangular(5,10,15)’ with Units of ‘minutes’.
Place a ModelEntity instance from the Project Library and add an additional symbol from the Symbols ribbon. Select the new symbol (value
1) and change the color from the default green. This will allow the ModelEntity.Picture to be changed to view the re-directed entities.
Defining the Node Selection List from the Source
Within the Definitions window, select the Lists panel. C reate a Node list named ‘NodeList1’ and add ‘Input@Server1’ and ‘Input@Server2’ to
the list.
Within the Facility window, change the Source’s Interarrival Time to Random.Exponential(.15) and Maximum Arrivals (Stopping C onditions
section) to ‘80’.
Within the Source’s output node, change the Entity Destination Type to ‘Select From List’, the Node List Name to ‘NodeList1’ and the
Selection Condition to ‘C andidate.Server.ResourceState != 3’. This will send the entities to the first entry in the node list, as long as the
resource state isn’t set to 3 (Failed).
Defining the Processes When Failures Occur
Within the Processes window, in the Server1_Failed process, add a Search step, within an Assign step and a Transfer step connected to the
Found exit of the Search.
Within the Search step, change the Collection Type to ‘QueueState’. Set the Queue State Name to ‘Server1.InputBuffer.C ontents’. For
Search Type select ‘Forward’. Under Advanced Options, set the Limit to ‘100’. This will search the contents of the queue of entities waiting
to process at the failed server.
Within the Assign step, change the State Variable Name to ‘ModelEntity.Picture’ and New Value to ‘1’.
Within the Transfer step, change From to ‘C urrentStation’ To to ‘Node’, and Node Name to ‘BasicNode2’. Under Advanced Options, click on
Token Wait Action and select ‘WaitUntilTransferringEvent’.
Add the same logic to Server2_Failed process except within the Search step, the Queue State Name is ‘Server2.InputBuffer.C ontents’ and
within the Transfer step, the Node Name is ‘BasicNode1’.
Enhancements:
With the above logic, all entities currently sitting in the queue when a Server fails will be automatically moved to the other Server. This, however,
will not move those entities that are already en-route to the failed Server. Note that the processes named Input_Server1_Exited and
Input_Server2_Exited (which are on the input node of the corresponding servers) will transfer those en-route entities as well.
61 / 815
Simio Reference Guide
C heckingNextEntityAheadO nLink - SimBit
Problem:
I want to know the traffic that is in-front of an entity on a link.
Categories:
Add-On Process Logic
Key Concepts:
Add-On Process, Decide Step, Delay Step, Floor Label, NextEntityAheadOnLink, Path, TransferNode
Technical Approach:
A process is created which triggers when an entity enters a path. In the process, entity is delayed to maintain the desired fixed distance from the
next entity ahead of it on the link. A floor label is used to display information on the ModelEntity.
Details for Building the Model:
Simple System Setup
Add a Source, TransferNode and Sink from the Standard Library. C onnect the Source to TransferNode and TransferNode to Sink using
Paths.
In the Properties window for Path2, under Add-On Process Triggers, click Entered and select ‘[C reate New]’. This will create a new process
named Path2_Entered within the Processes window.
Place an instance of ModelEntity from the Project Library named ‘DefaultEntity’. Highlight the Entity and attach a Floor Label from the
Symbols ribbon. Edit the Floor Label from the Appearance ribbon. Add ‘Entity {ID} is following {NextEntityAheadOnLink} at
{NetworkDistanceTo.NextEntityAheadOnLink}’ as Label Text.
Defining the Process
Under Path2_Entered, add a Decide step into the process. Set the Decide Type to ‘C onditionBased’ and Expression to
‘ModelEntity.NetworkDistanceTo.NextEntityAheadOnLink < 10 & & ModelEntity.NetworkDistanceTo.NextEntityAheadOnLink != 0’.This will
evaluate the entity, if any, in front of the current entity and will return a ‘True’ if the distance is less than 10 (meters, which is the default
distance units).
From the Decide step’s True exit, add a Delay Step with the Delay Time of ‘2’ and Units of ‘Seconds’. The Delay step should then connect
back to the Decide step for re-evaluation.
62 / 815
Simio Reference Guide
C hooseAlternateSequence - SimBit
Problem:
I have a model that normally process parts in the sequence Server1, Server2, Server3, Inspect, Sink but based on the result of the inspection, it
sometimes must be diverted to Adjust and then restart at Server2.
Categories:
Add-On Process Logic, Sequence Tables
Key Concepts:
Sequence Table, By Sequence, Entity Destination Type, Add-On Process, SetRow Step
Assumption:
The source produces one type of entity. The entity will follow a primary sequence of: Source – Server1 – Server2 – Server3 – Inspect – Sink.
But if it fails inspection (30% of the time) it will divert to an alternate sequence of Adjust and then resume its normal sequence from Server2.
Technical Approach:
Separate Sequence Tables are created for the entity to follow its normal sequence and sometimes divert to another route. We will create one
main sequence table which is identical to the first sequence specified above. We will create an additional sequence to switch to if the entity fails
and has to go to the Adjust server. In order to make decisions at the inspection, add-on processes will be created.
Details for Building the Model:
Simple System Setup
Place a Source and a Sink in the Facility window. In between them, place four Servers that are relatively next to each other and place
Server5 parallel to Server4.
C onnect an Output Node of Source to an Input Node of Server1, an Output Node of Server1 to an Input Node of Server2, an Output Node
of Server2 to an Input Node of Server3, an Output Node of Server3 to an Input Node of Server4, and an Output Node of Server4 to the
Sink with a Path. An Output Node of Server 4 to an Input Node of Server5 and an Output Node of Server 5 to an Input Node of Server2
must be connected with a Path also.
Rename Server4 to Inspect and Server5 to Adjust. Place one Model Entity object in a Facility window. Rename Model Entity to ‘Part’.
Setting up the Sequence Tables
In the Data Window, select the Tables panel and add two Sequence Tables. Name them ‘NormalSequence’ and ‘AdjustmentSequence’.
For the NormalSequence, set the following sequence: Input@Server1 – Input@Server2 – Input@Server3 – Input@Inspect – Input@Sink1
For the AdjustmentSequence, set the sequence: Input@Adjust.
Setting up Add-On Process
In the Facility window, by clicking Inspect object and under Add-On Process Triggers by double clicking After Processing, a process will be
created by default in a Processes window.
Repeat these steps with Adjust object in order to create After Processing Add-On Process as well.
Setting up Process Logic
In a Processes Window in the Inspect_AfterProcessing process, place a Decide step to represent the inspection and the likelihood of
passing. C hange its Decide Type is going to be ‘ProbabilityBased’ with Expression set to ‘0.7’. The True exit represents “Passed” and
requires no action – we will leave that unchanged. The False exit represents “Failed” and requires using SetRow step to change to an
alternate Sequence (set Table Name to ‘AdjustmentSequence’ and leave Row Number at its default (the start of the sequence)). Here we
have also added an Assign step to set the ModelEntity.Picture to ‘1’ so we can identify it as a red failed part in the model.
In the Adjust_AfterProcessing process, we need to restore the part to its normal look and processing. Place SetRow step with Table Name
of ‘NormalSequence’. Set the Row Number to ‘2’ to allow entity to resume with Server2 object and follow its normal sequence. Also add an
Assign step to set the ModelEntity.Picture back to ‘0’ so it will again be green.
Finalizing the Model
C hange the Initial Sequence of the Entity to ‘NormalSequence’.
Add Additional Symbol to the entity and color it red.
C hange the Interarrival Time on the Source to ‘Random.Exponential(.3)’ to give a more balanced system.
63 / 815
Simio Reference Guide
C ombinerNode - SimBit
Problem:
I want to create a user-defined node that can batch entities based on entity priority.
Categories:
Building New Objects / Hierarchy, C ombining and Separating Entities
Key Concepts:
Batch Step, BatchLogic Element, BatchMembers Queue, Expression Property, Decide Step, Discrete State, EndTransfer Step, Node C lass,
OnEntered, OnEnteredParking, Path, Park Step, Search Step, State Variable, Station Element, Transfer Step, UnPark Step
Technical Approach:
A node object is created that has process logic which stops entities at the node to batch them into the user-defined Batch Size and then sends
them out through the node. The process logic first checks if the entity needs to be batched. If so, the entity is transferred to the ParkingStation
until the batch is complete. If a parent already exists in the batch logic for that priority, the entity becomes a member. After all the members of
the batch arrive, the batched entity is transferred from the ParkingStation back to the beginning of the node process. Since the entity is batched,
the batched entity is transferred to the outbound link.
Details for Building the Model:
C reating the Node Object and Defining the Properties, States and Elements
On Project Home ribbon, click the New Model dropdown list and select Node C lass. A new Node will be created in the Navigation window.
In the Node Model Properties (right click on the object and select Properties), change the Model Name to 'C ombinerNode'.
In the Definitions Window, select Properties window. From the Standard Property list, select Expression. In the Properties window, change
the Name to ‘BatchSize’, set Default Value as ‘2’, Display Name to ‘Batch Size’, Category Name to ‘Process Logic’, and Description to ‘Total
number in group, including parent.’
C lick Properties (Inherited). Select C apacityType. C hange Visible to ‘False’. Also do this for InitialC apacity, WorkSchedule, RankingRule,
and DynamicSelectionRule. C hanging the visibility will hide these properties in the C ombinerNode Properties window since we will not be
using them.
C lick the States button on the Definitions panel, and select Real from the States ribbon to add a new state. C hange the Name to ‘Batched’
and the Initial State Value to ‘0’.
Select the Elements button from the Definitions panel, and add a BatchLogic element from the Elements ribbon. Set Batch Quantity to
‘BatchSize – 1’. BatchSize typically represents the number of ‘member’ entities to batch with a single parent entity. Set Matching Rule to
‘MatchMembersAndParent’, Member Match Expression to ‘ModelEntity.Priority’, and Parent Match Expression to ‘ModelEntity.Priority’.
C reating Process Logic for the C ombinerNode
In the Processes window, click Select Process and select OnEntered.
Add the following steps in order to the OnEntered process: Decide, Park, Search, Decide, Batch, Assign and UnPark. Batch, Park, and
UnPark are under All Steps.
Select the first Decide Step; set Decide Type to ‘C onditionBased’ and Expression to ‘Batched==0’. When all entities first enter the node,
this condition will be true and they will continue out the True exit (you will see shortly when the condition will be false).
The Park step is used so that entities will sit and graphically wait at the node until the batch is made (otherwise, they will be shown at the
node on top of each other). No property changes are necessary for this step.
Set the Search step Collection Type to ‘QueueState’, Queue State Name to ‘BatchLogic1.ParentQueue’, Match Condition to
‘ModelEntity.Priority==C andidate.ModelEntity.Priority’, Search Expression to ‘1’. This step is used to determine if there is already a ‘parent’
entity (one entity of that same priority value). The value of the Search Expression is returned in the Token.ReturnValue for the process. If
no items are found (no parent yet), the return value will be 0.
For the second Decide step, set Decide Type to ‘C onditionBased’ and Expression to ‘Token.ReturnValue<1’ to check the above returned
information.
Within the Batch step, set Batch Logic Name to ‘BatchLogic1’ and Category to ‘Parent’.
Set the Assign step State Variable Name to ‘Batched’ and New Value to ‘1’.
The UnPark step is used once the batch is made to move the newly batched entity from the parking area of the station (the entity then
goes back ’into’ the node and goes through the OnEntered process, which is why we set the Batched variable to 1, so that newly batched
entities will exit the False exit of the Decide step, as shown below).
Add an Assign step to the False branch of the first Decide step. Set the State Variable Name to ‘Batched’ and New Value to ‘0’.
Add a Transfer step after the Assign step; set From to ‘C urrentNode’ and To as ‘OutboundLink’. This will cause only newly batched entities
to leave the node on the outbound link.
Add a Batch step to the False branch of the second Decide step. Set Batch Logic Name to ‘BatchLogic1’ and Category to ‘Member’. All
entities except the first entering ‘parent’ will go here and be batched with the parent entity.
C lick on Select Process on the Process ribbon and select OnEnteredParking. Add an EndTransfer step so that when the entities are parked,
their transfer into the parking station is complete.
Simple System Setup
C lick Model in the Navigation window. Add two Sources and a Sink from Standard Library. From the Project library (below Standard and
Flow Libraries on the left), place a C ombinerNode in the Facility window. C onnect the Sources to the C ombinerNode and the C ombinerNode
to the Sink using Paths.
Place two instances of ModelEntity from the Project Library. Select one Entity instance and in the Symbol ribbon, click Draw Queue and
select BatchMembers. Draw a line near the Entity and do the same for the other Entity. Set one entity's Initial Priority to ‘1’ and the other's
Initial Priority to ‘2’. Select one entity, click the C olor dropdown in the Symbols Ribbon, select Red, and click the top of the entity.
Set Source1 Entity Type to ‘DefaultEntity’ and Source2 Entity Type to ‘ModelEntity1’.
Select the C ombinerNode and set Batch Size to ‘5’.
64 / 815
Simio Reference Guide
C ombineMatchingMembers - SimBit
Problem:
I want to batch multiple entities together for subsequent processing. Only entities with identical state values can be batched together.
Categories:
C ombining and Separating Entities
Key Concepts:
BatchMembers Queue, C ombiner, Matching Rule, MemberInputBuffer, ModelEntity, ParentInputBuffer, Priority, Queue
Assumptions:
We will batch 4 parts together into each container and as many as 5 batches can be worked on concurrently.
Technical Approach:
Use the existing state named ‘ModelEntity.Priority’ and use an Add-On Process in the Source to assign it. Use a C ombiner of capacity 5 to do the
batching of 4 Parts into a C ontainer.
Details for Building the Model:
Simple System Setup
Add two Sources, a C ombiner, a Server and a Sink to the Facility Window.
C onnect the Sources to the C ombiner, the C ombiner to the Server and Server to the Sink with Paths.
Adding Multiple Entity Types
Drag two ModelEntity objects from the Project Library into the Facility Window and change the Name of each. Specify two different entity
types, ‘Parts’ and ‘C ontainers’.
Designate each Source object to generate a different part type by changing the Entity Type property on one to be ‘Parts’ and the other to
be ‘C ontainers’.
C hanging the Entity Priority
Within the ‘Parts’ Source object , enter the State Assignments, Before Exiting repeating editor and add a State Variable Name
‘ModelEntity.Priority’ with a New Value of 1 or 2 using the ‘Random.Discrete( 1, .5, 2, 1)’ distribution function.
Using the C ombiner
The C ombiner is batching four members (Parts) to one parent (C ontainer) and only batches members together that have matching priority
value (e.g. each batch will have either four entities with priority of 1 or four entities with priority of 2). This is done by specifying the Batch
Quantity to ‘4’, Matching Rule to ‘Match Members’ and Member Match Expression to ‘ModelEntity.Priority’.
As mentioned in Assumptions, the C ombiner has a Capacity of ‘5’, meaning up to 5 batches may be processing at a time, with Processing
Time set to ‘Random.Uniform(1,5)’.
Enhancing the Animation
Move the queue that displays parents waiting for a match.
Add a queue that displays members waiting for a match by selecting a Detached Queue from the Drawing tab and changing the Queue
State to ‘C ombiner1.MemberInputBuffer.C ontents’.
65 / 815
Simio Reference Guide
C ombineT henSeparate - SimBit
Problem:
I have two different entity types entering the system. I need to batch them together, process the combined batch and then un-batch them before
exiting the system.
Categories:
C ombining and Separating Entities
Key Concepts:
C ombiner, Separation Mode, Separator, Split Batch
Assumptions:
Parts are batched, then processed through a Server and then separated.
Technical Approach:
Two sources create the two different entity types and then lead into a C ombiner object that batches two entities together. The batched entities are
processed by a Server and then sent to a Separator to be un-batched again before exiting the system.
Details for Building the Model:
Simple System Setup
Place two Sources in the Facility Window. Also place a C ombiner, a Server, a Separator and two Sinks into the Facility Window.
C onnect the Sources to the C ombiner, the C ombiner to the Server, the Server to the Separator and the Separator to each Sink using a
Path.
Defining Multiple Entity Types
Place two ModelEntity objects into the Facility Window by dragging them from Project Library window. C hange the Name property to
‘Entity1’ and ‘Entity2’, respectively.
Within each Source, change the Entity Type property to generate either ‘Entity1’ or ‘Entity2’.
Using the C ombiner
The C ombiner Batch Quantity should be set to ‘1’ so that the entity at the Parent input node waits for 1 entity at the Member input node
and then batches together.
Separating Entities
The Separation Mode property in the Separator object is set to ‘Split Batch’ and the Split Quantity is set to ‘1’.
Embellishments:
The same requirements could be modeled without a Server object. The processing time of the Server from the above approach could instead be
put in the Processing Time of the C ombiner object.
66 / 815
Simio Reference Guide
C ommunicationBetweenO bjects - SimBit
Problem:
One object wants to “watch” another’s behavior and react to it.
Categories:
Building New Objects / Hierarchy, Discrete States
Key Concepts:
Assign Step, C ontinueProcess, Monitor, Process Triggering Event, Real State Variable, State Property, Status Label, Timer Element
Assumptions:
We have two fixed objects (the Subject and the Observer), each of which has a state (SubjectRate and ObserverRate). The Subject changes
SubjectRate randomly. The Observer wants to change ObserverRate to match SubjectRate.
Technical Approach:
Both of the two fixed objects are process models (e.g. no facility logic or objects). The Observer is defined with a State Property, ObserverRate,
that allows a State Property from another object, SubjectRate, to be passed in. The Observer then uses that state property for both setting up a
monitor and getting the value for ObserverRate.
Details for Building the Model:
Defining the Subject
Define a new fixed object Subject with a discrete state variable with Name ‘SubjectRate’.
In the Definitions Window, within the Elements panel, add a Timer element with Name ‘Timer1’ to fire an event with Interval of ‘1’ hour.
In the Processes Window, add a process with Name ‘SubjectUpdatesValue’ whose Triggering Event is ‘Timer1.Event’. Add an Assign step
where the State Variable Name is ‘SubjectRate’ and the New Value is ‘Random.Triangular( 0, 1, 2)’.
Defining the Observer
Define a new fixed object Observer with a discrete state variable with Name ‘ObserverRate’.
In the Definitions Tab of Observer, select the Properties panel and add a State Property with Name ‘SubjectRate’. This will allow the value
of this property, when placed in a Facility Window of a model, to be assigned to the SubjectRate of the Subject.
In the Definitions Window, within the Elements tab, add a Monitor element to fire a process when the State Variable Name ‘SubjectRate’
changes.
In the Processes Window, add a process with Name ‘ObserverFollowsSubject’ whose Triggering Event is ‘Monitor1.Event’.
Add an Assign step where the State Variable Name is ‘ObserverRate’ and the New Value is ‘SubjectRate’.
Defining a new model and using Subject and Observer objects
Open a new model and place one Subject and one Observer within the Facility Window.
In the properties window for the Observer, enter ‘Subject1.SubjectRate’ in the SubjectRate property.
Discussion:
If you watch the trace you will see that every hour the following sequence will occur:
Timer1 triggers an event which triggers the process SubjectUpdatesValue
SubjectRate changes value which triggers the monitor on SubjectRate
The monitor triggers the process ObserverFollowsSubject
ObserverRate changes value to match SubjectRate
67 / 815
Simio Reference Guide
C onwip - SimBit
Problem:
I would like to model a C ONWIP system (constant level of WIP). The system should begin with 10 entities in the system and as soon as one entity
leaves the system, another should arrive.
Categories:
Buffering, Data Tables
Key Concepts:
C reate Step, Data Table, Limit, Numeric Property, OnRun Initialized Process, Real State Variable, Search Step, Source, Status Label, Table Station
Element Property, Transfer Step
Assumptions:
This model contains 5 servers and the initial 10 entities are placed evenly at each server(i.e. 2 entities at each Server to begin). When a new
entity arrives, it will be randomly sent to one of the 5 servers.
Technical Approach:
Upon initialization, the model looks in a Data table to find any initial WIP that should exist in the system and It creates those entities and transfers
them to the appropriate station. The Source is set to create an arrival whenever an entity enters the Sink.
Details for Building the Model:
Simple System Setup
Place a Source and a Sink into the Facility window. Also place a Model Entity from the Project Library into the Facility window, which will be
called DefaultEntity.
Place 5 Servers in between the Server and Sink. These Servers are in parallel.
C onnect everything with Paths.
C lick on the Source object and set the Arrival Mode property to ‘OnEvent’. Set the Event Name property to ‘[email protected]’. This tells
the Source object to only produce arrivals when the event [email protected] occurs. This creates a pull system where arrivals occur
whenever an entity enters the Sink is about to exit the system.
C reate Data Table
The Data Table will contain the number of entities that should be in the system upon initialization and where they should be located.
Go to the Data window and click the Add Data Table icon in the ribbon to add a new table.
Add a column that is an Integer property by selecting Integer property from the Standard Property drop down in the ribbon. The column
can be renamed to InitialWIP.
Add another column that is a Station property by selecting Station from the Element Reference drop down in the ribbon. The column can
be renamed to Station.
Populate this table by putting the value of 2 in each row of the first column and then selecting Server1.InputBuffer for the first row,
Server2.InputBuffer for the second row, etc – for the second column.
Add Process Logic
From within the Processes window, create a new process by selecting OnRunInitialized from the Select Process drop down in the ribbon.
Place a Search step into this process, followed by a C reate step in the Found segment of the Search Step, and finally, a Transfer
step in the C reated segment of the C reate step.
In the Search step, set the Collection Type property to ‘TableRows’ and select the name of the Data Table that you created above.
Within the Advanced Options section of the Search step, change the value ‘1’ in the Limit property to 'Infinity'. This will allow the
Search to find all rows in the table.
In the C reate step, the Create Type property should be set to ‘NewObject’ and the Object Instance Name should be set to ‘Default
Entity’. The Number of Objects property should be set to ‘InitialWIP.InitialWIP’, where InitialWIP is the name of the Data Table and
InitialWIP is the name of the Integer column in the Data Table. This tells the C reate Step to create the number of entities that are
listed in the Integer column of the Data Table.
In the Transfer step, set From to ‘FreeSpace’ (since entities are created in Free Space by default) and the To property to ‘Station’.
The Station Name property should be set to ‘InitialWIP.Station’, where InitialWIP is the name of the Data Table and Station is the
name of the Station property in the table.
Embellishments:
If you would like to see the current number of entities in the system, you can add a Status Label to the Facility window and set the expression to
DefaultEntity.Population.NumberInSystem.
68 / 815
Simio Reference Guide
C ustomR outingG roup - SimBit
Problem:
I would like arriving entities from two different locations to select between servers based on the closest server available. Entities from one of the
sources have priority over the other, however, when a busy server becomes available.
Categories:
Decision Logic – Paths, Decision Logic - Processing, Entity C haracteristics
Key Concepts:
Buffer C apacity, Entity Destination Type, InputBuffer, Lists, NodeList, Picture, Priority, RoutingGroup Element, State Assignments
Technical Approach:
In this example, we will have two Sources feeding entities into one of three Servers. The buffer capacities of the Servers are zero, so entities will
wait at the Sources to proceed forward. To ensure that entities from the Source1 object have priority over those from Source2, we will create a
custom RoutingGroup that both Sources will reference. The RoutingGroup will have a Route Request Ranking Rule of ‘Smallest Value First’ based
on the entity priority value.
Details for Building the Model:
Simple System Setup
Place two Sources, three Servers and a Sink. C onnect each of the Sources to each of the Servers with Paths (6 paths), then connect each
of the 3 Servers to the Sink.
Place a ModelEntity from the Project Library into the Facility window. While the entity is highlighted, click on the Add Additional Symbol
button to add a symbol. C hange the symbol for the value 1 to be the color blue.
C reate Node List and Routing Group Element
From within the Definitions window, click on the Lists panel and add a Node type list (NodeList1) to include the three Servers –
Input@Server1, Input@Server2, Input@Server3.
Also from within the Definitions window, click on the Elements panel and add a RoutingGroup element named 'RoutingGroup1'. Specify the
Node List Name to be ‘NodeList1’. Under the Advanced Options, change the Route Request Ranking Rule to be ‘Smallest Value First’ and the
Route Request Ranking Expression leave as ‘Entity.Priority’. When multiple entities are waiting to move from this routing group, they will be
ranked based on their priority instead of first in first out.
Editing the Source Objects
Within each of the Sources, change the Interarrival Time to ‘Random.Exponential(0.18)’ minutes.
Within Source1, add State Assignments of State Variable Name ‘ModelEntity.Picture’ to ‘0’ and State Variable Name ‘ModelEntity.Priority’ to
‘1’.
Within Source2, add State Assignments of State Variable Name ‘ModelEntity.Picture’ to ‘1’ and State Variable Name ‘ModelEntity.Priority to
‘2’.
Within the output TransferNode of each of the Sources, change the Entity Destination Type to ‘Use C ustom Routing Group’. Specify the
Routing Group Name as ‘RoutingGroup1’. C hange the Selection Goal to ‘Smallest Distance’.
Note that by using the same RoutingGroup element for both Source objects, if an entity has to wait for a Server object to become
available, the entities from BOTH Source objects are evaluated together and will be ranked based on their priority values. Therefore,
waiting entities from Source1 (green color) will move to a Server before waiting entities at Source2 (blue color).
Editing the Server Objects
Within each of the Servers, change the Input Buffer under Buffer C apacities to ‘0’. Therefore, no entities will wait at the Server for
processing; they will wait at the Source objects. This is because of the buffer capacity in conjunction with the Blocked Destination Rule at
the Source output nodes as ‘Select Available Only’.
69 / 815
Simio Reference Guide
C ustomUnbatching - SimBit
Problem:
I have two entity types (P1 and P2) batched to a parent entity type (C rate). I need to unbatch the P2 entities, change their dimensions and send
them to a different sink.
Categories:
Add-On Process Logic, C ombining and Separating Entities
Key Concepts:
Add-On Process, Assign Step, C ombiner, Decide Step, Match C ondition, Priority, Selection Weight, Sink, Source, TransferNode, Transfer Step,
UnBatch Step
Technical Approach:
A mix of five P1 and P2 entities are batched to the C rate entity at the C ombiner. When the batched entities reach TransferNode1, the P2 entities
are unbatched, transferred to TansferNode1 from Free Space, and resized using Add-On Process logic. Then the P2 entities are sent to a separate
Sink using Path Selection Weight.
Details for Building the Model:
Simple System Setup
Place three Sources in the Facility window. Also place a C ombiner, a TransferNode and two Sinks into the Facility window.
Using Paths, connect Source1 to the ParentInput@C ombiner1 node. C onnect Source2 and Source3 to the MemeberInput@C ombiner1 node.
Then connect the C ombiner to the TransferNode and the TransferNode to both Sinks.
Place three ModelEntity objects into the Facility window from Project Library window. C hange the ModelEntity Name to ‘C rate’, ‘P1’ and ‘P2’,
respectively.
Select the Entity named ‘C rate’ and in the Symbol Ribbon, click Draw Queue dropdown and select BatchMembers. Then draw a line above
the ‘C rate’ entity. Right click to stop drawing the queue. This line will show all entities batched to the ‘C rate’ entity.
C hange the P2 Entity Initial Priority to ‘2’ in the ModelEntity properties.
C hange the Entity Type of Source1 to ‘C rate’, Entity Type of Source2 to ‘P1’ and Source3 to ‘P2’. C hange the Interarrival Time of Source1
to ‘Random.Exponential (.6)’ minutes.
Set the C ombiner Batch Quantity to ‘5’.
Select the path between the TransferNode and the Sink1. C hange its Selection Weight to ‘ModelEntity.EntityType == P2’.
On the path between the TransferNode and the Sink2, set its Selection Weight property to ‘ModelEntity.EntityType != P2’.
UnBatching Entities Add-On Process Logic
C reate a process on the Entered Add-On Process Trigger in the TranferNode1 properties. This process will be triggered whenever an entity
enters this TransferNode.
Place a Decide step. Set the Decide Type property to ‘C onditionBased’ and set the Expression to ‘ModelEntity.BatchMembers == 0’.
C rate entities will have 5 batched members and P2 entities will have 0 batched members once it is unbatched and re-enters the
node.
On the True branch leaving the Decide step, place an Assign step. Set the State Variable Name to ‘ModelEntity.Size.Width’ and the
New Value to ‘ModelEntity.Size.Width * 2’.
On the False branch of the Decide step, place an UnBatch step. Set the Desired Quantity property to ‘Entity.BatchMembers’ and the
Match Condition to ‘C andidate.ModelEntity.Priority==2’.
In the Member segment leaving the UnBatch step, place a Transfer step. Set the From property to ‘FreeSpace’, the To property to
‘Node’ and the Node Name property to ‘TransferNode1’. This will send all unbatched P2 entities to the same TransferNode and
trigger this process again for re-sizing the entity.
Embellishments:
Select the path between the TransferNode and the Sink1 and change the Allow Passing property to ‘False’. That will show all unbatched entities
separated trough the path instead of all of them in just one entity.
C hange the path Speed Limit to ‘0.5’ for the path between the C ombiner and the TransferNode and the paths between the TransferNode and Sink1
and Sink2.
Note: The UnBatching Process Logic in this model can be replaced with a Separator object, but the goal of this SimBit is to show the features of
the UnBatch step.
70 / 815
Simio Reference Guide
DashboardR eportInteractiveLogs - SimBit
Problem:
For an existing project, I want to be able to graphically display the resource utilization as well as display a vehicle’s pickup and drop off times in
chart format. We will accomplish this by creating a Dashboard Report from an existing SimBit project VehicleVisitsServiceC enter.
Categories:
Dashboard Reports, C ustom Statistics
Key Concepts:
Dashboard Reports, Interactive Logging, Log Observations, Resource State
Assumption:
This SimBit will illustrate how to create a Dashboard Report of log files generated within the VehicleVisitsServiceC enter project. In order to create
a Dashboard Report for Interactive Logs, you must have the Simio Enterprise Edition.
Technical Approach:
A dashboard with a grid of vehicle pickup times and a pie chart of resource utilization percentages will be created.
Details for Building the Model:
System Setup
Load the VehicleVisitsServiceC enter Simio project.
For Server1, Server2 and MyVehicle1, under the Advanced Options change the Log Resource Usage property to ‘True’.
From the Run ribbon, under Advanced Options, make sure Enable Interactive Logging is turned on.
Fast Forward the model to completion.
C reating the Dashboard Report
Select Results, Logs, Resource Usage Log and Transporter Usage Log and make sure there is a log table that is populated with data. If not,
verify the above steps.
Select Results, Dashboard Reports, Dashboard Report C reate.
In the Add Dashboard window, select an name for the dashboard (ex: Pick Ups).
Select Transporter Usage Log from the pull down list on the left of the window.
C lick on Grid in the Dashboard ribbon. This will create a Grid of items in the Transporter Usage Log and insert it into the dashboard.
From the Transporter Usage Log, drag Resource over top of the C olumns data item to the right. Follow that by dragging From Node, Start
Time, To Node, End Time and Entity onto the C olumns data items. This identifies which columns will appear on the grid.
For the Start Time and End Time items, click on the right of the item to change the modifier to Date-Hour-Minute-Second.
Right click in the Grid area, select Edit Names and change the Dashboard item name to Pick Ups.
Now select Resource State Log from the pull down list on the left side of the window.
C lick on Pies in the Dashboard ribbon. This will create a pie chart of items in the Resource State Log and insert it into the dashboard.
From the Resource State Log, drag Duration over the Value data item, State over the Argument data item and Resource over the Series
data item.
Right click in the Pie area, select Edit Names and change the Dashboard item name to Resource States.
Select the Pie item and drag it below the Grid item.
C lick the Save button in the upper left corner of the ribbon to save the dashboard. C lose the DashboardDesignerForm.
Various Dashboard Reports can be displayed in the results tab by selecting a dashboard from the Select pull down list.
Embellishments:
Add a Pivot grid using the data in the Resource State Log using the Duration as the Value data item, State as the C olumn data item and Resource
as the Row data item. This will display a chart of the amount of time the resource was in each state.
71 / 815
Simio Reference Guide
DashboardR eportT allies - SimBit
Problem:
For an existing project, I want to be able to graphically display the time in the system for each entity in a model, once the model has completed.
We will accomplish this by creating a Dashboard Report from an existing SimBit TallyStatisticsInTables.
Categories:
Dashboard Reports, C ustom Statistics
Key Concepts:
Dashboard Reports, Data Table, TallyStatistic, Log Observations, Tally Step, Entered, Add-On Process, Table Reference Assignments, On C reated
Entity, Dynamic Object Property, Expression Property, Table Tally Statistic Element Property, Selection Weight, Path
Assumption:
This SimBit will illustrate how to create a Dashboard Report of a TallyStatistic already being generated within the TallyStatisticsInTables project. In
order to create a Dashboard Report for Tallies, you must have the Simio Team or Enterprise Edition.
Technical Approach:
A chart of the Time in System for a given entity will be graphed over the length of the model run.
Details for Building the Model:
System Setup
Load the TallyStatisticsInTables SimBit.
Under Definitions, Elements, TallyStatistic PartA_Passed, change the Log Observations property (under Advanced Options) to ‘True’.
Fast Forward the model to completion.
C reating the Dashboard Report
Select Results, Logs, Tally Observation Log and make sure there is a log table that is populated with data. If not, verify that Log
Observations is set to ‘True’.
Select the Dashboard Reports panel, and click on Dashboard Report in the Dashboards ribbon.
In the Add Dashboard window, select an name for the dashboard (ex:Tallies).
Select Tally Observation Log from the pull down list on the left of the window.
C lick on C hart within the Dashboard ribbon. This will create a C hart dashboard item and insert it into the dashboard.
From the Tally Observation Log list of options, drag Value over top of the Value data item to the right. C lick on the icon to the right of the
Value(SUM) data item and change the chart type to Line.
Drag Time over top of the Argument data item. C lick on the arrow in the Time data item and change the modifier from Year to Date-Hour-
Minute. Make sure the arrow to the left of the Time Data Item is pointing up so that our timeline is in the right order. (you can click once on
the arrow to change from up to down or down to up).
Drag DataSource onto the Series data item.
Right click in the C hart area and change the Dashboard item name to Time In System.
C lick the Save button in the upper left corner of the ribbon to save the dashboard. C lose the DashboardDesignerForm.
Various Dashboard Reports can be displayed in the results tab by selecting a dashboard from the Select pull down list.
Embellishments:
Add a Range Filter to the dashboard. This will allow you to apply filtering to your dashboard items. A Range Filter displays a chart with selection
thumbs that allow you to filter out values displayed on the argument axis.
72 / 815
Simio Reference Guide
DbR eadW rite - SimBit
Problem:
I want to use MySQL to read data into Simio and also to write data from Simio.
Categories:
File Management
Key Concepts:
DBC onnect Element, DBRead Step, DBWrite Step, DBQuery Step, DBExecute Step, Database, SQL, MySQL
Assumptions:
Database connectivity must already be setup or this model will not run! See Appendix for example.
There are two approaches described below, one model using DbRead, and DbWrite, and another model using DbQuery and DbExecute.
Approach Using DbRead and DbWrite
Technical Approach:
DbC onnect Element is used to connect with the MySQL database. The OnRunInitialized process is used to delete existing data from the database
table. An Add-On process is used within an object where data is read using DbRead step. The position is defined where data has to be written in
the database using Assign step. Then using DbWrite step, data is written into database.
Details for Building the Model:
Simple System Setup
Within the Facility window, place a Source, a Server and a Sink and connect them using Path objects.
Within the Sink’s input node, double-click on the Entered Add-On Process to create a new process named ‘Input_Sink1_Entered’. We will
add steps within that process shortly.
Defining the States for the Model
Within the Definitions window, click on the States panel and add a String state with the Name ‘StringState1’. Set the Initial State Value to
‘DefaultEntity.11.’
Add a Real state with the Name ‘RealState1’. C hange the Initial State Value to ‘-1’.
Add two DateTime states with the Name of ‘DateTimeState1’ and ‘DateTimeState2’. Set their Initial State Value properties to ‘10/1/12’ and
‘11/1/12’, respectively.
Add two Integer states with the Name of ‘IntegerState1’ and ‘RowID’. Leave the Initial State Value of both to the default ‘0’.
Add a Boolean state with the Name ‘SimpleDbSteps’ that has an Initial State Value of ‘True’.
Defining the DbC onnect Element
Within the Definitions window, click on the Element panel and select the DbC onnect element from the User Defined button pull down.
In the property window for DbC onnect1, enter the Connection String as ‘Server=localhost; Port=3306; Database=world; Uid=root;
Pwd=root’. C lick on Provider Name and set it as ‘MySQL Data Provider’.
Using the Database Steps in a Process
Within the Processes window, click on Select Process in the Process ribbon and select the OnRunInitialized process. Add a DbExecute step
from the User Defined panel to the process. Specify the DbConnect as ‘DbC onnect1’, the SQL Statement as ‘Delete From TestReadWrite
where Id>@1’. Within the Items repeat group, enter the Expression ‘RowID’.
Next, within the Input_Sink1_Entered process, add the Decide, DbRead, Assign and DbWrite steps.
Within the Decide step, keep Decide Type as ‘C onditionBased’ and add Expression as ‘RowID > 0’.
For the DbRead properties, the DbConnect is ‘DbC onnect1’, created above. Assign the Table Name to ‘TestReadWrite’. C lick on Columns
repeating property editor and add 5 items as shown below
Column – State
String1 – StringState1
Integer1 – IntegerState1
Real1 – RealState1
DateTime1 – DateTimeState1
DateTime2 – DateTimeState2
Within the Where repeating property editor, add Where Column value ‘Id’ and Where State value ‘RowID’.
Within the Assign step, enter the State Variable Name as ‘RowID’ and New Value as ‘RowID+1’.
For the DbWrite properties, the DbConnect is ‘DbC onnect1’ and the Table Name is ‘TestReadWrite’. C lick on Columns repeating property
editor and add 6 items as shown below
Column – Expression
Id -- RowID
String1 – Entity.Name
Integer1 – Entity.ID
Real1 – TimeNow
DateTime1 – String.FromDateTime( Entity.TimeC reated, "yyyy/MM/dd HH:mm:ss")
DateTime2 – String.FromDateTime( TimeNow, "yyyy/MM/dd HH:mm:ss")
Adding Status Labels to the Facility Window
From Animation ribbon, select and place 6 Status Labels in the Facility window.
For first label, enter the Expression ‘StringState1’. Repeat the same for the other 5 states defined above (not needed is the SimpleDbSteps
Boolean state). In the case of the DateTime states, use the Expression ‘DateTime.ToString(DateTimeState1)’ and
73 / 815
Boolean state). In the case of the DateTime states, use the Expression ‘DateTime.ToString(DateTimeState1)’ and
‘DateTime.ToString(DateTimeState2)’.
Approach Using SQL Query (DBQuery and DBExecute)
All the states and process information remains the same as above, but in the Processes window, use the DbQuery and DbExecute steps instead of
DbRead and DbWrite steps.
For the DbQuery step, the DbConnect is ‘DbC onnect1’. For the SQL Statement, enter ‘Select String1, Integer1, Real1, DateTime1,
DateTime2 from TestReadWrite where Id = @6’. Within the States repeating property editor, add 6 State values:
State
StringState1
IntegerState1
RealState1
DateTimeState1
DateTimeState2
RowID
For the DbExecute step, the DbConnect is ‘DbC onnect1’. The SQL Statement value is ‘Insert into TestReadWrite (Id, String1, Integer1,
Real1, DateTime1, DateTime2) values (@1, '@2', @3, @4, '@5', '@6')’. Within the Items repeating property editor, add 6 Expression values:
Expression
RowID
Entity.Name
Entity.ID
TimeNow
String.FromDateTime( Entity.TimeC reated, "yyyy/MM/dd HH:mm:ss")
String.FromDateTime( TimeNow, "yyyy/MM/dd HH:mm:ss")
Appendix:
Instructions to Install MySQL
Go to the link below to install MySQL
http://dev.mysql.com/downloads/installer/
Download ‘mysql-installer-community-5.6.11.0.msi’ version or higher and run the install.
On MySQL Installer window, select ‘Install MySQL Products’
On Find latest products tab, click Execute and then click Next.
On Setup Type tab, select Developer Default and click Next.
On C heck Requirements tab, click Execute and then Next.
On Installation tab, click Execute and then Next.
On C onfiguration tab, click Next. When prompted for MySQL Root Password, enter ‘root’ and click Next till you get out of C onfiguration tab.
On C omplete tab, click Finish.
Now go to the link below to install MySQL connector.
http://dev.mysql.com/downloads/connector/net/
Download ‘mysql-connector-net-6.6.5.msi’ version (you must use this version) and run the install. When prompted, choose the C omplete
install.
On Setup window, click Next.
C lick C hange, then click Next and again click C hange
C lick Finish.
Instructions to C reate table in MySQL
Open MySQL Workbench.
C lick on ‘Local instance MySQL56’ and enter password ‘root’.
Enter the code below to create a table ‘TestReadWrite'
USE world;
CREATE TABLE `testreadwrite` (
`Id` int(11) NOT NULL,
`String1` varchar(45) DEFAULT NULL,
`DateTime1` datetime DEFAULT NULL,
`Integer1` int(11) DEFAULT NULL,
`Real1` double DEFAULT NULL,
`DateTime2` datetime DEFAULT NULL,
PRIMARY KEY (`Id`)
)
C lick Execute
74 / 815
Simio Reference Guide
DefineEntityP roperties - SimBit
Problem:
I have multiple kinds of entities going through a working system. Each type of entity has its unique processing time and rejection rates.
Categories:
Entity C haracteristics
Key Concepts:
Expression Property, Numeric Property, Path, Selection Weight
Assumptions:
One Source produces only one type of entity. Reject rates are based on the ratio of the total number of entities that need to be reworked to the
total number of entities coming out of the server. (So there is a possibility that some entities will never reach the sink.)
Technical Approach:
Add processing time and rejection rates as properties to ModelEntity, so each type of entity can define its unique processing time and rejection
rates. The processing time of the Server is referencing the processing time property of ModelEntity, the weights of the paths represent rejection
and success based on the rejection rate property of ModelEntity.
Details for Building the Model:
Simple System Setup
Place two Sources, a Server and a Sink from the Standard Library into the Facility Window.
Use Path to connect two Sources’ output nodes to the input node of Server separately (Path1, Path2), connect the output node of the
Server to its input node (Path3), and also the Server’s output node to the Sink (Path4).
Add two ModelEntity objects from the Project Library into the Facility Window, name one of them PartA, the other one PartB.
Set Source1’s Entity Type to ‘PartA’, Source2’s Entity Type to ‘PartB’. Set the Interarrival Time of both of these two Sources to
‘Random.Exponential(.5)’.
Generating Entity Properties
Go to Navigation Window, click on the current project DefineEntityProperties, and then go to ModelEntity. Open the Definitions Window and
select the Properties panel.
C lick on Standard Property Ribbon, choose Real Data type, and create a Numeric Property. Name it ‘RejectRate’, its Display Name is
‘Reject Rate’, Description is ‘Ratio of rejections (0-1)’, and Default Value is ‘0.0’.
Again, go to Standard Property, choose Expression Data type, and create an Expression Property. Name it ‘ProcessingTime’, its Display
Name is ‘Processing Time’, and Default Value is ‘0.0’, Unit Type is ‘Time’, Default Units is ‘Minutes’.
In order to make those created properties to be used by customer more conveniently, we can save them to a separate category of
properties which we will call ‘C ustom’. For the property ‘RejectRate’, go to Properties Window, click on Category Name, and create a new
category with the name of ‘C ustom’, this will save ‘RejectRate’ to a new property category which is ‘C ustom’. Do the same thing for the
property ‘ProcessingTime’.
Using Entity Properties
Go back to Model Window and open the Facility Window. Go to Server1, set ProcessingTime to 'ModelEntity.ProcessingTime. This will let the
Server’s processing time use each Entity’s specific processing time according to their entity type.
C lick on Path3, which connects the output node of the Server to its input node. Then go to the Properties Window, right click on Selection
Weight and choose Set Referenced Property, and then choose Create New Referenced Property, and create a new referenced property
with the name ‘ModelEntity.RejectRate’. This will let entities be rejected and go through Server again based on their reject rates
corresponding to their entity types.
C lick on Path4, which connects the output node of the Server to the Sink, then set its Selection Weight to ‘1-ModelEntity.RejectRate’.
Specify Data on Each Entity Instance
For entity PartA and PartB, click on either one of them and go to Properties Window, there will be two properties we just defined: Reject
Rate and Processing Time.
Here we can specify reject rate and processing time on each instance of different types of entities. Set PartA’s Reject Rate to ‘0.1’,
Processing Time to ‘0.2’ (Minutes); set PartB’s Reject Rate to ‘0.5’, Processing Time to ‘0.1’ (Minutes).
75 / 815
Simio Reference Guide
DisableFailureT imers - SimBit
Problem:
I want my model to stop running when all entities have finished processing, but the failures in the system keep the simulation running.
Categories:
Add-On Process Logic, Arrival Logic
Key Concepts:
C alendar Time Based Failure, EventC ount, Failure, Maximum Arrivals, Server
Assumption:
Only one Source is generating entities and once the maximum arrivals have been created, the simulation should stop running.
Technical Approach:
When the number of entities that have been created at the Source reaches the maximum value of entities to be created, the Timer state for the
calendar time based failure associated with the server is disabled. This is done through an add-on process.
Details for Building the Model:
Simple System Setup
Place a Source, a Server and a Sink from the Standard Library into the Facility window. Use Paths to connect the Source to the Server and
the Server to the Sink.
Within the Source’s Advanced Options, change the Maximum Arrivals to ‘25’ so we can determine how long it takes to process 25 entities
through the sytem.
Server Failure
Within the Server, under the Reliability Logic section of properties, change the Failure Type to ‘C alendar Time Based’. C hange the Uptime
Between Failures to ‘10’ and the Units to ‘Minutes’. C hange the Time to Repair to ‘1’ and the Units to ‘Minutes’.
Turning Off Failures When Entities Stop
Within the Processes window, create a new process named Process1. Add a Decide step that will have the Decide Type as ‘C onditionBased’
and the Expression as ‘Source1.EntityArrivals.EventC ount == Source1.MaximumArrivals’. This will evaluate the entities exiting the source
with the maximum arrivals value to see if all of the entities have been created.
From the True exit of the Decide step, add an Assign step. Assign the State Variable Name ‘Server1.C alendarTimeBasedFailures.Enabled’
to the New Value of ‘0’. This means the failures are no longer enabled, but are disabled. This will ensure that no additional events continue
on the event calendar to keep the simulation running after the entities have all completed processing.
Within the Facility window, within the Source’s output node, change the Exited Add-On Process Trigger to ‘Process1’ so that when an entity
exits the node, this process is run.
Enhancements:
Within every Server, there are multiple types of failures that can be defined. In this example, we demonstrate turning off the C alendar Time
Based Failures. If you review the ‘MyServer’ object in the Navigation window, you will see in the Definitions window, Elements panel, there are
multiple Timer elements that are initially disabled. These are enabled if Failure Type corresponding to that Timer is used. Therefore, you can
disable any of these types of failures by simply using the corresponding Timer name.
76 / 815
Simio Reference Guide
DiscreteLookupT able - SimBit
Problem:
The entities in my model have different processing times depending on a priority that is assigned to the entities in the middle of the model. The
processing times and entity priorities are mapped in a table.
Categories:
Add-On Process Logic, Decision Logic – Processing, Lookup and Rate Tables
Key Concepts:
Lookup Table, Linear Interpolation, ModelEntity, Path, Priority, Selection Weight
Technical Approach:
The system has three servers in parallel, followed by one server in series. Depending on which server processes the entity, it is assigned a
different value to the state variable, ModelEntity.Priority. The fourth server uses this state variable and reads a Lookup Table to determine the
processing time.
Details for Building the Model:
Simple System Setup
Place a Source, Sink and 4 Servers in the Facility Window. The first three Servers are in parallel and they all lead to the fourth Server that
is in series.
The three paths leading from the Source to the first three Servers each have a different link Selection Weight of ‘.5’, ‘.3’ and ‘.2’. This
means that 50% (.5/(.5+.3+.2)) of the entities go to one server, 30% go to another and 20% to another.
C hanging the Entity Priority on Paths
Within the State Assignments properties of the paths leading to Server4 (from Server1, Server2 and Server3), enter the On Entering
repeating editor. Add a new assignment to specify the State Variable Name is ‘ModelEntity.Priority’, where the New Value is ‘ 1’ for those
departing Server 1 on path 4, ‘2’ for those from Server2 on path 5 and ‘3’ for those entities from Server3 on path 6.
Adding a Lookup Table
C lick on the Data tab and select the Lookup Tables panel. C lick the Lookup Table button to create a new table.
C hange the Name of the table in the Properties Window to ‘ProcessingTimes’.
Enter three rows of data in the table, mapping the numbers 1, 2, 3 to the values 3,5,6.
Utilizing a Table within a Server for Processing Times
In the Processing Time property of Server 4 in the Facility Window, use the following syntax to reference the table
‘ProcessingTimes[ModelEntity.Priority]’.
77 / 815
Simio Reference Guide
DynamicallyC reatingVehicles - SimBit
Problem:
I have a system where a transporter carries parts from machine to machine. When the system gets moderately busy and I have more than 4
parts in the system, I would like to bring in another vehicle to help with the work. Similarly, if the system becomes extremely busy and there are
more than 8 parts in the system, I would like to bring in a third vehicle.
Categories:
Vehicles
Key Concepts:
Add-On Process, C reate Step, Decide Step, Label, Monitor, On Associated Object Destroyed, On Entered, Process Triggering Event, Real State
Variable, Ride on Transporter, Sink, Source, Transfer Step, Vehicle
Assumptions:
A second vehicle is only created the first time the number of parts in the system goes above 4. And even if the number of parts becomes less
than 4, the second vehicle remains part of the model, it is not destroyed. There is similar logic for the creation of the third vehicle.
Technical Approach:
Two different monitor elements watch a Model State that keeps track of the number of parts in the system. The first monitor fires an event when
the number of parts in the system goes over 4. This event triggers a process that checks to see how many vehicles are currently in the system
and if there is only one, it creates a new vehicle object. Similarly, the second monitor fires an event when the number of parts in the system goes
over 8 and a third vehicle is created (if there are only 2 in the system at the time). The reason the process checks to see how many vehicles are
in the system before it creates a new one is because the monitor element will fire the event each time the State positively crosses the threshold
value (4 or 8). So there might be 5 parts in the system, but then it goes down to 4 and up again to 5. We do not want to create a new vehicle
every time it goes above 4, just the first time.
Details for Building the Model:
Simple System Setup
Add a Source, three Servers, a Vehicle and a Sink to the Facility Window.
C onnect the objects together with Paths. C reate two paths between each Server object, each one traveling in opposite directions. Our
example has a Bi Directional path between the input and output nodes of Server 3 so the transporter can travel around the object.
In our example, the Interarrival Time of the Source object is set to ‘Random.Exponential(.3)’ minutes and the Processing Time of Server1
is set to ‘Random.Triangular(.05, .06, .08)’ minutes.
The Vehicle’s Desired Speed is set to ‘0.5’ Meters per second and the Initial Node (Home) is set to ‘Output@Server1’.
Keeping Track of the Number in System
A new discrete model State is created, called ‘Number In System’. This is done by clicking on the Definitions tab, selecting the States panel
and adding a new state using the Discrete State button on the ribbon tab. This state is incremented with an Assign Step that is within a
process which is triggered by an Add On Process trigger in the Source object, called Created Entity. This process is triggered right after an
entity has been created by the Source.
The state Number in System is decremented with an Assign Step that is within a process which is triggered by an Add On Process trigger in
the Sink object, called Entered.
C reating the Monitor Elements
Go to the Definitions tab and select the Elements panel. C lick on the Monitor icon in the General Ribbon group. The Monitor Type is
‘C rossingStateC hange’ and the State Variable Name is ‘NumberinSystem’, or whatever name you gave to your model State variable. The
Threshold Value is ‘4’ and the C rossing Direction is ‘Positive’. This monitor will fire an event whenever the state variable crosses from 4 to
5.
Add a second Monitor element which is very similar to the first. The only difference with this monitor is that the Threshold Value is set to 8.
Processes that C reate the New Vehicle
Select the Processes tab in the Project Model tabs. C lick on the C reate Process icon in the Process Ribbon group.
In the Properties window of this new Process, set the Triggering Event to ‘Monitor_Over4.Event’ (exact name will depend on what you
named your monitor). This indicates that when that event is fired, it will trigger this process to execute.
Place a Decide step in the Process. The Decide Type is condition based and the Expression is set to ‘Vehicle1.Population.NumberInSystem
< 2’, which will ensure that we only create a new vehicle if there is only one in the system.
Place a C reate step in the True segment leaving the Decide step. The Create Type is ‘NewObject’ and the Object Instance Name is
‘Vehicle1’ (the name of your vehicle).
When a vehicle is created, it is created in Free Space. So it needs to be transferred to a node that is on the network. Place a Transfer step
on the C reated segment leaving the C reate step. From is set to ‘FreeSpace’, To is set to ‘Node’ and Node Name is set to ‘Output@Server1’.
A similar process should be created for the monitor that is watching for more than 8 parts in the system. The only difference in this
process is that the Expression in the Decide step is ‘Vehicle1.Popultion.NumberInSystem < 3’.
78 / 815
Simio Reference Guide
ElectricVehicle - SimBit
Problem:
I have an electric vehicle that it is used for the transportation of the entities in the system. The vehicle is sent to a charging station when the
battery level decreases to a certain threshold.
Categories:
Add-On Process Logic, Building New Objects / Hierarchy, C ustom Object, Vehicles
Key Concepts:
Assign Step, Bidirectional Path, C rossingStateC hange, Decide Step, Dynamic Label Text, Execute Step, Level State Variable, Monitor, Movement,
Movement.Rate, Off Shift, Override, Rate, Ride On Transporter, Subclass, Vehicle
Assumptions:
The electric vehicle battery consumption is directly related to the distance travelled, and it loses its charge at a rate of 1% per meter travelled.
When the Battery level reaches 20% remaining, the vehicle will finish unloading is current entity and travel to the charging station. The vehicle
charges at a rate of 5% per minute.
Technical Approach:
A Vehicle is subclassed from the Vehicle in the Standard Library and has additional process logic to track the battery level. A Monitor watches the
battery level and triggers a process to make the vehicle go off shift and send it to the charging station when the battery level is low. When the
Vehicle is done charging, the Vehicle goes back on shift and resumes transporting entities.
Details for Building the Model:
Simple System Setup
In the Facility Window place a Source, a Server and a Sink. Also place one BasicNode above the Server, and a second BasicNode,
renamed ‘C harger’, to the right of the first BasicNode.
Place a ModelEntity from the Project Library into the Facility window.
Using Paths to connect the Source to the Server and the Server to the Sink. C onnect BasicNode1 to the Source, the Server, the Sink, and
BasicNode ‘C harger’. Also connect the Server’s input node to Server’s output node. Select all the paths change the Type property to
‘Bidirectional’.
Within the Source, change the Interarrival Time property to ‘10’ minutes. Within the Server, change the Processing Time property to ‘5’
minutes.
C reating a Sub-C lassed Object MyVehicle
C reate a new vehicle called MyVehicle that is subclassed from Vehicle by right-clicking on Vehicle in the Standard Library and selecting
Subclass.
Select MyVehicle in the Navigation window and in its Definitions window, States panel, add a Level State Variable with Name
‘BatteryRemaining’ and change the Initial State Value property to ‘100’. This will track the current battery level, which will start with a full
battery.
In the Elements panel, add a Monitor element with the Name ‘MovementRateC hanged’ and change the State Variable Name property to
‘Movement.Rate’ and the Triggered Process Name property to ‘OnMovementRateC hanged’. Every time the Vehicle starts and stops, the
OnMovementRateC hanged process is triggered.
Add another Monitor element with the Name ‘MonitorBatteryRemaining’ and change the State Variable Name property to
‘BatteryRemaining’. C hange the Monitor Type property to ‘C rossingStateC hange’. Set the Initial Threshold Value property to ‘100’ and
change the Triggered Process Name to ‘FullC hargeDetected’. This will trigger the FullC hargeDetected process every time the
BatteryRemaining state increases to 100.
Within the Processes window of the MyVehicle object, click C reate Process to add a new process and change its Name to
‘StartC hargingBattery’.
Add a Decide step and change the Condition property to ‘HomeNode==C urrentNode’.
On the True branch leaving the Decide step, place an Assign step. Set the State Variable Name property to ‘BatteryRemaining.Rate’
and its New Value to ‘300’. When the Vehicle is at the C harger node, the battery level will increase at a rate of 300 per hour.
C reate a new process named ‘FullC hargeDetected’. This process is triggered when the BatteryRemaining variable reaches 100.
Add an Assign step and set the State Variable Name ‘BatteryRemaining.Rate’ to New Value of ‘0’.
Add another Assign step to the right of the previous Assign step, and set the State Variable Name to ‘C urrentC apacity’ and the New
Value to ‘1’. This will change the current state of the Vehicle to ‘Onshift’. Now that the vehicle is fully charged and on shift, it will
travel to the next entity waiting for transport.
C reate a third process named ‘OnMovementRateC hanged’.
Add an Assign step, and change the State Variable Name property to ‘BatteryRemaining.Rate’ and the New Value to ‘-
Movement.Rate’. The will decrease the battery level at the same rate the vehicle is travelling.
Add an Execute step for the Process Name of ‘StartC hargingBattery’.
Right click the process “OnRiderUnloaded” and select Override to allow the process to be modified.
On the right side of the Fire step, add a Decide step and change the Condition property to 'BatteryRemaining < 20 &&
RideStation.C ontents == 0'.
On the True branch leaving the Decide step, place an Assign step. Set the State Variable Name to ‘C urrentC apacity’ and the New
Value to ‘0’. This will change the current state of the Vehicle to ‘Offshift’ if the BatteryRemaining is below 20 and there are no
entities left on the Vehicle. The Vehicle is set to go to its Home Node (C harger) when it goes off shift.
Vehicle Setup
Place a MyVehicle object from the Project Library to the Facility window and change the Name to ‘ElectricVehicle’.
Expand the Animation property and set the Dynamic Label Text property to ‘Math.Round(MyVehicle.BatteryRemaining, 1)’. That will show a
label next to MyVehicle object with the current BatteryRemaining state value.
C hange the Initial Desired Speed property to ‘0.5’ Meters per Second.
Under Routing Logic, change the Initial Node (Home) property to ‘C harger’. Also change the Idle Action property to ‘Remain to Place’ and
the Off Shift Action property to ‘Park At Home’.
79 / 815
the Off Shift Action property to ‘Park At Home’.
Transferring the Entity
Within the Source output node, specify the Entity Destination Type of ‘Specific’ and the Node Name of ‘Input@Server1’. C hange the Ride on
Transporter to ‘True’ and the Transporter Name to ‘ElectricVehicle’.
Within the Server output node, specify the Entity Destination Type of ‘Specific’ and the Node Name of ‘Input@Sink1’. C hange the Ride on
Transporter to ‘True’ and the Transporter Name to ‘ElectricVehicle’.
These previous steps tell the entity where to go next and on what vehicle (otherwise, it may leave the node on any of the connected
bidirectional paths).
Animation
C hange the color of the top of the Entity object in order to identify it when it is being transported by the vehicle.
C hange the symbol of the BasicNode C harger to identify where the charger is.
80 / 815
Simio Reference Guide
EntitiesEnteringAlongC onveyor - SimBit
Problem:
I have multiple types of entities that enter onto a single conveyor from multiple merge points. Entities then travel down the single conveyor for
later processing.
Categories:
C onveyor Systems
Key Concepts:
BasicNode, C onveyor
Assumptions:
There are three types of entities that enter the system. Each entity type has a unique entry area onto which it will later merge onto a single
conveyor system. When arriving at its merge point, the entity must wait for adequate space on the conveyor before merging. At any merge point,
entities enter based on a first in first out basis.
Technical Approach:
Use three Source objects to model the arriving entity types. Use three BasicNodes to model the merge points on the main conveyor system.
Finally, use C onveyor objects to model the entry conveyors for each part type from the respective sources to the merge points, as well as for the
main conveyor system.
Details for Building the Model:
Simple System Setup
Place three Source objects and a Sink in the Facility Window.
Place three BasicNodes into the Facility Window. These nodes will represent the merge points from each individual part type entering onto
the main conveyor.
Defining the C onveyor System
C onnect each Source object to a BasicNode using the C onveyor object.
Then, starting at the leftmost BasicNode, connect it to the next BasicNode, and then again to the next with a C onveyor. C onnect the
rightmost BasicNode to the Sink object. This will represent the entities leaving the conveyor system.
Specifying C onveyor C haracteristics
For each of the six (6) conveyor objects, the default C onveyor characteristics will be used. This includes the Conveyor Speed of ‘2, as well
as the Accumulating property of ‘True’. We would like all of our conveyors to be accumulating, therefore if a given merge point is blocked,
entities will begin to accumulate on their respective entering conveyor.
Defining Multiple Entity Types
Place three ModelEntity objects from the Project Library and change the Name them ‘PartA’, ‘PartB’ and ‘PartC ’.
C hange the entity symbols, so that you can graphically see the difference in the parts on the conveyors. We used the Simio symbol library
to select various “box” symbols for each of the entity types.
Within the three Source objects, specify the Entity Type as ‘PartA’, ‘PartB’ and ‘PartC ’. Therefore, each source will generate a different part
type.
C hanging the C onveyor Animation
In order to graphically make the conveyor paths look like conveyors, click on the conveyor path and select one of the path decorators
from the Path Decorators ribbon (i.e., conveyor, single lane, track, etc.).
81 / 815
Simio Reference Guide
EntityFollowsSequence - SimBit
Problem:
I have an entity that needs to be processed in a particular order by a series of machines.
Categories:
Decision Logic – Paths, Sequence Tables
Key Concepts:
By Sequence, Entity Destination Type, ModelEntity, Sequence Table, Table Transfer Node Property
Assumptions:
The source only produces one type of entity. This entity will follow the Sequence: Server 3 - Server 2 - Server 1 – Sink 1.
Technical Approach:
A Sequence Table is created and the entity is set to follow this Sequence in its Routing Logic. Each Output TransferNode is set to pass the entity to
its next destination By Sequence.
Details for Building the Model:
Simple System Setup
Add a Source, Sink and three Servers to the Facility Window. Update the Processing Time of each Server to be ‘Random.Triangular(0.5,
0.8, 1.2)’.
Adding a Sequence Table
In the Data Window, select the Tables panel and add a Sequence Table with Name ‘MySequence’. Add the Destinations in the following
order: Input@Server3 -> Input@Server2 -> Input@Server1 -> Input@Sink1.
Assigning the Sequence to the Entity
In the Facility Window, place an entity from the Project Library into the model.
C hange the Routing Logic Initial Sequence property of the DefaultEntity to ‘MySequence’.
Modifying the TransferNodes
For each of the objects in the system, including Source and all three Servers, click on the TransferNode, change the Entity Destination
Type property (under Routing Logic) to ‘By Sequence’.
Double-click on the Path to connect the Source object to all three Servers, and then connect all the Servers to each other and to the Sink
object.
Embellishments:
There are many ways to make this model more specific. Try changing the Default entity’s Travel Logic to a desired speed or the Source’s
Interarrival Time rate.
82 / 815
Simio Reference Guide
EntityFollowsSequenceMultiple - SimBit
Problem:
*Enhancement of EntityFollowsSequence.spf*
I have multiple sources; each producing their own specific entity type. Each entity type needs to be processed in a particular order by a series of
machines.
Categories:
Decision Logic – Paths, Sequence Tables
Key Concepts:
By Sequence, Entity Destination Type, ModelEntity, Sequence Table, Table Transfer Node Property, TransferNode
Assumptions:
Each source only produces one type of entity.
• Source 1 produces Part A (Green) which follows the Sequence: Server 1 – Server 2 – Sink 1.
• Source 2 produces Part B (Red) which follows the Sequence: Server 3 – Server 2 – Server 1 – Sink 1.
• Source 3 produces Part C (Blue) which follows the Sequence: Server 2 – Sink 1.
Technical Approach:
A Sequence Table is created for each entity type and each entity is set to follow this Sequence in its Routing Logic. Each output TransferNode,
except those at Source 2 and Source 3, is set to pass the entity to its next destination ‘By Sequence’. The output TransferNodes at Source 2 and
Source 3 have been excluded because an entity will travel from these nodes to the TransferNode at Source 1, which already has ‘By Sequence’ in
its Routing Logic.
Details for Building the Model:
Simple System Setup
Add three Sources, three Servers and a Sink to the Facility Window. Update the Processing Time of each Server to be
‘Random.Triangular(0.5, 0.8, 1.2)’.
Adding a Sequence Table
In the Data Window, select the Tables panel and add three Sequence Tables named ‘SequenceA’, ‘SequenceB’ and ‘SequenceC ’. Set the
Destinations in each table in the following orders:
SequenceA : Input@Server1 -> Input@Server2 -> Input@Sink1
SequenceB : Input@Server3 -> Input@Server2 -> Input@Server1 -> Input@Sink1
SequenceC : Input@Server2 -> Input@Sink1
Assigning the Sequences to the Entities
Place three DefaultEntity objects from the Project Library into the Facility Window. C hange the Name of each to ‘PartA’, ‘PartB’ and ‘PartC ’.
C hange the Routing Logic Initial Sequence property of each PartA, PartB, and PartC to ‘SequenceA’, ‘SequenceB’, and ‘SequenceC ’,
respectively.
Modifying the TransferNodes
For each output TransferNode, except those at Source2 and Source3, change the Entity Destination Type property to ‘By Sequence’.
Entities created at Source2 and Source3 will connect through the output TransferNode at Source1.
Double-click on the Path to connect the Source1 object to all three Servers, and then connect all the Servers to each other and to the Sink
object.
Embellishments:
There are many ways to make this model more specific. Try changing any entity’s Travel Logic Speed Limit to a desired speed or the Source’s
Interarrival Time rate.
83 / 815
Simio Reference Guide
EntityFollowsSequenceW ithT able - SimBit
Problem:
*Enhancement of EntityFollowsSequenceMultiple.spf*
I have a single source producing multiple types of entities. Each entity type needs to be processed in a particular order by a series of machines.
The service times at each server are dependent upon the entity type.
Categories:
Data Tables, Decision Logic – Paths, Decision Logic – Processing, Sequence Tables
Key Concepts:
Before C reating Entities, By Sequence, Data Table, Dynamic Object Property, Entity Destination Type, Expression Property, ModelEntity, Numeric
Property, On C reated Entity, RandomRow, Sequence Table, Server, Source, Table Reference Assignments, Table Sequence Property, Table
Transfer Node Property
Assumptions:
The Source produces three types of entities:
• Part A (Green) which follows the Sequence: Server 1 – Server 2 – Server 3 – Sink 1.
• Part B (Red) which follows the Sequence: Server 3 – Server 2 – Server 1 – Sink 1.
• Part C (Blue) which follows the Sequence: Server 2 – Sink 1.
Technical Approach:
A separate Sequence Table is created for each entity type to keep track of the Sequences and Process Times for each entity type. A Data Table is
created to help the Servers determine how long to process an entity based on its type. The Data Table will be read by setting the Table Name
property of the Source. The Source will also reference the Data Table after an entity has been created to get reference to the appropriate
Sequence Table based on the assigned row from the Job Table. Each TransferNode is set to pass the entity to its next destination ‘By Sequence’.
Details for Building the Model:
Simple System Setup
Add a Source, a Sink and three servers to the Facility Window. Also, place three ModelEntity objects from the Project Library into the
window.
Setting up the Sequence Tables
In the Data Window, select the Tables panel and add three Sequence Tables named ‘SequenceA’, ‘SequenceB’, and ‘SequenceC ’. For the
order of Destinations in each table, please refer to EntityFollowsSequenceMultiple.
Add an Expression Property to each Sequence Table with the Name ‘ProcessTime’. Set the ProcessTime according to the following:
SequenceA: Input@Server1 = Random.Uniform(0.5, 0.9), Input@Server2 = Random.Triangular(0.5, 1.1, 1.2), Input@Sink1 = 0.0
SequenceB: Input@Server3 = Random.Triangular(0.5, 0.8, 1.2), Input@Server2 = 1.5, Input@Server1 = 1, Input@Sink1 = 0.0
SequenceC : Input@Server2 = Random.Triangular(0.5, 1.2, 1.6), Input@Sink1 = 0.0
Setting up the Data Table
• Add a Data Table named ‘JobTable’ with the following Properties and in the following order:
(Entity Object Reference) PartType : PartA, PartB, PartC
(Expression) ProcessTime : SequenceA.ProcessTime, SequenceB.ProcessTime, SequenceC .ProcessTime
(Integer) ProductMix : 10, 20, 30
(Sequence) PartSequence : SequenceA, SequenceB, SequenceC
C reating Multiple Entity Types from Source:
In the Facility Window, expand the Table Reference Assignments in the Properties Window of the Source object.
Under the Before Creating Entities subcategory, set the Table Name to ‘JobTable’ and the Row Number to ‘JobTable.ProductMix.RandomRow
’
Under the On Created Entity subcategory, set the Table Name to ‘JobTable.PartSequence’ and leave the Row Number empty.
Finalizing the Model
C hange the Arrival Logic Entity Type property of the Source to ‘JobTable.PartType’.
C hange all Processing Times of the Servers to ‘JobTable.ProcessTime’.
For each TransferNode, change the Entity Destination Type property to ‘By Sequence’.
Embellishments:
There are many ways to make this model more specific. Try changing any entity’s Travel Logic Speed Limit to a desired speed, the Source’s
Interarrival Time rate, or any Server’s Capacity.
See Also:
EntityFollowsSequenceMultiple.spf
84 / 815
Simio Reference Guide
EntityFollowsSequenceW ithT able2 - SimBit
Problem:
*Enhancement of EntityFollowsSequenceMultiple.spf*
I have a single source producing multiple types of entities. Each entity type needs to be processed in a particular order by a series of machines.
The service times at each server are dependent upon the entity type.
Categories:
Data Tables
Key Concepts:
Before C reating Entities, By Sequence, Data Table, Dynamic Object Property, Entity Destination Type, Expression Property, ModelEntity, Numeric
Property, RandomRow, Relational Table, Sequence Table, Server, Source, String Property, Table Foreign Key Property, Table Key, Table Reference
Assignments, Table Transfer Node Property
Assumptions:
The Source produces three types of entities:
Part A (Green) which follows the Sequence: Server 1 – Server 2 – Server 3 – Sink 1.
Part B (Red) which follows the Sequence: Server 3 – Server 2 – Server 1 – Sink 1.
Part C (Blue) which follows the Sequence: Server 2 – Sink 1.
Technical Approach:
A single Sequence Table is created to keep track of the Sequences and Process Times for each entity type. A Data Table is created to specify
product mix and point to the proper section of the Sequences table using the Foreign Keys feature. The Table Assignment properties of the
Source will be used to select a random entity type from the Data Table while the entity is being created. Each TransferNode is set to pass the
entity to its next destination ‘By Sequence’.
Details for Building the Model:
Simple System Setup
Add a Source, a Sink and three servers to the Facility Window. Also, place three ModelEntity objects from the Project Library into the
window.
Setting up the Data Table
Go to the Data tab, select the Tables panel and add a Data Table named ‘JobTable’ with the following Properties and in the following order:
(Entity Object Reference) PartType : PartA, PartB, PartC
(Integer) ProductMix : 10, 20, 30
(String) SequenceType : A,B,C
When the SequenceType column is selected, make this the primary key of this table by clicking the “Set C olumn as Key” icon in the
Ribbon.
Setting up the Sequence Tables
Also the Data Window within the Tables panel, add a Sequence Table named ‘Sequences’. For the order of Destinations in each table,
please refer to EntityFollowsSequenceMultiple.pdf.
Add a Foreign Key property to this Sequence Table by clicking on the Foreign Key icon in the Ribbon. The Name of this property should be
set to 'SequenceType'. The TableKey property should be set to 'JobTable.SequenceType'.
Add an Expression Property to the Sequence Table with the Name set to ‘ProcessTime’. Set the ProcessTime according to the following:
SequenceA: Input@Server1 = Random.Uniform(0.5, 0.9), Input@Server2 = Random.Triangular(0.5, 1.1, 1.2), Input@Sink1 = 0.0
SequenceB: Input@Server3 = Random.Triangular(0.5, 0.8, 1.2), Input@Server2 = 1.5, Input@Server1 = 1, Input@Sink1 = 0.0
SequenceC : Input@Server2 = Random.Triangular(0.5, 1.2, 1.6), Input@Sink1 = 0.0
C reating Multiple Entities from Single Source:
In the Facility Window, Source object, expand the Table Reference Assignment section.
Set the Table Name property to ‘JobTable’, and the Row Number to ‘JobTable.ProductMix.RandomRow’.
Finalizing the Model
C hange the Arrival Logic Entity Type property of the Source to ‘JobTable.PartType’.
C hange all Processing Times of the Servers to 'Sequences.ProcessTime’.
For each TransferNode, change the Entity Destination Type property to ‘By Sequence’.
Embellishments:
There are many ways to make this model more specific. Try changing any entity’s Travel Logic Speed Limit to a desired speed, the Source’s
Interarrival Time rate, or any Server’s Capacity.
See Also:
EntityFollowsSequenceMultiple.spf, EntityFollowsSequenceWithTable.spf (Uses simple (not relational) table to accomplish the same thing) and
UsingRelationalTables.spf
85 / 815
Simio Reference Guide
EntityStopsO nLink - Simbit
Problem:
I have a system where the entities in the system must stop moving on their links when a particular event occurs.
Categories:
Decision Logic -- Paths
Key Concepts:
Add-On Process, Allow Passing, C alendar Time Based Failure, C urrent Symbol Index, C urrent Symbol Index, Event, Failure, Failure.Active, Fire
Step, ModelEntity, On Failed, On Repaired, ParentObjectMovement, Path, Real State Variable, Resume Step, Server, Subscribe Step, Suspend
Step, Time To Repair, Uptime Between Failures, Wait Step
Assumptions:
Entities that are currently moving on links will stop mid-stream when a particular event occurs. In this example, that event is a server failure.
Once the failure has been fixed, all entities resume their movement.
Technical Approach:
The Subscribe step for the Model Entity is used to tie together the events of the model, such as failure and repair of the Server, with events for
the entity itself, such as suspending and resuming movement on a link. Two properties for the entity are used to define the event names. When
those events occur in the model, all currently moving entities have their movement stopped or started.
Details for Building the Model:
Simple System Setup
Add a Source, Sink and Server to the Facility Window. Add a ModelEntity to the Facility Window. C onnect the Source to the Server and the
Server to the Sink using Paths. C hange the Allow Passing property of each Path to ‘False’.
Adding the Server Failure
In the Reliability Logic section of the Properties window for Server1, add a failure by changing the Failure Type to ‘C alendar Time Based’.
Set the Uptime Between Failures property to ‘2’ and Units to ‘Minutes’, and the Time to Repair property to ‘1’ and Units to ‘Minutes’.
Displaying the Server Failure
When Server1 is highlighted, click on Add Additional Symbol on the Symbols tab, then click on the C olor item to change the color of the
second symbol to red.
In the Animation section of Server1 properties, change the Current Symbol Index to the expression ‘Server1.Failure.Active’. These two
changes will cause the Server1 symbol to change to red whenever the server fails.
Model Entity: Suspending and Resuming the Entity Movement
In the Definitions Window of the Model Entity, add two new properties, ‘SuspendMyselfEvent’ and ‘ResumeMyselfEvent’. These two
properties will then be edited in the Model Entity’s properties window to tie the events in the model to the model entity.
In the Processes Window of the Model Entity, use the C reate Process button to create two new processes called SuspendMyself and
ResumeMyself. We will add steps to these processes shortly.
Also in the Processes Window of the Model Entity, use the Select Process button to select the OnC reated process. Within that process, add
two Subscribe steps. In the first Suspend step, right click on Event Name and Set Referenced Property to ‘SuspendMyselfEvent’. Set the
Process Name to ‘SuspendMyself’. In the second Suspend step, right click on Event Name and Set Referenced Property to
‘ResumeMyselfEvent’. Set the Process Name to ‘ResumeMyself’.
Within the SuspendMyself process, add a Suspend step and change the Suspend Type to ‘ParentObjectMovement’. This will stop the
movement of all entities currently created when this process is triggered.
Within the ResumeMyself process, add a Resume step and change the Resume Type to ‘ParentObjectMovement’. This will resume all entity
movement of all entities when this process is triggered.
Model: Firing the Events to Stop Entity Movement
Go to the Model and open the Processes window. Add two new processes called SuspendAll and ResumeAll. These processes will be
triggered when the Server fails and is repaired.
In the Definitions window, add two new events, ‘SuspendEverybody’ and ‘ResumeEverybody’. These events will be fired from the
Processes just defined.
In the Processes window of the model, within the SuspendAll process, add a Fire step with the Event Name ‘SuspendEverybody’. Within the
ResumeAll process, add a Fire step with the Event Name ‘Resume Everybody’.
Move to the Facility window and highlight Server1. Within the Add-On Process Triggers, change the Failed property to ‘SuspendAll’ and the
Repaired property to ‘ResumeAll’. This will fire the events to suspend and resume entities when the Server is failed and repaired,
respectively.
Model: Specifying the Model Entity Properties for the Events
C lick on ModelEntity1 that is placed in the Model. In the General section of properties, you will notice the two new properties we added
above called SuspendMyselfEvent and ResumeMyselfEvent. These are also referenced in the Subscribe steps for the ModelEntity.
C hange the SuspendMyselfEvent property to ‘SuspendEverybody’ and the ResumeMyselfEvent property to ‘ResumeEverybody’. These will
then feed into the Subscribe steps such that when those events are fired within the model, the associated processes in the ModelEntity will
be triggered.
Model: Stopping Incoming Entities
All of the above steps will stop entities that have been created and are moving in the system. To also stop incoming entities (as the Source
will continue to generate entities), the following steps can be followed.
In the model’s Definitions window, States panel, add a new Discrete State with Name of ‘MovementSuspended’. The Initial State Value
property should remain as ‘0’. This state will be evaluated when incoming entities enter the system to determine if movement is suspended
or not.
Within the Facility window, highlight the transfer node of Source1 and add an Add-On Process Trigger to the Entered property by double-
clicking on Entered. This will create a new process called ‘Output_Source1_Entered’.
86 / 815
Within the Process window, you will see the new process called ‘Output_Source1_Entered. Within this, add a Decide step where the Decide
Type is ‘C onditionBased’ and the Expression is ‘MovementSuspended==1’. From the True exit, add a Wait step, to wait for the Event Name
‘ResumeEverybody’. From the False exit, there will be no steps.
Finally, within the SuspendAll process (in this Processes window), add an Assign step (after the Fire step) where you assign the State
Variable Name ‘MovementSuspended’ to the New Value of ‘1’. And similarly, in the ResumeAll process (in this Processes window), add an
Assign step (after the Fire step) where you reset the State Variable Name ‘MovementSuspended’ to the New Value of ‘0’.
Embellishments:
Entities may be suspended and resumed based on any number of happenings in a model, including time and/or a state variable reaching a given
value. You may also cause an event to occur by placing a Button in the Facility window and/or C onsole window.
87 / 815
Simio Reference Guide
ExamplesO fC onveyors - SimBit
Problem:
I would like to understand how various conveyor configurations behave.
Categories:
C onveyor Systems
Key Concepts:
Accumulating, Auto Align C ells , BasicNode, BasicNode, C alendar Time Based Failure, C ell Location, C onveyor, C ross Logic, Entity Alignment,
Failure, Fixed Number C ells , Initial C apacity, Largest Value First, Number of C ells, On Event Arrival Mode, Time To Repair, Uptime Between
Failures
Technical Approach:
A “Master Source” creates the Entity arrivals for all other sources. This allows all sets of conveyors to depict their behavior on the exact same
arrivals. The sets of conveyors are then used to depict transfers between different conveyor configurations.
Details for Building the Model:
Standard – all defaults left untouched.
Simply entities traveling on our standard conveyor
Accumulating – all defaults left untouched.
Entities will form a queue on the first conveyor if Processing Station is not completely clear. A new entity will not be able to enter the
Processing Station until the occupying entity’s trailing edge has entered the exit conveyor.
Non-Accumulating – The entry conveyor has Accumulating set to ‘False’.
If an Entity cannot immediately gain access to the Server, the entire conveyor will temporarily stop movement. When the Entity in the
Processing Station completely exits the Server, the next Entity will enter and the conveyor will begin moving again.
C hanging Speeds from Fast to Slow – The second conveyor’s Desired Speed has been set to ‘0.5 m/s’.
The first entity will enter the second conveyor and begin moving at the speed of the slower conveyor. If Entities are created with a small
enough interarrival time, the second entity will collide with the first entity and move on the first conveyor at the speed of the second
conveyor.
C hanging Speeds with a Non-Accumulating C onveyor – The first conveyor has Accumulating set to ‘False’ and the second conveyor’s Desired
Speed has been set to ‘0.5 m/s’.
The first entity will enter the second conveyor and begin moving at the speed of the slower conveyor. If Entities are created with a small
enough interarrival time, the second entity will collide with the first entity and the speed of the faster conveyor will be set to the speed of
the slower conveyor. All other entities entering the faster conveyor will move at the speed of the slower conveyor until all queued entities
have completely left the first conveyor.
C hanging Speeds From Faster C ell Aligned to Slower C ell Aligned – Each conveyor has Entity Alignment set to ‘C ell Location’, Cell Spacing Type is
set to ‘Fixed Number C ells', Number of Cells is set to ‘8’ and Auto Align Cells is set to ‘No’
Entities travel down the cell aligned conveyor on a chain dog. When the entity gets to the next cell aligned conveyor, it has to wait until a
chain dog from that conveyor comes by to pick it up. Because the second conveyor is slower, this will cause entities to form a queue on
the first conveyor and the entities will disengage from their chain dogs. Once a chain dog from the second conveyor picks up a waiting
entity, the other waiting entities will step along the first conveyor, starting with the entity farthest along the conveyor, as chain dogs
become available.
C hanging Speeds From Slower C ell Aligned to Faster C ell Aligned – Each conveyor has Entity Alignment set to ‘C ell Location’, Cell Spacing Type is
set to ‘Fixed Number C ells', Number of Cells is set to ‘8’ and Auto Align Cells is set to ‘No’
Entities travel down the cell aligned conveyor on a chain dog. When the entity gets to the next cell aligned conveyor, it has to wait until a
chain dog from that conveyor comes by to pick it up. Because the second conveyor is faster, there will never be any queuing because a
chain dog will always arrive to pick up a waiting entity before the next entity arrives at the end of the link.
Faster C ell Aligned Non-Accumulating to a Slower C ell Aligned – Each conveyor has Entity Alignment set to ‘C ell Location’, C ell Spacing Type is set
to ‘Fixed Number C ells, Number of C ells is set to ‘8’ and Auto Align Cells is set to ‘No’, and the first conveyor has Accumulating set to ‘False’
Entities travel down the cell aligned conveyor on a chain dog. When the entity gets to the next cell aligned conveyor, it has to wait until a
chain dog comes by to pick it up and disengages itself from the first conveyor. If a second entity reaches the end of the conveyor before
the first is picked up, it will stop the movement of the entire conveyor. When the waiting entity enters the slower conveyor, the entire first
conveyor moves at the slower rate. After the entity is completely off of the first conveyor it will run at full speed.
Moving Onto Failing C ell Aligned from C ell Aligned – Each conveyor has Entity Alignment set to ‘C ell Location’, Cell Spacing Type is set to ‘Fixed
Number C ells', Number of Cells is set to ‘8’ and Auto Align Cells is set to ‘No’. The second conveyor has C alendar Time Based with an Uptime
Between Failures of ‘0.1 minutes’ and a Time To Repair of ‘0.1 minutes’
This situation is similar to moving onto a slower cell aligned conveyor. Entities will form a queue and after the first entity completely exits
the first conveyor, the waiting entities will step forward when chain dogs become available.
Merging C onveyors With Different Speeds – The two merging conveyors have their Desired Speeds set to ‘3 m/s’ and ‘4 m/s’, and they are
merging onto a conveyor moving at 2 m/s.
If there is a queue at the merge point, entities will take turns merging based on a FIFO Entry Ranking Rule.
Merging C ell Aligned C onveyors With Different Speeds – Same setup as above but Each conveyor has Entity Alignment set to ‘C ell Location’, Cell
Spacing Type is set to ‘Fixed Number C ells', Number of Cells is set to ‘8’ and Auto Align Cells is set to ‘No’
Entities will merge based on a FIFO Entry ranking rule, but when it is an entities turn to merge, it must first wait for an available chain dog.
Similar to other accumulating cell aligned conveyors, the remaining waiting entities will step their way to the end of the conveyor when
chain dogs become available.
Problem:
I would like to understand some of the functions available to use with dynamic objects (entities, transporters, etc).
Categories:
Functions
Key Concepts:
C apacity.Allocated, C urrentLink, DestinationNode, Distance, Dynamic Object, Floating Label, FrontTraffic, Function, ID, IsRiding, Location.X,
Math.Round(), NumberC reated, NumberDestroyed, NumberInSystem, Ride on Transporter, RideStation.C apacity.Remaining, C urrentTransporter,
Round, SlipSpeed, TransferNode, Vehicle
Assumptions:
The functions shown in this model are not the entire list of available functions. To see all the available functions and to get additional information
on all functions, see the Functions page.
Status Labels are used to display the expressions for the population functions. Status Labels are added to the Facility window from the Animation
Ribbon. Floating Labels are used to label these functions. Floor Labels are used to display the titles of each section. Rectangles and Polylines were
also used to create the displays in this model. Floating Labels, Floor labels, Rectangles and Polylines are all added to the Facility window from the
Drawing Ribbon. The functions that are attached to the entity and the Transporter are attached Floor Labels that contain both text and
expressions.
Technical Approach:
The attached Floor Labels were added to this model by first placing a Vehicle (from the standard library) into the Facility window. Also place a
ModelEntity (from the project library) into the Facility window.
C lick on each object and select Floor Label from the Attached Animation category in the Ribbon. Draw an attached Floor Label and then click on
the Edit button in the Ribbon to edit the text. Text is typed into the Label Text window directly. An expression can be entered into this label by
surrounding it with curved brackets { }. Because the expressions are attached to the object, the object qualifier does not need to be part of the
expression. For example, to display Vehicle1.C apacity.Allocated in a label that is attached to Vehicle1, the expression should read
{C apacity.Allocated}.
Details for Building the Model:
Examples of Functions Available for a Dynamic Object
Vehicle1.Capacity.Allocated – Returns the current number of capacity units of Vehicle1 that have been allocated (have been seized)
Note: These are resource capacity units, not ride capacity units.
Vehicle1.CurrentLink – If Vehicle1’s leading edge is currently on or at the end of a link, this function returns a reference to the link.
Vehicle1.DestinationNode – Returns a reference to the Vehicle1’s current destination node or returns ‘Nothing’ if it does not have a
destination assigned.
Vehicle1.ID – Returns the unique ID number of Vehicle1.
Vehicle1.RideStation.Capacity.Remaining – Returns the current available carrying capacity of this transporter.
Vehicle1.SlipSpeed – If the entity (or vehicle) is currently on a link, then this function returns the minimum of the link’s current speed or
the speed of the next entity immediately ahead on the same link. If there is no traffic ahead on the link, then this function simply returns
the link’s current speed.
DefaultEntity.ID – Returns the unique ID number of this entity.
DefaultEntity.DestinationNode – Returns a reference to the entity’s current destination node or returns ‘Nothing’ if it does not have a
destination assigned
DefaultEntity.FrontTraffic.Distance – If the entity object is currently on a link, then this function returns the distance from the entity’s
leading edge to the trailing edge of the next entity immediately ahead on the same link. If there is no traffic ahead on the link, then this
function returns the distance from the entity’s leading edge to the end of the link. Note: The FrontTraffic function can be used alone and it
will return True (or 1) if there is an entity ahead of it on the link. In addition to the Distance function, there is also a FrontTraffic.ID function
that will return the ID of any front traffic and FrontTraffic.Speed that will return the current speed of an entity that is traveling ahead on the
link. See Functions, States and Events for Link Objects for more information.
DefaultEntity.IsRiding – Returns ‘True’ (or ‘1) if the entity is currently riding on a Transporter.
DefaultEntity.CurrentTransporter – If the entity object is currently riding on a transporter, then this function returns a reference to
that transporter.
DefaultEntity.Location.X – Returns the X coordinate of the object’s current location. Therefore, this changes as the entity moves along
the link. Location.X and Location.Y are also available.
Examples of Functions Available a Population of Dynamic Objects
DefaultEntity.Population.NumberInSystem – Returns the current number of objects of this object’s type that are currently in the
system.
DefaultEntity.Population.NumberCreated – Returns the total number of objects of this object’s type that have been created.
DefaultEntity.Population.NumberDestroyed – Returns the total number of objects of this object’s type that have been destroyed.
See Also:
The SimBit titled ExamplesOfFunctions_StaticObjects for examples of functions that are available for static objects.
90 / 815
Simio Reference Guide
ExamplesO fFunctions_StaticO bjects - SimBit
Problem:
I would like to understand some of the functions available to use with static objects.
Categories:
Functions
Key Concepts:
AssociatedStationLoad, Average, AverageTimeWaiting, C apacity.Allocated, C apacity.Remaining, C ontents, C urrentDirection, EventC ount,
InputBuffer, LastRecordedValue, Load, Location.X, NumberEntered, NumberOccurences(), NumberTravelers, NumberWaiting, OutputBuffer, Path,
PercentTime(), Processing, ResourceState, Server, Sink, TimeInSystem, TimeOnLink, TotalTime()
Assumptions:
The functions shown in this model are not the entire list of available functions. To see all the available functions and to get additional information
on all functions, see the Functions page.
Status Labels are used to display the expressions. Status Labels are added to the Facility window from the Animation Ribbon. Floating Labels are
used to label the functions. Floor Labels are used to display the titles of each section. Rectangles and Polylines were also used to create the
displays in this model. Floating Labels, Floor labels, Rectangles and Polylines are all added to the Facility window from the Drawing Ribbon.
Details for Building the Model:
Examples of Functions Available for a Source
Source1.Location.X – Returns the X coordinate of the Source’s current location. The location function is available for all static and
dynamic objects. Other options available are Location.Y and Location.Z
Source1.EntityArrivals.EventCount - Returns the number of events that have been fired by the Timer since its last reset. The
EventC ount function is available with any Timer element.
Source1.OutputBuffer.Contents – Returns the number of entities currently in the OutputBuffer station. There are other functions
available to use with the C ontents queue, such as AverageNumberWaiting and MaximumTimeWaiting. See the Functions page for
information on Queue State functions.
Examples of Functions Available for a Path
Path1.CurrentDirection – Returns the current direction of traffic on this link. The value returned is Enum.TrafficDirection.Forward,
Enum.TrafficDirection.Reverse or Enum.TrafficDirection.None. (1, 2 or 3). This function is available for all Link objects.
Path1.TimeOnLink.Average – Returns the average time the traveler was on this link. Maximum and Minimum are also available.
Path1.NumberTravelers – Returns the current number of travelers on this link. There are other functions available to use with this
function: NumberTravelers.Accumulated, NumberTravelers.Average, NumberTravelers.Minimum, NumberTravelers.Maximum,
NumberTravelers.Entered, NumberTravelers.Exited. See Functions, States and Events for Link Objects Help page for additional information
on these functions.
Examples of Functions Available for a Sink
Sink1.InputBuffer.NumberEntered – Returns the total number of entity objects that have entered this station. NumberExited is also
available.
Sink1.TimeInSystem.Average – Returns the average of the observations recorded. In this example, this is the average time in system
of the entity objects that enter into this Sink object. TimeInSystem is a TallyStatistic element and Average is a function available to all
TallyStatistic elements. Other functions available for TallyStatistics are NumberObservations, HalfWidth, LastRecordedValue, Maximum and
Minimum. The value is multiplied by 60 to convert from hours to minutes and is rounded to 1 significant digit using the Math.Round
function.
Sink1.TimeInSystem.LastRecordedValue – Returns the last recorded value for this TimeInSystem TallyStatistic within the Sink object.
The TimeInSystem is referring to the TimeInSystem of the entities that enter this Sink object. TimeInSystem is a TallyStatistic element
and LastRecordedValue is a function available to all TallyStatistic elements. Other functions available for TallyStatistics are
NumberObservations, HalfWidth, Average, Maximum and Minimum. The value is multiplied by 60 to convert from hours to minutes and is
rounded to 1 significant digit using the Math.Round function.
Examples of Functions Available for a Server
Server1.Capacity.Remaining – Returns the current unallocated capacity of this object. Other related functions are C apacity.Allocated,
C apacity.Initial, C apacity.Maximum, C apacity.Minimum, C apacity.Previous, C apacity.Remaining, C apacity.AllocatedTo(owner) (Returns the
number of capacity units of this object currently seized and owned by the executing token’s associated object.)
Server1.Capacity.Allocated – Returns the current number of capacity units of this object that are allocated (have been seized).
Server1.InputBuffer.Contents.AverageTimeWaiting – Returns the average time that an entity waited in the C ontents queue state of
the InputBuffer(in hours). In other words, the average time that an entity spent in the InputBuffer of Server1. There are other functions
available to use with the C ontents queue, such as AverageNumberWaiting and MaximumTimeWaiting. The value is multiplied by 60 to
convert from hours to minutes and is rounded to 1 significant digit using the Math.Round function. See the Functions page for information
on Queue State functions.
Server1.InputBuffer.Contents.NumberWaiting – Returns the current number of entities waiting in the InputBuffer of Server1.
Server1.Processing.Contents – Returns the current number of entities that are in the Processing station of Server1.
Server1.ResourceState.PercentTime(1) – Returns the percent time that this Resource list state had the value of 1. In other words,
the percentage of the total simulation time that Server1 was in the Resource State of 1 (Busy). Default Server ResourceState Values: 0 –
Idle, 1 – Busy, 2 – Blocked, 3 – Failed, 4 - OffShift
Server1.ResourceState.TotalTime(0) – Returns the total time that this Resource list state had the value of 0. In other words, the total
amount of time that Server1 was Idle. Default Server ResourceState Values: 0 – Idle, 1 – Busy, 2 – Blocked, 3 – Failed, 4 - OffShift
Server1.ResourceState.NumberOccurences(3) – Returns the number of times that Server entered into the Resource list state of 3.
In other words, it returns the number of times that Server1 entered the Failed state. Default Server ResourceState Values: 0 – Idle, 1 –
Busy, 2 – Blocked, 3 – Failed, 4 - OffShift
Server1.ResourceState == 1 - Returns the value of 0 if Server1 is not currently in ResourceState of 1 and returns a value of 1 when
Server1’s ResourceState is currently = 1. Default Server ResourceState Values: 0 – Idle, 1 – Busy, 2 – Blocked, 3 – Failed, 4 - OffShift
[email protected] – For an external input node, this function returns the current 'load' on the station locations
inside the node's associated object that may be entered using the node. The associated station 'load' is defined as the sum of current
entities en route to the node intending to enter the stations, plus the current entities already arrived to the node but still waiting to enter
the stations, plus the current entities occupying the stations.
91 / 815
the stations, plus the current entities occupying the stations.
Embellishments:
In order to have the Server turn Red when it’s in the Failed state, select the Server and click Add Additional Symbol in the Ribbon. When symbol
2 of 2 is Active, click on the C olor button in the ribbon, select the color Red, and then click onto the Server. This will turn Symbol 2 into a Red
Server. With the Server selected, go to the property called C urrent Symbol Index under the Animation category in the properties window. Enter
the expression, ‘Server1.ResourceState == 3’. Therefore, when the Server is in Resource State 3 (Failed), this expression evaluates to True,
which is a value of 1. This value is an index into the symbol list (0-based index) and therefore will display the Red symbol when this expression is
True. When the expression is False and evaluates to 0, it will display the first symbol in the symbol list, which is the standard grey Server.
See Also:
The SimBit titled ExamplesOfFunctions_DynamicObjects for examples of functions that are available for dynamic objects.
92 / 815
Simio Reference Guide
ExcelR eadW rite - SimBit
Problem:
I want to use MS Excel to read data into Simio and also to write data from Simio.
Categories:
File Management
Key Concepts:
Add-On Process, ExcelRead Step, ExcelWrite Step, Assign Step, ExcelC onnect Element, String State Variable, Integer State Variable
Technical Approach:
ExcelC onnect element is used to connect with the Excel sheet. An add-on process is used where row and column position are defined using Assign
step from where data has to be read in Excel file. Then using ExcelRead step, data is read and using ExcelWrite step, data is written into Excel.
Details for Building the Model:
Simple System Setup
Within the Facility window, add a Source, a Server and a Sink from Standard Library. C onnect the objects using Paths.
Within the Source object, change the Maximum Arrivals (under Stopping C onditions) to ‘30’.
Within the output node of the Source, within the Add-On Process Triggers section, double-click on the Entered property to create a new
process named ‘Output_Source1_Entered’.
Adding States and Elements
Within the Definitions tab, click on the States panel. Add a String State and three Integer State and name them ‘StringState’,
‘RowIntegerState’, ‘C olumnIntegerState’, ‘IntegerState’.
Next, click on Element panel and within the Element Ribbon, select on User Defined button to select ExcelC onnect element. In the property
window for ExcelC onnect1 created, enter the Excel Workbook name ‘ExcelReadWrite.xlsx’.
C reating the Writing Process
Within the Processes window, in the Process named Output_Source1_Entered, add two Assign steps from C ommon Steps panel and
ExcelRead and ExcelWrite Step from User Defined panel of steps.
For the first Assign step, assign the State Variable Name ‘C olumnIntegerState’ and New Value ‘C olumnIntegerState +1’. For the sSecond
Assign step, assign State Variable Name ‘RowIntegerState’ and New Value ‘RowIntegerState +1’.
For the ExcelRead step, select ‘ExcelC onnect1’ from the list for the ExcelC onnect property. C lick on Worksheet and enter ‘Sheet1’. For Row
, enter ‘RowIntegerState’ and for Starting C olumn, enter ‘1’. Then click on States to open repeating property editor. Add. a State
‘StringState’ and another State ‘IntegerState’.
For the ExcelWrite step, again select ‘ExcelC onnect1’ for the ExcelC onnect property. Add the Worksheet value of ‘Sheet2’. For Row, enter
‘RowIntegerState’ and for Starting C olumn, enter ‘C olumnIntegerState’.Then click on Items to enter the repeating property editor. Add an
Expression named ‘TimeNow’, one named ‘StringState’ and one named ‘IntegerState’.
Animating the State Information within the Facility Window
Within the Facility window, click on the Animation ribbon. Select Status Label and draw two Status Labels in Facility window. For the first
Status Label, enter the Expression ‘StringState’. For second Status Label, enter the Expression ‘IntegerState’.
93 / 815
Simio Reference Guide
FacilityModelW ithinModel - SimBit
Problem:
You have a facility in which many of the operations are similar. You wish to make a single “object” that encompasses 3 serial processes into a
single process for simplicity.
Categories:
Building New Objects / Hierarchy
Key Concepts:
BasicNode, Expression Property, External View, ExternalNode, FacilityNode, Input Logic Type, Server, To Parent External Node, Bind To External
Input Node, Bind To External Output Node, Externally Visible
Assumptions:
The similar processes that will be made into an object include a single Server (ProcessA), which then moves entities to one of 2 more Servers
(Process B), followed by a fourth Server (ProcessC ).
Technical Approach:
Within the first model, called ProcessABC , we will define the processing necessary for this single object. It includes ProcessA, ProcessB_1 and
ProcessB_2, and ProcessC . All logic for these Servers will be assumed unchangeable except for the Processing Time property for each.
Therefore, when this ProcessABC model is placed into the Facility Window of another model, the user must only specify the four processing times
for the various Servers. The External Window is used to define the view of the model, including the input and output nodes.
Details for Building the Model:
Simple System Setup
Rename Model to ProcessABC by clicking on MySimioProject, highlighting the Models panel and clicking on Model. Pressing F2 (or clicking
again on Model) will put you in rename mode.
Place 4 Servers within the Facility Window of ProcessABC and rename them to ProcessA, ProcessB_1, ProcessB_2 and ProcessC . C onnect
them with Paths – ProcessA to both ProcessB_1 and ProcessB_2, and then both ProcessB_1, ProcessB_2 connected to ProcessC .
Defining the Properties of a Hierarchical Model
Highlight each Server and use the Processing Time property to indicate that the data for this processing time be given in the parent object.
This is done by highlighting the Processing Time property (it will turn blue) and using the right click to select “Set Referenced Property” and
then select “C reate New Referenced Property”. This will open a dialog to specify the name of the property in the parent ProcessABC that
the user will be able to edit (i.e., ProcessTimeA). Once you do this, the field will have the name of the property with a small green arrow in
front of it. This means that the value will be “inherited” from the parent object ProcessABC when it is placed in a model. Do this will all four
Servers.
Defining the External View of Model
From the Facility window, right click on the Input Node of ProcessA and select Bind To New External Input Node. You will be prompted to
name the new External Node. Keep the default name of Input_ProcessA. This is the node where entities will enter into this object. They will
automatically enter this object and go directly into ProcessA.
Similarly, right click on the Output Node of ProcessC and select Bind To New External Output Node. You will be prompted to name the new
External Node. Keep the default name of Output_ProcessC . This is the node where entities will exit this object. They will automatically exit
this object when they enter into the Output node of ProcessC .
Using the Model within Another Model
Open a new model and within its Facility Window, place a ProcessABC object from the Project Library.
Select the Source and Sink objects from the Standard Library and place them in the Facility Window.
C onnect the Source1 to ProcessABC and then ProcessABC to the Sink1 using Paths. Notice when you highlight ProcessABC , you have
access to all the processing times, namely ProcessTimeA, ProcessTimeB_1, ProcessTimeB_2 and ProcessTimeC. When you run this new
model, the logic behind ProcessABC then includes all logic specified within that model.
Discussion:
Notice that when you placed the Server objects into the ProcessABC model, they automatically appeared as part of the External View of that
object. If you right click on each Server (ProcessA, ProcessB, etc) in the Facility window of model ProcessABC , you’ll see that the option,
Externally Visible is selected by default. This means that these objects will be visible in the External View of this object (will be seen when this
object is placed inside another model). If you unselect Externally Visible from the right click menu of an object, it will no longer appear in the
External View of that object.
94 / 815
Simio Reference Guide
FreeSpaceMovement - SimBit
Problem:
I would like to learn how an Entity and a Vehicle can travel in Free Space.
Categories:
Add-On Process Logic, Movement In Free Space, Vehicles
Key Concepts:
Add-On Process, FreeSpace, Initial Network, ModelEntity, Transfer Step, Travel Step
Assumption:
Moving in Free Space means that an entity is moving within the Facility window but it is not moving on a Link.
Technical Approach:
This project contains three models and each model demonstrates a concept in free space movement.
The model named FreeSpaceTravelWithNoDestinationSet contains a DefaultEntity with its Initial Network property set to ‘No Network (Free
Space)’. The entity does not have a destination set when it travels so Simio will send the entity to the closest External Input Node. In this model
there are three possible External Input Nodes for it to travel to; Input@Server1, Input@Server2 or Input@Sink1. Moving these objects around
before or during the run will show that the entity will always choose the node that is closest to its current location.
The model named TransferIntoFreeSpace_UseTravelStep contains a DefaultEntity with its Initial Network property set to the default value of
‘Global’. This allows the entity to travel on the Path leaving the Source. When the entity enters BasicNode1, the Add On Process uses a Transfer
Step to transfer the entity into Free Space and then the Travel Step tells the entity to move to the location where BasicNode2 is currently located.
After the entity arrives at that location, another Transfer Step transfers the entity from Free Space into BasicNode2. Since it is still on the Global
network, it will then follow the Path leaving BasicNode2 and travel to Sink1.
The model named VehicleTravelInFreeSpace contains a DefaultEntity and a Vehicle that both have their Initial Network property set to ‘No
Network (Free Space)’. This demonstrates how a vehicle can travel in free space.
Details for Building the FreeSpaceTravelWithNoDestinationSet Model:
Place a Source, two Servers, and a Sink into the Facility window. Leave some space between the objects so you can see the entity moving
in Free Space.
Place a ModelEntity object from the Project Library into the Facility window.
Select the DefaultEntity instance in the Facility window and change the Initial Network property to ‘No Network (Free Space)’.
The entity does not have a destination set and because there are no links, the entity does not know where to go. In this situation, Simio will find
the closest External Input Node and send the entity there. In this model, the External Input Nodes are Input@Server1, Input@Server2 and
Input@Sink1. Whichever node is closest to the entity will be selected as its destination. Move the objects around to see how the destination
changes depending on the distance between the entity and the input nodes.
Details for Building the TransferIntoFreeSpace_UseTravelStep Model:
Place a Source, a Sink and two Basic nodes into the Facility window. C onnect the output node of the Source to BasicNode1 with a Path.
C onnect BasicNode2 to the input node of Sink1 with a Path.
Select BasicNode1 and create a new Add On Process by selecting ‘C reate New’ in the dropdown of the Entered Add On Process trigger
property of this node. This will create a new process that will appear in the Processes window.
Place a Transfer Step into the process. Set the From property to ‘C urrentNode’ and the To property to ‘FreeSpace’.
Place a Travel Step. Set the Destination Type to ‘Specific Object’, set the Destination Object to ‘BasicNode2’, and set the Units
(under Maximum Movement Rate) to ‘Meters per Second’.
Place another Transfer Step and set the From property to ‘FreeSpace’, the To property to ‘Node’ and the Node Name property to
‘BasicNode2’.
By default, the DefaultEntity is set to travel on the Global network. This allows it to travel on all Links. Therefore, it travels on the Path leaving the
Source and arrives at BasicNode1. At that point, we need to tell the entity to go into FreeSpace. We do that with a Transfer Step, transferring the
entity from the current node into Free Space. The Travel Step is used only when an entity is in Free Space and it tells the entity where to move.
When the entity arrives at BasicNode2, it is still in Free Space so it cannot travel on the Path into the Sink. So we need another Transfer Step that
transfers the entity from Free Space into BasicNode2. At this point, it’s still on the global network and therefore it travels on the Path into the
Sink.
Details for Building the VehicleTravelInFreeSpace Model:
Place a Source, a Sink and a Transfer node into the Facility window.
Place a Vehicle into the Facility window.
Set the Vehicle’s Initial Network property to ‘No Network (Free Space)’. Set the Initial Node (Home) property to ‘TransferNode1’ and
the Idle Action property to ‘Go To Home’.
Place a ModelEntity into the Facility window from the Project Library (bottom left of screen).
Set the Initial Network property to ‘No Network (Free Space)’.
Select the Output@Source1 node and set the Entity Destination Type property to ‘Specific’ and the Node Name property to ‘TransferNode1’.
Select TransferNode1 and set the Entity Destination Type property to ‘Specific’ and the Node Name property to ‘Input@Sink1’. Set the Ride
On Transporter property to ‘True’ and the Transporter Type property to ‘Specific’ and the Transporter Name property to ‘Vehicle1’.
This is a simple model demonstrating that a Vehicle can travel in Free Space.
Embellishments
Instead of a Vehicle object, use a Worker object to show that a Worker can also travel in Free Space. A Travel Step can also be used with a
Vehicle or Worker object.
Problem:
I would like to password protect my model.
Categories:
File Management
Key Concepts:
Add-On Process, Data Table, Dynamic Object Property, Expression Property, Numeric Property, On C reating Entities, Password Protect,
RandomRow, SetRow Step, Source, String Property
Assumptions:
The password to open the object named MyModel is ‘simio’.
Technical Approach:
A password will be added to MyModel by using the Protection feature.
Details for Building the Model:
Adding a Password to MyModel
C lick on MySimioProject in the Navigation window and select the Models panel.
Highlight the model that you would like to password protect and click on the Protect button in the Edit ribbon.
Enter ‘simio’ or a desired password into the field.
Upon reopening the project file, the correct password will have to be entered to gain access.
You can later unprotect the model by selecting the Unprotect button if desired.
Embellishments
This method of protection can also be used for any model object in the Navigation window.
97 / 815
Simio Reference Guide
Financials - SimBit
Problem:
I would like my model to calculate costs, such as capital costs of objects, usage costs, holding costs and the cost of transporting an entity on a
vehicle.
Categories:
Add-On Process Logic, Decision Logic – Paths, Entity C haracteristics, Vehicles, Workstations
Key Concepts:
Add-On Process, Assign Step, Bidirectional Path, C ost C enter, Financials, InputBuffer, ModelEntity, Entered, Pivot Grid, Processing, Ride on
Transporter, Selection Weight, Vehicle, Workstation
Technical Approach:
This model gives examples of how to use a few different costing features in Simio. One object demonstrates the C apital C ost property, another
uses the Holding C ost property which calculates the cost to hold an entity in the Input Buffer of this object. The model also shows how the user
can manually apply costs with an Assign Step. It also contains a Vehicle which has costs associated with each entity that rides on the vehicle. All
the costs in this model are rolled up into one of four C ost C enters.
Details for Building the Model:
Simple System Setup
Place a Source object and change the Interarrival Time property to ‘Random.Exponential(.8)
Place a Server object and change the name of the Server to InspectionA, C onnect the Source to the Server with a Path.
Place a Sink object and name it FailedInspection. C onnect the Server InspectionA to this FailedInspection Sink with a Path. Set the
Selection Weight property to ‘.3’.
Place a Workstation object and name it Paint. C onnect the Server to the Workstation with a Path and set the Selection Weight property to
‘.7’
Place a Sink object and name it 'Sink1'. C onnect the Workstation Paint to this Sink with a Path. C hange the Type property on the Path to
‘Bidirectional’.
Place a Vehicle object. Set its Initial Home property to ‘Output@Paint’.
C onfigure C osting of InspectionA
Select InspectionA (Server) and open the Financials property category. View the drop down selection list for the Parent C ost C enter
property by clicking on the down arrow that appears when this property is selected.
C reate a new C ost C enter by selecting ‘C reate New’ from the drop down. Name this new C ost C enter ‘InspectionC ostC enter’. All
the costs incurred at this Server will be rolled up to this new C ost C enter.
C onfigure C osting of Paint
Select Paint (Workstation) and change the Processing Time property to ‘Random.Triangular(.2, .3, .4)’. Open the Financials property
category. View the drop down selection list for the Parent C ost C enter property by clicking the down arrow that appears when this property
is selected.
C reate a new C ost C enter by selecting ‘C reate New’ from the drop down. Name this new C ost C enter ‘PaintC ostC enter’. All the
costs incurred at this Workstation will be rolled up to this new C ost C enter.
Set the Capital Cost property to ‘100,000’ USD. This is a one time cost of 100,000 to just own this Workstation.
Expand the Buffer C osts subcategory and expand the InputBuffer category. Set the Holding Cost Rate (under Input Buffer) to ‘200’
USD per Hour. This is a $200 cost for each hour that an entity if held in the Input Buffer of this Workstation.
C onfigure C osting of Vehicle
Select the Vehicle object and set the Parent Cost Center property to a new C ost C enter named ‘TransportationC osts’. Expand the Transport
C osts property category and set the Cost Per Rider property to ‘10’ USD. This cost will be incurred each time a rider is loaded onto the
vehicle.
C onfigure C osting of Failed Inspections
C reate a new C ost C enter element by going into the Definitions window/Elements panel. C lick on the C ost C enter element icon in the
ribbon. Name this new C ost C enter, ’C ostOfFailedParts’.
Select the Path that connects the Server InspectionA to the Sink called FailedInspection. Double click on the Add On Process trigger
property Entered to create a new Add On process.
Place an Assign Step in the process and set the State Variable Name to ‘C ostOfFailedParts.C ost’ and the New Value to
‘C ostOfFailedParts.C ost + 150’. Therefore, each time an entity enters this path and therefore executes this process, $150 will be
added to the C ost C enter, C ostOfFailedParts. This is an example of how to assign cost manually within process logic.
C onfigure C ost on the Entity
Place a ModelEntity object into the Facility window. Expand the Financials property category and set the Initial Cost Rate property to 100
USD per Hour. This is the cost per hour for this entity.
Explanation of Results
Set the Ending Type of the model to ’10 hours’, on the Run Tab of the ribbon menu. Run the model until the end. C lick on the Results Tab to
view the Pivot Grid.
If you view the Model object type category, you will see the breakdown of costs into each of the 4 cost centers; C ostOfFailedParts,
InspectionC ostC enter, PaintC ostC enter, TransportationC osts. You will also see a grand total of costs at the Model object level.
To see details of the C ostOfFailedParts cost, find the results for the Path2 (or the name of the Path where the Add On Process is located
which assigns the cost). Note the Total Number Entered in the Throughput category. It is 221. Multiply this by the cost for entering that path
($150), you get the total of $33,150, which is the total cost of the C ostOfFailedParts cost center.
To see the details of the InspectionC ostC enter, find the results for the InspectionA Server.
You’ll first notice costs in the Input Buffer station of this object. This comes from the cost on the entity object ($100 per USD). The
cost of the entity, when it is located at this Server’s InputBuffer, is rolled up into the InspectionC ostC enter. Note the Average
98 / 815
Number in Station (.0452) and multiply this by the C ost Rate on the entity object ($100) and also by the total simulation time, which
was 10 hrs. This is a total of 45.2203, which is shown in the Total C ost of this InputBuffer.
Also notice that there are costs for the Processing station of this Server. This cost comes from the cost on the entity object. The cost
of the entity, when it is located at this Server’s processing station, is rolled up into the InspectionC ostC enter. Note the Average
Number in Station for processing (.2565) and multiply this by the C ost Rate on the entity object ($100) and also by the total
simulation time (10 hrs) and this gives $256.4687, which is shown in the Total C ost of this processing station.
To see the details of the PaintC ostC enter, find the results for the Paint Workstation. We had put a $100,000 value in the C apital C ost for
this object and this is shown in the C apital C ost Data Item of this object.
We also put $200 USD per hour in the Holding C ost for the InputBuffer of this object. The cost of the entity also needs to be
included, which is $100 USD. Note the Average Number in Station is .0478. Multiply $300 times .0478 and then by the 10 simulation
hours and you get the total cost of this Input Buffer station, $144.
There is also cost in the Processing Station, which is the cost of the entity at this object. Note the Average Number in Station is
.2804. Multiply that by 10 simulation hours and $100 entity cost and you get the $280.4 shown in the total for this station.
To see the details of the TransportationC osts, see the Vehicle object type results. There are two costs being rolled into this cost center. The
first is the Transport C ost that we defined, which is $100 for every rider. Note the NumberEntered in the Throughput category of the
RideStation is 557. Multiply this by $100 and you get a total of $5570.00. The other cost if the cost of the entity. Note the
AverageNumberInStation of this Ride Station is .0712. Multiply this by $100 (entity cost) and by the 10hr simulation and you get 71.2.
Added to $5570 is the total cost of $5641.2 that is shown in the results.
99 / 815
Simio Reference Guide
FindAMinimumStateValue - SimBit
Problem:
I have 3 servers and want to keep track of the total processing time allocated to server (including entity at the server and those en route) with a
state variable. I want to then find the minimum value to the various servers to even out the load to each throughout the simulation.
Categories:
Add-On Process Logic, Decision Logic -- Processing, Discrete States, Entity C haracteristics
Key Concepts:
Add-On Process, Assign Step, Data Table, Find Step, SetNode Step, State Variable, Status Label
Assumptions:
We assume that the method for allocating entities to the various servers is based on the smallest processing time sent to any given server. Each
entity will be assigned a processing time when it is created.
Technical Approach:
Use a state on the entity to assign the entity processing time upon its creation. Use a state variable (vector) that stores the total processing time
for each given server based on the entity at the server and those en route to the server. Use the Find step to determine which of the three
servers has had the least amount of processing time allocated to it. The first value within the state variable will refer to the first server, Server1,
and so on. We will also store the input node for each of the three servers within a table, so that we can use the SetNode step to set the
appropriate destination after the Find step.
Details for Building the Model:
Adding the ModelEntity ProcessingTime
Within the Navigation window, click on the ModelEntity and go to the Definitions tab, States panel.
Add a real state variable named ProcessingTime, which will be referred to as ModelEntity.ProcessingTime in the model.
Simple System Setup
Within the Navigation window, click on the Model and go to the Facility window.
Add a Source, three Servers and a Sink to the Facility window.
C onnect the Source to each of the three Servers and each Server to the Sink with Paths.
Modifying the Source
C hange the Interarrival Time to ‘Random.Exponential(.05)’.
Within the Before Exiting section of the State Assignments, add an assignment to the State Variable Name ‘ModelEntity.ProcessingTime’ a
New Value of ‘Random.Uniform(.1,.3)'.
C lick on the output node and go to the Entered add-on process. Double-click on Entered to add the process ‘Output_Source1_Entered’.
Adding a State Variable Vector
Within the Definitions window, States panel, add an integer type variable named ‘Index’. This will be used within the Find step itself. This
variable will remain as Dimension Type of ‘Scalar’.
Add a real state variable named ‘ServerProcessingTime’. C hange the Dimension Type to ‘Vector’ and the Rows to ‘3’. These values are
then referenced ServerProcessingTime[1], ServerProcessingTime[2] and ServerProcessingTime[3].
Using the Find Step
Within the Processes window, in the new process that was added above (‘Output_Source1_Entered’), add a Find step. This step requires an
index variable (which could be any name, but we have just created one named ‘Index’ above). Set the Index Variable Name to ‘Index’.
The value of this variable will be set to the item that is ‘Found’ (if any). Keep the Starting Index as ‘1’ and change the Ending Index to ‘3’.
This will then allow us to search the 3 vector values of the ServerProcessingTime variable.
C hange the Search Type to ‘Minimize Expression’. Set the Search Expression to ‘ServerProcessingTime[Index]’. This will allow the Find step
to look at all three values of the ServerProcessingTime variable and find the minimum value. When the simulation first starts, all values
are 0 and thus, the first one will be found.
Using the Index Value from the Find Step
After the Find step, from the ‘Found’ exit, place an Assign step and a SetNode step. Within the Assign step, set the State Variable Name to
‘ServerProcessingTime’ and the Row to ‘Index’. Input the New Value as ‘ServerProcessingTime[Index] + ModelEntity.ProcessingTime’.
Remember that the value ‘Index’ will be either 1, 2 or 3 (starting to ending index) based on the search type and expression specified.
Therefore, with this Assign step, we are increasing the value of whichever minimum variable was found by the entity’s processing time that
was assigned in the Source.
Within the SetNode, we will be leaving the Destination Type as ‘Specific’ and now need to determine how to specify the Node Name for the
corresponding server to where we’d like the entity to move.
Using a Data Table to Store Input Nodes for Possible Destinations
Because the variable ‘Index’ will return a value between 1-3, we will set up a data table that will have corresponding input nodes for the
three Servers. We’ll then index into the table within the SetNode step. To do this, go to the Data window, Tables panel and add a Data
Table named ‘Table1’. Add an Object Reference type column of type Node. C hange the Name of the column to ‘WhichServer’. Input the
three input nodes for the servers, such as Input@Server1, Input@Server2 and Input@Server3. We can then reference the correct row by
the variable ‘Index’.
Go back to the Processes window and within the SetNode step, set the Node Name to ‘Table1[Index].WhichServer’. This will set the entity
destination to the appropriate server. Because the Entity Destination Type on the Output@Source1 node is ‘C ontinue’, the entity will use its
node destination to know where to go next.
Using ModelEntity.ProcessingTime in the Server
Within each of the three servers, change the Processing Time property to ‘ModelEntity.ProcessingTime’ to use the value that was assigned
to each individual entity.
Within the Before Exiting section of the State Assignments of each server, we will decrease the state variable vector for the particular
server. Set the State Variable Name to ‘ServerProcessingTime’. For Server1, the Row would be ‘1’, for Server 2, the Row would be ‘2’ and
so on. The New Value should be ‘ServerProcessingTime[1] – ModelEntity.ProcessingTime’ (for Server1, with the value in brackets reflecting
100 / 815
so on. The New Value should be ‘ServerProcessingTime[1] – ModelEntity.ProcessingTime’ (for Server1, with the value in brackets reflecting
the server number). This will then decrease the state variable after the entity is processed.
Enhancements:
Add a Status Label next to each of the Servers that references the state variable vector for each (such as ServerProcessingTime[1], etc.). This
way, you can see that the incoming entity is sent to the one with the minimum value of that vector. Additionally, on the DefaultEntity placed in the
Facility window, attach a status label that shows the ModelEntity.ProcessingTime value as it moves through the system.
101 / 815
Simio Reference Guide
Flow C oncepts - SimBit
This SimBit project includes seven models that demonstrate the use of the Simio Flow Library. Models included in this SimBit:
1. SimpleFlow – Demonstrates flow from a FlowSource object, through a FlowC onnector object, to a FlowSink object.
2. FillingEmpyingTank – Demonstrates filling and emptying a tank object.
3. TransferringFromOneTankToAnother – Demonstrates transferring from one tank object to another.
4. MergedFlow – Demonstrates merging two different entity flows.
5. SplitFlow – Demonstrates splitting a single entity flow into two entity flows.
6. CreateDiscreteEntitiesBasedOnFlow – Demonstrates the use of monitors and events to create discrete entities when a tank reaches
a certain flow level.
7. SimpleFiller – Demonstrates the use of the C ontainerEntity and Filler objects to illustrate a filling operation of combining discrete
containers with continuous flow.
8. SimpleEmptier – Demonstrates the use of the Emptier object to illustrate full container entities with multiple products emptying into
multiple flow streams based on their product type to flow sink objects.
Model 1: SimpleFlow
Problem:
I want to create an entity flow from a FlowSource object, through a FlowC onnector , to a FlowSink object. In addition, I want to monitor the flow
volume and stop the flow at 5 cubic meters of total volume.
Categories:
Flow Library
Key Concepts:
FlowSource, FlowSink, FlowC onnector
Assumptions:
Flow rate and stopping condition are in units of cubic meters.
Technical Approach:
C reate entity flow using a FlowSource and send it directly to the FlowSink through a FlowC onnector. Terminate the flow using the Maximum
Volume stopping condition on the FlowSource.
Details for Building the Model:
Simple System Setup:
Place a FlowSource and FlowSink from the Flow Library in the Facility window.
C onnect the source and sink using a FlowC onnector.
Set the Maximum Volume property of the FlowSource object to ‘5’ cubic meters.
Place a Status Label and set its Expression property to ‘[email protected] urrentMaximumFlowRate’.
Place a Status Label and set its Expression property to ‘[email protected] urrentVolumeFlowOut’.
Place a ModelEntity from the Project Library into the model and change the color to whatever color you’d like the flow to be.
Model 2: FillingEmptyingTank
Problem:
I want to fill a tank until the tank reaches the high mark. Once reaching the high mark, the tank should empty until it reaches the low mark, at
which point it should repeat the fill-empty cycle.
Categories:
Flow Library, Add-On Process Logic
Key Concepts:
FlowSource, FlowSink, Tank, FlowC onnector, Assign Step
Assumptions:
Flow is in units of cubic meters.
Technical Approach:
When the tank reaches the high point, stop the flow from the source and start the flow out of the tank. When the tank reaches the low point, start
the flow from the source and stop the flow out of the tank.
Details for Building the Model:
Simple System Setup
Place a FlowSource, at Tank, and a FlowSink from the Flow Library in the Facility window.
C onnect the FlowSource to the Tank input and the Tank output to the FlowSink.
Set the Initial Volume Capacity of the Tank object to ‘10’ cubic meters.
Set the Low Mark, Mid Mark, and High Mark properties of the Tank object to ‘2’, ‘5’, and ‘8’ cubic meters, respectively.
C reate an add-on process for the Above High Mark property of the tank. This process should use two Assign steps to assign
‘[email protected]’ to ‘False’ (shutting off the flow though the output node of the FlowSource) and
‘[email protected]’ to ‘True’ (enabling the flow out of the tank).
C reate an add-on process for the Below Low Mark property of the tank. This process should also use Assign steps to assign
‘[email protected]’ to ‘True’ (enabling the flow though the output node of the FlowSource) and
‘[email protected]’ to’ False’ (shutting off the flow out of the tank).
Add the Status Labels displaying the volume in the Tank and the maximum flow rate and flow enabled state of the output FlowNodes of the
FlowSource and Tank objects. Keep in mind that ‘False’ is a value of 0, while ‘True’ is a value of 1 within the enabled state labels.
102 / 815
FlowSource and Tank objects. Keep in mind that ‘False’ is a value of 0, while ‘True’ is a value of 1 within the enabled state labels.
Model 3: TransferringFromOneTankToAnother
Problem:
I would like to fill a tank until it reaches its high point. Once this happens, I’d like to transfer the contents into another tank at a much higher rate.
When the second tank reaches its high point, empty it.
Categories:
Flow Library, Add-On Process Logic
Key Concepts:
FlowSource, FlowSink, FlowC onnector, Tank, Regulator, Assign Step
Assumptions:
Flow is in units of cubic meters and flow rates are in units of cubic meters per hour.
Technical Approach:
Add up two tanks and set the flow rates for the output node of the first tank and the input to the second tank to be higher than the input to the
first tank (and the output from the source). C ontrol the flow between the tanks and to the sink using the add-on processes for the tank levels.
Details for Building the Model:
Simple System Setup
Place a FlowSource, two Tanks, and a FlowSink from the Flow Library in the Facility window.
C onnect the FlowSource to one of the Tank inputs, that Tank’s output to the other Tank’s input, and the second Tank’s output to the
FlowSink (all using FlowC onnectors).
Set the Initial Volume Capacity for both Tank objects to ‘10’ cubic meters and set the first tank’s low medium and high marks to ‘1’, ‘5’, and
‘9’ cubic meters, respectively. Set the second tank’s low, medium, and high marks to ‘0’, ‘5’, and ‘8’ cubic meters, respectively.
Set the Initial Maximum Flow rate parameters for the Output@Tank1 and the Input@Tank2 to be ‘1500’ cubic meters per hour.
Set the Initial Maximum Flow rate parameters for the Output@Tank2 and the Input@FlowSink1 to be ‘200’ cubic meters per hour.
Set the Above High Mark add-on process for Tank1 to enable flow to Tank2 by assigning the ‘[email protected]’ to
‘True’ and set the Below Low Mark add-on process to disable the flow by setting the same property to ‘False’.
Set the Above High Mark add-on process for Tank2 to enable flow to the sink by assigning the ‘[email protected]’ to
‘True’ and set the Below Low Mark add-on process to disable the flow by setting the same property to ‘False’.
Add status labels for the current volume in the tanks.
Place 3 ModelEntity objects in the Facility window and change the color of each to be different. Within the output flow nodes of the tanks,
change the Initial Output Entity Type to be ‘ModelEntity2’ and ‘ModelEntity3’, respectively, to show different flow colors on all the three
connectors.
Model 4: MergedFlow
Problem:
I want to merge two flows into a single flow.
Categories:
Flow Library
Key Concepts:
FlowSource, FlowSink, FlowC onnector, FlowNode
Assumptions:
All entity types may merge together. Flow will be merged proportionally based on the inflow rates from the various sources.
Technical Approach:
C reate two separate entity flows and merge them into a single flow at a FlowNode.
Details for Building the Model:
Simple System Setup
Place two FlowSource objects and a FlowSink object in the Facility window.
Place a FlowNode between the two FlowSource objects and the FlowSink object.
C onnect each FlowSource object to the FlowNode using FlowC onnectors.
C onnect the FlowC onnector to the FlowSink.
Set the Initial Maximum Flow Rate properties for FlowNode1 and the Input@FlowSink1 to be ‘200’ cubic meters per hour.
Set the Flow Control Mode for FlowNode1 to be ‘Merge Flow’.
Place three ModelEntity instances in the Facility window and specify that each of the two FlowSources use a different entity type by setting
the Entity Type property.
Set the Initial Output Entity Type property for FlowNode1 to be the third entity type.
Add status labels for the flow volumes (FlowNode.FlowRegulator.C urrentVolumeFlowOut).
Model 5: SplitFlow
Problem:
I want to split a single flow into two flows and use the flow connector link weights to determine the proportion of flow set to each link.
Categories:
Flow Library
Key Concepts:
103 / 815
FlowSource, FlowSink, FlowC onnector, FlowNode
Assumptions:
The link weights of the outgoing FlowC onnectors to the FlowSinks will be used to proportionally allocate flow in each direction.
Technical Approach:
Use the Split Flow option on the FlowNode to allocate flow proportionally to a number of FlowSink objects.
Details for Building the Model:
Simple System Setup
Place a FlowSource object and two FlowSink objects in the Facility window.
Place a FlowNode between the FlowSource and the two FlowSink objects.
C onnect the FlowSouce to the FlowNode and connect the FlowNode to the two FlowSink objects using FlowC onnectors.
Set the Flow Control Mode property for FlowNode1 to ‘Split Flow’ and change the Split Allocation Rule to ‘Proportional Based On Link
Weights’.
Set the Selection Weight properties for FlowC onnector2 and FlowC onnector3 to ‘.65’ and ‘.35’, respectively.
C reate status labels for the flow rates using the Expression: ‘Math.If(TimeNow > .05, FlowC onnector2.C urrentVolumeFlowOut /TimeNow,
"N/A")’.
Model 6: CreateDiscreteEntitiesBasedOnFlow
Problem:
I want to create a discrete entity based on the amount of flow coming out of a tank. This model is an enhancement of the FillingEmptyingTank
model in this project.
Categories:
Flow Library, Add-On Process Logic
Key Concepts:
FlowSource, FlowSink, FlowC onnector, Tank, Monitor
Assumptions:
A discrete entity is created for every 1 cubic meter of volume transferred out of the tank.
Technical Approach:
A monitor is used to detect changes in the volume transferred out of the tank. The monitor crossing value is changed every time a cubic meter is
transferred, so that the crossing value is increased each time a discrete entity is created. The Source for discrete entities is based on an event
triggered by the monitor to generate the entities at the appropriate times.
Details for Building the Model:
Simple System Setup
Place a FlowSource, at Tank, and a FlowSink from the Flow Library in the Facility window.
C onnect the FlowSource to the Tank input and the Tank output to the FlowSink.
Set the Tank properties similar to that of the Tank in the FillingEmptyingTank model (described above).
Add the Tank1_AboveHighMark and Tank1_BelowLowMark add-on processes like the FillingEmptyingTank model.
Adding Discrete Entity C reation
Add a Source and Sink from the Standard Library to the Facility window. Place an additional ModelEntity in the window as well and name it
‘ModelEntity2’.
C onnect the Source1 to the Sink1 with a C onveyor. C hange the Initial Desired Speed to ‘3’ and the Units to ‘Meters per Minute’.
Within the Definitions window, Elements panel, add a Monitor element with the Name ‘TransferMonitor’. This will monitor the tank based on
the current volume flow out of the tank.
C hange the Monitor Type to C rossingStateC hange. The State Variable Name that we will be monitoring is based on the function
‘[email protected] urrentVolumeFlowOut’. C hange the Initial Threshold Value to ‘1’. This monitor will automatically cause an
event when the tanks output volume crosses the threshold in the positive direction. You’ll see that we will be also changing the threshold
value within the process.
Within the Processes window, add a new process. The Triggering Event for the process will be the ‘TransferMonitor.Event’. Within this
process, add an Assign step, where the State Variable Name is ‘TransferMonitor.C urrentThresholdValue’ and the New Value is
‘Math.ceiling(TransferMonitor.C urrentThresholdValue) + 0.999999’. This will increase the threshold of the monitor from its initial value of 1
(at the start of the simulation) by 1 each time a discrete entity is generated. This will cause the monitor to be fired for every volume out
change of 1 cubic meter. Use 0.999999 instead of 1 to make sure the entity is created before the lower mark process is triggered.
Within the Source in the Facility window, change the Entity Type to ‘ModelEntity2’, the Arrival Mode to ‘On Event’ and the Triggering Event
Name to ‘TransferMonitor.Event’. Therefore, a discrete entity will only be generated when the TransferMonitor.Event is fired.
Model 7: SimpleFiller
Problem:
I want to have liquid volume arrive to a filling operation and fill containers until they are full.
Categories:
Flow Library
Key Concepts:
C ontainerEntity, Filler, FlowSource, FlowC onnector
Assumptions:
Flow rate is in units of cubic meters and will fill containers until they are full.
104 / 815
Technical Approach:
C reate entity flow using a FlowSource and send it directly to the Filler through a FlowC onnector. C reate C ontainerEntities using a Source that
move into the Filler to be filled with liquid volume.
Details for Building the Model:
Simple System Setup
Place a FlowSource and Filler from the Flow Library in the Facility window and connect them using a FlowC onnector.
Place a C ontainerEntity in the Facility window from the Flow Library as well.
From the Standard Library, place a Source and connect the Source with the C ontainerInput node of the Filler using a Path.
Place a Sink to the right of the Filler and connect the output from the Filler with the Sink with a Path.
Within the Source, change the Entity Type to ‘C ontainerEntity1’ to create container type entities instead of model entities.
Model 8: SimpleEmptier
Problem:
I want to have full containers of a mixed liquid (2 product types) that I’d like to empty and send to their respective locations.
Categories:
Flow Library
Key Concepts:
C ontainerEntity, Emptier, FlowSource, FlowC onnector, Processing C ount Based
Assumptions:
Flow rate is in units of cubic meters and product will flow from the emptier based on product type.
Technical Approach:
Full container entities are created using a Source and sent directly to the Emptier. Two flow streams exit the FlowNode of the Emptier to multiple
FlowSinks. The Flow C ontrol Mode of the Emptier’s output FlowNode is Single Flow (No Splitting) such that the product is only split based on the
Selection Weights of the flow connectors.
Details for Building the Model:
Simple System Setup
Place a Source and a Sink from the Standard Library in the Facility window.
Place an Emptier and two FlowSink objects from the Flow Library in the Facility window. C onnect the Source to the Emptier and connect the
C ontainerOutput of the Emptier to the Sink using Paths.
C onnect the FlowOutput of the Emptier to each of the FlowSinks using FlowC onnectors.
Place a C ontainerEntity in the Facility window from the Flow Library, as well as two ModelEntity objects from the Project Library.
ModelEntity and C ontainerEntity Setup
C hange the Name of one of the ModelEntity objects to ‘Red’ and the other to ‘Green’. C hange the Red entity color triangle to the color red
using the Symbols ribbon.
Edit the C ontainerEntity object Initial C ontents by adding two rows to the repeating property editor. First, the Entity Type should be ‘Green’
with a Quantity of ‘.1’. The second initial content should be of Entity Type ‘Red’ with a Quantity of ‘.1’. Given that the Initial Volume
Capacity is the default value of ‘0.2’, this will fill the container when the entity is first created.
Within the Source, change the Entity Type for arriving to be ‘C ontainerEntity1’.
Emptier C onfiguration
Within the Emptier, we will also define Reliability Logic, such that the Emptier fails every x C ontainerEntities that it processes. C hange the
Failure Type to ‘Processing C ount Based’, with the Count Between Failures as ‘20’ and the Time to Repair as ‘Random.Uniform(.5,1) and
Units as ‘Minutes’.
On the FlowOutput node of the Emptier, specify the Initial Maximum Flow Rate of ‘60’ (default Units of ‘C ubic Meters per Hour’). In the
Output Flow C ontrol section, change the Flow Control Mode to ‘Single Flow (No Splitting)’ so that the flow will not be automatically split by
volume between the two flow connectors. We’d like the flow out to be based only on product. This will then be done ‘By Link Weight’ as the
Outbound Link Rule.
C lick on the FlowC onnector to FlowSink1 and specify the Selection Weight as ‘Is.Red’. If this expression evaluates to ‘True’ or a value of ‘1’,
then the product can flow through this connector. On the second FlowC onnector to FlowSink2, change the Selection Weight to ‘Is.Green’.
Therefore, when the product is emptied from the containers at the C ombiner, the Red product will flow to FlowSink1, while the Green
product will flow to FlowSink2.
105 / 815
Simio Reference Guide
HierarchyW ithT ables - SimBit
Problem:
I have a model that references data from tables and I would like to place this model inside of another model. Therefore, I would like to have a
“submodel” reference data in a table.
Categories:
Building New Objects / Hierarchy, Data Tables
Key Concepts:
Add-On Process, BasicNode, C ontents, Data Table, Expression Property, Expression Property, ExternalNode, FacilityNode, Foreign Key, Input Logic
Type, Key column, Numeric Property, Numeric Property, On Entered, Processing, Queue, Repeating Group Property, Resource, Search Step,
Server, SetRow Step, String Property, Submodel, Token, TransferNode, Externally Visible, Bind To External Output Node, Bind To External Input
Node
Technical Approach:
The model is the placed into another model is a SimBit named “SearchTableUponEnteringObject”. That model contains three Servers in parallel.
An entity travels to one of the three Servers, seizes a certain number of Resources, delays for a certain amount of time and then releases the
Resources. The number of Resources and the delay duration are different for each Server. This information is stored in a table. To find the
appropriate row in the table, the token must search the table and find the row that contains the information for that particular Server. The search
uses the ID of the Server object to find the appropriate row in the table.
In Simio, all tables exist at the top level, e.g. in the main model. Any “outside” data that is referenced inside an object or submodel must be
passed into the submodel via properties defined on that submodel. The mechanism for passing in sets of data like found in Tables is to define a
Repeat Group property. This Repeat Group is then used to store the information from the top level model. A Search step in the submodel can be
used to search the Repeat Group property to find the appropriate row of information.
Details for Building the Model:
Update the Submodel
Facility window
Delete the Source object and replace it with a Basic Node and connect this to the first Transfer Node with a connector. The Basic Node is
the entry point into this model. We no longer need a Source object because entities will be created in the top level model and enter this
submodel through the new Basic Node.
Delete the Sink object.
Definitions window
C reate a new Repeating Group property from the Properties panel by clicking the ‘Repeat Group’ icon in the ribbon. Name this property
‘Data’. Type ‘C ustom Properties’ into the Category Name property of this Data property so this new property is in its own category, for
easier reading.
Ensure that this new property is selected/highlighted in the window and then selecting ‘Expression property’ from the Standard Property
drop down in the ribbon. This will create a new Expression Property within the Repeat Group property. Name this Expression property
‘Hours’.
C lick back onto the Data Repeat Group property in the window and select Object from the Object Reference property drop down to create
an Object Reference property within the Repeat Group. Name this ‘ServerName’.
Add a final property to the Repeat Group and this property should be an Integer Property, found under the Standard Property drop down.
Name this property ‘NumberOfResources’.
Now, using the Search feature on the Project Home tab, find all the references to the ServerData table and change these references to the
new “Data” repeat group instead. You’ll often need to right click on a property name, select ‘Set Referenced Property’ and then select Data
from the list of properties that appear.
The Data Table named ServerData is no longer needed so this can be deleted.
C reate an External View
By Default, all the objects in the Facility window are set to be Externally Visible, which means that they will be part of the External View of
this object. If you have placed any status labels or floor labels, you might consider not having these be part of the External View. To
remove them from the External View, right click on the object in the Facility window and select Externally Visible, so that it is no longer
highlighted. Similarly, consider not having the static Resource object be visible in the External View. Right click on this object and select
Externally Visible.
To create the entry point into this model, you will need to create an External Node. Select the Basic Node at the beginning of this model
and right click. Select Bind To New External Input Node. Set the name to ‘Input’.
Similarly, select the Transfer Node at the end of this model and right click. Select Bind To New External Output Node. Set the name to
‘Output’. This creates an exit point for entities to travel out of this model.
Rename the model by right clicking on the object within the Navigation window in the top right of the Simio interface. Select Rename from
the right click drop down menu and name the model ‘SearchTable’.
Create the Main, Top Level Model
C reate a new Model, either within the same project or in another project. If you create a new model in another project, you’ll need to load this
submodel into the project by using the “Load Library” icon on the Project Home tab.
Facility window
Place a Source and a Sink and place two instances of the submodel in parallel between the Source and the Sink. C onnect the Source and
the Sink to both submodel instances with Paths. C hange the Interarrival Time of the Source to ‘Random.Exponential(3)’.
Data window
C reate two new Data Tables by clicking ‘Add Data Table’ from the ribbon. Name one table ‘ServerData’ and the other table ‘ServerNames’.
In ServerData, add three columns; a String Property column named “Name”, an Integer Property column named “NumberOfResources”
and an Expression Property column named “Hours”.
C lick on the Name column and select ‘Set C olumn as Key’ from the ribbon
Place the following data into the Table:
106 / 815
Server1,3,.1
Server2,2,.05
Server3,1,.02
In ServerNames, add two columns; an Object Reference column named “ServerNames”, and a Foreign Key column named ServerName
(click Foreign Key from ribbon). Set the Table Key property of the Foreign Key column to 'ServerData.Name'.
Place the following data into the Table:
Server1, SearchTable1.Server1
Server2, SearchTable1.Server2
Server3, SearchTable1.Server3
Server1, SearchTable2.Server1
Server2, SearchTable2.Server2
Server3, SearchTable2.Server3
Facility window
Back in the Facility window, click on one of the instances of SearchTable and find the new Data property. Open the Repeat Group by
clicking of the ellipse on the far right and hit Add when the new window pops up.
Right click on Hours and set this to ‘ServerData.Hours’.
Type in ‘ServerData.NumberOfResources’ into the NumberOfResources property.
Right click on ServerName and set this to ‘ServerNames.ServerNames’.
After closing the Repeat Group editor window, right click onto the Data property, select ‘Set Referenced Property’ and select
‘ServerNames’. This is telling the Data property to look to the ServerNames table.
Repeat the above steps for the second instance of the submodel.
See Also:
Open the SimBit named “SearchTableUponEnteringObject.spfx” to see details of how that model was built.
107 / 815
Simio Reference Guide
HourlyStatistic - SimBit
Problem:
I want to know the average number of Entities in a Server’s Input Buffer per hour of the simulation.
Categories:
Add-On Process Logic, Buffering, Building New Objects / Hierarchy, C ustom Statistics
Key Concepts:
Add-On Process, Hourly Statistics, TallyStatistic, Tally Step, Subclass, C ustom Object, Timer, MyServer
Assumptions:
We are only concerned with Hourly Statistics.
Technical Approach:
We will create a timer that will fire every hour and trigger a process to record the average value for that particular hour.
Details for Building the Model:
Simple System Setup
Place a Source, a Server, and a Sink in the Facility Window.
C onnect the Source to the Server, and the Server to the Sink with Paths.
C reating the States and Elements
In the Elements panel of the Definition tab, add a TallyStatistic and a Timer.
Name the TallyStatistic ‘HourlyAverage’ and the Timer ‘HourlyTimer’.
Keep the defaults for TallyStatistic.
C hange the Time Offset to ‘1 hour’ in the Timer.
In the States panel of the Definitions tab, add two Real States.
Rename the states to ‘AverageAtBeginning’ and ‘TimeAtBeginning’.
C reating the Assignment Process
In the Processes tab, click ‘C reate Process’ to add a new process to the model.
Rename this Process C alculateHourlyAve.
Set the Triggering Event to ‘HourlyTimer.Event’.
Place a Tally Step in the process.
Set the Tally Statistic Name to ‘HourlyAverage’.
Leave the Value Type as ‘Expression’ and set the Value to ‘(Server1.InputBuffer.C ontents.AverageNumberWaiting * Run.TimeNow -
AverageAtBeginning * TimeAtBeginning)/(HourlyTimer.TimeInterval)’.
Server1.InputBuffer.C ontents.AverageNumberWaiting returns the Average Number Waiting for the entire run, if you multiply by
Run.TimeNow you will get the total number of Entities that had to wait in the Input Buffer for the entire run. Next we then subtract
AverageAtBeginning (which we save each time) multiplied by the TimeAtBeginning to get the total number of Entities that had to wait in the
Input Buffer BEFORE this interval started. By subtracting the total number waiting before this interval from the total number waiting, you
get the total number waiting DURING this interval. Finally, to get the Average over that interval, we divide the Number Waiting during the
interval by the TimeInterval of the timer (which in this case is 1 hour).
Place an Assign Step in the process.
Assign the State Variable Name ‘AverageAtBeginning’ the New Value of ‘Server1.InputBuffer.C ontents.AverageNumberWaiting’.
Add another assignment that assigns ‘TimeAtBeginning’ the New Value of ‘Run.TimeNow’.
As seen in the previous Tally Step, these values will be used to determine the “old” number waiting for the entire run that will be
subtracted from the “new” number waiting to get the number waiting for that interval.
Embellishments:
This methodology is easy to implement when dealing with a small number of servers, but could become quite tedious when trying to implement
on a large scale – a separate TallyStatistic and AverageAtBeginning State would be needed for each Server.
To avoid having to do all of these manual assignments, we can move all of this logic (the Timer, Tally, States, and Process) into a sub-classed
Server. Everything is essentially the same except instead of Tallying/Assigning ‘Server1.InputBuffer.C ontents.AverageNumberWaiting’ we only
need to use the expression ‘InputBuffer.C ontents.AverageNumberWaiting’ because the process is referring to its Parent Object.
With all of the logic contained inside the MyServer, you just have to place the object in the Facility window and each MyServer will calculate the
Average Number Waiting itself. This is demonstrated within the UsingC ustomServer found in the Navigation window.
Also, the technique of Subtracting the old Total from the current Total Divided by a Time Interval will work for any length interval – it does not
have to be 1 hour. That is why we divide by ‘HourlyInterval.TimeInterval’.
108 / 815
Simio Reference Guide
ImportExportT ables - SimBit
Problem:
I would like to import data from a .csv file into a data table in Simio.
Categories:
Data Tables
Key Concepts:
Before C reating Entities, C onnector, Data Table, Export Table, Expression Property, Import Data, Numeric Property, Random.Discrete(), Server,
Source, Table Reference Assignments
Assumptions:
This example model is a simple source, server, sink model and the server gets its processing time by reading the data in this imported table.
Technical Approach:
It is recommended that before you import a table that you create an empty table that has the appropriate properties (columns) and then export
this table to a .csv file. After filling this table with data, the user can import this table into the empty table that was created in Simio.
Details for Building the Model:
Simple System Setup
Place a Source, Server and a Sink the Facility Window. C onnect the Source to the Server and the Server to the Sink with Paths.
Assigning Table Row Number
Within the Source object, within the Table Reference Assignments / Before C reating Entities section, enter a Table Name of ‘Table1’ and
the Row Number equal to ‘Random.Discrete(1, .25, 2, .5, 3, .75, 4, 1)’. This will assign the token a row number from a discrete distribution
to assign the values 1, 2, 3 and 4 with equal probability.
Adding a Data Table and Exporting Blank Table
In the Data Window, select the Tables panel and click on the Add Data Table icon from the ribbon. The main part of the window will appear
blank, but you will see a new tab created with the name of the new table (Table1, by default).
To add a column to this table, select Expression from the Standard Property drop down. C hange the Unit Type to ‘Time’ and the Default
Units to ‘Minutes’ so that our processing times may be specified in minutes.
C lick on the Export icon from the Table tab in the ribbon. Save the .csv file to the computer.
Importing Data to a Data Table
Open the .csv file in an editor, such as Excel, and add the appropriate data, keeping the column name untouched.
To import the data, the spreadsheet must first be ‘bound’ to the model. C lick on the ‘Bind To’ button in the Table ribbon, select C SV file
select the appropriate File Name. Then, select Binding Options from the Table ribbon and select Manual to manually import the data into
the table. The Import button will then be available to import the data from the spreadsheet into Simio.
Using the Data Table in the Server
In the Facility Window, set the Processing Time property of the Server to read ‘Table1.ExpressionProperty1’ (assuming you kept the
default name, ExpressionProperty1, of the expression property in the table).
109 / 815
Simio Reference Guide
InfectionP ropagationUsingC ontinuousAndFlow - SimBit
Problem:
I want to know how to model a continuous system or how to model System Dynamics. I want to know how to model a system of infection
propagation.
Categories:
C ontinuous Systems, Flow Library, Functions, Level States
Key Concepts:
Assign Step, Decide Step, Delay Step, FlowC onnector, Functions, Level State Variable, OnRun Initialized Process, System Dynamics, Tank
Technical Approach:
There are two models in this project, demonstrating two different ways to model this system. The model named, “UsingFlowObjects”
demonstrates how to model the system with objects from the standard flow library. There are four Tank objects, connected together with Flow
C onnectors. The contents in the first tank represent the total population, which is susceptible. The second tank represents the number of people
exposed to the infection. The flow nodes in between these tanks are set to allow flow at the rate of RateExposed, which is a function that
calculates the rate of exposure. The third tank represents the number of people who are infectious. The flow nodes in between Exposed and
Infectious allow flow at the rate of RateInfectious, which is a function that calculates the rate of infection. The fourth tank represents the number
of people who have recovered. The flow nodes between Infectious and Recovered allow flow at the rate of RateRecovered, which is a function
that calculates the rate in which people recover.
The model named, “UsingLevelStates” demonstrates how to model the system using Level State variables and one simple process. Instead of
having Tank objects represent the number of people in each stage, this model uses Level State variables (continuous variables). There are four
of these variables, representing Susceptible, Exposed, Infectious and Recovered. A process is called upon Run Initialized it assigns a new value to
these level state variables and then delays for one hour, after which the rates of the variables are updated again. Similar to the model using Flow
Objects, this model also uses Functions to calculate rates.
Details for Building the Model – UsingFlowObjects:
Adding Properties and Functions
Go to the Definitions window and into the Properties panel. C reate the following new Numeric properties, which will allow the user to input
information into the model regarding the population size and infection rates.
TotalPopulation – set the Default Value to ‘10000’, Unit Type to ‘Volume / C ubic Meters’.
Infectifity – set Default Value to ‘6’.
C ontactRateInfectious – set Default Value to ‘1.25’.
AverageIncubationTime – set Default Value to ‘10’ and Unit Type to ‘Time / Hours’.
AverageIllnessDuration – set Default Value to ‘15’ and Unit Type to ‘Time / Hours’.
C lick onto the Functions panel. C reate three new functions.
RateExposed –set the Expression to ‘Infectious.FlowC ontainer.C ontents.Weight * C ontactRateInfectious * Infectifity *
Susceptible.FlowC ontainer.C ontents.Weight / TotalPopulation’. Set the Return Type to ‘Number’ and the Unit Type to
‘VolumeFlowRate’.
RateInfectious – set the Expression to ‘Exposed.FlowC ontainer.C ontents.Weight / AverageIncubationTime’. Set the Return Type to
‘Number’ and the Unit Type to ‘VolumeFlowRate’.
RateRecovered – set the Expression set to ‘Infectious.FlowC ontainer.C ontents.Weight / AverageIllnessDuration’. Set the Return
Type to ‘Number’ and the Unit Type to ‘VolumeFlowRate’.
Adding Tanks to the Facility Window
In the Facility window, place four Tank objects from the Flow Library into the Facility window. Rename Tank1 to ‘Susceptible’, Tank2 to
‘Exposed’, Tank3 to ‘Infectious’ and Tank4 to ‘Recovered’. C onnect Susceptible to Exposed with a Flow C onnector, Exposed to Infectious
together with a Flow C onnector and Infectious and Recovered together with a Flow C onnector.
Select all four Tanks by holding down C TRL and clicking onto each Tank. Enter ‘TotalPopulation’ into the Initial Volume Capacity property of
the tanks.
C lick onto the Susceptible Tank and click into the Initial Contents property to indicate that there are initial contents in this Tank. In the
Repeating Property Editor, click Add to add a new row. The Entity Type property is ‘DefaultEntity’ and the Quantity property should be set
to ‘TotalPopulation – 1’.
C lick onto the Infectious Tank and click into the Initial Contents property to indicate that there are initial contents in this Tank. The Entity
Type property is ‘DefaultEntity’ and the Quantity property should be set to ‘1’.
Holding down the C TRL key, select the Output@Susceptible and the Input@Exposed and set the Maximum Flow Rate Equation to
‘RateExposed’. This rate will be dynamically updated every hour because the Update Interval on these nodes is set to ‘1’ hour, by default.
Holding down the C TRL key, select the Output@Exposed and the Input@Infectious and set the Maximum Flow Rate Equation to
‘RateInfectious’. This rate will be dynamically updated every hour because the Update Interval on these nodes is set to ‘1’ hour, by default.
Holding down the C TRL key, select the Output@Infectious and the Input@Recovered and set the Maximum Flow Rate Equation to
‘RateRecovered’. This rate will be dynamically updated every hour because the Update Interval on these nodes is set to ‘1’ hour, by
default.
Details for Building the Model – UsingLevelStates:
Adding States, Properties and Functions
Go to the Definitions window and into the States panel. C reate the following new Level State Variables by clicking onto Level in the ribbon.
Pop_Susceptible
Pop_Exposed
Pop_Infectious
Pop_Recovered
C lick into the Properties panel within the Definitions window. C reate the following new Numeric properties, which will allow the user to input
information into the model regarding the population size and infection rates.
110 / 815
TotalPopulation – set the Default Value to ‘10000’.
Infectifity – set the Default Value to ‘6’.
C ontactRateInfectious – set the Default Value to ‘1.25’.
AverageIncubationTime – set the Default Value to ‘10’ and the Unit Type to ‘Time / Hours’.
AverageIllnessDuration – set the Default Value to ‘15’ and the Unit Type to ‘Time / Hours’.
C lick onto the Functions panel. C reate three new functions.
RateExposed – set the Expression to ‘Pop_Infectious * C ontactRateInfectious * Infectifity * Pop_Susceptible / TotalPopulation’. Set
the Return Type to ‘Number’.
RateInfectious – set the Expression to ‘Pop_Exposed / AverageIncubationTime’ and the Return Type to ‘Number’.
RateRecovered – set the Expression to ‘Pop_Infectious / AverageIllnessDuration’ and the Return Type to ‘Number’.
Adding Steps in Processes Window
In the Processes window, open the Select Process drop down from the ribbon and select OnRunInitialized. This will create a new process
that is triggered at the beginning of the run.
Place an Assign Step into this process. This Assign step will have two assignments.
Set State Variable Name to ‘Pop_Susceptible’ and New Value to ‘TotalPopulation – 1’.
Add another assignment in this step by opening the Repeat Group for Assignments (More) and set State Variable Name to
‘Pop_Infectious’ and New Value to ‘1.
Place another Assign Step in this process. This Assign step will have four assignments.
Open the Repeat Group for Assignments (More) and set State Variable Name to ‘Pop_Susceptible.Rate’ and New Value to ‘-
RateExposed’.
C lick Add to add another assignment. Set State Variable Name to ‘Pop_Exposed.Rate’ and New Value to ‘RateExposed-
RateInfectious’.
C lick Add to add another assignment. Set State Variable Name to ‘Pop_Infectious.Rate’ and New Value to ‘RateInfectious-
RateRecovered’.
C lick Add to add another assignment. Set State Variable Name to ‘Pop_Recovered.Rate’ and New Value to ‘RateRecovered’.
Place a Delay step after the second Assign Step and set the Delay Time to ‘1’ (hour). Drag the segment leaving the Decide Step so that it
connects to the beginning of the second Assign step. This will tell the process logic to delay for one hour and then update the Assignments
in the second Assign step. It will therefore update the assignments every hour.
111 / 815
Simio Reference Guide
InitializeO bjectP ropertiesFromAT able - SimBit
Problem:
I have objects in my model that should get their initial property values from information in a Data Table.
Categories:
Data Tables
Key Concepts:
Auto-Set Table Row Reference, Data Table, Set Referenced Property
Technical Approach:
There are two Servers in this model and each Server will get some initial property values from a Data Table. The Data Table contains two rows;
one for each Server that exists in the model. The Table contains four properties (columns): an object instance property which contains the name
of each Server, an expression property which contains the Processing Time of each Server, another expression property which contains the
C apital C ost of each Server, and another object instance property that contains the name of a Worker object that this Server should seize during
processing. In order for each Server to know which row to look at in the Table, the first object instance property (column) that contains the name
of the Server, must have its Auto-set Table Row Reference property set to ‘True’. This tells Simio that the object contained in this column will
automatically have a row reference set to this table and therefore we can reference the data contained in this table in the properties of each
Server instance in the model.
Details for Building the Model:
Simple System Setup
Place a Source and Sink into the Facility window. Place two Server objects, in parallel and connect the Source to both Servers with Paths
and connect each Server to the Sink with paths.
Place four Basic Nodes in the center of the model so that they form a diamond shape. BasicNode1 is right below Server1, BasicNode2 is
right above Server2, BasicNode3 is at the left point of the diamond and BasicNode4 is on the left point of the diamond. C onnect these
nodes together with Paths so the Worker can travel from node to node in a circular pattern.
Place two Worker objects into the Facility window. Set the Initial Node property of Worker1 to ‘BasicNode3’ and its Idle Action property to
‘GoToHome’. Set the Initial Node property of Worker2 to ‘BasicNode4’ and its Idle Action property to ‘GoToHome’.
C reate the Data Table
Go to the Data Window and click Add Data Table to create a new Table.
From the Object Reference drop down in the ribbon, select Object to create a new column. Rename this column ‘ServerName’.
From the Standard Property drop down in the ribbon, select Expression to create a new column. Rename this column
‘ProcessingTime’. In the Properties of this new column, set the Unit Type property to ‘Time’ and the Default Units property to
‘Minutes’.
From the Standard Property drop down in the ribbon, select Expression to create a new column. Rename this column ‘C apital C ost’.
From the Object Reference drop down in the ribbon, select Object to create a new column. Rename this column ‘Worker’.
Fill in the following data into the new Table:
Row 1: Server Name = ‘Server1’, ProcessingTime = ‘Random.Triangular(.3, .4, .6)’, C apitalC ost = ‘2000’, Worker = ‘Worker1’.
Row 2: Server Name = ‘Server2’, ProcessingTime = ‘.5’, C apitalC ost = ‘1000’, Worker = ‘Worker2’.
C lick onto the first column, ServerName, so that you see its properties appear in the property window on the lower right side of the
interface. Under the Advanced Options property category, set the Auto-set Table Row Reference property to ‘True’.
C onfigure Server to Read Table
Go to the Facility window and select Server1. Expand the Financials Property category and right click into the Capital Cost property of this
Server and select ‘Set Referenced Property’. From the options available, find Table1.C apitalC ost and select this so that the Capital Cost
property now gets its value from Table1.C apitalC ost.
Right click into the Processing Time property of this Server and select ‘Set Referenced Property’. From the options available, find
Table1.ProcessingTime and select this so that the Processing Time property now gets its value from Table1.ProcessingTime.
Expand the Secondary Resources property category and expand the Resource for Processing sub-category. Right click into the Object
Name property and select ‘Set Referenced Property’. From the options available, find Table1.Worker and select this so that the Object
Name property now gets its value from Table1.Worker.
Set the Request Move property to ‘To Node’ and set the Destination Node property to ‘BasicNode1’. Visually seeing the Worker move to the
Server will help validate that the Server is getting the correct information from the Table.
Exactly repeat the above four bullet points for Server2, except for the Destination Node property, set this to ‘BasicNode2’ instead so that
the Worker moves to the node above Server2.
Embellishments:
Notice that this SimBit contains floor labels that display the property values of each Server to visually validate to the user that each Server is
getting the correct information from the Data Table.
112 / 815
Simio Reference Guide
InterruptibleO perator - SimBit
Problem:
I would like to model a system with 2 Servers and a movable operator that needs to be present at the server for processing and be able to
interrupt the processing of a lower priority job for a higher priority job.
Categories:
Decision Logic -- Processing
Key Concepts:
Add-On Process, Allow Passing, Assign Step, BasicNode, Bidirectional Path, C urrent Symbol Index, Filter Expression, Initial Desired Speed,
Interrupt Step, Interrupted Process Action, Largest Value First, ModelEntity, Processing, After Processing, Path, Priority, Ranking Expression,
Ranking Rule, Release Step, Request Move, ResumeDelay, Seize Step, Server, Time Offset, Value Expression, Vehicle
Assumptions:
The interrupted part is allowed to remain in the processing station until the operator returns. Upon processing for the second time the job only
requires the remaining processing time, no set-up or tear-down time.
Technical Approach:
Upon the arrival of a high priority job, the server will attempt to seize the operator. If the operator is already seized, the job that is being
processed is interrupted. The server releases the operator which is then seized by the high priority job’s server. After the operator is finished
processing all the high priority jobs, it is then released and re-seized by the low priority job. Once the operator returns, the only processing time
remaining on that entity is the remaining processing time that was not executed before the interruption.
Details for Building the Model:
Simple System Setup
Drag in 2 Sources, 2 Servers, and 2 Sinks to the Facility View. Arrange them in two Source-Server-Sink sets and place a Basic Node next
to each Server.
C onnect the Source-Server-Sink sets with unidirectional Paths and change Allow Passing to 'False' in the Paths going from Source to
Server. C onnect the Basic Nodes with a bidirectional Path. C lick on BasicNode1 and attach ParkingStation.C ontents queue, because this will
be the Initial Node.
Defining a Vehicle
Drag a standard Vehicle into the Facility window. C hange its Desired Speed to ‘0.1 Meters per Second’. Set the Initial Node to ‘BasicNode1'.
Set its Ranking Rule to ‘Largest Value First’, with a Ranking Expression of ‘ModelEntity.Priority’.
Altering Entities
Drag two ModelEntities into the Facility window and name them ‘HighPriorityJob’ and ‘StandardJob’.
C hange the color of HighPriorityJob to red and set its Initial Priority to ‘3.0’.
Add an additional symbol to StandardJob and change the second symbol’s color to yellow. Set their Desired Speed properties to ‘0.2
Meters per Second’.
Defining Fixed Objects
C hange the Entity Type property in Source2 to ‘StandardJob’. Set the Interarrival Time to ‘Random.Exponential(30)’ minutes and Entities
Per Arrival to ‘2’.
C hange the Time Offset, as well as the Interarrival Time, in Source1 to ‘Random.Exponential(50)’.
Both Server1 and Server2 should have their Initial Capacity property set to ‘Infinity’, Processing Time property set to
‘Random.Triangular(10,20,30)’, and Input Buffer Capacity property set to ‘1’.
Adding Process Logic for Seizing and Releasing the Vehicle
In Server2, create a process in the Processing add-on process trigger. Add a Seize step in this process. Have this step seize Vehicle1.
C lick on the “…” button to open the Repeating Property Editor. C lick the Add button and choose ‘Vehicle1’ for the Object Name. C hange
Request Move from ‘None’ to ‘ToNode’ and the Destination Node to ‘BasicNode2’.
Also in Server2, create a process in the After Processing add-on process trigger. Add a Release Step that releases Vehicle1. C lick the “…”
button next to Releases in the Property window to open the Repeating Property Editor. C lick the Add button and select ‘Vehicle1’ from the
drop down list next to Object Name.
Similarly, you can do the exact same thing for Server1 (or you can re-use the process named Server2_AfterProcessing and eliminate this
step, if preferred). Add a Release Step that releases Vehicle1. C lick the “…” button next to Releases in the Property window to open the
Repeating Property Editor. C lick the Add button and select ‘Vehicle1’ from the drop down list next to Object Name.
Adding Process Logic for Interruption
To set the Interrupting logic, create a process in Server1’s Processing add-on process trigger. Place an Interrupt Step to interrupt the
activity taking place at the other server (Server2). Select the Process Name to ‘Server2.OnEnteredProcessing’ from the drop down list.
C hange the Interrupted Process Action to ‘ResumeProcess’.
On the Original segment leaving the Interrupt step, place a Seize step that seizes Vehicle1. Open the Repeating Property Editor in the
Seizes property. In the Editor, select ‘Vehicle1’ from the drop down list next to Object Name. C hange the Request Move to ‘ToNode’ with
Destination Node ‘BasicNode1’.
On the Interrupted segment leaving the Interrupt step, place an Assign step that changes the picture of the interrupted entity. Set the
State Variable Name to ‘ModelEntity.Picture’, the New Value to ‘1’.
Add an additional Assignment to increase the interrupted Entity’s priority by opening the Repeating Property Editor of the Assign Step. Add
a new Item with State Variable Name set to ‘ModelEntity.Priority’ and set its New Value to ‘2’. This gives the interrupted entity higher
priority than an uninterrupted StandardJob so that it can resume processing on this particular job but still lower Priority than a
HighPriorityJob so it can be interrupted if need be.
After the Assign on the interrupted segment, add a Release step and select Vehicle1 in the Repeating Property Editor. This releases the
vehicle from Server2 and allows it to be seized by a HighPriorityJob.
Place a Seize step, seize Vehicle1 in the Repeating Property Editor. Set Request Move to ‘ToNode’ with Destination Node set to
‘BasicNode2’. This puts the interrupted server back in the vehicle’s queue list of objects that are trying to seize it, so that as soon as it
become free it will return to Server2 to complete processing.
113 / 815
Finally, add an Assign step changing the picture back to the original green color to signify processing has resumed. To do this, set the State
Variable Name to ‘ModelEntity.Picture’ with a New Value of ‘0’.
See Also:
InterruptingAcrossMultipleServers and InterruptingServerWithMultipleC apacity.
114 / 815
Simio Reference Guide
InterruptingAcrossMultipleServers - SimBit
Problem:
I have multiple entities with different priorities and multiple servers. If all servers are busy, I want to be able to interrupt the processing at a
server processing a lower priority entity.
Categories:
Decision Logic -- Processing
Key Concepts:
Add-On Process, Allow Passing, BasicNode, Blocked Destination Rule, C andidate, C ondition Based, C onnector, Decide Step, Entity, Entity
Destination Type, Filter Expression, Interrupt Step, Largest Value First, Last Seized, On C reating Entities, On Entered, OnEnteredProcessing, Path ,
Priority, Ranking Rule, Real State Variable, Release Order, Release Step, ResourceState, Save Remaining Time, Select Available Only, Selection
Rule, Smallest Value First, Source, Transfer Step, TransferNode, Value Expression
Assumptions:
All entities wait at one spot for an available server. All interrupted entities wait in the same FIFO queue.
Technical Approach:
All entities go to a single node with routing logic to select an available server. If all servers are busy and the entity that is attempting to enter the
server has a higher priority than at least 1 entity being processed, then the lower priority entity is interrupted (with its remaining processing time
saved) and routed back to the entry node.
Details for Building the Model:
Simple System Setup
Place 3 Sources, 3 Servers, 3 Entities, a Sink, a Basic Node and a Transfer Node into the Facility Window. Position the Sources so that they
are aligned vertically and align the Servers similarly.
Rename the entities ‘LowPriority’, ‘MediumPriority’, and ‘HighPriority’.
C hange the color of HighPriority to red and its Initial Priority to ‘3.0’. C hange the color of MediumPriority to yellow and its Initial Priority to
‘2.0’. Also, add an additional symbol and change its color to a slightly different shade of yellow. For LowPriority, keep the Initial Priority at
‘1.0’ and the color green, but add an additional symbol and change its color to a light green.
Position the Transfer Node in between the Sources and the Servers. All Sources will be sent here first and then to a Server.
Rename BasicNode1 ‘ReRoute’. Position this node above the set of Servers. This node will act as the exit point for the interrupted jobs that
have to be removed.
Draw paths going from the Sources to the Transfer Node, as well as from ReRoute to the Transfer Node. Set the Allow Passing property to
‘False’ for these paths to allow them to queue up at the Transfer Node.
C onnect the Transfer Node to the Servers using C onnectors and connect the Servers to the Sink with Paths.
Modifying Library Objects
Add a Discrete State to the ModelEntity called ‘ProcessingTime’. To do this, click on ModelEntity in the Navigation window. C lick on
Definitions Tab, then States. Add a Discrete State, and then change the name to ‘ProcessingTime’.
Go back to the Navigation window and change to the Model for the following steps.
To select nodes and servers from a list, go to the Definitions tab and then to Lists panel. Add a Node List with name of ‘ServerInputNodes’
with the nodes Input@Server1, Input@Server2, and Input@Server3.
Add an Object List and name it ‘ServerList’ with the objects Server1, Server2 and Server3.
Rename the Sources ‘LowPrioritySource’, ‘MediumPrioritySource’, and ‘HighPrioritySource’.
Modify the LowPriority Source so that it has an Entity Type of ‘LowPriorityJob’, Time Offset of ‘Random.Exponential(.5)’ and Interrarrival
Time of ‘Random.Exponential(1)’.
Modify the MediumPrioritySource so that is has an Entity Type of ‘MediumPriorityJob’, Time Offset of ‘Random.Exponential(2)’, and
Interrarrival Time of ‘Random.Exponential(2)’.
Modify the HighPrioritySource so that is has an Entity Type of ‘HighPriorityJob’, Time Offset of ‘Random.Exponential(3)’, and Interrarrival
Time of ‘Random.Exponential(3)’.
Assigning Processing Time
Within the Processes window, create a New Process and name it ‘AssignProcessingTime’.
Place an Assign step in the process and set the State Variable Name to ‘ModelEntity.ProcessingTime’, New Value is
‘Random.Triangular(.8,1.5,3)’ and Units is ‘Minutes’.
Enter this process name in the all three Servers’ Created Entities Add-On Process Trigger property.
Set all of the Servers’ Processing Time properties to ‘ModelEntity.ProcessingTime’. Also, change their Input Buffer properties to ‘0’.
TransferNode1 Routing Logic
TransferNode1 needs to route jobs based on their priorities and only to servers with open processing stations. C hange the Ranking Rule to
‘Largest Value First’, the Entity Destination Type to ‘Select From List’, the Node List Name to ‘ServerInputNodes’ and the Blocked
Destination Rule to ‘Select Available Only’.
Interruption Process Logic
Place a Decide step to determine if the Server is available. C hange the Decide Type to ‘C ondition Based’, and Expression to
‘((Server1.ResourceState + Server2.ResourceState + Server3.ResourceState) < 3) || (ModelEntity.Priority==1.5)’. If the Server is busy,
the Server*.ResourceState will return a value of 1. Therefore, if the sum of the ResourceStates is less than 3, there is an open spot and
the entity can be processed as usual. Or, if the entity that entered the node has a Priority of 1.5, that means it’s a LowPriority Entity and
should interrupt anything.
From the False exit, add an Interrupt step and change the Process Name to ‘Server1.OnEnteredProcessing’, the Selection Rule to ‘Smallest
Value First’ and the Filter Expression to ‘C andidate.Entity.Priority < Entity.Priority’.
In the Interrupt step Advanced Options, add 2 more processes in Process Names (More): including Process Name of
‘Server2.OnEnteredProcessing’ and Process Name of ‘Server3.OnEnteredProcessing’. C hange the Save Remaining Time property to
‘ModelEntity.ProcessingTime’. Important note that the Save Remaining Time property saves the value in ‘Hours’, so we will need to convert
back to minutes within an Assign step.
115 / 815
On the Interrupted exit, place an Assign step and change the State Variable Name to ‘ModelEntity.Picture’, New Value to ‘1’ and make
another assignment under Assignments (More) of State Variable Name called ‘ModelEntity.Priority’, and New Value of ‘ModelEntity.Priority +
.5’.
Next, place a Release step and change the Object Type to 'FromList', Object List Name to ‘ServerList’ and Release Order to ‘LastSeized’.
Lastly, add a Transfer step after the Assign step and change the From to ‘C urrentStation’, To to ‘Node’ and Node Name to
‘RerouteBackToWorkcellEntry’.
Embellishments:
In this model all interrupted entities wait on the same path with a FIFO selection method. This is because they are waiting on the same path and
only the first entity is being evaluated at the Transfer Node, all the other entities are still waiting to arrive to the node. This means that if a
LowPriorityJob is in front of a MediumPriorityJob, MediumPriorityJob would have to wait for the LowPriorityJob to be processed before being
considered. To correct this, add another path with Allow Passing set to ‘False’. C hange the Outbound Link Rule in the BasicNode to ‘By Link
Weight’. Set the Link Weight for one Path to ‘ModelEntity.Priority == 1.5’ and ‘ModelEntity.Priority == 2.5’ for the other. This will now allow both
types of entities to be present at the Node at the same time, correcting the selection logic.
See Also:
InterruptibleOperator and InterruptingServerWithMultipleC apacity.
116 / 815
Simio Reference Guide
InterruptingServerW ithMultipleC apacity - SimBit
Problem:
I have a server with capacity of three and I would like a higher priority job to be able to interrupt the processing of one of the lower priority jobs
currently being processed, and move the interrupted job back into the input buffer to complete processing later.
Categories:
Decision Logic -- Processing
Key Concepts:
Add-On Process, Assign Step, Before Exiting, C andidate, C apacity.Remaining, Decide Step, Entity, Filter Expression, From C urrent Station,
Interrupt Step, Largest Value First, On Entered, OnEnteredProcessing, Priority, Ranking Rule, Release Step, Save Remaining Time, Selection Rule,
Server, Smallest Value First, Source, State Assignments, Transfer Step, Value Expression
Assumptions:
All entities have the same Processing Time distribution and the remaining process time will be saved.
Technical Approach:
When the entity arrives to the Server, it looks at the server and sees if there is any remaining capacity. If not, the entity will interrupt any entity
with a lower priority than itself. If the arriving entity has the same or lower priority than the three entities being processed it will enter the Input
Buffer and wait for one of the entities to finish processing.
Details for Building the Model:
Simple System Setup
Drag in a Source, Server, and Sink. C onnect them all with C onnectors.
Drag in three Entity Instances and rename them ‘LowPriorityJob’, ‘MediumPriorityJob’, and’ HighPriorityJob’.
C hange the color of HighPriorityJob to red and its Initial Priority to ‘3.0’, MediumPriorityJob to yellow and its Initial Priority to ‘2.0’, and add
an additional symbol to LowPriorityJob and change the additional symbol to a light green, but leave its Initial Priority ‘1.0’.
Set Interarrival Time in Source1 to ‘Random.Exponential(.6)’ minutes.
C reating Multiple Entities from One Source
Add a Data Table in the Data tab and name it ‘JobMix’. Add a Real Property called ‘Percentage’ and an Entity Object Reference Property
called ‘EntityType’. Fill in the table so that it looks like:
Percentage----EntityType
70 -------------LowPriorityJob
30 -------------MediumPriorityJob
10 -------------HighPriorityJob
In Source1, set Entity Type to ‘JobMix.EntityType’.
Expand the Table Reference Assignment properties and set the Table Name to ‘JobMix’ and Row Number to
‘JobMix.Percentage.RandomRow’.
Assigning Process Time to Entities
In the ModelEntity’s Definitions tab, add a Discrete State called ‘ProcessingTime’.
Then, within the model Facility window, in the Source, create a new process in the C reated Entity add-on process trigger and add an
Assign step. In the step set State Variable Name to ‘ModelEntity.ProcessingTime’ and New Value to ‘Random.Triangular(1,2,3)’.
Modifying Server1
Drag Server1’s Input Buffer below and resize it so that it is approximately 4 servers long so that you can see the activity.
C hange the Server’s Initial Capacity to ‘3’.
Set the Ranking Rule to ‘Largest Value First’ with a Ranking Expression of ‘Entity.Priority’.
C hange to Processing Time to ‘ModelEntity.ProcessingTime’.
Process Logic for Interrupting
On the Server, add an Add On Process Trigger to Entered to interrupt processing.
Place a Decide step to determine if the Server is Available. The Decide Type is ‘C onditionBased’ with the Expression
‘Server1.C apacity.Remaining > 0’. If this is True, interruption is not necessary and no further action is needed.
If it is False, it means that the Server is full and if the Entity has a higher Priority than any one entity on the Server then we need to
interrupt processing. So we place an Interrupt step on the False Branch with the following changes:
In General Options, change Process Name to ‘Server1.OnEnteredProcessing’, Selection Rule to ‘Smallest Value First’ (This interrupts the
entity with the smallest priority), Value Expression to ‘C andidate.Entity.Priority’, and Filter Expression to ‘C andidate.Entity.Priority <
Entity.Priority’ (Ensures that the entity the Server is considering interrupting has a lower priority than the one that just entered the
Server).
In Advanced Options, set Save Remaining Time to ‘ModelEntity.ProcessingTime’. The Server will now use remaining processing time the
next time it evaluates ModelEntity.ProcessingTime.
On the “Interrupted” branch, place an Assign step to change to picture of the interrupted entity. State Variable Name is ‘ModelEntity.Picture’
and New Value is ‘1’. (The “Original” branch is for the higher priority Entity so it will be processed as usual, so therefore no steps are
needed.)
After the Assign, place a Release step releasing Server1. C lick on the “…” button and select ‘Server1’ from the Object Name drop down
list.
Then, place a Transfer step to transfer the entity back into the input buffer. C onfigure the Transfer Step so that From is set to
‘C urrentStation’, To to ‘Station’, and Station Name to ‘Server1.InputBuffer’.
See Also:
InterruptibleOperator and InterruptingAcrossMultipleServers
117 / 815
C opyright 2006-2015, Simio LLC . All Rights Reserved.
118 / 815
Simio Reference Guide
InputAnalysis - SimBit
Problem:
Because I am lacking enough real-world data for my model, I want to use Input Analysis and Response Sensitivity to determine whether my
models arrival rates or processing time have the biggest impact on the model responses (Time In System and Number In System).
Based on the limited number of real-world data inputs for Arrival Times and Processing Time in my model, I want to use Input Analysis and
Sample Size Error to determine which inputs have the biggest contribution to my output errors on the model responses.
Categories:
Input Analysis
Key Concepts:
Input Parameters, Data, Analysis, Experiment, Response Sensitivity, Sample Size Error
Technical Approach:
There are two models in the project, each demonstrating a different aspect of Input Analysis. .Both models include a simple 2 Source-Server-
Sink logic to illustrate this input analysis features. Three Input Parameters are defined which will be used to measure the effect of the changes in
Arrival Rates and Processing Time on the Number in System and Time in System.
In the first model, titled “ResponseSensitivity”, the input parameters include the distribution type, but no information on the number of data
samples for the data sets. In this model, the Response Sensitivity analysis within the experiment will be used.
The second model, titled “SampleSizeError”, includes the same input parameters, but additional information regarding the sample sizes for the
distributions. It is assumed that each of the Input Parameter distributions have been derived based on a sample size of 100. In this model, the
Sample Size Error analysis within the experiment will be used.
Details for Building the Model - ResponseSensitivity:
Simple System Setup
Place two Sources, a Server and a Sink object in the Facility window. C onnect each Source to the Server and the Server to the Sink object
using a Path.
Defining Input Parameters
In the Data window, select the Input Parameters panel button and add 3 Distribution parameters. Name them ‘Arrival1’, ‘Arrival2’, and
‘ProcessingTime’ respectively. For Arrival1, change the Distribution Type to ‘Exponential’ with a Mean of ‘10’. Set the Unit Type to ‘Time’
and the Units to ‘Minutes’. Do the same for Arrival2 but change the Mean to ‘12’.
For ProcessingTime, set the Distribution Type to ‘Triangular’ with a Minimum, Mode and Maximum set to ‘8’, ‘10’ and ‘12’ respectively.
C hange the Unit Type to ‘Time’ and change the Units to ‘Minutes’.
In the Facility window, on the Server object, change the Processing Time to ‘ProcessingTime’. On Source1 change the Interarrival Time to
‘Arrival 1’. On Source2 change the Interarrival Time to ‘Arrival2’.
Defining the Experiment – ResponseSensitivity
In the Navigation window, right click on Model and select ‘New Experiment’.
In the Experiment window, click on the Design ribbon and select Add Response.
Name the Response ‘TimeInSystem’ and on this response add the Expression as ‘DefaultEntity.Population.TimeInSystem.Average’, change
the Unit Type to ‘Time’ and the Display Units to ‘Minutes’.
Add another Response. Name this ‘NumberInSystem’. C hange the Expression to ‘DefaultEntity.Population.NumberInSystem.Average’.
In the Experiment Properties window, change the Default Replications to ‘100’.
Analyzing the Results – ResponseSensitivity
From the Experiment window, Design ribbon, select Run. Once the runs have completed, click on the Input Analysis tab and then select
Response Sensitivity on the panel.
A Tornado C hart with be displayed which will show each inputs sensitivity coefficient for each response. You can select which response to
view from the pull-down list in the upper left corner. Select TimeInSystem from the pull-down list if it isn’t already displayed. What can be
inferred here is that an increase in the ProcessingTime has the most impact on the TimeInSystem of the entities.
Select NumberInSystem from the pull-down list and you can infer the same. However, for the NumberInSystem, there is very little
difference between an increase in ProcessingTime and a decrease in Arrival1. C lick on the Bar C hart tab at the bottom of this window.
Here you can see the percentage of impact each input has on each response.
Details for Building the Model - SampleSizeError:
Simple System Setup
Place two Sources, a Server and a Sink object in the Facility window. C onnect each Source to the Server and the Server to the Sink object
using a Path.
Defining Input Parameters
In the Data window, select the Input Parameters panel button and add 3 Distribution parameters. Name them ‘Arrival1’, ‘Arrival2’, and
‘ProcessingTime’ respectively. For Arrival1, change the Distribution Type to ‘Exponential’ with a Mean of ‘10’. Set the Unit Type to ‘Time’
and the Units to ‘Minutes’. C hange the Number of Data Samples to ‘100’ and set Include in Sample Size Error Analysis to ‘True’. Do the
same for Arrival2 but change the Mean to ‘12’.
For ProcessingTime, set the Distribution Type to ‘Triangular’ with a Minimum, Mode and Maximum set to ‘8’, ‘10’ and ‘12’ respectively.
C hange the Unit Type to ‘Time’ and change the Units to ‘Minutes’. C hange the Number of Data Samples to ‘100’ and set Include in Sample
Size Error Analysis to ‘True’.
In the Facility window, on the Server object, change the Processing Time to ‘ProcessingTime’. On Source1 change the Interarrival Time to
‘Arrival 1’. On Source2 change the Interarrival Time to ‘Arrival2’.
Defining the Experiment – SampleSizeError
In the Navigation window, right click on Model and select ‘New Experiment’.
In the Experiment window, click on the Design tab and select Add Response.
119 / 815
Name the Response ‘TimeInSystem’ and on this response add the Expression as ‘DefaultEntity.PopulationTimeInSystem.Average’, change
the Unit Type to ‘Time’ and the Display Units to ‘Minutes’.
Add another Response. Name this ‘NumberInSystem’. C hange the Expression to ‘DefaultEntity.Population.NumberInSystem.Average’.
C hange the Default Replications on this experiment to ‘100’.
Analyzing the Results – SampleSizeError
From the Experiment window, select the Design tab and select Run.
Once the runs have completed, select the Input Analysis tab and click on Sample Size Error panel button.
You must first click on Run Analysis button within the Sample Size Error ribbon. Once the runs have completed, a chart will appear that will
display the C ontribution to Uncertainty for Scenario1. This shows which inputs have the biggest contribution to the response. What can be
inferred here is that Arrival1’s uncertainty has the biggest impact on the TimeInSystem. The SMORE plot below the chart illustrates the
standard confidence interval for the mean (in tan) and the expanded half width due to input uncertainty in blue. As we can see from this
graph we have more input uncertainty than experimentation uncertainty in this example.
The second bar chart, Benefit of Additional Samples, shows the relative benefit of collecting additional data for each input parameter. In
many cases, such as in this example, the bar chart will appear similar to the relative C ontribution to Uncertainty bar chart. We would not
expect this to be the case if the Number of Data Samples properties of the Input Parameters were widely different.
120 / 815
Simio Reference Guide
KeepingW orkerR eserved - SimBit
Problem:
I would like for the same vehicle or worker to perform both transport and processing tasks for a particular entity as it moves through the system.
Categories:
Animation, Entity C haracteristics, Decision Logic – Processing, Worker
Key Concepts:
C onnector, Keep Reserved If, Path, Ride On Transporter, Secondary Resources, Server, Sink, Source, Worker
Assumption:
The worker or vehicle can only have a ride capacity of ‘1’ to be reserved, otherwise a runtime warning will be issued.
Technical Approach:
The nurse (worker) will be used to transport entity from Source to first Server and then be used for processing at the Server. Upon completion of
processing, the same nurse (worker) will transport the entity to the next Server and again be used for processing and transport to the Sink. The
Keep Reserved If property within the TransferNode (for transport tasks) and within the Server (for processing tasks) will be set to ‘True’ (or value
of ‘1’).
Details for Building the Model:
Simple System Setup
Place a Source, two Servers and a Sink within the Facility window. C onnect Source1 to Server1, Server1 to Server2 and Server2 to Sink
with Paths. C onnect the Sink back to the Source with a Path.
Within the Source1, change the Interarrival Time to ‘Random.Exponential(.3)’ minutes.
C onnect the input node of each Server to the output node of the same Server with C onnectors. This will allow the Worker to travel both
to/from the Servers.
Place a ModelEntity from the Project Library and rename it ‘Patient’.
Place a Worker in the Facility window and rename it ‘Nurse’. C hange the Park While Busy property to ‘True’. Specify the Initial Node
(Home) location as Output@Source1 and the Idle Action to ‘Go To Home’ so that any idle workers will return to the Source. Specify the
Initial Number in System as ‘3’ so that there are 3 Nurses.
Using the Worker for Transport Tasks
Within the output nodes of the Source, Server1, and Server2, change the Ride On Transporter to ‘True’ and the Transporter Name to
‘Nurse’. Within the Source1 and Server1 output nodes, specify the Keep Reserved If property as ‘True’. This will cause the Nurse, upon
dropping off the entity at its destination location, to be ‘reserved’ so that it may immediately be used then for processing at the server.
Using the Worker for Processing Tasks
Within the Server1 and Server2, change the Processing Time to ‘Random.Triangular(.2,.3,.4)’ minutes and the Input Buffer capacity to ‘0’.
Within the Secondary Resources section of properties, specify the Object Name as ‘Nurse’. Specify the Keep Reserved If property as ‘True’.
This will cause the Nurse, upon completion of the processing task, to be ‘reserved’ so that it may immediately be used then for transport to
the next location.
Enhancement:
In this example, there are status label graphics attached to both the ModelEntity and Worker objects. Use the Entity.ID function to return
information specific to the entity (i.e, String.Format("P#{0}", Entity.ID)) or the Entity.Population.Index function for information on the specific
Worker (String.Format("Nurse#{0}", Entity.Population.Index)).
121 / 815
Simio Reference Guide
KeepQ ueueT imeForLast10Entities - SimBit
Problem:
I want keep an updated value for the total queue time for the last ten (10) entities in a Server queue.
Categories:
Add-On Process Logic, Buffering, C ustom Statistics, Entity C haracteristics
Key Concepts:
Add-On Process, Before Processing, C reate Step, Decide Step, Destroy Step, Entered, Insert Step, ModelEntity, Real State Variable, Remove
Step, Search Step, Status Label, Status Plot, Storage Element, Storage Queue
Assumption:
The total queue time of entities in the queue is only calculated once there are ten values accumulated. From then, the calculation is done on the
ten most recent entities in the queue. If the entity does not wait at all, a value of zero is recorded and is included in the total.
Technical Approach:
When an entity enters the Server, its ModelEntity.TimeInQueue is set to the current simulation time. Once the entity has been allocated the Server
capacity, a copy of that entity is created that will be stored in a storage queue so that statistics may be calculated. Once ten copy entities are in
the storage, the queue is searched and time in queue time calculated. Each time a new entity enters (after the first 10), the first entity is then
removed from the storage and system.
Details for Building the Model:
Simple System Setup
Place a Source, a Server and a Sink from the Standard Library into the Facility window. Use Paths to connect the Source to the Server and
the Server to the Sink.
Adding a New State to ModelEntity
Within the Navigation window, click on ModelEntity. Within the ModelEntity Definitions window, click on the States panel and add a new Real
type State with the Name ‘TimeInQueue’. This will be referenced as ModelEntity.TimeInQueue in the main model.
Go back to the Model and within the Facility window, place a ModelEntity from the Project Library. While this object is highlighted, click on
the Symbols ribbon and place a Status Label (attached) to the entity. This should automatically say Attached To ‘DefaultEntity’ and then
add the Expression ‘TimeInQueue’ This way, when each entity instance moves through the system, you can see its time in queue
calculation.
Define a New State and Element for the Model
Within the Definitions window, Elements panel, add a new Storage type element with the Name ‘Storage1’. This will be used to ‘store’ all
the 10 entity copies for waiting time calculations.
Also within the Definitions window, click on the States panel and add a new Real type state with the Name ‘TotalWait’.
Adding Logic to the Server To C alculate Queue Times
Within the Server, add a new process to the Entered Add-On Process Trigger named ‘Server1_Entered’. Within the Processes window, add
an Assign step to this process. The State Variable Name should be ‘ModelEntity.TimeInSystem’ and the New Value should be
‘Run.TimeNow’. This will “mark” the time that the entity entered the queue for the server with the current simulation time which will be re-
calculated later.
Go back to the Facility window and again within the Server, add a process name to Before Processing of ‘Server1_BeforeProcessing’.
Within this process add the following steps:
C reate step with Create Type of ‘C opyAssociatedObject’ and Object Instance Name of ‘DefaultEntity’.
From the C reated exit of the C reate step, add an Assign step. The State Variable Name should be ‘ModelEntity.TimeInQueue’ and
the New Value should be ‘Run.TimeNow – ModelEntity.TimeInQueue’. This re-calculates the state to be the actual waiting time.
Next, add an Insert step with the Queue State Name of ‘Storage1.Queue’. Add a Decide step with the Decide Type of
‘C onditionBased’ and an Expression of ‘Storage1.Queue.NumberWaiting == 10’. This will allow us to only calculate the total wait
time once there are ten entities in the queue.
Add a Search step to the process from the True exit of the Decide step. The Collection Type is ‘QueueState’, the Queue State Name
is ‘Storage1.Queue’ and the Search Expression is ‘C andidate.ModelEntity.TimeInQueue’. The sum of this expression for the found
items in the queue will be stored in the ReturnValue state of the original executing token (i.e., Token.ReturnValue). The Limit in
Advanced Options should be set to ‘10’ so that we get the sum of all ten items in the queue.
From the Original exit of the Search step, add an Assign step that will assign the State Variable Name 'TotalWait' to the New Value
‘Token.ReturnValue’ (as discussed above).
Now that the calculation is done, we will remove the first entity in the queue so that when the next entity copy enters, the
calculations will be done correctly. This is done by using another Search step to get a pointer to the correct entity. The Collection
Type is ‘QueueState’ and the Queue State Name is ‘Storage1.Queue’. Note that the Limit remains the default value of ‘1’, as we want
a pointer to the first entity found in that queue.
From the Found exit of the Search step, add a Remove step with the Queue State Name of ‘Storage1.Queue’ and then from the
Removed exit of the step, place a Destroy step, with Destroy Type of ‘AssociatedObject’ which will dispose of the copied
entity/token that is no longer needed.
122 / 815
Simio Reference Guide
LearningC urveW ithLookup - SimBit
Problem:
I have a machine that increases its efficiency subject to a learning curve function.
Categories:
Lookup and Rate Tables
Key Concepts:
Lookup Table, Learning C urve, Linear Interpolation, Server, Status Plot
Assumptions:
The Server starts at 20% effective. After 12 hours the Server is 90% effective and after 18 hours the Server is 100% effective. At 100%
efficiency, the Server’s Processing Time is 10 minutes.
Technical Approach:
The Server’s learning curve will be represented by a Lookup Table. The Processing Time property of the Server will reference this Lookup Table.
Details for Building the Model:
Simple System Setup
Add a Source, Server, and Sink to the Facility Window.
Using a Lookup Table
In the Data Window, select the Lookup Tables panel and add a Lookup Table with the Name property of ‘LearningC urve’. Add the following
(X, f(X)) pairs in the table: (0, 0.2), (12, 0.9), (18, 1). This lookup will be used within the Processing Time of the Server as the efficiency.
Specifying the Server Processing Time
Update the Processing Time of the Server to ‘10/LearningC urve[Run.TimeNow]’. Run.TimeNow is a function that returns the current
simulation time.
Embellishments:
To make this model more specific, try changing the Default entity’s Travel Logic to a desired speed, the Source’s Interarrival Time rate or the
Speed Limits on the Paths.
123 / 815
Simio Reference Guide
LeveledArrivals - SimBit
Problem:
I would like to model a system where parts of different types arrive in a certain order.
Categories:
Arrival Logic, Data Tables
Key Concepts:
AvailableRowC ount, Before C reating Entities, Before Exiting, C ondition, Data Table, Dynamic Object Property, Entity Type, Math.If(), Real State
Variable, Source, State Assignments, Table Reference Assignments
Assumption:
This is a simply Source, Server, Sink model that simply demonstrates controlling the order of arriving entities.
Technical Approach:
The Source reads information from a Data Table to determine which entity type to create for each arrival.
Details for Building the Model:
Simple System Setup
Place a Source, a Server and a Sink into the Facility window and connect them with Paths.
Place 4 ModelEntity objects into the Facility window and name them PartA, PartB, PartC and PartD.
Ensure that the color of each entity is different to help with model verification. To change the color of an entity, select the entity and
then select a color from the C olor drop down in the Symbols ribbon and click back onto the entity. It should then change colors.
C reate Data Table
The Data Table will contain the order in which the different entities should arrive.
Go to the Data window and click the Add Data Table icon in the ribbon to add a new table.
Add a column that is an Entity property by selecting Entity from the Object Reference drop down in the ribbon. The column can be
renamed to Parts.
Fill the table with any orders you’d like – in this example, they arrive in the order A A A A B B B C C D and this pattern repeats.
Add Table Referencing To Source object
Go to the Definitions window and create a new State variable. From within the Definitions window, click on the States panel along the left
side of the interface and then click on Real in the ribbon to create a new Discrete State.Name it ‘RowNumber’. C hange the Initial State
Value to ‘1’.
From within the Facility window, click on the Source and expand the Table Reference Assignments category. Next, expand the Before
Creating Entities category and set the Table Name to ‘Table1’ and the Row Number to ‘RowNumber’ (the new State). This is telling the
Source object to set a reference to the Data Table before an entity is created.
Set the Entity Type property of the Source to be Table1.Parts, where Table1 is the name of the Data Table and Parts is the name of the
column within the table. This will tell the Source to look in this table to determine which type of entity to create.
Expand the State Assignments property category and open the Repeating Property editor of the Before Exiting property (by clicking on the
ellipse in the text box). C lick Add to create a new Assignment and set State Variable Name to ‘RowNumber’ and New Value to ‘Math.If(
RowNumber == Table1.AvailableRowC ount, 1, (RowNumber + 1) )’ This checks to see if the current value of RowNumber is equal to the
total number of rows in the table (i.e. are we at the last row?). If True, it sets the value of RowNumber back to 1 so it reads at the
beginning of the table again. If False, RowNumber is incremented by 1.
Embellishments:
C hange the pattern of arrivals or try adding additional information into the Data Table and using it in the model.
124 / 815
Simio Reference Guide
LogicBasedO nEntityP roperty - SimBit
Problem:
I have entities that need to be sent to certain destinations based on their entity type.
Categories:
Decision Logic -- Paths
Key Concepts:
Numeric Property, Path, Selection Weight
Assumptions:
Each source only produces one type of entity. Source1 produces ModelEntity1 (Green) and Source2 produces ModelEntity2 (Red).
Technical Approach:
An Integer Property will be added to the Default Entity. The Property will be set as unique for each entity instance. The Property will then be
referenced in order to make a decision.
Details for Building the Model:
Simple System Setup
Add two ModelEntity objects from the Project Library and two Sources, a Server, and two Sinks from the Standard Library to the Facility
Window.
Adding an Integer Property to the Default Entity
Highlight ModelEntity in the Navigation window (not the Model) and select the Definitions tab and Properties panel.
Add a new integer property by clicking on Standard Property > Integer.
C hange the Name property to ‘EntityType’. You can also change its default value here if you like.
Defining the Entity.Type
In the Facility Window of the Model, in the ModelEntity1 and ModelEntity2 instances, you will see the new EntityType property you just
created.
Set the EntityType Property to ‘1’ and ‘2’, respectively.
C reating the Logic Decision
To make the decision, you will take advantage of the Selection Weight property on the outgoing links from Server.
For one link, change the Selection Weight to the expression ‘ModelEntity.EntityType==1’. For the other, change the Selection Weight to the
expression ‘ModelEntity.EntityType==2’.
Discussion:
This procedure of using a Property works well for entities that will not change during the run (e.g. ModelEntity2 always has a value of 2). If
“EntityType” is something that could change during the run, you would instead make it a State (Properties cannot change during a run, but States
can).
See Also:
LogicBasedOnEntityState.spf
125 / 815
Simio Reference Guide
LogicBasedO nEntityState - SimBit
Problem:
I have entities that need to be sent to certain destinations based on their entity type.
Categories:
Decision Logic – Paths, EntityC haracteristics
Key Concepts:
Before Exiting, Path, Real State Variable, State Assignments
Assumptions:
Each source only produces one type of entity. Source 1 produces ModelEntity1 (Green) and Source 2 produces ModelEntity2 (Red).
Technical Approach:
A Discrete State Variable will be added to the ModelEntity. An Add-On Process will be used to assign this State Variable a value based on the
entity type. The State will then be referenced in order to make a decision.
Details for Building the Model:
Simple System Setup
Add two ModelEntity objects from the Project Library and two Sources, a Server, and two Sinks from the Standard Library to the Facility
Window.
C hange the name of the ModelEntity objects to ModelEntity1 and ModelEntity2 and make sure that Source1 has an Entity Type of
‘ModelEntity1’, while Source2 has a an Entity Type of ‘ModelEntity2’.
C reating the Discrete State Variable
Highlight ModelEntity in the Navigation window (not the Model) and select the Definitions tab and States panel.
Add a Discrete State Variable to the ModelEntity with Name ‘EntityType’.
Assigning the State Variable
Within the State Assignments section of the Sources, enter the Before Exiting repeating editor and add the State Variable Name of
‘ModelEntity.EntityType’ a New Value of ‘1.0’ (for Source1) and State Variable Name of ‘ModelEntity.EntityType’ a New Value of ‘2.0’ (for
Source2).
C reating the Logic Decision
To make the decision, you will take advantage of the Selection Weight property on the outgoing links from the Server.
For one link, change the Selection Weight as the expression ‘ModelEntity.EntityType==1.0’. For the other, use the expression
‘ModelEntity.EntityType==2.0’.
Discussion:
This procedure of using a State works well for items that could change during the run (e.g. perhaps EntityType needs to change as it proceeds
through processing). If the item will not change during the run, it would be easier and more efficient to have EntityType be a Property instead of a
State of the ModelEntity.
See Also:
LogicBasedOnEntityProperty.spf
126 / 815
Simio Reference Guide
MassFlow P rocessing - SimBit
Problem:
I have 2 stockpiles of material and I want material to flow from the first stockpile to the second at a variable rate. When the flow rate changes,
the second stockpile has to wait for the new flow rate to reach it before noticing a change in flow rate.
Categories:
Building New Objects / Hierarchy, Level States
Key Concepts:
Assign Step, Button, C onveyor, C reate Step, Delay Step, EndTransfer Step, Event, Expression Property, External View, ExternalNode, Fixed C lass
Object, Label, Level State Variable, OnInitialized Process, OnRun Initialized Process, Process Triggering Event, Real State Variable, Size.Height,
Size.Length, Size.Width, Station Element, Status Label, Status Label, Timer Element, Transfer Step
Assumptions:
All flows go from the left to the right. Increased flow means more flow is leaving the first stockpile, meaning the flow rate becomes more negative
(and vice versa - a decrease in flow means less material is leaving and the flow becomes less negative).
Technical Approach:
We will create a new object called a StockPile and represent the amount of material1 in each stock pile with a Level State Variable. At various
events, we will change the outgoing rate of the first stockpile object and pass the new rate to the second stockpile object using an entity to
represent the leading edge of the new flow of material.
Details for Building the Model:
Adding a State to ModelEntity
First we must create the State on the Entity that will carry the new Flow Rate information from one pile to the other. To do this, click on
ModelEntity in the Navigation Window and go to the States Panel in the Definitions Tab. Add a Real State and name it ’FlowC hange’.
C reating the StockPile Object Definition
In your Project Home Tab, click ‘New Model’ to add a Fixed C lass Object to your Project Library. Rename this Object ‘StockPile’ by right-
clicking on the new object and choosing ‘Rename’.
In the Elements Panel of the Definitions Tab, add a new Station Element by clicking the button in the Ribbon. Name this station ‘Pile’.
Next, add an Expression Property from the Standard Property drop-down list in the Ribbon of the Properties Panel. Name this property
‘InitialOreQuantity’. C hange the Category Name to ‘Initial Ore Quantity’.
In the States Panel, add a Level State and Name it ‘OreQuantity’.
Defining the StockPile Object’s External View
In the External Panel of the Definitions tab, you can (optionally) give your StockPile a new Symbol by clicking on Place Symbol button in
the Ribbon. If you have an applicable 3D image you can choose Import Symbol. If not, you can choose to Download a Symbol from
Trimble Warehouse. You can find this particular symbol by searching for “Trash Pile” – it will be the first option. You may want to resize
your symbol in the symbol editor.
After placing the symbol, click on the External Node button in the Ribbon and bring in 2 External Nodes. Place one on the left-hand side of
the object and one on the right-hand side. C lick on the left-hand node. C hange its Node Class to ‘BasicNode’, its Input Logic Type to
‘ProcessStation’ and the Station to ‘Pile’. Rename this node ‘Input’.
For the right-hand node, change its Node Class to ‘TransferNode’ and change its Name to ‘Output’. Leave the Input Logic Type to ‘None’,
since this will be the output node.
Defining the StockPile Object Processes
In the Processes window, select ‘OnRunInitialized’ from the Select Process drop-down to create a new OnRunInitialized Process. Drag in an
Assign Step from the list of C ommon Steps. Set the State Variable Name to ‘OreQuantity’ and right-click on the New Value, click on Set
Referenced Property and select the Property ‘InitialOreQuanity’ from the list. This Process will set the initial value for each stockpile’s ore
level to match the user-defined initial ore quantity property that will later be defined in the Model.
Next, click C reate Process in the Ribbon. Set the Triggering Event in the Properties Window to ‘Pile.Entered’. This process will then be
activated when the pile is entered by an entity. Within the process, place an EndTransfer step to signal that the Station has accepted the
exchange. After that, place an Assign step that assigns the State Variable Name of ‘OreQuanitity.Rate’ the Value of ‘
–ModelEntity.FlowC hange’. This allows the receiving StockPile to receive at a rate equal (but opposite) to the rate that is flowing out of the
first StockPile. Lastly, place a Destroy step to destroy the entity carrying the information after it has been received.
C reating the Model
In your ‘Model’ Object, drag in 2 StockPile objects from the Project Library and connect them with a C onveyor. Set the C onveyor’s Initial
Desired Speed to ‘.05 Meters per Second’.
In the Elements Panel in the Definitions Tab, add a Timer Element and name it ‘RateC hange’. Set its Time Interval to
‘Random.Exponential(10)’ and the Units to ‘Minutes’. This timer will represent random points in time that the flow rate could change in a
system. This could be the arrival of a new truck, another worker is on shift, etc.
In your Events Panel, add an Event and name it ‘Stop’.
Adding Model Processes Window
In the Process tab, click on the C reate Process button in the ribbon and create a process with the Name ‘TimerRateC hange’. Set the
Triggering Event for this Process to ‘RateC hange.Event’. First, place an Assign step into the process. Set the State Variable Name to
‘StockPile1.OreQuantity.Rate’ and the New Value to ‘StockPile1.OreQuantity.Rate + Random.Uniform(-10,0)’. This will Increase the “Flow
Out” of the stockpile.
Next, we create an entity to carry the new Rate down the conveyor to the next stockpile. This entity will act as the leading edge of the new
flow of material. To do this, we must place a C reate step after the Assign and create a DefaultEntity Object Instance Name.
From the C reated exit of the C reate step, we need to Assign the new Flow Rate that was created in the first Step so we place an Assign.
Set the State Variable Name to ‘ModelEntity.FlowC hange’ and its New Value to ‘StockPile1.OreQuantity.Rate’.
Finally, place a Transfer Step after the Assign. We will Transfer From ‘FreeSpace’ (where the entity is C reated), To ‘Node’, Node Name ‘
Output@StockPile1’.
We want the almost the exact same process for the Stop Event. C opy the first Process by clicking in the white space of the Process. When
the process gets shaded with diagonal lines and the Properties window changes to the Process Properties, it means that it is selected, so
127 / 815
the process gets shaded with diagonal lines and the Properties window changes to the Process Properties, it means that it is selected, so
press C trl+C , then C trl+V to copy and paste the entire Process.
C hange the Name to ‘StopFlow’, Triggering Event to ‘Stop’ and in the first Assign step change the New Value to ‘0’.
Animating the Stockpiles
To represent the animation of the stockpiles, we need to make a new process. In the Processes Window, click the Select Process button in
the Ribbon and choose ‘OnInitialized’ from the drop down list. Place an Assign Step to assign the Height, Length, and Width of the
StockPiles according to the size of the OreQuantity State. To do this, set the first State Variable Name to ‘StockPile1.Size.Height’ and the
New Value to ‘StockPile1.OreQuantity/20’.
C lick the ‘…’ button next to Assignments (More) and add 5 additional items. Set the first item’s State Variable Name to
‘StockPile1.Size.Length’ and its New Value to ‘StockPile1.OreQuantity/10’. Similarly, the next item will be ‘StockPile1.Size.Width’ and its
New Value will be ‘StockPile1.OreQuantity/10’. Fill out the next 3 items with the same State Variable Names and Values but with StockPile2
instead.
Add a Delay step and set the Delay Time to an appropriate amount. 0.5 min was used in this example.
Drag the process Endpoint to the input of the Delay to create a loop. This allows the animation to update every time the Delay is executed.
Enhancing Animation
In the Animation Ribbon in the Facility tab, add a Button and the Button Text to ‘Stop Flow’ and set the Event Name to ‘Stop’.
Attach Status Labels to each StockPile by clicking on each StockPile object, then clicking the Status Label button in the Symbols Tab. Set
the Expression to ‘OreQuantity’, and add another for ‘OreQuantity.Rate’. Add both Status Labels for the other StockPile objects, as well.
Drag in a ModelEntity Instance and attach a Status Label to it and set this Expression to ‘FlowC hange’.
Embellishments:
If left running, StockPile1’s OreQuantity will become extremely negative, which in reality is impossible. To end the run when StockPile1’s
OreQuantity reaches 0.0, see the SimBit ‘UsingMonitor’ for detailed instructions.
1 Material refers to the substance flowing from one stockpile to the other – not to be confused with a Simio Material Element
128 / 815
Simio Reference Guide
MergingC onveyorsC ontrolledByG ate - SimBit
Problem:
I want to model merging conveyors that prevent package collisions by having a gate that stops a package before the merge point if it would
collide with another.
Categories:
Add-On Process Logic, C onveyor Systems
Key Concepts:
C onveyor, Resource, Add-On Process, Seize Step, Release Step
Assumptions:
There are two types of entities that exit from two sources on conveyors and merge onto single conveyor system. At merge point, a conveyor
must prevent arriving entities from collisions by stopping them to move forward. Entities enter a single conveyor system on a first in first out
basis.
Technical approach:
A resource of capacity 1 is created to represent the gate or passage of a single entity. An add-on process is used at the entry to each merging
conveyor to seize the gate, thus metering flow to a single entity at a time. At the merge node, another add-on process is used to release the
gate, allowing the next waiting entity to proceed.
129 / 815
Simio Reference Guide
MoveableO perator - SimBit
Problem:
I want to model a system that has two Servers in series and requires a Worker to be present at each Server before processing can occur.
Animation should show the Worker moving between the two servers and parking at the appropriate Server for processing.
Categories:
Building New Objects / Hierarchy
Key Concepts:
Add-On Process, Assign Step, Before Exiting, C ontents, Decide Step, InputBuffer, On Evaluating Seize Request, On Released, ParkingStation
Queue, RideStation Queue, Secondary Resources, Server, State Assignments, Worker
Assumptions:
There is only one Worker in the system. It will work at the first Server until the second Server has 5 or more entities waiting in its queue. The
Worker will then work on the second Server until the input buffer is empty and then return to working on the first Server.
Technical Approach:
The Worker is modeled with a standard Worker object. The Worker object travels between two nodes that are located near each Server, which
animates the moveable resource. The Worker object is seized by each Server before processing and the model ensures that the object is located
at the appropriate node before it begins Processing. Add On Processes on the Worker object will check the contents of the Input Buffer queue to
see if the Worker should be working at Server1 or Server2. A state variable at the Model will indicate which Server the Worker should be working
on.
Details for Building the Model:
Simple System Setup
Add a Source, two Servers and a Sink to the Facility Window. Add a ModelEntity object to the Facility Window and change its picture to a
box.
C onnect the Source to the first Server, connect the first and second Server together and connect the second Server to the Sink with Paths.
Add two Basic Nodes that are connected to each other with a bi-directional path. Place the nodes near each of the Servers. This is the path
that the movable resource will take between the Servers.
Place a Worker object in the Facility window and change its picture to a person by clicking on the Worker object and selecting a new
symbol from the Project symbol library in the ribbon.
Set the Park While Busy property of the Worker to ‘True’, which will tell the Worker to park at the node while it’s processing instead
of stay on the link.
Set the Initial Node(Home) property to ‘BasicNode1’.
Adding Logic to the Servers
C lick on Server1 and expand the Secondary Resources property category. Under the Resource for Processing category, set the Object
Type property to ‘Specific’, set the Object Name property to ‘Worker1’. Set the Request Move property to ‘To Node’ and the Destination
Node property to ‘BasicNode1’. This tells the Server that it must seize Worker1 and it must arrive at BasicNode1 before processing can
begin at this Server.
Repeat the above step for Server2. It must also seize Worker1 and before processing, but set the Destination Node property to
‘BasicNode2’ instead of ‘BasicNode1’ so that Worker1 arrives at the node closest to Server2.
C lick back on Server1 and expand the State Assignments property category. Open the Repeating Property editor for the Before Exiting
property by clicking on the ellipse that appears in the text box of this property. C lick Add and set the State Variable Name to
‘ModelEntity.Priority’ and the New Value to ‘2’. This changes the priority of all entities that leave this Server from the default value of 1 to
the new value of 2.
C reate New State
In the Definitions window of the model, go to the States panel.
C reate a new Real Discrete state by clicking on Real in the ribbon. Name this new state ‘WorkerTaskPriority’. This will keep track of
which server the Worker should be working at. Set the Initial State Value in the properties window to ‘1’.
Add On Process Logic for Worker
C lick on the Worker object and expand the Add On Process Triggers property category.
C reate a new process that is called from the Released property by selecting ‘C reate New’ from the drop down of this input box. This
new process will check the current Task Priority when Worker is Released from a job.
Go to the processes window and in the process called Worker_Released, place a Decide Step which checks the input buffer
of Server 2 to see if there are 5 or more entities waiting. Set the Decide Type to ‘C onditionBased’ and the Expression to
Server2.InputBuffer.C ontents >= 5. If True, the state WorkerTaskPriority is set to a value of ‘2’ with an Assign Step. If False,
another Decide Step checks to see if the input buffer is empty and if so, it assigns the value of ‘0’ to the state
WorkerTaskPriority with an Assign Step. This tells the system that the Worker will move to Server2 and work there until the
input buffer is empty.
Back in the Facility window, click on the Worker.
C reate a new process that is called from the Evaluating Seize Request property by selecting ‘C reate New’ from the drop down of
this input box. This new process will be executed each time a Server is attempting Allocation of the Worker Object.
Go to the processes window and in the process called Worker1_EvaluatingSeizeRequest, place a Decide step that checks to
see if the entity that is evaluating its allocation should get the capacity of the Worker. Set the Decide Type to
‘C onditionBased’ and the Expression to 'Entity.Priority == WorkerTaskPriority'. If True, then the entity will get capacity of the
Worker since the Worker object is supposed to stay at that server, based on the value of WorkerTaskPriority. If the priorities
do no not match, Token.ReturnValue is set to ‘False’, which means that the allocation attempt of the Worker object was
rejected.
131 / 815
Simio Reference Guide
MoveASeizedO bject - SimBit
Problem:
I have seized a moveable resource and now I’d like it to move to a couple of locations within the model before I release the capacity of the
resource.
Categories:
Worker
Key Concepts:
Decide Step, Delay Step, ID, Is.Worker, ModelEntity, Move Step, Location.Parent, Path, Secondary Resources, Selection Weight, Server, Worker
Technical Approach:
There are two Server objects that both need to seize a Worker object and have the Worker move to the Server before processing can begin.
After processing finishes at each Server, the After Processing Add On Process trigger executes a process. This process tells the Worker object to
move to a node, delay, then move to another node and delay again. The entire time, the Entity within the Server “owns” the capacity of the
Worker. Finally, the Worker is told to move back to the Server where the Entity is still waiting in the Processing station. Once the Worker reaches
the Server, the entity releases capacity of both the Server and the Worker and it moves out of the Server.
Details for Building the Model:
Simple System Setup
Place a Source object, followed by two Server objects that are in parallel, within the Facility window. Rename the Server objects to Room1
and Room2. C onnect the Source to the Servers with paths.
C lick on the Source object and change the Interarrival Time property to ‘Random.Exponential(9)’.
Place two Sink objects, one near each Server, and connect Room1 to Sink1 with a path and connect Room2 to Sink2 with a path.
Place two Transfer Nodes into the Facility window, somewhere between Room1 and Room2. Name one TransferNode ‘Lab’ and the other
‘Desk’.
Place Paths going from the output nodes of the servers to Lab, from Lab to Desk, and from Desk back to the server output nodes.
Place a Worker object into the Facility window. Set its Initial Node (Home) property to ‘Desk’ and set its Idle Action property to ‘Go to
Home’.
In the Paths connecting the Output Nodes to Lab, set the Selection Weight to ‘Is.Worker’ to ensure that no Entities travel on these paths
(they are for workers only). Entities will go directly into the Sinks.
Logic for Seizing and Moving Worker
Select Room1 and set its Processing Time property to ‘2’ minutes.
Expand the Secondary Resources category within Room1’s properties and under the Resource for Processing category, set the Object
Name property to ‘Worker1’. In this same property category, set the Request Move property to ‘To Node’ and set the Destination Node
property to ‘Output@Room1’. This is where we tell Room1 to seize Worker1 and have it move to Room1, before processing can begin at
the server.
Repeat the above steps for the Room2, but instead of setting Destination Node to ‘Output@Room1’, enter ‘Output@Room2’.
Within the Processes window, create a new process by clicking on ‘C reate Process’ in the ribbon. Name this process ‘Server_Processed’.
Place a Move Step in this process. Open the Resource Move Requests repeat group property window by clicking on the … (elipse
button). Within the editor window that appears, click the Add button and set Object Name to ‘Worker1’ and Destination Node to ‘Lab’.
Place a Delay Step and set the Delay Time to ‘2’ and Units to ‘Minutes’. This is how long the Worker will wait at the Lab node before
moving on.
Place another Move Step and within the Resource Move Request – Repeating Property editor window, set Object Name to ‘Worker1’
and Destination Node to ‘Desk’.
Place a Delay Step and set the Delay Time to ‘2’ and Units to ‘Minutes’. This is how long the Worker will wait at the Desk node
before moving on.
Place a Decide Step, which will check to see which Room the Worker should return to. Set the Decide Type to ‘C ondition’ and the
Expression to ‘ModelEntity.Location.Parent == Room1’. This is checking to see if the Entity that “owns” this Worker right now is
currently located in Room1.
In the True segment leaving the Decide Step, place a Move Step that moves ‘Worker1’ to ‘Output@Room1’. In the False segment
leaving the Decide Step, place a Move Step that moves ‘Worker1’ to ‘Output@Room2’.
Within the Facility window, select Room1 and expand the Add On Process Triggers property category. In the After Processing trigger, select
the new process you just created. Do the same thing for Room2. The same process can be called from each Server.
Embellishments:
Add additional Move Steps that require the Worker to visit other locations while it is seized by the entity. Or increase the Interarrival Time on the
Source object and then increase the number dynamic Worker objects there are in the system to ‘2’.
Discussion:
Because the entity “owns” the Worker object while it is moving through the system, no other object can get capacity of this Worker object. It is
“Busy” until the Entity releases the capacity of the Worker. In this example, the Entity releases capacity of the Worker once the Entity leaves the
Server.
132 / 815
Simio Reference Guide
MultipleInputArgumentsO nP rocesses - SimBit
Problem:
I have a Worker that needs to service 2 different Servers upon a server failure. Rather than having separate add-on processes for each server,
I’d like a single process that will seize the Worker when either Server fails.
Categories:
Add-On Process Logic, Worker
Key Concepts:
Add-On Process, Failure, On Failed, On Repaired, Process Input Arguments, Seize Step, Set Referenced Property, Release Step, Server, Worker,
Time to Repair, Token, Uptime Between Failures
Assumptions:
A single Worker is used to repair 2 different Servers when they fail. A bi-directional path is used to transfer the Worker between the Servers. The
same failure type property values are used with the Servers.
Additional Notes:
Input Arguments on processes allow the user to have single shared process between objects. In this SimBit, the seized worker is directed to the
appropriate work location, no matter where the process is called from. While not illustrated here, it’s also possible to return a value (or values) in
a similar fashion using return values.
Technical Approach:
Two Source-Server-Sink sets of objects connected by paths are placed in the model. A Worker is transferred between the Servers via a bi-
directional Path between the Servers. Reliability logic (Uptime Between Failures and Time To Repair) is defined via referenced properties. Add-On
processes, along with process input arguments, are used to seize the worker when needed.
Details for Building the Model:
System Setup
In the Facility window, place a Source, a Server and a Sink object and connect them with Path objects. Repeat this process with a second
set of objects below in parallel to the first set. On both Source objects, change Interarrival Time to ‘Random.Exponential(.5)’.
Place a BasicNode (BasicNode1) next to Server1, a BasicNode (BasicNode2) next to Server2 and a third BasicNode (HomeNode) between
the Source objects. C onnect these nodes with a bi-directional path. Place a Worker object in the Facility window and set the following
property values: Initial Node (Home) to ‘HomeNode’, Idle Action to ‘Park At Home’. C lick on the HomeNode and in the Appearance ribbon,
select Draw Queue and add a ParkingStation.C ontents queue. On that same ribbon, turn off the Parking Queue option.
In the Server1 object, under Reliability Logic, set the Failure Type to ‘C alendar Time Based’ and create a new referenced property for
Uptime Between Failures called ‘UptimeBetweenFailures’ and one for Time To Repair called ‘TimeToRepair’. In Server2, under Reliability
Logic, set the Failure Type to ‘C alendar Time Based’ and set a referenced property on Uptime Between Failures to ‘UptimeBetweenFailures’
and on Time To Repair to ‘TimeToRepair’. Right click on the Model and select Properties. Under C ontrols, General set
UptimeBetweenFailures to ‘Random.Exponential(5)’, Units to ‘Minutes’, TimeToRepair to ‘Random.Uniform(.25,.5)’ and Units to ‘Minutes’.
In both of the Server objects, under Add-On Process Triggers, set Failed to ‘Server_Failed’ and Repaired to ‘Server_Repaired’.
Add-On Processes and Input Arguments
In the Definitions window, under Tokens, add a new token called “MyToken”. Add an Object Reference of type Node and call it ‘Destination’.
In the Processes window, highlight the Server_Failed process and under Advanced Options, change Token Class Name to ‘MyToken’. Select
Input Arguments to open the repeating property editor. Add an item where Name is ‘LocalNode’ and State Variable Name is
‘MyToken.Destination’.
In the Server_Failed process, add a Seize step. Select Resource Seizes to open the repeating property editor. Add an item where Object
Name is ‘Worker1’, Request Move is ‘ToNode’ and Destinationi is ‘MyToken.Destination’.
In the Server_Repaired process, add a Release step and select Resource Releases to open the repeating property editor. Add an item
where Object Name is ‘Worker1’.
In the Facility window, select Server1 and under the Failed Add-On Process Triggers, Input Arguments, set Local Node to ‘BasicNode1’.
Select Server2 and under the Failed Add-On Process Triggers, Input Arguments, set Local Node to ‘BasicNode2’.
133 / 815
Simio Reference Guide
NotifyStep - SimBit
Problem:
When a certain event occurs or when a variable reaches a certain point, I want the simulation to pause while a message is given to the user,
asking them to either continue running the simulation or giving them the ability to pause the simulation to investigate the event.
Categories:
Add-On Process Logic, Buffering
Key Concepts:
C ontents, C rossingStateC hange, Event, InputBuffer, Monitor, Notify Step, On C hange Detected Process
Technical Approach:
A message can be displayed to the screen with a Notify Step. This model will place a Notify Step to be executed when a Monitor element fires.
This Monitor element fires when the contents of the Server’s InputBuffer station exceed 3.
Details for Building the Model:
Simple System Setup
Place a Source, a Server and a Sink into the Facility window and connect them with Paths.
Go to the Definitions Window. You should be in the Elements panel (Elements highlighted on the left of the screen).
C lick on Monitor in the Ribbon to create a new Monitor element.
Set the Monitor Type property to ‘C rossingStateC hange’
Set the State Variable Name to ‘Server1.InputBuffer.C ontents’
Set the Threshold Value to ‘3’.
Set the Crossing Direction property should be set to ‘Positive’, which means that this Monitor will fire when the contents of the
InputBuffer cross over the value of 3 in the positive direction (i.e. when it increases from 3 to 4).
In the drop down of the On Change Detected Process property, create a new Process by select “C reate New”. This new process will
be executed when this Monitor fires.
Go to the Processes window and you should see the new Process that was just created. Place a Notify Step into this process (located under
All Steps).
Set the Notification Type to ‘Warning’
Set the Message Heading to “InputBuffer Monitor” (include the double quotes since this is a String)
Set the Message Content to “InputBuffer has more than 3 entities” ((include the double quotes since this is a String)
Embellishments:
C hange the contents of the String message that is in the Message Heading or the Message Content properties. First select “C ontinue running” in
the pop up window and then select “Pause the Simulation”, to see the behavior of the two choices. Finally, select “Don’t show this warning again”
at the bottom of the window to turn off future warnings.
Discussion:
The Warning Level is controlled from the Run ribbon under Advanced Options. The user can set the Warning Level to Alert User (this is the
default), Write to Trace Only, or Do Nothing. Once the user selects Do Nothing or selects the “Don’t show this warning again” check box in the pop
up window, they must select Re-enable Disabled Warnings from the Advanced Options tab to get the Warnings to reappear.
134 / 815
Simio Reference Guide
O bjectR eferenceO nEntity - SimBit
Problem:
I would like to keep track of what Server an entity visited so that this information can be used later in the model. I would like to keep a reference
to an object on my entity.
Categories:
Decision Logic -– Paths, Decision Logic -– Processing, Entity C haracteristics
Key Concepts:
Active Symbol, Object Reference State, Location.Parent, Selection Weight
Assumptions:
If an Entity is processed at Server1, it must route to Server5 for processing after it finishes at Server4. If an Entity is processed at Server2, it
must route to Server6 for processing after it finishes at Server4.
Technical Approach:
An Object Reference State is created on the ModelEntity object, which will be used to hold a reference to which Server the entity visited first
(either Server1 or Server2). The Selection Weight properties on the paths the leave Output@Server4 will contain expressions that will route the
entity to correct Server, either Server5 or Server6, depending on which Server it visited at the beginning of the model. The logic in these
expressions checks the value of the Object Reference State on each entity to determine if it was processed at Server1 or Server2.
Details for Building the Model:
Simple System Setup
Place a Source (Source1) and Sink (Sink1) at the left and right sides, respectively, of the Facility window.
Place two Server2 in parallel after the Source and name them Server1 and Server2. C onnect Source1 to each new Server with Paths.
Place two Servers, in series, next. Name them Server3 and Server4. C onnect them together with Paths and connect both Server1 and
Server2 to Server3 with a Path.
Place two additional Servers, in parallel, after Server4. Name them Server5 and Server6. C onnect Server4 to each new Server with a
Path and connect Server5 and Server6 to the Sink with Paths.
Place a ModelEntity object from the Project Library, into the Facility window. Select the entity in the Facility window and click on ‘Add
Additional Symbol’ icon in the Ribbon. C hange the color of the second symbol to Red. First, ensure that he second symbol is displayed by
selecting the entity in the Facility window and checking the Active Symbol icon in the Ribbon. If (2 of 2) is displayed, you are viewing the
second symbol. C lick on the C olor drop down in the Ribbon, find Red, and then click back onto the Entity object to change its color. (if you
are viewing 1 of 2, or the first symbol, simply select the second symbol from the Active Symbol drop down)
C reating the Object Reference State on the ModelEntity
C lick onto ModelEntity in the Navigation window in the upper right side of the interface. Once ModelEntity is selected, you are now viewing
the object definition for this object. Go to the Definitions window of the ModelEntity object.
Go to the States Panel by selecting States on the left panel.
C lick on the Object Reference icon in the ribbon to create a new Object Reference State. Rename this new state, FirstServer.
Adding Logic to the Model
Back in the main Model, click on Server1 and expand the State Assignments property category. Add a new assignment in the On Entering
property. C lick Add to create a new Assignment once the Repeating Property Editor window is open. Set the State Variable Name to
‘ModelEntity.FirstServer’. Set the New Value property to ‘ModelEntity.Location.Parent’.
The function ModelEntity.Location.Parent will return a reference to the object where the entity is current located (it’s ParentObject)
and at this moment, the ParentObject is Server1, so it will assign a reference of Server1 to the new state named FirstServer on
each entity that passed through.
C lick on Server2 and add the exact same assignment to this Server. (Exact same State Variable Name and same expression for New
Value). However, before you exit the Repeat Group editor, add a second Assigment. Set the State Variable Name to ‘ModelEntity.Picture’
and the New Value to ‘1’.
This will change the color of all entities leaving Server2 to Red. This will help with visually confirming that these entities will be
routed to Server6.
Select the Path that leads from Server4 to Server5. Set the Selection Weight property to ‘ModelEntity.FirstServer == Server1’. This tells
Simio that only entities that have their FirstServer state set to ‘Server1’ will be able to take this Path.
Similarly, select the Path that leads from Server4 to Server6. Set the Selection Weight property to ‘ModelEntity.FirstServer == Server2’.
This tells Simio that only entities that have their FirstServer state set to ‘Server2’ will be able to take this Path.
135 / 815
Simio Reference Guide
O neQ ueueForMultipleServers - SimBit
Problem:
I have multiple servers and I would like one queue that feeds into these two servers.
Categories:
Buffering
Key Concepts:
Allow Passing, Blocked Destination Rule, Input Buffer, Lists, NodeList, Path, Select Available Only, Selection Goal, TransferNode
Assumptions:
If there are entities waiting and one of the servers becomes available, the first entity in the queue will move to the available server for
processing.
Technical Approach:
There are two servers, but the same concept can be applied if there were more than two servers. The InputBuffer property on each server is set
to ‘0’. This will ensure that entities do not wait at each server. A Transfer Node is placed in front of the two servers. The Transfer Node is
configured to only send entities on paths that are available, which ensures that the entities will wait here if there are no servers available. The
Path that leads to the Transfer Node has its Allow Passing property set to ‘False’ so that the entities wait one behind the other on this link.
Details for Building the Model:
Simple System Setup
Place a Source object and a Sink object in the Facility window. In between, place two Servers that are in parallel to each other. Place a
Transfer Node in front of these two Servers.
C onnect the Source to the Transfer Node with a Path. Set the path’s Allow Passing property to ‘False’.
C onnect the Transfer Node to the input node of each server with paths.
C onnect the output nodes of each server to the Sink.
C reate a Node List
Go to the Definitions window and open the Lists panel. C reate a new Node List by clicking on the Node icon in the ribbon. In the node list,
first list Input@Server1, followed by Input@Server2.
Ensuring One Queue
C lick on the Transfer Node. Set the Entity Destination Type property to ‘Select From List’.
Set the Node List Name property to the name of your new Node List.
The Selection Goal property is set to ‘Random’ in this example.
The Blocked Destination Rule is set to ‘Select Available Only’. This ensures that the entity does not leave this Transfer Node and travel to
its destination if there are entities at each server.
Eliminate Input Buffers
Eliminate the Input Buffer at each server so that the entities cannot wait in this location for server capacity. Set the Input Buffer property
on each server to 0.
Embellishment:
Experiment with more servers and see the behavior change when you change the Blocked Destination Rule property on the Transfer Node.
136 / 815
Simio Reference Guide
O verflow W IP - SimBit
Problem:
I have parts that are processed by two machines, always in FIFO order. I have a small WIP area in front of the machines – parts always go here
to wait if space is available. If the small WIP area is full, parts go to an overflow area, but are still pulled in FIFO order regardless of location.
Categories:
Buffering
Key Concepts:
C apacity.Allocated, Lists, ModelEntity, ObjectList, Path, Ranking Expression, Ranking Rule, Resource, Secondary Resources, Selection Weight,
Smallest Value First, TimeC reated
Technical Approach:
Represent the WIP areas as Servers with the specified capacity, but no processing time. Don’t leave the Server until the processing machine is
ready to process it. Use resource default behavior to select FIFO from all waiting parts (regardless of location).
Details for Building the Model:
Simple System Setup
Add a Source, 4 Servers, and a Sink to the Facility Window. Two of the Servers will be the MainWIP and OverflowWIP areas, while the
other two Servers will be ServerA and ServerB.
Determining the WIP Area to go to
In the Selection Weight property for the path to MainWIP, use the 'MainWIP.C apacity.Allocated < MainWIP.C apacity'. This will evaluate the
number of busy “spots” in this Server as compared to the capacity.
In the Selection Weight property for the path to OverflowWIP, use the ‘MainWIP.C apacity.Allocated == MainWIP.C apacity’.
Defining the Machines
Place resource with Name ‘ResourceA’ and ‘ResourceB’ representing each machine.
Open the Definitions tab, Lists panel and add an Object list with Name ‘Machines’.
Add ‘ResourceA’ and ‘ResourceB’ to the list.
Details for Machine Selection
Within each WIP area (MainWIP and OverflowWIP), within the Secondary Resources / Other Resource Seizes section of properties, enter
the After Processing repeating editor and change the Object Type to ‘FromList’, and the Object List Name to ‘Machines’. The Selection Goal
should remain as the default ‘PreferredOrder’ to select the first available machine from the list. These are seized just before the WIP
resource is released.
Within each Server (ServerA and ServerB), within the Secondary Resources / Other Resource Releases section of properties, enter the
After Processing repeating editor and change the Object Type to ‘FromList’, and the Object List Name to ‘Machine’.
Details for Moving to the Selected Machine
Using paths, connect each of the WIP type Servers to each of the processing type Servers, ServerA and ServerB.
In the Selection Weight property for each path to MachineA, use the expression ‘ResourceA.C apacity.UnitsOwned’.
In the Selection Weight property for each path to MachineB, use the expression ‘ResourceB.C apacity.UnitsOwned’.
The combination of the above will result in a weight of 1 for the correct path and a weight of 0 for the other path.
Animation Embellishment:
To make it easier to see the FIFO behavior, we used different entity symbols based on creation time. Look in the Current Symbol property for
PartA and to see the expression used to use a different symbol each hour.
137 / 815
Simio Reference Guide
P athSelectionR ule - SimBit
Problem:
I have a bidirectional path that takes entities from two different inputs to two different outputs, with entities coming from both sides of the path. I
want to be able to direct how the entities flow onto the path, but I’m not sure how the Traffic Direction Rule property on a Path works.
Categories:
Decision Logic -- Paths
Key Concepts:
Allow Passing, Bidirectional Path, Entity Destination Type, Maximum Arrivals, Path, Prefer Desired Direction, Source, Time Offset, Traffic Direction
Rule
Assumptions:
There is no passing on the bidirectional path. Entities move onto the link from both node entrances. The systems shown are identical except for
the Traffic Direction Rule property on the bi-directional Path.
Technical Approach:
A model is developed with a system containing two sources, two sinks and a bidirectional link. This first group of objects is then copied to a
second system. To evaluate the difference between the systems, the model will be deterministic, meaning no random distributions will be used.
The only difference will be the Traffic Direction Rule property on the bidirectional path.
Details for Building the Model:
Simple System Setup
Place a Source (Source1) and Sink (Sink1) at the left side of the Facility window. Then, place a second Source (Source2) and Sink (Sink2)
on the right side.
Within Source1, change the Interarrival Time to ‘.2’ and the under the Stopping C onditions category, change Maximum Arrivals to ‘5’.
Within Source2, change the Time Offset to ‘0.1’, the Interarrival Time to .2 and the Maximum Arrivals to ‘5’.
Setting the Destinations
C lick on the output node of Source1 (Output@Source1) and change the Entity Destination Type to ‘Specific’ and the Node Name to
‘Input@Sink2’.
Do the same for Source2 (Output@Source2) and specify the Entity Destination Type as ‘Specific’ and the Node Name as ‘Input@Sink1’.
Adding Nodes, Paths and a Bidirectional Path
Place a BasicNode1 to the right of Source1/Sink1. Place a second BasicNode2 to the left of Source2/Sink2.
Using Paths, connect Source1 to BasicNode1 and Source2 to BasicNode2. Then connect BasicNode1 to Sink1 and BasicNode2 to Sink2. For
the Paths connecting the Sources to the BasicNodes, set Allow Passing to ‘False’.
Add a path connecting BasicNode1 and BasicNode2. C hange the path’s Type to ‘Bidirectional’, Allow Passing to ‘False’ and Speed Limit to
‘.1’.
C opying System1 to System2
Now that we have a single system completed, we will copy it to make an identical one. This can be done by moving the mouse to the top
left corner above the Source1 and C trl-Left C lick and drag to highlight all the objects in system1 (including both Sources, Sinks,
BasicNodes and all paths).
C trl-C will copy the system and position the mouse below system1 and use C trl-V to paste the copy. All objects will be renamed with
unique names.
Edit the bidirectional path for System2 and change the Traffic Direction Rule to ‘Prefer Desired Direction’. You may need to expand the
properties under Type to see this property.
C hange the entity destination Node Name properties in the Source Output Nodes to ‘Input@Sink1_1’ and ‘Input@Sink2_1’.
138 / 815
Simio Reference Guide
P ickUpDropO ffFlow - SimBit
Problem:
I would like to model flow being carried on a moving entity. The moving entity’s C ontainer would be filled with flow. It would then travel to a new
destination and then empty the flow out of its C ontainer.
Categories:
Add-On Process Logic, Flow Library
Key Concepts:
Assign Step, C ondition, C ontents, C ustom Object, Decide Step, Event, Execute Step, Fire Step, FlowNode, ModelEntity, Notify Step, Remove Step,
Transfer Step, Wait Step
Assumptions:
The model described below will support two entities arriving from the Source object. If this number is altered, the tank capacity and volume will
need to be adjusted to support this.
Technical Approach:
There is a Tank that initially contains 600 cubic meters of flow. There is a second Tank that is initially empty but can hold up to 600 cubic meters.
The ModelEntity object has a C ontainer element that will hold 300 cubic meters of flow. The traveling entity arrives at a Node and flow is
transferring from the first Tank into the C ontainer on the entity. Flow is transferred until the entity’s C ontainer is full. At this point, the transfer of
flow is stopped and the entity travels to the next Node. At this point, flow is transferred from the entity’s C ontainer into the second Tank. When
the entity’s C ontainer is empty, the entity leaves the Node and travels to the Sink.
Details for Building the Model:
System Setup
Drag out two instances of ModelEntity, so there is an instance of DefaultEntity and ModelEntity1 in the Facility window. DefaultEntity will be
the traveling entity and ModelEntity1 will be the flow.
Place a Source (Source1) and Sink (Sink1) at the left and right sides, respectively, of the Facility window.
Set the Maximum Arrivals property on the Source to ‘2’.
Place two TransferNodes in between the Source and the Sink and connect each objects with a Path.
C lick onto the path that connects the Source to the first TransferNode. Set the Initial Traveler Capacity to ‘1’ so that only one
traveling entity will be on this link at the same time. This is required so that the second entity does not arrive at the first
TransferNode and request a transfer of flow while the first entity is still accepting a transfer of flow.
Place two Tank objects (from the Flow Library). Place one Tank near the first TransferNode and the other Tank near the second
TransferNode.
For Tank1, set the Initial Volume Capacity property to ‘600 cubic meters’. Add a row to the Initial C ontents repeat group property
and set the Entity Type property to ‘Modelentity1’ and the Quantity to ‘600’, which indicates that this Tank will initially have 600 cubic
meters of ModelEntity1 inside of it.
For Tank2, set the Initial Volume Capacity property to ‘600 cubic meters’.
In the Run Ribbon, set the Speed Factor to at least 300 for a more appropriate animation speed.
Adding a C ontainer to the ModelEntity object
C lick on the ModelEntity object in the Navigation window (right side of interface) to enter into this object’s definition.
Go to the ModelEntity’s Definitions window and click onto “C ontainer” in the Elements ribbon.
Set the C ontainer’s Initial Volume Capacity to ‘300’ cubic meters.
Find the On Full Process and On Empty Process properties of the C ontainer and select “C reate New” for each property so that you
have created two new processes that will be triggered when this C ontainer is Full and Empty.
From within the ModelEntity’s Definitions window, go to the Events panel (find Events along the left hand side of the interface). C reate two
new Events by clicking on “Event” in the Events ribbon. Name one event ‘Full’ and the other ‘Empty’.
Go to the ModelEntity’s Processes window. Find the two new processes that were created earlier from the C ontainer element.
Place a Fire Step in the C ontainer1_OnEmptyProcess. Set the Event Name of this step to ‘Empty’.
Place a Fire Step in the C ontainer1_OnFullProcess. Set the Event Name of this step to ‘Full’.
Process Logic to Transfer Flow
Navigate back to the main model by clicking onto Model in the Navigation window. Go to the Model’s Processes window. C reate 4 new
Processes by clicking on C reate Process in the Process ribbon.
C lick onto the first process and set it’s Name property to ‘FillShip’.
In this process, we’ll be transferring flow from Tank1 into the entity’s C ontainer. First, make sure there is sufficient flow in
Tank1 to transfer. Place a Decide Step that checks the condition “Tank1.FlowC ontainer.C ontents > 0’.
If False, place a Notify Step that tells the user there isn’t sufficient flow.
If True, place a Transfer Step to transfer the flow.
Set From to ‘C urrentNode’
Set To to ‘C ontainer’
Set Container Name to ‘ModelEntity.C ontainer1’
Set Flow Regulator Name to ‘[email protected]’
Under Advanced Options, set Entity Type to ‘SpecificObject’ and Entity Object to
‘Tank1.FlowC ontainer.C ontents.FirstItem.Modelentity’ . This is telling Simio that you specifically want to find the entity
that is currently in the C ontents queue of the FlowC ontainer inside of Tank1 and transfer that entity into the current
entity’s C ontainer1
139 / 815
C lick onto the second process and set it’s Name property to ‘TransferFromTank1ToShip”.
Place an Execute Step with the Process Name property set to ‘FillShip’. In the Advanced Options, set the Token Wait Action to
‘None (C ontinue)’. This will tell Simio to execute the FillShip process, but this token will not wait for that process to finish, it
will continue onto the next step.
Place a Wait Step and set the Event Name to ‘ModelEntity.Full’.
Place a Decide Step and set the Expression to ‘[email protected]>0’, which
checks if there is still an entity in the Flow Request Queue of the Tank’s output node. An entity would still be in this queue if
only a partial amount of the flow was transferred out of the tank. We need to remove the entity from this queue because we
are done with this transfer of flow. This is how we “cancel” a flow transfer request. Simio will keep on trying to transfer the
rest of the flow volume to this entity, unless you remove it from the Flow Request Queue when you are done. If we had
transferred all of the volume that was in the Tank, this step would not be necessary.
C lick onto the third process and set it’s Name property to ‘EmptyShip”
In this process, we’ll be transferring flow from the entity’s C ontainer into Tank2.
Place a Transfer Step to transfer the flow.
Set From to ‘C urrentC ontainer’
Set To to ‘C ontainer’
Set Container Name to ‘Tank2.FlowC ontainer’
Set Flow Regulator Name to ‘[email protected]’
Under Advanced Options, set Entity Type to ‘SpecificObject’ and Entity Object to
‘ModelEntity.C ontainer1.C ontents.FirstItem.Modelentity’. This is telling Simio that you specifically want to find the
entity that is currently in the C ontents queue of the entity’s C ontainer and transfer that entity into the FlowC ontainer
of Tank2.
C lick onto the fourth process and set it’s Name property to ‘TransferFromShipToTank2”.
Place an Execute Step with the Process Name property set to ‘EmptyShip’. In the Advanced Options, set the Token Wait
Action to ‘None (C ontinue)’. This will tell Simio to execute the EmptyShip process, but this token will not wait for that process
to finish, it will continue onto the next step.
Place a Wait Step and set the Event Name to ‘ModelEntity.Empty’.
Navigate back to the Facility window of the model and click onto TransferNode1. In the Entered Add On Process trigger property, select
“TransferFromTank1ToShip” in the dropdown so that this process is executed when the entity enters this node. Similiarly, click onto
TransferNode2. In the Entered Add On Process trigger property, select “TransferFromShipToTank2” in the dropdown so that this process is
executed when the entity enters this node.
140 / 815
Simio Reference Guide
P rocessModelW ithinModel - SimBit
Problem:
There is a series of simple steps in your facility that are repeated many times throughout the operation. You wish to have a small user-defined
“model object” that can be placed multiple times in your model logic.
Categories:
Building New Objects / Hierarchy
Key Concepts:
BasicNode, C ontinueProcess, Delay Step, EndTransfer Step, Expression Property, ExternalNode, Object Instance Property, ProcessStation,
Release Step, Resource, Seize Step, Station Element, Transfer Step
Assumptions:
The similar steps that will be made into an object include seizing a resource, delaying for a given amount of time and releasing the resource. The
Processes Window steps of Seize, Delay, and Release will be used. All logic within this model object will be specified in the Processes Window.
Technical Approach:
Within the first model, called SeizeDelayRelease, we will define the processing necessary for this single object, which includes the Seize, Delay
and Release steps. This logic will remain unchangeable, however, the end user of the SeizeDelayRelease object will be able to specify a single
resource name (for seizing / releasing), as well as the delay time.
Details for Building the Model:
Defining the SeizeDelayRelease Process Logic
Open a new model and rename the Model to SeizeDelayRelease by selecting MySimioProject in the Navigation window, selecting the
Models panel, highlighting Model and clicking to rename.
Open the Processes window of SeizeDelayRelease. C reate a process with Name ‘Process1’.
Place the Seize, Delay and Release steps into Process1.
For any properties that the end user will be able to specify, highlight the property, right click and select Set Referenced Property, C reate
New Referenced Property and specify a property name. In this example, within the Delay step, set the Delay Time property to ‘DelayTime’.
You will see a green arrow to the left of DelayTime, indicating that the value will come from the parent object, SeizeDelayRelease. Do the
same for the Object Name for Seize and Release steps to specify a ‘Resource Name’ in the parent object.
Defining the SeizeDelayRelease External View
C lick on the Definitons tab and select the External panel, where you will specify what the user will see in a Facility Window when they place
this model. Place an ellipse, and two external nodes (one for entry, one for exit) in the view.
C hange the entry node’s NodeClass to ‘BasicNode’. The logic of this model is only in the Processes Window, thus the Input Logic Type is
‘ProcessStation’, with the Station of ‘EntryStation’.
C hange the exit node’s NodeClass to ‘TransferNode’. Input Logic Type is ‘None’, as this is a transfer out.
Utilizing the Entry and Exit Node within the Process Logic
Return to the Processes Window and change the change the Triggering Event property to EntryStation.Entered (recall that the entry node’s
Input Logic Type was ProcessStation called EntryStation).
Add an EndTransfer step at the start of the process, before the Seize step. This will stop the transfer into the model so that other logic may
begin.
Place a Transfer step after the Release step. C hange the From property to ‘C urrentStation’, since we entered this process via station
(EntryStation). The To property should be ‘ParentExternalNode’, with the External Node Name of ‘Node2’ (name of exit node in External
Window).
Using the SeizeDelayRelease Model in Another Model
Open a new model and within its Facility Window, place a Source and Sink from the Standard Library and a SeizeDelayRelease model from
the Project Library and connect them with Paths. Place a Resource and change the Name to ‘Resource1’.
Highlight SeizeDelayRelease and specify the ResourceName as ‘Resource1’ and the DelayTime as ‘3.1’.
When you run this new model, the logic behind SeizeDelayRelease then includes all process logic specified within that model. You may
place SeizeDelayRelease as many times in your new model as you like with varying ResourceName and DelayTime properties.
141 / 815
Simio Reference Guide
R andomValueFromT able - SimBit
Problem:
I would like to use real data for my system, including time between arrivals and processing times, instead of distribution data. Recent research1
suggests that sampling directly from real data may be more accurate than using a fitted distribution.
Categories:
Arrival Logic, Data Tables, Entity C haracteristics
Key Concepts:
Before C reating Entities, Data Table, Foreign Key, Object Reference Property, RandomRow, RandomValue, Table Foreign Key Property
Technical Approach:
This model illustrates use of two different types of data. The top subsystem illustrates using data where you have a standalone set of collected
values, for example historical processing times. The bottom subsystem illustrates using data where you have a set of collected values with
identifying or categorizing information, for example historical processing times by entity type.
C reate a table for each set of arrival and/or processing data that will be read during the simulation run. For data that is entity type specific, a
foreign key column within a table is utilized to classify the data. In this example, the first Source/Server/Sink combination will read data for both
source arrivals, as well as server processing times from two separate tables. In the second Source/Server/Sink combination, two entity types will
be generated that have processing time information located within a relational table.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink in the Facility window. C onnect these with Paths.
Place a second Source, Server, and Sink combination in the Facility window and connect as well.
Place 3 ModelEntity objects from the Project Library into the Facility Window and change the Name property values to ‘Green’, ‘Red’ and
‘Blue’- change their picture colors to match.
Defining the Data Tables with Product Information
C lick on the Data tab of the model and select the Tables panel. Add a DataTable with the Name ‘Source1Table’ and add a ‘Real’ type
property named ‘ArrivalTimes_1’. C opy and paste in any ‘real’ data you may have for time between arrivals (in this example, we
generated 50 data points from StatFit2).
Add a DataTable with the Name ‘Server1Table’ and add a ‘Real’ type property named ‘ProcessingTimes_1’. C opy and paste in any ‘real’
data you may have for processing times (in this example, we generated 100 data points from StatFit2).
Add a third Data Table with the Name ‘PartTypes’. Add two column properties; including an Entity Object Reference property named
‘WhichType’ and an Integer type property named ‘HowMuch’. Add ‘Red’ and ‘Green’ to the Entity Object Reference column and have
corresponding ‘HowMuch’ property values of ‘40’ and ‘60’. We will use the RandowRow function to generate the entity type from Source2.
C lick on the column ‘WhichType’ and select the Set C olumn as Key button. We will use this as a key for the next table.
Finally, add a Data Table with the Name ‘Server2Table’ that includes a Foreign Key column named ‘PartType’ as well as a real type column
named ‘ProcessingTimes_2’. For the ‘PartType’ column, set the column property named Table Key to ‘PartTypes.WhichType’, which
references the column noted in previous step. In this table, you will add associated times for both ‘Blue’ and ‘Red’ type parts. The
RandomValue function will be used to randomly pick a value from the associated data for the given part type calling the table.
Generating Random Values for Source1 and Server1
Within Source1, change the Entity Type to ‘Green’ and the Interarrival Time to ‘Source1Table.ArrivalTimes_1.RandomValue’. This will
randomly select a value from the Source1Table (ArrivalTimes_1 property) as the interarrival time each time an entity is generated.
Within Server1, change the Processing Time property to ‘Server1Table.ProcessingTimes_1.RandomValue’. This function will pull a random
value from the Server1Table’s ProcessingTimes_1 column each time an entity is processed.
Generating Random Entity Types and then Random Values from Relational Table
Within Source2, open the Table Reference Assignments / Before C reating Entities section of properties and specify the Table Name as
‘PartTypes’ and the Row Number as ‘PartTypes.HowMuch.RandomRow’.
C hange the Interarrival Time to ‘Random.Exponential(6)’. The Entity Type can then be specified as ‘PartTypes.WhichType’, which will be
based on the part type generated (40% Blue and 60% Red based on HowMuch column property values).
Within Server2, change the Processing Time property to ‘Server2Table.ProcessingTimes_2.RandomValue’. This function will pull a random
value from the associated part type’s ProcessingTimes_2 column entries each time an entity is processed.
Footnote:
1) Nelson, WSC 2013, http://www.simio.com/resources/presentations/2013-Winter-Simulation-C onference/pdfs/WSC 2013-Titan-Keynote-Nelson-
Simulation-C urmudgeon.pdf
142 / 815
Simio Reference Guide
R ecordDistanceT raveled - SimBit
Problem:
I want to record the distance traveled by a vehicle per hour.
Categories:
C ustom Statistics, Vehicles, C ustom Object
Key Concepts:
Subclass, Real State Variable, Discrete State, TallyStatistic, Movement, Distance, Periodic Statistic, Hourly Statistic
Technical Approach:
The Vehicle object will be sub-classed to make a customized vehicle in order to add a state and statistic on top of the standard vehicle behavior. A
process will be added to the vehicle to update the state and record the periodic statistic.
Details for Building the Model:
C reating a Sub-C lassed Object MyVehicle
C reate a new vehicle class called MyVehicle that is sub-classed from Vehicle by right-clicking on Vehicle in the Standard Library and
choosing Subclass.
Adding the State and Statistic to MyVehicle
Select MyVehicle in the Navigation window and click on the Definitions tab, States panel to add a discrete state with Name
‘PreviousDistanceTraveled’ and Unit Type of ‘Length’. This will be used to record the distance traveled at the beginning of each period (each
hour).
Also within the Definitions window, select the Elements panel and add a Tally Statistic with Name ‘DistanceTraveledPerHour’ and Unit Type
of ‘Length’. To make this statistic appear beside the existing distance traveled statistic, under the Results C lassification properties, use Data
Source of ‘[Object]’, C ategory of ‘Travel’ and Data Item ‘DistanceTraveledPerHour’.
Also within the Definitions window Elements panel add a Timer with Name ‘HourlyTally’ and Time Offset of ‘1’. This will be used to trigger a
process at the end of the first hour and each subsequent hour.
Within the Processes window add a new process with Name ‘RecordAndResetDistanceTraveled’ and Triggering Event Name of
‘HourlyTally.Event’. This process will be triggered at the end of each hour so we can calculate and record the travel during that hour and
then reset our internal state. Add two steps to this process.
Add a Tally Step with Tally Statistic Name of ‘DistancedTraveledPerHour’ and Value of ‘TotalDistanceTraveled -
PreviousDistanceTraveled’.
Add an Assign Step to assign the State Variable Name ‘PreviousDistanceTraveled’ to the New Value of ‘TotalDistanceTraveled’.
Building the Model
Select Model from the Navigation window and within the Facility window, place a Source and Sink and connect them with two paths, one
from Source1 to Sink1 and the other from Sink1 to Source1.
Within the Source, change the Interarrival Time to be ‘Random.Exponential(10)’.
Place one of the subclassed vehicle objects by selecting MyVehicle from the Project Library on the left. Specify the Initial Desired Speed to
be '0.5' and the Initial Node (Home) to be ‘Input@Sink1’.
Embellishment:
Add a floor label that will display the distance traveled using the Expression ‘MyVehicle1[1].TotalDistanceTraveled’. You can also display the travel
distance within the current hour by calculating it from the expression ‘MyVehicle1[1].TotalDistanceTraveled -
MyVehicle1[1].PreviousDistanceTraveled’. An attached label could be made to the vehicle in a similar fashion but omitting the ‘MyVehicle1[1].’
term in each expression.
Advanced Notes:
The TotalDistanceTraveled function is very efficient because it is based on a level which is only updated on demand. But if this function (or any
level) is used in certain types of animation and status displays like a floor label or plot, the frequent updating required may cause noticeable
speed degradation.
The changes made to the subclassed vehicle in this SimBit are all “safe” additions, no built-in logic was overridden. This means that you can
confidently update such an object when new changes are introduced by Simio.
143 / 815
Simio Reference Guide
R eferenceBatchedEntity - SimBit
Problem:
I would like to make a decision based on the state (priority) of a batched entity. The Vehicle that the parent entity should select is determined by
the priority state of the member entity.
Categories:
C ombining and Separating Entities, Entity C haracteristics, Vehicles
Key Concepts:
Allow Passing, BatchMembers Queue, Before Exiting, Bidirectional Path, C ombiner, C ondition Based, C urrent Symbol Index, Object Reference
State, Priority, Ride on Transporter, Selection Rule, State Assignments, Vehicle
Technical Approach:
There are three Sources which create entities that will enter a C ombiner. One Source creates what will become the parent entity and the other
two Sources create member entities. One of the member Sources assigns a priority of ‘2’ to the member entity and the other assigns a priority of
‘3’ to its entities. After entities are combined, they ride on a Vehicle. There are two Vehicles to select from and one has a priority value of ‘2’ and
the other has a priority value of ‘3’. The Parent entity must have knowledge of the priority state on the member entity because the value of the
member entity’s priority must equal the value of the Vehicle’s priority. The parent entity has an entity reference state which stores a reference to
the batched member entity so that it can use a function to determine the priority of the member entity.
Details for Building the Model:
Simple System Setup
Place three Source objects into the Facility window. Name them Source_Parent, Source_MemberA and Source_MemberB.
Set the Interarrival Time of Source_Parent to ‘Random.Exponential(.5)’
Set the Interarrival Time of Source_MemberA to ‘Random.Exponential(.75)’ and set the Time OffSet to ‘.2’
Set the Interarrival Time of Source_MemberB to ‘Random.Exponential(.75)’
Place a C ombiner object and a Sink object. C onnect the C ombiner object to the Sink object with a Path. Set the Type property of this path
to ‘Bi-Directional’ and the Allow Passing property to ‘False’. This will allow Vehicles to travel back and forth on the path and not travel on
top of each other.
C onnect Source_Parent to the Parent Input Node of the C ombiner with a Path. C onnect both Source_MemberA and Source_MemberB to
the Member Input Node of the C ombiner with Paths.
Place two Vehicle objects into Facility window. Name one VehicleA and keep its color the default blue. Name the other VehicleB and change
its color to red by selecting red from the C olor drop down in the ribbon while that Vehicle object is selected in the Facility window.
C reate a Transporter List
Select VehicleA and right click. Select ‘Add to Transporter List’ and then select ‘C reate New Transporter List’. Name this list,
‘TransporterList1’.
Select VehicleB and right click. Select ‘Add to Transporter List’ and select ‘TransporterList1’.
To view this List that was just created with a right click shortcut, go to the Definitions tab and then to the Lists Panel. Lists can also be
created in this window.
C reate Additional Entity Symbols
Place a ModelEntity into the Facility window. Select the entityand give it a total of three symbols by clicking on the Add Additional Symbol
icon in the ribbon twice so that the Active Symbol drop down now has a symbol for index 0, 1 and 2.
Select index 1 from the Active Symbol drop down and select a new color (i.e. light blue) and click onto the entity object in the
Facility window to change its color. Similarly, select index 2 from the Active Symbol drop down and select a different color (i.e. pink)
and click onto the entity object to change its color. Index 0 should still display a green entity object.
Select the DefaultEntity object and set its Current Symbol Index property to ‘ModelEntity.Priority – 1’. This will control which symbol is
displayed.
To animate the batched entity, select the DefaultEntity object in the Facility window and select BatchMembers from the Draw Queue drop
down in the Symbols ribbon. Draw the queue near the DefaultEntity object.
Set Properties and States on Entity and Vehicles
Select VehicleA and set its Initial Priority property to ‘2’. Set its Initial Home property to ‘Output@C ombiner1’ and its Idle Action to ‘Park At
Home’.
Select VehicleB and set its Initial Priority property to ‘3’. Set its Initial Home property to ‘Output@C ombiner1’ and its Idle Action to ‘Park At
Home’.
Select Source_MemberA and open the Before Exiting repeat group property under the State Assignments category. Add a State
Assignment where the State Variable Name is set to ‘ModelEntity.Priority’ and the New Value is set to ‘2’.
Select Source_MemberB and open the Before Exiting repeat group property under the State Assignments category. Add a State
Assignment where the State Variable Name is set to ‘ModelEntity.Priority’ and the New Value is set to ‘3’.
C reate Entity Reference State on ModelEntity
Go to the object definition of ModelEntity by selecting it in the Navigation window in the upper right corner of the interface. Go to the
Definitions tab of the ModelEntity and click into the States panel by selecting States on the left side. C reate an Entity Reference State by
selecting ‘Entity’ from the Object Reference drop down menu in the ribbon. Rename this new state, ‘MyBatchedEntity’. This state can later
be referenced using ‘ModelEntity.MyBatchedEntity’.
Add Logic to Model
Navigate back to the main model by selecting Model in the Navigation window. Select the C ombiner object and open the Before Exiting
repeat group property editor, found under the State Assignments category.
Add a new State Assignment where the State Variable Name is ‘ModelEntity.MyBatchedEntity’ and the New Value is
‘ModelEntity.BatchMembers.FirstItem’. The BatchMembers.FirstItem function returns a reference to the first item located in the
BatchMembers queue of this entity. In this case, there is only one entity in the BatchMember queue. The entity reference state,
MyBatchedEntity now contains a reference to the batched entity.
144 / 815
Select the Output@C ombiner1 node and set the Ride On Transporter property to ‘True’.
Set the Transporter Type property to ‘From List’ and the Transporter List Name property to ‘TransporterList1’.
Set the Selection Condition property to ‘ModelEntity.MyBatchedEntity.Priority == C andidate.Transporter.Priority’. This will tell the
model to only select a Vehicle that has a same Priority as the batched entity.
145 / 815
Simio Reference Guide
R egeneratingC ombiner - SimBit
Problem:
You have a palletizer or similar machine but you do not know the exact timing of when to have pallets arrive.
Categories:
C ombining and Separating Entities
Key Concepts:
BatchMembers Queue, C ombiner, On Event Arrival Mode, ParentInputBuffer, Source
Assumptions:
We want to have a supply of three pallets waiting so the process will rarely be delayed by lack of pallets.
Technical Approach:
Use the standard features of a Source object to create one new pallet each time one is consumed. Use the Initial Number Entities property on the
Source when ‘On Event’ is used to generate initial entities (must be at least 1, we used 3).
Details for Building the Model:
Simple System Setup
Place two ModelEntity objects from the Project Library and two Sources, one C ombiner, and one Sink from the Standard Library in the
Facility window of a new model. C onnect Source1 to the ParentInput@C ombiner1 with a C onveyor. C onnect Source2 to the
MemberInput@C ombiner1 with a path. C onnect C ombiner1 to the Sink with a Path.
C hange the Name of the one of the ModelEntity instances to ‘Pallet’ and the other to ‘Part’.
C reating the Pallets
Within Source1, change the Entity Type to ‘Pallet’. Specify Arrival Mode of ‘On Event’. For Event Name, choose ‘Output@C ombiner1.Exited’.
On Source1, specify the number of Initial Number Entities as ‘3’. This will generate pallets to start the simulation.
C reating the Parts and C ombining Them onto Pallets
Within Source2, change the Entity Type to ‘Part’. Set the Time Offset to ‘.5’ minutes so that the parts arrive after the initial pallets.
Within C ombiner1, specify the Batch Quantity as ‘7’. This will combine 7 parts onto a single pallet for later processing. C hange the
Processing Time property to Random.Exponential(1) and the Parent Input Buffer to ‘1’. This will cause the other pallets to wait on the
conveyor.
Discussion:
When Source1 is initialized at the beginning of the model run, it will create 3 Pallet entities and send them out of the normal Source exit node.
C ombiner1 automatically fires an event every time a parent entity exits the C ombiner object. Source1 will wait for that event and create a new
entity each time it occurs, effectively replacing the pallet that was just consumed.
Embellishment:
We added an Attached Queue to the Pallet entity symbol and associated it with the Queue State named 'Pallet.BatchMembers'. This will display the
members in any batch associated with the Pallet, or in this case, after the Pallet “picks up” entities in the C ombiner, they will appear on the pallet.
146 / 815
Simio Reference Guide
R elationalT ableInR epeatingP roperty - SimBit
Problem:
I have three types of patients that require different processing times, as well as multiple doctors and/or nurses for processing.
Categories:
Data Tables, Worker, Workstations
Key Concepts:
Before C reating Entities, Data Table, Dynamic Object Property, Expression Property, Foreign Key, Idle Action, Initial Node (Home), Key column,
Numeric Property, ParkingStation Queue, RandomRow, Ranking Rule, Request Move, ResourceState, Smallest Value First, Status Label, Table
Reference Assignments, Worker, Workstation
Assumption:
Each of the three patient types will have a nurse / doctor combination that determines both the name (doctor/nurse) and quantity of each that is
needed. More severe patients will have higher priority. There will be one nurse and two doctors available to the patients.
Technical Approach:
Relational tables are used to store information about the patients. A Data Table is created that will store information about each patient type,
including the percentage of each that enters the system, and the processing times. A separate related table will include for each patient type the
caregiver type (nurse or doctor) and quantity required. Workers will be used for the Doctors and Nurse and will move between the workstations
to process the patients.
Details for Building the Model:
Simple System Setup
Add a Source, two Workstations, and a Sink to the Facility Window. Also, place three ModelEntity objects from the Project Library into the
window.
C hange the Names of the ModelEntity to be 'Patient_Mild', 'Patient_Medium' and 'Patient_Severe'. C hange the symbol color of each to
distinguish them from one another. This is done by highlighting the symbol and selecting the appropriate C olor from the Symbols ribbon.
Paths and Extra Basic Nodes
Use Paths and connect Source1 each Workstation, and both Workstations to Sink1.
Place a BasicNode above each of the transfer nodes at both Workstations. These nodes will be the used by the Nurses and Doctors to
move between and serve the patients. BasicNode1 should be above Workstation1 and BasicNode2 should be located above Workstation2.
Place an additional BasicNode located in between the workstations, BasicNode3. This will be used as the ‘resting’ location for the workers
when they are not with a patient.
Use unidirectional Paths to connect BasicNode1 to BasicNode3, BasicNode3 to BasicNode2 and then in the other direction from BasicNode2
to BasicNode3 and BasicNode3 to BasicNode1.
Defining the Workers
Place two Worker objects in the Facility Window and rename them ‘Doctor’ and ‘Nurse’. C hange the color of one of the Workers so that you
can tell them apart graphically.
C hange the Park While Busy property to ‘True’ so that graphically we can animate the workers while they are busy.
Within each, change the Initial Node (Home) to ‘BasicNode3’ where they will all start out at the start of the simulation run. Additionally,
change the Idle Action to ‘Go To Home’ so they return to BasicNode3 when they are done with a patient if they are not needed.
Because we have two doctors in the system, change the Initial Number in System (under Dynamic Objects) of the Doctor object to ‘2’.
Setting up the Data Tables
In the Data Window, select the Tables panel and add a Data Table named ‘Patients’ with the following properties and in the following order:
(Entity Object Reference with Name ‘EntityType’) Patient_Mild, Patient_Medium, Patient_Severe
(Integer with Name ‘AmountEach’) 50,40,10
(Expression with Name ‘ProcessingTime ‘ , Unit Type ‘Time and Default Units ‘Minutes’) Random.Triangular(2,3,4),
Random.Triangular(4,6,8), Random.Triangular(10,15,20)
Select the EntityType column and select the Set C olumn as Key button – this will allow data from this column to be referenced with
a Foreign Key column in another table
Add another Data Table named ‘Workers’ with the following properties and in the following order:
Foreign Key with Name ‘EntityType’ and Table Key of ‘Patients.EntityType’) Patient_Mild, Patient_Medium, Patient _Medium,
Patient_Severe, Patient_Severe
Object Instance Transporter with Name ‘Worker Name)Nurse, Nurse, Doctor, Nurse, Doctor
Integer with Name ‘QuantityNeeded ‘) 1,1,1,1,2
** NOTE: Notice in this table, there is 1 Nurse needed for Patient_Mild, 1 Nurse and 1 Doctor needed for Patient_Medium and 1
Nurse and 2 Doctors needed for Patient_Severe. The entity type may be referenced multiple times within the foreign key column in
this table, depending upon the type of caregivers needed
C reating Multiple Entity Types from Source
In the Facility Window, expand the Table Reference Assignment in the Properties Window of the Source object.
Under the Before Creating Entities subcategory, set the Table Name to ‘Patients’ and the Row Number to
‘Patients.AmountEach.RandomRow’.
C hange the Entity Type to ‘Patients.EntityType’ and Interarrival Time to ‘Random.Exponential (5)’.
Specifying the Patient Priority
Within each of the ModelEntity objects, change the priorities of each. The Patient_Mild has an Initial Priority of ‘2’, while Patient_Medium is
‘1’ and Patient_Severe is ‘0’.
Within each of the Workstations, change the Ranking Rule to ‘Smallest Value First’ based on the Ranking Expression ‘Entity.Priority’.
147 / 815
Adding Processing Time and Assignment Information to the Workstations
Within each Workstation, change the Processing Time to ‘Patients.ProcessingTime’.
Expand the Other Requirements and click on the button within the Secondary Resources property to open the repeating property editor.
Use the Add button and add an Object Name of ‘Workers.WorkerName’ and Number of Objects(within the Advanced Options section) of
‘Workers.QuantityNeeded’.
Also within this same repeating property, change the Request Move to ‘To Node’ and specify the Destination Node as ‘BasicNode1’ for
Workstation1 and as ‘BasicNode2’ for Workstation2. This will request that the workers move to the specific basic node locations when
requested at each given workstation.
C lose the repeating property editor and notice that the Secondary Resources property now says ‘1 Row’. Remember that the patient
(entity) itself has a SetRow originally set to ‘Patients’ and its row reference to the specific row in that table (via the Source1 object). We
are now using the relational table ‘Workers’ within the repeating property editor; because of this, we will need to make a change to the
Secondary Resources property that currently says ‘1 Row’. In order for Simio to determine how many rows it really needs to evaluate
within the repeating property editor (since some patients require multiple workers), the data table ‘Workers’ will be referenced in the
Secondary Resources property. Right click on property, select Set Referenced Property and select ‘Workers’. You should see ‘Workers’
then replace ‘1 Row’ in the Secondary Resources property.
Animating the Worker Status and Parking Areas
The status of the doctors and nurses can be animated using a Status Label from the Animation ribbon. Place three status symbols in the
Facility Window. Because the doctors and nurse are dynamic objects, they can be referenced individually. C hange the Expression of the
status labels to ‘Nurse[1].ResourceState’, ‘Doctor[1].ResourceState’ and ‘Doctor[2].ResourceState’, respectively.
Note that the ResourceState function for Workers is ‘0’ when Idle and ‘1’ when Busy.
C lick on BasicNode1 (next to Workstation1) and select Draw Queue > ParkingStation.C ontents from the Appearance ribbon. Place three
vertices for the queue so that there is a location for each of the doctors and nurse to appear while they are busy. Do the same for
BasicNode2.
148 / 815
Simio Reference Guide
R emoveFromAllocationQ ueue - SimBit
Problem:
I have an entity that is waiting for capacity of a resource type object, such as a Server. If the entity has been waiting for 5 minutes, it leaves the
queue and exits the system.
Categories:
Decision Logic -- Processing
Key Concepts:
Add-On Process, AllocationQueue, Assign Step, C ontinueProcess, EndProcess, Execute Step, On Associated Object Destroyed, On Entered, Real
State Variable, Remove Step, SetNode Step, Status Label, Run.TimeNow, Token Actions, Renege, Reneging
Assumption:
In this model, the scenario is a call center where the entities are incoming calls. The callers wait on the line for one of three customer service
reps but if they are not serviced within 5 minutes, they hang up. The waiting time for each entity is displayed in an attached status label, rounded
to the next lowest integer.
Technical Approach:
The Remove Step is used to remove an entity from the Server’s Allocation Queue if it has been waiting longer than 5 minutes. When the entity
enters the Server, it executes a new process (Process1) and then continues with its processing. The new process delays for 5 minutes and then
attempts to remove the entity from the Allocation Queue, if it is still in the queue. This process has a property called Token Associated Object
Destroyed Action, which is set to ‘EndProcess’. This indicates that if the object that is associated with the token executing the process (the entity)
is destroyed, then end the process. So if the entity is still waiting in the queue, it will be removed by this process. But if the entity is no longer
waiting and has been destroyed, this process will be ended.
Details for Building the Model:
Simple System Setup
Place a Source, a Server and two Sinks into the Facility window. C onnect the Source to the Server with a path and connect the Server to
each Sink with paths.
Drag a ModelEntity object into the Facility window. This can be renamed to C ustomerC all to represent a phone call.
C lick on the Source and rename it to ‘Incoming C alls’. Set the Interarrival Time to ‘Random.Exponential(.7)’
C lick on the Server and rename it to ‘C ustomerServiceReps’. Set the ProcessingTime to ‘Random.Exponential(4)’. Set the Initial Capacity
to ‘3’.
Rename one Sink to ‘HangUps’ and the other to ‘ServicedC ustomers’
Add A State to ModelEntity
C lick on the ModelEntity from within the Navigation window on the top right side of the interface. Go to the Definitions tab (this is the
Definitions window of the ModelEntity).
C lick on the States panel on the left. C lick on ‘Discrete State’ in the ribbon to create a new state variable. Rename it to ‘TimeEnteredLine’.
Process Logic
C reate a new Add On Process in the ‘Entered’ trigger of the Server. It will be named ‘Server1_Entered’.
From within the Processes window, place an Assign Step in the ‘Server1_Entered’ process. Set the State Variable Name to
‘ModelEntity.TimeEnteredLine’ and New Value to ‘Run.TimeNow’. This is recording when this entity begins its wait in the Server queue.
Place a SetNode Step after the Assign Step. Set the Destination Type to ‘Specific’ and the Node Name to ‘Input@ServicedC ustomers’. By
default, entities should exit through this Sink.
C reate a new process by clicking on the ‘C reate Process’ icon in the ribbon. Name this ‘Process1’. In the properties of this process, set
Token Associated Object Destroyed Action property to ‘EndProcess’
Back in the ‘Server1_Entered’ process, place an Execute Step after the SetNode Step. Set the Process Name to ‘Process1’ and the Token
Wait Action to ‘None (C ontinue)’. This will cause Process1 to be executed, but the token (and therefore the entity) will continue on with its
action while Process1 begins execution.
Place a Delay Step in Process1. The Delay Time should be 5 minutes.
Place a Remove Step next, that has it’s QueueStateName set to ‘C ustomerServiceReps.AllocationQueue’.
In the Removed segment leaving the Remove Step, place a SetNode Step. The Destination Type should be set to ‘Specific’ and the Node
Name should be ‘Input@HangUp’. This will send removed entities (entities still in the queue after the 5 minute delay), to the HangUp sink.
After the SetNode Step in Process1, place a Transfer Step. Set From to ‘C urrentStation’ and To to ‘Node’ and Node Name to
‘Output@C ustomerServiceReps’. When an entity is removed from a queue, it must be transferred somewhere. Set the Token Wait Action
property to 'WaitUntilTransferringEvent'.
Status Labels
C lick on the C ustomerC all entity in the Facility window and draw an attached Status Label by clicking the Status Label icon in the ribbon
(while C ustomerC all is selected). Set the Expression property to ‘Math.Floor((Run.TimeNow – TimeEnteredLine)*60). This will display the
waiting time (rounded) of each entity as it travels the system.
C lick on each Sink object and draw a Floor Label by clicking the Floor Label icon in the ribbon (while the Sink is selected). Then, click on
the Edit icon in the ribbon to edit the text of this attached Floor Labels. Type ‘Total HangUps: {InputBuffer.NumberEntered}’ and ‘Total
Serviced C ustomers: {InputBuffer.NumberEntered}.
Embellishments:
Vary the Delay time to see how the system changes or set the Delay time as a property and vary it within an experiment. Experiment with the
capacity of the C ustomer Service Rep server to see the impact on the number of customers who hang up.
149 / 815
Simio Reference Guide
R equestR ideFromSameT ransporter - SimBit
Problem:
I have entities that select a transporter from a list, after being processed at a Server, the entity must be picked up by the same transporter.
Categories:
Entity C haracteristics, Worker
Key Concepts:
Object Reference State, Add-On Process, Assign Step, Transporters, ModelEntity, ObjectList, TransporterList, Ride on Transporter,
Entity.C urrentTransporter, Functions
Assumption:
There is one unit of each worker type in the system.
Technical Approach:
A Transporter Reference State Variable will be added to the ModelEntity. An Add-On Process will be used to assign this state variable a value
based on the Transporter that picks up the entity. The transporter reference state will then be used to request a ride on a particular worker later
in the model.
Details for Building the Model:
Simple System Setup
Place a Source, a Server, and a Sink from the Standard Library. Use two Unidirectional Paths (one in the forward, and one in the reverse,
direction) to connect Source and Server1, Input@Server1 and Output@Server1, and Output@Server1 to Sink1. – The reason we use 2
paths here is to avoid deadlocks when the 2 transporters are traveling in opposite directions.
Then connect the Sink to the Source using just one path.
Adding the Transporters and Transporter List
Place two Worker objects in the Facility and change the Name properties to ‘WorkerA’ and ‘WorkerB’.
While holding the C trl key, click on each of the Worker objects. While they are highlighted, right-click in the highlighted area and select
Add to Transporter List > C reate a New Transporter List and name the list ‘WorkerList’. You will notice now that within the Definitions
window, List panel, this new Transporter List is available to view/edit and contains our 2 worker objects.
Also while both Workers are selected, set their Initial Node to ‘Output@Source1’.
Adding a Transporter Reference State
Within the Navigation window, highlight the ModelEntity and go to its Definitions window, States panel.
From the States ribbon, select Object Reference > Transporter. C hange the Name of the object reference state to ‘WhoPickedMeUp’. This
will generate a new state on the entity, referenced ModelEntity.WhoPickedMeUp, which can store a reference to a particular instance of a
Worker.
Defining the Logic
Within the Navigation window, go back to the Model and make sure you are in the Facility window.
Select one of the Workers, expand its Add-On Process Triggers and double-click on the Loaded trigger (make sure you click on the word
Loaded), which will automatically create a new process, and take you to the Processes window.
Add an Assign step to the process and assign the State Variable Name ‘ModelEntity.WhoPickedMeUp’ to the New Value
‘Entity.C urrentTransporter’ – This function returns a reference to the transporter object where the entity is currently riding.
Go back into the Facility window. C lick on the other Worker and add this same process to its Loaded Add-on Process Trigger. The same
Assign step will now be called by both Workers.
Set the Ride on Transporter Property in Output@Source1 to ‘True’, Transporter Type to ‘From List’, and Transporter List Name to
‘WorkerList’.
Finally, set the Ride on Transporter Property in Output@Server1 to ‘True’, leave the Transporter Type as ‘Specific’, and set the Transporter
Name to ‘ModelEntity.WhoPickedMeUp’. – You will have to manually type this value in, the Transporter Name property will make the state
available in the drop down.
Enhancing the Animation
Set the Speed Factor in the Run Window to be 0.010.
Drag in an instance of ModelEntity. While it is selected, click on ‘Status Label’ and draw a box next to the entity. Set its Expression to
‘WhoPickedMeUp’. – The ‘ModelEntity’ is not necessary because the label is already attached to the ModelEntity so it knows what object we
are referring to.
To Rotate the Status Label, press C trl and drag on of the green dots in the corner of the label.
150 / 815
Simio Reference Guide
R esourcesW ithW orkSchedules - SimBit
Problem:
There are two employees that work at a ticket counter. The employees follow two different work schedules.
Categories:
Schedules / C hangeovers
Key Concepts:
C urrent Symbol Index, ObjectList, Resource, Schedules, Secondary Resources
Assumptions:
The work schedule is the same each day – it follows a one day cycle.
Technical Approach:
A server represents the ticket counter and a resource object is used to represent an employee. The capacity of each resource is determined by a
work schedule.
Details for Building the Model:
Simple System Setup
Place a Source, Server, Sink and two Resource objects into the Facility Window. C hange the Name of the resources to ‘Employee1’ and
‘Employee2’.
If you’d like to change the symbol representing the entity, place a ModelEntity object from the Project Library into the Facility Window and
select a new symbol from the symbol tab.
Specifying Information about the Employees
C lick on the Definitions tab, select the Lists panel and create a new Object List with Name ‘ObjectList1’. C lick on the text boxes of the list to
get a drop down that will show all the available objects from the model. Put both ‘Employee1’ and ‘Employee2’ objects in the list.
In the Data tab, Schedules panel, add two new schedules by clicking on the Work Schedules button on the Schedule tab and entering the
schedule Name ‘Schedule1’ and ‘Schedule2’.
Set the number of Days in each schedule to ‘1’. This indicates that this one day schedule repeats itself for each day the simulation is run.
C reate a two Day Patterns by clicking on the Day Patterns tab. Name the two patterns ‘DayPattern1’ and ‘DayPattern2’.
C lick on the ‘+’ sign to expand the Work Periods
C reate a pattern that has a Value of ‘1’ (on shift) in these time slots: 8:00 AM - 10:00 AM, and 12:00 PM -2:00 PM for ‘DayPattern1’. For
‘DayPattern2’, specify a Value of ‘1’ from 8:00 AM - 12:00 PM for. Leave everything else empty, which indicates Off Shift times.
Back within the Work Schedules tab, select ‘DayPattern1’ for ‘Schedule1’ and ‘DayPattern2’ for ‘Schedule2’.
Select each Resource and change the Capacity Type to ‘Work Schedule’ and select the appropriate Work Schedule, either ‘Schedule1’ or
‘Schedule2’.
Using the Employees at the TicketC ounter
In the Facility Window, within the TicketC ounter (Server), open the Secondary Resources and find the Resource for Processing section of
properties. C hange the Object Type to ‘FromList’ and the Object List Name to ‘ObjectList1’.
Animating the Employees
In order to animate the Resource objects to change color when they are busy, click on one of the Employees in the Facility Window. Select
Add Additional Symbol from the symbols tab of the Ribbon. With the Active Symbol icon reading 2 of 2, select a new color (i.e. green)
from the C olor icon in the symbols tab and then click on the center circle of the Resource object. By default, this resource will now change
to green when it is busy. (This is controlled by the default expression in the current symbol index property of the resource object).
151 / 815
Simio Reference Guide
R esourceStatesW henO ffShift - SimBit
Problem:
I have a system with two Servers that each seize a secondary Resource before processing begins. Each Server behaves differently if it is
processing an entity when the seized secondary Resource goes Off Shift. Server1 will finish processing any entities that are currently being
processed but will not begin working on another entity until the secondary Resource is back On Shift. Server2 will immediately end the processing
of any entities when the secondary Resource goes Off Shift.
Categories:
Add-On Process Logic, Resources, Schedules / C hangeovers
Key Concepts:
Add-On Process, Interrupt Step, On Off Shift, OnEnteredProcessing, Real State Variable, Resource, Resource, ResourceState, Save Remaining
Time, Schedules, Status Pie
Assumptions:
When Server2 immediately ends the processing of any entities when the secondary Resource goes Off Shift, the interrupted entity will remember
how much time it has left for processing and get sent back to the InputBuffer of Server2 to queue up so it can finish its processing time when the
secondary Resource comes back On Shift.
Technical Approach:
Server1 will use the default behavior when any seized secondary Resource goes Off Shift, which is to continue processing any entities that are in
the middle of processing during the shift change. The Resource will be put into the Resource State of “OffShiftBusy” during the time when it is
finishing the processing of these entities. Server2 will not follow the default behavior, but instead when the secondary Resource goes Off Shift, it
will Interrupt any processing that is currently occurring on Server2. C apacity of Server2 will be immediately released and the entity will be
transferred back to Server2.InputBuffer with a Transfer Step.
Details for Building the Model:
Simple System Setup
Place a Source and a Sink into the Facility window. Place two Servers between that are in parallel to each other. C onnect the Source to
both Servers with Paths and connect both Servers to the Sink with Paths.
Place two Resource objects into the Facility window.
C reate Work Schedules:
Go to the Data window and go to the Schedules panel by clicking Schedules in the left hand side of the Data window.
Add a new schedule by clicking on the Work Schedules button and entering the schedule Name ‘WorkSchedule1’.
Set the Start Date (i.e. 6/14/2010) and the number of Days to ‘1’.
C reate a Day Pattern by clicking on the Day Pattern tab. Enter the Name ‘DayPattern1’.
C lick on the ‘+’ sign to expand the Work Periods.
C reate a schedule that has a Value of ‘1’ (on shift) in these time slots: 8:00-8:10am, 8:15-8:25am, 8:30-8:40am, and 8:45-8:55am. Leave
everything else empty, which indicates Off Shift times. The schedule of the run starting time day is adjusted depending on the schedule’s
number of days. As the schedule’s number of days is one day, every day will have the same schedule independently of the fact that the
run date is prior to the schedule date. For example a run date starting June 12th vs. a schedule start date on June 14th.
Back in the Facility window, click onto each Resource object and change the C apacity Type property of each to ‘WorkSchedule’ and select
the new Schedule for the Work Schedule property. The same schedule can be used for both Resource objects.
C hange the Run Time parameters by clicking on the Run Tab in the Ribbon. Set the Starting Time to 8:00am and set the Ending Type to 1
Hour.
Adding a New State to ModelEntity
C reate a new State on the ModelEntity. This will keep tracking of the processing time and it is needed because during the Interrupt Step,
we save off the remaining processing time.
C lick on the ModelEntity within the Navigation Window in the top right. When this is selected, go into the Definitions window. You are now in
the Definitions window of the ModelEntity (not the main model).
C lick on the States panel to the left and click on Discrete State in the Ribbon to add a new State. Name this ProcessingTime. Set the Initial
State Value to ‘.4’
Go back to the main model by clicking on Model in the Navigation window.
Go to the Facility window and click on Server1. Set the Processing Time property to ‘ModelEntity.ProcessingTime’. Do the same for
Server2.
Add Process Logic to main Model:
From the Facility window of the main model, click on Server1. C reate two new processes in the Processing and After Processing Add On
Process triggers.
Do the same for Server2 (click on the Server2 and create two new Add On Processes for Processing and After Processing)
Go to the Processes window and place a Seize Step in Server1_Processing process and place a Release Step in the
Server1_AfterProcessing process. These steps will seize the secondary Resource before Server1 begins processing and it will release it
after it has finished processing. In the Seize Step, set Object Type to ‘Specific’ and select ‘Resource1’ from the dropdown of Object Name.
Leave everything else as the defaults.
Do the same for Server2 – add a Seize Step to the Processing process and a Release Step to the Processed process. But instead of seizing
and releasing Resource1 – use Resource2.
Server1 and Resource1 will follow the default behavior when Resource1 goes Off Shift. But Server2 and Resource2 will immediately end
processing. So we need to add process logic when Resource2 goes Off Shift. From within the Facility window, select Resource2. C reate a
new process in the Off Shift Add On Process trigger.
From within the Processes window, place an Interrupt Step in this new process. Set the Process Name to ‘Server2.OnEnteredProcessing’.
Set the Interrupted Process Action to ‘EndProcess’. And set Save RemainingTime to ‘ModelEntity.ProcessingTime’.
In the Interrupted segment of the Interrupt Step, place a Release Step. In the Release Step, set Object Type to ‘Specific’ and select
‘Resource2’ from the dropdown of Object Name. Leave everything else as the defaults.
After the Release Step, place a Transfer Step to move any entity currently being processed into the InputBuffer. Set From to
‘C urrentStation’ and To to ‘Station’ and Station Name to ‘Server2.InputBuffer’.
152 / 815
‘C urrentStation’ and To to ‘Station’ and Station Name to ‘Server2.InputBuffer’.
Adding ResourceState Pie C harts to Facility Window:
In the Facility window, select Resource1 and then click on Status Pie within the Ribbon. Draw the Pie C hart into the Facility window. This
will create a Status pie chart that is attached to Resource1. In the properties window of the Status Pie, set DataType to ‘ListState’ and
ListState to ‘ResourceState’.
Do the same for Resource2. When the model runs, notice the different between the Resource States between the two Resources.
Resource1 will have some time where it is 'OffShiftBusy' because it will finish working on an entity, but Resource2 will never have this
State because it will always interrupt processing when it goes Off Shift so it will never be OffShiftBusy.
Embellishments:
C hange the Work Schedule durations or the Processing times to see changes to flow and balance of the system and therefore to the time spent in
each ResourceState.
See Also:
See Interrupt Step and List States help pages.
153 / 815
Simio Reference Guide
R otatingVehicleExample - SimBit
Problem:
I want a robot to pick parts from the source, to process them at a server and drop them at the sink.
Categories:
Add-On Process Logic, Vehicles
Key Concepts:
Assign Step, C reate Step, Delay Step, Execute Step, Movement.Heading, Movement.X, Movement.Y, Movement.Z, Token Wait Action, Vehicle
Technical Approach:
Add a Vehicle and initialize its coordinates (X, Y, Z) to a basic node placed earlier in the model. Assign new angular values to Movement.Heading
and delay the vehicle to rotate the robot.
154 / 815
Place another Execute step to execute the ‘Server_Process’ that rotates the Vehicle towards the Server object.
C hange the Token Wait Action of the Execute Step to ‘None (C ontinue)’ so that the entity does not wait for the Vehicle to turn before going
to the Server.
Server Add-On Process
Go back to the Facility window and within Server1, create an add-on process at Processed.
Within the Processes window in this new process, place a Delay step to represent the processing time at Server1, ‘2’ minutes.
Place an Execute step to execute ‘Sink_Process’ to rotate the Vehicle towards the Sink object.
C hange the Token Wait Action of the Execute Step to ‘None (C ontinue)’ so that the entity does not wait for the Vehicle to turn before going
to the Sink.
Sink Add-On Process
Within the Facility window, highlight Sink1 and create an add-on process at Entered.
Place a Delay step to model the robot unloading time, ’0.5’ minutes.
Place a Release step to release the vehicle.
Rotating the Vehicle
There are three new processes that need to be added to the Processes window, Source_Process, Server_Process and Sink_Process. These
processes all use the same logic to rotate the vehicle. The only difference resides in the destination heading at the Decide step and the
increments sign (10 or -10) at the Assign step.
Within each process, place a C onditionBased Decide step to check if the vehicle has reached the specified object. For Source_Process, the
Expression is set to ‘Vehicle1[1].Movement.Heading == -90’. For Server_Process, the Expression is ‘Vehicle1[1].Movement.Heading == 0’.
For Sink_Process, the Expression in the Decide step is ‘Vehicle1[1].Movement.Heading == 90’.
Place an Assign step at the False branch of each Decide Step to increment/decrement the vehicle heading by 10. For the Source_Process,
the New Value is ‘Vehicle1[1].Movement.Heading – 10’, while for Server_Process and Sink_Process, the New Value is
‘Vehicle1[1].Movement.Heading + 10’.
Place a Delay step with a Delay Time of ‘3’ and Units of ‘Seconds’ after the Assign step in each process to adjust the rotation speed.
C onnect the Delay steps back to the entry points of the Decide steps for each process.
Enhancing the Animation
In this model, we have placed the objects in a way such as Source1 is at -90°, Server1 is at 0° and Sink1 is at 90°. However, if we don’t
know the angles we could use the Arctangent to find the object’s heading. It is referred to as Math.Atan() in Simio. Also, to find out the
distances, we could use the object’s Location function.
In order not to have the robot rotate about its center, we edited the symbol by adding a small polyline to the robot:
C lick on the project name.
Select Symbols.
Right click on the robot symbol and select Edit.
Draw a small polyline. Leave one third of the robot length between the robot edge and the polyline.
155 / 815
Simio Reference Guide
R outingW ithoutP aths - SimBit
Problem:
My entities travel through a sequence of nodes and there is no travel time in between nodes. Instead of using zero-time TimePaths or
C onnectors, I’d like to have my entities move directly from node to node without traveling on a link.
Categories:
Data Tables, Decision Logic -- Processing
Key Concepts:
Add-On Process, Data Table, Expression Property, Expression Property, Node Property, On Entered, Real State Variable, Search Step, Transfer
Step
Assumption:
The routing information comes from a Simio data table.
Technical Approach:
A Data Table contains two columns; one which is a node property which contains the routing information and the other is an integer property
which indicates the part type. Each entity in the system has a part type and this is used to determine the routing information from the Data Table.
A Transfer Step transfers the entities from Node to Node, eliminating the need for links.
Details for Building the Model:
Simple System Setup
Place two standard Sources, four Servers and one Sink object into the Facility window.
Place two ModelEntity objects into the Facility window. Name one ModelEntity “PartA” and the other “PartB”. C olor PartB red by selecting
the entity in the Facility window and selecting the color red from the C olor dropdown in the Decoration section of the ribbon.
Set Entity Type in Source1 to ‘PartA’ and to ‘PartB’ in Source2.
C reate the Data Table
C reate a new Data Table by going to the Data Window and clicking on Add Data Table from the Tables section of the Table ribbon.
Add a new column to the table by selecting Expression from the Standard Property dropdown in the Properties section of the Table ribbon.
Name this property ‘Part Type’ by changing the Name property in the properties window.
Add another column to the table by selecting Node from the Object Reference dropdown in the Properties section of the Table ribbon.
Name this property ‘MyDestination’.
Fill in the table with the following information:
156 / 815
Simio Reference Guide
ScheduledMaterialArrivals - SimBit
Problem:
I have a data file specifying the times that materials arrive to the system.
Categories:
Data Tables, Workstations
Key Concepts:
Data Table, Event, Material Element, Numeric Property, Process Triggering Event, Produce Step, Source, Timer Element, Workstation
Technical Approach:
C reate a table that specifies the arrival time and quantity of each delivery. C reate a timer that triggers a Produce step in a process to introduce
material into the system.
Details for Building the Model:
Simple System Setup
Place a Source, WorkStation and Sink in the Facility window.
Specify that the Source creates 1 arrival with 6 entities per arrival.
Defining the Data Table with Arrival Information
Open the Data window of the model and select the Tables panel. Use the Add Data Table button to create a table with the Name
‘MaterIalDeliverySchedule’ and include the following columns:
‘ArrivalTime’ – A standard property of type Real that will be used in the Timer object to decide what is created at what time.
‘Quantity’ - A standard property of type Integer that contains a number to indicate the quantity of material delivered at that time.
There should be 3 rows containing ArrivalTime and Quantity: 1, 3; 1.5, 1; 0.5, 2. Note that the rows do not need to be in numerical order
by time.
Material Arrivals using Data Table Information
In the Definitions window, select the Elements panel:
Add a Material element named Widget
Add a Timer named MaterialArrival. Set the Interval Type to ArrivalTable. Set the Arrival Time Property to
MaterialDeliverySchedule.ArrivalTime (the property name within the table that contains the arrival time).
In the Processes window:
C reate a new process named MaterialHasArrived. Set the Triggering Event to MaterialArrival.Event (the event that is fired by the
timer).
Add a Produce step to that process. Set the Production Type to Material. Set the Material Name to Widget. Set the Quantity to
MaterialDeliverySchedule.Quantity (the property name within the table that contains the quantity delivered).
Using the Material Information in the Model
On WorkStation1, within the Materials repeating property editor (Materials and Other C onstraints grouping of properties), specify the
Action Type as 'C onsume', Consumption Type as 'Material' and Material Name as 'Widget'. The Quantity property should be specified as the
entity function 'Entity.Operation.Activity.BatchSize'.
Discussion:
When you use the Arrival Table features of the Timer it will process each row in the table at the correctly specified time and, when triggering a
process, the token in that process will have the specified row associated with it. When a step such as Produce is executed, any table references
will refer to that specified row, allowing other table properties such as Quantity to be used.
Embellishments:
The data in the table can be imported from an external data file and even bound to an external file to cause automatic import at model
initialization. A property of type Date Time can be used instead of a numeric property to store the arrival time.
157 / 815
Simio Reference Guide
ScheduledMaterialArrivalsW ithDeviation - SimBit
Problem:
I have a machine that consumes material and material is scheduled to be available (produced) at specific times. I want to see how variation
around the material arrival times affects my system.
Categories:
Arrival Logic, Data Tables
Key Concepts:
Add-On Process, Arrival Time Deviation, Data Table, Material Element, Numeric Property, On Exited, Produce Step, Source, Status Plot,
Workstation
Assumptions:
We will assume a constant entity interarrival time and a constant processing time so we can see the affects of the material arrival variation.
Technical Approach:
A Workstation object is used and it consumes 1 unit of material with a 1 minute processing time. We set the Material arrival times to be scheduled
to arrive just as the material is due to run out. We will use 2 systems: one with no variation around the material arrival time, and one without.
Details for Building the Model:
Simple System Setup
Place 4 Sources, 2 Workstations and 4 Sinks from the Standard Library into the Facility Window.
C onnect Source1, Workstation1, and Sink1 with Paths. C onnect Source2 and Sink2 with a Path, as well.
Place these two groups of objects on the left hand side of the Facility window.
Now replicate this system with the remaining objects on the right side of the Facility window. C onnect Source3, Workstation2, and Sink3
with paths, as well as Source4 and Sink4.
C reating the Material Arrival Table
In the Tables panel of the Data tab, click Add Data Table. Name this table ‘MaterialArrivalTable’.
Under Standard Property, click ‘Real’ to add a Real Property.
Name this Property ‘ArrivalTime’ and set its Unit Type to ‘Time’ and leave the Units ‘Hours’.
We want the Material to arrive every 15 minutes, so we will fill in the table with arrival table with arrivals every 0.25 hours (0.25, 0.5,
0.75, 1, 1.25, etc…) up to 3 hours.
C reating the Material Elements
Open the Definitions window and select the Elements panel. In the Workflow category, click on the Material Element twice adding 2
Materials: ‘Material1’ and ‘Material2’.
Set both of their Initial Quantities to ‘15’.
Process to Produce Material
The Source-Sink portion of each system is designed to illustrate Material arrivals. So we have to trigger a Produce step somehow.
In Source2, create a process on the Exited Add-On Process Trigger.
In this Source2_Exited process, place a Produce Step. Set the Production Type to ‘Material’, the Material Name to ‘Material1’ and the
Quantity to ‘15’.
Do the same thing for Source4, create a process in Source4’s Exited Add-On Process Trigger.
In the Source4_Exited process, place a Produce Step. Set the Production Type to ‘Material’, the Material Name to ‘Material2’ and the
Quantity to ‘15’.
Defining the Object Properties
Within the Facility window, edit both Source1 and Source3 (either by pressing C trl and selecting both or by editing them separately) so that
the Interarrival Time is ‘1’ and Units is ‘Minutes’ and that the Maximum Time under Stopping C onditions is ‘3’ and Units is ‘Hours’.
Set the Processing Time in both Workstations to ‘1’ and Units to ‘Minutes’.
Within the Materials and Other C onstraints section of the Workstation, open the Materials repeating property editor and set Action Type to
‘C onsume’ and Consumption Type to ‘Material’. Select the Material Name property as ‘Material1’ for Workstation1, and ‘Material2’ for
Workstation2. The Quantity property for both workstations should be ‘Entity.Operation.Activity.BatchSize’.
In both Source2 and Source4, set the Arrival Mode to ‘Arrival Table’ and the Arrival Time Property to ‘MaterialArrivalTable.ArrivalTime’.
In Source2, leave the Arrival Time Deviation property set to ‘0.0’. But in Source4, set it to ‘Random.Uniform(-0.2, 0.2 )’ and Units to
‘Hours’ meaning that the entity will try to arrive via the time specified in MaterialArrivalTable.ArrivalTime – but the actual arrival time will
be anywhere from .2 hours early to .2 hours late.
Embellishments:
We can add some animation, to show the current remaining number of materials while we’re running this model.
C hoose Status Plot from Animation under Facility Tools, create a Status Plot, with the Title ‘C onstant Material Arrivals’, then set the X Axis label to
be ‘Time’ and the Y Axis label to be ‘Quantity’.
Then click on the plot, go to Properties Window, add 2 rows in the Additional Expressions. One row has the Expression set to
‘Material1.QuantityAvailable’, and the Label set to ‘Material1’. The other row has the Expression set to ‘Workstation1.InputBuffer.C ontents’, and the
Label set to ‘Buffer C ontents’. Then we’ll have two animation lines within the plot, one represents the number of Material1 units remaining and the
other one represents the number entities in Workstation1’s Input Buffer.
We want to recreate a similar plot for the Variable System. So we add another Status Plot. We name the new plot ‘Variable Material Arrivals’ and
again set the X Axis label to be ‘Time’ and the Y Axis label to be ‘Quantity’.
We again add 2 rows in the Additional Expressions. But this time we set, the first one to ‘Material2.QuantityAvailable’, and the Label set to
‘Material2’. The other row has the Expression set to ‘Workstation2.InputBuffer.C ontents’, and the Label set to ‘Buffer C ontents’.
158 / 815
These two graphs illustrate how variation upon arrivals can really wreak havoc on the system by occasionally starving the system of material and
allowing a queue to form at the workstation. With constant arrival times and processing times, it is impossible to recover from these queues and
waiting times become significantly longer.
159 / 815
Simio Reference Guide
ScheduleUsesAP roperty - SimBit
Problem:
I would like to use a Work Schedule where the capacity within the schedule is dependent on a user input property.
Categories:
Schedules / C hangeovers
Key concepts:
On Shift, Off Shift, Schedules, Server, WorkSchedule
Technical Approach:
This is a simple Source, Server, Sink model where the Server follows a Work Schedule. The capacity within the Work Schedule is set by the value
of a property. Therefore, when the user changes the value of the property for the simulation run, the capacity of the Server uses this value since
it is reading this value from within the Work Schedule.
Details for Building the Model:
Simple System Setup
Place a Source object, a Server object and a Sink object and connect the Source to the Server with a Path and connect the Server to the
Sink with a Path.
Set the Interarrival Time of the Source to ‘Random.Exponential(.2)’ minutes.
Set the Capacity Type property of the Server object to ‘WorkSchedule’ and set the Work Schedule property to ‘StandardWeek’.
Defining the Property
Go to the Properties window by selecting Properties along the left panel from within the Definitions window.
Select Integer from the Standard Property drop down in the Properties ribbon. Rename this new property, ‘ServerC apacity’.
Defining the Schedule
Go to the Schedules window by selecting Schedule along the left panel from within the Data window.
C lick onto the Day Patterns tab. You’ll see the ‘StandardDay’ day pattern. C lick onto the ‘+’ to expand the pattern.
The Value column has a value of ‘1’ by default. This means that when the simulation clock is between the hours listed, the value of ‘1’ is
set to the capacity of resource that is following this Day Pattern within the a specified Work Schedule. Replace the ‘1’ with the name of the
new property that was created, ‘ServerC apacity’. Have the schedule use this new property for both the 8am-12pm timeframe and the
1pm-5pm timeframe. Note that this Day Pattern named ‘Standard Day’ is then referenced within the ‘Standard Week’ work schedule.
Setting the Model’s ServerC apacity Property
Before you run the model, set the value of the ServerCapacity property by finding it in the Model Properties. Either click into the open
space of the Facility window to bring up Model Properties, or right click onto the name of the Model from within the Navigation window and
select Model Properties. You’ll see the new property, ServerC apacity, and you can set the value and run the model to see how the capacity
of the Server is set to the value of this new property.
You might consider having the model start running at 8:00am, which is when the Work Schedule begins On Shift. This is controlled on the
Run ribbon, under Run Setup.
Embellishments:
C reate an experiment and create different scenarios where the ServerCapacity property has different values and compare the throughput and
average time in system of the entities. To create an Experiment, either right click onto the name of the Model in the Navigation Window and select
New Experiment or click onto New Experiment from the Project Home ribbon.
160 / 815
Simio Reference Guide
SearchStationElement - SimBit
Problem:
I’d like to use a Station element and I’d like to search the entities in a Station and find one that meets my specific criteria.
Categories:
Add-On Process Logic, C ombining and Separating Entities, Decision Logic -- Processing
Key concepts:
Active Symbol, Add-On Process, Batch Step, Decide Step, EndTransfer Step, From C urrent Station, Match C ondition, On C reated Entity, On Event
Arrival Mode, ReturnValue, Search Step, Selection Weight, State Assignments, Station Element, Transfer Step
Technical Approach:
Each time Source1 creates an entity, another entity is created via a C reate Step within a process. It is given a new picture (30% - green, 30% -
red, 40% - blue). This new entity is then transferred into Station1.
Another Source sends an entity to Server1. Before processing at Server1, the entity searches Station1 to try and find a matching entity
(ModelEntity.Picture) and if a match is found, they are batched, processed and they move to the Sink named Batched. If there is not currently a
match in the Station, the entity is processed and moves to the Sink named Single.
Details for Building the Model:
C reating Entities for the Station
Place a Source object and a Sink object and connect them with a Path.
In the Source object (Source1), set the Arrival Mode property to ‘On Event’. Set the Initial Number Entities to ‘10’. Set the
Triggering Event Name to ‘Station1.Exited’.
This Source object will start by creating 10 entities, but will then wait to create another entity when an entity exits Station1.
C reate a new Add-On Process in the Created Entity Add-On Process trigger. We will populate this process later when we get to the
Processes window.
Place a ModelEntity from the Project Library into the Facility window.
With the DefaultEntity selected, click onto Add Additional Symbol (twice) in the Symbols ribbon so that there are three different
symbols now available for this DefaultEntity.
Make the second symbol active by selecting 2 of 3 from the Active Symbol drop down in the Symbols ribbon (the entity should still
be selected in the Facility window). C lick onto C olor in the Symbols ribbon and select Red and then click onto the DefaultEntity so
that the color turns Red.
Make the third symbol active by selecting 3 of 3 from the Active Symbol drop down in the Symbols ribbon (the entity should still be
selected in the Facility window). C lick onto C olor in the Symbols ribbon and select Blue and then click onto the DefaultEntity so that
the color turns Blue.
You should now have three different symbols for the Default Entity – green, red and blue, where green has a ‘0’ next to it in the
Active Symbol drop down, Red has a ‘1’ and Blue has a ‘2’.
C reating Entities for Server Processing
Place another Source object, a Server object and two Sink objects into the Facility window. C hange the Name of one of the Sinks ‘Batched’
and the other ‘Single’.
C onnect Source2 to Server1 with a Path and connect Server1 to each of the Sink objects with a Path.
In Source2, create a new State Assignment in the Before Existing Assignment property. Use the Discrete distribution to assign a random
value to State Variable Name of ‘ModelEntity.Picture’, which is a built-in state on the ModelEntity object (this also controls the color of the
DefaultEntity symbol). The New Value of the assignment is ‘Random.Discrete(0, .3, 1, .6, 2, 1 )’. This will assign 30% of the entities green,
30% red and 40% blue.
In Server1, set the Initial Capacity property to ‘5’ and the Processing Time property to ‘.1’ minutes. C reate a new Add-On Process in the
Processing Add-On Process Triggers. We will populate this process later when we get to the Processes window.
Select the path that leads from the Server to the Batched Sink. Set the Selection Weight of this path to ‘ModelEntity.BatchMembers > 0’.
This will force only entities that have another entity in its BatchMembers queue (i.e. batched entities) to follow this path.
Select the other path which leads from the Server to the Single Sink. Set the Selection Weight of this path to ‘ModelEntity.BatchMembers
== 0’. This will force only entities that do not have an entity in the BatchMembers queue (i.e. unbatched, single entities) to follow this path.
C reating Elements in the Definitions Window
Within the Definitions tab, select the Elements panel. C lick onto Station in the Elements ribbon to create a new Station element.
C lick onto Batch Logic in the Elements ribbon to create a new Batch Logic element. This will be used within process logic to batch entities
together.
Process Logic within the Processes Window
C lick onto C reate Process in the Processes ribbon to create a new process, named Process1.
Find the process property named Triggering Event Name and populate it with the event, ‘Station1.Entered’. This indicates that this
process will be executed whenever an entity enters Station1.
Place an EndTransfer step into this process. This indicates that the transfer has been completed and that the entity is now inside the
station.
Find the Source1_C reatedEntity process. This is the process that is executed each time Source1 creates an entity.
Place a C reate Step. Set the Entity Type property to ‘DefaultEntity’.
In the C reated exit leaving the C reate step, place an Assign step. Set the State Variable Name property to ‘ModelEntity.Picture’ and
the New Value property to ‘Random.Discrete(0, .3, 1, .6, 2, 1 )’. This will assign 30% of the entities to green, 30% - red, 40% -
blue.
After the Assign Step, place a Transfer step. Set the From property to ‘FreeSpace’. Entities are always created in FreeSpace. Set the
To property to ‘Station’ and the Station Name to ‘Station1’.
Find the Server1_Processing process. This is the process that is executed each time an entity is about to start processing on Server1.
161 / 815
Place a Search step. This step will search the Station to try and find an entity with the same color as the entity about to process at
the Server. If a matching entity is found, its ModelEntity.ID is saved into the Token.ReturnValue. Set the Collection Type to
‘QueueState’ and the Queue State Name to ‘Station1.C ontents.’ Set the Match Condition to ‘ModelEntity.Picture ==
C andidate.ModelEntity.Picture’. Set the Search Expression to ‘ModelEntity.ID’.
Place a Decide step out of the Original exit leaving the Search step. Set the Decide Type to ‘C onditionalBased’ and the Expression
to ‘Token.ReturnValue == 0’. This checks to see if the Search Step found a matching entity. If the ReturnValue of the token is
anything other than zero, then the Search step found a match and put the ModelEntity.ID of that entity into the Token.ReturnValue.
Place a Batch step out of the False exit leaving the Decide step. Set the Batch Logic Name to the name of the Batch Element that
was created earlier. Set the Category to ‘Parent’. This entity (which is the original entity at the Server), will become the parent in
the batch.
Place a Transfer step out of the Found exit of the Search step. Set the From property to ‘C urrentStation’ and the To property to
‘FreeSpace’. This Step is only executed if a matching entity is found via the Search step. It will transfer that entity out of the Station
and into FreeSpace.
Place a Batch step after the Transfer step. Set the Batch Logic Name to the name of the Batch Element that was created earlier. Set
the Category to ‘Member’. This entity (which is entity that was just transferred out of the Station), will become the member in the
batch.
Animating Queues
Animate the contents of the Station by clicking onto the Animation ribbon and selecting Detached Queue. Draw a queue into the Facility
window and set the Queue State to ‘Station1.C ontents’.
Animate the batched items that are attached to the ModelEntity by selecting the DefaultEntity in the Facility window and selecting Batch
Members from the Draw Queue dropdown in the Symbols ribbon. Draw the queue somewhere near the instance of DefaultEntity. This is an
attached queue.
162 / 815
Simio Reference Guide
SearchT ables - SimBit
Problem:
I would like to be able to search through a Data Table and select a row based on certain criteria.
Categories:
Arrival Logic, Data Tables
Key Concepts:
Add-On Process, Assign Step, C ollection Type, C urrent Symbol Index, Data Table, Match C ondition, ModelEntity, Node Property, Numeric Property,
On C reated Entity, Priority, Search Step, SetNode Step, TableRows, TransferNode
Technical Approach:
A Data Table contains an Integer property and a Node Property. Each entity is assigned a value of 1, 2, 3 or 4 to its priority. A token searches the
Data Table on behalf of the entity to find the row that matches the value of its priority. Once the appropriate row is found, the destination of the
entity is set to the Node that is listed in the Data Table.
Details for Building the Model:
Simple System Setup
Place a Source and a Sink into the Facility window. Place four Transfer nodes in between the two objects - the nodes should be in parallel.
C onnect the Source to each of the four nodes and connect each node to the Sink.
Place a ModelEntity into the Facility window. To help with model verification, we’ll have the entity change color depending on its priority
(and therefore its destination node).
Select the DefaultEntity in the Facility window and click on the Add Additional Symbol icon in the ribbon. You will see that the icon to
the right, Active Symbol, now displays 2 of 2. C lick on the C olor icon, select a color and then click back into the Default Entity in the
Facility window. The symbol should change color. You have now changed the color of whatever symbol is active (if it says 2 of 2,
then you changed the color of the second symbol that is associated with this Default Entity object).
Add two more symbols to this object by repeating the steps above and assign a unique color to each of the four symbols.
C reate Data Table
Go to the Data window, and within the Tables panel, click the Add Data Table icon in the ribbon to add a new table.
Add a column that is an Integer property by selecting Integer from the Standard Property drop down in the ribbon. The column can be
renamed to Priority.
Add a second column to the table – a Node Property, by select Node from the Object Reference drop down in the ribbon. The column can
be renamed to Node.
Fill the table with data – such as:
1 , TransferNode1
2 , TransferNode2
3 , TransferNode3
4 , TransferNode4
Add Process Logic
From within the Facility window, click on the Source and create a new Add On Process for the trigger called Created Entity. (select C reate
New from the drop down)
From within the Processes window, you should see the new Process that was created.
Place an Assign step in the process. The StateVariable Name should be ModelEntity.Priority and the New Value should be
Random.Discrete(1, .25, 2, .5, 3, .75, 4, 1). Each entity has a 25% chance of being assigned a Priority of 1, 2, 3 or 4.
Place a Search Step after the Assign Step. The Collection Type property should be set to ‘TableRows’ and the Table Name property
should be the name of your Data Table (Table1). Set the Match Condition to be ‘ModelEntity.Priority == Table1.Priority’. This will
ensure that the entity is set to read the row that matches its priority value.
In the Found segment of the Search Step, place a SetNode step. The Destination Type property is ‘Specific’ and the Node Name
property should be set to ‘Table1.Node’.
Embellishments:
C hange the matching condition for searching the table and add additional information in the Data Table to be used in the model.
163 / 815
Simio Reference Guide
SearchT ableUponEnteringO bject - SimBit
Problem:
Each object in my model reads data from a table to determine its processing time and the number of resources it must seize before processing. I
do not want to hard code the row where each object should look for its data, but instead the entity should search the table whenever it enters the
Server to find the appropriate data.
Categories:
Data Tables
Key Concepts:
Add-On Process, Blocked Destination Rule, C yclic, Data Table, Entity, Entity Destination Type, Expression Property, ID, NodeList, Numeric
Property, On Entered, Location.Parent, Real State Variable, Resource, RowNumber, Save Index Found, Search Step, Secondary Resources, Select
Available Only, Selection Goal, Server, SetRow Step, String Property, Token, Token State, TransferNode
Technical Approach:
This model contains three Servers in parallel. An entity travels to one of the three Servers, seizes a certain number of Resources, delays for a
certain amount of time and then releases the Resources. The number of Resources and the delay duration is different for each Server. This
information is stored in a table. To find the appropriate row in the table, the token must search the table and find the row that contains the
information for that particular Server. The search uses the ID of the Server object to find the appropriate row in the table.
Details for Building the Model:
Basic Model Setup within the Facility window
Place a Source followed by a Transfer Node and connect them with a C onnector.
Place three Servers in parallel and another Transfer Node after these Servers. C onnect the first TransferNode to all three Servers with
Paths and connect the Servers to the second Transfer Node with Paths.
Place a Sink and connect to the second Transfer Node to the Sink.
Go to the Definitions window and create a new Node List from the Lists panel on the left. Add Input@Server1, Input@Server2 and
Input@Server3 to the Node List.
Back in the Facility window, set the EntityDestinationType property of the first Transfer Node to ‘Select From List’ and set Node List Name to
your new List. Set Selection Goal to ‘C yclic’.
Place a standard Resource object and set the Initial Capacity to ‘6’. Name this ‘Resources’.
C reating the Table within the Data window
C reate a new Data Table by clicking the ‘Add Data Table’ icon in the ribbon. Name this table ‘ServerData’
In ServerData, add four columns; An Object property named ‘ServerName’, an Integer Property column named ‘NumberOfResources’ and
an Expression Property column named ‘Hours’.
Place the following data into the Table:
Server1, 3, .1
Server2, 2, .05
Server3, 1, .02
Adding a New Token in the Definitions window
Go to the Tokens panel within the Definitions window and click on the ‘Add Token’ icon in the ribbon.
Select the name of the new token and then click on the ‘Real’ icon in the ribbon to add a new Real State to this token. Name this new
state, ‘RowNumber’. The new token type will be used in the process below. The default token in Simio does not have any custom States
and this model will save off a row number within the process into a custom state on the token so we will use this new token type instead of
the default Simio token.
Searching the Table in the Processes window
C reate a new Process by clicking ‘C reate Process’ from the ribbon. Name this process ‘MyProcess’ in the properties window. C lick
anywhere within the process and open the Advanced Options category in the Process Properties window. Set the Token Class Name to
‘MyToken1’ , which is the name of the new token you created above.
Place a Search Step
Set the Collection Type to ‘TableRows’.
Set the Table Name to ‘ServerData’. This tells the Search Step to search through the Table to find the appropriate row.
Set the Match Condition to ‘Entity.Location.Parent == ServerData.ServerName’. The function Entity.Location.Parent returns a
reference to the object that this Entity is currently inside of (i.e. the current Server). And we want the Search step to find the row
within the ServerName column of the ServerData that matches the current Server.
Set Save Index Found to 'MyToken1.RowNumber' to save off the row number temporarily.
Place a SetRow step in the Original segment leaving the Search step. Set the Table Name property to ‘ServerData’ and the Row Number to
‘MyToken1.RowNumber’.
Referencing the Table within the Servers
Return to the Facility window and select Server1. Set the Processing Time property to ‘ServerData.Hours’ to read the processing time from
the table.
Under the Secondary Resources category, find ‘Other Resource Seizes’ and open the window for Before Processing. Set Object Name to
‘Resources’ and Units Per Object to ‘ServerData.NumberOfResources’. This tells the Server to seize capacity of Resources before
processing begins at this Server.
Under the Secondary Resources category, find ‘Other Resource Releases’ and open the window for After Processing. Set Object Name to
‘Resources’ and Units Per Object to ‘ServerData.NumberOfResources’. This tells the Server to release capacity of Resources after
processing is finished at this Server.
Find the Entered Add On Process trigger within this Server and select the new process you named MyProcess from the drop down. This
tells the Server to execute this process when an entity enters this Server and this is where the entity will search the table to find the
appropriate row.
164 / 815
Repeat the above steps for the other two Servers.
See Also:
The SimBit named “HierarchyWithTables.spfx” uses this model inside of another model and demonstrates the changes that are needed to this
model in order for it to work properly as a submodel inside of another.
165 / 815
Simio Reference Guide
SeizingSameR esourceFromList - SimBit
Problem:
I have entities that select a resource from a list of resources, but once selected, they must use that same resource throughout their processing.
Categories:
Entity C haracteristics
Key Concepts:
Object Reference State, Add-On Process, Assign Step, Resources, Discrete State, ModelEntity, ObjectList, Lists, Resource, Secondary Resources
Assumptions:
There are three resources within the set. Server1 has a capacity of 3, while Server2 has a capacity of 1.
Technical Approach:
An Object Reference State Variable will be added to the ModelEntity. An Add-On Process will be used to assign this state variable a value based
on the resource the entity seized from a resource set. The object reference state will then be used to seize that particular resource later in the
processing.
Details for Building the Model:
Simple System Setup
Place a Source, two Servers and a Sink from the Standard Library. Use Paths to connect the Source to Server1, Server1 to Server2, and
Server2 to the Sink. C hange the Interarrival Time of the Source to ‘Random.Exponential(3)’.
C hange the Initial Capacity of Server1 to ‘3’ because the server can process up to 3 entities at a time. Also change the server’s Processing
Time to ‘Random.Triangular(1,2,3)’.
C hange the Processing Time of Server2 to ‘Random.Triangular(1,2,3)’.
Adding the Resources and Resource List
Place three Resource objects in the Facility and change the Name properties to ‘R1’, ‘R2’ and ‘R3’.
Place the mouse to the top left of all three resources, and press the C trl key and drag the mouse to encompass all three Resources. While
they are all highlighted, right-click in the highlighted area and select Add to Object List > C reate a New Object List and name the list
‘Resources’. You will notice now that within the Definitions window, List panel, the three resource objects have been added to the
Resources list.
Adding an Object Reference State
Within the Navigation window, highlight the ModelEntity and go to its Definitions window, States panel.
From the States ribbon, select Object Reference > Object. C hange the Name of the object reference state to ‘WhichResource’. This will
generate a new state of the entity, referenced ModelEntity.WhichState, that can store a reference to the resource that is seized in Server1.
Seizing the Resources
Within the Navigation window, go back to the Model and make sure you are in the Facility window.
Within Server1, under Secondary Resources, change the Object Type to ‘From List’ and the Object List Name to ‘Resources’.
Also within Server1, under the Add-On Process Triggers, double click on Processing, which will create a new process named
‘Server1_Processing’ and will also take you within the Processes window.
Add an Assign step to the process and assign the State Variable Name ‘ModelEntity.WhichResource’ to the New Value
‘ModelEntity.SeizedResources.LastItem’. This will store a reference to the last item that the entity seized, which would be one of the 3
resources. We can then use that information within Server2.
Go back into the Facility window. Within Server2’s Secondary Resources, keep the Object Type of ‘Specific’ and add the value
‘ModelEntity.WhichResource’ as the Object Name. This will then use each entity’s object reference that was assigned to determine the
resource to seize.
Embellishments:
This model could also easily be built using 3 workers instead of 3 resources. The worker may be selected to move the entity from Server1 to
Server2. First of all, you would add 3 worker objects to the model; group select them and right-click to Add to Transporter List (instead of Object
List). C hange the Object List Name in Server1 to the Transporter list name you just created. Finally, if you wanted to have the worker move the
entity from one server to the other, you would click on the transfer node of Server1 (Output@Server1), specify Ride on Transporter as ‘True’ and
specify the Transporter Name as ‘ModelEntity.WhichResource.Transporter’.
** Note: If the Object Reference state on the entity was a ‘Transporter’ object reference, the Transporter Name would be specified as
‘ModelEntity.WhichResource’; but because the object reference was an Object and Simio is looking for a Transporter Name (as opposed to Object
Name), the name must include the ‘.Transporter’ to signify what type of object it is. See help for Element and Object Reference States for more
information.
166 / 815
Simio Reference Guide
SeizingVehicle - SimBit
Problem:
I would like to model a system that has a vehicle which is used for both transport and non transport activities. The vehicle’s capacity is seized by
another object for the non-transport activities.
Categories:
Vehicle
Key Concepts:
Add-On Process, Decide Step, Is, Processing, After Processing, Release Step, Ride on Transporter, Seize Step, Vehicle
Technical Approach:
There are two Sources that each produce a different type of entity; PartA and PartB. Both types of entities are processed by Server1. However,
PartB type entities require the Vehicle object to be seized before processing at Server1 can occur. A Decide Step before processing checks to see
what part type it is and then a Seize step seizes capacity of the Vehicle object and requests a move to the Node near Server1. All entities are
then processed by Server2 and the Vehicle is required to transport all entities from Server2 to the Sink. Therefore, the same Vehicle object is
transporting entities and also visiting Server1 to help with processing. Helping with Server1 has a higher priority.
Details for Building the Model:
Simple System Setup
Place two Sources and two ModelEntity objects into the Facility window. Rename the entity objects to PartA and PartB. Set Source1’s Entity
Type property to ‘PartA’ and Source2’s Entity Type property to ‘PartB’. C hange the Interarrival Time of Source2 to Random.Exponential(.9)
hours.
Place a Vehicle into the Facility window. Set the Initial Node(Home) to ‘Output@Server2’ and Idle Action to ‘None’.
Place two Servers into the Facility window, in series. C onnect both Sources to Server1 with Paths and connect Server1 and Server2 with a
Path.
Place a Sink into the Facility window and connect Server2 with the Sink with a Path. C hange the Type property of the Path to ‘Bidirectional’.
This is required so the vehicle can travel back and forth on this path.
In the Output node of Server2, set the Entity Destination property to ‘Specific’ and the Node Name to ‘Input@Sink1’. Set Ride On
Transporter to ‘True’, Transporter Type to ‘Specific’ and Transporter Name to ‘Vehicle1’.
Place a TransferNode just above Server1. This will be where the Vehicle moves when it is helping with processing for Server1. Place a Path
between Server2 and the new TransferNode. Make this path bi-directional by setting the Type property to ‘Bidirectional’.
Add Process Logic
From within the Facility window, click on Server1 and create two new Add On Processes for the triggers Processing and After
Processing.(select C reate New from the drop down)
From within the Processes window, you should see the new Processes that were created.
In the Server1_Processing process, place a Decide step. The Decide Type is ‘C onditional’ and the Expression is ‘Is.PartB’. This
checks to see if the entity is a PartB type entity.
In the True segment, place a Seize step. Open the Seizes – Repeating Property Editor by pressing the … button on the right side of
the Seizes property. The Object Type is ‘Specific’ and the Object Name is ‘Vehicle1’. Set the Request Move to ‘ToNode’ and the
Destination Node to ‘TransferNode1’. This will request that Vehicle1 move to TransferNode1 for servicing PartB before it starts
processing.
In the Server1_AfterProcessing process, place a Decide step. The Decide Type is ‘C onditional’ and the Expression is ‘Is.PartB’. This
checks to see if the entity is a PartB type entity.
In the True segment, place a Release Step. Set the Object Name to ‘Vehicle1’ within the Releases – Repeating Property Editor.
167 / 815
Simio Reference Guide
SelectEntityC olorFromStringList - SimBit
Problem:
I would like to choose, from a menu, a property for each entity added to my model. The destination of each entity is dependent upon its property
value.
Categories:
Entity C haracteristics
Key Concepts:
List Property, ModelEntity, Selection Weight, StringList
Assumptions:
Each entity color is associated with exactly one source and sink. One server will process each entity type.
Technical Approach:
A string list of colors is created in the ModelEntity objects’ Definitions windows. A list property is created and when an entity is placed, the
property value of that entity is selected from a menu.
Details for Building the Model:
Simple System Setup
Add two Sources, a Server, and three Sinks to the Facility Window.
C onnect the two Sources to the Server with Paths. C onnect the Server to the three Sinks with Paths.
C reating a String List
Select the ModelEntity in the Navigation window. Then click the Definitions tab and select Lists in the panel. Add a String List with the Name
of ‘C olors’. Add as many colors as desired.
Adding a List Property
In the Properties panel of the Definitions window of the ModelEntity, add a List Property with the Name ‘C olor’.
Set the List Name property under Logic to ‘C olors’ and the Category Name property under Appearance to ‘Properties’. This will give the
user the option to specify C olor as a property of an entity and the list of C olors will be shown as options.
Adding an Entity to the Model
Place a ModelEntity from the Project Library in the Facility Window. Select the desired color from the Color property drop down list. Then
change the color of the entity to match that choice.
C hange the Entity Type Arrival Logic property of the Source to match the color of its associated entity.
Set the Selection Weight of each path from the Server to the Sink to ‘ModelEntity.C olor==ModelEntity.List.C olors.[Desired C olor]’. For
example, if you created Red entities and Blue entities, you would want to have at least a Red Sink and a Blue Sink and then have the
Selection Weight expression have ModelEntity.C olor==ModelEntity.List.C olors.Blue on one of the paths and
ModelEntity.C olor==ModelEntity.List.C olors.Red on the other.
Note: The actual color of the entity is not related to this color property we are putting onto the ModelEntity. This is just to control logic. To
change the animated color, you should select the entity and change its color with the C olor button in the Symbols ribbon.
Embellishments:
Add entities, sources and sinks of additional colors.
168 / 815
Simio Reference Guide
SelectEntityT ypeFromT able - SimBit
Problem:
I have a data file containing information about my products, product mix and processing parameters.
Categories:
Entity C haracteristics
Key Concepts:
Before C reating Entities, Data Table, Data Table, Dynamic Object Property, Expression Property, Numeric Property, RandomRow, Source, Table
Reference Assignments
Technical Approach:
C reate a table that contains the product mix and processing information for each part type possible.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink in the Facility Window.
Place 3 ModelEntity objects from the Project Library into the Facility Window and change the Name property values to ‘PartA’, ‘PartB’ and
‘PartC ’.
Defining the Data Table with Product Information
C lick on the Data tab of the model and select the Tables panel. Add a DataTable with the Name ‘ProductTable’ and include the following
columns:
‘PartType’ – An object reference property of type Entity that will be used in the Source object to decide what is created
‘ProductMix’ - A standard property of type Real that contains a number to indicate the weight (likelihood) of creating that entity type.
‘ProcessTime’ - A standard property of type Expression to be used elsewhere in the model.
There should be 3 rows containing PartType, ProductMix and ProcessTime data: PartA, 50, 2; PartB, 30, 4; and PartC , 20;
Random.Uniform(4, 6).
Generating Random Entities using Data Table Information
Within Source1, expand the Table Reference Assignment section of the Properties Window.
Set the Table Name to ‘ProductTable’. Apply the RandomRow table function to the ProductMix column by setting the value of the Row
Number to ‘ProductTable.ProductMix.RandomRow. This will select a row based on the weight value in each row (e.g. the first part type (row
1) will be selected 50/(50+30+20) or 50% of the time).
Using the Product Information in the Model
On Source1, specify the Entity Type property to be created from ‘ProductTable.PartType’.
On Server1, specify the Processing Time property as ‘ProductTable.ProcessTime’.
Discussion:
You could add additional columns to provide data for use elsewhere in the model.
There are two forms of referencing table data:
TableName.PropertyName - When you use SetRow as we have done here to set the row for that entity, you do not need to specify the row
number.
TableName[RowNumber].PropertyName - If you want to explicitly reference a different row, or make a table reference from an entity that
does not have a designated row, you can use this form.
169 / 815
Simio Reference Guide
SelectingR esourceFromList - SimBit
Problem:
I have a group of 2 Resources called Mechanics. I have three Servers in parallel that all share the group of mechanics for processing and must
seize one of the two before it can process the entity.
Categories:
Resources
Key Concepts:
Lists, ObjectList, Resource, Secondary Resources, Server
Assumptions:
There are no restrictions on which mechanic should be seized – either resource can work on any one of the three servers. Each server seizes in
Preferred Order, which means if both resources are available, they will always select Resource 1.
Technical Approach:
Place both the Servers and the Resources in the Facility Window before then creating an Object List the Lists panel of the Definitions Window. Use
Add-On Processes in each Server to Seize and Release from the List.
Details for Building the Model:
Simple System Setup
Place a Source, a Sink and three Servers (in parallel) in the Facility Window. Ensure that the Servers each have a capacity of Infinity. The
server capacity is not the constraint in this model – the ability to seize a Resource is the constraint.
Place two Resources in the Facility Window.
Defining the Resource List
C lick on the Definitions tab and select the Lists panel. Since we are creating a List of Resources, which are Objects, we need to click on the
Object list button. C hange the Name of the list to ‘Mechanics’.
Select the first cell in the table and select ‘Resource1’. Then do the same for the second row and select ‘Resource2’.
Using the Resources in the Server Processing
Within each of the 3 Servers, enter the Secondary Resources / Resource for Processing section or properties. C hange the Object Type to
‘FromList’ and the Object List Name to ‘Mechanics’.
See Also:
A related SimBit is SelectingResourcesAsAGroup.spf, which would be used if you’d like to seize multiple mechanics together before processing.
170 / 815
Simio Reference Guide
SelectingR esourcesAsAG roup - SimBit
Problem:
I have a group of 4 Resources called Mechanics. I have a Server that all requires two mechanics for processing and must seize both before it can
process the entity.
Categories:
Resources
Key Concepts:
Lists, ObjectList, Resource, Secondary Resources, Server
Assumptions:
There are no restrictions on which two mechanics should be seized. Each server seizes in Preferred Order, which means if all resources are
available, they will always select the first two listed in the object list. Other selection rules might result in different usage patterns.
Technical Approach:
Place both the server and the resources in the Facility Window before then creating an Object list in the Lists panel of the Definitions Window. Use
Add-On Processes in the Server to Seize and Release from the object list.
Details for Building the Model:
Simple System Setup
Place a Source, a Sink and one Server in the Facility Window. Ensure that the Server has a capacity of Infinity. The server capacity is not
the constraint in this model – the ability to seize a Resource is the constraint.
Place four Resources in the Facility Window.
Defining the Resource List
C lick on the Definitions tab and select the Lists panel. Since we are creating a List of Resources, which are Objects, we need to click on the
Object list button. C hange the Name of the list to ‘Mechanics’.
Select the first cell in the table and select ‘Resource1’. Then do the same for the second row and select ‘Resource2’, and continue with
‘Resource3’ and ‘Resource4’ in the third and fourth rows.
Using the Resources in the Server Processing
Within Server1, we will use the properties within the Secondary Resources section to seize the resources before processing and release
the resources after processing.
In the Other Resource Seizes section, enter the Before Processing repeating editor and change the Object Type to ‘FromList’. The Object
List Name should be ‘Mechanics’ and ensure that the Number of Objects is set to ‘2’. The Selection Goal is ‘PreferredOrder’ so that so that if
multiple Resources are available, the Resource that is listed first in the List will be selected.
Do a similar thing for the Other Resource Releases section, After Processingrepeating editor – release from an Object List Name of
‘Mechanics’ and the Number of Objects of ‘2’.
Embellishment:
We have added a second symbol to each resource and changed the color of the disk to red to indicate when it is busy.
171 / 815
Simio Reference Guide
SelectServerW ithShortestLine - SimBit
Problem:
I would like my entities to always go to the Server with the least number of entities waiting in its queue.
Categories:
Decision Logic -- Paths
Key Concepts:
AssociatedStationLoad, C andidate, Entity Destination Type, Lists, Node, NodeList, Selection Goal, SmallestValue, Source, TransferNode
Assumptions:
There is one Source producing entities that are choosing which Server to go to.
Technical Approach:
A Node List of all Input Nodes at the Servers will be created in the Definitions Window. The Routing Logic at the Output Node of the Source will set
the Entity Destination Type to ‘Select From List’. The entities will select the Server with the largest value of remaining input capacity.
Details for Building the Model:
Simple System Setup
Add a Source, three Servers and three Sinks to the Facility Window. Set a different Processing Time for each of the Servers; for example
Server1 is set to ‘20’ minutes, Server2 is set to ‘Random.Triangular(1,3,8)’ minutes and Server3 is set to ‘0.1’ minutes.
Use Paths to connect the Source to each Server and each Server to its respective Sink.
C reating a Node List
• Select the Definitions tab and click on the Lists panel to add a Node list and change its Name to ‘Servers’. Add the three Input Nodes of
the Servers to the list. The order of the list will not affect the model.
Adding Logic to the Model
Select the Source’s Output Node and change the Entity Destination Type to ‘Select From List’. C hoose the newly created node list called
‘Servers’ for the Node List Name property.
The Selection Goal should be set to ‘Smallest Value’ and the Selection Expression should be set to ‘C andidate.Node.AssociatedStationLoad’.
This will ensure that the entity chooses a Server based on the least number of entities waiting or en-route to the Server.
Embellishments:
Try changing the Interarrival Time of the Source or the Processing Times of the Servers.
172 / 815
Simio Reference Guide
SelectSpecificVehicle - SimBit
Problem:
I have two different parts in my system and each part should be carried by a specific vehicle. Therefore, the part will wait for a specific vehicle,
even if other vehicles are available.
Categories:
Vehicles
Key Concepts:
DestinationNode, Initial Node (Home), Lists, ModelEntity, NumberRiders, Priority, Ride on Transporter, Server, TransferNode, TransporterList,
Vehicle, VisitRequestQueue
Technical Approach:
We will utilize the Priority property on the ModelEntity object and the Priority property on the Vehicle object. We’ll assume that the value in the
ModelEntity’s property must match the value in the Vehicle’s property in order for that Vehicle to be selected.
Details for Building the Model:
System Setup
Place two Source objects and a Server object and connect both Sources to the Server with paths.
Place a Sink object and connect the Server to the Sink. Also, draw a Path from the Sink back to the Output node of the Server. This path
will be utilized by the Vehicles.
Place two ModelEntity objects from the Project Library and rename one to ‘PartA’ and the other to ‘PartB’. C onsider changing the color of
one entity by selecting it in the Facility window and selecting a color from the C olor icon in the ribbon and then clicking back onto the Entity
in the Facility window.
Assign a value to the Initial Priority property on each Part. C lick on PartA and set the Initial Priority property to a value of ‘1.0’. C lick on
PartB and set the Initial Priority property to a value of ‘2.0’.
C lick on Source2 and change the Entity Type property to ‘PartB’. Ensure that Source1 has its Entity Type property set to ‘PartA’. This will
ensure that each Source will create a different type of entity.
Place two Vehicle objects, naming one “PartA_Vehicle” and the other “PartB_Vehicle”. C onsider changing the color of one of the Vehicles.
Assign a value to the Initial Priority property on each Vehicle. C lick on PartA_Vehicle and set the Initial Priority property to a value of ‘1.0’.
C lick on PartB_Vehicle and set the Initial Priority property to a value of ‘2.0’.
Assign an Initial Node location for each vehicle to tell Simio where to place these vehicles at the beginning of the run. C lick on each vehicle
and set Initial Node (Home) to ‘Input@Sink1’.
Vehicle Selection Logic
We will create a Transporter List. Go to the Definitions window and click on Lists in the left side panel. C lick on Transporter in the Ribbon to
create a Transporter List.
Enter two rows – one for each vehicle you’ve placed in your model.
Back in the Facility window, click on the Output Node of Server1. This is where we will tell Simio that each entity entering this node should
request a ride on a Vehicle. We will also specific exactly which Vehicle the entity should request from our Transporter List.
Set Ride On Transporter property to ‘True’. Set Transporter Type to ‘From List’. Set Transporter List Name to the name of the list you just
created. Put this expression into the Selection Condition property, ‘C andidate.Transporter.Priority == ModelEntity.Priority’. This tells Simio,
from the possible list of candidates (transporters), the Priority property must equal the Priority property on this current ModelEntity.
Discussion:
C onsider these other examples to use in the Selection Condition property of a Transfer Node, when selecting a Transporter:
C andidate.Transporter.NumberRiders < 2 – To select the Transporter with its current number of entities riding on it as less than 2.
C andidate.Transporter.DestinationNode == Server1 – To select the Transporter that has its Destination Node currently set to Server1.
C andidate.Transporter.VisitRequestQueue == 0 – To select the Transporter that does not currently have any destination visit requests.
Embellishments:
C hange the Initial Ride Capacity property of each Vehicle (SimBit has Initial Ride Capacity set to ‘3’) to see how the system behavior changes.
173 / 815
Simio Reference Guide
SeparatorMakesC opies - SimBit
Problem:
I would like to have an entity create three identical copies of itself so there are a total of 4 entities that are exactly the same.
Categories:
C ombining and Separating Entities
Key Concepts:
Make C opies, Maximum Arrivals, Separation Mode, Separator
Assumptions:
One Entity type goes into the Separator. The Separator produces three exact copies of the entity. The Source produces 100 entities and therefore
the Separator produces 300 copies, which means there is a total of 400 entities at the end of the model. The copies and the originals depart
through separate sinks.
Technical Approach:
A Separator is placed into the model and the Separation Mode property is set to ‘Make C opies’. Two different Sinks are used in order to collect
statistics separately on the original entities and the copied entities.
Details for Building the Model:
Simple System Setup
Place a Source, Separator and two Sinks in the Facility Window.
C onnect the Source to the Separator and the Separator to both Sinks using Paths such that the parent entity will go to Sink1, while the
copies will go to Sink2.
Defining the Source
Set the Maximum Arrivals to ‘100’. This will turn off the Source once 100 entities have been generated.
Defining the Separator
Set the Separation Mode property to ‘Make C opies’. The Copy Quantity is set to ‘3’.
174 / 815
Simio Reference Guide
SequentialP rocessingByBatchSpecifiedInT able - SimBit
Problem:
I have unlimited inventory and a Server that produces parts from that inventory.
Categories:
Add-On Process Logic, Data Tables
Key Concepts:
Assign Step, AvailableRowC ount, C urrent Symbol Index, Data Table, Decide Step, ModelEntity, Numeric Property, Picture, Real State Variable
Assumptions:
I have a table that tells me what parts I want to produce and in what sequence. When I complete the sequence I will restart.
Technical Approach:
Use a Source, tightly linked to a Server to represent the generic arrivals from inventory. Use a table to supply the production data. Use add-on
processes in the Server to control indexing through the table.
Details for Building the Model:
Simple System Setup
C reate a model with Source, Server, and Sink, connected by a C onnector and a Path respectively.
Add a ModelEntity from the Project Library and change the Name to ‘AnyEntity’.
C lick on AnyEntity and then use the Add Additional Symbol button to add a second entity picture. C lick on the color icon to change the
color of that first entity (Index 0). The entity at Index 1 will remain the original color.
Setting up the Data Table
In the Tables panel of the Data Window, select the Add Data Table button to add a table with the Name ‘DataTable1’ with Integer properties
for PartType and Quantity. Set the PartType value to match the indexes defined in the AnyEntity Symbol (0 and 1).
Specify the Quantity values required for each PartType.
Adding Discrete State Variables to the Model
C lick on the Definitions tab of the model and select the States panel.
Add a Discrete State Variable with the Name ‘Index’ to track which table row is being processed.
Add a Discrete State Variable with the Name ‘C ount’ to track quantity produced for that row.
We will use the predefined state Picture on the ModelEntity to track what is being produced.
Process Logic
Go to the Processes Window and create a Process with the Name ‘Process1’.
Place a Decide step with an Assign step connected to the True exit. Place another Assign step then Decide and Assign steps from the False
exit. The second Decide step False exit should connect to the first Decide input, as should the last Assign exit.
C hange the Name of the first Decide step to ‘DecideIsC urrentRowDone’. This will compare the row quantity produced to quantity desired
by using the Decide Type of ‘C onditionBased’ and Expression of ‘C ount < DataTable1[Index].Quantity’.
If the above condition is true, then the True exit Assign step with Name ‘AssignPictureAndC ount’ assigns the picture to the row PartType
(State Variable Name is ‘ModelEntity.Picture’ and New Value is ‘DataTable1[Index].PartType’) and increments the row production counter
(State Variable Name is ‘C ount’ and New Value is ‘C ount+1’).
If the above condition is false, then the False exit Assign with Name ‘AssignRowAndC ount’ increments the row index using State Variable
Name is ‘Index and New Value is ‘Index+1’. It also assigns the row production counter, ‘C ount’ to ‘0’.
The next Decide step ‘DecideIfEndOfTable’ determines if the Index has passed the last specified table row by using ‘C onditionBased’
evaluation and Expression ‘Index >=DataTable1.AvailableRowC ount’ (where the function AvailableRowC ount returns the total number of
rows in the data table).
If the above condition is true, then the last Assign step ‘AssignRestart’ assigns the ‘Index’ back to ‘1’.
After we have decided our new row, both branches go back to the initial Decide.
C onnect the Process Logic to the Server
Go back to the Server properties in the Facility Window. Use the pull down list for the Entered Add-On Process Triggers and select
‘Process1’.
Discussion:
This could also have been done with a custom object that encompassed both entity creation and processing. In this case you could have actually
created the desired entity types rather than using a state to represent entity type.
175 / 815
Simio Reference Guide
ServerFollowsC apacitySchedule - SimBit
Problem:
I have a server that follows a schedule with entities entering the system 24 hours a day. C apacity of server changes over the day.
Categories:
Schedules / C hangeovers
Key Concepts:
C urrent Symbol Index, Off Shift, On Shift, Schedules, Server, Work Exceptions, WorkSchedule
Assumptions:
The server works from 8:00 am to 5:00 pm with a capacity of 2, from 5:00 pm to 9:00 pm with a capacity of 1, and a capacity of 0 otherwise.
The server also has a work exception and is off shift for an entire day.
Technical Approach:
A Schedule is created for a Server and the Server is set to follow this Schedule in its Process Logic. When the Server is Off Shift it will turn red
indicating a C urrent C apacity of zero.
Details for Building the Model:
Simple System Setup
Add a Source, Server and Sink to the Facility Window. Update the Processing Time of the Server to ‘0.25’ and Units to ‘Hours’.
C onnect the Source, Server and Sink using Paths.
C reating a Work Schedule
In the Data Window, select the Schedules panel and add a Work Schedule with Name ‘Schedule1’.
C reate a Day Pattern by clicking on the Day Pattern tab and enter the Name ‘DayPattern1’. Enter the number of Days as ‘7’.
C lick on the ‘+’ sign to expand the Work Periods.
Specify that ‘DayPattern1’ that has a Value of ‘2’ (on shift) from 8:00 am to 5:00 pm and capacity Value of ‘1’ from 5:00 pm to 9:00 pm.
Leave everything else empty, which indicates Off Shift times.
Under Work Schedules, select ‘DayPattern1’ for days 1 through 5. Because Day 6 and Day 7 have no day pattern specified, it is assumed
that the capacity value is 0 (off shift) for those days.
Expand the ‘+’ sign on ‘Schedule1’. Under the Work Period Exceptions tab, add an exception on Day 4 that has the capacity Value of ‘0’
(off shift) for 24 hours.
In the Facility Window, change the Process Logic Capacity Type property of the Server to ‘WorkSchedule’.
C hange the Process Logic Work Schedule property of the Server to ‘Schedule1’.
Animating the Off Shift Server
Select the Server and click the Add Additional Symbol in the ribbon. Then select the first of the two Active Symbols and change its color to
Red.
For the Server, change the Appearance Current Symbol Index to ‘Server1.C urrentC apacity’.
Embellishments:
To enhance the model for specific needs, try shifting the Server’s work schedule, the Source’s Interarrival Time rate, or the Server’s Processing
Time rate.
176 / 815
Simio Reference Guide
ServerFollowsDailySchedule - SimBit
Problem:
I have a server that follows a daily schedule with entities entering the system 24 hours a day.
Categories:
Schedules / C hangeovers
Key Concepts:
C urrent Symbol Index, Off Shift, On Shift, Schedules, Server, WorkSchedule
Assumptions:
The server works an 8 hour shift with a 30 minute break. The server’s queue has an infinite capacity.
Technical Approach:
A Schedule is created for a Server and the Server is set to follow this Schedule in its Process Logic. When the Server is Off Shift it will turn red
indicating a C urrent C apacity of zero.
Details for Building the Model:
Simple System Setup
Add a Source, Server and Sink to the Facility Window. Update the Processing Time of the Server to ‘Random.Triangular (0.1, 0.15, 0.25)’
and the Units to ‘Hours’.
C reating a Daily Work Schedule
In the Data Window, select the Schedules panel and add a Work Schedule with the Name ‘Shift8Hours’.
C reate a Day Pattern by clicking on the Day Pattern tab and enter the Name ‘DayPattern1’.
C hange the number of Days to ‘7’.
C lick on the ‘+’ sign to expand the Work Periods.
Enter the Start Time and End Time from 8:00 am to 12:00 and 12:30 pm to 4:30 pm that has a Value of ‘1’. Leave everything else empty,
which indicates Off Shift times.
Under Work Schedules, select 'DayPattern1' for days 1 through 5. Days 6 and 7 will not have a day pattern specified, thus the capacity
value will be 0 (off shift).
Within the Facility window, change the Server’s Process Logic Capacity Type property to ‘WorkSchedule’.
C hange the Process Logic Work Schedule property to ‘Shift8Hours’.
Animating the Off Shift Server
Select the Server and click the Add Additional Symbol in the ribbon. Then select the first of the two Active Symbols and change its color to
Red.
C hange the Appearance Current Symbol Index to ‘Server1.C urrentC apacity’.
Embellishments:
To enhance the model for specific needs, try shifting the Server’s work schedule, the Source’s Interarrival Time rate, or the Server’s Processing
Time rate.
177 / 815
Simio Reference Guide
ServerFollowsO ddSchedule - SimBit
Problem:
I have a server that follows an odd schedule with entities entering the system 24 hours a day.
Categories:
Schedules / C hangeovers
Key Concepts:
C urrent Symbol Index, Off Shift, On Shift, Schedules, Server, WorkSchedule
Assumptions:
The server works for 45 minutes then rests for 15 minutes. The server’s queue has an infinite capacity.
Technical Approach:
A Schedule is created for the Server and the Server is set to follow this Schedule in its Process Logic. When the Server is Off Shift it will turn red
indicating a C urrent C apacity of zero.
Details for Building the Model:
Simple System Setup
Add a Source, Server and Sink to the Facility Window. Update the Processing Time of the Server to be ‘Random.Triangular (0.1, 0.15,
0.25)’ and the Units to be ‘Hours’.
C reating a Work Schedule
In the Data Window, select the Schedules panel and add a Work Schedule with Name ‘Shift45Minutes’.
C reate a Day Pattern by clicking on the Day Pattern tab and specifying the Name ‘DayPattern1’.
C lick on the ‘+’ sign to expand the Work Periods.
Enter into ‘DayPattern1’ the following information: 12:00 am to 12:45 am and from 12:45 am to 1:45 am and from 2:00 am to 2:45 am
that has a Value of ‘1’. Leave everything else empty, which indicates Off Shift times.
Under Work Schedules, select ‘DayPattern1’ for day 1.
Within the Facility Window, change the Server’s Process Logic Capacity Type property to ‘WorkSchedule’.
C hange the Process Logic Work Schedule property to ‘Shift45Minutes’.
Animating the Off Shift Server
With the Server selected, click the Add Additional Symbol in the ribbon. Then select the first of the two Active Symbols and change its
color to Red.
C hange the Appearance Current Symbol Index to ‘Server1.C apacity’.
Embellishments:
To enhance the model for specific needs, try shifting the Server’s work schedule, the Source’s Interarrival Time rate, or the Server’s Processing
Time rate.
See Also:
To see how to make a more traditional 8 hour work day schedule, see ServerFollowsDailySchedule.spf.
178 / 815
Simio Reference Guide
ServerUsingT askSequence - SimBit
This SimBit project includes three models that demonstrate the use of the Server’s Task Sequence capability.
Models included in this SimBit:
1. MultiTaskServer_SpecificTime – Demonstrates the Server’s task sequence option of using a Specific Time delay for a task. The time
delay is then specified directly within the dialog for each particular task.
2. MultiTaskServer_ProcessName – Demonstrates the Server’s task sequence option of using a Process Name for a task. The process
logic is then included within a specific process within the Processes window.
3. MultiTaskServer_Submodel – Demonstrates the Server’s task sequence option of using a Submodel to model the process flow for the
task. The process logic for the task is then determined by the Facility window entity flow starting at the Submodel Starting Node and
continuing until that process flow is complete and the entity is destroyed.
Model 1: MultiTaskServer_SpecificTime
Problem:
I want to model multiple tasks within a similar physical location. My entity has a single task first, but then has two tasks that are done in parallel.
My tasks are all represented with simple delays.
Categories:
MultiTask Server
Key Concepts:
Active Symbol, Add-On Process, Assign Step, Finished Task, Picture, Process, Process Type, Server, Task Sequence
Assumptions:
Only a single entity is flowing through the system so that the focus can be on the task flow of that single entity. The entity will go through 4
different simple delay tasks, some of which can be done simultaneously.
Technical Approach:
Use the Process Type of ‘Task Sequence’ on the Server object to specify all the tasks, their dependencies and logic.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink from the Standard Library in the Facility window. C onnect the Source to the Server and the Server to the
Sink with Paths.
Within the Source, change the Maximum Arrivals property to ‘1’ so that only a single entity enters the system.
Adding Tasks to the Server
Within the Server, change the Process Type to ‘Task Sequence’. Within the Processing Tasks property, open the repeating property editor
and specify four different tasks.
Sequence Number set to ‘10’ for the first task with the Name of ‘C lean’. Within this task, the Branch Type is ‘Always’ (all entities perform
this task). The Process Type is ‘Specific Time’ and the Processing Time is ‘1’ minute.
The next two tasks can be done in parallel and can only be started once the first task, 10, is done. Therefore we will set the Sequence
Number set to ’20.1’ for the first task with the Name of ‘Trim1’. Within this task, the Branch Type is ‘Always’. The Process Type is ‘Specific
Time’ and the Processing Time is also ‘1’ minute. The other parallel task is Sequence Number ’20.2’, with the Name of ‘Paint’. The Branch
Type is ‘Always’, Process Type is ‘Specific Time’ and Processing Time is ‘5’ minutes. The extension from the 20 (20.1 and 20.2) indicates
that they can be done in parallel.
Finally, a task is performed after task 20.1 but can be done prior to 20.2 being complete. Therefore, we will indicate the Sequence Number
set to ’30.1’ for the task with the Name of ‘Trim2’. Within this task, the Branch Type is ‘Always’, the Process Type is ‘Specific Time’ and the
Processing Time is ‘1’ minute.
Animating the Entity C hanges
Place a ModelEntity from the Project Library into the Facility window. C lick on the green symbol and within the Symbols ribbon, click on
Add Additional Symbol to create 5 different symbols (which you will then color with unique colors) for various symbol states.
When any of the tasks is completed, the animation symbol for the entity (ModelEntity.Picture) will be updated to show that a task has been
completed. Within the Processes window, add a process named ‘Server1_FinishedTask’. Add an Assign step to this process to assign the
State Variable Name ‘ModelEntity.Picture’ to the New Value ‘ModelEntity.Picture + 1’.
Re-enter the Server’s Processing Tasks repeating editor and change the Finished Task add-on process to be ‘Server1_FinishedTask’ for
each of the tasks shown. All tasks can use this same process to simply update the entity picture symbol by one each time.
Model 2: MultiTaskServer_ProcessName
Problem:
I want to model multiple more complicated tasks within a similar physical location. My entity has a single task first, but then has two tasks that
are done in parallel. The logic for each task is defined within processes in the Processes window.
Categories:
MultiTask Server
Key Concepts:
Active Symbol, Add-On Process, Assign Step, Delay Step, Picture, Process, Process Type, Server, Task Sequence
Assumptions:
Only a single entity is flowing through the system so that the focus can be on the task flow of that single entity. The entity will go through 4
different tasks, some of which can be done simultaneously. The task logic for each task is represented in different processes in the Processes
window.
Technical Approach:
179 / 815
Use the Process Type of ‘Task Sequence’ on the Server object to specify all the tasks, their dependencies and logic.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink from the Standard Library in the Facility window. C onnect the Source to the Server and the Server to the
Sink with Paths.
Within the Source, change the Maximum Arrivals property to ‘1’ so that only a single entity enters the system.
Adding Process Logic for Each Task
Within the Processes window, use the C reate Process to create four unique processes with the Names of 'C lean_Process', 'Paint_Process',
'Trim1_Process' and 'Trim2_Process'.
Within the C lean_Process, add a Delay step with the Delay Time of ‘1’ minute. Add an Assign step that will assign the State Variable Name
of ‘ModelEntity.Picture’ to the New Value of ‘ModelEntity.Picture + 1’. The picture assignment will be discussed more below.
Within the Trim1_Process and Trim2_Process, add the same two steps as above (Delay for 1 minute and Assign entity picture). * NOTE: If
these processes for multiple tasks were always going to remain the same, you could alternatively have a single process that has the Delay
and Assign and reference that within the Task (steps below).
Within the Paint_Process, add a a Delay step with the Delay Time of ‘5’ minutes. Add an Assign step that will assign the State Variable
Name of ‘ModelEntity.Picture’ to the New Value of ‘ModelEntity.Picture + 1’.
Adding Tasks to the Server
Within the Server, change the Process Type to ‘Task Sequence’. Within the Processing Tasks property, open the repeating property editor
and specify four different tasks.
Sequence Number set to ‘10’ for the first task with the Name of ‘C lean’. Within this task, the Branch Type is ‘Always’ (all entities perform
this task). The Process Type is ‘Process Name’ and the Process Name refers to the ‘C lean_Process’ that was created above.
The next two tasks can be done in parallel and can only be started once the first task, 10, is done. Therefore we will set the Sequence
Number set to ’20.1’ for the first task with the Name of ‘Trim1’. Within this task, the Branch Type is ‘Always’. The Process Type is ‘Process
Name’ and the Process Name is ‘Trim1_Process’. The other parallel task is Sequence Number ’20.2’, with the Name of ‘Paint’. The Branch
Type is ‘Always’, Process Type is ‘Process Name’ and Process Name is ‘Paint_Process’. The extension from the 20 (20.1 and 20.2) indicates
that these two tasks can be done in parallel.
Finally, a task is performed after task 20.1 but can be done prior to 20.2 being complete. Therefore, we will indicate the Sequence Number
set to ’30.1’ for the task with the Name of ‘Trim2’. Within this task, the Branch Type is ‘Always’, the Process Type is ‘Process Name’ and the
Process Name is ‘Trim2_Process’.
Animating the Entity C hanges
Place a ModelEntity from the Project Library into the Facility window. C lick on the green symbol and within the Symbols ribbon, click on
Add Additional Symbol to create 5 different symbols (which you will then color with unique colors) for various symbol states.
When any of the tasks is completed, the animation symbol for the entity (ModelEntity.Picture) will be updated to show that a task has been
completed. Remember that within the Processes window, we have Assign steps at the end of each process to assign the ModelEntity.Picture
to be one more than it previously was.
Model 3: MultiTaskServer_Submodel
Problem:
I want to model multiple tasks that may be done in different physical locations while the entity remains at a Server. My entity has a single task
first, but then has two tasks that are done in parallel at different locations.
Categories:
MultiTask Server
Key Concepts:
Active Symbol, Add-On Process, Assign Step, Finished Task, Picture, Process Type, Server, Submodel, Task Sequence
Assumptions:
Only a single entity is flowing through the system so that the focus can be on the task flow of that single entity. The entity will go through 4
different tasks, some of which can be done simultaneously. The task logic for the last three tasks is represented within the Facility window.
Technical Approach:
Use the Process Type of ‘Task Sequence’ on the Server object to specify all the tasks, their dependencies and logic.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink from the Standard Library in the Facility window. C onnect the Source to the Server and the Server to the
Sink with Paths.
Within the Source, change the Maximum Arrivals property to ‘1’ so that only a single entity enters the system.
Submodel Logic for Tasks in Facility Window
Place three Servers and Sinks in the Facility window (in addition to those placed above). C onnect each Server to a Sink with a Path. Name
the first Server ‘Lab1_Test’, the second one ‘Lab2_Test’ and the third ‘XRay_Test’. Within both the Lab1_Test and Lab2_Test servers, specify
the Processing Time of ‘1’ minute. Within the XRay_Test, specify the Processing Time of ‘5’ minutes.
Adding Tasks to the Server
Within the Server, change the Process Type to ‘Task Sequence’. Within the Processing Tasks property, open the repeating property editor
and specify four different tasks.
Sequence Number set to ‘10’ for the first task with the Name of ‘C heckup’. Within this task, the Branch Type is ‘Always’ (all entities perform
this task). The Process Type is ‘Specific Time’ and the Processing Time is ‘1’ minute.
The next two tasks can be done in parallel and can only be started once the first task, 10, is done. Therefore we will set the Sequence
Number set to ’20.1’ for the first task with the Name of ‘Lab1’. Within this task, the Branch Type is ‘Always’. The Process Type is
‘Submodel’, the Submodel Entity Type is ‘DefaultEntity’ and the Submodel Starting Node is ‘Input@Lab1_Test’. The other parallel task is
Sequence Number ’20.2’, with the Name of ‘XRay’. The Branch Type is ‘Always’, Process Type is ‘Submodel’, Submodel Entity Type is
’DefaultEntity’ and Submodel Starting Node is ‘Input@XRay_Test’. The extension from the 20 (20.1 and 20.2) indicates that they can be
done in parallel.
180 / 815
done in parallel.
Finally, a task is performed after task 20.1 but can be done prior to 20.2 being complete. Therefore, we will indicate the Sequence Number
set to ’30.1’ for the task with the Name of ‘Lab2’. Within this task, the Branch Type is ‘Always’, the Process Type is ‘Submodel’, Submodel
Entity Type is ‘DefaultEntity’ and the Submodel Starting Node is ‘Input@Lab2_Test’.
Animating the Entity C hanges
Place a ModelEntity from the Project Library into the Facility window. C lick on the green symbol and within the Symbols ribbon, click on
Add Additional Symbol to create 5 different symbols (which you will then color with unique colors) for various symbol states.
When any of the tasks is completed, the animation symbol for the entity (ModelEntity.Picture) will be updated to show that a task has been
completed. Within the Processes window, add a process named ‘Server1_FinishedTask’. Add an Assign step to this process to assign the
State Variable Name ‘ModelEntity.Picture’ to the New Value ‘ModelEntity.Picture + 1’.
Re-enter the Server’s Processing Tasks repeating editor and change the Finished Task add-on process to be ‘Server1_FinishedTask’ for
each of the tasks shown. All tasks can use this same process to simply update the entity picture symbol by one each time.
Required introduction
181 / 815
Simio Reference Guide
ServerUsingT askSequence_AlternativeMethodsForDefiningT askP recedence - SimBit
This SimBit project includes three models using the Server object that demonstrate the alternative methods available to define the task
precedence dependencies for a task sequence.
Models included in this SimBit:
SequenceNumberMethodExample- Demonstrates how to define the task precedence dependencies for a task sequence by using task
sequence numbers.
ImmediatePredecessorsMethodExample – Demonstrates how to define the task precedence dependencies for a task sequence by
specifying the immediate predecessors for each task.
ImmediateSuccessorsMethodExample – Demonstrates how to define the task precedence dependencies for a task sequence by
specifying the immediate successors for each task.
Figure 1 illustrates the example task sequence that is demonstrated by each of the example models using an alternative task precedence
method. First ‘Task1’ is started. When ‘Task1’ is finished then both ‘Task2’ and ‘Task3’ can start. When ‘Task2’ is finished, then ‘Task4’ can start.
When ‘Task3’ is finished, then ‘Task5’ can start. Finally, ‘Task6’ can start once both ‘Task4’ and ‘Task5’ have finished.
Model 1: SequenceNumberMethodExample
Problem:
I want to model the example task sequence shown in Figure 1 at a Server object using task sequence numbers to define the task precedence
dependencies.
Categories:
MultiTask Server
Key Concepts:
Data Table, Server, Process Type, Task Sequence, Task Precedence Method
Technical Approach:
Table 1 below shows the task data using the ‘Sequence Number’ task precedence method that will produce the example task sequence shown in
Figure 1.
182 / 815
Mapping the Table Data to the Server in the Facility Window
Go to the Server object in the Facility window and do the following:
Specify the Process Type as ‘Task Sequence’. Then, right-click on the Processing Tasks repeat group and set a reference to the
‘ProcessingTasks’ table. This indicates that the ProcessingTasks table will be used as the referenced data source for getting processing task
information.
Open the Processing Tasks repeat group. Map the columns from the ProcessingTasks table to the appropriate corresponding properties in
the repeat group (refer to the SimBit if necessary as a guide).
Model 2: ImmediatePredecessorsMethodExample
Problem:
I want to model the example task sequence shown in Figure 1 at a Server object, specifying the immediate predecessors for each task to define
the task precedence dependencies.
Categories:
MultiTask Server
Key Concepts:
Data Table, Server, Process Type, Task Sequence, Task Precedence Method
Technical Approach:
Table 2 illustrates some task data using the ‘Immediate Predecessors’ task precedence method that will produce the example task sequence
shown in Figure 1.
183 / 815
Categories:
MultiTask Server
Key Concepts:
Data Table, Server, Process Type, Task Sequence, Task Precedence Method
Technical Approach:
Table 3 illustrates some task data using the ‘Immediate Successors’ task precedence method that will produce the example task sequence shown
in Figure 1.
184 / 815
Simio Reference Guide
ServersUsingT askSequenceW ithDataT ables_Flow Line - SimBit
Problem:
I want to model a system where the entities being processed follow a fixed work path, and where the operations performed at the physical
processing locations are task sequences that are also the same for each entity. For modeling purposes, it is desired that all operation data for
each physical processing location is defined in a set of relational data tables.
Categories:
MultiTask Server, Data Tables
Key Concepts:
Auto-Set Table Row Reference, Data Table, Materials Element, Process Type, Resources, Server, Task Sequence
Assumptions:
The modeled system is a flow line that consists of three server locations visited in a fixed sequence. Entities enter the system at the front of the
line and then are processed through the three servers before finishing at a sink.
Technical Approach:
The operation data for each physical processing location is defined in a set of relational data tables using the design shown in Figure 1.
185 / 815
Mapping the Table Data to the Objects in the Facility Window
Go to the Facility window and do the following:
Source object – Make sure the Entity Type property is specified as the model entity type that you placed in the model.
For Each Server object – Specify the Process Type as ‘Task Sequence’. Then, right-click on the Processing Tasks repeat group and set
a reference to the ‘ProcessingTasks’ table. This indicates that the ProcessingTasks table will be used as the referenced data source for
getting processing task information. Finally, in the Process Logic->Other Task Sequence Options properties, specify the Task Resources
Referenced Table Name as the ‘TaskResources’ table table and the Task Materials Referenced Table Name as the ‘TaskMaterials’ table.
186 / 815
Referenced Table Name as the ‘TaskResources’ table table and the Task Materials Referenced Table Name as the ‘TaskMaterials’ table.
This indicates that those tables will be used as the referenced data sources for getting task resource and material requirements.
For Each Server object – Open the Processing Tasks repeat group. Map the columns from the ProcessingTasks, TaskResources and
TaskMaterials tables to the appropriate corresponding properties in the repeat group (refer to the SimBit if necessary as a guide).
In the Servers table, make sure that the Auto-set Table Row Reference property for the ServerName column is set to ‘True’.
Embellishments:
Experiment with different server operation data in the relational data tables.
See also:
ServersUsingTaskSequencesWithDataTables_JobShop.spfx
ServerUsingTaskSequencesWithWorkers.spfx
187 / 815
Simio Reference Guide
ServersUsingT askSequenceW ithDataT ables_JobShop - SimBit
Problem:
I want to model a system where the entities being processed have different routings based on type, and where the operations performed at the
physical processing locations are task sequences that are also dependent on the job type. For modeling purposes, it is desired that all product
mix, job routing, and operation data is defined in a set of relational data tables.
Categories:
MultiTask Server, Data Tables
Key Concepts:
Data Table, Material Element, Process Type, RandomRow, Sequence Table, Server, Source, Table Reference Assignments, Task Sequence
Assumptions:
The modeled system has three possible server locations where entities are processed. An entity will enter the system and visit those one or more
of the server locations in a sequence that is dependent on the job type. Not all of the servers have to be visited and a server may be visited
more than once.
Technical Approach:
The product mix, job routing, and operation data is defined in a set of relational data tables using the design shown in Figure 1.
188 / 815
189 / 815
Mapping the Table Data to the Objects in the Facility Window
Go to the Facility window and do the following:
Source object – Specify the Entity Type property as ‘JobTypes.JobType’. Go to the Table Reference Assignments->Before Creating
Entities properties, and specify the Table Name as ‘JobTypes’ and the Row Number as ‘JobTypes.MixPercentage.RandomRow’. The Source
will then randomly create entities of the types specified in the JobTypes table using the specified mix percentages.
For Each ‘Output’ TransferNode object – Specify the Entity Destination Type as ‘By Sequence’. Then, when an entity exits the Source
or any of the Server objects, it will set its next destination based on the JobRoutings sequence table.
For Each Server object – Specify the Process Type as ‘Task Sequence’. Then, right-click on the Processing Tasks repeat group and set
a reference to the ‘ProcessingTasks’ table. This indicates that the ProcessingTasks table will be used as the referenced data source for
getting processing task information. Finally, in the Process Logic->Other Task Sequence Options properties, specify the Task Resources
Referenced Table Name as the ‘TaskResources’ table and the Task Materials Referenced Table Name as the 'TaskMaterials' table. This
indicates that those tables will be used as the referenced data sources for getting task resource and material requirements. .
For Each Server object – Open the Processing Tasks repeat group. Map the columns from the ProcessingTasks, TaskResources, and
TaskMaterials tables to the appropriate corresponding properties in the repeat group (refer to the SimBit if necessary as a guide).
Embellishments:
Experiment with different product mix, job routing, and operation data in the relational data tables.
See also:
ServersUsingTaskSequencesWithDataTables_FlowLine.spfx
ServerUsingTaskSequencesWithWorkers.spfx
190 / 815
Simio Reference Guide
ServerUsingT askSequenceW ithW orkers - SimBit
Problem:
I want to model multiple tasks within a similar physical location. Each task requires a worker to help perform the task. Most tasks are done all the
time, while one is done only a percentage of the time.
Categories:
Add-On Process Logic, MultiTask Server, Worker
Key Concepts:
Active Symbol, Add-On Process, Assign Step, BasicNode, Decide Step, InputBuffer, ObjectList, Picture, Process, Process Type, Request Move,
Server, Started Task, Status Label, Task Sequence, Worker
Assumptions:
Only a single entity will process at a Server at a time and incoming entities will wait at the Source until a Server is idle before being assigned to
one of the two Servers. All tasks are sequential, there are no parallel tasks.
One of the tasks (lab work) is a probabilistic task. We will assume that even if that task is not completed for a given entity that all remaining
tasks will continue as planned.
Technical Approach:
Use the Process Type of ‘Task Sequence’ on the Server objects to specify all the tasks, their dependencies, logic and resources required. Tasks
are sequential so task numbering will be simple at 10, 20, 30, 40.
Details for Building the Model:
Simple System Setup
Place a Source, a Server (we will later copy this first one to another) and Sink from the Standard Library in the Facility window. C onnect
the Source to the Server and then the Server to the Sink with Paths.
Within the Source, change the Interarrival Time property to ‘Random.Exponential(6)’ to send entities into the system.
Place two BasicNode objects in the model, both near the bottom of the Facility window below the Server to the left and right. Rename them
NursesStation and Lab. Place another Basic Node near the Server and name it ‘ExamRoomNode’. This will be where the nurse/doctor visit
when performing an entity task. Do not connect the nodes with Paths just yet, we will do that shortly.
Defining Workers
Place three Worker objects in the Facility window and rename them 'Nurse1', 'Nurse2' and 'Doctor'. C hange each of the worker’s Initial
Node (Home) property to ‘NursesStation’ and Idle Action to ‘Park At Home’. This will cause them all to be located at the BasicNode
NursesStation at the start of the simulation and they will travel back to this area when they are idle.
Within the Definitions tab, Lists panel, add a Transporter List named 'Nurses' and include Nurse1 and Nurse2.
Adding Tasks to the Server
Within Server, change the Process Type to ‘Task Sequence’. Within the Processing Tasks property, open the repeating property editor and
specify four different tasks.
Sequence Number set to ‘10’ for the first task with the Name of ‘C heck Vitals’. Within this task, the Branch Type is ‘Always’ (all entities
perform this task). The Process Type is ‘Specific Time’ and the Processing Time is ‘3’ minutes. Within the Resource Requirements section,
we will be requiring a nurse to perform this task. Set the Object Type to ‘Select From List’ and the Object Name to ‘Nurses’ meaning we will
select from among the available nurses. Additionally, set the Request Move property to ‘To Node’ and Destination Node to
‘ExamRoomNode’. This will require the nurse to move to the Server to perform the task (as opposed to staying at its current location).
Add another processing task with a Sequence Number set of ‘20’ and the Name of ‘Lab Work’. Within this task, the Branch Type is
‘Probabilistic’ with the Condition or Probability as ‘.8’, meaning approximately 80% of the entities will require this task. The Process Type is
‘Specific Time’ and the Processing Time is ‘2’ minutes. Within the Resource Requirements section, we will be requiring a nurse to again
perform this task. Set the Object Type to ‘Select From List’ and the Object Name to ‘Nurses’ meaning we will select from among the
available nurses. Additionally, set the Request Move property to ‘To Node’ and Destination Node to ‘Lab’. This will require the nurse to move
to the Lab to perform the task, even though the entity is still at the Server1 location.
The third processing task should have a Sequence Number set of ‘30’ and the Name of ‘Nurse Visit’. Within this task, the Branch Type is
‘Always’. The Process Type is ‘Specific Time’ and the Processing Time is ‘3’ minutes. Within the Resource Requirements section, we will be
requiring a nurse so specify the same information as the previous two tasks. Set the Request Move property to ‘To Node’ and Destination
Node to ‘ExamRoomNode’ so that the nurse returns to Server1 for processing. IMPORTANT NOTE: Within the Task Information section of
properties, change the Auto Cancel Trigger to ‘None’. This is very important because this property can allow the cancellation of this task if
all predecessor tasks are cancelled if left at the default value (if the probability based lab work task isn’t done, the ‘None’ property value
for this field makes sure that the task is not automatically cancelled).
Finally, the last processing task should have a Sequence Number set of ‘40’ and the Name of ‘Doctor Visit’. Within this task, the Branch
Type is ‘Always’. The Process Type is ‘Specific Time’ and the Processing Time is ‘5’ minutes. Within the Resource Requirements section, we
will now be requiring the Object Type of ‘Specific’ and Object Name of ‘Doctor’. Set the Request Move property to ‘To Node’ and Destination
Node to ‘ExamRoomNode’ so that the doctor moves to the Server1 for processing.
Within the main properties of the Server, under the Buffer C apacities section, change the Input Buffer to ‘0’. This will make sure that
entities don’t accumulate in the Server1 buffer while waiting. We will add some logic to the Source to help with this as well in the below
section.
NOTE about Resources Utilized within Processing Tasks – When using Resources within various processing tasks in the Server (Task
Sequence based), the resource is ‘Reserved’, by default, for processing from one task to another. This is done with the two properties
Keep Reserved If (set to ‘True’) and Reservation Timeout (set to ‘Math.Epsilon’). This will ensure that a resource used in one task will not
be allocated to another entity in another area when it is to be used for another processing task immediately after (such as in this example,
the nurse is used for 3 tasks in a row).
Adding the Second Server and Associated Logic
Because our Servers will have similar task information, we chose to fill out all the task information first within a single Server, Server1.
Now let’s copy the Server by highlighting Server1 and using C trl-C and C trl-V to copy and paste. C hange the Name of the copied Server
to ‘Server2’. This way, all 4 tasks within the Processing Tasks are copied and you can simply edit them.
First, place another BasicNode object near Server2 and name it ‘ExamRoomNode2’. This is where the nurses/doctor will travel for
processing at this server.
Edit the Processing Tasks and change the Destination Node for the requested move of the workers from ‘ExamRoomNode’ to
‘ExamRoomNode2’ for the 10, 30 and 40 sequence number tasks (done at the server). We will still require the lab work to be done at the
191 / 815
‘ExamRoomNode2’ for the 10, 30 and 40 sequence number tasks (done at the server). We will still require the lab work to be done at the
lab. C hange the Lab Work task Condition or Probability to be ‘.7’, requiring only 70% of the patients to need lab work from this server.
C onnecting the Worker Paths
Note that we now have 4 BasicNode objects for the workers (Doctor/Nurses) to move between when processing. These workers in this
example will not move along any of the same paths as the entities. Note also that ‘Bidirectional’ type paths, when multiple Workers (and/or
Vehicles) are moving can cause potential lockups unless by-pass type paths are used. Therefore, we will avoid that all together and simply
draw two unidirectional paths between the various nodes. C onnect the NursesStation node to the ExamRoomNode in both directions with
Paths. Then, connect the ExamRoomNode to the ExamRoomNode2 with Paths. Finally, connect the ExamRoomNode to the Lab with Paths in
both directions.
Selecting Between Multiple Servers from Source
In this example, we’d like our entities to wait at the Source object if a Server isn’t available for processing (no buffer space at Servers).
Note that if we simply left the ‘0’ Input Buffer on the Servers and no other logic, entities could reside on the Paths connecting the Source
and each Server. Therefore, we will first make a List of possible Server options from which to select. Go to the Definitions tab and Lists
panel. Add a Node list with the Name ‘ExamRooms’ that includes the ‘Input@Server1’ and the ‘Input@Server2’ as the members of the list.
Within the Facility window, click on the output node of Source1. C hange the Entity Destination Type to ‘Select From List’. The Node List
Name should be ‘ExamRooms’. The Selection Goal of ‘Preferred Order’ will select a node from the list based on the listed order (Server1
first, then Server2). The Blocked Destination Rule of ‘Select Available Only’ will cause the entities to wait at the Source output area if there
is no capacity available at the Servers.
Animating the Processing Task Name of the Servers
Note that in this example, the processing task name is graphically animated for each of the two Servers. It is possible in this particular
example for two reasons. First, the Server Initial Capacity itself is ‘1’ and does not change. That means that ONLY ONE entity will ever be
able to go through the Process Tasks listed within the Server at any given time. Second, the entity processing tasks at the Server are all
serial tasks, meaning that only one task is occurring at a time, then the next, and so on. If the entity had multiple tasks occurring
simultaneously, signified by the Sequence Number values, the task names would not be able to be displayed as they are.
When an entity is processing through sequence tasks in the Server, the token(s) associated with that entity have a function
‘Token.TaskInfo.Name’ that carries the task sequence name (i.e., C heck Vitals, Lab Work, etc.). Because of the above discussion, each
Server will only be going through one task at a time, and therefore we will add two model states to the model. Within the Definitions tab,
States panel, add two String type states and name them ‘Server1_Task’ and ‘Server2_Task’. These states will be assigned a value based
on the Token.TaskInfo.Name function when the task changes.
In the Processes window, create a new process named ‘Task_Assignment’. Within this process, add a Decide step. The Condition or
Probability property should be ‘ModelEntity.Location.Parent == Server1’. This will check the location of the entity (is it at Server1 or
Server2 so we know which state variable to update). From the True exit, add an Assign step that assigns the State Variable Name
‘Server1_Task’ to the New Value of ‘Token.TaskInfo.Name’ and then from the False exit, add a similar Assign steps that assigns the State
Variable Name ‘Server2_Task’ to the New Value ‘Token.TaskInfo.Name’.
In order to update these variables after every task, enter the Processing Tasks repeating property window for the servers and under the
Add-On Process Triggers section, add the Starting Task process as ’ Task_Assignment’ for every task in each server. This is done in the
Starting Task section (instead of the Finished Task section) since we would like to update the variable in the animation just prior to the task
starting and view it during the task. The value will then change when the task changes.
Optional – The variables will not automatically ‘clear’ when the entity is done processing. To clear the variables, make a similar process to
the above described with Decide and two Assign steps. Assign the state variables to “ “ (blank, as they are strings but need to be in
quotes). On the last task for each Server, reference this new process in the Finished Task add-on process trigger.
Finally, the state variables can be graphically shown in the Facility window by clicking on the Animation ribbon and placing Status Labels
with the Expression values ‘Server1_Task’ and ‘Server2_Task’.
See Also:
ServersUsingTaskSequencesWithDataTables_FlowLine.spfx
ServersUsingTaskSequencesWithDataTables_JobShop.spfx
192 / 815
Simio Reference Guide
ServerW ithT ransferInC onstraints - SimBit
Problem:
This small example illustrates usage of the ‘Transfer-In C onstraints’ feature that is available in Advanced Options for the processor-oriented
standard library objects.
In this problem, there are three servers arranged in a line. When an entity arrives to a server, if there are already three (3) entities waiting in the
input buffer to be processed, then the entity continues to the next server. The exception is the last server in the line, which has no transfer-in
constraints and thus accepts all overflow of entities that cannot be processed by the first two servers.
Categories:
Decision Logic -- Paths
Key Concepts:
Server, Queue, Path
Assumptions:
For either ‘Server1’ or ‘Server2’ in this model, a maximum of 3 entities may ever be waiting in the input buffer. The last server, ‘Server3’, has no
such constraint and thus can accept all overflow of entities that cannot be processed by the first two servers.
Technical Approach:
Use the Advanced Options section, Transfer-In C onstraints functionality available for the Server object.
Details for Building the Model:
Simple System Setup
Place a Source, three Servers, and a Sink in the Facility window.
Move the input nodes of the Servers to the top portion of the Servers and the output nodes to the bottom portion below the object name.
C onnect the Source to Server1’s input node. Then connect Server1’s input node to Server 2’s and then to Server 3’s node. Logically, the
entities will attempt to travel from the Source to Server1. If the entity violates the server’s transfer-in constraints, then the entity travels
to the second server Server2. If transfer-in constraints for that server are also violated, then the entity continues on to Server3 which will
always accept the entity.
C onnect all three Servers output nodes to the Sink.
Logic Details within the Objects
Within the Source, change the Interarrival Time to ‘Random.Exponential(.1)’. Within Server1, change the Processing Time to
‘Random.Triangular(.3,.4,.6)’.
Within both Server1 and Server2, open the Advanced Options properties and change the Transfer-In Constraints to ‘C ustom C ondition’.
Then, specify the Transfer-In Condition as ‘Server.InputBuffer.C ontents < 3’. This will cause entities to evaluate the contents of the input
buffer for a given server before entering the node at that server. If the condition is true, the entity will enter the node, if not, it will
continue.
Because the arrival rate on the Source is quite high, and the Server1 processing time is longer than the other Servers, you’ll see that after
a short while, entities will bypass Server1 and continue to Server2. Then once Server2 buffer gets larger, incoming entities continue to
Server3.
193 / 815
Simio Reference Guide
SetP ropertyBasedO nValueO fListP roperty - SimBit
Problem:
I have a String List property and the value of a numeric property within the model is set depending on the value of the String List property.
Categories:
Decision Logic -- Paths
Key concepts:
List Property, Math.If, Maximum Arrivals, Path, StringList, TimeOnLink
Technical Approach:
A TimePath connects the Source to the Sink. The Travel Time property on this TimePath is set based on the current value of the List Property
named ExitLocation.
If the value of this property is 'Far', the Travel Time is 5 minutes. If the value of this property is 'Near', the Travel Time is 1 minutes.
Details for Building the Model:
Defining the Lists and Properties
Go to the Lists window by selecting Lists along the left panel from within the Definitions window. C lick on String in the ListData ribbon to
create a new String List. Name this new list ‘ExitLocations’. Add two entries into the list - ‘Near’ and ‘Far’.
Go to the Properties window by selecting Properties along the left panel from within the Definitions window. Select List from the Standard
Property drop down in the Properties ribbon. C hange the Name of this new property to ‘ExitLocation’. Set the ListName property of this
property to ‘ExitLocations’.
Simple System Setup
Within the Facility window, place a Source object and a Sink object and connect them with a TimePath.
In the Source object, set the Interarrival Time property to ‘1’ minute. Set the Maximum Arrivals, under the Stopping C onditions category,
to ‘10’.
C lick onto the TimePath and set the Travel Time property to ‘Math.If(ExitLocation == List.ExitLocations.Far,5, 1)’ This expression checks
the value of the ExitLocation string list property and if it is set to ‘Near’, the value of the Travel Time property is set to ‘1’. If the value of
the ExitLocation string list property is set to ‘Far’, the value of the Travel Time property is set to ‘5’.
Testing the Model
Because the Source object is set to only create 10 entities, the model can be tested by seeing how long the model takes to run through 10
entities. The model can also be tested by displaying a status label that returns the average time that an entity spends on the link (i.e.
TimePath1.TimeOnLink.Average).
194 / 815
Simio Reference Guide
SimpleElevatorO bject - SimBit
Problem:
I want to know how to model a simple elevator.
Categories:
Animation, Building New Objects/Hierarchy, Decision Logic – Paths, Vehicles
Key Concepts:
Bind To External Input Node, Bind To External Output Node, C onnector, C ustom Object, External View, Externally Visible, Idle Action, Initial Node
(Home), Location.X, Location.Y, Location.Z, Minimum Dwell Time, ModelEntity, Network Turnaround Method, Object Reference Property, Parking
Station Queue, Ride On Transporter, RideStation Queue, Vehicle
Technical Approach:
We build a custom elevator object that consists of 2 transfer nodes and a bi-directional path connecting the two nodes. A standard vehicle object
is used as the elevator platform that travels between the two nodes. There are also two external nodes where entities transfer out of the object.
The object has two properties for the user to provide inputs; the Minimum Dwell Time of the Elevator and the C apacity of the Elevator.
There are two models that include the Elevator object to demonstrate how it can be used in model logic. The first model uses two elevator
objects. The entity must go up to the second floor to travel between the two elevators, and then back down to the first floor to exit the system.
The second model uses two elevator objects on top of one another, to model a three story facility. The first elevator carries entities up to the
second floor and back to the first floor and the second elevator carries entities to and from the second and third floor.
Enhanced Technical Approach:
To build the Elevator Object:
C lick New Model from the Project Home ribbon to create a new fixed object in this project
C lick onto the new object in the Navigation window and change the name to ElevatorObject. Ensure the ElevatorObject object is selected in
the Navigation window and proceed to the next step.
Facility Window:
Place down two Transfer Nodes. Name them: TransferNode1, TransferNode2
Drag a standard Vehicle object into the Facility window.
Set the Network Turnaround Method property to ‘Reverse’
Set the Initial Node (Home) property to ‘TransferNode1’
Set the Idle Action and OffShiftAction properties to ‘RemainInPlace’
Flatten the Vehicle so it looks like a flat elevator platform
On TransferNode1, set the Entity Destination Type property to ‘Specific’ and set the Node Name property to ‘TransferNode2’.
C reate a new Add On Process in the Entered Add On Process trigger property of TransferNode1 by selecting C reate New in the drop down
of this property. Do the same for TransferNode2.
On TransferNode2, set the Entity Destination Type property to ‘Specific’ and set the Node Name property to ‘TransferNode1’.
On each node, expand the General Properties, and then the Physical C haracteristics and Location to find the X,Y,Z Location properties. Set
these properties to:
TransferNode1 – X: 0, Y: 0, Z: 0
TransferNode2 – X: 0, Y: 6, Z: 0
Draw a Path between the two nodes and set the Type property to ‘BiDirectional’
C reating the External View of the Elevator Object
C lick onto the TransferNode1 node. Right click and select Bind to New External Input Node. Name this FirstFloorIn1. This creates an
External Input Node that sends entities directly to the FirstFloorIn facility node.
C lick onto the TransferNode2 node. Right click and select Bind to New External Input Node. Name this SecondFloorIn1. This creates an
External Input Node that sends entities directly to the SecondFloorIn facility node.
Right click onto Vehicle1 and select Externally Visible. This will make this object NOT externally visible in the External View.
Go to the Definitions Window and into the External View panel. C lick onto the External Node in the Ribbon and place an External Node near
the TransferNode1 and name it FirstFloorOut. Set the Node Class Name property to ‘TransferNode’. Place another External Node near the
TransferNode2 and name it SecondFloorOut. Set the Node Class Name property to ‘TransferNode’.
Processes Window:
In the Add On Process for TransferNode1 Entered process trigger: Place a Decide Step with the Expression property set to ‘Is.Modelentity’
to check if this is the entity arriving to the node.
In the True segment leaving the Decide step, place another Decide step with an Expression set to ‘Modelentity.PreviousNode !=
FirstFloorIn’ This checks to see if the entity arrived from outside of the elevator or if it came through the elevator from the other
node.
In the True segment leaving this Decide Step, place a Transfer Step. Set the From property to ‘C urrentNode’, the To property to
‘ParentExternalNode’ and the ExternalNodeName to ‘FirstFloorOut’. This transfers an entity out of the object if the entity did not just
enter into the object.
In the False segment leaving this Decide Step, place a SetNode step. Set the Destination Type property to ‘Specific’ and the Node
Name property set to ‘TransferNode2’.
After the SetNode step, place a Ride Step. Set the Transporter Type property to ‘Specific’ and the Transporter Name to ‘Elevator’
Adding Object Reference Properties to the Elevator Object:
In order to give the user some control over the behavior of the ElevatorObject object, you can create some properties on this object.
C lick on Vehicle1 and find the Initial Ride Capacity property. Right click onto the name of this property and select Create New
Referenced property. Name this new property ‘ElevatorC apacity’.
Set the Minimum Dwell Time Type of the Vehicle to ‘Specific Time’. Right click onto the Minimum Dwell Time property and select
195 / 815
Create New Referenced property. Name this new property ‘Minimum Dwell Time’.
To see these new properties and change the default values, go to the Definitions window of the ElevatorObject object and go to the
Properties Panel. C hange the default of the Elevator C apacity to ‘1’ and the default of the Minimum Dwell Time property to 5
seconds.
C reate "SingleStory" Model:
C lick New Model to create a new Fixed Object in this project. Name it UsingElevator.
Place down two Source objects, two Sink objects, and two ElevatorObject objects (from the Project Library).
Draw paths from one Source to FirstFloorIn on ElevatorObject1, from SecondFloorOut to SecondFloorIn of ElevatorObject2 and then from
FirstFloorOut to one of the Sink objects.
Draw paths from the other Source to FirstFloorIn on ElevatorObject2, from SecondFloorOut to SecondFloorIn of the ElevatorObject1 and
then from FirstFloorOut to the other Sink object.
C reate "ThreeStories" Model:
Place an instance of the ElevatorObject object and another directly on top of it. (To move an object up and down in the Facility Window,
select the object, hold down the Shift key and drag it up or down)
C onnect the SecondFloorOut node of the first elevator to the FirstFloorIn node of the second elevator with a C onnector. C onnect the
FirstFloorOut node of the second elevator to the SecondFloorIn node of the first elevator with a C onnector.
Place a Source object at the level of the first elevator and connect it to FirstFloorIn with a Path. Add another Source object at the level of
the second elevator. C onnect this Source to FirstFloorIn of the second elevator and SecondFloorIn of the first elevator. The Source will
send half of its entities down to the first floor and half up to the third floor.
Place three Sinks into the Facility window; one at the first floor level, another at the second floor level and a third at the third floor level.
C onnect the FirstFloorOut node to the first floor Sink with a Path. C onnect the SecondFloorOut node of the first elevator and the
FirstFloorOut node of the second elevator to the second floor Sink with a Path. And connect the SecondFloorOut node of the second
elevator to the third floor Sink.
196 / 815
Simio Reference Guide
SimpleLeastSlackSelectionR ule - SimBit
Problem:
I have multiple entities with different due dates and I want to them to be processed with a Least Slack scheduling methodology.
Categories:
Buffering, Lookup and Rate Tables
Key Concepts:
Arrival Mode, Numeric Property, Ranking Expression, Ranking Rule, Rate Tables, Server, Smallest Value First, Time Varying Arrival Rate
Assumptions:
Assume that Processing Time is the same and constant for each type of entity and also assume that entities are allowed to be processed even
after their deadline.
Technical Approach:
Entities are created in separate Sources according to an appropriate Time Varying Arrival Rate. The entities then travel to a Server that selects
the next job based on a Selection Rule to accept the entity type with the least slack waiting in the queue.
Details for Building the Model:
Simple System Setup
In the Facility window, place four Sources and four ModelEntity objects to go along with each Source. Also place a Server and a Sink.
C onnect all the Sources to the Server, as well as the Server to the Sink, with Paths.
Rename the ModelEntities ‘EarlyIn_LateOut’, ‘EarlyIn_EarlyOut’, ‘LateIn_LateOut’, and ‘LateIn_EarlyOut’ and rename the Sources that each
is generated from in a similar fashion (we used EL, EE, LL, LE). Also, change the color of the entity symbols so that each entity type can be
differentiated.
Extend the Input Buffer for the Server so that all entities in the queue will be visible.
C reate Rate Tables
In each Source set the Entity Type to the appropriate Entity. C hange Arrival Mode to ‘Time Varying Arrival Rate’ and notice that the Rate
Table box is now highlighted. This means that a Rate Table has to be created for each type of Entity.
Go to the Data Window and then to the Rate Tables Panel to create a Rate Table. C reate four Rate Tables with names associated with the
entity types (i.e., EarlyIn_LateOut_RT, EarlyIn_LateOut_RT, etc.).
The Interval Size for each table should be’ 1’ hour, while the Number of Intervals for each should be ‘6’. Note that the last 2 hours in all the
tables are 0, indicating no entity arrivals, which will allow the system to empty. The specific rate tables for this example are as follows:
Once these tables are created, go back to the appropriate Source and select the Rate Table that goes with that Source.
Assigning the Due Date
The Due Date will be represented as a Property of the ModelEntity, since it will not change values during the simulation run.
Select ModelEntity in the Navigation Window in the upper right-hand portion of the screen. Go to the Definitions Window and then
Properties Panel. Add a Standard Property (type Real) and rename it ‘DueDate’.
To set the DueDate for each entity, go back to the Model and notice in each entity instance, there is a new property called DueDate.
In this example, the deadlines are set as follows: EarlyIn_EarlyOut to ‘2.5’, EarlyIn_LateOut to ‘7’, LateIn_EarlyOut to ‘6’, and
LateIn_LateOut to ‘8’.
With the default Run Setup settings, the model starts at midnight (represented numerically as 0), so if the entity is to be “shipped”
at 2:30 AM its DueDate is to be set at ‘2.5’.
C onfiguring the Server to Select Entities with Least Slack
The Server in this model is to process entities based off of a Least Slack scheduling methodology. Slack is defined as the Deadline minus
the Remaining Process Time. Because this model only has one server, processing time can be ignored.
Within the Server, change the Processing Time to ‘4’ minutes. Then, change the Ranking Rule to ‘Smallest Value First’. Set the Ranking
Expression to ‘ModelEntity.DueDate’. This means that the Server is going to prioritize the queue according to DueDate, and select the
197 / 815
Expression to ‘ModelEntity.DueDate’. This means that the Server is going to prioritize the queue according to DueDate, and select the
entity with the smallest value, or essentially, the one with the earliest value.
Discussion:
Slack is the “cushion” that an object has between it is potentially done processing and its deadline. In this model, this cushion should have been
mathematically described in the Ranking Expression as ‘ModelEntity.DueDate – (Run.TimeNow + ModelEntity.ProcessingTime)’. The Remaining
Processing Time would become a factor if entities had different processing times. This could happen if there were multiple Servers and/or entities
followed a different sequence of steps, or if the entities just simply have different processing times.
If the Due Dates were exactly the same for all entities, the Ranking Rule would be the opposite of the one used in this example. It would be set to
‘Largest Value First’ with a Ranking Expression of ‘ModelEntity.ProcessingTime’.
Of course, if both Due Date and Processing Time are not consistent between the entities, the entire expression is necessary.
198 / 815
Simio Reference Guide
SimpleT ank - SimBit
Problem:
I want to model the level of a fluid tank complete with animation.
Categories:
Add-On Process Logic, Level States
Key Concepts:
C ircular Gauge, C rossingStateC hange, Floor Label, Level State Variable, Monitor, Rate, Resource, Size.Height, StateStatistic, Status Label
Assumptions:
This tank has a C apacity of 1000 units and fills at a rate of +1000/hr and empties at a rate of -5000/hr with a pause of .1 hours between
changes. The height of the tank in the Facility Window has been set to 5 meters.
Technical Approach:
A resource is created along with other drawing elements to represent a tank. Add-On processes are created to mimic the tank filling/emptying
logic as well as to animate the level of fluid in the tank.
Details for Building the Model:
C reating the Tank
Place a resource into the Facility Window.
C hange the symbol to represent the fluid level in the tank – a cylinder was used in this example – and resize it to an appropriate size (the
Height was set to 5 in this example).
Options to improve animation:
To represent the shell of the tank, draw a polyline around the outer-edge of the cylinder, leaving an opening so that the fluid level is
visible. C hange the Object Height to equal the height of the fluid level.
To represent the top of the tank, draw a circle and change its Object Height. Place it on top of the other two parts.
To show tank action in 2D view, add a dial gauge using the expression TankVolume and range 0 to 1000. In 3D view use “Shift-
Drag” to raise it and place it on top of the tank.
C reating the Add-On Process Logic
Add a Level State Variable called 'TankVolume' in the States panel of the Definitions Window.
In the Processes Window, create 2 processes called TankFull and TankEmpty to dictate the tank’s actions at those points in time.
For TankEmpty:
Add an Assign step and call it StopEmptying. Set the State Variable Name to ‘TankVolume.Rate’ and the New Value to '0'.
Add a Delay step and call it WaitForSupply. Set the Delay Time to '0.1' Hours.
Add an Assign step and call it StartFilling. Set the State Variable Name to ‘TankVolume.Rate’ and the New Value to '1000'.
For TankFull:
Add an Assign step and call it StopFilling. Set the State Variable Name to ‘TankVolume.Rate’ and the New Value to '0'.
Add a Delay step and call it Pause. Set the Delay Time to '0.1' Hours.
Add an Assign step and call it StartEmptying. Set the State Variable Name to ‘TankVolume.Rate’ and the New Value to '-5000'.
In the Definitions Window, Elements panel, add 2 Monitor Elements – MonitorTankFull and MonitorTankEmpty. These monitors trigger an
event when its condition is reached.
For MonitorTankFull:
Set Monitor Type to ‘C rossingStateC hange’
Set State Variable Name to 'TankVolume'
Set Threshold Value to '1000'
Crossing Direction to ‘Positive’
On Change Detected Process will be 'TankFull'
For MonitorTankEmpty:
Set Monitor Type to ‘C rossingStateC hange’
Set State Variable Name to 'TankVolume'
Set Threshold Value to '0'
Crossing Direction to ‘Negative’
On Change Detected Process will be 'TankEmpty'
To represent the animation of the tank we need to make a new process.
In the Processes Window, click the Select Process button in the ribbon and choose ‘OnInitialized’ from the drop down list. Drag an
Execute step and set Process Name in the Logic to TankEmpty.
Add a Delay step called DelayBetweenUpdates and set the Delay Time to an appropriate amount. 1 min was used in this example.
Add an Assign step. Set the State Variable Name to ‘Tank.Size.Height’. The New Value is going to be a representation of the tank’s
fluid level. So, when it is full the value should be equal to the height set to the resource (5). In this case it was set to
TankVolume/200 because the maximum volume is 1000 and 1000/200 equals the height of the resource – 5.
Drag the process Endpoint to the input of the Delay to create a loop. This allows the animation to update every time the Delay is
executed.
Embellishments:
We’ve added a Status Plot to illustrate the TankVolume over time, as well as Status Labels to represent the Tank Volume and Fill Rate. It can be
seen that the animated fluid level mirrors the change in TankVolume.
199 / 815
Discussion:
The delay time used in the DelayBetweenUpdates process step may affect run time. A large delay time between animation updates results in a
faster run time because the model does not have to update the resource height as frequently. On the other hand, a smaller delay time results in a
smoother, more accurate animation at the potential expense of a longer run time.
200 / 815
Simio Reference Guide
SingleVehicleUsage - SimBit
Problem:
I have entities that require movement on a vehicle between operations.
Categories:
Vehicles
Key Concepts:
Ride on Transporter, TransferNode, Vehicle
Assumptions:
There is a single vehicle that moves all entities. The vehicle can move up to 2 entities at a time between the objects in the system. All paths are
unidirectional.
Technical Approach:
Set the Transfer Nodes on the Source and Server objects to specify that a vehicle is required for movement. With unidirectional paths, the vehicle
must have a path to return from the Sink to the Source, even though the entity doesn’t travel between those objects.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink in the Facility Window.
Defining the Vehicle and its C haracteristics
Place a Vehicle in the Facility Window.
Within the Transport Logic section, change the Initial Ride Capacity to ‘2’. This will allow up to 2 entities to be moved on the vehicle at one
time. C hange the Load Time to ‘1’ and the Unload Time to ‘Random.Uniform(1,3)’. Each entity incurs the load delay when getting on the
vehicle and the unload delay when getting off the vehicle.
Modifying the Transfer Nodes
C lick on the Transfer Node (exit) of the Source and change the Ride On Transporter property to ‘True’. Specify the Transporter Type as
‘Specific’ and Transporter Name as ‘Vehicle1’.
Do the same thing as above for Server object’s Transfer Node.
Placing the Paths
Double click on the Path to define the multiple paths between the Source, Server and Sink objects.
When using vehicles, the Basic Node (entry) on the Server must be connected to the Transfer node (exit) on the Server so the Vehicle can
move from one node to the next.
C lick on one of the paths. Note that the Type is set to ‘Unidirectional’. Since the paths are unidirectional, place a path also from the Sink
object back to the Source object. While the entities will exit the system at the Sink, the Vehicle must have a path to return to the Source to
pick up additional entities for transfer.
Embellishments:
Try changing the paths to be bidirectional or changing the initial ride capacity of the vehicle.
201 / 815
Simio Reference Guide
SingleW orkerC ompletesP rocessAndMovesT oNode - SimBit
Problem:
I want to model a system that has multiple Servers in series and requires a Worker to be present at each Server before processing can occur.
The worker completes work across all servers for one entity before another entity can begin processing. Animation should show the Worker
moving between the two servers and parking at the appropriate Server for processing. The Server and Worker should change color when
working. There is only one Worker in the system.
Categories:
Add-On Process Logic, Worker, Resources
Key Concepts:
Active Symbol, Add-On Process, Before Processing, Initial Node (Home), Move Step, Secondary Resources, Server, Worker
Assumptions:
There is only one Worker in the system. It will work at the first Server, and then proceed to work at the second Server with the same entity that
finished at Server1. The Worker will then return to working on the first Server. * NOTE: In this example, the worker moves to the second server
at approximately the same speed as the entity – should this be different, additional logic may be required.
Technical Approach:
The Worker is modeled with a standard Worker object. The Worker object travels between two nodes that are located near each Server, which
animates the moveable resource. The Worker object is seized by the first Server before processing and the model ensures that the object is
located at the appropriate node before it begins Processing. Add On Processes on the first server onExited will request the worker to move to the
second server before processing. The second server will release the worker after processing.
Details for Building the Model:
Simple System Setup
Add a Source, two Servers and a Sink to the Facility window. C hange the Interarrival Time of the Source to ‘Random.Exponential (.53)’
minutes.
C onnect the Source to the first Server, connect the first and second Server together and connect the second Server to the Sink with Paths.
Add two Basic Nodes that are connected to each other with a bi-directional path. Place the nodes near each of the Servers. This is the path
that the movable resource will take between the Servers.
Place a Worker object in the Facility window. Add a symbol to this worker and change it to green by clicking on the Worker object, adding
a new symbol by selecting add additional symbol from the Additional Symbols category in the ribbon. C olor the worker green by selecting
C olor from the decoration ribbon. The worker will already turn green when working as its animation is by default set to
‘Worker.C apacity.Allocated > 0’.
Set the Park While Busy property of the Worker to ‘True’, which will tell the Worker to park at the node while it’s processing instead
of stay on the link.
Set the Initial Node(Home) property to ‘BasicNode1’.
Adding Logic to the Servers
C lick on Server1 and expand the Secondary Resources property category. Under the Other Resource Seizes category, open the repeat
group for Before Processing. Add a new repeat group property by selecting Add. Select the repeat group and set the Object Type property
to ‘Specific’, set the Object Name property to ‘Worker1’. Set the Request Move property to ‘To Node’ and the Destination Node property to
‘BasicNode1’. This tells the Server that it must seize Worker1 and it must arrive at BasicNode1 before processing can begin at this Server.
Repeat the above step for Server2, except instead under Other Resource Releases and After Processing. This will tell Server 2 to release
the worker on completion of processing.
Add On Process Logic for Server1
C lick on the Server1 object and expand the Add On Process Triggers property category.
C reate a new process that is called from the Exited property by selecting ‘C reate New’ from the drop down of this input box. This
new process will tell the Worker to move to Server 2 once the entity has left Server 1.
Go to the processes window and in the process called Server1_Exited, place a Move Step. Open the Resource Move Request
repeat group and add a new property. Set the Object Type to specific, the Object Name to ‘Worker1’, and the Destination
Node to ‘BasicNode2’. C lose the repeat group.
Adding Animation
Add a symbol to this worker and change it to green by clicking on the Worker object, adding a new symbol by selecting add additional
symbol from the Additional Symbols category in the ribbon. C olor the worker green by selecting C olor from the decoration ribbon. The
worker will already turn green when working as its animation is by default set to ‘Worker.C apacity.Allocated > 0’.
Repeat the same step for Server1 and Server2.
202 / 815
Simio Reference Guide
SortingC onveyorSystem - SimBit
Problem:
I have a conveyor system that sorts boxes and sends them to the appropriate shipping dock.
Categories:
C onveyor Systems, Sequence Tables
Key Concepts:
By Sequence, C onveyor, Data Table, Dynamic Object Property, Entity Destination Type, Numeric Property, RandomRow, Sequence Table,
TransferNode
Assumptions:
There are three different types of boxes and each type of box has its own shipping dock.
Technical Approach:
There is only one Source. It reads a Data Table to determine how many of each type of box to produce. The boxes travel on a conveyor to the
Labeling machine (a Server). They leave the Labeling machine and travel on the conveyor system. The system uses Sequence Tables to
determine the route of each type of box.
Details for Building the Model:
Simple System Setup
Place a Source object and a Server object into the Facility window. The Server can be renamed “Labeling Machine”. Set it’s Input Buffer
capacity to 0 to force any waiting entities to stay on the conveyor. Place three Transfer Nodes in a line after the Server. And finally, place
three Sink objects, one below each of the Transfer Nodes. These Sink objects represent the shipping docks and they can be renamed
Box1_Dock, Box2_Dock, Box3_Dock.
C onnect the Source to the Server with a C onveyor. C onnect the Server to the first Transfer Node with a C onveyor and connect the other
Transfer Nodes together with C onveyors. And finally, connect each Transfer Node to the Sink that was placed below it.
Drag three instances of ModelEntity into the Facility window. Rename them to Box1, Box2 and Box3. You can also change the symbol and
the colors, if desired. This is accomplished by selecting the entity and then choosing a symbol from the Symbol Library found in the
Ribbon. The color of the symbol can be changed by selecting a new color from the C olor menu in the Ribbon (when the entity is selected)
and then clicking on the part of the entity that you’d like changed.
C reating Tables
Go to the Tables panel within the Data window. C reate a new Data Table by clicking on the Add Data Table icon in the Ribbon.
Add a new column to this table of type, “Entity”. This is done by selecting “Entity” from the Object Reference drop down in the
Ribbon. You can rename this property to be “BoxType” from within the Properties window on the right.
Add another column to this table of type, “Real”. This is done by select “Real” from the Standard Property drop down in the Ribbon.
You can rename this property to be “ProductMix”.
Enter data into this table, such as: Box1 .4 Box2 .3 Box3 .3
Add Three Sequence Tables by clicking on the Add Sequence Table icon in the Ribbon (3 times). There is one Sequence table for each type
of Box. The Sequence Table consists of rows of Nodes and the Entity (Box) will follow this route, going from the node listed first and then
proceed row by row.
In SequenceTable1, enter the following rows of data: Input@Labeling, TransferNode1, Input@Box1_Dock
In SequenceTable2, enter the following rows of data: Input@Labeling, TransferNode1, TransferNode2, Input@Box2_Dock
In SequenceTable3, enter the following rows of data: Input@Labeling, TransferNode1, TransferNode2, TransferNode3,
Input@Box3_Dock
Using the Data Table
From within the Facility window, click on the Source and expand the Table Reference Assignment section in the Properties Window.
Set the Table Name to the name of your Data Table (i.e. ‘Table1’)
The Row Number is set to ‘Table1.ProductMix.RandomRow’. This function tells Simio to use the values in the Product Mix column as a
weighted average to determine which row to set at any given time. So in our example, 40% of the time row 1 will be read. 30% of the
time, row 2 will be read and 30% of the time, row 3 will be read.
Set the Entity Type property to ‘Table1.BoxType’. The Source will create the entity listed in the BoxType column of Table1. Therefore, 40%
of the time Box1 types will be created, 30% of the time, Box2 types will be created and 30% of the time, Box3 types will be created.
Using the Sequence Tables
In order to tell the Entity which Sequence Table to use, click on each Entity instance (Box) and set the InitialSequence property. Box1’s
property should be set to ‘SequenceTable1’, Box2 to ‘SequenceTable2’, and Box3 to ‘SequenceTable3’.
You also need to configure each of the Transfer Nodes in the model to use Sequence Tables to determine the next location for the entity.
Therefore, click on each Transfer Node (including the output nodes of the Source and the Server) and set the EntityDestination property to
‘BySequence’.
Embellishments:
Experiment by changing the sequences in the Sequence Tables. See how the model behaves when the TransferNodes do not use “BySequence”
for their EntityDestination property. Vary the values of the ProductMix column in the Data Table to see different amounts of each box type
created.
Instead of using predetermined sequences, other approaches to sort the packages could include:
Use an add-on process when leaving the Server to set the entity destination to the proper loading dock.
Add decision logic in add-on processes at Transfer Nodes 1 and 2 to represent a scanner that would “read” the entity and direct it down the
appropriate path.
203 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
204 / 815
Simio Reference Guide
SourceServerSinkApproaches - SimBit
Problem:
Source – Server – Sink (SSS) is a frequently used problem for beginners in simulation because it can be easily compared to queueing theory
problems such as M/M/1 and M/M/2. But even that simple model has several possible approaches. We provide this project both to illustrate three
approaches and to provide a tool for fast experimentation by beginners.
Categories:
Decision Logic -- Processing
Key Concepts:
Analysis, C apacity.Allocated, C ontents, C reate Step, Delay Step, Delay Step, Destroy Step, Experiment, Expression Property, Histogram,
InputBuffer, OutputStatistic, Pivot Grid, Release Step, Replication, Response, Server, Sink, Status Label, Tally Step, TallyStatistic, Timer Element,
Transfer Step, WaitUntilTransferringEvent
Assumptions:
We are assuming a very simple system consisting of a single arrival stream, a single (perhaps multiple capacity) server, and then the entity is
disposed. The primary statistics of interest are the time in queue and number in queue.
Unlike most SimBits, our goal here is not to teach you the details of how to build these, but rather to provide the modeling concepts and leave
you with a useful tool for beginning analysis.
Technical Approach:
This project file contains three models. We have one model (SSS_Library) built using only the Standard Library. This is the easiest to build, but
also runs significantly slower because it contains some overhead of objects and statistics. The other two models are built entirely from processes
– one with just tokens (SSS_Process) and one with entities (SSS_Process_with_Entity). While not complex, these are a little more difficult to build
and understand because you have to do some of the “plumbing” yourself, but the reward is significantly faster execution.
Using these Objects:
Each object has four properties to adjust their behavior: Time Between Arrivals, Maximum Arrivals, Service Time, and Number of Servers. By
adjusting those parameters you can compare simulation results to those of many common queuing problems. By adjusting the number of
replications in the experiments, you can see a clear illustration of the value of running sufficient replications.
Running Interactively to watch the provided animation
Select a model in Navigation window in the upper right (each model name begins with “SSS_”). C hange to the Facility window for the selected
model. Right click on the model name and select Properties to open the Model Properties. You will find the four properties in the Process Logic
category. Set them and run to watch the animation.
Running experiments to perform a reliable statistical analysis
From the Navigation window, load the experiment for the selected model. You will see the four C ontrols (the properties) as well as two Responses
(the Key performance Indicators). You can get a quick summary of the results here as well as go to the Pivot Grid for more complete data.
To really appreciate the value of additional replications, select the Response C hart tab in the experiment window, turn on the Histogram and
Rotate Plot buttons if not already on, reset the run, then press run and watch how much the early results vary.
Modeling Concepts:
As mentioned above, our goal here is not to teach you the details of how to build these, but rather to provide the modeling concepts. So here are
some of the concepts for each approach.
SSS_Library
Build the model by placing the three objects and connecting them with C onnectors, not Paths, so they do not impact the timing. We expose the
four properties by right-clicking on each property to create a new reference property. Then in the Properties panel of the Definitions tab, we fine
tune the “properties” of each property to control things like category, units, default value, and display name. We also hide the inherited properties
that we do not want to clutter our model property window.
SSS_Process
This model is built using the Processes window and the Definitions window. In the processes window, we set up a simple Seize, Delay, Release,
Tally. Since only one item is being seized, we can use the Parent Object itself as the constraint. We set up a separate Assign using the
OnRunInitialized process to assign that desired quantity of the parent object. Note that this is all done with the Token that is executing the process
– we never create any entities.
In the Definitions window we add a Timer to trigger periodic token arrivals t our process. We add a TallyStatistic to collect TimeInSystem and we
add two OutputStatistics to collect the final values of the Queue statistics.
SSS_Process_with_Entity
This model is built using the Processes window and the Definitions window similar to above. But instead of using just the tokens, we also create
Entities to support better animation. Since we have an entity, we also take advantage of using a Station as our constraint. Transferring into a
station is similar to seizing a resource. Destroying the entity after it finishes processing also removes it from the station, the equivalent of a
release.
Since the Entity and Station automatically generate their own statistics, we do not need the Tally step, or TallyStatistic and OutputStatistic
elements.
Embellishments:
Note that while we have discussed this as a project containing three models, you could also load the spfx file as a library containing three objects.
205 / 815
Simio Reference Guide
SourceW ithC ustomEntityT ypeP roperty - SimBit
Problem:
I would like my Source object to create multiple entity types but instead of reading a table to get the information about which types of entities to
create, I would like my user to input this information through a property on the Source object.
Categories:
Arrival Logic, Building New Objects / Hierarchy
Key Concepts:
C reate Step, Dynamic Object Property, Expression Property, Override, Process, RandomRow, Repeating Group Property, SetRow Step, Status
Label, Subclass
Assumptions:
A new, custom Source object is created, by subclassing the Source from Simio’s standard library.
Technical Approach:
We subclass a standard Source object and add a new Repeating Group property that contains a Dynamic Object Instance property (Entity
property) and an Expression property. This is the property used to input information into this Source on which type of entity to create and the
percentage of which type of entity to create. The OnEntityArrival process is Overridden and modified. A new SetRow step is used to reference the
contents of the new RepeatingGroup property. The C reate Step is modified to reference the RepeatingGroup’s Entity property for its Object
Instance Name. This tells the new Source object to set a row in the Repeating Group property (based on the probabilities entered) and then
create that particular type of entity.
Details:
Subclass the Standard Source object
From the standard library in the Facility window, right click on the standard Source object and select “SubC lass”. This will place a new,
subclassed Source object in your Project Library and you will automatically be navigated into this object. In other words, you’ll see the
new Source in the Navigation window (top right corner of interface) and the new Source will be highlighted. This indicates that you are
inside of that new Source object – looking at its Facility window, not the main model’s Facility window.
From within this new Source object, go to its Definitions window. C lick on the Properties panel on the left to view the Properties window.
C reate a new Repeating Group property on this object by clicking the icon in the ribbon named “Repeat Group”.
Rename this property ‘Entity_Types’ and set the Description in the properties window to ‘The type of entity to create and the
probability of creating this type.’
Set the Category Name to ‘Arrival Logic’.
Ensure that this new property is highlighted in the Properties Window and then select “Entity” from the ‘Object Reference’ property
dropdown of the Ribbon. This is adding a new Dynamic Object Instance type property into this Repeat Group property. This new
property should appear under the heading Entity_Types.Properties in the main part of the Properties window, if it were indeed
added to the Repeat Group.
With this new Dynamic Object Instance property highlighted/selected, change the Name to ‘Entity_Type’ and set the
Description to ‘The type of entity to create’.
Set the Category Name to ‘Arrival Logic’
Go back and select/highlight the Entity_Types property and select ‘Expression’ from the Standard Properties dropdown of the
Ribbon. This is adding a new Expression type property into this Repeat Group. This new property should appear under the heading
Entity_Types.Properties, alongside the Entity_Type property.
With this new Expression property highlighted/selected, change the Name to ‘Probability’ and set the Description to ‘The
probability of creating this type of entity.’
Set the Category Name to ‘Arrival Logic’
From within this new Source object, go to its Processes window. Find the OnEntityArrival process and select it by clicking anywhere in the
process. C lick the Override button in the ribbon and see the process change to a White background, which indicates that you can now
modify the logic.
Place a new SetRow step after the Execute step and before the C reate step.
C hange the Name to ‘RandomRowInEntity_Types’.
Right click on the Table Name property and select ‘Set Referenced Property’ and select the Entity_Types Repeat Group
property that we just created.
Put the expression, ‘Entity_Types.Probability.RandomRow’ into the expression for Row Number, which tells this SetRow step
to select a row in the Entity_Types Repeat group, based on the values in the Probability property.
Ensure the Object Type property is set to ‘Token’ (found in the Advanced Options category), so that we are telling the Token
to set a reference to the Repeat Group and not the associated object (which doesn’t exist yet).
C lick on the C reate Step and right click on the Object Instance Name property. Select ‘Set Referenced Property’ and select
Entity_Types.Entity_Type, which tells this C reate Step to look there for which type of entity to create
Use the new Source in the main Model
Navigate back to the main Model by selecting ‘Model’ in the Navigation window (upper right). From the Facility window, drag a standard
Server and a standard Sink from the Standard Library. Find the new Source we created in the Project Library (bottom left, under the
standard Library) and drag one instance of the new Source into the Facility window. C onnect the three objects with Paths.
Drag three instance of ModelEntity into the Facility window and rename them to ‘PartA’, ‘PartB’ and ‘PartC ’. Give each entity a unique color
by selecting the instance, and selecting color from the Ribbon and then clicking back on the entity to give it that color.
C lick on the instance of the new Source object within the Facility window and find the Entity_Types property in the Arrival Logic category.
C lick the ellipse at the far right of the new property to open the Repeat Group editor (to begin entering values).
C lick ‘Add’ to add a new row into this Repeat Group property. Enter ‘PartA’ for Entity_Type and ‘.3’ for the value of the Probability
property.
206 / 815
C lick ‘Add’ twice more to add a row for creating ‘PartB’ with a probability of ‘.4’ and ‘PartC ’ with a probability of ‘.3’.
Embellishments:
C onsider adding Status Labels and/or Floor Labels to visually display how many of each type of entity has been created, in order to help debug
and validate the behavior of the new Source object. (The expression, ‘PartA.NumberC reated’ will return the number of this type of entity that was
created by the Source.)
207 / 815
Simio Reference Guide
SourceW ithR ateT able - SimBit
Problem:
I have entities for which the arrival rate varies over time.
Categories:
Arrival Logic
Key Concepts:
Arrival Mode, Poisson Distribution, Rate Tables, Source, Time Varying Arrival Rate
Assumptions:
I have an average of 20 entities arrive during every third hour (e.g. 2:00, 5:00, 8:00, 11:00, …). On other hours I have no arrivals.
Technical Approach:
Specify the arrival data in a Rate Table. Reference that rate table in a Source object.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink in the Facility Window.
C onnect the Source to Server and Server to Sink using Paths.
Defining a Rate Table
In the Data Window, select the Rate Tables panel and create a new rate table with Name ‘RateTable1’. C hange the Interval Size property to
‘1’ and the Number of Intervals to ‘24’.
Add the data for the average number of arrivals during each period.
Using the Rate Table within a Source
C hange the Source1 Arrival Mode property to ‘Time Varying Arrival Rate’ and Rate Table to ‘RateTable1’.
Discussion:
Do not expect an exact number of arrivals in any given period. This is random, a non-homogeneous Poisson distribution. Over a sufficient
number of trials, it will produce the average number of arrivals specified, but for any given period it may be unlikely to generate the exact
number specified.
208 / 815
Simio Reference Guide
StringStates - SimBit
Problem:
I would like to check the priority of part and then use a String State to display to the screen, whether or not the current part is considered a high
risk part, a medium risk part or a low risk part.
Categories:
Discrete States, Functions
Key Concepts:
Before Exiting, C ondition, C urrent Symbol Index, Floor Label, Math.If(), ModelEntity, Priority, State Assignments, String State Variable
Assumptiona:
There are five different parts produced in this model, each assigned a priority of 1-5, with equal probability. Priority 1 is considered High Risk,
Priority 2 is considered Medium Risk and the rest are considered Low Risk.
Technical Approach:
Assign the entity a value of 1-5 in the ModelEntity.Priority state via the Before Exiting State Assignment property of the Source object. Assign a
value of “HIGH”, “MEDIUM” or “LOW” to a String State, via the On Entering State Assignment property of the Source object, based on the priority
of the entity that has just entered this Server. The String State is written to the screen in a Floor Label. The Math.If function is used to check
ModelEntity.Priority and then assign a value to the String State.
Details for Building the Model:
Simple System Setup
Drag a standard Source, a standard Server and a standard Sink into the Facility window. C onnect them with Paths.
Drag a ModelEntity into the Facility window from the Project Library. Rename this to ‘Parts’. With the ModelEntity selected in the Facility
window, click Add Additional Symbol button in the Ribbon to give this entity a total of 5 symbols. Assign a different color to each symbol.
To assign colors to each symbol, select the ModelEntity object and click the C olor button in the icon. Select the desired color and
then click back onto the ModelEntity object in the Facility window. You should see the color change. You have just changed the color
of the “active symbol”. To determine which symbol is active, look at the Active Symbol button in the icon. To change which symbol
is active, select the appropriate symbol from the Active Symbol dropdown.
When the ModelEntity object is selected in the Facility window, find the Current Symbol Index property in the properties window.
C hange the expression to ‘ModelEntity.Priority -1’. (The minus 1 is needed because the Symbol index is 0 based but the smallest
priority we’ll assign is 1)
State Assignments
C reate a new String State on the Model by going to the Definitions window and clicking on the States panel along the left side of the
window.
C lick the String button in the Ribbon to create a String state. Rename it ‘Alert’.
Back in the model’s Facility window, click on the Source object in the Facility window.
Find the Before Exiting property under the State Assignments category in the properties window and add a row to this repeat group
property (by click on the ellipse that appears in this input box).
The State Variable Name is ‘ModelEntity.Priority’ and the New Value expression should be Random.Discrete(1,.2, 2,.4, 3, .6, 4, .8, 5,
1 ) , which assigns the value of 1-5, each with an equal probability of .2
C lick on the Server object in the Facility window.
Find the On Entering property under the State Assignments category in the properties window and add a row to this repeat group
property.
The State Variable Name is ‘Alert’ and the New Value expression should be Math.If((ModelEntity.Priority == 1), "HIGH",
(ModelEntity.Priority ==2), "MEDIUM", "LOW") This expression will assign a value of “HIGH” to Alert if the ModelEntity being
processed has a priority of 1, it will return “MEDIUM” if the priority is 2 and “LOW” otherwise .
Add a Floor Label
Add a floor label in the Facility window that will animate the current value of the Alert state variable. From the Drawing tab of the ribbon,
click on the Floor Label button and draw and floor label somewhere in the Facility window.
With the Floor Label selected, click the Edit button in the Ribbon, and type what you’d like to display. This example uses: The part being
processed is {alert} risk. Notice that an expression must be between these brackets {}. The tags that are part of this Floor Label changes
the text to the color blue and underlines the text.
Embellishments:
Slowing down the arrival and processing rates might make it easier to see the behavior of the system. In this example, the Source’s Interarrival
Time was changed from the default to ‘Random.Exponential(2)’ and the Processing Time of the Server was changed to ‘1’. You can also slow down
the animation on the Run Tab of the ribbon.
209 / 815
Simio Reference Guide
T ableR eferenceInR epeatingP roperty - SimBit
Problem:
I have three types of entities and want to store their respective information about processing times, which worker to use and which assignments
to make within a table.
Categories:
Data Tables, Worker
Key Concepts:
Before C reating Entities, Data Table, Dynamic Object Property, Expression Property, Numeric Property, RandomRow, Ride on Transporter, State
Assignments, State Property, Table Reference Assignments, Table Transporter Property
Assumption:
There are three types of entities and each one has only one worker that it uses and has only one assignment to make.
Technical Approach:
A Data Table is created that will store information about each entity type. Each row in the table will include information related to a specific entity
type, including the percentage of each that enters the system, the worker that is needed to move the entity, the processing time at a given server
and finally, the entity state and value to assign when the entity gets to the server.
Details for Building the Model:
Simple System Setup
Add a Source, Server, and Sink, as well as two Worker objects to the Facility Window. Also, place three ModelEntity objects from the
Project Library into the window.
C hange the Names of the ModelEntity to be 'Red', 'Blue' and 'Green'. C hange the symbol color of each to match the name. This is done by
highlighting the symbol and selecting the appropriate C olor from the Symbols ribbon. We will be changing the picture of the Red entity, so
select the Red entity symbol, click on Add Additional Symbol in the Symbol ribbon and change the picture so that graphically the symbols
for 0 and 1 are different (colors or texture).
C hange the color of one of the Workers so that you can tell them apart graphically.
Use Paths and connect Source1 to Server1, Server1 to Source1 (using unidirectional paths instead of a single bidirectional path) and also
Server1 to Sink1.
Setting up the Data Tables
In the Data Window, select the Tables panel and add a Data Table named ‘Table1’ with the following properties and in the following order:
(Entity Object Reference with Name ‘EntityType’) Blue, Green, Red
(Integer with Name ‘Percentages’) 30, 35, 35
(Expression with Name ‘ProcessTime ‘ ,Unit Type ‘Time and Default Units ‘Minutes’) Random.Triangular(1,2,3), 3.4,
Random.Uniform(5,6)
(State with Name ‘StateName’) ModelEntity.Priority, ModelEntity.Size.Width, ModelEntity.Picture
(Expression with Name ‘StateValue1’) 2, 1.4, 1
(Transporter Object Reference with Name ‘Workers’) Worker1, Worker2, Worker1
C reating Multiple Entity Types from Source
In the Facility Window, expand the Table Reference Assignment in the Properties Window of the Source object.
Under the Before C reating Entities subcategory, set the Table Name to ‘Table1’ and the Row Number to ‘Table1.Percentages.RandomRow’.
C hange the Entity Type to ‘Table1.EntityType’ and set the Interarrival Time to ‘Random.Exponential(2)’.
Specifying the Worker for Transport
Within the Source’s transfer node, ‘Ouptut@Source1’, change the Ride on Transporter property to ‘True’.
C hange the Transporter Name to ‘Table1.Workers’.
Adding Processing Time and Assignment Information to the Server
Within Server1, change the Processing Time to ‘Table1.ProcessTime’.
Expand the State Assignments and click on the button within the On Entering property to open the repeating property editor. Use the Add
button and add a State Variable Name of ‘Table1.StateName’ and New Value of ‘Table1.StateValue1’. C lose the dialog and you should see
the On Entered property change to ‘1 Row’.
210 / 815
Simio Reference Guide
T allyStatisticsInT able - SimBit
Problem:
I have two different entity types and two exits from the system. I would like to keep entity statistics, by type, for each exit from the system.
Categories:
C ustom Statistics
Key Concepts:
Add-On Process, Data Table, Dynamic Object Property, Expression Property, On C reated Entity, On Entered, Path, Selection Weight, Table
Reference Assignments, Table Tally Statistic Element Property, Tally Step, TallyStatistic
Assumptions:
There are two entity types which go through a single server, then through an inspection area where they either pass inspection or fail inspection.
Technical Approach:
A Data Table is used to store information about each entity type as it moves through the system, including the processing time at the Server, the
inspection percentages and also the tally statistics names that will be used when the entity either passes or fails inspection.
Details for Building the Model:
Simple System Setup
Add two Sources, two Servers and two Sinks to the Facility window. C onnect both Sources to Server1 with Paths. C onnect Server1 to
Server2, then Server2 to both Sinks with Paths.
C hange the Name of Sink1 to ‘Passed_Inpection’ and the Name of Sink2 to ‘Failed_Inspection’.
Add two ModelEntities from the Project Library to the Facility window. C hange the Name property (under General category) on one to
‘PartA’ and the other to ‘PartB’. C hange the C olor of the PartA symbol to red.
Setting Up Tally Statistics
We will keep statistics on each part type that goes through each exit; therefore 4 tally statistics will be needed. In the Definitions tab,
Elements panel, click on the Tally Statistic button and add 4 tallies.
C hange the Name properties (under General) to ‘PartA_Passed’, ‘PartA_Failed’, ‘PartB_Passed’ and ‘PartB_Failed’.
Adding a Data Table
C reate a new table by clicking on the Data tab, Tables panel and selecting Add Data Table. Within the table, there will be five columns.
First, add a Object Reference – Entity, then two Standard Property – Expression fields, then two Element Reference – Tally Statistic
columns.
C hange the Name of the first column to ‘Entity Type’. Add ‘PartA’ and ‘PartB’ as the row values in the column.
C hange the Name of the second column to ‘Process Time’ and its associated Unit Type to ‘Time’ and Default Units to ‘Minutes’. Add
‘Random.Triangular(3,4,5)’ and ‘Random.Triangular(3,5.4,7)’ as the processing time values in the column.
The third column should have the Name of ‘Inspection Rate’. The rate should be ‘.9’ for PartA and ‘.84’ for PartB.
Finally, the last two columns, which are tally references, should have Name values of ‘Passed Tally’ and ‘Failed Tally’. In the ‘Passed Tally’
column, enter the ‘PartA_Passed’ and ‘PartB_Passed’ tally names. In the ‘Failed Tally’ column, enter the ‘PartA_Failed’ and ‘PartB_Failed’
tally names. These names will be referenced within the Tally step later in this description.
Setting up the Source Objects
In the Facility Window, change the Entity Type property for Source1 to ‘PartA’. In order to reference the table data, set the Table Name
property to ‘Table 1’ and the Row Number to ‘1’.
C hange the Entity Type property for Source2 to ‘PartB’. In order to reference the table data, set the Table Name property to ‘Table 1’ and
the Row Number to ‘2’.
Modifying the Servers and Paths
Within Server1, change the Processing Time to reference the table with ‘Table1.ProcessTime’. Within Server2, change the Name to
‘Inspection’ and the Processing Time to ‘Random.Triangular(2,2.5,3)’. All part types have the same inspection time distribution.
On the paths from Inspection to the Passed_Inspection and Failed_Inspection sinks, we will be modifying the Selection Weight property to
reflect the rate of failure for each part type. For the path going to Passed_Inspection, change the Selection Weight to
‘Table1.InspectionRate’. For the path going to Failed_Inspection, change the Selection Weight to ‘1-Table1.InspectionRate’.
Using C ustom Tally Statistics
Within the Passed_Inspection Sink, create a new process in the Add-On Process Triggers Entered property named
‘Passed_Inpection_Entered’. Within the Failed_Inspection object, create a similar new process in the Entered property named
‘Failed_Inspection_Entered’.
Within the Processes window, in the Passed_Inspection_Entered process, add a Tally step. Have the Value Type of ‘Expression’,
TallyStatistic Name property of ‘Table1.PassedTally’, and Value of ‘ModelEntity.TimeInSystem’.
Do the same for the Failed_Inspection_Entered by adding a Tally step, changing the TallyStatistic Name to ‘Table1.FailedTally’ and Value to
‘ModelEntity.TimeInSystem’.
The above Tally steps will then point into the correct columns of Table1 to utilize the various Tally Statistics elements for each of the part
types, PartA and PartB. These custom statistics can then be seen in the Model statistics, with the Data Source value being the Tally Statistic
Name (PartA_Passed, PartA_Failed, etc.).
Embellishments:
The tally statistics that are added may be modified to categorize them in a more meaningful fashion. Within the Tally Statistics elements in the
Definitions tab, each tally has a Results C lassification area of properties. Using the Data Source, Category and Data Item properties can help to
classify the user statistics in the results. For example, you may wish to set them as ‘Results’, ‘PartA’ and ‘Passed’ respectively (and similar for the
other Tallies).
212 / 815
Simio Reference Guide
T ankC leanInP laceT rigger - SimBit
Problem:
Empty and clean the tank when the inflow entity type changes, but if the tank is already empty, skip cleaning. The time to clean the tank is
dependent on which inflow entity type is used.
Categories:
Add-On Process Logic, Flow Library
Key Concepts:
Add-On Process, Assign Step, C hangeovers, C lean In-Place Triggers, Decide Step, Delay Step, FlowC onnector, FlowSink, FlowSource,
LastC hangeoverState, List Property, StringList
Technical Approach:
The Inflow entity type changes every 5 minutes by enabling and disabling FlowSource regulators. Using the Tank’s C lean-In-Place Triggers, the
tank is cleaned on the event when the inflow entity type changes. The required cleaning time is then determined by looking at the specified
‘From/To’ changeover matrix and getting the time when transitioning from the last changeover state to the current changeover state of the clean
in-place operation. When the entity type changes but the tank is empty, the LastC hangeoverState variable is set to 0 so the cleaning is skipped.
Details for Building the Model:
Simple System Setup
Add 3 FlowSources, a Tank, and a FlowSink to the Facility window. Add 3 ModelEntity objects to the Facility window. C onnect the
FlowSources to the Tank and the Tank to the FlowSink using FlowC onnectors.
Rename the ModelEntity objects ‘Flow1’, ‘Flow2’, and ‘Flow3’. Select Flow2, click the C olor dropdown, select Red, and click Flow2. Select
Flow3, click the C olor dropdown, select Light Blue, and click Flow3. Set Entity Type of FlowSource1 to ‘Flow1’, Entity Type of FlowSource2 to
‘Flow2’, and Entity Type of FlowSource3 to ‘Flow3’.
Flow Regulator Logic
Within the output flow nodes of the FlowSource objects, set Regulator Initially Enabled to ‘False’ for FlowSource2 and FlowSource3. This
causes the flow from both FlowSource2 and FlowSource3 to initially be off, while the flow from FlowSource1 will start immediately.
Within the output flow nodes of FlowSource3 and Tank1, set the Initial Maximum Flow Rate to ‘25’ C ubic Meters per Hour.
C lick the Processes window and select OnRunInitialization from the Select Process dropdown. Add the following steps in order - Delay,
Assign, Delay, Assign, Delay, and Assign. C lick the third Assign step and move the end point to the beginning of the first Delay step.
Set the Delay Time to ’5’ and Units to ‘Minutes’ for each Delay step.
For the first Assign, set the State Variable Name to ‘[email protected]’ and New Value to ‘False’. Add a Row to
Assignments (More) and set the State Variable Name to ‘[email protected]’ and New Value to ‘True’.
For the second Assign, set the State Variable Name to ‘[email protected]’ and New Value to ‘False’. Add a Row to
Assignments (More) and set the State Variable Name to ‘[email protected]’ and New Value to ‘True’.
For the third Assign, set the State Variable Name to ‘[email protected]’ and New Value to ‘False’. Add a Row to
Assignments (More) and set the State Variable Name to ‘[email protected]’ and New Value to ‘True’.
C lean In-Place Triggers Logic
Select ModelEntity in the Navigation window. C lick the Definitions window then select Lists from the panel. C lick the String button. Select
StringList1 and rename it to ‘FlowTypeList’. Type ‘Flow1’, ‘Flow2’, ‘Flow3’ into the list.
C lick the Property option from the Definitions panel. C lick the Standard Property Window and select List. C hange the Name to ‘FlowType’.
Set the List Name to ‘FlowTypeList’.
Select Model in the Navigation window. C lick the Facility window. C lick each Model Entity, and set the Flow Type to its Entity’s name.
C lick the Definitions window then Lists button. C lick the String button. Select StringList1 and type ‘Flow1’, ‘Flow2’, ‘Flow3’ into the list.
Select the Data window, C hangeovers button on the panel. C lick the C hangeover Matrix button. Set the String List Name to ‘StringList1’
and Time Units to ‘Minutes’ for C hangeoverMatrix1. Fill in the Matrix '0,1,2;4,0,3;5,6,0'.
C lick the Facility window and select the Tank. Add a row to the C lean-In-Place Triggers and set Triggering Event Name to
‘Tank1.InflowEntityTypeC hanged’, Cleaning Time Type to ‘Sequence Dependent’, Operation Attribute to ‘ModelEntity.FlowType’, and
Changeover Matrix to ‘C hangeoverMatrix1’.
Double click New Inflow Entering label of the Add-On Process Triggers to create a new process.
In the Processes window, add a Decide step and an Assign step (from the True exit of the Decide step) to the new process.
Within the Decide step, set the Expression to ‘Tank1.FillStatus==0’, and on the Assign step, set the State Variable Name to
‘Tank1.LastC hangeoverState’ and New Value to ‘0’. This will check to see if the tank is empty (fillstatus is ‘0’), the changeover will not be
necessary.
213 / 815
Simio Reference Guide
T askSequenceAndW orker - SimBit
This SimBit project includes two models that demonstrate the use of the Server’s Task Sequence capability including Workers.
Models included in this SimBit:
1. TaskSequenceAndWorker_InServer – Demonstrates the Server’s task sequence option including a number of process tasks requiring
workers. The data within this model is stored directly within the Server object.
2. TaskSequenceAndWorker_InTable – Demonstrates the Server’s task sequence option including a number of process tasks requiring
workers. The data within this model is stored in a table and referenced from within the Server object. This provides additional flexibility as
the data can be read in from an external data source.
Model 1: TaskSequenceAndWorker_InServer
Problem:
I would like to perform a number of concurrent tasks at a Server with a worker, including having the worker move to another location, perform a
task then move back to my location. The information about the tasks is specified in the Server.
Categories:
Add-On Process Logic, Decision Logic – Processing, MultiTask Server, Path, People, Resources, Worker
Key Concepts:
Add-On Process, Bidirectional Path, DestinationNode, Keep Reserved If, Release Step, Request Move, Resource, Seize Step, Server, Task
Sequence, TransferNode, Worker
Assumption:
We will be reserving the Worker within the Server’s processing tasks for each task and then again for the transport task from one Server to the
next. It is assumed that the object ride capacity is ‘1’ when using reserved workers/vehicles.
Technical Approach:
There are multiple tasks that occur within the waiting area of the model, including seizing a room resource, seizing the nurse worker to go and
clean the room, then moving the nurse to the patient location. The ‘Keep Reserved If’ options are set to ‘True’ so that the same nurse performs
the various operations, as well as is reserved for transporting the entity patient to the Exam Server. All tasks that occur within the waiting room
are specified using the Task Sequence option for processing in a Server.
Details for Building the Model:
Simple System Setup
Place a Source, two Servers and a Sink in the Facility window. C hange the Name of the Source to ‘ArrivalArea’, the first Server to
‘WaitingArea’ and the second Server to ‘Exam1’. Name the Sink ‘Door’. Add a ModelEntity to the model and name it ‘SickPatient’. Position
the Servers and their input/output nodes as shown in the example.
Place three TransferNode objects in the Facility window, one to the top left of the Exam1 server (‘NurseStation’), one directly below that
and in line with the WaitingArea and Exam1 servers (‘TransferNode1’) and one below the Exam1 server (‘TransferNode2’).
C onnect the ArrivalArea source to the WaitingArea server with a Path. Use Paths to connect the NurseStation node to TransferNode1 and
then all other possible paths. Note that using bidirectional paths is an easy way to allow travel in both directions, but keep in mind this can
cause potential deadlocking with multiple workers/vehicles and can cause entity logic trouble if the entity destination is ‘C ontinue’ and not
a specific destination.
C onnect the input/output nodes in the Exam1 server with a C onnector or Path.
Defining the Worker (Nurse)
Place a Worker object in the Facility window with the Name ‘Nurse’. C hange the Initial Node (Home) to ‘NurseStation’ and the Idle Action to
‘Park At Home’. Note that in this particular model, we only have a single nurse (Initial Number in System under Population is default of ‘1’).
Entity Arrivals
Within the ArrivalArea source, change the Interarrival Time to ‘Random.Exponential(2.5)’ minutes. The connection to the WaitingArea will
allow all entities to directly move to that area for processing.
Waiting Area Logic
Within the WaitingArea server, change the Initial Capacity to 10. This will allow 10 entities to be waiting in the area in a graphical queue to
perform the various tasks specified.
C hange the Process Type to ‘Task Sequence’ and enter the Processing Tasks repeating properties dialog. All tasks will occur sequentially,
therefore we will number them as such.
For Sequence Number ‘10’, the Name is ‘ReserveRoom’ and the Process Type is ‘Process Name’. The Process Name that will include
the logic for this process is ‘GetRoom’. (see below).
For Sequence Number ‘20’, the Name is ‘SendNurseToRoomAndC lean’, the Process Type is ‘Specific Time’ and Processing Time is
‘Random.Triangular(.5,1,1.5)’. It is important to note that for this process task, the nurse is required. Thus, the Object Name is
‘Nurse’, the Request Move is ‘ToNode’ and Destination Node is ‘Input@Exam1’. This task will seize the nurse, move the nurse to the
Exam1 location and delay for the processing time specified.
For Sequence Number ‘30’, the Name is ‘BringBackNurse’, the Process Type is ‘Specific Time’ and Processing Time is ‘0’. The nurse
is also required for this task. Thus, the Object Name is ‘Nurse’, the Request Move is ‘ToNode’ and Destination Node is
‘Output@WaitingArea’. This task will seize the nurse, move the nurse to the WaitingArea location.
One key concept with multiple process tasks using resource requirements is that by default, within the Advanced Options section of
properties, the Keep Reserved If is set to ‘True’. Therefore, the resource is reserved automatically when used from one task to
another.
Within the WaitingArea output node, change the Entity Destination Type to ‘Specific’ and the Node Name to ‘Input@Exam1’. It is important
to specify the entity destination when a network of nodes will be passed to that the entity continues to its correct destination. C hange the
Ride On Transporter to ‘True’ and the Transporter Name to ‘Nurse’. Note that the Keep Reserved If property is blank, meaning we will not
reserve the nurse for processing in the exam room, although if the nurse was needed for that processing, this should be set to ‘True’.
Exam Logic
Within the Exam1 server, change the Processing Time to ‘Random.Triangular(1,2,3)’ minutes. Within the Add-On Process Triggers, specify
the process name ‘LeaveRoom’ on the Exited property. Next, we will determine the logic for that process, as well as the ‘GetRoom’
214process
/ 815
the process name ‘LeaveRoom’ on the Exited property. Next, we will determine the logic for that process, as well as the ‘GetRoom’ process
specified in the WaitingArea process task.
GetRoom and LeaveRoom Processes Logic
Within the Facility window, place a Resource object with the Name ‘Room1’. This room object will be used to control the number of entities
(patients) that are allowed to have the room reserved/cleaned or be in the room at any given time.
Within the Processes window, create two processes. The first process has a Name of ‘GetRoom’ and should contain a single Seize step that
seizes the Object Name ‘Room1’ resource. This is done, as noted above, within the first task of the WaitingArea, before the nurse worker
is moved to the room for cleaning.
The second process has a Name of ‘LeaveRoom’ and should contain a single Release step that releases the Object Name ‘Room1’
resource. This release is performed once the processing time at the Exam1 server is complete and the entity is exiting the server.
Model 2: TaskSequenceAndWorker_InTable
Problem:
I would like to perform a number of concurrent tasks at a Server with a worker, including having the worker move to another location, perform a
task then move back to my location. The information about the tasks should be specified in a table so that it is easily editable and/or imported
from an external data file.
Categories:
Add-On Process Logic, Data Tables, Decision Logic – Processing, MultiTask Server, Path, People, Resources, Worker
Key Concepts:
Add-On Process, Bidirectional Path, Data Table, DestinationNode, Enumeration Property, Keep Reserved If, Node Property, Object Reference
Property, Process Element Reference Property, Release Step, Request Move, Resource, Seize Step, Server, Set Referenced Property String
Property, Task Sequence, Table Sequence Property, TransferNode, Worker
Assumption:
We will be reserving the Worker within the Server’s processing tasks for each task and then again for the transport task from one Server to the
next. It is assumed that the object ride capacity is ‘1’ when using reserved workers/vehicles.
Technical Approach:
There are multiple tasks that occur within the waiting area of the model, including seizing a room resource, seizing the nurse worker to go and
clean the room, then moving the nurse to the patient location. The ‘Keep Reserved If’ options are set to ‘True’ so that the same nurse performs
the various operations, as well as is reserved for transporting the entity patient to the Exam Server. All tasks that occur within the waiting room
are specified using the Task Sequence option however, all property values are specified directly within a data table.
Details for Building the Model:
Simple System Setup
Same as Model 1 above.
Defining the Worker (Nurse)
Same as Model 1 above.
Entity Arrivals
Same as Model 1 above.
Data Tables and Process Task Properties
Within the Data window, add a new Data Table to the model. C hange the Name of the table to ‘ActivityTasks’. Include the following column
types/names:
Sequence Number property (Standard Property) – Name is ‘TaskSequenceNumber’
String property (Standard Property) – Name is ‘TaskName’
Enumeration property (Standard Property) – Name is ‘ProcessType’ (Enum Type is ‘TaskProcessType’)
Expression property (Standard Property) – Name is ‘ProcessingTime’ (Unit Type is ‘Time’ and Default Units are ‘Minutes’)
Process Element property (Element Reference) – Name is ‘ProcessName’
Object property (Object Reference) – Name is ‘ObjectName’
Enumeration property (Standard Property) – Name is ‘RequestMove’ (Enum Type is ‘SeizeReqeustVisitType’)
Node property (Object Reference) – Name is ‘DestinationNode’
Each row in the table will then represent a unique processing task. Since there will be three processing tasks, there should be three rows,
including the following data:
Task Sequence Number ‘10’, Task Name ‘ReserveRoom’, Process Type ‘Process Name’, Processing Time ‘0’, Process Name
‘GetRoom’, Object Name *blank*, Request Move ‘None’ and Destination Node *blank*
Task Sequence Number ‘20’, Task Name ‘SendNurseToRoomAndC lean, Process Type ‘Specific Time’, Processing Time
‘Random.Triangular(.5,1,1.5)’, Process Name *blank*, Object Name ‘Nurse’, Request Move ‘ToNode’ and Destination Node
‘Input@Exam1’
Task Sequence Number ‘30’, Task Name ‘BringBackNurse’, Process Type ‘Specific Time’, Processing Time ‘0’, Process Name
*blank*, Object Name ‘Nurse’, Request Move ‘ToNode’ and Destination Node ‘Output@WaitingArea’
IMPORTANT NOTE: When using Table Data for entry into a repeating group of properties, you must have a column for each property that
MAY be changed in a given entry / process task – if the property remains as the default value for all entries, it is not necessary to have a
column feed-in (i.e., the Selection Goal for the Resource Requirement).
Waiting Area Logic
Within the WaitingArea server, change the Initial C apacity to 10. This will allow 10 entities to be waiting in the area in a graphical queue to
perform the various tasks specified.
C hange the Process Type to ‘Task Sequence’ and enter the Processing Tasks repeating properties dialog. The task data will come directly
from the particular table generated in the above step.
Set the Sequence Number to ‘ActivityTasks.TaskSequenceNumber’
215 / 815
Set the Name to ‘ActivityTasks.TaskName’
Set the Process Type to ‘ActivityTasks.ProcessType’
Set the Processing Time to ‘ActivityTasks.TaskProcessingTime’
Set the Process Name to ‘ActivityTasks.ProcessName’
Set the Object Name to ‘ActivityTasks.ObjectName’
Set the Request Move to ‘ActivityTasks.RequestMove’
Set the Destination Node to ‘ActivityTasks.DestinationNode’
Then close the Processing Tasks repeating property editor.
Within the Processing Tasks property field, type in ‘ActivityTasks’ which is the name of the table. This is important for the repeating editor
to know the table reference where all internal data is stored.
Within the WaitingArea output node, change the Entity Destination Type to ‘Specific’ and the Node Name to ‘Input@Exam1’. It is important
to specify the entity destination when a network of nodes will be passed to that the entity continues to its correct destination. C hange the
Ride On Transporter to ‘True’ and the Transporter Name to ‘Nurse’. Note that the Keep Reserved If property is blank, meaning we will not
reserve the nurse for processing in the exam room, although if the nurse was needed for that processing, this should be set to ‘True’.
Exam Logic
Same as Model 1 above.
GetRoom and LeaveRoom Processes Logic
Same as Model 1 above.
216 / 815
Simio Reference Guide
T ransferLine - SimBit
Problem:
You have a transfer line that has a single conveyor with multiple workstations.All parts on the conveyor move together. None can move unless all
are ready.
Categories:
Add-On Process Logic, C onveyor Systems
Key Concepts:
Accumulating, Add-On Process, BasicNode, C onveyor, DesiredSpeed, On Entered, Real State Variable, TransferNode
Assumptions:
Entities will move synchronously and all are aligned at the designated stopping locations (either workstation or intermediate location) together.
Technical Approach:
Use multiple non-accumulating conveyors. Use nodes with add-on processes to delay for the operations and coordinate the conveyor segments.
Details for Building the Model:
Simple System Setup
Place a Source and Sink object in the Facility Window.
Place 3 BasicNodes and 1 TransferNode in the middle of the Source and Sink objects. C onnect the Source to the first BasicNode with a
Path, as well as the TransferNode to the Sink with a Path.
Use 3 C onveyors to connect the three BasicNodes together, as this will represent our workstations that move synchronously.
Defining System States
C lick on the Definitions tab and select the States panel. Add a Discrete State with the Name ‘NumberStationsWorking’ that represents how
many stations have operations in progress that would prevent the line from moving.
Using Add-On Process Triggers
On the two internal nodes representing the workstations, in the Entered trigger for add-on processes, add the process named
‘TransferLineNode_Entered’. Open the Processes Window and define the logic for this process.
Add an Assign step that increases the State Variable Name ‘NumberStationsWorking’ to ‘NumberStationsWorking + 1’ to indicate that this
operation is in-process. In the same Assign step, assign the ‘C onveyor*.DesiredSpeed’ of each conveyor to 0.
Use a Delay step for the processing time at that workstation (if you needed processing resources you would seize before the delay and
release after the delay).
Add another Assign step to decrement ‘NumberStationsWorking’ to indicate that this operation is complete.
Use the Decide step to determine if all other operations are done (‘NumberStationsWorking == 0’) and if all other operations are done,
restore the ‘C onveyor*.DesiredSpeed’ of each conveyor using an Assign step.
217 / 815
Simio Reference Guide
T ransporterListForVehiclesO nDifferentSchedules - SimBit
Problem:
I require vehicles to transport my entities and there are vehicles that follow different work schedules. I would like to select whichever vehicle is
currently On Shift. If more than one vehicle is On Shift, I will select whichever is closest to the entity that requires a ride.
Categories:
Schedules / C hangeovers, Vehicles
Key concepts:
Entity Destination Type, Initial Node (Home), On Shift, Ride On Transporter, Schedules, TransporterList, Transporters, WorkSchedule
Technical Approach:
The entity needs a ride on a Transporter to get from Server1 to Sink1. There are two possible Vehicles; one follows a standard day shift and the
other is on second shift, which begins at 3:00pm. A Transporter List is used so the entity selects whichever Vehicle is available at the time.
Details for Building the Model:
C reating Vehicle Schedules
Go to the Schedules window by selecting Schedules along the left panel from within the Definitions window.
C lick on the Day Patterns tab and change the Name of the Day Pattern to ‘StandardFirstShift’. Keep the contents of the Day Pattern with
the default 8am-12pm (1) and 1pm-5pm (1).
C reate a second Day Pattern by starting to type in the next row of the Day Pattern table. Name this new Day Pattern
’StandardSecondShift’.
C lick onto the ‘+’ next to this new Day Pattern to enter the times for this new shift.
C reate a row where the Start Time is ‘3:00 PM’ and the End Time is ‘7:00 PM’. The Value should be ‘1’.
C reate another row where Start Time is ‘8:00 PM’ and the End Time is ’12:00 AM’. The Value should be ‘1’.
C lick back onto the Work Schedules tab. C hange the Name of the default Work Schedule listed to ‘FirstShiftWeek’. Set the Days column to
‘1’ so that this schedule will repeat the same daily schedule for the duration of the simulation. Set the Day1 column to ‘StandardFirstShift’.
C reate a new Work Schedule by creating another row in the table. Name the new Work Schedule ‘SecondShiftWeek’. Set the Days column
to ‘1’ and the Day1 column to ‘StandardSecondShift’.
Simple System Setup
Place a Source, Server and Sink object in the Facility window. Place a TransferNode between the Server and Sink. C onnect the Source to
the Server with a Path. C onnect the Server to the Sink, then the Sink to the TransferNode, and the TransferNode back to the Server with
Paths. This should form a circle so that traffic will travel in one direction from the Server to Sink to TransferNode and back to the Server.
In the Source, set the Interarrival Time property to ‘Random.Exponential(4)’ minutes.
Set the Processing Time of the Server object to ‘Random.Triangular(3,4,5)’ minutes.
Place two Vehicle objects and change the Name properties to ‘FirstShift’ and ‘SecondShift’.
Set the Initial Node (Home) property of both Vehicles to the name of the TransferNode that was placed. Set the Idle Action and the
OffShift Action to ‘ParkAtHome’.
Set the Initial Desired Speed of each Vehicle to ‘.1’ Meter per Second.
Set the Capacity Type of each Vehicle to ‘WorkSchedule’ and set the FirstShift vehicle’s Work Schedule property to ‘FirstShiftWeek’
and the SecondShift vehicle’s Work Schedule property to ‘SecondShiftWeek’.
Defining the Vehicle List
Go to the Lists window by selecting Lists along the left panel from within the Definitions window.
C lick on the Transporter in the ListData ribbon to create a new Transporter List. Add the names of two vehicles that were placed into the
model.
Selecting the Vehicle From the List
Within the Facility window, click onto the Output@Server1 node. Set the Entity Destination Type to ‘Specific’ and the Node Name property
to ‘Input@Sink1’. This will ensure that the entity is dropped off at the Sink and that it will not return back to the Server. Set the Ride On
Transporter property to ‘True’. Set the Transporter Type property to ‘Select From List’ and set the Transporter List Name to the name of
the Transporter List that was created.
Testing the Model
Run the model beginning at 1:00pm. At this point in time, the First Shift vehicle is available. At 3pm, the Second Shift vehicle will come On
Shift and they are both available until 5pm, which is when the First Shift vehicle is no longer available.
218 / 815
Simio Reference Guide
T ravelW ithSteeringBehavior - SimBit
Problem:
Demonstrate more flexible modeling of entity movement in free space. This uses Travel step to illustrate various options. These features are
generally used when you want to show more realistic movement of pedestrians and people. These concepts are often used in agent-based
modeling.
Categories:
People, Add-on Process Logic, Path
Key Concepts:
SteeringRule, Pedestrian, People, Agent, Transfer Step
Assumptions:
We are modeling with the Standard Library but would like to use process logic to attain additional realism in modeling people movement.
Technical Approach:
The Steering Behavior options on the Travel step only work in Free Space. We will supplement the Standard Library objects with process logic that
will Transfer the entity into free space, initiate realistic movement with the Travel step, then Transfer the entity onto its target destination. We will
repeat this process with three different configurations to illustrate optional ways of using the Travel Step:
A - Using a simple path (a line) and specify on the Travel step the width of the travel path (e.g. how far from the line) in which entity can
travel.
B - Follow along a network (but still in free space) and use the defined width of each path to constrain the entity travel.
C - Enhance option B using a rule to have entities avoid colliding with each other.
Details for Building the Model:
Option A Setup
Place a Source (SourceA), two BasicNodes (BasicNodeA1 and BasicNodeA2), and a Sink (SinkA) in the Facility window. C onnect with Paths.
Place a ModelEntity object (DefaultEntity) and change its Initial Network to ‘No Network (Free Space)’ so that all movements will be made
in Free Space, instead of on the network.
C hange Interarrival Time of SourceA to ‘Random.Exponential(.03)’.
In the Processes Window, C reate Process and name ‘OutputSourceA_Exited’.
Add a Transfer Step with From set to ‘C urrentNode’ and To set to ‘FreeSpace’.
On the OK branch add a Travel step with Steering Behavior set to ‘Follow Network Path’. This indicates that even though the entity is now in
free space (not on the network), we want to use the drawn network paths to guide its movement.
Also on the Travel step:
Set Starting Node to ‘Output@SourceA’ to tell the entity where on the network to start.
Set Ending Node to ‘Input@SinkA’ to tell the entity where on the network to end.
Set Path Width to ‘4’ meters to let the entity travel 2 meters to either side of the line.
Add a second Transfer Step to the end of the process with From set to ‘FreeSpace’, To set to ‘Node’, and Node Name set to ‘Input@SinkA’.
Moving back to the Facility window, click on the output node of the source (Output@SourceA) and in the Add-On Process Triggers C ategory
set Exited to ‘Output_SourceA_Exited’.
At this point you should be able to run the model. You will see that instead of following the line exactly that entities will stray within the 4 meters
surrounding the line. But it will still get its direction from the network almost as though it is really on the network. But it is not on the network (it is
in free space) so it will not respect any of the options specified on the paths.
Option B Setup
Execute all of the steps in Option A with the following changes:
Wherever an ‘A’ appears in a name make it a ‘B’.
For the three paths, change the path Width (under the General category > Physical C haracteristics > Size) to ‘6’, ‘3’, and ‘2’ respectively.
You can also set the color of the Paths using the C olor button on the Drawing ribbon.
On the Travel step:
Leave Path Width set to its default of ‘C andidate.Link.Size.Width’ which lets the entity react to the width of the path it is traveling on.
Set Update Time Interval to ‘0.3’ to indicate your sensitivity to it straying off the path. You can experiment with this number. A
smaller number will provide better animation performance, but it will do so at the cost of execution speed.
Option C Setup
Execute all of the steps in Option B with the following changes:
Wherever an ‘B’ appears in a name make it a ‘C ’.
On the Travel step:
Set Avoid Collisions to ‘True’ to indicate that you want the entities to try to avoid colliding with each other.
You should now be able to run the model and see how the three sets of options compare to each other. You can adjust the various parameters to
customize the performance.
Embellishments:
The Steering Rules for the Travel step are implemented in user code. More advanced users can use the example C # code found in the
Examples\UserExtensions folder to implement their own, more complex or customized rules. An alternate approach to using the Travel step in
processes in the way illustrated above is to instead customize the process logic included in the ModelEntity definition.
Problem:
I would like to explore the different options that are available for an entity turnaround method on a network.
Categories:
Entity C haracteristics
Key Concepts:
Deadlock, Network Turnaround Method
Technical Approach:
We set up three options each with a source, three bidirectional paths and 2 transfer nodes.
Details for Building the Model:
Simple System Setup
For each option, place a Source and two TransferNodes in parallel. C hange the Maximum Arrivals property on each Source to ‘1’. This
allows you to see the movement of a single entity at a node as it transfers between links.
Use three bidirectional paths to link each node to the Source and to link the two nodes.
Place three ModelEntities (Exit_Entity, Rotate_Entity & Reverse Entity) and assign each one to a Source by setting the Entity Type in the
Source Arrival Logic to the corresponding entity name.
The Exit_Entity Network Turnaround Method will keep its default value, ‘Exit & Re-enter’.
Set the Rotate_Entity Network Turnaround Method to ‘Rotate In Place’.
Set the Reverse_Entity Network Turnaround Method to ‘Reverse’.
Discussion:
Exit_Entity:
This entity will 'Exit & Re-enter' a node when it is changing directions on a bidirectional link. This is the default setting for entities, workers and
vehicles. The entity actually exits the link, and re-enters it as it turns around. This method is the most deadlock avoidance friendly option.
Rotate_Entity:
This entity will 'Rotate in Place' at a node when it is changing directions on a bidirectional link. The entity never exits the link, but simply rotates
and continues on the same link in the opposite direction. This method could cause deadlocks.
Reverse_Entity:
This entity will 'Reverse' its animation symbol at a node when it is changing directions on a bidirectional link. The entity never actually leaves the
link when changing directions, it simply goes in a reverse direction (tail first). This allows for modeling such things as elevators.
221 / 815
Simio Reference Guide
UpdateStateInModelFromO bject - SimBit
Problem:
I have a user-created object in my model and want to update a state variable in the main model from within that object. ** NOTE: This is an
extension of the SimBit ‘ProcessModelWithinModel.spfx’.
Categories:
Building New Objects / Hierarchy
Key Concepts:
BasicNode, C ontinueProcess, Delay Step, EndTransfer Step, Expression Property, ExternalNode, Object Instance Property, ProcessStation,
Release Step, Resource, Seize Step, Station Element, Submodel, Transfer Step, State Property
Assumptions:
The SimBit ‘ProcessModelWithinModel.spfx’ is used as a baseline for this example. The steps show how to add a state property reference to an
object so that a state in the main model can be appropriately updated.
Technical Approach:
A state type property will be utilized within the user-created object. Once the object is placed in a model, the property will then reference the
state defined within the model.
Details for Building the Model:
ProcessModelWithinModel.spfx
Open the SimBit ‘ProcessModelWithinModel.spfx and review the corresponding *.pdf file for logic details.
Defining a State-Type Property
Within the Navigation bar, click on thte SeizeDelayRelease object.
Go to the Definitions window, Properties panel to add a new property to the object. This is done by selecting Standard Property and then
clicking on State within the pull-down list.
Rename the state ‘WhichState’ and change the Category Name to ‘Properties’ so that it appears in the same area with the ResourceName
and DelayTime properties for the object.
Assigning the State within the SeizeDelayRelease Object
C lick on the Processes window of the SeizeDelayRelease object. After the Seize step, add an Assign step.
Within the Assign step, right click on the State Variable Name property, select ‘Set Referenced Property’ and click on ‘WhichState’. This will
cause ‘WhichState’ to be placed in the property field with a green arrow, indicating a reference from an object property.
Within the New Value field, enter the value ‘WhichState + 1’. This will cause each token going through this process to increase the
associated state by 1.
Defining the State within the Model
Within the Navigation window, click on the Model and go to the Definitions tab, States panel.
Add a new Integer type State and change the Name to ‘Model_C ount’.
Within the Facility window of the model, add an animated status label of this state by going to the Animation ribbon, selecting and placing a
Status Label and entering the Expression ‘Model_C ount’.
Defining Which State to Reference within the Object
C lick on the SeizeDelayRelease object within the Model’s Facility Window.
Notice in the Properties window, under the category Properties, there is a new property called WhichState, which you will specify as
‘Model_C ount’.
222 / 815
Simio Reference Guide
UserDefinedListState - SimBit
Problem:
I would like to create my own, custom List State that will produce time persistent statistics on each value that is assigned to the state.
Categories:
Buffering, C ustom Statistics, Discrete States
Key Concepts:
Before Exiting, Buffer C apacity, List State, Math.If(), On Entering, State Assignments, Status Pie, StringList
Technical Approach:
We set up a system that has two servers in series (Server1 and Server2), which are in parallel with two other servers (Server3 and Server4) in
series. We would like statistics on when either Server1 or Server2 are busy and statistics on when either Server3 or Server4 is busy. In other
words, we’d like to know when the top line of servers is busy and when the bottom line of servers is busy. By creating a custom ListState for
Line1 (which includes Server1 and Server2) and a custom ListState for Line2 (which includes Server3 and Server4), we will get statistics such as
the average amount of time spent in the Busy state and the number of occurrences that each Line was in the Busy state.
Details for Building the Model:
Simple System Setup
Place a Source and a Sink object in the Facility window
In between these two objects, place 4 Server objects. Set the Input Buffer Capacity and the Output Buffer Capacity to ‘0’ for all 4 servers
so that we do not have any buffering in the system. Server1 and Server2 are in series so therefore connect the Source to Server1 with a
Path, connect Server1 to Server2 with a C onnector and connect Server2 to the Sink with a Path.
Server3 and Server4 are in series so therefore connect the Source to Server3 with a Path, connect Server3 to Server4 with a C onnector
and connect Server4 to the Sink with a Path.
C reate the two List States:
From the Definitions window, go to the States panel. C reate new List State by clicking on ‘List’ in the States ribbon. Name this new state
‘Line1ListState’. C reate another new ListState and name is ‘Line2ListState’.
Leave the States Panel and go to the Lists panel (found on the left side of the interface). C reate a new String List by clicking on ‘String’ in
the ribbon menu. Name this new List ‘Line1’. Enter the word ‘Idle’ into the first row of the List and the word ‘Busy’ into the second row of
the List.
C reate another String List by clicking on ‘String’ in the ribbon menu. Name this new List, ‘Line2’. Enter the word ‘Idle’ into the first row of
the List and the word ‘Busy’ into the second row of the List.
Go back to the States panel where you created the List States and select Line1ListState. In the properties window of this State, set the
String List Name property to ‘Line1’ and set the Initial State Value property to ‘Idle’.
Select Line2ListState. In the properties window of this State, set the String List Name property to ‘Line2’ and set the Initial State Value
property to ‘Idle’.
Assign Values to List States:
Go back to the Facility window where we’ll assign values to our new List States. Select the first Server in the top series (Server1) and
expand the State Assignments property category in the properties window. C lick on the ellipse (the … button) in the On Entering property
and when the On Entering Repeating Property Editor window appears, click Add. Set the State Variable Name to ‘Line1ListState’ and the
New Value to ‘1’. Assigning a value of 1 to this List State is equivalent to setting it to the list value of ‘Busy’ (the List is 0-indexed so Idle =0
and Busy = 1).
C lick on the second Server in the top series (Server2) and expand the State Assignments property category in the properties window.
C lick on the ellipse (the … button) in the On Exiting property and when the On Entering Repeating Property Editor window appears, click
Add. Set the State Variable Name to ‘Line1ListState’ and the New Value to ‘Math.If(Server1.Processing.C ontents>0, 1, 0)’. This Math.If
statement says that if there is an entity being processed at Server1, then keep the value of the Line1ListState at ‘1’. If not, then set it to
‘0’, which is Idle.
Select the first Server in the bottom series (Server3) and expand the State Assignments property category in the properties window. C lick
on the ellipse (the … button) in the On Entering property and when the On Entering Repeating Property Editor window appears, click Add.
Set the State Variable Name to ‘Line2ListState’ and the New Value to ‘1’.
C lick on the second Server in the bottom series (Server4) and expand the State Assignments property category in the properties window.
C lick on the ellipse (the … button) in the On Exiting property and when the On Entering Repeating Property Editor window appears, click
Add. Set the State Variable Name to ‘Line2ListState’ and the New Value to ‘Math.If(Server2.Processing.C ontents>0, 1, 0)’. This Math.If
statement says that if there is an entity being processed at Server2, then keep the value of the Line2ListState at ‘1’. If not, then set it to
‘0’, which is Idle.
Place two Status Pie charts from the Animation ribbon into the Facility window. Set the Data Type property of the Status Pie to ‘List State’
and the List State property to ‘Line1ListState’ (and ‘Line2ListState’ for the second chart).
Embellishments:
C onsider adding additional values to each List and then assigning the appropriate index into the ListState to see that a ListState can contain more
than just the two values (0 and 1) that this SimBit demonstrated.
Discussion:
The statistics for these new ListStates are displayed in the Results window after the run is complete. For each ListState, there are statistics for
Average Time, Total Time, Percent Time and Number of Occurences for each State Value (i.e. Busy, Idle in our example).
Most of the Simio Standard Library objects contain a built in ListState, called ResourceState, which is automatically updated with values such as
“Busy”, “Idle”, “OffShift”, etc.
There are functions available for a ListState, such as MyListState.AverageTime(stateValue), MyListState.TotalTime(stateValue),
MyListState.PercentTime(stateValue), MyListState.NumberOccurences(stateValue)
223 / 815
Simio Reference Guide
UsingAddR owandO utputT able_Enterprise - SimBit
Problem:
I want to be able to write entity specific output information to an output data table at the end of the simulation run. *Enterprise edition only*
Categories:
Data Tables, Enterprise
Key Concepts:
Add-On Process, Assign Step, AddRow Step, Data Table, Real State Variable, Run.TimeNow, State Assignments, String State Variable, Maximum
Arrivals
Assumptions:
All data is added to the output table when the entity is about to leave the system. Both functions and state variable information is used to write
the appropriate state information to the output table.
Technical Approach:
An output data table is utilized to write out information regarding an entity to a table at the end of the simulation run. The AddRow step is used to
add a new row to the table with each entity leaving the system, while the Assign step will assign values to the various columns in the table for
that given entity instance.
Details for Building the Model:
Simple System Setup
Place a Source, two Servers and a Sink in the Facility window. Use paths to connect the Source to each of the Servers, and each of the
Servers to the Sink.
Place a ModelEntity from the Project Library in the Facility window.
Within the Source, open the Stopping C onditions section and change the Maximum Arrivals property to ‘20’. C hange the Ending Type in the
Run Setup section of the Run ribbon to ‘1 hours’.
Defining an Entity State
Within the Navigation window, click on the ModelEntity. Go to the Definitions window, States panel and add a String state variable with the
Name ‘WhichServer’. This will be used to store (with the entity) which of the two servers it utilized. This state can be referenced as
ModelEntity.WhichServer.
Defining the Output Table
Open the Data window, select the Tables panel and add an Output Table.
Still within the Data window, click on the States ribbon to add several states to the output table. First, add a Real state variable and change
the Name to ‘TimeEntered’. This will store the simulation time that the entity entered the system.
Then, add a String state variable with the Name ‘EntityName’. This will store the entity name, such as DefaultEntity.94.
The next column added should be another Real state variable with the Name ‘TimeLeaving’ that will store the simulation time that the
entity finished in the system.
Finally, add another String state variable with the Name ‘ServerName’ that will indicate which of the two Servers through which the entity
was processed.
Adding a Row to an Output Table During the Run
Because output tables are tables with no data at the start of the simulation run, data must be added during the run through the use of
object states. To add a row to an output table, the AddRow step is used.
Within the Navigation window, go back to the Model. In the Facility window, within the input node of the Sink (Input@Sink1), double click
directly on the Entered add on process trigger so that it automatically creates a process within the Processes window named
‘Input_Sink1_Entered’. This should reference the process from within the input node, as well as place you within the Processes window to
begin defining the process.
Within the process, add an AddRow step with a Table Name of ‘OutputTable1’. Each time an entity goes through the Sink, a new row will be
added to the output table.
Next, add an Assign step and make the following assignments to the states in the table:
State Variable Name – ‘OutputTable1.TimeEntered’, New Value – ‘ModelEntity.TimeC reated’
State Variable Name – ‘OutputTable1.EntityName’, New Value – ‘ModelEntity.Name’
State Variable Name – ‘OutputTable1.TimeLeaving’, New Value – ‘Run.TimeNow’
State Variable Name – ‘OutputTable1.ServerName’, New Value – ‘ModelEntity.WhichServer’
Assigning the ModelEntity.WhichServer Value
Within Server1, under the State Assignments section of properties, click on On Entering to enter an assignment through the repeating
property editor. Assign the State Variable Name ‘ModelEntity.WhichServer’ to the New Value of ‘Server1.Name’.
Within Server2, do the same thing, except assign the State Variable Name ‘ModelEntity.WhichServer’ to the New Value of ‘Server2.Name’.
Running the Model
You will notice that the output table, while it has column headers, does not include any data. Once the simulation has been run, the output
table will be filled with data upon clicking the Stop button.
224 / 815
Simio Reference Guide
UsingaMonitor - SimBit
Problem:
I have is a simple model with a source, server and sink and would like to know at what point in time during the simulation run the queue for the
server exceeds 9 for the first time.
Categories:
Add-On Process Logic, C ustom Statistics
Key Concepts:
Add-On Process, C ontents, C rossingStateC hange, Event, InputBuffer, Monitor, On Entered, Process Triggering Event, Real State Variable,
Stopping C ondition, TimeNow
Assumptions:
Since the time is the only information desired, the simulation stops running after the queue reaches 9 for the first time.
Technical Approach:
A state variable is updated with the number of entities in the server queue each time a new entity enters the server. A Monitor element is used to
track this state variable and trigger an event when the state variable goes over the value of 9. The triggering of this event executes a process
that updates another variable with the current simulation time and the simulation stops. The variable with the simulation time is displayed in the
Results Window as a State Statistic.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink in the Facility Window. Update the Processing Time property of the Server to be
‘Random.Triangular(.2,.3,.5)’ so that the Server has some queuing.
C onnect the Source and Server, as well as the Server and Sink with Paths.
C reating Discrete State Variables
C lick on the Definitions tab and select the States panel. C reate two discrete state variables, one called ‘NumberInQueue’ and the other
called ‘TimeWhenOver9’.
Using an Add-On Process Trigger
Within the Server object, create an Add-On Process by double-clicking on Entered. This will take you to the Processes Window. In this
process, add an Assign step that assigns the State Variable Name ‘NumberInQueue’ to the New Value of ‘Server1.InputBuffer.C ontents’.
(Note: this is a function that returns the number in the inputbuffer queue for this Server).
C reating and Using a Monitor
Select the Elements Panel within the Definitions tab to add a Monitor element with its Name as ‘Monitor_Over9’. The Monitor Type property
should be changed to ‘C rossingStateC hange’. The State Variable Name that it is monitoring should be set to ‘NumberInQueue’ and the
Threshold Value is ‘9’.
Adding a New Process
C reate a new process using the C reate Process icon in Processes Window. Set the Triggering Event property for the process to the name
of the Monitor you just created, followed by .Event, ‘Monitor_Over9.Event’.
Place an Assign step in this new process and have that Assign step update the State Variable Name ‘TimeWhenOver9’ to the current
simulation time, using with the function ‘Run.TimeNow’ as the New Value.
Stopping the Simulation Run
C lick on the Definitions Window and select the Elements panel to create a new State Statistic.
Set the State Variable Name to ‘TimeWhenOver9’ and the Stopping Condition to ‘TimeWhenOver9 > 0’. This will stop the simulation run
once this threshold is met for the first time.
225 / 815
Simio Reference Guide
UsingAStorageQ ueue - SimBit
Problem:
I would like entities to wait in a queue and then I’d like to search the queue for a particular entity and remove it from the queue.
Categories:
Add-On Process Logic, C ombining and Separating Entities
Key Concepts:
Add-On Process, Allow Passing, Assign Step, Batch Step, BatchLogic Element, C andidate, Decide Step, Detached Queue, Entities Per Arrival,
Insert Step, ModelEntity, Movement.X, Node, NodeList, On Entered, AssociatedStationLoad, Random Symbol, Real State Variable, Remove Step,
Route Step, RoutingGroup Element, Search Step, Selection Goal, SetNode Step, SmallestValue, Storage Element, Storage Queue, Time Offset,
TimeC reated, UnBatch Step
Technical Approach:
Entities arrive in pairs by the Source creating two entities per arrival and batching them together. When the pair reaches the first node, they are
un-batched. One entity is routed to an available Server and the other entity is put into a Storage queue, where it sits until its partner has finished
processing. In order to match up the entities again, we search the Storage queue for an entity that has the exact same “TimeC reated” stamp on
it, which indicates that these two entities were originally paired together upon creation. Once the correct entity is found in the queue, it is
removed and batched with its partner, before traveling to the Sink.
Details for Building the Model:
Simple System Setup
Place a Source, a Sink and one TransferNode into the Facility window. Place the TransferNode so that it is in between the Source and the
Sink. C onnect the Source to the TransferNode with a Path and connect the TransferNode to the Sink with a Path.
C lick on the Source, and set the Time Offset property to ‘.1’ and set the Entities Per Arrival to ‘2’.
In both Paths, set the Allow Passing property to “False” so that we are able to see the entities traveling one by one on the paths.
Place three Servers into the Facility window. Set the Initial Capacity property of each Server to ‘2’.
Draw a Path from the TransferNode to the Input Node of each Server. Draw a Path from the Output Node of each Server back to the
TransferNode – for a total of 6 new paths.
Animating the Entity as People:
We animate the entities as different people so it is easier to see the different partners splitting and pairing back together. Drag the
ModelEntity object from the Project Library on the bottom left into the Facility window.
Select the new DefaultEntity within the window. Select a symbol of a person from the Symbols dropdown in the Ribbon. The entity should
change from a green triangle to the person that was selected.
With the DefaultEntity selected, click on the Add Additional Symbol button in the Ribbon. The Active Symbol button in the Ribbon should
now show (2 of 2) because there are now two symbols associated with DefaultEntity. You can change the hair color, skin color or clothing
color of the person symbol by clicking on C olor in the Ribbon and then clicking on the specific part of the person symbol.
Keep adding additional symbols and altering their colors, in order to provide variety to the entities traveling in the model.
With the DefaultEntity selected, change the Random Symbol property, in the properties window, to ‘True’. This will tell Simio to randomly
select a symbol from the multiple symbols you’ve created for DefaultEntity.
C reate Elements – Storage, Batch Logic and Routing Group:
From within the Definitions window, click on the Elements panel and add a Storage element by clicking on the Storage button in the
Ribbon. Rename it ‘WaitingArea’
Add a Batch Logic element by clicking on the Batch Logic button in the Ribbon. The default property values are fine.
C lick on the Lists panel within the Definitions window and create a Node list by clicking on the Node button in the Ribbon. Enter
Input@Server1, Input@Server2, Input@Server3 as the nodes within the List. (In order to add a new row to the list, click outside of the list
or hit Tab)
Back in the Elements panel, add a Routing Group element by clicking on the Routing Group button in the Ribbon. In the Node List Name
property, select the node list that you just created.
C reate new State Variables:
Add a State to the ModelEntity that will tracked when it has finished processing at a Server. C lick on the ModelEntity within the Navigation
window (top right). Once the ModelEntity is highlighted (you are within the ModelEntity model), click on the Definitions window. C lick on the
States panel and click on Discrete State in the ribbon, to add a new State to the ModelEntity. Rename it ‘Processed’.
Add a State to the main Model that will help us keep track of which entity will be the Parent and which will be the Member. With the Model
selected in the Navigation window, go to the Definitions window and click on the States panel. Add a new Discrete State named
‘TrackBatching’. Set the Initial State Value property to ‘1’. Also, add a state named ‘WhichOne’ which will store the associated token found
in the Search step so that we can Remove the correct entity from the Storage queue.
Add Processing Logic:
From within the Processes window of the main Model, create a new process by clicking on the ‘C reate Process’ button in the Ribbon.
Place a Decide Step. Set the Decide Type property to ‘C onditionBased’ and set the Expression to ‘TrackBatching == 1’. This checks
to see if this is the first created entity and if so, it will become the parent.
In the True segment leaving the Decide Step, place an Assign Step. This step should set the TrackBatching state to the value of ‘2’.
After this Assign Step, place a Batch Step. Use the BatchLogic element created earlier and set the Category property to ‘Parent’.
In the False segment leaving the Decide Step, place a Batch Step. Use the BatchLogic element created earlier and set the Category
property to ‘Member’.
After this step, place an Assign Step. This step should set the TrackBatching state to the value of ‘1’, which indicates that this batch
is finished and a new batch will start.
In the Facility window, click on the Output Node of the Source object and select this new Process from the drop down of the Entered Add
On Process trigger. This will cause this new process to be triggered whenever an entity enters this output node.
While in the Facility window, click on the TransferNode and select ‘C reate New’ from the drop down of the Entered Add On Process trigger.
This will create a new process that will be triggered whenever an entity enters this node.
226 / 815
From within the Processes window, place a Decide Step within this new process. Set the Decide Type property to ‘C onditionBased’ and set
the Expression to ‘ModelEntity.Processed == 0’. This checks to see if the entity is just arriving to the node and it not yet processed or if the
entity is leaving the system and just finished processing at a Server.
In the True segment leaving the Decide step, place a Route step. Set the Routing Group Name property to the Routing Group
element that was created earlier. Set the Selection Goal to ‘Smallest Value’ and and the Selection Expression to
‘C andidate.Node.AssociatedStationLoad’. This step will set the destination node for the entity to one of the three possible Servers,
based on the number of entities currently en-route and processing at the various stations (AssociatedStationLoad).
After the Route Step, place an UnBatch step (the defaults are fine).
In the Member segment leaving the UnBatch Step, place an Insert Step. Set the Queue State Name property to
‘WaitingArea.Queue’, the storage queue created earlier.
After the Insert Step, place an Assign Step. Set ’ModelEntity.Movement.X’ to ‘1000’.
Back in the False segment of the first Decide Step, place a Search step. Set Collection Type to ‘QueueState’. Set Queue State Name
to ‘WaitingArea.Queue’. And set Match Condition to ‘ModelEntity.TimeC reated == C andidate.Entity.TimeC reated’. This searches the
Waiting Area queue and finds the entity that was originally created at the same time as this entity. C lick on the Advanced Options
within the Search step and specify the Save Index Found property as ‘WhichOne’ to save which token in the storage was found in
the Search.
In the Original segment leaving the Search step, place a Batch step. Use the BatchLogic element created earlier and set the
Category property to ‘Parent’.
After this step, place a SetNode step. Set Destination Type to ‘Specific’ and the Node Name to ‘Input@Exit’ (or Input@Sink). This will
route entities that have already been processed, out of the system and ensure that they do not follow a path back to the Servers.
In the Found segment of the Search step, place a Remove step. Set the Queue State Name to ‘WaitingArea.Queue’. Under
Advanced Options, set the Removal Type to ‘AtRankIndex’ and Rank Index to ‘WhichOne’. This will remove the partner entity from
the queue (after it’s been found by the Search step).
In the Removed segment of the Remove step, place a Batch step. Use the BatchLogic element created earlier and set the Category
property to ‘Member’. This will batch up this removed entity as a member to its parent partner that searched for it.
Animate the Waiting Area Storage Queue:
And finally, animate the Storage queue within the Facility window. C lick on the Detached Queue button from within the Animation ribbon. Draw the
queue within the Facility window. Set the Queue State within the properties window to ‘WaitingArea.Queue’.
See Also:
Help topics for Storage, Batch Logic, Routing Group, Insert Step, Remove Step, Search Step, Batch Step, Route Step, SetNode step.
227 / 815
Simio Reference Guide
UsingButtonsT oAffectSystem - SimBit
Problem:
I want to use external buttons to control the arrival rate of my system and to Stop/Start the conveyor within my system.
Categories:
Arrival Logic
Key Concepts:
Assign Step, Button, C onveyor, Decide Step, DesiredSpeed, Event, Math.Max(), Maximum, Process Triggering Event, Real State Variable
Assumptions:
The initial arrival rate is set to 0.5 (unit/minute), each time the arrival rate is increased/decreased, the rate changes (increases/decreases) 0.05
(unit/minute). The minimum arrival rate should be 0.05 (unit/minute), it means that when the arrival rate is 0.05 (unit/minute), it cannot be
decreased further. There is no upper limit for increasing the arrival rate.
The initial speed of the conveyor is set to 0.5 (meters/sec). To start the conveyor again when it’s stopped, the resume speed is set to be the
speed just before it’s stopped. We only control the Stop/Start for C onveyor1 which connects the Server to the Sink.
Technical Approach:
Four events will be created: StopC onveyor, StartC onveyor, IncreaseRate, DecreaseRate. Those four events will trigger four processes which will
implement corresponding actions. Also, we create four buttons by using Animation tool, each one of these buttons is logically connected to an
event which has the corresponding function with the Button.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink from the Standard Library into the Facility Window. C onnect them with C onveyors. C onveyor2 connects
Source and Server, C onveyor1 connects Server and Sink. Set the Desired Speed for both the C onveyors to .5.
C reating Discrete State Variables
Open the Definitions Window and select the States panel, add two Discrete State Variables with Names ‘Rate’ and ‘ResumeSpeed’.
‘Rate’ will track the arrival rate of the Source; its Initial State Value is ‘0.5’.
'ResumeSpeed’ will save the speed of C onveyor1 before it’s stopped, and resume it with the saved speed. Its Initial State Value is ‘0’.
Set the Interarrival Time of the Source to ‘1/Rate’.
C reating Events
Open the Definitions Window and select the Events panel.
C reate four events with names: StopC onveyor, StartC onveyor, IncreaseRate, DecreaseRate.
Generating Processes C orresponding to Events
Open the Processes Window; add four processes by clicking on the Create Processes ribbon.
Name the first process ‘Decrease’. Then go to the Properties Window, set the Triggering Event to ‘StartC onveyor’. Add an Assign step to
this process, within this Assign step, set the State Variable Name to ‘C onveyor1.DesiredSpeed’, the New Value is ‘ResumeSpeed’.
Name the second process ‘Increase’. Then go to the Properties Window, set the Triggering Event to ‘StopC onveyor’. Add two Assign steps
to this process. For the first Assign, set the State Variable Name to ‘ResumeSpeed’, the New Value is ‘C onveyor1.DesiredSpeed’. This step
will save the current speed of C onveyor1 to the state variable ‘ResumeSpeed’. For the second Assign, set the State Variable Name to
‘C onveyor1.DesiredSpeed’, the New Value is ‘0’. This will stop C onveyor1.
Name the third process ‘RateDown’. Then go to the Properties Window, set the Triggering Event to ‘DecreaseRate’. Add an Assign step to
this process. For this Assign, set the State Variable Name to ‘Rate’, the New Value is ‘Math.Max(.05, Rate-0.05)’.This will ensure that the
arrival rate will not be decreased below 0.05 (unit/minute).
Name the fourth process ‘RateUp’. Then go to the Properties Window, set the Triggering Event to ‘IncreaseRate’. Add an Assign step to this
process; then set the State Variable Name to ‘Rate’, the New Value is ‘Rate+.05’.
C reating Buttons
C lick on Animation ribbon under the Facility Tools, choose Button, and create four Buttons.
Put two of them near the Source. For the first Button, input ‘Increase Interarrival Rate’ for the Button Text, set the Event Name to
‘IncreaseRate’. For the second Button, input ‘Decrease Interarrival Rate’ for the Button Text, set the Event Name to ‘DecreaseRate’.
Put the other two Buttons near C onveyor1 (which connects Server and Sink). For the first Button, input ‘Stop C onveyor’ for the Button
Text, set the Event Name to ‘StopC onveyor’. For the second Button, input ‘Start C onveyor’ for the Button Text, set the Event Name to
‘StartC onveyor’.
Embellishments:
We can add some animation to show the current Arrival Rate of the Source while we’re running this model. C hoose Status Label from Animation,
Set the Expression to ‘Rate’.
228 / 815
Simio Reference Guide
UsingR elationalT ables - SimBit
Problem:
I have data that exists in different tables and the tables are linked together with foreign keys, as in a relational database. I would like an entity to
reference data from these tables.
Categories:
Data Tables
Key Concepts:
Arrival Table, Expression Property, Foreign Key, Key, ModelEntity, Numeric Property, Picture, Relational Table, Selection Weight, State
Assignments, String Property
Assumptions:
In order to easily witness that the entity is reading the correct information from the tables from within the Facility Window, only Red entities will
visit the TireService, Blue entities will visit the OilService and Green entities will visit the BrakeService.
Technical Approach:
Three Data Tables are created that are all linked together with foreign keys so that an entity can reference information from all three tables with
one simple SetRow step. The Source gets entity Arrival Times from the Arrivals table and each Workstation gets its Processing Time from the
ServiceTimes table. The entity’s color (symbol) is determined from the Picture table.
Details for Building the Model:
Simple System Setup
Add a Source, a Sink and three Workstations to the Facility Window. C onnect the Source to each of the Workstations and each Workstation
to the Sink with Paths. Also, drag a ModelEntity object into the window.
Setting up the Data Tables
To add data tables, click on the Data tab and select the Tables panel.
Add a Data Table named ‘Picture’ with the following Properties and in the following order:
(Integer) PictureIndex : 0, 1, 2
(String) C olor: Green, Red, Blue (Make this column the Primary Key to this table by clicking the Set C olumn as Key icon in the
ribbon.)
Add a Data Table named ‘ServiceTimes’ with the following Properties and in the following order:
(String) TypeOfService : Brakes, Oil, Tires (Make this column the Primary Key to this table by clicking the Set C olumn as Key icon
in the ribbon.)
(Expression) ServiceTime: Random.Triangular(1.5, 2, 2.5), 1 , Random.Triangular(.5, 1, 1.2)
(Foreign Key) C arC olor: Green, Blue, Red (To add this column, click the Foreign Key icon in the ribbon and then rename the
property to ‘C arC olor’. Set the TableKey property to ‘Picture.C olor’)
Add a Data Table named ‘Arrivals’ with the following Properties and in the following order:
(Real) ArrivalTime : 0, .25, .5, .75, 1 (Make this column the Primary Key to this table by clicking the Set C olumn as Key icon in the
ribbon. )
(Foreign Key) TypeOfService: Brakes, Tires, Oil, Oil, Tires (To add this column, click the Foreign Key icon in the ribbon and then
rename the property to ‘TypeOfService’. Set the TableKey property to ‘ServiceTimes.TypeOfService’)
C hanging Object Properties
In the Source:
C hange the Arrival Logic Arrival Mode property of the Source to ‘Arrival Table’ and the Arrival Time Property to ‘Arrivals.
ArrivalTime’.
C hange the Arrival Logic Maximum Arrivals to 5.
Within the State Assignments section, open the Before Exiting repeating property editor and assign the State Variable Name to
‘ModelEntity.Picture’ and the New Value to ‘Picture.PictureIndex’
In each Workstation:
C hange the Processing Time property to ‘ServiceTimes.ServiceTime’
Adding Additional Symbols
In the Facility Window, with the ModelEntity selected, click the Add Additional Symbol icon in the ribbon twice to add two additional symbols
for this object. Keep the color of symbol 0 as Green, change symbol 1 to Red and symbol 2 to Blue. For additional details on this process,
see the Adding Additional Symbols Help page.
Embellishments:
Try adding additional properties to the tables and referencing the information from within the model.
See Also:
EntityFollowsSequenceWithTable2.spf
229 / 815
Simio Reference Guide
VehicleFinishesAndP arksW henO ffShift - SimBit
Problem:
I want a Transporter to follow the same Work Schedule as a Server in my system. If the Server goes Off Shift when the Transporter is the middle
of traveling on a link, the Transporter should finish traveling to the end, park and stop working. When the Server goes back On Shift, the
Transporter will begin working where it left off.
Categories:
Vehicles
Key Concepts:
Add-On Process, Off Shift, On Off Shift, On On Shift, On Shift, Real State Variable, Ride on Transporter, Schedules, Vehicle, Wait Step, Fire Step
Assumptions:
The Vehicle and Server will follow the same WorkSchedule. If the vehicle goes Off Shift while transporting an entity, it will continue and drop off
the entity before parking. If the vehicle goes Off Shift while moving to pick up an entity, it will not perform the pickup until it is On Shift.
Technical Approach:
When a vehicle goes off shift, it will automatically drop off and/or pick up any entities that it is scheduled to drop off / pick up. Because we would
like our vehicle to stop at a node when it is off shift, we will use Add-On Process Logic at the node where it may pick up to ensure that the vehicle
stops until the off shift period has ended. This will be done with a Decide step condition and Wait / Fire steps.
Details for Building the Model:
Simple System Setup
Add a Source, a Server and a Sink to the Facility Window.
C onnect the objects together with Paths. Ensure that the Type property of the path from the Server to the Sink is set to ‘Bi-directional’ so
the vehicle can travel back and forth.
In order to slow down the entity arrival to best view the vehicle’s behavior, change the Interarrival Time of the Source object to
‘Random.Exponential(4)’ minutes.
Adding the Vehicle
Add a vehicle object from the Standard Library with the Name ‘Vehicle1’.
Select the Output Node of the Server and set the Ride On Transporter property to ‘True’, the Transporter Type to ‘Specific’ and then select
your Vehicle for the Transporter Name property.
In order to slow down the animation to best view the vehicle’s behavior, change the Desired Speed property of the Vehicle to ‘0.04’
(meters per second).
C hange the Initial Ride Capacity to ‘Infinity’ and set the Initial Node (Home) property of the Vehicle to ‘Output@Server1’.
C reating a Work Schedule
Go to the Data Window and click on the Schedules panel. C lick the Work Schedule icon in the Schedule ribbon to add a new Work
Schedule. C hange the Name to ‘Schedule1’ and set the Days to ‘1’.
Add a Day Pattern with the Name ‘DayPattern1’ to include the following entries: 8:00 AM – 8:15 AM, 8:30 AM – 8:45 AM and 9:00 AM –
12:00 PM. All of these rows should have the Value of ‘1’ indicating a capacity of one or on shift. The times when there aren’t any values
are assumed to be off shift.
Under Work Schedules, select ‘DayPattern1’ for day 1.
Adding the Schedule to the Server and Vehicle
In the Facility window, select the Server object and set the Capacity Type property to ‘WorkSchedule’. Select the work schedule that was
just created for the Work Schedule property.
Do the same for the Vehicle object. Under the Process Logic section of properties, change the Capacity Type to ‘WorkSchedule’ and add
the new work schedule that was created.
Adding Vehicle Off Shift Logic
Within the Definitions window, States panel, add a new Real state variable with the Name ‘OffShift’. We will assign this variable to ‘1’ when
the vehicle goes off shift and back to ‘0’ when on shift.
Within the Definitions window, Events panel, add a new event with the Name ‘Event1’. This will be used within the Wait/Fire steps placed
shortly.
Within the Facility window, highlight the Vehicle and add On Shift and Off Shift add-on processes, named ‘Vehicle1_OnShift’ and
‘Vehicle1_OffShift’, respectively.
Within the Processes window, ‘Vehicle1_OffShift’ process, add an Assign step and specify the State Variable Name ‘OffShift’ to the New
Value of ‘1’.
Within the Processes window, ‘Vehicle1_OnShift' process, add an Assign step and specify the State Variable Name ‘OffShift’ to the New
Value of ‘0’.
Within the Facility window, highlight the Vehicle and add Entered Node add-on processes, named ‘Vehicle1_EnteredNode’. Within this
process, we will evaluate if the vehicle is off shift and if so, will wait at the node.
Within the Vehicle1_EnteredNode process, place a Decide step. C hange the Decide Type to ‘C onditionBased’ and enter the Expression
‘OffShift==1&&Is.Vehicle&&Vehicle.NumberRiders==0’. From the True exit of the Decide, place a Wait step, with the Event Name of
‘Event1’. Looking at the condition specified, we are checking to see if the vehicle is off shift (OffShift==1) and the associated object is the
vehicle (Is.Vehicle) as opposed to the entity itself and the vehicle has no riders (Vehicle.NumberRiders==0), then the token must wait at
the node for Event1 to be fired. Thus, if the vehicle is off shift but has riders, the vehicle will not wait, but will drop off its riders and by
default will park.
Within the ‘Vehicle1_OnShift’ process, after the Assign step, place a Fire step, with the Event Name of ‘Event1’. Here, we will fire Event1
when the off shift period is over (thus releasing the vehicle waiting in the above logic, if necessary).
Enhancing the Animation
If you’d like the Server to appear different when it is Idle vs. Busy vs. OffShift, you need to select the Server object in the Facility Window
and click on the Add Additional Symbol icon in the Ribbon. Do this twice so there are now three symbols associated with this object.
C hange which symbol is ‘Active’ with the Active Symbol icon. Once the symbol is active, you can change the appearance of that symbol.
230 / 815
C hange which symbol is ‘Active’ with the Active Symbol icon. Once the symbol is active, you can change the appearance of that symbol.
The Current Symbol Index property of the Server controls which symbol is displayed during the run. The value of this property is used in
the symbol index (the numbers listed next to the symbols in the Active Symbol drop down). In this example, the following expression is
used so symbol 1 is displayed when the Server is On Shift (capacity = 1) but not busy, symbol 2 is displayed when the Server is On Shift
and Busy and symbol 0 is displayed when the server goes Off Shift (capacity = 0): (Server1.C apacity.Allocated + 1) * Server1.C apacity
• C hanging the appearance of the Vehicle during the run is done in a similar fashion. This example has two symbols for the vehicle, one
that is Blue and one that is Red. The Current Symbol Index of the Vehicle is set to the state 'OffShift', which we set within the Vehicle’s
add-on processes.
231 / 815
Simio Reference Guide
VehicleFixedR oute - SimBit
Problem:
I have a vehicle, such as a bus, that loops around a specific route picking up and dropping off entities at varying locations.
Categories:
Vehicles
Key Concepts:
Entity Destination Type, Fixed Route, Ride on Transporter, Sequence Table, Vehicle
Assumptions:
There are four specific pickup / drop-off locations in the fixed route for the vehicle. Entities must wait at their pickup location for the vehicle to
come to them, based on the vehicle’s route sequence. Therefore, entities are not picked up based on a first in first out basis for requesting the
vehicle, but are picked up based on the vehicle’s location on the route at the time. All entities that are picked up at a given location are dropped
off at a different, fixed location in this example.
Technical Approach:
Each pickup / drop-off location in the system is represented by Source and a Sink objects. By placing these objects near each other, they can be
virtually the same physical location represented by two objects. The vehicle in the system will move along a fixed route that is specified in a
clockwise manner. All Source and Sink objects are then connected using unidirectional Paths to show the direction of the vehicle movement.
Entities entering at the various Sources will each have specific destination location Sinks to be dropped off by the vehicle.
Details for Building the Model:
Simple System Setup
Place four Source objects and four Sink objects in the Facility Window. Move the nodes on these objects to be close to each other, as you
will be connecting them to represent the vehicle path.
C onnect the various sink and source objects with Paths in the following order – Source1-Sink1-Source2-Sink2-Source3-Sink3-Source4-
Sink4-Source1. This will form a circular path between all the objects in the system.
Defining the Vehicle Route
Open the Data Window and select the Tables panel. Here you will define the fixed route that the vehicle will take when moving between the
objects. C lick on Add Sequence Table and enter the various nodes that the Vehicle will visit, in order. These include ‘Output@Source1’,
‘Input@Sink1’, ‘Output@Source2’, ‘Input@Sink2’... ‘Output@Source4’, ‘Input@Sink4’. When the vehicle has gotten to the last destination in
the table, it will move to the first one listed and continue through the list again and again until the simulation ends. This table will
automatically have the Name ‘SequenceTable1’.
Defining the Vehicle
Place a Vehicle in the Facility Window. Within the Vehicle’s Properties window, change the Routing Type to ‘Fixed Route’ and the Route
Sequence to the ‘SequenceTable1’ table that was just defined.
The Initial Ride Capacity for the vehicle specifies the maximum number of entities on the vehicle simultaneously. C hange this value to
'Infinity', such that the Vehicle statistics can later be evaluated to determine the minimum, maximum and average number of entities
riding on the vehicle.
Set the Load Time and the Unload Time to ‘0.02’ minutes each to provide a brief pause while each entity is loaded or unloaded.
We will also replace the default animated queue on the transporter (Vehicle1.RideStation.C ontents) with a U shaped one that will display
more entities.
C reating the Part Types
The Source objects will generate entities to enter the system. In the example, four different types of ModelEntity objects were placed in
the Facility Window, with Name properties of ‘PartA’, ‘PartB’, ‘PartC ’ and ‘PartD’. For each of the Source objects, change the Entity Type
property to generate a different entity type.
Transferring using a Vehicle
In this example, entities get on the Vehicle at each Source and are taken by the vehicle to any destination node (to be specified by the
user). C lick on the Source1 TransferNode. Under the Routing Logic, specify the Entity Destination Type as ‘Specific’ and the Node Name as
‘Input@Sink3’. In the example, we have specified that Source1 goes to Sink3, Source2 goes to Sink4, Source3 goes to Sink1 and Source4
goes to Sink2. You can specify your different sources go to whichever sink input nodes you like. This will give the entity a “destination” so
that when it is moved by the vehicle along the designated path, the entity knows which node to exit, at which time it will be dropped off by
the vehicle.
Finally, in order for the entity at each Source node to be moved along the path using the vehicle, click on Source1’s TransferNode and
change Ride on Transporter to ‘True’. This will allow you then to select a Transporter Type (‘Specific’) and Transporter Name (‘Vehicle1’).
Do the same for the other three transfer nodes.
232 / 815
Simio Reference Guide
VehicleMovingBackward - SimBit
Problem:
I would like to model a vehicle moving back and forth on a path and not have unrealistic “jumps” in the animation.
Categories:
Vehicles
Key Concepts:
Allow Passing, Detached Queue, Entity Destination Type, ParkingStation Queue, Ride on Transporter, Vehicle
Assumptions:
When a vehicle changes direction at a node it often appears to jump to a new position. This is because the head of the vehicle determines the
position of the vehicle on a link or when it enters a node. For example, the vehicle will enter a node from the right and when the vehicle tries to
turn around, it will appear to be entering the node from the left; making an undesired “flip” around the node.
Technical Approach:
The vehicle used will look the same in both directions, meaning the head and tail of the vehicle cannot be distinguished from each other. A
mixture of Paths and C onnectors will be used between four TransferNodes to model the course that the Vehicle will follow. In order to make it
appear like the vehicle is moving backward, a path will be used to animate its normal movement between the TransferNodes at the ends of the
course and a connector will be used to animate the vehicle’s turn around movement.
Details for Building the Model:
Simple System Setup
Add a ModelEntity, Source, Sink and four TransferNodes to the Facility Window. C onnect the Source to TransferNode2 and TransferNode4
to the Sink using Paths.
Add a Path from TransferNode2 to TransferNode4 and another Path from TransferNode3 to TransferNode1.
Add a C onnector from TransferNode1 to TransferNode2 and another C onnector from TransferNode3 to TransferNode4. The C onnectors
have been made visible in this example by drawing them without overlapping the Paths.
Animating the Vehicle
Add a Vehicle to the Facility Window. Set the Initial Node (Home) to ‘TransferNode1’ and the Idle Action to ‘Park at Home’.
It is very important that the distance between TransferNode1 and TransferNode2 and the distance between TransferNode3 and
TransferNode4 is greater than the length of the Vehicle. This is because the Vehicle needs to have enough room to instantly turn itself
around on the Path and C onnector without getting stuck. Otherwise it could block itself from turning around.
Animating the Entities
Select the Output Node on the Source and change the Entity Destination to ‘Specific’ and select ‘TransferNode4’ and the destination.
Select the Path between the Source and TransferNode2 and change the Allow Passing property to ‘False’. This will cause the Entities to line
up in order as they wait to be transported by the Vehicle.
Select TransferNode2 and change the Ride on Transporter property to ‘True’ and select ‘Vehicle1’ as the Transporter Name.
Select TransferNode4 and change the Entity Destination Type property to ‘Specific’ and the Node Name to ‘Input@Sink1’.
Animating the Parking Queues
In order to make it appear that the Vehicle is parking on its route while idle, the Parking Queues for TransferNode1 and TransferNode4
must be drawn and placed directly on the route.
Add two detached queues to the Facility Window and change the Queue State of one to ‘TransferNode1.ParkingStation.InProcess’ by
choosing it from the drop down menu. C hange the Queue State of the other queue to ‘TransferNode1.ParkingStation.InProcess’. Then
move these queues to their respective places in between the TransferNodes.
Embellishments:
Try changing the Interarrival Time of the Source or the Desired Speed of the Vehicle. Also, try different a Idle Action for the Vehicle.
233 / 815
Simio Reference Guide
VehiclesP assingO nR oadway - SimBit
Problem:
Model a simple version of a roadway with sections that allow passing and sections that do not.
Categories:
Vehicles
Key Concepts:
Allow Passing, Path, Path Decorators
Assumptions:
There are separate Source/Path/Sink sets for each direction of the road. Multiple vehicles can pass a vehicle simultaneously without regard for
oncoming traffic.
Technical Approach:
Two sources, placed at opposite ends of the model, create the entities with random speeds mimicking vehicles entering separate sides of a
roadway. The roadway is separated into three sections – two curved sections that do not allow passing and one straight section that does. After
the vehicle has driven the entire roadway it exits the system.
Details for Building the Model:
C reating the Roadway
Place two Sources and two Sinks in the model, with one source and sink on each side of the model. Position them so that there are 2
Source/Sink pairs representing either side of the road. Separate them so that the vehicles have enough room to illustrate the vehicle
movement.
Place 4 TransferNodes in between the Source/Sink pairs (2 for each pair) to represent the passing section.
Move left Sink’s BasicNode and the right Source’s TransferNode so that that both Source/Sink Pairs have their nodes facing eachother.
Double-click on Path to create the lanes of the road. Start at one of the Sources and start clicking to create a curved section of the
roadway. End this section at one of the TransferNodes.
From this TransferNode draw a straight line connecting it to a second TransferNode.
Then create another curved section ending at a Sink.
C reate the other lane in the same manner. Start at the other Source and create another curved section leading to a new TransferNode,
followed by a straight section to the final TransferNode, then a section leading to the second Sink. Make sure to mimic the contour of the
first lane.
To each path, add a single lane path decorator and set the path width (Size – Width) to 2 meters.
Adding Entity Symbols
Add a Vehicle to the Facility Window. Set the Initial Node (Home) to ‘TransferNode1’ and the Idle Action to ‘Park at Home’.
It is very important that the distance between TransferNode1 and TransferNode2 and the distance between TransferNode3 and
TransferNode4 is greater than the length of the Vehicle. This is because the Vehicle needs to have enough room to instantly turn itself
around on the Path and C onnector without getting stuck. Otherwise it could block itself from turning around.
Animating the Entities
Place a ModelEntity from the Project Library into the Facility Window.
After making sure the ModelEntity is selected, click on Add Additional Symbol in the Symbols tab. C lick on the button repeatedly until you
have reached an appropriate level of Active Symbols (in this example there are 9 Active Symbols).
Go through all of the Active Symbols in the dropdown list and change each vehicle symbol to a different color or different symbol.
Set the ModelEntity’s Random Symbol property to ‘True’.
Modeling the Vehicle Movement
C hange the ModelEntity’s Initial Desired Speed to ‘Random.Uniform(1,5)’ Meters per Second.
To prevent the vehicles from passing on the curved sections of the road, click on the curved sections and change the Allow Passing in the
Travel Logic to ‘False’.
234 / 815
Simio Reference Guide
VehicleStopsW henServerO ffShift - SimBit
Problem:
I want a Transporter to follow the same Work Schedule as a Server in my system. The Transporter should stop working immediately when the
Server goes Off Shift.
Categories:
Vehicles
Key Concepts:
Add-On Process, AssociateObjectMovement, Off Shift, On Off Shift, On On Shift, On Shift, Real State Variable, Resume Step, Ride on Transporter,
Schedules, Search Step, Subclass, Suspend Step, Vehicle
Assumptions:
The Vehicle object’s capacity cannot be controlled by a Work Schedule so the Vehicle’s logic will be suspended when the Server goes Off Shift
and it will resume its logic when the Server goes back On Shift.
Technical Approach:
Subclass the standard Vehicle object and change the OnVisitingNode processes property Public from ‘False’ to ‘True’. This will allow this process to
appear in the selection list of the Suspend Step. The Suspend Step will suspend this process from within the OffShift Add On Process of the
Server. Similarly, the Resume Step will resume the OnVisitingNode process from within the OnShift Add On Process of the Server. The Vehicle’s
movement is also suspended and resumed with a Suspend Step from within the same Add On Processes.
Details for Building the Model:
Simple System Setup
Add a Source, a Server and a Sink to the Facility Window.
C onnect the objects together with Paths. Ensure that the Type property of the path from the Server to the Sink is set to ‘Bi-directional’ so
the vehicle can travel back and forth.
In order to slow down the entity arrival to best view the vehicle’s behavior, change the Interarrival Time of the Source object to
‘Random.Exponential(4)’ minutes.
Subclassing the Vehicle Object
Select MySimioProject in the Navigation Window and highlight the Models panel. On the Edit ribbon, press the Subclass From Library button
and select the Vehicle. This will create a sub-classed ‘MyVehicle’ object.
Highlight Model in the Navigation Window to return the main model and place the MyVehicle object from the Project Library into the Facility
Window. In order to make it look like a true vehicle, when the object is selected in the Facility Window, select a vehicle symbol from the
Project Symbols dropdown in the Ribbon.
Select the Output Node of the Server and set the Ride On Transporter property to ‘True’, the Transporter Type to ‘Specific’ and then select
your Vehicle for the Transporter Name property.
In order to slow down the animation to best view the vehicle’s behavior, change the Desired Speed property of the Vehicle to ‘0.04’
(meters per second).
Set the Initial Node (Home) property of the Vehicle to ‘Output@Server1’.
C reating a Work Schedule
Go to the Data Window and select the Schedules panel. C lick the Work Schedule icon from the Schedule ribbon and change the Name to
‘Schedule1’ and the Days to ‘1’.
In the Day Patterns tab, add a new one with the Name ‘DayPattern1’ and press the ‘+’ to open the pattern.
Add three rows to reflect the following schedule: 8:00 AM – 8:15 AM with a Value of ‘1’, 8:30 AM – 8:45 Am with a Value of ‘1’ and 9:00 AM
– 12:00 PM with a Value of ‘1’. NOTE: The times when there aren’t on shift times are considered to be off shift (capacity value of 0).
Go back to the Work Schedules Tab and select ‘DayPattern1’ for Day 1.
Add the Schedule to the Server and C reate logic to Stop Vehicle
Highlight the MyVehicle object in the Navigation Window and open the MyVehicle’s Processes Window. Find the process OnVisitingNode and
click on the process. C lick the Override icon in the top Ribbon and then change the Public property from ‘False’ to ‘True’.
In the Model’s Facility Window, select the Server object and set the Capacity Type property to ‘WorkSchedule’. Select the work schedule
that was just created for the Work Schedule property.
From within the Server properties window, select the dropdown icon from the Add On Process trigger OffShift and select ‘C reate New’. Do
the same for the trigger OnShift. (if you double click on the name of the Property, i.e. On Shift, you will be taken to the Process Window)
In the Model’s Processes Window, you should see the two new processes that were created from the Server’s Add On Process triggers. In
the Off Shift process, place a Search Step (found under All Steps). The Search Step is needed to create a token that points at the Vehicle
instance so the Vehicle can be suspended. The Collection Type of the Search Step is set to ‘ObjectInstance’ and the Object Instance Name
is set to the name of the subclassed Vehicle. The other properties can be kept with their default values.
Place a Suspend Step (found under All Steps) in the Found segment leaving the Search Step. The Suspend Type of this step is set to
‘AssociatedObjectMovement’. This will stop the vehicle’s movement immediately.
Place a second Suspend Step directly after the first Suspend Step in the Found segment. The Suspend Type of this step is set to Process
and the Process Name is set to the OnVisitingNode process of the Vehicle. (i.e. MyVehicle.OnVisitingNode)
Almost the exact same logic should be put in the On Shift process, except instead of the Suspend Steps, Resume Steps should be used to
both resume the vehicle’s movement and the OnVisitingNode process.
Enhancing the Animation
If you’d like the Server to appear different when it is Idle vs. Busy vs. OffShift, you need to select the Server object in the Facility Window
and click on the Add Additional Symbol icon in the Ribbon. Do this twice so there are now three symbols associated with this object.
C hange which symbol is ‘Active’ with the Active Symbol icon. Once the symbol is active, you can change the appearance of that symbol.
The Current Symbol Index property of the Server controls which symbol is displayed during the run. The value of this property is used in
the symbol index (the numbers listed next to the symbols in the Active Symbol drop down). In this example, the following expression is
used so symbol 1 is displayed when the Server is On Shift (capacity = 1) but not busy, symbol 2 is displayed when the Server is On Shift
and Busy and symbol 0 is displayed when the server goes Off Shift (capacity = 0): (Server1.C apacity.Allocated + 1) * Server1.C apacity
235 / 815
C hanging the appearance of the vehicle during the run is done in a similar fashion. This example has two symbols for the vehicle, one that
is Blue and one that is Red. The Current Symbol Index of the Vehicle is set to a State Variable called Off Shift. This state is set to ‘1’ with
an Assign Step after the Suspend Step that stops the vehicle. It is set to ‘0’ when the Vehicle resumes its movement.
236 / 815
Simio Reference Guide
VehicleVisitsServiceC enter - SimBit
Problem:
I want to model a system that contains a vehicle that is subject to random failures. And upon failure, the vehicle finishes its delivery, if not idle,
and then proceeds to a Service C enter to be repaired or serviced.
Categories:
Vehicles
Key Concepts:
C apacity.Initial, C apacity.Remaining, C ontents, Decide Step, Event, Failure, Failure.Active, ID, Node Property, OnInitialized Process, Override,
Park Step, ParkingStation, ParkingStation Queue, Real State Variable, Ride on Transporter, Search Step, SetNode Step, Subclass, Time To Repair,
UnPark Step, Uptime Between Failures, Vehicle, Wait Step
Assumptions:
There is only one Vehicle in the system.
Technical Approach:
C hanges are required to the standard Vehicle object, therefore it is subclassed into the Project Library. A new Node Property is added to this
object to hold information about the service center node. From within the Vehicle object, the OnFailed, FailureOccurenceLogic, OnRepaired and
OnVisitingNode processes are updated with custom logic to indicate that the vehicle must not immediately stop in place upon Failure, but instead
finish delivery, if appropriate, and then travel to the service node before starting its repair time delay.
Details for Building the Model:
Simple System Setup
Add a Source, two Servers and a Sink to the Facility Window. C hange the mean Interarrival Time on the Source to
‘Random.Exponential(1)’.
C onnect the Source to the first Server, connect the first and second Server together and connect the second Server to the Sink with Paths.
Add a Basic Node and connect it to the Output Node of Server 1 and the Input Node of Server 2.
Make the path between the two Servers bi-directional, along with the two paths connecting the Basic Node. To make a path bi-directional,
set its Type property to ‘Bidirectional’.
C lick on the Output Node of Server 1.
Set its Entity Destination property to ‘Specific’ and the Node Name property to ‘Input@Server2’. Entities will always go to Server2.
Set its Ride On Transporter property to ‘True’, it’s Transporter Type property to ‘Specific’. You’ll need to set the Transporter Name
property to ‘MyVehicle1’ but this cannot be done until your custom Vehicle is in your Facility Window and this happens later.
C ustomize a Vehicle
Because we want our vehicle to have some unique behavior (e.g. go to a specified node before failing) we will start by creating a new vehicle
object based on the existing Vehicle, then add a new property and other definitions that it will need.
Subclass the standard Vehicle object into your Project Library. This is done by clicking on MySimioProject in the Navigation Window, then
selecting the Models panel. C lick on the Subclass From Library button from the ribbon and select Vehicle. This adds a subclassed MyVehicle
object to the library.
Highlight the Model in the Navigation Window and select the Definitions tab, Properties panel. Add a new Node Property (from the Object
Reference icon in the ribbon) and name it ServiceNode. If you put ‘Reliability’ in the Category Name property of this new property, it will
appear in that category of the Vehicle, next to the other information about Failures.
In the Definitions Window, select the Events panel and add a new Event that is named 'ArrivedAtServiceNode'.
FailureOccurenceLogic Process
In the Processes Window, find the FailureOccurenceLogic process and select Override from the ribbon. This will allow you to make changes
to this process.In the Processes Window, find the OnFailed process and select Override from the ribbon. This will allow you to make
changes to this process.
Place a SelectVisit Step in the Failed segment leaving the Allocate Step. The existing PlanVisit Step will then be in the Failed segment of
this new SelectVisit step
Place a Decide Step in the OK segment leaving the Select Visit Step. The expression should be “IsParked” to check if this vehicle is
parked. Place a UnPark Step in the True segment, so the vehicle will unpark itself if it indeed is parked.
OnFailed Process
We want our vehicle to automatically move to a repair location on failure, so we need to replace the default failure logic with some custom logic.
In the Processes Window, find the OnFailed process and select Override from the ribbon. This will allow you to make changes to this
process.
Delete the first two Suspend steps which suspend the ParentObjectMovement and OnVisitingNode. When the failure occurs, we don’t want
the vehicle to immediately stop. Additionally, if the vehicle is transferring an entity, we need it to continue (including going through
OnVisitingNode) until the entity is dropped off.
After the Suspend Failure Occurence Logic step, add a Decide step to see if there are riders on the Vehicle or if its capacity is not seized,
meaning that it is not on its way to get a rider. (Expression is NumberRiders == 0 & & C apacity.Remaining == C apacity.Initial)
From the True branch of this step, place a SetNode step. The Object Type is ‘ParentObject’, the Destination Type is ‘Specific’ and the Node
Name should be set to the new ServiceNode property. To set a property here, right click on Node Name and select SetReferencedProperty
and then select ServiceNode.
After the SetNode Step, place a Decide step that checks if the Vehicle is parked. (IsParked).
From the True branch of this step, place a UnPark step. The UnPark Type is set to ‘Parent Object’.
After this UnPark Step, place a Fire step to fire the Event Name ‘RemainInPlaceEnded’. This will cause the parked vehicle logic to continue
in the OnVisitingNode process (where the Wait step for ‘RemainInPlace’ step exists).
After the Fire step, place a Wait step. The Event Name is set to ‘ArrivedAtServiceNode’.
C onnect the False branch of both Decide steps to the Wait step (‘ArrivedAtServiceNode’).
The Wait step will flow into the Execute step (‘FailedAddOnProcess’) that was part of the original process. All the other steps in the process
remain untouched.
237 / 815
remain untouched.
OnRepaired Process
Because the two Suspend steps in the OnFailed process were deleted, you will also need to delete the corresponding Resume steps in this
process, the Resume ‘ParentObjectMovement’ and the Resume ‘OnVisitingNode’ process.
OnVisitingNode Process
As part of implementing our custom failure logic, we need to special handle the case when the vehicle arrives at the repair location and also when
the vehicle is failed but arrives at the location with an entity to dropoff.
Find the OnVisitingNode process and Override it.
Find the IfNotVisitingNode Decide step. Place a new Decide step in the False branch, directly before the Decide (IfBusy) step. This new
Decide step checks to see if the Vehicle is at the Service Node. (C urrentNode != ServiceNode) If not, it continues with the normal logic.
In the False branch of this new Decide step, place a Park step. The Entity Type is ‘Parent Object’ and the Node Name is the ServiceNode
property. Set this by right clicking on the Node Name and selecting SetReferencedProperty and the selecting ServiceNode.
After this Park step, place a Fire Step. This will fire the event ‘ArrivedAtServiceNode’. The branch then exits this Process.
Go to the bottom, right of this process and find a Decide step titled “IfOffShift”. In the False branch of this Decide step, place a Decide Step
that determines if the vehicle is failed (ResourceState==List.ResourceStateName.Failed). You’ll need to disconnect the False branch from
it’s current connection in order to add the new Decide Step.
The True branch should contain a new Dropoff step where the Unload Time references ‘UnloadTime’ property, followed by a Wait step
where Event Name is ‘RiderUnloaded’. These can be copied / pasted from earlier logic prior to the Pickup step. The Wait step connects
back around to the Dropoff step. The Wait step should have an Exclusion Expression of ‘!UnloadedAddOnProcess.HasValue’ so that the
vehicle doesn’t wait if it has failed carrying an entity but doesn’t have an unload add-on process.
The Failed branch of the Dropoff step should connect to a Release step (also can be copied from earlier logic) where Object Type is ‘Parent
Object’, and Units per Object is SeizedResources.C apacityOwnedOf(ParentObject). The Owner in Advanced Options is ‘ParentObject’.
From the Release step, place a SetNode step. Object Type is ‘Parent Object’ and the Node Name is the ServiceNode property.
The False branch of the Decide step that was added and the segment leaving the Set Node step should both connect to the second step
(Decide) in the process with Name ‘IfNotVisitingNode’. The ‘-‘ and ‘+’ keys on the keyboard can be used within the process to zoom in/out.
This may be necessary to connect these steps.
The rest of this process remains unchanged.
Place the Vehicle into the Model
Here we will customize how the default vehicle looks.
Before you place the Vehicle into the Facility Window of the model, you might want to change the External view of the Vehicle (how it looks
in the Facility window). To do this, go to the External panel of the Definitions Window for the Vehicle object. Place a symbol of a vehicle
and place the RideStation.C ontents queue on the Vehicle.
Place the new customized Vehicle into the Facility Window of the model.
Set the Initial Node property to ‘Output@Server1’.
Set the Failure Type to ‘C alendar Time Based’. Set Uptime Between Failures to 3 minutes. Set Time to Repair to 1 minute.
Set ServiceNode to 'BasicNode1'.
C lick onto Output@Server1 and set the Ride On Transporter property to ‘True’ and the Transporter Name to the name of the customized
vehicle you placed into the model.
238 / 815
Simio Reference Guide
VehicleW ithVariableR ideC apacity - SimBit
Problem:
I have a vehicle that can pick up a variable number of entities at any given location, based on a distribution.
Categories:
Vehicles
Key Concepts:
Add-On Process, Assign Step, Decide Step, Is.Vehicle, Math.Floor(), NumberRiders, On Evaluating Transport Request, On Exited, ReturnValue,
Round, Token, Vehicle
Assumptions:
There is a single vehicle that can pick up anywhere from one to five entities at Source1.
Technical Approach:
A state variable, RidersNeeded, will be used to sample from a distribution to determine how many entities the vehicle will pick up at a given time
for each pickup. The Initial Ride C apacity of the vehicle will be set to 5, which will be the maximum number of entities the vehicle can move. The
Evaluating Transport Request add-on process will be used to compare the RidersNeeded value sampled with the number of current riders function
of the vehicle to determine if a ride request is accepted or not.
Details for Building the Model:
Simple System Setup
Add a Source and Sink from the Standard Library to the Facility window. C onnect the objects with a Path.
C hange the Type of the Path to ‘Bidirectional’ so the vehicle may go back and forth between the Source and Sink.
Adding and Using a State Variable
Within the Definitions tab, States panel, add a Discrete State and change the Name to ‘RidersNeeded’.
Set the Initial State Value to ‘1’, which will allow the vehicle to pick up one entity for its first pickup.
Within the Processes window, use the C reate Process button and create a process with the Name ‘ResetRiderNumber’. Within this process,
add a Decide step and change the Decide Type to ‘C onditionBased’ and Expression to ‘Is.Vehicle’.
Add an Assign step to the process from the True branch of the Decide step. Within the Assign step, change the State Variable Name to
‘RidersNeeded’ and the New Value to ‘Math.Floor(Random.Triangular(1,3,6))’. This will assign the RidersNeeded state to a new value each
time the vehicle leaves the Source for its next pickup. The Math.Floor function is used to truncate the values generated from the
distribution to integer values.
Within the Facility window, highlight the output node of the source (Output@Source1) and, under the Add-On Process Triggers Exited
property, add the process ‘ResetRiderNumber’ that was just defined above.
Defining the Vehicle
Place a Vehicle object in the Facility window and change the Initial Ride Capacity to ‘5’. This will set the maximum capacity of the vehicle.
Within the Add-On Process Triggers section, create a new process for the Evaluating Transport Request property called
‘Vehicle1_EvaluatingTransportRequest’.
Open the Processes window. In the Vehicle1_EvaluatingTransportRequest process, add a Decide step with the Decide Type of
‘C onditionBased’ and the Expression of ‘Vehicle.NumberRiders<RidersNeeded’. The Vehicle.NumberRiders is a function that looks at the
current number of entities on the vehicle. The RidersNeeded is the state variable that we use to determine the number of riders for a
particular pickup. This process will be evaluated with each entity awaiting transport at Source1.
From the False connection of the Decide step, add an Assign step. Within the Assign step, set the State Variable Name to
‘Token.ReturnValue’ and the Value to ‘0.0’. When the Token.ReturnValue is set to less or equal to 0.0, the transport request is rejected,
which is what will happen for those requests above the RidersNeeded state value.
Embellishments:
The RidersNeeded state variable can be animated by using a Status Label from the Animation tab and changing the Expression to ‘RidersNeeded’.
This is useful in making sure that the vehicle is picking up the number of riders as determined by the RidersNeeded state variable value sampled
from the distribution.
239 / 815
Simio Reference Guide
VisitAllServersInAnyO rder - SimBit
Problem:
An entity must process through ServerA, then Servers 1, 2, and 3 in any order but must do all three, then finish with ServerC . This model
illustrates how a simple modification can be made to an object to permit more intelligent use, in this case allowing selection of only objects that
still need the service it provides.
Categories:
Building New Objects / Hierarchy, Decision Logic -- Paths, Discrete States
Key concepts:
Entity Destination Type, State Variable, Selection Goal, Selection C ondition, C andidate, NodeList
Assumptions:
The three pooled servers have the same processing time and each has a single buffer position. The entities can process through the 3 servers in
any order, but must process at each of the 3 servers exactly once before moving on to Server C . The server with the smallest overload is
selected. If no server is available that is still needed, the entity will wait in the Dispatching area (a node).
Technical Approach:
There are two key requirements:
Each entity must keep track of which of the three servers it needs to visit and which have already been visited. This is done by adding
three states to the ModelEntity.
The easiest way to select between servers is to use the TransferNode’s built-in Entity Destination Type and in particular it’s Selection
C ondition. In order to take advantage of this, we created a custom MyServer by subclassing from Server. The only change to MyServer is
to add a HasEntityVisited property into which can be passed the appropriate entity state corresponding to that server.
Other logic includes path weights on Path9 and Path10 for determining if entity should return to dispatching or continue to ServerC .
Embellishments:
We added 3 status labels (one for each custom state) on each entity picture so you can see which stations have been visited.
We added 3 pictures to the entity that gets successfully darker as more stations are visited so you can tell its status at a glance.
240 / 815
Simio Reference Guide
W F_AdditionalR esource - SimBit
Problem:
I want to model the ability of some process-aware information systems to allocate a work item to an additional resource.
Categories:
Worker
Key Concepts:
Functions, Lists, Server, Secondary Resources, Worker
Assumptions:
There are two entity types in the system and two Workers. A productivity function is used to calculate the processing times of each entity type.
Technical Approach:
Entities will seize randomly a Worker from a list. EntTypeB entities require 2 resources for processing. This is specified in Number of Objects
property of the Secondary Resources seize in order to an EntTypeB entity seizes 2 workers.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink into the Facility window. Put the objects in series and connect them with paths.
Place another Source object and connect the Output@Source2 to Input@Sever1 using a Path.
Add two Worker objects into the Facility window. Set the Park While Busy to ‘True’ and the Initial Network as ‘No Network (Free Space)’.Set
‘Output@Source1’ Node as the Initial Home for each Worker. Set the Idle Action and Off Shift Action properties of each worker to ‘Part At
Home’. C hange Worker2 color to Red by clicking in C olor in the ribbon.
Defining the Entity Types
Place two ModelEntity objects into the Facility window and change their names to ‘EntTypeA’ and ‘EntTypeB’. C lick on EntTypeB and change
its color to Red by clicking in C olor in the Ribbon. Set Entity Type property of Source2 to ‘EntTypeB’, while the Entity Type for Source1
should be ‘EntTypeA’.
C reating a List of Workers
In the Definitions window, go to the Lists panel. Add a new Object list. Name it ‘Resources’ and add Worker1 and Worker2 to the list.
C reating a Function and Set Processing Times
In the Definitions window, go to the Functions panel. Add a new Function. Name it ‘Productivity’ and change Expression property to
‘Math.If(Entity.SeizedResources.NumberItems > 1, 1.5, 1)’.
C lick in Server1 and change Processing Time property to ‘Random.Triangular(3,5,7)/Productivity’.
Seizing the Secondary Resources Within the Server
C lick on Server1 and within the Secondary Resources, Other Resource Seizes section, enter the Before Processing repeat group. Use the
Add button and change Object Type to ‘Select From List’, Object List to ‘Resources’, Request Move to ‘To Node’ and Destination to
‘Input@Server1’. Expand Advanced Options, change the value of Number of Objects property to ‘Math.If(ModelEntity.Is.EntTypeB,2,1)’ and
change the value of Selection Goal to ‘Random’. This will cause the entities of EntTypeB to require 2 workers from the set, while any other
entities require only 1.
Within the Secondary Resources section of Server1, under the Other Resource Releases section, enter the After Processing repeat group
and Add a release of Object Type ‘Select From List’, Object List Name to ‘Resources’ and Number of Objects to
‘Math.If(ModelEntity.Is.EntTypeB,2,1)’ to release the resource(s) that were seized.
241 / 815
Simio Reference Guide
W F_Authorization - SimBit
Problem:
I want to model the ability of some process-aware information systems to specify the range of authorized workers able for processing entities in
a given server.
Categories:
Worker
Key Concepts:
Data Table, Lists, Secondary Resources, Server, State Assignments, Table Reference Assignments, Worker
Assumptions:
There are two entity types created from the same entity instance in the system. Green and Red workers are authorized to process green and red
entities while the yellow worker can process both.
Technical Approach:
Lists of Workers are used to represent authorized workers per each entity type. A Data Table is used to store for each entity type its symbol
reference, percentage of arrival and a reference to the list of authorized resources for processing in Server1. A table row reference is associated
randomly to each created entity at the Source object by percentage of arrival. Add-on process triggers are used to seize and release the
authorized workers in Server1.
Details for Building the Model:
Simple System Setup
Place a Source, Server and Sink into the Facility window. Put the objects in series and connect them with Paths.
Add three Worker objects into the Facility window. Set ‘Output@Source1’ Node as the Initial Home for each Worker. Set the Idle Action of
each worker to ‘Park at Home’, the Initial Network to ‘No Network (Free Space)’ and the Park While Busy to ‘True’.
C licking in Worker1, 2 and 3 and change their color to Green, Yellow and Red respectively by selecting C olor in the ribbon.
Place a ModelEntity into the Facility window and change its the name to ‘ProcessC aseType’. C lick on it and add an additional symbol.
C hange the color of active symbol 1 to Red in order to distinguish the entity types.
C reating Lists of Workers Representing Authorized Resources
In the Definitions window, go to the Lists panel. Add 2 new Object lists. Name them ‘AuthorizedGroup_One’ and ‘AuthorizedGroup_Two’
respectively. Add Workers 1 and 2 into the AuthorizedGroup_One list and Workers 3 and 4 into AuthorizedGroup_Two list. These lists
represent authorized resources.
C reating a Data Table
Go to the Data window, and within the Tables panel, click the Add Data Table icon the ribbon to add a new table. Name it ‘EntityData’.
Add 3 columns that are a String, Integer and Real standard properties by selecting each data type from the Standard Property drop down
in the ribbon. C hange the names of each column to ‘Name’, ‘Symbol’ and ‘Percentage’ respectively.
Add fourth column to the table – an Object List reference by selecting Object List from the Object Reference drop down in the ribbon. The
column can be renamed to ‘AuthorizedResources’.
Fill the table with data – such as:
TypeA, 0, 40, AuthorizedGroup_One
TypeB, 1, 60, AuthorizedGroup_Two
Associating a Data Table Row Reference to the ModelEntity and C hanging Its C olor
C lick on the Source object and expand Table Reference Assignments property category. Expand On C reated Entity and set Table Name
property to ‘EntityData’ and Row Number property to ‘EntityData.Percentage.RandomRow’. This will associate a table row reference to a
created entity based on the percentage of arrival specified in the table.
C lick on the Source Object and expand State Assignments property category. C lick on the “…” button to open the Repeating Property
Editor. C lick the Add button and change State Variable Name to ‘ModelEntity.Picture’ and New Value to ‘EntityData.Symbol’. This will change
the color of a new created entity by its corresponding active symbol.
Specifying the Secondary Resources Required
C lick on Server1 and within the Secondary Resources, Resource for Processing properties, specify the Object Type as ‘Select From List’,
Object List Name to ‘EntityData.AuthorizedResources’, Selection Goal as ‘Random’, Request Move as ‘To Node’ and Destination Node as
‘Input@Server1’. This will require each entity to seize the appropriate resource to be used during the processing delay.
C hange the Server Initial Capacity to ‘Infinity’ to that multiple workers can process entities at the same time at this location.
242 / 815
Simio Reference Guide
W orkersArriveLateT oShift - SimBit
Problem:
I would like to model the fact that my Worker will sometimes arrive late to Shift.
Categories:
Building New Objects / Hierarchy, C ustom Statistics, Decision Logic -- Processing, Discrete States, Schedules / C hangeovers, Worker
Key Concepts:
Active Symbol, Assign Step, Decide Step, Floor Label, NumberOccurences, Off Shift, On Shift, Schedules, Secondary Resources, Server,
TallyStatistic, WorkSchedule, Worker
Assumptions:
This model assumes that the worker could arrive late to all shifts, including the shift that begins after the lunch hour break.
Technical Approach:
A Server seizes a Worker object before processing and releases it after processing. The standard Worker object is subclassed in order to keep
the original object definition, but allowing the user to make a few changes to the logic to account for the fact that the Worker might arrive late.
The new Worker’s OnC apacityC hanged process is Overridden and five new Steps are added to this logic. A Decide step checks the
ProbabilityOfArrivingLate property and if the Worker is late, the MinutesLateToShift property is assigned to a State variable and the picture of the
Worker is set to Red. The Worker delays for the assigned amount of time, a Tally step updates a TallyStatistic that keeps track of the minutes that
this Worker is late to the shift. Finally the picture of the Worker is set back to Blue and they return On Shift.
Details for Building the Model:
System Setup
Place a standard Source, Server and Sink object from the Standard Library into the Facility window and connect them with Paths.
Alternatively, click on the Select Add-in button on the Project Home ribbon tab and select Place Source, Server, Sink.
Place a Transfer Node somewhere near the Server and name it WorkForServer1. Place another Transfer Node a short distance away from
the Server and name this WorkerHome. C onnect these two nodes with a Path and set the Path’s Type property to ‘Bidirectional’. This will
be the path that the Worker object takes.
Subclass a Worker
Right click on the Worker Object in the standard library and select Subclass. This will create a new object in the Project Library called
MyWorker. You’ll find this new object in the Project Library located in the bottom left part of the interface, underneath the Standard Library
The new object definition for MyWorker appears in the Navigation window in the upper right corner. C lick onto MyWorker to enter into this
new object . You’ll be in MyWorker’s Processes window at first.
Go to this object’s Definitions window and then click into the Properties panel. C reate two new Expression properties by selecting
Expression from the Standard Property drop down menu in the ribbon.
Name the first property ProbabilityOfArrivingLate. In the CategoryName property of this new expression property, type in
‘ArrivingLateToShift’. This creates a new property category which helps us keep our new properties organized.
Name the second expression property MinutesLateToShift In the CategoryName property of this new expression property, select
‘ArrivingLateToShift’ so this appears in the same category as the other new property.
C lick onto the States panel to add two new States to this object. Add a Real State by clicking on Real in the ribbon. Name this new state,
“MinutesLateToShift_State”. Add another Real State and name this new state “AnimationPicture”. We’ll discuss how these are used in the
details below.
Go to the Object’s Processes window. Find the OnC apacityC hanged process. C lick anywhere inside this process and then click Override in
the Process ribbon. The process should then turn white and you can now make changes to the process.
Place a Decide step directly after the first Decide step in that process, which is named IfOnShift. Name the new Decide Step, “Late?”. Enter
the expression “1-ProbabilityOfArrivingLate” into the Expression property of this new Decide Step. The True segment leaving this step will
tell the token to continue with the original logic (i.e. go to the Notify Step). The False segment will contain additional new logic.
Place an Assign step in the False segment leaving that Decide step. Set the State Variable Name to ‘MinutesLateToShift_State’ and the New
Value to ‘MinutesLateToShift’. Note: Because the property can be entered as a Random distribution, we want to get a value from this
random distribution once (now) and assign it to a State Variable. And then we’ll use this State variable in the upcoming Delay Step and
Tally Step. If we were to instead use the property in the Delay step and the Tally step, we’d sample the random distribution each time and
therefore has different values for the Delay and the Tally, thus making our statistics wrong).
In this same Assign step, add another Assignment where the State Variable Name is ‘AnimationPicture’ and the New Value is ‘1’. This will
allow us to turn the Worker Red when it’s late for its shift.
Place a Delay step next and set the Delay Time property to ‘MinutesLateToShift_State’.
Place a Tally step next and select ‘C reateNew’ from the drop down in the Tally Statistic Name property. Name the new Tally Statistic
‘LateToShift’. In the Value property of this step, enter ‘MinutesLatetoShift_State’ so that we record the value of the state into the new Tally
Statistic. Note: The Simbit has a BreakPoint on this Step to help the user easily see when the Worker arrives late.
Place an Assign step and set the State Variable Name to ‘AnimationPicture’ and the New Value to ‘0’. This will allow us to change the color
of the Worker back to Blue when its going back On Shift. C onnect the process back up to the beginning of the Notify Step so that the token
will continue with the original logic to go back OnShift.
Add to the MyWorker1 Instance
Go back to the main model by clicking Model in the Navigation window. Drag an instance of MyWorker into the Facility window.
Select MyWorker1 in the window and set the following properties:
Capacity Type to ‘WorkSchedule’
Work Schedule to ‘StandardWeek’
Initial Node (Home) to ‘WorkerHome’
OffShift Action to ‘GoToHome’
Find the new property category called “ArrivingLateToShift” where you should see the two new properties that were created.
Set the ProbabilityOfArrivingLate to ‘1’ (100%)
243 / 815
Set the MinutesLateToShift to ‘Random.Uniform(5,10)’
With the MyWorker1 instance still selected, click on the Add Additional Symbol button in the Symbols ribbon. This will add another symbol
for this instance. Symbol 2 of 2 should be selected so click onto the C olor ribbon button and select Red and then click back onto the
instance of MyWorker so that it turns Red. If you go back to symbol 1 by selecting symbol 0 in the Active Symbol ribbon drop down, you’ll
see that it is still Blue.
Ensuring that the MyWorker1 instance is still selected, open it’s Animation property category and find the property Current Symbol Index.
Set it to ‘MyWorker.AnimationPicture’ So when the logic in our MyWorker object sets the State AnimationPicture to 1, the Red symbol will
be displayed and when the logic sets it back to ‘0’, the Blue symbol will be displayed.
Embellishments:
The SimBit includes some Floor Labels to describe the model and the properties of MyWorker1. One of the Floor Labels displays the current value
of the Tally Statistic we added to the MyWorker object. The expression {MyWorker1[1].LateToShift.Average * 60} displays the Average value of
the Tally Statistic. Note: The expression must point to a specific member of the MyWorker1 population (in this case [1]). This is because there
might be more than 1 MyWorker1 in the model at any given time and this expression needs to know which MyWorker1 to look at.
244 / 815
Simio Reference Guide
W orkerUsedForMultipleT asks - SimBit
Problem:
I have a system where my worker is responsible for both transportation type tasks, as well as inspection type tasks. Therefore, the worker must
move entities from one location to another, but also must be available at the inspection area to perform stationary tasks.
Categories:
Worker
Key Concepts:
Add-On Process, BasicNode, Decide Step, Is.ModelEntity, On Entered, Request Move, Ride on Transporter, Seize Step, Worker
Assumptions:
There is one worker who is responsible for both transport and stationary tasks. The worker does not take breaks or go off-shift.
Technical Approach:
The worker will be responsible for moving entities from the Source to the Server so that the entities may continue processing at the Server. This
will be done by using the Worker as a Transporter type object. Additional entities are sent through a node in need of inspection by the Worker.
The Worker will move to the node for inspection and later return to the transport tasks. Add-on Process Triggers at the node will be used to Seize
and Release the Worker for this stationary task.
Details for Building the Model:
System Setup
Add a Source, a Server, and a Sink to the Facility window. C onnect the Source to Server and also the Server to the Sink with Paths. Since
the Worker will be moving the entities between the Source and Server, change the Type of path to ‘Bidirectional’. C hange the Source1
Interarrival Time property to ‘Random.Exponential(.5)’ minutes.
Add a Worker object to the Facility window.
Add a second Source, a BasicNode and a second Sink. C onnect Source2 to BasicNode1 and also BasicNode1 to Sink2 with Paths. The
Worker’s inspection task will occur at the BasicNode. C hange the Source2 Interarrival Time property to ‘5’ minutes.
Finally, add a Path between the input node of Server1 and the BasicNode1. This will allow the worker to move between the various tasks.
C hange the path’s Type property to ‘Bidirectional’.
Requesting the Worker for Transport Task
Within the output node of Source1 – Output@Source1, change the Transport Logic properties to reflect that a worker is needed to move the
entity from location to location. This is done by setting the Ride on Transporter property to ‘True’ and Transporter Name to ‘Worker1’.
Requesting the Worker for Stationary Task
Entities coming from Source2 will require the Worker for the inspection process, which will be done at BasicNode1. Within BasicNode1,
create a new process in the Entered Add-On Process Trigger named ‘BasicNode1_Entered’.
Within the Processes window, place a Decide step into the BasicNode1_Enterer process. This will be used determine whether the object
entering the node is the entity (coming from Source2) or the worker (coming to do the inspection). The Decide Type should be
‘C onditionBased’ and the Expression should be ‘Is.ModelEntity’.
In the True segment leaving the Decide step (which will be the ModelEntity objects), place a Seize step, Delay step, then Release step.
Within the Seize step, set the Object Name property to 'Worker1', the Request Move to ‘ToNode’ and the Destination Node to ‘BasicNode1’.
This will not only give control of the Worker to the entity by using the Seize, but will cause the Worker to move to the entity’s location at
BasicNode1.
Within the Delay step, change the Delay Time to ‘2’ and the Units to ‘Minutes’. In the Release step, set the Object Name to 'Worker1'.
In the False segment leaving the Decide step, there will be no additional logic. Only the token associated with the incoming Worker will be
coming out the False exit and no additional logic is required. However, we used the Decide so that the Worker would not also try to Seize
(itself) upon entry to the node.
Placing Parking Queues for the Worker
When Worker1 is not being utilized, it can be animated at its node location by placing a parking queue. In the Facility window, click on the
Animation tab and select Detached Queue. Place a queue by left clicking once to start the queue, dragging the mouse and left clicking
again to place the end of the queue. Right click to end the queue placement. The Queue State for the Source1 location should be
‘[email protected]’.
Parking areas should also be added to the Server 1 (‘[email protected]’) and BasicNode1
(‘BasicNode1.ParkingStation.InProcess’).
245 / 815
Simio Reference Guide
W orkerUsesW orkSchedule - SimBit
Problem:
I have a system where my worker is responsible for helping with operations at two different locations. The worker takes breaks and goes off-shift
based on a work schedule.
Categories:
Worker, Schedules / C hangeovers
Key Concepts:
Off Shift, On Shift, Request Move, ResourceState, Schedules, Secondary Resources, Worker, WorkSchedule
Assumptions:
There is one worker who is responsible who performs stationary tasks at two server locations. The worker goes on break at a different location.
Technical Approach:
The Worker will be responsible for helping processing at both Server1 and Server2. Add-On Process Triggers will be used to specify that the
Worker is required at node locations associated with the Servers. A Work Schedule will be defined to specify when the worker is On Shift and Off
Shift.
Details for Building the Model:
Simple System Setup
Add a Source, two Servers, and a Sink to the Facility window. C onnect the Source to each Server and also both Servers to the Sink with
Paths. Set the Allow Passing property on all paths to ‘False’.
C hange the Source1 Interarrival Time property to ‘10’ minutes. C hange the Server1 and Server2 Processing Time properties to
‘Random.Triangular(6,8,10)’. Keep all Time Units as ‘Minutes’.
Add a Worker object to the Facility window.
Add three BasicNode objects to the Facility Window. Place one directly below Source1, one directly above Source2 and the third one to the
right and middle of the other 2 BasicNodes. These will be used as the locations between which the worker moves. C onnect the three paths
in a triangle by using Paths and change the Type of each to ‘Bidirectional’.
Requesting the Worker for Stationary Tasks
Worker1 will be required at for processing at both Server1 and Server2.
Within Server1, enter the Secondary Resources / Resources for Processing section of properties and set the Object Name property to
‘Worker1’, the Request Move to ‘ToNode’ and the Destination Node to ‘BasicNode1’. This will not only give control of the Worker to the
entity, but will cause the Worker to move to BasicNode1.
Within Server2, do the same thing except set the Node Name to ‘BasicNode2’ so the Worker moves to the BasicNode2 node to process at
Server2.
Defining the Worker’s Work Schedule
Within the Data tab, Schedules panel, click on the Work Schedule button to create a new work schedule with the Name ‘Schedule1’.
C hange the Days to ‘1’.
Add a Day Pattern with the Name ‘DayPattern1’ and click the ‘+’ to enter the information for the day pattern.
Add four rows to reflect the on shift times, which will all have a Value of ‘1’. The times are 12:00 AM – 12:30 AM, 1:00 AM – 2:00 AM, 2:30
AM – 4:00 AM and 4:30 AM – 12:00 PM. All other times are assumed the capacity value of 0 or off shift.
IMPORTANT NOTE: With Worker object schedules, the Value field within the Day Pattern should be set at either 0 or 1 (but not greater than
1). This is because the capacity of the dynamic set of Worker objects is based on the Initial Number in System property defined within the
Worker. The work schedule is used to define only On Shift and Off Shift times for the ‘group’ of workers.
Back in the Work Schedule tab, select ‘DayPattern1’ for Day 1.
Defining the Worker’s C haracteristics
Within the Worker1 object, change the Capacity Type to ‘Work Schedule’ and the Schedule Name to ‘Schedule1’.
Within the Routing Logic properties, add an Initial Node (Home) property of ‘BasicNode3’. Worker1 will start out the simulation at this
location. When the worker is idle, it will stay where it is located, so set the Idle Action property to ‘Remain In Place’. When the worker goes
off shift, however, we will move it back to BasicNode3, so change the Off Shift Action to ‘Go To Home’.
Optional: C hanging Worker Animation Symbol
C hange the Current Symbol Index property of the worker (Animation) to ‘Worker.ResourceState’ such that the value of the worker’s
resource state will be used to animate the worker in various colors depending upon the state that it is in (i.e., Idle, Busy, OffShift, etc.).
The resource state values for a Worker are Idle = 0, Busy = 1, OffShift = 4, OffShiftBusy = 6, Transporting = 7 and OffShiftTransporting =
9. In this example, the worker doesn’t do any transporting, thus states Transporting and OffShiftTransporting are not used. Highlight the
Worker1 object and select the Add Additional Symbols button from the Symbols tab. To animate all possible states, there should be 7
symbols (numbered 0 – 6).
C hange the color of the various symbols to reflect the states by clicking on Active Symbol (1 of 7) and selecting the symbol to change.
Once the Active Symbol has changed, the C olor can be changed by selecting the appropriate color and then clicking on Worker1.
246 / 815
Simio Reference Guide
W orkerUsesW orkSchedule_InterruptW orkingO ffShift - SimBit
Problem:
I would like a Server and the secondary resource, a Worker, to stop processing an entity when the Worker goes off shift. When the Worker
comes back on shift, the Server and Worker will continue processing the interrupted entity for the remaining processing time.
Categories:
Add-On Process Logic, Schedules / C hangeovers, Worker
Key Concepts:
Add-On Process, Assign Step, C andidate, Interrupt Step, Math.If, Off Shift, Picture, Priority, Processing, Ranking Rule, Real State Variable,
Release Step, ResourceOwners, Save Remaining Time, Search Step, Secondary Resources, SeizedResources, Status Pie, Transfer Step, Token,
Token State, Worker, WorkSchedule
Technical Approach:
Entities are sent to one of two servers, and each server requires the worker to perform a process. Every 30 minutes, the worker goes off shift for
30 minutes. If the worker goes off shift while processing an entity, the process is interrupted, the entity priority is increased, and the entity goes
back to the server’s input buffer. When the worker goes back on shift, the unfinished entity is processed first for its remaining processing time
because it has the highest priority.
Details for Building the Model:
Simple System Setup
Place a Source, 2 Servers, a Sink, a Worker and 3 BasicNodes into the Facility window. Place BasicNode1 next to Server1, BasicNode2
next to Server2 and BasicNode3 between BasicNodes 1 and 2.
Using Paths, connect Source1 to both Servers and each Server to the Sink.
C onnect BasicNode1 to BasicNode2, BasicNode2 to BasicNode3, and BasicNode3 to BasicNode1 (creating a triangle). C hange the Path
Type property to ‘Bidirectional’ for each path connecting the three BasicNodes.
Place a ModelEntity object from the Project Library into the Facility window.
Within the Source, change the Interarrival Time to ‘10’ minutes.
Edit the Worker, change the Initial Node (Home) property to ‘BasicNode3’. C hange the Idle Action to ‘Remain In Place’ and the Off Shift
Action property to ‘Go To Home’. C hange the Ranking Rule property to ‘Largest Value First’ and set the Ranking Expression as
‘ModelEntity.Priority’.
C hange Server1 Ranking Rule property to ‘Largest Value First’ and set the Ranking Expression as ‘ModelEntity.Priority’. Also expand the
Secondary Resources property category, and in Resource for Processing set the Object Name property to ‘Worker1’. C hange the Request
Move to ‘To Node’ and the Destination Node to ‘BasicNode1’.
Repeat the above step for Server2, but set the Destination Node property to ‘BasicNode2’ instead of ‘BasicNode1’.
Work Schedules
Go to the Data Window and click on the Schedules View. C hange the first row Name on the Day Patterns tab to ‘DayPattern1’ and expand
DayPattern1. In the Start Time column set the rows as 12:00 AM, 1:00 AM, 2:00 AM,…,11:00 AM. Set all the rows in the Duration column to
’30 minutes’ and set the End Time column as 12:30 AM, 1:30 AM, 2:30 AM,…,11:30 AM respectively. The Value of the Worker C apacity
during these times is 1 (on shift), otherwise it is 0 (off shift).
C hange the first row Name on the Work Schedule tab to ‘Schedule1’, set the Days column to ‘1’, and set the Day 1 column to ‘DayPattern1’
.
C lick on the Worker1 object in the Facility window and change the Capacity Type property to ‘WorkSchedule’ and change the Work
Schedule to ‘Schedule1’.
ModelEntity
Within the Navigation window, click on ModelEntity. On the ModelEntity Definitions window, click the States panel and add a new State (type
Real) with the Name ‘RemainingProcessingTime’. C hange the Unit Type property to ‘Time’. This will be referenced as
‘ModelEntity.RemainingProcessingTime’ in the main model.
In the Model Facility window, change the Processing Time property of both Servers to ‘Math.If(ModelEntity.RemainingProcessingTime > 0,
ModelEntity.RemainingProcessingTime, Random.Triangular(16, 18, 20))’.
Add On Process Logic for Worker1
In the Definitions window, under the Tokens panel, click Add Token to add a new token called ‘MyToken1’. Add two Object Reference States
and call them ‘WorkerInstance’ and ‘ServerInstance’.
In the Processes Window, click C reate Process and rename the process ‘ResourceOffShift’. In the process logic do the following:
Open the process properties by clicking the white space in the process. In the Advanced Options, change the Token Class Name
property to ‘MyToken1’. This process will use MyToken1 instead of the base token so the two object reference states can be used.
Place an Assign step and set the State Variable Name property to ‘MyToken1.WorkerInstance’ and set the New Value to ’Worker’.
Place a Search step after the Assign step and change its Collection Type to ‘ResourceOwners’. This will search for the entity that
seized the worker for processing.
On the Found segment of the Search step, place another Search step. C hange its Collection Type to ‘SeizedResources’ and its Match
Condition property to ‘C andidate.Object != MyToken1.WorkerInstance’. This will search for the objects seized by the associated
object (the Entity) but only find objects that are not the Worker.
In the Found segment of the second Search step, place an Assign step and set the State Variable Name to
‘MyToken1.ServerInstance’ and New Value to ’Server’.
Place an Interrupt step after the Assign step. C hange the Process Name to ‘MyToken1.ServerInstance.Server.OnEnteredProcessing’
and under Advanced Options, set Save Remaining Time to ‘ModelEntity.RemainingProcessingTime’.
On the Interrupted segment place an Assign step. C hange the State Variable Name property to ‘Modelentity.Priority’ and the New
Value to ‘2’.
Place a Transfer step after the Assign step. C hange the From property to ‘C urrentStation’, the To property to ‘Station’ and the
Station Name to ‘MyToken1.ServerInstance.Server.InputBuffer’.
On the OK segment leaving the Transfer step, place a Release step. C lick the 3 dots on Resource Releases and add 2 Resource
Releases. In the first one, set the Object Name to ‘MyToken1.WorkerInstance’ and in the second one, set the Object Name to
‘MyToken1.ServerInstance’.
247 / 815
In the Facility window, select Worker1 and expand the Add-On Process Triggers property category. Set Off Shift to process
‘ResourceOffShift’. This process will be triggered whenever the Worker changes its state to OffShift.
Animation
Select the Entity and click the Add Additional Symbol button on the Symbols Ribbon to add a second entity picture. C lick the Active Symbol
button and select the symbol index 1. C lick the C olor dropdown and select Red. Then click the Entity Instance to turn the entity red.
Select a Server object and expand the Add-On Process Triggers property category. Add a process in Processing by double clicking the
name Processing. This automatically creates a new process and moves to the Processes Window. This new process will be triggered
whenever the Server starts processing.
Place an Assign step in the process and change the State Variable Name property to ‘Modelentity.Picture’ and the New Value to ’1’.
That will help to visualize the entity that is being processed and locate the interrupted entity when the worker goes off shift.
Add the name of the process created above to the other Server object in the Processing Add-On Process Trigger.
Add a Status Pie to the Facility window and change the Data Type property to ‘ListState’ and the List State to ‘Worker1[1].ResourceState’.
Also change its Text Scale to '0.75'.
In the Run ribbon, set the Speed Factor to '30'.
248 / 815
Simio Reference Guide
W orkstationW ithMaterialC onsumption - SimBit
Problem:
I have a machine that uses some material and produces some material and I’d like to model the usage and production of the material.
Categories:
Workstations
Key Concepts:
Bill of Materials, Material Element, Operation Quantity, OutputStatistic, QuantityC onsumed, QuantityProduced, Workstation
Assumptions:
The source only produces 20 arrivals. One bookshelf is created for every entity that enters the workstation and for each bookshelf that is
created, 8 nails are consumed and 2 pieces of wood. There are initially 100 units of wood and 400 units of nails.
Technical Approach:
A Workstation object is used and it consumes materials from a Bill of Materials. The Workstation object produces a material (bookshelf). The
number of bookshelves produced and the number of nails and pieces of wood consumed is recorded with an output statistic.
Details for Building the Model:
Simple System Setup
Place a Source, Workstation and Sink from the Standard Library into the Facility Window.
Update the Source to set the Maximum Arrivals property to ‘20’.
C reating the Bill of Materials
Open the Data Window and select the Elements panel. C reate four new Material elements by clicking on the Material Icon in the top ribbon
menu.
C hange the Name of the first material element to be ‘Wood’. The Initial Quantity should be set to ‘100’.
C hange the Name of the second to be ‘Nails’. The Initial Quantity should be set to ‘400’.
C hange the Name of the third material element to be ‘BookShelf’. The Initial Quantity is ‘0’.
C hange the Name of the fourth material element to be ‘BookShelfMaterials’. Add two rows to the BillofMaterial property – one for the
Material Name ‘Nails’, which should have a Quantity of ‘8’ and the other row for Material Name ‘Wood’, which should have a Quantity of ‘2’.
Generating Output Statistics
Also within the Data Window, Elements panel, create three output statistics by clicking on the Output Statistic icon.
The first output statistic can have the Name ‘BookShelvesProduced’ and the Expression should be ‘BookShelf.QuantityProduced’.
The second output statistic can have the Name ‘NailsUsed’ and the Expression should be ‘Nails.QuantityC onsumed’.
The third output statistic can have the Name ‘WoodUsed’ and the Expression should be ‘Wood.QuanityC onsumed’.
Defining the Workstation
Within the Facility Window, edit the Workstation object and change the Processing Batch Size property to ‘1’ and the Processing Time to
‘Random.Triangular(0.5,0.8,1.2)’.
Within the Materials and Other C onstraints section of the Workstation, open the Materials repeating property editor. Add one entry that has
Action Type set to ‘C onsume’, Consumption Type as ‘Bill of Materials’ and Material Name as ‘BookShelfMaterials’. The Quantity is ‘1’. Add a
second entry in which the Action Type is ‘Produce’, the Production Type is ‘Material’ and the Material Name is ‘BookShelf’. The Quantity is
‘1’ and the Production Delay Time in Advanced Options is ‘1.5’ minutes.
249 / 815
Simio Reference Guide
W orkstationW ithMaterialC onsumptionAndR eplenish - SimBit
Problem:
I have a machine that uses some material and produces some material, and I’d like to provide replenishment of the material once depleted, and
model this process. (Enhancement of WorkstationWithMaterialC onsumption.spfx).
Categories:
Workstations
Key Concepts:
Bill of Materials, Event, Material Element, Monitor, OutputStatistic, Produce Step, QuantityAvailable, QuantityC onsumed, QuantityProduced,
Workstation
Assumptions:
The source has infinite arrivals. One bookshelf is created for every entity that enters the workstation and for each bookshelf that is created, 8
nails and 2 pieces of wood are consumed. There are initially 30 units of wood and 60 units of nails. Each time wood is depleted, we replenish 40
of it; each time nails are depleted, we replenish 80 of them. Due to different replenishment policies, the lead time of replenishment for wood and
nails are different.
Technical Approach:
A Workstation object is used and it consumes materials from a Bill of Materials. The Workstation object produces a material (bookshelf). The
number of bookshelves produced and the number of nails and pieces of wood consumed is recorded with an output statistic. We use two Monitor
elements to watch Model States that keep track of the numbers of wood and nails remaining in the system. Each monitor fires an event when the
number of the material it monitors in the system goes below a certain threshold value, and then this event triggers the replenishment process for
this material.
Details for Building the Model:
Simple System Setup
Place a Source, Workstation and Sink from the Standard Library into the Facility Window. C hange the Interarrival Time of the Source to be
‘Random.Exponential(1.0)’.
C reating the Bill of Materials
Open the Data Window and select the Elements panel. C reate four new Material elements by clicking on the Material Icon in the top ribbon
menu.
C hange the Name of the first material element to be ‘Wood’. The Initial Quantity should be set to ‘30’. C hange the Name of the second to
be ‘Nails’. The Initial Quantity should be set to ‘60’. C hange the Name of the third material element to be ‘BookShelf’. The Initial Quantity is
‘0’. C hange the Name of the fourth material element to be ‘BookShelfMaterials’.
Add two rows to the BillofMaterial property – one for the Material Name ‘Nails’, which should have a Quantity of ‘8’ and the other row for
Material Name ‘Wood’, which should have a Quantity of ‘2’.
C reating the Monitor Elements
Open the Definitions Window and select the Elements panel. C lick on the Monitor icon in the General Ribbon group. The Monitor Type is
‘C rossingStateC hange’ and the State Variable Name is ‘Wood.QuantityAvailable’. The Threshold Value is ‘10’ and the Crossing Direction is
‘Negative’. This monitor will fire an event named ‘Wood_Monitor_OnEventProcess’ whenever the state variable crosses from 10 to 9.
Add a second Monitor element which is very similar to the first. The differences with this monitor are that the State Variable Name is
‘Nails.QuantityAvailable’, the Threshold Value is set to ‘20’ and fired event name is ‘Nails_Monitor_OnEventProcess’.
Process of C reating Replenishment
Go to the Processes Window. There will be two processes: ‘Wood_Monitor_OnEventProcess’ and ‘Nails_Monitor_OnEventProcess’ shown in
this window.
For the process ‘Nails_Monitor_OnEventProcess’, place a Delay step in the Process. The Delay Time is ‘0.5’, and the Units is set to ‘Minutes’.
Then place a Produce step in the process. The Production Type is ‘Material’, Material Name is ‘Nails’, and the Quantity is ‘80’. This process
will be executed when the remaining quantity of Nails is below 20, and then the process will delay for 0.5 minute as the delivery lead time,
and replenish 80 Nails.
For the process ‘Wood_Monitor_OnEventProcess’, it’s very similar to the first process. The differences are the Delay Time for Delay step is
set to ‘2’; within the Produce step, the Material Name is ‘Wood’, and the Quantity is ‘40’.
Generating Output Statistics
Also within the Data Window, Elements panel, create three output statistics by clicking on the Output Statistic icon.
The first output statistic can have the Name ‘BookShelvesProduced’ and the Expression should be ‘BookShelf.QuantityProduced’.
The second output statistic can have the Name ‘NailsUsed’ and the Expression should be ‘Nails.QuantityC onsumed’.
The third output statistic can have the Name ‘WoodUsed’ and the Expression should be ‘Wood.QuanityC onsumed’.
Defining the Workstation
Within the Facility Window, edit the Workstation object and change the Processing Batch Size property to ‘1’ and the Processing Time to
‘Random.Triangular(0.5,0.8,1.2)’.
Within the Materials and Other C onstraints section of the Workstation, open the Materials repeating property editor. Add one entry that has
Action Type set to ‘C onsume’, Consumption Type as ‘Bill of Materials’ and Material Name as ‘BookShelfMaterials’. The Quantity is ‘1’. Add a
second entry in which the Action Type is ‘Produce’, the Production Type is ‘Material’ and the Material Name is ‘BookShelf’. The Quantity is
‘1’ and the Production Delay Time in Advanced Options is ‘1.5’ minutes.
Embellishments:
We can add some animation, to show the current remaining number of materials while we’re running this model.
C hoose Status Plot from Animation under Facility Tools, create a Status Plot, with the name ‘Material Available’, then set the X Axis label to be
‘Time’ and the Y Axis label to be ‘Pieces’, and change the time interval shown on the X Axis to be ‘30 minutes’.
Then click on the plot, go to Properties Window, add 2 rows in the Additional Expressions. One row has the Expression set to
‘Nails.QuantityAvailable’, and the Label set to ‘Nails’. The other row has the Expression set to ‘Wood.QuantityAvailable’, and the Label set to
‘Wood’. Then we’ll have two animation lines within the plot, one represents the number of remaining nails and the other one represents the
250 / 815
‘Wood’. Then we’ll have two animation lines within the plot, one represents the number of remaining nails and the other one represents the
number of remaining wood.
251 / 815
Simio Reference Guide
W orkstationW ithSequenceDependentSetup - SimBit
Problem:
I have a Workstation that requires a certain setup time based on which entity type needs to be processed.
Categories:
Workstations
Key Concepts:
C hangeovers, List Property, Sequence Dependent, Status Pie, StringList, Time Offset, Workstation
Assumptions:
Each source only produces one type of entity. The model will complete its run faster if the Workstation processes all entities of one type before
changing over to process entities of another type.
Technical Approach:
A String List is created in the List panel of the Definitions window for the ModelEntity. A List property is defined in the Model Entity’s Definitions
window, Properties panel. A Workstation with a Sequence Dependent setup time is used and a C hangeover matrix defines the various setup
times. A Time Offset will be used to demonstrate the impact of setup times.
Details for Building the Model:
Simple System Setup
Add two Sources, a Workstation and two Sinks to the Facility Window. C hange the Interarrival Times of the Sources to ‘0.1’ minutes and
the Maximum Arrival of each Source to ‘10’. Also set the Time Offset property of one of the Sources to ‘5’ minutes.
C onnect the Sources to the Workstation and the Workstation to each Sink with Paths.
Adding a String List
C lick on the Definitions tab and select the Lists panel to add a String List named ‘C olors’. Add as many colors as desired. Be sure to add
this same String List to the Lists within the Definitions tab of the Model.
Adding a List Property
Within the Definitions Window of the ModelEntity, select the Properties panel and add a List Property with the Name ‘C olor’.
Set the List Name property under Logic to ‘C olors’ and the C ategory Name property under Appearance to ‘Properties’. This will give the
user the option to specify C olor as a property of an entity and the list of C olors will be shown as options.
C reating a C hangeover Matrix
In the Data Window, select the C hangeovers panel. C reate a C hangeover Matrix and change the Name to ‘C leaning’. C hange the List
Name property to be ‘C olors’.
Fill in the matrix with desired values or follow the example: (Note: these values will be in Hours):
ChangeOver Matrix Inputs
252 / 815
Simio Reference Guide
W ritingT oAFile - SimBit
Problem:
I’d like to write values to a file during the run.
Categories:
File Management
Key Concepts:
Assign Step, Event, File Element, Monitor, Write Step, Write Step
Assumptions:
This model writes to a .csv file.
Technical Approach:
This model has a state variable that keeps track of the number of entities in the queue for Server 1. A monitor watches this variable and writes
the value of the variable and the current simulation time to a .csv file every time the value of that variable changes.
Details for Building the Model:
Simple System Setup
Add a Source, Server and Sink object to the Facility Window.
C reating a New State Variable
C reate an Add On Process that is triggered when an entity enters the Input Buffer of the Server.
Add an Assign Step to this process and in the State Variable drop down, select C reate New.
Name the new state variable ‘ServerQueue’.
The New Value property should be set to ‘ServerQueue + 1’.
C reate an Add On Process that is triggered when an entity hits the Processing station of the Server.
Add an Assign Step to this process and select ‘ServerQueue’ as the State Variable.
The New Value property should be set to ‘ServerQueue – 1’.
C reating a Monitor Element
C reate a new Monitor Element from the Definition Window’s Element panel. The Monitor Type is ‘DiscreteStateC hange’ and the State
Variable should be set to ‘ServerQueue’.
C reating a File Element
While in the Elements panel, create a new File Element from the User Defined ribbon icon. Set the FilePath to a location where you have
permission to create a new file. The example uses the file name ‘WritingToAFile.csv’.
Adding Logic to the Model
In the Processes Window, add a new process by clicking the C reate Process icon in the ribbon.
Set the Triggering Event for this new process to be ‘Monitor.Event’ – where “Monitor” is replaced with the actual name of your
Monitor element.
Add a Write Step to this process. It can be found in the User Defined Steps. Select the new File element that was created. Add two
items to the Items property. The first item should be the ‘TimeNow’ function, which gives the current simulation time. And the
second item should be the ‘ServerQueue’ state variable.
The format property is set to ‘{0}, {1}’. The {0} is replaced with the value of the first item, in this case, ‘TimeNow’. The {1} is
replaced with the value of the second item, in this case, ‘ServerQueue’. The values are written to the file each time the Monitor
element fires its event, which is each time the value of ServerQueue changes.
253 / 815
Simio Reference Guide
Sample SimBit Solutions
Basic Search
The Basic Search a general search that allows the users to search categories, Simbits name and Simbits related keywords and descriptions at the
same time. The user can enter any word or set of words in the search field. The search engine will look for all the Simbits that contain the
word(s) within its keywords, categories or description.
Advanced Search
The Advanced Search is a more refined search that allows the users to look up Simbits by filtering on one category and up to three keywords.
The C ategory field includes twenty four (24) different general areas under which a SimBit may be classified. Some SimBits are shown under
multiple categories. The main SimBits help page shows the various categories and the SimBits within them. The three Keyword fields include
more than 250 words that may be used to find a specific modeling concept or Simio step, function or property.
The default behavior searches the SimBits for the Category AND [Keyword1 OR Keyword2 OR Keyword3] specified. A User may choose not
to enter a category and only search by one or more keywords. This is accomplished by leaving the category field blank.
The “Require all keywords (and)” button allows for “AND” logic search that will list the results of searching for Keyword1 AND Keyword2 AND
Keyword3. Thus the default search logic is replaced by Category AND [Keyword1 AND Keyword2 AND Keyword3]. The search engine will
ignore any empty fields when performing the search, be it a keyword or category.
The 'Reset' button to the right of the keywords will reset all keywords and the category to blank fields.
In the following example, the C ategory is 'Decision Logic -- Processing' and two keywords are used 'Add-On Process' and 'ResourceState'. This
will search only the SimBits within the specified category looking for either of the the keywords specified. If the “Require all keywords (and)”
button was on, the search would require both the 'Add-On Process' and 'ResourceState' keyword to be in the SimBit's description, name and/or
key concepts section.
254 / 815
Search Results
The number of SimBits found by the search is displayed in the Search Results section. Note that even if a SimBit is displayed in multiple
categories, it is only counted as a single SimBit found.
The user is given the option of displaying the list of results by C ategory or Simbit Name. When displaying the results by C ategory, some simbits
will be displayed more than once as one SimBit can be classified under different categories. The name of the SimBit is listed, along with the
general description. Additional information, including the categories, keywords and general description of the SimBit are also shown.
255 / 815
Simio Reference Guide
Examples
An Example is a complete Simio model that illustrates how to use Simio. Each example has description that explains the details of the model
within a *.pdf file that will open automatically when the example is loaded. The example *.spfx files can be found in [public
documents]\Simio\Examples.
Below is a list of the Examples.
AirportTerminal
C laudesPizza
HospitalEmergencyDepartment
ManufacturingAssembly
MiningExample
PackagingSystem
SchedulingBatchBeverageProduction
SchedulingBicycleAssembly
SchedulingDiscretePartProduction
WarehouseExample
Note that the SchedulingDiscretePartProduction (formerly named RPSExample) and other scheduling examples were developed in Simio
Enterprise Edition. On-line help is available on all Simio Enterprise features discussed in Scheduling examples within the Scheduling in Simio
Enterprise help sections.
There is a folder within the [public documents]\Simio\Examples area named ProcessImprovementPrinciples. This folder contains 22 small
models that correspond to the Process Improvement Principles discussed in the book that is available through the Support ribbon, Books section.
256 / 815
Simio Reference Guide
AirportT erminal - Example
General Description
This model represents an Airport Terminal. The general process flow is as follows:
Passengers enter the airport
Passengers move to one of three check-in areas (2 self check-in and 1 full service counter)
Passengers move into security check
Bags are ‘separated’ from passengers and continue through xray
Passengers go through xray area
Bags and passengers are reunited
Passengers move to one of two large waiting areas for plane departure
* This example includes an ‘Experiment’ that utilizes input variables to run various configuration scenarios.
Detailed Description
Model Properties
Within the model’s properties, there are 4 options that can be set, including the number of self C heckinKiosks, C heckInC lerks, IDC hecks and
ScannerStations. These 4 properties can be varied within the experiment to evaluate various scenarios. Additionally, the value of these properties
may change the logic within the model itself.
In addition to the 4 visible properties discussed above, there are a number of hidden properties (Visible property set to ‘False’) that are used to
track the costing information. These are used in the calculations for the C ost, Revenue and Profit output statistics for the simulation model.
Passenger Arrival
Two sources create passengers into the airport – one (EarlyPassengers) that creates 20 groups of between 1-3 to start up the system, the other
(Entrance) on an arrival rate basis. Passengers move with their bags from the entry doorway to one of three areas – two self checkin areas (with
up to 4 servers each) and one full service counter (with up to 3 checkin clerks).
As the passengers enter the airport, there are three paths. The selection weight on the two of the paths is based on the value of the properties
for C heckInKiosks and C heckInC lerks. The value of IDC heck passes directly into the capacity of the IDC heck server. The ScannerStations
capacity (1 or 2) will turn on/off the path that is leading to the second scanner station. This is done through an add on process for the path and
will turn the direction to ‘none’ if there is only a single scanning station to prevent passengers from entering that path.
Security Area
Upon creation of the passenger, a bag was created and they were batched. After checkin, all passengers move to the security area, where they
are moved through one of two xray areas. Bags are ‘separated’ from the passengers and continue through their own xray process. A separator is
used at the scanners to split the passenger and his/her bag. Bags and passengers are reunited after the xray processes. Batch steps at the end
of the scanners for both parent and member are used.
Plane Departure Waiting Areas
The passengers ‘wait’ in the two large waiting areas for a plane. Timer elements are used to schedule plane events, causing the passengers to
leave the waiting area once the event occurs.
Experiment
This example is unique in that it has a defined experiment that includes 4 controls and 3 responses. The controls are the properties discussed
above and include the capacities for the main resources within the model. The responses include the costing information related to those
resources and are calculated based on the number of each of those resources.
257 / 815
Simio Reference Guide
C laudesP izza - Example
General Description
This model represents a Pizza by the slice restaurant. The general process flow is as follows:
Group of customers enter the restaurant
Individual customer places an order
C ustomer pays for order
Employee places slices in the oven to reheat
C ustomer waits for Pizza to come out of the oven
Once reheating is complete the customer waits for the rest of the group (or joins waiting group)
Group sits down at table (or waits for an available table)
Group eats pizza
Throws away trash at the trash can
Leave restaurant
*When the Trash C ans have 15 or more Dirty Trays, an employee will collect them and bring them back to the counter.
Detailed Description
C reating Unique Individuals in Groups
Groups enter the restaurant, each group consists of 1 to 4 customers, and each customer will order 1 to 3 pieces of pizza. Upon entering the
restaurant (Before Exiting the Source) we assign C ustomerEntity.GroupSize, C ustomerEntity.GroupNumber, C ustomerEntity.EatingTime, and
C ustomerEntity.Picture. Then, in the Output@Source Node we create a process that creates the rest of the group via a C reate step set to C reate
C opies. We then re-assign a Picture so they are not the same throughout the group. This process allows the group to have the same values for
the GroupSize, GroupNumber, and EatingTime which all come into play later in the model. Then, at various points in the model we assign State
values for the number of pieces of pizza and if the customer is considered a parent. By C reating C opies before assigning these States, we allow
some parts of the entities to be the same, and others to differ.
C reating the Pickup C ounter Object
After the Pizza has been taken out of the oven, the pieces go onto a Tray according to the State TrayEntity.OrderSize that is based off the state
C ustomerEntity.Ordersize (which is assigned when the customer enters the Path leading to the C ash Register). Then the customer carries the
Tray (that is carrying the Pizza) to the Table. This can be done using 2 C ombiner Objects, or in this model we made one simple object that
combines all three Entities.
There are three Entities that are going to enter this object with two separate Batch Logic Elements that are to be used to join the Entities together
- first the Pizza gets batched to the Tray, then the Tray gets batched to the C ustomer. The PickUpC ounter Object uses Station Elements to do the
batching, each Station is designed to do a portion of the batching.
There are 3 Input Nodes: one for Tray, Pizza, and C ustomer. Each one of these nodes corresponds to an InputBuffer where the object waits for
the corresponding Parent/Member for its batch logic. After the Tray and Pizza are combined, the pair is transferred to an intermediate station
where it attempts to Batch the Pizza/Tray as a Member with the C ustomer. After everything is batched together, the C ustomer is transferred to
the OrderFulfilled node.
C reating the Trash C an Object
The Trash C an is Similar to the C ounter except it was created using Standard Library Objects instead of processes. The trash can consists of 2
separators, the first one separates the customer from the Tray and Pizza, and the second separates the tray and pizza – with the pizza going into
a Sink to destroy it.
Then, we defined an external view with one input node and 2 output nodes: one for the customer that leads to the Exit, and one for the tray which
(in the model) is set to RideOnTransporter = True so that the worker can come pick up the waiting trays.
C reating the Table Objects
After the group is together (leaves the WaitForGroup C ombiner), the group is routed to an available table. After routing to the table, the group is
Unbatched so that they can each sit in their own seat at the table. One difficulty is that if the group is smaller than 4 members, there is still
remaining capacity at the table and some groups could be routed to the table even though it is technically occupied. This requires some add-on
processes to a standard Server Object. To avoid having to create add-on processes at each table, we created a new table object.
This object consists of two stations, SplitStation and EatingStation. When the SplitStation is entered, we Unbatch the group and transfer the
Parents and Members to the EatingStation. After the transfer we assigned the SplitStation.C urrentC apacity to 0 – this means that the table is no
longer considered available and no customers can be routed to this table, even if there is available capacity.
Then, after Delaying for EatingTime, we assign the C apacity of the SplitStation back to its original value, signifying that the table is available for
new customers.
258 / 815
Simio Reference Guide
HospitalEmergencyDepartment - Example
General Description
This model represents a small Emergency Department (ED) consisting of a waiting area, a registration desk, a triage room, a radiology station, a
billing area, 6 beds and 6 rooms that are used for patients that are admitted into the hospital.
Patients enter the ED through the front door entrance and go directly to the registration desk. After they are registered, they wait in the waiting
area to be sent to the triage room. After they are seen in the triage room, they wait in the waiting area for an available bed. When a bed and a
nurse are both available, the nurse greets the patient and walks them to the bed. The patient waits in the bed for an available doctor, who is
accompanied by a nurse. They finish treating the patient and the patient either visits billing before exiting the ED or is sent to the Radiology room.
If a patient is seen at Radiology, they are either sent to billing and then sent home, or admitted into a room for a longer stay. Once admitted into
a room, the patient is again visited by a doctor and a nurse and then released to billing and then home.
Patients also enter the ED from an ambulance. The ambulance can carry up to 2 patients . They arrive at the emergency entrance and are
greeted by a nurse who will walk them directly into a room. After being treated by a doctor, an emergency patient will either visit billing or the
Radiology department.
There are a number of statistics collected in this model. The details of these statistics are discussed below. The Facility window contains two
different floor labels with statistics and the C onsole window contains floor labels, status pie charts and status plots.
A small experiment can be used to vary the number of nurses, the number of doctors and the number of radiologists to see the impact on
Average Wait Time for Doctor, Number of Patients in System and Average Length of Stay.
Detailed Description
System Initialization
The system does not begin empty. It is initialized so that there are patients in the system at the beginning of the model run. This is controlled by
a process called “OnInitialization” which is executed when the main model is first initialized. This process searches a Data Table called
'Initialization' and uses the content of this table to create a set number of patients, with certain priorities and place them in a specific location
(station) within the model. This is done with the combination of a Search step, C reate step, Assign step and Transfer step.
Patient Arrivals
The large main door is the Source of the main arrivals of patients. This Source uses a Rate Table to determine the rate of arrivals into the
system. The Source also references a Data table named 'PatientPriority' which determines the type of patient to create and therefore which
symbol to display for the entity.
Arrivals are created for the Emergency entrance from a Source that can be found off on the “road” to the side of the ED near the ambulance. This
Source also references the PatientPriority table to assign a priority to a patient. There is an Add-On Process on this Source that checks to see if
all the Rooms are full after the patient is created. If there is no room in this Emergency Department for this patient, a state variable is
incremented to keep track of the number of Diversions from this hospital and then this patient is destroyed and not sent into the ED. But for most
patients created, they request a ride on the ambulance vehicle and are dropped off at the emergency entrance where they are met by a nurse
who walks them to a room.
Registration, Waiting Area and Triage
The registration desk is a standard Server with Initial Capacity of '3'. After the patients are registered, they visit the Server named
'WaitingAreaBeforeTriaged', which has the symbol of a set of waiting rooms chairs. They visit Triage when it is available and then sit at the Server
named 'WaitingArea_PostTriaged' until a bed and nurse are available. The nurse arrives to walk the patient to the bed. The nurse is a standard
Worker object that is requested in the TransferNode 'ToBeds', by a patient.
Beds, Rooms, Radiology and Billing
A Bed is an object that is part of the Project Library. It is a subclassed version of the standard Simio Server object. It has a custom symbol for its
External View, some custom logic to change the current symbol of the bed and a custom State that helps track the time a patient waits in this bed
for a doctor to visit. Each of the 6 instances of the Bed, has 5 possible symbols that can be displayed; one empty bed and one bed filled with each
of the 4 different patient types. The expression in the C urrent Symbol Index property of each Bed determines what symbol is currently displayed.
Each instance of the Bed also has requests a Doctor to visit using the Resource For Processing section of the Secondary Resources properties.
The Before Processing property in the Other Resource Seizes properties requests a Nurse to visit this bed. Once the Doctor and the Nurse arrive,
the processing begins at this Bed and then both the Doctor and Nurse are released. Link Weights on the Paths leaving the output node of each
Bed determine the percentage of patients that visit Radiology vs Billing.
A Room object is very similar to a Bed object, with a different External View symbol. Patients are only routed to a Room if they are sent there
after visiting Radiology or if they arrive through the Emergency entrance.
The Radiology department is a standard Server object, with the capacity referencing a property. The default value of this property is 1, but the
user can vary the capacity of this object through the Experiment because it is referencing a property. See the Experiment section below for more
details on this.
The Billing desk is a standard Server object. All patients leaving the Billing desk travel to the front door and exit the system.
Statistics
The following statistics are collected and displayed in the Facility window. Utilization statistics, status charts and plots can be found in the C onsole
window (Definitions tab, C onsole panel). The Math.Round function is used within the floor labels to truncate display of real numbers to a single
decimal point.
Average Wait Time to See Doctor: The wait time is calculated with a Tally Statistic on the Bed object and this overall value is found by
taking an average of the wait times of all the beds.
Number of Patients Admitted: This is calculated with a Tally Statistic that records the number of patients that are admitted into a Room.
Percentage of Beds and Rooms Occupied: This is calculated with a State variable that tracks the number of Beds and Rooms occupied
at the current time.
Number of Diversions From Hospital: This is calculated with a State variable that tracks the number of times that a patient wanted to
enter the ED through the Emergency entrance but could not visit this hospital because all the Rooms were full.
Average Number of Patients in System: This is a function on the ModelEntity, named Population.NumberInSystem.Average
Average Wait Time for a Bed (min): This is calculated with a Tally Statistic that records the amount of time that a patient waits for a
Bed.
Average Length of Stay (min): This is calculated with a Tally Statistic that records the amount of time that a patient is in a Bed or a
Room.
259 / 815
Total Leave Without Being Seen (LWBS): This is calculated with a State variable that tracks the number of patients who arrive in the
main entrance but leave because the waiting area is too full or the average wait time is too long.
Experiment
An Experiment exists on the main model that varies the input of three C ontrols; 'Number of Nurses', 'Number of Doctors' and 'Number of
Radiologists'. These controls appear in the experiment because they are all properties on the main model. The 'Number of Nurses' property is
referenced from the Initial Capacity property on the Nurse Worker object. The 'Number of Doctors' property is referenced from the Initial
Capacity property on the Doctor Worker object. And the 'Number of Radiologists' property is referenced from the Initial Capacity property on the
Radiology object.
There are three Responses defined in this experiment. 'Average Wait Time For Doctor' contains the expression that determines the average wait
time for a doctor across all the beds. 'Number of Patients in System' contains the expression, 'Patients.Population.NumberInSystem.Average'.
And 'Average Length of Stay' contains the expression 'LengthOfStayStatistic.Average * 60', which references the Tally Statistic that tracks this
duration.
Selecting the 'Average Length of Stay' Response will show that this Response has its Objective set to 'Minimize' so that the OptQuest Add –In
knows to create scenarios that will best minimize the value in this Response.
260 / 815
Simio Reference Guide
ManufacturingAssembly - Example
General Description
This model represents an assembly line manufacturing Lamps. The general process flow is as follows:
Pallets containing lamp bases are withdrawn from inventory by a fork lift
Individual lamps bases are sent to preparation (Prep)
Lamps bases and shades are assembled
Lamps are sent to repair if any defects are detected
Finished lamps are packaged
Packages of lamps are shipped randomly through 2 docks
Detailed Description
Model States
This model has two defined model states – 'NumberInPrep' and 'TotalShipped'. These states are meant to respectively track the number of lamps
bases in preparation and the total number of assembled lamps shipped.
Lamps bases Arrival
Lamps bases are withdrawn from two inventories which are modeled as sources. On the model initialization, the lamp bases are taken from
inventory 1. During the model run, if the the number of lamps bases in Prep is less than 2 the lamp bases are randomly created at either
inventory 1 or 2. This is modeled through the use of a Monitor element on the 'NumberInPrep' state variable with a Threshold Value of '2' and a
'Negative' Crossing Direction. When this threshold value becomes less than 2 (i.e 1) the monitor will fire an Event triggering Process1 to create
new bases at the inventories.
Pallets Discharge
Each pallet holds 10 lamp bases. The pallet’s contents are emptied at the Separator object at the beginning of the line. The bases are sent down
the C onveyor while the pallets are taken to a storage rack that is represented with a Sink.
Lamps Bases Preparation
The number of lamp bases in preparation is tracked through a user defined state that is incremented and decremented respectively as lamps
bases enter and leave the Prep server. After preparation, the lamps bases are randomly sent to one of the two existing combiners.
Lamps Assembly
The lamps shades are generated by two sources each linked to a combiner. Each base is combined with one shade. The lamp base represents the
combiner parent while the lamp shade represents the combiner member.
Lamps Packaging
All lamps assembled at C ombiner2 go directly to packaging. 70% of lamps assembled at C ombiner1 are sent directly to packaging, while the
remaining 30% are taken by the repair staff to the RepairStation. After the lamps are repaired, the repair staff takes them to packaging.
Lamps Shipping
After the packaging, the assembled lamps are randomly taken by the DockResource to one of the two available docks that are modeled as Sinks.
The random selection is enforced through the use of a 'Random' Selection Goal at the output node of the packaging server where the Entity
Destination Type is set to 'Select From List' and the Node List Name is a list containing the docks’ input nodes.
Useful Tips
Note the use of processes to change the appearance of the entity after each station
At the separator member output node to model the lamp bases
At the separator parent output node to model the pallets
At the combiners output to model the assembled lamps
At the packaging output node to model the ready to ship package
261 / 815
Simio Reference Guide
MiningExample - Example
General Description
This example represents an ore mine. The general process flow is as follows:
Ore is extracted from three different C hutes.
A MineTrain will pick up the ore and drop it off at the Dump.
Three MineTrains are available and will pick up ore according to when the ore was created.
* A two scenario experiment is used with two distinct values of the control 'OverallHoursBetweenLoads'.
Detailed Description
Ores Extraction
The ores are extracted from three different chutes modeled as sources. Each source’s interarrival time is defined as an expression using the
property 'OverallHoursBetweenLoads'. Each created entity is assigned a priority based on the time it was created through assigning the New
Value to 'Run.TimeNow'.
All resources output nodes Entity Destination Type are set to 'Input@Dump' so that all the entities are dropped off at the dump.
Ores Transportation
Three mine trains are available for the transportation of the extracted ore. The trains are modeled as a Vehicle with an Initial Number in System
equals to '3'. The trains Transport Logic Task Selection Strategy is based on 'Smallest Priority'. Because the Ore’s priority was set to the time it
was created, the trains will pick up the ore in the order it was created.
Bypass Siding
Because the Bi-Directional track only allows traffic moving in one direction at a time, we must make use of a bypass area to allow for passing.
This area consists of a separate track for each direction of traffic. It allows for the train to exit the bi-directional portion of the track and park
temporarily to avoid another train moving in the opposite direction. If this section were not there, then the trains would collide and it would result
in a deadlock.
*Please see the SimBit ‘BidirectionalPaths’ for a more detailed description of bypass sidings.
C ustom Statistics
The 'TimeBetweenLoads' is a user defined Tally Statistic to track the time between loads at the dump. A Tally step is used where the Value Type is
assigned to 'TimeBetween' to record the time between loads arrival to the dump.
Useful Tips
The Network Turnaround Method for the MineTrain vehicle has been set to 'Reverse' to allow for the train to reverse while on the path – as
opposed to exiting and re-entering the path in a forward direction.
262 / 815
Simio Reference Guide
P ackagingSystem - Example
General Description
This model represents a packaging system. The general process flow is as follows:
Four types of products are created.
Products are transported on conveyors.
Pallets are transported from the Pallet Supply to the palletizer through a conveyor.
The packaging is done at the palletizer.
Packages are transported through a conveyor for shipment.
Products
Four Sources create four types of products each flowing on a separate conveyor. The merging takes place in three stages.
The Soda and Toy products merger
Grab Bags and Golf C lubs merger
C omplete merge of the four products at the merging zone
After the last merger, the products continue their way to the Palletizer on a conveyor.
Pallets
The Source PalletSupply creates pallets that are transported to the Palletizer through a Power and Free Monorail that is modeled as a C onveyor.
The conveyor travel logic Entity Alignment is set to ‘C ell Location’ to represent the hooks position along the conveyor.
Palletizer
Packaging is done at the Palletizer which is modeled using a C ombiner. In this model, products represent the C ombiner members while the pallet
represents the C ombiner parent. A Pallet holds six products.
Shipping
Pallets are transported through a C onveyor to the Shipping station where they get destroyed. The Shipping station is modeled as a Sink.
263 / 815
Simio Reference Guide
SchedulingBatchBeverageP roduction - Example
General Description
This example uses Simio Enterprise Edition to schedule a batch processing system that mixes and fills a beverage product. Although Simio
Enterprise Edition is required to build this model, it may be viewed using Simio Design or Team Edition.
To understand the data schema and scheduling results in this example you should first read the Simio Scheduling Overview document. This
problem description assumes that you are familiar with the standard data schema and scheduling concepts that are presented in that document.
In this example, we wish to generate a 30-day production schedule for this facility that fully accounts for the limited resources in the system. This
example contains orders for both manufactured material and finished material. Raw materials are also modeled as a constraint in this system.
The manufactured materials, named Green Bulk, Red Bulk and Blue Bulk, must be mixed at a mixing machine and then put into a Tank. The
finished good materials, such as Green Pack, Red Pack and Blue Pack, begin at a Filler machine and are then packed at a Packing machine.
Workers are required at each of these steps in the process and the appropriate manufactured material must be available in the Tanks in order for
the finished goods produce to be processed. Raw materials, such as bottles and labels, are also modeled in this system and are required as part
of the finished goods filling process.
Detailed Description
System Initialization
The system does not begin empty. It is initialized with a few orders already in the system and having completed a portion of their processes.
These orders are listed in the table named WorkInProcess, which also indicates the current step in the routing, the quantity that has already been
completed and any cost that has been accrued up to this point in time. The ‘Initialized’ process is executed when the run begins. This process
searches the ManufacturingOrders table and then the WorkInProcess table and uses the content of this table to create entities that represent the
work orders listed in this table and places them in the appropriate location within the model, based on the C urrent Resource listed. This is done
with the combination of Search steps, a C reate step, Assign steps and a Transfer step. This Initialize process also searches the
ManufacturingOrders table to find any orders where the release date is prior to the current start date of the model and when it finds these orders,
it creates entities representing the order and sends them to the output node of the MOArrivals source object.
Arrival of Manufacturing Orders
The MOArrivals source creates Mo type entities, which represent manufacturing orders. This source produces arrivals according to the
ReleaseDate column in the Manufacturing Orders table, for all orders with the Order Status of 'New'.
Manufactured Material (GreenBulk, RedBulk, BlueBulk)
If an order is a manufactured material, it will first route to a Mixing machine and then to a TankFill machine, as outlined in the Routings table. The
transfer node named Mixing uses a C ustom Routing Group to decide to route the entity to either Mixing1, Mixing2, or Mixing3. The C ustom
Routing Group is set to a Referenced Property so that a user can experiment with using different routing rules. By default, this Mixing Rule
property is set to ‘MixingMinSetupRoutingGroup’ which will route the entity to the Mixing machine that will result in the least amount of setup time.
C ustom Routing Group elements are defined in the Definitions window. It is at this transfer node where the entity checks to see if the raw
materials that are required to be consumed at the Mixing workstation are available. If they are not available, the entity will wait here at the
Mixing transfer node, instead of waiting at the Mixing workstation.
Once the materials are available, they can be selected to be run on a Mixing workstation. The Mixing TransferNode uses a Route Request
Dynamic Selection Rule determine the sequence of jobs for Mixing1, Mixing2 and Mixing3. The Route Request Dynamic Selection Rule is set to a
Referenced Property so that a user can experiment with using different routing rules. By default, this Mixing Selection Rule property is set to
‘Standard Dispatching Rule’ which has a number of child properties. For the Standard Dispatching Rule, the Dispatching Rule property is set to
LeastSetupTIme and the Tie Breaker Rule property is set to EarliestDueDate. Using these Standard Dispatching Rule properties, entities will be
selected based on least amount of setup time on a Mixing workstation. If more than one entity has the same least setup time, the entity with the
earliest due date will be selected.
Before Setup occurs at each Mixing workstation, the process AddManufacturingOrdersOutput adds a row in the table named
ManufacturingOrdersOutput and records the start time of this order on this mixing machine. The endtime is recorded after this order is finished on
this Mixing workstation and it has seized capacity of a Tank. This seize step is found in the Mixing_Teardown process on each Mixing workstation.
The order will route to the TankFill transfer node, where it will select to route to either the TankFill1 or TankFill2 workstation by selecting from the
node list ‘TankFillList’. Similar to what occurs at the Mixing workstation, before Setup occurs at each TankFill workstation, the process
AddManufacturingOrdersOutput adds a row in the table named ManufacturingOrdersOutput and records the start time of this order on this
TankFiller machine. The endtime is recorded after this order is finished on this TankFiller workstation. After the order is completed at the
TankFiller, it is routed to the server named HoldingTankStorageServer where it waits until it is needed by an entity at the Filler machine. At that
point, the entity representing this manufactured material order will get transferred to the DisposeBulkOrders sink, where the current time and
cost is recorded in the Manufacturing Orders table for this manufactured material order.
Finished Material (GreenPack, RedPack, BluePack)
If an order is a finished material, it will first route to a Filler Machine (PackFill) and then to a Packer machine, as outlined in the Routings table. In
the PackFill TransferNode, entity checks to see if the raw materials that are required to be consumed at the Filler workstation are available. If
they are not available, the entity will wait here at the PackFill TransferNode, instead of waiting at the Filler workstation.
Once the materials are available, they can be selected to be run on a Filler workstation. The PackFill TransferNode uses a Route Request Dynamic
Selection Rule determine the sequence of jobs for Filler1 and Filler2. The Route Request Dynamic Selection Rule is set to a Referenced Property
so that a user can experiment with using different routing rules. By default, this Packing Selection Rule property is set to ‘Standard Dispatching
Rule’ which has a number of child properties. For the Standard Dispatching Rule, the Dispatching Rule property is set to LargestPriorityValue and
the Tie Breaker Rule property is set to EarliestDueDate. Using these Standard Dispatching Rule properties, entities will be selected will based on
largest priority value. If more than one entity has the same largest priority value, the entity with the earliest due date will be selected.
After an order is finished setting up at the Filler workstation, it executes a process named ‘Filler_FinishedSetup’. This process Searches the
BillOfMaterials table (rows related to the current routing key only) to find any row that has ReleaseHoldingTank column set to True. This indicates
that the Holding Tank Storage server should be searched for this material. If an entity of the material type is found in the Holding Tank Storage
server, it releases capacity of the Holding Tank Storage server, releases capacity of the Holding Tanks and is transferred out of the Storage into
the DisposeBulkOrders sink.
The entity representing the Finished Material order will leave the Filler workstation after processing and get routed to a Packer workstation. After
processing at a Packer workstion, the entity is routed to the AddToStorage transfer node, where it will select the appropriate storage location
based on its picture, which indicates if it is a RedPack, GreenPack or BluePack. The ship date in the Manufacturing Orders table for this finished
material order is updated when the entity enters the storage server.
Raw Materials (Label, Bottle)
Entities representing raw materials of Labels and Bottles are created by the Source objects MaterialArrivalsLabels and MaterialArrivalsBottles.
These source objects point to the appropriate row in the Materials table so the entity has a reference to either Bottle material or Label material. A
forklift is required to take the entity from the source to the Receiving server. The process ForkLift_Unloaded is executed when the vehicle unloads
264 / 815
forklift is required to take the entity from the source to the Receiving server. The process ForkLift_Unloaded is executed when the vehicle unloads
the entity and it produces the appropriate material (either Bottle or Label). These are consumed by a FinishedGood order at the Filler workstation
as part of the BillOfMaterials.
Data Tables
The following is a summary of the default tables that are based on the B2MML standard.
Materials:
A list of materials that can be produced at this production facility.
Note that the Gantt color defines the bar color to use for drawing entities associated with this material in the Entity Workflow Gantt. All orders for
this material will be drawn using this color. The Picture ID determines which entity symbol should be used for drawing the entity that is associated
with this material in the Facility view of the model. All entities representing orders for this material will be depicted in the Facility view using the
specified Picture ID. The Material C olor is used in the sequence dependent changeover matrix for determining the color dependent changeover
time. By default, this table is configured for changeovers that are dependent on color. This column could be changed to Size or another attribute
that determines the sequence dependent changeover time.
Routings:
A list of job routings for each material specifying the resource and processing time for each task required to produce the material.
Depending upon the application this table might be extended with additional columns specifying a setup time, operator, tooling, etc. The Routing
Key is a key column that requires a unique name and is typically specified as a material name with an underscore and step number appended.
For example, RedBulkMixing would be step 10 for producing RedBulk material. The step numbers are typically specified as 10, 20, 30, etc. The
sequence is the resource location where this step is performed. This is typically the input node of a specific workstation or a TransferNode from
which downstream workstations are dynamically selected. For example the TransferNode might be located at a group of five similar machines,
and then the entity is dynamically routed to one of the five machines based on availability and a selection rule – e.g. smallest changeover time.
Bill of Materials:
A list of component materials that are required at a specific routing sequence location to produce a material.
The Routing Key is a foreign key reference to Routing table. Note that there is a many-to-one relationship that supports multiple materials
consumed/produced for the same Routing Key. All the materials that are listed in this table with the same Routing Key will be consumed/produced
at that routing step.
Resources:
A list of fixed resources where processing steps are performed.
A compelling advantage of the Simio scheduling solution is the flexibility offered by a custom-built model of the production system. However, for
simple applications that do not require this flexibility the Resource table can be used to eliminate the need to manually build the Simio model. The
resources that are defined in this table can be automatically placed in the Facility model by running the Configure Resources Add-In. The first
time this Add-In is run it places the resources at the specified X, Z locations (within the 2D view the X axis increases as you move to the right,
and the Z axis increases as you move in the downward direction). Once placed the resources can be moved interactively using the drag-and-drop
features in the Facility view. Once placed the resource can also be repositioned using the table by entering the new location in the table, setting
Update Location to 'True', and then re-running the Add-In.
265 / 815
Update Location to 'True', and then re-running the Add-In.
Work In Process:
A list of current orders that are in the system, along with their current status.
The information in this table is typically imported from the MES system and defines the current state of all the active orders that are being
processed in the system. The Order ID is a foreign key reference to the orders that are listed in the Manufacturing Orders table with their Order
Status specified as WIP. The information in this table defines the current route number and resource where the order is being processed, along
with the quantity completed at this resource. The Accrued C ost is also specified in applications where activity-based costing is being used to track
the production cost for the orders.
The OnInitialized process is used in the model to search the Manufacturing Orders table for WIP orders, and then initialize the model with entities
representing each order. The process computes the remaining processing time at the current resource based on the completed quantity of work,
sets the sequence number and accrued cost, and then sends the entity to the input node of the specified resource.
Manufacturing Orders Output:
An Output Table defining order start and end time on each resource used for creating Table Reports.
The foreign key reference for the Order ID ties this output data to the other input tables for the model. This makes it easy to create custom Table
Reports on the relations data set that display relevant information on the orders as well as the scheduled start and end time for each order on
each resource in the system.
Model Properties
MaterialArrivalQty: The quantity of the raw materials that should arrive each time a raw material entity is created in the system.
Referenced in the Entities Per Arrival property of the MaterialArrivalsLabels and MaterialArrivalsBottles source objects.
WorkersQty: The number of workers in the system. Referenced in the Initial Number In System property of the Workers instance.
TanksQty: The number of tanks in the system. Referenced in the Initial Capacity property of the Tanks resource object.
ForkLiftQty: The number of forklifts in the system. Referenced in the Initial Number In System property of the ForkLift instance.
MixingRule: The routing rule (or Routing Group element) that is used to select which Mixing workstation to use for the entity. Referenced
in the Routing Group Name property of the Mixing transfer node.
PackFillRule: The routing rule (or Routing Group element) that is used to select which Filler workstation to use for the entity. Referenced
in the Routing Group Name property of the PackFill transfer node.
BulkMinInv: This is an integer property that indicates the inventory level that when reached, will trigger a replenishment of that
inventory. This is only used when the Planning Mode property is set to 0.
PlanningMode: This is an expression property that should be set to 0 or 1. By default, it is set to 1 and the model will run as described in
this detailed description section. However, when the Planning Mode property is set to 0, the mixing operations are triggered when the
minimum inventory level is reached, as defined by the BulkMinInv property. Any mixing orders in the tables do not get scheduled until the
minimum inventory level is reached. This is a Kanban approach to scheduling and might be used when the user wants to sequence the
Filler line and then have a mechanism that will ensure that the upstream operations are completed right before the filling operations is to
start.
Adding C ustom Dashboards
Our next step is to enhance the model with some custom dashboards. We will import three standard dashboards to our model that are designed
to work with the default data schema. These dashboards are saved in XML format and included in the DiscretePartProductionFiles folder that is
saved with this example. These dashboards display material, order details, and a dispatch list for use by operators.
To import these dashboards go to Dashboards Report view of the Results window and select the Dashboards ribbon. C lick in the Import button
and browse to the folder, and select the three dashboard xml files named DispatchList, Materials, and OrderDetails.
Set the Model Run Time
Our final step is the set the run parameters for the model. From the Operational Planning ribbon in the Planning window specify the starting time
as 12/1/2015 12pm and select the ending time as 60 days.
Experiments
There are two experiments on this model. One experiment is setup to use OptQuest to minimize cost by the setting of the model properties listed
above. The Lateness response references a Tally Statistic that is recorded on the input node of the DisposeBulkOrders sink object. It records any
late orders and by how much time they are late. There is also a response for Number C ompleted because it is critical that all orders are
processed so the user does not want to choose a scenario where some orders are not filled.
The second experiment is used to compare the alternative routing logic at both the Mixing machines and the Filler machines by changing the
values of the Mixing Rule and the PackFillRule.
The Scheduling Interface
The model can now be used to generate a plan. Go to the Planning Tab and click C reate Plan in the Operational Planning Ribbon. This will
generate the deterministic plan, which will populate the Resource Plan, Entity Workflow, Logs, Tables and Results. C lick onto Analyze Risk in the
Operational Planning Ribbon and multiple replications, with variability, will be run to assess the risk of the plan. The Entity Workflow, Tables and
266 / 815
Results will be updated with risk analysis for all the Targets defined in the model.
267 / 815
Simio Reference Guide
SchedulingBicycleAssembly - Example
General Description
The example uses Simio Enterprise Edition to schedule a bicycle assembly line. Simio Enterprise Edition is a simulation tool for developing
applications in Risk-based Planning and Scheduling (RPS). RPS is the dual use of a simulation model to generate both a detailed resource
constrained deterministic schedule as well as a probability-based risk analysis of that schedule to account for variation in the system. RPS is used
to generate schedules that minimize risks and reduce costs in the presence of uncertainty. Although Simio Enterprise Edition is required to build
this model, it may be viewed using Simio Design or Team Edition.
To understand the data schema and scheduling results in this example you should first read the Simio Scheduling Overview document. This
problem description assumes that you are familiar with the standard data schema and scheduling concepts that are presented in that document.
The system to be scheduled in this example is a bicycle assembly facility. The facility is a job shop that produces finished goods on a final
assembly line as well as parts or components for final assembly based on the customer orders. The schedule also includes a number of
purchased parts required for final assembly. We wish to generate a 7-day production schedule for this facility that fully accounts for the limited
resources and parts in the system.
The facility consists of three (3) functional areas named Component Manufacturing, Assembly Line, and Shipping and Receiving. These areas are
described in more detail below.
The Component Manufacturing area consist of (5) work centers (C ut, Shape, Weld, Machine and Paint) with each work center containing 2
workstations. The entry point to the work centers is modeled a Transfer Node with the corresponding workstations are model using the
Workstation object. The TransferNodes are used to select the order to process based on a standard dispatching rule.
All the Workstations also require an Operator that is modeled as a Worker named Operators with an initial capacity of ten (10) and managed by a
work schedule called 'OperatorSchedule'. The Paint workstations have sequence dependent setup times where the setup time is specified in a
changeover matrix based on the item color. Possible item colors are defined in a string list named MaterialColor with values None, Green, and
White. The Component Manufacturing area produces six (6) manufactured items for final assembly (GreenFinishedFrame, WhiteFinishedFrame,
GreenFinishedFork, WhiteFinishedFork, GreenFinishedHandleBar and WhiteFinishedHandleBar). Each of these items has its own routing and unique
processing time and material requirements at each workstation within its routing.
The Assembly Line area produces six (6) finished goods to satisfy the customer orders for Walmart, C ostco and Ambridge Bike Shop
(EcoBikeSTDGreen, EcoBikeSTDWhite, EcoBikeEXTGreen and EcoBikeEXTWhite). The Assembly Line area consist two (2) identical assembly lines
with four (4) work centers in each line named Mainframe, Power, Final and Test. The selection of the two assembly lines is controlled by a
TransferNode called AssemblyNode to allocate the selected line from a list called AssemblyList.
Each of the four (4) machines per assembly line is modeled using a Server object with a capacity of one (1). All the Servers also require an
Assembler that is modeled as a Worker named Assemblers with an initial capacity of ten (10) and managed by a work schedule called
AssemblerSchedule.
The MainFrame servers use task sequences to first consume the correct components. These final assembly components are listed per final
product in the Bill Of Materials table. Once material are consumed, one of two task are completed. If the number of Assemblers in the system is
<= 4, one Assembler is used for the task and the processing time is set to 12 minutes. If the number of Assemblers in the system is >4, two
Assembers are used for the task and the processing time is set to 6 minutes. A condition on the 20 Sequence Number tasks are used to select
which number of operators and processing times. In addition, the task sequences call 2 processes called MainFrame_StartingTask and
MainFrame_FinishedTask that are used to control animation that delivers stock and receiving material to the AssemblyLine using Forklifts.
The Shipping and Receiving area consists of three processes. The first process is to create and execute the procurement process (resupply) of
items required for final assembly according to the PurchasedMaterial table. The second process is the update of stock modeled by a Workstation
object using two add on processes called UpdateManufacturingOrdersOutput and AddManufacturingOrdersOutput. The third process is to perform
the packing and shipping task. This is modeled using a C ombiner object including one add on process called PackAndShip_Exited. The C ombiner
object is used to match the order with the actually quantity required to fulfill the customer order.
The B2MML-based data schema discussed in the Simio Scheduling Overview document is used to hold the production data for this example.
Detailed Description
System Initialization
The system begins with no Work In Progress (WIP) and starts with an empty production line. It is initialized by reading the orders, both for
components and finished goods, from the ManufacturingOrders table.
Arrival of Manufacturing Orders
The manufacturing orders fall into two (2) categories being Production Orders for manufactured components required for final assembly as well
as the C ustomer Orders for final assembly that includes both the manufactured components as well as procured items required to produce the
finished products. These manufacturing orders are released into the system and scheduled based on the release and due dates provided in the
ManufacturingOrders table. This is modeled by using a Source object (MRPOrders) that is reading the ArrivalsTable.
Manufactured Material (GreenFinishedFrame, WhiteFinishedFrame, GreenFinishedFork, WhiteFinishedFork, GreenFinishedHandleBar and
WhiteFinishedHandleBar)
If an order is a manufactured material, it will route to a combinations of workcenters (C ut, Shape, Machine, Weld and Paint) as outlined in the
Routings table. The output node of the Source object (MRPOrders) is routing the orders to the relevant workstations based on the required
Sequence per component as setup in the Routing table. At the Paint workcenters, the setup times are dependent on the color of the component
and it is controlled by a changeover matrix to provide the required setup time based on the color change required for the next item to be painted.
At three (3) of the workcenters (C ut, Shape and Paint) the transfer node is used for the entity to check if the raw materials that are required to
be consumed at the workstation are available. If they are not available, the entity will wait at the relevant transfer node, instead of waiting at the
workstation.
Before processing occurs at each workstation, the process AddManufacturingOrdersOutput adds a row in the table named
ManufacturingOrdersOutput and records the start time of this order on the workstation. The end time is recorded after this order is finished on the
workstation.
After the manufacturing order is completed at the last operation in the manufacturing process the sequence will route the entity to the workstation
called Stock in the Shipping and Receiving area to record the completion time for availability for use at the Assembly Line for the production of
the finished material. At that point, the entity representing this manufactured material order will get transferred to the Sink1 object to be disposed
of.
Finished Material (EcoBikeSTDGreen, EcoBikeSTDWhite, EcoBikeEXTGreen and EcoBikeEXTWhite)
If an order is a finished material, it will first route to the Separator object (AssemblyLine) in the Assembly area to create two entities, one to
represent the order for consolidation at Shipping and one to drive the assembly line, providing the processing and material information required.
The entity created to drive the assembly process is routed via a path to a transfer node (AssemblyNode) where it is routed to one of two
assembly lines reading the destination from a node list called AssemblyList. The two assembly lines are identical with 4 workstations each 268 / 815
assembly lines reading the destination from a node list called AssemblyList. The two assembly lines are identical with 4 workstations each
(Mainframe, Power, Final and Test) to complete the final assembly of the finished material and then routed to a Pack and Ship Station modelled by
a C ombiner object to match the customer order with the actual material manufactured to complete the customer order. The entity is routed by
just following a sequential path from one workstation to another. The manufacturing order is marked completed by removing the quantity from
the material list by using a process trigger (PackAndShip_Exited) in the C ombiner object before disposing of the entity in the Sink object called
C ustomer.
Purchased Materials (Seat, BrakeSet, WheelSet, Motor, FenderSet, StdBattery, ExtBattery)
Entities activating the purchased material process are created by the Source object PurchasedParts. This source object point to the appropriate
row in the PurchasedMaterials table so the entity has a reference to the purchased material items’ arrival date and time. The material then
becomes available in the system for consumptions by the Assembly line.
Data Tables
The following is a summary of the default tables that are based on the B2MML standard. It is important to note that the base model can also be
generated by importing these files in C SV format as described in the Simio Scheduling Overview document and explained in detail in the Discrete
Part Production example also included as one of the scheduling examples as part of the Simio 8 install.
Manufacturing Orders:
A list of all production orders to be processed during this planning period.
Note that the Ship Date and Production C ost are both output columns in the Manufacturing Orders table; they are written from the simulation
model to the table as the schedule is generated by the deterministic simulation run. Also note that the last four columns are targets.
Purchased Materials:
A list of materials that are purchased at this production facility.
Depending on the application there can be various purchased part or raw material items that are required as part of the production process.
These items with their arrival dates and quantities can be imported into the model.
Materials:
A list of materials that can be produced at this production facility.
Note that the Gantt color defines the bar color to use for drawing entities associated with this material in the Entity Workflow Gantt. All orders for
this material will be drawn using this color. The Picture ID determines which entity symbol should be used for drawing the entity that is associated
with this material in the Facility view of the model. All entities representing orders for this material will be depicted in the Facility view using the
specified Picture ID. The Material C olor is used in the sequence dependent changeover matrix for determining the color dependent changeover
time. By default, this table is configured for changeovers that are dependent on color. This column could be changed to Size or another attribute
that determines the sequence dependent changeover time.
Routings:
A list of job routings for each material specifying the resource and processing time for each task required to produce the material.
269 / 815
Depending upon the application this table might be extended with additional columns specifying a setup time, operator, tooling, etc. The Routing
Key is a key column that requires a unique name and is typically specified as a material name with an underscore and step number appended.
For example, FinishedGoodA_10 would be step 10 for producing FinishedGoodA. The step numbers are typically specified as 10, 20, 30, etc. The
sequence is the resource location where this step is performed. This is typically the input node of a specific workstation or a TransferNode from
which downstream workstations are dynamically selected. For example the TransferNode might be located at a group of five similar machines,
and then the entity is dynamically routed to one of the five machines based on availability and a selection rule – e.g. smallest changeover time.
Bill of Materials:
A list of component materials that are required at a specific routing sequence location to produce a material.
The Routing Key is a foreign key reference to Routing table. Note that there is a many-to-one relationship that supports multiple materials
consumed/produced for the same Routing Key. All the materials that are listed in this table with the same Routing Key will be consumed/produced
at that routing step.
Resources:
A list of fixed resources where processing steps are performed.
A compelling advantage of the Simio scheduling solution is the flexibility offered by a custom-built model of the production system. However, for
simple applications that do not require this flexibility the Resource table can be used to eliminate the need to manually build the Simio model. The
resources that are defined in this table can be automatically placed in the Facility model by running the C onfigure Resources Add-In. The first
time this Add-In is run it places the resources at the specified X, Z locations (within the 2D view the X axis increases as you move to the right,
and the Z axis increases as you move in the downward direction). Once placed the resources can be moved interactively using the drag-and-drop
features in the Facility view. Once placed the resource can also be repositioned using the table by entering the new location in the table, setting
Update Location to True, and then re-running the Add-In.
Work In Process:
A list of current orders that are in the system, along with their current status.
The information in this table is typically imported from the MES system and defines the current state of all the active orders that are being
processed in the system. The Order ID is a foreign key reference to the orders that are listed in the Manufacturing Orders table with their Order
Status specified as WIP. The information in this table defines the current route number and resource where the order is being processed, along
with the quantity completed at this resource. The Accrued C ost is also specified in applications where activity-based costing is being used to track
the production cost for the orders.
An OnRunInitialized process is typically used in the model to search the Manufacturing Orders table for WIP orders, and then initialize the model
with entities representing each order. The process computes the remaining processing time at the current resource based on the completed
quantity of work, sets the sequence number and accrued cost, and then sends the entity to the input node of the specified resource.
Manufacturing Orders Output:
An Output Table defining order start and end time on each resource used for creating Table Reports.
270 / 815
The foreign key reference for the Order ID ties this output data to the other input tables for the model. This makes it easy to create custom Table
Reports on the relations data set that display relevant information on the orders as well as the scheduled start and end time for each order on
each resource in the system.
The Scheduling Interface
Once the model has been completed and the data imported (already completed in the example model) can the scheduler start to use the system
to generate a schedule by selecting the Planning tab. Following below is an explanation of some of the different views available under the
planning tab.
Facility View
Once the model has been completed it can be viewed and run in the facility view to observe the actual process in a visual way representing the
facility as shown below:
Resource Plan
The Resource Plan provides a summary of how each resource in the system is utilized by each entity/order that is processed by that resource.
The Resource Plan presents this information in both a graphical view (Gantt) and tabular view (Usage and State Logs). The resource view show
the resource usage for both the parts manufacturing as well as the final assembly areas. Also available on the Gantt chart view is the material
levels for both the manufactured and the purchased material. By selecting the “plus” sign associated with each resource in the resource list on the
left of the Gantt chart will expand the view showing the orders that are constrained by the resource as a result of material, capacity or operator
constraints as well as the resource state (idle, busy, etc.).
The thick black lines on the Gantt chart indicate the various summary views and by selecting the “plus” or “minus” sign for that row will expand or
collapse the view associated with that specific section of the chart to select only the view of interest to the planner. The time horizon on the Gantt
view can be changed by using the zoom function after selecting the Gantt view from the top ribbon.
By double clicking on any of the orders the view will change to the Entity Workflow view to observe the constraints associated with each specific
order.
271 / 815
Entity Workflow
By selecting the Entity Workflow tab on the left the planner can view all the orders in the system. This includes both the manufactured material
orders as well as the finished material orders. By expanding the view for the various order types by selecting the “plus” or “minus” sign on the
order list at the left-hand side of the Gantt chart will show all the customer orders as indicated by the screenshot below.
By further expanding the view for each order will also show the resource and material constraints associated with each order providing direct
feedback to the planner as to the reasons for order lateness.
Results
By selecting the results tab the planner will get access to a host of information regarding the schedule that has been produced by the system.
272 / 815
By selecting the results tab the planner will get access to a host of information regarding the schedule that has been produced by the system.
These results include a pivot table, Dashboard reports, Risk plots, Table reports, Target detail and more. Below is an example of a resource state
dashboard view.
These results tab can be used to do a detail analysis of the schedule results to fully understand the system behavior to try alternative options to
improve the plan such as increasing resource capacity or providing additional material, etc.
273 / 815
Simio Reference Guide
SchedulingDiscreteP artP roduction - Example
General Description
The example uses Simio Enterprise Edition to schedule discrete part production. Simio Enterprise Edition is a simulation tool for developing
applications in Risk-based Planning and Scheduling (RPS). RPS is the dual use of a simulation model to generate both a detailed resource
constrained deterministic schedule as well as a probability-based risk analysis of that schedule to account for variation in the system. RPS is used
to generate schedules that minimize risks and reduce costs in the presence of uncertainty. Although Simio Enterprise Edition is required to build
this model, it may be viewed using Simio Design or Team Edition.
To understand the data schema and scheduling results in this example you should first read the Simio Scheduling Overview document. This
problem description assumes that you are familiar with the standard data schema and scheduling concepts that are presented in that document.
The system to be scheduled in this example is a discrete part manufacturing facility. The facility is a job shop that produces finished goods. We
wish to generate a 30-day production schedule for this facility that fully accounts for the limited resources in the system.
The facility consists of functionally grouped machine groups named Cut, Weld, Shape, and Finish, with two machines within each machine group.
Each of these machines is modeled using a Workstation, with a TransferNode that is named for the machine group (e.g. C ut) and is used to
dynamically route based on a scheduling rule to the selected machine (C ut1 or C ut2) within the group. The Shape and Weld Workstations also
require an Operator that is that is modeled as a Worker named Operators with a capacity that can be varied between experiments. The C ut
workstations have a change-dependent setup time where the setup time is 0 minutes if the same material color s produced, and 8-hour setup
time is a different material color is being produced. The Weld station has a sequence dependent setup time where the setup time is specified in a
changeover matrix based on material color. Possible material colors are defined in a string list named MaterialColor with values None, Red,
Green, and Blue.
There are three finished goods (FinishedGoodA, FinishedGoodB, and FinishedGoodC) that are produced in this facility, and each has its own
routing and unique processing time and material requirements at each workstation within its routing. The B2MML-based data schema discussed in
the Simio Scheduling Overview document is used to hold the production data for this example.
Although we are modeling the material consumption at each workstation, in this example we are not explicitly modeling the material resupply
logic. The consumed materials include MaterialX and MaterialY, and each has sufficient levels to supply production during the planning horizon.
The Bicycle example model that is installed with Simio illustrates modeling of the material resupply based on a Purchased Material arrival table.
In this example we are provided a set of C SV/Word files for automatically generating the major components of the model, and populating the
required data tables. This illustrates the concept of a “data-driven” scheduling model where the model is created automatically using Simio data
Add-ins.
Detailed Description
In this example we are provided the following additional data files that we will use for building the model and populating the data tables:
These are located in the DiscretePartProductionFiles folder that is located in the same directory as this example.
To build this model we open a new model and execute the following steps:
1) Run the Add Scheduling List and Tables.
2) Import the Resources.csv into the Resources table.
3) Run the C onfigure Resources add-in.
4) Import the remaining csv files into the data tables.
5) Enhance the model logic.
6) Add custom Dashboards and Reports.
7) Set Run start at 12/1/2015 and run for 30 days.
We will now describe each of these steps in detail.
Run the Add Scheduling List and Tables Add-In
Our first step is to run the Add Scheduling List and Tables add in from the Tables ribbon in the Data window. This add-in automatically creates the
Resources, Materials, Manufacturing Orders, Routings, Bill of Materials, and Work In Process data tables; and the Order Status and the Material
Color string list. These data tables will be populated at a later step by importing data from csv files. The Order Status string list is used to define
orders as one of two types: New orders that are being released to the facility, and WIP orders that are currently in process. The Material Color
string list is a default string list for use with change dependent setup times. In a typical application this list would be renamed to size, part group,
etc., based on the attribute that triggers a dependent setup change. In this example we will use the default Material C olor list to define the
changeover attribute.
Import the Resources
Next we will populate the Resources table by importing the data from the Resources.csv data file. To do so we first bind to the file by selecting
Bind To C SV on the Table ribbon of the Data window, and then browse to and selet the Resources.C SV file in the
Documents\Simio\Examples\DiscretePartsProduction \DiscretePartProductionFiles folder. We then set our binding option to manual, and then click
on Import to import the resource data into the table. Note the table initially has many errors flagged in red because the object and list names
specified in the table do not yet exists. That issue will be address in the next step.
C onfigure Scheduling Resources
We now will run the C onfigure Scheduling Resources add-in from the Tables ribbon of the Data window to automatically generate the objects and
Node Lists that are specified in the Resources table. Note that the Workstations, TransferNodes, Source, and Sink are automatically placed in the
274 / 815
Node Lists that are specified in the Resources table. Note that the Workstations, TransferNodes, Source, and Sink are automatically placed in the
Facility view at their specified locations. At the completion of this step the error flags in the Resources table are all removed since the referenced
objects and list now all exists. The resulting model is depicted below:
Note that we have specified the string list name associated with this matrix as Material C olor.
We will also add some basic cost information to our model to enable Simio to automatically calculate activity-based costing. This hourly cost in
USD is summarized below:
This information is entered for each of these objects with the parent cost center specified as Overhead.
Next we edit the properties for the Weld1 and Weld2 Workstations to specify the Setup Time Type as Sequence Dependent, and the C hangeover
matrix as WeldSetup. We also edit the properties for C ut1 and C ut2 to specify the Setup Time Type as Change Dependent, the Operation Attribute
as Material.MaterialC olor, and the Setup Time If Different to 8 hours.
Next, we are going to use two (2) standard dispatching rules to determine the sequence of jobs for the two C ut machines and two Weld machines.
For the C ut and Weld TransferNodes we specify the Route Request Dynamic Selection Rule as Standard Dispatching Rule. In the case of C ut
TransferNode, we specify the Dispatching Rule property to LargestPriorityValue and Tie Breaker Rule to EarliestDueDate. For the Weld
TransferNode, we specify Dispatching Rule property to LeastSetupTime and Tie Breaker Rule to EarliestDueDate.
Our final model logic enhancement is to add process logic to initialize our WIP orders as well as new orders whose start time is before the
scheduled start time for the schedule. In the Process window we added the OnRunInitialized standard process, which is called by Simio at the
start of each simulation run. We then browse to the DiscretePartProductionFiles folder and open up the WIPProcessXML word document that
contains the XML logic for the required initialization process for this model. Select and copy this XML into the process window. Add an Execute
step to the OnInitializedRun process that executes this Initialize process. The resulting process window is shown below:
The Initialize process has two Search steps; the first to search for jobs that have an earlier start time than now so that they can be released, and
the second to search for WIP jobs. This second group has the C urrentRouteNumber and RemainingWork state variables assigned before sending
the entities to their current Workstation.
C ustomizing the Default Logs
Although the default Gantt display and Logs work fine for many applications, it is convenient to be able to extend the Logs with additional
276 / 815
information, and to use this extra information to augment the Gantt display. We will add three new custom columns to the Resource Usage Log for
this purpose. The first specifies the name of the material being produced on the resource. The second is the desired fill color for drawing bars on
the Gantt. The third is the desired outline color for drawing these same bars.
To add new custom columns to the Resource Usage Log click on Add C olumn in the Logs ribbon in the Logs view of the Planning Window. We will
rename the first custom column MaterialName, specify its Data Format as String, the Gantt Display Type as EntityGantt, and specify the
expression as Math.If( Owner.Is.Mo, Owner.ManufacturingOrders.MaterialName, " "). Hence if the owning entity is a manufacturing order we use
the material name from the orders table, otherwise we specify a blank string. We rename the second custom column GanttC olor, set the Data
Format to C olor, specify the Use as Gantt C olor as OwnerItemFillC olor, and then specify the expression as Math.If( Owner.Is.Mo,
Math.If(Owner.ModelEntity.C urrentRouteNumber == Owner.Routings.RouteNumber, C olor.Yellow, Owner.Materials.GanttC olor), C olor.Black). This
draws the Gantt bar in yellow if it is a WIP order at its current route step, or the color specified in the materials table or black othewise. We
rename the third custom column OutlineC olor, set its Data Format to C olor, specify the Use As Gantt C olor property as OwnerItemBorderC olor,
and specify the expression as Math.If( Owner.Is.MO, Math.If(TimeNow> Owner.ManufacturingOrders.DueDate, C olor.Red,
Owner.Materials.GanttC olor), C olor.Black). This draws the border in red if the order is late, or uses the material color or black otherwise.
Adding C ustom Dashboards
Our next step is to enhance the model with some custom dashboards. We will import three standard dashboards to our model that are designed
to work with the default data schema. These dashboards are saved in XML format and included in the DiscretePartProductionFiles folder that is
saved with this example. These dashboards display material, order details, and a dispatch list for use by operators.
To import these dashboards go to Dashboards Report view of the Results window and select the Dashboards ribbon. C lick in the Import button
and browse to the folder, and select the three dashboard xml files named DispatchList, Materials, and OrderDetails.
Set the Model Run Time
Our final step is the set the run parameters for the model. From the Operational Planning ribbon in the Planning window specify the starting time
as 12/1/2015 8am and select the ending time as 30 days.
Generating the Schedule
Once our model is complete we can generate the schedule by clicking on C reate Plan on the Operational Planning ribbon in the Planning window.
This generates the deterministic schedule by automatically removing the randomness from the model. We can then generate the risk analysis for
this schedule by clicking on the Analyze Risk button on the same ribbon. The following depicts a zoom-in portion of the Resource Plan for this
example.
As discussed in the Simio Scheduling Overview document there are many different ways to view the schedule and the associated risk. For
example, the following is dashboard for the dispatch list that we imported using the XML file. This dashboard shows the resource utilization and
dispatch list for the currently selected resource (C ut2).
277 / 815
Simio Reference Guide
W arehouseExample - Example
General Description
This model represents a warehouse. The general process flow is as follows:
Products are generated and processed at the finish machine.
A forklift picks up the products for storage.
A second forklift picks up the stored products from the storages to the shipping dock.
Products are loaded into a truck for shipment.
* This example uses a subclassed server ‘MyServer’.
Detailed Description
Initializing the Storage Areas
We initialize the Storage Areas with and Initial WIP. Each storage area has its Initial WIP defined in a table, Table1. To create these entities at the
beginning of the run, we add a OnRunInitialized Process in the Process window. The process searches Table1, creating a seperate token for each
row. These tokens exit through the found branch and create the amount of Product defined in the ‘InitialWIP’ column. Then we assign a small
processing time, signifiying this product has already been stored for a period of time. And then we transfer to the storage areas.
Storing the Product
The warehouse contains 12 storage areas. The products are picked up by a forklift after being processed by the Finish machine, which is a
Server. The forklift knows where to drop the products by setting PickUp node Entity Destination Type to ‘Select From List’ where the list includes
the input nodes of the storages. The drop off is done randomly by setting the Selection Goal to ‘Random’.
Storage Areas
As the storages share the same processing time, initial capacity and external view, we decide to model these storages as a subclassed server
‘MyServer’ to avoid repetitive value settings. The External View and the default values for the ‘ProcessingTime’ and ‘IntialC apacity’ properties
were altered in the MyServer’s Definitions tab, Properties panel, so that when placed in the model, it is prepopulated with the correct values and
symbol.
Shipping
The products are picked up from the storages by a second forklift that delivers them to the shipping truck. The forklift is triggered through setting
the storage area’s output node’s Ride on Transporter property to ‘True’. The products are dropped off at a Server with zero processing time
where they are loaded onto a conveyor to the shipping station that is modeled as a Sink.
Useful Tips
Note the use of polylines to define the path decorator of the forklifts circuits.
278 / 815
Simio Reference Guide
Frequently Asked Q uestions
279 / 815
Simio Reference Guide
Modeling in Simio
In Simio, the user should think in terms of the physical objects that make up the system. The users places these objects in the Facility Window
and they interact based on their internal logic. The objects that are placed in the Facility Window are user-defined and are stored in libraries. A
Simio library contains object definitions that represent the physical components of a system. Simio has a Standard Object Library that includes 14
pre-built object definitions that can be used to model a wide range of systems.
Simio also provides the user with the ability to create their own object definitions. These can be created from any of the five classes of Object
Types. The user defined objects are stored in the Project Library.
Simio allows a user to create their own Design Add-Ons (such as the Source, Server, Sink Add On avialable in the Project Home tab), User
Selection Rules, Steps, Elements, and Data Table importers. For more information on integrating custom code into Simio, see C ustom Simio
Extensions.
Modeling and animation are done as a single step in Simio. And Simio provides a number of tools for enhancing the animation and for importing
and downloading symbols into the model.
280 / 815
Simio Reference Guide
Navigation
The Navigation window is found in the top right side of the interface, above the Properties window. It is used to navigate between different models
within the project, navigate to the Project window, to Experiments, and to project Symbols.
The Navigation Window
Navigating between the different models within the project is done through the Navigation window. When a user clicks on a model in this window,
it becomes the active model. Therefore, the model windows in the main part of the interface are now associated with the model that is highlighted
in the Navigation window. The type of windows that are available for a particular model depend on the object class of the active model. For
example, for a model of object class Fixed, the Facility, Processes, Definitions, Data, and Results windows are shown. However, for a model of
object class Entity, only Processes, Definitions, and Data are shown. This is because it does not make sense for an Entity object to have a Facility
window or a Results window.
When a Model is selected in the Navigation window, a right click will give the user a choice to add a new fixed object class Model, add a new Entity
model, add a new Experiment to this model, rename the selected model, view the model properties or delete the selected model. There is an
additional option to view / modify the object references in a given model. When the Project is selected in the Navigation window, a right click will
give the user a choice to add a new fixed object class Model, add a new Entity model, rename the project and view the project properties. When
an Experiment is selected in the Navigation window, a right click will give the user a choice to add a new fixed object class Model, add a new
Entity model, add a new experiment, duplicate the experiment, rename the experiment, view the experiment properties or delete the experiment.
The Navigation Window - Right Click Menus
Within the Navigation window, users have the ability to re-order project items in the window via drag and drop. Moving a model can be done by
simply highlighting the model, dragging it to a location in the list and dropping it. A small blue curved “insert here” arrow will appear when moving
it to display where it will be located when dropped into a new location. For example, a user may wish to move the ModelEntity model below the
various project related models.
Note that the various sections of the ‘tree’ are collapsible as well. When you click on one of the “v” symbols next to a model that has multiple
experiments, for example, it will close the items and then contain a “>” next to it instead of a “v”.
Users may re-arrange the order of sibling items (nodes) by dragging them around. That is, you can re-order items within the same parent node:
Top-level models within the project
Experiments within their parent model (actually, the “Experiments” node for that model)
Baseline models within their parent model (similarly, the “Baselines” node for that model)
Symbols within the “Symbols” node
281 / 815
Simio Reference Guide
P roject W indow
The Project Window is accessed by clicking on the name of the project from within the Navigation window. It contains all of the models,
experiments, symbols, textures, and path decorators that a user has in their project.
The Project Window
282 / 815
Simio Reference Guide
Model W indows
Windows
The following windows can be accessed using the Model Window tabs.
The Facility Window
The Processes Window
The Definitions Window
The Data Window
The Results Window
283 / 815
Simio Reference Guide
T he Facility W indow
284 / 815
Load Action This property is visible when the Runnable property is 'True'. It indicates if the model should automatically enter a run mode
immediately after loading. Options include None, Reset, Step, Run and FastForward.
Update Interval Provides a model-level value that may be used in models or custom objects to trigger periodic user-specified actions. This
value, while not used directly by Simio, is available at run-time via Run.UpdateInterval.
Units Time units used for the model's Update Interval.
C heck Base for Indicates if Simio should include this object's inherited properties when checking if it has any Advanced properties.
Advanced
Properties
Available in If True, this object can be used to build models in the Express Edition of Simio.
Express Edition
(Enterprise Only)
C oncurrent Specifies the maximum number of replications that will be run simulataneously. The default value of 0 allows Simio to
Replication Limit determine this value.
(Risk Analysis -
Enterprise Only)
Parse Element If True, element functions will be the last thing searched to get a match to an identifier in an expression. If False, element
Functions In functions will be searched before states, expression functions, child elements and objects, external nodes, and schedules. If
Expressions this value is changed, the model must be saved and reloaded in order for it to take effect across all expressoins. This was
(C ompatability) implicitly False in Sprint 106 and older.
Note: Within our SimBits, we utilize the Description, Keywords and C ategories properties to separate the various files, as seen when using the
Support ribbon, Sample SimBit Solutions button that allows users to search the various SimBits files. Users may add models to the default SimBit
directory (documents/Simio/SimBits) and any *.spfx model files will be indexed and categorized based on the C ategory and Keyword properties
listed. C ategories are used in both the Basic and Advanced Search, while Keywords are used in the Advanced Search. The Description text
property will be displayed below the specific C ategory and is used for searching specific terms as well.
285 / 815
Simio Reference Guide
Status Labels, P lots, G auges and Buttons
Status Labels, Status Plots, Status Pies, Floor Labels, C ircular Gauges, Linear Gauges, Stacked Bars and Buttons can be placed in the Facility
Window. If an animation status object is attached to Entities or Transporters within the Facility window, it will travel with the dynamic instances.
Many of the same animation items can be placed within the Definitions tab, External Window and C onsole Window.
The Animation Ribbon from the Facility Window
More information regarding the various object queues and animating queues can be found on the Queues page.
The user can add a Status Label for displaying static text or the value of an expression inside a text display rectangle. After selecting Status
Label left click in the window to place the first vertex, and then drag and left click again to add the opposite vertex.
The following is an example of first using the Status Label for text and then using it to display an expression. In this case the expression shown is
Server1.Processing.NumberExited.
A Status Label in the Facility Window
The Status Plot displays the value of an expression over time inside a display rectangle. After selecting Status Plot left click in the window to
place the first vertex, and then drag and left click again to add the opposite vertex. The Plot displays a maximum of 100 data points, eliminating
the oldest 25 points every time it reaches a total of 100. The Status Plot allows for more than one expression. The Appearance ribbon (as seen
above the plot shown below) allows the user to change the Labels, Time Range and Style of the plot.
The following is an example of a Status Plot with two expressions: Number Waiting in Queue at the Server and the Total Number of Failures at the
Server.
A Status Plot with Two Expressions
286 / 815
The Status Pie shows the values of a list of expressions (in percentages of their total summation). In other words, the percentages shown in the
pie chart are percentages relative to the total of all values in the pie chart. The Appearance ribbon (as seen below) allows the user to change the
Title, Legend and Style of the status pie. There is also an option to Show Zero Values in Legend, which will enable or disable repeat group or list
values that result in zero within the legend.
When displaying the Status Pie legend with List States that have no spaces, Simio will automatically insert spaces when there is a capital letter in
the name. For example, a List value of Line2Idle will appear in the status pie legend as Line2 Idle.
The following is an example of a Status Pie can displays the Maximum value of two different State Statistics (i.e. MissedDeliveries.Maximum
where MissedDeliveries is a State Statistic).
A Status Pie
The Circular Gauge will display the value of an expression in a the style of a circular gauge. The Appearance ribbon (as seen above the circular
gauge shown below) allows the user to change the Style and Scale of the gauge.
The following is an example of a circular gauge displaying the value of Server1.C apacity.Allocated.Average.
A Circular Gauge in the Facility Window
The Linear Gauge will display the value of an expression in a the style of a linear gauge. The Appearance ribbon (as seen above the linear
gauge shown below) allows the user to change the Style and Scale of the gauge.
The following is an example of a linear gauge displaying the value of Server1.NumberWaitingAllocation.
A Linear Gauge in the Facility Window
287 / 815
The Stacked Bar adds a status stacked bar for displaying information in the simulation. After selecting the Stacked Bar, left click in the window
to place the first vertex, then drag and left click again to add the opposite vertex.
The Stacked Bar can be rectangular or ellipse shaped. The scale type of the Stacked Bar can be specified as either Volume or Linear. If Volume is
selected, the value of the expression will be used for the volume of each block. Alternatively, if Linear is selected, the value of the expression will
be used for the height of each block. The large portion of this animation symbol is best viewed in 3D, as the expressions or queue contents are
displayed on top of each other. The Floor Display options of Left and Right, however, allow the contents to be shown in 2D within a gauge type
rectangle to the left or right of the main stacked bar.
The types of stacked bars include C ontainer, Queue and Expression. If the Type is C ontainer, then simply indicate the C ontainer element to
animate, and the stacked bar will display C ontainer contents by Volume. To visualize a C ontainer by weight, the Queue Type stacked bar can be
used. If the Type is Queue, then the options include Queue State, Queue Item Expression and Total Expression are available. Total Expression
allows a user to specify a total space available. If Expressions is selected, then a repeat group of Expression Values is displayed, where users can
specify an Expression and a C olor. Like Queue, a Total Expression can also be specified.
Any texture can be applied to a stacked bar (the middle blue part), and that material will be the one used to display the total volume available.
The following is an example of a stacked bar displaying the Server's processing contents queue, Server1.Processing.C ontents, in terms of the
ModelEntity.Size.
A Stacked Bar in the Facility Window
Adding a Button will provide the user the opportunity for firing an event within the model while it is running. After selecting Button left click in the
window to place the first vertex, and then drag and left click again to add the opposite vertex. The text size of the button can be adjusted by
specifying the Text Scale property for the Button on the Appearance ribbon. A button can be used during the run to trigger a Process, create a
new Entity at a Source, etc. During a run, if the focus is not on the Facility Window when the user wants to click the button, the user will need to
288 / 815
new Entity at a Source, etc. During a run, if the focus is not on the Facility Window when the user wants to click the button, the user will need to
first click somewhere in the Facility Window to return focus to this window and then click on the button to fire the Event.
Buttons within the Facility Window
289 / 815
Simio Reference Guide
T he P rocesses W indow
A user can also add one of the standard processes that are automatically executed by Simio by selecting one from the drop down under the
Select Process icon. There is no need to define a triggering event for these processes because Simio executes them automatically. For example,
the OnRunInitialized process is executed when this object/model is first initialized. The OnC apacityReleased is executed as soon as the capacity
of this object/model has been released. The capacity related standard processes will only appear in the drop down if this object is a Resource
object. (An object is a Resource object if its Resource Object property is set to 'True'.)
Adding a Standard Process
Steps are added to processes by clicking and dragging from either the C ommon Steps panel on the left or from the All Steps(A-Z) panel on the
bottom left. All of the C ommon Steps are also listed in the All Steps panel. Any custom user created steps will appear in the User Defined steps
panel on the bottom left.
Process Element Properties
Listed below are the properties of a Process:
Property Description
Triggering The name of an event that will trigger a new token to execute the steps in this process. Refer to the Subscribe and Unsubscribe
Event Name steps to dynamically add or cancel triggering events for a process during a simulation run.
Triggering Optional condition to be evaluated whenever a triggering event occurs, and which must also be true to cause the execution of
Event this process.
C ondition
Token C lass The token class that all tokens executing this process will be created from.
Name
290 / 815
Name
Input A list of input arguments that will be passed to the process if it is executed using an Execute step.
Arguments
Name (Input A unique identifier for the input argument.
Arguments)
Description Description text for the input argument.
(Input
Arguments)
State Variable Name of the token state variable that will store the value for the input argument when a token begins executing the process.
Name (Input
Arguments)
Return Values A list of values that will be returned by the process if it is executed using an Execute step.
Name (Return A unique identifier for the returned value.
Values)
Description Description text for the returned value.
(Return
Values)
Expression The expressoin that is evaluated to return the value.
(Return
Values)
Token Action The action taken by a token in this process if the token's associated object is destroyed. If the action is 'EndProcess', then the
On Associated token will automatically end processing upon exiting its current step. Note that this proprety setting will be ignored by a token if
Object it is directly responsible for the associated object being destroyed (e.g., the token is executing a Destroy step in the process).
Destroyed In that case, the token will continue processing regardless.
Token Action The action taken by a token in this process if the token's associated object requests a transfer to a new location. If the action is
On Associated 'EndProcess', then the token will automatically end processing upon exiting its current step. Note that this property setting will
Object Transfer be ignored if it is directly responsible for the transfer request (e.g., the token is executing a Transfer step in the process). In
Requested that case, the token will continue processing regardless.
Initially Specifies whether the process is enabled when the system is initialized. Any attempt to execute a disabled process will be
Enabled ignored by the simulation engine.
Allow Step Allows or suppresses trace messages from steps in this process. (Note: This applies ONLY to steps in this process; it does not
Trace propagate to steps in other processes that might be called from this one.)
Multiple entire processes can be selected for copy/paste into the same Processes window or a different model Processes window. This can be
done by clicking the first process to copy to select it. Shift-click on another process will highlight the first selected, the last selected and all
processes in between. C trl-click will keep the current selection and highlight the process that is selected as well, allowing for multiple processes to
be highlighted that are not next to each other. When the processes are highlighted, the light blue hatching can be seen in the background of the
process. From the keyboard, C trl-C / C trl-V / C trl-X can be used to then cut/copy/paste the multiple processes, or alternatively, the
C ut/C opy/Paste buttons within the Project Home ribbon may be used.
Shift-Select and Ctrl-Select Multiple Processes for Copy/Paste
291 / 815
A user can change where any segment from a step goes. To do this, select the step, then move the endpoints of its outgoing segments by clicking
and dragging on the little circles on the end of the segment. A segment cannot be moved from a step if it leaves part of the process disconnected
from the begin step.
Within the Processes window, there is an autoscroll capability which is useful when editing large processes. If you are moving a step from one
part of the process to another, you can either use the '-' key to zoom out to view the process, or simply click on the step to move and Simio will
autoscroll to the left or right as you move the step. Autoscrolling is also helpful in connecting the step's exit to another step that is several steps
away. By selecting the step's segment circle and moving it to the left or right, the processes window will autoscroll in that direction. When working
with larger processes, you are able disconnect a segment by selecting the step and right-clicking, as seen below. The options for Disconnect Exit
and/or Disconnect Alternate Exit are available if the step's exit can be disconnected without leaving part of the process disconnected from the
Begin step.
Right Clicking to Disconnect an Exit
The Properties Spreadsheet Window is available for editing information within a Process or particular Step type in a grid-like format. C opy/paste
may be used within the grid to easily change information in multiple columns for processes or steps. Additionally, multiple steps can be multi-
selected by using C trl-click. This allows common properties to be edited within the Properties window on the right side of the Simio interface.
293 / 815
Simio Reference Guide
Steps
Steps are used to define logic within your simulation model. Each step performs an action such as seize, delay, decide, or wait. Steps are
stateless, but may change the state of an element/token/entity/object. Steps are organized into groups within the Processes Window.
They include the C ommon Steps, All Steps and User-Defined Steps.
If you hover over a step within a process, you can view the information specified in the Properties and/or Repeat Group without having to open
the details in the properties window.
Hovering over a Step that contains information in a Repeat Group property
294 / 815
Simio Reference Guide
C ommon Steps
The C ommon Steps library includes some of the most commonly used steps including:
Assign step is used to assign a new value to a state variable.
C reate step is used to generate objects into the system.
Decide step may be used to determine the flow of a token through process logic.
Delay step delays the arriving token in the step for the specified time duration.
Destroy step destroys either the parent object or the executing token's associated object.
EndTransfer step may be used to indicate that the entity object associated with the executing token has completed transfer into an object or
station.
Execute step may be used to execute a specified process.
Find step may be used to search the value of an expression over a specified range of one or more index variables. The expression will typically
involve array variables (vectors or multi-dimensional arrays) or indexing related functions.
Fire step may be used to fire an object event.
Move step may be used to request a move from one or more moveable resources that have been seized by either the parent object or object
associated with the executing token. The executing token will be held in the Move step until the resources have arrived to the requested locations.
Release step releases capacity of one or more objects on behalf of the parent object or the object associated with the executing token.
Search step may be used to search a collection of objects.
Seize step may be used to seize capacity of one or more objects on behalf of the parent object or the object associated with the executing token.
SetNode step may be used to set the destination node of any entity object.
Tally step tallies an observation for each token arriving to this step.
Transfer step may be used to transfer the entity object associated with the executing token between objects and between free space and objects.
Wait step may be used to hold the arriving token in the step until a specified event occurs.
C ustomizable "C ommon Steps" Panel
The C ommon Steps panel can be customized. If you're looking at a different steps panel (All Steps or User Defined), you can right-click on a step
and add or remove it from C ommon Steps. You can also use drag and drop to re-arrange the steps on the C ommon Steps panel. There is also an
option to restore the C ommon Steps to their default steps and order. This is a product-level feature (not per-project or per-model).
295 / 815
Simio Reference Guide
All Steps
The All Steps (A-Z) library includes all of the Simio steps. These steps provide the runtime logic for the simulation and include:
AddRow step may be used to add a new row to a specified output table (Simio Enterprise edition only). A reference to the added row is assigned
to the executing token or object.
Allocate step may be used to manually trigger an allocation attempt of the parent object's available resource capacity (if any) to other objects
waiting for units of that capacity.
Arrive step may be used by an entity object to notify its accepted visit requests that the entity has 'arrived' to its current location.
Assign step is used to assign a new value to a state variable. The Set* steps are used to set the values of other items.
Batch step may be used in conjunction with the BatchLogic element to match multiple entities together, form those entities into a batch, and then
attach the batched members to a parent entity.
C learStatistics step may be used to clear model statistics.
C onsume step consumes the specified quantity of a material - either at the top level only - or the exploded bill of material.
C reate may be used to create new object realizations of a specified object instance type.
Decide step may be used to determine the flow of a token through process logic.
Delay step delays the arriving token in the step for the specified time duration.
Destroy step destroys either the parent object or the executing token's associated object.
Disengage step may be used to unlock an entity's location from a location on the parent link so that the link and entity may move independently.
Dropoff step may be used by a transporter object to drop off a riding entity into the transporter's current node.
EndActivity step ends the current activity within an operation.
EndOperation step ends the operation.
EndRun step ends the simulation run.
EndTransfer step may be used to indicate that the entity object associated with the executing token has completed transfer into an object or
station.
Engage step may be used to lock an entity's location to a location on the parent link object.
Execute step may be used to execute a specified process.
Fail step starts a downtime of type Failure Name.
Find step may be used to search the value of an expression over a specified range of one or more index variables. The expression will typically
involve array variables (vectors or multi-dimensional arrays) or indexing related functions.
Fire step may be used to fire an object event.
Insert step may be used to insert an object into a specified queue.
Interrupt step may be used to interrupt process delays.
Move step may be used to request a move from one or more moveable resources that have been seized by either the parent object or object
associated with the executing token. The executing token will be held in the Move step until the resources have arrived to the requested locations.
Notify step may be used to output a user defined trace or warning message.
Park step may be used to move an entity object into the parking station of a node.
Pickup step may be used by a transporter object to pick up an entity waiting in the ride pickup queue of the transporter's current node.
PlanVisit step may be used by a transporter object to search for and accept a pickup reservation request in the system.
Produce step produces the specified quantity of material - either at the top level only - or at the exploded bill of material..
Release step releases capacity of one or more objects on behalf of the parent object or the object associated with the executing token.
Remove step may be used to remove an object from a specified queue.
RemoveRows step may be used to remove all existing rows from an output table.
Repair step ends a downtime of type Failure Name.
Reserve step allows the reservation of a specific resource capacity.
Resume step may be used to resume a process or to resume the movement of an object.
Ride step may be used to initiate a transporter ride request for an entity object at a node.
Route step may be used with a RoutingGroup element to route an entity object to a destination selected from a list of candidate nodes.
Search step may be used to search a collection of objects.
Seize step may be used to seize capacity of one or more objects on behalf of the parent object or the object associated with the executing token.
SelectDropoff step may be used to set the destination node of the parent transporter object to the dropoff location of a riding entity.
SelectVisit step may be used to set the destination node of the parent transporter object to a pickup location that was accepted using the PlanVisit
step.
SetNetwork step may be used to set the network of links used by an entity to travel between node locations.
SetNode step may be used to set the destination node of any entity object.
SetRow step may be used to assign a data table row or sequence table row to a token or object.
296 / 815
StartActivity step starts the next activity in a reserved operation.
StartOperation step starts an operation.
StartTasks step may be used to initiate a task sequence that is associated with an object in the model.
Subscribe step may be used to add a new triggering event for a process, indicating that the process is to be executed if the event occurs.
Suspend step may be used to suspend a process or to suspend the movement of an object.
Tally step tallies an observation for each token arriving to this step.
Transfer step may be used to transfer the entity object associated with the executing token between objects and between free space and objects.
Travel step may be used to do a direct (straight-line) movement of an entity in free space to a specified location.
UnBatch step may be used to remove batch members from the parent entity object associated with the executing token.
UnPark step may be used to move an entity object out of the parking station of a node.
UnReserve step ay be used to cancel any reservations for a resource made by a specified owner up to a desired number of reserved capacity
units cancelled.
UnSubscribe step may be used to cancel a triggering event for a process.
VisitNode step may be used within a node object's logic to initiate the OnVisitingNode process of the entity associated with the executing token.
Wait step may be used to hold the arriving token in the step until a specified event occurs.
297 / 815
Simio Reference Guide
User Defined Steps
Simio provides an open architecture that allows users to add new steps and elements to the system. Steps and elements may be coded in any
.NET language (Visual Basic, C #, J#, etc.). You would simply add your *.dll files to the UserExtensions folder of Simio. For additional information
on creating your own custom Steps, see C ustom Simio Extensions and C:\Program Files\Simio\Simio API Reference Guide.chm. See
Simio Visual Studio Templates for information on how to use the templates provided by Simio to get started with User Defined Steps.
Simio provides several sample User Defined steps including C loseGate, OpenGate, PassThruGate, Read, and Write.
298 / 815
Simio Reference Guide
C loseG ate
CloseGate
The C loseGate user defined step may be used to close a specific gate name.
The C loseGate step is used in conjunction with the OpenGate and PassThruGate user defined steps and the BinaryGate user defined element.
299 / 815
Simio Reference Guide
DbExecute
DbExecute
The DbExecute is a user defined step may be used to execute an SQL statement on a database.
The DbExecute step is used in conjunction with the DbC onnect user defined element.
300 / 815
Simio Reference Guide
DbQ uery
DbQuery
The DbQuery is a user defined step may be used to query data from a database.
The DbQuery step is used in conjunction with the DbC onnect user defined element.
301 / 815
Simio Reference Guide
DbR ead
DbRead
The DbRead is a user defined step may be used to read data from a database.
The DbRead step is used in conjunction with the DbC onnect user defined element.
302 / 815
Simio Reference Guide
DbW rite
DbWrite
The DbWrite is a user defined step may be used to write data to a database.
The DbWrite step is used in conjunction with the DbC onnect user defined element.
303 / 815
Simio Reference Guide
ExcelR ead
ExcelRead
The ExcelRead is a user defined step may be used to read values from an Excel worksheet.
The ExcelRead step is used in conjunction with the ExcelC onnect user defined element.
304 / 815
Simio Reference Guide
ExcelW rite
ExcelWrite
The ExcelWrite is a user defined step may be used to write values to an Excel worksheet.
The ExcelWrite step is used in conjunction with the ExcelC onnect user defined element.
NOTE: When running the ExcelWrite step, you must stop the model before you can look at the data. If you don’t, you will get a file lock warning.
305 / 815
Simio Reference Guide
O penG ate
OpenGate
The OpenGate user defined step may be used to open a specific gate name.
The OpenGate step is used in conjunction with the C loseGate and PassThruGate user defined steps and the BinaryGate user defined element.
306 / 815
Simio Reference Guide
P assT hruG ate
PassThruGate
The PassThruGate user defined step allows tokens through a specific gate name if it is opened.
The PassThruGate step is used in conjunction with the OpenGate and C loseGate user defined steps and the BinaryGate user defined element.
307 / 815
Simio Reference Guide
R ead
Read
The Read user defined step may be used to read data into the model from a file.
The Read step is used in conjunction with the File user defined element. If the Separator property is left blank, one entire line in the file will be
read into one State. In order to read in individual values, enter the appropriate character into the Separator property. For example, a .csv or. xls
file should have a comma listed in the Separator property so that each individual cell is read into a State. Note that if you read values into a
State, it must be numeric since States cannot hold non-numeric characters.
The Read step supports reading to and from Numeric states, as well as String states and DateTime states.
308 / 815
Simio Reference Guide
R elocateO bject
RelocateObject
The RelocateObject user defined step may be used to instantaneously change the location of an object, including fixed objects and unconnected
nodes, at runtime.
When relocating or moving a fixed object, such as a Server or Workstation, the Include Associated Nodes property set to 'True' will move the
object location (and animation) as well as nodes that are attached to the object.
Note that attempting to change the location of a Link or a Node with attached Links will result in a runtime error.
309 / 815
Simio Reference Guide
W rite
Write
The Write user defined step may be used to write data from the model to a file. To reference an item from the items specified in the Item
Property when writing to a text file, use balanced brackets {}. {0} will reference the first item specified, {1} the second item, etc. For example,
the following sentence can be specified in the format property: There are {0} parts of type {1} at time {2}. When writing to a .csv type file, the
format field can be left empty since it uses a common-separated format by default.
The Write step is used in conjunction with the File user defined element. See the WritingToAFile SimBit for an example on how to use the File
Element.
The Write step supports writing to and from Numeric states, as well as String states and DateTime states.
310 / 815
Simio Reference Guide
Steps R eference
This Steps Reference section has detailed information for all steps in Simio.
311 / 815
Simio Reference Guide
Allocate
Allocate
The Allocate step may be used to manually trigger an allocation attempt of the resource's available capacity (if any) to other objects waiting for
units of that capacity. The Cancel All Reservations First property, if set to 'True', will cancel any active reservations (done through the Release
step, if any) before the allocation is started.
The Allocate step will force the designated resource to step through its allocation queue using its designated Ranking Rule and Dynamic Selection
Rule, giving each waiting seize request in turn an opportunity to re-evaluate its seize. This may result in the designated resource being allocated,
or re-evaluation of the seize request may result in a different resource being allocated, or possibly no resource allocation at all.
312 / 815
Simio Reference Guide
AddR ow
AddRow
The AddRow step and associated Output table can only be used with Simio Enterprise Edition.
The AddRow step may be used to add a new row to a specified Output table. A reference to the added row is assigned to the executing token or
object.
The AddRow step is used only with Output tables (not standard data tables). To assign the data within the row, use an Assign step, where you
assign the State Variable Name of 'OutputTableName.C olumnName' to a New Value based on the type of column specified (i.e., real, integer,
string, object reference, etc.).
For an example of using the AddRow step, please refer to the SimBit UsingAddRowandOutputTable_Enterprise.
Listed below are the properties of AddRow:
Property Description
Table The name of the sequence or data table.
Name
Object Indicates the item for which a reference to the newly created table row will be assigned. It may be a reference to the parent object,
Type to the executing token, to the object associated with the executing token, or to a specific object or element.
Object or The name of the object or element to be assigned a reference to the newly added table row.
Element
313 / 815
Simio Reference Guide
Arrive
Arrive
The Arrive step may be used to have an entity object notify its accepted visit requests that the entity has 'arrived' to its current location.
Within the Standard Library, the Vehicle and Worker objects both use the Arrive step in their OnVisitingNode process logic (logic related to be
used as a moveable resource for processing tasks).
The step’s current usage is for modeling a moveable resource entity. It may be used by a resource entity to explicitly notify a token waiting at a
Seize or Move step that the entity resource has officially ‘arrived’ at the requested destination node location and thus the token responsible for
the resource move request may now be released from the Seize or Move step to execute any subsequent process logic.
314 / 815
Simio Reference Guide
Assign
Assign
The Assign step may be used to assign a new value to a state variable.
The state specified can be owned by the token, visiting entity, parent object, or member element.
The Assignments (More) section can be used for conditional assignments using the Skip Assignment If property.
For examples of using the Assign step, please refer to the SimBits LearningC urveWithFunction, LeveledArrivals, LogicBasedOnEntityState,
RecordDistanceTraveled and SimpleTank.
Other steps, such as the Set* steps, are used for assigning the values of other items. The SetRow step can be used to assign a table name and
row to an object or token. The SetNode step may be used to assign the destination node of an entity. The SetNetwork step is used to assign a
network of links to an entity for travel.
315 / 815
Simio Reference Guide
Batch
Batch
The Batch step may be used in conjunction with the BatchLogic element to match multiple entities together, form those entities into a batch, and
then attach the batched members to a parent entity. Use the UnBatch step to later remove batch members.
316 / 815
Simio Reference Guide
C learStatistics
ClearStatistics
The C learStatistics step may be used to clear model statistics. Users can easily reset either all model statistics or only the statistics for specific
objects or elements.
State variables have a property named Auto Reset When Statistics Cleared that will indicate whether or not the particular state variable will be
automatically reset to its initial value if the statistics are cleared by this step.
Possible uses for this step include wanting to clear all statistics during an interactive run based on some triggering event or ‘warmup’ time, or
wanting to collect and report periodic statistics (e.g., some logic that every hour writes out some object or element statistics and then clears
them).
317 / 815
Simio Reference Guide
C onsume
Consume
The C onsume step consumes the specified quantity of a material - either at the top material level only - or the exploded bill of material. A
Consume Materials (More) repeat group is provided that allows the definition of repeating material consumption data. Alternatively, a data table
may be mapped to that repeat group.
For the single material type, the specified quantity of this material is directly consumed. For the bill of material type, the material listed in the "bill
of materials" is consumed by the token, where quantity is the quantity in the bill times the top level quantity (typically 1). A token waits at this
step until all quantities have been allocated. Allocations are made incrementally as material becomes available. Only the first waiting entity in the
Material queue is eligible for allocation.
The C onsume step works in conjunction with the Produce step. If the quantity of all the bill of materials in the C onsume step is not available, the
token waits at the C onsume step. Elsewhere in the model, the Produce step should be used to increase a material's quantity and once that is
done, the C onsume step will use the material produced.
The Owner property provides a context when determining which object will be allocated the consumed material’s C ost Per Unit in the Materials
element.
318 / 815
Simio Reference Guide
C reate
Create
The C reate step may be used to create new object realizations of a specified object instance type. A new token associated with a created object
will exit the 'C reated' exit point of the step.
If the Create Type is 'NewObject' and Object Instance Name property is not specified, no object will be created. If the C reate Type is
'C opyParentObject' or 'C opyAssociatedObject' and the Object Instance Name is not specified, the newly created object will be of the same type
as the original.
If the Create Type is 'NewObject' and Object Instance Name property is specified, a newly created object of the specified type will be created.
The object will have its default values for all states and properties. If the Create Type is 'C opyParentObject' or 'C opyAssociatedObject' and Object
Instance Name is specified, much information from the original object is copied to the newly created object. This includes all table references
assigned to the original, all the original object’s state values, and the original’s assigned network and destination. If the original is following a
sequence table, the current sequence table index is copied as well. Note that if the entity type of the copy is different than the original’s type,
then only the state values of common inherited object states can be copied. Also, the size state values will not be copied and thus a copy of a
different type will be sized according to the default size for that different type.
When an object is created using CreateType 'NewObject', it is placed into Free Space within the Facility Window, at the object instance location.
When an object is created by CreateType= ’C opyParentObject’ or ‘C opyAssociatedObject’, it is initially located in Free Space at the same location
as the original object that was copied. Therefore, you might need to use a Transfer step directly following a C reate step, in order to place the new
object in a specific location, such as on a Link or into a Station or Node.
Within the Advanced Options section of properties, the Save Created Entity Reference may be used to optionally save the name of a state
variable that stores a reference to the entity created by the step (will be the last entity if multiple were created). Note that the assigned state
variable may be a state on the original token executing the C reate step or simply a model state variable.
There are two exits from the C reate step, including the Original and the C reated exits. A token for the newly created entity will first exit from the
'C reated' exit and proceed until a delay type step occurs for the token or its associated entity. Then the original token will exit the 'Original' exit.
The Math.Epsilon function may be used in a Delay step for the created token to affect the order of event processing.
For examples of using the C reate step, please refer to the SimBits C ONWIP and DynamicallyC reatingVehicles.
319 / 815
Simio Reference Guide
Decide
Decide
The Decide step may be used to determine the flow of a token through process logic. The Decide Step evaluates an Expression so any properties
that are referenced in the Decide step must be expression properties.
The arriving token exits either the 'True' or 'False' exit point based on the specified probability or condition.
For examples of using the Decide step, please refer to the SimBits SequentialProcessingByBatchSpecifiedInTable and MoveableOperator.
320 / 815
Simio Reference Guide
Delay
Delay
The Delay step delays the arriving token in the step for the specified time duration.
NOTE: Simio will produce an error if a delay time expression returns a negative value. This can occur if you use an unbounded distribution that
might produce negative values, such as a Normal Distribution, within the Delay Time of the Delay step. See Distributions for more information.
321 / 815
Simio Reference Guide
Destroy
Destroy
The Destroy step destroys either the parent object, the executing token's associated object or the object specified as an object reference.
Only object types supporting dynamic creation may be destroyed. All processes are immediately terminated for the destroyed object. All
schedule events (e.g. end of step delays) are cancelled from the calendar. If the parent is destroyed then the token does not exit the step.
322 / 815
Simio Reference Guide
Disengage
Disengage
The Disengage step may be used to unlock an entity's location from a location on the parent link so that the link and entity may move
independently. The Engage step is used to engage an entity.
Once disengaged an entity is free to move across the link at its on speed, and the link is free to move at its own speed without being affected by
the movement (or stoppage) of the entity.
Note:
This Step can only be used from within a Link object.
323 / 815
Simio Reference Guide
Dropoff
Dropoff
The Dropoff step may be used to attempt a transporter drop-off of a riding entity into a node.
Use the Pickup step to pick up an entity waiting to ride.
NOTE: Simio will produce an error if a delay time expression returns a negative value. This can occur if you use an unbounded distribution that
might produce negative values, such as a Normal Distribution, within the Unload Time of the Dropoff step. See Distributions for more information.
324 / 815
Simio Reference Guide
EndActivity
EndActivity
The EndActivity step ends the current activity within an operation.
325 / 815
Simio Reference Guide
EndO peration
EndOperation
The EndOperation step ends the operation.
This step releases the parent resource and shifts any conflicting operation spans into the future.
326 / 815
Simio Reference Guide
EndR un
EndRun
The EndRun step ends the simulation run.
This step ends the current simulation run. (Note that the OnRunEnding process will not be triggered by this step during an interactive run, but
instead the user must press the Stop or Reset button to trigger that process.)
327 / 815
Simio Reference Guide
EndT ransfer
EndTransfer
The EndTransfer step may be used to indicate that the parent object, object associated with the executing token, or specific entity object
reference has completed transfer into an object or station.
328 / 815
Simio Reference Guide
Engage
Engage
The Engage step may be used to lock an entity's location to a location on the parent link object. The method used to align the entity on the link is
determined by the link's EntityAlignment property. The Disengage step is used to disengage an entity.
Once engaged, an entity remains engaged until it is disengaged by the Disengage step. The entity engages the link using the link's
EntityAlignment property setting of 'AnyLocation' or 'C ellLocation'. If 'C ellLocation', then the entity can only engage the link at fixed cell locations
along the link's length. The entity will wait for the next cell to arrive before engaging the link. If 'AnyLocation', then the entity can engage the link
at any location without waiting. When engaged both the entity and moveable link location are co-aligned and must move in unison. When an
engaged entity arrives to the end of a link it forces the link to stop to remain co-aligned at the engaged position.
Note:
This Step can only be used from within a Link object.
329 / 815
Simio Reference Guide
Execute
Execute
The Execute step may be used to execute a specified process.
The owner of the process can be the parent object or the associated entity. The arriving token either exits immediately or waits on the process to
finish based on the Token Wait Action.
If the Token Wait Action is 'None (C ontinue)', the execution of the specified process is scheduled on the simulation calendar as an early current
event. The original token then immediately exits the step. For example, suppose a token passes through multiple Execute steps (with action ‘None
(C ontinue)’) in sequence. Once the original token stopped running, you would see the execution of the specified processes occur in the same
sequence that the Execute steps were hit (FIFO order).
If the Token Wait Action is 'WaitUntilProcessC ompleted', the specified process is immediately executed. If that process is completed with no
delays, then the original token can immediately exit the Execute step and continues its processing. Otherwise, if the specified process did have
delays, then the original token is held at the Execute step until that other process is completed. For example, suppose the OnRunEnding interface
process has an Execute step with action ‘WaitUntilProcessC ompleted’. As long as the specified process runs with no delays, you would see the full
logic of that specified process executed as part of the ‘OnRunEnding’ call.
330 / 815
Simio Reference Guide
Fail
Fail
The Fail step starts a downtime of type Failure Name.
331 / 815
Simio Reference Guide
Find
Find
The Find step may be used to search the value of an expression over a specified range of one or more index variables. The expression will
typically involve array variables (vectors or multi-dimensional arrays) or indexing related functions.
Search types supported by the Find step include finding the index variable value(s) that satisfy the specified expression as a logical condition, as
well as searches that minimize or maximize the expression. The arriving token exits either the 'Found' or 'NotFound' exit point of the step based
on whether or not a successful result is found by the search.
The starting index of an index variable can be smaller or larger than the ending index, corresponding to a forward or backward search.
If the Search Type is ‘C ondition’, then the token will exit the ‘Found’ exit point of the Find step with the index variable(s) set to the first value(s)
within the search range that satisfy the conditional search expression. Additionally, the value ‘True (1)’ will be stored into the ReturnValue state of
the executing token.
If the condition is not satisfied by an result within the search range, then the token will exit the ‘NotFound’ exit point of the Find step with the
index variable(s) set to 0 and the value ‘False (0)’ stored into the ReturnValue state of the executing token.
If the Search Type is specified as ‘MinimizeExpression’ or ‘MaximizeExpression’, then the token will exit the ‘Found’ exit point of the Find step with
the index variable(s) set to the value(s) within the search range that minimized or maximized the expression. Additionally, the minimum or
maximum expression value found will be stored into the ReturnValue state of the executing token.
If multiple index variables are specified, then the search range will be conducted as a nested indexed search in the order that the index variables
are listed. For example, if two index variables ‘J’ and ‘K’ are specified with search ranges 3-4 and 4-6 respectively, then the search expression will
be evaluated using the following index value order:
J=3,K=4
J=3,K=5
J=3,K=6
J=4,K=4
J=4,K=5
J=4,K=6
For an example of using the Find step, please refer to the SimBit FindAMinimumStateValue.
Search The search condition or expression containing the specified index variables.
Expression
If the search type is 'C ondition' and a result satisfying the search condition is found, then the value 'True' will be stored into the
ReturnValue state of the executing token. Otherwise the value 'False' will be stored.
If the search type is 'MinimizeExpression' or 'MaximizeExpression', then the minimum or maximum expression value found will be
stored into the ReturnValue state of the executing token.
332 / 815
Simio Reference Guide
Find - Discussion and Examples
333 / 815
Simio Reference Guide
Fire
Fire
The Fire step may be used to fire an object event. It can be used in conjunction with the Wait step.
For examples of using the Fire step, please refer to the SimBits EntityMovementInFreeSpace and EntityStopsOnLink.
334 / 815
Simio Reference Guide
Insert
Insert
The Insert step may be used to insert an object into a specified queue. Refer to the Storage element to define a custom queue in the model.
335 / 815
Simio Reference Guide
Interrupt
Interrupt
The Interrupt step may be used to interrupt process delays. A token delaying at a process' Delay step is considered a candidate for interruption if
the 'Interruptible' property of the Delay step evaluates to 'True'. To add logic for handling interrupted items (e.g., re-routing logic), the Interrupt
step can create new tokens that are associated with the interrupted items. These tokens will exit the 'Interrupted' exit point of the step.
The Interrupt step may be used to model resource preemption scenarios, allowing model logic to interrupt a process delay activity that is using a
resource, in order to release the resource for a higher priority activity. This approach allows very flexible preemption capability with precise
control over which entities are preempted and how the preempted entities are subsequently processed.
Objects within the Standard Library that may be interrupted with the Interrupt step include the Server, C ombiner and Separator. Within each of
these objects, the processing time delay is 'interruptible'. To interrupt a token at a Server, C ombiner or Separator, simply specify
ObjectName.OnEnteredProcessing as the Process Name property of the Interrupt step.
When a token enters the Interrupt step, it will interrupt the specified process and then the token will exit the "Original" exit of the step and
continue processing. Once this original token completes its steps (or begins a delay type step), a token associated with the interrupted entity is
created and will leave the "Interrupted" exit of the step and continue any specified steps.
For examples of using the Interrupt step, please refer to the SimBits InterruptibleOperator, InterruptingAcrossMultipleServers,
InterruptingServerWithMultipleC apacity and WorkerUsesWorkSchedule_InterruptWorkingOffShift.
336 / 815
Simio Reference Guide
Move
Move
The Move step may be used to request a move from one or more moveable resources that have been seized by either the parent object or
object associated with the executing token. The executing token will be held in the Move step until the resources have arrived to the requested
locations.
This step may be used in conjunction with the Seize step and the Release step.
337 / 815
Simio Reference Guide
Notify
Notify
The Notify step may be used to output a user defined trace, warning message or error, depending on the Notification Type.
The Warning Level in the Run ribbon is used to determine where warning messages are displayed.
338 / 815
Simio Reference Guide
P ark
Park
The Park step may be used to move an entity object into the parking station of a node.
The Token Wait Action property indicates whether the token is going to wait in the step until the transferring entity ‘Transferring’ or ‘Transferred’
event is fired.
339 / 815
Simio Reference Guide
P ickup
Pickup
The Pickup step may be used to attempt a transporter pick-up of an entity waiting in the ride pickup queue of a node.
The waiting entities are examined in the order of the pickup queue. Note that both the entity and the transporter have to "Accept" the selected
entity pickup. If the entity/transporter accept the pickup, the Pickup step removes the entity from the RidePickupQueue of the node and transfers
it into the ride station of the transporter using the standard transfer mechanism (i.e., the EndTransfer step completes the transfer). The token is
held in the Pickup step until the entity transfer is completed. If no TransferIn process handler is provided for the ride station on the transporter
then a zero time transfer is provided by default. The token exits one of two exit points depending on the result of the pickup attempt. It exits the
primary exit point if a pickup was successful. It exits the secondary exit if the pickup attempt failed. Entities that are picked up by a transporter
may be later dropped off using the Dropoff step.
NOTE: Simio will produce an error if a delay time expression returns a negative value. This can occur if you use an unbounded distribution that
might produce negative values, such as a Normal Distribution, within the Load Time of the Pickup step. See Distributions for more information.
340 / 815
Simio Reference Guide
P lanVisit
PlanVisit
The PlanVisit step may be used to have an entity object search for and accept a not yet reserved visit request in the system. Possible visit
requests may include pickup requests initiated at Ride steps (applicable to transporter entities) as well as move requests initiated at Seize or
Move steps (applicable to resource enabled entities). The SelectVisit step can be later used to have an entity actually set its current destination
node to an accepted visit location.
The trip is selected based on the selection goal specified. The goal can be SmallestDistance, LargestDistance, SmallestPriority, LargestPriority or
FirstInQueue. When selecting a trip, the entities in the global visit request queue are examined in order based on the selection goal. A candidate
entity is not selected unless accepted by the entity. Once an entity is selected, this same process is done for the transporter. Hence both the
candidate entity and the transporter have to agree to the trip before the reservation is booked.
341 / 815
Simio Reference Guide
P roduce
Produce
The Produce step produces the specified quantity of material - either at the top material level only - or at the exploded bill of material. A Produce
Materials (More) repeat group is provided that allows the definition of repeating material production data. Alternatively, a data table may be
mapped to that repeat group.
NOTE: Simio will produce an error if a delay time expression returns a negative value. This can occur if you use an unbounded distribution that
might produce negative values, such as a Normal Distribution, within the Production Delay Time of the Produce step. See Distributions for more
information.
For examples of using the Produce step, please refer to the SimBits ScheduledMaterialArrivals and
WorkstationWithMaterialC onsumptionAndReplenish.
342 / 815
Simio Reference Guide
R elease
Release
The Release step may be used to release capacity of one or more objects on behalf of the parent object or the object associated with the
executing token.
This step may be used in conjunction with the Seize step.
The Release step has an option to allow an owner object to keep the released resource capacity 'reserved' for possible later reuse. Reserved
resource capacity is capacity that although unallocated has been set aside for a specific future owner thus preventing its use by anyone else.
Whenever resource capacity becomes available, that capacity cannot be allocated to a seize request waiting in the resource’s allocation queue
unless that there is either sufficient unreserved capacity available or the owner of the seize request has sufficient reservation(s). For example, if
all of a resource’s available capacity has been reserved, a seize request without a reservation will have to wait in the allocation queue until either
active reservations for the desired resource have been cancelled or sufficient unreserved capacity has been released or scheduled. Note that
seize requests with reservations will be allowed to seize a resource even if ranked in that resource’s allocation queue behind requests with no
reservations.
A resource reservation will be automatically cancelled if one of the following events occurs - the Reservation Timeout property is used and the
specified timeout period expires OR the reservation owner is an entity that is destroyed. Note that if the Reservation Timeout is specified as the
value ‘Math.EPSILON’ then the resource reservation will be automatically cancelled at the end of the current simulation time step if there has been
no immediate re-seize of the resource by the same owner object. When a reservation is cancelled, the OnCapacityReservationCancelled process
for that particular resource is executed.
The Allocate step provides an option to cancel all active reservations for a resource (regardless of who has made the reservations) before
attempting to allocate the resource’s capacity to any waiting seize requests.
For examples of using the Release step, please refer to the SimBits OverflowWIP, ResourcesWithWorkSchedules, SeizingVehicle and
SelectingResourceFromList.
Releases.Reservation An optional wait time before automatically cancelling the reservation if the released capacicty is being kept reserved.
Timeout
Releases.On Optional process that is executed by a token associated with a released object after the release occurs.
Released Process
Owner Type The object that has seized the resource capacity units to be released. Specified as either the object associated with the
executing token, the parent object, or as a specific object reference.
Owner Object The specific object that has seized the resource capacity units to be released.
Release Operation Indicates whether to release activity resources specified for the owner entity's current operation.
Resources
Seized Resources Indicates an advanced filter to first apply to the owner object's list of current seized resources before attempting the
Filter resource releases. TokenSeizedResourcesOnly option will filter to only include resource seizes that occurred specifically
due to Seize step exectuation(s) by the same token now at the Release step.
343 / 815
Simio Reference Guide
R emove
Remove
The Remove step may be used to remove an object from a specified queue. There are two exits from the Remove step, including the Original and
the Removed exits. A token for the removed entity will first exit from the 'Removed' exit and proceed until a delay type step occurs for the token
or its associated entity. Then the original token will exit the 'Original' exit. The Math.Epsilon function may be used in a Delay step for the removed
token to affect the order of event processing.
The Interrupt Step is different, yet somewhat similar. It can be used to Interrupt a processing delay. So if you want to cancel an entity's request
for a Resource's capacity or a entity's Transfer request, use a Remove Step to remove an entity from a queue. But if you want to cancel an entity
that is currently within a process delay, use an Interrupt Step to cancel the delay.
Removing from a Storage Queue
The user can create their own queue within Simio and place entities in this queue (Insert Step) and remove the entities from the queue (Remove
Step). Refer to the Storage element to define a custom queue in the model.
Removing from a Resource Allocation Queue
Removing an item from a Resource's Allocation Queue is very powerful and allows for what is commonly referred to as "Reneging". This cancels
a Seize attempt. If an entity has already requested capacity of any resource type object and is therefore waiting in the Resource's Allocation
Queue (i.e. Server1.AllocationQueue), the entity can be removed from the queue and therefore their request for that object's capacity is
cancelled. An example of use for this feature might be when a customer has waited too long in line and decides to leave the facility without being
serviced. The customer had already requested capacity of the "server" and was waiting in line for the server, but the Remove Step can cancel
their request.
Removing from a Station's Entry Queue
Removing an item from a Station's EntryQueue or a Link object's EntryQueue, is interpreted as canceling the Transfer step transfer request. In
other words, the entity no longer waits to enter a station. The token executing the Transfer step ends its processing (i.e., is destroyed) upon the
canceling action.
Removing from a Link Object's Entry Queue
Removing an entity from a Link object's EntryQueue would cancel the Transfer request for this entity to wait to enter the Link.
Removing from a Batch Queue
Removing an entity from a BatchLogic element's ParentQueue allows the user to cancel a Batch Step activity where the entity is waiting to collect
a batch. Similarly, removing an entity from a BatchLogic element's MemberQueue allows the user to cancel a Batch Step activity involving a
member waiting to be batched.
Removing from a RoutingGroup RouteRequest Queue
Removing an entity from a RoutingGroup element's RouteRequestQueue is canceling a Route Step waiting to route this entity to a set of Blocked
node destinations.
Note:
Simio does not support removing from the following types of queues: Node RidePickupQueue, Material AllocationQueue, Network
VisitRequestQueue, Entity VisitRequestQueue, Entity BatchQueue, Station MemberQueue.
344 / 815
Simio Reference Guide
R emoveR ows
RemoveRows
The RemoveRows step may be used to remove all existing rows from an output table. Any table references held by tokens or objects become
invalid.
345 / 815
Simio Reference Guide
R epair
Repair
The Repair step ends a downtime of type Failure Name.
346 / 815
Simio Reference Guide
R eserve
The Reserve step may be used to reserve a resources or materials for possible later use by a specified owner. Other objects will be unable to use
a reserved item unless the reservation is cancelled. Use the UnReserve step to cancel a resource or material reservation.
Resource is used to in this context to refer to Resources, Workers and Vehicles in the Standard Library. Reserved resource capacity is capacity
that, although unallocated, has been set aside for a specific future owner thus preventing its use by anyone else without a reservation.
A Reservations (More) repeat group allows a user to define repeating reservations either through entry into the repeat group or by using a data
table mapped to that repeat group.
If the name of the resource to reserve is a member of a population (i.e., worker or vehicle), the Resource Name can be specified as either the
specific resource within the population, such as 'Truck[1]' or 'Truck[2]' or may alternatively be specified by simply the resource name, such as
'Truck'. If the population of that resource is greater than 1, keep in mind that reserving 'Truck' would always reserve the first member of the
population, Truck[1] unless explicitly specified.
See the Reservations page for more details.
347 / 815
Simio Reference Guide
R esume
Resume
The Resume step may be used to resume model behavior that has been suspended using the Suspend step. The Resume step can resume a
process, the movement of an object or a flow regulator's capability.
If the Resume Type is 'Process', the owner of the process can be the parent object or the associated object of the executing token. If the Resume
Type is 'ObjectMovement', the movement of the parent or associated object or specific object is resumed. The object must be either a link or an
agent. If the Resume Type is 'RegulatorFlow', the name of the flow regulator to resume flow capability is specified.
A Resume Actions (More) repeat group allows a user to define multiple resumed actions either through entry into the repeat group or by using a
data table mapped to that repeat group.
For examples of using the Resume step, please refer to the SimBits EntityStopsOnLink, VehicleFinishesAndParksWhenOffShift and
VehicleStopsWhenServerOffShift.
348 / 815
Simio Reference Guide
R ide
Ride
The Ride step may be used to initiate a transporter ride request for an entity object at a node.
When executing a Ride step, if the rider entity attempts to select a transporter from a group of candidates (e.g., from a list or from a population
of some specific transporter type), the preference will be to select a transporter resource that the entity has reserved. For example, if an entity is
attempting to seize a transporter from a list that contains candidates ‘Worker1’, ‘Worker2’, and ‘Worker3’, and the entity has an active resource
reservation for ‘Worker2’, then the entity will have a preference to select ‘Worker2’ irrespective of the Ride step’s specified reservation method
and selection goal.
Additionally, the Ride step provides a Token Wait Action property in its advanced options. This property controls whether the token executing the
Ride step immediately continues to the next process step, or whether the token waits until the rider entity starts or has finished transferring onto
a selected transporter.
349 / 815
Simio Reference Guide
R oute
Route
The Route step may be used with a RoutingGroup element to route an entity object to a destination selected from a list of candidate nodes.
It is also possible to reserve materials for consumption at an upstream node prior to routing to the destination node. This is done through the
Required Materials repeating property editor.
350 / 815
Simio Reference Guide
Search
Search
The Search step may be used to search a collection of objects or table rows.
A search expression may be specified that is evaluated in the context of each item found by the search. The sum of this expression for the found
items will be stored into the ReturnValue state of the original executing token. That token state value can then be referenced later on in the
process.
The Search step may also be used to create new tokens that are associated with, or point to, the items found by the search. These tokens will
exit the 'Found' exit point of the step. If the search is done on a Collection Type such as 'EntityPopulation', 'QueueState' or 'SeizedResources'
where there is an associated object that can be found, the 'Found' token will be associated with that found object (thus the associated object's
states are accessible for reviewing, changing, etc.). However, if the Collection Type of the Search step is 'TableRows' for example, then the
'Found' token has a pointer to the associated row in the table (and not to any particular object).
There are two exits from the Search step labeled 'Original' and 'Found'. First, the tokens for the found entity(s) will exit the 'Found' exit and
proceed until until a delay type step occurs for the token or its associated entity. Then the original token will exit from the 'Original' exit. The
Math.Epsilon function may be used in a Delay step for the found tokens to affect the order of event processing.
The original token always continues out of the Original segment, regardless of whether or not the Search Step finds anything. All steps that exist
in the Original segment leaving the Search step will always be executed. A new token will only be created in the Found segment if something is
found in the Search step. So if something was found by the Search step, all steps that exist in the Found segment will be executed. But, if nothing
was found by the Search step, then none of the steps that exist in that Found segment will be executed (because a token was never created for
that segment).
Model trace provided for the Search step during the simulation run includes the number of items and exact items found by the search.
Additionally, if the Save Index Found and Save Number Found options are used, the trace includes the state variable assignment information.
For examples of using the Search step, please refer to the SimBits C ONWIP, SearchTables, RoutingWithoutPaths,
VehicleFinishesAndParksWhenOffShift, and VehicleStopsWhenServerOffShift.
Additional information on the Search step can be found in the Search - Discussion and Examples page.
351 / 815
Ending The one-based ending index of the search. When defaulted, the ending index is the last item in the collection if a forward search, or
Index the first item in the collection if a backward search.
Limit The maximum number of objects to find.
Save Index Optional discrete state variable to save the one-based index of the last item found in the collection by the search.
Found
Save Optional discrete state variable to save the total number of items in the collection found by the search.
Number
Found
352 / 815
Simio Reference Guide
Search - Discussion and Examples
This above example can be found in the SearchTables simbit. Additionally, the three scheduling type examples within the Examples folder utilize
the Search step for performing various tasks.
Example 2 - Using Search step to search a Queue for an entity with certain characteristics
In this example, we are searching for a particular entity within a queue state named 'WaitingArea.Queue'. The match condition is specified as
'ModelEntity.TimeC reated == C andidate.Entity.TimeC reated'. The term ModelEntity.TimeCreated refers to the entity's associated token that has
entered the Search step. The term Candidate.Entity.TimeCreated refers to the collection of entities that are located within the WatitingArea queue.
Any time a collection of items are searched, the keyword 'C andidate' should be used in the condition to explicitly reference a candidate entity
within the collection.
The state variable WhichOne will store the index value into the queue of the entity (if any) that is found. This Search step can be found within the
UsingAStorageQueue simbit.
353 / 815
Simio Reference Guide
Seize
Seize
The Seize step may be used to seize capacity of one or more objects on behalf of the parent object or the object associated with the executing
token.
Every object represents a resource with a capacity. Object resources must be seized/released in whole units and can be owned by the parent
object or the object associated with the executing token. The objects to be seized by the owner can be from a specific object or selected from an
object list. In the case of a specific object it can be a static object, such as a Standard Library 'Resource', or selected from a population of
dynamic objects, such as a Standard Library 'Worker' or 'Vehicle'. When selecting from an object list or a population and the number of objects
required is less than the number available, the resource selection rule is used to select between the available objects. An object list may contain
both dynamic objects and static objects. In the case of populations all members within the population are eligible for selection. Object capacity
may be released later by either a specific name or by an object list name. In the case of a list name, the objects that are owned from the
specified list are eligible to be released. They are released based on order which is specified as FirstSeized or LastSeized.
The resource may be allocated to either the parent object or associated object. If it is seized by the parent object then it must be released by the
parent object. If it is seized by the associated object then it may be carried by the associated object across multiple objects.
The Seize step may be used in conjunction with the Release step.
For examples of using the Seize step, please refer to the SimBits OverflowWIP, ResourcesWithWorkSchedules, SeizingVehicle and
SelectingResourceFromList.
354 / 815
Simio Reference Guide
SelectDropoff
SelectDropoff
The SelectDropoff step may be used to set the destination node of a transporter object to the drop-off location of a riding entity.
If a destination is selected the token exits the primary exit point, otherwise it exits the failed exit point.
355 / 815
Simio Reference Guide
SelectVisit
SelectVisit
The SelectVisit step may be used to set the destination node of an entity object to the location of an accepted visit request. Possible visit requests
may include pickup requests initiated at Ride steps (applicable to transporter entities) as well as move requests initiated at Seize or Move steps
(applicable to resource enabled entities). To have an entity first search for and accept a not yet reserved visit request in the system, use the
PlanVisit step.
If a destination is selected the token exits the primary exit point, otherwise it exits the failed exit point.
356 / 815
Simio Reference Guide
SetNetwork
SetNetwork
The SetNetwork step may be used to set the network of links used by an entity to travel between node locations.
357 / 815
Simio Reference Guide
SetNode
SetNode
The SetNode step may be used to set the destination node of any entity object.
For an example of using the SetNode step, please refer to the SimBit SearchTables.
Entity Type The entity object whose destination node value is to be set. May be specified as either the object associated with the
executing token, the parent object, or as a specific object reference.
Entity Object The specific entity object whose destination node value is to be set.
Auto C lear If Visit Indicates whether to automatically clear the assigned destination node if for any reason the entity visits a different node
Different Node beforehand.
358 / 815
Simio Reference Guide
SetR ow
SetRow
The SetRow step (formerly named SetTable) may be used to assign a data table or sequence table to a token or object, or to set or reset the
current associated row. The current row index into the table is specified by the RowIndex property. A token or an object can be bound to more
than one table at a time. To do this, simply use two SetRow steps to reference each table of interest.
For more information, please refer to the SetRow - Discussion and Examples page.
For examples of using the SetRow step, please refer to the SimBits EntityFollowsSequenceWithTable, EntityFollowsSequenceWithTable2,
LeveledArrivals, SelectEntityTypeFromTable and UsingRelationalTables.
359 / 815
Simio Reference Guide
SetR ow - Discussion and Examples
Example
360 / 815
Simio Reference Guide
StartActivity
StartActivity
The StartActivity step starts the next activity in a reserved operation.
361 / 815
Simio Reference Guide
StartO peration
StartOperation
The StartOperation step starts an operation.
An operation cannot start until capacity is available and a time slot is available. The required time slot is the best case time based on the parent
work schedule - this is extended by the buffer time to account for delays caused by secondary resources, materials, travel, etc. If capacity is
available and the best case time slot is available it seizes the parent resource and starts the operation. If the actual operation time exceeds the
available time slot the future operation is slipped to accommodate this operation.
362 / 815
Simio Reference Guide
StartT asks
StartTasks
The StartTasks step is used to initiate a task sequence that is associated with an object in the model. Refer to the Task Sequence element to
define a task sequence.
363 / 815
Simio Reference Guide
Subscribe
Subscribe
The Subscribe step may be used to add a new triggering event for a process, indicating that the process is to be executed if the event occurs.
Multiple events may be subscribed to within a single Subscribe step by using the Events (More) repeating group of properties.
The Event C ondition property allows a condition to be evaluated when the event occurs. This condition must be evaluated to True to trigger the
process that is specified.
An example of its use would be in the scenario where a Server seizes a Resource before it starts processing and the Resource goes on and off
shift during the run. If you want the Server to stop processing when the Resource goes off shift, the Subscribe step can be used to trigger a
process that will suspend the Server when the event Resource.CapacityChanged occurs and the new capacity is 0. In this example, the process
that will suspend the Server would use a Suspend Step to suspend the OnEnteredProcessing process of the Server. Since this process is not a
public process in the Standard Library Server object, the user would need to subclass a Server object, override the OnEnteredProcess process
and change the Public property to 'True'. After these changes, that process will be available in the Suspend Step.
Also, the Workstation object takes advantage of these steps to suspend or resume the processing of the current job if any secondary resources
go ‘off-shift’ or ‘on-shift’ respectively.
For an example of using the Subscribe step, please refer to the SimBit EntityStopsOnLink.
364 / 815
Simio Reference Guide
Suspend
Suspend
The Suspend step may be used to suspend various types of model behavior. The Resume step may then be later used to remove the suspension.
The Suspend step can suspend a process, the movement of an object or a flow regulator's flow capability.
If the Suspend Type is 'Process', the owner of the process can be the parent object or the associated object of the executing token. The tokens in
the process are all frozen in their current state. If a process is suspended that is not yet started, when it is "started" it will be immediately
suspended. If the Suspend Type is 'ObjectMovement', the movement of the parent or associated object or specific object is suspended. The
object must be either a link or an agent. If the Suspend Type is 'RegulatorFlow', the name of the flow regulator to suspend is specified.
A Suspend Actions (More) repeat group allows a user to define multiple suspended actions either through entry into the repeat group or by using
a data table mapped to that repeat group.
For examples of using the Suspend step, please refer to the SimBits EntityStopsOnLink, VehicleFinishesAndParksWhenOffShift and
VehicleStopsWhenServerOffShift.
365 / 815
Simio Reference Guide
T ally
Tally
The Tally step tallies an observation for each token arriving to this step.
The recorded value can be specified as an expression or can be the time between arrivals to the Tally step. The values are recorded by a
TallyStatistic element.
For examples of using the Tally step, please refer to the SimBits TallyStatisticsInTable, SourceServerSinkApproaches and HourlyStatistic.
366 / 815
Simio Reference Guide
T ransfer
Transfer
The Transfer step may be used to transfer an entity object between objects and between different types of locations, such as free space and
objects.
If transferring an entity to a node, the Transfer step automatically sets the entity's destination to that node if the entity does not already have a
destination set.
A user can use a Transfer step to transfer an object between object locations without the entity having to use the external nodes to enter and exit
objects. So, for example, you can immediately transfer an entity from inside object A to a node outside object B using the Transfer step.
Whenever attempting a transfer from 'C urrentNode' to 'OutboundLink', if the entity's C urrentTravelMode state is 'Free Space Only' or the entity
has no network assigned then the transfer attempt will fail and the token exits the 'Failed' exit point of the Transfer step. Whenever attempting a
transfer from 'C urrentNode' to 'FreeSpace', if the entity has an assigned network and its C urrentTravelMode is 'Network Only' then the transfer
attempt will fail and the token exits the 'Failed' exit point of the Transfer step. Whenever attempting a transfer from 'C urrentNode' to
'OutboundLink', if there is only 1 possible outbound link from the node that is a member of the entity's currently assigned network, and the
Outbound Link Rule is 'Shortest Path' but there is no followable network path to the entity's next destination, then:
If the entity's C urrentTravelMode state is 'Network Only', then the Transfer step will go ahead and still transfer the entity onto the sole
outbound link. This behaviour allows for the possibility that a followable network path emerges after the entity moves through the next
downstream object.
If the entity's C urrentTravelMode state is 'Network If Possible', then the transfer attempt will fail and the token exits the 'Failed' exit point
of the Transfer step. This behavior allows the entity to then do an immediate transfer from 'C urrentNode' to 'FreeSpace' in order to begin
traveling to its next destination in free space.
Note:
It is only safe at this point to Transfer an entity into or out of an object through the external nodes since most objects make the assumption
that an entity is going to enter or exit through nodes. For example, external logic might immediately Transfer an entity out of a Server object
and transfer it over to some other location outside the logic. However, if that happens, the tokens running inside the Server will not realize that
the entity was transferred out and it will assume the entity is still inside the Server. It will continue trying to process the entity and an error will
occur.
For examples of using the Transfer step, please refer to the SimBits C ONWIP, DynamicallyC reatingVehicles, and FreeSpaceMovement.
Outbound The rule used by the entity to select an outbound link from its current node to its next destination. Note that if the rule is set to
Link Rule 'Shortest Path', and the entity does not have an assigned destination, then the rule will revert to 'By Link Weight' selection.
Outbound The name of the specific outbound link that will be selected by the entity.
Link Name
C ontainer The name of the container into which the entity is to be transferred. This property is visible when To is 'C ontainer'.
Name
Flow The regulator used if transferring the entity's mass and volume as a continuous flow into the new location. This property is visible
Regulator when To is 'AssociatedObject', 'OutboundLink' or 'C ontainer'.
Name
Entity The entity object to be transferred. Specified as either the object associated with the executing token, the parent object, or as a
Type specific object reference.
Entity The specific entity object that is to be transferred.
Object
Random The random number stream to be used if the entity is transferring from current node to outbound link and is probabilistically
Number selecting the outbound link using the node's 'By Link Weight' outbound link rule.
Stream
Fail If Indicates whether to cancel the transfer attempt if the location where the entity is to be physically transferred into is considered
Blocked blocked. If the transfer attempt is cancelled, then the arriving token will immediately exit the 'Failed' exit point of the Transfer step.
367 / 815
Token The wait action to be taken by the token arriving to the Transfer step. Options include WaitUntilTransferredEvent and
Wait WaitUntilTransferringEvent.
Action
368 / 815
Simio Reference Guide
T ransfer - Discussion and Examples
Example 1 - Current Node to Outbound Link Using Various Outbound Link Preferences
If you wanted to model a train moving on a track network, then the leading locomotive at a node in the track network might execute a Transfer
step from current node to outbound link using an Outbound Link Preference of ‘Default’.
Each following ‘RailC ar’ object in a train, to simply select from a node the same outbound link that was selected by the car or locomotive
immediately in front of them, might execute a Transfer step using Outbound Link Preference of ‘Specific’ and Outbound Link Name specified as
‘RailC ar.TrainPredecessor.TrailingLink’, where ‘TrainPredecessor’ would be an entity reference state variable on a railroad car that is pointing to
the predecessor car or locomotive that the railcar is directly connected to and immediately following.
369 / 815
Simio Reference Guide
T ravel
Travel
The Travel step may be used to do a direct (straight-line) movement of an entity in free space to a specified location. The executing token may
be held at the Travel step until the travel movement is completed (Token Wait Option set to 'WaitUntilTravelC ompleted') or it may continue
through its steps (Token Wait Option set to 'None (C ontinue)') while the travel occurs.
The default Steering Behavior is 'Direct to Destination' where the travel destination can be specified as a specific fixed (non-moveable) object, as
absolute coordinates, or as relative coordinates from the entity's current location. Additionally, a desired maximum movement rate and ending
movement rate for the travel may be specified.
A Steering Behavior of 'Follow Network Path' requires a starting and ending node. The entity will then follow the shortest path between them in
free space, attempting to stay within the boundries of the links, defined by each link's Width (or 1 meter if no Width is defined). The Path Width
can also be varied so that the entity can directly specify a radius that will override the link's width.
The free space travel movement will be automatically cancelled if another Travel step is executed, the entity is transferred out of free space, or if
any of the entity's movement parameters are changed by unrelated model logic (e.g., an Assign step is used to deviate the entity's movement
direction or rate from the active travel operation's assigned parameters).
The Suspend and Resume steps may be used to suspend and resume the free-space travel movement.
Entity objects (such as ModelEntity, Worker, and Vehicle) have an OnEnteredFreeSpace standard process that is executed if the entity transfers
from a non-free space location into free space.
For an example of using the Transfer step, please refer to the SimBit FreeSpaceMovement.
370 / 815
Simio Reference Guide
UnBatch
UnBatch
The UnBatch step may be used to remove batch members from a parent entity object. A new token associated with an unbatched member will
exit the 'Member' exit point of the step. Use the Batch step to add batch members.
The Match Condition property may be used to unbatch only certain entities from the batch based on a condition specified. For example, a Match
Condition may be specified as 'C andidate.ModelEntity.Is.RedPart' where RedPart is the name of the entity. When unbatched from the parent, only
those entities of type RedPart will be unbatched and any other members of the batch (BluePart, GreenPart, etc.) will remain with the batch. The
Removal Order can be used to determine the order of searching for the Desired Split Quantity number of members to unbatch.
When a member entity is unbatched from a parent entity, it is placed into free-space at the same XYZ location of the parent entity. C urrently,
Simio only supports UnBatch into free space, not directly into a node. Free-space has no possible content capacity constraints so the members
are unbatched there. Then, a Transfer step should be used to transfer the member entity into the station or node desired. If the Transfer step is
not used, then by default, when an entity enters free space, it simply starts traveling at its desired in whatever current direction it happens to be
pointing in. However, the ModelEntity’s OnEnteredFreeSpace logic assigns the movement rate of the entity to ‘0.0’ if the entity can’t determine a
free space travel movement to some particular node.
The UnBatch step is used internally within the Separate object in the Standard Library for unbatching. The member entity token enters a Transfer
step after the UnBatch step to move the entity into the member output buffer station.
For an example of the Unbatch step, see the C ustomUnbatching or UsingAStorageQueue SimBit.
Parent Entity The parent entity object that is carrying the batch members. May be specified as either the object associated with the executing
Type token, the parent object, or as a specific object reference.
Parent Entity The specific parent entity object that is carrying the batch members.
Object
371 / 815
Simio Reference Guide
UnP ark
UnPark
The UnPark step may be used to transfer an entity object out of a node's parking station and into the node.
The Token Wait Action property indicates whether the token is going to wait in the step until the transferring entity ‘Transferring’ or ‘Transferred’
event is fired.
372 / 815
Simio Reference Guide
UnR eserve
The UnReserve step may be used to cancel any reservations for resources or materials made by a specified owner. Use the Reserve step to
create a new resource or material reservation.
If the name of the resource to unreserve is a member of a population (i.e., worker or vehicle), the Resource Name can be specified as either the
specific resource within the population, such as 'Truck[1]' or 'Truck[2]' or may alternatively be specified by simply the resource name, such as
'Truck'. If the population of that resource is greater than 1, keep in mind that unreserving 'Truck' would always unreserve the first member of the
population (numerically) that has been reserved. For example, let's say an entity has reserved Truck[3] and Truck[1]. Then, if the entity tries to
unreserve 'Truck', if Truck[1] still has an outstanding reservation, it will first be unreserved, otherwise Truck[3] will be unreserved.
See the Reservations page for more details.
373 / 815
Simio Reference Guide
Unsubscribe
Unsubscribe
The Unsubscribe step may be used to cancel a triggering event for a process. This is used in conjunction with the Subscribe step. See the
Subscribe step for an example of use. Multiple events and processes may be specified within a single Unsubscribe step by using the Events
(More) repeating properties.
374 / 815
Simio Reference Guide
VisitNode
VisitNode
The VisitNode step may be used within a node object's logic to initiate the OnVisitingNode process of the entity associated with the executing
token. The token waits until the entity's OnVisitingNode process is completed before exiting the step.
Note:
This Step can only be used from within a Node object.
375 / 815
Simio Reference Guide
W ait
Wait
The Wait step may be used to hold the arriving token in the step until one or more specified events occur.
The Token Wait Action determines whether the arriving token is waiting for all of the specified events to occur ('WaitUntilAllEvents') or just a
single event to occur ('WaitUntilAnyEvent').
The tokens are released from the Wait step in order that they arrived to the step (that is, First In First Out). When multiple tokens are waiting at
the Wait step, all tokens are released when the specified event is fired.
The Wait step can be used in conjunction with the Fire step.
For examples of using the Wait step, please refer to the SimBits EntityStopsOnLink, VehicleVisitsServiceC enter, and
VehicleFinishesAndParksWhenOffShift.
376 / 815
Simio Reference Guide
T he Definitions W indow
Note:
The collapsable feature of the inherited properties, states, and events is only available with the Microsoft Vista O/S or higher. Earlier versions of
the O/S will not see the inherited properties, states and events collapsed.
377 / 815
Simio Reference Guide
Elements
Elements represent things in a process that change state over time. Elements are added to a list and then referenced by one or more process
steps in the Processes window. The elements within Simio include the following:
Activity is performed by an operation that is owned by an object.
BatchLogic element may be used in conjunction with the Batch step to match multiple entities together, form those entities into a batch, and then
attach the batched members to a parent entity.
C ontainer element may be used to define a volume or weight capacity constrained location for holding entities representing quantities of fluids or
other mass. Use the Tranfer step to initiate tranfers of entities into or out of a container.
C ostC enter element may be used to define an identifiable area of responsibility where costs are allocated or incurred. C ost centers may be linked
in a hierarchical structure for cost accounting and reporting purposes, whereby costs are automatically rolled up through the cost center
hierarchy.
Failure element may be used to define a failure mode. Failure downtime occurrences are started and ended using the Fail and Repair steps.
Material can be consumed and produced by tokens.
Monitor element may be used to monitor a state variable and fire an event whenever there is a discrete change or threshold crossing of the state
value.
Network is a list of links to which an entity may be assigned to follow via the shortest path to its destination.
Operation is a sequence of activities that are performed by an object over time.
OutputStatistic element defines an expression that can be optionally recorded at the end of each replication of a simulation.
Regulator element may be used to regulate flow rates into or out of a location. Use the Regulate step to change regulator maximum flow rates as
well as perform more complex regulator flow actions involving wait conditions.
RoutingGroup element is used with a Route step to route an entity object to a destination selected from a list of candidate nodes.
StateStatistic element may be used to record time-persistent statistics on a state variable.
Station element may be used to define a capacity constrained location within an object where one or more visiting entity objects can reside. The
Transfer step is used to transfer entities into and out of a station.
Storage element may be used to define a custom queue state for temporarily holding one or more objects. The Insert and Remove steps are
used to insert and remove objects from the storage element's queue.
TallyStatistic element tallies observational statistics that are recorded using the Tally step.
TaskSequence element may be used to more easilyl define and execute structured sequences of processing tasks. The StartTasks step is used to
start a task sequence that is associated with an object in the system.
Timer element fires a stream of events according to a specified IntervalType.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for all Elements. Please refer to the User Interface for more details.
378 / 815
Simio Reference Guide
Elements R eference
This Elements Reference section has detailed information for all elements in Simio.
379 / 815
Simio Reference Guide
Activity
Activity
An activity is performed by an operation that is owned by an object.
An operation is a sequence of activities that are performed by an object over time. Time slots for operations/activities may be reserved in the
future. Activities may be started and ended. An activity time scales by a work schedule (if any). Activity times can be specific, change dependent,
or sequence dependent. Dependent times are based on an entity list value. This list value (numeric) is typically provided by a list property (color,
size, type, etc.) on the entity.
380 / 815
Simio Reference Guide
BatchLogic
BatchLogic
The BatchLogic element may be used in conjunction with the Batch step to match multiple entities together, form those entities into a batch, and
then attach the batched members to a parent entity.
381 / 815
Simio Reference Guide
C ontainer
Container
The C ontainer element may be used to define a volume or weight capacity constrained location for holding entities representing quantities of
fluids or other mass. Use the Transfer step to initiate tranfers of entities into or out of a container.
The states listed below for the flow into and out of C ontainers are read-only. These may be monitored to detect when a target volume or weight
quantity has been transferred (e.g., new monitor threshold = C ontainerName.C urrentVolumeFlowIn + SomeVolumeQuantity). The rate values of
the state variables might be monitored to detect flow rate changes (e.g., you could monitor C ontainerX.C urrentVolumeFlowIn.Rate for changes).
Statistics are generated automatically for the flow in and flow out of a container based on the flow states listed below.
For examples of using the C ontainer element, please refer to the Flow Library objects including FlowSource, FlowSink, and Tank.
382 / 815
Simio Reference Guide
C ostC enter
CostCenter
The C ostC enter may be used to define an identifiable area of responsibility where costs are allocated or incurred. C ost centers may be linked in a
hierarchical structure for cost accounting and reporting purposes, whereby costs are automatically rolled up through the cost center hierarchy.
C osts can be manually assigned to a C ost C enter element by using an Assign Step. The C ost is updated by assigning a value to C ostC enter.C ost
and the Rate is updated by assigning a value to C ostC enter.C ost.Rate
383 / 815
Simio Reference Guide
Failure
Failure
The Failure element may be used to define a failure mode. Failure downtime occurrences are started and ended using the Fail and Repair steps.
384 / 815
Simio Reference Guide
Material
Material
Material can be consumed and produced by tokens using the C onsume and Produce steps. Material may also be reserved and unreserved by
using the Reserve and UnReserve steps.
Only the first waiting token may consume material. SmallestValueFirst and MaxValue rankings are based on the priority specified on the C onsume
step. Material is hierarchical and may hold a bill of material that is required to produce the top level material. Material may be
consumed/produced at the top level, or the expanded bill of material. Materials may be consumed or produced through the Workstation object
within the Standard Library also, as well as through the Task Sequences within Server, C ombiner and Separator objects.
The material functions, QuantityC onsumed and QuantityProduced, are statistics functions that return the total material quantity consumed or
produced during the run. These values are cleared at the end of a warm-up period.
For an example of using the Material element, please refer to the SimBit ScheduledMaterialArrivals.
385 / 815
Simio Reference Guide
Monitor
Monitor
The Monitor element may be used to detect a discrete value change or threshold crossing of a specified state variable. It is added to a model
from the Elements panel found within the Definitions window.
The Monitor has an Enabled state that allows the Monitor to be enabled/disabled.
When a Monitor event is fired, if there are any processes specified to be triggered by that event, then the created tokens are associated with the
object that owns the Monitor element. For additional information, visit the Monitor - Discussions and Examples page.
The Monitor's Initial Threshold Value may be changed during the simulation run by assigning the 'MonitorName.C urrentThresholdValue' state to a
new value.
For examples of using the Monitor element, please refer to the SimBits DynamicallyC reatingVehicles, UsingaMonitor and WritingToAFile.
The State Variable Name to be monitored may be a member of an object or element reference state variable (i.e.,
EntityReferenceState.StateName) which allows the state variable monitored by an individual Monitor element to dynamically change. The Monitor
element will 're-wire' to the state variable to be monitored each time the Monitor is enabled (i.e., its Enabled state changes from False to True).
386 / 815
Simio Reference Guide
Monitor - Discussion and Examples
Discussion
In order to have a process execute when a Monitor fires its event, the Triggering Event property on the Process must be set to the name of the
Monitor's event. A new process can be created from the Steps tab of the Processes Window by clicking the C reate Process button in the ribbon. In
the Properties window of this new process, select the name of the Monitor (.Event) from the drop down of the Triggering Event property. This will
cause this process to be executed each time the specified Monitor fires an event.
Linking a Monitor's Event and a Process
Monitor Example 1
The following is an example of a Monitor that watches a predefined Simio queue state, called Server1.InputBuffer.C ontents, which holds the value
for the number of entities currently waiting in the InputBuffer of the object called Server1.
Since its MonitorType property is set to 'C rossingStateC hange', this Monitor will fire an event when the value of
Server1.InputBuffer.C ontents crosses over the specified Threshold Value, which is 3.
Because the CrossingDirection property is set to 'Positive', the Monitor will fire when the value crosses in the positive direction from 3 to 4,
not in the negative direction from 3 to 2.
The On Change Detected Process property is set to the process named 'Monitor1_OnC hangeDetectedProcess' so as soon as the Monitor's
event is fired, it will execute 'Monitor1_OnC hangeDetectedProcess' before any other logic is executed.
Properties Window of a Monitor Element
387 / 815
Simio Reference Guide
Network
Network
A Network is a list of links to which an entity may be assigned to follow via the shortest path to its destination.
A link may be in multiple networks. The Network keeps a master list of network nodes for each node that is connected in the network. A node is
considered connected if it has at least one incoming or outgoing link that is a member of the network. Each interection has a list of network nodes
- one for each network that the node is a member (by being the starting or ending node of a member link). Hence each network node is both on
the master list of network nodes owned by the network, and the local list of network nodes owned by the node. Each network node keeps a list of
outbound member links, and a count of inbound member links. When both counts are zero, the node is removed from both the master list and the
node list. Each network node has a vector of shortest path links from this node to all nodes in the master network node list. Each vector is
indexed in the same order as the master network node list owned by the network. The shortest path link is found by locating the network node
for the destination transfer station in this master list, and then using the index of this node to index into the shortest path vector. Hence the
runtime computation is O(n), where n is the number of network nodes. This can be improved by implementing a compare function to sort the list,
and then using a binary search. The shortest path vector is only computed for network nodes with 2 or more outbound links. The
C omputeShortestNetwork method is called to compute the shortest path vector for each of these nodes.
The NextLink and NextNode functions listed below will allow process logic to 'walk along' the shortest path from one node to another node, link by
link and/or node by node.
For more information regarding the Turnaround Method, see the Path - Discussion and Examples page.
388 / 815
Simio Reference Guide
O peration
Operation
An operation is a sequence of activities that are performed by an object over time.
An operation may have one or more activities.
*Note: The above function is currently used by the Workstation in its logic to not allow an entity to seize the Workstation unless the following
condition is true: (Operation.EstimatedMakespanFor(Entity) = (MaximumMakespan - MakespanBufferTime)
389 / 815
condition is true: (Operation.EstimatedMakespanFor(Entity) = (MaximumMakespan - MakespanBufferTime)
390 / 815
Simio Reference Guide
O utputStatistic
OutputStatistic
The OutputStatistic element defines an expression that can be optionally recorded at the end of each replication of a simulation.
391 / 815
Simio Reference Guide
O utputStatistic - Discussion and Examples
OutputStatistic Example 1
The following is an example of a OutputStatistic element that is evaluating an expression which uses three different state variables to determine a
price for bad customer service.
The Expression property is evaluated and recorded at the end of each replication of the simulation. It multiplies the value of the state
WaitForTable and multiplies it by a factor of 3.5. It does the same for the states WaitForGreeting and WaitForFood, using different pricing
factors and adds these all together.
The Category property is set to 'C osts', indicating that this OutputStatistic will appear in the user defined C ategory called 'C osts' in the
pivot table within the Results Window.
Properties Window of the OutputStatistic Element
392 / 815
Simio Reference Guide
R egulator
Regulator
The Regulator element may be used to regulate flow transfers of entities into or out of a location.
The Regulator is modeled after a "pump", where the C urrentMaximumFlowRate state is the throttle/speed setting, and the Enabled state is the
on/off switch.
If the Input Flow Control Mode of a Regulator is set to 'MergeFlow', entities with different Destination Nodes will not be merged. Simio dynamically
stops/starts merging if an entity waiting or in a merge at a regulator changes its Destination Node.
Merge Allocation Rules when merging inflow include 'ProportionalBasedOnInflowRates', 'PreferredOrderByQueueRank' and
'ProportionalBasedOnExpression'.
The states listed below for the flow out of Regulators are read-only. These may be monitored to detect when a target volume or weight quantity
has been transferred (e.g., new monitor threshold = RegulatorXYZ.C urrentVolumeFlowOut + SomeVolumeQuantity). The rate values of the state
variables might be monitored to detect flow rate changes (e.g., you could monitor Regulator.C urrentVolumeFlowOut.Rate for changes).
The Initial Output Yield Factor property specifies the yield factor for the start of the simulation run. The Regulator.C urrentOutputYieldFactor can be
assigned to change the yield over the course of the simulation run.
When a regulator is disabled and then enabled again, the outbound link selections are reevaluated.
Statistics are generated automatically for the flow out of a regulator, based on the flow states listed below, if the value is greater than 0. Statistics
will also be reported on the flow in for the regulator, if the value is not equal to the flow out (that is, if a yield factor is applied).
For examples of using the Regulator element, please refer to the Flow Example models on the Simio User Forum (xFlowNode). The Regulator
element is used inside the FlowNode object.
393 / 815
C urrentWeightFlowOut State to get the current total weight flowed out of this regulator. The 'rate' from this state is also available.
Enabled Indicates whether the regulator is currently enabled.
394 / 815
Simio Reference Guide
R outingG roup
RoutingGroup
The RoutingGroup element is used with a Route step to route an entity object to a destination selected from a list of candidate nodes (a Node
List). If using only a static Route Request Ranking Rule on a RoutingGroup, when the destination in the RoutingGroup becomes available, the
algorithm is to search through the RouteRequestQueue starting at Rank 1 and find the first eligible entity that meets eligibility requirements.
The Standard Library TransferNode object uses a RoutingGroup element in its internal logic to determine where the entities will travel when they
leave the node. A user can create their own RoutingGroup element for use in a custom object.
The TransferNode also includes an option to 'Use C ustom Routing Group' within the Entity Destination Type property. This advanced option allows
users to reference a custom RoutingGroup element directly within the TransferNode. There are several use cases for using this feature which are
noted within the TransferNode - Discussion and Examples page. One use case is if multiple routing entities are blocked and waiting for an
available destination (i.e., select the next entity to route from multiple blocked waiting locations), the RoutingGroup element provides a Dynamic
Selection rule to dynamically select one of the waiting entities. This is a similar feature to a resource object being able to dynamically select an
entity waiting to seize.
By default, for each candidate destination node in a Routing Group element’s node list that is an ‘Input’ node into an associated object station
location, the Routing Group automatically listens for station state changes (such as entities entering or exiting the station or the station’s capacity
changing) and then does a selection search through its RouteRequestQueue. The default Destination Blocked Condition that is specified for the
Routing Group element includes a default definition of blocked that is based on a candidate node being an ‘Input’ node with an associated station
and it is considered ‘blocked’ if the associated station does not have any remaining capacity. There may, however, be modeling situations where
just listening for station state changes at ‘Input’ nodes is not enough triggering events for the Routing Group to cover all possible selection search
scenarios. Sometimes, an additional selection search may need to a be triggered based on a conditional upstream system event (i.e., the number
of entities waiting on a path larger than 3). The Select Route Requests Triggers repeat group of Triggering Events/C onditions allows users to
define additional triggers that will cause re-evaluation of the routing group logic.
There are two processes that may be executed from within this RoutingGroup element, during and after the decision making process for the
destination. These include the On Evaluating Route Request Process and the On Destination Node Assigned Process properties.
395 / 815
Simio Reference Guide
StateStatistic
StateStatistic
The StateStatistic element may be used to record time-persistent statistics on a state variable. It is added to a model from the Elements panel
within the Definitions window.
If the state variable is a continuous-change variable, then a trapezoidal integration method is used to record the statistical observations.
Otherwise, for a discrete state variable, a rectangular integration method is used.
NOTE: Runtime confidence interval half-widths are never calculated when running an experiment scenario for multiple replications or when
running the model interactively. The C onfidence Level property of a StateStatistic element thus only applies if running an experiment scenario for
a single replication. For more information, see the Batch Means section of Experiments page.
For examples of a StateStatistic, see the StateStatistic - Discussion and Examples page.
396 / 815
Simio Reference Guide
StateStatistic - Discussion and Examples
StateStatistic Example 1
The following is an example of a StateStatistic element.
Since its State Variable Name property is set to 'NumberFailed', it will collect statistics on the state variable called NumberFailed.
The Category property determines what will appear in the Pivot table of the Results Window in the C ategory field. In this example, it will
show the value of 'User'. The user can put any word into this field in order to add custom organization of the Pivot Table.
The Data Item property is set to 'General' which indicates that in the Pivot Table of the Results Window, the word 'General' will appear in
the Data Item cateogry. The user can put any word into this field in order to add custom organization of the Pivot Table.
StateStatistic Element and How it Appears in the Results Window
StateStatistic Example 2
The following is an example of a StateStatistic element that is also being used to stop the simulation run.
Since its State Variable Name property is set to 'NumberInSystem', it will collect statistics on the state variable called NumberInSystem.
The Stopping Condition property is evaluated each time a value is recorded for the statistic NumberInSystem. When it is evaluated, if the
expression evaluates to 'True' then the simulation run is ended. In this case, the simulation run ends whenever the NumberInSystem
equals 0 and the simulation has run for at least 8 hours.
StateStatistic Element with Stopping Condition to End the Simulation Run
397 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
398 / 815
Simio Reference Guide
Station
Station
The Station element may be used to define a capacity constrained location for holding entities representing discrete items. The Transfer step is
used to transfer entities into and out of a station. The EndTransfer step should be used to end the entity transfer into a Station. A Station element
is added to a model from the Elements panel within the Definitions window.
Station elements are built into some of the Simio Standard Library objects. Some examples are: Server.InputBuffer, Server.Processing,
Server.OutputBuffer, C ombiner.ParentInputBuffer, Separator.MemberOutputBuffer, Workstation.Processing, Vehicle.RideStation, etc.
The contents of a station queue can be accessed by utilizing the 'C ontents' state of the station. For example, 'Server1.InputBuffer.C ontents'
displays the contents of the queue at the Server1 InputBuffer station. See the Functions in Simio - Automatic page for various functions that can
be accessed for queues.
The Station element's C ontents queue also has several read-only parameters (not for all queues, only Station content queues). This includes
Volume, Volume.Rate, Weight and Weight.Rate. These parameters represent the cumulative Weight and Volume of the contents of the queue.
Since they are parameters, they can also be used in a Monitor, so you can see when the volume of objects in a given station exceeds a specified
value. As an example, 'Server1.OutputBuffer.C ontents.Weight' would provide the cumulative weight of all the entities waiting in the output buffer
of Server1.
Visit the Station - Discussions and Examples page for more information.
400 / 815
Simio Reference Guide
Station - Discussion and Examples
Station Example 1
The following is an example of a Station element that uses a Dynamic Selection Rule to select which entity can enter in to this Station next.
Since its Dynamic Selection Rule property is set to 'Largest Value First', if this Stations capacity becomes available and there are entities in
the Entry Queue, this Station will select entities from the Entry Queue based on the rule of Largest Value First.
The Value Expression property is set to 'C andidate.Entity.Priority', so the Station will select the entity with the largest value for the state
ModelEntity.Priority.
The Filter Expression property is set to 'C andidate.ModelEntity.PartType == 2' so it will only look to select entities that meet this criteria.
Properties Window of a Station Element
401 / 815
Simio Reference Guide
Storage
Storage
The Storage element may be used to define a queue for temporarily holding one or more objects. A Storage element is added to a model from
the Elements panel in the Definitions window. The Insert and Remove steps are used to insert and remove objects from the Storage element's
queue. There are functions that can be used to get information about a Queue State.
A queue can be animated from the Drawing Tab by selecting Detached Queue.
402 / 815
Simio Reference Guide
Storage - Discussion and Examples
Storage Example 1
The following is an example of a basic Storage element.
Since its Ranking Rule property is set to 'FirstInFirstOut', the first entity that enters this queue will be the first to leave, when a Remove
step is used to take entities out of the queue.
An Insert Step is used to add entities to the Storage queue. In this example, an entity is the associated object of the token that is
executing the process, so the Object Type property of the Insert Step is set to 'AssociatedObject'.
Since Rank Placement property is blank, the entities simply follow the static ranking rule of FirstInFirstOut to determine their placement in
the queue.
A Remove Step takes the entity out of the queue. An entity also leaves the queue if it has been destroyed elsewhere in the system.
Storage Element and Related Steps
403 / 815
Simio Reference Guide
T allyStatistic
TallyStatistic
The TallyStatistic element tallies observational statistics that are recorded using the Tally step. It is added to a model from the Elements panel
within the Definitions window.
The TallyStatistic element is referenced by the Tally step which specifies a value to be tallied. A single TallyStatistic element may be referenced
by multiple Tally Steps.
NOTE: Runtime confidence interval half-widths are never calculated when running an experiment scenario for multiple replications or when
running the model interactively. The C onfidence Level property of a TallyStatistic element thus only applies if running an experiment scenario for
a single replication. For more information, see the Batch Means section of Experiments page.
For additional information, including functions for tally statistics, examples and logging observations, see the TallyStatistic - Discussion and
Examples page.
404 / 815
Simio Reference Guide
T allyStatistic - Discussion and Examples
Discussion
The following functions are available for a TallyStatistic and can be used in an Expression within your model logic or displayed in a Status Label or
Floor Label in the Facility window (see Functions for information on what value they return):
TallyStatistic.Average
TallyStatistic.HalfWidth
TallyStatistic.LastRecordedValue
TallyStatistic.Maximum
TallyStatistic.Minimum
TallyStatistic.NumberObservations
TallyStatistic Example 1
The following is an example of a TallyStatistic element that tallies the time it takes for an entity to arrive at Server2.
The TallyStatistic is created in the Elements panel within the Definitions window. It is simply given a name, an optional label, category and
data item in its properties window. In this example, the Confidence Level property is set to 90%, which will determine how the Half Width is
calculated in the results.
In order to use a TallyStatistic, a Tally Step must be inserted into the logic of the model. In this example, the Tally Step is added to a
process that is triggered by the Entered Add-On process trigger of the Input Node of Server2.
The Value property is set to the expression 'Run.TimeNow - ModelEntity.TimeC reated'. Run.TimeNow is the current simulation time and
ModelEntity.TimeC reated is a Simio function that returns the simulation time when this entity was first created. The result of this
expression is recorded into the TallyStatistic each time this Tally Step is executed.
Using a TallyStatistic Element
405 / 815
Simio Reference Guide
T askSequence
TaskSequence
A Task Sequence element is used to define and execute structured sequences of processing tasks. A StartTasks step references a Task Sequence
element and is used to start a task sequence that is associated with an object in the system.
The Task Sequence Number Scheme
The task sequence numbering scheme supported by the Task Sequence element has the following format:
XX.YY.YY.YY…
XX is an integer referred to as the root sequence number. This number is the primary key that determines the serial precedence requirements of
a task.
YY are optional integer suffixes separated by dots (periods) that can be appended to the root sequence number in order to define parallel
subsequences in the task workflow. As many suffixes as needed may be appended to a root number to represent the desired task sequence
structure accurately.
The precedence rules used to determine task order are as follows:
1. If the task sequence number consists of only a root number (only XX), then all tasks with lower root numbers (ignoring any suffixes) must
precede that task. Note: It is possible to have one or more tasks with the same root sequence number, with or without suffixes.
2. If the task sequence number consists of a root number and one or more suffixes, then all tasks with lower root numbers must precede
that task, as long as those tasks either have no suffixes or all shared suffixes match.
3. If the task sequence number consists of a root number and one or more suffixes, then all tasks whose sequence number is the same root
number without any suffixes must precede that task.
406 / 815
For examples of the Task Sequence element, see the Task Sequence - Discussion and Examples page. A SimBit is available that includes multiple
model examples, please refer to the ServerUsingTaskSequence SimBit.
407 / 815
Simio Reference Guide
T askSequence - Discussion and Examples
The following description and screen shot are only for the 'SequenceNumberMethod'.
There are three rows in the Tasks repeat group property; one row for each task in this workflow.
The Sequence Number property determines the order in which the tasks are performed and if any tasks should proceed others. In this
example, Task1 must be performed first, followed by Task2, then finishing with Task3.
The StartTasks step is used to start the tasks within a specified Task Sequence element.
The Task Sequence Element to Perform the Above Workflow (TaskSeqeuenceMethod)
408 / 815
Example Workflow #2
The following description and screen shot are only for the 'SequenceNumberMethod'.
There are five rows in the Tasks repeat group property; one row for each task in this workflow.
The Sequence Number property determines the order in which the tasks are performed and if any tasks should proceed others. In this
example, Task1 and Task2 are performed in parallel and are started first. Once both of the Sequence Number 10 tasks have been
completed, then Task3 and Task4 can be started in parallel (both indicated as Sequence 20's).Once the 20's have been completed, then
Task5 may begin (Sequence Number 30).
Note that this example follows Rule #1 in the Task Sequence element, that is, if the task sequence number consists of only a root number
(only XX), then all tasks with lower root numbers (ignoring any suffixes) must precede that task. Note that it is possible to have one or
more tasks with the same root sequence number, with or without suffixes.
Task Sequence Example 3
The following is an example of a Task Sequence element which defines the following tasks, some of which are in series (have precedence
constraints) and others which can be done in parallel.
Example Workflow #3
The following description and screen shot are only for the 'SequenceNumberMethod'.
There are six rows in the Tasks repeat group property; one row for each task in this workflow.
The Sequence Number property determines the order in which the tasks are performed and if any tasks should proceed others. In this
example, Task1 must be performed first, followed by Task2 and Task4, since sequence number 20 is greater than 10, but less than 30.
These two tasks can be performed in parallel, as determined by the number after the 20. Task3 must not begin until Task2 is complete and
Task5 must wait until Task4 is complete. Task6 can be performed after both Task3 and Task5 are complete, since 40 is greater than 30.
409 / 815
The Task Sequence Element to Perform the Above Workflow
410 / 815
There are six rows in the Tasks repeat group property; one row for each task in this workflow.
If the entity object associated with the active task sequence is a 'Red' entity, then the tasks performed (in sequential order) will be Task1,
Task2, Task3 and finally Task6. Otherwise, the tasks performed will be Task1, Task4, Task5 and finally Task6.
The Task Sequence Element to Perform the Above Workflow
411 / 815
Simio Reference Guide
T imer
Timer
The Timer element fires a stream of events according to a specified IntervalType. It is added to a model from the Elements Window from within
the Definitions Tab.
If the IntervalType is Time or TimeInState, then the first event occurs at TimeOffset. If the IntervalType is RateTable, EventC ount or ArrivalTable,
then the first event time is determined by the rate pattern, event count or the numeric table property. The maximum number of timer events is
limited to MaximumEvents. The MaximumEvents expression will be re-evaluated each time it is required to be looked at. The Reset event will
reset the timer. The Timer has an Enabled state that allows the Timer to be enabled/disabled. To disable a Timer, set its Enabled property
(Timer.Enabled) to 0. If the timer is disabled and it is an EventC ount timer, then the triggering event fire notification is stopped. If the timer is
disabled and it is a Time, TimeInState, or RateTable timer, then the calendar event stream is stopped.
When a Timer event is fired, it can be used as the triggering event that executes a Process. If there are any processes specified to be triggered
by that event, then the created tokens are associated with the object that owns the Timer element. For additional information on using Timers,
see the Timer - Discussions and Examples page.
The standard Source object uses a Timer element to generate arrivals. For examples of how it uses the timer, see the Source - Discussion and
Examples page.
For an example of using the Timer element, please refer to the SimBit ScheduledMaterialArrivals.
412 / 815
Listed below are the states of Timer:
State Description
Enabled Indicates whether the timer is currently enabled.
ElapsedTime The time (or time in state if applicable) that has elapsed since the last timer event.
413 / 815
Simio Reference Guide
T imer - Discussion and Examples
Discussion
In order to have a process execute when a Timer fires its event, the Triggering Event property on the Process must be set to the name of the
Timer's event. A new process can be created from the Processes Window by clicking the C reate Process button in the ribbon. In the Properties
window of this new process, select the name of the Timer (.Event) from the drop down of the Triggering Event property. This will cause this
process to be executed each time the specified Timer fires an event.
Linking a Timer's Event and a Process
If the Timer element's Interval Type is 'TimeInState', then State Value expression is re-evaluated on every state change. This allows the user to
model an expression whereby the timer's Time Offset and Interarrival Time values are based on multiple possible state values instead of a single
state value. For example, if Interval Type = 'TimeInState', State Variable Name = 'myState', State Value =
'Math.If((myState==3)||(myState==4),myState,Math.NaN)'. This would cause the TimeOffset and Interarrival Time values of the timer to be
based on the time that the state variable 'myState' had values of 3 or 4.
Timer Example 1
The following is an example of a Timer that fires 5 events, an hour apart, starting at 2 hours after the beginning of the run.
The Time Offset property is set to '2 hours' so this Timer does not fire it's first event until 2 hours into the simulation run.
The Time Interval property is set to '1 hour' which indicates that the events are fired with one hour in between events.
The Maximum Events property tells the Timer to stop firing after 5 events have been fired.
Timer Example 2
The following is an example of a Timer that fires an event every time 5 entities have entered the Input Node of Server1. Therefore, the Timer
fires an event after 5 entities have entered the input node, then again when 10 entities have entered, again when 15 entities have entered, etc.
The Interval Type property is set to 'Event C ount' so this Timer counts the number of specified events to determine when to fire its own
event next.
The Triggering Event property is set to '[email protected]' which determines that this is the event that is counted by the Timer.
The Triggering Event Count property tells the Timer to fire its event after 5 occurences of [email protected].
414 / 815
Timer Example 3
The following is an example of a Timer that fires its event based on information in a Data Table. The Timer reads information from a Date Time,
an Integer or Real property in a Data Table to determine when to fire its next event. If a Date Time property is used, the timing of the event will
be calculated by the time span from the starting date of the simulation to the value in the table. So if the starting date of the simulation was
1/1/2008 12:00:00 AM, and the Date Time in the table was 1/1/2008 2:30:00AM, the event would be fired at time 2.5 hours. If a Real or Integer
property is used, the event will fire at the simulation start time plus the numeric value of the property.
The Interval Type property is set to 'Arrival Table' so this Timer looks to a property in a Data Table to determine when to fire its next
event.
The Arrival Time Property property is set to 'Table1.Notification' which tells this Timer to read the property called Notification from the table
called Table1, to determine when to fire its next event.
Timer Example 4
The following is an example of a Timer that fires its event based on the amount of time spent in a state. In this example, the timer will fire when
the total time that Server1's ResourceState = 1 reaches 3 hours. In other words, when Server1 has been busy for a total of 3 hours, the timer
will fire.
The Interval Type property is set to 'TimeInState' so this Timer looks to the state variable Server1.Resource.TotalTime to determine when
to fire its next event.
416 / 815
Simio Reference Guide
User Defined Elements
Simio provides an open architecture that allows users to add new steps and elements to the system. Steps and elements may be coded in any
.NET language (Visual Basic, C #, J#, etc.). You would simply add your *.dll files to the UserExtensions folder of Simio. For additional information
on creating your own custom Elements, see C ustom Simio Extensions and C:\Program Files\Simio\Simio API Reference Guide.chm. See
Simio Visual Studio Templates for information on how to use the templates provided by Simio to get started with User Defined Elements.
Simio provides several sample User Defined elements including BinaryGate and File.
417 / 815
Simio Reference Guide
BinaryG ate
BinaryGate
The BinaryGate user defined element defines the gate name and its characteristics. A BinaryGate is initially closed and must be opened before
any object can flow through it. The BinaryGate element is used in conjunction with the OpenGate, C loseGate and PassThruGate user defined
steps.
418 / 815
Simio Reference Guide
DbC onnect
DbConnect
The DbC onnect user defined element defines the database provider and connection to the database. It is used in conjunction with several of the
user defined steps, including DbExecute, DbQuery, DbRead, and DbWrite.
419 / 815
Simio Reference Guide
ExcelC onnect
ExcelConnect
The ExcelC onnect user defined element may be used in conjuntion with the user defined ExcelRead and ExcelWrite steps to read and write to an
Excel spreadsheet.
420 / 815
Simio Reference Guide
File
File
The File user defined element defines the file name and its characteristics. The user should ensure that they have sufficient privledges to write to
the location that they specify for the file path.
The File element is used in conjunction with the Read and Write user defined steps. See the WritingToAFile SimBit for an example on how to use
the File Element.
421 / 815
Simio Reference Guide
P roperties
Properties
Properties of a model object are the input parameters associated with that object. They are added to a model from the Properties panel of the
Definitions window.
A Property holds a specific data type. It is a static input parameter (e.g. processing time, batch size) for the object and does not change during
the running of the simulation. There are four different types of Properties that can be added to the model by selecting the appropriate icon in the
ribbon menu; Standard Properties, Element Reference Properties, Object Reference Properties and Repeat Group Properties. Learn more about
the properties of the Simio standard objects by viewing the details of each Standard Library Object.
Properties may also be put into repeating groups. An example of a repeating property is the Assignments(More) property of the Assign step in the
Processes window. These repeat group type properties allow the user to specify multiple, similar properties within a different interface. See
Repeat Groups for more information.
422 / 815
The main model properties may be referenced by properties of objects within your model – i.e. they get their values from these properties. The
easiest way to simultaneously add the main level properties and create the reference to it is to right-click on a property of interest for an object
within your model and select “Add Reference Property”. This adds a new property to the parent model and sets the reference to this new
property. You can see this new property by clicking on the Definitions tab and selecting the Properties panel for your main model. C hanging the
default value of the property affects the model if that property is referenced by objects in the model.
Different types of properties (as shown above, for example, Real, Integer, Expression, Entity Object Reference, etc.) may have different
properties that can be specified to determine their behavior. The properties for a Real type Property are shown below and include Logic,
Appearance and General Type properties.
423 / 815
Within the Logic portion of properties, the Default Value can be specified. This is the initial value that the property has and can typically be
changed. Each property also has three properties called Switch Property Name, Switch Condition and Switch Value. These are used if this
particular property is only used based on the value of another property. For example, the property of a Fixed object type called InitialCapacity is
only displayed if the property Capacity Type is equal to the value 'Fixed'. It does not make sense to display Capacity if the Capacity Type is
'WorkSchedule'. Therefore, on the property Capacity, the Switch Property Name is set to 'C apacityType', Switch Condition is set to 'Equal' and
Switch Value is set to 'Fixed'. See the main Model's Definitions window, Properties panel and select the property InitialCapacity to see this
example. The Switch Value property can have multiple values associated with it. To specify multiple values within the Switch Value field, enter the
values, separated by commas. For example, if a property, Property2, is displayed only if another property, Property1, has a value of either 1, 2
or 4, then the Switch Property Name for Property2 would be 'Property1', the Switch Condition would be 'Equal'and the Switch Value would be '1, 2,
4'.
Within the Appearance category of information, the Display Name is used to show what is displayed to the user within the object. A property may
be categorized, such that it appears within a given section based on the Category Name of properties for that model object. Properties will be
shown in the model, as well as the experiment, based on their Category Name. It may also have a Parent Property Name, such that it is listed
'underneath' another property and accessible with the '+'.
Within the General section of properties for a Property are three other important pieces of information for the Property. The Required Value
determines whether the user must include a value for this property to run the simulation. The Visible determines whether or not the user actually
sees this value with the list of properties for the object. Finally, the Commonly Used Property field determines whether the property will appear
when the 'Show C ommonly Used Properties Only' checkbox is enabled. By default, all properties that have the Commonly Used Property field set
as 'True' will be shown at all times within the object or model. When an object is used in hierarchy, you will have inherited properties from that
object. For inherited properties, there is an Advanced Options property named Check Base for Advanced Properties that determines if you want
to use the same settings used in the parent object. If you subclass from the Standard Library, this should already be enabled.
Listed below are the commonly used properties of Properties:
Property Description
Default The default value for the property.
Value
Switch The name of the enum property that is used as an on-off switch to make this property visible.
Property
Name
Switch The conditional operator used to compare Switch Property Name to Switch Value.
C ondition
Switch The value of the Switch Property Name that is checked against the Switch Condition to indicate whether this property is visible. To
Value use multiple values of Switch Property Name in the comparison, enter the values separated by commas.
424 / 815
A Property can be used as an input parameter into an Experiment. Once a Referenced Property is added to a model, it then appears in the table
of the Experiment Design Window. The user can enter a value into the table for that Property and might choose to run multiple scenarios, each
with a different value entered for the Property(s).
HasValue function - For element and object type properties, this function would be referenced as 'ElementPropertyName.HasValue' or
'ObjectPropertyName.HasValue'. This function is useful for checking in model logic whether an optional property has been specified a value or
not. The function returns True (1) if a value has been specified for the property, otherwise the value False (0) is returned. If the property is a
repeat group, HasValue will return True(1) if one or more entries have been entered into the repeat group, otherwise the value False (0) is
returned.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for Properties. Please refer to the User Interface for more details.
Property Default Values and Macros
There are 'macros' that can be put in the default value of a property that will expand to the correct value when an object with that property is
instantiated. These macros include:
$(InstanceName)
$(DefinitionName)
425 / 815
$(AssociatedObjectInstanceName)
$(AssociatedObjectDefinitionName)
These macros make it easier to design a library object that can be reused without errors occuring.
Note:
An Expression Property may contain random variables or state variables that return a different value each time. Hence although the
expression definition does not change during the run, the value of the expression does.
Both a State Property and an Expression Property have dual behavior because they are derived from a Numeric Property. A State
Property can be used to reference a state variable (e.g. statistics element) or it can be used to return the value of the state variable. An
Expression Property can be used to reference an expression or it can be used to return the value of the expression.
The user has the ability to hide values for an Enum Property or to change the caption that is displayed in the Enum property. This is done by
expanding the C aptions category in the Enum properties window and selecting or unselecting values or changing the display name of the value.
In order to add rows to a Repeating Group Property, first add a Repeat Group property in the Properties window. Then ensure that it is
selected (highlighted) and add the properties that you wish to be part of the repeating group. The sub-properties will appear in the Properties
window under a category such as RepeatingProperty1.Properties.
The DateTime is a Numeric Property that returns the time span from the starting date of the simulation to itself. For example, if the starting
date of the simulation was 1/1/2008 12:00:00 AM, and the DateTime is 1/1/2008 2:30:00AM, the value 2.5 is returned if DateTime is
referenced in an expression or an Arrival Table.
426 / 815
Simio Reference Guide
R epeat G roups
427 / 815
Referencing Tables within Repeating Properties
The procedure for referencing a table entry from within a repeating property depends upon how the table is referenced. Typically, when
referencing a table column, the entity previously was assigned a pointer to a specific row in the table. This is done using the SetRow step in the
Processes window or through the Table Reference Assignment within the Source object. Below are the steps for referencing a simple table and a
relational table from within a repeating property.
For more information on referencing tables within repeating properties, please see the SimBits TableReferenceInRepeatingProperty,
RelationalTableInRepeatingProperty and SourceWithC ustomEntityTypeProperty.
Simple Table References
Tables may be referenced within a repeating property and repeat group field. When referencing a table column within a particular repeating
property, you would specify MyTableName.MyPropertyName, where MyPropertyName is the name of the property column within the table. This
referencing assumes that the user has already put an explicit SetRow to this same table earlier in the logic. In the below example, there are two
entity types (PartA and PartB) which require a different resource for processing at a Workstation (PartA requires Jane, PartB requires Joe). The
information about the entity types and associated resource needed is stored in a table, EntityNames. The processing entity, prior to referencing
the table, used a SetRow of EntityNames and the particular row number.
The Object Name references the table by using 'EntityNames.ResourceName'. Once the table is referenced within the repeating property, '1 Row'
will appear in the Secondary Resources property of the Workstation. When Simio encounters the table reference in the repeat group tuple, the
resource can be determined because it already has a row set for that table for the current entity.
Referencing a Simple Table and Column Property within a Repeating Property
428 / 815
Relational Table References
Relational tables may also be referenced within a repeating property and repeat group field by using MyRelationalTableName.MyPropertyName.
This referencing assumes that the user has done a SetRow to a different, but related table earlier in the logic.
In the diagram shown below, there are two tables in the model,EntityTable and Resources. The EntityTable simply lists the Entity Names, PartA
and PartB and is set as a key column. When entities in the model are created, their SetRow should be set to either PartA or PartB from the
EntityTable. See Tables for more information. There is also a table named Resources that contains the names of the resources that each of the
two part types requires for processing at a given Workcenter. In this Resources table, the Entity Reference is a Foreign Key, and Resource
Needed specifies one or more resources for each entity type.
Referencing a Relational Table and Column Property within a Repeating Property
In this case, because the entity has no known row within the Resources table, one additional step is needed. In addition to referencing the table
and property column within the actual repeating property, the table name must be referenced in the main property. For example, as shown in the
diagram below, the table, Resources, is referenced in the Secondary Resources property. To reference a table within a property, right click on the
property and select the Set Referenced Property and select the table name to reference, as shown below. By doing this, the software will know
that there are not a fixed number of entries based on what has been entered into the repeat group, but it is based on what is shown in the table.
Referencing the Table Name within a Repeat Group Property
429 / 815
Repeating Groups and Object Building
When building an object, such as a Source or Server, you may need to define a repeat group and repeating properties, for such steps as Assign,
Seize or Release. One feature of repeat groups and their properties is that they may be referenced similar to referencing tables. For example,
let’s say you have a repeat group named MyRepeatGroup with two properties within the repeat group, MyTime and MyEntityReference. You may
utilize the SetRow step with the Table Name set as ‘MyRepeatGroup’. Other table functions, as shown below, may also be referenced within an
expression.
• MyRepeatGroup.MyTime
• MyRepeatGroup[x].MyTime
• MyRepeatGroup.MyTime.RandomRow
• MyRepeatGroup.AvailableRowC ount
• MyRepeatGroup.MyEntityReference, as a reference property in places that take an entity reference
For more information on using repeating properties, please see the SimBits TableReferenceInRepeatingProperty,
RelationalTableInRepeatingProperty and SourceWithC ustomEntityTypeProperty.
430 / 815
Simio Reference Guide
States
States
Simio allows the user to add either a Discrete State or a C ontinuous State to the model. States are added to a model from the States panel within
the Definitions window. For additional information on how to assign a State to an object, see the help topic Assigning States.
States are categorized as either Inherited or not. Inherited states automatically are generated with a given object. Other states are added by the
user. The user interface of the States window allows the user to sort and/or filter the columns (Name, Object Type and Display Name). To the
right of each column name is an arrow icon for sorting and a filter icon for filtering. This allows users to more easily organize an object's states
when there are many defined.
Discrete States
A Real state variable represents a real numeric value that may change by assignment logic at discrete times during a model run.
An Integer state variable represents an integer numeric value that may change by assignment logic at discrete times during a model run.
A Boolean state variable represents a boolean (true or false)value that may change by assignment logic at discrete times during a model
run.
A DateTime state variable represents a datetime value that may change by assignment logic at discrete times during a model run.
A List state variable represents an integer variable with a discrete set of possible values from 0 to N. A zero-based indexed string list is
used to define the possible integer values for the state. A list state's value may be changed by assignment logic at discrete times during a
model run, and the state will automatically collect and report time-persistent statistics for each of its state values. For more information,
see List States.
A String state variable represents a string value that may change by assignment logic at discrete times during a model run. For more
information, see String States.
An Element Reference state variable defines an element reference variable that may be changed by assignment logic at discrete times
during a model run. You can assign a value to an element reference state using an Assign step in a process. The expression used as the
value for the assignment must return an element reference.
An Object Reference state variable defines an object reference variable that may be changed by assignment logic at discrete times
during a model run. You can assign a value to an object reference state using an Assign step in a process. The expression used as the
value for the assignment must return an object reference.
A List Reference state variable defines a list reference variable that may be changed by assignment logic at discrete times during a
model run. You can assign a value to a list reference state using an Assign step in a process. The expression used as the value for the
assignment must return a list reference, for example from an Object List Property or another List Reference State.
C ontinuous States
A Level continuous-change state variable defines a numeric variable that may change continuously over time based on the current value
of its rate. An automatic rate variable, based on the LevelStateName.Rate can be used to modify the rate of change throughout the
simulation run. The state's rate parameter is a discrete-change value that may be changed by assignment logic at discrete times during a
model run.
A Level with Acceleration continuous-change state variable defines a numeric variable that may change continuously over time based
on the current value of its rate and acceleration. The state's rate, acceleration and acceleration duration parameters are discrete-change
values that may be changed by assignment logic at discrete times during a model run.
A State might represent a count of completed parts, the status of a machine selected from an enumeration state list, the temperature of an ingot
heating in a furnace, the level of oil in a ship being filled, or the accumulation level on a conveyor belt.
A Real or Integer state has a property called Unit Type. This classifies the units of the values stored in this state variable. The choices are
Unspecified, Time, TravelRate, Length, C urrency and C urrencyPerTimeUnit. Time units available in Simio are Hours, Minutes, Seconds, Days and
Weeks. Travel Rate units available in Simio are Meters Per Hour, Meters Per Minute, Meters Per Second, Kilometers Per Hour, Feet Per Second,
Feet Per Minute and Miles Per Hour. Length units available in Simio are Meters, Kilometers, C entimeters, Inches, Feet, Yards and Miles. C urrency
units include over 100 world-wide currency units.
431 / 815
units include over 100 world-wide currency units.
A State variable is assigned a value using an Assign Step in a process. Statistics can be recorded on state variables by creating a StateStatistic
element in the Elements Window.
Every object in Simio has States that are inherited from its base class. To learn more about inherited States on each type of object, see the
following Functions, States and Events help pages for Entity object, Node objects, Link objects, Transporter objects and Resource objects.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for all States. Please refer to the User Interface for more details.
State Arrays
All reference states, with the exception of a List state, can become arrays or a matrices by changing the the Dimension Type property. If the
Dimension Type property is set to 'Scalar', the State does not have a dimension and is therefore a scalar Discrete State. If the Dimension Type
property is set to 'Vector', the State is 1 dimensional and the Rows property will determine the number of rows in the array. If the Dimension
Type property is set to 'Matrix', the state is a 2-dimensional matrix and the Rows and Columns properties will determine the number of rows and
columns in the matrix. The Dimension Type property may also be set to 'Matrix From Table' meaning that there is an associated table from which
the 2-dimensional array is sized and initialized. Finally, up to 10-dimensional arrays may be specified by selecting the appropriate Dimension Type
property, as shown below.
In order to reference a State Array, use the syntax StateArray[2], where StateArray is the name of the State variable and 2 is the value of the
row that is referenced. A multi dimensional State Array can be referenced similarly, such as, StateArray[2,3] where 2,3 is the index to the matrix
in this 2 dimensional array. State Array indexing is 1 based.
In order to initialize a State Array, the user should bind the array to a Data Table. When bound, the array size will be initialized from the number
of rows and numeric columns in the table, and the array data will be initialized from the data in the table. To bind an array to a table, set the
Dimension Type property of the state to 'Matrix From Table' and select the appropriate table from the drop down of the Table Name property.
Listed below are the properties of States:
Property Description
Dimension The state variable's dimension type, see the above section titled State Arrays for more information.
Type
Rows The size of dimension 1.
C olumns The size of dimension 2.
Table The table from which the array is sized and initialized (used for 'Matrix from Table' Dimension Type). The array is given the same
Name number of rows as the table and a colum for each numeric column (number, expression, state reference) in the table. Numeric
values are then copied from the table to the array. Expressions are evaluated to get their numeric value and the state references
get the value from the state.
Dimension The size of dimension 3-10.
3-10 Size
Unit Type C lassifies the units of the values stored in this state variable.
Initial State The initial value for this state.
Value
String List The name of the string list that defines the list state's discrete set of possible integer values and their associated labels. Note that
Name the integer equivalent of each value label in the string list will be the zero-based index into the list.
Automatic Indicates whether automatic assignments to this list state will be performed by the simulation engine, with each possible list state
Assignment value being associated with an autostate.
Type
Resource Indicates the method used to calculate capacity utilization statistics for the resource object containing this list state.
Utilization
C alculation
432 / 815
C alculation
Auto Reset Indicates whether or not this state variable will be automatically reset to its initial state value(S) whenever statistics for the state's
When parent object or element are cleared. This could be from warm-up Period in an experiment or from using the C learStatistics step.
Statistics
C leared
Display The optional format specifier used when displaying this state's value. Specifiers includ N or F followed by an optional number of
Format decimal places. If left blank, the format will be N4 (Number, 4 digits after the decimal point).
Unit Type The name of the property whose value will be used to determine the units classification of this state.
Property
Queue States
A Queue State holds a list of objects or tokens. Queue states are used in such things as Station and Storage elements. Queue states in Storage
elements can be modified by using the Insert and Remove step to add and remove objects from them. There are a number of functions that can
be used with Queue States.
433 / 815
Simio Reference Guide
List States
List States
There are two types of List States including Automatic List States and User Defined List States. There are also functions available to use with List
States.
Automatic List States for Standard Library - Server, Combiner, Separator, Resource, Workstation, Vehicle, and Worker
With many of the Standard Library objects, there is an automatic List State that is updated during the simulation, namely the
'ObjectName.ResourceState'. This list state references a string list named 'ResourceStateName' and the states are automatically assigned as
'ResourceAutoStates'; therefore, no user assignments to the list state are required.
When using the 'ResourceAutoStates', the interface displays and allows the configuration of the autostates associated with the possible list state
values. Multiple list entries may be associated with a single autostate (i.e., in the Workstation list shown below, Processing, Setup and Teardown
are all AllocatedAutoStates). Additionally, you may use the Assign step to assign a list state that is following autostates. The assignment is allowed
as long as the state value being assigned is associated with the current autostate condition. The simulation engine also will ‘save’ the last
assignment as the state value to be now used whenever it comes back to that particular autostate condition.
These automatic resource states have statistics calculated for the number of occurences and percentage of time spent in each given state. The
Status Pie may be used to graphically display the various states of an object. A Status Pie may be added by highlighting the desired object, i.e.,
Server1, and clicking on the Status Pie on the Symbols tab. Specify the Data Type property as 'ListState' and the List State property is
'ResourceState' as selected from the pulldown.
Below are the contents of the string list 'ResourceStateName' for the various objects and the object states that may be assigned.
Server, C ombiner and Separator
'ResourceStateName' string list for the Server, C ombiner and Separator object 'ResourceState' list state and the numerical equivalents include:
Starved (0)
Processing (1)
Blocked (2)
Failed (3)
Offshift (4)
FailedProcessing (5)
OffshiftProcessing (6)
Resource
'ResourceStateName' string list for the Resource object 'ResourceState' list state and the numerical equivalents include:
Idle (0)
Busy (1)
Failed (3)
Offshift (4)
FailedBusy (5)
OffShiftBusy (6)
Workstation
'ResourceStateName' string list for the Workstation object 'ResourceState' list state and the numerical equivalents include:
Starved (0)
Processing (1)
Blocked (2)
Failed (3)
Offshift (4)
Setup (5)
Teardown (6)
Vehicle
'ResourceStateName' string list for the Vehicle object 'ResourceState' list state and the numerical equivalents include:
Idle (0)
Busy (1)
Failed (3)
Offshift (4)
FailedBusy (5)
OffShiftBusy (6)
Transporting (7)
FailedTransporting (8)
OffShiftTransporting (9)
Worker
'ResourceStateName' string list for the Worker object 'ResourceState' list state and the numerical equivalents include:
Idle (0)
Busy (1)
Offshift (4)
OffShiftBusy (6)
Transporting (7)
434 / 815
OffShiftTransporting (9)
Automatic List States for Flow Library - Tank, ItemToFlowConverter, FlowToItemConverter and ContainerEntity
As with the Standard Library objects, several of the Flow Library objects also include automatically updated states. For flow objects, there is an
automatic List State that is updated during the simulation, namely the 'ObjectName.FillStatus'. Each of these objects has an internal FlowC ontainer
element and the states are automatically assigned as 'C ontainerAutoStates' associated with that FlowC ontainer element; therefore, no user
assignments to the list state are required.
These automatic container states have statistics calculated for the number of occurences and percentage of time spent in each given state. The
Status Pie may be used to graphically display the various states of an object. A Status Pie may be added by highlighting the desired object, i.e.,
Tank1, and clicking on the Status Pie on the Symbols tab. Specify the Data Type property as 'ListState' and the List State property is 'FillStatus' as
selected from the pulldown.
Below are the C ontainerAutoStates for the various objects and the object states that may be assigned.
Tank, ItemToFlowC onverter, FlowToItemC onverter, C ontainerEntity
The 'FlowC ontainer' within each of the objects has the following list states and the numerical equivalents:
Empty (0)
PartiallyFull (1)
Full (2)
User Defined List States
The user may define one or more List States for a model under the States panel in the Definitions window. The List State references a String List
that is defined in the List panel in the Definitions window. This is done by specifying the List Name property as 'MyStringListName', and Automatic
Assignment Type as 'None'. The Initial State Value must be a value from the String List and should represent the state of the model when it
initially starts running.
The String List should include any possible states that the user may want to assign to the List State using the Assign step. There are no automatic
assignments made during the simulation, as with the above automatic ResourceStates. Thus, the Assign step in the Processes Window should be
used to change the List State value from one string value to another. Statistics can be categorized automatically (default) or by using the Results
C lassification section of properties.
Assignments to the List State in the Assign step are made by specifying the State Variable Name property as 'ListStateName' and the New Value
property as 'List.ListName.Value', similar to referencing a list elsewhere in the model.
User Defined List State using Lists, States and Assign step
User defined List States will automatically generate statistics for the model (not specific object) on the number of occurences and percentage of
time the List State has a value for each of the given string values. The List State can also be graphically displayed by using the Status Pie found
on the Animation tab of the ribbon.
List States Functions
The following functions are available for List States:
AverageTime(stateValue)
NumberOccurances(stateValue)
PercentTime(stateValue)
TotalTime(stateValue)
435 / 815
Therefore, to reference the percentage of time that an object was in a certain state, use the syntax [ObjectName].PercentTime(stateValue),
where stateValue is the number referencing the state in the String List. The first value in the String List is value 0.
Utilization Statistics
The ResourceState list states provide time-persistent statistics for many of the objects in the simulation system. In addition to tracking these
utilization statistics for the Results page, the ResourceStates can also be used during the simulation run.
Because Simio automatically tracks the list states for the various objects, the information is available to track resource utilization statistics during
a simulation run to be displayed with a status label. While a status pie graphic for an object's list state can give you a pie chart of the various
states that the object is in, using the object's list state in an expression can show the percentage of time in each state.
For example, the expression 'Server1.ResourceState.PercentTime(1)' utilizes the resource state for Server1 to determine the percentage of time
that the server has the state value of 1 (which is Processing, as shown in the above section). Likewise,
'Vehicle1[1].ResourceState.PercentTime(0) would show the percentage of time that the first unit of Vehicle1 has the state value of 0, which is
Idle.
It may be desireable to determine the percentage of time in multiple states for an object. For example, if a worker is used for transporting tasks
as well as stationary tasks, use the expression 'Worker1[2].ResourceState.PercentTime(1)+ Worker1[2].ResourceState.PercentTime(7)' to
display the percentage of time that the second unit of Worker1 is either busy at a stationary task or busy transporting or moving between nodes.
Refer to the SimBits ExamplesOfFunctions_StaticObjects and ExamplesOfFunctions_DynamicObjects for examples of using and displaying various
functions with static objects(Source, Sink, Path, Server, and Resource) and dynamic objects (Entity, Vehicle, Worker).
436 / 815
Simio Reference Guide
String States
Simio supports '+' for strings, so “Hello” + “ World” turns into “Hello World”. Also supported are the logical comparison operators such as ==,>,
etc. For example, the expression 'MyStringstate==”Red"' and 'MyStringState > “A”' are valid for use in a Decide step.
See the StringStates SimBit to see an example of using String States in Simio.
437 / 815
Simio Reference Guide
R eference States
The types of element reference states and how they may be used are described below:
Activity - This refers to the name of an activity and may be used within the Operation element.
BatchLogic - This refers to the batchlogic element and may be used within the Batch step's BatchLogic Name property. This may be useful
when various entity types require different batching information that is then stored within the BatchLogic element reference state.
Container - This element reference state is used to store a container name. C ontainers are utilized within the Flow Library's Tank object.
CostCenter - This element reference state is used to store the name of a C ost C enter.
Failure - This element reference state is used to store failure names. An object may wish to utilize this state within the Fail and/or Repair
steps within the Processes window.
Material - This refers to a material element name. An entity may have a material element reference state that is used within the Produce
or C onsume steps within the Processes window.
Monitor - This refers to the name of a monitor element. An entity may have a monitor element reference state that tracks a particular
state of the entity.
Network - This refers to a network name. Entities may utilize a network element reference state to store individual network names that
may later be used in a SetNetwork step in the Processes window.
Operation - This refers to an operation name and may be used within the StartOperation and EndOperation steps within the Processes
window.
OutputStatistic - This refers to an output statistic name and may be used within a table that store statistics on various states.
Process - This refers to a process name within the Processes window. Entities may have a state variable that stores a different process
name for each entity type, where within a Server for processing, the element reference state is used within an add-on process property to
point to different processes to undergo.
Regulator - This refers to a regulator element name. Regulators are used within the Flow Library's FlowNode (and therefore Tank,
FlowSource and FlowSink).
Routing Group - This refers to a routing group name that may include various nodes in which the object will go through. Routing groups
refer to node lists. The routing group element reference would then be used within the Route step as the Route Group Name property.
StateStatistic - This refers to the name of a state statistic element. One application of a state statistic element reference would be within
a table to store the various state statistics.
Station - This refers to the name of a station element. An entity may have a station element reference and utilize that variable within the
Transfer step in the Processes window to transfer to a given Station Name based on the element reference state.
Storage - This refers to a storage element name and may be used within the Insert or Remove steps as the Queue State Name property.
Tally Statistic - This element reference state refers to a tally statistic element. An entity may have a reference to the tally statistic
element and utilize it within the Tally step as the Tally Statistic Name property.
Timer - This refers to a timer element name. This type of reference may be useful within a table, for example.
With the above element reference states, the state can be referenced by simply using the object name and element reference name. For
example, if you have a tally statistic element reference state on ModelEntity, then it is referenced 'ModelEntity.TallyStatisticStateName' within the
438 / 815
example, if you have a tally statistic element reference state on ModelEntity, then it is referenced 'ModelEntity.TallyStatisticStateName' within the
Tally step in the Processes window. Likewise, if you have a Process reference state named 'P1' on an entity, it would be referred to as
'ModelEntity.P1' within a step or property requiring a process name.
Object Reference States
An Object Reference state variable defines an object reference variable that may be changed by assignment logic at discrete times during a
model run. You can assign a value to an element reference state using an Assign step in a process. The expression used as the value for the
assignment must return an object reference.
Object Reference states can be also be arrays. An object reference state that is defined as a scalar is referenced by
'ObjectReferenceStateName'. An object reference state that is defined as a vector is referenced as 'ObjectReferenceStateName[rowindex]' .An
object reference state that is defined as a matrix is referenced as 'ObjectReferenceStateName[rowindex, columnindex]'. Refer to the States page
section on arrays for more information.
If an object reference state has no current value (null), it returns the keyword 'Nothing'. Users may wish to use this keyword in a comparison
statement to check whether an object reference exists (e.g., ModelEntity.ObjectReferenceValue == Nothing).
Object Reference States
Object reference states may also be used with functions for various objects. The types of object reference states and how they may be used are
described below:
Object - This general purpose object reference can be used for any of the below object reference states. An object reference simply
means that the state is some type of object.
ObjectList - This refers to an object list. This can be used for any general object type list referencing.
Entity - This refers to an entity reference and may be used to access function information related to entities.
Node - This object reference state is used to reference a node name. An entity may wish to reference a node within the Transfer step or
any object's property that requires a node name reference. The reference can also be used to get function information on the node.
NodeList - This object reference state is used to reference a node list. This may be useful when specifying an Entity Destination Type of
'Select From List'.
Transporter - This refers to a transporter name. Entities may utilize a transporter reference state to store a worker or vehicle name. This
type reference may also be used with transporter type functions.
TransporterList - This refers to a transporter list name. This may be useful when selecting bewteen multiple lists of transporters based
on the entity.
With the above object reference states, if the object is clearly known (i.e., entity, transporter), then the state can be referenced by simply using
the object name and object reference name. For example, if you have a transporter object reference state on ModelEntity, then it is referenced
'ModelEntity.TransporterStateName' within a Transporter Name property.
As with the element reference states, it is important to note that if you have an Object type reference state, which is more 'generic', you may
need to explicitly cast it to a reference of some type. For example, if you have an Object reference state called O1, and you wish to utilize this
state variable to store a Transporter object reference, you would reference 'ModelEntity.O1.Transporter'. Whether or not you need to include the
extra 'type' of reference depends upon the type of property field where it is being utilized. If a property asks for Object Name, for example, then
an object reference state can be utilized without the extra 'type'. With object references, this 'typing' is required because an object is a more
'generic' type of reference state and the various properties in which object reference states may be utilized may require the reference to be of a
specific type.
Please refer to the two SimBits on Object Referencing, ObjectReferenceOnEntity, and SeizingSameResourceFromList for examples.
List Reference States
A List Reference state variable defines a list reference variable that may be changed by assignment logic at discrete times during a model run.
You can assign a value to a list reference state using an Assign step in a process. The expression used as the value for the assignment must
return a list reference, for example from an Object List property or another List Reference State.
If a list reference state has no current value (null), it returns the keyword 'Nothing'. Users may wish to use this keyword in a comparison
statement to check whether a list reference exists (e.g., ModelEntity.MyWorkerList == Nothing).
439 / 815
Simio Reference Guide
Events
Events
An Event is a notification that can be given by one object and responded to by several. An Event is added to a model from the Events panel within
the Definitions window. An Event is fired with a Fire step in a process. A Process waits for a fired event by having its Triggering Event property set
to the name of the event that it is waiting for. A Wait step can also be used to wait for an event to be fired. The Subscribe step can be used to
dynamically add a triggering Event to a process.
For an example of adding new Events, please refer to the SimBit UsingButtonsToAffectSystem.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for Events. Please refer to the User Interface for more details.
There are a number of events that are automatically fired by Simio. The following events are summarized by object type, where ObjectName is
replaced by the name of the actual object:
Standard Server and Workstation Objects
ObjectName.C apacityC hanged
[email protected] apacityC hanged
[email protected]
[email protected]
[email protected] apacityC hanged
[email protected]
[email protected]
[email protected]
Note: Source and Sink objects are similiar except that Source does not have an Input Node and Sink does not have Output Node. C ombiner and
Separator are also similar except that C ombiner has both ParentInput and MemberInput and Separator has both ParentOutput and ParentInput.
Standard Resource Object
ObjectName.C apacityC hanged
ObjectName.Allocated
ObjectName.Released
Standard Entity Objects
ObjectName.C apacityC hanged
ObjectName.Destroyed
ObjectName.Engaged
ObjectName.Transferred
ObjectName.Transferring
Standard Vehicle and Worker Objects
ObjectName.C apacityC hanged
ObjectName.Destroyed
ObjectName.Engaged
ObjectName.Transferred
ObjectName.Transferring
ObjectName.RiderLoaded
ObjectName.RiderUnloaded
ObjectName.Allocated
ObjectName.Released
ObjectName.RemainInPlaceEnded
ObjectName.MinimumDellTimeExpirationReset
ObjectName.C alendarTimeBasedFailuresReset (Vehicle Only)
ObjectName.EventTimeBasedFailuresReset (Vehicle Only)
Standard Node Objects
ObjectName.C apacityC hanged
ObjectName.Entered
ObjectName.Exited
ObjectName.RiderWaiting **only for TransferNode
Standard Link Objects
ObjectName.C apacityC hanged
440 / 815
Simio Reference Guide
Functions
Functions
A function is a query of a calculated value that can be called by another object. To query for the value of a function, use it in an expression.
Any functions defined within this window are then listed under the 'User Functions' section of the Watch window during a simulation run.
Functions are most useful for sharing an expression across several objects. For example if you have a complex expression for calculating a
processing time, and you use that expression in several different places, you can instead make that expression a function. This can make your
model easier to maintain, since you can now update the expression in just one place and the new value will be returned everywhere that uses the
function.
You can also use functions simply to make your model easier to read. Rather than having the complex expression directly referenced in your
model, you can define the expression as a function, and give that function a meaningful name.
By combining the two above features, you can simplify routine use of your model. Say, for example, you had two different common ways of
calculating processing time. To avoid typing and retyping the appropriate expression each time you change, you could define functions named
“PTime_MethodA” and “PTime_MethodB” with the appropriate expressions and just change between those names as desired.
Listed below are the properties of Functions:
Property Description
Expression The expression to evaluate for the value of this function.
Return Type The type of the result returned from the expression. Return Type can be Number, String, ElementReference or Any.
Unit Type The type of units for the value of this function. Available for Number and Any.
441 / 815
Simio Reference Guide
Lists
Lists
Lists are used to define a collection of strings, objects, nodes, or transporters. List are also used to define the possible changeover states for a
changeover matrix (e.g. color, size, etc.), or to provide a list from which a selection is to be made (e.g. a resource to seize, transporter to select,
etc.). A List is added to a model from the Lists panel within the Definitions window. It can also be added by right-clicking on an object(s) within
the Facility window, as described below.
The members of list have a numeric index value that begins with 0. A List value may be referenced in an expression using the format
List.ListName.Value. For example, if we have a list named C olor with members Red, Green, Blue, Yellow, then List.C olor.Yellow returns a value
of 3. If we have a ListProperty (i.e. a property whose possible values are list members) named BikeC olor we can test conditions like BikeC olor
== List.C olor.Yellow.
One can also reference a List within another object. For example, if there is a list on a ModelEntity and you want to assign a value from this List to
a ListState within the Model, you can use the syntax ModelEntity.ListProperty1 == ModelEntity.List.MyStringList.Value1, where Value1 is a value
from MyStringList.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for all Lists. Please refer to the User Interface for more details.
String List
Defines a string list (e.g. Small, Medium, Large) that is used to define a list property that can have any value from the list, or the possible from-to
states in a changeover table. Examples of using string lists are the SimBits SelectEntityC olorFromStringList and
WorkstationWithSequenceDependentSetup. String lists must be defined in Definitions window for both the ModelEntity, as well as the Model.
String List Example
Object List
Defines an object list (e.g. Fred, Sue, Tom) referenced by steps (e.g. Search step) and objects (e.g. Server object) that allow for a selection of
an object from a list of objects. Examples of using object lists include the SimBits SelectingResouresAsAGroup and SelectingResourceFromList.
Object List Example
442 / 815
Node List
Defines a node list (e.g. Input@Drill, Input@Lathe, MergePoint) that is used by the TransferNode step and the RoutingGroup element to
dynamically route an entity to a node based on the current state. There are many examples of using the node list including the SimBits
SelectServerWithShortestLine, OneQueueForMultipleServers and UsingAStorageQueue.
Node List Example
Transporter List
Defines a transporter list (e.g. C art1, C art2, C art3) that is used by steps (e.g. Ride step) and objects (e.g. TransferNode) that allow for the
selection of a transporter from a list of transporters.
Transporter List Example
443 / 815
Adding Objects to Lists from the Facility Window
In addition to adding members to a List from the Definitions window, Lists panel, user's also have the option to select a single object or group
select multiple objects (using C trl-click to select multiple objects or C trl-click and drag to select an area). Once an object or group of objects is
selected, the right-click menu includes an 'Add to List' option as shown below. If only nodes are selected, the option to 'Add to Node List' will be
shown. Likewise, if only transporters are selected, the option to 'Add to Transporter List' will be shown. If multiple object types are selected, the
more generic 'Add to Object List' is displayed. Objects can be members of multiple lists. Once on a list, the right-click menu provides a 'Remove
from List' option as well. The right-click menu provides existing list names as well as a 'C reate New List' option, where the user is then prompted
for a new list name.
Right-Click Menu to Add Objects to a List from the Facility Window
444 / 815
Simio Reference Guide
T okens
Tokens
A Token executes the steps in a process flow. A Token may have one or more user defined states that carry information from Step to Step. A
Token may also reference an associated object such as an Entity that is visiting the parent object. Simio provides you with a default token named
Token that you can use for most of your processes.
Every token executing a process in Simio has an associated object and a contextual object. For a token that has been created by a C reate or
Search step for example, the token's associated object reference is the created entity or found object, while it's contextual object reference is the
object that was associated with the original token that executed the C reate or Search step.
If the token's process execution is part of a task sequence, the TaskInfo namespace will provide a set of functions (see table below) for accessing
information about the task assigned to the token.
You only need to add a Token through the Token panel of the Definitions tab if you require a Token with one or more custom states or if you wish
to use a Token as a counter in a process loop.
If you use a custom token with custom states, the states of the receiving token in the called process get set to match, much like passing function
arguments. If you set the ReturnValue of the token in the executed process, that value will be set (returned) to the token that started the
execute, much like a function return value. This allows the user to pass information between the processes, much like you would with a function.
The Execute step is used to move from one process to another.
An example of why a user might want to create a custom Token is if they are using a C reate step, with the Create Type set to 'NewObject', to
create a new Entity and they would like the new entity to have one of the same States that the original Entity has. Before the C reate step, the
Entity State can be saved into a custom Token State. And then from the C reated segment of the C reate step, the Token State can be applied to a
State on the new Entity.
Listed below are the States of Token:
State Description
ReturnValue A special-purpose, user-assignable numeric state value.
If the token is executing a decision process, then this state variable is used to return a 'True' or 'False' value for the decision. It
may also be used in the Search step to return the results of an expression evaluated across the searched collection.
Additionally, if the token is waiting at an Execute step until a specified process is completed, then this state variable may be used
to pass back a 'return value' from the other token that executed the separate process.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for Tokens. Please refer to the User Interface for more details.
445 / 815
Simio Reference Guide
External
External Window
The External panel of the Definitions window consists of two window that allow the user to define the graphical representation of a model that is
instantiated as an object into another model. The External window is comprised of a 3D drawing that depicts the object, along with external node
symbols that define associated node objects that serve as entry and exit points for the object. These associated node objects are automatically
created whenever this object is instantiated into a model. The External window may also contain animated queue states for the model. This
window is available for Fixed, Agent, Entity, and Transporter type models.
When creating the graphical representation for a model, first place a graphical symbol representing the model by using the Place Symbol button
or drawing features on the Drawing tab. Depending on the type of model you are building, you often will also place one or more external node
symbols. An external node defines an input and/or output point that may be used to enter or exit the model.
When utilizing hierarchy in building a model (for example, building an object from two servers connected with a path), objects that are placed
within the model's Facility window are, by default, shown in the External window. Within the Facility window, right-clicking on a particular object or
group of objects allows the 'Externally Visible' option to be turned on and off. Users may wish to selectively show some objects, and not others,
from the Facility window into the External window.
Additionally, Simio provides menu features to easily auto-create external node symbols in an object's External window that are bound to nodes
placed in that object's Facility window. If you right-clickg on a node in the Facility window and select the option 'Bind to External Input Node', then
a new external node with Node Class Name of 'BasicNode' and Input Location Type of 'Node' will be automatically created in the object's External
Window. Similarly, by right-clicking on a node in the Facility window and selecting the option 'Bind to External Output Node', a new external node
with Node Class Name of 'TransferNode' will be automatically created. Refer to the C reating New Objects page for more information on building
objects with hierarchy from the Facility window.
External Window
446 / 815
Within the Standard Library of objects, the Server, Workstation, C ombiner, Separator, Resource, Worker and Vehicle have additional symbols
defined based on the 'Object.ResourceState' expression specified within the Current Symbol Index property of the object (under the Animation
group of properties). You can find the states associated with the various Standard Library objects in the List States section of the help. The Filler
and Emptier objects within the Flow Library also contain additional symbols based on the state of the associated resource.
Additional Symbols Window
447 / 815
NOTE: Multi-Select of objects, as well as C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste), are supported for all objects in this window. Please refer
to the User Interface for more details.
448 / 815
Simio Reference Guide
C onsole
The C onsole allows you to deifne run time status and control mechanisms for your model. It can be used to track the status of your running
model, as well as define a status display when your model is used inside another one.
Several of the objects within the Standard Library include a console. If an object is placed inside another object, such as a model, the console can
be opened by right-clicking on the object and selecting Open C onsole.
A convenient way to look at the C onsole window of a model during a run is to tile the windows. To do this, click on the Definitions tab and move
the window to the right side of the screen for docking and select the C onsole panel. C lick on the Facility tab on the left to activate the Facility
window and Definitions window simulataneously, as shown below. The two windows will now be displayed vertically next to each other. This will
allow you to watch both views during the interactive run. To return the windows to their original position, right click on the Definitions tab and
select Move to Previous Tab Group.
449 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
450 / 815
Simio Reference Guide
T he Data W indow
451 / 815
Simio Reference Guide
T ables
Tables
Within the Data window, selecting the Table panel allows a user to add either a Data Table or a Sequence Table by clicking on the appropriate icon
in the ribbon menu.
Table Ribbon (from Table Panel in Data Window)
To reference a particular row in a table, the following syntax is used: DataTable[1].NumericProperty where the table name is DataTable, the
column (property) in the table is NumericProperty and the row number is 1. An expression that returns an integer can be used in the brackets to
specify a row. See Data Tables for more information about table functions and table referencing.
Add C olumn
The data columns within a data or sequence table are added by selecting a Standard Property, Element Reference, Object Reference or Foreign
Key from the Properties area of the Table ribbon.
Standard Properties include data such as integers, reals, expressions, strings, model events and states, and references to other data such as
lists, rate tables and schedules. These properties are typically used to store process times, arrival times or percentages for incoming part types,
quantities, or other numeric data.
An Element Reference includes data such as stations, activities, material, failures and other elements that are defined in the Elements panel of
the Definitions window.
An Object Reference includes data such as Entity types, Objects such as Resource Names, Nodes and Transporters, as well as references to
Node and Transporter Lists. These properties are typically used to store entity types for arriving entities, resources to use for processing, or
vehicles to request for movement.
A Foreign Key reference is used to relate data from multiple data and/or sequence tables. When a foreign key property is added, the Table Key
property is used to make a row in this table link directly to another row in the table specified by the Table Key. When the row in this table is
referenced using a SetRow step in the Processes Window, the data in the row and the row it points to (via the TableName.C olumn listed in the
Table Key property) will be immediately available. The TableName.C olumn that is referenced must be specified as 'Set C olumn As Key'. It is
important to note that the type of property this column becomes is based on the Table Key's TableName.C olumn property. Therefore, if you are
referencing an Entity object column, this column will also be Entity objects.
A table can be searched by using a Search Step to browse the table looking for certain criteria. Tables may also be used with the C andidate
keyword in an expression while evaluating a condition. For example, it may be used when selecting a Worker to seize from a list of workers,
where each worker is bound to a particular table row, the Selection Expression may read "C andidate.TableName.C olumnName > 100". Here you
need the candidate keyword to tell Simio you want to know about the row each candidate worker is bound to, NOT whatever row the executing
entity is bound to.
Edit C olumn
The Set Column As Key button allows the user to indicate that the highlighted column may be referenced by another data and/or sequence
table. This button makes the current column a Key for this table (you may have multiple columns that are Key in a single table). This column's
data can then be referenced by Foreign Key properties in other tables, which will link the rows in those tables to a row in this table. The Set
C olumn as Key and Foreign Key are used together for relational type data tables. See Relational Tables, as well as the UsingRelationalTables
SimBit and the EntityFollowsSequenceWithTable2 SimBit for examples on using the relational table functionality.
Once a column has been added to the table, it may be moved to the left or to the right to reorganize the table. This can be done by selecting the
table column you wish to move by highlighting the column header. The Move Left and Move Right buttons on the Table tab can be used to move
the column within the table.
The C hange Type drop down button on the ribbon is available when a column is selected. It allows the user to change an existing column to a new
type (real -> expression, string -> real, etc…). When converting, it attempts to keep all values in the rows of that column; however, the user may
have to edit the values based on the column type that is being used.
Any column may be deleted by simply highlighting the column header and pressing the Remove C olumn button.
Importing, Exporting and Binding To Tables
The user can import, export and bind to data tables to utilize data external to Simio. See the Importing and Binding to Tables page for more
information.
Auto-C reating Elements
The data within either a Data Table or Sequence Table can be used to automatically create new Elements (within the Definitions window /
Elements panel), as well as their associated properties. See the Table-Based Elements section for more detailed information.
Table Filtering
The columns within the tables include a small filter icon that can be used to filter the data within the particular column. C lick the filter glyph in a
column header and select an option from it. You may filter based on a particular entry in the column, or specify a custom filter. There is a bar at
the bottom to turn the filter on/off, see your most recent filters, and edit the filter.
Filtering a Table Column
452 / 815
Scheduling and Wonderware Add-Ins
The Add Scheduling Lists and Tables add-in will automatically add six(6) new data tables to the simulation model, including Resources,
Materials, ManufacturingOrders, Routings, BillOfMaterials and WorkInProcess. Within each of the tables, several columns have been added,
including key columns to relate several of the tables. The tables have been added to be similar (although not identical) in structure to the
SchedulingDiscretePartProduction example, available through the Support ribbon, Examples button.
In addition to automatically adding tables to the model, this add-in also generates two (2) string lists within the Definitions tab / Lists panel. This
inlcudes th MaterialC olor and OrderStatus. MaterialC olor list includes None, Red, Green and Blue while OrderStatus includes New and WIP. These
string lists are referenced in the various tables listed above.
The Configure Scheduling Resources add-in will add new objects to the Facility window based on the Resources table information. For
example, if C ut, Weld and Finish are Resource Names within the Resources table, the Object Type and XLocation/ZLocation values will be utilized
to determine where to place those objects within the Facility window. The add-in, in combination with the Resources table data, will add the
appropriate objects to the model. If the Update Location checkbox is 'True' and the the location of the object(s) has been changed, the C onfigure
Scheduling Resources add-in can again be used to move the object locations when necessary.
The Add Wonderware MES Lists and Tables add-in adds the lists and table into a Simio model that is used to integrate with Wonderware MES.
The Configure MES Entities add-in will add a Wonderware MES object for each row in the Ents table. It will also create groupings (node lists) of
homogeneous resources. See the Add-Ins Ribbon page for more add-ins within Simio Enterprise.
For more information on the Wonderware MES add-ins described above, see
http://www.simio.com/downloads/public/software/SimioProductionSchedulingWonderwareMESInterface.pdf.
453 / 815
Simio Reference Guide
Data T ables
Data Tables
Tables are used to hold model data that may be referenced by individual entities and/or tokens. The data columns in the table can be any of the
property types provided by Simio including expressions, object references, class types, etc. Each entity/token in the model can then reference a
specific row of data in the table.
Each entity/token can set an active row of the table using the SetRow step in the Processes Window. The following functions can be used with
data tables:
TableName.PropertyName: references a property value in the active row.
TableName[RowNumber].PropertyName: references a property value in any row.
TableName[RowNumber, ColumnNumber]: references a property value in any row and column.
TableName.PropertyName.RandomRow: returns a random row index using the values in the property as weights (e.g. product mix).
TableName.AvailableRowCount: returns the number of rows in the given table.
Data import and export can be used for both Data Tables and Sequence Tables. Data Table import/export supports all field types as strings. All
errors are noted after the import is complete. You may wish to start with designing your table and using the Export button to get the proper
format. You can then import any data into your table. If the data table already has some data within it, an import will simply add file contents at
the bottom of the table.
Selecting Random Values from a Table
Many times, the data that is available from a system is actual real data, which is then read into an input processor/analyzer for fitting the best
distribution to the data. While Simio supports many distribution types, we also support the method of utilizing the information directly from the
actual data. The 'RandomValue' table function below allows for data to be selected directly from the table.
TableName.PropertyName.RandomValue: returns the value of the property for a randomly selected row in the table, where each row has an
equal probability of being selected.
Note that if the table has primary key/foreign key relationships, and the active token or object is referencing a row selection set in the table, then
this function will return the value for a row randomly selected from the related rows only. Otherwise, the row will be randomly selected from all
rows in the table.
If randomness is disabled in a model and the 'RandomValue' function is utilized, the following behavior will be exhibited. If the table property (i.e.,
table column) is a numeric property, then the ‘RandomValue’ function will return the average value of all rows for the property. If the table
property is non-numeric (e.g., a column of strings or object references), then the function will return the value of the middle-ish row in the table
(i.e., the row value corresponding to .5 cumulative probability).
The ‘RandomValue’ table property function returns a value equivalent to the following expression:
TableName[Math.C eiling(Random.Uniform(0,TableName.AvailableRowC ount))].PropertyName. Therefore, if a user is interested in the application
of this function but wants to use a different random number stream value than Simio’s default, the above alternative expression approach may be
taken and then the optional stream argument for the Random.Uniform function specified, such as
TableName[Math.C eiling(Random.Uniform(0,TableName.AvailableRowC ount, Stream))].PropertyName.
Time-Indexed Table Properties
Within the properties of a data table, under the Advanced Options section, is a Time-indexed property that may be set to 'True' or 'False'. By
default, all tables are set to 'False'. By changing this to 'True', additional properties for the table, such as Starting Time, Interval Size and On
Interval Process may be specified. Within a time-indexed table, you can then have a column(s) of values within the table and retrieve a single
value from the column, not by direct indexing, but indirectly, based on the current simulation time. The values within the table can be accessed
using a function for time-indexed tables:
TableName.PropertyName.TimeIndexedValue: returns the value of the property in the row that corresponds to the current simulation time.
If the current time is out of range of the table's rows, then this will return either the first row's or last row's value for the requested property.
You may also get access to the row number, based on the current simulation time, to be used with a standard table function, such as
TableName[RowNumber].PropertyName. This row number can be accessed using the function:
TableName.TimeIndexedRow: returns the row index that corresponds to the current simulation time. Note that if the current simulation time is
before or after the time ranges mapped to the table rows, this should return 1 (the index of the first row, if current time is too early), or N (the
index of the last row, if the current simulation time is too late).
The On Interval Process is an optional process that can be specified that will run at the start of each time interval. Note that this process runs
"early". That is, it is scheduled on the event calendar at a slightly higher priority than most other things, so you use it to set things up for the next
time interval, supposedly before anything else occurs that would be affected.
In the picture below, the value of Table1.ProcessingTime.TimeIndexedValue will be 10 for the first hour. At the start of the first hour, the On
Interval Process named 'Process1' will be run. From then on, every 1 hour, the time indexed value within the table that is referenced will be
updated to the next row and 'Process1' will be run.
454 / 815
Table Property Referencing
A Table property is defined within the Definitions window, Properties panel of an object. This table property can be used within the Processes
window steps, such as SetRow, AddRow and Search.
Functions similar to those listed above can be used with a table property, however the row and column specified must resolve to numeric values.
That is, the column name cannot be used within the table property reference, only the relative column number.
TableProperty[RowNumber, ColumnNumber]: returns a value from a row, column location of a table pointed to by a table property.
TableProperty.AvailableRowCount: returns the number of rows for a table pointed to by a table property.
TableProperty.TimeIndexedRow - returns the time indexed row of a table pointed to by a table property.
Some examples of using these table properties include the following:
TableProperty1[3, 4] returns the value at row 3, column 4 within the table referenced in TableProperty1.
MyFixed1.MyTableProp[3, 4] returns the value of row 3, column 4 within the table referenced in MyTableProp within some instance of an object
named MyFixed1.
NOTE: Reals and Expressions -- Unit Types
When using a Standard Property of type Real or Expression, the Unit Type may be specified as a Time unit. When the time unit is specified within
the table, that time unit is used for any calculations using the table column. For example, if Table1 has a real property ProcessTimes that is
specified as 'minutes' in the Unit Type property, and the table is referenced 'Table1.ProcessTimes' within a delay, then the time Units specific to
the delay property are not shown and the time units of the table column (minutes) are used. Likewise, the same table entry may be referenced
within an expression in a time delay, such as 'Table1.ProcessTimes * 0.5'. In that case, the Units property for the expression is displayed (and
can be changed), but will NOT be used, as the table reference includes the units (minutes in this case) to be utilized. Within the model, multiple
table entries may be used in an expression with varying time units and Simio converts them to the correct base time unit.
455 / 815
Simio Reference Guide
R elational T ables
Relational Tables
As mentioned in the Tables page, a foreign key may be used to create a table relation. This approach allows exploition of relational data design to
simplify Simio tables.
A Foreign Key reference is used to relate data from multiple data and/or sequence tables. When a foreign key property is added, the Table Key
property is used to make a row in this table link directly to another row in the table specified by the Table Key. The Set C olumn As Key button
allows the user to indicate that the highlighted column may be referenced by another data and/or sequence table. This button makes the current
column a Key for this table (you may have multiple columns that are Key in a single table). This column's data can then be referenced by Foreign
Key properties in other tables, which will link the rows in those tables to a row in this table. The Set C olumn as Key and Foreign Key are used
together for relational type data tables.
Relational tables include Master-Detail, which allows the relationships bewteen various tables to be visually seen. For those tables that have a
column that is designated as ‘Set C olumn As Key’, users can see a “detail” view, which is a collection of rows pointing to a specific keyed row in a
table. The small ‘+’ sign in front of the row indicates that the detail view is available. When the ‘+’ is pressed, portions of the related table, those
specific to the entry that was expanded, will be shown.
Master-Detail shown within Relational Data Tables
For example, in the screen shot shown above, the Type of Service is defined as a Key C olumn. Therefore, this column can be used within another
table as a reference (i.e., within the Arrivals table, Type of Service column is set as a Foreign Key type of property and thus references the Type
of Service column within the Service Times table). Note that the name of a Foreign Key column does not have to be the same as the Key C olumn
name.
The detail view can be edited just like the main view (insert / remove rows, edit rows, copy/paste, etc.). Additionally, a keyboard shortcut
(C trl+Shift+’+’) can be used to insert rows into any data grid, such as tables or lists.
456 / 815
Simio Reference Guide
Sequence T ables
Sequence Tables
A Sequence Table is a data table that has a destination column that is used to specify a sequence of destinations for an entity (e.g. the job routing
sequence in a job shop). You can also add additional data columns to the sequence table and reference these values like any other table (e.g.
TableName.PropertyName).
The sequence table that an entity follows can be initially set as the Initial Sequence property of the entity instance. The routing logic for an entity
can specify that the entity destination is to be set “By Sequence”. This may be specified in the Entity Destination Type for the TransferNode or
Destination Type of the SetNode step.
When setting the next destination “By Sequence”, the next table row in the entities’ sequence table is made active and the entities’ destination is
set to the destination specified in that row. The active row in the sequence table is automatically incremented each time the destination is set “By
Sequence”.
A destination can be any node in your model. If an object (e.g. a Server) has a single associated input node then the destination can be specified
in shortened form as Server (instead of Input@Server). This is convenient for routing between the objects in your model. However, if the object
has multiple input names (e.g. C ombiner), then the input nodes must be fully qualified as NodeName@ObjectName (e.g. ParentInput@C ombiner
and MemberInput@C ombiner). By default only the input nodes for objects are in the list of destinations. If you want to set a destination to
another node in the model, click on the Destination column header and change the Accepts Any Node property to "True".
Data import and export can be used for both Data Tables and Sequence Tables. Sequence Table import/export supports all field types as strings.
All errors are noted after the import is complete. You may wish to start with designing your table and using the Export button to get the proper
format. You can then import any data into your table. If the data table already has some data within it, an import will simply add file contents at
the bottom of the table.
C hanging an Entity Sequence or Active Row
The entity has an initial sequence that is assigned with the Intial Sequence property within the ModelEntity. The sequence table associated with an
entity can be changed by using the SetRow step. For example, if you have two sequence tables and the entity's original table is Table1, you can
change it during the model logic to Table2. Keep in mind that each routing 'By Sequence' will update the row in the table by one. Therefore, if you
assign a new table association after processing at a Server, for example, you may need to initially set the row to '0' such that when the entity
leaves the Server 'By Sequence' it updates the table association to row 1 and sends the entity to the first location in the sequence table.
The SetRow step can also be used to change the entity's active row within a sequence table. C hanging the active row may be useful for rework,
for example, to route an entity back through a given set of steps.
Sequence Functions
There are a number of entity sequence related functions that can be used during the simulation run. These functions can be found on the
Functions, States and Events for Entity Objects page.
Both BasicNode and TransferNode objects have a Sequence Expected Operation Time property. This property is used to estimate an expected
operation time if the node is in the destination sequence of an entity's assigned sequence table.
For Server and Separator objects, the Sequence Expected Operation Time for the 'Input' node is the Processing Time. For the C ombiner object,
the Sequence Expected Operation Time for the 'ParentInput' node is the Processing Time. The Sequence Expected Operation Time property value
for the 'Input' node of the Workstation is the Setup Time (if specific and thus sequence independent) + Processing Time + Teardown Time. Any
sequence dependent setup time estimates are not included by default in the expected operation time at a workstation.
457 / 815
Note that when estimating the expected operation time for a sequence jobstep, the expression evaluation is always deterministic. Thus, if a
random distribution is specified, then the expected value for that random distribution will be assumed. The expected operation times for the job
steps in an entity's sequence will be evaluated once on the first function call that requires the information. For performance efficiency reasons,
those estimates will then be stored and simply reused on any subsequent function calls requiring the information.
Examples
For examples of using sequences, please refer to the SimBits EntityFollowsSequence, EntityFollowsSequenceMultiple,
EntityFollowsSequenceWithTable, and SortingC onveyorSystem.
458 / 815
Simio Reference Guide
Importing and Binding T o T ables
The user can import, export and bind to data tables to utilize data external to Simio.
If you open a model that was created by another user and the Table ribbon within the Data window has the Import and the Bind To buttons
greyed out, this indicates that the table has been bound to an external file. You should also see the Remove Binding button is active so that you
can remove the binding. Simio also provides the name of the file and the location is the space above the Table, in order to direct users to the
external file that is currently bound to that Table. Holding down the Shift key while pressing the Remove Binding button will prompt the user
whether they'd like to unbind all the tables in the model.
A Table that is Bound to an External File
459 / 815
If the Runnable property is set to 'True' then if this model is placed inside another model, the top level model will not recognize changes made in
the source file. The user must open the child model and either run the model to trigger an automatic import or perform a manual import so that
the new data from the source file is now loaded into the data tables.
Note: The above statements apply to the scenario where the child model definition is in the same project as the parent model. If the child model
definition is located in a separate project, the top level model will never automatically recognize changes in a data source that is bound to a child
model. The user must open the child model, re-import the data and save the child model. When the parent model is then opened, it should
prompt the user that changes have been made to the child definition and the user has the option to accept these changes.
Importing and Exporting Data into Tables
The user can export the table to a comma separated value (C SV) file by clicking on the Export icon in the ribbon menu. This is particularly useful
to create a table in the proper format if you wish to add your table data externally (e.g. in Excel) and later import it into Simio. The user can also
import the data from a database file, comma separated value (csv) file or from a Microsoft Excel file into the table by clicking on the Import icon
in the ribbon menu. Users can use the Import option to import the current table's data into the table or may select Import All to import each
bound table's data from its data source. As was mentioned above, the Import option is only available once a file is bound to the table and the
Binding Options is set to 'Manual'. It is recommended that the initial table be generated by first exporting an existing (possibly blank) table from
Simio.
When performing an import from Excel, it will always assume the first row selected is a column name. Also, the import logic always tries to match
up already existing column names in the table with column names from the data, and if it cannot match a column from the data up with a column
in the table (and the table actually has columns already in it), it throws the data away. If you run into this problem, delete all the columns in the
table and do the import again with a blank Simio table.
Data can be copied out of Excel and pasted into a Simio table. C opy the data from Excel, click on the appropriate row and column of the Simio
table and click C trl-V to paste the data into the Simio table.
See the functions that can be used with Tables.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for Data and Sequence Tables. Please refer to the User Interface for more
details.
460 / 815
Simio Reference Guide
T able-Based Elements (Auto-C reate)
Element Objects
When a column within a sequence or data table is of the type Element Reference, the user will get the following options within the property
window:
By default, any Element Object columns will have a Reference Type (Advanced Options)of 'Reference' to simply reference a previously defined
element. However, if the Reference Type is changed to 'C reate', then any entries into that column will automatically create a new element of the
specified type (in the example above and below, a Material element is used as an example).
When an Element is automatically created, you will see it located within the Definitions window, Elements panel. It will be clearly marked as auto-
created and it cannot be deleted. Any edits to the element Name within either the data table or the element panel window will be reflected in each
other.
461 / 815
In addition to the element itself being created, any properties of that element may also then be referenced and created by a column within the
table. This is done with the Initial Property Values repeatable property within the Element Reference property window, as shown below. For each
given Element type, a different set of Property Name properties are available from the list. In this example, the 'InitialQuantity' of a material is
input. Within the Value property, an expression can be entered which will be fed into the property information within the Element itself. In this
example, a table reference is used, 'Table1.InitialQuantity'.
The value of the property specified in the Value field will then get fed into the appropriate property within the Element itself, as shown below.
Likewise, the Value reference (above) can also be a simple integer value, such as '3' that will similarly be fed into the correct property value
within the Element itself.
462 / 815
Finally, it is important to note that if an auto-created Element's property value is linked to a table (as it is in the example above, using
'Table1.InitialQuantity'), the Auto-set Table Row Reference property for the Element in the table must be set to 'True'. This is shown in the below
diagram.
The Auto-set Table Row Reference property, if true, then at run initialization, the Element pointed to by each row in the table will have a table
reference set to that row. This will allow an entry in an Element column to 'correpond' to the same row entry in another column, which is essential
for defining Element properties.
463 / 815
Simio Reference Guide
Lookup T ables
Lookup Tables
By clicking on the Data tab and selecting the Lookup Tables panel, users may add a table to model situations where a value (e.g. processing
time) is dependent on some other value (e.g. number of completed cycles). Lookup tables return a function value based on a lookup value.
The value of a lookup can be specified in an expression using the format Name[X_Expression], where Name is the name of the lookup table,
and X_Expression (specified as any valid expression) is the independent index value into the lookup. For example C ycleTime(NumberBusy)
returns the value from the lookup table named C ycleTime based on the current value of the NumberBusy state. The lookup value is computed
using linear interpolation between the defined values. If the index is out of the defined range then the closest endpoint (first/last) point in the
range is returned.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for Lookup Tables. Please refer to the User Interface for more details.
464 / 815
Simio Reference Guide
R ate T ables
Rate Tables
The Rate Tables panel in the Data window allows the user to model situations where an arrival/event rate varies discretely over time. The number
of fixed rate periods and the length of each rate period can be specified in the Rate table. The rate pattern automatically repeats during the
running of the simulation.
A Rate table is used by the Source object / Timer element to generate entities / events with a time-varying rate. Internally, a non-stationary
Exponential distribution is used to calculate the rates. The rate units for the Poisson arrival process is Arrivals per Hour, regardless of the time
units specified for the intervals of the rate table.
In order to use a Rate Table with the standard Source object, set the Arrival Mode property in the Source to 'Time Varying Arrival Rate' and then
select the appropriate Rate Table for the Rate Table property. The Source also includes a Rate Scale Factor property that can be used to easily
modify the values within the table by a given factor instead of changing the values separately. For example, to increase the Rate Table values by
50%, simply specify the Rate Scale Factor within the Source to '1.5'.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for Rate Tables. Please refer to the User Interface for more details.
465 / 815
Simio Reference Guide
Schedules
Schedules
Schedules are used to model situations where the capacity of an object varies over time. An object (e.g. Server) can have an associated
schedule that automatically changes its capacity over time. A schedule is comprised of a repeating base pattern called a Work Schedule with
superimposed exceptions (e.g. holidays or planned maintenance). Schedules are defined within the Data tab, Schedules panel of a model.
A Work Schedule is defined by specifying the number of repeating days within the schedule and the associated Day Pattern for each day. Multiple
work schedules can be defined within the Work Schedules tab.
Work Schedule Window
A Day Pattern consists of a single or multiple Work Periods that define on shift and off shift periods with a starting time, duration and ending time.
Any periods that are not defined are considered to be off shift, or have a capacity Value of '0'. A cost multiplier may be defined for the given
work period as well. An on shift Work Period entry has a value that defines the capacity of the object that is following this schedule. Multiple Day
Patterns can be defined within the Day Patterns tab.
Day Pattern / Work Period window
Exceptions override the repeating work schedule for the duration of the exception. Exceptions can be defined within the Work Day Exceptions tab
and within the Work Period Exceptions tab, both from the Work Schedule tab. A Work Day exception may be used for holidays or single days and
is defined by a single calendar day and an alternative Day Pattern for that calendar day. A Work Period exception may be used for overtime,
planned maintenance, vacation periods, etc., and is defined by starting day/time and ending day/time. Within the Work Period exceptions, the
capacity Value can be specified.
Work Day Exceptions and Work Period Exceptions
466 / 815
Creating a Work Schedule
C lick on the Data window tab and click on the Schedules panel.
By default, a work schedule named 'Standard Week' is already available for use or modification. To add a new schedule, you can either
press the Work Schedule button on the Schedule toolbar or simply enter a new work schedule Name.
The starting date of the schedule should be entered in the Start Date property in date format.
Specify how many days are in the schedule by inserting a number between 1 and 28 in the Days property. In other words, how many days
until this schedule repeats itself. If any schedule has more days than another schedule, the extra days for the particular schedule will be
grayed and not editable. If the number of Days is '7', days will be shown as days of the week, based on the Start Date specified.
Select a Day Pattern name for each day specified.
Important Note regarding Start Date: The Start Date is the date on which a repeating cycle starts. That repeating cycle then repeats infinitely in
both directions (e.g., backwards in time as well). To override that behavior and prevent immediate availability in a schedule with a future start
date, you would need to add an exception to prevent that interim availability.
Creating a Day Pattern with Work Periods
Day Patterns are defined within the Day Patterns tab of the Schedules window. A default Day Pattern named 'DayPattern1' has been
provided. To add a new day pattern, you can either press the Day Pattern button on the Schedule toolbar or simply enter a new day
pattern Name.
To enter values into the Day Pattern, press the '+' next to the name and the Work Periods will open.
With the Work Periods, enter the Start Time. You may then enter either the Duration (and the End Time will be determined) or the End
Time (and the duration will be calculated).
The Value field is used to determine the capacity of the object using the schedule. See notes below on limitations for Worker schedules.
The C ost Multiplier property is applied to the idle and usage cost rates of a resource following the work schedule. This may be useful for
specifying overtime costing.
Multiple Work Period rows may be added for various capacities throughout the day. If there is a time period where no information is
specified, Simio assumes the capacity to be '0'.
Important Note regarding Schedules and Worker object: The Value field for a worker should either be '1' (indicating On Shift) or '0' (indicating Off
Shift), as the capacity of the Worker object is defined within the object itself using the Initial Number In System property. The schedule for the
Worker should be used only to define On Shift or Off Shift times, not capacity values.
Adding a Work Day or Work Period Exception to the Schedule
Within the Work Schedules tab, select the Work Schedule that will have Exceptions
C lick on the '+' next to the Work Schedule.
For a Work Day exception, select the Date for the exception and specify a Day Pattern that should be used for this date. When this date is
encountered, Simio will use the exception Day Pattern instead of the Day Pattern specified in the main Work Schedule.
For a Work Period exception, enter the Start column and select the date and time of the exception. Within the End column, enter the date
and time that the exception will end. For that same exception, enter the capacity Value that will be used instead of the value specified in
the associated Work Schedule's Day Pattern. A cost multiplier may also be specified with the work period exception.
An experiment can be run that uses a Schedule as an input into the model. This allows for the user to experiment with how different work
schedules can affect their key performance metrics. To experiment with a schedule, create a Schedule type property on the model, from the
Definitions window. From within the Facility window, go to the object that will be following the work schedules and set the Work Schedule property
of that object instance to reference the new Schedule property that you created above. From the Experiment design window, you can input the
name of a Work Schedule into different scenarios on an Experiment.
Additionally, the Value and Cost Multiplier properties of a schedule and/or exception can be expressions. This includes the ability to utilize a
property value (for experimentation) within a Value or Cost Multiplier field. For example, the Value property may be set to a property named
'Value1' for a given exception, where the 'Value1' property can be used within the experiment to test various capacities for a given Resource.
467 / 815
'Value1' for a given exception, where the 'Value1' property can be used within the experiment to test various capacities for a given Resource.
Functions Available for Schedules
Listed below are the Functions of Schedules:
Function Description
Value(dateTime) Returns the schedule's value for the specified numeric datetime (simulation time).
NextValue(dateTime) Returns the schedule's next value if at the specified numeric datetime (simulation time).
TimeOfNextValue(dateTime) Returns the simulation time (in hours) of the schedule's next value change if at the specified numeric datetime
(simulation time).
TimeUntilNextValue(dateTime) Returns the time duration remaining (in hours) until the schedule's next value change if at the specified numeric
datetime (simulation time).
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for Schedules. Please refer to the User Interface for more details.
468 / 815
Simio Reference Guide
C hangeovers
Changeovers
C hangeover matrices are used to model situations where an activity time (e.g. the setup time for a workstation) is sequence dependent. The
activity time is the matrix value indexed in row/column by a list value such as color, size, part family, etc. The row is selected based on this value
for the previous entity, and the column is selected based on this value for the current entity.
When using C hangeovers, a string list must be defined within both the model, as well as the model entity. Lists are specified within the Definitions
tab, Lists panel. See the help section on Lists for more information on String lists. An example of using a changeover matrix is found in the SimBit
WorkstationWithSequenceDependentSetup.
Conceptual Example of Changeover Matrix
The changeover matrix data is also accessible in an expression. A changeover matrix value may now be referenced in any expression using the
syntax MatrixName[row,column], where the row and column subscripts are numeric constants or expressions that return zero-based row and
column indexes into the matrix. When a changeover matrix has been added to a model, the available changeover matrix syntax can be viewed
within the expression builder.
The name of a changeover matrix can also be accessed within an object property (repeating or non-repeating). The object’s process logic is then
able to get to the matrix data through the property reference. This is done by adding a C hangeover Matrix type property to the model by going to
Definitions / Properties / Standard Property and adding a property. Then, in the process logic of the object that has the property, the syntax for
ChangeOverMatrixPropertyName.Matrix[row,column] or
RepeatGroupPropertyName.ChangeOverMatrixPropertyName.Matrix[row,column] may be used to access a value at a specified row
and column index location in the changeover matrix that is being referenced. ChangeoverMatrixPropertyName.Matrix.Name can be used to
get the string name of the changeover matrix that has been specified using the property.
NOTE: C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste) is supported for C hangeovers. Please refer to the User Interface for more details.
469 / 815
Simio Reference Guide
Input P arameters
Input Parameters
Input Parameters are generally used to define named parameters which can then be referenced anywhere within your model. For example you
might define Input Parameters named InterarrivalTime and ProcessingTime, and then reference these names on the Source and Server objects
in your model. There are several advantages in using Input Parameters in place of directly entering these expressions in the model.
Input Parameters can be shared across multiple objects; e.g. if five servers all share the same Process Time, they can all reference the
same Input Parameter.
It is more convenient to enter distributions using Input Parameters since the distribution parameters are individually defined as properties
of the Input Parameter and a histogram is based on 10,000 samples is provided to show the shape of the distribution for the parameters.
Input Parameters enable both Response Sensitivity and Sample Size Error analysis.
Input Parameters are defined by selecting the Data window tab, and then selecting Input Parameters on the left panel. There are three different
types of Input Parameters – Distributions, Table Values, and Expressions.
A Distribution is used to specify a random distribution. The parameters for the distribution are specified in the property grid, and the histogram
based on 10,000 samples of that distribution is displayed in the bottom panel of the window. In addition to the distribution parameters you also
define a Boolean flag that specifies if this Input Parameter is to be active in the Response Sensitivity analysis, and a second Boolean flag that
specifies if the Input Parameter is to be included in the Sample Size Error analysis. If it is included in the Sample Size Error analysis you also
specify the number of real-world observations that were used in fitting this distribution.
The second type of Input Parameter is a Table Value and is used whenever the actual observational data is randomly sampled in place of fitting
the data to a distribution and then sampling from that distribution. This is typically the preferred approach when actual data is available, given
that you are confident that you have a representative sample and/or you have no additional information about the process. In this case you
specify the table column name that holds the real-world observations.
470 / 815
The third type of Input Parameter is an Expression. In this case you can specify any mathematical expression, including random distributions
and model properties. Although this is the most general form of the Input Parameter, one limitation is that it cannot be used in the Sample Size
Error analysis.
471 / 815
The input parameter name is then referenced within an object's property field in a model, similar to the way that states and property values are
used. Right-clicking on a object's property value in the Facility window also allows the user to create a new input parameter or select from the
already existing input parameters. Alternatively, the input parameter name can be used by itself or within an expression in any object's property
field that accepts an expression.
The input parameters are unique, in that they are also used within the Experiments defined for a model. The Input Analysis tab within an
Experiment will display all input parameters and associated scenario results. See the Response Sensitivity and Sample Size Error Analysis topic
for additional information.
472 / 815
Simio Reference Guide
T he R esults W indow
Results Window
The Results window allows the user to display the the results in the form of a Pivot Grid, Reports, Dashboard Reports, Table Reports or Logs,
depending upon which is selected in the panel. The data from the Pivot Grid and Logs can be exported into a .csv file.
For information on how to add manual statistics to the project, see OutputStatistic, StateStatistic and TallyStatistic.
473 / 815
Simio Reference Guide
P ivot G rid
Pivot Grid
The Pivot Grid displays result data from a simulation run(s). It lets the user interactively analyze the results in the form of a dynamic rotatable
table. You can drag and drop columns in the table to rotate or “pivot” the data. You can also filter and sort the information that is shown. This is
similar to features found in the pivot table provided by Microsoft Excel.
The Results window displays the Pivot Grid panel by default. So when you first click the Results tab, you are viewing the Pivot Grid.
The section of the Pivot Grid ribbon labeled "Status Units" allows the user to specify the units to be displayed in the reports, pivot grid, watch
window, status bar, and trace window.
The following categories help to organize the result data:
C ontent – category used for statistics on the number of things inside or on something, such as NumberInSystem or NumberOnLink.
Throughput – category used for totals on items entered/created or items exited/destroyed.
C apacity – category used for statistics related to capacity, including number of units allocated over time, units scheduled and utilization of
the object. Scheduled utilization is calculated based on the units utilized divided by the units scheduled.
FlowTime – category used for entity time in system (population or by Sink) or entity time on link.
HoldingTime – category used for entity time held in a station location or held in a batch.
ResourceState - category used to show occurances, percent and average times in each of the resource states in which an object may be.
C osts - category used to show final values of cost for each object or cost center, in addition to Population.C ost statistics for Entity and
Transporter type objects.
A Pivot Grid
This Pivot Grid provides a very easy way to manipulate, summarize, and display data and provides a powerful mechanism for exploring your data
(data mining).
The red circle above identifies the columns and their symbols. C olumns may be moved around within the pivot grid. The up/down arrow may be
used to sort the rows within a column into alphabetical order. Moving the mouse over a given column will display the filter button (described
below). Data items may be moved to reconfigure the table.
474 / 815
Grouping: For example, left click and drag the leftmost column named Object Type to the top row (next to Data Source Type). You will see that
the data is no longer grouped by Object Type, but rather only by Object Name. You may also drag the columns to different positions to cause the
data to be grouped differently. For example, if you wanted all of your data items displayed together (e.g. all the Arrivals statistics together) you
could drag the Data Item column to the far left, in front of Object Name.
Sorting: You will see a small triangle in every column heading – this determines the sorting order for that column. If you click on that triangle (or
in fact almost anywhere in the heading box), it will toggle the column sort order between ascending and descending.
Filtering: You may have noticed that the Statistic heading in the Pivot table above has an extra symbol in the upper right corner – a funnel. This
indicates that it is filtering the data. If you click on the funnel you will see a menu indicating all possible values in that column and you will see
that Minimum has been unchecked. This means that any items labeled with Minimum have been suppressed (our default setting). If you check the
Minimum or the (Show All), you will see all the minimum values will now be added to your report.
Filtering
All column headings and items in the filter area have this filtering capability. For example, if you hover the mouse over the upper right corner of
the Object Type box (the one you just moved to the filter area), you will see that funnel appear. C licking on that funnel shows all object types
found in the report. If you have no interest in seeing statistics on your paths for example, simply uncheck the Paths item and all of the statistics
associated with paths will be suppressed.
The C hange View, Add View and Manage Views button allow you to record column ordering, column width, sort and filter settings and save them
to a particular 'view' for later reference. Within the C hange View button is also the option to reset the pivot grid to the original default view. When
a named view is open, you will see Showing Named View: "ViewName" at the top of the grid.
475 / 815
Simio Reference Guide
R eports
Reports
The Reports panel of the Results tab displays a traditionally formatted report that provides flexible visual formatting for inclusion in printed
documents and is useful in presenting results to others. Reports are provided for both a single scenario and for comparing two scenarios. After
clicking on the Results tab and Reports panel button to view the reports, select the appropriate report from the C urrent Report dropdown in the
ribbon menu.
The Report Designer allows you to create a custom Report based on generated model data. Reports can be made using data from the Interactive
Model Results (i.e. the data displayed in the Pivot Grid), the Resource Usage Log, the Resource State Log and the C onstraint Log.
476 / 815
Simio Reference Guide
R eport Designer (Enterprise)
The Report Designer allows you to create a custom Report based on generated model data. Reports can be made using data from the Interactive
Model Results (i.e. the data displayed in the Pivot Grid), the Resource Usage Log, the Resource State Log and the C onstraint Log. Simio also
provides access to the Report Designer through the Table Reports panel button of the Results window. C ustom reports may be created using any
of the data tables within a Simio model.
C ustom reports can contain tables, charts, grids, pictures, text and interactive features, such as drop down selections and check boxes. There is
complete documentation, including helpful videos, on how to create custom reports using this interface on the Dev Express website:
https://documentation.devexpress.com/#WindowsForms/C ustomDocument8118
The Report Designer button can be found on the Reports ribbon, which is visible from the Results window when you view the Reports panel.
Report Designer is also available within the Table Reports panel to create custom table reports from data tables in a model. The Reports ribbon is
also available when viewing the Reports window of the Planning/Results panel or viewing the Reports window of an Experiment. The Report
Designer button can also be found on the Table Report ribbon, which is visible from the Results window when you view the Table Reports panel.
The Report Designer interface will appear in the new window. Depending on what data source you selected from the Report Designer drop down
in the ribbon, the Field List will be populated with the appropriate tables and fields that are available from this data source. This is the data that
can be used to create your custom report.
477 / 815
These are the tools that are used to design the layout of the report. They are placed into the appropriate band within the main grid area.
478 / 815
You can customize the layout of the report by right clicking in the main grid area and selecting Insert Band and then selecting Report Header,
PageHeader, GroupHeader, GroupFooter, ReportFooter or PageFooter. Each type of band has its own use, such as the Report Header, that
whatever is placed in this band is common among all pages of the report. For example, you might put a report title here by placing a Label from
the Toolbox. Or the Page Footer can be used to display page related information that is common on all pages, such as a page number.
Simio has three reports that are found on the Reports page of the Results tab. These are the Interactive Detail report, the Scenario
Comparison report and the Scenario Detail report. If you are using the Enterprise version, there are more reports on the Reports tab of the
Results page. These reports are the Resource Dispatch List, the Workflow Constraints Analysis and the Resource Utilization Summary.
All six of these reports can be found in the Simio reports folder (\\Public\Public Documents\Simio\Reports). You can open these reports in the
Report Designer to see how they were created and to use these as a starting point for creating your own custom report.
479 / 815
Simio Reference Guide
Dashboard R eports
Selecting C reate Dashboard Report will prompt you to enter a dashboard name. Once a name is entered, the DashboardDesignerForm window
will appear.
From here, you have the option to insert various dashboard items such as a pivot grid, grid, chart, pie chart, gauge, card image, text box or
range filter.
Pivot – A pivot grid displays a cross tabular report. It can be used to present multi-dimensional data in an easy to read format.
Grid – A grid shows data in a tabular form while allowing you to summarize against specific measures or calculate differences between them.
Chart – A chart visualizes data in an XY diagram, allowing you to render a wide range if diagram types such as a bar, point, area, range, bubble
or financial chart.
Pies – A pie chart displays a series of pies that represent the contribution of each value to the total.
Gauges – A gauge chart is another method for displaying a series of model data. It displays two values – one with a needle and one with a
marker on the scale.
Cards – C ards display the differences between two values, which can be expressed as an absolute for percent.
Choropleth Map – This item allows you to place an choropleth map dashboard item onto your dashboard.
Geo Point Map – This allows you to place a geo point map dashboard item onto your dashboard.
Range Filter – A Range Filter item allows you to apply filtering to other dashboard items. It displays a chart with selection thumbs over it that
allow you to filter out values displayed along the argument axis.
Image – An Image item allows you to insert an image into the dashboard. Right clicking in the Image item will allow you to load or import in
image.
Text Box – A Text Box item allows you to enter text onto your dashboard. Right clicking within the Text Box item allows you to enter text.
Once a dashboard item has been inserted, you have the ability to duplicate or delete an item. There is also the ability to add a dashboard title
and to identify currency units to be displayed.
In addition, right clicking into a dashboard item will give you the option to show an item caption, duplicate or delete the item, edit the dashboard
item name, edit an item filter, print preview the item or export to a PDF or image (.PNG) file.
Once a dashboard item is inserted into the window, other ribbons or tools are available which are specific to the item inserted. These are briefly
discussed below. By hovering over each tool within the ribbon, you will get more information on what each tool accomplishes.
Pivot Data Tools include Edit Filter, C lear, Ignore Master Filters and Initial State Layout while Pivot Design Tools include Show C aption and Edit
Names options.
480 / 815
Grid Tools include Data Tools and Design Tools. Data Tools include Edit Filter, C lear, Single Master Filter, Multiple Master Filter, Drill Down, C ross-
Data-Source Filtering and Ignore Master Filters. Grid Design Tools include Show C aption, Edit Names, Horizontal Lines, Vertical Lines, Merge C ells,
Banded Rows and C olumn Headers.
C hart tools consist of Data Tools and Design Tools. C hart Data Tools include Edit Filter, C lear, Single Master Filter, Multiple Master Filter, Drill Down,
C ross-Data-Source Filtering, Ignore Master Filters, Arguments and Series.
C hart Design Tools include Show C aption, Edit Names, Rotate, X-Axis Settings, Y-Axis Settings, Show Legend and Series Type.
Pie Tools include Data Tools and Design Tools. Pie Data Tools include Edit Filter, C lear, Single Master Filter, Multiple Master Filter, Drill Down, C ross-
Data-Source Filtering, Ignore Master Filters, Arguments and Series.
Pie Design Tools include Show C aption, Edit Names, Auto Arrange, Arrange in C olumns, Arrange in Rows, Data Labels, Tooltips, Show Pie
C aptions and Pie or Donut style.
Gauges Tools include Data Tools and Design Tools. Gauges Data Tools include Edit Filter, C lear, Master Filter, Single Master Filter, Multiple Master
Filter, Drill Down, C ross-Data-Source Filtering and Ignore Master Filters.
481 / 815
Filter, Drill Down, C ross-Data-Source Filtering and Ignore Master Filters.
Gauges Design Tools include Show C aption, Edit Names, Auto Arrange, Arrange in C olumns, Arrange in Rows, and styles such as Full C ircular,
Half-C ircular, Left-Quarter C ircular, Right-Quarter C ircular, Three-Fourth C ircular, Linear Horizontal, Linear Vertical and Show Gauge C aptions.
C ards Tools include Data Tools and Design Tools. C ards Data Tools include Edit Filter, C lear, Single Master Filter, Multiple Master Filter, Drill Down,
C ross-Data-Source Filtering and Ignore Master Filters.
C ards Design Tools include Show C aption, Edit Names, Auto Arrange, Arrange in C olumns or Arrange in Rows.
Map Tools include Data Tools and Design Tools. Map Data Tools include Edit Filter, C lear, Single Master Filter, Multiple Master Filter, C ross-Data-
Source Filtering and Ignore Master Filters.
Map Design Tools include Show C aption, Edit Names, Show Legend (choropleth maps only), Load Mao, Import Map and Default Map options.
Range Filter Tools include Data Tools and Design Tools. Data Tools include Edit Filter, C lear and C ross-Data-Source Filtering.
482 / 815
Range Filter Design Tools include Show C aption, Edit Names and allow you to change the series type to a Line, Stacked Line, Full Stacked Line,
Area, Stacked Area or Full-Stacked Area.
Image Design Tools include Show C aption, Edit Names and include options such as Load Image, Import Image, C lip, Stretch, Squeeze, Zoom and
Alignment.
Text Box Design Tools allow you Show C aption, Edit Names as well as allowing you edit various text settings.
There is also a Data Source ribbon tab in the dashboard reports designer, so that a data source, such as a database, may be connected to
retreive additional external data for a dashboard. The New Data Source button on the Data Source ribbon will open the following dialog.
483 / 815
Next, the data connection parameters, such as Provider, Server name, Database and other pertinent information, are specified.
The object to include in your data source is then selected and can later be seen in the list of data logs and reports to utilize when building the
dashboard report.
484 / 815
In earlier versions of Simio, there was the concept of a dashboard where plots, pie charts, gauges, etc. could be added to a model. This
functionality is still available however it has been renamed to C onsole and is now available under the Definitions tab. While the items in the
C onsole view are animated as the model runs, the new Dashboard Reports display post run data.
Dashboard Report Edition Specific Functionality
Dashboard Report functionality varies based on your license type. Below is a chart that describes the differences:
Edition/License
Functionality
Type
Evaluation Access to the Dashboard Reports Window and ability to view dashboards that contain state and tally observations in addition
to user created tables. No editing is permitted.
Express Edition Access to the Dashboard Reports Window and ability to view dashboards that contain state and tally observations in addition
to user created tables. No editing is permitted.
Design Edition Access to the Dashboard Reports Window and ability to view dashboards that contain state and tally observations in addition
to user created tables. No editing is permitted.
Team Edition Access to the Dashboard Reports Window and ability to view dashboards. C reation and editing of dashboards are limited to
state and tally observations in addition to user created tables.
University Design Access to the Dashboard Reports Window and ability to view dashboards. C reation and editing of dashboards are limited to
Edition state and tally observations in addition to user created tables.
Enterprise Edition Access to the Dashboard Reports Window and ability to view dashboards. C reation and editing of dashboards are not limited.
University Access to the Dashboard Reports Window and ability to view dashboards. C reation and editing of dashboards are not limited.
Enterprise Edition
Student Edition Access to the Dashboard Reports Window and ability to view dashboards. C reation and editing of dashboards are limited to
state and tally observations in addition to user created tables.
Scheduler Edition Access to the Dashboard Reports Window and ability to view dashboards created with any data source. No editing is
permitted.
Partner Edition Access to the Dashboard Reports Window and ability to view dashboards that contain stat and tally observations in addition
to user created tables. No editing is permitted.
Example 1 – How to create a dashboard report with a model that contains tallies
Problem – In the HospitalEmergencyDepartment example, I want to be able to graphically display the differences between the times patients wait
for rooms, times patients wait for beds and patients length of stay, both as an average as well as each data point over time.
This example will illustrate how to create a simple dashboard that will display tally statistics.
Load the HospitalEmergencyDepartment SIMIO Project File located in your Examples folder.
Open the Definitions window and for each TallyStatistic, under Advanced Options, set the Log Observations value to ‘True’ for TallyStatistic
TimeWaitiedForBeds, TimeWaitedForRoom and LengthOfStayStatistic. This will create a log of the tally observation data that will be used to
populate the dashboard items.
485 / 815
Fast forward the model to completion. Once the model run has ended, open the Results window and then select the Dashboard Reports view.
C lick Dashboard Report C reate in the upper left corner of the window and select a dashboard name (ex: Tallies).
486 / 815
From the dropdown list in the upper left corner, select Tally Observation Log. That is the log file we will use to populate the dashboard.
From the Dashboard ribbon click on C ards. C ards are used to display the differences between values. A C ard window and corresponding data
items will appear.
On the left side of the window, under Tally Observation Log, select the Value item and drag it onto the Actual data item box. This is the value that
will be displayed on each card. Now change the modifier from Sum to Average by clicking on the arrow to the right of the data item box. This will
cause the average of all Values in the log for each data source item to be displayed on each card.
487 / 815
Now drag the DataSource item onto the Series data item box. This will create a card for each DataSource item in the Tally Observation Log and
label each card with the name of the DataSource item. Each C ard will display the average of all Values for that Tally.
Right click in the C ard box and select Edit Names. C hange the name from C hart 1 to Tallies. You should see something that looks like this.
On the Dashboard ribbon and select C hart. Drag Value item onto the Value data item box (keeping the modifier as Sum). This will display the
sum of the Value for each Tally item. To the left of the Value(Sum) data item box, click on the icon and change the Series type to Point.
488 / 815
Drag the Time item to the Argument data item box and change the modifier to be Date-Hour-Minute. This will define the X-axis as a time line.
Make sure the arrow next to the Time data item is pointing up so that the chart will show the correct order of the time line.
Drag the DataSource item to Series data item box. This identifies the Tallies that are to be charted. Right click in the C hart box and select Edit
Names to change the name from C hart 1 to Values Over Time.
489 / 815
Now click on Range Filter in the Dashboard ribbon. This will allow you to apply filtering to the to the dashboard items.
Drag the Value item over the Value data item box, keeping the Sum modifier. Drag the Time item over the Argument data item box, changing the
modifier to Date-Hour-Minute. By identifying the Argument as Time, you will be able to filter the other items with the dashboard bases on the time
range. Drag the DataSource item to the Series data item box.
Each window within the DashboardDesignerForm window can be resized and moved. Below is an example of what can be shown.
490 / 815
Select Save from the dashboard ribbon and close the DashboardDesignerForm window. To view a specific dashboard report, select it from the
Select pull down list.
You may also want to try to use the selection thumbs on the range filter to see how the dashboard changes. Also, try using the grid item instead
of the cards to display the same results in grid fashion.
Example 2 – How to create a dashboard report with a tables
Problem – In the SchedulingDiscretePartProduction model, I want to be able to graphically display material usage over time as well as the
resource states of the operator, forklift and workstations as a percentage of model duration.
Load the SchedulingDiscretePartProduction SIMIO Project File located in your Examples folder. In the Facility window, under the Run Ribbon,
under Advanced Options, make sure Enable Interactive Logging is turned on. This will ensure that log file data will be captured.
Fast forward the model to completion. Once the model run has ended, open the Results window and then select the Dashboard Reports view.
491 / 815
C lick Dashboard Report C reate in the upper left corner of the window and select a dashboard name (ex: Materials). This will bring up the
DashboardDesignerForm window.
From the dropdown list in the upper left corner, select Material Usage Log. That is the log file we will use to populate the dashboard.
From the Dashboard ribbon click on C ards. C ards are used to display the differences between values.
On the left side of the window, under Material Usage Log, select the Quantity item and drag it onto the Actual data item box. This is the value that
will be displayed on each card. This will cause the sum of all Material Quantities in the log for each data source item to be displayed on each card.
Now drag the Material item onto the Series data item box. This will create a card for each Material item in the Material Usage Log and label each
card with the name of the Material item. Each C ard will display the Sum of all Material Quantities.
492 / 815
* Note: You may 'hide' the large number shown on the C ards (in this case, Quantity(Sum))by toggling the Hide Card Numbers option under the
Edit menu for the report.
Right click in the C ard box and select Edit Names. C hange the name from C hart 1 to Materials. You should see something that looks like this.
On the Dashboard ribbon and select C hart. Drag the StockLevel item onto the Value data item box (keeping the modifier as Sum). This defines
the data item, in this case StockLevel, to chart. To the left of the StockLevel(Sum) data item box, change the Series type to Step Line.
493 / 815
Drag the Time item to the Argument data item box and change the modifier to be Date-Hour-Minute. This will define the X-axis as a time line.
Make sure the arrow next to the Time data item is pointing up so that the chart will show the correct order of the time line
Drag the Material item to Series data item box. This defines the Materials types that will be charted. Right click in the C hart box and select Edit
Names to change the name from C hart 1 to Stock Level.
C lick the title bar of the Stock Level chart and move it below the Material cards. Save the dashboard. You should see something that looks like
this.
You may also want to try adding a Range Filter to the dashboard to allow you to display the data in a shorter time span.
Let’s create another dashboard. Name this one Pick Ups. Make sure Transporter Usage Log appears from the pull down list on the left side of the
window.
On the Dashboard ribbon click on Grid. Drag the Resource item onto the first C olumn data item box, followed by Start Time (Date-Hour-Minute),
From Node, End Time(Date-Hour-Minute), To Node and Entity. This identifies the columns that will be displayed on the grid and their corresponding
values.
494 / 815
C hange the grid name to Pick Ups. You should have something that looks like this.
C hange the log file on the left side to me Resource State Log. From the Dashboard ribbon click on Pies.
On the left side of the window, under Resource State Log, select the Duration item and drag it onto the Actual data item box. This is the value that
will be displayed within each pie.
Drag the State item onto the Argument data item box. This identifies for each State, the Duration in that State will be displayed.
Drag the Resource item onto the Series data item. This will create a pie in the dashboard for each Resource item.
Right click in the Pie window and select Edit Names. C hange the name from Pie 1 to Resource States. You should see something that looks like
this.
495 / 815
You may also want to try using the Resource State Log and create a pivot grade to display the actual values of the states and not just a
percentage of the whole.
496 / 815
Simio Reference Guide
T able R eports
The Table Reports window provides access to the Report Designer for creating reports using the data within the various Data Tables in Simio. All
user licensing allows for access to previously developed table reports (Select pull-down list), however, the create Table Report button, as
displayed below, is only available to Enterprise users.
497 / 815
Simio Reference Guide
Logs
Logs
The Logs window includes detailed logs for the interactive run displayed in multiple tabbed windows.
For all Simio license types, this includes the State Observation Log and Tally Observation Log.
For Simio Enterprise Edition customers, this also includes the Resource Usage Log, Resource State Log, Resource C apacity Log, C onstraint Log,
Transporter Usage Log, Material Usage Log and Task Log.
498 / 815
Simio Reference Guide
State O bservation Log
The State Observation Log displays the log of values over time of State Statistic elements which had Log Observations set to 'True'. There are
twelve automatic columns that are provided with the log. Depending upon the type of state variable that is being tracked, data will appear in
either the Value/Units, Rate/Units or Acceleration/Units fields. These include:
Time - The simulation date and time that the state change occurred.
Object Type - The type of object that includes the state statistic, which may be Model or another object.
Object Name - The name of the object within the model that includes the state statistic.
Data Source - The name of the state statistic being tracked or optional data source string as specified within state statistic element.
Category - The category string value as specified in the state statistic element, which is UserSpecified by default.
Data Item - The data item string value as specified in the state statistic element, which is StateValue by default.
Value - The value of the state variable at the time specified.
Units - The time units for the Value indicated.
Rate - The rate for the level continuous-change state variable.
Units - The time units for the Rate indicated.
Acceleration - The acceleration for the level with acceleration continuous-change state variable.
Units - The time units for the Acceleration indicated.
499 / 815
Simio Reference Guide
T ally O bservation Log
The Tally Observation Log displays the log of values over time of Tally Statistic elements which had Log Observations set to 'True'. There are eight
automatic columns that are provided with the log including:
Time - The simulation date and time that a tally statistic observation was added.
Object Type - The type of object that includes the tally statistic, which may be Model or another object.
Object Name - The name of the object within the model that includes the tally statistic.
Data Source - The name of the tally statistic being tracked or optional data source string as specified within tally statistic element.
Category - The category string value as specified in the tally statistic element, which is UserSpecified by default.
Data Item - The data item string value as specified in the tally statistic element, which is TallyValue by default.
Value - The value of the tally statistic observation at the time specified.
Units - The time units for the Value indicated.
500 / 815
Simio Reference Guide
Interactive And Experiment R esults
501 / 815
Simio Reference Guide
Exporting
Exporting
Results data can be exported to a .csv file by clicking the Export Results icon in the ribbon menu when viewing the Pivot Grid. If an experiment
was run with more than one replication, the user has a choice of exporting the details or the summary. The detailed export will include data from
all the replications. The summary export will only include the summary across all the replications.
502 / 815
Simio Reference Guide
Standard O bject Library
Most library objects such as Entities, Sources, Sinks, and Servers have a Size property. This provides the relationship between animated size and
the physical size in the model (when needed). Nodes are an exception and do not have any physical space in the model. There is no travel time
required to pass through a node (although time could be required to execute any logic specified in a node).
In the Standard Library, the processing time delays for the Server, C ombiner, and Separator objects are now marked as interruptible. The
process in these objects performing the processing delay activity is named 'OnEnteredProcessing'. Thus, to interrupt processing activity at a
Server, C ombiner, or Separator, you may now use the Interrupt step to interrupt the 'OnEnteredProcessing' process of the target object.
Right clicking on an object in the Standard Library allows the user to subclass it into their own Project Library.
To view all the Functions available for these Intelligent Objects, see the Functions help page.
503 / 815
Simio Reference Guide
BasicNode
A Basic node is a simple node to support connection between links. Most objects that support incoming connections have an associated
(embedded) basic node. Many times, Basic nodes are used as starting and/or ending points of links. They may also used as intersection points for
vehicle networks.
Because transporters commonly travel through nodes, the state assignments functionality provided by the BasicNode and TransferNode objects
make it easy for a user to distinguish between entity or transporter state assignments by providing an Assign If condition option. Note that these
available assign condition type choices (C ustom C ondition, Entity Entering, No C ondition, Transporter Entering) are also available within the tally
condition choices if defining a tally statistic using the node’s Tally Statistics -> On Entering repeat group.
The Add-On Process Triggers allow additional logic to be specified when using the Basic Node.
505 / 815
Simio Reference Guide
BasicNode - Discussion and Examples
-->
Discussion
Entity Destination
Automatic destination is to continue
From the basic node, the entity will simply continue down the appropriate path leaving this node, as determined by the rules mentioned
above. If a SetNode step was used in the Processes window, this entity is instead going to a specific node.
** If the entity's destination is not reacheable
If the entity's destination is not reachable because there is no physical link between the basic node and the destination node, the entity will
automatically destroyed. For example, if there are no paths from the node leading out or no path to the specific destination specified
(SetNode), the entity will be automatically destroyed. If the Warning Level is set to either Alert User or Write to Trace Only, then the user
will recieve a warning that this has occurred. In some cases, users may intend for this to occur, in which case, they may disable the
warnings.
506 / 815
Simio Reference Guide
T ransferNode
A Transfer Node is a more comprehensive node that supports connection to paths as well as the ability to select destination, path, and transfer
device. Most objects that support outgoing connections have an associated (embedded) transfer node.
Because transporters commonly travel through nodes, the state assignments functionality provided by the BasicNode and TransferNode objects
make it easy for a user to distinguish between entity or transporter state assignments by providing an Assign If condition option. Note that these
available assign condition type choices (C ustom C ondition, Entity Entering, No C ondition, Transporter Entering) are also available within the tally
condition choices if defining a tally statistic using the node’s Tally Statistics -> On Entering repeat group.
The Add-On Process Triggers allow additional logic to be specified when using the Transfer Node.
For more information, see Transfer Node - Discussion and Examples.
On Entering (State Repeat Group, Optional state assignments when an entity is entering the TransferNode object.
Assignments) Assignments
Assign If (State C ustom C ondition required to perform the assignment.
Assignments) C ondition,
Entity Entering,
No C ondition,
Transporter
Entering
C ondition (State Expression C ondition required to perform the assignment when Assign If is 'C ustom C ondition'.
Assignments)
State Variable Name State Name The name of the state that will be assigned a new value.
(State Assignments)
New Value (State Expression The new value to assign.
Assignments)
On Entering (Tally Repeat Group, Optional tally statistics to be calculated when an entity enters the node object.
Statistics) Tally Statistics
On Exited (Tally Repeat Group, Optional tally statistics to be calculated when an entity has exited the node object.
Statistics) Tally Statistics
Tally If (Tally C ustom The condition required to record the tally statistic.
Statistics) C ondition,
Entity Entering,
No C ondition,
Transporter
Entering
Tally Statistic Name TallyStatistic The tally statistic for which the value is to be recorded.
(Tally Statistics) Element Name
Value Type (Tally Expression, The type of value to record. The value type 'Expression' records the value of the specified expression.
Statistics) TimeBetween The value type 'TimeBetween' records the time between arrivals to Tally steps referencing the tally
statistic.
Value (Tally Statistics) Expression The expression value to be recorded.
Run Initialized Add-On Process Occurs when the simulation run is initialized.
Process Instance Name
508 / 815
Run Ending Add-On Process Occurs when the simulation run is ending.
Process Instance Name
Entered Add-On Process Occurs when a travelling Entity or Transporter's leading edge has entered this node's crossing point.
Process Instance Name
Exited Add-On Process Process Occurs when a travelling Entity or Transporter has exited this node's crossing point.
Instance Name
Sequence Expected Expression The expression used to estimate an expected operation time if this node is in the destination sequence
Operation Time of an entity's assigned sequence table.
Branching Random Expression The random number stream to be used if the entity is transferring from the node to an outbound link
Number Stream and is probabilistically selecting the outbound link using the node's 'By Link Weight' outbound link rule.
Bound External Output Node Instance The name of an external output node that this node has been bound to in order to transfer entities out of
Node Name the parent object. The transfer attempt will be performed by an entity immediately upon entering the
node and, if successful, all other entry, crossing and routing logic for the node will be ignored.
Report Statistics True or False A Boolean property may be True or False and used in expressions as a numeric 1.0 (True) or 0.0 (False)
value.
509 / 815
Simio Reference Guide
T ransferNode - Discussion and Examples
Discussion
511 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
512 / 815
Simio Reference Guide
Source
A Source is an object that allows the creation of entities at a specified rate, by a specified arrival pattern, on the firing of an event. The Source
has an Output Buffer where entities can wait before leaving the Source via a Node. This buffer can have a fixed capacity so that entities will balk
if the capacity is full. From the output node the entities leave on the outgoing link(s) to wherever the designed logic is going to send them.
State assignments can be made upon exiting the Source. The Add-On Process Triggers allow additional logic to be specified when using the
Source.
For more information, see Source - Discussion and Examples.
514 / 815
Simio Reference Guide
Source - Discussion and Examples
Discussion
515 / 815
If Balk Node Name is 'None (Destroy Entity)'
A ‘NumberBalked’ total will be reported by the OutputBuffer station under Throughput (along with 'NumberEntered' and 'NumberExited').
Since the balked entities were automatically destroyed at the Source, those destroyed entities will not be recorded as observations in the
population ‘TimeInSystem’ and ‘C ostPerItem’ tallies for the entity type.
If Balk Node Name is a Specific Node Name
A ‘NumberBalked’ total will be reported by the OutputBuffer station under Throughput (along with 'NumberEntered' and 'NumberExited').
Because the balked entities were sent to another node, where they may continue in processing, the balked entities will be recorded as
observations in the population ‘TimeInSystem’ and ‘C ostPerItem’ tallies for the entity type.
516 / 815
Simio Reference Guide
Sink
The Sink destroys entities. It also has the capability to collect automatic statistics.
The ‘TimeInSystem’ TallyStatistic generated by this object has its C onfidence Level property specified as ‘Default’. The user may change the
C onfidence Level used by the Sink's tally by simply changing the C onfidence Level in the Experiment.
State assignments can be made upon entering the Sink. The Add-On Process Triggers allow additional logic to be specified when using the Sink.
Listed below are the properties of the Sink: Indicates whether the time in system observations on entities destroyed by this Sink are to be
automatically logged. Go to Results > Logs > Tally Observation Log to view the logged data.
Property Valid Entry Description
TransferIn Expression The time required to transfer an entity into this Sink object. This property may be specified using a random sample
Time from a distribution.
On Entering Repeat Optional state assignments when an entity is entering the Sink object.
(state Group,
assignment) Assignments
Parent C ost C ost C enter The cost center that costs allocated to this object are rolled up into. If a parent cost center is not explicitly
C enter Name specified, then costs will be automatically rolled up into the parent object containing this object.
C apital C ost Expression The initial one-time setup cost to add this object to the system.
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Input Buffer
C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Input
Buffer C osts)
Run Initialized Process Occurs when the simulation run is initialized.
Add-On Instance
Process Name
Run Ending Process Occurs when the simulation run is ending.
Add-On Instance
Process Name
Entered Add- Process Occurs when an entity has entered this Sink object.
On Process Instance
Name
Destroying Process Occurs when an entity is about to be destroyed by this Sink object.
Entity Add-On Instance
Process Name
Transfer-In Disable, Indicates the type of constraints used to determine whether entities can transfer into this fixed object via external
C onstraints Default, input nodes. If specified as 'Default', then the Can Transfer In & Out of Objects property setting for the entity type
C ustom will determine whether an entity can perform a transfer into the object.
C ondition
Transfer-In Expression The condition required to allow an entity to transfer into this fixed object via an external input node.
C ondition
Log Time In True, False
System
Observations
Report True or False A Boolean property may be True or False and used in expressions as a numeric 1.0 (True) or 0.0 (False) value.
Statistics
Report Gantt True or False A Boolean property may be True or False and used in expressions as a numeric 1.0 (True) or 0.0 (False) value.
517 / 815
Simio Reference Guide
Server
In Simio, a Server represents a capacitated resource with optional constrained input and output buffers.
A Server is an object that contains three capacitated stations with associated queues. The three stations that make up a standard Server are the
InputBuffer, Processing and OutputBuffer stations. When a Server is used in a model,it appears as though an entity enters the Server, is
processed and then leaves the Server. A more detailed explanation of what happens to the entity is that when it first enters the Server, it enters
the InputBuffer station, if the InputBuffer property is greater than 0. It waits here until there is available capacity in the Processing station. The
capacity of this station is controlled by the Initial Capacity property of the Server. Once it has been processed, it moves into the OutputBuffer
station, if the OutputBuffer is set greater than 0 and it waits until it can leave the Server. The three green queue lines that are placed in the
Facility window with the Server, animate the entity while it is in each of these three stations. The three station approach allows for the capability to
have both infinite and finite capacity queues.
Standard Server placed in Facility Window
The logic that is being performed once the entity enters the Server object spawns what is called a Token. A Token is a completely different object
than an entity. It is used to trigger logical events in the Processes Window of the model.
Within the Processing station of the Server, the Process Type may be a 'Specific Time' or based on a 'Task Sequence'. The default 'Specific Time'
will delay the entity at the processing station of the Server for the simple Processing Time specified. The 'Task Sequence' option will require a
number of Processing Tasks and associated information to be specified. This is explained in greater detail within the Task Sequence - Processing
Tasks section.
A Server may have failures, which are specified within the Reliability section of the Properties window. State assignments can be made upon
entering and exiting the Server. Secondary Resources may be seized and/or released by the entity upon entering the Server, and before and
after processing occurs. The Add-On Process Triggers allow additional logic to be specified when using the Server.
An entity processing at a Server may be interrupted with the Interrupt step. The Processing Time delay is the only interruptible delay within the
Server.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the Server.
For more information, see Server - Discussion and Examples.
Listed below are the properties of the Server:
Property Valid Entry Description
C apacity Type Fixed, Work Schedule The method used to specify the capacity of this Server object.
Initial C apacity Expression The initial fixed capacity of this Server object.
Work Schedule Work Schedule Name The capacity work schedule that this Server object follows.
Work Day Repeat Group, Work Day Work Day schedule exceptions specific to this resource.
Exceptions Exceptions
Work Period Repeat Group, Work Period Work Period schedule exceptions specific to this resource.
Exceptions Exceptions
Ranking Rule First In First Out, Last In First The static ranking rule used to order entities waiting to be allocated capacity of this Server
Out, Smallest Value First, object.
Largest Value First
Ranking Expression The expression used with a Smallest Value First or Largest Value First ranking rule.
Expression
Dynamic None, or one of several Indicates whether this object, when its capacity becomes available, dynamically selects the
Selection Rule Dynamic Selection Rules next allocation request from its statically ranked allocation queue using a dynamic selection
rule.
TransferIn Time Expression The time required to transfer an entity into this Server object. This property may be
specified using a random sample from a distribution.
Process Type Speific Time, Task Sequence The method used to model the processing of an entity at this Server object.
Processing Time Expression The time required for this Server object to process each entity. This property may be
specified using a random sample from a distribution.
Processing Tasks Repeat Group, Tasks The set of tasks required for this Server object to process an entity.
Off-Shift Rule Suspend Processing, Finish The processing rule used at the Server at the end of a shift.
Work Already Started
If the rule is 'Suspend Processing', then the Server will immediately suspend all processing
and set its resource state to 'OffShift'. Processing will resume at the start of the next shift.
If the rule is 'Finish Work Already Started', then the Server will not accept any new entities
but will continue processing if necessary to finish work already started. The Server's
resource state will be set to 'OffShiftProcessing' if processing entities during an off-shift
period.
Task Precedence SequenceNumberMethod, The method used to define the task precedence dependencies. C an be either by specifying
Method ImmediatePredecessorsMethod, task sequence numbers, specifying the immediate predecessors for each task, or specifying
518 / 815
ImmediateSuccessorsMethod the immediate successors for each task.
Task Resource Table Name Optional name of data table to be used as the referenced data source for getting task
Referenced Table resource requirements.
Name
Task Materials Table Name Optional name of data table to be used as the referenced data source for getting task
Referenced Table material requirements.
Name
Branching Expression The random number stream to be used if there is probabilistic branching in the task
Random Number sequence.
Stream
Input Buffer Integer >= 0 The number of entities that can be held in this Server object's input buffer.
C apacity
Output Buffer Integer >=0 The number of entities that can be held in this Server object's output buffer.
C apacity
Failure Type No Failures, C alendar Time Specifies whether this Server object has failures that affect the object's availability, and the
Based, Processing C ount method used to trigger the failure occurrences. See the Reliability page for additional
Based, Event C ount Based, information on Failures.
Processing Time Based
Event Name Event Instance Name The name of the event which determines when the next failure occurs.
Uptime Between Expression The uptime between failure occurrences. This property may be specified using a random
Failures sample form a distribution.
C ount Between Expression The count between failure occurrences. This property may be specified using a random
Failures sample from a distribution.
Time To Repair Expression The time required to repair a failure when one occurs. This property may be specified using
a random sample from a distribution.
On Entering Repeat Group, Assignments Optional state assignments when an entity is entering the Server object.
(State
Assignments)
Before Exiting Repeat Group, Assignments Optional state assignments when an entity is ready to exit the Server object.
(State
Assignments)
Object Type Specific, From List, The method for specifying the object to be seized and held for the Server's processing time.
(Secondary ParentObject
Resource for
Processing)
Object Name Object Instance Name The name of the object to be seized.
(Secondary
Resource for
Processing)
Object List Name Object List Instance Name The name of the object list from which an object will be selected to be seized.
(Secondary
Resource for
Processing)
Selection Goal Smallest Distance, Largest The goal for selecting objects to seize.
(Secondary Distance, Preferred Order,
Resource for Smallest Value, Largest Value,
Processing) Random
Selection Expression The expression evaluated for each object that is a candidate to seize. In the expression, use
Expression the keyword C andidate to reference an object in the collection of candidates to be seized
(Secondary (e.g., C andidate.Object.C apacity.Remaining).
Resource for
Processing)
Request Move None, To Node Indicates whether a move to a specified location will be requested from the seized resource.
(Secondary Processing will not be able to start until the resource has arrived to the requested location.
Resource for
Processing)
Destination Node Node Instance Name The name of the specific node location that the seized resource will be requested to move to.
(Secondary
Resource for
Processing)
Keep Reserved If Expression On processing completion, an optional condition indicating whether to keep the resource
(Secondary reserved for possible later reuse by the same entity. Other entities will be unable to use the
Resource for resource unless the reservation is cancelled.
Processing)
Note that when an entity is attempting to select a resource from a group of candidates (e.g.,
from a list or from a population of some resource type), by default a preference will be given
to select a resource that has already been reserved by that entity irrespective of the
specified selection goal.
Reservation Expression If the Keep Reserved Condition is true, then an optional wait time before automatically
Timeout cancelling the reservation.
(Secondary
Resource for
Processing)
On Entering Repeat Group, Resource Seizes Optional secondary resource seizes when an entity is entering the Server object.
(Other Resource
Seizes)
Before Repeat Group, Resource Seizes Optional secondary resource seizes once an entity has been allocated Server capacity, to be
Processing completed before starting the processing time.
(Other Resource
Seizes)
519 / 815
After Processing Repeat Group, Resource Seizes Optional secondary resource seizes after an entity has finished processing, to be completed
(Other Resource before releasing the Server capacity.
Seizes)
On Entering Repeat Group, Resource Optional secondary resource releases to be performed when an entity is entering the Server
(Other Resource Releases object.
Releases)
Before Repeat Group, Resource Optional secondary resource releases once an entity has been allocated Server capacity,
Processing Releases before starting the processing time.
(Other Resource
Releases)
After Processing Repeat Group, Resource Optional secondary resource releases after an entity has finished processing, before
(Other Resource Releases releasing the Server capacity.
Releases)
Parent C ost C ost C enter Name The cost center that costs allocated to this object are rolled up into. If a parent cost center is
C enter not explicitly specified, then costs will be automatically rolled up into the parent object
containing this object.
C apital C ost Expression The initial one-time setup cost to add this object to the system.
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Input Buffer
C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Input
Buffer C osts)
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Output Buffer
C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Output
Buffer C osts)
Idle C ost Rate Expression The cost per unit time charged, or accrued, to the cost of the server for each unutilized
(Resource C osts) scheduled capacity unit.
C ost Per Use Expression The one-time cost that is accrued each time the server is used, regardless of the usage
(Resource C osts) duration. This cost will be charged to the cost of the entity using the server.
Usage C ost Rate Expression The cost per unit time to use the server if in a utilized state. This cost will be charged to the
(Resource C osts) cost of the entity using the server.
Run Initialized Process Instance Name Occurs when the simulation run is initialized.
Add-On Process
Run Ending Add- Process Instance Name Occurs when the simulation run is ending.
On Process
Entered Add-On Process Instance Name Occurs when an entity has entered this server object.
Process
Before Process Instance Name Occurs when an entity has been allocated server capacity, but before entering (or ending
Processing Add- transfer into) the object's processing station.
On Process
Processing Add- Process Instance Name Occurs when an entity has been allocated server capacity and is about to start processing.
On Process
After Processing Process Instance Name Occurs when an entity has completed the processing time and is about to attempt its exit
Add-On Process from the server's processing station in order to release the server capacity.
Exited Add-On Process Instance Name Occurs when an entity has exited this server object.
Process
Failed Add-On Process Instance Name Occurs when this object has failed.
Process
Repaired Add-On Process Instance Name Occurs when a failure is repaired at this object.
Process
Evaluating Seize Process Instance Name Occurs when this Server object is evaluating whether to accept or reject a request to seize
Request Add-On capacity of the server. In the executed decision process, assigning a value of less than or
Process Triggers equal to '0' to the executing token's ReturnValue state (Token.ReturnValue) indicates that the
seize request is rejected.
On Shift Add-On Process Instance Name Occurs when the object goes 'on shift' because of its specified work schedule.
Process
Off Shift Add-On Process Instance Name Occurs when the object goes 'off shift' because of its specified work schedule.
Process
Transfer-In Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer into this
C onstraints C ondition fixed object via external input nodes. If specified as 'Default', then the Can Transfer In & Out
of Objects property setting for the entity type will determine whether an entity can perform a
transfer into the object.
Transfer-In Expression The condition required to allow an entity to transfer into this fixed object via an external
C ondition input node.
Transfer-Out Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer out of this
C onstraints C ondition fixed object via external output nodes. If specified as 'Default', then the Can Transfer In &
Out of Objects property setting for the entity type will determine whether an entity can
perform a transfer out of the object.
Transfer-Out Expression The condition required to allow an entity to transfer out of this fixed object via an external
C ondition output node.
Expected Setup Expression The expression used to estimate an expected setup time for an entity at this fixed object.
Time Expression
Expected Expression The expression used to estimate an expected operation time for an entity at this fixed
Operation Time object.
520 / 815
Operation Time object.
Expression
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go
Usage to Results -> Logs to view logged data.
Display C ategory String Optional text used for hierarchically arranging resources in the Resource Plan window. Use
backslashes for multiple levels (e.g., One\Two\Three).
Display C olor C olor A color to be used when showing this object in various windows (currently only Gantt
windows in Simio Enterprise and Simio Scheduling Editions). If not specified, then this
property defaults to a color derived from the object's unique name.
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
521 / 815
Simio Reference Guide
Server - Discussion and Examples
Discussion
Server that has no Buffers (i.e. InputBuffer and OutputBuffer properites set to 0)
When a user sets the InputBuffer property to 0, it sets this Server object to have no space for buffering inside the object. In other words,
if an entity arrives to the Srever and there is no available capacity of the main Processing station, the entity must wait outside of the
Server until the capacity of the Server becomes available. If the entity is entering the Server via an incoming link, the entity will wait on
the link.
Similarly, if the OutputBuffer property is set to 0, the entity must have an available physical location to move into before it can leave the
Server. For example, if the entity must ride on a Transporter after it leaves the Server and the Transporter is not available at the time, the
entity will wait in the Processing station of the Server until the Transporter arrives at the output node to pick up the entity.
522 / 815
Simio Reference Guide
R esource
A Resource is a static capacitated Fixed Object that can be seized. It does not move within the Facility window. If you would like a moveable
Resource, consider seizing capacity of a Vehicle or Worker object.
A resource's capacity can be fixed or controlled by a work schedule. A resource object may have a capacity of 0 to N and is considered 'OffShift'
if capacity = 0 or 'OnShift' if capacity > 0.
Resources can be grouped together in an object list so they can be seized as a group or selected from a list of possible resources based on a
selection criteria. A seize operation requires a negotiation between the objects involved. An object could refuse the seize request because he/she
has other activities to perform. Hence in Simio, objects allow or disallow themselves to be seized and released by other objects.
A Resource may have failures, which are specified within the Reliability section of the Properties window. The Add-On Process Triggers allow
additional logic to be specified when using the Resource.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the Resource.
For more information, see Resources - Discussion and Examples.
Listed below are the properties of the Resource:
Property Valid Entry Description
C apacity Type Fixed, WorkSchedule The method used to specify the capacity of this Resource object.
Initial Expression The initial capacity of this Resource object.
C apacity
Work WorkSchedule Name The capacity work schedule that this Resource object follows.
Schedule
Work Day Repeat Group, Work Day Work Day schedule exceptions specific to this resource.
Exceptions Exceptions
Work Period Repeat Group, Work Work Period schedule exceptions specific to this resource.
Exceptions Period Exceptions
Ranking Rule First In First Out, Last In The static ranking rule used to order entities waiting to be allocated capacity of this Resource object.
First Out, Smallest Value
First, Largest Value First
Ranking Expression The expression used with a Smallest Value First or Largest Value First ranking rule.
Expression
Dynamic None, or one of several Indicates whether this Resource object, when allocation of its capacity is performed, dynamically
Selection Rule Dynamic Selection Rules selects the next allocation request using an expression-based rule.
Failure Type No Failures, C alendar Specifies whether this Resource object has failures that affect the object's availability, and the
Time Based, Usage C ount method used to trigger the failure occurrences.
Based, Event C ount
Based, Usage Time Based
Event Name Event Instance Name The name of the event which determines when the next failure occurs.
Uptime Expression The uptime between failure occurrences. This property may be specified using a random sample form
Between a distribution.
Failures
C ount Expression The count between failure occurrences. This property may be specified using a random sample from
Between a distribution.
Failures
Time To Expression The time required to repair a failure when one occurs. This property may be specified using a random
Repair sample from a distribution.
Parent C ost C ost C enter Name The cost center that costs allocated to this object are rolled up into. If a parent cost center is not
C enter explicitly specified, then costs will be automatically rolled up into the parent object containing this
object.
C apital C ost Expression The initial one-time setup cost to add this object to the system.
Idle C ost Expression The cost per unit time charged, or accrued, to the cost of the resource for each unutilized scheduled
Rate(Resource capacity unit.
C osts)
C ost Per Expression The one-time cost that is accrued each time the resource is used, regardless of the usage duration.
Use(Resource This cost will be charged to the cost of the owner object using the resource.
C osts)
Usage C ost Expression The cost per capacity unit time to use the resource if in a utilized state. This cost will be charged to
Rate(Resource the cost of the owner object using the resource.
C osts)
Run Initialized Process Instance Name Occurs when the simulation run is initialized.
Add-On
Process
Triggers
Run Ending Process Instance Name Occurs when the simulation run is ending.
Add-On
Process
Allocated Add- Process Instance Name Occurs when this Resource object has had capacity allocated to another object.
On Process
Triggers
Released Add- Process Instance Name Occurs when this Resource object has had capacity released by another object.
On Process
Triggers
Failed Add-On Process Instance Name Occurs when this object has failed.
Process
Triggers
523 / 815
Repaired Add- Process Instance Name Occurs when a failure is repaired at this object.
On Process
Triggers
Evaluating Process Instance Name Occurs when this Resource is evaluating whether to accept or reject a capacity allocation attempt. In
Seize Request the executed decision process, assigning a value of less than or equal to '0' to the executing token's
Add-On ReturnValue state (Token.ReturnValue) indicates that the allocation attempt is rejected. The Token
Process that executes this process is associated with the C andidate object.
Triggers
On Shift Add- Process Instance Name Occurs when the object goes 'on shift' because of its specified work schedule.
On Process
Triggers
Off Shift Add- Process Instance Name Occurs when the object goes 'off shift' because of its specified work schedule.
On Process
Triggers
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go to
Usage Results -> Logs to view logged data.
Display String Optional text used for hierarchically arranging resources in the Resource Plan window. Use
C ategory backslashes for multiple levels (e.g., One\Two\Three).
Display C olor C olor A color to be used when showing this object in various windows (currently only Gantt windows in
Simio Enterprise and Simio Scheduling Editions). If not specified, then this property defaults to a color
derived from the object's unique name.
Report True or False A Boolean property may be True or False and used in expressions as a numeric 1.0 (True) or 0.0
Statistics (False) value.
For additional information on Resources, see the help topic Resources - Discussion and Examples.
524 / 815
Simio Reference Guide
R esources - Discussion and Examples
Discussion
525 / 815
This Resource Object from the standard object library will have a changing capacity that is based on a work schedule named Schedule1. The
details of this work schedule could be found in the Schedules Panel within the Data Window of this model. This Resource Object will also
dynamically select from its internal resource allocation queue using the expression ModelEntity.Priority. It will select the entity with the smallest
value for ModelEntity.Priority to be allocated capacity next.
526 / 815
Simio Reference Guide
C ombiner
A Combiner represents a capacitated resource with two input buffers and one output buffer.
The C ombiner object contains four capacitated stations with associated queues; one station for the parent input buffer, one for the member input
buffer, the processing station and the output buffer station. The four station approach allows for the capability to have both infinite and finite
capacity queues.
An entity arrives at the parent input node of the C ombiner. This station has a queue and a capacity. Entities also arrive to the member input node
which has its own queue and capacity. The entities wait in these queues until they batch together according to the logic specified in the properties
of the C ombiner. The quantity of the batch can be specified by an expression (i.e. a variable or a random distribution). The Matching Rule
property specifies if the entities should meet a certain criteria before they can be batched together. If there is a criteria, the Member Match
Expression and the Parent Match Expression is where the criteria is specified. For the Matching Rule of 'Match Members' and 'Match Members and
Parent', the match will occur on the first match encountered by any waiting entities, not just when the first waiting entity has a match. Therefore,
entities are not necessarily matched based on their order of arrival.
The transfer-in times for the parent and member entities run concurrently. For example, if a Parent Transfer-In Time is '1' minute and a Member
Transfer-In Time is '2' minutes, they will be ready to match (given matching requirements) after 2 minutes if they arrive at the C ombiner at the
same time.
The C ombiner does not only batch entities together, it also has process logic and capacity logic similar to a Server Object. If the entity is be
processed by the C ombiner, it then appears at the process station's queue. After the logic of the process has completed, if there is space the
entity will be moved to the output member queue.
Within the Processing station of the C ombiner, the Process Type may be a 'Specific Time' or based on a 'Task Sequence'. The default 'Specific
Time' will delay the entity at the processing station of the C ombiner for the simple Processing Time specified. The 'Task Sequence' option will
require a number of Processing Tasks and associated information to be specified. This is explained in greater detail within the Task Sequence -
Processing Tasks section.
A C ombiner may have failures, which are specified within the Reliability section of the Properties window. State assignments can be made upon
entering and exiting the C ombiner. Secondary Resources may be seized and/or released upon the parent entity entering the C ombiner, and
before and after processing occurs. The Add-On Process Triggers allow additional logic to be specified when using the C ombiner.
An entity processing at a C ombiner may be interrupted with the Interrupt step. The Processing Time delay is the only interruptible delay within
the C ombiner.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the C ombiner.
For SimBits using the C ombiner object, please review C ombineThenSeparate, C ustomUnbatching and C ombineMatchingMembers.
Listed below are the properties of the Combiner:
Property Valid Entry Description
Batch Quantity Expression truncated to integer Expression evaluated for each parent entity when it enters the C ombiner. Determines the
number of member entities that will be attached (assembled) to the parent entity.
Matching Rule Any Entity, Match Members, Determines how member entities and parent entities are grouped. 'Any Entity' indicates that the
Match Members And Parent first members of the specified batch quantity will be taken and attached to the first parent.
'Match Members' indicates that members must be matched together using a specified
expression . 'Match Members And Parent' indicates that parents must also be matched with
members to attach a group to a parent.
Member Match Expression The expression whose value must be the same among all member entities in order to create a
Expression group.
Parent Match Expression The expression for the parent entity whose value must be the same as the match expression
Expression for the group members in order to attach the group to the parent.
Parent First In First Out, Last In First The rule used to rank the order of entities in this C ombiner object's parent input buffer.
Ranking Rule Out, Smallest Value First,
Largest Value First
Parent Expression The expression used with a Smallest Value First or Largest Value First ranking rule.
Ranking
Expression
Member First In First Out, Last In First The rule used to rank the order of entities in this C ombiner object's member input buffer.
Ranking Rule Out, Smallest Value First,
Largest Value First
Member Expression The expression used with a Smallest Value First or Largest Value First ranking rule.
Ranking
Expression
C apacity Type Fixed, Work Schedule The method used to specify the number of batching operations that this C ombiner object can
simultaneously process.
Initial Expression The initial capacity of this C ombiner object.
C apacity
Work WorkSchedule name The capacity work schedule that this C ombiner object follows.
Schedule
Work Day Repeat Group, Work Day Work Day schedule exceptions specific to this resource.
Exceptions Exceptions
Work Period Repeat Group, Work Period Work Period schedule exceptions specific to this resource.
Exceptions Exceptions
Parent Expression The time required to transfer a parent entity into this C ombiner object. This property may be
TransferIn specified using a random sample from a distribution.
Time
Member Expression The time required to transfer a member entity into this C ombiner object. This property may be
TransferIn specified using a random sample from a distribution.
Time
Process Type Speific Time, Task Sequence The method used to model the processing of an entity at this C ombiner object.
Processing Expression The time required for this C ombiner object to process each entity. This property may be
Time specified using a random sample from a distribution.
527 / 815
Time specified using a random sample from a distribution.
Processing Repeat Group, Tasks The set of tasks required for this C ombiner object to process an entity.
Tasks
Off-Shift Rule Suspend Processing, Finish The processing rule used at the C ombiner at the end of a shift.
Work Already Started
If the rule is 'Suspend Processing', then the C ombiner will immediately suspend all processing
and set its resource state to 'OffShift'. Processing will resume at the start of the next shift.
If the rule is 'Finish Work Already Started', then the C ombiner will not accept any new entities
but will continue processing if necessary to finish work already started. The C ombiner's
resource state will be set to 'OffShiftProcessing' if processing entities during an off-shift period.
Task SequenceNumberMethod, The method used to define the task precedence dependencies. C an be either by specifying task
Precedence ImmediatePredecessorsMethod, sequence numbers, specifying the immediate predecessors for each task, or specifying the
Method ImmediateSuccessorsMethod immediate successors for each task.
Task Resource Table Name Optional name of data table to be used as the referenced data source for getting task resource
Referenced requirements.
Table Name
Task Materials Table Name Optional name of data table to be used as the referenced data source for getting task material
Referenced requirements.
Table Name
Branching Expression The random number stream to be used if there is probabilistic branching in the task sequence.
Random
Number
Stream
Parent Integer >= 1 The number of entities that can be held in this C ombiner object's parent input buffer.
InputBuffer
C apacity
Member Integer >= 1 The number of entities that can be held in this C ombiner object's member input buffer.
InputBuffer
C apacity
OutputBuffer Integer >= 0 The number of entities that can be held in this C ombiner object's output buffer.
C apacity
Failure Type No Failures, C alendar Time Specifies whether this C ombiner object has failures that affect the object's availability, and the
Based, Processing C ount method used to trigger the failure occurrences.
Based, Event C ount Based,
Processing Time Based
Event Name Event Instance Name The name of the event which determines when the next failure occurs.
Uptime Expression The uptime between failure occurrences. This property may be specified using a random
Between sample form a distribution.
Failures
C ount Expression The count between failure occurrences. This property may be specified using a random sample
Between from a distribution.
Failures
Time To Expression The time required to repair a failure when one occurs. This property may be specified using a
Repair random sample from a distribution.
On Parent Repeat Group, Assignments Optional state assignments when a parent entity is entering the C ombiner object.
Entering
(State
Assignment)
On Member Repeat Group, Assignments Optional state assignments when a member entity is entering the C ombiner object.
Entering
(State
Assignment)
Before Exiting Repeat Group, Assignments Optional state assignments when an entity is ready to exit the C ombiner object.
(State
Assignment)
Object Type Specific, From List, The method for specifying the object to be seized and held for the C ombiner's processing time.
(Secondary ParentObject
Resource for
Processing)
Object Name Object Instance Name The name of the object to be seized.
(Secondary
Resource for
Processing)
Object List Object List Instance Name The name of the object list from which an object will be selected to be seized.
Name
(Secondary
Resource for
Processing)
Selection Goal Smallest Distance, Largest The goal for selecting objects to seize.
(Secondary Distance, Preferred Order,
Resource for Smallest Value, Largest Value,
Processing) Random
Selection Expression The expression evaluated for each object that is a candidate to seize. In the expression, use
Expression the keyword C andidate to reference an object in the collection of candidates to be seized (e.g.,
(Secondary C andidate.Object.C apacity.Remaining).
Resource for
Processing)
Request Move None, To Node Indicates whether a move to a specified location will be requested from the seized resource.
(Secondary Processing will not be able to start until the resource has arrived to the requested location.
Resource for
528 / 815
Processing)
Destination Node Instance Name The name of the specific node location that the seized resource will be requested to move to.
Node
(Secondary
Resource for
Processing)
Keep Expression On processing completion, an optional condition indicating whether to keep the resource
Reserved If reserved for possible later reuse by the same entity. Other entities will be unable to use the
(Secondary resource unless the reservation is cancelled.
Resource for
Processing) Note that when an entity is attempting to select a resource from a group of candidates (e.g.,
from a list or from a population of some resource type), by default a preference will be given to
select a resource that has already been reserved by that entity irrespective of the specified
selection goal.
Reservation Expression If the Keep Reserved Condition is true, then an optional wait time before automatically
Timeout cancelling the reservation.
(Secondary
Resource for
Processing)
On Parent Repeat Group, Resource Seizes Optional secondary resource seizes when an entity is entering the parent input buffer of the
Entering C ombiner object.
(Other
Resource
Seizes)
Before Repeat Group, Resource Seizes Optional secondary resource seizes once a batch's parent entity has collected its batch
Processing members and been allocated C ombiner capacity, to be completed before starting the
(Other processing time.
Resource
Seizes)
After Repeat Group, Resource Seizes Optional secondary resource seizes after a batch's parent entity has finished processing, to be
Processing completed before releasing the C ombiner capacity.
(Other
Resource
Seizes)
On Parent Repeat Group, Resource Optional secondary resource releases to be performed when an entity is entering the parent
Entering Releases input buffer of the C ombiner object.
(Other
Resource
Releases)
Before Repeat Group, Resource Optional secondary resource releases once a batch's parent entity has collected its batch
Processing Releases members and been allocated C ombiner capacity, before starting the processing time.
(Other
Resource
Releases)
After Repeat Group, Resource Optional secondary resource releases after a batch's parent entity has finished processing,
Processing Releases before releasing the C ombiner capacity.
(Other
Resource
Releases)
Parent C ost C ost C enter Name The cost center that costs allocated to this object are rolled up into. If a parent cost center is
C enter not explicitly specified, then costs will be automatically rolled up into the parent object
containing this object.
C apital C ost Expression The initial one-time setup cost to add this object to the system.
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Parent Input
Buffer C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Parent
Input Buffer
C osts)
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Member
Input Buffer
C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Member
Input Buffer
C osts)
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Output Buffer
C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Output
Buffer C osts)
Idle C ost Expression The cost per unit time charged, or accrued, to the cost of the combiner for each unutilized
Rate(Resource scheduled capacity unit.
C osts)
C ost Per Expression The one-time cost that is accrued each time the combiner is used, regardless of the usage
Use(Resource duration. This cost will be charged to the cost of the entity using the combiner.
C osts)
Usage C ost Expression The cost per unit time to use the combiner if in a utilized state. This cost will be charged to the
Rate(Resource cost of the entity using the combiner.
529 / 815
C osts)
Run Initialized Process Instance Name Occurs when the simulation run is initialized.
Add-On
Process
Run Ending Process Instance Name Occurs when the simulation run is ending.
Add-On
Process
ParentEntered Process Instance Name Occurs when an entity has entered the parent input buffer of this combiner object.
Add-On
Process
Member Process Instance Name Occurs when an entity has entered the member input buffer of this combiner object.
Entered Add-
On Process
Before Process Instance Name Occurs when batch's parent entity has been allocated combiner capacity, but before entering
Processing (or ending transfer into) the object's processing station.
Add-On
Process
Processing Process Instance Name Occurs when a batch's parent entity has been allocated combiner capacity and is about to be
Add-On removed from the parent input buffer and start processing.
Process
After Process Instance Name Occurs when a batch's parent entity has completed the processing time and is about to attempt
Processing its exit from the combiner's processing station in order to release the combiner capacity.
Add-On
Process
Exited Add-On Process Instance Name Occurs when a batch's parent entity has exited this combiner object.
Process
Failed Add-On Process Instance Name Occurs when this object has failed.
Process
Repaired Add- Process Instance Name Occurs when a failure is repaired at this object.
On Process
Evaluating Process Instance Name Occurs when this C ombiner object is evaluating whether to accept or reject a request to seize
Seize Request capacity of the combiner. In the executed decision process, assigning a value of less than or
Add-On equal to '0' to the executing token's ReturnValue state (Token.ReturnValue) indicates that the
Process seize request is rejected.
Triggers
On Shift Add- Process Instance Name Occurs when the object goes 'on shift' because of its specified work schedule.
On Process
Off Shift Add- Process Instance Name Occurs when the object goes 'off shift' because of its specified work schedule.
On Process
Transfer-In Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer into this fixed
C onstraints C ondition object via external input nodes. If specified as 'Default', then the Can Transfer In & Out of
Objects property setting for the entity type will determine whether an entity can perform a
transfer into the object.
Transfer-In Expression The condition required to allow an entity to transfer into this fixed object via an external input
C ondition node.
Transfer-Out Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer out of this
C onstraints C ondition fixed object via external output nodes. If specified as 'Default', then the Can Transfer In & Out
of Objects property setting for the entity type will determine whether an entity can perform a
transfer out of the object.
Transfer-Out Expression The condition required to allow an entity to transfer out of this fixed object via an external
C ondition output node.
Expected Expression The expression used to estimate an expected setup time for an entity at this fixed object.
Setup Time
Expression
Expected Expression The expression used to estimate an expected operation time for an entity at this fixed object.
Operation
Time
Expression
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go to
Usage Results -> Logs to view logged data.
Display String Optional text used for hierarchically arranging resources in the Resource Plan window. Use
C ategory backslashes for multiple levels (e.g., One\Two\Three).
Display C olor C olor A color to be used when showing this object in various windows (currently only Gantt windows
in Simio Enterprise and Simio Scheduling Editions). If not specified, then this property defaults
to a color derived from the object's unique name.
Report True or False Specifies if statistics are to be automatically reported for this object.
Statistics
530 / 815
Simio Reference Guide
C ombiner - Discussion and Examples
Discussion
Batch Quantity
If the Batch Quantity is set to an integer value X, the C ombiner will wait until X members arrive to the member entry node before the
batch is processed. This Batch Quantity does not include the parent entity arriving to the parent entry node.
If the Batch Quantity is set to an expression based on the entity, for example 'ModelEntity.BatchSize', the parent entity's value for
'ModelEntity.BatchSize' is evaluated and not the member entity values. By using an entity property or state, the batch size that will be used
is based on the entity, and therefore can vary.
Matching Rule
If the Matching Rule is set to 'Any Entity', the C ombiner will use the Batch Quantity property to determine how many entities to batch
together and it will batch the first X entities that arrive to the C ombiner, where X is the number specified in Batch Quantity.
If the Matching Rule is set to 'Match Members', the C ombiner will only batch member entities together if the value of the Member Match
Expression is the same amongst all the member entities. If the Member Match Expression of an entity arriving to the member input buffer
does not match the other Member Match Expressions of the other entities watching to be batched, the entity will wait until enough other
entities arrive that provide a match for this value and the total number of matching entities equal the Batch Quantity.
If the Matching Rule is set to 'Match Members and Parent', the C ombiner will only batch member entities together if the value of the
Member Match Expression is the same amongst all the member entities and the parent entity. If the Member Match Expression of an entity
arriving to the member input buffer does not match the other Member Match Expressions of the other entities watching to be batched and
the parent entity waiting to be batched, the entity will wait until enough other entities arrive that provide a match for this value and the
total number of matching entities equal the Batch Quantity.
Hierarchical Batching
Since a parent represents the container that holds batch members, if a parent arrives with an existing batch (e.g. the container is partly
full) then the new batch will be added to the existing batch and the outgoing batch size of the parent will be the sum of the incoming batch
size plus the additional members added. If you desire to build hierarchical batches (e.g., items batch into boxes, then boxes batch into
pallets) it is important to remember that the batch items (boxes, in the example) must go into a combiner as members, with the container
(a pallet in the example) as the new parent.
531 / 815
This C ombiner Object from the standard object library will have a changing capacity that is based on a work schedule named TwentyMinBreak.
This C ombiner Object will batch entities that arrive to both its parent input node and member input node together, only if they have a matching
value for the state called ModelEntity.PartType. The C ombiner will batch 3 member entities together. It also has the Processing Time property set
to 5 minutes so after the entities are batched together, they will be delayed within this C ombiner object for 5 minutes before exiting through the
output node.
532 / 815
Simio Reference Guide
Separator
A Separator represents a capacitated resource with one input buffers and two output buffers.
The Separator object contains four capacitated stations with associated queues; one station for the input buffer, one for the processing station,
one for the parent output buffer and another station for the member output buffer. The four station approach allows for the capability to have both
infinite and finite capacity queues.
An entity arrives at the input node of the Separator. This station has a queue and a capacity. If the Separation Mode is set to 'Make C opies', the
Separator will create the number of entities that is specified in Copy Quantity. The copies may be specified as a different entity type by using the
Copy Entity Type property. The original entity will depart the Separator from the parent output node and the copies will depart from the member
output node. If the Separation Mode is set to 'Split Batch', the Separator will unbatch the specified number of entities from the parent entity. The
number is specified in Desired Split Quantity. The original entity, which is the parent entity, will depart from the parent node and the member
entities depart from the member output node. The Match Condition property may be used to unbatch only certain entities from the batch based on
a condition specified. For example, a Match Condition may be specified as 'C andidate.ModelEntity.Is.RedPart' where RedPart is the name of the
entity. When unbatched from the parent, only those entities of type RedPart will be unbatched and any other members of the batch (BluePart,
GreenPart, etc.) will remain with the batch. The Removal Order can be used to determine the order of searching for the Desired Split Quantity
number of members to unbatch.
The Separator does not only unbatch entities and make copies of entities, it also has process logic and capacity logic similar to a Server Object. If
the entity is be processed by the Separator, it appears at the process station's queue while its being processed and then performs the logic of
separating or copying entities. After the logic of the process has completed, if there is space the entity will be moved to the output member
queue.
Within the Processing station of the Separator, the Process Type may be a 'Specific Time' or based on a 'Task Sequence'. The default 'Specific
Time' will delay the entity at the processing station of the Separator for the simple Processing Time specified. The 'Task Sequence' option will
require a number of Processing Tasks and associated information to be specified. This is explained in greater detail within the Task Sequence -
Processing Tasks section.
A Separator may have failures, which are specified within the Reliability section of the Properties window. State assignments can be made upon
entering and exiting the Separator. Secondary Resources may be seized and/or released by the entity upon entering the Separator, and before
and after processing occurs. The Add-On Process Triggers allow additional logic to be specified when using the Separator.
An entity processing at a Separator may be interrupted with the Interrupt step. The Processing Time delay is the only interruptible delay within
the Separator.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the Separator.
For more information, see Separator - Discussion and Examples.
Listed below are the properties of the Separator:
Property Valid Entry Description
Separation Mode Split Batch, Make C opies The method for separating the incoming entity. If 'Split Batch' , then the Separator object will
split/unbatch the specified number of member entities from the parent entity. If 'Make
C opies', then the Separator object will make the specified number of copies of the original
incoming entity.
Desired Split Expression The desired number of batch members to split off (unbatch) from the parent entity.
Quantity
Removal Order LastBatchedFirst, The order in which to search for and split off batch members from the parent entity.
FirstBatchedFirst
Match C ondition Expression Optional match condition used to filter the batch member entities. Only members that match
the criteria given by the expression will be split off from the batch.
In the condition, use the keyword 'C andidate' to explicitly reference a candidate entity in the
batch members being searched (e.g., C andidate.Entity.Priority > 0).
C opy Quantity Expression The number of copies to make of the original incoming entity.
C opy Entity Type Entity Name The entity type of the created copies. If this property is not specified, then the same type as
the original incoming entity will be assumed.
C apacity Type Fixed, Work Schedule The method used to specify the number of batching operations that this Separator object can
simultaneously process.
Initial C apacity Expression The initial capacity of this Separator object.
Work Schedule WorkSchedule name The capacity work schedule that this Separator object follows.
Work Day Repeat Group, Work Day Work Day schedule exceptions specific to this resource.
Exceptions Exceptions
Work Period Repeat Group, Work Period Work Period schedule exceptions specific to this resource.
Exceptions Exceptions
Ranking Rule First In First Out, Last In First The static ranking rule used to order entities waiting to be allocated capacity of this
Out, Smallest Value First, Separator object.
Largest Value First
Ranking Expression The expression used with a Smallest Value First or Largest Value First ranking rule.
Expression
Dynamic None, or one of several Indicates whether this object, when its capacity becomes available, dynamically selects the
Selection Rule Dynamic Selection Rules next allocation request from its statically ranked allocation queue using a dynamic selection
rule.
TransferIn Time Expression The time required to transfer an entity into this Separator object. This property may be
specified using a random sample from a distribution.
Process Type Speific Time, Task Sequence The method used to model the processing of an entity at this Separator object.
Processing Time Expression The time required for this Separator object to process each entity. This property may be
specified using a random sample from a distribution.
Processing Tasks Repeat Group, Tasks The set of tasks required for this Separator object to process an entity.
Off-Shift Rule Suspend Processing, Finish The processing rule used at the Separator at the end of a shift.
Work Already Started
533 / 815
Work Already Started
If the rule is 'Suspend Processing', then the Separator will immediately suspend all
processing and set its resource state to 'OffShift'. Processing will resume at the start of the
next shift.
If the rule is 'Finish Work Already Started', then the Separator will not accept any new
entities but will continue processing if necessary to finish work already started. The
Separator's resource state will be set to 'OffShiftProcessing' if processing entities during an
off-shift period.
Task Precedence SequenceNumberMethod, The method used to define the task precedence dependencies. C an be either by specifying
Method ImmediatePredecessorsMethod, task sequence numbers, specifying the immediate predecessors for each task, or specifying
ImmediateSuccessorsMethod the immediate successors for each task.
Task Resource Table Name Optional name of data table to be used as the referenced data source for getting task
Referenced Table resource requirements.
Name
Task Materials Table Name Optional name of data table to be used as the referenced data source for getting task
Referenced Table material requirements.
Name
Branching Expression The random number stream to be used if there is probabilistic branching in the task
Random Number sequence.
Stream
Input Buffer Integer >= 0 The number of entities that can be held in this Separator object's input buffer.
C apacity
Parent Output Integer >= 0 The number of entities that can be held in this Separator object's parent output buffer.
Buffer C apacity
Failure Type No Failures, C alendar Time Specifies whether this Separator object has failures that affect the object's availability, and
Based, Event C ount Based, the method used to trigger the failure occurrences.
Event C ount Based, Processing
Time Based
Event Name Event Instance Name The name of the event which determines when the next failure occurs.
Uptime Between Expression The uptime between failure occurrences. This property may be specified using a random
Failures sample form a distribution.
C ount Between Expression The count between failure occurrences. This property may be specified using a random
Failures sample from a distribution.
Time To Repair Expression The time required to repair a failure when one occurs. This property may be specified using
a random sample from a distribution.
On Entering Repeat Group, Assignments Optional state assignments when an entity is entering the Separator object.
(State
Assignment)
Before Parent Repeat Group, Assignments Optional state assignments when a parent entity is ready to exit the Separator object.
Exiting (State
Assignment)
Before Member Repeat Group, Assignments Optional state assignments when a separated member entity is ready to exit the Separator
Exiting (State object.
Assignment)
Object Type Specific, From List, The method for specifying the object to be seized and held for the Separator's processing
(Secondary ParentObject time.
Resource for
Processing)
Object Name Object Instance Name The name of the object to be seized.
(Secondary
Resource for
Processing)
Object List Name Object List Instance Name The name of the object list from which an object will be selected to be seized.
(Secondary
Resource for
Processing)
Selection Goal Smallest Distance, Largest The goal for selecting objects to seize.
(Secondary Distance, Preferred Order,
Resource for Smallest Value, Largest Value,
Processing) Random
Selection Expression The expression evaluated for each object that is a candidate to seize. In the expression, use
Expression the keyword C andidate to reference an object in the collection of candidates to be seized
(Secondary (e.g., C andidate.Object.C apacity.Remaining).
Resource for
Processing)
Request Move None, To Node Indicates whether a move to a specified location will be requested from the seized resource.
(Secondary Processing will not be able to start until the resource has arrived to the requested location.
Resource for
Processing)
Destination Node Node Instance Name The name of the specific node location that the seized resource will be requested to move to.
(Secondary
Resource for
Processing)
Keep Reserved If Expression On processing completion, an optional condition indicating whether to keep the resource
(Secondary reserved for possible later reuse by the same entity. Other entities will be unable to use the
Resource for resource unless the reservation is cancelled.
Processing)
Note that when an entity is attempting to select a resource from a group of candidates (e.g.,
from a list or from a population of some resource type), by default a preference will be
given to select a resource that has already been reserved by that entity irrespective of the
specified selection goal.
534 / 815
Reservation Expression If the Keep Reserved Condition is true, then an optional wait time before automatically
Timeout cancelling the reservation.
(Secondary
Resource for
Processing)
On Parent Repeat Group, Resource Seizes Optional secondary resource seizes when an entity is entering the Separator object.
Entering (Other
Resource Seizes)
Before Repeat Group, Resource Seizes Optional secondary resource seizes once an entity has been allocated Separator capacity, to
Processing be completed before starting the processing time.
(Other Resource
Seizes)
After Processing Repeat Group, Resource Seizes Optional secondary resource seizes after an entity has finished processing, to be completed
(Other Resource before releasing the Separator capacity and then executing the separation logic.
Seizes)
On Parent Repeat Group, Resource Optional secondary resource releases to be performed when an entity is entering the
Entering (Other Releases Separator object.
Resource
Releases)
Before Repeat Group, Resource Optional secondary resource releases once an entity has been allocated Separator capacity,
Processing Releases before starting the processing time.
(Other Resource
Releases)
After Processing Repeat Group, Resource Optional secondary resource releases after an entity has finished processing, before
(Other Resource Releases releasing the Separator capacity and then executing the separation logic.
Releases)
Parent C ost C ost C enter Name The cost center that costs allocated to this object are rolled up into. If a parent cost center is
C enter not explicitly specified, then costs will be automatically rolled up into the parent object
containing this object.
C apital C ost Expression The initial one-time setup cost to add this object to the system.
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Parent Output
Buffer C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Parent
Output Buffer
C osts)
C ost Per Use Expression The cost to hold an entity in this buffer irrespective of the waiting time.
(Member Output
Buffer C osts)
Holding C ost Expression The cost per unit time to hold an entity in this buffer.
Rate (Member
Output Buffer
C osts)
Idle C ost Expression The cost per unit time charged, or accrued, to the cost of the separator for each unutilized
Rate(Resource scheduled capacity unit.
C osts)
C ost Per Expression The one-time cost that is accrued each time the separator is used, regardless of the usage
Use(Resource duration. This cost will be charged to the cost of the entity using the separator.
C osts)
Usage C ost Expression The cost per unit time to use the separator if in a utilized state. This cost will be charged to
Rate(Resource the cost of the entity using the separator.
C osts)
Run Initialized Process Instance Name Occurs when the simulation run is initialized.
Add-On Process
Run Ending Add- Process Instance Name Occurs when the simulation run is ending.
On Process
Entered Add-On Process Instance Name Occurs when an entity has entered the input buffer of this separator object.
Process
Before Process Instance Name Occurs when an entity has been allocated separator capacity, but before entering (or ending
Processing Add- transfer into) the object's processing station.
On Process
Processing Add- Process Instance Name Occurs when an entity has been allocated separator capacity and is about to start
On Process processing.
After Processing Process Instance Name Occurs when an entity has completed the processing time and is about to do the separation
Add-On Process logic, before attempting its exit from the separator's processing station in order to release
the separator capacity.
Parent Exited Process Instance Name Occurs when a parent entity has exited this separator object.
Add-On Process
Member Exited Process Instance Name Occurs when a separated member entity has exited this separator object.
Add-On Process
Failed Add-On Process Instance Name Occurs when this object has failed.
Process
Repaired Add-On Process Instance Name Occurs when a failure is repaired at this object.
Process
Evaluating Seize Process Instance Name Occurs when this Separator object is evaluating whether to accept or reject a request to
Request Add-On seize capacity of the separator. In the executed decision process, assigning a value of less
Process Triggers than or equal to '0' to the executing token's ReturnValue state (Token.ReturnValue) indicates
that the seize request is rejected.
535 / 815
OnShift Add-On Process Instance Name Occurs when the object goes 'on shift' because of its specified work schedule.
Process
OffShift Add-On Process Instance Name Occurs when the object goes 'off shift' because of its specified work schedule.
Process
Transfer-In Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer into this
C onstraints C ondition fixed object via external input nodes. If specified as 'Default', then the Can Transfer In &
Out of Objects property setting for the entity type will determine whether an entity can
perform a transfer into the object.
Transfer-In Expression The condition required to allow an entity to transfer into this fixed object via an external
C ondition input node.
Transfer-Out Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer out of this
C onstraints C ondition fixed object via external output nodes. If specified as 'Default', then the Can Transfer In &
Out of Objects property setting for the entity type will determine whether an entity can
perform a transfer out of the object.
Transfer-Out Expression The condition required to allow an entity to transfer out of this fixed object via an external
C ondition output node.
Expected Setup Expression The expression used to estimate an expected setup time for an entity at this fixed object.
Time Expression
Expected Expression The expression used to estimate an expected operation time for an entity at this fixed
Operation Time object.
Expression
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go
Usage to Results -> Logs to view logged data.
Display C ategory String Optional text used for hierarchically arranging resources in the Resource Plan window. Use
backslashes for multiple levels (e.g., One\Two\Three).
Display C olor C olor A color to be used when showing this object in various windows (currently only Gantt
windows in Simio Enterprise and Simio Scheduling Editions). If not specified, then this
property defaults to a color derived from the object's unique name.
Report Statistics True or False A Boolean property may be True or False and used in expressions as a numeric 1.0 (True) or
0.0 (False) value.
536 / 815
Simio Reference Guide
Separator - Discussion and Examples
Discussion
Separation Mode
If the Separation Mode is set to 'Split Batch', the Separator will use the Split Quantity property to determine how many entities to separate.
By default, Entity.BatchMembers is specified in the Split Quantity property because this holds the number of member entities in the batch if
the entity is a parent entity. However, any value can be specified in the Split Quantity property.
If the Separation Mode is set to 'Make C opies', the Separator will make X number of copies of the parent entity, where X is the quantity
specified in Copy Quantity. The original entity will depart through the parent output node and the new copies will depart through the
member output node. The copies may be specified as a different entity type than the original, by specifying a Copy Entity Type property. If
the entities are of a different type, the much information from the original entity is copied to the newly created entities. This includes all
table references assigned to the original, all the original object’s state values, and the original’s assigned network and destination. If the
original is following a sequence table, the current sequence table index is copied as well. Note that if the entity type of the copy is different
than the original’s type, then only the state values of common inherited object states can be copied. Also, the size state values will not be
copied and thus a copy of a different type will be sized according to the default size for that different type.
537 / 815
Simio Reference Guide
W orkStation
In Simio, a Workstation represents a capacitated resource with optional constrained input and output buffers.
A Workstation is modeled as a sequence of three Activities: Setup, Processing, and Teardown. The sequence of Activities is referred to as an
Operation. The Setup Time can be Specific, C hange-Dependent, or Sequence-Dependent. A Specific time can be a constant or be product/order
dependent by referencing a table. C hange/Sequence dependent times can be based on any characteristic of the product (e.g. size or color). The
entity that is processed through the workstation represents a production lot. The data for a production lot is typically held in data tables, and then
referenced by the entity. The next production lot to be processed can be selected based on both a static ranking and a dynamic selection process.
The workstation may have a fixed capacity, or follow a capacity schedule. However, take note that the standard Workstation object only
processes one job at a time. In other words, it has a fixed capacity of 1.
The Operation Quantity specifies the number of “items” in the production lot that is represented by each arriving entity. This value can be a
constant or be product/order dependent by referencing a table. The lot can be processed as a single production unit, or the lot can be broken into
a sequence of batches that are processed one at a time until the entire lot has been produced. For example a lot of 1000 units may be processed
in batches of 100 at a time. Note that a single setup and teardown activity is performed, but 10 separate batches of 100 are sequentially
processed through the processing activity.
Multiple materials or a bill of material may be required to start the processing of each batch. Additionally, multiple materials or a bill of material
may be produced at the end of each batch processing. A batch of produced material may also have a transfer time before it becomes available
by other workstations. These materials can be specified through the Materials repeating property editor. This makes it easy to model situations
involving intermediate transfer batching. Typically, a bill of materials is used for consumption and a material is produced, however Simio also
allows for a bill of materials to be produced, to model cases such as disassembly.
The Workstation object is considered to be a primary resource that is required during the entire operation: i.e. setup, the processing of all
batches, and teardown. In addition, any number of secondary resources may be required and held by each batch across one or more of the three
activities. Secondary resources can be specific resources or selected based on rules from a list of resources.
A production lot may have a maximum make span that limits when it can be started based on the availability of the primary resource. The
maximum make span may be a constant or order/product dependent by referencing a table. The make span check verifies that that the primary
resource is available to complete the operation within the maximum make span. For example a lot that has a maximum make span of 3 hours will
not start 2 hours before an off-shift period of 8 hours begins, because it’s make span would exceed its maximum value. However, the make span
check does not guarantee that material and/or secondary resources will be available at the needed times. Hence a production lot that passes the
make span check may still exceed it’s make span if delays in material/secondary resources occur.
A Workstation may have failures, which are specified within the Reliability section of the Properties window. State assignments can be made upon
entering and exiting the Workstation. The Add-On Process Triggers allow additional logic to be specified when using the Workstation.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the WorkStation.
For more information, see Workstation - Discussion and Examples.
Listed below are the properties of the Workstation:
Property Valid Entry Description
C apacity Type Fixed, Work The method used to specify the capacity of this Workstation object. The capacity is fixed at 1
Schedule and cannot be changed.
Work Schedule Work Schedule The capacity work schedule that this Workstation object follows. *Note* C urrently the GUI
Name allows a user to add a Work Schedule with capacity greater than 1 to a Workstation, however
because the standard Workstation object can only process one job at a time, if the schedule
has a capacity greater than 1, it is simply interpreted as 1 by the Workstation.
Work Day Exceptions Repeat Group, Work Day schedule exceptions specific to this resource.
Work Day
Exceptions
Work Period Exceptions Repeat Group, Work Period schedule exceptions specific to this resource.
Work Period
Exceptions
Ranking Rule First In First The static ranking rule used to order entities waiting to be allocated capacity of this
Out, Last In Workstation object.
First Out,
Smallest Value
First, Largest
Value First
Ranking Expression Expression The expression used with a Smallest Value First or Largest Value First ranking rule.
Dynamic Selection Rule None, or one of Indicates whether this Workstation object dynamically selects the next entity to work on when
several the workstation is ready to process another job, instead of only using the ranking rule to
Dynamic determine processing order.
Selection Rules
TransferIn Time Expression The time required to transfer an entity into this Workstation object. This property may be
specified using a random sample from a distribution.
Operation Quantity Expression The item quantity assumed for each operation performed at this Workstation. This property
may be used with Processing Batch Size property to perform an operation's processing
activity in a single batch or a set of sequential batches.
Setup Time Type Specific, The method used for specifying the setup time of an operation.
C hange
Dependent,
Sequence
Dependent
Setup Time Expression The setup time required at this Workstation object before processing an entity. This property
may be specified using a random sample from a distribution.
Operation Attribute Expression The expression evaluated for each operation that is used to determine the change-dependent
or sequence dependent setup time. Note that, for a sequence dependent time, the operation
attribute expression is evaluated as a zero-based index into the C hangeover Matrix string list
for which 'from-to' pairs are defined. For example, an operation attribute of '0' means that the
entity's comparison value is the first value in the changeover matrix string list. Referencing a
list property on the processing entity as the operation attribute is particularly useful for
modeling sequence-dependent setup times.
538 / 815
Setup Time If Same Expression The setup time if there has not been a change in the Operation Attribute from the previous
operation to the current opeartion. This property may be specified using a random sample
from a distribution.
Setup Time If Different Expression The setup time if there has been a change in the Operation Attribute from the previous
operation to the current opeartion. This property may be specified using a random sample
from a distribution.
C hangeOver Matrix C hangeover The changeover matrix that defines the operation's setup time dependent on the attribute
Matrix Instance change from the previous operation to the current operation.
Processing Batch Size Expression Optional batch size used instead of the Operation Quantity to perform the processing activity
as a set of sequential batches. Must be less than or equal to the operation quantity. If not
specified, then the batch size is assumed to be the operation quantity and the processing
activity is performed in a single batch.
Processing Time Expression The time required to process an individual batch. This property may be specified using a
random sample from a distribution.
Teardown Time Expression The teardown time required for an operation after completing the processing of all batches.
This property may be specified using a random sample from a distribution.
Input Buffer Integer >= 0 The number of entities that can be held in this Workstation object's input buffer.
Output Buffer Integer >=0 The number of entities that can be held in this Workstation object's output buffer.
Failure Type No Failures, Specifies whether this Workstation object has failures that affect the object's availability, and
C alendar Time the method used to trigger the failure occurrences.
Based,
Processing
C ount Based,
Event C ount
Based,
Processing
Time Based
Event Name Event Instance The name of the event which determines when the next failure occurs.
Name
Uptime Between Failures Expression The uptime between failure occurrences. This property may be specified using a random
sample form a distribution.
C ount Between Failures Expression The count between failure occurrences. This property may be specified using a random
sample from a distribution.
Time To Repair Expression The time required to repair a failure when one occurs. This property may be specified using a
random sample from a distribution.
On Entering (state assignment) Repeat Group, Optional state assignments when an entity is entering the Workstation object.
Assignments
Before Exiting (state Repeat Group, Optional state assignments when an entity is ready to exit the Workstation object.
assignment) Assignments
Secondary Resources Repeating The secondary resources that are required for activities at this Workstation object.
Property
SecondaryResources.Object Specific, From The method for specifying the object(s) required as a secondary resource.
Type List
SecondaryResources.Object Object Instance The name of the object type that is required.
Name Name
SecondaryResources.Object List Object List The name of the object list from which one or more objects will be selected.
Name Instance Name
SecondaryResources.Activity All, Specific, All The range of activities that the secondary resource is required for.
Range But Specific
SecondaryResources.Activity Setup, The specific activity at this Workstation object that the secondary resource either is or is not
Processing, required for.
Teardown
SecondaryResources.Request None, To Node Indicates whether a move to a specified location will be requested from the seized object(s).
Move Workstation activity will not continue until all resources have arrived to the requested
location.
SecondaryResources.Destination Node Instance The name of the specific node location that the seized resource(s) will be requested to move
Node Name to.
SecondaryResources.Move Expression The priority of the move request if a PlanVisit step or SelectVisit step is used by the seized
Priority resource(s) to choose a visit destination from multiple candidates. If not specified, and the
owner object performing the seize is an entity object, then this property defaults to the
processing entity's Priority state value.
SecondaryResources.Number Of Expression The number of objects that are required.
Objects truncated to
integer
SecondaryResources.Units Per Expression The number of capacity units that are required per object.
Object truncated to
integer
(SecondaryResources)Selection Smallest The goal used to rank object preference when multiple candidates are available.
Goal Distance,
Largest
Distance,
Preferred
Order, Smallest
Value, Largest
Value
(SecondaryResources)Selection Expression An optional condition evaluated for each candidate object that must be true for the object to
C ondition be eligible for seizing. In the condition, use the keyword C andidate to reference an object in
the collection of candidates.
539 / 815
SecondaryResources.Selection Smallest The goal for selecting objects to seize.
Goal Distance,
Largest
Distance,
Preferred
Order, Smallest
Value, Largest
Value, Random
SecondaryResources.Selection Expression The expression evaluated for each object that is a candidate to seize. In the expression, use
Expression the keyword C andidate to reference an object in the collection of candidates to be seized
(e.g., C andidate.Object.C apacity.Remaining).
SecondaryResources.Selection Expression An optional condition evaluated for each candidate object that must be true for the object to
C ondition be eligible for seizing. In the condition, use the keyword C andidate to reference an object in
the collection of candidates (e.g., C andidate.Object.C apacity.Remaining)
Materials Repeating Materials consumed or produced by processing activities at this workstation
Property
Materials.Action Type C onsume, The type of material-related action required.
Produce
Materials.C onsumption Type Material, Bill Of Indicates whether to consume a single material or bill of materials. The material consumption
Materials will be required to start the processing time of a batch (i.e., is a material consumption
requirement per batch).
Materials.Production Type Material, Bill Of Indicates whether to produce a single material or bill of materials. The material production
Materials will occur after finishing the processing time of a batch (i.e., is a material production result
per batch).
Materials.Material Name Material The name of the material which is to be either specifically consumed or produced, or whose
Instance Name Bill of Materials is to be consumed or produced.
Materials.Quantity Expression The quantity to be consumed or produced.
Materials.Produced Delay Time Expression An optional delay time after finishing the processing time of a batch until the produced
material is actually added to the system.
Maximum Makespan Expression The maximum length of the time allowed for this operation, from the start of the setup
activity until the completion of the teardown activity at this Workstation object. An operation
cannot be started unless its estimated makespan is less than this Maximum value minus the
Makespan Buffer Time. Note that, if the Workstation object is following a Work Schedule, then
'off-shift' periods in the schedule will be factored into and extend the estimated makespan
time.
Makespan Buffer Time Expression An operation cannot be started unless its estimated makespan is less than the Maximum
Makespan minus this Buffer Time.
Parent C ost C enter C ost C enter The cost center that costs allocated to this object are rolled up into. If a parent cost center is
Name not explicitly specified, then costs will be automatically rolled up into the parent object
containing this object.
C apital C ost Expression The initial one-time setup cost to add this object to the system.
C ost Per Use (Input Buffer Expression The cost to hold an entity in this buffer irrespective of the waiting time.
C osts)
Holding C ost Rate (Input Buffer Expression The cost per unit time to hold an entity in this buffer.
C osts)
C ost Per Use (Output Buffer Expression The cost to hold an entity in this buffer irrespective of the waiting time.
C osts)
Holding C ost Rate (Output Buffer Expression The cost per unit time to hold an entity in this buffer.
C osts)
Idle C ost Rate (Resource C osts) Expression The cost per unit time charged, or accrued, to the cost of the workstation during periods that
the workstation is scheduled but unutilized.
C ost Per Use (Resource C osts) Expression The one-time cost that is accrued each time the workstation is used, regardless of the usage
duration. This cost will be charged to the costt of the entity using the workstation.
Setup C ost Rate (Resource Expression The cost per unit time to use the workstation for setup activity. This cost will be charged to
C osts) the cost of the entity using the workstation.
Processing C ost Rate (Resource Expression The cost per unit time to use the workstation for processing activity. This cost will be charged
C osts) tot the cost of the entity using the workstation.
Teardown C ost Rate (Resource Expression The cost per unit time to use the workstation for teardown activity. This cost will be charged
C osts) to the costt of the entity using the workstation.
Run Initialized Add-On Process Process Occurs when the simulation run is initialized.
Instance Name
Run Ending Add-On Process Process Occurs when the simulation run is ending.
Instance Name
Entered Add-On Process Process Occurs immediately after an entity as entered this object and is about to start TransferIn
Instance Name Time.
Setting Up Add-On Process Process Occurs when an operation's setup time is about to begin.
Instance Name
Finished SetUp Add-On Process Process Occurs when an operation's setup time is finished and the release of secondary resources due
Instance Name to finish setup is about to occur.
Processing Batch Add-On Process Occurs when the processing time for a batch is about to begin.
Process Instance Name
Processed Batch Add-On Process Occurs when the processing time for a batch has completed and the material production or
Process Instance Name release of secondary resources due to finish the batch is about to occur.
Tearing Down Add-On Process Process Occurs when an operation's teardown time is about to begin.
Instance Name
Finished Teardown Add-On Process Occurs when an operation's teardown time is finished and the release of secondary resources
Process Instance Name due to finish teardown is about to occur.
540 / 815
Finished Good Operation Add-On Process Occurs when an operation has finished and the makespan of the operation has satisfied the
Process Instance Name Maximum Makespan condition.
Finished Bad Operation Add-On Process Occurs when an operation has finished and the makespan of the operation has exceeded the
Process Instance Name Maximum Makespan condition.
Exited Add-On Process Process Occurs when an entity as exited this object.
Instance Name
Failed Add-On Process Process Occurs when this object has failed.
Instance Name
Repaired Add-On Process Process Occurs when a failure is repaired at this object.
Instance Name
Evaluating Seize Request Add- Process Occurs when this Workstation object is evaluating whether to accept or reject a request to
On Process Triggers Instance Name seize capacity of the workstation. In the executed decision process, assigning a value of less
than or equal to '0' to the executing token's ReturnValue state (Token.ReturnValue) indicates
that the seize request is rejected.
On Shift Add-On Process Process Occurs when the object goes On Shift because of its specified Work Schedule.
Instance Name
Off Shift Add-On Process Process Occurs when the object goes Off Shift because of its specified Work Schedule.
Instance Name
Log Resource Usage True or False Indicates whether usage related events for this resource are to be automatically logged. Go
to Results -> Logs to view logged data.
Transfer-In C onstraints Disable, Indicates the type of constraints used to determine whether entities can transfer into this
Default, fixed object via external input nodes. If specified as 'Default', then the Can Transfer In & Out
C ustom of Objects property setting for the entity type will determine whether an entity can perform a
C ondition transfer into the object.
Transfer-In C ondition Expression The condition required to allow an entity to transfer into this fixed object via an external input
node.
Transfer-Out C onstraints Disable, Indicates the type of constraints used to determine whether entities can transfer out of this
Default, fixed object via external output nodes. If specified as 'Default', then the Can Transfer In &
C ustom Out of Objects property setting for the entity type will determine whether an entity can
C ondition perform a transfer out of the object.
Transfer-Out C ondition Expression The condition required to allow an entity to transfer out of this fixed object via an external
output node.
Expected Setup Time Expression Expression The expression used to estimate an expected setup time for an entity at this fixed object.
Expected Operation Time Expression The expression used to estimate an expected operation time for an entity at this fixed object.
Expression
Report Statistics True or False A Boolean property may be True or False and used in expressions as a numeric 1.0 (True) or
0.0 (False) value.
541 / 815
Simio Reference Guide
W orkstation - Discussion and Examples
Discussion
In this example below, a Workstation is the primary resource and the secondary resource is an object named Resource1. Notice the
Activity Range and Activity properties. Resource1 is only seized for the Setup and Teardown activities, not the Processing activity.
Details of the Secondary Resource on a Workstation
543 / 815
Sequence Dependent Setup Time
The Setup Time for each entity arriving to the Workstation can be set to a value that is determined by the combination of an attribute on
the previous entity and the same attribute on the current entity (i.e. Setup times for From-To pairs are defined in a C hangeOverMatrix).
The Setup Time Type property should be set to 'Sequence Dependent'. The Operation Attribute is evaluated as a zero based index into the
C hangeover Matrix string list. An Operation Attribute value of '0' means that the entity's comparison value is the first in the String List. The
following example of a Sequence Dependent Setup time uses a List Property to compare sequential operations and determine which setup
time should be used. The ModelEntity object has a String List with three values; Small, Medium and Large. Each ModelEntity has a different
value for the ListProperty. Since the Operation Attribute is set to ModelEntity.ListProperty1, this is what is used to determine the Setup
Time from the C hangeOver Matrix.
Sequence Dependent Setup Time
544 / 815
Simio Reference Guide
Vehicle
Vehicles
A Vehicle object may be used to define a dynamic population of moveable unit resources in the modeled system. Each individual vehicle member
in the population is tracked separately, in terms of both animation and statistics.
Vehicles are modeling objects that can pickup entity objects at a location, carry those objects through a network of links or free space, then drop
the entities off at a destination location. This object also has the ability to move off of a network while maintaining association with a node on the
network (i.e., park at a node in a network).You can create other transporter models that behave differently than the standard Vehicle model; e.g.
you could create an object definition for a subway car, AGV, or bus.
An ‘On Demand’ Vehicle object may be used as a moveable resource that is seized and released by model logic for non-transport tasks. A ‘Fixed
Route’ vehicle will never be available to be seized, as the behavior of that type of vehicle is designed to maintain its specified fixed routing
sequence and only do pickups and drop-offs at the locations specified along the route. If an ‘On Demand’ Vehicle object is being used for both
transport and non-transport tasks, then by default, the non-transport tasks will always be prioritized before transport tasks.
If a Vehicle's C urrentTravelMode is 'Network If Possible', then the vehicle will accept any node in the same Facility view as a valid destination for
pickups, drop-offs, processing tasks, etc. (because the Vehicle's travel movements will be able to be performed using either its currently assigned
network or in free space).
You can define the Initial Number In System for the Vehicle population. You may also use the C reate step or Source object to dynamically create
and add new members to the population during the run. However, note that you cannot dynamically Destroy a Vehicle because resource objects
in Simio are not destroyable.
A Vehicle may have failures, which are specified within the Reliability section of the Properties window. The Add-On Process Triggers allow
additional logic to be specified when using the Vehicle.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the Vehicle.
For more information, see Vehicle - Discussion and Examples.
Listed below are the properties of the Vehicle:
Property Valid Entry Description
Initial Ride Integer The initial carrying capacity of this Vehicle object.
C apacity
Task Selection Smallest The strategy used by the Vehicle object to select its next transport pickup or dropoff task.
Strategy Distance, Largest
Distance,Smallest
Priority, Largest
Priority, First In
Queue
Load Time Expression The time required for this Vehicle object to load an entity (i.e., the load time per entity).
Unload Time Expression The time required for this Vehicle object to unload an entity (i.e., the unload time per entity).
Park To True or False Indicates whether this Vehicle object should park to load and unload entities at a node. Parking a vehicle can
Load/Unload be useful to avoid blocking other travelers on the network.
Minimum Dwell Until Event, Specifies the minimum dwell time requirement for this Vehicle object when loading and unloading entities at a
Dwell Time Dwell Until Full, node. A 'minimum dwell time' is a minimum amount of time the vehicle is required to wait, or 'dwell', at a
Type No Requirement, node to load and unload entities.
Specific Time
Event Name Event Name The name of the event that will indicate the expiration of the minimum wait time requirement for this Vehicle
object when loading and unloading entities at a node.
Minimum Expression The specific minimum amount of time that this Vehicle object is required to wait, or 'dwell', at a node to load
Dwell Time and unload entities.
Dwell Only If Expression If specified, this condition will be used to indicate whether the vehicle must respect the minimum dwell time at
a node if that requirement has not yet expired, thereby forcing the vehicle to wait, or 'dwell', at the node for
possible additional loads. Example uses of this property might include allowing the vehicle to exit a node
before the minimum dwell time has expired if the vehicle has reached full ride capacity, or if there is little to
no chance of additional loads. Another example condition might be to only respect the minimum dwell time
requirement if the vehicle is at a node meeting some specific criteria.
Initial Desired Expression The initial desired speed value for this Vehicle object when traveling between locations.
Speed
Initial Travel Free Space Only, The initial travel mode for entities of this type.
Mode Network Only,
Network If 'Free Space Only' indicates that the entities are required to perform travel movements in free space.
Possible
'Network Only' indicates that the entities are required to perform travel movements using the currently
assigned network.
'Network If Possible' indicates a preference for the entities to perform travel movement using the currently
assigned network, but if no followable network path exists to the next destination then travel in free space is
allowed.
NOTE: Refer to the user-assignable 'C urrentTravelMode' state variable of an entity to dynamically change its
travel mode during a simulation run. An entity's travel mode may also be changed using the 'Outbound Travel
Mode' property provided by a node.
Initial Network Network Instance The initial network of links used by this Vehicle object to travel between node locations.
Name
Network Exit & Re-enter, When traveling on a network, the default method used by objects of this type to turn around at a node in
Turnaround Rotate in Place, order to move in the opposite direction on a bidirectional link. The 'Turnaround Method' property of a Network
Method Reverse element may also be used to override this default on a network-by-network basis.
Free Space Direct To The behavior used to steer an entity of this type when traveling in free space to a destination.
Steering Destination,
Behavior Follow Network 'Direct To Destination' will steer an entity in a straight line to its destination.
Path If Possible
545 / 815
Path If Possible
'Follow Network Path If Possible' will prefer to steer an entity along a path following its currently assigned
network, staying within the boundries of the drawn path width. However, if no followable network path exists
to the entity's destination then the entity will be steered in a straight line. Note: In order to use this steering
behavior, make sure the entity's travel mode is set to 'Free Space Only'.
Update Expression The time interval between updates checking an entity's adherence to the network path.
Interval
Avoid True or False Indicates whether the steering behavior will attempt to avoid collisions with other entities that are following
C ollisions the same network path.
Initial Priority Expression The initial priority value of this Vehicle object at the beginning of the simulation run.
Initial Node Node Instance The initial node location of this Vehicle object at the beginning of the simulation run. Also indicates the
(Home) Name vehicle's 'Home' location if the object's 'Idle Action' is specified as 'Park At Home' or 'Go To Home'.
Routing Type On Demand, Specifies the routing behavior of this Vehicle. If 'On Demand',then the vehicle will route to locations on the
Fixed Route network according to visit requests. An 'On Demand' vehicle may also be used as a moveable resource that is
seized and released for non-transport related tasks by model process logic. If 'Fixed Route', then the vehicle
will follow a fixed route sequence to transport riders and will only load and unload entities at locations on the
specified route.
Route Sequence The sequence table that defines the route sequence that this vehicle will loop.
Sequence Instance Name
Idle Action Park At Node, Go The action of this Vehicle object when it does not have any transportation tasks to perform.
to Home, Remain
In Place, Park At
Home, Roam
Off Shift Park At Node, Go The action of this Vehicle object when it goes 'off shift'. Note that, if the vehicle is busy or transporting when
Action to Home, Remain an off shift period begins, then this action will be taken when the vehicle is released from (i.e., finishes the
In Place, Park At remaining tasks.
Home
C apacity Type Fixed, Work The availability of this vehicle type to perform tasks. 'Fixed' indicates that this type of vehicle is always
Schedule available. 'WorkSchedule' indicates that each vehicle of this type follows a work schedule defining its 'On-
shift', 'Off-shift' availability over time.
Work Schedule The name of the schedule that defines the 'On-shift', 'Off-shift' availability of this type of vehicle over time.
Schedule Property
Work Day Repeat Group, Work Day schedule exceptions specific to this resource.
Exceptions Work Day
Exceptions
Work Period Repeat Group, Work Period schedule exceptions specific to this resource.
Exceptions Work Period
Exceptions
Ranking Rule First In First Out, The static ranking rule used to order requests waiting to seize this Vehicle object for a process task. Note:
Last In First Out, This feature only applies to an 'On Demand' routing type vehicle.
Smallest Value
First, Largest
Value First
Ranking Expression The expression used with a 'Smallest Value First' or 'Largest Value First' static ranking rule for ordering
Expression requests waiting to be allocated capacity of this object.
Dynamic None, or one of Indicates whether this vehicle, when it becomes available, dynamically selects the next seize request from its
Selection Rule several Dynamic statically ranked allocation queue using a dynamic selection rule. Note: This feature only applies to an 'On
Selection Rules Demand' routing type vehicle.
Park While True or False Indicates whether this Vehicle object should park while busy at a node due to a seize request. Parking a
Busy vehicle can be useful to avoid blocking other travelers on the network.
Failure Type No Failures, Specifies whether this Vehicle object has failures that affect the object's availability, and the method used to
C alendar Time trigger the failure occurrences.
Based, Event
C ount Based
Event Name Event Instance The name of the event which determines when the next failure occurs.
Name
Uptime Expression The uptime between failure occurrences. This property may be specified using a random sample from a
Between distribution.
Failures
C ount Expression The count between failure occurrences. This property may be specified using a random sample from a
Between distribution.
Failures
Time To Expression The time required to repair a failure when one occurs. This property may be specified using a random sample
Repair from a distribution.
Parent C ost C ost C enter The cost center that costs allocated to vehicles of this type are rolled up into. If a parent cost center is not
C enter Name explicitly specified, then costs allocated to a vehicle will be automatically rolled up into the parent object that
contains the vehicle's current location.
C apital C ost Expression The initial one-time setup cost to add a vehicle of this type to the system.
Per Vehicle
C ost Per Rider Expression The cost to load and transport an entity using a transporter of this type, irrespective of the transportation
(Transport time. This cost is allocated to an entity when it is loaded onto the transporter.
C osts)
Transport C ost Expression The cost per unit time to transport an entity using a transporter of this type.
Rate
(Transport
C osts)
Idle C ost Expression The cost per unit time charged, or accrued, to the cost of a vehicle of this type when it is idle.
Rate(Resource
C osts)
546 / 815
C ost Per Expression The one-time cost that is accrued each time a vehicle of this type is used for a non-transport task, regardless
Use(Resource of the usage duration. This cost will be charged to the cost of the owner object(i.e., task) using the vehicle.
C osts)
Usage C ost Expression The cost per unit time to use a vehicle of this type for a non-transport task. This cost will be charged to the
Rate(Resource cost of the owner object (i.e., task) using the vehicle.
C osts)
Run Initialized Process Instance Occurs when the simulation run is initialized. Note: This trigger will only occur for Vehicle objects created by
Add-On Name the Intiial Number in System setting.
Process
Triggers
Run Ending Process Instance Occurs when the simulation run is ending.
Add-On Name
Process
Triggers
Allocated Add- Process Instance Occurs when this Vehicle resource has been allocated to perform some transport tasks, or when another
On Process Name object has seized this Vehicle resource for some non-transport related task.
Triggers
Released Add- Process Instance Occurs when this Vehicle resource has been released after completing a set of tranport tasks, or when
On Process Name another object has released this Vehicle resource from some non-transport related task.
Triggers
Failed Add-On Process Instance Occurs when the vehicle has failed.
Process Name
Triggers
Repaired Add- Process Instance Occurs when a failure is repaired at the vehicle.
On Process Name
Triggers
Entered Node Process Instance Occurs when this vehicle has entered a node.
Add-On Name
Process
Triggers
Unloaded Add- Process Instance Occurs after an entity is unloaded from this vehicle.
On Process Name
Triggers
Loaded Add- Process Instance Occurs after an entity is loaded onto the vehicle.
On Process Name
Triggers
Exiting Node Process Instance Occurs when this vehicle object is about to begin exiting a node.
Add-On Name
Process
Triggers
Evaluating Process Instance Occurs when this vehicle is evaluating whether or not to accept the pickup of a rider. In the executed decision
Transport Name process, assigning the value less than or equal to 0.0 to the executing token's ReturnValue state
Request Add- (Token.ReturnValue) indicates that the potential rider is rejected.
On Process
Triggers
Evaluating Process Instance Occurs when an 'On Demand' routing type Vehicle is evaluating whether to accept or reject a seize allocation
Seize Request Name attempt by some process in the system. In the executed decision process, assigning a value less than or
Add-On equal to 0.0 to the executing token's ReturnValue state (Token.ReturnValue) indicates that the allocation
Process attempt is rejected.
Triggers
On Shift Add- Process Instance Occurs when the object goes 'on shift' because of its specified work schedule.
On Process Name
Triggers
Off Shift Add- Process Instance Occurs when the object goes 'off shift' because of a specified work schedule.
On Process Name
Triggers
Initial Number Integer The initial number of Vehicle objects of this type in the system. Vehicles are initially located in free-space at
in System the object instance location.
Maximum Integer The maximum number of objects of this instance that can be simultaneously in the system. If this limit is
Number in exceeded then a runtime error is generated.
System
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go to Results ->
Usage Logs to view logged data.
Display String Optional text used for hierarchically arranging resources in the Resource Plan window. Use backslashes for
C ategory multiple levels (e.g., One\Two\Three).
Display C olor C olor A color to be used when showing this object in various windows (currently only Gantt windows in Simio
Enterprise and Simio Scheduling Editions). If not specified, then this property defaults to a color derived from
the object's unique name.
C an Transfer True or False Indicates whether objects of this type are by default allowed to transfer into and out of fixed objects via those
In & Out of object's external input / output nodes.
Objects
Report True or False A Boolean property may be True or False and used in expressions as a numeric 1.0 (True) or 0.0 (False)
Statistics value.
547 / 815
Simio Reference Guide
Vehicle - Discussion and Examples
Discussion
548 / 815
To prioritize specifically among transport tasks, specify the Task Selection Strategy in the Transport Logic category of the Vehicle object’s
properties. To prioritize specifically among non-transport tasks, you may use the Ranking Rule or Dynamic Selection Rule properties
available in the Process Logic category of the Vehicle object’s properties. If you want to implement even more customized control of how
an ‘On Demand’ Vehicle object selects its next task then you may take advantage of the Evaluating Transport Request and Evaluating
Seize Request Add-On process triggers. For example, you can use those Add-On processes to implement logic on a particular vehicle such
as “Don’t accept any non-transport tasks until all my transport tasks are finished first”.
If the Park While Busy property is specified as 'True', the vehicle(s) will be placed in the parking area of the node at which it is processing.
There are two ways to animate the parking area. First, click on a specific node and then select the Parking Queue button from the
Appearance ribbon. Alternatively, click on a specific node and select Draw Queue / ParkingStation.C ontents and draw the animated queue.
Example 1
Vehicle_Example 1
549 / 815
This shows the Transfer Node properties window for the Output Node of a Server and the Vehicle properties window for Vehicle1. The
entities that enter this node will wait to be picked up by the Transporter named Vehicle1. If there are more than one type of Vehicle1
objects in the model at the time, the C loset will be reserved. The Vehicle1 object will take the entities from the Output Node of the Server
to the Input Node of Sink1, as specified in the Node Name property of the Node. The Initial Ride Capacity property is set to 'Infinity' so the
Transporter will pick up all the entities that are waiting in the [email protected] at the time it arrives at the Output node.
550 / 815
Simio Reference Guide
W orker
A Worker object may be used to define a dynamic population of moveable unit resources in the modeled system. Each individual worker member
in the population is tracked separately, in terms of both animation and statistics. Each individual worker member in the population may have a
resource capacity of 0 (OffShift) or 1 (OnShift). A Worker can follow an OnShift/OffShift work schedule or have a fixed capacity.
In Simio, a Worker may be used as a moveable resource that is seized and released to process tasks by model process logic. Additionally, a
worker may be used to transport entity objects between node locations. By default, new seize requests are always prioritized over new transport
requests.
Workers have characteristics of both the Standard Library objects of Vehicles and Resources. Workers may have a fixed capacity or may utilize a
defined work schedule, similar to a resource. Workers also physically move between objects and can carry one or more entities from one location
to another, similar to vehicles. Workers have a physical location in the Facility window, defined by the Intial Node (Home), Idle Action and Off Shift
Action properties specified with the Worker. The worker may have a home location to which it moves when idle / off-shift, may remain at its last
utilized location or may roam the network of paths.
When a Worker object is scheduled to go 'Off-Shift', if the worker is still in the process of performing a task then it will first complete any
remaining work before going into the 'OffShift' resource state. No new seize or transport requests will be accepted during the off-shift period.
While finishing those tasks, the worker object will be in either the 'OffShiftBusy' state or 'OffShiftTransporting' state. If in the 'OffShiftTransporting'
state, the Worker will complete any pickups at a reserved node location (if it has already accepted a pickup transport request). The Worker will
also finish any remaining rider drop-offs. Once all remaining drop-offs are completed and the Worker object's RideStation queue is empty, it will
go into the 'OffShift' state and perform the Off Shift Action (Park at Node, etc.). If in the 'OffShiftBusy' state, the Worker will complete any
traveling to the requested task destination. It will then remain at that location until released. Once released, it will go into the 'OffShift' state and
perform the Off Shift Action specified. Note: If the user would like to interrupt a process task delay when a Worker goes off-shift (to immediately
preempt usage of and release the worker), there is the option of using the Interrupt step to do so.
If a Worker's C urrentTravelMode is 'Network If Possible', then the worker will accept any node in the same Facility view as a valid destination for
pickups, drop-offs, processing tasks, etc. (because the Worker's travel movements will be able to be performed using either its currently
assigned network or in free space).
The Initial Number In System may be defined for the Worker population. Additionally, the C reate step or Source object may be used to
dynamically create and add new members to the population during the run. However, note that Worker objects cannot be dynamically destroyed
(Destroy step) because resource objects in Simio are not destroyable.
The Add-On Process Triggers allow additional logic to be specified when using the Worker.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the Worker.
For more information, see Worker - Discussion and Examples.
Listed below are the properties of the Worker:
Property Valid Entry Description
C apacity Type Fixed, Work The availability of this worker type to perform tasks. 'Fixed' indicates that this type of worker is always
Schedule available. 'WorkSchedule' indicates that each worker of this type follows a work schedule defining its 'On-
shift', 'Off-shift' availability over time.
Work Schedule The name of the schedule that defines the 'On-shift', 'Off-shift' availability of this type of worker over time.
Schedule Property
Work Day Repeat Group, Work Day schedule exceptions specific to this resource.
Exceptions Work Day
Exceptions
Work Period Repeat Group, Work Period schedule exceptions specific to this resource.
Exceptions Work Period
Exceptions
Ranking Rule First In First Out, The static ranking rule used to order requests waiting to seize this Worker object for a process task.
Last In First Out,
Smallest Value
First, Largest
Value First
Ranking Expression The expression used with a Smallest Value First or Largest Value First ranking rule.
Expression
Dynamic None, or one of Indicates whether this Worker object, when it becomes available, dynamically selectes the next seize
Selection Rule several Dynamic reqeuest from its statically ranked allocation queue using a dynamic selection rule.
Selection Rules
Park While True or False Indicates whether this Worker object should park while busy at a node due to a seize request. Parking a
Busy worker can be useful to avoid blocking other travelers on the network.
Intial Desired Expression The initial value for the desired travel speed of this Worker object when traveling between locations.
Speed
Initial Travel Free Space Only, The initial travel mode for entities of this type.
Mode Network Only,
Network If 'Free Space Only' indicates that the entities are required to perform travel movements in free space.
Possible
'Network Only' indicates that the entities are required to perform travel movements using the currently
assigned network.
'Network If Possible' indicates a preference for the entities to perform travel movement using the currently
assigned network, but if no followable network path exists to the next destination then travel in free space is
allowed.
NOTE: Refer to the user-assignable 'C urrentTravelMode' state variable of an entity to dynamically change its
travel mode during a simulation run. An entity's travel mode may also be changed using the 'Outbound Travel
Mode' property provided by a node.
Initial Network Network Instance The initial network of paths used by this Worker object to travel between locations.
Name
Network Exit & Re-enter, When traveling on a network, the default method used by objects of this type to turn around at a node in
Turnaround Rotate in Place, order to move in the opposite direction on a bidirectional link. The 'Turnaround Method' property of a Network
Method Reverse element may also be used to override this default on a network-by-network basis.
551 / 815
Free Space Direct To The behavior used to steer an entity of this type when traveling in free space to a destination.
Steering Destination,
Behavior Follow Network 'Direct To Destination' will steer an entity in a straight line to its destination.
Path If Possible
'Follow Network Path If Possible' will prefer to steer an entity along a path following its currently assigned
network, staying within the boundries of the drawn path width. However, if no followable network path exists
to the entity's destination then the entity will be steered in a straight line. Note: In order to use this steering
behavior, make sure the entity's travel mode is set to 'Free Space Only'.
Update Expression The time interval between updates checking an entity's adherence to the network path.
Interval
Avoid True or False Indicates whether the steering behavior will attempt to avoid collisions with other entities that are following
C ollisions the same network path.
Initial Priority Real The initial priority value of this Worker object.
Initial Node Node Instance The initial node location of this Worker object at the beginning of the simulation run. Also indicates the
(Home) Name worker's 'Home' location if the object is specified to 'Park At Home' or 'Go To Home' when idle or off shift.
Idle Action Park At Node, Go The action of this Worker object when it does not have any tasks to perform.
to Home, Remain
In Place, Park At
Home, Roam
Off Shift Park At Node, Go The action of this Worker object when it goes 'off shift'. Note that, if the worker is busy when an off shift
Action to Home, Remain period begins, then this action is not taken until the worker is released from its last task.
In Place, Park At
Home
Initial Ride Integer The initial carrying capacity of this Worker object.
C apacity
Task Selection Smallest The strategy used by the Worker object to select its next transport task.
Strategy Distance, Largest
Distance,Smallest
Priority, Largest
Priority, First In
Queue
Load Time Expression The time required for this Worker object to load an entity (i.e., load time per entity).
Unload Time Expression The time required for this Worker object to unload an entity (i.e., unload time per entity).
Park To True or False Indicates whether this Worker object should park to load and unload entities at a node. Parking a worker can
Load/Unload be useful to avoid blocking other travelers on the network.
Minimum Dwell Until Event, Specifies the minimum dwell time requirement for this Worker object when loading and unloading entities at a
Dwell Time Dwell Until Full, node. A 'minimum dwell time' is a minimum amount of time the worker is required to wait, or 'dwell', at a
Type No Requirement, node to load and unload entities.
Specific Time
Event Name Event Name The name of the event that will indicate the expiration of the minimum wait time requirement for this Worker
object when loading and unloading entities at a node.
Minimum Expression The specific minimum amount of time that this Worker object is required to wait, or 'dwell', at a node to load
Dwell Time and unload entities.
Dwell Only If Expression If specified, this condition will be used to indicate whether the worker must respect the minimum dwell time at
a node if that requirement has not yet expired, thereby forcing the worker to wait, or 'dwell', at the node for
possible additional loads. Example uses of this property might include allowing the worker to exit a node
before the minimum dwell time has expired if the worker has reached full ride capacity, or if there is little to
no chance of additional loads. Another example condition might be to only respect the minimum dwell time
requirement if the worker is at a node meeting some specific criteria.
Parent C ost C ost C enter The cost center that costs allocated to workers of this type are rolled up into. If a parent cost center is not
C enter Name explicitly specified, then costs allocated to a worker will be automatically rolled up into the parent object that
contains the worker's current location.
C apital C ost Expression The initial one-time setup cost to add a worker of this type to the system.
Per Worker
C ost Per Rider Expression The cost to load and transport an entity using a transporter of this type, irrespective of the transportation
(Transport time. This cost is allocated to an entity when it is loaded onto the transporter.
C osts)
Transport C ost Expression The cost per unit time to transport an entity using a transporter of this type.
Rate
(Transport
C osts)
Idle C ost Expression The cost per unit time charged, or accrued, to the cost of a worker of this type when it is idle.
Rate(Resource
C osts)
C ost Per Expression The one-time cost that is accrued each time a worker of this type is used for a non-transport task, regardless
Use(Resource of the usage duration. This cost will be charged to the cost of the owner object(i.e., task) using the worker.
C osts)
Usage C ost Expression The cost per unit time to use a worker of this type for a non-transport task. This cost will be charged to the
Rate(Resource cost of the owner object (i.e., task) using the worker.
C osts)
Run Initialized Process Instance Occurs when the simulation run is initialized. Note: This trigger will only occur for Worker objects created by
Add-On Name the Intiial Number in System setting.
Process
Triggers
Run Ending Process Instance Occurs when the simulation run is ending.
Add-On Name
Process
Triggers
Allocated Add- Process Instance Occurs when this Worker resource has been allocated to perform some transport tasks, or when another
552 / 815
On Process Name object has seized this Worker resource for some non-transport related task.
Triggers
Released Add- Process Instance Occurs when this Worker resource has been released (freed) after completing a set of tranport tasks, or
On Process Name when another object has released this Worker resource from some non-transport related task.
Triggers
Entered Node Process Instance Occurs when this Worker object has entered a node.
Add-On Name
Process
Triggers
Unloaded Add- Process Instance Occurs after an entity is unloaded from this Worker.
On Process Name
Triggers
Loaded Add- Process Instance Occurs after an entity is loaded onto the Worker.
On Process Name
Triggers
Exiting Node Process Instance Occurs when this Worker object is about to begin exiting a node.
Add-On Name
Process
Triggers
Evaluating Process Instance Occurs when this Worker object is evaluating whether or not to accept or reject a transport request from a
Transport Name potential rider. In the executed decision process, assigning the value less than or equal to 0.0 to the executing
Request Add- token's ReturnValue state (Token.ReturnValue) indicates that the transport request is rejected.
On Process
Triggers
Evaluating Process Instance Occurs when this Worker object is evaluating whether to accept or reject a seize allocation attempt by some
Seize Request Name process in the system. In the executed decision process, assigning a value less than or equal to 0.0 to the
Add-On executing token's ReturnValue state (Token.ReturnValue) indicates that the seize request is rejected.
Process
Triggers
On Shift Add- Process Instance Occurs when the object goes 'on shift' because of its specified work schedule.
On Process Name
Triggers
Off Shift Add- Process Instance Occurs when the object goes 'off shift' because of its specified work schedule.
On Process Name
Triggers
Initial Number Integer The initial number of Worker objects of this type in the system.
in System
Maximum Integer The maximum number of objects of this type that can be simultaneously in the system. If this limit is
Number in exceeded then a runtime error is generated.
System
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go to Results ->
Usage Logs to view logged data.
Display String Optional text used for hierarchically arranging resources in the Resource Plan window. Use backslashes for
C ategory multiple levels (e.g., One\Two\Three).
Display C olor C olor A color to be used when showing this object in various windows (currently only Gantt windows in Simio
Enterprise and Simio Scheduling Editions). If not specified, then this property defaults to a color derived from
the object's unique name.
C an Transfer True or False Indicates whether objects of this type are by default allowed to transfer into and out of fixed objects via those
In & Out of object's external input / output nodes.
Objects
Report True or False Specifies if statistics are to be automatically reported for this object.
Statistics
553 / 815
Simio Reference Guide
W orker - Discussion and Examples
Discussion
555 / 815
Simio Reference Guide
C onnector
A Connector object is a link that may be used to define a non passing pathway between two node locations where the travel time is
instantaneous. It is a Link object that is hard-coded with its DrawnToScale property set to ‘False’ and its LogicalLength property set to ‘0.0’.
Entities will never actually enter, move across or exit a C onnector, but will always instead immediately do a node-to-node direct transfer across
the link. Note that entities travel across a C onnector one at a time, which is different behavior than the standard Path link type. Entities waiting to
enter a C onnector are inserted into the C onnector's EntryQueue.
C onnectors can be animated with Path Decorators.
556 / 815
Simio Reference Guide
P ath
A Path object is a link that may be used to define a pathway between two node locations where the travel time is determined by the path length
and a traveler's speed. Passing may or may not be allowed. Paths can be animated with Path Decorators.
The Add-On Process Triggers allow additional logic to be specified when using the Path.
There are two categories of statistics that are generated for paths, including traveler statistics and flow statistics. The Data Source 'Travelers'
provides information related to the througput, flowtime and content on a particular path. The Data Source section 'Flow' provides throughout
information on the flow in and out of a particular path. Flow values are reported only if at least one of them is greater than 0.
For more information, see Path - Discussion and Examples.
557 / 815
Simio Reference Guide
P ath - Discussion and Examples
Discussion
558 / 815
Simio Reference Guide
T imeP ath
A TimePath object is a link that may be used to define a pathway between two node locations where the travel time is user specified. TimePaths
can be animated with Path Decorators.
The Add-On Process Triggers allow additional logic to be specified when using the TimePath.
There are two categories of statistics that are generated for time paths, including traveler statistics and flow statistics. The Data Source
'Travelers' provides information related to the througput, flowtime and content on a particular time path. The Data Source section 'Flow' provides
throughout information on the flow in and out of a particular time path. Flow values are reported only if at least one of them is greater than 0.
559 / 815
Simio Reference Guide
C onveyor
Conveyor
A C onveyor is a link that can represent both accumulating and non-accumulating devices. The specific conveyor defined in the Standard Object
Library supports both fixed and variable spacing and accurately models the merging of entities of various sizes on the conveyor. C onveyors can
be animated with Path Decorators.
A C onveyor may have failures, which are specified within the Reliability section of the Properties window. The Add-On Process Triggers allow
additional logic to be specified when using the C onveyor.
There are two categories of statistics that are generated for conveyors, including traveler statistics and flow statistics. The Data Source 'Travelers'
provides information related to the througput, flowtime and content on a particular conveyor. The Data Source section 'Flow' provides throughout
information on the flow in and out of a particular conveyor. Flow values are reported only if at least one of them is greater than 0.
For more information, see C onveyor - Discussion and Examples.
561 / 815
Simio Reference Guide
C onveyor - Discussion and Examples
Discussion
Accumulation
The following functions are available to track Accumulated entities on a conveyor (or other type of links):
NumberTravelers.Accumulated
NumberTravelers.Accumulated.Minimum
NumberTravelers.Accumulated.Maximum
NumberTravelers.Accumulated.Average
The C onveyor's Accumulating property indicates that if the entity at the end of the conveyor is stopped, then the conveyor itself (i.e., everybody
else) should stop. If the Accumulating property of the standard library C onveyor object is set to ‘False’, the NumberTravelers.Accumulated
function may still be positive. For instance, if an entity is stopped at the end of the conveyor, it will be considered Accumulated. See the definition
of Accumulation in the Link section of the Object Types page.
Examples
Example 1
C onveyor object with Accumulating property set to True and then False. When Server1 is processing an entity, all entities on the conveyor will
continue moving to the server with an accumulating conveyor. If the conveyor is non-accumulating, the conveyor stops and all entities keep their
spacing when the server is busy. Both scenarios assume "0" input buffer capacity for Server1.
Conveyor - Accumulating Verses Non-Accumulating
Example 2
C onveyor object with Entity Alignment property set to 'C ell Location'. The example below shows one conveyor with Number of Cells set to '2' and
the other with Number of Cells set to '3'.
Conveyor with Specific Cell Location
562 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
563 / 815
Simio Reference Guide
Flow Library
564 / 815
Simio Reference Guide
Flow Source
The FlowSource object may be used to generate a flow of fluid or other mass of a specified entity type. The source of supply is by default
considered to be infinite, but alternatively may be configure to run out if a stopping condition is met.
The flow rate out of the FlowSource is regulated by its 'Output' flow node.
Please refer to the SimBit FlowC oncepts for models using the FlowSource.
Listed below are the properties of the FlowSource:
Property Valid Entry Description
Entity Type Entity Instance The entity type generated by the flow source.
Name
Maximum Volume Expression The maximum volume to be generated by and flow out of this FlowSource object. If this limit is reached,
Out then the FlowSource object will stop generating flow.
Maximum Weight Expression The maximum weight to be generated by and flow out of this FlowSource object. If this limit is reached,
Flow Out then the FlowSource object will stop generating flow.
Maximum Time Expression The maximum time from the beginning of the simulation run after which this FlowSource object will stop
generating flow.
Stop Event Name Event Name The name of the event which will cause this FlowSource object to stop generating flow.
Run Initialized Add- Process Occurs when the simulation run is initialized.
On Process Instance Name
Run Ending Add-On Process Occurs when the simulation run is ending.
Process Instance Name
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
565 / 815
Simio Reference Guide
Flow Sink
The FlowSink object may be used to destroy the flow of entities representing quantities of fluids or other mass that have finished processing in
the model.
The flow rate into the FlowSink is regulated by its 'Input' flow node.
Please refer to the SimBit FlowC oncepts for models using the FlowSink.
Listed below are the properties of the FlowSink:
Property Valid Entry Description
Run Initialized Add-On Process Process Instance Name Occurs when the simulation run is initialized.
Run Ending Add-On Process Process Instance Name Occurs when the simulation run is ending.
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
566 / 815
Simio Reference Guide
T ank
The Tank object may be used to model a volume or weight capacity constrained location for holding entities representing quantities of fluids or
other mass.
The flow rate into the Tank is regulated by its 'Input' flow node. The flow rate out of the tank is regulated by its 'Output' flow node.
The tank may include Initial Contents of various entity types. Additionally, the Auto Refill Mode allows the specification of when, if at all, the tank
will be automatically refilled. The tank may also be automatically emptied or cleaned upon particular event triggers and conditions. These are
specified in the Purge Contents Triggers or Clean In-Place Triggers repeating properties.
State assignments can be made when the Tank reaches various levels when rising and falling. Additionally, the Add-On Process Triggers allow
additional logic to be specified when using the Tank.
Please refer to the FillingEmpyingTank and TransferringFromOneTankToAnother models within the SimBit FlowC oncepts, as well as the
InfectionPropagationUsingC ontinuousAndFlow SimBit for Tank examples.
Listed below are the properties of the Tank:
Property Valid Entry Description
C apacity Unit Type Volume, Weight The unit type to be used for specifying the tank's physical capacity.
Initial Volume Expression The initial maximum physical volume that can be stored in this tank.
C apacity
Initial Weight Expression The initial maximum physical weight that can be stored in this tank.
C apacity
Initial C ontents Repeat Group, Initial The contents present in the tank when the system is initialized.
C ontents
Entity Type (Initial Entity Instance Name The initial content entity type.
C ontents)
Unit Type (Initial Volume, Weight The unit type to be used for specifying the initial content quantity.
C ontents)
Quantity (Initial Expression The initial content quantity.
C ontents)
Auto Refill Mode No Automatic Refills, Indicates whether the tank has automatic refills, and if so, whether a refill is triggered when the
Refill When Empty, Refill tank becomes empty, when its contents level has falledn below the 'Low' mark, or when some
When Low, Refill When other specified triggering event occurs. The tank will be refilled to the maximum level determined
Specific Event by its physical volume or weight capacity.
Refill Triggering Valid Event Name The name of the event that will indicate when the tank is to be refilled.
Event Name
Delay Time Until Expression The delay time after a refill triggering event before the refill action is actually performed.
Refill
Refill Entity Type Entity Instance Name The entity type that the tank will be refilled with.
Purge C ontents Repeat Group, Triggers Optional event-driven triggers that will immediately remove and dispose of all contents in the tank,
Triggers putting the tank into an empty state.
Triggering Event Valid Event Name The name of the event whose occurrence will indicate that all contents from the tank are to be
Name (Purge immediately removed and disposed of, putting the tank into an empty state.
C ontents Triggers)
C ondition (Purge Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be
C ontents Triggers) true to purge the tank's contents.
C lean In-Place Repeat Group, Triggers Optional event-driven triggers that will immediately remove and dispose of any contents held in
Triggers the tank and then suspend new inflow until a specified cleaning time has elapsed.
Triggering Event Valid Event Name The name of the event whose occurrence will indicate that the tank is to be cleaned.
Name (C lean In-
Place Triggers)
C ondition (C lean Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be
In-Place Triggers) true to trigger a cleaning operation.
C leaning Time Specific, Sequence The method used to specify the time required to clean the tank.
Type (C lean In- Dependent
Place Triggers)
C leaning Time Expression The time required to clean the tank.
(C lean In-Place
Triggers)
Operation Expression The attribute expression to be evaluated for each cleaning operation and whose 'from/to' value
Attribute (C lean changes will determine the sequence-dependent times required to clean the tank.
In-Place Triggers)
Initial C leaning Expression The time required to clean the tank if the first cleaning operation or if the changeover state stored
Time (C lean In- for the previous operation has been cleared.
Place Triggers)
C hangeover C hangeover Matrix The name of the changeover matrix that defines the sequence-dependent cleaning times.
Matrix (C lean In- Name
Place Triggers)
Low-Low Mark Expression The contents level value to be used as the tank's 'Low-Low' mark.
Low Mark Expression The contents level value to be used as the tank's 'Low' mark.
Mid Mark Expression The contents level value to be used as the tank's 'Mid' mark.
High Mark Expression The contents level value to be used as the tank's 'High' mark.
High-High Mark Expression The contents level value to be used as the tank's 'High-High' mark.
On New Inflow Repeat Group, Optional state assignments when a new inflow is starting to enter this Tank object, which may be
Entering (State Assignments either the first inflow into an empty tank or a change in inflow entity type into a partially full tank.
Assignments)
567 / 815
Assignments)
Above Low-Low Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'Low-Low'
Mark (On Tank Assignments mark.
Level Rising State
Assignments)
Above Low Mark Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'Low'
(On Tank Level Assignments mark.
Rising State
Assignments)
Above Mid Mark Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'Mid'
(On Tank Level Assignments mark.
Rising State
Assignments)
Above High Mark Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'High'
(On Tank Level Assignments mark.
Rising State
Assignments)
Above High-High Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'High-
Mark (On Tank Assignments High' mark.
Level Rising State
Assignments)
Tank Full (On Tank Repeat Group, Optional state assignments when the contents level of the tank has reached the tank's maximum
Level Rising State Assignments volume or weight capacity.
Assignments)
Below High-High Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'High-
Mark (On Tank Assignments High' mark.
Level Falling State
Assignments)
Below High Mark Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'High'
(On Tank Level Assignments mark.
Falling State
Assignments)
Above Mid Mark Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'Mid'
(On Tank Level Assignments mark.
Falling State
Assignments)
Below Low Mark Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'Low'
(On Tank Level Assignments mark.
Falling State
Assignments)
Below Low-Low Repeat Group, Optional state assignments when the contents level of the tank is rising above the tank's 'Low-Low'
Mark (On Tank Assignments mark.
Level Falling State
Assignments)
Tank Empty (On Repeat Group, Optional state assignments when the contents level of the tank has fallen to zero and the tank has
Tank Level Falling Assignments thus become empty.
State
Assignments)
Run Initialized Process Instance Name Occurs when the simulation run is initialized.
Add-On Process
Run Ending Add- Process Instance Name Occurs when the simulation run is ending.
On Process
New Inflow Process Instance Name Occurs when a new inflow is starting to enter this Tank object, which may be either the first inflow
Entering Add-On into an empty tank or a change in the inflow entity type into a partially full tank.
Process
Note than a token executing this add-on process will be associated with the flow entity that is
entering the tank. Also, if the logic of the specified process includes any delays, then the inflow
rate into the tank will be halted until the process has completed.
Tank Level Rising - Process Instance Name Occurs when the contents level of the tank is rising above the tank's 'Low-Low' mark.
Above Low-Low
Mark Add-On
Process
Tank Level Rising - Process Instance Name Occurs when the contents level of the tank is rising above the tank's 'Low' mark.
Above Low Mark
Add-On Process
Tank Level Rising - Process Instance Name Occurs when the contents level of the tank is rising above the tank's 'Mid' mark.
Above Mid Mark
Add-On Process
Tank Level Rising - Process Instance Name Occurs when the contents level of the tank is rising above the tank's 'High' mark.
Above High Mark
Add-On Process
Tank Level Rising - Process Instance Name Occurs when the contents level of the tank is rising above the tank's 'High-High' mark.
Above High-High
Mark Add-On
Process
Tank Level Rising - Process Instance Name Occurs when the contents level of the tank has reached the tank's maximum volume or weight
Tank Full Add-On capacity.
Process
Tank Level Falling Process Instance Name Occurs when the contents level of the tank is falling below the tank's 'High-High' mark.
- Below High-High
Mark Add-On
Process
568 / 815
Process
Tank Level Falling Process Instance Name Occurs when the contents level of the tank is falling below the tank's 'High' mark.
- Below High Mark
Add-On Process
Tank Level Falling Process Instance Name Occurs when the contents level of the tank is falling below the tank's 'Mid' mark.
- Below Mid Mark
Add-On Process
Tank Level Falling Process Instance Name Occurs when the contents level of the tank is falling below the tank's 'Low' mark.
- Below Low Mark
Add-On Process
Tank Level Falling Process Instance Name Occurs when the contents level of the tank is falling below the tank's 'Low-Low' mark.
- Below Low-Low
Mark Add-On
Process
Tank Level Falling Process Instance Name Occurs when the contents level of the tank has fallen to zero and the tank has thus become empty.
- Tank Empty Add-
On Process
C ontents Ranking First In First Out, Last In The static rule used to rank flow entities located in this tank's 'StorageTank.C ontents' queue.
Rule First Out, Smallest value
First, Largest Value First
C ontents Ranking Expression The expression used with a 'SmallestValueFirst' or 'LargestValueFirst' ranking rule.
Expression
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
569 / 815
Simio Reference Guide
C ontainerEntity
The C ontainerEntity object may be used to model a type of moveable container (e.g., barrels or totes) for carrying flow entities representing
quantities of fluids or other mass.
The C ontainerEntity provides an easy way to define a discrete entity type that represents a type of container for carrying flow. In terms of object
design, this object is essentially a simplified combination of the ModelEntity and Tank objects.
State assignments can be made when the C ontainerEntity becomes full or empty. Additionally, the Add-On Process Triggers allow additional logic
to be specified when using the C ontainerEntity.
Listed below are the properties of the ContainerEntity:
Property Valid Entry Description
C apacity Unit Volume, Weight The unit type to be used for specifying the physical capacity of a container entity of this type.
Type
Initial Expression The initial maximum physical volume that can be stored in a container entity of this type.
Volume
C apacity
Initial Weight Expression The initial maximum physical weight that can be stored in a container entity of this type.
C apacity
Initial Repeat Group The intial contents present in a container entity of this type when the entity is created.
C ontents
Entity Type Entity Instance The initial content entity type.
(Initial Name
C ontents)
Unit Type Volume, Weight The unit type to be used for specifying the initial content quantity.
(Initial
C ontents)
Quantity Expression The initial content quantity.
(Initial
C ontents)
Initial Expression The initial desired speed value for entities of this type.
Desired
Speed
Initial Network Element The initial network of links used by entities of this type to travel between node locations. This includes the
Network Property default 'Global' network and 'No Network (FreeSpace)'.
Network Exit & Re-enter, When traveling on a network, the default method used by objects of this type to turn around at a node in
Turnaround Rotate in Place, order to move in the opposite direction on a bidirectional link. The 'Turnaround Method' property of a
Method Reverse Network element may also be used to override this default on a network-by-network basis.
Free Space Direct To The behavior used to steer an entity of this type when traveling in free space to a destination.
Steering Destination, Follow
Behavior Network Path If 'Direct To Destination' will steer an entity in a straight line to its destination.
Possible
'Follow Network Path If Possible' will prefer to steer an entity along a path following its currently assigned
network, staying within the boundries of the drawn path width. However, if no followable network path exists
to the entity's destination then the entity will be steered in a straight line. Note: In order to use this steering
behavior, make sure the entity's travel mode is set to 'Free Space Only'.
Update Expression The time interval between updates checking an entity's adherence to the network path.
Interval
Avoid True or False Indicates whether the steering behavior will attempt to avoid collisions with other entities that are following
C ollisions the same network path.
Initial Priority Expression The initial priority value for entities of this type.
Initial Sequence Property An initial destination sequence that entities of this type use for routing purposes.
Sequence
On C ontainer Repeat Group, Optional state assignments when the contents level of a container entity of this type has reached the
Full (State Assignments container's maximum volume or weight capacity.
Assignments)
On C ontainer Repeat Group, Optional state assignments when the contents level of a container entity of this type has fallen to zero and
Empty (State Assignments the container has thus become empty.
Assignments)
Run Process Instance Occurs when the simulation run is initialized.
Initialized Name
Add-On
Process
Run Ending Process Instance Occurs when the simulation run is ending.
Add-On Name
Process
C ontainer Process Instance Occurs when the contents level of a container entity of this type has reached the container's maximum
Full Add-On Name volume or weight capacity.
Process
C ontainer Process Instance Occurs when the contents of a container entity of this type has fallen to zero and the container has thus
Empty Add- Name become empty.
On Process
Initial Numeric The initial number of objects of this type in the system at the beginning of the simulation run. Entities are
Number in initially located in free-space at the object instance location.
System
Maximum Numeric The maximum number of objects of this type that can simultaneously be in the system. If this limit is
Number in exceeded then a runtime error is generated.
System
570 / 815
System
Destroyable True or False Specifies whether objects of this type can be destroyed using the Destroy Step.
C an Transfer True or False Indicates whether entities of this type are by default allowed to transfer into and out of fixed objects via
In & Out of those object's external input / output nodes.
Objects
Due Date Expression The expression used to return a 'due date' value for an entity of this type.
Expression
Gantt True or False An expression evaluated at run time to determine if the entity should appear in the Entity Gantt window.
Visibility
C ontents First In First Out, The static rule to rank flow entities located in the 'FlowC ontainer.C ontents' queue of a container entity of this
Ranking Rule Last In First Out, type.
Smallest Value
First, Largest Value
First
C ontents Expression The expression used with a 'SmallestValueFirst' or 'LargestValueFirst' ranking rule.
Ranking
Expression
C urrent Size State Variable The optional name of a state variable that indexes into the object's associated symbol list, and whose value
Index will automatically resize the object to match the size of the indexed symbol.
Size.Length Numeric The initial graphical length of the entity.
Size.Width Numeric The initial graphical width of the entity.
Size.Height Numeric The initial graphical height of the entity.
Volume Numeric The initial logical volume of the object in cubic meters. If blank, the initial logical volume will be the implicit
volume defined by the Size. At runtime, the ratio between the logical volume and the Size implicit volume
will be kept constant.
Weight Numeric The weight density of an entity of this type in kilograms per cubic meter. The default value for density is 1
Density kilogram per cubic meter. At runtime, a change to Weight or Volume will make a change in the other to
make sure Density remains constant.
C urrent Expression An expression that returns a value for the index in the list for the current symbol to display.
Symbol
Index
Random True or False If true, each new object will be randomly assigned a symbol from the associated list of symbols.
Symbol
C urrent Expression An expression that returns the numeric index or string name of the current animation of the active symbol.
Animation
Index If the expression is not defined, returns an index that is out of the range of the list of animations, or a name
of an animation that does not exist, Simio will fallback to using the action specified in the Default Animation
Action.
Default Expression Indicates if and how Simio will animate objects that don't have an explicit animation set via the C urrent
Animation Animation Index expression.
Action
None indicates no action will be taken. Moving indicates actively moving entities will be animated with any
available forward movement animations from the active symbol. MovingandIdle indicates actively moving
entity and idle objects will be animated with any available forward movement or idle animations from the
active symbol.
571 / 815
Simio Reference Guide
Filler
The Filler object may be used to fill any type of entity that has one or more container locations, including an entity type defined using the
C ontainerEntity object. The properties, structure, and process logic design of the Filler is very similar to a Server from the Standard Library. The
Filler has InputBuffer, Processing, and OutputBuffer station locations, all of which are animated within the Facility window. C ontainer entities
transfer through those stations in sequence, entering the Filler using its ‘C ontainerInput’ BasicNode and exiting the Filler using its ‘Output’
TransferNode. The primary difference between a Filler and Server is that instead of a ‘Processing Time’ delay incurred by an entity that uses a
Server, the processing delay incurred by an entity at a Filler is instead determined by the time it takes to fill the entity’s container location(s). The
flow stream that fills containers at the Filler is pulled from the Filler’s ‘FlowInput’ FlowNode.
The Filler object may fill the C ontainerEntity object provided in the Flow Library, or a user specified type of entity (or transporter) object that has
containers. If the entity that enters the Filler has a C ontainer element, then that container can be filled. If an entity enters the Filler object and it
has no container locations, then the filling time will be 0.0 and a warning will be displayed to alert the user that there may be a modeling logic
issue. Similarly, if an entity enters the Filler object and its container location(s) are already full, then the filling time will be 0.0. The Filler object
provides two types of Fill Target. A container can either be filled until full, or a Desired Quantity can be added to each container using an
expression. Note that if the Desired Quantity expression does not return a positive quantity, then the filling time will be 0.0. Thus the user might
use a desired quantity expression that returns a value of 0.0 if the current container is not desired to be filled (e.g., don’t fill a container unless it
already contains flow contents of a certain type). The current flow container location being filled by a Filler may be referenced in an expression by
looking at is C urrentFlowC ontainer state variable. If the Fill Target Type is ‘Add Specific Quantity’, then the filling operation will be considered
completed when the desired quantity is added or the container becomes full, whichever event occurs first. Note that if using work schedules and
the Filler goes off-shift, then the current filling operation is immediate suspended and will then be resumed when the Filler goes back on-shift. This
immediate suspension of all current processing activity is consistent with Simio’s other ‘Processor’ type objects.
A Filler may have failures, which are specified within the Reliability section of the Properties window. State assignments can be made upon
entering and exiting the Filler. Secondary Resources may be seized and/or released by the entity upon entering the Filler, and before and after
filling occurs. The Add-On Process Triggers allow additional logic to be specified when using the Filler. The Filler Add-On Process Triggers are
unique in that there are processes available for Before Processing and After Processing (as with Server), but there are also processes for Filling
C ontainer and Filled C ontainer, as these may be triggered multiple times for an entity object entering the Filler with multiple containers.
An entity processing at a Filler may NOT be interrupted with the Interrupt step.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the Filler.
Listed below are the properties of the Filler:
Property Valid Entry Description
C apacity Type Fixed, Work Schedule The availability of this Filler for processing. 'Fixed' indicates that this Filler is always available.
'WorkSchedule' indicates that this Filler follows a work schedule defining its 'On-Shift, Off-
Shift' availability over time.
Work Schedule Work Schedule Name The name of the schedule that specifies the capacity for this resource over time.
Work Day Repeat Group, Work Day Work Day schedule exceptions specific to this resource.
Exceptions Exceptions
Work Period Repeat Group, Work Period Work Period schedule exceptions specific to this resource.
Exceptions Exceptions
Ranking Rule First In First Out, Last In First The static ranking rule used to order entities waiting to be allocated capacity of this Filler
Out, Smallest Value First, object.
Largest Value First
Ranking Expression The expression used with a 'Smallest Value First' or 'Largest Value First' ranking rule.
Expression
Dynamic None, or one of several Indicates whether this resource, when its capacity becomes available, dynamically selects the
Selection Rule Dynamic Selection Rules next seize request from its statically ranked allocation queue using a dynamic selection rule.
Transfer-In Time Expression The time required to transfer an entity into this object.
Fill Target Type Fill Until Full, Add Specific Indicates whether the Filler object will fill each container until full or add a specific desired
Quantity quantity.
Quantity Unit Volume, Weight The unit type to be used for specifying the desired quantity to add to a container.
Type
Desired Quantity Expression The desired quantity to add to a container. Filling activity will end once this volume or weight
quantity has been added or the container has become full, whichever event occurs first.
Stop Early Event Valid Event Name Optional name of an event whose occurrence will trigger the Filler object to stop filling a
Name container early, before reaching the specified fill target.
Input Buffer Integer >= 0 The number of entities that can be held in this Filler object's input buffer.
C apacity
Output Buffer Integer >=0 The number of entities that can be held in this Filler object's output buffer.
C apacity
Failure Type No Failures, C alendar Time Specifies whether this Filler object has failures that affect the object's availability, and the
Based, Processing C ount method used to trigger the failure occurrences. See the Reliability page for additional
Based, Event C ount Based, information on Failures.
Processing Time Based
Failure Event Event Instance Name The name of the event which determines when the next failure occurs.
Name
Uptime Between Expression The uptime between failure occurrences. This property may be specified using a random
Failures sample form a distribution.
C ount Between Expression The count between failure occurrences. This property may be specified using a random
Failures sample from a distribution.
Time To Repair Expression The time required to repair a failure when one occurs. This property may be specified using a
random sample from a distribution.
On Entering Repeat Group, Assignments Optional state assignments when an entity is entering the Filler object.
(State
Assignment)
Before Exiting Repeat Group, Assignments Optional state assignments when an entity is ready to exit the Filler object.
(State
Assignment)
572 / 815
Assignment)
Object Type Specific, From List The method for specifying the object to be seized and held for the while an entity is being
(Secondary processed.
Resource for
Processing)
Object Name Object Instance Name The name of the object to be seized.
(Secondary
Resource for
Processing)
Object List Name Object List Instance Name The name of the object list from which an object will be selected to be seized.
(Secondary
Resource for
Processing)
Selection Goal Smallest Distance, Largest The goal for selecting the object to seize.
(Secondary Distance, Preferred Order,
Resource for Smallest Value, Largest Value,
Processing) Random
Selection Expression The expression evaluated for each object that is a candidate to seize. In the expression, use
Expression the keyword C andidate to reference an object in the collection of candidates to be seized
(Secondary (e.g., C andidate.Object.C apacity.Remaining).
Resource for
Processing)
Request Move None, To Node Indicates whether a move to a specified location will be requested from the seized resource.
(Secondary Processing will not be able to start until the resource has arrived to the requested location.
Resource for
Processing)
Destination Node Node Instance Name The name of the specific node location that the seized resource will be requested to move to.
(Secondary
Resource for
Processing)
Keep Reserved If Expression On processing completion, an optional condition indicating whether to keep the resource
(Secondary reserved for possible later reuse by the same entity. Other entities will be unable to use the
Resource for resource unless the reservation is cancelled.
Processing)
Note that when an entity is attempting to select a resource from a group of candidates (e.g.,
from a list or from a population of some resource type), by default a preference will be given
to select a resource that has already been reserved by that entity irrespective of the
specified selection goal.
Reservation Expression If the Keep Reserved Condition is true, then an optional wait time before automatically
Timeout cancelling the reservation.
(Secondary
Resource for
Processing)
On Entering Repeat Group, Resource Secondary resource seizes required when an entity is entering the Filler object.
(Other Resource Seizes
Seizes)
Before Repeat Group, Resource Secondary resource seizes required once an entity has been allocated Filler capacity, but
Processing Seizes before entering (or ending transfer into) its processing station.
(Other Resource
Seizes)
After Processing Repeat Group, Resource Secondary resource seizes required after all possible container elements of an entity have
(Other Resource Seizes been filled and the entity is now about to attempt its exit from the Filler's processing station.
Seizes)
On Entering Repeat Group, Resource Secondary resource releases to be performed when an entity is entering the Filler object.
(Other Resource Releases
Releases)
Before Filling Repeat Group, Resource Secondary resource releases to be performed once an entity has been allocated Filler
(Other Resource Releases capacity, but before entering (or ending transfer into) its processing station.
Releases)
After Filling Repeat Group, Resource Secondary resource releases to be performed after all possible container elements of an
(Other Resource Releases entity have been filled and the entity is now about to attempt its exit from the Filler's
Releases) processing station.
Run Initialized Process Instance Name Occurs when the simulation run is initialized.
Add-On Process
Run Ending Add- Process Instance Name Occurs when the simulation run is ending.
On Process
Entered Add-On Process Instance Name Occurs immediately after an entity has entered this object and is about to start the 'Transfer-
Process In Time'.
Before Process Instance Name Occurs when an entity has been allocated Filler capacity, but before entering (or ending
Processing Add- transfer into) the Filler's processing station.
On Process
Filling C ontainer Process Instance Name Occurs when the Filler is about to start filling a container element of the current entity in its
Add-On Process processing station.
Filled C ontainer Process Instance Name Occurs when the Filler has finished filling a container element of the current entity in its
Add-On Process processing station.
After Processing Process Instance Name Occurs when all possible container elements of an entity have been filled, and the entity is
Add-On Process now about to attempt its exit from the Filler's processing station.
Exited Add-On Process Instance Name Occurs when an entity has exited this object.
Process
Failed Add-On Process Instance Name Occurs when this object has failed.
Process
573 / 815
Process
Repaired Add-On Process Instance Name Occurs when a failure is repaired at this object.
Process
Evaluating Seize Process Instance Name Occurs when this Filler object is evaluating whether to accept or reject a request to seize
Request Add-On capacity of the filler. In the executed decision process, assigning a value of less than or equal
Process Triggers to '0' to the executing token's ReturnValue state (Token.ReturnValue) indicates that the seize
request is rejected.
On Shift Add-On Process Instance Name Occurs when the object goes 'on shift' because of its specified work schedule.
Process
Off Shift Add-On Process Instance Name Occurs when the object goes 'off shift' because of its specified work schedule.
Process
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go
Usage to Results -> Logs to view logged data.
Transfer-In Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer into this
C onstraints C ondition fixed object via external input nodes. If specified as 'Default', then the Can Transfer In & Out
of Objects property setting for the entity type will determine whether an entity can perform a
transfer into the object.
Transfer-In Expression The condition required to allow an entity to transfer into this fixed object via an external input
C ondition node.
Transfer-Out Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer out of this
C onstraints C ondition fixed object via external output nodes. If specified as 'Default', then the Can Transfer In &
Out of Objects property setting for the entity type will determine whether an entity can
perform a transfer out of the object.
Transfer-Out Expression The condition required to allow an entity to transfer out of this fixed object via an external
C ondition output node.
Expected Setup Expression The expression used to estimate an expected setup time for an entity at this fixed object.
Time Expression
Expected Expression The expression used to estimate an expected operation time for an entity at this fixed object.
Operation Time
Expression
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
574 / 815
Simio Reference Guide
Emptier
The Emptier object may be used to empty any type of entity that has one or more container locations, including an entity type defined using the
C ontainerEntity object. The properties, structure, and process logic design of the Emptier is very similar to a Server from the Standard Library.
The Emptier has InputBuffer, Processing, and OutputBuffer station locations, all of which are animated within the Facility window. C ontainer
entities transfer through those stations in sequence, entering the Emptier using its ‘Input’ BasicNode. Discrete entities then exit the Emptier using
its ‘C ontainerOutput’ TransferNode while flow stream exits the Emptier using the 'FlowOutput' FlowNode. The primary difference between an
Emptier and Server is that instead of a ‘Processing Time’ delay incurred by an entity that uses a Server, the processing delay incurred by an
entity at an Emptier is instead determined by the time it takes to empty the entity’s container location(s).
The Emptier object may empty the C ontainerEntity object provided in the Flow Library, or a user specified type of entity (or transporter) object
that has containers. If the entity that enters the Emptier has a C ontainer element, then that container can be emptied. If an entity enters the
Emptier object and it has no container locations, then the emptying time will be 0.0 and a warning will be displayed to alert the user that there
may be a modeling logic issue. Similarly, if an entity enters the Emptier object and its container location(s) are already empty, then the emptying
time will be 0.0. The Emptier object provides two types of Empty Target. A container can either be emptied until empty, or a Desired Quantity can
be removed from each container using an expression. Note that if the Desired Quantity expression does not return a positive quantity, then the
emptying time will be 0.0. Thus the user might use a desired quantity expression that returns a value of 0.0 if the current container is not desired
to be emptied (e.g., don’t empty a container unless it already contains flow contents of a certain type). The current flow container location being
emptied by an Emptier may be referenced in an expression by looking at is C urrentFlowC ontainer state variable. If the Empty Target Type is
‘Remove Specific Quantity’, then the emptying operation will be considered completed when the desired quantity is removed or the container
becomes empty, whichever event occurs first. Note that if using work schedules and the Emptier goes off-shift, then the current emptying
operation is immediate suspended and will then be resumed when the Emptier goes back on-shift. This immediate suspension of all current
processing activity is consistent with Simio’s other ‘Processor’ type objects.
An Emptier may have failures, which are specified within the Reliability section of the Properties window. State assignments can be made upon
entering and exiting the Emptier. Secondary Resources may be seized and/or released by the entity upon entering the Emptier, and before and
after emptying occurs. The Add-On Process Triggers allow additional logic to be specified when using the Emptier. The Emptier Add-On Process
Triggers are unique in that there are processes available for Before Processing and After Processing (as with Server), but there are also
processes for Emptying C ontainer and Emptied C ontainer, as these may be triggered multiple times for an entity object entering the Emptier with
multiple containers.
An entity processing at a Emptier may NOT be interrupted with the Interrupt step.
The Work Day and Work Period Exceptions pages provides additional information on work schedule exceptions for the Emptier.
Listed below are the properties of the Emptier:
Property Valid Entry Description
C apacity Type Fixed, Work Schedule The availability of this Emptier. 'Fixed' indicates that this Emptier is always available.
'WorkSchedule' indicates that this Emptier follows a work schedule defining its 'On-Shift, Off-
Shift' availability over time.
Work Schedule Work Schedule Name The name of the schedule that specifies the capacity for this resource over time.
Work Day Repeat Group, Work Day Work Day schedule exceptions specific to this resource.
Exceptions Exceptions
Work Period Repeat Group, Work Period Work Period schedule exceptions specific to this resource.
Exceptions Exceptions
Ranking Rule First In First Out, Last In First The static ranking rule used to order entities waiting to be allocated capacity of this Emptier
Out, Smallest Value First, object.
Largest Value First
Ranking Expression The expression used with a 'Smallest Value First' or 'Largest Value First' ranking rule.
Expression
Dynamic None, or one of several Indicates whether this resource, when its capacity becomes available, dynamically selects the
Selection Rule Dynamic Selection Rules next seize request from its statically ranked allocation queue using a dynamic selection rule.
Transfer-In Time Expression The time required to transfer an entity into this object.
Empty Target Empty All C ontents, Remove Indicates whether the Emptier object will empty all contents from each container or remove a
Type Specific Quantity specific desired quantity.
Quantity Unit Volume, Weight The unit type to be used for specifying the desired quantity to remove from a container.
Type
Desired Quantity Expression The desired quantity to remove from a container. Emptying activity will end once this volume
or weight quantity has been removed or the container has become empty, whichever event
occurs first.
Stop Early Event Valid Event Name Optional name of an event whose occurrence will trigger the Emptier object to stop emptying
Name a container early, before reaching the specified empty target.
Input Buffer Integer >= 0 The number of entities that can be held in this object's input buffer.
C apacity
Output Buffer Integer >=0 The number of entities that can be held in this object's output buffer.
C apacity
Failure Type No Failures, C alendar Time Specifies whether this Emptier object has failures that affect the object's availability, and the
Based, Processing C ount method used to trigger the failure occurrences. See the Reliability page for additional
Based, Event C ount Based, information on Failures.
Processing Time Based
Failure Event Event Instance Name The name of the event which determines when the next failure occurs.
Name
Uptime Between Expression The uptime between failure occurrences. This property may be specified using a random
Failures sample form a distribution.
C ount Between Expression The count between failure occurrences. This property may be specified using a random
Failures sample from a distribution.
Time To Repair Expression The time required to repair a failure when one occurs. This property may be specified using a
random sample from a distribution.
On Entering Repeat Group, Assignments Optional state assignments when an entity is entering the Emptier object.
(State
Assignment)
575 / 815
Before Exiting Repeat Group, Assignments Optional state assignments when an entity is ready to exit the Emptier object.
(State
Assignment)
Object Type Specific, From List The method for specifying the object to be seized and held for the while an entity is being
(Secondary processed.
Resource for
Processing)
Object Name Object Instance Name The name of the object to be seized.
(Secondary
Resource for
Processing)
Object List Name Object List Instance Name The name of the object list from which an object will be selected to be seized.
(Secondary
Resource for
Processing)
Selection Goal Smallest Distance, Largest The goal for selecting the object to seize.
(Secondary Distance, Preferred Order,
Resource for Smallest Value, Largest Value,
Processing) Random
Selection Expression The expression evaluated for each object that is a candidate to seize. In the expression, use
Expression the keyword C andidate to reference an object in the collection of candidates to be seized
(Secondary (e.g., C andidate.Object.C apacity.Remaining).
Resource for
Processing)
Request Move None, To Node Indicates whether a move to a specified location will be requested from the seized resource.
(Secondary Processing will not be able to start until the resource has arrived to the requested location.
Resource for
Processing)
Destination Node Node Instance Name The name of the specific node location that the seized resource will be requested to move to.
(Secondary
Resource for
Processing)
Keep Reserved If Expression On processing completion, an optional condition indicating whether to keep the resource
(Secondary reserved for possible later reuse by the same entity. Other entities will be unable to use the
Resource for resource unless the reservation is cancelled.
Processing)
Note that when an entity is attempting to select a resource from a group of candidates (e.g.,
from a list or from a population of some resource type), by default a preference will be given
to select a resource that has already been reserved by that entity irrespective of the
specified selection goal.
Reservation Expression If the Keep Reserved Condition is true, then an optional wait time before automatically
Timeout cancelling the reservation.
(Secondary
Resource for
Processing)
On Entering Repeat Group, Resource Secondary resource seizes required when an entity is entering the Emptier object.
(Other Resource Seizes
Seizes)
Before Repeat Group, Resource Secondary resource seizes required once an entity has been allocated Emptier capacity, but
Processing Seizes before entering (or ending transfer into) its processing station.
(Other Resource
Seizes)
After Processing Repeat Group, Resource Secondary resource seizes required after all possible container elements of an entity have
(Other Resource Seizes been emptied and the entity is about to attempt its exit from the Emptier's processing station.
Seizes)
On Entering Repeat Group, Resource Secondary resource releases to be performed when an entity is entering the Emptier object.
(Other Resource Releases
Releases)
Before Filling Repeat Group, Resource Secondary resource releases to be performed once an entity has been allocated Emptier
(Other Resource Releases capacity, but before entering (or ending transfer into) its processing station.
Releases)
After Filling Repeat Group, Resource Secondary resource releases to be performed after all possible container elements of an
(Other Resource Releases entity have been emptied and entity is now about to attempt its exit from the Emptier's
Releases) processing station.
Run Initialized Process Instance Name Occurs when the simulation run is initialized.
Add-On Process
Run Ending Add- Process Instance Name Occurs when the simulation run is ending.
On Process
Entered Add-On Process Instance Name Occurs immediately after an entity has entered this object and is about to start the
Process 'TransferIn Time'.
Before Process Instance Name Occurs when an entity has been allocated Emptier capacity, but before entering (or ending
Processing Add- transfer into) the Emptier's processing station.
On Process
Emptying Process Instance Name Occurs when the Emptier is about to start filling a container element of the current entity in
C ontainer Add- its processing station.
On Process
Emptied Process Instance Name Occurs when the Emptier has finished emptying a container element of the current entity in
C ontainer Add- its processing station.
On Process
After Processing Process Instance Name Occurs when all possible container elements of an entity have been emptied, and the entity is
576 / 815
Add-On Process now about to attempt its exit from the Emptier's processing station.
Exited Add-On Process Instance Name Occurs when an entity has exited this object.
Process
Failed Add-On Process Instance Name Occurs when this object has failed.
Process
Repaired Add-On Process Instance Name Occurs when a failure is repaired at this object.
Process
Evaluating Seize Process Instance Name Occurs when this Emptier object is evaluating whether to accept or reject a request to seize
Request Add-On capacity of the emptier. In the executed decision process, assigning a value of less than or
Process Triggers equal to '0' to the executing token's ReturnValue state (Token.ReturnValue) indicates that the
seize request is rejected.
On Shift Add-On Process Instance Name Occurs when the object goes 'on shift' because of its specified work schedule.
Process
Off Shift Add-On Process Instance Name Occurs when the object goes 'off shift' because of its specified work schedule.
Process
Log Resource True or False Indicates whether usage related events for this resource are to be automatically logged. Go
Usage to Results -> Logs to view logged data.
Transfer-In Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer into this
C onstraints C ondition fixed object via external input nodes. If specified as 'Default', then the Can Transfer In & Out
of Objects property setting for the entity type will determine whether an entity can perform a
transfer into the object.
Transfer-In Expression The condition required to allow an entity to transfer into this fixed object via an external input
C ondition node.
Transfer-Out Disable, Default, C ustom Indicates the type of constraints used to determine whether entities can transfer out of this
C onstraints C ondition fixed object via external output nodes. If specified as 'Default', then the Can Transfer In &
Out of Objects property setting for the entity type will determine whether an entity can
perform a transfer out of the object.
Transfer-Out Expression The condition required to allow an entity to transfer out of this fixed object via an external
C ondition output node.
Expected Setup Expression The expression used to estimate an expected setup time for an entity at this fixed object.
Time Expression
Expected Expression The expression used to estimate an expected operation time for an entity at this fixed object.
Operation Time
Expression
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
577 / 815
Simio Reference Guide
ItemT oFlow C onverter
The ItemToFlowC onveyor object is used to model a process that converts entities representing discrete items into flow entities representing
quantities of fluids or other mass.
The flow rate out of the ItemToFlowC onverter is regulated by its 'Output' flow node. Discrete item entities enter the object through its 'Input' basic
node and are then processed into flow.
When creating flow, the user has the option to either copy attributes from the input discrete entity, or to create new flow with no copying. If
copying, then all possible states, table references, and destination settings are copied over. See the Flow Entity Creation Method property for
more information.
The conversion logic properties are evaluated in the context of the input. Thus, for the ItemToFlowC onverter, the conversion logic properties can
be based on attributes of the discrete item entity.
The discrete item input buffer capacity for the ItemToFlowC onverter object can be infinite, limited, or specified as ‘0’ to not have any buffer. If a
limited buffer or no buffer situation, then blocking can occur.
The converter may stop producing outflow early before reaching flow quantity specified by using the Stop Early Triggers repeating properties.The
converter may also may require the removal and disposal of generated flow upon particular event triggers and conditions. These are specified in
the Purge Contents Triggers and Clean In-Place Triggers repeating properties.
Listed below are the properties of the ItemToFlowConverter:
Property Valid Entry Description
Flow Quantity Volume, Weight The unit type to be used for specifying the flow quantity per discrete item.
Unit Type
Flow Quantity Expression The amount of outflow created from a discrete item entity.
Per Item
Stop Early Repeat Group, Triggers Optional event-driven triggers that will immediately cause the ItemToFlowC onverter object to stop
Triggers producing outflow for the current discrete item entity early, before reaching the specified flow quantity
per discrete item. The converter's flow container will be put into an empty state and ready to process
the next discrete item.
Triggering Valid Event Name The name of the event whose occurrence will trigger the ItemToFlowC onverter object to stop producing
Event Name outflow for the current discrete item early, before reaching the specified flow quantity per discrete item.
(Stop Early The converter's flow container will be put into an empty state and ready to process the next discrete
Triggers) item.
C ondition Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be true to
(Stop Early trigger the ItemToFlowC onverter object to stop early.
Triggers)
Flow Output Same As Item, Valid The entity type of the created outflow.
Entity Type Entity Type
Item Ranking First In First Out, Last The static ranking rule used to order discrete item entities to be processed into flow.
Rule In First Out, Smallest
Value First, Largest
Value First
Item Ranking Expression The expression used with a 'Smallest Value First' or 'Largest Value First' ranking rule.
Expression
Flow Entity C opy Item The method used to create a flow entity. If copying item attributes, then all possible state values,
C reation Attributes,C reate New destination settings, and table references will be copied from the processed discrete item entity to the
Method (No C opying) created flow entity.
Purge Repeat Group, Triggers Optional event-driven triggers that will immediately remove and dispose of any generated flow waiting
C ontents to exit the ItemToFlowC onverter object, putting the converter's flow container into an empty state and
Triggers cancelling any further outflow for the discrete item entity whose conversion was in-process.
Triggering Valid Event Name The name of the event whose occurrence will indicate that any generated flow waiting to exit the
Event Name converter object is to be immediately removed and disposed of, putting the converter's flow container
(Purge into an empty state and cancelling any further outflow for the discrete item entity whose conversion was
C ontents in-process.
Triggers)
C ondition Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be true to
(Purge purge the converter's flow container.
C ontents
Triggers)
C lean In-Place Repeat Group, Triggers Optional event-driven triggers that will immediately remove and dispose of any generated flow waiting
Triggers to exit the converter object and then suspend further processing until a specified cleaning time has
elapsed.
Triggering Valid Event Name The name of the event whose occurrence will indicate that the converter's flow container is to be
Event Name cleaned.
(C lean In-
Place Triggers)
C ondition Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be true to
(C lean In- trigger a cleaning operation.
Place Triggers)
C leaning Time Specific, Sequence The method used to specify the time required to clean the converter's flow container.
Type (C lean Dependent
In-Place
Triggers)
C leaning Time Expression The time required to clean the converter's flow container.
(C lean In-
Place Triggers)
Operation Expression The attribute expression to be evaluated for each cleaning operation and whose 'from/to' value changes
Attribute will determine the sequence-dependent times required to clean the converter's flow container.
(C lean In-
Place Triggers)
578 / 815
Place Triggers)
Initial C leaning Expression The time required to clean the converter's flow container if the first cleaning operation or if the
Time (C lean changeover state stored for the previous operation has been cleared.
In-Place
Triggers)
C hangeover C hangeover Matrix The name of the changeover matrix that defines the sequence-dependent cleaning times.
Matrix (C lean Name
In-Place
Triggers)
Input Buffer Integer >= 0 The number of discrete item entities that can be held in this object's input buffer.
C apacity
On Item Repeat Group, Optional state assignments when a discrete item entity is entering this ItemToFlowC onverter object.
Entering (State Assignments
Assignment)
Run Initialized Process Instance Occurs when the simulation run is initialized.
Add-On Name
Process
Run Ending Process Instance Occurs when the simulation run is ending.
Add-On Name
Process
Item Entered Process Instance Occurs immediately after a discrete item entity has entered this ItemToFlowC onverter object.
Add-On Name
Process
Processing Process Instance Occurs when a discrete item entity is about to be processed into outflow.
Item Add-On Name
Process
C reated Flow Process Instance Occurs when flow content has been created from a discrete item entity, just before the flow entity
Add-On Name attempts to start exiting the ItemToFlowC onverter object.
Process
Flow Exited Process Instance Occurs when the outflow created from a discrete item entity has fully exited this ItemToFlowC onverter
Add-On Name object.
Process
C leaning Process Instance Occurs when a clean-in-place operation is beginning at the converter.
C onverter Name
Add-On
Process
C leaned Process Instance Occurs when a clean-in-place operation is finishing at the converter.
C onverter Name
Add-On
Process
Transfer-In Disable, Default, Indicates the type of constraints used to determine whether entities can transfer into this fixed object
C onstraints C ustom C ondition via external input nodes. If specified as 'Default', then the Can Transfer In & Out of Objects property
setting for the entity type will determine whether an entity can perform a transfer into the object.
Transfer-In Expression The condition required to allow an entity to transfer into this fixed object via an external input node.
C ondition
Report True or False Specifies if statitsics are to be automatically reported for this object.
Statistics
579 / 815
Simio Reference Guide
Flow T oItemC onverter
The FlowToItemC onverter object used to model a process that converts flow entities representing quantities of fluids or other mass into entities
representing discrete items.
The flow rate into the FlowToItemC onverter is regulated by its 'Input' flow node. Discrete item entities exit the object from its 'Output' transfer
node.
When creating discrete entities, the user has the option to either copy attributes from the flow, or to create new discrete entities with no copying.
If copying, then all possible states, table references, and destination settings are copied over. See the Item Entity C reation Method property for
more information.
The conversion logic properties are evaluated in the context of the input. Thus, for the FlowToItemC onverter object, the conversion logic
properties can be based on the attributes of the new inflow entity.
The discrete item output buffer capacity for the FlowToItemC onverter object can be infinite, limited, or specified as ‘0’ to not have any buffer. If a
limited buffer or no buffer situation, then blocking can occur.
The converter may stop waiting for inflow and create a discrete item earlier than the flow quantity specified by using the Stop Early Triggers
repeating properties. The converter may also may require the removal and disposal of inflow collected upon particular event triggers and
conditions. These are specified in the Purge Contents Triggers and Clean In-Place Triggers repeating properties.
Listed below are the properties of the FlowToItemConverter:
Property Valid Entry Description
Flow Quantity Volume, Weight The unit type to be used for specifying the flow quantity per discrete item.
Unit Type
Flow Quantity Expression The amount of inflow required to create a discrete item entity.
Per Item
Stop Early Repeat Group, Optional event-driven triggers that will immediately cause the FlowToItemC onverter object to stop waiting
Triggers Triggers for additional inflow and create the next discrete item entity early, using whatever inflow that has
accumulated in the converter's flow container but before reaching the specified flow quantity per discrete
item.
Triggering Event Valid Event The name of the event whose occurence will trigger the FlowToItemC onverter object to stop waiting for
Name (Stop Name additional inflow and create the next discrete item entity early, using whatever inflow that has accumulated
Early Triggers) in the converter's flow container but before reaching the specified flow quantity per discrete item.
C ondition (Stop Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be true to
Early Triggers) trigger the FlowToItemC onverter object to stop early.
Item Output Same As Inflow, The entity type of the created discrete items.
Entity Type Valid Entity Type
Item Entity C opy Flow The method used to create a discrete item entity. If copying flow attributes, then all possible state values,
C reation Method Attributes,C reate destination settings, and table references will be copied from the accumulated flow entity to the created
New (No discrete item entity.
C opying)
Purge C ontents Repeat Group, Optional event-driven triggers that will immediately remove and dispose of any inflow collected by the
Triggers Triggers converter object for creating the next discrete item entity, putting the converter's flow container back into an
empty state.
Triggering Event Valid Event The name of the event whose occurrence will indicate that any inflow collected by the converter object is to
Name (Purge Name be immediately removed and disposed of, putting the converter's flow container back into an empty state.
C ontents
Triggers)
C ondition (Purge Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be true to
C ontents purge the converter's flow container.
Triggers)
C lean In-Place Repeat Group, Optional event-driven triggers that will immediately remove and dispose of any inflow collected by the
Triggers Triggers converter object for creating the next discrete item entity and then suspend new inflow until a specified
cleaning time has elapsed.
Triggering Event Valid Event The name of the event whose occurrence will indicate that the converter's flow container is to be cleaned.
Name (C lean In- Name
Place Triggers)
C ondition (C lean Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be true to
In-Place trigger a cleaning operation.
Triggers)
C leaning Time Specific, The method used to specify the time required to clean the converter's flow container.
Type (C lean In- Sequence
Place Triggers) Dependent
C leaning Time Expression The time required to clean the converter's flow container.
(C lean In-Place
Triggers)
Operation Expression The attribute expression to be evaluated for each cleaning operation and whose 'from/to' value changes will
Attribute (C lean determine the sequence-dependent times required to clean the converter's flow container.
In-Place
Triggers)
Initial C leaning Expression The time required to clean the converter's flow container if the first cleaning operation or if the changeover
Time (C lean In- state stored for the previous operation has been cleared.
Place Triggers)
C hangeover C hangeover The name of the changeover matrix that defines the sequence-dependent cleaning times.
Matrix (C lean Matrix Name
In-Place
Triggers)
Output Buffer Integer >= 0 The number of discrete item entities that can be held in this object's output buffer.
C apacity
580 / 815
On New Inflow Repeat Group, Optional state assignments when a new inflow is entering this FlowToItemC onverter object, which may be
Entering (State Assignments either the first inflow to begin creation of a new discrete item or a change in the inflow entity type.
Assignment)
Before Item Repeat Group, Optional state assignments when a discrete item entity is ready to exit this FlowToItemC onverter object.
Exiting (State Assignments
Assignment)
Run Initialized Process Instance Occurs when the simulation run is initialized.
Add-On Process Name
Run Ending Add- Process Instance Occurs when the simulation run is ending.
On Process Name
New Inflow Process Instance Occurs when a new inflow is starting to enter this FlowToItemC onverter object, which may be either the first
Entering Add-On Name inflow to begin creation of a new discrete item or a change in the inflow entity type.
Process
Note that a token executing this add-on process will be associated with the flow entity that is entering the
converter. Also, if the logic of the specified process includes any delays, then the inflow into the converter
will be paused until the process has completed.
C reate Item Process Instance Occurs when a discrete item entity has been created from accumlulated inflow, just before the entity
Add-On Process Name attempts to enter the output buffer or exit the FlowToItemC onverter object.
Item Exited Process Instance Occurs when a discrete item entity has exited this FlowToItemC onverter object.
Add-On Process Name
C leaning Process Instance Occurs when a clean-in-place operation is beginning at the converter.
C onverter Add- Name
On Process
C leaned Process Instance Occurs when a clean-in-place operation is finishing at the converter.
C onverter Add- Name
On Process
Transfer-Out Disable, Default, Indicates the type of constraints used to determine whether entities can transfer out of this fixed object via
C onstraints C ustom external output nodes. If specified as 'Default', then the Can Transfer In & Out of Objects property setting
C ondition for the entity type will determine whether an entity can perform a transfer out of the object.
Transfer-Out Expression The condition required to allow an entity to transfer out of this fixed object via an external output node.
C ondition
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
581 / 815
Simio Reference Guide
Flow Node
A FlowNode object is a node specifically designed to regulate the flow of entities representing quantities of fluid or other mass.
C ommon applications of a FlowNode object include use as an 'Input' or 'Output' node for controlling flow into or out of another object (such as an
object representing a tank). A FlowNode may be used to model a flow control point in a network of links.
The output entity type of the outflow from the node can be dynamically changed by assigning the flow node’s
FlowRegulator.C urrentDesiredOutputEntityType' state variable.
The FlowNode allows optional dynamic updating of either maximum flow rate and/or the output yield factor of the node’s flow regulator. Values
are updated based on the Update Interval time specified. Note that the first update is done to the initial flow rate and/or initial yield value at
simulation time 0, and then updated every Update Interval time specified.
Please refer to the SimBit FlowC oncepts for models using the FlowNode. Note that FlowNodes are also incorporated into the FlowSource, FlowSink
and Tank objects.
Listed below are the properties of the FlowNode:
Property Valid Entry Description
Flow Rate Volume Flow Rate, The unit type to be used for specifying the maximum flow rate of the node's flow regulator.
Unit Type Weight Flow Rate
Initial Expression The initial maximum flow rate allowed by the node's flow regulator.
Maximum
Flow Rate
Initial Expression The initial output yield factor for the regulator. This factor is entered as a ratio of output to inflow, and may
Output be used to scale the flow into the regulator such that there is a physical loss or gain represented in the
Yield regulator's output flow.
Factor
Initial Entity Name Optional property specifying the initial desired entity type of the outflow produced by the node's flow
Output regulator. If unspecified, then the output flow entity type will be automatically determined by the inflow entity
Entity types.
Type
Regulator True, False Specifies whether the node's flow regulator is enabled when the system is initialized.
Initially
Enabled
Flow SingleFlow (No The mode used by the node's flow regulator to control the inflow from inbound links.
C ontrol Merging), Merge Flow
Mode
(Input
Flow
C ontrol)
Inbound By Link Weight, By The rule used by the node's flow regulator to prioritize inflows from inbound links. If the rule specified is 'By
Link Rule Flow Priority Link Weight', then the flow entity on the inbound link with the largest selection weight will be selected first. If
the rule is specified as 'By Flow Priority', then the flow entity with the largest priority value (regardless of the
link used) will be selected first.
Switch State Variable Name Optional discrete variable to use as a switch control mechanism for dynamically changing the current
C ontrol inbound link selection. If this property is specified, then the selection weight expressions of the node's
Variable inbound links will be reevaluated whenever the switch control variable's value changes in order to change
(Input priority to the link with the now largest weight. The inbound link selection weight expressions, as a typical
Flow modeling approach, are recommended to be based on the switch control variable's current value. For
C ontrol) example, enter link selection weight expressions such as 'MySwitchC ontrolVar == 1', 'MySwitchC ontrolVar
== 2', etc.
Flow Expression The expression used to return the priority value of an inflow request at the node.
Priority
Expression
Merge Any Entity Type, Specifies the match conditions required to merge inflow requests at this node into a single output flow. If the
Matching Same Entity Type matching rule is specified as 'Any Entity Type', then all inflows may be merged together regardless of entity
Rule type. If the matching rule is specified as 'Same Entity Type', then only the inflows of the same entity type
may be merged.
Merge Proportional Based on The allocation rule used by the node's flow regulator to merge inflow from inbound links.
Allocation Inflow Rates,
Rule Preferred Order By
Link Weight,
Proportional Based on
Link Weights
Flow Single Flow (No The mode used by the node's flow regulator to control outflow to outbound links.
C ontrol Splitting), Split Flow
Mode
(Output
Flow
C ontrol)
Outbound By Link Weight, The rule used by the node's flow regulator to send outflows to outbound links. If the rule is specified as 'By
Link Rule Shortest Path Link Weight', then the outbound link with the largest selection weight will be selected by a flow entity. If the
rule is specified as 'Shortest Path' and the flow entity has an assigned destination, then the next link in the
shortest pah to that destination will be selected. For any flow entity that does not have an assigned
destination, then the 'By Link Weight' is always assumed.
Switch State Variable Name Optional discrete variable to use as a switch control mechanism for dynamically changing the current
C ontrol outbound link selection. If this property is specified, then the selection weight expressions of the node's
Variable outbound links will be reevaluated whenever the switch control variable's value changes in order to change
(Output priority to the link with the now largest weight. The outbound link selection weight expressions, as a typical
Flow modeling approach, are recommended to be based on the switch control variable's current value. For
C ontrol) example, enter link selection weight expressions such as 'MySwitchC ontrolVar == 1', 'MySwitchC ontrolVar
== 2', etc.
582 / 815
Split Evenly If Possible, The allocation rule used by the node's flow regulator to split outflow to outbound links.
Allocation Preferred Order By
Rule Link Weight, If the rule is specified as ‘Evenly If Possible’, then the flow regulator will distribute flow as evenly as possible
Proportional Based On to the node’s outbound links while still maximizing total outflow.
Link Weights,
Proportional Based On If the rule is specified as ‘Preferred Order By Link Weight’, then the flow regulator will distribute flow in
Link Weights If priority order to the node’s outbound links while still maximizing total outflow. The outbound link with the
Possible largest selection weight will be selected first, and if that link cannot accept the full output then overflow will
be sent to the outbound link with the next largest selection weight and so forth.
If the rule is specified as ‘Proportional Based On Link Weights’, then the flow regulator will proportionally
distribute flow to the node’s outbound links using the ratios of the link selection weights. This rule will not
maximize total outflow, but rather, will reduce the output to all links as necessary to maintain the specified
ratios.
If the rule is specified as ‘Proportional Based On Link Weights If Possible’, then the flow regulator will
distribute flow as proportionally as possible to the node’s outbound links using the ratios of the link selection
weights, while still adjusting when necessary to maximize total outflow. For example, if there are three
outbound links designated to receive 20%, 30%, and 50% of the flow and the outbound link designated for
50% becomes blocked, then this rule will automatically adjust so that the other two outbound links will
receive 40% and 60% of the flow until the blockage is cleared.
583 / 815
Simio Reference Guide
Flow C onnector
The FlowC onnector object may be used to define a direct, zero travel distance connection from one flow node location to another.
Please refer to the SimBit FlowC oncepts for models using the FlowC onnector.
Listed below are the properties of the FlowConnector:
Property Valid Entry Description
Selection Weight Expression The weight expression for this link if using a 'By Link Weight' rule to select an outbound link from a node.
Report Statistics True or False Specifies if statitsics are to be automatically reported for this object.
584 / 815
Simio Reference Guide
P ipe
The Pipe object may be used to define a flow connection from one flow node location to another where flow travel time and pipeline volume is of
significant interest. NOTE: There are known issues with the New Inflow Entering options when multiple flow entities of the same entity type arrive
into a single pipe; currently, the state assignments and add-on processes are triggered for each unique flow entity.
The pipe may be automatically emptied upon particular event triggers and conditions. These are specified in the Purge Contents Triggers
repeating properties.
State assignments can be made when the Pipe has a new inflow entity type or is full or empty. Additionally, the Add-On Process Triggers allow
additional logic to be specified when using the Pipe object.
Purge C ontent Repeat Optional event-driven triggers that will immediately remove and dispose any flow present in the pipe, putting the
Triggers Group, pipe into an empty state.
Triggers
Triggering Event Valid Event The name of the event whose occurence will indicate that all flow present in the pipe is to be immediately
Name (Purge Name removed and disposed of, putting the pipe into an empty state.
C ontents
Triggers)
C ondition (Purge Expression Optional condition to be evaluated whenever the triggering event occurs, and which must also be true to purge
C ontents the pipe's contents.
Triggers)
Selection Weight Expression The weight expression for this link if using the 'By Link Weight' rule to select an outbound link from a node.
On New Inflow Repeat Optional state assignments when a new inflow is starting to enter this Pipe object, which may be either the first
Entering (State Group, inflow to an empty pipe or a change in the inflow entity type.
Assignments) Assignments
On Pipe Full Repeat Optional state assignments when the pipe's volume has become completely filled.
(State Group,
Assignments) Assignments
On Pipe Empty Repeat Optional state assignments when the pipe's volume has become empty.
(State Group,
Assignments) Assignments
Run Initialized Process Occurs when the simulation run is initialized.
Add-On Process Instance
Name
Run Ending Add- Process Occurs when the simulation run is ending.
On Process Instance
Name
New Inflow Process Occurs when a new inflow is starting to enter this Pipe object, which may be either the first inflow into an empty
Entering Add-On Instance pipe or a change in the inflow entity type.
Process Name
Note that a token executing this add-on process will be associated with the flow entity that is entering the pipe.
Also, if the logic of the specified process includes any delays, then the inflow rate into the pipe will be paused
until the process has completed.
Pipe Full Add-On Process Occurs when the pipe's volume has become completely filled.
585 / 815
Pipe Full Add-On Process Occurs when the pipe's volume has become completely filled.
Process Instance
Name
Pipe Empty Add- Process Occurs when the pipe's volume has become empty.
On Process Instance
Name
Report Statistics True or Specifies if statitsics are to be automatically reported for this object.
False
C ross Section Ellipse, Specifies the geometric shape of this link's cross section.
Shape Rectangle,
Trapezoid
586 / 815
Simio Reference Guide
P roject Library
The Project Library is a list of objects (i.e. models) that are contained within a project. The Project Library is found in the Libraries window, from
within the Facility window. It appears under the Standard Library and it can be expanded vertically in the case of a large library. When a new
model is created, it appears in the Project Library. A model can be dragged into the Facility window of another model from the Project Library. If
the model appears grey in the Project Library, this indicates that it cannot be placed into the active Facility window because that particular model
is currently active and you cannot drag a model into itself.
The Project Library
For information on how to create a new object for the Project Library, see C reating New Objects.
The models within the Project Library can also be viewed in the Project window, where they can be renamed, edited and deleted. To navigate to
the Project window, select the name of the project within the Navigation window. You can also edit a model by selecting the model from within the
Navigation window.
A user can import a library of objects from another project into the current project and they will appear in the Project Library and therefore
available for use in the current project. To import a library, select the Load Library icon from the Project Home ribbon. Select an .spf file and the
models from that selected project will then appear in a new Library called MySimioProject. Models from this imported library can be copied or
subclassed into the current project from within the Project window. They can also be subclassed with a simple right click from the Project Library
window.
587 / 815
Simio Reference Guide
ModelEntity
You will find one ModelEntity automatically created within a new Project Library. The ModelEntity is the default entity definition in your project. A
user does not need to drag it into the Facility window. A ModelEntity called DefaultEntity is already part of the Project and can therefore be
created by a Source object or with the C reate Step without having an instance in the Facility window. However, if you would like to change the
symbol of the Entity or change any of the properties of the instance, you need to drag a ModelEntity into the Facility window from the Project
Library. Additional instances of ModelEntity can also be dragged into the model.
For information on the difference between Entities and Tokens, see the Tokens and Entities help page.
Initial Network The network of links used by objects of this type to travel between node locations. This includes the default 'Global'
Network Element network and 'No Network (FreeSpace)'.
Property
Network Exit & Re- When traveling on a network, the default method used by objects of this type to turn around at a node in order to
Turnaround enter, Rotate move in the opposite direction on a bidirectional link. The 'Turnaround Method' property of a Network element may
Method in Place, also be used to override this default on a network-by-network basis.
Reverse
Free Space Direct To The behavior used to steer an entity of this type when traveling in free space to a destination.
Steering Destination,
Behavior Follow Network 'Direct To Destination' will steer an entity in a straight line to its destination.
Path If
Possible 'Follow Network Path If Possible' will prefer to steer an entity along a path following its currently assigned network,
staying within the boundries of the drawn path width. However, if no followable network path exists to the entity's
destination then the entity will be steered in a straight line. Note: In order to use this steering behavior, make sure
the entity's travel mode is set to 'Free Space Only'.
Update Expression The time interval between updates checking an entity's adherence to the network path.
Interval
Avoid True or False Indicates whether the steering behavior will attempt to avoid collisions with other entities that are following the
C ollisions same network path.
588 / 815
C ollisions same network path.
Initial Expression The initial priority value for objects of this type.
Priority
Initial Sequence An initial destination sequence that objects of this type use for routing purposes.
Sequence Property
Initial Numeric The initial number of objects of this type in the system at the beginning of the simulation run. Entities are initially
Number in located in free-space at the object instance location.
System
Maximum Numeric The maximum number of objects of this type that can simultaneously be in the system. If this limit is exceeded
Number in then a runtime error is generated.
System
Destroyable True or False Specifies whether objects of this type can be destroyed using the Destroy Step.
Initial C ost Expression The initial value of the C ost state for an object of this type, which stores the total cost that has been allocated to
the object.
Initial C ost Expression The initial value of the C ost.Rate parameter for an object of this type, which indicates a cost per unit time that is to
Rate be allocated to the object.
C an True or False Indicates whether entities of this type are by default allowed to transfer into and out of fixed objects via those
Transfer In object's external input / output nodes.
& Out of
Objects
Due Date Expression The expression used to return a 'due date' value for an entity of this type.
Expression
Gantt True or False An expression evaluated at run time to determine if the entity should appear in the Entity Gantt window.
Visibility
C urrent State Variable The optional name of a state variable that indexes into the object's associated symbol list, and whose value will
Size Index automatically resize the object to match the size of the indexed symbol.
Size.Length Numeric The initial graphical length of the entity.
Size.Width Numeric The initial graphical width of the entity.
Size.Height Numeric The initial graphical height of the entity.
Volume Numeric The initial logical volume of the object in cubic meters. If blank, the initial logical volume will be the implicit volume
defined by the Size. At runtime, the ratio between the logical volume and the Size implicit volume will be kept
constant.
Weight Numeric The weight density of an entity of this type in kilograms per cubic meter. The default value for density is 1 kilogram
Density per cubic meter. At runtime, a change to Weight or Volume will make a change in the other to make sure Density
remains constant.
C urrent Expression An expression that returns a value for the index in the list for the current symbol to display.
Symbol
Index
Random True or False If true, each new object will be randomly assigned a symbol from the associated list of symbols.
Symbol
C urrent Expression An expression that returns the numeric index or string name of the current animation of the active symbol.
Animation
Index If the expression is not defined, returns an index that is out of the range of the list of animations, or a name of an
animation that does not exist, Simio will fallback to using the action specified in the Default Animation Action.
Default Expression Indicates if and how Simio will animate objects that don't have an explicit animation set via the C urrent Animation
Animation Index expression.
Action
None indicates no action will be taken. Moving indicates actively moving entities will be animated with any available
forward movement animations from the active symbol. MovingandIdle indicates actively moving entity and idle
objects will be animated with any available forward movement or idle animations from the active symbol.
589 / 815
Simio Reference Guide
Entity R outing and Movement
Entity Routing
Entities can be routed in Simio in a number of different ways, such as using Sequences, going to specific nodes or following along on paths
and using their Selection Weights to determine where to go next. Entity routing is generally determined by the TransferNodes that the
entities pass through. The Entity Destination Type property determines how the entity will travel when it leaves the node. Read this
TransferNode help page for more detailed information on how to determine how the entity will travel through the system.
590 / 815
Simio Reference Guide
Entity Size and Volume
Entities have a number of characteristics, including Picture, Size, Volume, Weight and Density. Within the Project Library, the ModelEntity object is
typically used to place an Entity type within the Facility window. Once an ModelEntity (named DefaultEntity once placed) is in the Facility window,
the user can change its various characteristics.
Making up the entity's 'Size' characteristic are three dimensions, Length, Width, and Height, found under the 'General / Physical
C haracteristics' section of properties of the entity. By default, those are 0.5 x. 0.5 x 0.25 meters, respectively. Therefore the implicit Size volume
of an entity is 0.0625 cubic meters. These characteristics can be referenced (or changed within an Assign step) by using the
ModelEntity.Size.Length, ModelEntity.Size.Width and ModelEntity.Size.Height states of the entity. The implicit Size volume calculated is referenced
by the state ModelEntity.Size.
The entity also includes a state named Volume, which can be specified within the 'General / Physical C haracteristics' section of properties for the
entity. If not specified, the model will use the Size calculation of volume as the ModelEntity.Volume state. If specified, then this
ModelEntity.Volume state is the logical volume of the entity. The ratio of the Size volume to the logical Volume is kept constant during the
simulation run. In other words, if you change one value, you will see the other immediately change as well. The ModelEntity.Volume may be
changed during the simulation run by using an Assign step.
The entity has a Density characteristic, which has an initial value specified through the 'General / Physical C haracteristics' section of properties
of the entity. The default value for the density is '1' Kilograms per C ubic Meter. Density is not a state of the entity and therefore, cannot be
changed during the simulation run. If the Weight of an entity changes, the Volume of that entity will change to keep a constant Density. Likewise,
if the Volume of the entity changes, the Weight will automcatically change to keep a constant Density.
The entity has a Weight state, referred to as ModelEntity.Weight, that can be changed during the simulation run. The entity's Weight is initially
calculated based on the Volume and Density specified.
Both Weight and Volume have an associated Rate, referred to as ModelEntity.Weight.Rate and ModelEntity.Volume.Rate, respectively. These rates
are initially set to '0' (in the appropriate units based on the Units Settings) and can be changed during the simulation run with an Assign step.
These rate states will automatically change the associated Weight or Volume of the entity over time.
ModelEntity.Weight and ModelEntity.Volume can both be monitored, which would be done through the ModelEntity object in the Navigation window
by placing a Monitor element within the Definitions window / Elements panel.
591 / 815
Simio Reference Guide
Assigning States
You might be familiar with the term “attribute” or “variable” from other software packages. In Simio, you’ll find States and Properties.
Properties of an object are the input parameters associated with that object. A Property holds a specific data type. It is a static input parameter
(e.g. processing time, batch size) for the object and does not change during the running of the simulation. Properties are used to send
information between objects (inputs and outputs) and they are also used for experimentation when a user wants to experiment with using
different input parameters for their model.
A State represents a numeric or string value that may change during the run. It is sometimes referred to as a State Variable because its value
can vary during the run. A State can be added to any object in your Project Library. When a State is added to the main model object, it can be
seen and accessed by all the objects within that main model. Therefore, it is similar to what is often referred to as a “global variable” in other
software packages. When a State is added to another object, such as the ModelEntity object, it is part of that object’s definition. Therefore, a
state on a ModelEntity is similar to what is often referred to as an “attribute” of each entity that is going through the system. For example, if you
add a Discrete State to the default ModelEntity object, called “MyC ustomState”, then each entity that enters the system will have MyC ustomState
on it and therefore can have a unique value assigned to that State. For example, a State on an entity might contain a value that specifies this
entity’s unique bar code, this entity’s due date or a number that will be used to identify which shipment this entity should go into. And the value of
the state can be updated or referenced during the run with the syntax ModelEntity.MyC ustomState, in an expression.
A common task in simulation is to assign values to a State within the model logic. In Simio, we provide a number of different ways to make
assignments. The easiest and most straightforward way to make an assignment to a State variable is to use the properties found under the State
Assignments category of each object. These properties provide an easy, straightforward way to make an assignment to a State when an entity is
either entering or exiting this object. As an alternative, you can use the Add-On Process triggers to execute a process, where you can use an
Assign Step, along with other logic, to make an assignment to a State.
Two Different Approaches for Making a State Assignment upon Entering the Server Object
592 / 815
Simio Reference Guide
Secondary R esources
Secondary Resources
Secondary resources are available within the Workstation object, as well as the Server, C ombiner and Separator objects in the Standard Library.
Within the Flow Library, the Filler and Emptier objects both contain secondary resources as well. A secondary resource is simply an additional
resource that may be seized and/or released to assist with processing at the object. Each of the objects mentioned has a 'primary' resource that
is included with the object that is used for processing. You may consider an operator, worker, tool or any other limited resource that is needed for
all or part of processing to be a secondary resource.
Within Workstations
There are secondary resources that may be used with the Workstation object. These resources are specified within the Other Requirements
section of properties for the Workstation and are allocated to the entity for specific processing tasks within the workstation. Any secondary
resources specified in this manner are allocated for setup, processing, teardown or all activities, based on the Activity Range property specified.
The activitites which the resources are used for are specified within the Secondary Resources repeating property editor. There are no options to
keep a resource 'reserved' within this section of Secondary Resources of a Workstation object.
Secondary Resources within a Workstation
Within Servers, C ombiners and Separators of the Standard Library and Filler and Emptier of the Flow Library
There are also secondary resources that can be used with the Server, C ombiner and Separator objects, as well as the Filler and Emptier within
the Flow Library. These resources are specified within the Secondary Resources section of properties for the object. The secondary resources
section of properties is broken up into three sections, including the 'Resource for Processing', 'Other Resource Seizes' and 'Other Resource
Releases'.
Within the 'Resource for Processing' section, any resource specified here will be seized before the entity begins processing within the object and
will be released once processing is complete. This can be a single resource or one from a list, and the properties are specified directly in the main
property window for the object. A resource that is specified as the 'Resource for Processing' will be seized before any resources specified in the
'Other Resource Seizes' / 'Before Processing' and will be released after any resources in the 'Other Resource Releases' / 'After Processing'.
Additionally, multiple resources can be specified for seizing / releasing at various other times within the object. For the Server and Separator, this
includes On Entering, Before Processing and After Processing. For the C ombiner, it includes On Parent Entering, Before Processing and After
Processing. Within each of these categories, the repeating property editor may be opened by pressing the small box to the right to enter multiple
resources to seize or release at the specified time.
Secondary resources allow the user the flexibility to 'carry' resources between objects. For example, you may seize an operator upon entering
Server1 and not release that operator within Server1. Then the entity continues through several other servers and finally releases the Operator
after processing at Server5.
Within any of the secondary resources sections, the resource seized may be 'reserved' if the Keep Reserved If property expression results in a
'True' or '1' type evaluation. See the Reservations page for more details about keeping resources reserved.
Secondary Resources within a Server
593 / 815
Listed below are the properties of the Other Resource Seizes:
Property Valid Entry Description
Object Specific, From List The method for specifying the resource object(s) to be seized.
Type
Object Object Instance Name The name of the resource object to be seized.
Name
Object List Object List Instance Name The name of the object list from which one or more resource objects will be selected to be
Name seized.
Selection Smallest Distance, Largest The goal for selecting resource objects to seize.
Goal Distance, Preferred Order,
Smallest Value, Largest Value,
Random
Selection Expression The expression evaluated for each resource that is a candidate to seize. In the expression, use
Expression the keyword C andidate to reference an object in the collection of candidates to be seized (e.g.,
C andidate.Object.C apacity.Remaining).
Request None, To Node Indicates whether a move to a specified location will be requested from the seized resource(s).
Move Server activity will not continue until all resources have arrived to the requested location.
Destination Node Instance Name The name of the specific node location that the seized resource(s) will be requested to move to.
Node
Move Expression The priority of the move request if a PlanVisit or SelectVisit step is used by the seized
Priority resource(s) to choose a visit destination from multiple candidates. If not specified, then this
property defaults to the processing entity's Priority state value.
Number of Expression The number of individual resource objects of which to seize capacity units.
Objects
Units Per Expression The number of capacity units to seize per resource object.
Object
Selection Expression An optional condition evaluated for each candidate resource that must be true for the object to
C ondition be eligible for seizing. In the condition, use the keyword 'C andidate' to reference an object in a
collection of candidates (e.g., C andidate.Object.C apacity.Remaining).
On Seized Process Instance Name Optional process that is executed by tokens associated with each seized resource.
Process
595 / 815
Simio Reference Guide
T ask Sequence - P rocessing T asks
For a Task Sequence, the Server, C ombiner and Separator objects allow you to model the processing of an individual task using one of the
following general process types:
Specific Time – The processing of the task is defined as a specific processing time. The task is considered finished once the time duration
has elapsed.
Process Name – The processing of the task is handled by executing a specified process name. The task is considered finished once the
token that was created to execute the invoked process has ended its processing.
Submodel – The processing of the task is handled by executing a part of the overall model that is defined elsewhere in the Facility
window. The task creates a new entity of a specified entity type and then sends that new entity to a specified node (the starting point for
the submodel). The task is considered finished once the entity that was created to execute the submodel has ended its processing (i.e.,
has been destroyed).
Specific Time
Specific Time as Process Type
If the Process Type property is specified as 'Specific Time', the entity will be delayed for that specific amount of time before it moves from the
processing station. This is the default behavior for the Server/C ombiner/Separator objects and only behavior for the Server in Simio sprint
versions prior to Simio 7.119 (and C ombiner/Separator prior to Simio 7.130).
The Process Type as 'Specific Time'
596 / 815
Process Name
If the Process Type property is specified as 'Task Sequence' and the Process Type within the particular Task is specified as 'Process Name', the
task is considered finished once the token that was created to execute the invoked process has ended its processing.
The Task Sequence Process Type as 'Process Name'
597 / 815
Submodel
If the Process Type property is specified as 'Task Sequence' and the Process Type within the particular Task is specified as 'Submodel', the task
creates a new entity of a specified entity type and then sends that new entity to a specified node (the starting point for the submodel). The task is
considered finished once the entity that was created to execute the submodel has ended its processing (i.e., has been destroyed).
The Task Sequence Process Type as 'Submodel'
Resource Requirements
Within each processing task, Simio also supports the definition of resource requirements, which includes specifying the resource that will be
seized and released for the task and whether the resource will be 'reserved' for additional tasks.
Note that the default values for the Keep Reserved If and Reservation Timeout properties (as shown below) are set to 'True' and 'Math.Epsilon'
respectively. If these property values are left unchanged by the user, then by default once the task is finished the entity will always momentarily
keep reserved the resource(s) that were seized to perform the task, just in case there happens to be an immediate next task whose specified
resource requirements will prefer to re-seize (continue using) the same resource(s).
If there is no immediate re-seize, then the resource reservation(s) will be automatically cancelled at the end of the same time step as the epsilon
reservation timeout period expires. This default behavior is intended to make it easy for the user to model the same task resource(s) being used
for multiple tasks that are performed consecutively.
The Resource Requirements for a Processing Task
598 / 815
Material Requirements
In addition to resource requirements for a given task, Simio also supports material requirements, which includes specifying the material (or bill of
materials) that will be consumed or produced for the task.
Note that an Action Type property with choices ‘C onsume’ or ‘Produce’ allows the user specify either material consumption required to start the
processing of the task or material production that occurs after the processing of the task is finished. The material consumption will occur after all
resources are seized, but before the Starting Task add-on process. The material production will occur after the Finished Task add-on process, but
before releasing any seized resources.
The Material Requirements for a Processing Task
599 / 815
Once the data table has been generated, data can be entered into the table. Within the Facility window, as shown below, once the Server has the
Process Type of 'Task Seqeuence', the Processing Tasks property will be visible. Right-clicking on the Processing Tasks property will allow the
user to 'Set Referenced Property' to the table named 'Table1'. The name 'Table1' will then appear within the Processing Tasks property field with a
green (reference) arrow. C licking on the ... button to the right will open the repeating property editor and the properties within this repeat group
will then automatically reference the table columns within Table1. Any column property that was previously deleted (because it would not be used
for whateever reason) will appear with the property default value.
Within the HealthC areC linic example (See Support ribbon / Examples), there are two servers in the system that help to process two different
600 / 815
types of entities. Data tables are used in this example to store the various information for specific process tasks, as can be seen in the picture
below. Relational tables and key columns are used within this example so that both Server objects reference the same data table for processing
task information, based on the patient (entity) type and activity (key).
Using Task Sequences with Data Tables - Multiple Resources and/or Materials for a Specific Task
Another example of using task sequences with data tables is within the SimBit ServersUsingTaskSequenceWithDataTables_FlowLine. This small
example takes the data table concept a bit further so that multiple resources (and/or materials) can be used within a single process task. Note
that, by default, each task in the Processing Tasks repeating properties has a single resource/resource list specification and single material
requirement. If multiple resources/workers are required for a particular task, the resource requirements can be stored in a separate data table
than that described above. This similar approach can also be taken for specifying multiple materials within a given task. Within an object using
the 'Task Sequence' option, the Other Task Sequence Options section of properties is available. The Task Resources Referenced Table Name and
Task Materials Referenced Table Name properties have pull down list of data tables. In the below example, the 'Task Resources' table stores
information regarding the multiple task resources for a given task. Within the Processing Tasks repeating properties, the Resource Requirements
properties will then reference a different table than the table that stores the individual task information. The tables must be relational with foreign
601 / 815
properties will then reference a different table than the table that stores the individual task information. The tables must be relational with foreign
key and key columns as shown in the SimBit documentation.
For more information on structuring Task Sequences, please refer to the Task Sequence element and Task Sequence - Discussion and Examples.
For SimBit examples that include Task Sequences, please refer to ServerUsingTaskSequence,
ServersUsingTaskSequenceWithDataTables_FlowLine, ServersUsingTaskSequenceWithDataTables_JobShop and
ServerUsingTaskSequenceWithWorkers. Additionally, the HealthC areC linic example includes task sequences using data tables, as noted in the
above discussion.
Listed below are the properties of the Processing Tasks Repeating Properties in Server/Combiner/Separator:
Property Valid Entry Description
Sequence Real Sequence number used to define the task precedence constraints. To model a task sequence that is
Number simply a serially ordered set of tasks, define the tasks with increasing sequence numbers (e.g., the first
task is numbered '10', the second task is numbered '20', and so forth). Shown if the Task Precedence
Method (Other Task Sequence Options) is 'SequenceNumberMethod'.
For a more in-depth discussion on task sequence numbering including examples of how to model
sequences with tasks processed in parallel, please refer to the Task Sequence element documentation.
ID Number Integer Unique integer identifier number for the task. Shown if the Task Precedence Method (Other Task
Sequence Options) is 'ImmediatePredecessorsMethod' or 'ImmediateSuccessorsMethod'.
Name Task Name Name field for the task.
Branch Type Always, C onditional, Indicates whether the task is always performed, whether it is instead treated as the first task of a
Probabilistic conditional or probabilistic branch in the process workflow.
C ondition or Expression The branch condition or probability specified as an expression. If a condition, then enter the logical
Probability condition. If a probability, enter the chance of selecting the task as a value between 0.0 (0%) and 1.0
(100%).
Process Type Specific Time, Process The method used to model the processing of a task.
Name, Submodel
Processing Expression The time required to perform the task.
Time
Process Process Instance Name The name of the process that will be executed in order to perform the task. The task will be considered
Name finished once this invoked process has ended.
Submodel Valid Entity Name The type of entity to be created that will be sent to the submodel. The task will be considered finished
Entity Type once this entity has ended its processing (i.e., has been destroyed).
Submodel Node Name The node that is the starting point for the submodel.
Starting
Node
602 / 815
Save Entity Reference State Optional entity reference state variable to save a reference to the original entity being processed at the
Original Variable server. C an be a state variable defined on the submodel entity, to allow easy access to submodel logic
Entity to the original entity's attributes.
Reference
Immediate Valid Integer ID Lists the ID numbers of the tasks which must be finished or cancelled before this task can start. To
Predecessors Numbers specify more than one predecessor, enter multiple task ID numbers separated by commas. Shown
when the Task Precedence Method is 'ImmediatePredecessorsMethod'.
Immediate Valid Integer ID Lists the ID numbers of the tasks which can't start until this task is finished or cancelled. To specify
Successors Numbers more than one successor, enter multiple task ID numbers separated by commas. Shown when the Task
Precedence Method is 'ImmediateSuccessorsMethod'.
Auto C ancel None,All Immediate Specifies the type of trigger (if any) that will automatically cancel the task. If the trigger type is 'All
Trigger Predecessors C ancelled Immediate Predecessors C ancelled', then the task will be automatically cancelled if all of its immediate
predecessors in the task sequence are cancelled (e.g., due to conditional or probabilistic branching).
For a more in-depth discussion of this option including examples, please refer to the Task Sequence
element documentation.
Object Type Specific, Select From List The method for specifying the resource object(s) to be seized.
Object Name Object Name The name of the resource object to be seized.
Object List Object List Name The name of the object list from which one or more resource objects will be selected to be seized.
Name
Selection Smallest Distance, The goal for selecting the resource object(s) to seize.
Goal Largest Distance,
Preferred Order, Smallest
Value, Largest Value,
Random
Request None, To Node Indicates whether a move to a specified location will be requested from the seized resource(s). The
Move task will not start until all resources have arrived to the requested location.
Number of Expression The number of individual resource objects to seize capacity units of.
Objects
Units Per Expression The number of capacity units to seize per resource request.
Object
Selection Expression An optional condition evaluated for each candidate resource that must be true for the resource to be
C ondition eligible for seizing. In the condition, use the keyword 'C andidate' to reference an object in the collection
of candidates (e.g., C andidate.Object.C apacity.Remaining)
Keep Expression Optional condition indicating whether to keep the released resource capacity reserved for possible later
Reserved If reuse by the same owner object. Other objects will be unable to seize the reserved capacity unless the
reservation is cancelled.
Note that when attempting to seize a resource from a group of candidates (e.g., from a list or from a
population of some resource type), by default a preference will be given to select resource(s) that have
already been reserved irrespective of the specified seize selection goal.
Reservation Expression If the released capacity is being kept reserved, an optional wait time before automatically cancelling
Timeout the reservation.
Action Type C onsume, Produce The type of material-related action required.
C onsumption Material, BillOfMaterials Indicates whether to consume a single material or a bill of materials. The material consumption will be
Type required to start the processing of the task.
Production Material, BillOfMaterials Indicates whether to produce a single material or a bill of materials. The material consumption will
Type occur after finishing the processing of the task.
Material Material Name The name of the material which is to be either specifically consumed or produced, or whose bill of
Name materials is to be consumed or produced.
Quantity Expression The quantity to be consumed or produced.
Production Expression An optional delay time after finishing the processing of the task until the produced material is actually
Delay Time added to the system.
Starting Task Process Instance Name Occurs when the processing of the task is about to begin.
Add-On
Process
Finished Task Process Instance Name Occurs when the processing of the task has been finished.
Add-On
Process
603 / 815
Simio Reference Guide
R eservations
Reservations for Resources (including Resource, Worker and Vehicle within the Standard Library)
The 'Reserve' capability is automatically incorporated into various Standard Library objects with the Secondary Resources options within Server,
C ombiner, and Separator. See the Keep Reserved If and Reservation Timeout properties in these objects. Reservation capability is also available
within the Secondary Resource options in the Filler and Emptier of the Flow Libary.
If there are multiple reservations for the same resource, then standard ranking and dynamic selections rules apply in terms of the order of who
(among the owners with reservations)gets to use the resource. Note that there is no limit on the number of active concurrent reservations for a
resource (i.e., you can have a 100 entities with reservations for the same resource at any given time). When a resource becomes available, if
there are active reservations then it will only allow an entity with an active reservation to seize it. If there happen to be multiple entities with
active reservations waiting in the resource's AllocationQueue trying to seize it, then the best entity with a reservation per the allocation queue’s
ranking rule and/or the resource’s dynamic selection rule will be the next entity to get the resource. For example, suppose Entity1 (Priority = 1),
Entity2 (Priority = 2), and Entity3 (Priority = 3) all are trying to seize Worker1[1]. But only Entity1 and Entity2 have reservations. If Worker1[1] is
released, it will look in its AllocationQueue for the next entity to seize it. Let’s suppose its ranking rule is ‘Largest Priority First’. Entity3 is the
highest ranked entity in its allocation queue, but that entity has no reservation so it can’t seize the worker. Both Entity1 and Entity2 have
reservations, so Entity2 is the next entity to get the worker because it has the highest priority among all the waiting entities with reservations.
When attempting a Seize or Ride step, the entity will prefer to immediately select a reserved resource. But if it cannot select that resource, then it
will simply select the best resource immediately available per the specified selection goal/rule at the Seize or Ride step. For example, suppose
an entity is trying to select a resource from a list that has Worker1[1], Worker2[1], and Worker3[1] using Preferred Order selection goal, and it
has a reservation for Worker1[1]. It will prefer to immediately seize Worker1[1] but if that worker is being used by someone else then the entity
will instead seize any available worker if possible using the specified Preferred Order selection goal. So if Worker2[1] is immediately available
then it will simply seize Worker2[1].
Additionally, within the Transfer node of any Standard Library object, if a Transporter is used for transfer (Worker/Vehicle), the Keep Reserved If
property is available to reserve the transporter upon dropping off an entity after transport. This then allows resources to be allocated for
transport to a Server, for example, reserved and used for processing at that Server and then reserved and used for transport to the next
destination. It is important to note that if a transporter has a ride capacity greater than 1 (default), the transporter will not be reserved by the
entity(s) riding on the transporter and a runtime warning will be displayed (see below).
Transfer Node - 'Keep Reserved If' True with Ride Capacity Greater than 1
While many objects include the ability for reservations, Simio also includes this capability within the Steps in the Processes window. The Reserve
step in a process may be used to arbitrarily reserve a resource’s capacity for possible later use. Reserved resource capacity is capacity that,
although unallocated, has been set aside for a specific future owner thus preventing its use by anyone else without a reservation. The UnReserve
step may be used to cancel any reservations for a resource made by a specified owner up to a desired number of reserved capacity units
cancelled.
604 / 815
Simio Reference Guide
T ally Statistics
Tally Statistics
Tally statistics are available within the BasicNode and TransferNode objects, as well as the Source, Sink, Server, C ombiner, Separator and
Workstation external nodes. Tally statistics can be specified when an object enters a node (On Entered) and when an object exits a node (On
Exited).
Within the repeating property editor, the user may select the situation when the tally statitstic will be calculated. The Tally If property determines
whether tallies are generated when an entity enters/exits the node, or when a transporter (vehicle or worker) enters/exits the node.
Alternatively, the tally may be generated when any object enters ('No C ondition') or when a specific condition is met ('C ustom C ondition').
Multiple tallies can be generated by simply specifying multiple rows in the repeat group, as shown below.
On Entering Tally Statistics
As with the Tally step within the Processes window, any tallies that are generated with the Tally Statistics section of an object must have an
associated Tally Statistic element defined within the Elements panel of the Definitions window. For example, in the above screen shot, the Tally
Statistic Names of 'Blue_In_Server' and 'Total_In_Server' must be defined.
With either basic or transfer type node, the On Entered tally statistics are generated prior to the 'On Entered' add on process and crossing
capacity (if specified) is allocated. The On Exited tally statistics are generated prior to releasing the crossing capacity (if specified) and Exited add
on process.
605 / 815
Simio Reference Guide
Add-on P rocess T riggers
Add-on Processes are a special case of processes. Add-on processes are typically defined by a user to help customize object behavior or add
specific behavior into a model. The objects in the Standard Library contain Add On Process triggers. When an Add On Process is defined in the
Add On Process trigger property of an object, when the object fires a particular event, the Add On Process is executed. The example below shows
a trigger called "C reated Entity". When the Source object creates an entity, an event is fired that this trigger picks up and if there is a process
defined in the "C reated Entity" Add On Process Trigger, it then executes the defined process.
How to Utilize the Add On Process Triggers of a Standard Object
Select the Object and the Process Trigger
Select the object in the Facility Window and then expand the Add-On Process Triggers list. C lick on the trigger that you would like to use
and select C reate New from the drop down list of that trigger.
Add Steps to the Process
C lick on the Processes tab and the new Add-On Process will appear in the window.
C lick and drag a Step into the Process between the beginning and end step instances. The functionality of this Step can be customized by
changing the properties in the Properties window in the lower right corner.
These images are from the Process Window of the new Add-On Process, with an Assign Step that assigns a new State Variable to the Entity.
606 / 815
Simio Reference Guide
R eliability
Reliability
The Reliability section of Properties window is included in the following Standard Library objects: Server, C ombiner, Separator, Workcenter,
Resource, Vehicle and C onveyor. This section allows the user to define failure and repair time information for the object. By default, there are no
failures when an object is initially placed in the Facility Window.
No Failures
If the Failure Type is set to 'No Failures', then failures will not occur for the specific object. By default, there are no failures for an object
when it is originally placed in the Facility Window.
Note:
The standard library objects are defined so that if they go off-shift during a repair, the repair time continues during the off-shift period. If the
user would like the repair time to stop during the off-shift period, the object should be subclassed and customized.
Examples
Example 1 - C alendar Time Based Failures
Reliability_Example 1
In this example, the Server may begin processing an entity at time 0.0 for 10 minutes. When the failure occurs at time 8 minutes, the entity
processing stops and the failure repair time begins for 2 minutes. Once the failure has been repaired at 10 minutes, the remaining 2 minutes of
the entity processing begins.
Example 2 - Event C ount Based Failures
607 / 815
Reliability_Example 2
In this example, the Server has event count based failures, based on the event called ‘Tool_C hange’. After this event has been called 10 times,
the failure will occur and will take between 3 to 5 minutes, based on a uniform distribution, to be repaired.
Example 3 - Processing C ount Based Failures
Reliability_Example 3
In this example, the Server has a processing count based failure based on a Uniform distribution between 50 and 100 entities. Therefore, once
that number of entities has completed processing through the Server, the failure will occur for a repair time based on a triangular distribution with
a mean of 2 minutes, mode of 4 minutes and maximum of 6 minutes.
608 / 815
Simio Reference Guide
W ork Day and W ork P eriod Exceptions
Work Day Exceptions and Work Period Exceptions are available when a Work Schedule is used for the Server, C ombiner, Separator, Workstation,
Resource, Worker and Vehicle. Exceptions override the repeating work schedule for the duration of the exception.
609 / 815
Listed below are the properties of the Work Period Exceptions:
Property Valid Entry Description
Start Time Valid Date and Time Specifies the starting date and time for this exception.
End Time Valid Date and Time Specifies the ending date and time for this exception.
Exception Type Downtime, GeneralException Specifies the exception type.
Value Real Specifies the capacity value to be used for the duration of this exception.
C ost Multiplier Real Specifies the cost multiplier to be used for the duration of this exception.
Description Expression Specifies an optional description for this exception.
610 / 815
Simio Reference Guide
C reating New O bjects
There a several ways to create new objects in Simio. Objects can be created from scratch by the user by selecting one of the Simio object
classes or or by using APIs. A more common and easier way to create a new object is to copy (or subclass) one of the Simio Standard Library
objects and use the standard logic as a base when customizing the logic for your own needs. Models from other libraries can also be subclassed
and used as a basis for creating a new object. Once a new object is created within the project, it can be added to models by dragging it from the
Project Library into the Facility window of a model. The Project Library is located below the Standard Object Library on the left side of the
interface.
It is worth noting here that Model and Object are used interchangably throughout this document. This is because in Simio a model is actually an
object that can be used inside of another model. And an object itself is a model because it has it's own internal logic and there might be other
objects inside of an object, which is why it can also be referred to as a model. Therefore, try to keep in mind that the Model and Object are one in
the same.
The main model within a project is usually a Fixed class object. The simplest way of adding logic to a model is by using the Standard Library
objects in this new Fixed C lass object. This is done by creating a new model and then placing objects from the Standard Libary into the Facility
window of the model. By placing a number of objects, such as Sources, Servers, C ombiners, Separators and Sinks, and connecting them with
various types of links, you can represent a wide variety of systems in a model.
An object definition has five primary components: properties, states, events, external view, and logic. There are three approaches to defining the
model logic for an object. One approach is to sub-class an existing object definition and then change/extend its behavior using processes. This
approach is typically used when there is an existing object that has behavior similar to the desired object, and can be “tweaked” in terms of
property names, descriptions, and behavior to meet the needs of the new object. A second approach is to create your model hierarchically using
a facility model. This approach can also be combined with the use of add-on processes to define custom behavior within the facility objects. This
approach is typically used for building up higher level facility components such a work center comprised of two machines, a worker, and tooling.
The third and most flexible approach is to create the object definition behavior from scratch using a process model. This is the approach that was
used to create the Standard Library. All three approaches are described below.
Creating an Object by Subclassing Another Object
Simio comes with a standard library of object models that are located in the Standard Object Libary and their behavior can be enhanced with
Add-On processes. If the desired behavior cannot be created by simply using Add On Processes, a user might need to customize the internal
process logic. This is done by first subclassing an object and then overriding the processes. An object can be subclassed from within the Project
window. Once an object is subclassed, a process must be Overridden, by selecting the Override icon in the ribbon, before any changes can be
made.
Subclassing a Standard Library Server from the Project Window
Models can also be subclassed from the Facility window by right clicking on the object in the library window, located on the left side of the
interface.
Subclassing from the Facility Window
611 / 815
Creating an Object by Copying or Cloning an Object from the Library
Selecting the Copy From Library to Edit button allows a user to choose a model from any attached library and copy it into their project, so it can
then be modified. You would use this option when you want to create a new object and want to use an existing object as a starting point. The
difference between this option and subclassing from the library is that when a change is made to the original object's definition, an object that
was copied is not updated with the new changes in the original object's definition. Whereas a subclassed object will inherit the changes to all
processes that were not "overriden".
Select the Clone From Library button allows a user to choose a model from any attached library and copy it into their project. This should be used
when the user wants to re-arrange where models live in different libraries. If the user would like to modify the objects, they should consider Copy
from Library to Edit or Subclass From Library.
Copying or Cloning from Library
612 / 815
The input and output nodes for the object whose logic is in the Facility window can also be automatically added to the External view. This is done
by right-clicking on the node and selecting either the 'Bind to New External Input Node' or 'Bind to New External Output Node' options, as shown
below.
Binding to External Nodes
Within the Definitions tab, External window, new nodes are placed that will be used to connect into and out of the newly defined model logic in the
Facility window. For external input nodes, the Node Class is specified as 'BasicNode', Input Logic Type as 'FacilityNode' and the Node Name is
automatically generated. For external output nodes, the Node Class is 'TransferNode' and the Input Logic Type is 'None'. It is important to note
that with the Transfer Node that is generated by using 'Bind to External Output Node', the node name is placed in the Facility window's node
Advanced Options area under the property Bound External Output Node. This can be seen in the example below.
IMPORTANT NOTE: An external node cannot be used as both external output node and external input node.
External Window
613 / 815
For an example of using building a new object with logic in the Facility window, refer to the SimBit FacilityModelWithinModel.
New Object Logic within the Processes Window
The most flexible approach is to create the object definition behavior from scratch using a process model. This is the approach that was used to
create the Standard Library.
Within Simio, we have provided a basis for new object logic within the Processes window, called a Processor. By selecting New Model > Fixed
Object > Processor from the Project Home tab, a new Fixed model is added, and it includes a Station and Input and Output Nodes. It also includes
a process for processing entities, as shown below. Additional logic would be added between the EndTransfer and Transfer steps within the
Processes window.
Processor
614 / 815
For an example of using building a new object with logic in the Processes window, refer to the SimBit ProcessModelWithinModel.
Objects created by Custom Code
Simio objects are created from Simio Processes, Steps and Elements. A user can create their own custom Steps and Elements from any .NET
language and then use these to create their own Simio objects. User created Steps, Element, Add-Ins, or Dynamic Selection Rules should be
placed in the [Simio Binary Directory]\UserExtensions\ directory. See the C ustom Simio Extensions page and C:\Program Files\Simio\Simio
API Reference Guide.chm for additional information on creating custom logic with code.
Anatomy of an Object
Object Types define core functionality. Object Types include fixed, link, node, agent, entity (agent) and Transporter (entity). An object type
defines a mode of behavior (e.g. provides a pathway between two nodes). An object model defines the actual behavior of the object within its
class (e.g. accumulating conveyor). You, as a user, can define a wide range of behaviors within each object class.
Properties (static) pass values into the model logic for the object. The properties for the object are shown in the Properties window, located on
the lower right side of the GUI. Standard Library Objects have a fixed number of properties that are important for the behavior of that object.
Sub-classed objects can include the original object properties and also any user-defined properties. All of the properties for a given object can be
found in the Properties panel in the Definitions window.
States (dynamic) change over time. States can be specified as Discrete, Level or Movement. The state names for a given model can be seen in
the States panel of the Definitions window. Additional states can be added in this panel as well. States can be referenced during the simulation
run as they dynamically change over time.
Events fire and trigger actions. Events can be added or changed within the Events panel of the Definitions window of an object.
External views define the object’s graphical appearance within a Facility window and entry and exit points for the object. When defining a new
model object or modifying a subclassed object, the external view is used to place the external nodes (entry / exit points), as well as the symbol
of the object and graphical queues. The External view is defined in the External panel within the Definitions window. By default, all objects placed
in the Facility window will be automatically shown in the External view. The right-click menu when an object is selected allows the user to turn off
the 'Externally Visible' option on an object by object basis.
Consoles depict the dynamic state over time. Status labels, plots and buttons can be placed in an object's console to graphically view the
simulation progress and states throughout the simulation run.
615 / 815
Simio Reference Guide
Using A C ustom O bject In A Model
After you’ve created a custom object, by either subclassing it from another object, copying it from another object or creating it from scratch, you
need to ensure that it is ready to be used inside of model (or another object). You should address the following things before using the object:
Properties
The object builder should decide what type of information the object (or model) should receive from the “outside”. In other words, what type of
information will the object need to get from the model that it is placed into. Or, perhaps you want to allow the modeler to be able to assign the
value of Processing Time or C apacity, for example. If so, properties need to be created for these parameters so that when this object is placed
into another model, the user can assign a different value to that property for each instance of this object that is placed.
Creating a Property So Users Can Input Data into Submodel
External View
The object builder should decide what this object (or model) will look like when it is placed into a model. This is controlled in the External View
under the Definitions window. If the object is built with other objects, the objects will all be visible in the External View by default. To set an object
to not be displayed in the external view, right click on that object in the Facility window and unselect Externally Visible. If the object is built with
processes only, the object builder will need to create an External View manually and must place External Input and Output Nodes. See the Entry
and Exit Points section below for additional information on this.
Entry and Exit Points
If entities or other types of objects will be entering this object (or model), the object builder should ensure that there is at least one entry point
and exit point defined. If this object is built with other objects, the entry and exit points are usually nodes. A node can be set up to be an entry
point by right clicking on that node in the Facility window and selecting 'Bind To External Input Node' and this will automatically create a new
External Input Node where entities can enter into this object. An exit node can be defined similarly by right clicking on an existing node in the
Facility window and selecting 'Bind To External Output Node'. If this object is built with only processes and no objects, the object builder will need
to create External Input and Output Nodes in the External View. This is done by clicking on the External Node icon in the ribbon and placing two
nodes into the External View. Make one of these nodes the entry point into the object by setting the Node Class property to Basic Node and the
Input Logic Type property to ProcessStation. Next, select the Station where the entities should go when they enter into this object. Make the other
node the exit point out of the object by setting the Node Class property to TransferNode and the Input Logic Type to the default of None.
Entry and Exit Points for Submodel
616 / 815
Data Tables
If the object (or model) contains data tables, the object builder will need to create Repeat Group properties that will have the exact same
structure as the data tables and will contain the same data. All the references in the model will then reference the new Repeat Group properties
instead of the Data Tables. This is because when you place this model (or object) inside another model, the Data Tables should live at the top
level model, instead of inside this submodel. This will allow the user to be able to see the data and the Tables and manipulate the data or bind the
tables to an outside source. By creating Repeat Group properties on the submodel and referencing these instead of the Data Tables, this allows
the user to pass data down into the submodel from the top level model. (Remember that information can only be passed into an object through
properties).
Before this object/model is placed inside another model, the user should export the data from each table to a .csv file. Next, the user should click
the 'C onvert to Repeat Group' icon in the ribbon to convert this table to a Repeat Group property. By clicking this, Simio automatically creates a
new Repeat Group property with the same structure as the table. It also changes all the references in the model to now reference this Repeat
Group, instead of the Table. And it renames the table so the _original is appended to the name. This model is no longer looking at this table for
data, but instead at the Repeat Group property.
Convert To Repeat Group Icon
The user will go to the new project (the top level model) and load the custom object into this new project so that it appears in the Project Library.
The user will place an instance of the object into the Facility window of the model. The user will then create new Data Tables in this model. To
assist in creating a Table with the same schema/structure as the table in the submodel, Simio gives the users the option to select available
Schemas from the drop down available with the Add Data Table icon. Select the schema of the Repeat Group from the submodel that was just
617 / 815
Schemas from the drop down available with the Add Data Table icon. Select the schema of the Repeat Group from the submodel that was just
placed into the model. A new Data table has been created and now the data can be imported from the .csv file. Import the data by clicking the
Import icon.
Uses Table Schema from SubModel
Next, the user will tell the Repeat Group property on the instance of the submodel to look at this new Data Table for data. C lick on the instance of
the submodel that was placed in the Facility window and find the new Repeat Group property. Enter a reference to the appropriate row in the Data
Table so that it maps the data from the Table into the Repeat Group. An important step that is often missed is that the Repeat Group itself must
be set to reference the Data Table, like the example below.
Map the Data Table into the Repeat Group property
This will send the data from the Data Table down into the submodel’s repeat group property so that the submodel can use this information in its
logic.
618 / 815
Simio Reference Guide
Versioning of Simio O bjects
Versioning of the objects is a 2 part process; editing the version numbers as well as the description of the changes. Note that these features are
available in Simio 6.100 or later.
Version Number
Versioning in Simio is done at the object level; libraries are not versioned. There are 2 version numbers used for a Simio object – a User Defined
Version and an Internal Version. The User Defined Version is editable by the Object developer. The Internal version is not.
To modify the User Defined Version of an object, bring up that object’s properties window. The User Defined Version (which is editable) is shown,
in addition to the un-editable Internal Version number. The User Defined Version can be any integer or an integer combination separated by a
period (ex: 21.4).
The Internal Version of a Simio object is automatically incremented each time a change is made to the object.
To view the existing version of an object, with an object placed in the Facility window, right click on the model and select Object References.
Below is an example of the window that will appear, displaying the User Defined Version and the Internal Version number.
619 / 815
Advanced Tip: In some unusual situations, an object in your project may behave erratically because it has gotten out of sync with the library it
came from. In these cases it may help to use Shift-C lick to enter this feature in edit mode. This will allow you to reset the Internal Version of the
object to 0 and reload a fresh definition of the object. To edit the existing version of an object, with the object placed in the Facility window, right-
click on Model and the shift-click on Object References. This will allow you to edit the Internal Version.
Documenting Object Changes
When a project that uses objects that have changed is loaded, an Object Updates Available dialog will appear. By clicking on the plus sign next to
the Source library and Object name, a description of the changes made will appear.
However, in order for a user to know that what changes have been made, these changes have to be added to the object. This is done via the
Describe C hanges button on the Edit ribbon of the library.
C licking on that option will bring up the C hange Description dialog shown below. Note that at this time it is not possible to tie in the version
number with the changes associated with that version.
620 / 815
Simio Reference Guide
Animation
Animation
In Simo, modeling and animation are done as a single step. You can layout your model with realistic spatial relations that accurately mimic your
real life system. The Facility window is a 3-D drawing space in which you place objects that represent the physical components of your system.
The appearance of these objects can be easily changed by altering the color of the default objects or replacing the objects with a symbol from the
large library of default symbols provided by Simio. Simio provides symbols in the following categories; buildings, equipment, medical, restaurant,
people, vehicles, trucks and other. But Simio does not limit the user to the symbols provided. The user can import their own images or download
from the Trimble 3D warehouse or Autocad. This feature allows you to incorporate symbols that provide a more realistic feel to your model.
Simio allows the user to add static symbols, labels and imported screen shots into the model as well. The user can easily add logic to the model
to change the appearance of objects and entities as they change states throughout the run. The ability to change the view and see the model
from a 3D perspective provides a excellent tool for presenting the real life view of the system. See the example models to see Simio animation
in use.
Status Labels, Status Plots, Status Pies, Floor Labels, C ircular Gauges, Linear Gauges, Stacked Bars and Buttons can be placed in the Facility
Window. They can also be attached to objects in the Facility Window. If they are attached to Entities or Transporters, they will travel with those
dynamic instances. They can be placed in the External and C onsole views as well. To see specific information about this features, see the C onsole
help page.
A user can create Named Views which is a saved view of the current position and orientation of the camera. These named views can then be
combined into a series of camera sequences, which can then be played back by the user. The user can also record an .avi video of the animation
of a model by using the Record Run Animation button. Named Views, camera sequences and .avi recording can all be found on the View ribbon.
621 / 815
Simio Reference Guide
Symbols
Symbols
A user can add animation components, such as attached queues and status labels, as well as download, import and create new symbols from the
Symbols tab ribbon. Symbols can be added as static objects within the Facility window or they can replace the standard Simio symbol of an
object. For example, to change the symbol of the Default Entity from a green triangular to a custom symbol, simply select the entity object and
then either select a symbol from the Simio symbol library, import a symbol or download a symbol from the Trimble 3D Warehouse.
Symbols Tab Ribbon
622 / 815
Downloading, Importing and Creating New Symbols
New Symbol Icon from the Project Home Tab
Downloading
A symbol can be downloaded from the Trimble 3D Warehouse. This is a site on the web that contains hundreds of thousands of 3D images that
you can incorporate into your model. To download a symbol, go to the Project Home tab in the ribbon menu and click on the New Symbol icon.
Select the option for Download Symbol and you will be connected to the Trimble 3D Warehouse. You must have an internet connection to access
this website.
After the symbol has been selected from the Trimble 3D Warehouse and the user downloads it, Simio will display the new symbol in an Import
pop up window.
Import Window after Downloading a Tank Symbol
623 / 815
The image is first shown in 2D but can also be viewed in 3D by clicking on the 3D icon in the top left corner of the import window. The large blue
arrow on the image shows the user which direction Simio will consider to be the front of this image. If the user wishes to rotate the symbol, the
Rotate icon provides options for rotating at 90, 10 or 1 degrees clockwise or counterclockwise.
The image of a person is displayed next to the symbol to provide a hint regarding the size of this symbol as compared with the size of a human in
the Simio application. The user can resize the symbol (in terms of meters) with the length, width and height boxes in the Object Size panel.
In addition to displaying the downloaded image in Simio, the Sketchup file is also stored in the \My Documents\My Simio3D Warehouse
Downloads directory of your computer. Trimble SketchUp (free download) can be used to customize an image (e.g. adding or removing
components or changing colors).
Importing
A symbol can be imported from a file, such as a symbol created in Trimble SketchUp or AutoC AD (*.dxf and *.dwg). AutoC AD is a very popular
standard supported by many products that features both 2D and 3D drawings. (Note: Not all products follow the standard closely so results may
vary on *.dxf/*.dwg files generated from programs other than AutoC AD.) Symbols can be imported from a .jpg file and the symbol will become a
2D image. Simio supports importing from a number of 3D formats, which can be viewed by selecting the All Items button when performing the
import for opening a particular type file.
To import a file, go to the Project Home tab in the ribbon menu and click on the New Symbol icon. Select the option for Import Symbol and find
the file to import. The symbol will be displayed in the Import Window and can be resized and rotated similar to a downloaded symbol discussed
above. Or if you'd like to import a symbol for an object, select the object and then click the Import Symbol icon in the Symbols ribbon menu. For
more information on importing animation symbols (e.g. people that walk, run, jump, etc.), refer to the Animating Moving Objects (Walking
People) page.
Exporting a Simio symbol and Using a Simio Symbol in another project
A symbol can be exported out of Simio. It is saved as a Simio specific format(.ssf). The symbol can then be used in another project. In order for
the symbol to be used in another project, it must be placed in the correct directory on your computer so that Simio can recognize it. You should
be able to find the Symbols folder under \Public\PublicDocuments\Simio. Any .ssf files placed in this folder will be recognized by Simio and will be
accessible via the Place Symbol drop down menu from the Drawing Ribbon tab.
Creating New Symbols
A new symbol can be created by the user using the drawing tools, colors and textures. This new symbol can be exported so that it can be
reused in other projects. When it is exported, it is stored in [public documents]\Simio\Symbols. To create a new symbol, go to the Project Home
tab in the ribbon menu and click on the New Symbol icon. Select the option for C reate New Symbol and a new window will appear where you can
create the new symbol.
There are two windows that are available, Design and Look, as shown below. Within the Design window, any existing symbol is shown (from our
library of symbols, for example). A new symbol can be added by using the various buttons on the Drawing ribbon. Within the Look window,
various 'looks' can be applied to the same single symbol 3d geometry. Each look may have a different texture or color. When multiple looks are
applied, the symbols then appear within the symbol library as multiple symbols to be selected. As an example, Simio's animated people are really
a single 3d geometry model, but N textures applied. This saves on both disk and video memory as opposed to having X different symbols with
the same geometry.
Symbol Design and Look
624 / 815
Viewing Your Symbols
Symbols will be added to your Project window. The project window is found by clicking on the name of the project within the Navigation window.
Within the Project window, the Symbols panel can be selected from the icons on the left. Symbols can be copied, deleted and edited. The Project
Graphics can also be viewed in the Place Symbol drop down found in the Drawing Tab.
Viewing Your Symbols
625 / 815
Symbols, Textures and File Size / Run Performance
When downloading and editing symbols, there is some symbol size information to keep in mind. First of all, using images with low polygon count
will keep the project file size small. Additionally, using lower fidelity 3D models may make your animation run faster, but it is highly dependent on
your particular graphics card and C PU. And finally, there is no difference in drawing speed for stationary or moving objects. 100 stationary
servers will draw just as fast as 100 moving entities. However, the simulation itself may be slower with moving objects because of the additional
logic involved.
When deciding on textures for symbols, keep the following information in mind. The advantage of .dds files is potentially significant memory
savings when rendering them. The size on disk is the size in memory. Unlike something like a .jpg file where the size on disk is often significantly
smaller than the size in memory. The possible disadvantage to .dds files is that they are dependent on driver support, and users may run into
problems on some drivers/graphics settings. Users can force the emulation of DDS support by setting File->Settings->Graphics->C ompressed
Texture Hardware Support to “Disabled”. To generate a *.dds file, users can download a tool, for example Paint.NET (http://www.getpaint.net/),
which can convert image files into *.dds format.
626 / 815
Simio Reference Guide
Drawing
Drawing
A user can add symbols, lines, rectangles, ellipses, curves, polygons and labels to the Facility Window or External Window of their model.
Drawing Tab Ribbon (from Facility Window)
You can also change the color of any object or add texture to the object. After adding these drawings to the model, the user can change the line
style, the object's height or the line width by selecting the object (i.e. curve) and viewing the Drawing tab.
With polylines and curves, additional vertices may be added or removed by using the Add Vertex and Remove Vertex buttons on the Edit ribbon.
When a polyline or curve is selected and the Add Vertex button is pressed, the polyline or curve will get an extra vertex added to the end. You
may click to place the vertex anywhere in the Facility window. If the new vertex is placed on the line between two other vertices, it will be added
to the middle section of that line. If the new vertex is placed outside of the line, it will be added as a vertex at the end of the line. To remove a
vertex, simply click on the vertex to remove and select the Remove Vertex button and the line will be redrawn.
NOTE: Multi-Select of objects, as well as C trl-X (C ut), C trl-C (C opy), and C trl-V (Paste), are supported for all items on the Drawing tab. Please
refer to the User Interface for more details.
Adding Labels to the Facility Window
Simio provides the ability to add two different types of labels to the Facility Window. The Floating Label is simple, one line of text. The text size,
font or color cannot be changed in this label. It is similar to the labels that are attached to the objects that are placed in the window. In both 2D
and 3D view, the label will always remain faced at the screen (upright in the Z direction).
The Floor Label draws a text box on the floor of the Facility Window. Therefore, in 3D view, the label remains flush to the floor. It has more
flexibilty for changing the appearance of the text. Once the Floor Label is drawn in the Facility Window, select it to see the Appearance Tab in the
Ribbon. The Appearance Tab allows you to control how many characters per line will appear in the label. The background color for this label can
easily be changed by clicking on the Background C olor icon. You can also change the text for the label by clicking the Edit button found in the
Text group of the Ribbon. A Label Text dialog will appear where you may change the text. In order to change the appearance of the text, you can
use the following tags:
<b> and </b> will make the text bold
<i> and </i> will make the text italic
<u> and </u> will make the text underlined
You can change the color of the text by putting the name of the color in a tag, such as <red>
The font of the text can be changed by putting the name of the font in a tag, such as <font name="Arial">
Floor Labels can also show the value of expressions. To specify an expression put it between curly braces. For example, a label with the
text “The current day is: <b>{Math.Floor(Run.TimeNow/24)}</b>”, at hour 50, would show “The current day is: 2”, with the 2 in bold text.
Appearance Tab Ribbon (when Floor Label is selected)
627 / 815
If using the Default Font (not specifying a particular font, for example <font name="Arial">), you can choose the Default Font ‘spacing’ for the
floor label. The Proportional and Fixed buttons don't affect the overall text layout, only the text not surrounded by <font> tags. The default
Proportional font is “Tahoma” while the default Fixed font is “C onsolas”.
628 / 815
Adding External Nodes to the External Window
When seen from the External Window, the Drawing Tab also contains an icon called External Node. Adding this to the External Window provides
an entry or exit point into and out of the model.
629 / 815
Simio Reference Guide
Adding Additional Symbols
When the object is selected in the Facility Window, the user can change the properties of the object instance in the Properties window. The user
can change the Current Symbol Index property and put an expression that will return a value that is the index in the associated symbol list -
the symbols that are displayed in the Active Symbol list. Whatever value is returned by the expression in this property will determine which
symbol is displayed during the run. The value returned must be an integer so that it corresponds to a value in the symbol list.
When the Random Symbol property is set to 'True', each new object will be randomly assigned a symbol from the associated list of symbols.
Note that, since physical sizes are determined by the state variable specified as the Current Size Index (defaulted to ModelEntity.Picture in new
model entities), the physical size of the entity will not change until that state variable does. To make the entity have both the symbol picture and
size specified by the symbol, set Random Symbol to 'False', and make sure the C urrent Size Index and C urren Symbol Index use the same state
variable (which in new model entities is already defaulted to 'ModelEntity.Priority' for both properties), then randomly assign a value to that state
variable in process logic.
In the example below, the expression in the C urrent Symbol Index is ModelEntity.Picture. This is a built-in state variable that can be used to hold
a value for the entity symbol.
Properties Window
630 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
631 / 815
Simio Reference Guide
Animating Moving O bjects (W alking P eople)
A user may use a numeric index for the animation by removing the Animation string state and adding an Animation real state OR by adding a
different real state and changing the Current Animation Index property value appropriately.
Alternatively, the Current Animation Index property may be set to a string or numeric value directly in the property field itself. See the examples
shown below under C urrent Animation Index.
Animated People and Animations for Simio’s Library\Animated\* Directories
Within the Project Symbols on the Symbols ribbon, there are a number of animated people that come automatically with Simio. They are located
within Library\Animated\* directories and include a number of male and female symbols, as well as children, elderly persons, soldiers and toons.
Within a given directory, the symbols are similar, with the each having different clothing (textures). An entity symbol may be changed from the
default green triangle to an animated person by selecting one of the available animated symbols within the directory.
Once placed in a model, a symbol is associated with one or more animations. To get a list of available animations for a given object, be sure the
object's Active Symbol is one with animations, then right click on the object and select List Animations of Active Symbol, which brings up a simple
dialog with a list.
632 / 815
Note that the animations above have both a numeric and string value. If using the default ModelEntity.Animation state, the string value would be
assigned. If using a numeric state, the numeric value would be assigned.
For example, in an Assign step when the entity is created, you may assign ModelEntity.Animation = Random.Discrete(“Walk”, .25, “Run”, .5,
“Jump”,.75, “Dance1”,1). In this case, 25% of the entities created would walk through the simulation, another 25% would run, another 25% would
jump and the remaining would dance.
IMPORTANT NOTE: Animations in the list are case-sensitive. If the animation is not exactly as noted when assigned, the default animation will
be the first one listed.
Current Animation Index
The Current Animation Index allows the animations to be listed by either name or number, so any of these values would be correct within the
Current Animation Index property field (using the animations shown above for the woman):
22 – This will make the entity dance.
“Swim” – This will make the entity swim.
ModelEntity.Animation – This will look at the entity’s ModelEntity.Animation string value to determine what the animation will look like –
when an entity is created, for example, you could assign ModelEntity.Animation = Random.Discrete(“Swim”, .5, “Jump”, 1) such that 50%
of the entities will swim and the other 50% will jump.
ModelEntity.NumericProperty – This will look at the entity’s ModelEntity.NumericProperty integer value to determine what the animation will
look like – similar to above, except that with this property, if it is a real or integer value, you may assign it to ‘3’ for jumping, ‘24’ for
swimming, etc.
Not having the expression defined, returning an invalid index (like 0 or something beyond the bounds), or an invalid name (like empty string ""),
makes Simio fallback to doing the default animation, based on the Default Animation Action property.
Default Animation Action
The Default Animation Action property can be one of the following values:
None - Simio will have no default animation.
Moving - Simio will have default animation when the object is moving, and C urrent Animation Index did not provide an explicit animation.
MovingAndIdle - Simio will have default animation when the object is moving or when it is idle, and C urrent Animation Index did not
provide and explicit animation.
Default Animation Action and C urrent Animation Index will be disabled unless you have at least one symbol applied to the object that has
animations in it.
Refer to the SimBit AnimatedPeople for several examples of animating moving objects.
-----------------------------------------------------------------------------------------------------
Importing New Animations
Simio includes a number of Animated symbols (male and female), which can be found in Library\Animated\People. Users also have the capability
to import their own animations.
633 / 815
New animated symbols can be imported using either the Project Home ribbon, New Symbol button (Import Symbol) or by highlighting an existing
symbol in the Facility window and selecting the Import Symbol button from the Symbols ribbon. Typical 3D files have a *.dae (digital asset
exchange) filename extension and are in C OLLADA (interchange file format for interactive 3D applications) file format. Once imported, there is an
Import Options dialog that allows the user to specify several features.
Ignore Uncolored Faces property determines if the import will ignore any faces without color or texture information. This value is set to ‘False’ as
a default. The Load Material property determines if any material settings, such as color and texture, will be considered. This value is set at ‘True’
as a default. The Split Animation File property is a path to a text file that describes how the first animation should be split, with an entry on each
line of the file in the form N1-N2 Name, where N1 is the start frame, N2 is the end frame and the Name is the animation name.
Once the Import Options dialog is accepted, the Import dialog is displayed. This includes options to specify the size of the symbol, name, and
rotations options on the Import tab.
Additionally, there is an Animation tab on the import dialog. This includes two buttons, Default Forward Animation and Default Idle Animation, as
well as time / distance fields, and Play/Stop buttons.
Default Forward Animation is enabled when Distance is > 0, and disabled otherwise. When enabled, it defaults to True. Default Idle Animation is
enabled when Distance == 0, and disabled otherwise, it defaults to False.
When a selected animation has Default Forward Animation turned on, it will be included in the set of animations Simio looks at when trying to do
"default animation" for some agent that is currently moving.
When a selected animation has Default Idle Animation turned on, it will be included in the set of animations Simio looks at when trying to do
"default animation" for some object that is NOT currently moving.
Default Idle Animation Example:
Below, you will see that the ‘Idle’ animation was selected (under the Name property) and the Distance is specified as ‘0’. The Default Idle
Animation button is available, and in this case it is selected, as an idle animation symbol to be displayed for the idle activity. Note that when the
button is selected, it will appear in ( ) next to the animation name on the dropdown list.
634 / 815
Default Idle Animation Example:
Below, you will see that the ‘Walk’ animation was selected (under the Name property) and the Distance is specified as ‘0.1’. The Default Forward
Animation button is now available instead of the Default Idle Animation button. The Play and Stop buttons may be used to see what the animation
will look like, for example, how fast the person appears to walk. Once the Default Forward Animation button is selected, the ( ) will be shown next
to the animation on the dropdown and the animation will be available for use within the simulation.
635 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
636 / 815
Simio Reference Guide
C hanging the View
The function key, F11, allows the capability of collapsing all of the ribbons and other windows so that the simulation animation can be seen on the
full screen. Pressing the F11 or Esc key while in full screen will then put back the ribbons and windows that were collapsed. The F11 key can also
be used in all other windows, such as Processes, Data (for tables), Results, and Experiments.
View
The 2D icon changes the view to a 2D top down view. This is the default view. Left click on any empty space and drag to pan. Right click and
drag up and down to zoom.
The 3D icon changes the view to a 3D perspective view. There are many ways to move around in the 3D view including:
Left click on any empty space and drag to pan
Right click and drag up and down to zoom and drag left and right to rotate
Left-click and drag any object to move it in the horizontal plane
C trl and drag any object to move it on top of another object
C trl and drag any object selection handle to rotate it
Left-click to select a node object
C trl+Shift and left-click on a node to start drawing a link
C trl+Scroll wheel changes the viewing angle of the camera
Shift+Scroll wheel moves the camera straight up and down
Up arrow moves forward
Down arrow moves left
Left arrow turns left (or moves left in top-down mode)
Right arrow turns right (or moves right in top-down mode)
Shift+Left arrow moves left
Shift+Right arrow moves right
[W] key sets the camera 1.7 meters off the ground, with the angle pointing almost straight out (i.e. “walking mode”)
Pinch-to-zoom and two-finger-rotate gestures are also supported, provided user has a touch screen
The View All icon brings all objects into view within the window.
The Auto Rotate icon starts auto-rotating the view. The user can click on any empty space to stop the rotation. Once auto-rotation is stopped,
the view will remain where it currently is.
The Walk icon sets the camer 1.7 meters off the ground, and has the same function as the [W] key listed above.
The Background Color icon will change the background color of the entire Facility window floor in both the 2D and 3D views.
The SkyBox icon opens a library of static and dynamic scenes that can be placed in the 3D animation. Dynamic scenary includes several options
for clouds that move with the animation as the model runs. Typically, the Speed Factor should be set to 5 - 10 or greater to see movement. Static
skybox options include many outdoor scenes. The 'None' option will remove any existing skybox. Users can create their own SkyBoxes as well.
The “library” skyboxes are simply *.zip files with images inside them with the names front, back, left, right, top, bottom. They don’t need to have
all of those names in them, Simio will use whatever ones it finds. They are located in the Skybox folder under \Public\PublicDocuments\Simio.
The Day/Night Cycle icon is available if the SkyBox is set to a dynamic skybox. This on/off icon indicates if the animation should alter the
ambient light and display a moving sun and moon in accordance witht a day/night cycle.
Snap to Grid will snap moving object or handle locations to grid lines to allow for object alignment. The snap locations will be dependent on the
grid level. In the below diagram, the left grid shown is the default zoom location and objects will snap to those larger grid lines when placed. The
right grid shown is zoomed in several times and displays more granular grid lines, in which case, the objects will snap to those smaller grid lines.
Thus, zooming in within the Facility window will provide the user with more precise placement. Both Grid and Snap can be turned on/off using the
right-click menu or pressing the G (Grid) or S (Snap) keys.
Additionally, Snap to Grid also snaps rotations of objects. When rotating objects with snap enabled, the object will rotate in 15 degree increments
(thus 4 rotations to move the object 90 degrees).
637 / 815
When placing objects, note that the center of the object is the location of the snap to grid. When snap is turned on and a link is being drawn, or a
link vertex moved, Simio will not only snap to the grid, but snap to the closest *visible* (on the screen) node. A dashed blue line will show what
node caused the snap, as shown below.
Named Views
Named Views allow you to place the camera at a location and save that view for later using Add View. You can either pick a specific view to go
to, or cycle through them using the Change View option. C hange or delete a specific view using the Manage Views option. Named views may
have a name as well as a 'HotKey' that will allow users to simply press the HotKey on the keyboard and move to that particular view.
Map
There are two button options under the Maps section of the ribbon. The Set Map Location button provides options for setting the latitude and
longitude coordinates of 0,0 in the model. The Map View option provides a drop down list of options for the type of map to see, from various
online sources. Additional information on maps and creating links between nodes using the maps can be found on the Maps page.
638 / 815
C amera Tracking
There are two buttons in the Camera Tracking group, including Change Item and Camera Placement. These icons are disabled until you
enter run mode and have at least one item for tracking. You may right click on any Agent, Entity or Transporter (this includes Workers / Vehicles)
and select the 'Track with C amera' option. When selected, the camera icon will have a small black square around it. Once you select the 'Track
with C amera' option, the agent / entity / transporter identifier will appear on the C hange Item list. Selecting 'Track with C amera' when the item is
already on the C hange Item list will remove it from the tracking list. By default, all non-destroyable agents, such as Workers and Vehicles, are
put onto the C hange Item list for selection at the start of the simulation run. If there are no Workers or Vehicles in your model, the C hange Item
button will remain disabled in run mode, until you have selected 'Track with C amera' for an object.
When running, you can click on the button part of Change Item to cycle between tracking different items in the model, or tracking nothing, and
letting you move the camera where you wish. If you click the drop down part, you can select a specific item, or [None], meaning you want to turn
off tracking.
The C amera Placement dropdown allows you to change the perspective of tracking and how you would like to track the object. Options include
'Move camera with object', 'Watch from a distance', 'Follow behind' and 'Lead in front', providing multiple camera angles from which to view
agents. When an item you are tracking (such as an entity) gets destroyed, Simio will put you back to the view you were when you first selected
the item to be tracked.
Example of Camera Placement buttons, as seen with dropdowns
C amera Sequences
Within the Camera Sequences group, there are options to Edit and Play. A C amera Sequence is a sequence of instructions that can be played
back either by selecting the Sequence under the Play button, or by using a hotkey associated with the sequence. Therefore, the Edit button allows
you to Add / Edit / Delete an entire sequence of named views or a particular view within the sequence. To add a camera sequence, simply type a
sequence name in the Name column and an associated key in the HotKey column. You will then be able to expand the sequence by pressing the
+ button. This will open the Views dialog for inputting the specific Named View, Seconds to Stay (at that particular view), and the Seconds To Next
View (to change between the views).
The Play button will display the available sequences that may be selected. Once a sequence is selected, Simio will rotate through the various
views. If there is currently a sequence playing, a small icon will be displayed in the lower right corner with the sequence name. The sequence will
stop if the user performs any other action (i.e., such as changing the view, mouse click, etc.). Once all views have been displayed, the camera
will remain at the last view specified.
Example of Camera Seqeuences, with multiple Named Views
639 / 815
Video
The Video group contains the Record Run Animation and Stop Recording buttons. These buttons allow the user to create an .avi recording of
the model animation. C licking on the Record Run Animation button will prompt the user to choose a name and location for their .avi file. The user
will also be prompted to select a video compressor. The options that the user will be given will vary depending on what is installed on the PC . We
recommend using a state of the art codec, like DivX, Xvid, x264, ffmpeg, or others. Once the user begins the interactive model run by clicking
the Run button, an .avi video of each animation frame will begin. The recording stops when the model runs ends or when the user clicks the Stop
Recording button.
The video will record the animation in the working space of the Facility window. If the user switches into another Simio window while the recording
is occuring, whatever is present in the same defined space as the Facility window, will be recorded. For example, if the user switches over to the
Data window during the recording, the tables will be recorded, but the left hand panel will not be in view, assuming the Library Panel was
expanded in the Facility window. If the user collapses the Library panel before recording, the working space will be increased, thereby creating a
larger area for animation capture both in the Facility window and other windows. To begin recording in full screen mode, click the Record Run
Animation button, hit F11 to get to full screen mode and then hit F5 to begin the model run.
If the user switches into an application outside of Simio, whatever is shown in that same Facility window space is also recorded. This allows a user
to animate a model running in the Facility window and then switch over to a spreadsheet to show external data and then move back into Simio to
show more animation or possibly another Simio window, such as the tables in the Data window.
640 / 815
Simio Reference Guide
Maps
On the View ribbon, there are two button options under the Maps section. The Set Map Location button provides options for setting the latitude
and longitude coordinates of 0,0 in the model. This setting will be used for things such as placement of the background map, if enabled. The Map
View option provides a drop down list of options for the type of map to see, from various online sources. The option selected will set the map tile
source for the current view. It is important to note that the map is only displayed with the model when the user is connected to the internet with
access to the map; the map does not become a permanent part of the model itself.
The options within the Set Map Location are utilized when a map is displayed. The By Latitude and Longitude option always shows the current
lat/long to which the map is centered.
Users can change the default latitude and longitude by using the By Address option. Please note that By Address will only find an address when
a map is currently loaded. The Find Address dialog will appear where the user can enter a specific street address, city and state name or
particular landmark (as shown below). A dialog will then ask the user to select the specific address from the list, providing a list of possible
options based on the original user input. Once the location has been entered, the map center will move to the particular location and the default
coordinates within the By Latitude and Longitude dialog will update.
There is also an option to set the map location to the computer's current location, provided the computer graphical location is enabled. The
options for setting the computer location vary by operating system.
Note that Simio uses a “Web Mercator” (https://en.wikipedia.org/wiki/Web_Mercator) projection to convert from the spherical lat/long coordinates
to our 2 dimensional x,y,z coordinates. This simply means that things close to the equator are their actual size, while the further you get away,
the more distorted they become. Additionally, not only does Simio use that projection, but it further scales down the size so that things close to
641 / 815
the more distorted they become. Additionally, not only does Simio use that projection, but it further scales down the size so that things close to
0,0 are much closer to their actual meter offsets from that location. If a user zooms all the way out, they may find the world's width does not
match the earth's circumference.
Moving an Object to a Specific Map Location
When the map is enabled, any similulation object may be moved to a given location within the map as well. This can be done by right-clicking on
an object (such as a BasicNode, Server, or TransferNode, for example), selecting the Move Object option and moving the object to a latitude and
longitude, address or computer's current location.
This add link option will call out to a routing service to get the road route between two geographic locations. It will set the resulting link’s Drawn to
Scale property to 'False', and set the Logical Length property to the measured length of the entire route. Below you see the link that was drawn
from the two nodes selected in the above diagram:
642 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
643 / 815
Simio Reference Guide
Visibility
Visibility
From within the Facility Window, the Visibility Ribbon can be used to toggle on and off various objects, as well as view the networks.
The Visibility Ribbon, as seen from the Facility Window
When the Grid, Labels, Axes, Arrows, Links, Nodes, Queues, Status and Buttons icons are highlighted, this indicates that they are visible
within the window. If the user clicks on any of these icons and unhighlights it, the particular feature will not appear in the window. It is important
to note that when an feature is not visible, it also is not editable. Therefore selecting, copying, deleting, etc. of groups of objects will not select
anything that is not visible. An item must be made visible first before it can be edited.
The Direct Shadows icon shows or hides shadows from a directional light source, like the sun. The light source in Simio is fixed in the corner at
a 45 degree angle. However, if Direct Shadows are used in conjunction with a dynamic Skybox and the Day/Night cycle, the shadows will be
adjusted for the change in the light source. The Diffuse Shadows icon shows or hides soft shadows from other objects interacting with the
illumination of an object. Only one of the shadows icons may be on at a time. Note: If running Simio under DirectX or OpenGL software fallback,
shadows will not work.
The Entity Instances icon determines whether or not the Entity and Transporter instances will be visible while in run mode. If disabled, any
instances that exist when going into run mode will be hidden and then shown again when leaving run mode. If enabled, these instances will be
visible at all times including run mode. The Dynamic Labels icon works in conjunction with a property on Entities and Transporters (which
includes Worker / Vehicle) named Dynamic Label Text (in the Animation category of properties). The Dynamic Label Text is an expression which
returns a string to show a floating label below a dynamic entity at runtime. This floating label is similar to the label shown on fixed objects
(Source1, Server1, Sink1, etc.). The Dynamic Labels icon on the Visibility ribbon allows users to enable or disable these labels separately from
the Labels specified for other fixed objects.
The View Networks dropdown, highlights the links within the network(s) that are selected. Each network highlight can be individually toggled on
and off. When selected, the Union icon shows the union of all selected networks. The link is in the union of the selected networks if it is a
member of ANY of the networks. When selected, the Intersection icon shows the intersection of all selected networks. The link is in the
intersection of the selected networks if it is a member of ALL of the networks.
Note that subsections of the Visibility section icons (Grid, Labels and Axes) can currently be found on the View ribbon in the C onsole, External,
and Symbol editing ribbons.
644 / 815
Simio Reference Guide
Animating Links
Let's add a conveyor between the Source and the Sink. C lick on the C onveyor object in the Standard Library and then click on the transfer node
displayed on the Source and have the conveyor end at the basic node displayed with the Sink. Another way to add a conveyor is to click on the
transfer node displayed on the Source while holding down the C trl+Shift keys and dragging the link to the Sink node. Because you haven't
selected which type of link this is yet, the small menu will be displayed that asks you to select the type of link you'd like, in this case we'd select
C onveyor.
The Drawn to Scale option in the Properties window determines the relationship between the animated length and the logical length used in
calculating movement in your model. If Drawn To Scale is False, that means that the logical length will be exactly the value specified in the
Logical Length property. This is best to use if you know the exact link length and it is important that the model reflect that. The disadvantage of
this approach is that if you later adjust the path (e.g. move the Source and Sink in our example closer or further apart) that adjustment will not
be reflected in the model. If Drawn To Scale is set to True, that means that the Logical Length property will be ignored and instead the length
used in your model logic will be determined by the length drawn in your animation. This is best to use when you are experimenting with different
layouts and you want the model logic to reflect what you are currently looking at. The disadvantage of this approach is that you don’t have an
exact logical length. In our example, it is likely that you drew the conveyor slightly more or less than 10 meters. While this might not matter in
early experimentation, it could be important in your final analysis.
When the link is selected in the Facility window, the Edit tab is displayed in the Ribbon. This contains a library of path decorators, as well as
options to add and remove vertices from the link. Additional vertices may be added to or removed from a link by using the Add Vertex and
Remove Vertex buttons. When a link is selected and the Add Vertex button is pressed, a green vertex is provided that can be placed anywhere
along the link. To remove a vertex, simply click on the vertex to remove and select the Remove Vertex button and the link will be redrawn.
Adding a Vertex to a Link
An additional option on the Edit ribbon is the Always Orient Vertically button that provides the option to have the entities' vertical orientation
always remain upright regardless of the angle of the actual link that is selected. This is useful for people going up stairs, for example. Note that
tihs option only affects animation. Logically, the entities still occupy space on the link as if they are vertically aligned at the same angle as the link
itself.
There is a library of path decorators that are provided with Simio. Simply clicking on a path decorator from that window will change the
appearance of the link that is selected. In our example, we will select the conveyor path decorator that is found in the window.
Conveyor Path Decorator
645 / 815
Once the path decorator is added to an object in our project, it appears in the Path Decorators panel within the Project window. C lick on the name
of the Project in the Navigation window to open the Project window. Path Decorators are stored in [public documents]\Simio\PathDecorators .
Even though this example was for a conveyor type link, any type of link can have a Path Decorator displayed on it.
Path Decorators in the Project Window
When multiple links are connected that have path decorators, the node (BasicNode or TransferNode) that connects the links may be highlighted to
access the Appearance ribbon. There are Link Graphic options for Merge and No Merge that provide the user the ability to specify how the paths
look when they intersect at the node. Merge will blend the paths such that they are solidly connected as shown below, whereas the No Merge
draws the links such that they do not connect at the node intersection.
646 / 815
Connecting Multiple Nodes with Links
As mentioned above, you can utilize the Standard Library 'link' type objects, such as Path, C onveyor, TimePath, etc. to connect the nodes of
various standard objects to one another. Alternatively, you can click on a node while holding down the C trl+Shift keys to start a link to another
node.
When placing multiple nodes within the Facility window, there is an option for connecting those nodes automatically by using the right-click menu.
If the last two or more undo-able actions were placing nodes, the right-click menu within the Facility window provides an 'Add Links to Placed
Nodes' menu item that allows links of a certain type to be generated between the nodes that were just placed.
Multiple Nodes Placed Into Facility Window
Paths Automatically Connecting Nodes in the Order That They Were Placed
647 / 815
After the links get created, they are all selected as well, so edits can be made, if desired, within the Properties window on the right.
Note that this only shows up if the last undoable action was placing a node. So if you place 3 nodes, then go create a table, then come back to the
Facility window, you *will not* see this option, as the last undoable action was create a table.
648 / 815
Simio Reference Guide
Expression Editor, Functions and Distributions
For detailed information on the available States, Functions and Events for each object type, see the Functions page. For detailed information
on the available random distributions, see the Distributions page. The Math Functions page will give details on the available Math Functions to
use in the Expression Editor. For a listing of various operators for use in expressions, see the Math and Logical Operators page. Various
keywords that may be used within expressions are found on the Keywords page. The contents of the Simio enumerations can be found in the
Enumerations page and an explanation on when to use the keyword 'Candidate' in an expression can be found here. Continue reading below for
information on how to use our Expression Editor.
The Expression Editor
The Expression Editor is found in the property window for many different properties throughout the Simio product. If the property type utilizes the
expression editor, it can be accessed when the user selects the property in the properties window and clicks on the down arrow that appears to
the left. A horizontal input box will appear with a green checkbox and red X at the left end of the box. The expression box can be expanded
(resized) by using click-drag on the left side of the expression box. Any resizing will remain for all expression editing until the user resizes again.
When the user types anything into this input box, a dropdown menu will appear below, showing the user a list of possible entries. There is a
content filtering option on the left side of the expression editor dropdown. When the content filtering is enabled (yellow), the auto-completer will
hide content that is not typically useful in the current context. For example, within most properties in the Facility window, the content filtering
enabled will cause any statistics functions to be taken out of the list. However, within the Experiment window, any expression properties may
typically include statistics functions. Therefore, within that context, enabling the filter will hide all content except for the statistics functions. You
may enable the filter at any time during the expression building process. The following screen shot shows the choices at the beginning of the list,
when the user types an "a" into the input box (no filtering).
The top of the list that appears when a user types an "a" into the Expression Editor
The expression editor can be used to specify a random distribution. The user should type in the word Random into the expression editor,
followed by a period (.) and they will be given the choice of all the random distributions supported by Simio. To see a list of all distributions found
in Simio, see the Distributions help page.
The top of the list that appears when a user types Random. into the Expression Editor
The expression editor can be used to apply math functions to any value. The user should type in the word Math into the expression editor,
followed by a period (.) and they will be given the choice of all the math functions supported by Simio.
The top of the list that appears when a user types Math. into the Expression Editor
649 / 815
If the user should type in the name of an object from the model into the expression editor, followed by a period (.), they will be given the
choice of all the functions, properties and states that can be referenced for this particular object. To learn more about functions that are available
in Simio, see the Functions help page. You might also need clarification on what name to put into a function. See the Object Hierarchy page to
learn whether to reference the object definition name, the object instance name or the object runspace (i.e. ModelEntity vs DefaultEntity).
The top of the list that appear when ModelEntity. is entered into the Expression Editor
Anything that appears bold in the expression editor dropdown, is a valid selection that will return a value. If the selection is not in bold, you need
to type a period (.) and add additional information to the expression in order to get a valid response. If a double greater than sign (>>) appears
after a name listed in the Expression Editor drop down, this indicates that if this name is selected alone, it is a valid expression. However, there
are other functions available with this choice. By selecting the name in the drop down and then typing another period (.), the available functions
will appear. See the example below.
Understanding >> in the Expression Editor
650 / 815
Next to each of the selections within the expression editor is a graphical symbol that indicates if the selection is a property, state, function,
statistic function, and so on. The tooltip for the selection also indicates what the selection represents, as shown below.
652 / 815
Simio Reference Guide
Functions in Simio - Automatic
Functions available for the Simio state variable type Queue State:
Function Return Value
NumberWaiting Returns the current number of entities waiting in this Queue.
AverageNumberWaiting Returns the average number of entities waiting in this Queue.
AverageTimeWaiting Returns the average time that an entity waits in this Queue.
MaximumNumberWaiting Returns the maximum number of entities waiting in this Queue.
MaximumTimeWaiting Returns the maximum time that an entity waits in this Queue.
MinimumNumberWaiting Returns the minimum number of entities waiting in this Queue.
MinimumTimeWaiting Returns the minimum time that an entity waits in this Queue.
MinimumC ostWaiting Returns the minimum cost that an item accumulated while it waited in the queue.
MaximumC ostWaiting Returns the maximum cost that an item accumulated while it waited in the queue.
AverageC ostWaiting Returns the average cost that an item accumulated while it waited in the queue.
FirstItem Returns a reference to the item ranked first in the queue.
LastItem Returns a reference to the itetm ranked last in the queue.
ItemAtIndex(index) Returns a reference to the item ranked at a specific index position in the queue.
IndexOfItem(object) Returns the rank position of a specified object in the queue. If the queue does not contain the object, then the value 0
is returned.
C ontains(object) Returns True(1) if the queue contains the specified object. Otherwise the value False (0) is returned.
TimeWaiting (object) Returns the time that a specified object has been waiting in the queue. If the queue does not contain the object then
NaN is returned.
Functions available for the Simio State variable type List States:
Function Return Value
AverageTime(stateValue) Returns the average time that the object has spent in this Resource State.
NumberOccurences(stateValue) Returns the number of times that this object has gone into this Resource State.
PercentTime(stateValue) Returns the percentage of the total simulation time that this object has been in this Resource State.
TotalTime(stateValue) Returns the total amount of time that this object has been in this Resource State.
Therefore, to reference the percentage of time that an object was in a certain state, use the syntax [ObjectName].PercentTime(stateValue),
where stateValue is the number referencing the state in the String List. The first value in the String List is value 0.
Functions available for the Simio String States:
Function Return Value
String.Length(string) Returns the length of a string
String.C ontains(string, substring) Returns true if substring is in string, otherwise false
String.Substring(string, startindex[, Returns the string starting at the specified index of the string until the end. If the length argument is
length]) specified, then returns a string of that length starting at the index.
String.FromReal(value[, Returns the string representation of a specified numeric value.
formatString, useLocalC ultureInfo])
The numeric value may be converted to its equivalent string representation using a specified numeric
format string. The formatString argument should contain either a valid standard numeric format specifier
653 / 815
format string. The formatString argument should contain either a valid standard numeric format specifier
(see .NET Standard Numeric Format Strings) or any combination of custom numeric format specifiers (see
.NET C ustom Numeric Format Strings).
The useLocalC ultureInfo argument indicates whether to convert the numeric value to a string using local
culture-specific format information. If this argument is false or unspecified, then the formatting used will be
culture-insensitive (invariant culture).
String.ToReal(string [, Returns a numeric value converted from a specified string representation of a number.
useLocalC ultureInfo])
The useLocalC ultureInfo argument indicates whether to convert the string to a numeric value using local
culture-specific format information. If this argument is false or unspecified, then the formatting used will be
culture-insensitive (invariant culture).
String.FromDateTime(dateTime [, Returns the string representation of a specified numeric datetime (simulation time) value.
formatString, useLocalC ultureInfo])
The datetime value may be converted to its equivalent string representation using a specified date and
time format string. The formatString argument should contain either a single format specifier character
(see .NET Standard Date and Time Format Strings) or a custom format pattern (see .NET C ustom Date and
Time Format Strings).
The useLocalC ultureInfo argument indicates whether to convert the datetime value to a string using local
culture-specific format information. If this argument is false or unspecified, then the formatting used will be
culture-insensitive (invariant culture).
String.ToDateTime(dateTime [, Returns a numeric datetime (simulation time) value converted from a specified string representation of a
useLocalC ultureInfo]) date and time.
The useLocalC ultureInfo argument indicates whether to convert the string to a datetime value using local
culture-specific format information. If this argument is false or unspecified, then the formatting used will be
culture-insensitive (invariant culture).
String.Format(formatstring, arg1, Returns a formatted string using the specified format string with any number of parameters. The
arg2, …) formatString argument should contain a format pattern that follows .NET string formatting conventions.
String.C ompare(string1, string2 [, C ompares two specified strings and returns 0 if the two strings are equal, -1 if the first string is less than
useLocalC ultureInfo]) (alphabetically before) the second string, or 1 if the first string is greater than (alphabetically after) the
second string.
The useLocalC ultureInfo argument indicates whether to use local culture-specific information to influence
the string comparison. If this argument is false or unspecified, then the comparison will be culture-
insensitive (invariant culture).
String.C ompareIgnoreC ase(string1, C ompares two specified strings, ignoring case, and returns 0 if the two strings are equal, -1 if the first
string2 [, useLocalC ultureInfo]) string is less than (alphabetically before) the second string, or 1 if the first string is greater than
(alphabetically after) the second string.
The useLocalC ultureInfo argument indicates whether to use local culture-specific information to influence
the string comparison. If this argument is false or unspecified, then the comparison will be culture-
insensitive (invariant culture).
String.Trim(string) Returns a specified string with any leading and trailing white-space characters removed.
String.NewLine Returns the newline constant defined for the local platform. Useful for adding a line break to form a multi-
line string.
DateTime.ToString(dateTime [, Returns the string representation of a specified numeric datetime (simulation time) value.
formatString,
useLocalC ultureInfo]) The datetime value may be converted to its equivalent string representation using a specified date and time
format string. The formatString argument should contain either a single format specifier character (see .NET
Standard Date and Time Format Strings) or a custom format pattern (see .NET C ustom Date and Time
Format Strings).
The useLocalC ultureInfo argument indicates whether to convert the datetime value to a string using local
culture-specific format information. If this argument is false or unspecified, then the formatting used will be
culture-insensitive (invariant culture).
655 / 815
Simio Reference Guide
Functions, States and Events for All Intelligent O bjects
Listed below are the Functions available for all Intelligent Objects that have External Nodes (i.e.Input and Output nodes):
Function Return Value
Input Returns a reference to the external input node associated with the object.
Output Returns a reference to the external output node associated with the object.
Listed below are the Functions available for Intelligent Objects that are Enabled as Resource Objects *:
Function Return Value
C apacity Returns the current capacity of the object.
C apacity.Initial Returns the initial capacity of the object.
C apacity.Previous Returns the previous capacity of the object.
656 / 815
C apacity.Remaining Returns the current unallocated capacity of the object.
C apacity.Allocated Returns the current number of capacity units of the object that are allocated (have been seized).
C apacity.Allocated.Average Returns the average number of capacity units of the object that have been allocated during the run.
C apacity.Allocated.Minimum Returns the minimum number of capacity units of the object that have been allocated during the run.
C apacity.Allocated.Maximum Returns the maximum number of capacity units of the object that have been allocated during the run.
C apacity.Allocated.Total Returns the total number of capacity units of the object that have been allocated during the run.
C apacity.AllocatedTo(owner) Returns the current number of capacity units of this resource that are allocated to (have been seized by)
a specified owner object.
C apacity.Reserved Returns the current number of capacity units of the resource that have been reserved.
C apacity.ReservedTo(owner) Returns the current number of capacity units of the resource that have been reserved for use by a
specified owner object.
C apacity.Average Returns the average scheduled capacity of the object during the run.
C apacity.Minimum Returns the minimum scheduled capacity of the object during the run.
C apacity.Maximum Returns the maximum scheduled capacity of the object during the run.
C apacity.Next Returns the next scheduled capacity of this resource.
*Note: If the resource is not following a work schedule then this function simply returns the current
capacity since any future capacity changes are unknown.
C apacity.TimeOfLastC hange Returns the simulation time (in hours) that the capacity of this resource most recently changed.
C apacity.TimeOfNextC hange Returns the simulation time (in hours) of the next scheduled capacity change of this resource.
*Note: If the resource is not following a work schedule then this function simply returns infinity since the
timing of any future capacity changes are unknown.
C apacity.TimeSinceLastC hange Returns the elapsed time duration (in hours) since the most recent capacity change of this resource.
C apacity.TimeUntilNextC hange Returns the time duration remaining (in hours) until the next scheduled capacity of this resource.
*Note: If the resource is not following a work schedule then this function simply returns infinity since the
timing of any future capacity changes are unknown.
C apacity.IdleC ost Returns the total cost that was accrued to the cost of the resource due to idle capacity units.
C apacity.UsageC ostC harged Returns the total cost that was charged to users of the resource's capacity.
ResourceOwners The objects that currently own (have seized) capacity units of this resource.
ResourceOwners.NumberItems Returns the number of objects that currently own (have seized) capacity units of this resource.
ResourceOwners.FirstItem Returns a reference to the first owner in the list of owners that have currently seized capacity units of
this resource.
ResourceOwners.LastItem Returns a reference to the last owner in the list of owners that have currently seized capacity units of this
resource.
ResourceOwners.ItemAtIndex(index) Returns a reference to the owner at a specified index position in the list of owners that have currently
seized capacity units of this resource.
ResourceOwners.IndexOfItem(owner) Returns the one-based index of the first occurence of a specified owner in the list of owners that have
currently seized capacity units of this resource. If the owner has not seized the resource then the value 0
is returned.
ResourceOwners.C ontains(owner) Returns True(1) if the list of owners that have currently seized capacity units of this resource includes the
specified owner. Otherwise the value False (0) is returned.
* Note: Standard Library Objects that are enabled as 'Resource Objects' include Node, Link, Vehicle, Operator and fixed objects such as Server,
Workstation, etc.
Listed below are the Inherited States of all Intelligent Objects:
State Description
Trace Flag A flag to turn on/off trace information for this object. A value of 0 denotes off, all other values denote on.
Size The current volume size of this object in cubic meters. Has state parameters Size.Length, Size.Width, and Size.Height.
C ost The current cost of this object in the default currency units. Each intelligent object has a cost 'level' state that gets/sets the
total cost that has been allocated to the object. The value of the state may increase continuously over time based on the value
of its C ost.Rate parameter. It is a user-assignable state.
AllocationQueue The queue of objects that are waiting to seize this object.
C urrentC apacity State that may be assigned to dynamically change the current capacity of this object.
Listed below are the Inherited Events associated with all Intelligent Objects:
Event Description
C apacityC hanged Fired when the resource capacity for this object has been changed by a work schedule.
657 / 815
Simio Reference Guide
Functions, States and Events for Entity O bjects
Listed below are the Inherited States of any object derived from Simio base class - Entity object:
State Description
Picture A utility state to hold a picture index. This state can then be referenced in an expression for C urrent Symbol Index.
Size The current volume size of the object in cubic meters. Has state parameters Size.Length, Size.Width, and Size.Height.
Movement The total linear distance that this object has traveled in free space or on its current network link. Has state parameters
Movement.Rate, Movement.X, Movement.Y, Movement.Z, Movement.Pitch, Movement.Heading, and Movement.Roll.
DesiredSpeed The desired movement rate of this object. Non-zero does not mean the object is currently moving.
Priority The current priority value for this object.
C ellRange The cell alignment distance for this object.
VisitRequestQueue The queue of destination visit requests for this object.
BatchMembers The queue of batch members that this object owns.
Volume The current logical volume of the object. At runtime, the ratio between the logical volume and the Size implicit volume will
remain constant.
Weight The current logical weight of the object.
C urrentNetwork The entity object's currently assigned network.
C urrentTravelMode The current travel mode for the entity. Possible values include FreeSpaceOnly (0), NetworkOnly (1), or NetworkIfPossible
(2).
Listed below are the Inherited Events associated with any object derived from Simio base class - Entity object:
Event Description
Destroyed The Destroyed event provides notification that the entity has been destroyed.
Engaged The Engaged event provides notification that the entity has been engaged (locked) to a location on a link.
Transferring The Transferring event provides notification that the entity has started transferring into another object or a station location.
Transferred The Transferred event provides notification that the entity has completed transferring into another object or a station location.
660 / 815
Simio Reference Guide
Functions, States and Events for T ransporter O bjects
Listed below are the Inherited States available for any object derived from the Simio base object class - Transporter:
State Return Value
HomeNode (on the standard Vehicle The name of the Node that is set as the Home node for this object. This state is assignable.
object)
ResourceState (on the standard Vehicle The current resource state of this object (numeric values for this state are Idle = 0, Busy = 1, Failed =
object) 3, OffShift = 4).
Listed below are the Inherited Events associated with any object derived from Simio base class - Transporter object:
Event Description
RiderLoaded (on the standard Vehicle object) The RiderLoaded event provides notification to the vehicle's OnVisitingNode process that a rider
has been loaded.
RiderUnloaded (on the standard Vehicle The RiderUnloaded event provides notification to the vehicle's OnVisitingNode process that a
object) rider has been unloaded.
C alendarTimeBasedFailuresReset (on the An occurrence of this event will reset the 'C alendarTimeBasedFailures' timer.
standard Vehicle object)
EventC ountBasedFailuresReset (on the An occurrence of this event will reset the 'EventC ountBasedFailures' timer.
standard Vehicle object)
Allocated (on the standard Vehicle object) The Allocated event provides notification to the vehicle's OnVisitingNode process that capacity of
this Vehicle object has been allocated.
Released (on the standard Vehicle object) The Released event provides notification to the vehicle's OnVisitingNode process that capacity of
this Vehicle object has been released.
661 / 815
Simio Reference Guide
Functions, States and Events for O bjects Enabled as R esource O bjects
ExpectedOperationTimeFor(entity) Returns an estimate of the expected opeartion time for a specified entity at the fixed object.
NOTE: Refer to the ExpectedOperationTimeExpression property in the Advanced Options of the fixed object
to specify the expression used to estimate an operation time for an entity.
Listed below are the Inherited States of any object derived from Simio base class - Fixed object:
State Description
ResourceState The current resource state of this object (numeric values for this state are Starved = 0, Processing = 1, Blocked = 2, Failed = 3,
OffShift = 4).
662 / 815
Simio Reference Guide
Functions, States and Events for Node O bjects
AssociatedStationLoad For an external input node, this function returns the current 'load' on the station locations
inside the node's associated object that may be entered using the node
The associated station 'load' is defined as the sum of current entities en route to the node
intending to enter the stations, plus the current entities already arrived to the node but still
waiting to enter the stations, plus the current entities occupying the stations.
663 / 815
waiting to enter the stations, plus the current entities occupying the stations.
AssociatedStationOverload For an external input node, this function returns the current difference between the load
and capacity values (a positive difference indicating an 'overload') for the station locations
inside the node's associated object that may be entered using the node.
The associated station 'load' is defined as the sum of current entities en route to the node
intending to enter the stations, plus the current entities already arrived to the node but still
waiting to enter the stations, plus the current entities occupying the stations. This function
returns the difference between that load and the current station capacity (Overload = Load
- C apacity).
Inherited States available for any object derived from the Simio base object class Node:
State Description
EntryQueue The queue of entities that are waiting to enter this node.
RidePickupQueue The queue of entities that are waiting at this node to be picked up by and ride on a transporter.
C urrentTravelerC apacity State used to get or set the current maximum number of travelers that may simultaneously occupy this node.
Inherited Events available for any object derived from the Simio base object class Node:
Event Description
Entered The Entered event provides notification that a traveler has entered the crossing point of the node. (on the standard TransferNode
and BasicNode)
Exited The Exited event provides notification that a traveler has exited the crossing point of the node.(on the standard TransferNode and
BasicNode)
RiderWaiting The RiderWaiting event provides notification that a traveler has entered the RidePickupQueue of the node waiting for a ride. (on
the standard TransferNode)
664 / 815
Simio Reference Guide
Functions, States and Events for Link O bjects
Listed below are the Functions available for any object derived from Simio base class - Link object:
Function Return Value
NumberTravelers Returns the current number of travelers on the link.
NumberTravelers.Minimum Returns the minimum number of travelers that have been on the link.
NumberTravelers.Maximum Returns the maximum number of travelers that have been on the link.
NumberTravelers.Average Returns the average number of travelers that have been on the link.
NumberTravelers.Entered Returns the total number of travelers that have entered the link.
NumberTravelers.Exited Returns the total number of travelers that have exited the link.
NumberTravelers.Accumulated Returns the total number of travelers that are accumulated on the link. Note:An entity is counted as
an ‘Accumulated’ traveler on a link if the entity has reached the end of the link and has been stopped
there without being engaged to the link OR if the entity’s leading edge has collided with the trailing
edge of an entity in front of it on the link, and the entity has accumulated behind that entity without
being engaged to the link. Therefore, the NumberTravelers.Accumulated function is tracking
accumulation anywhere on the link, not just from the end. Once flagged as ‘Accumulated’, the entity
will continue to be considered ‘Accumulated’ until either its leading edge leaves the link or the collision
situation is cleared. If a link is a ‘Connector’ (i.e., drawn to scale with logical length = 0) then entities
are never considered to be on the link and NumberTravelers and NumberTravelers.Accumulated are
always 0.
Accumulated Entities
Listed below are the Inherited States of any object derived from Simio base class - Link object:
State Description
TransferInState State indicating whether an entity is currently transferring onto this link (Idle = 0, Busy = 1).
DesiredSpeed The desired movement rate of the 'Mark' on this link, which is a reference point along the link's length whose
movement represents the link's movement. Non-zero does not indicate that the link 'Mark' is currently moving.
Movement The position of the 'Mark' on this link, which is a reference point along the link's length whose movement
represents the link's movement. This state variable has a parameter that returns the current Rate (speed) of the
mark.
EntryQueue The queue of entities that are waiting to enter this link.
C ontents State used to access the queue of entities that are physically located on the link. * Note that they are ranked in
order of entry onto the link.
DistanceFromFirstEdgeToEnd The distance from the leading or trailing edge of the first entity on this link to the end of the link.
DesiredDirection The desired traffic direction on this link. Assignable values are Enum.TrafficDirection.Either,
Enum.TrafficDirection.Forward, Enum.TrafficDirection.Reverse, or Enum.TrafficDirection.None.
C urrentVolumeFlowIn State used to get the current total volume flowed into this link. The 'rate' from this state is also available.
C urrentVolumeFlowOut State used to get the current total volume flowed out of this link. The 'rate' from this state is also available.
C urrentWeightFlowIn State used to get the current total weight flowed into this link. The 'rate' from this state is also available.
C urrentWeightFlowOut State used to get the current total weight flowed out of this link. The 'rate' from this state is also available.
AvailableVolumeFlowInRate Gets the current potential volume inflow rate for the link if ideal case where there are no link-related flow
constraints. Note that this is a private variable primarily intended for flow link object builders (and thus will only be
visible inside a link object's process view).
AvailableWeightFlowInRate Gets the current potential weight inflow rate for the link if ideal case where there are no link-related flow
constraints. Note that this is a private variable primarily intended for flow link object builders (and thus will only be
visible inside a link object's process view).
665 / 815
visible inside a link object's process view).
666 / 815
Simio Reference Guide
O bsolete Functions
Obsolete Functions
Listed below are the Functions that are obsolete, meaning replaced by current functions, but may still be used in older models.:
Obsolete Function Replaced by Current Function
ActualDurationFor(entity) C urrentBatchDurationFor(entity)
ActualSetupTime ExpectedSetupTimeFor(entity)
BatchesRequiredFor(entity) NumberBatchesRequiredFor(entity)
BatchParentID BatchParent.ID
C apacity.UnitsOwned C apacity.AllocatedTo(owner)
C apacity.C urrentOwners ResourceOwners
C apacity.C urrentOwners.NumberItems ResourceOwners.NumberItems
C apacity.C urrentOwners.FirstItem ResourceOwners.FirstItem
C apacity.C urrentOwners.LastItem ResourceOwners.LastItem
C apacity.C urrentOwners.ItemAtIndex(index) ResourceOwners.ItemAtIndex(index)
C apacity.C urrentOwners.IndexOfItem(owner) ResourceOwners.IndexOfItem(owner)
C urrentLinkID C urrentLink.ID
C urrentNodeID C urrentNode.ID
DestinationNodeID DestinationNode.ID
DisableRandomness Run.RandomnessDisabled
FrontTraffic EntityAheadOnLink != Nothing
FrontTraffic.ID EntityAheadOnLink.ID
FrontTraffic.Distance Math.If(EntityAheadOnLink != Nothing, Max(EntityAheadOnLink.Movement –
EntityAheadOnLink.Length – Movement, 0), C urrentLink.Length – Movement)
FrontTraffic.Speed Math.If(EntityAheadOnLink != Nothing, EntityAheadOnLink.Movement.Rate, DesiredSpeed)
InputC apacity InputLocation.C apacity
InputLocation AssociatedStation
For example, InputLocation.C apacity is replaced with AssociatedStation.C apacity
InputLocation.Load AssociatedStationLoad
InputLocation.OverLoad AssociatedStationOverLoad
InputLocation.NumberInLocation AssociatedStation.C ontents
InputLocation.NumberWaitingEntry, AssociatedStation.EntryQueue.NumberWaiting
InputNumberWaiting
InputLocation.C apacityRemaining, AssociatedStation.C apacity.Remaining
InputRemainingC apacity
IsExternalInputNode IsInputNode
NumberParked ParkingStation.C ontents
NumberOccupiedLinks
NumberOccupiedNodes
NumberRouting NumberRoutingIn
NumberRoutingIn NumberTravelers.RoutingIn
NumberTransportersRouting NumberRoutingIn.Transporters
NumberRoutingIn.Transporters *Use Load/Overload functions
NumberRoutingIn.C anEnterAssociatedObject *Use Load/Overload functions
ParentRunSpaceID Location.Parent.ID
Population.Name EntityType.Name
RideID ReservedTransporter.ID or C urrentTransporter.ID
SeizedResources.C apacityUnitsOwned(resource) SeizedResources.C apacityOwnedOf(resource)
SequenceTableRow Sequence.C urrentJobStep
SequenceTableRowC ount Sequence.NumberJobSteps
TableRow Sequence.C urrentJobStep
TimeNow Run.TimeNow
667 / 815
Simio Reference Guide
Distributions
Distributions
Simio supports a number of distributions used to draw random samples. Simio supports an infinite number of random number streams. To specify
a particular stream for a distribution to use, list the number of the stream directly after the last parameter proceeded by a comma. For example,
Random.Triangular(.1, .2, .3, 2) to use stream number 2. When running a model from an experiment, replications of the same scenario will use
different portions of the stream and different scenarios will start from the same point in the stream.
To access these distribution from within the Expression Editor, type in the word Random, followed by a period (.) to see the list of distributions.
Beta Distribution
Binomial Distribution
C ontinuous Distribution
Discrete Distribution
Erlang Distribution
Exponential Distribution
Gamma Distribution
Geometric Distribution
JohnsonSB Distribution
JohnsonUB Distribution
LogLogistic Distribution
LogNormal Distribution
NegativeBinomial Distribution
Normal Distribution
PearsonVI Distribution
Pert Distribution
Poisson Distribution
Triangular Distribution
Uniform Distribution
Weibull Distribution
NOTE: Simio will produce an error if a delay time expression returns a negative value. This can occur if you use an unbounded distribution that
might produce negative values, such as a Normal Distribution, within a Delay.
Simio produces an error to alert you that your distribution would have a spike at time 0.0 and the mean would be higher than what you specified.
If you want to use an unbounded distribution and convert all negative values to 0.0 (ignoring the above problems), then use an expression like:
Math.Maximum(0.0, Random.Normal(5.0, 2.0))
Examples
1. How do I generate values for which:
10% of the time I get values between 0 and 25
35% of the time I get values between 25 and 50
55% of the time I get values between 50 and 100
Random.Discrete(x, .1, y, .45, z, 1) where x = Random.Uniform(0, 25), y = Random.Uniform(25,50), z=Random.Uniform(50,100)
In other words: Random.Discrete((Random.Uniform(0, 25)), .1, (Random.Uniform(25,50)), .45, (Random.Uniform(50,100)), 1)
Distribution Fitting Software
The following are recommended solutions for statistical distribution fitting (e.g., Input Analysis):
Stat::Fit from Geer Mountain Software (http://www.geerms.com/) has direct support for Simio built into their latest version. They also have a
free student version available.
ExpertFit from Averill Law and Associates (http://www.averill-law.com/) has a comprehensive tool kit and direct support for Simio in their latest
version.
Because the above packages have direct support for Simio (e.g., their output exactly matches and can be cut and pasted into a Simio expression)
they are the easiest to use. The following packages will provide a similar data analysis, but the results must be manually translated to match
Simio's required inputs:
BestFit is part of the @Risk Excel-based toolkit from Palisade Software (http://www.palisade.com/).
Note, here is a conversion chart for BestFit submitted by Barry Nelson:
668 / 815
EasyFit from Mathwave (http://www.mathwave.com/en/home.html) has both standalone and Excel versions.
A product named R has both free and commercial versions available. One source is http://www.r-project.org/.
669 / 815
Simio Reference Guide
Beta
Random.Beta(alpha1, alpha2)
The Beta distribution has a range from 0 to 1 and can take a wide variety of shapes based on the two shape parameters (alpha1 and alpha2).
The Pert distribution is a special case of the Beta and is often used as a rough model in the absence of data.
The Expected Value of the Beta distribution is E(x) = Alpha1/(Alpha1+Alpha2).
Example of the Shape of a Beta Distribution
670 / 815
Simio Reference Guide
Binomial
Random.Binomial(ProbababilityOfSuccess, NumberTrials)
The Binomial distribution is a discrete distribution representing the number of successes in a specified number of independent trails. The
parameters are the probability of success for each trial, and the total number of trials.
The Expected Value of the Binomial distribution is E(x) = ProbabilityofSuccess * NumberTrials.
Example of the Shape of a Binomial Distribution
671 / 815
Simio Reference Guide
C ontinuous
Random.Continuous(v 1, c 1, v 2, c 2, …. ,v N, c N)
This is an empirical distribution defined by a set of value and cumulative probability pairs(v i , c i) that define a piecewise linear cumulative
distribution function for a continuous random variable over the defined range of values.
This implementation has an implied V 0 of 0. So C 1 represents the probability of a value between 0.0 and V 1 . If you want your first range to start
at other than 0 (e.g. at V 1 ), then specify C 1 as 0.0.
This distribution may be used as an alternative to a theoretical distribution using empirical data to define the points on the cumulative distribution
function. Note that there is always an even number of parameters since the parameters are defined in pairs (value, cumulative probability).
The Expected Value of the C ontinuous distribution is
672 / 815
Simio Reference Guide
Discrete
Random.Discrete(v 1, c 1, v 2, c 2, …. ,v N, c N)
This is an empirical distribution defined by a set of value and cumulative probability pairs (v i, c i) that define a stepwise linear cumulative
distribution function for a discrete random variable. This distribution defines a set of N possible discrete values, where N is the number of value
and cumulative probability pairs. Note that the number of parameters for this distribution is 2*N. This distribution is typically used to make
random discrete assignments to a state.
The Expected Value of the Discrete distribution is
Examples
Example 1 - Assigning a Single Value
Suppose you want to assign a value of 1, 2, 3 or 4 to an entity priority, based on a certain percentage to each value. 40% of the entitys will have
a priority of 1, 35% of the entities have a priority of 2, 10% have a priority of 3 and the remaining 15% a priority of 4. The discrete distribution
would be specified as Random.Discrete(1,.4,2,.75,3,.85,4,1) where the values are specified in the distribution along with the cumulative
probability.
Example 2 - Assigning a String State
You may wish to define an entity string state, named PartType, to a value based on a discrete distribution. Suppose you wish for 50% of the
entities created to be "TypeA", 20% are "TypeB" and the remaining 30% are "TypeC ". Your discrete distribution would then be
Random.Discrete("TypeA",.5,"TypeB",.7, "TypeC ",1)
Example 3 - Assigning a Value from Various Distributions
Suppose you wanted a processing time to be taken from one of two distributions. You can specify the value parameters within the discrete
distribution based on an expression. Let's say that 20% of the time, the value should be longer processing time due to unforseen circumstances,
while 80% of the time, the processing time is shorter. The discrete distribution can be specified as
Random.Discrete(Random.Normal(50,3),.2,Random.Normal(10,.5),1)
For examples of using the Discrete distribution, please refer to the SimBits C ombineMatchingMembers, StringStates, ImportExportTables and
AnimatedPeople .
673 / 815
Simio Reference Guide
Erlang
Random.Erlang(mean, K)
The Erlang distribution models an n-phase activity where the time for each phase is exponentially distributed. The Erlang has parameters that
specify the mean and number of integer phases (K).
Erlang is the sum of K exponentials, each with an expected value of Mean/K. The Mean parameter is the mean of the Erlang, not the mean of the
individual exponentials.
Example of the Shape of a Erlang Distribution
674 / 815
Simio Reference Guide
Exponential
Random.Exponential(mean)
The Exponential distribution is often used to model inter-arrival times based on a Poisson process. This distribution has a single parameter that
specifies the mean. This distribution is generally not appropriate for modeling process delay times.
The Expected Value of the Exponential distribution is E(x) = mean.
Example of the Shape of a Exponential Distribution
For examples of using the Exponential distribution, please refer to the Source object's Interarrival Time property in many of the SimBits and
Examples.
675 / 815
Simio Reference Guide
G amma
Random.Gamma(shape, scale)
The Gamma distribution has a shape and scale parameter. The mean of the distribution is the product of these parameters. The Erlang is a special
case of the Gamma with an integer shape parameter.
The Expected Value of the Gamma distribution is E(x) = shape * scale.
Example of the Shape of a Gamma Distribution
676 / 815
Simio Reference Guide
G eometric
Random.Geometric(ProbabilityOfSuccess)
The Geometric distribution is a discrete distribution and represents the number of failures before the first success. The parameter for the
distribution specifies the probability of success for each independent trial.
The Expected Value of the Geometric distribution is E(x) = (1 - ProbabilityOfSuccess) / ProbabilityOfSuccess.
Example of the Shape of a Geometric Distribution
677 / 815
Simio Reference Guide
JohnsonSB
678 / 815
Simio Reference Guide
JohnsonSU
679 / 815
Simio Reference Guide
LogLogistic
Random.LogLogistic(shape, scale)
The LogLogistic distribution has one shape and one scale parameter, both of which must be non-negative. This distribution has a range from 0 to
infinity and is typically used to model a task time.
The Expected Value of the LogLogistic distribution is
680 / 815
Simio Reference Guide
Lognormal
Random.LogNormal(normalMean, normalStdDev)
A sample from the Lognormal distribution is generated by first generating a sample N from the normal distribution, and then converting this to a
Lognormal sample, LN, using the following equation:
LN = eN
Note that the parameters specified for the Lognormal are the mean and standard deviation of the underlying normal before transformation to the
Lognormal distribution. In some cases you may know the mean and standard deviation of the Lognormal distribution and need to convert these to
the corresponding mean and standard deviation of the normal for use in specifying the distribution. Let LogNormalMean be the mean
LogNormalStdDev be the standard deviation of the Lognormal. You can calculate the mean (normalMean) and standard deviation (normalStdDev)
of the underlying normal distribution using the following formulas.
You then use the normalMean and normalStdDev as the parameters of the Lognormal distribution to generate samples with mean and standard
deviation given by LogNormalMean and LogNormalStdDev.
The Expected Value of the Lognormal distribution is E(x) = Lognormal Mean = e ^ (normalMean + normStdDev * normStdDev/2).
Example of the Shape of a Lognormal Distribution
681 / 815
Simio Reference Guide
NegativeBinomial
Random.NegativeBinomial(ProbabilityOfSuccess, NumberOfSuccesses)
The NegativeBinomial distribution is a discrete distribution and represents the number of failures before reaching the specified number of
successes. The parameters of the distribution are the probability of success for each trail, and the number of required successes.
The Expected Value of the NegativeBinomial distribution is E(x) = (ProbabilityOfSuccess * (1 - NumberOfSuccesses))/NumberOfSuccesses.
Example of the Shape of a Negative Binomial Distribution
682 / 815
Simio Reference Guide
Normal
683 / 815
Simio Reference Guide
P earsonVI
684 / 815
Simio Reference Guide
P ert
685 / 815
Simio Reference Guide
P oisson
Random.Poisson(mean)
The Poisson distribution has a single parameter that specifies the mean. This distribution is a discrete distribution that models the number of
occurrences in an interval of time when the events are occurring at a constant rate according to a Poisson process. The time between each event
is exponentially distributed and the number of events in a specified time is Poisson distributed. The parameter of the distribution is the rate of
event occurrence (events per unit time), and must be a non-negative value.
The Expected Value of the Poisson distribution is E(x) = mean.
Example of the Shape of a Poisson Distribution
686 / 815
Simio Reference Guide
T riangular
687 / 815
Simio Reference Guide
Uniform
Random.Uniform(minimum, maximum)
The Uniform distribution has parameters that specify the minimum and maximum values. All values within this range have an equal probability of
occurring.
The Expected Value of the Uniform distribution is E(x) = (minimum + maximum)/2.
Example of the Shape of a Uniform Distribution
688 / 815
Simio Reference Guide
W eibull
Random.Weibull(shape, scale)
The Weibull distribution has a shape parameter and scale parameter. This distribution has a range from 0 to Infinity and is skewed to the left. If
the system has a large number of components that are all required for the system to function and each component fails independently then the
time between failures can be approximated by this distribution.
The Expected Value of the Weibull distribution is E(x) = (scale/shape)*Г(1/shape) where Г is the Gamma function.
Example of the Shape of a Weibull Distribution
689 / 815
Simio Reference Guide
Math Functions
Math Functions
Simio supports a number of math functions that can be used in an expression. To access these math functions from within the Expression Editor,
type in the word Math, followed by a period (.) to see the list of functions.
Math.Abs(value)
Returns the absolute value of the specified number. The absolute value of a number is its unsigned magnitude.
Math.Acos(value)
Returns the arc cosine of the specified number (in radians).
Math.Asin(value)
Returns the arc sine of the specified number (in radians).
Math.Atan(value)
Returns the arc tangent of the specified number (in radians).
Math.C eiling(value)
Returns the smallest integer not less than the specified number.
Math.C os(value)
Returns the cosine of the specified number (in radians).
Math.e
Returns the value of the mathematical constant e, which is approximately 2.718.
Math.Epsilon
Represents the smallest real value greater than zero. (Note: The standard BasicNode and the standard TransferNode objects do a
delay for Math.Epsilon, in order to guarantee the correct order of events. The Delay step actually interprets Math.Epsilon as a delay
of 0.0, but it forces the event to be put at the end of the current event list.)
Math.Exp(value)
Returns the value of the mathematical constant e, to the power of the specified number.
Math.Floor(value)
Returns the largest integer not greater than the specified number.
Math.If(test1, value1, test2, value2, test3, value3, …, otherwise value)
Returns the value specified in valueN if the testN is True. Returns the value specified in otherwiseValue if all the testN are False. For
example, Math.If(ModelEntity.Priority == 2, 1, 3) would return the value of 1 if the expression ModelEntity.Priority == 2 is True and
would return the value of 3, otherwise.
Math.IsNaN(value)
Returns the value of 0 true and 1 if false, based on the value that is evaluated. If the value is NaN (which means Not a Number),
then the function will return a "True" or 1. If the value is not NaN, it will return a "False" or 0. This function is used in conjunction
with the Math.NaN function.
Math.Log (value)
Returns the natural logarithm (base e) of the specified value.
Math.Log10 (value)
Returns the logarithm (base 10) of the specified value.
Math.Max (value1, value2)
Returns the value which is the maximum between the two specified values (i.e. expressions).
Math.Min (value1, value2)
Returns the value which is the minimum between the two specified values (i.e. expressions).
Math.NaN
Returns the value of NaN, which means Not a Number. It may be used in some special cases with Math.If(), for example, to return a
value indicating that nothing was valid within the Math.If() so there isn't a value. Math.NaN can be used in conjunction with the
Math.IsNaN()function. One of the special rules of NaN is that it does not equal anything, even itself. So the expression “Math.NaN
== Math.NaN” would be false. In order to test if a value is NaN, then you need to use Math.IsNaN(), so the expression
“Math.IsNaN(Math.NaN)” is true.
Math.Pi
Returns the value of Pi, which is approximately 3.1415.
Math.Pow (value, power)
Returns the result of the specified value to the specified power. For example, Math.Pow(2,3) returns 8.
Math.Remainder (value1, value2)
Returns the remainder, which is defined as value1-(math.floor(value1/value2)*value2)
Math.Round (value[, digits]) where digits is the number of significant digits (defaults to 0)
690 / 815
When used without optional argument, returns the closest integer to the specified number. This function rounds down from .50 and
rounds up from .51. For example, Math.Round(4.5) will return 4 and Math.Round(4.51) will return 5.
If you would like to round a number to a specific number of significant digits, specify the number of digits in the optional second
argument. For example, if you have the number 1.2345 and you'd like to round it to 2 significant digits after the decimal, you would
use the expression, Math.Round(1.2345, 2) to get 1.23.
You can also use this with expressions. For example if you would like to take a number in hours (like Run.TimeNow) and display it
in minutes to the nearest tenths, you would use the expression Math.Round(Run.TimeNow*60, 1). A time of 1.5123 hours would be
displayed as 90.7 minutes.
Math.Sin (value)
Returns the sine of the specified number (in radians).
Math.Sqrt (value)
Returns the square root of the specified number.
Math.SumOfSamples (randomExpression, numberOfSamples)
Independently samples a specified random expression for a specified number of times and returns the total sum of the samples.
The expected value returned will be the expected value of the random expression, multipled by the number of samples. For
example, if the Random Expression is specified as 'Random.Uniform(1,2) and the Number of Samples is specified as '100', then the
expcted sum of the samples is 1.5 x 100 =150. Therefore, if you enter the expression
'Math.SumOfSamples(Random.Uniform(1,2),100)' and then disable randomness in the model, you will see that expression always
returns the value 150.
If the specified number of samples is not a positive integer, then the function returns the value of 0.0
Math.Tan (value)
Returns the tangent of the specified number (in radians).
691 / 815
Simio Reference Guide
Math and Logical O perators
692 / 815
Simio Reference Guide
Keywords
693 / 815
Simio Reference Guide
Enumerations
Enumerations
Simio has a number of built in Enumeration types that are used throughout the product and can be referenced in an expression. To access these
enumerations from within the Expression Editor, type in the word Enum, followed by a period (.) to see the list.
An example of using an Enum within an expression is shown below. This is a scenario where a user is changing the direction of travel on a Path
and can choose from a list of possible values from Enum.TrafficDirection
Using an Enum within an Assign Step Expression
694 / 815
Enum.DecideType.ProbabilityBased
Destination Modes - A choice of methods to use for determining the entity's destination node. This is used in the Destination Type
property of the SetNode step. 'By Sequence' requires that the entity object has been assigned a sequence table. The destination node
value will be set to the next destination in the sequence.
Enum.DestinationModes.Specific
Enum.DestinationModes.BySequence
Enum.DestinationModes.Expression
Destroy Type - Used in the Destroy Step to indicate which object is to be destroyed; the parent object or the object associated with the
token.
Enum.DestroyType.ParentObject
Enum.DestroyType.AssociatedObject
Duration Type - Used in an Activity element and the standard Workstation object to provide the choices available to determine how the
per batch time duration for the activity or operation is specified. 'Specific' dictates that the duration of the activity will be a specific value
that is evaluated as a user entered expression. 'C hangeDependent' is used to specify an activity who's duration will be determined by one
expression if the Comparison Expression is the same for the current entity as it was for the previous entity and a different expression if
the value is different than the previous entity. 'SequenceDependent' is used to specify that the activity or operation should reference a
C hangeOver matrix to determine its duration.
Enum.DurationType.Specific
Enum.DurationType.C hangeDependent
Enum.DurationType.SequenceDependent
Element Scope - Found in the properties of all Elements. This is used to define the element as either a public or private element, hence
determining whether this element is publicly accessible outsides of its containing object.
Enum.ElementScope.Private
Enum.ElementScope.Public
Entity Alignment - Used for aligning travelers on a link. If 'Any Location', then a traveler can engage at any location on the link. If 'C ell
Location', then the link length has a discrete number of cell locations, and the leading edge of an engaged traveler must align with a cell
boundary. A standard C onveyor object is the only link that displays the Entity Alignment enum property.
Enum.EntityAlignment.AnyLocation
Enum.EntityAlignment.C ellLocation
Entity Travel Mode - Used for the initial travel mode for ModelEntity, Worker and Vehicle. 'Free Space Only' indicates that the entity is
required to perform travel movements in free space.'Network Only' indicates that the entity is required to perform travel movements using
its currently assigned network. 'Network If Possible' indicates a preference for the entity to perform travel movements using its currently
assigned network, but if no followable network path exists to its next destination then travel in free space is allowed.
Enum.EntityTravelMode.FreeSpaceOnly
Enum.EntityTravelMode.NetworkOnly
Enum.EntityTravelMode.NetworkIfPossible
Execute Step Action - Found in the Execute Step and used to determine whether or not the token that is executing the Execute step
waits until the new process is completed before continuing on in the current process or if the token continues in the current process while
the new process is executed at the same time.
Enum.ExecuteStepAction.WaitUntilC ompleted
Enum.ExecuteStepAction.C ontinue
Extended Selection Goal - Found in the Ride Step and therefore the standard TransferNode when Ride On Transporter property is set to
'True'. This enumeration populates the Selection Goal property and allows the user to rank the transporter preference when multiple
candidates are available to ride on.
Enum.ExtendedSelectionGoal.PreferredOrder
Enum.ExtendedSelectionGoal.SmallestValue
Enum.ExtendedSelectionGoal.LargestValue
Insert Object Type - Provides the choice of Associated Object or Parent Object, for use in the Insert Step. This allows the user to specify
which object will be inserted into a storage queue.
Enum.InsertObjectType.AssociatedObject
Enum.InsertObjectType.ParentObject
Interrupted Process Action - Found in the Interrupt Step as a choice for how the interrupted process delay will be handled. EndProcess
will immediately end the current delay. However, the choice of ResumeProcess will cause the interrupted delay to resume for the remaining
delay time once the interruption process is finished (i.e. the new token created by the Interrupt Step to handle the interruption occurrence
ends its processing)
Enum.InterruptedProcessAction.EndProcess
Enum.InterruptedProcessAction.ResumeProcess
Link Selection Preference - Used by an entity to select an outbound link from this location to the next. This enumeration is found in the
Outbound Link Preference property of the standard TransferNode.
Enum.LinkSelectionPreference.Any
Enum.LinkSelectionPreference.Available
Link Selection Rule - Used by an entity to select an outbound link from this location to its next destination. This enumerator is found in
the Outbound Link Rule property of the standard TransferNode. Shortest Path is only used when the entity already has a destination set. It
will determine the shortest path between the current location and the destination of the entity. If the entity does not have a destination set
(Entity.DestinationNode = Nothing), then ByLinkWeight will be used for routing. ByLinkWeight tells Simio to look at the Selection Weight
properties of the outbound links to determine the routing for the entity.
Enum.LinkSelectionRule.ByLinkWeight
Enum.LinkSelectionRule.ShortestPath
695 / 815
Link Type - The choices found in the Type property of all Link objects. It is only visible on the standard library Path and TimePath. The
other Link objects have this property but it is not visible, by default. A bidirectional link allows entities to move in both directions on the
link and a unidirectional link only allows movement in one direction at a time. By default, this is the direction in which the link was drawn in
the Facility window (i.e. the direction the arrows are pointing).
Enum.LinkType.Bidirectional
Enum.LinkType.Unidirectional
Match Type - This enumeration is found in the Matching Rule property of the Batching Logic element and therefore the standard
C ombiner object, since it uses the Batching Logic element. This determines how the entities will be batched together. 'Any Entity' indicates
that the first members of the specified batch quantity will be attached to the first entity in the parent queue. There is no specific matching
criteria. 'Match Members' indicates that members must be matched together using a specified expression. 'Match Members and Parent'
indicates that parents must also be matched with members according to a specified expression.
Enum.MatchType.AnyEntity
Enum.MatchType.MatchMembers
Enum.MatchType.MatchMembersAndParent
Material Options - This enumeration is found in the Material Consumption property and Material Production property of the Activity
Element and the standard Workstation, since this object uses the Activity Element. It determines if material will be consumed or produced
by this activity (per batch). 'BillOfMaterials' indicates that the Material(s) to be consumed/produced can be found as part of a Bill Of
Materials. 'Material' is indicating that a specific Material element will be consumed or produced. Either of these two choices (BillOfMaterials
or Material) will switch on the Consumed Material Name and Consumed Quantity properties or Produced Material Name and Produced
Quantity properties.
Enum.MaterialOptions.BillOfMaterials
Enum.MaterialOptions.Material
Enum.MaterialOptions.None
Monitor Type - This enumeration is found in the Monitor Type property of the Monitor element. This determines if the Monitor will fire an
event whenever the value of the State Variable changes (DiscreteStateC hange) or if it will only fire an event when the State Variables
value crosses a specified threshold value in the crossing direction specified.
Enum.MonitorType.DiscreteStateC hange
Enum.MonitorType.C rossingStateC hange
Input Node Logic Type - Indicates the location type within the object that an entity will transfer into when entering from an external
node. These choices are found in the Input Logic Type property on an External Node Instance, found when an external node is placed in
the External View of an object. If an object's external node has Input Node Logic set to ProcessStation, the entity will be transferred into a
station when it enters the object. If the object's external node has Input Node Logic set to FacilityNode, the entity will be transferred to a
Node that is defined within the Facility window of this object.
Enum.InputNodeLogicType.None
Enum.InputNodeLogicType.ProcessStation
Enum.InputNodeLogicType.FacilityNode
Node Outbound Travel Mode - Indicates whether to assign a new travel mode to entities attempting to transfer from this node to either
free space or an outbound link. 'C ontinue' indicates that there is no assignment. The entities are to continue using their currently assigned
travel modes. 'Free Space Only', 'Network Only' and 'Network If Possible' will assign the current travel mode to the specified value.
Enum.NodeOutboundTravelMode.C ontinue
Enum.NodeOutboundTravelMode.FreeSpaceOnly
Enum.NodeOutboundTravelMode.NetworkOnly
Enum.NodeOutboundTravelMode.NetworkIfPossible
Node Selection Goal - These choices are found in the Selection Goal property of the Route Step and therefore also in the standard
TransferNode since this object uses a Route Step when its Entity Destination Type property is set to 'SelectFromList'. The enumeration is
used to decide which node to select from the nodes in the specified Node List.
Enum.NodeSelectionGoal.SmallestDistance
Enum.NodeSelectionGoal.LargestDistance
Enum.NodeSelectionGoal.PreferredOrder
Enum.NodeSelectionGoal.C yclic
Enum.NodeSelectionGoal.Random
Enum.NodeSelectionGoal.SmallestValue
Enum.NodeSelectionGoal.LargestValue
Object Release Order - Found in the Release Order property of the Release Step, this indicates the order in which to release objects that
are owned by the specified owner.
Enum.ObjectReleaseOrder.FirstSeized
Enum.ObjectReleaseOrder.LastSeized
Object Seize Type - Found in the Object Type property of the Seize Step, this indicates the method for specifying the object(s) to be
seized. 'FromList' will trigger the user to select an object list from the Object List Name property. 'Specific' will allow the user to enter the
name of a specific object in the Object Name property of the Seize step. And 'ParentObject' will indicate that the Seize step should seize
capacity of the parent object of the token that is executing this Seize step.
Enum.ObjectSeizeType.FromList
Enum.ObjectSeizeType.ParentObject
Enum.ObjectSeizeType.Specific
Owner Type - Found in the Owner property of the Seize Step, this determines which object will be allocated capacity of the seized object.
In other words, which object will perform the seize - the parent object of the token or the associated object of the token.
Enum.OwnerType.ParentObject
Enum.OwnerType.AssociatedObject
Park Unpark Type - Found in both the Park Type and UnPark Type properties of the Park Step and the UnPark Step. These properties
are used to determine which object to park or unpark; the parent object of the token or the associated object of the token. 696 / 815
are used to determine which object to park or unpark; the parent object of the token or the associated object of the token.
Enum.ParkUnParkType.ParentObject
Enum.ParkUnParkType.AssociatedObject
Queue Ranking - This enumeration is found in multiple places throughout Simio. Most notably, it is used in the Ranking Rule property of
almost all of the standard library objects. It provides choices for the static ranking rule of the queues of these objects. For example, the
Server uses these choices in its Ranking Rule property to order the requests waiting to be allocated capacity of the object. The
TransferNode uses it to order travelers waiting to cross through the node.
Enum.QueueRanking.FirstInFirstOut
Enum.QueueRanking.LastInFirstOut
Enum.QueueRanking.SmallestValueFirst
Enum.QueueRanking.LargestValueFirst
Remove Object Type - This enumeration is found in the Removal Type property of the Remove Step. It specifies whether the step is
removing the parent object, the object associated with the token or and object at a specific rank within the queue.
Enum.RemoveObjectType.ParentObject
Enum.RemoveObjectType.AssociatedObject
Enum.RemoveObject.AtRankIndex
Reservation Method - This enumeration is found in the Reservation Method property of the Ride Step and therefore also in the standard
TransferNode since this object uses a Ride Step in its logic. This property specifies which method to use to select and reserve a transporter
to ride on. ReserveC losest will find the transporter that is physically closest to the TransferNode. If there are two that are of equal
distance, the node's Selection Goal property will be used to determine which transporter to select. ReserveBest simply looks to the
Selection Goal and Selection Criteria properties and finds the Transporter that best fits the goal. The FirstAvailableAtLocation will cause the
entities to wait for a Transporter to arrive to the node.
Enum.ReservationMethod.ReserveC losest
Enum.ReservationMethod.ReserveBest
Enum.ReservationMethod.FirstAvailableAtLocation
Search Collection Type - These choices are found in the Collection Type property of the Search Step. It indicates where the Search
Step will perform its search.
Enum.SearchC ollectionType.ObjectInstance
Enum.SearchC ollectionType.ObjectList
Enum.SearchC ollectionType.ObjectsSeizedByParentObject
Enum.SearchC ollectionType.ObjectsSeizedByAssociatedObject
Enum.SearchC ollectionType.QueueState
Enum.SearchC ollectionType.TableRows
Search Type - This enumeration is found in the Search Type property of the Search Step. It indicates what type of Search should be
performed. 'Forward' indicates that the collection will be searched starting at the value set in the Starting Index property of the Search
Step or at the beginning of the collection, by default. The collection is then searched moving forward. 'Backward' indicates that the
collection will be searched starting at the value set in the Starting Index property of the Search Step or at the end of the collection, by
default. The collection is then searched moving backward. 'MinimizeReturnValue' will search the collection and return the minimum value
that it finds for the criteria listed in the Return Value property. 'MaximizeReturnValue' will search the collection and return the maximum
value that it finds for the criteria listed in the Return Value property.
Enum.SearchC ollectionType.ObjectInstance
Enum.SearchType.Forward
Enum.SearchType.Backward
Enum.SearchType.MinimizeReturnValue
Enum.SearchType.MaximizeReturnValue
Seize Request Move Type - This enumeration is found in the Request Move property of the Seize Step. It indicates whether a move to a
specified location will be requested from the seized object(s). 'None' indicates that a move is not required. 'ToNode' indicates that the
seized object must arrive to the specified node before the token will be released from the Seize Step.
Enum.SeizeRequestVisitType.None
Enum.SeizeRequestVisitType.ToNode
Seize Selection Goal - This enumeration is found in the Select Goal property of the Seize Step. It determines the criteria that the Seize
step will use to determine which object to seize.
Enum.SeizeSelectionGoal.SmallestDistance
Enum.SeizeSelectionGoal.LargestDistance
Enum.SeizeSelectionGoal.PreferredOrder
Enum.SeizeSelectionGoal.SmallestValue
Enum.SeizeSelectionGoal.LargestValue
Enum.SeizeSelectionGoal.Random
SetRow Object Type - This enumeration is found in the Object Type property of the SetRow Step. It specifies whether the step is
assigning a table reference to the parent object, executing token, object associated with the executing token, or a specific object or
element.
Enum.SetTableObjectType.ParentObject
Enum.SetTableObjectType.AssociatedObject
Enum.SetTableObjectType.Token
Enum.SetTableObjectType.SpecificObjectOrElement
Set Value Object Type - This enumeration is found in the Object Type property of the Set Node Step. It specifies whether the step is
setting the destination node value of the parent object or of the object associated with the executing token.
Enum.SetValueObjectType.ParentObject
697 / 815
Enum.SetValueObjectType.AssociatedObject
Statistic Confidence Interval Type - This enumeration is found in the Confidence Interval property of the State Statistic Element and
the Tally Statistic Element. It specifies what confidence interval to use to calculate a confidence interval half width statistic for the average
of the recorded values. 'Default' will indicate that the confidence interval used will be either 'None' if running interactively, or will be the
experiment's specified confidence level if running an experiment scenario for a single replication.
Enum.StatisticC onfidenceIntervalType.None
Enum.StatisticC onfidenceIntervalType.Default
Enum.StatisticC onfidenceIntervalType.Point90
Enum.StatisticC onfidenceIntervalType.Point95
Enum.StatisticC onfidenceIntervalType.Point98
Enum.StatisticC onfidenceIntervalType.Point99
Suspend Resume Type - This enumeration is found in both the Suspend Type property of the Suspend Step and the Resume Type
property of the Resume Step. It specifies what type of behavior or movement to suspend or resume. 'ParentObjectMovement' suspends or
resumes the movement (Movement.Rate) of the token's parent object. 'AssociatedObjectMovement' suspends or resumes the movement
(Movement.Rate) of the token's associated object. And 'Process' will suspend or resume the token that is executing the specified process.
Enum.SuspendResumeType.ParentObjectMovement
Enum.SuspendResumeType.AssociatedObjectMovement
Enum.SuspendResumeType.Process
Tally Value Type - This enumeration is found in the Value Type property of the Tally Step. It specifies what type of observation to
record. 'Expression' will record the value of the specified expression into the Tally Statistic. 'TimeBetween' records the time between
arrivals to the Tally Step.
Enum.TallyValueType.Expression
Enum.TallyValueType.TimeBetween
Timer Interval Type - These choices are found in the Interval Type property of the Timer Element. It determines the mode that is used
by the Timer Element to determine the time interval between two successive timer events. 'Time' indicates that the time between events is
specified in the Time Offset and Time Interval properties. 'TimeInState' indicates that the Timer will fire an event based on the amount of
time spent in a certain state. The Timer determines the State from the specified value in the State Variable Name property and the State
value property. 'RateTable' tells the Timer Element to fire events according to the specified Rate table, which defines how the rate of timer
events changes over time (the event occurrences follow a non-stationary poisson process). 'EventC ount' will trigger an event according to
the number of Triggering Event occurrences. 'ArrivalTable' indicates that the Timer will fire events according to the times listed in the
numeric table property (i.e. table column) of the specified table.
Enum.TimerIntervalType.Time
Enum.TimerIntervalType.TimeInState
Enum.TimerIntervalType.RateTable
Enum.TimerIntervalType.EventC ount
Enum.TimerIntervalType.ArrivalTable
Traffic Direction - This enumeration is found in the Initial Desired Direction property of all the standard Link objects, such as the Path.
When the Type property is set to 'BiDirectional', this property is switched on to allow the user to specify which direction the traffic should
travel on this link. 'Either' indicates that traffic can travel in both directions, both forward and reverse. 'Forward' restricts traffic to travel in
the forward direction, or the direction that matches the direction in which the arrows are pointing. 'Reverse' restricts traffic to travel in the
opposite direction. When Traffic Direction is set to 'None', entities cannot travel on this link.
Enum.TrafficDirection.Either
Enum.TrafficDirection.Forward
Enum.TrafficDirection.Reverse
Enum.TrafficDirection.None
Traffic Direction Rule - This enumeration is found in the Traffic Direction Rule property of all the standard Link objects, such as the Path.
When the Type property is set to 'BiDirectional', this property is switched on to allow the user to specify the rule that is used to direct
traffic entry onto the bidirectional link.
Enum.TrafficDirectionRule.FirstInEntryQueue
Enum.TrafficDirectionRule.MatchDesiredDirection
Enum.TrafficDirectionRule.PreferDesiredDirection
Transfer From Type - This enumeration is found in the From property of all the Transfer Step. This indicates the location type that the
entity object is to be transferred from.
Enum.TransferFromType.FreeSpace
Enum.TransferFromType.C urrentStation
Enum.TransferFromType.C urrentNode
Enum.TransferFromType.EndOfLink
Transfer Object Type - This enumeration is found in the Object Type property of all the Transfer Step. This specifies which entity object
is to be transferred, either the parent object or the object associated with the executing token.
Enum.TransferObjectType.ParentObject
Enum.TransferObjectType.AssociatedObject
Transfer To Type - These choices aree found in the To property of all the Transfer Step. This indicates the location type that the entity
object is to be transferred to.
Enum.TransferToType.AssociatedObject
Enum.TransferToType.FreeSpace
Enum.TransferToType.Node
Enum.TransferToType.OutboundLink
Enum.TransferToType.ParentExternalNode
Enum.TransferToType.Station
698 / 815
Transporter Type - This enumeration is found in the Transporter Type property of the Ride Step and therefore also in the standard
TransferNode since this object uses a Ride Step in its logic. This property specifies where to look to reserve a transporter to ride on -
either to a specific transporter or select from a list of transporters.
Enum.TransporterType.Specific
Enum.TransporterType.FromList
Trip Selection Goal - This enumeration is found in the Task Selection Strategy property of the standard Vehicle object. It specifies the
strategy used by the Vehicle object to select its next transport task.
Enum.TripSelectionGoal.SmallestDistance
Enum.TripSelectionGoal.LargestDistance
Enum.TripSelectionGoal.SmallestPriority
Enum.TripSelectionGoal.LargestPriority
Enum.TripSelectionGoal.FirstInQueue
699 / 815
Simio Reference Guide
R eferencing C andidate O bjects
700 / 815
Simio Reference Guide
R unning the Model
There is also a small run icon and stop icon in the Quick Access Toolbar at the very top left of the Simio application. This can be accessed from
anywhere in the application and allows the user quick access to start, pause or stop a run. Note that a run can begin by the user hitting F5 (and
paused with F5) and can be stopped with Shift-F5.
Save, Run, Stop
701 / 815
Automatically Return Zero Instead of NaN in Expressions is initially set to False. If it is True, then for any element or state function with no
parameters that is used in an expression, the engine will automatically adjust a NaN result returned by the function to zero. This was implicitly
true in Sprint 85 and older.
Do Not Perform Unit Conversions for State Parameters is initially set to False. If it is True, then the engine will not properly handle conversions of
state parameters such as Weight or Volume parameters of a queue that is holding entities. This was implicitly True in Sprint 89 and older.
Maximum Expression Stack Size indicates the size of the stack expressions to evaluate before throwing a runtime error. For example, if
expression A calls into expression B, which calls into expression C , a stack size of at least 3 would be necessary. The default value is set to '20'.
These options have been put into the software for compatibility reasons, so that when a changes was made internally to the Simio software, it
would not automatically 'update' a user's model such that their results are different.
Ensure Foreign Nodes Cast To Non Node Types Are Associated Nodes is set to False by default. If True, Simio will give a runtime error if a node is
referenced via the Foreign/C andidate/Owner keywords, the cast given is not a Node type, and the node is not associated with an object as an
external input or output node. This option was implicitly True in Sprint 90 and older.
Always Allow 'Infinity' As Link Selection Weight Value is an option that recommended to be set to False. This indicates whether 'Infinity' is always
allowed as a possible value for a link selection weight.
Assume Input Node Entries Are To Associated Object If No Drawn Outbound Links is initially set to True. If it is True, then if an entity is entering a
node with no drawn outbound links and that node is an external input node to enter another object, the engine will assume the entity's objective
is to enter the input node's associated object and thus execute the node's standard 'OnEnteredAssociatedObject' process (if specified). Prior to
Sprint 99, a runtime error would be given if the node had no outbound links.
Ignore Short Circuit Evaluation In Expressions is initially set to True. If it is True, then Simio will not 'short circuit' evaluation of expressions using
&& or || in them. For example, 'MyRefState != Nothing && Random.Uniform(MyRefState.MyEntity.MyState, 100)< 5' will normally 'short circuit'
evaluation if it sees that MyRefState is Nothing and will not evaluate the latter part of the && statement. If the setting is True, Simio will evaluate
both parts no matter what. This option was added to the software within Sprint 101.
Ignore Primary-Foreign Key Relationships When Evaluating Table Property 'RandomRow' Function is initially set to False. If using
TableName.PropertyName.RandomRow function syntax in an expression and this seting is set to True, then the value returned by the RandomRow
function will ignore any foreign-primary key relationships and always return a random row index into the entire table, regardless of whether or
not the active token or object is referencing a row selection in the table. This option was added in Simio Sprint 102.
Throw Error If Index Out Of Range When Evaluating An 'ItemAtIndex' Function is initially set to True. If using
C ollection.ItemAtIndex(index)function syntax in an expression and this setting is set to True, then when evaluating the function, a runtime error
will be thrown if the index argument is out of range. Otherwise, an undefined or null value will be returned without any error. This option was
added in Sprint 105.
Use Performance-Optimized Steps is initially set to True. If this setting is True, then at runtime Simio will attempt to use performance-tuned
versions of certain steps where possible. The recommended value for this setting is True.
Default List State Results Classification Data Item String represents the default string used as the Data Item field for classifying results reported
by list states in the model. Note that you may insert a state variable label into the Data Item classification string by using the special parameter
'$(StateValueLabel)'. When a list state is reporting statistics for an individual state value, if that parameter occurs within the Data Item
classification string then it will be replaced with the actual state value label. The default value for this is 'Time$(StateValueLabel)'.
702 / 815
Prevent Monitor Triggering During State Initialization is initially set to True. Indicates whether monitors in the model will be prevented from
triggering during the value initialization of their monitored state variables.
Harvest Available Rows Via Union Across All Rows Referenced From Original Table is initially set to False. Indicates whether calculation of
available rows will result from the union of all row relations into tables referenced via foreign key from the table explicitly selected. This was
implicitly True in Sprint 134 and older.
Always Associate Dynamic Selection Rule Evaluations With the Objects Making The Selections is initially set to True. Indicates whether expression
evaluations when using a dynamic selection rule are always associated with the objects making the selections. The recommended value for this
setting is True. For models built in Sprint 134 or older, this value should be changed to True to utilize the dynamic selection rules correctly.
Set CurrentJobStep When Setting Row On Sequence Destination Table is initially set to False. Indicates if, when executing a SetRow on a table,
and that table contains sequence destinations, and a previous table selection was made with foreign keys into that table, if the C urrentJobStep
should be set to the row indicated in the SetRow step. The recommended value for this setting is False. This was implicitly True in Sprint 134 and
older.
703 / 815
Simio Reference Guide
T race
Trace
The Trace window can be displayed by clicking on the Trace Window icon in the Run Tab of the ribbon menu. The Trace window will appear at the
bottom of the application and will read Trace - Trace On. If the user clicks the Trace Window icon again, the window will remain but it will read
Trace - Trace Off. To close the window, the user can click the X in the top right corner of the Trace Window. This window can be moved around the
application by clicking and dragging. It is important to note that if a project was saved with the Trace Window on, Simio will automatically open
the Trace Window when opening a project to avoid running with the trace accidentally turned on. Excluded Steps and Processes are not shown in
the Trace.
The Run Tab with the Model Trace Clicked On
If the Trace has been on during the model run, the contents will also be written to a .csv file. This file can be located in the same location where
the project file is saved. This file can be loaded into Excel so it can be filtered and sorted for ease in troubleshooting and understanding of the
exact processing steps of the model. There is a limit to the size of the file so if the model is run for a long period of time, the .csv file might not
contain all of the contents of the trace.
The time units that are displayed within the Trace Window can be changed by selecting the desired units from the Units Settings button, Time
property drop down, found on the Run Ribbon.
A user can filter the Trace window by any of the column headers. There is a filter icon located to the right of each column name. This allows the
user to hide sections of the trace so it is easier to analyze the sections of that are of interest. For instance, if you would like to only trace the
activities of one particular entity or one particular process, you can filter so that you only view the activity of that entity or process in the Trace
window. No other activity is displayed in the Trace until the filter is removed. To set a filter, select the filter icon within a given column and and
select the entity (or object, process, token, step, etc.) of interest from the drop down. Simio allows for more than one filter at a time. The filters
that are set are displayed at the bottom left of the Trace window. Filters can be removed by selecting the 'x' next to the filter on the bottom left of
the Trace window, by selecting (All) within a given filtered column or by clicking on the 'x' next to the filter within the column filter dropdown.
C ustom filters may also be specified (see below custom filter dialog).
Filtering Trace by Entity (Customer.179) and Starting to Add an Additional Filter by Object
704 / 815
Simio Reference Guide
Breakpoints
Adding a Breakpoint
A Breakpoint can be added to an object, node or link in the Facility window, or to a step within the Processes window. It causes the execution of
the model to pause when an entity or a transporter arrives to the specified object, node or link or when a token arrives to the specified step.
A Breakpoint can be added in two ways in the Facility window. A breakpoint may be added by clicking the Breakpoint icon in the Run ribbon when
the object, node, or link is selected. Alternatively, if an object, node or link is selected in the Facility window, right-click will bring up a small menu
that includes Breakpoint.
Similarly, within the Processes window, a breakpoint may be added to a step in several ways. First, the Breakpoint icon on either the Run ribbon
or Process ribbon can be selected when the desired step is highlighted. Alternatively, if a step is selected, the right-click menu provides a
Breakpoint option to turn the breakpoint off and on. Steps with breakpoints are then shown in red.
Breakpoint Properties
Listed below are the properties of Breakpoints:
Property Description
Expression The expression to be evaluated.
When The option for determining when to break on a specified expression. WhenTrue will break when the expression specified is evaluated
to true. WhenC hanged will break when the expression specified has changed from the previously evaluated value when that
breakpoint object or step was reached.
C ount The option for a count-based break, based on the number of times the breakpoint has been 'hit'. Always will not track the count,
C ondition EqualTo will break when the hit count is equal to the C ount value, and AtLeast will break when the hit count is equal to or greater
than the C ount value.
C ount The value associated with the C ount C ondition for breaking either EqualTo or AtLeast a certain value.
706 / 815
Simio Reference Guide
Start and End T ime O ptions
Simio also provides the user with the ability to specify a stopping condition for the model run, which is done in the properties of both a
StateStatistic and a TallyStatistic. See Elements for information on these statistic elements.
707 / 815
Simio Reference Guide
W arning Level
Warning Level
The Warning Level sets the warning reporting level for the current model. There are three levels of warnings:
Alert User - Display warnings in a pop-up window. If this option is selected, the runtime warnings for the current model will be written to
the Trace window and will also appear in pop-up message boxes during an interactive simulation run. The user will have the option of
preventing individual warnings from appearing in pop-ups.
Write to Trace Only - Report warnings to the Trace window. If this option is selected, the runtime warnings for the current model will be
written only to the Trace window.
Do Nothing - Turn off warning reporting.
When a warning pop-up is displayed, the user will be given the option to turn off future warnings of the same type. In the bottom left corner of
the pop-up, a box may be checked that indicates "Don't show this warning again". Within the Advanced Options, Warning Levels area, there is an
option to Re-enable Disabled Warnings, which will re-enable all previous disabled warnings for the current simulation model.
There are several automatic warnings that have been implemented within Simio. These include when the limit of a given object has been
exceeded (as defined in the object's Maximum Number in System property), when a potential deadlocking situation has occurred at a node (when
two bidirectional links intersect at a node), when the number of active tokens has exceeded a given value and when the number of active agents
or entities in the model is exceeded (the last two possibly due to logic issues and potentially resulting to memory issues).
708 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
709 / 815
Simio Reference Guide
R andomness
Randomness
Within the Advanced Options button on the Run ribbon within the Facility window and the Processes window, the options to Disable Randomness
and specify the Random Number are available.
Disable Randomness
Disabling randomness is often useful to facilitate verification and debugging, and for generating deterministic schedules, but is not appropriate for
most typical simulation applications. If the randomness is disabled, any random distribution reference will return the expected value instead of a
random variate. Additionally any probabilistic selection in the logic (e.g., probability based Decide step, link selection weights, the table property
RandomRow function, Random selection goal in Route step) will always select the choice that includes the 0.5 (or “50%”) cumulative probability.
There is a Run.RandomnessDisabled function that is available to determine during the simulation run whether the randomness is turned off or
on. This function may be useful in process steps to change the logic or data in your system if the DisableRandomness button is 'True' or 'False'.
For example, you may wish to have a Decide step that is 'C onditionBased'and evaluates the Expression 'DisableRandomness==False', meaning
that distributions will be used. The True exit may have a Delay step that delays for Random.Normal(10,1), where the average delay is 10
minutes; however, the False exit may have a Delay step may delay for 11 minutes, using a 10% 'buffer' since there are no distributions utilized.
Replication Number
The Replication Number option is for use in interactive model only. This option may be used to generate the same sequence of random samples
during an interactive run as would be generated for a specific replication when running the model in experiment mode. All random number
streams will be initialized using seed values corresponding to the specified replication number. This is useful if the user detects an error, warning
or problem with output in one of the simulation runs and would like to interactively view a particular replication.
710 / 815
Simio Reference Guide
Financials
Financials
Financials can be added to a model by either adding a C ost C enter element manually and then assigning a value to the C ostC enter.C ost or the
C ostC enter.C ost.Rate with an Assign Step, or by using the Financial properties on each Standard Library object. See the Financials category of
the properties of each Standard Library object to see where to assign costs such as C apital C ost, C ost Per Use, Holding C ost and Transportation
C osts.
Within the Advanced Options button on the Run ribbon within the Facility window and the Processes window, the options to specify Financial
information, including the default currency type and exchange rates, is available.
Default C urrency
The default currency option sets the default currency units assumed by the simulation model for financial data entry and reporting purposes. The
value is initially USD (United States dollar). Options to change the default currency can be found on the C ostC enter element, as well as on any
currency type state, such as C ost. The level state, C ost, is available on all intelligent objects and may be assigned by using the Assign step.
Set Exchange Rates
This option will set the exchange rates to be used by the model for conversion between any currency and Simio's base currency which is the US
Dollar (USD). For a currency whose exchange rate is not explicitly specified, a 1:1 exchange rate will be assumed. When this option is selected,
the dialog shown below is displayed. Under the currency column, a drop-down list of over 100 world-wide currency types is available. The
exchange rate column requires an integer or real value.
711 / 815
Simio Reference Guide
Speed Factor
Speed Factor
The Speed Factor represents the amount of simulation time between each animation frame. Lower values produce slower, more fluid animation.
Higher values produce faster, more coarse animation. The time between animation frames can be adjusted by using the Adjust Speed slider or by
typing in a new value into the Speed Factor text box. This is just an arbitrary scale. It will adjust how smooth the animation is by scheduling more
or less frames to render. The speed of the animation will vary from machine to machine, depending on your machine's performance. The scale is
in tenths of a second, so “10” will schedule a frame render for every 1 second of animation time, and “600” will schedule a frame render for
every minute of simulation time.
Animation Speed controls on the Run Tab
Simio provides an option for setting the Animation Type to Smooth or Course. Smooth animation will draw every animated frame, according to
the speed factor. C ourse animation will draw less frames, which produces faster animation that is less smooth. We recommend using Smooth
animation when recording a video with the .avi recording features.
Advanced Animation Options - Animation Type
712 / 815
Simio Reference Guide
Units Settings
The Unit Settings button provides a list of nine (9) combo boxes for various unit types in the simulation. The dialog allows the user to set the units
used to display time, length and distance travel rate, area and rate, volume and volume flow rate, and mass and weight flow rate.
These units are displayed in the the reports, pivot grid, watch window, status bar and trace window. Note that Status Labels in the Facility window
are always shown in the default unit setting.
713 / 815
Simio Reference Guide
W atching an O bject
714 / 815
Simio Reference Guide
Debugging the Model
One of the most common tools for debugging a simulation model is the animation. Simio includes both 2D and 3D animation graphics that allow
you to quickly and easily build a model and watch it run. By watching the animation, you can visually see the paths that entities take, the number
of entities in various queues, vehicle movements and much of what is going on in the system. You may find issues that cause you to investigate
further why things are happening as they are and Simio has a number of tools to help.
Trace Window
A very important tool for debugging a simulation model is the model trace. The model trace allows you to see exactly what is occurring during the
simulation run with each step that occurs. This enables you to slowly “walk through” the simulation events one step at a time to determine
whether the logic that has been incorporated is working as intended.
The Trace window can be displayed by clicking on the Trace Window icon in the Run tab of the ribbon menu. General information for turning on/off
debugging tools can be found in the Trace, Breakpoint, Running the Model and User Interface sections of help.
More specifics about Trace can be found in the below section titled Trace Window Details.
Run Tab Options
There are several options available on the Run tab for running a model interactively. These include the Run/Pause, Stop, Step, Fast-Forward and
Reset buttons. Typically when first running a model, you may like to set the Starting Time and Ending Type to the appropriate values (8 hours, 1
day, 10 days, etc.) and run the simulation. If your model runs and entities proceed through the objects as you’d expect them to, this may be all
you are likely to do. However, to get a closer look at what is happening or to ‘debug’ a potential or known problem, you will need more
information from the simulation run.
Run / Pause
The Run button is useful for running the simulation model without specific pauses between objects or for particular logic. Notice that when you
click on the Run button, it becomes a Pause button that you can press to simply Pause the model at the current simulation time. The Pause button
then reverts back to a Run button to continue the simulation.
Step
The Step button is extremely useful when tracing through the simulation run. When the active window is the Facility window, the Step button
will stop the simulation when an entity moves from one object to another. However, stepping when the Processes window is the active window
will stop the simulation as a token moves from step to step in a process. This includes the steps within the Standard Library objects.
Step in Facility window
For example, let’s say you have a simple simulation model of Source1 – Server1 – Sink1, connected by paths. If the Facility window is active,
then using Step, the simulation model will pause and entity will be seen moving between the following objects with each step:
Source1 (in OutputBuffer.C ontents queue)
Output@Source1 Transfer Node then moves along path to
Input@Server1 Basic Node
Server1 (in InputBuffer.C ontents queue to the left of the Server)
Server1 (in Processing.C ontents queue above the Server)
Server1 (in OutputBuffer.C ontents queue)
Output@Server1 Transfer Node then moves along path to
Input@Sink1 Basic Node
Step in Processes window
If the Processes window is active, the simulation model will pause much more frequently, as it stops at each step within the processes window
(including those built-in steps within a Standard Library object).
Many times it is also helpful to be able to view the animation while stepping through at a detailed level. This can be done by right-clicking on the
Processes tab and selecting New Vertical Tab Group. This will make two windows visible within the main viewing area, where you may have both
the Facility window and Processes window visible simultaneously. Making sure to have the Processes window active (highlighted), using the Step
button in the same example above will stop at each individual step that occurs in the simulation. It is very useful at this time to have the Model
Trace button activated and the Trace window open. The steps that occur within the above example are too numerous to detail, however, the
processes that are occurring and the logic that is being executed are displayed in the Trace window.
Fast-Forward
The Fast-Forward button is useful when you would like to move quickly through a portion of the simulation model without viewing the animated
objects in the Facility or C onsole windows. This is useful when you have a Breakpoint set and would like to get to that logic quickly. It may also be
useful to run until a certain time, which we will discuss in the Running Until a Given Time section below.
Reset / Stop
The Reset button can be used to re-initialize the model to its starting conditions. When Reset is used, all trace shown in the Trace window is
cleared. The Stop button is also used to stop the simulation run. One difference to note is that the Trace shown in the Trace window is not cleared
when using the Stop button. Trace can be viewed even when the model is stopped. Using the Stop button will cause the model to re-initialize upon
using the Go or Step buttons.
Running Until a Given Time
When debugging a model, there may be situations where you want to run the simulation for a given amount of time before pausing the model to
review everything in more detail. You may do this by specifying, through the Run tab, and Ending Type of Run Length with a given run length
specified. Once the model has run (or fast-forwarded) for that time, this Run Length can be changed and you may continue to step through or run
the model. For example, if you want to run the model for 2 hours then start stepping through the model, set the Run Length of 2 hours, and run
the model (or fast-forward). It will appear as though the model has run to completion (i.e., End of Run shown on bottom left run status bar). You
may now change the Run Length to 3 hours and the run status bar at the bottom left will change to “Paused”, where you may now wish to step.
Running until a given time is very useful if you have a modeling error at a specific time and would like to get back to that error quickly, or if you
have a particular time during the simulation where you would like to observe in detail what is happening.
Running Until a Breakpoint
A breakpoint can be added to an object, node or link in the Facility window, as well as to a step within the Processes window. A breakpoint will
cause the execution of the model to pause when an entity or transporter arrive to the specified object, node or link or when a token arrives at the
specified step.
715 / 815
specified step.
Within the Facility window, the breakpoint can be added to an object by highlighting the object and clicking on the Breakpoint icon on the Run tab
or by right-clicking on the object and selecting Breakpoint. Within the Processes window, the breakpoint can be added by selecting the
appropriate step and clicking on the Breakpoint icon in either the Process or Run tab.
Running until a breakpoint can be especially useful when defining a process within Add-On Process Triggers in the Standard Library objects. With
a breakpoint set, the model will run until that particular step is executed. If the Processes window is active, you may wish to Step through the
various steps in the process to make sure that the logic you added is working as intended.
Creating a Single Entity Through the System
Depending upon the complexity of your system and reason for debugging, it may be useful to simplify the number of entities through the system.
If you have a system with a lot of object interactions and/or you have an error occurring at a specific time with multiple entities, then this option
would not work for you. However, if you are trying to determine why an entity is going a particular route or whether a specific process is working
correctly, it may be very useful to allow only a single entity go through the system at a time.
What benefit does that provide? When tracing through specific logic or stepping to see an object move through the system, allowing only one
entity at a time into the system may allow you to more quickly determine what the problem is without having interaction and movement of other
objects in the system. Within the Stopping C onditions section of the Source, the Maximum Arrivals property allows you to specify the number of
entities to create; for example, 1 for a single entity.
Trace Window Details
The Trace window is opened by clicking on the Model Trace button on the Run tab. Once the Trace window is opened, the actual model trace can
be turned on/off by using the same Model Trace button. You will notice that within the Trace window, there are several columns to provide you
with much information about what is happening in the simulation model. These columns include:
Time – The current simulation time, in time units as specified on the Run tab. These time units may be changed during the simulation run
and the change will be reflected in the Trace window.
Entity – The current 'Associated Object' executing the logic. This is typically an Entity and includes ModelEntity objects, as well as Vehicles
and Workers (since they are also “entities”). Entity references include the name of the ModelEntity instance, as well as a defined number,
which is assigned by the simulation and will remain with the entity as it moves through the system until it is destroyed. Vehicles and
Workers will include the name and dynamic object instance (i.e., [1], [2], etc.). Other references that are not Entities include timers and
failures, for example, in which case you will see the 'Associated Object' for that timer or failure.
Object – The name of the object where the current entity is evaluating logic. This may include names of fixed objects, such as Source1,
Server1 or Resource1. It may also include nodes, or links such as Input@Server1 or Path1 or dynamic objects, such as Vehicle1[1] or
Worker1[2]. Within the Process steps, this object is typically refered to as the 'Parent Object'.
Process – The process in which the entity’s’ associated token is executing. This may include a user defined process such as
Server2_Processed or a Standard Library object process such as OnEnteredProcessing.
Token – The token number that is executing a given step. This token is automatically created when the process execution is initiated and
will exist only while in the steps in a given process. The token can refer to both the Associated Object and the Parent object.ok
[Step]StepName – The internal name of the step that the token is executing; for example, Assign, Delay, Decide or Transfer followed by
the user-defined name of the Step. When you are writing your own processes the user-defined name can be very helpful in understanding
and debugging your model.
Action – The action that is taken based on the step that is executed. For example, it may say ‘Delaying Token for ‘0.32’ hours until time
‘1.35’ hours’ or ‘ Token branching on condition ‘Is.RedOnes, Token sent to False exit.’ These actions are very useful in determining exactly
what is happening in your model on a step by step basis.
As you can see in the above picture, the model trace can be quite extensive. This trace output is automatically saved to the file
‘ModelName_Model_Trace.csv’ in the folder where the model is located. You may wish to later view the file, rename it or search the file for
specific information.
Within the Trace window, the trace file can also be filtered to include only information you wish to view. Each column within the Trace window has
a filter button to the right of the column name. For example, perhaps you would like to view the specific trace information for a given entity
instead of all entities in the system. Within the entity column, click on the filter button and select the entity you would like to view. Filters can later
be removed to view all of the trace content by selecting (All) from a specific column's filter list. The existing filters are shown at the bottom left of
the Trace window.
Reviewing Simulation Data via Animation objects or Watch window
Other tools are also available when debugging a simulation model. These include the ability to view certain pieces of information during the
simulation model, from the number in a given queue to the value of particular function or statistic.
Animation in the Facility or Console windows
Within the Facility and C onsole windows, you may graphically animate any number of variables or functions by using the tools on the Animation
tab, such as status labels, plots or pies. For example, a status label may be useful for displaying the value of a user defined state variable,
‘inventory’, that you increase / decrease throughout the model. Status symbols can be stand alone or can also be attached to a particular object.
This can be done by highlighting the object, such as a Server or Node and selecting the animation symbol from the Symbol tab. See the following
functions, states and events pages for entity, node, transporter, resource and link objects for a listing of expressions you may wish to animate.
As just mentioned, animation can be attached directly to an object. This can be a stationary object, such as a Server, but can also be a dynamic
object, such as an Entity, Worker or Vehicle. Viewing information, such as an property or state of an entity, as it moves through the system can
provide invaluable information. Additionally, floor labels can include embedded expressions that can be very useful for debugging. See three
716 / 815
provide invaluable information. Additionally, floor labels can include embedded expressions that can be very useful for debugging. See three
SimBits, ExamplesofFunctions_StaticObjects.spfx, ExamplesofFunctions_DynamicObjects.spfx and OverflowWIP.spfx to see many of the functions
displayed in the Facility window and attached to objects.
Watch Window
The Watch window is another very useful tool for viewing information during the simulation run. Within this window, you can view the values of
various states and functions for any number of objects in the system. To add a Watch on a particular object, right click on the object in the Facility
window and select Watch. This will automatically open the Watch window at the bottom portion of the project. The Watch button on the Project
Home tab can be used to turn the Watch window off and on. When the model is run, any objects that are being watched will be displayed with a
“+”. C licking on the “+” will expand the object to show any functions, variables and processes associated with it. Refer to the Watching an Object
page for more details.
Additionally, the model itself has a section containing any user defined state variables as well. The values are updated when the run has paused
or when the Step button is used to move through the model. More detailed information about the user interface can be found in on the Watch
window section of help. By watching the values of functions and states on specific objects and the model, this will allow you to make sure that
values are being updated as you expect.
Summary
Simio includes many interactive tools for helping in the verification phase of your simulation project. Whether you have an error that has
occurred in your model or simply are stepping through the model to be sure that the logic you have implemented is working correctly, using a
combination of the Trace window, Watch window and/or animation within the Facility window can help provide great insight into the processes that
are being run and decisions that are being made within your simulation model.
717 / 815
Simio Reference Guide
Simio Event C alendar
The event calendar is the central core of any simulation engine. Its purpose is to maintain an ordered list of events that need to be executed at
the current and future times. These events correspond to token/entity movements through the system (e.g. an entity reaching the end of a link).
In large models there could be many thousands of events scheduled on the event calendar to occur at different times. Having an efficient
mechanism for handling a large number of scheduled events is crucial to fast execution of the model.
The Simio engine runs a model by executing the following event loop:
While (simulation is running)
{
Remove the next event from the event calendar
Advance Run.TimeNow to the time of this event
Execute the event logic for this event
}
Note that within this simple loop Simio is repeatedly removing the next event, advancing Run.TimeNow to the time of this event, and then
executing the logic for that event. The event logic will in turn often schedule additional events to occur, either at the current time (Run.TimeNow),
or after a time delay (Run.TimeNow + DelayTime).
The most common event that is executed by Simio in this loop is a “token arrived to a step” event. Each step has a method that is called when
this event executes. This method processes the logic for the step, making state changes as necessary to the arriving token, associated or parent
object, and/or one or more elements in the model.
In many cases the step arrival event executes in zero simulated time and the arriving token can immediately continue to the next step without
returning to the event calendar. However if a time delay occurs within the step (e.g. a Delay step) then the token arrival to the next step in the
sequence is scheduled on the calendar to occur at the end of the delay.
Some of the steps in Simio have more than one token that departs the step at the same simulated point in time. In most cases the token
departing the primary exit point is processed immediately and the token exiting the secondary exit point is scheduled to arrive to its next step at
the current time (Run.TimeNow). Hence the arriving token and secondary token depart the step at the same simulated time, but one token
executes its logic before the other. Each step with multiple departing tokens has a defined order for processing the departing tokens as
documented in the Simio Reference Guide.
Two primary actions that repeatedly take place during the simulation run are scheduling of a calendar event to occur at either the current time or
a later time, and removing the next event item from the calendar. These actions will take place millions of times in a typical simulation. In
addition to these it is also sometimes necessary to cancel a scheduled event (i.e. remove it from the calendar even though it’s not the next
event), or adjust the scheduled event time. All of these actions must be very efficient in execution.
The scheduled events in Simio are maintained internally using two connected data structures illustrated below: an ordered list and a minimum
heap. The ordered list holds all current events that are scheduled to execute at the current time (Run.TimeNow). The minimum heap is a tree
structure that holds events that are scheduled to occur in the future. The scheduled event time for each node in the tree is always less than or
equal to the event times for the two nodes that are immediately below it in the tree (if any). For example the top most event is scheduled to
occur at time 11, and this is less than the event times (13, 12) immediately below it in the tree. As time advances events are moved from the
future events heap to the current events list.
Each scheduled event item (either on the current events list or future events heap) maintains the following information:
Event time: The time that this event is to be executed.
Event method: A method that is to be called to execute the logic associated with the event.
Event object: An object (e.g. an entity) that is associated with the event.
Event index: An index that is incremented and assigned to each event item when it is scheduled.
Event type: An event type (Normal, Early, Late) that is used to break ties between events.
The events that are on the current events list are all scheduled to occur at the current time (Run.TimeNow). The times on the future events heap
will be greater than or equal to Run.TimeNow. The algorithm executes each of the events on the current events list until it is empty. Note that
during this period time does not advance. It then advances time to the time of the next event on the future events heap (always the top item on
the heap) and continues removing all events from the heap that are scheduled at that time and places them on the current events list for
execution.
The process of handling ties (i.e. events scheduled to occur at the same time) is very important in simulation engine design. Although a minimum
heap is very efficient in handling large numbers of events, it is not very good at dealing with ties. In Simio the relative position of tied events are
ignored when on the heap, but then sorted properly once moved to the current events list. This sorting is done first by event type to make events
scheduled as Early to execute first, events scheduled as Normal to execute next, and finally followed by events scheduled as Late. Within an
event type the events are ordered by event index; i.e. the order in which they were scheduled. An example of an Early event is an “initialization”
event for the simulation. An example of a Late event is the “end of run” event that occurs at the end of the simulation. The vast majority of
events are Normal events.
The heap is maintained during the simulation using operations that “bubble” an event up or down the tree. A bubble down operation compares an
event item to its left and right child. If it is less than or equal to both it is in its proper location and the bubble operation is complete. Otherwise it
trades places with its child with the smallest event time and this process continues until the event is bubbled down to its correct location in the
tree. A bubble up operation is slightly faster because we are comparing an event to its parent, and trading with the parent if the event time for
718 / 815
tree. A bubble up operation is slightly faster because we are comparing an event to its parent, and trading with the parent if the event time for
the parent is greater. Hence a bubble down requires two comparisons at each step where a bubble up requires only one.
Whenever we add a new event to the future event heap we add it to the next position in the bottom row of the heap and bubble it up to its correct
location in the tree. Whenever we remove the next event from the calendar we remove the top most event node from the tree, and then move
the far right event from the bottom row to the newly open position in the top row, and then bubble it down.
Note that if a scheduled event is canceled it can be removed from the tree and replaced with far right event from the bottom row which is then
bubbled up or down as necessary. Likewise an event that changes its scheduled event time can remain on the heap and simply bubble up or down
as necessary.
719 / 815
Simio Reference Guide
R un-time P rofiling
Run-time Profiling
The ability to Enable Run-time Profiling can be found in the Advanced Options button on the Run ribbon. The Profile window can be activated by
selecting the Profile button in the Project Home ribbon under Windows.
Run-time profiling, if enabled, will record step execution counts and timing for various parts of the model to provide run-time performance
information.
Example of a Profile for the HospitalEmergencyDepartment Model
Within the Profile window, there are several columns that can provide information on run-time performance. The Object.Process.step information
is specified under the "Item" column. The "% Time in Parent" column shows the step's run-time contribution to the parent object as displayed by
the ">" symbol (expand to get more details on the steps beneath that ">"). The "% Time Overall" column shows what this step's run-time
contribution is to the overall run, rather than just to its immediate parent. The "C ount" column is how many times this particular step was hit. The
columns can be sorted, and we default to what you see above. Note that sorting is within each row's parent row, rather than across all rows.
720 / 815
Simio Reference Guide
Interactive Logging (Enterprise)
This option will enable logging to the following logs during an interactive run, including the Resource Usage Log, Resource State Log, Resource
C apacity Log, C onstraint Log and Transporter Usage Log. See the associated help topics for details on each of these log reports.
721 / 815
Simio Reference Guide
Simulation R eplications
Simio Replications
Simulation results are generally based on replicating a simulation model multiple times to generate identically distributed and independent (IID)
output samples. For example we might replicate a simulation model 25 times, and use the average waiting time recorded in each of the 25
replications as an estimate of the true but unknown value for the expected waiting time. Based on the IID assumption we can then use the 25
samples to generate a confidence interval on the expected waiting time.
Each replication will automatically initialize both the system state and statistics. The model state is initialized by initializing all objects within the
model to their default starting state, and running the OnRunInitialized process for each object to allow user-customization of the initialized state.
The model statistics are initialized by zeroing out all statistics values (e.g. the average time in system). If a warm up time is specified for the
replication the statistics are initialized again at the end of the warm up time without reinitializing the system state. In other words the initial
statistics recorded during the warm up period are discarded, but the simulation continues running from its current state.
Simio makes it easy to setup an experiment for a model that is comprised of one or more scenarios. Each scenario may have one or more
controls (i.e. properties that supply inputs to the model), and one or more responses (i.e. a value such as average waiting time that is recorded
at the end of each replication). Simio will then automatically run replications across each specified scenario, changing the values for the controls,
and recording the values for the responses. The built-in SMORE plots will then display the results of a specified “primary” response for each
scenario that combines error (confidence interval) and risk (percentiles) measures, and optionally plot individual samples and/or histograms of
the individual response samples that are recorded at the end of each replication.
Each replication typically employs random numbers for generating samples for the time between arrivals, processing times, repair times, etc.
These random numbers are automatically generated by Simio using the built-in Mersenne twister pseudorandom number generator. This state of
the art generator has an extremely long period (2^(19937) – 1 or about 10^6001) that means from a practical sense the sequence will never
repeat within a Simio simulation scenario.
The random numbers within a model are generated from independent streams, and you can employ as many streams within your model as you
desire. The initialization seeds for each stream are automatically set by Simio. By default all random samples are taken from internal stream
number 0, however you can specify a different stream by appending the optional stream parameter for each distribution. For example
Random.Uniform(3,5,1) returns a random sample from a uniform distribution between 3 and 5 using random stream number 1. As we will discuss
below the ability to select a specific stream is important when using a method called common random numbers (C RN) to reduce the variability in
our estimators when comparing multiple scenarios.
When replicating a simulation model each replication samples from a different but defined starting point within the stream. These starting points
are set very far apart in the stream so that there is no practical risk of overlap. Since the random numbers in each replication are different, each
replication produces a statistically independent estimate for each of the output responses.
Although the random numbers that are used across replications are different (because they have a different but defined starting point in the
stream), they are identical for each replication within each stream across scenarios. Hence rerunning a simulation experiment with the same set
of controls will always produce exactly the same results for each replication. For example the random numbers generated for stream number 3
and replication number 8 will always be the exactly the same sequence of numbers, regardless of which scenario is being evaluated. This is
important for two reasons: first it makes our simulation experiments repeatable, and second it makes it possible to use common random
numbers across scenarios.
The random sampling from streams across replications and scenarios is illustrated in the following example with 3 replications, 2 streams, and 7
scenarios. Stream 1 is represented by shades of blue and stream 2 is indicated by shades of red. The different shades of blue and red indicate
that a different segment of random numbers within each stream is being used across the three replications. Hence although the three replications
sample from the same streams, the random values returned from those three streams are different because we start of different positions within
those streams. Hence the results across replications are independent samples. However if we look down across scenarios we see that the random
samples by stream and replication number are identical across scenarios. Hence we have the potential to have highly correlated results across
the scenarios.
This pattern of random sampling supports the concept of common random numbers to reduce the variability of our estimators when comparing
across scenarios. The basic idea of common random numbers is that we would like the differences between scenarios to largely reflect the
differences in control settings and not the particular set of random values that were used for a particular scenario. In other words we would like
to subject all the scenarios to the same random pattern of arrivals, process times, etc., and in doing so create correlation across the scenarios,
while keeping independence across the replications. This will improve the underlying results for many statistical analysis procedures that compare
alternatives. For example both the built in Simio subset selection procedure and the Nelson and Kim add in for selecting the best system benefit
from the use of common random numbers.
To make effective use of common random numbers it is important to create as much correlation as possible across the scenarios. This is done by
ensuring (to the extent possible) that the common random numbers that are generated across scenarios are used in the same way. Note that
letting all random variables sample from the default stream (0) will typically not achieve this because the controls on the model (e.g. number of
servers), will change the sampling pattern from the steam, and therefore a random sample that was used for a processing time may now be used
for an inter-arrival time, etc. Ensuring the exact same usage of random numbers is not always convenient to do in all cases throughout722 the / 815
for an inter-arrival time, etc. Ensuring the exact same usage of random numbers is not always convenient to do in all cases throughout the
model, but typically very easy to do for arrival processes. By using a separate random number stream for all arrival processes we can guarantee
that we get the exact same sequence of arrivals across all scenarios.
A good practice is to always use stream 1 for inter-arrival times, stream 2 for task times, and then default everything else to stream 0. This is
very simple and effective way to induce correlation across scenarios and improving our ability to draw conclusions from the results.
723 / 815
Simio Reference Guide
Experiments
Experiments
Experiments are used to define a set of scenarios to be executed using the model. They are executed in batch mode. This is typically done (once
a model has been validated) to make production runs that compare one or more variations of the system.
Each scenario has a set of control variables (e.g. size of each input buffer) and output responses (e.g. the throughput, waiting times, etc.). The
control variables are the values assigned to properties of the associated model. Before adding an experiment you typically add properties to your
main model to serve as the controls that you want to change for each scenario. Since most models contain random components (e.g. service
times, failures, etc.) replications of the scenario are required to allow the computation of confidence intervals on the results.
An experiment is not owned by a model. Rather, an experiment references and uses a model (is “bound” to a model). This means that, if a model
is removed from a project, any experiments that referenced and used that model may remain in the project to preserve experiment results.
Users should be able to distribute experiments between projects.
Within the Analysis section of the Experiment properties window, a user can specify a warmup period for the run, as well as a confidence level.
Creating a New Experiment
An Experiment can be added to a project in two different ways. It can be added from within the Project Home ribbon by selecting the New
Experiment icon. A fixed type model must be active (highlighted in the Navigation window) and the new Experiment is bound to this active model.
An Experiment can also be added from within the Experiments panel in the Project window. The drop down menu of the Add Experiment icon in
the ribbon gives the user a choice of all the fixed type models that exist in the project. The user must select a model for the experiment to be
associated with. The experiment can then be renamed, edited, duplicated and deleted from the Experiments panel.
Adding an Experiment
724 / 815
The control values for a given scenario may be copied into the Model properties in the Facility window. See C ontrols for additional information.
Sorting and Filtering the Experiment Grid
The columns of the Experiment grid are categorized for easier reading. C olumns and categories can be reordered. The Experiment Grid can be
filtered and sorted. C licking in the upper right hand corner of a column will bring up the filtering menu. This allows the user to select a value to
filter by or allows the user to create a custom filtering expression. The grid can also be sorted by clicking once or twice on the column header to
be sorted. Multiple sorts can be added with shift-click.
Additionally, the columns of the experiment grid can be rearranged. The first row of column headers (Scenario, Replications, C ontrols) can be
dragged around to change the order of the columns. For example, a user might want to have the C ontrols columns appear first in the grid and
therefore they would drag the C ontrols column header to the left of Scenario. Similarly, a user can rearrange the second row of column headers,
but only within the umbrella of the parent column header. For example, a user can rearrange the order of the individual C ontrols columns by
dragging the columns around underneath the larger C ontrols column.
Filtering the Contents of a Column within an Experiment
Note:
Experiments cannot be run in Evaluation Mode of Simio unless the model is within the specified modeling limits. If you would like to see and run
an example experiment, see the AirportTerminal example model and go to the Experiment window.
726 / 815
Simio Reference Guide
C ontrols
Control Variables
The control variables are the values assigned to properties of the associated model. Before adding an experiment you typically add properties to
your main model to serve as the controls that you want to change for each scenario. Once a property exists in your model, it will appear as a
column in the experiment table in the Experiment Design Window. The property's DisplayName is what will appear as the column name. The user
can create multiple scenarios, each with a different value in the control variable.
Even though there are default values for the properties (controls), the experiment will use the values that are specified in the Experiment Design
table. Using the example below, if the default value of the ServerC apacity property is set to 3, the experiment will ignore this and use the values
specified in the table (1, 1, 2, 2), for each scenario, respectively. Therefore, do not assume that the default property values will be used if the
field in the Experiment Design table is left empty. The experiment will use the value of 0.
Experiment with Multiple Scenarios of Different Controls
727 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
728 / 815
Simio Reference Guide
R esponses and C onstraints
Often times a system will have user defined limitations – they could be putting a limit on the total number of cashiers at a grocery store, setting a
maximum time a customer is allowed to be waiting on hold at a call center, or making sure that the total cost of implementing a new system is
within budget. These limitations are essential for correctly modeling a process and must be represented by your simulation because without them,
your model can return infeasible results. Simio allows you to easily incorporate these limitations into your model through experimentation. If you
would like to determine if the result of a Scenario is acceptable then you can set an Upper or Lower Bound on a Response. If your limitation
involves C ontrols “interacting” with each other – such as the sum of the lengths of a set of conveyors has to be less than a certain value – then
you can represent this using a Constraint.
Responses
A Response specifies an expression that typically includes statistics recorded during the run, such as average waiting time or throughput, etc. The
response is recorded at the end of each replication of each scenario.
A value can be defined for a Lower Bound and an Upper Bound for this response. Simio will color the response red if it fall below the lower bound
or falls above the upper bound. Simio does not do anything else with the bounds except for changing the color in the interface. These bounds will
be used in the future with Experiment Add-Ins. Similarly, the response property named Objective will be used in the future for Experiment Add-
Ins.
To add a Response, simply click the Add Response button in the Experiment section of the Experiment Design Ribbon. The resulting Response
column can either act as a purely informative display of a certain statistic of interest or an objective function that you are trying to optimize. You
can customize a Response column type with the information entered in the following properties:
Name – The name of the response, which is reflected in the column header.
Expression – The expression to be evaluated at the end of the simulation run.
Objective – Indicates if larger or smaller values of this response are preferred. This is available for use with Add-Ins, such as the
OptQuest Add-In. It determines how OptQuest is to use the response information when determining the optimal solutions. Objective can
either be:
None – Just an informative response and not used to make decisions
Maximize– OptQuest drives the Experiment to achieve the greatest values for the objective function
Minimize– OptQuest drives the Experiment to achieve the lowest value for objective function
Upper Bound – Any values for this response above this value are considered infeasible
Lower Bound – Any values for this response that are below this value are considered infeasible
The response can be removed from the experiment by clicking the Remove Response icon in the Design tab of the ribbon menu.
Adding a Response to an Experiment
Constraints
If your limitation involves C ontrols “interacting” with each other – such as the sum of the lengths of a set of conveyors has to be less than a
certain value – then you can represent this using a C onstraint column. C onstraints are added by clicking the Add Constraint button in the
Experiment section of the Design Ribbon. C onstraints are designed to identify any out of limit controls that have been manually defined as well as
to limit automatic creation (by OptQuest) of scenarios with controls that would be out of limits. The values displayed in a constraint column will be
the value of the expression defined in the Expression property. When using OptQuest, this column will only show values that are within the
constraint bounds – this only works for linear constraints (no multiplication or division). All scenarios that violate input constraint bounds are
discarded before running in Simio thus will never show up on the screen.
Responses Vs Constraints
If all members of your system limitation expression can be represented by a C ontrol – use a Constraint .
If any member of your limiting expression needs to run a Scenario in order to be evaluated – use a Response.
729 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
730 / 815
Simio Reference Guide
Analysis - ExperimentP roperties
Note: C onsidering the waiting time of entities during the warm-up period could bias the results of the run and Simio takes the position of
excluding that bias. Therefore, the average waiting time statistic within a replication is not dependent on what happened during the warm-up
period.
Note: An experiment’s C onfidence Level setting may also be used to calculate runtime confidence interval half-widths on TallyStatistic or
StateStatistic element averages in the model. See the C onfidenceLevel property of the TallyStatistic and StateStatistic elements for more
information.
OptQuest for Simio Parameters
This section within the experiment properties will appear when the OptQuest for Simio Add-In is selected. This is where you define properties for
that Add-In, which will aid in finding an optimal solution for your model.
Select Best Scenario using KN Parameters
This section within the experiment properties will appear when the Select Best Scenario using KN Add-In is selected This is where you define
properties for that Add In, which will aid in selecting the best scenario from a list of candidate scenarios.
731 / 815
Simio Reference Guide
Experiment R esponse C hart
Graphing an Experiment
The Response Results window of an Experiment creates a Simio Measure of Risk & Error (SMORE) plot using the Response value that is selected
in the Response pull down menu. The plot is display results across replications, for each scenario. The Response Results tab can be moved so
that the graph can be seen plotting as the Design Window steps through replications and scenarios, in real time.
Simio Pivot Tables and Reports provide an estimate of the population mean and confidence interval based on multiple replications. While this is
exactly what is needed in some situations, in others it provides an inadequate amount of information required to make a decision taking into
account risk. As Dr. Nelson puts it in his paper discussing the concepts of Measure of Risk & Error (MORE) plots (Nelson 2008), “A baseball
player’s batting average is a meaningful historical statistic. However, a simulation is not trying to create history; instead it is trying to say
something about what will happen in the future and whether we can live with it.”
A Simio Measure of Risk & Error (SMORE) plot displays both the estimated expected value of a scenario and multiple levels of variability behind
the expected value. A SMORE plot consists of a Mean, C onfidence Interval for the Mean, Upper Percentile Value, C onfidence Interval for the
Upper Percentile Value, Lower Percentile Value, C onfidence Interval for the Lower Percentile Value, Median, Maximum Value, and Minimum Value
(sample illustrated below):
Parts of a SMORE Plot
In the Properties Window of an Experiment, the user is able to set the Upper and Lower percentiles (Upper Percentile will be set to 75 and Lower
to 25 by default), C onfidence level used to calculate C onfidence Intervals (95% by default).
Experiment Properties
The accuracy and usability of this plot depends on having a large amount of data, which means a large number of repetitions. All aspects of the
plot will not be displayed fully unless we have a sufficient amount of data. Simio always displays the Mean, Max, and Min. Once the scenario has
at least six replications, the Median, Upper and Lower Percentiles, and all C onfidence Intervals will be displayed. The Ribbon now has new buttons
allowing the user to be able to turn on/off C onfidence Intervals, Observations, Upper/Lower Bounds, and Lines Between Means.
SMORE Plot
On the bottom left-hand corner of the Response C hart Window is a Raw Data Tab. This tab allows the user to view the values that are used to
construct the SMORE plots for each Response including the Mean, Minimum Value, Maximum Value, Mean C onfidence Interval Half Width, Upper
and Lower Percentile values, the bounds for Percentile C onfidence Intervals. Copy Plot to Clipboard, Export Summaries, and Export Details
buttons have been added to the Ribbon. Exporting Summaries allows the user to export what they see in the Raw Data Tab, while Export Details
provides users with the exact Response Value for each unique Scenario-Response-Repetition combination. Users can use this data to create their
own plots if they wish. Note that this is different than exporting the detailed results from the Experiment Design window.
732 / 815
Simio Reference Guide
R esponse Sensitivity and Sample Size Error Analysis
Simio incorporates two types of input data analysis that relate the Input Parameters of a model to the Responses defined in the experiment.
Both of these are found in the Experiment window under the Input Analysis tab. Response Sensitivity analysis is used to determine the
sensitivity of the Responses to changes in the Input Parameters. Response Sensitivity analysis is very useful in situations where the input
parameters have been specified in the absence of real world data and shows which Input Parameters have the biggest influence on the Reponses.
Response Sensitivity analysis can be used early in a modeling project to help guide decisions on devoting time/money to initially collect real-
world observations for input parameters. In contrast Sample Size Error analysis is performed once some real-world data has been collected
and is used to determine the overall impact of estimating the Input Parameters (based on real-world data) on the uncertainty in the Responses,
to determine which estimated Input Parameters make the largest contribution to this uncertainty, and to identify the Input Parameters for which
additional real-world observations would have the greatest benefit in reducing the uncertainty in the Responses.
Response Sensitivity analysis is automatically performed by Simio whenever the number of replications for a scenario is greater than the number
of Input Parameters. Note that no additional simulation experiments are required to perform this analysis; it is performed by Simio whenever the
minimum number of replications have been made in estimating the Responses. Note that uncertainty in the Responses is created whenever we
estimate our Input Parameters based on real-world data, and Sample Size Error analysis is used to answer the basic question “do we have a
large enough sample size for our real-world data to have confidence in our results, and if not which Input Parameters should we focus on for
collecting additional real-world data?” Sample Size Error analysis is a more complex undertaking than Response Sensitivity analysis and requires
an additional set of special simulation replications. Hence while Response Sensitivity analysis is automatically run by Simio, Sample Size Error
analysis is an optional extra analysis that can be initiated by the user. Once initiated this complex analysis is fully automated within Simio.
Input Parameters and Experiment Responses
Both Response Sensitivity analysis and Sample Size Error analysis compute relationships between the Input Parameters in the model and the
Responses that are defined for an Experiment. Hence the analysis can only be performed if at least one Input Parameter and one Experiment
Response has been defined.
Input Parameters are generally used to define named parameters which can then be referenced anywhere within your model. For example you
might define Input Parameters named InterarrivalTime and ProcessingTime, and then reference these names on the Source and Server objects
in your model. There are several advantages in using Input Parameters in place of directly entering these expressions in the model.
1. Input Parameters can be shared across multiple objects; e.g. if five servers all share the same Process Time, they can all reference the same
Input Parameter.
2. It is more convenient to enter distributions using Input Parameters since the distribution parameters are individually defined as properties of
the Input Parameter and a histogram is based on 10,000 samples is provided to show the shape of the distribution for the parameters.
3. Input Parameters enable both Response Sensitivity and Sample Size Error analysis.
Input Parameters are defined by selecting the Data window tab, and then selecting Input Parameters on the left panel. There are three different
types of Input Parameters – Distributions, Table Values, and Expressions. A Distribution is used to specify a random distribution. The parameters
for the distribution are specified in the property grid, and the histogram based on 10,000 samples of that distribution is displayed in the bottom
panel of the window. In addition to the distribution parameters you also define a Boolean flag that specifies if this Input Parameter is to be active
in the Response Sensitivity analysis, and a second Boolean flag that specifies if the Input Parameter is to be included in the Sample Size Error
analysis. If it is included in the Sample Size Error analysis you also specify the number of real-world observations that were used in fitting this
distribution. The second type of Input Parameter is a Table Value and is used whenever the actual observational data is randomly sampled in
place of fitting the data to a distribution and then sampling from that distribution. This is typically the preferred approach when actual data is
available. In this case you specify the table column name that holds the real-world observations. The third type of Input Parameter is an
Expression. In this case you can specify any mathematical expression, including random distributions and model properties. Although this is the
most general form of the Input Parameter one limitation is that it cannot be used in the Sample Size Error analysis.
Specifying an Input Parameter of Type Distribution
The Sample Size Error analysis also provides a second bar chart (selected using the lower tabs) that shows the relative benefit of collecting
734 / 815
additional data for each input parameter. In many cases the bar chart will appear similar to the relative contribution bar chart. However this is not
always the case since it is possible the relative value of additional samples will differ from the relative contributions. This is the case when the
number of real world samples differs for each input parameter.
The SimBit project named InputAnalysis includes two models, ResponseSensitivity and SampleSizeError, that show an example of using input
parameters with the analysis techniques described above.
735 / 815
Simio Reference Guide
O ptQ uest Add-In
Right-click on the experiment name and select Experiment Properties. The OptQuest Parameters will now be displayed in the Properties window.
These new OptQuest parameters are:
Min Replications – The minimum number of replications you would like Simio to run
Max Replications – The maximum number of replications you would like Simio to run
Max Scenarios – Determines the maximum number of scenarios you want OptQuest to create. It is possible that OptQuest will come to an
optimum solution before it creates this amount of scenarios.
C onfidence Level – The level of accuracy you want OptQuest to use when statistically comparing one response value to another
Relative Error – Percentage of mean in which the half-width of the confidence interval is determined. For example, if the mean is 50 and
you set the Error Percent to 0.1 (or 10%), the confidence interval will be 50 ± 5. After running the default number of Replications,
OptQuest will determine if this condition has been satisfied. If not, Simio will run more replications to reduce the variability.
Objective Type - Single Objective, Multi-Objective Weighted or Pattern Frontier. In Single Objective, OptQuest determines the set of control
values that optimizes the experiment's Primary Response. In Multi-Objective Weighted, OptQuest optimizes across all responses with
Objective set to Minimize or Maximize, taking into account each response's Weight value, to determine a single "optimal" solution. In
Pattern Frontier, OptQuest optimizes across all responses with Objective set to Minimize or Maximize, and finds the set of scenarios that
are optimal, rather than a single "optimal" solution based on weights.
Experiment Parameters
Controls
The OptQuest Add-In adds additional properties to the input C ontrols. Without OptQuest, the user has to manually enter the combinations of
C ontrol values that are to be tested. With OptQuest, each Input C ontrol has a minimum value, maximum value, and an increment size that
dictates the step size for which OptQuest will move between the minimum and maximum values to create scenario combinations.
Sometimes not all C ontrols are used in an experiment. Each C ontrol has a parameter called “Include in Optimization” with values of Yes or No. By
default this is set to Yes. To exclude the control from the experiment, simply set this parameter to No and every scenario will use the default
value for that property.
Control Properties
737 / 815
Responses
To add a Response, simply click the Add Response button in the Experiment section of the Design Ribbon. The resulting Response column can
either act as a purely informative display of a certain statistic of interest or an objective function that you are trying to optimize. Responses are
designed to display the output from a model. In addition, you can add limits to responses to assist in identifying any scenarios that violate the
limits. If a Response is found to be infeasible for a particular Scenario, the value will still be displayed, but will have its cell highlighted in red and
will not be considered in optimization. If the value is greater than the upper bound the cell will be shaded with a gradient that has more red on the
right side of the cell. C onversely, if the value of the Scenario is less than the lower bound, the cell will be shaded towards the left side of the cell.
You can customize a Response column type with the information entered in the following properties:
Name – The name of this Response, which is reflected in the column header
Expression – Where you enter the left-hand side of your expression or objective function.
Objective – Determines how OptQuest is to use the response information when determining the optimal solutions. Objective can either be:
None – Just an informative response and not used to make decisions
Maximize Objective – OptQuest drives the Experiment to achieve the greatest values for the objective function
Minimize Objective – OptQuest drives the Experiment to achieve the lowest value for objective function
Upper Bound – Any values for this response above this value are considered infeasible
Lower Bound – Any values for this response that are below this value are considered infeasible
Response
738 / 815
Constraints
If you want to put a limitation on your experiment that involves input C ontrols “interacting” with each other – such as the sum of the lengths of a
set of conveyors has to be less than a certain value – then you can represent this using a C onstraint column. C onstraints are added by clicking
the Add Constraint button in the Experiment section of the Design Ribbon. C onstraints are designed to identify any out of limit controls that have
been manually defined as well as to limit automatic creation (by OptQuest) of scenarios with controls that would be out of limits. The values
displayed in a constraint column will be the value of the expression defined in the Expression property. When using OptQuest, this column will
only show values that are within the constraint bounds – this only works for linear constraints (no multiplication or division). All scenarios that
violate input constraint bounds are discarded before running in Simio thus will never show up on the screen. If the constraint is used to validate a
set of manually defined C ontrols, a violated C onstraint will be shaded red in the same manner as a violated Response. For additional information
on using Responses and C onstraints in an Experiment, see the Responses and C onstraints page.
In Summary: If all members of your system limitation expression can be represented by an input Control – use a Constraint.
If any member of your limiting expression needs to run a Scenario in order to be evaluated – use a Response .
Constraint
739 / 815
Objective Function Options
An Objective Function is a Response that defines the key area of interest, or goal of the Experiment. Because this Response is used to summarize
system performance, you must identify what constitutes optimal system performance and then let OptQuest know how to interpret the values for
this Response. OptQuest will use this information to steer the experiment towards optimal value for this specific Response obeying the constraints
given.
You may create a Response, which consists of an expression that is the Objective Function to be optimized. To optimize a single Response,
follow these 3 steps:
1. C reate a Response expression that represents the performance of your system - This expression can consist of one or multiple
components (C ontrols and/or other Expressions - to use a Response in the component, you must use the Response expression value not
the Response name). Usually, the expression is a sum of components multiplied by Weights, with the Weight representing the amount of
benefit or penalty of that C ontrol or Expression.
2. Set the Objective Goal to Maximize objective or Minimize objective - A general rule of thumb would be that you want to maximize your
benefits and minimize your costs. If an expression has more benefits than costs, maximize the entire expression. If there are more costs,
minimize.
3. Tell OptQuest to use this Response to optimize via the Primary Response property - OptQuest can only optimize based on one objective
function at a time, although it is possible to have multiple Responses with Maximize Objective or Minimize Objective selected. To set the
Primary Response, select the name of the response column containing the objective function to be used in the optimization from the drop
down list located in the Experiment Properties window.
In order for OptQuest to be able to run you must designate a Primary Response complete with an Objective Goal and a valid Expression.
The Emergency Department example model contains an experiment that uses 'Single Objective' Objective Type. It seeks to minimize the
Average Length of Stay response with upper bounds on both responses.
Using a Primary Response
740 / 815
You may want to find an optimal solution based on more than one Response by using the Multi-Objective Weighted optimization. Follow these
steps:
1. Decide which Responses should be part of the objective function.
2. Set the Objective Goal to Maximize Objective or Minimize Objective for each Responses that will be included in the optimization. Set the
Weight property for each Response that will be used. (OptQuest multiplies each response value by the weight, negates it if it is set to
Minimize, and then adds them together to get the value of the overall objective.)
3. Tell OptQuest to consider more than one Response via the Objective Type property. Set this to Multi-Objective Weighted.
To find an optimal set of solutions based on more than one Response,instead of just one optimal solution, set the Objective Type property to
Pattern Frontier. In this case, the Weight property on each Response is not used, but each Response to be used in the optimization must still
have its Objective property set to either Minimize or Maximize.
Results and the Optimal Solution
The Objective Function will be graphed using Simio Measure of Risk & Error (SMORE) Plots. Although the Mean Value is the primary area of
concern, the SMORE plot allows the user to see the variability behind the values and to make decisions accordingly. If two values have similar
Means, the variability of the system can act as another level of information as to which Scenario would be the best choice.
To easily spot the Optimal Solution, the Objective function can be sorted before running the Experiment so that as OptQuest creates Scenarios it
will plot Response values, in real time, ranked either ascending or descending. The Optimal Solution would simply be the Scenario that is listed at
the top of the Primary Response C olumn in the Design Tab or the furthest to the left in the Response C hart.
741 / 815
Simio Reference Guide
Scenario Subset Selection
Subset Selection
In general, the purpose of creating a simulation model and, subsequently, an experiment for that model is to create multiple scenarios for that
system and pick the best one to implement in the future. Therefore, it is extremely important to accurately choose the best alternative for the
system being studied.
A common comparison technique is to display a mean, and often, a confidence around the mean and allow for sorting based on comparison of the
means. A user is inclined to pick the scenario with the highest/lowest mean with little to no information regarding how the scenario compares to
other alternatives.
There has been considerable effort to research and develop statistically valid Ranking and Selection procedures over the past several decades –
a significant amount of which was done by Barry L. Nelson from Northwestern University. He has come up with a series of algorithms that group
Response values into the subgroups “Possible Best” and “Rejects” within each Response. The Possible Best group will consist of scenarios that
cannot be proven statistically different from each other, but can be proven to be statistically better than all of the scenarios in the Rejects group.
To indicate what constitutes “Best” the user will define a Response’s Objective in the Response Properties window, to be either Maximize or
Minimize. Maximize Objective will group the values that are statistically greater than the group of rejects, and conversely the Minimize Objective
will group together the smallest response values.
In the Experiment Window’s Design window, the cells in a Response column will be highlighted brown if they are considered to be “Rejects”
leaving the “Possible Best” scenarios with their intended coloring. A scenario can have a cell in one column considered “Possible Best” and at the
same time “Rejects” for another response.
With this visual feedback, a user can easily see what scenarios are worth further examining using the 'Select Best Scenario Using KN' Add-In.
742 / 815
Simio Reference Guide
Select Best Scenario Using KN Add-In
743 / 815
Simio Reference Guide
Experiment Example
An Example of Creating and Running an Experiment (Using the AirportTerminal Example Model)
The Simio example model, titled AirportTerminal.spfx, contains an Experiment that utilizes the OptQuest for Simio Add-In. It is recommended that
you familiarize yourself with this example in order to learn about the features and capabilities that available when running experiments in Simio.
The following is a step by step approach on how this example experiment was created. To create a new experiment, click on the New Experiment
icon in the Project Home ribbon. You can also create a new experiment by right clicking on the name of the model from within the Navigation
window.
Experiment C ontols
A C ontrol is automatically added to your experiment for any user defined properties that are at the model level. In this example, there are four
model level Properties that have their Visible property set to ‘True’, which indicates that they will appear as a control in an experiment. The
properties are: C heckIn Kiosks, C heckIn C lerks, ID C heck, Scanner Stations. In an experiment that does not use the OptQuest Add In, these
controls do not have properties. But when the OptQuest Add-In is used, you need to specify the following properties, which tell OptQuest whether
or not to include this in its optimization, the minimum and maximum values to set this control to, and how to increment the value. Notice that in
this example, only the first two controls are included in the optimization because their Include In Optimization property is set to 'yes'.
Properties of the "Checkin Kiosks" Control
Experiment Responses
C lick on Add a Response in the Experiment Design ribbon to add a Response to your experiment. This example contains three responses:
Revenue, Profit and C ost. C lick on the column header for Profit to see the properties of this Response. The properties indicate that the expression
being evaluated is the value of the “Profit” OutputStatistic (look in the Elements panel within the model to see details on this statistic), and the
Objective property indicates that the profit value should be maximized. The other two responses have an expression defined, but not an
objective.
Properties of the Response "Profit"
Experiment Properties
The Experiment properties for this example are shown below. Note: To get the Experiment Properties window to display at any time, right click on
the name of the experiment in the navigation window and select Experiment Properties.
Experiment Properties window (when OptQuest Add-In is used)
The Upper Percentile and Lower Percentile properties are used in the SMORE plots. The Primary Response property tells Simio which Response to
use for determining the optimal solution. In this example, we want our optimal solution to be based on the Profit Response and the objective that
is defined on that Response.
744 / 815
The OptQuest for Simio-Parameters section of the Experiment properties is where the user defines the information for the OptQuest Add In. In
this example, Simio will run a minimum of 6 replications and a maximum of 10 replications for each scenario. OptQuest decides how many
replications are required for each scenario. Before the user hits the run button to begin the experiment, it appears to contain only one scenario.
However, the OptQuest Add In runs multiple scenarios, until it has found the optimal solution, based on your defined C ontrols, C onstraints and
Objective on the Primary Response. The Experiment property, Max Scenarios, indicates that a maximum of 10 scenarios will be run. In this
example, the full 10 scenarios are run.
745 / 815
Simio Reference Guide
R eplication R unner
746 / 815
Simio Reference Guide
Model Summary R eport
747 / 815
Simio Reference Guide
C ustom Simio Extensions
Introduction
Simio’s architecture provides several extension points where users can integrate their own custom functionality written in a .Net language such as
Visual C # or Visual Basic .Net.
The types of user extensions supported include:
User Defined Steps
User Defined Elements
User Defined Selection Rules
Application Add-Ins
Simio’s extension points have been exposed as a set of interfaces that describe the methods and calling conventions to be implemented by any
user extended components. This set of interfaces is referred to as the Simio application programming interface (API). For detailed information on
the Simio API, see the file C:\Program Files\Simio\Simio API Reference Guide.chm.
Simio Visual Studio Templates and Examples:
To help get started creating Simio user extensions, a number of predefined Simio project and project item templates for Microsoft Visual Studio
2008 are available. These templates provide reusable and customizable project and item stubs that may be used to accelerate the development
process, removing the need to create new projects and items from scratch.
For more information, see Simio Visual Studio Templates.
Additionally, several User Extension Examples are included with the Simio installation.
General Steps to Create and Deploy a User Extension:
The general recommended steps to create and deploy a user extension are as follows:
C reate a new .Net project in Visual Studio 2008, or add an item to an existing project, using one of the Simio Visual Studio templates. Note
that, in addition to the commercial versions of Visual Studio, Microsoft also offers “Express” editions which are available as free downloads
from www.microsoft.com/express/Windows .
C omplete the implementation of the user extension and then build the .Net assembly (.dll) file.
To deploy the extension, copy the .dll file into the [My Documents]\SimioUserExtensions directory. If the folder does not already
exist you must create it. As an alternative, you may also copy it to [Simio Installation Directory]\UserExtensions, but ensure that you have
proper permission to copy files here.
Using a Deployed User Extension in Simio:
In a model’s Processes Window, all deployed user defined steps will be available from the left hand steps panel under User Defined.
In a model’s Definitions Window, when defining elements, all deployed user defined elements will be available via the User Defined button in the
Elements tab of the ribbon interface.
All deployed application add-ins will be available for use in a project via the Select Add-In button in the Project Home tab of the ribbon.
All deployed user defined selection rules will be available for use in a model as dynamic selection rules.
See Also
User Extensions: Getting Started Using Simio Visual Studio Templates
748 / 815
Simio Reference Guide
Simio Visual Studio T emplates
After creating your custom project in Visual Studio and building the .dll file, move the .dll file into the [My Documents]\SimioUserExtensions
directory. If the folder does not already exist you must create it. Restart Simio and it will automatically find that .dll and recognize your custom
user extension.
749 / 815
user extension.
750 / 815
Simio Reference Guide
P rotection
Protection
The protection feature allows an object builder to prevent an unauthorized user from viewing, subclassing, or editing the object definition. This
can be useful to protect your intellectual property or simply to prevent an object from being accidentally changed by a novice or unauthorized
user. To use this feature, navigate to the Project window from within the Navigation window. With the Models panel open, select the model that
you would like to protect. Select the Protect icon from the ribbon. You will be provided the opportunity to enter a password. When a project
containing a protected object is loaded, the user will be prevented from viewing or accessing the definition of any protected objects unless they
have the password. The object can still be instantiated normally in another model. To unprotect an object, select the object from within the Models
panel of the Project window and select Unprotect from the ribbon. Note that protection is at the object/model level. A project might contain
multiple objects, some unprotected and others protected individually.
Protecting a Model (select the Project in the Navigation window)
751 / 815
Simio Reference Guide
Simio User Extension Examples
752 / 815
Simio Reference Guide
Dynamic Selection R ules
Dynamic selection rules allow various places in Simio to select from a set of things based on some dynamic criteria.
Users can write their own rules in any .NET language, by implementing the interfaces ISelectionRuleDefinition and ISelectionRule. For more
information about creating your own Dynamic Selection Rules, see C ustom Simio Extensions.
These rules are used in Resource allocation selection (used within many of the Standard Library objects, such as Server, Resource, C ombiner,
Separator, Workstation, Worker, and Vehicle). Also used within the Routing Group route request selection, TransferNode route request selection
and Station entry selection.
Note:
Most of the time you will want to use the keyword C andidate when entering an expression.
Built In Rules
There are a number of built in selection rules. The C # sources to these rules are provided at [All User
Documents]\Simio\Examples\UserExtensions\SimioSelectionRules\.
These rules were built to be as generic as possible. Several domain specific rules can be used by simply using the right expression in one of the
rules.
Smallest Value First
Selects the entity which would have the smallest value for the given expression.
Largest Value First
Selects the entity which would have the largest value for the given expression.
For both the Smallest Value First and Largest Value First rules above, the Value Expression is used as the expression used with the rule. The
keyword 'C andidate' may be used to reference an object in the collection of candidates (e.g., C andidate.Entity.Priority). The Filter Expression may
be used to filter the list before the specified rule is applied. Again, the keyword 'C andidate' may be used to reference an object in the collection of
candidates.
Standard Dispatching Rule
Allows a user to easily specify a commonly used dispatching rule such as Earliest Due Date (EDD) or Least Setup Time as the dynamic selection
rule for selecting the next entity to process at a location such as a Server or Workstation.
Also allows a Look Ahead Window to be specified whereby only candidate entities whose due dates fall within a specific time window will be
considered for selection. If there are no candidates whose due dates fall within the look ahead window, then the window will be automatically
extended to include the candidate(s) with the earliest due date.
The below dispatching rules are available as drop-down list choices for the Dispatching Rule and Tie Breaker Rule sub-properties.
Listed below are the Standard Dispatching Rules that are currently supported:
Dispatching Rule Description
FirstInQueue The entity ranked nearest the front of the queue is selected.
LargestPriorityValue The entity with the largest priority state value is selected.
SmallestPriorityValue The entity with the smallest priority state value is selected.
EarliestDueDate The entity with the earliest due date is selected.
C riticalRatio The entity with the smallest critical ratio is selected. C ritical ratio is the amount of time remaining to complete the
entity’s assigned sequence in order to meet its due date divided by the total operation time remaining to complete
the entity’s sequence. Assumes that each candidate entity has been assigned a destination sequence.
LeastSetupTime The entity with the least setup time is selected.
LongestProcessingTime The entity with the longest operation time is selected.
ShortestProcessingTime The entity with the shortest operation time is selected.
LeastSlackTime The entity with the least slack time is selected. Slack time is the amount of time remaining until the entity’s due
date minus the total operation time remaining to complete the entity’s sequence. Assumes that each candidate
entity has been assigned a destination sequence.
LeastSlackTimePerOperation The entity with the least average slack time per its remaining operations is selected. Assumes that each candidate
entity has been assigned a destination sequence.
LeastWorkRemaining The entity with the least total operation time remaining to complete its assigned sequence is selected. Assumes
that each candidate entity has been assigned a destination sequence.
FewestOperationsRemaining The entity with the fewest number of operations remaining to complete its assigned sequence is selected. Assumes
that each candidate entity has been assigned a destination sequence.
LongestTimeWaiting The entity that has been waiting the longest time in the queue is selected.
ShortestTimeWaiting The entity that has been waiting the least time in the queue is selected.
LargestAttributeValue The entity with the largest value of the specified expression is selected.
SmallestAttributeValue The entity with the smallest value of the specified expression is selected.
C ampaignSequenceUp The entity that has a campaign value equal to or next largest compared to the value of the last processed entity is
selected. If none of the waiting entities have the same or larger value, then the rule starts a new campaign by
selecting the entity with the smallest value.
C ampaignSequenceDown The entity that has a campaign value equal to or next smallest compared to the value of the last processed entity
is selected. If none of the waiting entities have the same or smaller value, then the rule starts a new campaign by
selecting the entity with the largest value.
C ampaignSequenceC ycle Alternates back and forth between a campaign sequence up and a campaign sequence down. If the campaign is
increasing, it will continue to increase until no entities remain with the same or larger campaign value. When this
occurs, the rule then switches to a decreasing campaign and begins selecting entities that have the same or
smaller campaign value. When all such entities are exhausted, the rule returns to an increasing campaign strategy
and the cycle repeats.
753 / 815
and the cycle repeats.
See Also
ISelectionRuleDefinition
ISelectionRule
754 / 815
Simio Reference Guide
Scheduling in Simio Enterprise
755 / 815
Once the data is imported from the ERP system, a schedule is generated by simulating the flow of jobs using the Simio model with no variation.
The simulation is then replicated multiple times with variation incorporated to generate probabilistic risk measures for the associated schedule.
The risk measures include the probability of meeting user-defined targets, as well as expected, pessimistic, and optimistic schedule performance.
Various built-in analytical tools like Gantt charts, resource and entity activity tracking, root cause analysis, optimization, and even 3D animation
can be used to analyze and reduce the risk and improve the performance. The improved schedule and associated risk analysis may then be
exported back to the ERP system or deployed directly from Simio, if desired.
756 / 815
Simio Reference Guide
Enterprise Data W indow
With the Enterprise product, there are two additional ribbons located in the Data window, Tables panel. These include the States ribbon and the
Target ribbon, which are located to the right of the Table ribbon. Additionally, Enterprise users have the ability to add an Output Table to the
model. This is discussed below.
Table Ribbon - Enterprise
When defining a data table, many different type of columns are available from the Table ribbon, including standard properties, element
references and object references, as seen above. These allow the user to define a column as an expression, real, entity, transporter, tally statistic
and so on. Then, the data that is entered within each row of that column must be of that certain type, as defined. Typically, each row in the table
then has a value for each given column.
Output Tables
Output Tables are similar to Data Tables in that they define a collection of rows. Within an Output Table, however, the columns are all specified as
State type columns - that is, the values within the table will be written to the table during or after the simulation run. A token or entity may set an
active table row using the SetRow step. Once an active row has been set, the states in the table can be assigned values using
TableName.StateName. Rows are added to the table at run-time using the AddRow step. More information on adding states can be found on the
States ribbon page.
Output Tables - Enterprise
757 / 815
Simio Reference Guide
States (Enterprise)
States Ribbon
States Ribbon - Enterprise
In addition to column types from the Table ribbon, the user may also define a column as a table state. Table states are added by utilizing the
States ribbon and may be discrete or continuous. The Move Left and Move Right buttons allow you to move a particular column for organizational
purposes. As with other table columns, there are various types, including:
Real - The state representing a real numeric value that may change by assignment logic at discrete times during a model run.
Integer - The state variable representing an integer numeric value that may change by assignment logic at discrete times during a model
run.
Boolean - The state variable representing a logical or Boolean (true or false) value that may change by assignment logic at discrete times
during a model run.
DateTime - The state variable representing a datetime value that may change by assignment logic at discrete times during a model run.
List - The state variable representing an integer variable with a discrete set of possible values from 0 to N. A zero-based indexed string
list is used to define the possible integer values for the state. A list state's value may be changed by assignment logic at discrete times
during a model run, and the state will automatically collect and report time-persistent statistics for each of its state values. For more
information, see List States in the Simio on-line help.
String - The state variable representing a string value that may change by assignment logic at discrete times during a model run. For
more information, see String States in the Simio on-line help.
Element Reference - The state variable defining an element reference variable that may be changed by assignment logic at discrete
times during a model run. You can assign a value to an element reference state using an Assign step in a process. The expression used as
the value for that assignment must return an element reference. Element references include Element, Activity, Batch Logic, Failure,
Material, Network, Operation, Process, Routing Group, Station, Tally Statistic and Storage.
Object Reference – The state variable defining an object reference variable that may be changed by assignment logic at discrete times
during a model run. You can assign a value to an object reference state using an Assign step in a process. The expression used as the
value for the assignment must return an object reference. Object references include Object, Fixed, Link, Node, Entity and Transporter.
List Reference – The state variable defining a list reference variable that may be changed by assignment logic at discrete times during a
model run. You can assign a value to a list reference state using an Assign step in a process. The expression used as the value for the
assignment must return a list reference, for example from an Object List Property or another List State Reference.
Level - The continuous-change state variable defining a numeric variable that may change continuously over time based on the current
value of its rate. An automatic rate variable, based on the LevelStateName.Rate can be used to modify the rate of change throughout the
simulation run. The state's rate parameter is a discrete-change value that may be changed by assignment logic at discrete times during a
model run.
Level with Acceleration - The continuous-change state variable defining a numeric variable that may change continuously over time
based on the current value of its rate and acceleration. The state's rate, acceleration and acceleration duration parameters are discrete-
change values that may be changed by assignment logic at discrete times during a model run.
Unlike other column types, however, the table state column values are not input by the user at the start of the simulation run. These values are
assigned during the simulation run by an Assign step, based on the current row of the associated object. The table name and column name are
used in the assignment, similar to referencing other table columns. For example, if the table name is ManufacturingOrders and the table state
name is ShipDate, the assignment would be made to the State Variable Name 'ManufacturingOrders.ShipDate' as shown below. The actual row
that the New Value of 'Run.TimeNow' is entered into is based on the row that is associated with the entity.
Table states may also be utilized in an expression in the same way. For example, you may wish to continually add to a table state, in which case,
the assignment may be State Variable Name of ‘ManufacturingOrders.NumberOfDefects’ and the New Value is
‘ManufacturingOrders.NumberofDefects + 1’.
758 / 815
When you add a table state to the table, the entire column will be gray in color, as seen below. This signifies that it is a table state column and not
a regular column that requires entries. With all of the table state types, there are various properties, such as initial state value, unit type (some)
and dimension (for some).
Once the simulation model is running, values will be calculated for the table states and shown in the appropriate columns.
Table State 'ShipDate' Column
Similar to standard type table columns, the state type columns have a Visible property to determine whether the state column is visible or not
visible to a Scheduler type user in Operational Planning mode. This includes visibility in both the Tables and Gantt properties shown on the right
when a Gantt chart item is selected.
Table State Properties - Visibility
759 / 815
Simio Reference Guide
T argets (Enterprise)
A target is an expression that will be evaluated at the end of the simulation run to determine if a particular goal is met. Within the Targets ribbon,
there are two buttons, including Add Target and Remove Target, as well as a performance slider.
The Add Target button adds a new target to the table. A target’s Expression property is evaluated at the end of a simulation run and classified
according to the upper and lower bounds specified. When a target is added to a table, two columns named Value and Status are automatically
added. The Target name is shown above both of the columns. To edit the target, click on the target name and the properties of the target will be
visible.
The Value C lassifications section of properties allow the user to specify a string value that will be written to the Status column of the target after
the simulation run is complete. For example, if the target is a time based value, these may include On Time, Early, and Late.
The Appearance section contains a Display Name, which is shown on the top of the columns for the target. The Display Format allows you to
customize how the target value is displayed. For example a format of N1 indicates to display a numeric with 1 digit to the right of the decimal
point.
The Remove Target button removes a selected target from the table.
The performance classification slider allows the user to specify the ranges for target performance coloring (red/yellow). Target performance
values are the probability of meeting the specified target (expressed as a percent). Adjust the sliders to specify the ranges used for applying
color tot represent different performance levels. When a slider is moved, an indication of the percentages is shown above the slider, as seen in
the screen shot below.
760 / 815
Within Optional string used to classify the status of the target if its value is within the target’s specified lower and upper bounds.
Bounds
Below Optional string used to classify the status of the target if its value is below the target’s specified lower bound.
Lower
Bounds
Above Optional string used to classify the status of the target if its value is above the target’s specified upper bound.
Upper
Bounds
No Value Optional string used to classify the status of the target if the order has not completed and thus there is no value for that particular
target. The Value column will read NaN, while the Status will be reported as No Value (or optional string specified).
Below is an example of two tables that each includes a date time column (Due Date), a table state that is defined as a date time (Ship Date), and
a target (Slack / Target Date). Notice that there are two columns added for the target, including Value and Status. In the table on the top left, the
target's Expression property is calculated by subtracting the Ship Date from the Due Date column. The target is then a 'Real' value and is defined
as the Slack time (in days). In the table on the bottom right, the target's Expression property is the same as the Ship Date and is a 'DateTme'
value.
The target's Expression property is evaluated at the end of the simulation run and that expression is put into the appropriate row under the Value
column. If the entity/order is incomplete, the Value will be reported as NaN. The upper and lower bounds are then evaluated and any string value
classifications are used to determine the status of the same row.
Example of Table States and Targets at the End of a Simulation Run
761 / 815
Simio Reference Guide
Enterprise P lanning W indow
The Planning Window provides access to various windows used for scheduling purposes. These include the following:
Resource Plan displays information about how the resources are being used in a Gantt chart format.
Entity Workflow provides information about specific entities and their flow in a Gantt chart format.
Logs provides all information about how the resources are being used and the order of entity processing in various log formats – including the a
Resource Usage Log, Resource State Log and C onstraint Log.
Tables provides a view of all of the data and sequence tables that have been defined through the Data window.
Facility Model allows the user to view the Facility window animation without editing it.
Results displays simulation and scheduling results in various formats, including Target Summary, Risk Plots and Detailed Results.
762 / 815
Simio Reference Guide
R esource P lan (Enterprise)
The Resource Plan window provides a Gantt chart that displays each resource along with time bars that show each entity (e.g. a job) that utilizes
the resource. The changing resource state is shown on each Gantt row behind the time bars. You can expand each row to graphically edit the
resource capacity and to also show each entity that is waiting for the resource. Both the Gantt and Operational Planning ribbons are available.
The format of this Gantt window shows all of the resources in the simulation model in a Gantt chart format and includes the Gantt ribbon, as
discussed below.
In order for the Gantt chart to display a resource, the Log Resource Usage property under the Advanced Options category of the particular object
(within the Facility window) must be set to ‘True’. The Standard Library objects Server, C ombiner, Separator, Workstation, Resource, Worker and
Vehicle have resource logging capability. The Display C ategory property also allows users to specify an optional text for hierarchically arranging
resources within the Resource Plan window. Backslashes may be used for multiple levels (e.g., One\Two\Three).
Within the Operational Planning ribbon, the C reate Plan button allows the user to run the model to generate a resource plan. This model will be
run in a deterministic mode with no uncertainty to generate a resource plan. All distributions used in the model will return their expected values
and all failures in the model will be disabled.
Entities can be moved around on the Resource Gantt by dragging and dropping to a new location within the Gantt. See the Plan Resource
C onstraints section below for more details.
Gantt Ribbon
Within the Gantt ribbon, there are a number of options for navigating within the Gantt chart (View/Zoom sections), as well as turning on/off
specific rows under the various resources (Visibility section).
The Home button allows you to select the current home date for the Gantt chart. Options include Today (default value), First day of this Week,
First day of this Month and a Specific day. If Specific day is selected, a dialog will appear for the user to select the particular starting day from the
calendar.
Buttons are available on the Gantt ribbon for zooming In and Out of the Gantt chart view. Additional buttons are available to see All of the Gantt
chart, as well as to zoom to a particular Range, such as an hour, day, week, month or year.
The Visibility buttons allow you to toggle on/off the various rows beneath the resources shown within the Gantt. These include:
Resource States - Show or hide the resource state rows.
Exceptions - Show or hide the exception rows. These relate to the resource schedules and includes day exceptions and downtimes and
other exceptions.
763 / 815
Contraints - Show or hide the constraint rows. These display the various constrained entities.
Capacity Plots - Show or hide the capacity plots rows. These are shown for multiple capacity resources only.
Population Members - Show or hide the population member rows. This would include specific member information within vehicles and/or
workers.
Table Columns - Show or hide the rows that display time-indexed column values.
State Statistics - Show or hide the rows that display State Statistics that have their Log Observations property set to 'True'.
Show Transporter Riders (On Resource Row / On Separate Row) - Show the Transporter's riders on either the same row as the
Transporter or on a separate row. Hide the riders all together by deselecting both options.
Show Filtered Out Items - When the Gantt is filtered to a specific Resource or Entity, the user can show or hide the non-filtered items in
the Gantt. By default, the items that are filtered out are not displayed. If the user clicks onto Show Filtered Out Items, they will be shown
on the Gantt in a muted, lighter color.
Gantt Chart
Within the Gantt chart, the resource names in the model are shown on the left side of the chart. To the right of each resource is a calendar
formatted view of the entities or orders that have utilized the resource. The entity orders are color coded so it is easier to visualize the resources
that a particular order has been processed through.
When hovering the mouse over the colored portion of particular entity, details such as the entity identifier, resource name, start time, end time,
duration and capacity units owned, are provided in an ‘info tip’ box. In the below example, the mouse is hovered over OrderWIP7 at the Finish
resource. Within the info tip, if an entity is associated with any table data, then the states and target values are displayed in the info tip. In the
below example, only the basic resource information is displayed, which is what a user would see if the entity was NOT associated with any table
data.
In addition to the entity information shown above for a given resource, if the entity has an associated table row, all table information will also be
shown in the property window to the right when a particular entity at a given resource is selected. This property window allows the user to edit
any specific table data that is defined with the Editable property for the column as 'True'. Grayed data (not Editable) is also displayed for
reference purposes.
764 / 815
If the resource is a Fixed object, the Gantt chart is shown as above, with the entities shown directly to the right of the resource name. However, if
the Resource is a member of a population (such as a Worker or Vehicle), the Resource name should be expanded (using the '+'). This will display
the option to show the Population Members (again using the '+'). Once the population members are displayed (such as Operator[1]), the entities
that were processed with that resource are displayed to the right, as shown below.
If the Resource is a Worker or Vehicle that includes Load and Unload times, the graphical representation on the Resource Plan Gantt shows a
lighter color on the left (Load Time) and/or lighter color on the right (Unload Time) while the actual Transport time is displayed in the middle with
a darker shade of the color, as shown below. When hovering over the particular entity that seized the Worker or Vehicle, the entire Transport
(Busy) time is displayed (includes Load, Transport and Unload times).
By default, when a Resource is a Vehicle or Worker, any entity that is riding on the Vehicle or Worker will be displayed in the Resource Gantt on
the same row as the Vehicle/Worker. Whether or not these entities are displayed at all and where they are displayed can be controlled by the
user.
The user can select On Separate Row from the Gantt Ribbon, under Show Transporter Riders in the Visibility section of the ribbon to change how
the riding entities are displayed.
This will change the Gantt to display the riding entities on a separate row within the Gantt, as displayed below. In the example below, there are
two entities riding on a vehicle.
765 / 815
When neither On Resource Row or On Separate Row is selected in the ribbon, the entities riding on Vehicles or Workers will not be displayed in
the Gantt.
If a Resource has been seized, but not released, when the run finishes, the Resource will be displayed on the Gantt with three dots following at
the end. This indicates that the End Time of the seize is unknown and has not happen as of the time of the run completion.
766 / 815
If there are State Statistics for a user defined List State in the model, who's Log Observation property is set to 'True', the State Statistic will be
displayed in the Resource Gantt, if the State Statistics button is selected in the Gantt ribbon. Hovering over the row will show the value of the
State Statistic, the start time, end time and the duration that the state has had this value. The example below shows a custom Server, MyServer1,
which has a state statistic for a user defined List State, named PriorityState. The value of this List State changes throughout the model between
NonPriorityItems to PriorityItems.
The C onstrained Entities section will show any entities that have been waiting at the resource for processing. An example of the Finish resource’s
C ontrained Entities is shown below. The C onstrained Entities can be hovered over individually to find the starting time (in the input buffer), and
ending time (in the input buffer). The constrained entities’ colors correspond to the entity color as it is shown processing. While the example
below shows only a single constrained entity, a given resource may have multiple entities waiting to be processed and they will all be shown as
constrained entities.
767 / 815
The Tasks section will show the Task Sequence defined tasks associated with each resource. Many of the Standard Library objects, such as
Server, C ombiner, and Separator include the Processing Type of 'Task Sequence' in which individual Processing Tasks are specified in a repeating
property. Those Tasks for each resource can then be shown in the Gantt, as shown below.
768 / 815
Expanding the Resource State for Exceptions
For any resources that have a Capacity Type of 'WorkSchedule', the Resource State will display a '+' sign to the left that can be expanded into
work schedule exceptions. This includes Day Exceptions, as well as Downtimes and Other Exceptions.
Day Exceptions are an entire day with a given Day Pattern that may be different than the work day associated with the resource's schedule. For
example, perhaps a work schedule consists of five standard work days. A user may wish to have an extended day type schedule on any
particular day, which will then override the work schedule. To add a Day Exception using the Gantt, click on the beginning of a given day and drag
the mouse to the right. You will see a brown rectangle added to the Gantt. The property window on the right is used to enter the desired Day
Pattern name. One day at a time can be added to the day exceptions.
Downtimes and Other Exceptions are periods of time that can be specified as a 'Downtime' (where the resource capacity Value is '0'
automatically) or a 'GeneralException' (where the user can specify the resource capacity Value as well as Cost Multiplier. To add a Downtime or
Other Exception using the Gantt, click on the beginning of a given time period and drag the mouse to the right. You will see a brown hatched
rectangle added to the Gantt. The property window on the right is used to enter or change the desired Start Time, End Time, Exception Type and
associated properties.
With all exceptions, you can view the exception details by hovering the mouse over the brown rectangle, as seen below. C licking and highlighting
any exception will allow you to edit the details within the property window on the right.
769 / 815
Summaries within Resource Plan Gantt
The Summaries button on the Gantt ribbon is useful when using hierarchical grouping (like “Workstation\Welders”, etc. as in the below picture), or
when you have population member sub-rows under the main population row (such as Workers vs. Worker[1]). The summary 'roll-up' is the
overall time range of the nested time items using a summary bar.
Plan Resource Constraints (Drag and Drop within the Gantt Chart)
If the IncludeInPlanResourceConstraints property on the object instance is set to ‘True’, entities that have seized that object can be reordered in
the Resource Plan Gantt by dragging and dropping the entities within the Gantt.
Resource Allocation Dependencies (Reordering Entities Within the Same Resource Row)
If the IncludeInPlanResourceConstraints property on the object instance is set to ‘True’, entities that have seized that object can be reordered in
the Resource Plan Gantt by dragging and dropping the entities within the Object’s row in the Gantt. If the user drags and drops an entity to a new
location in the row, a new Allocation Rule is created and an entry is placed in the Resource Allocation Dependencies table. When the Plan is re-
generated, the rules listed in this table are used to determine the order in which resource allocations occur. In other words, when some
Candidate Entity Name wants to seize from some Resource or List Name, it will not be allowed to until some other Dependent Entity
Name has seized that same Resource or List Name a Dependent Entity Number of Seizes times. The user can manually delete rows from
the Resource Allocation Dependencies table. The plan should then be re-generated so that the deleted rules will not be applied to the plan.
In the example below, Order09 is scheduled on the C ut Resource after Order07 and Order08. The user drags Order09 before Order07 and
Order08 within the C ut Resource Row in the Gantt C hart, to create two new allocation dependencies: Order09 must be scheduled before Order07
and Order08. The plan is re-run and the new Gantt shows that Order09 is scheduled before these two orders on the C ut Resource.
Original Plan
770 / 815
New Plan - After Moving Order09
Resource List Requirements (Moving Entities to a New Resource Row in the Gantt)
If an entity is seizing from an object list, then it is possible for that entity to be forced to seize a specific object from that object list, if the
IncludeInPlanResourceConstraints property on the object instance is set to ‘True’. This is done by dragging and dropping the entity into the row of
the object that it should seize. If the user drags and drops an entity to a new resource row, a new Resource List Requirement is created in the
Resource List Requirement table. When the plan is re-generated, the rules listed in this table are used to determine which object should be seized
by the entities. In other words, the Candidate Entity Name is going to seize from the list Resource List Name, and it will not be able to seize
any resource from the list, but instead it will only be able to seize (and have to wait for) the Required Resource. The user can manually delete
rows from the Resource List Requirements table. The plan should then be re-generated so that the deleted rules will not be applied to the plan.
In the example below, the entities are seizing from a list containing three Resources; Resource1, Resource2 and Resources3. Originally, all the
entities seized from Resource1 and Resource2, leaving Resource3 idle. The Gantt below shows the new Plan after the scheduler dragged Part.16
from Resource2, down to Resource3, creating an entry in the Resource List Requirement table. This entry caused the new plan to force Part.16 to
seize Resource3.
771 / 815
Simio Reference Guide
Entity W orkflow (Enterprise)
The Entity Workflow window provides a Gantt chart that displays each entity along with time bars that shows each resource the entity utilizes. You
can expand each row to show each constraint that impedes the progress of the entity, as well as any tasks within a task sequence that the entity
has completed. The Gantt also displays date-time based milestones and targets for each entity, along with associated risk measures. The Gantt
ribbon is available from the Entity Workflow window. Within the Gantt ribbon, there are a number of options for navigating within the Gantt chart
(View/Zoom sections), as well as turning on/off specific rows under the various entities (Visibility section). The Grouping Expression allows the
various items within the Gantt to be grouped based on a column within the Resource Usage Log. See example 3 on the Resource Usage Log help
page for more details.
The color of a resource displayed in the Gantt is automatically generated. This color may be changed by specifying a Display Color property
within a particular resource object's Advanced Options group of properties when Log Resource Usage is 'True'.
If an Entity has seize a resource, but not released, when the run finishes, the Entity will be displayed on the Gantt with three dots following at the
end. This indicates that the End Time of the seize is unknown and has not happen as of the time of the run completion.
By hovering over a given resource within the Gantt for an entity, the entity (order) name is displayed, along with the start time, end time,
duration and capacity units owned. If the entity has an associated table row, that information is also displayed.
Right-C licking in the Gantt
The user can select a Resource in the Gantt and right click. The menu gives the user the option to "Re-Run to here, Filter to Resource: X, Filter to
Entity: X and C lear Filter", where X is the current Resource that is selected and the current entity that is selected.
Selecting "Re-Run to here" will bring the user to the Operational Planning Facility window and run the model and the animation until that particular
entity is processed at that particular Resource. Selecting "Filter to Resource: X" will filter the Gantt so that all of the instances of that Resource in
the Gantt will be brightly colored, but everything else in the Gantt will be muted a lighter color, making it easy to focus only on that particular
Resource. Selecting "Filter to Entity: X" will filter the Gantt so that all of the instances of that Entity in the Gantt will be brightly colored, but
everything else in the Gantt will be muted a lighter color, making it easy to focus only on that particular Entity. When the Resource Plan Gantt is
filtered to a particular Resource or Entity, the Entity Workflow Gantt is also filtered to that same Resource or Entity. And when the Entity Workflow
Gantt is filtered to a particular Resource or Entity, the Resource Plan Gantt is also filtered to that same Resource or Entity.
772 / 815
Expanding the Gantt Headings
Expanding the Entity Workflow window by selecting the >> at the top of the word Entity will display additional information about the target results
when a Risk Analysis is performed. This includes any target values and color coding based on target limits and performance classification that are
set. The Entity Workflow Gantt results may be sorted by clicking to the right of the target name of a particular column.
When the mouse hovers over a constraint for the entity, a display is shown that includes the type of object (workstation, server, worker, resource,
etc.), as well as the type of constraint. Types of constraints include Resource Availability (waiting for resource capacity to become available),
Resource Arrival (waiting for a worker or vehicle to arrive to the entity location) and Material Availability (waiting for material(s) specified to be
available for reservation).
Viewing the Tasks
Expanding the entity information using the ‘+’ will also provide detailed information on any Tasks (if the Tasks button on the Gantt ribbon is
selected) for each entity. Tasks are specified within many Standard Library objects by using the Processing Tasks method of processing to specify
the 'Task Sequence' for the object. Below the entity Order03 undergoes two tasks within the C ut object, the FirstC ut and SecondC ut. Hovering
773 / 815
the 'Task Sequence' for the object. Below the entity Order03 undergoes two tasks within the C ut object, the FirstC ut and SecondC ut. Hovering
over a specific task provides additional details about the task, including starting and ending times and duration. The Task Log shows detailed
information for all entities as well.
774 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
775 / 815
Simio Reference Guide
Logs (Enterprise)
The Logs panel provides access to various resource and entity specific logs. These include the following:
Resource Usage Log provides The information detailing each resource and the entity that utilized it.
Resource State Log includes details of the resource states over time.
Resource C apacity Log records changes in each resource's capacity over time.
C onstraint Log provides details of the constraints to the entity over time.
Transporter Usage Log includes details of the start and end times of the transporter's usage.
776 / 815
Simio Reference Guide
R esource Usage Log (Enterprise)
The Resource Usage Log provides information detailing each resource and the entity / order that utilized it. There are eight automatic columns
that are provided with the log. These include:
Resource - The name of the resource that is utilized.
Owner - The specific entity or order number utilizing the resource.
Start Time - The time that the entity seized the resource.
End Time - The time that the entity released the resource.
Duration - The total time that the entity was allocated the resource, as calculated by ‘End Time – Start Time’ in default time units.
Avg - The average number of units of the resource that has been seized.
Min – The minimum number of units of the resource that has been seized.
Max - The maximum number of units of the resource that has been seized.
NOTE: The Avg, Min and Max values represent the number of units of a given resource that has been seized by this particular owner. Therefore, if
1 unit of Resource1 is seized, a delay occurs, then another unit of Resource1 is seized, a delay occurs, then both are released, the Min value
would be ‘1’, the Max value would be ‘2’ and the Avg value would be the time weighted average over the Duration.
By selecting the + button within a particular Resource row, the Resource is expanded to include the detailed information about that resource and
its state, as shown below.
Note: The small checkbox that can be seen at the bottom left of the Resource State Details, as well as on the Resource Usage Log displays any
Filters that may have been set for the data.
Adding a Column to the Usage Log
When the Resource Usage Log tab is selected, the Operational Planning and Log ribbons are available.
The Log ribbon provides the ability to change the Usage Log.
For example, the Add C olumn button is available to add a column to the standard Usage Log table. When a column is added to the Resource
Usage Log, there are several properties that may be specified for the column, including:
Listed below are the properties of a Resource Usage Log Column:
Property Description
Expression The expression value to be recorded in this column for each resource usage row in the log. Note that the expression may contain
references to either the resource object or the owner object; if referencing the resource object, the keyword ‘Object’ must be used
(e.g., Object.C apacity.ScheduledUtilization); if referencing the owner object, the keyword ‘Owner’ must be used (e.g.,
Owner.Entity.Priority).
Data The data type format for the value of this column’s specified Expression (e.g., Real, Integer, Boolean, DateTime, String or C olor).
Format
Unit Type C lassifies the units of the value returned by this column’s specified Expression (available for Data Format types Real and Integer).
Evaluation The method used to evaluate and record this column’s expression value for each resource usage row in the log. If ‘StartTimeValue’,
Type then the expression’s value at the start time of the usage occurrence is logged. If ‘EndTimeValue’, then the expression’s value at the
end time of the usage occurrence is logged. If ‘ValueC hange’, then the expression’s change in value from the start time to 777
the end
/ 815
end time of the usage occurrence is logged. If ‘ValueC hange’, then the expression’s change in value from the start time to the end
time of the usage occurrence is logged.
Gantt Indicates if this column should appear in one of the Gantt views. Options include None, ResourceGantt, and EntityGantt. It is
Display important to note that the values shown in the ResourceGantt and EntityGantt will be the MOST RECENT values in the log for that
Type resource or entity.
Use as Specifies how this color expression should be used when drawing a Gantt chart.
Gantt
C olor
NOTE: Additional column information will NOT be shown on the Gantt charts for dynamic objects, such as Operators or Vehicles at this time.
In addition to the Add C olumn button, the Log ribbon includes options to change the Time Units, Length Units and Rate Units for the usage log.
These options are similar to the Status Units section of the Run ribbon within the Facility window and will change the units for all relevant windows.
All data within the Resource Usage Log may also be exported to a *.csv file by using the Export to C SV button.
Example 1 - Adding a Column to the Resource Usage Log for Sorting the Resources
This example shows the addition of a column to the Resource Usage Log chart. This column has the Gantt Display Type property as
'ResourceGantt' so that the values are displayed within the Gantt chart as well. The Expression property is generated from the Workstation table.
778 / 815
Example 2 - Adding a Column to the Resource Usage Log to Show Resource Utilization
This example is similar to Example 1 in that it shows the addition of a column to the Resource Usage Log chart that will be displayed in the
Resource Plan Gantt. The Expression property references the resource 'Object'.
Example 3 - Adding a Column to the Resource Usage Log to Group within the Entity Workflow Gantt
779 / 815
This example is similar to Examples 1 and 2 in that it shows the addition of a column to the Resource Usage Log chart. This column, however, will
be used within the Entity Workflow Gantt. The GanttDisplayType property is 'EntityGantt'. Items within the Entity Workflow Gantt can now be
grouped based on the new column named 'PartType'.
Example 4 - Adding Columns to the Resource Usage Log For Custom Gantt Colors
This example shows the addition of two columns to the Resource Usage Log chart that are used within the Resource Plan Gantt. The Data Format
property for both columns is 'C olor' and the Gantt Display Type is 'ResourceGantt'. The Expression for the FillColor column includes the order's
Priority from the Manufacturing Orders table. Those orders with priority 1 will be pink and those with priority 2 will be green. The Use As Gantt
Color property indicates it is the fill color as 'OwnerItemFillC olor'. The Expression for the BorderColor column includes the order's Order Status
780 / 815
(0=New, 1=WIP). Those orders that are WIP will have a red border, while those that are New will have a green border.
781 / 815
Simio Reference Guide
R esource State Log (Enterprise)
When the Resource State Log tab is selected, a smaller version of the Log ribbon and the standard Operational Planning ribbon are available.
Additional columns may not be added to the Resource State Log; therefore, only the Status Units properties and the Export to C SV options are
available from Resource State Log’s Log ribbon.
The Resource State Log includes details of the resource states over time. The columns that are shown in the Resource State Log include:
Duration - The total time that the resource was utilized in that given state, as calculated by ‘End Time – Start Time’.
Resource - The name of the resource that is utilized.
State - The specific state that the resource is in (e.g., Processing, Setup).
Auto State - The auto state associated with the state (e.g., Busy).
Start Time - The simulation time that the resource was seized.
End Time - The simulation time that resource was released.
782 / 815
Simio Reference Guide
R esource C apacity Log (Enterprise)
The Resource C apacity Log provides information detailing the resource capacity changes during the simulation run, based on various resource
schedules.There are seven automatic columns that are provided with the log. These include:
Resource - The name of the resource that is scheduled.
Scheduled - The maximum capacity of the specified resource at the given time.
Allocated - The number of resources that have been allocated or 'seized'.
Utilized - The number of resources that are in a 'utilized' state. This may be less than the 'allocated' value when a failure occurs or when
a part is in a workstation and has seized the resource but is waiting for material or a secondary resource, for example.
Start Time - The time that the resouce capacity/allocation/utilization change started.
End Time - The time that the resouce capacity/allocation/utilization change ended.
Duration (Time Units) – The total time that the capacity/allocation/utilization combination occurred, as calculated by ‘End Time – Start
Time’ in default time units.
In the above example, the Shape, Weld, C ut and Finish workstation resources have no scheduled capacity, based on their work schedules. Thus,
the allocated and utilized values are also zero. Then, at 8:00 am, the resources all have scheduled capacity of 1. Note the Weld resource that has
a scheduled capacity of 1, an allocated value of 1, yet a utilized value of 0 for a very short period of time. This corresponds to a wait for material
or secondary resource. Notice that the Weld resource has allocated and utilized values of 1 when the material/resource arrive.
In the corresponding Entity Workflow gantt below, note that the OrderWIP1 entity that is processing at Weld is first constrained by the availability
of the Weld resource until 8 am. Then, there is a very short period of time where the entity is waiting for the worker to arrive for processing.
Once the worker arrives, the Weld resource goes into a 'utilized' state, as seen in the Resource C apacity Log above.
Note: The small checkbox that can be seen at the bottom left of the Resource C apacity Log displays any Filters that may have been set for the
data.
The Log ribbon includes options to change the Time Units, Length Units and Rate Units for the capacity log. These options are similar to the Status
Units section of the Run ribbon within the Facility window and will change the units for all relevant windows.
All data within the Resource C apacity Log may also be exported to a *.csv file by using the Export to C SV button.
783 / 815
Simio Reference Guide
C onstraint Log (Enterprise)
When the C onstraint Log tab is selected, a smaller version of the Log ribbon and the standard Operational Planning ribbon are available.
Additional columns may not be added to the C onstraint Log; therefore, only the Status Units properties and the Export to C SV options are
available from C onstraint Log’s Log ribbon.
The C onstraint Log includes details of the constraints to the entity over time. The columns that are shown in the C onstraint Log include:
Entity - The name of the entity that is being tracked.
Facility Location - The name of the Server / Workstation from the facility window where the entity is being constrained.
Station - The area within the Facility Location where the entity is being constrained (for example, inputbuffer).
Constraint Type - The type of constraint that is causing the delay. This includes Resource Availability and Resource Arrival. Resource
Availability means the entity is waiting for capacity to become available of the given constraint item. Resource Arrival indicates that the
entity is waiting for a vehicle or worker to arrive to its location for movement to another location.
Constraint Item - The name of the constraint at the specified facility location. The constraint item may be the same as the facility
location if the entity is waiting for the resource within that facility location. For example, the entity may be located at the Weld facility
location and waiting for the Weld resource. The constraint item will be a different name than the facility location if the entity is waiting for
transportation from that location. For example, the entity may be located at the Weld facility location and waiting for the Operator. See
additional notes below for more information on constraint items.
Constraint Description - The type of constraint at the specified facility location. This specifies the type of constraint item for which the
entity is waiting. It is a descriptor for the object type, and includes Workstation, Server, Worker and Vehicle.
Wait Start Time - The simulation time that the entity began to wait for the constraint item (either for resource capacity or resource
arrival.
Wait End Time - The simulation time that entity was allocated the resource (resource capacity) or that the resource arrived to the entity
location (resource arrival).
Wait Duration - The total time that the entity was waiting, as calculated by ‘Wait End Time – Wait Start Time’.
As with all tables, the C onstraint Log can be sorted on any column and/or filtered by column.
In the above example, the C onstraint Log is filtered by entity and only shows Order01 constraints. The table is sorted by the Wait Start Time
column. First, the entity is constrained at the C ut workstation waiting for the capacity of the resource. Later, the entity moves through the Weld
and then to the Shape facility location where it is constrained by 3 items. First, it awaits the capacity of the Shape resource. Once it has the
Shape resource, it waits for capacity of an Operator (worker). Note that the C onstraint Item first indicates Operator (not Operator[1]), as initially,
the entity is waiting for capacity of any Operator type worker. Once capacity of an operator is available, then the entity incurs an additional wait
for the resource arrival of the specific Operator[1] that has been allocated to the entity.
784 / 815
Simio Reference Guide
T ransporter Usage Log (Enterprise)
The Transporter Usage Log provides information detailing each transporter and the entity / order that utilized it. There are five automatic columns
that are provided with the log. These include:
Transporter - The name of the transporter that is utilized.
Rider - The specific entity or order number transporting (riding) on the transporter.
From Node - The transfer node where the transporter picked up the rider.
To Node - The node where the transporter dropped off the rider.
Start Time - The time that the entity was physically on the transporter. This does not include transport to the entity or load time.
End Time - The time that the entity released the transporter.
Duration - The total time that the entity was on the transporter, as calculated by ‘End Time – Start Time’ in default time units.
785 / 815
Simio Reference Guide
Material Usage Log (Enterprise)
The Material Usage Log displays the log of material production and consumption over time of Material elements which had Log Material Usage set
to 'True'. There are five automatic columns that are provided with the log. These include:
Time - The simulation date and time that a material quantity changed.
Material - The name of the material that has been either produced or consumed.
Entity - The specific entity that produced or consumed the material quantity.
Quantity - The quantity of material that was utilized. A positive quantity is a production of the material, while a negative value is a
consumption of the material.
Stock Level - The amount of material left after the quantity specified was added or subtracted from the total.
Note that the Material Usage Log tracks *actual* consumption, not *requested* consumption. So if you ask for 10 units of material, but only 4 are
available, you'll get an entry saying quantity -4. Then if 10 more units get produced at some time later, you'll get *another* entry with -6, fulfilling
the consumption request.
In the example shown above, note that the first two entries at the start of the simulation run indicate that the Initial Quantity for each of these
materials had been specified. For several minutes after that, the quantities are reduced of each material. Note also that at time 12:05:28 AM, an
additional quantity of 80 Nails is produced, indicating a replentishment type of logic. This example log was taken directly from the SimBit
WorkstationWithMaterialC onsumptionAndReplentish.spfx. The SimBit was modified slightly by changing the Log Material Usage property to 'True'
for both Wood and Nails Materials elements.
786 / 815
Simio Reference Guide
T ask Log (Enterprise)
The Task Log displays the list of Task Sequence related Tasks completed over time for entities processed through objects using Task Sequence
type processing. There are nine columns that are provided with the Task Log, including:
Entity Id - The specific entity that completed the task.
Entity - The entity type's Display Name that completed the task. If no Display Name is specified on the instance of the ModelEntity object,
this will be the same as the Entity Id field.
Facility Location - The name of the object location at which the task is performed.
Station - The station location at which the task is performed.
Task Sequence - The name of the Task Sequence element within which the task is specified. For all Standard Library object processing
tasks, this will be 'ProcessingTaskSequence'.
Task - The name of the task that was completed.
Start Time - The start time of the task that was completed.
End Time - The end time of the task that was completed.
Duration - The total time that the entity was processed through the specified task.
787 / 815
Simio Reference Guide
T ables (Enterprise)
The Tables window provides a view of all of the data and sequence tables that have been defined through the Data window. These tables contain
a combination of input data, output states, and target values for the model. Once the Risk Analysis is run the target values are color coded for
High, Medium, and Low risk. You may edit the input data columns that are not “grayed”. This view also provides import/export functionality for the
table data.
Within each of the tables in the Data window, each column has an Operational Planning area of properties. Both the Tables section and Gantt
C hart section have three properties, Visible, Editable and Category Name. Visible specifies whether or not the column will be visible within the
Planning data table or Gantt chart. Editable determines whether or not the column will be editable within the Planning data table or Gantt chart.
C ategory Name is an optional string for displaying the column in the planning table or within the Gantt chart. If both Table type properties,
Editable and Visible, are set to ‘True’ for all columns, then the data tables within this planning table ribbon are exact copies of the corresponding
tables within the Data window. A Gantt chart column that is Visible will be displayed in the Resource Plan Gantt alphabetically, based on the
column name. This column may be turned off within the Gantt by toggling the Table C olumns button in the Gantt ribbon under Visibility.
States and Targets that have been defined for a table will appear slightly different than the original table. Each of the targets defined will appear
with two groupings of columns. First is the ‘TargetName Plan’, which will have the columns ‘Value (Time Units)’ and ‘Status’ as in the original data
table. Additionally, there is the ‘TargetName Risk’ grouping, which will include an ‘Average (Time Units)’ column and a ‘Within Bounds Name
Probability’ column. The table states and targets columns shown in the Tables window will initially be empty.
Within the Tables window, the Operational Planning ribbon is available.
Operational Planning Ribbon
The C reate Plan button will run the simulation model in a deterministic mode with no uncertainty to generate a resource plan. All distributions
used in the model will return their expected values and all failures in the model will be disabled. When the C reate Plan button is selected, Simio
will run the simulation and display the results of the table states columns, as well as the ‘TargetName Plan’ columns in the table. C reating the plan
will not display any values within the ‘TargetName Risk’ columns of the table.
The Analyze Risk button will run the simulation model in a stochastic mode with uncertainty to analyze the target risks specified within the model.
The Planning Horizon Starting Time and Ending Type specify the starting and ending times of the simulation model and are used for both creating
the plan and analyzing the risk. These values can also be seen in the Facility window’s Run ribbon.
The Confidence Level and the Replications Required properties are utilized only when analyzing risk. The Confidence Level is used to calculate the
confidence interval half-width statistics for the target averages and feasibility probabilities estimated by the risk assessment. The default
confidence level is '95%', however the user may also select from the list to include 90%, 95%, 98% and 99%. The Replications Required property
specifies the number of simulation replications to run for the risk assessment. The default value is '10'.
When performing the risk analysis, the number of replications specified is run and then the values within the ‘TargetName Risk’ columns will be
generated. The ‘Average (Time Units)’ column is calculated by using the target expression and taking the average value of that expression for the
number of replications. The ‘Within Bounds Name Probability’ column values are then determined from the number of simulation replications
whose average values fall within the upper and lower bounds specified by the user.
788 / 815
Simio Reference Guide
Facility Model (Enterprise)
The Facility Model is a 3D animated facility view that is useful for viewing an animation of the plan. You can jump to a specific resource and time
in the animation by right clicking on a resource bar in Gantt within the Resource Plan view and selecting “Re-run to here”. Right-clicking on a
particular resource within an Entity row in the Entity Workflow Gantt will also move to the Facility Model with "Re-run to here".
789 / 815
Simio Reference Guide
R esults (Enterprise)
The Results window provides information about the risk based planning and scheduling results, including a Target Summary, Risk Plots, Detailed
Results and Reports.
The Target Summary tab provides a high level summary of target performance including the number and percent of entities that fall within target
bounds. The Risk Plots provide a graphical summary of target performance including confidence intervals and percentiles for each target. The
Detailed Results tab provides detailed results (queue lengths, waiting times, etc.) for the plan in a pivot grid that you can sort, filter, and pivot.
The Reports tab provides detailed reports in both chart and graphical formats. These reports include Resource Dispatch Lists, Workflow C onstraint
Analyses and Resource Utilization Summaries.
Target Summary
Risk Plots
Detailed Results
Reports
790 / 815
Simio Reference Guide
T arget Summary (Enterprise)
The Target Summary window provides information in the form of a pivot grid for the entities / orders that are completed through the system. For
each ‘Target’ that is specified in any given data table, data is provided on the Above Upper Bounds, Within Bounds, Below Lower Bounds and No
Value property values. This includes both the percent of entities / orders that fall within the category, as well as the total number completed within
that category.
The Target Summary is only generated on the Plan (with no variation within the model). Only the Operational Planning ribbon is available for this
window.
791 / 815
Simio Reference Guide
T arget Details (Enterprise)
The Target Details window provides information on the Target results for each entity (order).
The value of the target, as a result of the plan, is displayed under the Target Plan columns and the expected value of the target, as a result of the
risk analysis, is displayed under the Target risk analysis columns. The values in the additional columns, Status and Probability, depend on what
the user has defined for the Target’s Upper and Lower Bounds and the label’s they’ve given each classification in the Value C lassification
properties of the Target. For more information on how to create a Target and define it’s properties, see the Target help page and the Scheduling
example models in the Examples folder.
Target Details (Operational Plan Results)
The Status will display "Within Bounds" if the value falls between the defined expressions in the Upper Bound and Lower Bound properties of the
Target. If the user has defined a Value C lassification for the Within Bounds property on the Target, such as OnTime, OnTime will appear in the
Status column instead of Within Bounds. Similarly, the user can define custom strings to display for a status of Above Bounds and Below Bounds,
from within the Target’s properties. These are defined when the Target itself is defined in a table within the model’s Data window.
The user might notice that some cells within the table are colored either yellow or red after the risk analysis is run. These colors help the user
identify which results are risky. By default, expected values with a within bounds probability of greater than 80 percent are left uncolored. Values
between 40 percent and 80 percent are colored yellow and values less than 40 percent are colored red. These percentages can be changed by
the user by changing the Performance C lassification slider in the ribbon from the Risk Plots Results tab.
The user can save a copy of the model in its current state for use as a baseline for comparison. The user might create an Operational Plan and
then want to make changes to the model or the data being read into the model. For more information on comparing Operational Plans, see the
Plan C omparison help page.
792 / 815
Simio Reference Guide
O perational P lan C omparison (Enterprise)
The user can save a copy of the model in its current state for use as a baseline for comparison. The user might create an Operational Plan and
then want to make changes to the model or the data being read into the model. They would like to compare the results of the new Operational
Plan with the results of another Operational Plan. The user can save a copy of the model in its current state. The user can save multiple copies of
the model in different states and compare each Operational Plan against the others. The user should take note that the size of the Simio project
file increases each time a baseline model is created and saved.
To save a model to compare Operational Plans, the user must first create a plan by clicking Create Plan in the Operational Planning ribbon. They
must also run a risk analysis by clicking Analyze Risk in the Operational Planning ribbon. Once the risk analysis is complete, the Save For
C omparing button in the Operational Planning ribbon will become active. When the user clicks this button, a copy of the model is created and this
baseline model now appears in the Navigation window under a new folder called Baselines.
Baselines in Navigation Window
At this point, the user can make changes to the model and then re-run an Operational Plan and re-run the Risk Analysis. The new Operational
Plan can then be compared to the saved baseline model to see what differences the new changes made to the Targets. In order to show the
differences between the current model and the baseline, the user must go to the Target Detail tab in the Results Panel. From within the Target
Details tab, if there is a baseline model, the user will see the Show Differences button available in the ribbon. If there is only one baseline, it will
automatically be populated in the C ompare To selection box in the ribbon. If there is more than one baseline, the user can select which baseline
model to compare against.
Comparing Two Operational Plans
When the Show Differences button is selected, the user will see new columns appear in the Target Details table. The Show Differences button
can be toggled on or off by the user to display and hide the new differences columns. When the button is selected, there will be a new column
named C hange under each Target’s plan results and risk analysis results. This will show the value change between the current model and the
baseline model that is currently selected in the Compare To selection box. In the Target’s plan results, there will also be a new column named
Status C hange that will show any change in the Target’s status. In the Target’s risk analysis results, there will be a new column named Probability
C hange that will show changes in the probability that this Target will be within the defined bounds. For more information on defining a Target and
its lower bound and upper bound, see the Target help page.
In the example above, the user saved a baseline operational plan and then made changes to the schedule within the current model. After making
the changes, they wanted to compare the target results of the current model with the new schedule to the target results in the baseline. You'll
notice that some orders went from OnTime to Late. You can see how much later the order is expected to be in the C hange column under Target
Ship Date - Risk Analysis. You'll also notice that some orders went from OnBudget to Overrun. And the C hange column under Target C ost - Risk
Analysis shows the new expected value for the C ost Target.
793 / 815
C opyright 2006-2015, Simio LLC . All Rights Reserved.
794 / 815
Simio Reference Guide
R isk P lots (Enterprise)
The Risk Plots window provides additional information on the target(s) specified within a Data table. Risk Plots charts can be generated with both
the Plan (deterministic run without variation), as well as with the Risk Analysis (stochastic run with variation).
By default, the format of the results are originally shown in a Box and Whisker type format, with the Target name shown at the top of the chart,
and each row within the TableName.Target shown along the y-axis. The x-axis shows the Target values.
If the user has only generated the plan, the results shown in the Risk Plots will include only the Expected Value of the Target (shown as a red
vertical line), and the Upper Bound property, as defined by the Target within the Data Table, as shown below. In the example shown below, all
entities were expected to be completed on time, as the pink shaded area is located to the right of the expected value, with the exception of
OrderWIP2. The expected value of the target ship date for OrderWIP2 is later than the Upper Bound value specified for the target.
Risk Plot for Plan Only
If the user has performed the risk analysis, the results shown in the Risk Plots will include the mean, min/max values, range and percentile
values, as shown below.
Risk Plot for Risk Analysis
795 / 815
Key to Target Chart
When the mouse is placed on the outer lines, the minimum and maximum values are displayed as the range of the observations. When the
mouse is hovered over the tan circle, the mean of the observations is displayed. When the mouse is placed over the upper portion of the box, it
will display the top range (50% - 75%) including the median and upper percentile value. Finally, when the mouse is hovered over the lower
portion of the box, the lower range (25% - 50%) including the lower percentile value and the median are shown.
The Target C hart and Operational Planning ribbons are available within the Risk Plots window. The Target C hart ribbon includes buttons for the
target data to be displayed in various ways.
The Plan Values button will display a red line for each observation on the box and whisker plot for the target. This displays the Expected Value of
the target as derived from the Plan. This expected value is also automatically calculated when performing risk analysis, as the plan is run first.
The C onfidence Intervals button will display three confidence intervals on the chart. The uppermost light blue rectangle shows the confidence
interval of the upper percentile and includes the start and end value of the interval. The lower light blue rectangle shows the corresponding data
for the lower percentile. The light brown rectangle shows the confidence interval of the mean, and includes the start and end values, as well as
the half-width.
796 / 815
The Histogram button will display a histogram of the replication data points on the SMORE plot. No additional data is provided when hovering the
mouse over the histogram.
The Limits button will display the upper and lower bound from the target when run in plan mode. The SMORE itself scales to the available result
data, so even if you have limits, they will not display if they are off the ‘sides’ of the SMORE. However, if you have result data in the range of 0 –
10 for example, and the limits are at 2 and 6, the Limits button will display them in light red over the SMORE plot area.
The Observations button simply displays each replication value for the target on the plot in light blue dots.
The Within Bounds Probability button will display a value within a box to indicate the probability of the target falling within the bounds that were
specified (including both the upper and lower bounds).
797 / 815
Simio Reference Guide
Detailed R esults (Enterprise)
The Detailed Results window includes summary statistics for the simulation run, as generated with the resource Plan. It is important to remember
that the results are calculated in a deterministic mode with no uncertainty. Therefore, the results displayed will be different than those displayed
within the Results tab window when running the general simulation model. Below is an example of the Detailed Results window.
798 / 815
Simio Reference Guide
R eports (Enterprise)
The Reports window provides several different chart-based and graphical summary reports for the plan. Again, these results are calculated in a
deterministic mode with no uncertainty. The reports include Resource Dispatch List, Workflow C onstraint Analysis and Resource Utilization
Summary. Each of these is described in more detail below. The reports can be customized with the Report Designer, if the standard report does
not meet your need.
C licking on 'Show Detail' in the top right corner of the report will display more information about each specific task, as seen below. For each task
that has been processed at the given resource, information is displayed regarding the amount and percentage of time the resource spent in
various 'states'. For example, states of the resource may include OffShift, Processing, Setup, Teardown or WaitingForSecondaryResource.
799 / 815
Workflow C onstraint Analysis
The Workflow C onstraint Analysis reports provide additional information to the C onstraint Log within the Entity Workflow window. The parameters
to be specified for this type of report include the the StartDate, EndDate and ShowGraphics. Once those are complete, clicking on the Submit
button will generate the report. C hanging the ShowGraphics from 'True' (default) to 'False' will turn off all graphical reports and show charts only.
For each constraint type, the report includes information on the C onstraint Item, number of Occurences, Average Wait and Total Wait times, both
in chart and graph formats. Types of contraints include Resource Availability and Resource Arrival. An example of the report sections is shown
below.
800 / 815
Resource Utilization Summary
The Resource Utilization Summary reports provide utilization summary information for all resources in the system. The parameters to be
specified for this type of report include the the StartDate, EndDate and ShowGraphics. Once those are complete, clicking on the Submit button will
generate the report. C hanging the ShowGraphics from 'True' (default) to 'False' will turn off all graphical reports and show charts only.
For each resource, the report includes information on the Resource State and Total Time that the resource is in that state, both in chart and graph
formats. This utilization report provides summary information for the State Log under the Resource Plan panel. Resource States include OffShift,
Setup, Processing, Teardown, Starved, and WaitingForSecondaryResource. An example of the Resource Utilization Summary for a single resource
is shown below.
801 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
802 / 815
Simio Reference Guide
Add-Ins R ibbon (Enterprise)
The Add-Ins ribbon when the Planning tab is active provides several specific add-in buttons for use in particular scheduling applications.
The Export Schedule to MES add-in will save the schedule back to Wonerware MES. It will save the schedule start, schedule end, schedule
resource and set the status of the first job to “Ready”. Note: User needs Wonderware MES C lient installed on the computer to access the
Wonderware MES API. The Import Downtime add-in will pull downtime information from Wonderware MES using the Wonderware MES API and
load them onto the appropriate resource in Simio. Note: User needs Wonderware MES C lient installed on the computer to access the Wonderware
MES API.
See the Scheduling and Wonderware Add-Ins section of the Tables page for additional table generating add-ins.
When using the Wonderware MES add-ins, once the various tables have been created within the Data tab, the user may utilize the table binding
option related to Wonderware MES. The Wonderware MES data bind reads the data tables and views in the Wonderware MES Database using
the Wonderware MES API. Note: User needs Wonderware MES C lient installed on the computer to access the Wonderware MES API.
For more information on the Wonderware MES add-ins described above, see
http://www.simio.com/downloads/public/software/SimioProductionSchedulingWonderwareMESInterface.pdf.
803 / 815
Simio Reference Guide
Appendix
804 / 815
Simio Reference Guide
System R equirements
Hardware Requirements
1 GHz or faster processor
1 GB of RAM (4 GB or more recommended)
Available hard drive space of 500 MB minimum for installation*
1,024x768 display (higher resolution recommended)
A 16-bit graphics card with 128 MB compatible with DirectX ver. 9
Internet connection required for online services
If you are using an existing system, then the above guidelines should provide acceptable performance. If the system falls short in memory or
graphics, note that memory is often fairly inexpensive. Most systems with inadequate memory can be easily and inexpensively upgraded.
Likewise graphics cards are also fairly inexpensive.
If you are buying a new system, then we recommend:
Multiple processors because Simio takes full advantage of multiple processors (e.g. hyper-threaded quad core will run 8 concurrent
replications).
A higher than standard screen resolution, perhaps 23” or larger, 1920x1200 resolution, and perhaps even a second or third monitor –
Simio takes full advantage of higher resolution and multiple monitors.
A 64 bit OS with 16G or more of memory will allow plenty of space to run very large models.
*Additional prerequisite software packages other than this product may require installation. and these other packages may require additional
available hard drive space for installation purposes.
***Not only can you use a second monitor for displaying help and documentation, but most Simio windows can be undocked and moved to a
second screen. For example, you can display the Trace or C onsole window on the second screen. Or you can simply have the animation span two
screens.
Software Requirements
Microsoft® Windows® Vista® with Service Pack 2 or later, Windows 7 SP 1 or later, or Windows 8 or later (Windows 10, 10.1, ...). Both 32
bit and 64 bit operating systems are fully supported and included with the install.
Miscellaneous Notes
Apple products like Mac are not officially supported, but many customers have had good results using Parallels or similar products.
Simio does work on a Surface Pro as long as the OS is standard Windows 8 not Windows 8 RT. Simio does offer touch screen support.
805 / 815
Simio Reference Guide
64 bit Execution
When you start Simio, by default, the 32 bit executable is run (Simio.exe). There is, however, an option for running the 64 bit version of Simio,
depending upon your computer.
Can I run Simio in 64 bit mode? Yes, but only if you are using a 64 bit OS.
Do I have to use the 64 bit version? No. If you are running a 64 bit OS you can run either the 32 bit or 64 bit version of Simio. By default
you will run the 32 bit version of Simio regardless of your OS. If your OS is 32 bit, you do not have a choice and can run only 32 bit Simio.
How can I run in 64 bit mode? Find Simio.exe (usually in C :\Program Files (x86)\Simio) and right next to it you will find Simio64.exe. You can
double-click it, run from the command line, or create a short-cut to it on your desktop.
Will it run faster? Sorry, probably not. All of the memory addressing is twice as long (i.e., 64 bits rather than 32 bits) so the C PU is working a
bit harder and models will generally execute a bit slower.
Why would I use 64 bit? In general, don't use it unless you need it. But you may need it to run very large models or lots of concurrent
replications of moderate-size models. Depending on exactly how you use it, running in 32 bit mode limits each process to using less than 2G of
memory, and sometimes much less:
Windows itself, plus Simio and every application you are running take part of that 2G.
Sharing that 2G between 8 concurrent replications leaves less than 250M per replication.
64 bit mode replaces those limits with numbers so high they are unlimited from a practical sense. You can load and run models that are limited
only by the amount of memory you have on your computer.
Memory is relatively inexpensive, so you can max out your system and Simio will take full advantage of all your memory and processors. You
can run models in Simio that could not be run in most other products. One simple example is that Simio permits you to load tables that are so
large they will not load into Excel.
806 / 815
Simio Reference Guide
Installation and Activation
807 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
808 / 815
Simio Reference Guide
C opyright Notices and Acknowledgements
809 / 815
Simio Reference Guide
C heck For Updates
A scenario when you might consider not accepting an update, is if you've created a new object by subclassing one of our standard objects and
you do not want your custom logic to be affected. If Simio detects that there are some objects with process overrides, the below dialog will be
displayed instead:
The Object Updates Available Window - Process Overrides in Objects
When the above dialog has been shown, the user then has an opportunity to open the Object Updates Available window from within the project.
To open the update window after you've looked more closely at your objects, you can bring it up by clicking on the Check for Updates icon in the
Project Home ribbon. As you can see in the below example, the Standard Library updates are suggested by a check in the update checkbox;
however, it is not suggested that users automatically update any subclassed objects that have process overrides, as it may incorporate some
object logic updates, but will not update the overridden processes. As shown below, those custom objects with process overrides do not have a
check in the update checkbox.
The Object Updates Available Window
810 / 815
Send comments on this topic to Support
C opyright 2006-2015, Simio LLC . All Rights Reserved.
811 / 815
Simio Reference Guide
T erms of Use (E U LA)
This is the End User License Agreement. C lick here to see the Run Time C apability, which is how the software works for someone without a
commericial license. C lick here to see our Academic Use Policy.
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------
------------------------------------------------------------------
ATTENTION: PLEASE READ THESE TERMS CAREFULLY BEFORE USING THIS SOFTWARE. USING THIS
SOFTWARE INDICATES THAT YOU ACCEPT THESE TERMS. IF YOU DO NOT ACCEPT THESE TERMS
("TERMS"), DO NOT USE THIS SOFTWARE.
END-USER LICENSE AGREEMENT
IMPORTANT—READ THIS AGREEMENT C AREFULLY: This End-User License Agreement (“EULA”) is a legal contract between you (either an
individual or a single entity) (“You or LIC ENSEE”) and Simio LLC . ("SIMIO”) for the software product or products that SIMIO licenses to You, which
includes computer software and may include associated media (“Software”). SIMIO may also license to You printed materials, and “online” or
electronic documentation ("Documentation"). An amendment or addendum to this EULA may accompany the Software. SIMIO IS WILLING TO
LIC ENSE THE SOFTWARE AND DOC UMENTATION TO YOU ONLY ON THE C ONDITION THAT YOU AC C EPT ALL OF THE TERMS AND C ONDITIONS IN
THIS AGREEMENT. YOU AC C EPT AND AGREE TO BE BOUND BY THE TERMS OF THIS EULA BY INSTALLING, C OPYING, OR OTHERWISE USING THE
SOFTWARE. IF YOU ARE AC C EPTING THESE TERMS ON BEHALF OF ANOTHER PERSON OR A C OMPANY OR OTHER LEGAL ENTITY, YOU
REPRESENT AND WARRANT THAT YOU HAVE FULL AUTHORITY TO BIND THAT PERSON, C OMPANY, OR LEGAL ENTITY TO THESE TERMS. IF YOU
DO NOT AGREE TO THESE TERMS, DO NOT DOWNLOAD, INSTALL, C OPY, AC C ESS, OR USE THE SOFTWARE, AND PROMPTLY RETURN THE
SOFTWARE WITH ALL AC C OMPANYING ITEMS TO YOUR PLAC E OF PURC HASE FOR A FULL REFUND. IF YOU DOWNLOADED THE PROGRAM,
C ONTAC T THE PARTY FROM WHOM YOU AC QUIRED IT. This Software is licensed to You -- not sold. Your rights to use the Software are only those
rights specified in this EULA. GRANT OF LIC ENSE Provided You comply with all the terms and conditions of this EULA, SIMIO and its third party
licensors grant You a non-exclusive license to install and use the Software on a single computer, a network server, or on multiple computers
owned or leased by the LIC ENSEE provided the number of installations and users is not greater than the number of valid software activations
purchased. This License does not grant You the right to provide or utilize the Software as an application service provider or the like. Any
attempted sublicense, rental, sale, lease, or commercial hosting of the Software is prohibited. However, You may transfer rights to use the
Software on a permanent basis, provided: (1) You transfer this EULA, the Software, and all accompanying written materials and retain no copies;
(2) the recipient agrees to the terms of this EULA; (3) the recipient agrees to follow the software activation process; and (4) You first notify SIMIO
in writing of the date of transfer and the recipient’s full name and address. If this Software is an upgrade or update to a previous version of a
SIMIO product, You may not transfer the prior version to another user. This EULA supersedes any prior license with respect to Your use of the
Software. This Software is protected under applicable patent and copyright laws. The Documentation is copyrighted. Unauthorized copying,
reverse assembly, reverse engineering, decompilation, and creating derivative works based on the Software are prohibited. You may make a
copy of the Software provided that any such copy is only for archival purposes to internally back-up the Software, or is created as an essential
step in the internal installation of Software within your organization. You may not make any other copies of the Software. LIMITED WARRANTY
The Software is warranted for ninety days after its initial delivery to You that it will substantially conform with its Documentation supplied by
SIMIO at the time of initial delivery of the Software. This warranty shall be void if You attempt to modify the Software in any way. SIMIO makes
no representation or warranty, express or implied, that the operation of the Software will be uninterrupted or error free, or that the functions
contained in the Software will meet or satisfy Your intended use or requirements; You assume complete responsibility for decisions made or
actions taken based on information obtained using the Software. TO THE MAXIMUM EXTENT PERMITTED BY LAW THE FOREGOING LIMITED
WARRANTY IS IN LIEU OF ALL OTHER WARRANTIES, EXPRESS OR IMPLIED, AND SIMIO DISC LAIMS ANY AND ALL IMPLIED WARRANTIES OR
C ONDITIONS, INC LUDING (WITHOUT LIMITATION) ANY WARRANTY OF TITLE, NONINFRINGEMENT OF THIRD PARTY RIGHTS, MERC HANTABILITY
OR FITNESS FOR A PARTIC ULAR PURPOSE OR ANY WARRANTY UNDER UC ITA. SOME C OUNTRIES AND STATES DO NOT ALLOW THE EXC LUSION
OF IMPLIED WARRANTIES, SO THE ABOVE EXC LUSION MAY NOT APPLY TO YOU. THIS WARRANTY GIVES YOU SPEC IFIC LEGAL RIGHTS, AND
YOU MAY ALSO HAVE OTHER RIGHTS WHIC H VARY FROM C OUNTRY TO C OUNTRY OR STATE TO STATE. LIMITATION OF REMEDIES SIMIO’s
entire liability and Your exclusive remedy for breach of the Limited Warranty shall be: 1. The replacement of the Software not meeting the
Limited Warranty specified above which is returned with proof of purchase; or 2. If SIMIO is unable to deliver replacement Software which meets
the Limited Warranty specified above, You may terminate this EULA by returning or destroying the Software as provided herein, and SIMIO or its
reseller will refund Your purchase price. LIMITATION OF LIABILITY TO THE MAXIMUM EXTENT PERMITTED BY APPLIC ABLE LAW, IN NO EVENT
SHALL SIMIO OR ITS THIRD PARTY LIC ENSORS BE LIABLE FOR ANY SPEC IAL, INC IDENTAL, INDIREC T, PUNITIVE, OR C ONSEQUENTIAL
DAMAGES WHATSOEVER (INC LUDING, BUT NOT LIMITED TO, DAMAGES FOR LOSS OF PROFITS OR C ONFIDENTIAL OR OTHER INFORMATION,
FOR BUSINESS INTERRUPTION, FOR LOST SAVINGS, FOR LOSS OF PRIVAC Y, AND FOR ANY OTHER PEC UNIARY OR OTHER LOSS WHATSOEVER)
ARISING OUT OF OR IN ANY WAY RELATED TO THE USE OF OR INABILITY TO USE THE SOFTWARE, EVEN IF SIMIO OR ITS RESELLER HAVE BEEN
ADVISED OF THE POSSIBILITY OF SUC H DAMAGES. SOME C OUNTRIES DO NOT ALLOW THE LIMITATION OR EXC LUSION OF LIABILITY FOR
INC IDENTAL OR C ONSEQUENTIAL DAMAGES, SO THE ABOVE LIMITATION MAY NOT APPLY TO YOU. SIMIO'S MAXIMUM C UMULATIVE LIABILITY
RELATIVE TO ALL C LAIMS AND LIABILITIES, INC LUDING THAT WITH RESPEC T TO DIREC T DAMAGES AND OBLIGATIONS UNDER ANY
INDEMNITY, WHETHER OR NOT INSURED, WILL NOT EXC EED THE C OST OF THE SOFTWARE GIVING RISE TO THE C LAIM OR LIABILITY. ALL OF
THESE DISC LAIMERS AND LIMITATIONS OF REMEDIES AND/OR LIABILITY WILL APPLY REGARDLESS OF ANY OTHER C ONTRARY PROVISION OF
THIS EULA OR ANY OTHER AGREEMENT BETWEEN YOU AND SIMIO AND REGARDLESS OF THE FORM OF AC TION, WHETHER IN C ONTRAC T, TORT
OR OTHERWISE, AND FURTHER WILL EXTEND TO THE BENEFIT OF SIMIO’S VENDORS, APPOINTED DISTRIBUTORS AND OTHER AUTHORIZED
RESELLERS AS THIRD-PARTY BENEFIC IARIES. TERM AND TERMINATION This EULA takes effect upon Your use of the Software and remains
effective until terminated for any reason. You may terminate it at any time by destroying all copies of the Software and Documentation in Your
possession. It will also automatically terminate if You fail to comply with any term or condition of this EULA. You agree on termination of this EULA
to either return to SIMIO or destroy all copies of the Software and Documentation in Your possession. AC ADEMIC USE If this Software was
purchased for academic or research use by an educational institution, it may be used for teaching and research purposes only. C ommercial use
of the Software is prohibited if the software was intended for educational use. Only the instructor/professor registered to the Software is eligible
to contact SIMIO for technical support and product updates. You have the right to make copies of the Software (the media excluding activation)
solely for academic, teaching and research purposes. PREPRODUC TION RELEASES As an accommodation to LIC ENSEE, SIMIO may provide
LIC ENSEE with a preproduction release of the Software (often labeled a “beta release”). These releases are not suitable for production use. Such
releases are provided on an “as is” basis. SIMIO does not warrant preproduction releases. SAMPLES The Software may contain samples that are
provided as an accommodation to You (“Sample Project Files”). These Sample Project files are intended to be used for example only. The Sample
Project Files may be contained in the Software, Documentation or downloaded from the SIMIO website. SIMIO and its third party licensors make
no representations or warranties regarding Your use of the Sample Project files and related Documentation. All such Sample Project Files are
provided "as is". SIMIO disclaims all warranties with regard to this information, including all implied warranties and conditions of merchantability,
fitness for a particular purpose, title and non-infringement. GOVERNMENT RESTRIC TED RIGHTS If You are a branch or agency of the United
States Government, the following provision applies. The Software and Documentation are comprised of "commercial computer software" and
"commercial computer software documentation" as such terms are used in 48 C .F.R. 12.212 (SEPT 1995) and are provided to the Government (i)
for acquisition by or on behalf of civilian agencies, consistent with the policy set forth in 48 C .F.R. 12.212; or (ii) for acquisition by or on behalf of
units of the Department of Defense, consistent with the policies set forth in 48 C .F.R. 227.7202-1 (JUN 1995) and 227.7202-3 (JUN 1995). EXPORT
C ONTROLS You acknowledge that the Software is subject to the export control laws and regulations of the United States and any amendments
thereof. You agree that You will not directly or indirectly transfer or use the Software except in compliance with applicable U.S. export laws and
regulations. OWNERSHIP The Software and Documentation are protected by patent, copyright and other intellectual property laws and treaties.
SIMIO or its licensors own the title, copyright, and other intellectual property rights in the Software and Documentation. The Software and
Documentation is licensed, not sold. Nothing in this EULA constitutes a waiver of our rights under U.S. or international patent or copyright law or
any other law. MISC ELLANEOUS This EULA shall be governed by the laws of the State of Pennsylvania, without regard to any conflict of laws
provisions. The United Nations C onvention on the International Sale of Goods will not apply. You agree to bring any action in connection with this
EULA or the Software exclusively in the state or federal courts of Pennsylvania, and You further agree to the jurisdiction of the state and federal
courts of Pennsylvania for any action that SIMIO brings against You. The Software may contain third party software which requires notices and/or
812 / 815
courts of Pennsylvania for any action that SIMIO brings against You. The Software may contain third party software which requires notices and/or
additional terms and conditions. Such required third party notices and/or additional terms and conditions are identified in the Software and are
made a part of and incorporated by reference into this EULA. By accepting this EULA, You agree to review such terms and conditions set forth
therein, if any, and your use of the Software will be deemed to be your acceptance thereof. This EULA, and any amendment or addendum to this
EULA that accompanies the Software is the complete and exclusive agreement between SIMIO and You, and supersedes all prior agreements,
whether written or oral, relating to the Software provided and the Documentation. This EULA may not be changed or modified except by an
instrument in writing signed by a duly authorized representative of SIMIO. If for any reason a court of competent jurisdiction finds any provision
of this EULA or portion thereof, to be unenforceable, that provision of the EULA shall be enforced to the maximum extent permissible so as to
effect the intent of the parties, and the remainder of this EULA shall continue in full force and effect. The parties acknowledge that they have
required the EULA to be drafted in English. Les parties reconnaissent avoir exigé la rédaction en anglais du C ontrat. In the event of a conflict
between the English and other language versions, the English version will prevail.
813 / 815
Simio Reference Guide
R un T ime C apability
814 / 815
Simio Reference Guide
Academic Use P olicy
815 / 815