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 22:58:54 +00:00
|
|
|
$samples = [[1, 60], [1, 61], [1, 62], [1, 63], [1, 65]];
|
|
|
|
$targets = [[3.1], [3.6], [3.8], [4], [4.1]];
|
2016-04-27 21:51:14 +00:00
|
|
|
|
|
|
|
$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 22:59:10 +00:00
|
|
|
$samples = [[1, 9300], [1, 10565], [1, 15000], [1, 15000], [1, 17764], [1, 57000], [1, 65940], [1, 73676], [1, 77006], [1, 93739], [1, 146088], [1, 153260]];
|
2016-04-29 22:58:54 +00:00
|
|
|
$targets = [[7100], [15500], [4400], [4400], [5900], [4600], [8800], [2000], [2750], [2550], [960], [1025]];
|
2016-04-27 21:51:14 +00:00
|
|
|
|
|
|
|
$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()
|
|
|
|
{
|
2016-04-30 11:32:40 +00:00
|
|
|
$delta = 0.01;
|
2016-04-29 21:03:08 +00:00
|
|
|
|
|
|
|
//http://www.stat.wmich.edu/s216/book/node129.html
|
2016-04-29 22:59:10 +00:00
|
|
|
$samples = [[1, 73676, 1996], [1, 77006, 1998], [1, 10565, 2000], [1, 146088, 1995], [1, 15000, 2001], [1, 65940, 2000], [1, 9300, 2000], [1, 93739, 1996], [1, 153260, 1994], [1, 17764, 2002], [1, 57000, 1998], [1, 15000, 2000]];
|
|
|
|
$targets = [[2000], [2750], [15500], [960], [4400], [8800], [7100], [2550], [1025], [5900], [4600], [4400]];
|
2016-04-29 21:03:08 +00:00
|
|
|
|
|
|
|
$regression = new LeastSquares();
|
|
|
|
$regression->train($samples, $targets);
|
|
|
|
|
2016-04-30 11:32:40 +00:00
|
|
|
$this->assertEquals(-800614.957, $regression->getIntercept(), '', $delta);
|
|
|
|
$this->assertEquals([-0.0327, 404.14], $regression->getCoefficients(), '', $delta);
|
|
|
|
$this->assertEquals(4094.82, $regression->predict([60000, 1996]), '', $delta);
|
|
|
|
$this->assertEquals(5711.40, $regression->predict([60000, 2000]), '', $delta);
|
2016-04-29 21:03:08 +00:00
|
|
|
}
|
2016-04-27 21:51:14 +00:00
|
|
|
}
|