Skip to content

A Rust simulation of the World's Worst Boardgame (W.W.B)

License

Notifications You must be signed in to change notification settings

RosstheRoss/wwb

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

W.W.B

A Rust simulation of the World's Worst Boardgame (W.W.B.) by Rich Hutnik.

Disclaimer

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.

What is W.W.B.?

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:

  1. Player rolls d6
  2. If not 5, next player's turn
  3. If 5, advance one space
  4. If players are on the same space that is NOT Start, move BOTH back to Start
  5. If there was no collision, roll d6 again
  6. If not 5, go back to Start
  7. If 5 again, nothing happens
  8. Next player's turn

Why?

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.

My current record

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.

Exact info

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.

Usage

Building

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

Running

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.

Using the contrib file

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.

License

This project is licensed under the 0BSD license. See the LICENSE file for details.

About

A Rust simulation of the World's Worst Boardgame (W.W.B)

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project