mirror of
https://github.com/Llewellynvdm/php-ml.git
synced 2024-09-22 12:19:02 +00:00
40 lines
672 B
PHP
40 lines
672 B
PHP
|
<?php
|
||
|
declare(strict_types = 1);
|
||
|
|
||
|
namespace Phpml\Math\Kernel;
|
||
|
|
||
|
use Phpml\Math\Kernel;
|
||
|
use Phpml\Math\Product;
|
||
|
|
||
|
class RBF implements Kernel
|
||
|
{
|
||
|
/**
|
||
|
* @var float
|
||
|
*/
|
||
|
private $gamma;
|
||
|
|
||
|
/**
|
||
|
* @param float $gamma
|
||
|
*/
|
||
|
public function __construct(float $gamma)
|
||
|
{
|
||
|
$this->gamma = $gamma;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param float $a
|
||
|
* @param float $b
|
||
|
*
|
||
|
* @return float
|
||
|
*/
|
||
|
public function compute($a, $b)
|
||
|
{
|
||
|
$score = 2 * Product::scalar($a, $b);
|
||
|
$squares = Product::scalar($a, $a) + Product::scalar($b, $b);
|
||
|
$result = exp(-$this->gamma * ($squares - $score));
|
||
|
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
}
|