Hexapawn

Hexapawn is a deterministic two-player game invented by Martin Gardner. It is played on a rectangular board of variable size, for example on a 3×3 board or on a chessboard. On a board of size n×m, each player begins with m pawns, one for each square in the row closest to them. The goal of each player is to advance one of their pawns to the opposite end of the board or to prevent the other player from moving.

A 3×3 hexapawn board

Hexapawn on the 3×3 board is a solved game; with perfect play, white will always lose in 3 moves: (1.b2 axb2 2.cxb2 c2 3.a2 c1#). Indeed, Gardner specifically constructed it as a game with a small game tree, in order to demonstrate how it could be played by a heuristic AI implemented by a mechanical computer based on Donald Michie's Matchbox Educable Noughts and Crosses Engine.

A variant of this game is octopawn, which is played on a 4×4 board with 4 pawns on each side. In octopawn, if both players play well, the second player to move will always lose.

Rules

As in chess, each pawn may be moved in two different ways: it may be moved one square forward, or it may capture a pawn one square diagonally ahead of it. A pawn may not be moved forward if there is a pawn in the next square. Unlike chess, the first move of a pawn may not advance it by two spaces. A player loses if he/she has no legal moves or the other player reaches the end of the board with a pawn.

Dawson's chess

Whenever a player advances a pawn to the penultimate rank (unless it is an isolated pawn) there is a threat to proceed to the final rank by capture. The opponent's only sensible responses are therefore either to capture the advanced pawn or to advance the threatened one, the latter only being sensible in the case that there is one threatened pawn rather than two. If one restricts 3×N hexapawn with the additional rule that the capture is always compulsory, the result is the game Dawson's chess.

Dawson's chess reduces to the impartial game denoted .137 in Conway's notation. This means that it is equivalent to a Nim-like game in which:

  • on a turn, the player may remove one to three objects from a heap,
  • removing just one object is a legal move only if the removed object is the only object in the heap, and
  • when removing three objects from a heap of five or more, the player may also split the remainder into two heaps.

The initial position is a single heap of size N. The nim-sequence for this game is

0.1120311033224052233011302110452740
  1120311033224455233011302110453748
  1120311033224455933011302110453748
  1120311033224455933011302110453748
  1120311033224455933011302110453748 ...,

where bold entries indicate the values that differ from the eventual periodic behavior of the sequence.

gollark: NOOOOOOOOOOOOOOOOOOOO!
gollark: What if we define `n` to only work on functions which do not call `n`, to be annoying?
gollark: Note: `Control.HaltingOracle` does not actually exist yet.
gollark: ```haskellimport Control.HaltingOraclemain :: IO ()main = program <- getLine print (willHalt program)```
gollark: It's like a t__y__pe*c*las**s**.

References

  • Mathematical Games, Scientific American, March 1962, reprinted in The Unexpected Hanging and Other Mathematical Diversions, by Martin Gardner, pp. 93ff
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.