There are two different binary versions of the Rocks'n'Diamonds game.
This is the standard Rocks'n'Diamonds game client with a GUI, which relies on SDL2
. All of the features such as using your own controller work here. Since graphics elements are being updated in the main game loop along with a frame delay, the controller will run in real time, which can be slow if you want to quickly test against multiple levels. Simulation faster than real time is possible as I have disabled the framebuffer updates if the simulating flag is set to true (i.e. by calling enginestate::setSimulatorFlag(true)
). However, there will be a slight performance hit if your controller is simulation based such as MCTS.
This is the same as the above, but with any graphics elements stripped out, and runs as a standard command line program. This doesn't depend on SDL2
, so installing it is not required. Since graphics elements are not used, controllers can run faster than real time, which is useful for replaying a level multiple times. Simulation based controllers will also see around a 2x performance increase in terms of number of simulations per second. I've been able to get around 8 engine simulations every 21 micro-seconds (8 engine simulations is the default number of ticks to move the agent from 1 tile to the next), but this doesn't include overhead for the design of the controller.
Since we cannot view the AI agent and see whether the controller was successful or not, replay files can be created which saves each action the controller tells the agent to perform. These replay files can then be loaded in the rocksndiamonds
version to view the actions the AI agent took.