Library to play with a rusty "Goban" (name of the board where we play Go !)
Use the version > 0.5.0 because in a bug detecting dead stones and in Ko detection
Channel : stable
Only contains move generation, and rules there is no IA, neither front-end.
Features:
Thanks to some help in profiling and optimisation we can run a playout randomly of an entire game in 3 ms (i7u 3.0 Ghz) (before it was 600ms ) !
The most important struct is Game who has all you need to create and manages go games.
``` use crate::goban::rules::; use crate::goban::rules::game::; use rand::seq::IteratorRandom; use goban::rules::game_builder::GameBuilder;
let mut g = Game::builder() .size((19,19)) .rule(CHINESE) // .komi(7.5) Komi is hardcoded for each rule, but can be override like this. .build().unwrap();
let mut i = 35; while !g.isover() && i != 0 { g.play( // legals return an iterator of (x,y) points (lazy) g.legals() .choose(&mut rand::threadrng()) .map(|point| Move::Play(point.0,point.1)) .unwrap()); i -= 1; g.displaygoban(); // None if the game is not finished println!("{:?}", g.outcome()); // Inner array using row policy println!("{:?}", g.goban().tovec());
}
{ let mut iterhistory = g.history().iter(); println!("{:?}", iterhistory.next().unwrap()); println!("{:?}", iterhistory.nextback().unwrap()) }
```
```{bash} ┏┯┯┯┯┯┯┯┓ ┠┼┼┼┼┼┼┼┨ ┠┼┼┼┼┼┼┼┨ ┠┼┼┼┼┼┼┼┨ ┠┼┼┼┼┼┼┼┨ ┠┼┼┼┼┼┼┼┨ ┠┼┼┼┼┼┼┼┨ ○┼┼┼┼┼┼┼┨ ┗┷┷┷┷┷┷┷┛
etc... ```