My thesis advisor played Boulderdash and Emerald Mine back in the day, and knew about the RnD client being open source with extensive levels (and custom levels readily available), and so thought that this would be an interesting research environment to create policies which can learn to play these games.
To allow use for my thesis project, I’ve done a lot of work to create an interface/hooks into the engine to allow input from a custom controller to send actions for the agent, and helper functions for common engine state information. I’ve also modified many parts of the game code to create a headless (no SDL image/sound) binary version of the game to allow for faster simulations of the game engine (helpful for simulation based agents such as MCTS which require faster than real-time engine simulation).
The project design has been based primarily around my thesis work and what I needed at the time, so the code is by no means the most elegant. It is at a point now where there shouldn't be major design changes, and I make no promises that it is bug free! However, there may be other people here which would like to play around with their own agents, or see the changes that I’ve made to inspire their own projects.
You can find the repo here: https://github.com/tuero/rocksndiamonds
It should compile fine on Linux/Mac with gcc/clang and cmake (install instructions/docs are on the repo page). It would be nice to get Windows support, but porting over has been non-trivial and I have been busy with my thesis work.
I hope this inspires others!


 
 