2016-04-21 22:54:38 +02:00
|
|
|
<?php
|
2016-04-25 22:55:34 +02:00
|
|
|
|
2016-11-20 22:53:17 +01:00
|
|
|
declare(strict_types=1);
|
2016-04-21 22:54:38 +02:00
|
|
|
|
2018-01-06 13:09:33 +01:00
|
|
|
namespace Phpml\Tests\Math\Kernel;
|
2016-04-21 22:54:38 +02:00
|
|
|
|
|
|
|
use Phpml\Math\Kernel\RBF;
|
2017-02-03 12:58:25 +01:00
|
|
|
use PHPUnit\Framework\TestCase;
|
2016-04-21 22:54:38 +02:00
|
|
|
|
2017-02-03 12:58:25 +01:00
|
|
|
class RBFTest extends TestCase
|
2016-04-21 22:54:38 +02:00
|
|
|
{
|
2017-11-14 21:21:23 +01:00
|
|
|
public function testComputeRBFKernelFunction(): void
|
2016-04-21 22:54:38 +02:00
|
|
|
{
|
|
|
|
$rbf = new RBF($gamma = 0.001);
|
|
|
|
|
|
|
|
$this->assertEquals(1, $rbf->compute([1, 2], [1, 2]));
|
|
|
|
$this->assertEquals(0.97336, $rbf->compute([1, 2, 3], [4, 5, 6]), '', $delta = 0.0001);
|
|
|
|
$this->assertEquals(0.00011, $rbf->compute([4, 5], [1, 100]), '', $delta = 0.0001);
|
|
|
|
|
|
|
|
$rbf = new RBF($gamma = 0.2);
|
|
|
|
|
|
|
|
$this->assertEquals(1, $rbf->compute([1, 2], [1, 2]));
|
|
|
|
$this->assertEquals(0.00451, $rbf->compute([1, 2, 3], [4, 5, 6]), '', $delta = 0.0001);
|
|
|
|
$this->assertEquals(0, $rbf->compute([4, 5], [1, 100]));
|
|
|
|
}
|
|
|
|
}
|