rapid-draughts
v1.0.2
Published
A super speedy, blazing fast, rocket-powered TypeScript draughts/checkers engine with move validation, AI and game history.
Downloads
132
Maintainers
Readme
rapid-draughts ⚡
A super speedy, blazing fast, rocket-powered TypeScript draughts/checkers engine with move validation, AI and game history.
It uses bitboards, a board representation that holds the draughts board in three 32 or 64 bit unsigned integers. One for the light pieces, dark pieces and the king pieces. Bitboards enable fast move generation and have minimal memory usage.
The english draughts / american checkers engine follows the WCDF ruleset.
Installing
Run the following command inside your node project:
npm install rapid-draughts
How To Use
import { DraughtsPlayer, DraughtsStatus } from 'rapid-draughts';
import {
EnglishDraughts as Draughts,
EnglishDraughtsComputerFactory as ComputerFactory,
} from 'rapid-draughts/english';
// Initialise the game
const draughts = Draughts.setup();
// Show the available moves and play one.
console.table(draughts.moves);
draughts.move(draughts.moves[0]);
// Initialise two computer players
const weakComputer = ComputerFactory.random();
const strongComputer = ComputerFactory.alphaBeta({
maxDepth: 7,
});
// Play with the AIs until there is a winner
while (draughts.status === DraughtsStatus.PLAYING) {
console.log(`${draughts.asciiBoard()}`);
console.log(`to_move = ${draughts.player}`);
const computerPlayer =
draughts.player === DraughtsPlayer.LIGHT ? weakComputer : strongComputer;
const move = await computerPlayer(draughts);
if (move) draughts.move(move);
}
// Announce the winner
console.log(`${draughts.asciiBoard()}`);
console.log(`status = ${draughts.status}`);
console.log(`ended after ${draughts.history.moves.length} moves`);
Online Demo
rapid-draughts powers the draughts game site draughts.org. Check it out!