phpOMS/tests/Math/Stochastic/Distribution/GammaDistributionTest.php
2020-09-27 16:49:19 +02:00

127 lines
3.5 KiB
PHP

<?php
/**
* Orange Management
*
* PHP Version 7.4
*
* @package tests
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link https://orange-management.org
*/
declare(strict_types=1);
namespace phpOMS\tests\Math\Stochastic\Distribution;
use phpOMS\Math\Stochastic\Distribution\GammaDistribution;
/**
* @internal
*/
class GammaDistributionTest extends \PHPUnit\Framework\TestCase
{
public function testPdfScale() : void
{
self::assertEqualsWithDelta(0.0734, GammaDistribution::getPdfScale(10, 4, 3), 0.001);
}
public function testPdfAlphaBete() : void
{
self::assertEqualsWithDelta(0.180447, GammaDistribution::getPdfRate(2, 4, 1), 0.001);
}
public function testCdfScale() : void
{
self::assertEqualsWithDelta(0.42701, GammaDistribution::getCdfScale(10, 4, 3), 0.001);
}
public function testCdfAlphaBete() : void
{
self::assertEqualsWithDelta(0.142876, GammaDistribution::getCdfRate(2, 4, 1), 0.001);
}
public function testPdfIntegerScale() : void
{
self::assertEqualsWithDelta(\exp(-1), GammaDistribution::getPdfIntegerScale(1, 1, 1), 0.001);
self::assertEqualsWithDelta(3 * \exp(-3 / 4) / 16, GammaDistribution::getPdfIntegerScale(3, 2, 4), 0.001);
}
public function testPdfIntegerRate() : void
{
self::assertEqualsWithDelta(0.180447, GammaDistribution::getPdfIntegerRate(2, 4, 1), 0.001);
}
public function testMeanScale() : void
{
self::assertEqualsWithDelta(8, GammaDistribution::getMeanScale(2, 4), 0.001);
}
public function testMeanRate() : void
{
$alpha = 4;
$beta = 2;
self::assertEquals($alpha / $beta, GammaDistribution::getMeanRate($alpha, $beta));
}
public function testVarianceScale() : void
{
self::assertEqualsWithDelta(32, GammaDistribution::getVarianceScale(2, 4), 0.001);
}
public function testVarianceRate() : void
{
$alpha = 4;
$beta = 2;
self::assertEquals($alpha / \pow($beta, 2), GammaDistribution::getVarianceRate($alpha, $beta));
}
public function testStandardDeviationScale() : void
{
self::assertEqualsWithDelta(\sqrt(32), GammaDistribution::getStandardDeviationScale(2, 4), 0.001);
}
public function testStandardDeviationRate() : void
{
$alpha = 4;
$beta = 2;
self::assertEquals(\sqrt($alpha / \pow($beta, 2)), GammaDistribution::getStandardDeviationRate($alpha, $beta));
}
public function testExKurtosis() : void
{
self::assertEqualsWithDelta(3, GammaDistribution::getExKurtosis(2, 4), 0.001);
}
public function testSkewness() : void
{
self::assertEqualsWithDelta(\sqrt(2), GammaDistribution::getSkewness(2, 4), 0.001);
}
public function testMgfScale() : void
{
$theta = 2;
$t = 1 / $theta * 0.4;
$k = 3;
self::assertEquals(\pow(1 - $theta * $t, -$k), GammaDistribution::getMgfScale($k, $t, $theta));
}
public function testMgfRate() : void
{
$alpha = 4;
$beta = 3;
$t = 2;
self::assertEquals(\pow(1 - $t / $beta, -$alpha), GammaDistribution::getMgfRate($t, $alpha, $beta));
}
public function testModeScale() : void
{
self::assertEquals((3 - 1) * 2, GammaDistribution::getModeScale(3, 2));
}
public function testModeRate() : void
{
self::assertEquals((3 - 1) / 2, GammaDistribution::getModeRate(3, 2));
}
}