PHP 8.1.0 RC 2 available for testing

gmp_hamdist

(PHP 4 >= 4.0.4, PHP 5, PHP 7, PHP 8)

gmp_hamdistDistancia Hamming

Descripción

gmp_hamdist(GMP|int|string $num1, GMP|int|string $num2): int

Devuelve la distancia hamming entre num1 y num2. Ambos operadores deberían ser no negativos.

Parámetros

num1

resource de número de GMP en PHP 5.5 y anterior, o un objeto de GMP en PHP 5.6 y posterior, o un string numérico siempre que sea posible convertirlo a un número.

Debería ser positivo.

num2

resource de número de GMP en PHP 5.5 y anterior, o un objeto de GMP en PHP 5.6 y posterior, o un string numérico siempre que sea posible convertirlo a un número.

Debería ser positivo.

Valores devueltos

La distancia de Hamming entre num1 y num2, como un int.

Ejemplos

Ejemplo #1 Ejemplo degmp_hamdist()

<?php
$ham1 
gmp_init("1001010011"2);
$ham2 gmp_init("1011111100"2);
echo 
gmp_hamdist($ham1$ham2) . "\n";

/* la distancia hamming es equivalente a: */
echo gmp_popcount(gmp_xor($ham1$ham2)) . "\n";
?>

El resultado del ejemplo sería:

6
6

Ver también

add a note add a note

User Contributed Notes 2 notes

up
3
Bas Vijfwinkel
3 years ago
For those without gmp support :

$hamming_distance = count(array_diff_assoc(str_split($string1), str_split($string2)));

And if you are not sure if your strings have equal length :

$hamming_distance = count(array_diff_assoc(str_split(str_pad($string1,strlen($string2)-strlen($string1),' ')), str_split(str_pad($string2,strlen($string1)-strlen($string2),' '))));
up
0
grabzila at gmail dot com
6 months ago
<?php
$hamdist
= gmp_hamdist(-100, -10); // 4
$hamdist = gmp_hamdist(100, 10);  // 5
?>

The function works great with negative numbers.
To Top