Simulator Usage: Simulation Mode
Pressing the "Start" button in Init Mode leads you to the second main mode of the simulation environment, which is Simulation Mode. In Simulation Mode, the computation of the amoebot structure that was set up in Init Mode is simulated in rounds, as explained on the reference pages. The state of the amoebot structure can be inspected in every round, even if the simulation has already progressed further than the currently viewed round, thanks to the history feature. Additionally, amoebot states can be modified in the latest system state and the last simulated rounds can be deleted, providing a way to play out different scenarios based on manual input.
As mentioned in the Init Mode guide, the UI in Simulation Mode is very similar to the Init Mode UI:
On this page, we only consider the functionality that has not been explained on the Init Mode page.
Bottom Bar
The Bottom Bar is only enabled in Simulation Mode. It contains all UI elements used to control the simulation progress.
On the left side of the bar is the round speed slider. This slider controls how much time passes between two rounds while the simulation is playing. The interval can be adjusted in steps, with the maximum and minimum values being 4s and 0s, respectively. Setting the interval to 0s will run the simulation as fast as possible but may make the application unresponsive.
The three buttons in the middle of the bar are the Play/Pause button (in the middle) and the Step buttons. The Play/Pause button toggles between the playing and the paused simulator state. While playing, the simulation will automatically progress one round at a time with the speed set using the round speed slider. With the left and right Step buttons, the simulation state can be moved back and forward one round while the simulation is paused. However, it can only be moved in the range of already simulated rounds. If stepping in a direction is not possible, the corresponding Step button is disabled.
The right side of the bar contains additional round controls and displays the current and maximum round. The slider indicates the currently selected round relative to the range of available rounds. It can be used to quickly scroll through the history while the simulation is paused. If the toggle button to the left of the slider is disabled, the simulation state will only be updated when the slider is released. If it is enabled, the state will already be updated while the slider is being moved, which makes navigation easier but may be less performant. If the Play button is pressed while a round before the latest round is selected, the simulator will first step through the remaining history before continuing to simulate new rounds.
The button left of the toggle is the Cut button. Pressing it will delete all simulated rounds after the currently selected round, i.e., cut off the end of the history. It can be used to restart the simulation (if pressed in round 0) or to replay a part of an algorithm that includes random behavior. This can be useful if some error only occurs when certain random decisions are made because the simulation can easily be repeated until these conditions are met.
Top Bar
The Top Bar shows various changes compared to Init Mode. Minor changes include that the Save button (second button in the left group) now works and the Settings button (third button in the right group) is now enabled. The Settings button is explained further below.
Tool Menu
In the middle-left menu (the tool menu), the tools specific to Init Mode have disappeared and one new tool is visible. The Selection tool works just like in Init Mode: Clicking on an amoebot opens the Particle Panel and clicking anywhere else in the Central Area closes it again.
data:image/s3,"s3://crabby-images/bae0e/bae0e8c26c86fa6a51db784ff910d4879119e639" alt="Partition Set Move Tool Partition Set Move Tool"
The new tool is the Partition Set Move tool. In algorithms that use circuits with non-singleton partition sets, this tool can be used to temporarily move around partition sets with the mouse. Non-singleton and non-empty partition sets are visualized as small circles inside of the amoebots, with lines connecting the circle to the pins contained in the partition set. These circles can be grabbed and dragged around using the left mouse button while the Partition Set Move tool is selected. However, changing the partition set placement mode (see below) or moving to a different round will discard all partition set movements made with this tool. For more information on partition sets, please refer to the corresponding reference page.
data:image/s3,"s3://crabby-images/8f2cb/8f2cb8e6ed17e198cd9d29755e63650141afe5d7" alt="View Menu View Menu"
View Menu
The view menu has not changed relative to Init Mode, but most of its effects can only be seen in Simulation Mode. The first button cycles through the three different view modes:
Hexagonal View ![]() |
Rounded Hexagonal View ![]() |
Graph View ![]() |
---|---|---|
![]() |
![]() |
![]() |
The second button cycles through four placement modes for partition sets:
Default Mode ![]() |
Disk mode ![]() |
Circle Mode ![]() |
Line Mode ![]() |
---|---|---|---|
![]() |
![]() |
![]() |
![]() |
The default mode prioritizes custom partition set placements defined in the algorithm code and falls back to the second mode if no position was set. The second mode is automatic disk placement. It distributes the partition sets inside a circle according to the average positions of the pins they contain. Afterwards, it uses a variant of LLoyd's algorithm to move partition sets that are too close further apart from each other, nudging them in a random direction if their positions are equal. The third mode is automatic circle placement. It is similar to disk placement but it distributes the partition sets directly on the circle instead of the area inside of the circle. Finally, the fourth mode is line placement. It simply distributes the partition sets evenly on a straight line in the center of the amoebot. The line is vertical in contracted amoebots and orthogonal to the expansion direction in expanded amoebots. The algorithm shown above (Boundary Test) defines custom partition set positions, which is why the default mode placement differs from disk placement.
The third and fourth button simply toggle the circuit and bond visualization on and off:
Circuits and bonds | Circuits and no bonds |
---|---|
![]() |
![]() |
No circuits and bonds | No circuits and no bonds |
![]() |
![]() |
data:image/s3,"s3://crabby-images/8f2cb/8f2cb8e6ed17e198cd9d29755e63650141afe5d7" alt="View Menu View Menu"
The last button in the view menu does not only affect the visualization. This button toggles the collision check. As long as the check is enabled, any collision occurring during joint movements will force the simulation to stop and display the colliding edges in the UI. Once the collision check is disabled, the simulation can proceed and will "forget" about the last collision.
data:image/s3,"s3://crabby-images/d6ae0/d6ae05678875930d9c3dacf5313e256abb4be154" alt="Settings Panel Settings Panel"
Settings Panel
The Settings Panel is opened by pressing the Top Bar button with the gear icon, which is the second-last button in the Top Bar. It will appear on the right side of the UI, where the Initialization Panel is in Init Mode. The panel contains some advanced camera controls, visualization options and other settings.
Camera Controls
Camera Angle
This slider controls the rotation angle of the viewport.
Moving the slider to the right rotates the camera counter-clockwise in 30 degree steps.
Camera Pos. X and Camera Pos. Y
These fields can be used to specify the coordinates of the center of the camera.
The position is only updated when the Apply
button below is clicked.
When the camera is centered or framed around the amoebot structure, the content of these fields is updated.
Grid Coordinates
If this toggle is enabled, the coordinates specified in the above fields are grid coordinates instead of world coordinates.
Camera Size
This field is used to specify the camera's orthographic size, which corresponds to the zoom level.
The value is applied to the camera when the Apply
button is clicked.
Its value is updated when the camera is framed around the amoebot structure by pressing the button in the Top Bar.
Apply
This button applies the currently set camera position and zoom level to the camera.
Visualization
Animations On/Off
This setting toggles the movement animations on and off.
Animations make the amoebot movements much easier to understand, but the simulation might run faster with animations turned off.
Compass Ov. Arrows
This setting changes the visualization of compass directions in the amoebot overlay showing the compasses of all amoebots.
When it is enabled, the compass directions are displayed as arrows.
When it is disabled, the directions are represented by their textual names (like E, NNE, etc.) instead.
Circuit Border
Toggles a thin black border for the circuit connections between amoebots.
For some circuit colors, this makes the circuits much easier to see.
The border is not visible if a beep is sent on the circuit.
Circular Ring
This setting toggles the ring around the amoebots in graph view mode (see view modes above).
Turning the rings off removes the color information from the amoebots but may be useful for creating screenshots with a particular style.
Fullscreen
When the application is built and run as a standalone outside the Unity Editor, this setting can be used to toggle between fullscreen and windowed mode.
It is recommended to run the application in fullscreen mode.
This setting has no effect when the simulator runs in the Unity Editor.
Other
Tooltips
This setting toggles the tooltip feature.
While tooltips are enabled, placing the cursor over a button and keeping it still for a short time will display a helpful tooltip.
Beep Failure Prob.
Here, you can set the probability of beep failures (TODO: Reference).
The value can be changed at any time but it will not have an effect while replaying already simulated rounds.
Save Settings
Press this button to store the current settings in the configuration file.
data:image/s3,"s3://crabby-images/eaa72/eaa72647215e58f54b4afb0fe6303385f512e5e6" alt="Particle Panel (Simulation Mode) Particle Panel (Simulation Mode)"
Particle Panel
The Particle Panel is available by clicking an amoebot with the Selection tool activated, both in Simulation and Init Mode. The difference between the two modes is that the panel now displays the particle attributes instead of the amoebot's initialization parameters, and it shows the algorithm's status info buttons (see below). Note that although the same algorithm as in the Init Mode example is selected (Line Formation), the Particle Panel displays different content.
The only content that is displayed in both modes are the chirality and compass direction, which are neither initialization parameters nor particle attributes. In Simulation Mode, their values cannot be changed anymore. The attribute values as well as the Anchor state (the little button left of the "Particle" text) can only be edited when the simulation state is in the latest round of the history. If you want to change an amoebot's state in an earlier round, you will need to cut off the rest of the history.
Above the attributes, you can now find the status info buttons of the algorithm. Pressing these buttons will run some method defined by the current algorithm that usually displays some additional information, like the spanning tree in the line formation algorithm. The result may depend on the currently selected amoebot. If the toggle next to a status info button is active, the corresponding method will be called automatically whenever the round changes. You can read more about status info methods on their model reference page.
Hotkeys
The simulation environment provides several hotkeys so that its functions can be accessed more easily. Here is a short overview of the currently set hotkeys:
Hotkey | Function |
---|---|
Right Ctrl + (Arrow Keys or WASD) | Camera Movement |
Space | Play/Pause |
PageUp or (Shift + Right Arrow Key) | Step Forward |
PageDown or (Shift + Left Arrow Key) | Step Back |
Shift + H | Hide/Show UI |
Shift + C | Center Camera |
Shift + F | Frame whole structure |
Shift + V | Take Screenshot |
Shift + S | Save Simulation State |
Shift + O | Load Simulation State |
Shift + Q | Exit Simulator |
If you want to modify the hotkeys, this can be done in the UIHandler
class found in Assets/Code/Graphics/UI/UIHandler.cs
.
You can read more about this class and the UI system implementation on the Dev Guide pages.
Next Steps
Continue by reading the Algorithm Development if you want to learn how amoebot algorithms are implemented.