NAME

Game::Theory::TwoPersonMatrix - Analyze a 2 person matrix game

VERSION

version 0.1502

SYNOPSIS

use Game::Theory::TwoPersonMatrix;
$g = Game::Theory::TwoPersonMatrix->new(
   1 => { 1 => 0.2, 2 => 0.3, 3 => 0.5 },
   2 => { 1 => 0.1, 2 => 0.7, 3 => 0.2 },
   payoff => [ [-5, 4, 6],
               [ 3,-2, 2],
               [ 2,-3, 1] ]
};
$g->row_reduce();
$g->col_reduce();
$p = $g->saddlepoint();
$o = $g->oddments();
$e = $g->expected_payoff();
$c = $g->counter_strategy($player);

$g = Game::Theory::TwoPersonMatrix->new(
   1 => { 1 => 0.1, 2 => 0.2, 3 => 0.7 },
   2 => { 1 => 0.1, 2 => 0.2, 3 => 0.3, 4 => 0.4 },
   payoff1 => [ [5,3,8,2],[6,5,7,1],[7,4,6,0] ],
   payoff2 => [ [2,0,1,3],[3,4,4,1],[5,6,8,2] ],
);
$t = $g->mm_tally();
$m = $g->pareto_optimal();
$n = $g->nash();
$e = $g->expected_payoff();

DESCRIPTION

A Game::Theory::TwoPersonMatrix analyzes a two person matrix game of player names, strategies and utilities ("payoffs").

The players must have the same number of strategies, and each strategy must have the same size utility vectors as all the others.

Players 1 and 2 are the "row" and "column" players, respectively. This is due to the tabular format of a matrix game:

                 Player 2
                 --------
        Strategy 0.5  0.5
Player |   0.5    1   -1  < Payoff
   1   |   0.5   -1    1  <

A non-zero sum game is represented by two payoff profiles, as above in the SYNOPSIS.

METHODS

new()

$g = Game::Theory::TwoPersonMatrix->new(
   1 => { 1 => '0.5', 2 => '0.5' },
   2 => { 1 => '0.5', 2 => '0.5' },
   payoff => [ [1,0],
               [0,1] ]
);
$g = Game::Theory::TwoPersonMatrix->new(
   payoff1 => [ [2,3],[2,1] ],
   payoff2 => [ [3,5],[2,3] ],
);

Create a new Game::Theory::TwoPersonMatrix object.

expected_payoff()

$e = $g->expected_payoff();

Return the expected payoff value of the game.

s_expected_payoff()

$g = Game::Theory::TwoPersonMatrix->new(
   1 => { 1 => '(1 - p)', 2 => 'p' },
   2 => { 1 => 1, 2 => 0 },
   payoff => [ ['a','b'], ['c','d'] ]
);
$s = $g->s_expected_payoff();

Return the expected payoff expression for a non-numeric game.

Using real payoff values, we solve the resulting expression for p in the eg/ examples.

counter_strategy()

$c = $g->counter_strategy($player);

Return the counter-strategies for a given player.

saddlepoint()

$p = $g->saddlepoint;

If the game is strictly determined, the saddlepoint is returned. Otherwise undef is returned.

oddments()

$o = $g->oddments();

Return each player's "oddments" for a 2x2 game.

row_reduce()

$g->row_reduce();

Reduce a game by identifying and eliminating strictly dominated rows and their associated player strategies.

col_reduce()

$g->col_reduce();

Reduce a game by identifying and eliminating strictly dominated columns and their associated opponent strategies.

mm_tally()

$t = $g->mm_tally();

For zero-sum games, return the maximum of row minimums and the minimum of column maximums. For non-zero-sum games, return the maximum of row and column minimums.

pareto_optimal()

$m = $g->pareto_optimal();

Return the Pareto optimal outcomes.

nash()

$n = $g->nash();

Identify the Nash equilibria.

Given payoff pair (a, b) a is maximum for its column and b is maximum for its row.

SEE ALSO

The eg/ and t/ scripts in this distribution.

"A Gentle Introduction to Game Theory"

http://www.amazon.com/Gentle-Introduction-Theory-Mathematical-World/dp/0821813390

http://books.google.com/books?id=8doVBAAAQBAJ

AUTHOR

Gene Boggs <gene@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Gene Boggs.

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