Алгоритм Луна - Википедия - Luhn algorithm

В Алгоритм Луна или же Формула Луна, также известный как "модуль 10 "или" мод 10 " алгоритм, названный в честь своего создателя, ученого IBM Ханс Петер Лун, это простой контрольная сумма формула, используемая для проверки различных идентификационных номеров, таких как номера кредитных карт, Номера IMEI, Национальные идентификационные номера провайдеров В Соединенных Штатах, Канадский Номера социального страхования, Израильский Идентификационные номера, Южноафриканский Идентификационные номера, Греческий Номера социального страхования (ΑΜΚΑ) и коды опросов, указанные на Макдоналдс, Тако Белл, и Компания Tractor Supply Co. квитанции. Это описано в Патент США № 2,950,048., подана 6 января 1954 г. и предоставлена ​​23 августа 1960 г.

Алгоритм находится в всеобщее достояние и широко используется сегодня. Это указано в ISO / IEC 7812 -1.[1] Он не предназначен для криптографически безопасная хеш-функция; он был разработан для защиты от случайных ошибок, а не от злонамеренных атак. Большинство кредитных карт и многие государственные идентификационные номера используют алгоритм как простой метод отличия действительных номеров от ошибочно набранных или иным образом неверных.

Описание

Формула сравнивает число с включенным контрольная цифра, который обычно добавляется к частичному номеру счета для генерации полного номера счета. Этот номер должен пройти следующий тест:

  1. Начиная с самой правой цифры (исключая контрольную цифру) и двигаясь влево, удвойте значение каждой второй цифры. Контрольная цифра не удваивается и не включается в этот расчет; первая удвоенная цифра - это цифра, расположенная сразу слева от контрольной цифры. Если результат этой операции удвоения больше 9 (например, 8 × 2 = 16), то сложите цифры результата (например, 16: 1 + 6 = 7, 18: 1 + 8 = 9) или, что то же самое, , вычтите 9 из результата (например, 16: 16 - 9 = 7, 18: 18 - 9 = 9).
  2. Возьмите сумму всех цифр (включая контрольную).
  3. Если общая по модулю 10 равно 0 (если сумма оканчивается нулем), то число действительно согласно формуле Луна; в противном случае это недействительно.

Пример вычисления контрольной цифры

Предположим, что для номера счета «7992739871» будет добавлена ​​контрольная цифра, которая будет иметь форму 7992739871x:

7992739871Икс
Удвойте друг друга718947691672Икс
Сумма цифр7994769772Икс

Сумма всех цифр в третьей строке, сумма цифр суммы, равна 67.

Контрольная цифра (x) получается путем вычисления суммы цифр суммы, а затем вычисления 9-кратного значения по модулю 10 (в форме уравнения ((67 × 9) по модулю 10)). В виде алгоритма:

  1. Вычислите сумму цифр суммы (67).
  2. Умножьте на 9 (603).
  3. 603 mod 10 - это контрольная цифра 3. Таким образом, х = 3.

(Альтернативный метод) Контрольная цифра (x) получается путем вычисления суммы других цифр (третья строка), а затем вычитания цифры единиц из 10 (67 => цифра единиц 7; 10-7 = контрольная цифра 3). В виде алгоритма:

  1. Вычислите сумму цифр суммы (67).
  2. Возьмите цифру единиц (7).
  3. Вычтите цифру единиц из 10.
  4. Результат (3) - это контрольная цифра. Если сумма цифр оканчивается на 0, то 0 является контрольной цифрой.

Это делает полный номер счета 79927398713.

Пример проверки контрольной цифры

Каждый из номеров 79927398710, 79927398711, 79927398712, 79927398713, 79927398714, 79927398715, 79927398716, 79927398717, 79927398718, 79927398719 можно проверить следующим образом.

  1. Удваивайте каждую вторую цифру, начиная с самого правого: (1 × 2) = 2, (8 × 2) = 16, (3 × 2) = 6, (2 × 2) = 4, (9 × 2) = 18
  2. Суммируйте все индивидуальный цифры (цифры в скобках - это произведения из шага 1): x (контрольная цифра) + (2) + 7 + (1 + 6) + 9 + (6) + 7 + (4) + 9 + (1 + 8 ) + 7 = х + 67.
  3. Если сумма кратна 10, возможно, номер счета действителен. Обратите внимание, что 3 - единственная допустимая цифра, которая дает сумму (70), кратную 10.
  4. Таким образом, все эти номера счетов недействительны, за исключением, возможно, 79927398713, у которого есть правильная контрольная цифра.

В качестве альтернативы вы можете использовать тот же алгоритм создания контрольной суммы, игнорируя уже имеющуюся контрольную сумму, как если бы она еще не была рассчитана. Затем вычислите контрольную сумму и сравните эту рассчитанную контрольную сумму с исходной контрольной суммой, включенной в номер кредитной карты. Если включенная контрольная сумма совпадает с рассчитанной контрольной суммой, то число действительное.

Сильные и слабые стороны

Алгоритм Луна обнаружит любую ошибку одной цифры, а также почти все перестановки соседних цифр. Однако он не обнаружит транспонирование двузначной последовательности. 09 к 90 (или наоборот). Он обнаружит большинство возможных двойных ошибок (не обнаружит 2255, 3366 или же 4477).

Другие, более сложные алгоритмы контрольной цифры (например, Алгоритм Верхоффа и Алгоритм дамма ) может обнаружить больше ошибок транскрипции. В Алгоритм Luhn mod N - это расширение, поддерживающее нечисловые строки.

Поскольку алгоритм работает с цифрами справа налево, а нулевые цифры влияют на результат, только если они вызывают сдвиг позиции, заполнение нулями начала строки чисел не влияет на вычисления. Следовательно, системы, которые дополняют определенное количество цифр (например, путем преобразования 1234 в 0001234), могут выполнять проверку Luhn до или после заполнения и достигать того же результата.

Добавление 0 к нечетным числам позволяет обрабатывать число слева направо, а не справа налево, удваивая нечетные цифры.

Алгоритм появился в патенте США.[2] для портативного механического устройства для вычисления контрольной суммы. Следовательно, требовалось, чтобы это было достаточно просто. Устройство взяло мод 10 сум механическим способом. В цифры замены, то есть результаты процедуры удвоения и сокращения не производились механически. Скорее, цифры были отмечены на корпусе машины в порядке их перестановки.

Реализация псевдокода

функция checkLuhn (строка purportedCC) {int sum: = integer (purportedCC [length (purportedCC) -1]) int nDigits: = length (purportedCC) int четность: = nDigits модуль 2 за i от 0 до nDigits - 2 {int digit: = integer (purportedCC [i]) если i модуль 2 = цифра четности: = цифра × 2 если цифра> 9 цифра: = цифра - 9 сумма: = сумма + цифра} возвращаться (модуль суммы 10) = 0}

использование

Помимо номеров кредитных карт, этот алгоритм также используется для вычисления контрольной цифры на номерах SIM-карт.

Рекомендации

внешняя ссылка