Generando sumas de Luhn

Hay muchas implementaciones para validar las sumas de comprobación de Luhn, pero muy pocas para generarlas. Me he encontradoéste sin embargo, en mis pruebas se ha revelado que tiene errores y no entiendo la lógica detrás de la variable delta.

He hecho esta función que supuestamente debería generar sumas de comprobación de Luhn, pero por alguna razón que aún no he entendido, la suma de comprobación generada no es válida la mitad del tiempo.

function Luhn($number, $iterations = 1)
{
    while ($iterations-- >= 1)
    {
        $stack = 0;
        $parity = strlen($number) % 2;
        $number = str_split($number, 1);

        foreach ($number as $key => $value)
        {
            if ($key % 2 == $parity)
            {
                $value *= 2;

                if ($value > 9)
                {
                    $value -= 9;
                }
            }

            $stack += $value;
        }

        $stack = 10 - $stack % 10;

        if ($stack == 10)
        {
            $stack = 0;
        }

        $number[] = $stack;
    }

    return implode('', $number);
}

Algunos ejemplos:

Luhn(3); // 37, invalid
Luhn(37); // 372, valid
Luhn(372); // 3728, invalid
Luhn(3728); // 37283, valid
Luhn(37283); // 372837, invalid
Luhn(372837); // 3728375, valid

Estoy validando las sumas de comprobación generadas.en contra de esta pagina, ¿Qué estoy haciendo mal aquí?

Para futuras referencias, aquí está la función de trabajo.

function Luhn($number, $iterations = 1)
{
    while ($iterations-- >= 1)
    {
        $stack = 0;
        $number = str_split(strrev($number), 1);

        foreach ($number as $key => $value)
        {
            if ($key % 2 == 0)
            {
                $value = array_sum(str_split($value * 2, 1));
            }

            $stack += $value;
        }

        $stack %= 10;

        if ($stack != 0)
        {
            $stack -= 10;
        }

        $number = implode('', array_reverse($number)) . abs($stack);
    }

    return $number;
}

Bajé la variable $ parity ya que no la necesitamos para este propósito, y para verificar:

function Luhn_Verify($number, $iterations = 1)
{
    $result = substr($number, 0, - $iterations);

    if (Luhn($result, $iterations) == $number)
    {
        return $result;
    }

    return false;
}

Respuestas a la pregunta(5)

Su respuesta a la pregunta