php-ml/src/Phpml/Metric/Distance.php
2016-04-04 22:38:51 +02:00

37 lines
621 B
PHP

<?php
declare(strict_types = 1);
namespace Phpml\Metric;
use Phpml\Exception\InvalidArgumentException;
class Distance
{
/**
* @param array $a
* @param array $b
*
* @return float
*
* @throws InvalidArgumentException
*/
public static function euclidean(array $a, array $b): float
{
if(count($a) != count($b))
{
throw InvalidArgumentException::sizeNotMatch();
}
$distance = 0;
for($i=0; $i<count($a); $i++)
{
$distance += pow($a[$i] - $b[$i], 2);
}
return sqrt($distance);
}
}