Xholon - Stupid Model 1 - Basic
What is it
This is the first in a series of 16 "Stupid Models". It's intended as a starting point for learning how to develop grid and agent-based models using Xholon. It can also be used to compare Xholon with other agent-based modeling tools that have also implemented the Stupid Model series.
100 bugs move around on a 100 by 100 two-dimensional grid. This is a toroidal space, so if a bug moves beyond the boundaries, it reappears at the opposite side. Each bug has only a single behavior, that it executes each time step. If at all possible, it must move to a randomly selected unoccupied location within plus or minus 4 spaces of its current location, in both the X and Y direction. Bugs, represented as red circles, are redrawn on the grid each time step. Xholon uses its default random number generator, which draws numbers from a uniform distribution.
Xholon features
StupidModel1_CompositeStructureHierarchy.xml specifies a collection of 100 bugs, that's separate from the 100 row by 100 gridCell grid. XhStupidModel1.java, in the postConfigure() method for the StupidModel object, moves the bugs to random initial positions. The behavior followed by each bug when it moves, is in BugStupidModel1.java.
One bug is intentionally a different color. It's white to make it easy to keep track of the movements of a typical bug. GridPanelStupidModel1.java implements this by checkinf for a specific xholon instance id.
The model runs forever. The maximum number of time steps is controlled by the MaxProcessLoops parameter in StupidModel1_xhn.xml .
You can pause and unpause the model by pressing the "Pause" node.
You can make the model run very quickly by disabling the grid display. Do this by selecting the "View --> gridViewer" node. Every time you press this node, the grid display will toggle on and off.
Credits and references
Railsback, S., Lytinen, S., Grimm, V. (2005). StupidModel and Extensions: A Template and Teaching Tool for Agent-based Modeling Platforms.


