mirror of
				https://github.com/furyfire/trueskill.git
				synced 2025-10-22 13:32:29 +02:00 
			
		
		
		
	Three teams of 1 not drawn passes
This commit is contained in:
		| @@ -162,29 +162,40 @@ class FactorGraphTrueSkillCalculator extends SkillCalculator | |||||||
|  |  | ||||||
|         $teamAssignmentsListCount = count($teamAssignmentsList); |         $teamAssignmentsListCount = count($teamAssignmentsList); | ||||||
|  |  | ||||||
|  |         $currentColumn = 0; | ||||||
|  |  | ||||||
|         for ($i = 0; $i < $teamAssignmentsListCount - 1; $i++) |         for ($i = 0; $i < $teamAssignmentsListCount - 1; $i++) | ||||||
|         { |         { | ||||||
|             $currentTeam = $teamAssignmentsList[$i]; |             $currentTeam = $teamAssignmentsList[$i]; | ||||||
|  |  | ||||||
|             // Need to add in 0's for all the previous players, since they're not |             // Need to add in 0's for all the previous players, since they're not | ||||||
|             // on this team |             // on this team | ||||||
|             $currentRowValues = array();             |             $playerAssignments[$currentColumn] = ($totalPreviousPlayers > 0) ? \array_fill(0, $totalPreviousPlayers, 0) : array(); | ||||||
|  |  | ||||||
|             foreach ($currentTeam->getAllPlayers() as $currentPlayer) |             foreach ($currentTeam->getAllPlayers() as $currentPlayer) | ||||||
|             { |             { | ||||||
|                 $currentRowValues[] = PartialPlay::getPartialPlayPercentage($currentPlayer); |                 $playerAssignments[$currentColumn][] = PartialPlay::getPartialPlayPercentage($currentPlayer); | ||||||
|                 // indicates the player is on the team |                 // indicates the player is on the team | ||||||
|                 $totalPreviousPlayers++; |                 $totalPreviousPlayers++; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             $rowsRemaining = $totalPlayers - $totalPreviousPlayers; | ||||||
|  |  | ||||||
|             $nextTeam = $teamAssignmentsList[$i + 1]; |             $nextTeam = $teamAssignmentsList[$i + 1]; | ||||||
|             foreach ($nextTeam->getAllPlayers() as $nextTeamPlayer) |             foreach ($nextTeam->getAllPlayers() as $nextTeamPlayer) | ||||||
|             { |             { | ||||||
|                 // Add a -1 * playing time to represent the difference |                 // Add a -1 * playing time to represent the difference | ||||||
|                 $currentRowValues[] = -1 * PartialPlay::getPartialPlayPercentage($nextTeamPlayer); |                 $playerAssignments[$currentColumn][] = -1 * PartialPlay::getPartialPlayPercentage($nextTeamPlayer); | ||||||
|  |                 $rowsRemaining--; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             $playerAssignments[] = &$currentRowValues; |             for ($ixAdditionalRow = 0; $ixAdditionalRow < $rowsRemaining; $ixAdditionalRow++) | ||||||
|  |             { | ||||||
|  |                 // Pad with zeros | ||||||
|  |                 $playerAssignments[$currentColumn][] = 0; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             $currentColumn++; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         $playerTeamAssignmentsMatrix = Matrix::fromColumnValues($totalPlayers, $teamAssignmentsListCount - 1, $playerAssignments); |         $playerTeamAssignmentsMatrix = Matrix::fromColumnValues($totalPlayers, $teamAssignmentsListCount - 1, $playerAssignments); | ||||||
|   | |||||||
| @@ -16,6 +16,8 @@ class FactorGraphTrueSkillCalculatorTest extends PHPUnit_Framework_TestCase | |||||||
|          |          | ||||||
|         TrueSkillCalculatorTests::testAllTwoPlayerScenarios($this, $calculator); |         TrueSkillCalculatorTests::testAllTwoPlayerScenarios($this, $calculator); | ||||||
|         TrueSkillCalculatorTests::testAllTwoTeamScenarios($this, $calculator); |         TrueSkillCalculatorTests::testAllTwoTeamScenarios($this, $calculator); | ||||||
|  |         TrueSkillCalculatorTests::testAllMultipleTeamScenarios($this, $calculator); | ||||||
|  |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -47,7 +47,17 @@ class TrueSkillCalculatorTests | |||||||
|         self::fourOnFourSimpleTest($testClass, $calculator); |         self::fourOnFourSimpleTest($testClass, $calculator); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     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); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     //------------------- Actual Tests --------------------------- |     //------------------- Actual Tests --------------------------- | ||||||
|     // If you see more than 3 digits of precision in the decimal point, then the expected values calculated from |     // If you see more than 3 digits of precision in the decimal point, then the expected values calculated from | ||||||
| @@ -571,6 +581,33 @@ class TrueSkillCalculatorTests | |||||||
|         self::assertMatchQuality($testClass, 0.447, $calculator->calculateMatchQuality($gameInfo, $teams)); |         self::assertMatchQuality($testClass, 0.447, $calculator->calculateMatchQuality($gameInfo, $teams)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private static function threeTeamsOfOneNotDrawn($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, 2, 3)); | ||||||
|  |  | ||||||
|  |         $player1NewRating = $newRatings->getRating($player1); | ||||||
|  |         self::assertRating($testClass, 31.675352419172107, 6.6559853776206905, $player1NewRating); | ||||||
|  |  | ||||||
|  |         $player2NewRating = $newRatings->getRating($player2); | ||||||
|  |         self::assertRating($testClass, 25.000000000003912, 6.2078966412243233, $player2NewRating); | ||||||
|  |  | ||||||
|  |         $player3NewRating = $newRatings->getRating($player3); | ||||||
|  |         self::assertRating($testClass, 18.324647580823971, 6.6559853776218318, $player3NewRating); | ||||||
|  |  | ||||||
|  |         self::assertMatchQuality($testClass, 0.200, $calculator->calculateMatchQuality($gameInfo, $teams)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private static function assertRating($testClass, $expectedMean, $expectedStandardDeviation, $actual) |     private static function assertRating($testClass, $expectedMean, $expectedStandardDeviation, $actual) | ||||||
|     { |     { | ||||||
|         $testClass->assertEquals($expectedMean, $actual->getMean(), '',  self::ERROR_TOLERANCE_TRUESKILL); |         $testClass->assertEquals($expectedMean, $actual->getMean(), '',  self::ERROR_TOLERANCE_TRUESKILL); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Jeff Moser
					Jeff Moser