y = e^(2 + 3 * ln(x)) $x = [0.25, 0.5, 1, 1.5]; $y = [0.115, 0.924, 7.389, 24.938]; $this->reg = LogLogRegression::getRegression($x, $y); } /** * @testdox The regression parameters are calculated correctly * @group framework */ public function testRegression() : void { self::assertEqualsWithDelta(['b0' => 2, 'b1' => 3], $this->reg, 0.2); } /** * @testdox The slope is calculated correctly * @group framework */ public function testSlope() : void { $y = 3; $x = 2; self::assertEqualsWithDelta($this->reg['b1'] * $y / $x, LogLogRegression::getSlope($this->reg['b1'], $y, $x), 0.2); } /** * @testdox The elasticity is calculated correctly * @group framework */ public function testElasticity() : void { self::assertEqualsWithDelta($this->reg['b1'], LogLogRegression::getElasticity($this->reg['b1'], 0, 0), 0.2); } /** * @testdox Different dimension sizes for x and y coordinates throw a InvalidDimensionException * @group framework */ public function testInvalidDimension() : void { $this->expectException(\phpOMS\Math\Matrix\Exception\InvalidDimensionException::class); $x = [1,2, 3]; $y = [1,2, 3, 4]; LogLogRegression::getRegression($x, $y); } }