mirror of
https://github.com/furyfire/trueskill.git
synced 2025-04-15 02:24:28 +00:00
39 lines
1.3 KiB
PHP
39 lines
1.3 KiB
PHP
<?php namespace Moserware\Skills\TrueSkill\Factors;
|
|
|
|
use Moserware\Skills\FactorGraphs\Factor;
|
|
use Moserware\Skills\FactorGraphs\Message;
|
|
use Moserware\Skills\FactorGraphs\Variable;
|
|
use Moserware\Skills\Numerics\GaussianDistribution;
|
|
|
|
abstract class GaussianFactor extends Factor
|
|
{
|
|
protected function __construct($name)
|
|
{
|
|
parent::__construct($name);
|
|
}
|
|
|
|
/**
|
|
* Sends the factor-graph message with and returns the log-normalization constant.
|
|
* @param Message $message
|
|
* @param Variable $variable
|
|
* @return float|int
|
|
*/
|
|
protected function sendMessageVariable(Message &$message, Variable &$variable)
|
|
{
|
|
$marginal = &$variable->getValue();
|
|
$messageValue = &$message->getValue();
|
|
$logZ = GaussianDistribution::logProductNormalization($marginal, $messageValue);
|
|
$variable->setValue(GaussianDistribution::multiply($marginal, $messageValue));
|
|
return $logZ;
|
|
}
|
|
|
|
public function &createVariableToMessageBinding(Variable &$variable)
|
|
{
|
|
$newDistribution = GaussianDistribution::fromPrecisionMean(0, 0);
|
|
$binding = &parent::createVariableToMessageBindingWithMessage($variable,
|
|
new Message(
|
|
$newDistribution,
|
|
sprintf("message from %s to %s", $this, $variable)));
|
|
return $binding;
|
|
}
|
|
} |