mirror of
https://github.com/Llewellynvdm/php-ml.git
synced 2024-09-28 06:59:02 +00:00
36 lines
686 B
PHP
36 lines
686 B
PHP
|
<?php
|
||
|
|
||
|
declare (strict_types = 1);
|
||
|
|
||
|
namespace Phpml\Metric\Distance;
|
||
|
|
||
|
use Phpml\Exception\InvalidArgumentException;
|
||
|
use Phpml\Metric\Distance;
|
||
|
|
||
|
class Euclidean implements Distance
|
||
|
{
|
||
|
/**
|
||
|
* @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::sizeNotMatch();
|
||
|
}
|
||
|
|
||
|
$distance = 0;
|
||
|
$count = count($a);
|
||
|
|
||
|
for ($i = 0; $i < $count; ++$i) {
|
||
|
$distance += pow($a[$i] - $b[$i], 2);
|
||
|
}
|
||
|
|
||
|
return sqrt($distance);
|
||
|
}
|
||
|
}
|