mirror of
https://github.com/furyfire/trueskill.git
synced 2025-01-16 01:47:39 +00:00
61 lines
1.2 KiB
PHP
61 lines
1.2 KiB
PHP
<?php
|
|
|
|
namespace Moserware\Skills\FactorGraphs;
|
|
|
|
require_once(dirname(__FILE__) . "/Factor.php");
|
|
|
|
/// <summary>
|
|
/// Helper class for computing the factor graph's normalization constant.
|
|
/// </summary>
|
|
class FactorList
|
|
{
|
|
private $_list = array();
|
|
|
|
public function getLogNormalization()
|
|
{
|
|
$list = &$this->_list;
|
|
foreach($list as &$currentFactor)
|
|
{
|
|
$currentFactor->resetMarginals();
|
|
}
|
|
|
|
$sumLogZ = 0.0;
|
|
|
|
$listCount = count($this->_list);
|
|
|
|
for ($i = 0; $i < $listCount; $i++)
|
|
{
|
|
$f = $this->_list[$i];
|
|
|
|
$numberOfMessages = $f->getNumberOfMessages();
|
|
|
|
for ($j = 0; $j < $numberOfMessages; $j++)
|
|
{
|
|
$sumLogZ += $f->sendMessageIndex($j);
|
|
}
|
|
}
|
|
|
|
$sumLogS = 0;
|
|
|
|
foreach($list as &$currentFactor)
|
|
{
|
|
$sumLogS = $sumLogS + $currentFactor->getLogNormalization();
|
|
}
|
|
|
|
return $sumLogZ + $sumLogS;
|
|
}
|
|
|
|
public function count()
|
|
{
|
|
return count($this->_list);
|
|
}
|
|
|
|
public function &addFactor(Factor &$factor)
|
|
{
|
|
$this->_list[] = $factor;
|
|
return $factor;
|
|
}
|
|
}
|
|
|
|
?>
|