NAME

Games::Chess::Coverage - Expose the potential energy states of a chess game

SYNOPSIS

use Games::Chess::Coverage;

$g = Games::Chess::Coverage->new;
$g = Games::Chess::Coverage->new( fen => $fen_string );
$g = Games::Chess::Coverage->new( game => $games_chess_object );

$pieces = $g->pieces;
$states = $g->states;

DESCRIPTION

A Games::Chess::Coverage object represents a chess game in terms of move and capture states by location.

A piece's coverage extends within its limit of mobility or until a collision occurs with another piece.

In my mind this module:

  • Is a chess analysis laboratory

  • Measures potential energy

  • Represents tension as a landscape

  • Shows footprint interference patterns (trends?)

  • Delineates power stuggle

  • Looks cool when visualized :-)

Note: This is not a chess playing module. It simply returns the state of a chess board. If you want to know what the coverage might be in say five ply, you must generate the FEN (or Games::Chess object) first. Please see "TO DO" for more details.

PUBLIC METHODS

CONSTRUCTOR

  • new

    $g = Games::Chess::Coverage->new( %attributes );

    Create a new Games::Chess::Coverage object based on the following optional attributes provided to the constructor as named parameters:

    Key      Default
    ________________
    verbose => 0
    game => new Games::Chess::Position
    fen => rnbqkbnr/pppppppp/8/8/8/8/PPPPPPPP/RNBQKBNR w KQkq - 0 1

    That is, calling the constructor with no arguments creates a new Games::Chess object with the traditional starting board position.

ACCESSORS

  • pieces

    $pieces = $g->pieces;

    This method returns a hash reference of the game coverage object's Games::Chess::Piece's keyed by their location.

  • states

    $states = $g->states;

    This method returns a hash reference of board location states.

CONVENIENCE METHODS

  • warp_spacetime

    $g->warp_spacetime( $manifold );

    Warp local space-time.

EXAMPLES

Coming soon to a theatre near you...

Until then, take a look at the eg directory in this distribution.

TO DO

Represent pawn promotion.

Make this tiny and fast with bit vector matrix calculations.

Use Chess::PGN::Filter and build a list of coverages for entire games in PGN.

Output ChessGML.

SEE ALSO

Games::Chess

This is a great site:

http://www.chessclub.demon.co.uk/tutorial/beginner/intro/intro.htm

Of course there is also

http://mathworld.wolfram.com/Chess.html

This is a related (possibly mathematically equivalent) concept:

http://www.users.globalnet.co.uk/~perry/maths/chessgraph/chessgraph.htm

Here is a chess glossary with many analysis terms:

http://www.jeremysilman.com/chess_glossary/glossary_chess_terms_a.html

What document on visualization would be complete without references to Edward R. Tufte?

http://www.edwardtufte.com/bboard/q-and-a-fetch-msg?msg_id=00013l&topic_id=1&topic=Ask%20E%2eT%2e and http://www.edwardtufte.com/bboard/q-and-a-fetch-msg?msg_id=0000Mn&topic_id=1&topic=Ask%20E%2eT%2e

And what chess module about analysis would be complete without a reference to the Canon of educational chess games?

http://www.ex.ac.uk/~dregis/DR/Canon/canonidx.html

DEDICATION

My chess playing Brother, Aaron. Hi Aaron. :-)

AUTHOR

Gene Boggs <gene@cpan.org>

COPYRIGHT AND LICENSE

Copyright 2004, Gene Boggs

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.