Either furl up a row of your pieces, or unfurl a stack. If you have a piece in your end row at the start of your turn, you win.
Generated at 10/05/2020, 22:34 from 1249 logged games.
Start Position
Each turn, choose one of two types of moves:
You win if you have a piece or stack on the row farthest from you at the start of your turn.
You lose if you have no legal moves.
General comments:
Play: Combinatorial
BGG Entry | Furl (HexHex 4) |
---|---|
BGG Rating | null |
#Voters | null |
SD | null |
BGG Weight | null |
#Voters | null |
Year | null |
Size (bytes) | 25791 |
---|---|
Reference Size | 10293 |
Ratio | 2.51 |
Ai Ai calculates the size of the implementation, and compares it to the Ai Ai implementation of the simplest possible game (which just fills the board). Note that this estimate may include some graphics and heuristics code as well as the game logic. See the wikipedia entry for more details.
Playouts per second | 16960.62 (58.96µs/playout) |
---|---|
Reference Size | 1104484.21 (0.91µs/playout) |
Ratio (low is good) | 65.12 |
Tavener complexity: the heat generated by playing every possible instance of a game with a perfectly efficient programme. Since this is not possible to calculate, Ai Ai calculates the number of random playouts per second and compares it to the fastest non-trivial Ai Ai game (Connect 4). This ratio gives a practical indication of how complex the game is. Combine this with the computational state space, and you can get an idea of how strong the default (MCTS-based) AI will be.
Label | Its/s | SD | Nodes/s | SD | Game length | SD |
---|---|---|---|---|---|---|
Random playout | 19,098 | 198 | 1,081,437 | 10,845 | 57 | 33 |
search.UCB | 57,808 | 118,275 | 12 | 8 | ||
search.UCT | 26,866 | 26,299 | 26 | 14 | ||
search.Minimax | 738,324 | 102,840 | 30 | 12 | ||
search.AlphaBeta | 136,447 | 62,146 | 35 | 16 |
Random: 10 second warmup for the hotspot compiler. 100 trials of 1000ms each.
Other: 100 playouts, means calculated over the first 5 moves only to avoid distortion due to speedup at end of game.
Rotation (Half turn) lost each game as expected.
Reflection (X axis) lost each game as expected.
Reflection (Y axis) lost each game as expected.
Copy last move lost each game as expected.
Mirroring strategies attempt to copy the previous move. On first move, they will attempt to play in the centre. If neither of these are possible, they will pick a random move. Each entry represents a different form of copying; direct copy, reflection in either the X or Y axis, half-turn rotation.
1: White win % | 54.68±2.77 | Includes draws = 50% |
---|---|---|
2: Black win % | 45.32±2.74 | Includes draws = 50% |
Draw % | 0.00 | Percentage of games where all players draw. |
Decisive % | 100.00 | Percentage of games with a single winner. |
Samples | 1249 | Quantity of logged games played |
Note: that win/loss statistics may vary depending on thinking time (horizon effect, etc.), bad heuristics, bugs, and other factors, so should be taken with a pinch of salt. (Given perfect play, any game of pure skill will always end in the same result.)
Note: Ai Ai differentiates between states where all players draw or win or lose; this is mostly to support cooperative games.
AI | Strong Wins | Draws | Strong Losses | #Games | Strong Win% | p1 Win% | Game Length |
---|---|---|---|---|---|---|---|
Random | |||||||
Rαβ + ocqBKs (t=0.01s) | 36 | 0 | 0 | 36 | 100.00 | 55.56 | 15.17 |
Rαβ + ocqBKs (t=0.07s) | 36 | 0 | 0 | 36 | 100.00 | 27.78 | 15.00 |
Rαβ + ocqBKs (t=0.55s) | 36 | 0 | 13 | 49 | 73.47 | 55.10 | 33.92 |
Level of Play: Strong beats Weak 60% of the time (lower bound with 90% confidence).
Draw%, p1 win% and game length may give some indication of trends as AI strength increases; but be aware that the AI can introduce bias due to horizon effects, poor heuristics, etc.
Game length | 30.17 | |
---|---|---|
Branching factor | 31.95 | |
Complexity | 10^37.06 | Based on game length and branching factor |
Computational Complexity | 10^6.42 | Sample quality (100 best): 3.30 |
Samples | 1249 | Quantity of logged games played |
Computational complexity (where present) is an estimate of the game tree reachable through actual play. For each game in turn, Ai Ai marks the positions reached in a hashtable, then counts the number of new moves added to the table. Once all moves are applied, it treats this sequence as a geometric progression and calculates the sum as n-> infinity.
Distinct actions | 758 | Number of distinct moves (e.g. "e4") regardless of position in game tree |
---|---|---|
Killer moves | 26 | A 'killer' move is selected by the AI more than 50% of the time Too many killers to list. |
Good moves | 390 | A good move is selected by the AI more than the average |
Bad moves | 367 | A bad move is selected by the AI less than the average |
Terrible moves | 105 | A terrible move is never selected by the AI Too many terrible moves to list. |
Samples | 1249 | Quantity of logged games played |
A mean of 71.95% of board locations were used per game.
Colour shows the frequency of visits.
This chart is based on a single playout, and gives a feel for the change in material over the course of a game.
Table: branching factor per turn.
This chart is based on a single playout, and gives a feel for the types of moves available over the course of a game.
Red: removal, Black: move, Blue: Add, Grey: pass, Purple: swap sides, Brown: other.
This chart shows the best move value with respect to the active player; the orange line represents the value of doing nothing (null move).
The lead changed on 2% of the game turns. Ai Ai found 3 critical turns (turns with only one good option).
This chart shows the relative temperature of all moves each turn. Colour range: black (worst), red, orange(even), yellow, white(best).
Measure | All players | Player 1 | Player 2 |
---|---|---|---|
Mean % of effective moves | 72.35 | 63.53 | 81.54 |
Mean no. of effective moves | 18.78 | 15.72 | 21.96 |
Effective game space | 10^-∞ | 10^26.90 | 10^-∞ |
Mean % of good moves | 38.14 | 54.32 | 21.29 |
Mean no. of good moves | 8.18 | 13.20 | 2.96 |
Good move game space | 10^32.48 | 10^24.40 | 10^8.08 |
These figures were calculated over a single game.
An effective move is one with score 0.1 of the best move (including the best move). -1 (loss) <= score <= 1 (win)
A good move has a score > 0. Note that when there are no good moves, an multiplier of 1 is used for the game space calculation.
Measure | Value | Description |
---|---|---|
Hot turns | 67.35% | A hot turn is one where making a move is better than doing nothing. |
Momentum | 16.33% | % of turns where a player improved their score. |
Correction | 34.69% | % of turns where the score headed back towards equality. |
Depth | 4.83% | Difference in evaluation between a short and long search. |
Drama | 4.90% | How much the winner was behind before their final victory. |
Foulup Factor | 83.67% | Moves that looked better than the best move after a short search. |
Surprising turns | 6.12% | Turns that looked bad after a short search, but good after a long one. |
Last lead change | 77.55% | Distance through game when the lead changed for the last time. |
Decisiveness | 20.41% | Distance from the result being known to the end of the game. |
These figures were calculated over a single game, and based on the measures of quality described in "Automatic Generation and Evaluation of Recombination Games" (Cameron Browne, 2007).
Moves | Animation |
---|---|
Furl d1:b3,Furl a7:a5,Furl g1:g3,Furl e6:e5,Furl d2:c3,Unfurl e5:g3,Unfurl c3:a5,Furl c7:c5,Furl b4:a5,Unfurl c5:c2 | |
Furl d1:b3,Furl a7:a5,Furl g1:g3,Furl d7:f5,Furl f2:f3,Furl b6:b5,Unfurl f3:f5,Unfurl b5:b3,Furl e2:e3,Furl b4:b3 | |
Furl d1:b3,Furl d7:f5,Furl g1:g3,Furl a7:a5,Furl f2:f3,Furl b6:b5,Unfurl f3:f5,Unfurl b5:b3,Furl e2:e3,Furl b4:b3 | |
Furl c2:c3,Furl c5:d5,Unfurl c3:a5,Furl d6:b6,Furl f3:g3,Unfurl b6:e3,Furl d2:d3,Unfurl d5:f3,Furl f1:d1,Furl c5:d4 | |
Furl c2:c3,Furl e6:e5,Furl g1:d1,Unfurl e5:e3,Furl d2:d3,Furl b6:d6,Unfurl d3:b5,Unfurl d6:g3,Furl c4:b5,Furl c7:d7 | |
Furl g2:f3,Furl d5:c5,Unfurl f3:f5,Furl b6:d6,Furl c3:b3,Unfurl d6:d3,Furl f2:e3,Unfurl c5:c3,Furl e1:g1,Furl d5:d4 | |
Furl g1:g3,Furl a7:a5,Furl d1:b3,Furl e6:e5,Furl d2:c3,Unfurl e5:g3,Unfurl c3:a5,Furl c7:c5,Furl b4:a5,Unfurl c5:c2 | |
Furl g1:g3,Furl a7:a5,Furl d1:b3,Furl d7:f5,Furl f2:f3,Furl b6:b5,Unfurl f3:f5,Unfurl b5:b3,Furl e2:e3,Furl b4:b3 | |
Furl g1:g3,Furl e6:e5,Furl d1:b3,Furl a7:a5,Furl d2:c3,Unfurl e5:g3,Unfurl c3:a5,Furl c7:c5,Furl b4:a5,Unfurl c5:c2 | |
Furl g1:g3,Furl d7:f5,Furl d1:b3,Furl a7:a5,Furl f2:f3,Furl b6:b5,Unfurl f3:f5,Unfurl b5:b3,Furl e2:e3,Furl b4:b3 | |
Furl g1:g3,Furl d7:f5,Furl f2:f3,Furl a7:a5,Furl d1:b3,Furl b6:b5,Unfurl f3:f5,Unfurl b5:b3,Furl e2:e3,Furl b4:b3 | |
Furl c2:c3,Furl c5:d5,Unfurl c3:a5,Furl e6:e5,Furl b4:b3,Unfurl d5:d3,Unfurl b3:b5,Furl a6:a7,Furl a5:b4,Furl b6:b7 |
Colour shows the success ratio of this play over the first 10moves; black < red < yellow < white.
Size shows the frequency this move is played.
0 | 1 | 2 | 3 |
---|---|---|---|
1 | 114 | 13110 | 461124 |
Note: most games do not take board rotation and reflection into consideration.
Multi-part turns could be treated as the same or different depth depending on the implementation.
Counts to depth N include all moves reachable at lower depths.
Inaccuracies may also exist due to hash collisions, but Ai Ai uses 64-bit hashes so these will be a very small fraction of a percentage point.
No solutions found to depth 3.
Puzzle | Solution |
---|---|
White to win in 18 moves | |
White to win in 12 moves | |
Black to win in 8 moves | |
Black to win in 6 moves | |
Black to win in 6 moves | |
White to win in 2 moves | |
White to win in 2 moves | |
White to win in 2 moves | |
White to win in 2 moves | |
White to win in 2 moves | |
Black to win in 4 moves | |
White to win in 6 moves |
Selection criteria: first move must be unique, and not forced to avoid losing. Beyond that, Puzzles will be rated by the product of [total move]/[best moves] at each step, and the best puzzles selected.