mirror of
https://github.com/furyfire/trueskill.git
synced 2025-01-16 01:47:39 +00:00
All of testAllMultipleTeamScenarios passes!
This commit is contained in:
@ -50,13 +50,13 @@ class TrueSkillCalculatorTests
|
||||
public static function testAllMultipleTeamScenarios($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
self::threeTeamsOfOneNotDrawn($testClass, $calculator);
|
||||
//self::threeTeamsOfOneDrawn(calculator);
|
||||
//self::fourTeamsOfOneNotDrawn(calculator);
|
||||
//self::fiveTeamsOfOneNotDrawn(calculator);
|
||||
//self::eightTeamsOfOneDrawn(calculator);
|
||||
//self::eightTeamsOfOneUpset(calculator);
|
||||
//self::sixteenTeamsOfOneNotDrawn(calculator);
|
||||
//self::twoOnFourOnTwoWinDraw(calculator);
|
||||
self::threeTeamsOfOneDrawn($testClass, $calculator);
|
||||
self::fourTeamsOfOneNotDrawn($testClass, $calculator);
|
||||
self::fiveTeamsOfOneNotDrawn($testClass, $calculator);
|
||||
self::eightTeamsOfOneDrawn($testClass, $calculator);
|
||||
self::eightTeamsOfOneUpset($testClass, $calculator);
|
||||
self::sixteenTeamsOfOneNotDrawn($testClass, $calculator);
|
||||
self::twoOnFourOnTwoWinDraw($testClass, $calculator);
|
||||
}
|
||||
|
||||
//------------------- Actual Tests ---------------------------
|
||||
@ -608,6 +608,346 @@ class TrueSkillCalculatorTests
|
||||
self::assertMatchQuality($testClass, 0.200, $calculator->calculateMatchQuality($gameInfo, $teams));
|
||||
}
|
||||
|
||||
private static function threeTeamsOfOneDrawn($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
$player1 = new Player(1);
|
||||
$player2 = new Player(2);
|
||||
$player3 = new Player(3);
|
||||
|
||||
$gameInfo = new GameInfo();
|
||||
|
||||
$team1 = new Team($player1, $gameInfo->getDefaultRating());
|
||||
$team2 = new Team($player2, $gameInfo->getDefaultRating());
|
||||
$team3 = new Team($player3, $gameInfo->getDefaultRating());
|
||||
|
||||
$teams = Teams::concat($team1, $team2, $team3);
|
||||
$newRatings = $calculator->calculateNewRatings($gameInfo, $teams, array(1, 1, 1));
|
||||
|
||||
$player1NewRating = $newRatings->getRating($player1);
|
||||
self::assertRating($testClass, 25.000, 5.698, $player1NewRating);
|
||||
|
||||
$player2NewRating = $newRatings->getRating($player2);
|
||||
self::assertRating($testClass, 25.000, 5.695, $player2NewRating);
|
||||
|
||||
$player3NewRating = $newRatings->getRating($player3);
|
||||
self::assertRating($testClass, 25.000, 5.698, $player3NewRating);
|
||||
|
||||
self::assertMatchQuality($testClass, 0.200, $calculator->calculateMatchQuality($gameInfo, $teams));
|
||||
}
|
||||
|
||||
private static function fourTeamsOfOneNotDrawn($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
$player1 = new Player(1);
|
||||
$player2 = new Player(2);
|
||||
$player3 = new Player(3);
|
||||
$player4 = new Player(4);
|
||||
$gameInfo = new GameInfo();
|
||||
|
||||
$team1 = new Team($player1, $gameInfo->getDefaultRating());
|
||||
$team2 = new Team($player2, $gameInfo->getDefaultRating());
|
||||
$team3 = new Team($player3, $gameInfo->getDefaultRating());
|
||||
$team4 = new Team($player4, $gameInfo->getDefaultRating());
|
||||
|
||||
$teams = Teams::concat($team1, $team2, $team3, $team4);
|
||||
|
||||
$newRatings = $calculator->calculateNewRatings($gameInfo, $teams, array(1, 2, 3, 4));
|
||||
|
||||
$player1NewRating = $newRatings->getRating($player1);
|
||||
self::assertRating($testClass, 33.206680965631264, 6.3481091698077057, $player1NewRating);
|
||||
|
||||
$player2NewRating = $newRatings->getRating($player2);
|
||||
self::assertRating($testClass, 27.401454693843323, 5.7871629348447584, $player2NewRating);
|
||||
|
||||
$player3NewRating = $newRatings->getRating($player3);
|
||||
self::assertRating($testClass, 22.598545306188374, 5.7871629348413451, $player3NewRating);
|
||||
|
||||
$player4NewRating = $newRatings->getRating($player4);
|
||||
self::assertRating($testClass, 16.793319034361271, 6.3481091698144967, $player4NewRating);
|
||||
|
||||
self::assertMatchQuality($testClass, 0.089, $calculator->calculateMatchQuality($gameInfo, $teams));
|
||||
}
|
||||
|
||||
private static function fiveTeamsOfOneNotDrawn($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
$player1 = new Player(1);
|
||||
$player2 = new Player(2);
|
||||
$player3 = new Player(3);
|
||||
$player4 = new Player(4);
|
||||
$player5 = new Player(5);
|
||||
$gameInfo = new GameInfo();
|
||||
|
||||
$team1 = new Team($player1, $gameInfo->getDefaultRating());
|
||||
$team2 = new Team($player2, $gameInfo->getDefaultRating());
|
||||
$team3 = new Team($player3, $gameInfo->getDefaultRating());
|
||||
$team4 = new Team($player4, $gameInfo->getDefaultRating());
|
||||
$team5 = new Team($player5, $gameInfo->getDefaultRating());
|
||||
|
||||
$teams = Teams::concat($team1, $team2, $team3, $team4, $team5);
|
||||
$newRatings = $calculator->calculateNewRatings($gameInfo, $teams, array(1, 2, 3, 4, 5));
|
||||
|
||||
$player1NewRating = $newRatings->getRating($player1);
|
||||
self::assertRating($testClass, 34.363135705841188, 6.1361528798112692, $player1NewRating);
|
||||
|
||||
$player2NewRating = $newRatings->getRating($player2);
|
||||
self::assertRating($testClass, 29.058448805636779, 5.5358352402833413, $player2NewRating);
|
||||
|
||||
$player3NewRating = $newRatings->getRating($player3);
|
||||
self::assertRating($testClass, 25.000000000031758, 5.4200805474429847, $player3NewRating);
|
||||
|
||||
$player4NewRating = $newRatings->getRating($player4);
|
||||
self::assertRating($testClass, 20.941551194426314, 5.5358352402709672, $player4NewRating);
|
||||
|
||||
$player5NewRating = $newRatings->getRating($player5);
|
||||
self::assertRating($testClass, 15.636864294158848, 6.136152879829349, $player5NewRating);
|
||||
|
||||
self::assertMatchQuality($testClass, 0.040, $calculator->calculateMatchQuality($gameInfo, $teams));
|
||||
}
|
||||
|
||||
private static function eightTeamsOfOneDrawn($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
$player1 = new Player(1);
|
||||
$player2 = new Player(2);
|
||||
$player3 = new Player(3);
|
||||
$player4 = new Player(4);
|
||||
$player5 = new Player(5);
|
||||
$player6 = new Player(6);
|
||||
$player7 = new Player(7);
|
||||
$player8 = new Player(8);
|
||||
$gameInfo = new GameInfo();
|
||||
|
||||
$team1 = new Team($player1, $gameInfo->getDefaultRating());
|
||||
$team2 = new Team($player2, $gameInfo->getDefaultRating());
|
||||
$team3 = new Team($player3, $gameInfo->getDefaultRating());
|
||||
$team4 = new Team($player4, $gameInfo->getDefaultRating());
|
||||
$team5 = new Team($player5, $gameInfo->getDefaultRating());
|
||||
$team6 = new Team($player6, $gameInfo->getDefaultRating());
|
||||
$team7 = new Team($player7, $gameInfo->getDefaultRating());
|
||||
$team8 = new Team($player8, $gameInfo->getDefaultRating());
|
||||
|
||||
$teams = Teams::concat($team1, $team2, $team3, $team4, $team5, $team6, $team7, $team8);
|
||||
$newRatings = $calculator->calculateNewRatings($gameInfo, $teams, array(1, 1, 1, 1, 1, 1, 1, 1));
|
||||
|
||||
$player1NewRating = $newRatings->getRating($player1);
|
||||
self::assertRating($testClass, 25.000, 4.592, $player1NewRating);
|
||||
|
||||
$player2NewRating = $newRatings->getRating($player2);
|
||||
self::assertRating($testClass, 25.000, 4.583, $player2NewRating);
|
||||
|
||||
$player3NewRating = $newRatings->getRating($player3);
|
||||
self::assertRating($testClass, 25.000, 4.576, $player3NewRating);
|
||||
|
||||
$player4NewRating = $newRatings->getRating($player4);
|
||||
self::assertRating($testClass, 25.000, 4.573, $player4NewRating);
|
||||
|
||||
$player5NewRating = $newRatings->getRating($player5);
|
||||
self::assertRating($testClass, 25.000, 4.573, $player5NewRating);
|
||||
|
||||
$player6NewRating = $newRatings->getRating($player6);
|
||||
self::assertRating($testClass, 25.000, 4.576, $player6NewRating);
|
||||
|
||||
$player7NewRating = $newRatings->getRating($player7);
|
||||
self::assertRating($testClass, 25.000, 4.583, $player7NewRating);
|
||||
|
||||
$player8NewRating = $newRatings->getRating($player8);
|
||||
self::assertRating($testClass, 25.000, 4.592, $player8NewRating);
|
||||
|
||||
self::AssertMatchQuality($testClass, 0.004, $calculator->calculateMatchQuality($gameInfo, $teams));
|
||||
}
|
||||
|
||||
private static function eightTeamsOfOneUpset($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
$player1 = new Player(1);
|
||||
$player2 = new Player(2);
|
||||
$player3 = new Player(3);
|
||||
$player4 = new Player(4);
|
||||
$player5 = new Player(5);
|
||||
$player6 = new Player(6);
|
||||
$player7 = new Player(7);
|
||||
$player8 = new Player(8);
|
||||
|
||||
$gameInfo = new GameInfo();
|
||||
|
||||
$team1 = new Team($player1, new Rating(10, 8));
|
||||
$team2 = new Team($player2, new Rating(15, 7));
|
||||
$team3 = new Team($player3, new Rating(20, 6));
|
||||
$team4 = new Team($player4, new Rating(25, 5));
|
||||
$team5 = new Team($player5, new Rating(30, 4));
|
||||
$team6 = new Team($player6, new Rating(35, 3));
|
||||
$team7 = new Team($player7, new Rating(40, 2));
|
||||
$team8 = new Team($player8, new Rating(45, 1));
|
||||
|
||||
$teams = Teams::concat($team1, $team2, $team3, $team4, $team5, $team6, $team7, $team8);
|
||||
$newRatings = $calculator->calculateNewRatings($gameInfo, $teams, array(1, 2, 3, 4, 5, 6, 7, 8));
|
||||
|
||||
$player1NewRating = $newRatings->getRating($player1);
|
||||
self::assertRating($testClass, 35.135, 4.506, $player1NewRating);
|
||||
|
||||
$player2NewRating = $newRatings->getRating($player2);
|
||||
self::assertRating($testClass, 32.585, 4.037, $player2NewRating);
|
||||
|
||||
$player3NewRating = $newRatings->getRating($player3);
|
||||
self::assertRating($testClass, 31.329, 3.756, $player3NewRating);
|
||||
|
||||
$player4NewRating = $newRatings->getRating($player4);
|
||||
self::assertRating($testClass, 30.984, 3.453, $player4NewRating);
|
||||
|
||||
$player5NewRating = $newRatings->getRating($player5);
|
||||
self::assertRating($testClass, 31.751, 3.064, $player5NewRating);
|
||||
|
||||
$player6NewRating = $newRatings->getRating($player6);
|
||||
self::assertRating($testClass, 34.051, 2.541, $player6NewRating);
|
||||
|
||||
$player7NewRating = $newRatings->getRating($player7);
|
||||
self::assertRating($testClass, 38.263, 1.849, $player7NewRating);
|
||||
|
||||
$player8NewRating = $newRatings->getRating($player8);
|
||||
self::assertRating($testClass, 44.118, 0.983, $player8NewRating);
|
||||
|
||||
self::assertMatchQuality($testClass, 0.000, $calculator->calculateMatchQuality($gameInfo, $teams));
|
||||
}
|
||||
|
||||
private static function sixteenTeamsOfOneNotDrawn($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
$player1 = new Player(1);
|
||||
$player2 = new Player(2);
|
||||
$player3 = new Player(3);
|
||||
$player4 = new Player(4);
|
||||
$player5 = new Player(5);
|
||||
$player6 = new Player(6);
|
||||
$player7 = new Player(7);
|
||||
$player8 = new Player(8);
|
||||
$player9 = new Player(9);
|
||||
$player10 = new Player(10);
|
||||
$player11 = new Player(11);
|
||||
$player12 = new Player(12);
|
||||
$player13 = new Player(13);
|
||||
$player14 = new Player(14);
|
||||
$player15 = new Player(15);
|
||||
$player16 = new Player(16);
|
||||
|
||||
$gameInfo = new GameInfo();
|
||||
|
||||
$team1 = new Team($player1, $gameInfo->getDefaultRating());
|
||||
$team2 = new Team($player2, $gameInfo->getDefaultRating());
|
||||
$team3 = new Team($player3, $gameInfo->getDefaultRating());
|
||||
$team4 = new Team($player4, $gameInfo->getDefaultRating());
|
||||
$team5 = new Team($player5, $gameInfo->getDefaultRating());
|
||||
$team6 = new Team($player6, $gameInfo->getDefaultRating());
|
||||
$team7 = new Team($player7, $gameInfo->getDefaultRating());
|
||||
$team8 = new Team($player8, $gameInfo->getDefaultRating());
|
||||
$team9 = new Team($player9, $gameInfo->getDefaultRating());
|
||||
$team10 = new Team($player10, $gameInfo->getDefaultRating());
|
||||
$team11 = new Team($player11, $gameInfo->getDefaultRating());
|
||||
$team12 = new Team($player12, $gameInfo->getDefaultRating());
|
||||
$team13 = new Team($player13, $gameInfo->getDefaultRating());
|
||||
$team14 = new Team($player14, $gameInfo->getDefaultRating());
|
||||
$team15 = new Team($player15, $gameInfo->getDefaultRating());
|
||||
$team16 = new Team($player16, $gameInfo->getDefaultRating());
|
||||
|
||||
$teams = Teams::concat(
|
||||
$team1, $team2, $team3, $team4, $team5,
|
||||
$team6, $team7, $team8, $team9, $team10,
|
||||
$team11, $team12, $team13, $team14, $team15,
|
||||
$team16);
|
||||
|
||||
$newRatings = $calculator->calculateNewRatings(
|
||||
$gameInfo, $teams,
|
||||
array(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16));
|
||||
|
||||
$player1NewRating = $newRatings->getRating($player1);
|
||||
self::assertRating($testClass, 40.53945776946920, 5.27581643889050, $player1NewRating);
|
||||
|
||||
$player2NewRating = $newRatings->getRating($player2);
|
||||
self::assertRating($testClass, 36.80951229454210, 4.71121217610266, $player2NewRating);
|
||||
|
||||
$player3NewRating = $newRatings->getRating($player3);
|
||||
self::assertRating($testClass, 34.34726355544460, 4.52440328139991, $player3NewRating);
|
||||
|
||||
$player4NewRating = $newRatings->getRating($player4);
|
||||
self::assertRating($testClass, 32.33614722608720, 4.43258628279632, $player4NewRating);
|
||||
|
||||
$player5NewRating = $newRatings->getRating($player5);
|
||||
self::assertRating($testClass, 30.55048814671730, 4.38010805034365, $player5NewRating);
|
||||
|
||||
$player6NewRating = $newRatings->getRating($player6);
|
||||
self::assertRating($testClass, 28.89277312234790, 4.34859291776483, $player6NewRating);
|
||||
|
||||
$player7NewRating = $newRatings->getRating($player7);
|
||||
self::assertRating($testClass, 27.30952161972210, 4.33037679041216, $player7NewRating);
|
||||
|
||||
$player8NewRating = $newRatings->getRating($player8);
|
||||
self::assertRating($testClass, 25.76571046519540, 4.32197078088701, $player8NewRating);
|
||||
|
||||
$player9NewRating = $newRatings->getRating($player9);
|
||||
self::assertRating($testClass, 24.23428953480470, 4.32197078088703, $player9NewRating);
|
||||
|
||||
$player10NewRating = $newRatings->getRating($player10);
|
||||
self::assertRating($testClass, 22.69047838027800, 4.33037679041219, $player10NewRating);
|
||||
|
||||
$player11NewRating = $newRatings->getRating($player11);
|
||||
self::assertRating($testClass, 21.10722687765220, 4.34859291776488, $player11NewRating);
|
||||
|
||||
$player12NewRating = $newRatings->getRating($player12);
|
||||
self::assertRating($testClass, 19.44951185328290, 4.38010805034375, $player12NewRating);
|
||||
|
||||
$player13NewRating = $newRatings->getRating($player13);
|
||||
self::assertRating($testClass, 17.66385277391300, 4.43258628279643, $player13NewRating);
|
||||
|
||||
$player14NewRating = $newRatings->getRating($player14);
|
||||
self::assertRating($testClass, 15.65273644455550, 4.52440328139996, $player14NewRating);
|
||||
|
||||
$player15NewRating = $newRatings->getRating($player15);
|
||||
self::assertRating($testClass, 13.19048770545810, 4.71121217610273, $player15NewRating);
|
||||
|
||||
$player16NewRating = $newRatings->getRating($player16);
|
||||
self::assertRating($testClass, 9.46054223053080, 5.27581643889032, $player16NewRating);
|
||||
}
|
||||
|
||||
private static function twoOnFourOnTwoWinDraw($testClass, SkillCalculator $calculator)
|
||||
{
|
||||
$player1 = new Player(1);
|
||||
$player2 = new Player(2);
|
||||
|
||||
$gameInfo = new GameInfo();
|
||||
|
||||
$team1 = new Team();
|
||||
$team1->addPlayer($player1, new Rating(40,4));
|
||||
$team1->addPlayer($player2, new Rating(45,3));
|
||||
|
||||
$player3 = new Player(3);
|
||||
$player4 = new Player(4);
|
||||
$player5 = new Player(5);
|
||||
$player6 = new Player(6);
|
||||
|
||||
$team2 = new Team();
|
||||
$team2->addPlayer($player3, new Rating(20, 7));
|
||||
$team2->addPlayer($player4, new Rating(19, 6));
|
||||
$team2->addPlayer($player5, new Rating(30, 9));
|
||||
$team2->addPlayer($player6, new Rating(10, 4));
|
||||
|
||||
$player7 = new Player(7);
|
||||
$player8 = new Player(8);
|
||||
|
||||
$team3 = new Team();
|
||||
$team3->addPlayer($player7, new Rating(50,5));
|
||||
$team3->addPlayer($player8, new Rating(30,2));
|
||||
|
||||
$teams = Teams::concat($team1, $team2, $team3);
|
||||
$newRatingsWinLose = $calculator->calculateNewRatings($gameInfo, $teams, array(1, 2, 2));
|
||||
|
||||
// Winners
|
||||
self::assertRating($testClass, 40.877, 3.840, $newRatingsWinLose->getRating($player1));
|
||||
self::assertRating($testClass, 45.493, 2.934, $newRatingsWinLose->getRating($player2));
|
||||
self::assertRating($testClass, 19.609, 6.396, $newRatingsWinLose->getRating($player3));
|
||||
self::assertRating($testClass, 18.712, 5.625, $newRatingsWinLose->getRating($player4));
|
||||
self::assertRating($testClass, 29.353, 7.673, $newRatingsWinLose->getRating($player5));
|
||||
self::assertRating($testClass, 9.872, 3.891, $newRatingsWinLose->getRating($player6));
|
||||
self::assertRating($testClass, 48.830, 4.590, $newRatingsWinLose->getRating($player7));
|
||||
self::assertRating($testClass, 29.813, 1.976, $newRatingsWinLose->getRating($player8));
|
||||
|
||||
self::assertMatchQuality($testClass, 0.367, $calculator->calculateMatchQuality($gameInfo, $teams));
|
||||
}
|
||||
|
||||
private static function assertRating($testClass, $expectedMean, $expectedStandardDeviation, $actual)
|
||||
{
|
||||
$testClass->assertEquals($expectedMean, $actual->getMean(), '', self::ERROR_TOLERANCE_TRUESKILL);
|
||||
|
Reference in New Issue
Block a user