trueskill/src/TrueSkill/Layers/PlayerSkillsToPerformancesLayer.php

70 lines
2.4 KiB
PHP
Raw Normal View History

2022-07-05 15:55:47 +02:00
<?php
namespace DNW\Skills\TrueSkill\Layers;
2022-07-05 15:33:34 +02:00
use DNW\Skills\FactorGraphs\KeyedVariable;
2022-07-05 15:55:47 +02:00
use DNW\Skills\FactorGraphs\ScheduleStep;
2022-07-05 15:33:34 +02:00
use DNW\Skills\Numerics\BasicMath;
use DNW\Skills\TrueSkill\Factors\GaussianLikelihoodFactor;
2022-07-05 15:55:47 +02:00
use DNW\Skills\TrueSkill\TrueSkillFactorGraph;
class PlayerSkillsToPerformancesLayer extends TrueSkillFactorGraphLayer
{
public function buildLayer()
{
$inputVariablesGroups = $this->getInputVariablesGroups();
2010-09-30 08:25:31 -04:00
$outputVariablesGroups = &$this->getOutputVariablesGroups();
foreach ($inputVariablesGroups as $currentTeam) {
2022-07-05 15:55:47 +02:00
$currentTeamPlayerPerformances = [];
foreach ($currentTeam as $playerSkillVariable) {
$localPlayerSkillVariable = $playerSkillVariable;
$currentPlayer = $localPlayerSkillVariable->getKey();
$playerPerformance = $this->createOutputVariable($currentPlayer);
$newLikelihoodFactor = $this->createLikelihood($localPlayerSkillVariable, $playerPerformance);
$this->addLayerFactor($newLikelihoodFactor);
$currentTeamPlayerPerformances[] = $playerPerformance;
}
$outputVariablesGroups[] = $currentTeamPlayerPerformances;
}
}
private function createLikelihood(KeyedVariable $playerSkill, KeyedVariable $playerPerformance)
{
return new GaussianLikelihoodFactor(
2016-05-24 15:12:29 +02:00
BasicMath::square($this->getParentFactorGraph()->getGameInfo()->getBeta()),
$playerPerformance,
$playerSkill
);
}
private function createOutputVariable($key)
{
2022-07-05 16:21:06 +02:00
return $this->getParentFactorGraph()->getVariableFactory()->createKeyedVariable($key, $key."'s performance");
}
public function createPriorSchedule()
{
$localFactors = $this->getLocalFactors();
2022-07-05 15:55:47 +02:00
return $this->scheduleSequence(
array_map(
2022-07-05 16:21:06 +02:00
fn($likelihood) => new ScheduleStep('Skill to Perf step', $likelihood, 0),
$localFactors),
2022-07-05 15:55:47 +02:00
'All skill to performance sending');
}
public function createPosteriorSchedule()
{
$localFactors = $this->getLocalFactors();
2022-07-05 15:55:47 +02:00
return $this->scheduleSequence(
array_map(
2022-07-05 16:21:06 +02:00
fn($likelihood) => new ScheduleStep('name', $likelihood, 1),
$localFactors),
2022-07-05 15:55:47 +02:00
'All skill to performance sending');
}
}