2016-03-19 22:14:29 +01:00
|
|
|
# Simulations of Hanabi strategies
|
|
|
|
|
2016-03-30 07:24:29 +02:00
|
|
|
Hanabi is a cooperative card game of incomplete information.
|
|
|
|
Despite relatively [simple rules](https://boardgamegeek.com/article/10670613#10670613),
|
|
|
|
the space of Hanabi strategies is quite interesting.
|
2016-04-02 23:29:46 +02:00
|
|
|
This project provides a framework for implementing Hanabi strategies in Rust.
|
2016-03-30 07:24:29 +02:00
|
|
|
It also explores some implementations, based on ideas from
|
|
|
|
[this paper](https://d0474d97-a-62cb3a1a-s-sites.googlegroups.com/site/rmgpgrwc/research-papers/Hanabi_final.pdf).
|
2016-04-02 23:29:46 +02:00
|
|
|
In particular, it contains an improved version of their "information strategy",
|
|
|
|
which achieves the best results I'm aware of for games with more than 2 players ([see below](#results)).
|
2016-03-19 22:14:29 +01:00
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
Please feel free to contact me about Hanabi strategies, or this framework.
|
2016-03-19 22:14:29 +01:00
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
Most similar projects I am aware of:
|
2016-03-19 22:14:29 +01:00
|
|
|
- https://github.com/rjtobin/HanSim (written for the paper mentioned above)
|
|
|
|
- https://github.com/Quuxplusone/Hanabi
|
|
|
|
|
|
|
|
## Setup
|
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
Install rust (rustc and cargo), and clone this git repo.
|
2016-03-19 22:14:29 +01:00
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
Then, in the repo root, run `cargo run -- -h` to see usage details.
|
2016-03-19 22:14:29 +01:00
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
For example, to simulate a 5 player game using the cheating strategy, for seeds 0-99:
|
2016-03-19 22:14:29 +01:00
|
|
|
```
|
2016-04-02 23:29:46 +02:00
|
|
|
cargo run -- -n 100 -s 0 -p 5 -g cheat
|
2016-03-19 22:14:29 +01:00
|
|
|
```
|
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
Or, if the simulation is slow, build with `--release` and use more threads:
|
2016-03-31 19:17:22 +02:00
|
|
|
```
|
2016-04-01 11:08:46 +02:00
|
|
|
time cargo run --release -- -n 10000 -o 1000 -s 0 -t 4 -p 5 -g info
|
|
|
|
```
|
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
Or, to see a transcript of the game with seed 222:
|
2016-04-01 11:08:46 +02:00
|
|
|
```
|
2016-04-02 23:29:46 +02:00
|
|
|
cargo run -- -s 222 -p 5 -g info -l debug | less
|
2016-03-31 19:17:22 +02:00
|
|
|
```
|
2016-03-19 22:14:29 +01:00
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
## Strategies
|
|
|
|
|
2016-04-04 09:26:42 +02:00
|
|
|
To write a strategy, you simply [implement a few traits](src/strategy.rs).
|
2016-04-02 23:29:46 +02:00
|
|
|
|
|
|
|
The framework is designed to take advantage of Rust's ownership system
|
|
|
|
so that you *can't cheat*, without using stuff like `Cell` or `Arc` or `Mutex`.
|
|
|
|
|
|
|
|
Generally, your strategy will be passed something of type `&BorrowedGameView`.
|
|
|
|
This game view contains many useful helper functions ([see here](src/game.rs)).
|
|
|
|
If you want to mutate a view, you'll want to do something like
|
|
|
|
`let mut self.view = OwnedGameView::clone_from(borrowed_view);`.
|
|
|
|
An OwnedGameView will have the same API as a borrowed one.
|
|
|
|
|
|
|
|
Some examples:
|
|
|
|
|
|
|
|
- [Basic dummy examples](src/strategies/examples.rs)
|
|
|
|
- [A cheating strategy](src/strategies/cheating.rs), using `Rc<RefCell<_>>`
|
|
|
|
- [The information strategy](src/strategies/information.rs)!
|
|
|
|
|
2016-03-31 09:02:09 +02:00
|
|
|
## Results
|
2016-03-19 22:14:29 +01:00
|
|
|
|
2016-04-02 23:29:46 +02:00
|
|
|
On seeds 0-9999, we have these average scores and win rates:
|
2016-04-01 11:08:46 +02:00
|
|
|
|
2018-03-24 03:29:59 +01:00
|
|
|
| | 2p | 3p | 4p | 5p |
|
|
|
|
|-------|---------|---------|---------|---------|
|
|
|
|
|cheat | 24.8600 | 24.9781 | 24.9715 | 24.9570 |
|
|
|
|
| | 90.52 % | 98.12 % | 97.74 % | 96.57 % |
|
2019-02-26 14:50:49 +01:00
|
|
|
|info | 21.9455 | 24.7136 | 24.8868 | 24.8976 |
|
|
|
|
| | 07.01 % | 79.46 % | 91.26 % | 91.91 % |
|
2016-03-19 22:14:29 +01:00
|
|
|
|
|
|
|
|
2016-04-01 09:14:13 +02:00
|
|
|
To reproduce:
|
|
|
|
```
|
2016-04-01 11:08:46 +02:00
|
|
|
n=10000 # number of rounds to simulate
|
|
|
|
t=4 # number of threads
|
2016-04-01 09:14:13 +02:00
|
|
|
for strategy in info cheat; do
|
|
|
|
for p in $(seq 2 5); do
|
2016-04-01 11:08:46 +02:00
|
|
|
time cargo run --release -- -n $n -s 0 -t $t -p $p -g $strategy;
|
2016-04-01 09:14:13 +02:00
|
|
|
done
|
|
|
|
done
|
|
|
|
```
|