2010-08-28 22:05:41 -04:00
|
|
|
<?php
|
|
|
|
namespace Moserware\Skills\Elo;
|
|
|
|
|
2010-09-18 21:19:51 -04:00
|
|
|
require_once(dirname(__FILE__) . "/../GameInfo.php");
|
|
|
|
require_once(dirname(__FILE__) . "/../Numerics/GaussianDistribution.php");
|
|
|
|
require_once(dirname(__FILE__) . "/KFactor.php");
|
|
|
|
require_once(dirname(__FILE__) . "/TwoPlayerEloCalculator.php");
|
|
|
|
|
|
|
|
use Moserware\Skills\GameInfo;
|
|
|
|
use Moserware\Numerics\GaussianDistribution;
|
|
|
|
|
2010-08-28 22:05:41 -04:00
|
|
|
class GaussianEloCalculator extends TwoPlayerEloCalculator
|
|
|
|
{
|
|
|
|
// From the paper
|
|
|
|
const STABLE_KFACTOR = 24;
|
|
|
|
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct(new KFactor(self::STABLE_KFACTOR));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPlayerWinProbability(GameInfo $gameInfo, $playerRating, $opponentRating)
|
|
|
|
{
|
|
|
|
$ratingDifference = $playerRating - $opponentRating;
|
|
|
|
|
|
|
|
// See equation 1.1 in the TrueSkill paper
|
|
|
|
return GaussianDistribution::cumulativeTo(
|
|
|
|
$ratingDifference
|
|
|
|
/
|
|
|
|
(sqrt(2) * $gameInfo->getBeta()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|