A Rust simulation of the World's Worst Boardgame (W.W.B.) by Rich Hutnik.
I am not affiliated with Rich Hutnik or the World's Worst Boardgame in any way. This project is a fan-made simulation of the game and is not endorsed by the creator. I also do not verify the simulation is correct, as I have not played the game myself. I have read the rules and adapted the game to my understanding of the rules.
W.W.B. is a "game" designed in 2011 by Rich Hutnik. It is a two-player game that is meant to be immensely frustrating and impossible to actually finish. The "board" is 102 cards, "Start", "Finish", and the numbers 1-100.
The game loop is as follows:
- Player rolls d6
- If not 5, next player's turn
- If 5, advance one space
- If players are on the same space that is NOT Start, move BOTH back to Start
- If there was no collision, roll d6 again
- If not 5, go back to Start
- If 5 again, nothing happens
- Next player's turn
I wanted to learn Rust and this seemed like a fun project to work on. A simulation of WWB has never been done either, the longest known one crashed at about 50 trillion turns with a high score of 17.
Using this program, a computer managed to go at least 15 trillion turns overnight with a high score of 17. The game runs about 150-200 million turns a second* on my AMD Ryzen 9 5900X running Arch Linux on WSL. Running it on Windows on the same machine was about the same.
* This program relies very heavily on single-threaded CPU performance, and performance will depend on your CPU. A 2011 Mac Mini only runs about 25 million turns a second, for example; a Raspberry Pi 4 runs about 19 million turns a second.
This program is single-threaded as the collision detection mechanic requires the two threads to essentially take turns as well as the fact that the game state is shared between the two threads. Performance gains are likely minimal and might even be negative, though I have not tested this.
The exact information of the game was on turn 19,097,444,399,063 Player 0 had a top score of 17 while Player 1 had a top score of 17.
Building this project requires Rust and Cargo. You can install them using rustup or through your package manager.
To build the project, run:
cargo build --release
To run the project, run:
./target/release/wwb [savefile]
where savefile
is an optional argument that specifies the file to save the game state to. If no savefile is provided, the game will start from the beginning and NOT SAVE.
Alternatively, you can use the following scripts to run the game:
./contrib/run-one
Builds and runs one instance of the game.
./contrib/run-in-parallel
Builds the program and runs one instance for every core on your machine.
These are sh scripts, Windows users will need to use WSL or a similar tool to run these scripts.
This project is licensed under the 0BSD license. See the LICENSE file for details.