2016-04-27 21:51:14 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare (strict_types = 1);
|
|
|
|
|
|
|
|
namespace tests\Regression;
|
|
|
|
|
|
|
|
use Phpml\Regression\LeastSquares;
|
|
|
|
|
|
|
|
class LeastSquaresTest extends \PHPUnit_Framework_TestCase
|
|
|
|
{
|
2016-04-29 21:03:08 +00:00
|
|
|
public function testPredictSingleFeatureSamples()
|
2016-04-27 21:51:14 +00:00
|
|
|
{
|
|
|
|
$delta = 0.01;
|
|
|
|
|
|
|
|
//https://www.easycalculation.com/analytical/learn-least-square-regression.php
|
2016-04-29 21:03:08 +00:00
|
|
|
$samples = [[60], [61], [62], [63], [65]];
|
2016-04-27 21:51:14 +00:00
|
|
|
$targets = [3.1, 3.6, 3.8, 4, 4.1];
|
|
|
|
|
|
|
|
$regression = new LeastSquares();
|
2016-04-29 21:03:08 +00:00
|
|
|
$regression->train($samples, $targets);
|
2016-04-27 21:51:14 +00:00
|
|
|
|
2016-04-29 21:03:08 +00:00
|
|
|
$this->assertEquals(4.06, $regression->predict([64]), '', $delta);
|
2016-04-27 21:51:14 +00:00
|
|
|
|
|
|
|
//http://www.stat.wmich.edu/s216/book/node127.html
|
2016-04-29 21:03:08 +00:00
|
|
|
$samples = [[9300], [10565], [15000], [15000], [17764], [57000], [65940], [73676], [77006], [93739], [146088], [153260]];
|
2016-04-27 21:51:14 +00:00
|
|
|
$targets = [7100, 15500, 4400, 4400, 5900, 4600, 8800, 2000, 2750, 2550, 960, 1025];
|
|
|
|
|
|
|
|
$regression = new LeastSquares();
|
2016-04-29 21:03:08 +00:00
|
|
|
$regression->train($samples, $targets);
|
2016-04-27 21:51:14 +00:00
|
|
|
|
2016-04-29 21:03:08 +00:00
|
|
|
$this->assertEquals(7659.35, $regression->predict([9300]), '', $delta);
|
|
|
|
$this->assertEquals(5213.81, $regression->predict([57000]), '', $delta);
|
|
|
|
$this->assertEquals(4188.13, $regression->predict([77006]), '', $delta);
|
|
|
|
$this->assertEquals(7659.35, $regression->predict([9300]), '', $delta);
|
|
|
|
$this->assertEquals(278.66, $regression->predict([153260]), '', $delta);
|
2016-04-27 21:51:14 +00:00
|
|
|
}
|
2016-04-29 21:03:08 +00:00
|
|
|
|
|
|
|
public function testPredictMultiFeaturesSamples()
|
|
|
|
{
|
|
|
|
$delta = 0.01;
|
|
|
|
|
|
|
|
//http://www.stat.wmich.edu/s216/book/node129.html
|
|
|
|
$samples = [[73676, 1996],[77006,1998],[ 10565, 2000],[146088, 1995],[ 15000, 2001],[ 65940, 2000],[ 9300, 2000],[ 93739, 1996],[153260, 1994],[ 17764, 2002],[ 57000, 1998],[ 15000, 2000]];
|
|
|
|
$targets = [2000, 2750, 15500, 960, 4400, 8800, 7100, 2550, 1025, 5900, 4600, 4400];
|
|
|
|
|
|
|
|
$regression = new LeastSquares();
|
|
|
|
$regression->train($samples, $targets);
|
|
|
|
|
|
|
|
$this->assertEquals(3807, $regression->predict([60000, 1996]), '', $delta);
|
|
|
|
}
|
|
|
|
|
2016-04-27 21:51:14 +00:00
|
|
|
}
|