php-ml/src/Phpml/Metric/Distance/Manhattan.php

36 lines
677 B
PHP
Raw Normal View History

<?php
declare (strict_types = 1);
namespace Phpml\Metric\Distance;
use Phpml\Exception\InvalidArgumentException;
use Phpml\Metric\Distance;
class Manhattan 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 += abs($a[$i] - $b[$i]);
}
return $distance;
}
}