LevenshteinHeuristic   A
last analyzed

Complexity

Total Complexity 1

Size/Duplication

Total Lines 12
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 6
c 1
b 0
f 0
dl 0
loc 12
rs 10
wmc 1

1 Method

Rating   Name   Duplication   Size   Complexity  
A estimate() 0 10 1
1
<?php declare(strict_types=1);
2
3
namespace Stratadox\PuzzleSolver\Puzzle\SlidingPuzzle;
4
5
use Stratadox\PuzzleSolver\Heuristic;
6
use Stratadox\PuzzleSolver\Puzzle;
7
use function assert;
8
use function levenshtein;
9
10
final class LevenshteinHeuristic implements Heuristic
11
{
12
    public function estimate(Puzzle $puzzle): float
13
    {
14
        assert($puzzle instanceof SlidingPuzzle);
15
16
        return levenshtein(
17
            $puzzle->goalState(),
18
            $puzzle->currentState(),
19
            100,
20
            1,
21
            100
22
        );
23
    }
24
}
25