Luhnův algoritmus je jednoduchý algoritmuskontrolního součtu čísel, používaný dnes při kontrole platnosti řady identifikačních čísel. Jako kontrolní mechanismus se nesnaží být kryptografickou hašovací funkcí a není odolný vůči cíleným útokům, jeho úkolem je pomoci při detekci náhodných chyb.
Algoritmus vymyslel Hans Peter Luhn z IBM a popsal jej v patentu 2 950 048 amerického patentového úřadu podaném 6. ledna 1954 a schváleném 23. srpna 1960.[2]
Dnes již algoritmus žádným patentem chráněn není a využívá se v mnoha aplikacích, je například součástí specifikace ISO/IEC 7812.
Algoritmus
Algoritmus je nezávislý na délce čísla (principiálně stačí dvouciferný řetězec).
Autorita přidělující identifikační číslo stanoví Luhnovým algoritmem kontrolní číslici a přidá ji na jeho pravý konec.
Při kontrole správnosti takového identifikačního čísla, například při jeho neautomatizovaném odečtu, se potom postupuje v těchto třech krocích:
Pro každou druhou číslici (bráno zprava, tedy se netýká kontrolní číslice) spočítáme její dvojnásobek.
Ciferné součty získaných dvojnásobků sečteme se zbývajícími číslicemi.
Pokud nám vyšel výsledek končící nulou (tedy číslo, jehož zbytek po dělení 10 je nula), původní číslo prošlo testem, jinak jím neprošlo.
Příklad
Identifikační údaj „21 RIV 54 CZ-ČD 5555 774–8“ na vozidle z ilustračního obrázku by byl kontrolován takto:
Vlastní součástí identifikace jsou jen číslice, k ostatním znakům se nepřihlíží, vstupem algoritmu je tedy číslo 215455557748.
Zdvojnásobením každé druhé číslice zprava získáme: (4×2) = 8, (7×2) = 14, (5×2) = 10, (5×2) = 10, (5×2) = 10, (2×2) = 4; (dvouciferné) výsledky nahradíme jejich cifernými součty.
↑Oznámení o zavedení nového variabilního symbolu [online]. Česká správa sociálního zabezpečení [cit. 2010-05-05]. Dostupné v archivu pořízeném dne 2010-04-13.
↑Computer for verifying numbers. Původce vynálezu: Hans P. LUHN. United States, Patent Office. Patentový spis US2950048. 1960-08-23. Dostupné: <online> [cit. 2023-07-28]. (anglicky)