php-ml/src/Phpml/Math/Distance/Minkowski.php

49 lines
919 B
PHP
Raw Normal View History

<?php
declare (strict_types = 1);
2016-04-20 21:56:33 +00:00
namespace Phpml\Math\Distance;
use Phpml\Exception\InvalidArgumentException;
2016-04-20 21:56:33 +00:00
use Phpml\Math\Distance;
class Minkowski implements Distance
{
/**
* @var float
*/
private $lambda;
/**
* @param float $lambda
*/
public function __construct(float $lambda = 3)
{
$this->lambda = $lambda;
}
/**
* @param array $a
* @param array $b
*
* @return float
*
* @throws InvalidArgumentException
*/
public function distance(array $a, array $b): float
{
if (count($a) !== count($b)) {
throw InvalidArgumentException::arraySizeNotMatch();
}
2016-04-17 15:47:30 +00:00
$distance = 0;
$count = count($a);
for ($i = 0; $i < $count; ++$i) {
$distance += pow(abs($a[$i] - $b[$i]), $this->lambda);
}
return pow($distance, 1 / $this->lambda);
}
}