Knowledge

Verhoeff algorithm

Source 📝

1037: 610: 58:
His goals were also practical, and he based the evaluation of different codes on live data from the Dutch postal system, using a weighted points system for different kinds of error. The analysis broke the errors down into a number of categories: first, by how many digits are in error; for those with
2037:
without needing to understand how to generate those tables from the underlying group and permutation theory. This is more properly considered a family of algorithms, as other permutations work too. Verhoeff's notes that the particular permutation, given above, is special as it has the property of
50:
Verhoeff had the goal of finding a decimal code—one where the check digit is a single decimal digit—which detected all single-digit errors and all transpositions of adjacent digits. At the time, supposed proofs of the nonexistence of these codes made base-11 codes popular, for example in the
795: 422: 115:). Additionally there are omitted and added digits. Although the frequencies of some of these kinds of errors might be small, some codes might be immune to them in addition to the primary goals of detecting all singles and transpositions. 1401: 1689: 1032:{\displaystyle f={\begin{pmatrix}e&r&r^{2}&r^{3}&r^{4}&s&rs&r^{2}s&r^{3}s&r^{4}s\\r&s&r^{2}s&rs&r^{2}&r^{3}s&r^{3}&e&r^{4}s&r^{4}\end{pmatrix}}} 1533: 2029: 1828: 1916: 2081: 118:
The phonetic errors in particular showed linguistic effects, because in Dutch, numbers are typically read in pairs; and also while 50 sounds similar to 15 in Dutch, 80 doesn't sound like 18.
605:{\displaystyle m={\begin{pmatrix}0&1&2&3&4&5&6&7&8&9\\e&r&r^{2}&r^{3}&r^{4}&s&rs&r^{2}s&r^{3}s&r^{4}s\end{pmatrix}}} 3316: 1216: 1140: 2041:
The strengths of the algorithm are that it detects all transliteration and transposition errors, and additionally most twin, twin jump, jump transposition and phonetic errors.
740: 789: 1084: 416: 2737: 39:
algorithm which detects all single-digit errors, and all transposition errors involving two adjacent digits, which was at the time thought impossible with such a code.
3396: 2597: 2152: 1562: 1245: 639: 365: 338: 3350: 1272: 1422: 1265: 682: 659: 1569: 3966: 1429: 3880: 3772: 1925: 1698: 2044:
The main weakness of the Verhoeff algorithm is its complexity. The calculations required cannot easily be expressed as a formula in say
52: 3745: 3716: 42:
The method was independently discovered by H. Peter Gumm in 1985, this time including a formal proof and an extension to any base.
1837: 2047: 3961: 3971: 3956: 3254: 1145: 1089: 687: 121:
Taking six-digit numbers as an example, Verhoeff reported the following classification of the errors:.
1920:
This is the same reflection being iteratively multiplied. Use that reflections are their own inverse.
748: 310:
The general idea of the algorithm is to represent each of the digits (0 through 9) as elements of the
3674: 1044: 370: 3872: 2695: 3886: 3876: 3778: 3768: 3741: 3712: 3704: 3762: 3733: 3840: 3809: 3682: 3366: 2567: 2122: 32: 1540: 1396:{\displaystyle f(a_{1})\cdot f^{2}(a_{2})\cdot \ldots \cdot f^{k}(a_{k})\cdot f^{k+1}(c)=e} 1223: 617: 343: 316: 3700: 28: 3329: 3220:
out of the individual digits of the number, taken from right to left (rightmost digit is
3169:
to each digit based on its position in the number. This is actually a single permutation
3678: 3865: 3648: 2084: 1407: 1250: 667: 644: 311: 3950: 2095:
The Verhoeff algorithm can be implemented using three tables: a multiplication table
3941: 3140:
represents the multiplicative inverse of a digit, that is, the value that satisfies
3797: 3092: 2034: 3166: 3096: 36: 3813: 3686: 1684:{\displaystyle f(r^{2})\cdot f^{2}(r^{4})\cdot f^{3}(r^{3}s)\cdot f^{4}(s)=e} 1537:
For example the check digit for 248 is 5. To verify this, use the mapping to
3798:"A new class of check-digit methods for arbitrary number systems (Corresp.)" 3845: 3828: 2083:. Lookup tables are required for easy calculation. A similar code is the 24: 1528:{\displaystyle c=f^{-1-k}\left(\prod _{n=1}^{k}f^{n}(a_{n})^{-1}\right)} 2024:{\displaystyle (r^{2}s\cdot r^{2}s)\cdot (r^{2}s\cdot r^{2}s)=e^{2}=e} 1823:{\displaystyle f^{4}(s)=f^{3}(r^{3}s)=f^{2}(r^{4})=f(r^{2})=r^{2}s} 367:, manipulate these, then map back into digits. Let this mapping be 3890: 3782: 3764:
The Edge of the Universe: Celebrating Ten Years of Math Horizons
3280: 3408: 2110: 1911:{\displaystyle r^{2}s\cdot r^{2}s\cdot r^{2}s\cdot r^{2}s=e} 3212:
The Verhoeff checksum calculation is performed as follows:
2076:{\displaystyle {\displaystyle \mathbb {Z} /10\mathbb {Z} }} 1220:
Using multiplicative notation for the group operation of
3361:, perform the calculation: the correct check digit is 2033:
In practice the algorithm is implemented using simple
810: 437: 3705:"5. Group Theory and the Verhoeff Check Digit Scheme" 3369: 3332: 3257: 2698: 2570: 2125: 2052: 2050: 1928: 1840: 1701: 1572: 1543: 1432: 1410: 1275: 1253: 1226: 1148: 1092: 1047: 798: 751: 690: 670: 647: 620: 425: 373: 346: 319: 3761:
Haunsperger, Deanna; Kennedy, Stephen, eds. (2006).
3711:. Mathematical Association of America. p. 153. 3087:, is based on multiplication in the dihedral group D 3767:. Mathematical Association of America. p. 38. 2781: 3864: 3390: 3344: 3310: 2731: 2591: 2146: 2075: 2023: 1910: 1822: 1683: 1556: 1527: 1416: 1395: 1259: 1239: 1210: 1134: 1078: 1031: 783: 734: 676: 653: 633: 604: 410: 359: 332: 1564:and insert into the LHS of the previous equation 3942:Detailed description of the Verhoeff algorithm 3858: 3856: 3709:Identification Numbers and Check Digit Schemes 1693:To evaluate this permutation quickly use that 8: 3324:The original number is valid if and only if 3738:Coding for Data and Computer Communications 3095:of the group. Note that this group is not 1424:is explicitly given by inverse permutation 3311:{\displaystyle d(c,p(i{\bmod {8}},n_{i}))} 3844: 3368: 3331: 3296: 3283: 3279: 3256: 2697: 2569: 2124: 2067: 2066: 2058: 2054: 2053: 2051: 2049: 2009: 1990: 1974: 1952: 1936: 1927: 1893: 1877: 1861: 1845: 1839: 1811: 1795: 1773: 1760: 1741: 1728: 1706: 1700: 1660: 1641: 1628: 1612: 1599: 1583: 1571: 1548: 1542: 1511: 1501: 1488: 1478: 1467: 1443: 1431: 1409: 1366: 1350: 1337: 1315: 1302: 1286: 1274: 1252: 1247:, the check digit is then simply a value 1231: 1225: 1202: 1165: 1147: 1126: 1110: 1097: 1091: 1058: 1046: 1015: 1000: 983: 968: 956: 933: 906: 891: 876: 851: 839: 827: 805: 797: 775: 762: 750: 723: 695: 689: 669: 646: 625: 619: 585: 570: 555: 530: 518: 506: 432: 424: 402: 372: 351: 345: 324: 318: 3925: 3913: 3671:Error Detecting Decimal Codes (Tract 29) 3634:is zero, so the check is correct. 3537: 3422: 2687: 2554: 2114: 2038:detecting 95.3% of the phonetic errors. 123: 3802:IEEE Transactions on Information Theory 3734:"§2.11 The Verhoeff Check Digit Method" 3661: 1211:{\displaystyle f(f(r^{3}))=f(rs)=r^{3}} 31:first published by Dutch mathematician 3829:"An improved decimal redundancy check" 3673:. The Mathematical Centre, Amsterdam. 3651:, earlier (1960) check digit algorithm 3871:(7th ed.). Brooks/Cole. p.  2690: 2117: 16:Way to detect errors in decimal codes 7: 3357:To generate a check digit, append a 664:For example given the code 248 then 35:in 1969. It was the first decimal 1135:{\displaystyle f^{2}(r^{3})=r^{3}} 14: 735:{\displaystyle a_{3}=m(8)=r^{3}s} 784:{\displaystyle f:D_{5}\to D_{5}} 641:and let the number of digits be 2087:, which has similar qualities. 59:two digits in error, there are 3967:Error detection and correction 3385: 3379: 3305: 3302: 3273: 3261: 3099:, that is, for some values of 2726: 2702: 2586: 2580: 2141: 2129: 1999: 1967: 1961: 1929: 1801: 1788: 1779: 1766: 1750: 1734: 1718: 1712: 1672: 1666: 1650: 1634: 1618: 1605: 1589: 1576: 1508: 1494: 1384: 1378: 1356: 1343: 1321: 1308: 1292: 1279: 1192: 1183: 1174: 1171: 1158: 1152: 1116: 1103: 1064: 1051: 768: 713: 707: 395: 392: 380: 1: 3867:Contemporary Abstract Algebra 3827:Sisson, Roger L. (May 1958). 3035: 3000: 2965: 2930: 2895: 2860: 2825: 2780: 2748: 2689: 2675: 2667: 2659: 2651: 2643: 2635: 2627: 2619: 2611: 2556: 2515: 2480: 2445: 2410: 2375: 2340: 2305: 2270: 2235: 2195: 2163: 2116: 125: 3740:. Springer. pp. 56–58. 3519:is 2, so the check digit is 3863:Gallian, Joseph A. (2010). 1079:{\displaystyle f(r^{3})=rs} 745:Now define the permutation 411:{\displaystyle m:\to D_{5}} 294: 284: 281: 273: 270: 262: 259: 251: 248: 240: 237: 229: 226: 218: 215: 207: 204: 196: 193: 185: 182: 174: 171: 163: 160: 149: 146: 3988: 3245:starting at zero, replace 3173:applied iteratively; i.e. 2742: 2732:{\displaystyle p(pos,num)} 2196: 2157: 2103:, and a permutation table 3833:Communications of the ACM 3796:Gumm, H. (January 1985). 340:. That is, map digits to 289: 278: 267: 256: 245: 154: 3814:10.1109/TIT.1985.1056991 3687:10.1002/zamm.19710510323 3230:Initialize the checksum 3732:Salomon, David (2005). 3392: 3391:{\displaystyle inv(c)} 3346: 3312: 3171:(1 5 8 9 4 2 7 0)(3 6) 3159:The permutation table 2733: 2593: 2592:{\displaystyle inv(j)} 2148: 2147:{\displaystyle d(j,k)} 2077: 2025: 1912: 1824: 1685: 1558: 1529: 1483: 1418: 1397: 1261: 1241: 1212: 1136: 1080: 1033: 785: 736: 678: 655: 635: 606: 412: 361: 334: 3902:verhoeff check digit. 3846:10.1145/368819.368854 3669:Verhoeff, J. (1969). 3393: 3347: 3313: 2734: 2594: 2149: 2091:Table-based algorithm 2078: 2026: 1913: 1825: 1686: 1559: 1557:{\displaystyle D_{5}} 1530: 1463: 1419: 1398: 1262: 1242: 1240:{\displaystyle D_{5}} 1213: 1137: 1086:. Another example is 1081: 1034: 786: 737: 679: 656: 636: 634:{\displaystyle a_{n}} 614:Let the nth digit be 607: 413: 362: 360:{\displaystyle D_{5}} 335: 333:{\displaystyle D_{5}} 3367: 3330: 3255: 3091:. and is simply the 2696: 2568: 2123: 2048: 1926: 1838: 1699: 1570: 1541: 1430: 1408: 1273: 1251: 1224: 1146: 1090: 1045: 796: 749: 688: 668: 645: 618: 423: 371: 344: 317: 3962:Checksum algorithms 3679:1971ZaMM...51..240N 3345:{\displaystyle c=0} 2099:, an inverse table 202:Jump transpositions 81:jump transpositions 3972:1969 introductions 3957:Modular arithmetic 3416:a check digit for 3388: 3342: 3308: 3134:The inverse table 2729: 2589: 2144: 2073: 2071: 2021: 1908: 1820: 1681: 1554: 1525: 1414: 1393: 1257: 1237: 1208: 1132: 1076: 1029: 1023: 781: 732: 674: 651: 631: 602: 596: 408: 357: 330: 21:Verhoeff algorithm 3882:978-0-547-16509-7 3774:978-0-88385-555-3 3639: 3638: 3629: 3628: 3523:(2), which is 3. 3514: 3513: 3081:The first table, 3078: 3077: 3071: 3070: 2684: 2683: 2551: 2550: 1417:{\displaystyle c} 1260:{\displaystyle c} 677:{\displaystyle k} 654:{\displaystyle k} 303: 302: 224:Other jump errors 3979: 3929: 3923: 3917: 3911: 3905: 3904: 3899: 3897: 3870: 3860: 3851: 3850: 3848: 3824: 3818: 3817: 3793: 3787: 3786: 3758: 3752: 3751: 3729: 3723: 3722: 3701:Kirtland, Joseph 3697: 3691: 3690: 3666: 3538: 3531:the check digit 3423: 3409: 3399: 3397: 3395: 3394: 3389: 3360: 3353: 3351: 3349: 3348: 3343: 3319: 3317: 3315: 3314: 3309: 3301: 3300: 3288: 3287: 3216:Create an array 3172: 2788: 2740: 2738: 2736: 2735: 2730: 2688: 2600: 2598: 2596: 2595: 2590: 2555: 2155: 2153: 2151: 2150: 2145: 2115: 2111: 2082: 2080: 2079: 2074: 2072: 2070: 2062: 2057: 2030: 2028: 2027: 2022: 2014: 2013: 1995: 1994: 1979: 1978: 1957: 1956: 1941: 1940: 1917: 1915: 1914: 1909: 1898: 1897: 1882: 1881: 1866: 1865: 1850: 1849: 1829: 1827: 1826: 1821: 1816: 1815: 1800: 1799: 1778: 1777: 1765: 1764: 1746: 1745: 1733: 1732: 1711: 1710: 1690: 1688: 1687: 1682: 1665: 1664: 1646: 1645: 1633: 1632: 1617: 1616: 1604: 1603: 1588: 1587: 1563: 1561: 1560: 1555: 1553: 1552: 1534: 1532: 1531: 1526: 1524: 1520: 1519: 1518: 1506: 1505: 1493: 1492: 1482: 1477: 1457: 1456: 1423: 1421: 1420: 1415: 1402: 1400: 1399: 1394: 1377: 1376: 1355: 1354: 1342: 1341: 1320: 1319: 1307: 1306: 1291: 1290: 1266: 1264: 1263: 1258: 1246: 1244: 1243: 1238: 1236: 1235: 1217: 1215: 1214: 1209: 1207: 1206: 1170: 1169: 1141: 1139: 1138: 1133: 1131: 1130: 1115: 1114: 1102: 1101: 1085: 1083: 1082: 1077: 1063: 1062: 1038: 1036: 1035: 1030: 1028: 1027: 1020: 1019: 1005: 1004: 988: 987: 973: 972: 961: 960: 938: 937: 911: 910: 896: 895: 881: 880: 856: 855: 844: 843: 832: 831: 790: 788: 787: 782: 780: 779: 767: 766: 741: 739: 738: 733: 728: 727: 700: 699: 683: 681: 680: 675: 660: 658: 657: 652: 640: 638: 637: 632: 630: 629: 611: 609: 608: 603: 601: 600: 590: 589: 575: 574: 560: 559: 535: 534: 523: 522: 511: 510: 417: 415: 414: 409: 407: 406: 366: 364: 363: 358: 356: 355: 339: 337: 336: 331: 329: 328: 127:Digits in error 124: 53:ISBN check digit 33:Jacobus Verhoeff 3987: 3986: 3982: 3981: 3980: 3978: 3977: 3976: 3947: 3946: 3938: 3933: 3932: 3924: 3920: 3912: 3908: 3895: 3893: 3883: 3862: 3861: 3854: 3826: 3825: 3821: 3795: 3794: 3790: 3775: 3760: 3759: 3755: 3748: 3731: 3730: 3726: 3719: 3699: 3698: 3694: 3668: 3667: 3663: 3658: 3645: 3640: 3562: 3550: 3447: 3435: 3406: 3365: 3364: 3362: 3358: 3328: 3327: 3325: 3292: 3253: 3252: 3250: 3237:For each index 3226: 3170: 3090: 3079: 2789: 2783: 2694: 2693: 2691: 2566: 2565: 2563: 2121: 2120: 2118: 2093: 2046: 2045: 2005: 1986: 1970: 1948: 1932: 1924: 1923: 1889: 1873: 1857: 1841: 1836: 1835: 1807: 1791: 1769: 1756: 1737: 1724: 1702: 1697: 1696: 1656: 1637: 1624: 1608: 1595: 1579: 1568: 1567: 1544: 1539: 1538: 1507: 1497: 1484: 1462: 1458: 1439: 1428: 1427: 1406: 1405: 1362: 1346: 1333: 1311: 1298: 1282: 1271: 1270: 1249: 1248: 1227: 1222: 1221: 1198: 1161: 1144: 1143: 1122: 1106: 1093: 1088: 1087: 1054: 1043: 1042: 1022: 1021: 1011: 1009: 996: 994: 989: 979: 977: 964: 962: 952: 950: 942: 929: 927: 922: 916: 915: 902: 900: 887: 885: 872: 870: 862: 857: 847: 845: 835: 833: 823: 821: 816: 806: 794: 793: 771: 758: 747: 746: 719: 691: 686: 685: 666: 665: 643: 642: 621: 616: 615: 595: 594: 581: 579: 566: 564: 551: 549: 541: 536: 526: 524: 514: 512: 502: 500: 495: 489: 488: 483: 478: 473: 468: 463: 458: 453: 448: 443: 433: 421: 420: 398: 369: 368: 347: 342: 341: 320: 315: 314: 308: 130:Classification 48: 29:error detection 17: 12: 11: 5: 3985: 3983: 3975: 3974: 3969: 3964: 3959: 3949: 3948: 3945: 3944: 3937: 3936:External links 3934: 3931: 3930: 3918: 3906: 3881: 3852: 3819: 3808:(1): 102–105. 3788: 3773: 3753: 3746: 3724: 3717: 3692: 3660: 3659: 3657: 3654: 3653: 3652: 3649:Luhn algorithm 3644: 3641: 3637: 3636: 3627: 3626: 3623: 3620: 3617: 3613: 3612: 3609: 3606: 3603: 3599: 3598: 3595: 3592: 3589: 3585: 3584: 3581: 3578: 3575: 3571: 3570: 3565: 3560: 3552: 3548: 3544: 3525: 3512: 3511: 3508: 3505: 3502: 3498: 3497: 3494: 3491: 3488: 3484: 3483: 3480: 3477: 3474: 3470: 3469: 3466: 3463: 3460: 3456: 3455: 3450: 3445: 3437: 3433: 3429: 3407: 3405: 3402: 3387: 3384: 3381: 3378: 3375: 3372: 3341: 3338: 3335: 3322: 3321: 3307: 3304: 3299: 3295: 3291: 3286: 3282: 3278: 3275: 3272: 3269: 3266: 3263: 3260: 3235: 3228: 3224: 3088: 3076: 3075: 3069: 3068: 3065: 3062: 3059: 3056: 3053: 3050: 3047: 3044: 3041: 3038: 3034: 3033: 3030: 3027: 3024: 3021: 3018: 3015: 3012: 3009: 3006: 3003: 2999: 2998: 2995: 2992: 2989: 2986: 2983: 2980: 2977: 2974: 2971: 2968: 2964: 2963: 2960: 2957: 2954: 2951: 2948: 2945: 2942: 2939: 2936: 2933: 2929: 2928: 2925: 2922: 2919: 2916: 2913: 2910: 2907: 2904: 2901: 2898: 2894: 2893: 2890: 2887: 2884: 2881: 2878: 2875: 2872: 2869: 2866: 2863: 2859: 2858: 2855: 2852: 2849: 2846: 2843: 2840: 2837: 2834: 2831: 2828: 2824: 2823: 2820: 2817: 2814: 2811: 2808: 2805: 2802: 2799: 2796: 2793: 2790: 2782: 2779: 2778: 2775: 2772: 2769: 2766: 2763: 2760: 2757: 2754: 2751: 2747: 2746: 2741: 2728: 2725: 2722: 2719: 2716: 2713: 2710: 2707: 2704: 2701: 2685: 2682: 2681: 2678: 2674: 2673: 2670: 2666: 2665: 2662: 2658: 2657: 2654: 2650: 2649: 2646: 2642: 2641: 2638: 2634: 2633: 2630: 2626: 2625: 2622: 2618: 2617: 2614: 2610: 2609: 2606: 2602: 2601: 2588: 2585: 2582: 2579: 2576: 2573: 2561: 2552: 2549: 2548: 2545: 2542: 2539: 2536: 2533: 2530: 2527: 2524: 2521: 2518: 2514: 2513: 2510: 2507: 2504: 2501: 2498: 2495: 2492: 2489: 2486: 2483: 2479: 2478: 2475: 2472: 2469: 2466: 2463: 2460: 2457: 2454: 2451: 2448: 2444: 2443: 2440: 2437: 2434: 2431: 2428: 2425: 2422: 2419: 2416: 2413: 2409: 2408: 2405: 2402: 2399: 2396: 2393: 2390: 2387: 2384: 2381: 2378: 2374: 2373: 2370: 2367: 2364: 2361: 2358: 2355: 2352: 2349: 2346: 2343: 2339: 2338: 2335: 2332: 2329: 2326: 2323: 2320: 2317: 2314: 2311: 2308: 2304: 2303: 2300: 2297: 2294: 2291: 2288: 2285: 2282: 2279: 2276: 2273: 2269: 2268: 2265: 2262: 2259: 2256: 2253: 2250: 2247: 2244: 2241: 2238: 2234: 2233: 2230: 2227: 2224: 2221: 2218: 2215: 2212: 2209: 2206: 2203: 2200: 2194: 2193: 2190: 2187: 2184: 2181: 2178: 2175: 2172: 2169: 2166: 2162: 2161: 2156: 2143: 2140: 2137: 2134: 2131: 2128: 2109: 2092: 2089: 2085:Damm algorithm 2069: 2065: 2061: 2056: 2020: 2017: 2012: 2008: 2004: 2001: 1998: 1993: 1989: 1985: 1982: 1977: 1973: 1969: 1966: 1963: 1960: 1955: 1951: 1947: 1944: 1939: 1935: 1931: 1907: 1904: 1901: 1896: 1892: 1888: 1885: 1880: 1876: 1872: 1869: 1864: 1860: 1856: 1853: 1848: 1844: 1819: 1814: 1810: 1806: 1803: 1798: 1794: 1790: 1787: 1784: 1781: 1776: 1772: 1768: 1763: 1759: 1755: 1752: 1749: 1744: 1740: 1736: 1731: 1727: 1723: 1720: 1717: 1714: 1709: 1705: 1680: 1677: 1674: 1671: 1668: 1663: 1659: 1655: 1652: 1649: 1644: 1640: 1636: 1631: 1627: 1623: 1620: 1615: 1611: 1607: 1602: 1598: 1594: 1591: 1586: 1582: 1578: 1575: 1551: 1547: 1523: 1517: 1514: 1510: 1504: 1500: 1496: 1491: 1487: 1481: 1476: 1473: 1470: 1466: 1461: 1455: 1452: 1449: 1446: 1442: 1438: 1435: 1413: 1392: 1389: 1386: 1383: 1380: 1375: 1372: 1369: 1365: 1361: 1358: 1353: 1349: 1345: 1340: 1336: 1332: 1329: 1326: 1323: 1318: 1314: 1310: 1305: 1301: 1297: 1294: 1289: 1285: 1281: 1278: 1256: 1234: 1230: 1205: 1201: 1197: 1194: 1191: 1188: 1185: 1182: 1179: 1176: 1173: 1168: 1164: 1160: 1157: 1154: 1151: 1129: 1125: 1121: 1118: 1113: 1109: 1105: 1100: 1096: 1075: 1072: 1069: 1066: 1061: 1057: 1053: 1050: 1026: 1018: 1014: 1010: 1008: 1003: 999: 995: 993: 990: 986: 982: 978: 976: 971: 967: 963: 959: 955: 951: 949: 946: 943: 941: 936: 932: 928: 926: 923: 921: 918: 917: 914: 909: 905: 901: 899: 894: 890: 886: 884: 879: 875: 871: 869: 866: 863: 861: 858: 854: 850: 846: 842: 838: 834: 830: 826: 822: 820: 817: 815: 812: 811: 809: 804: 801: 778: 774: 770: 765: 761: 757: 754: 731: 726: 722: 718: 715: 712: 709: 706: 703: 698: 694: 673: 650: 628: 624: 599: 593: 588: 584: 580: 578: 573: 569: 565: 563: 558: 554: 550: 548: 545: 542: 540: 537: 533: 529: 525: 521: 517: 513: 509: 505: 501: 499: 496: 494: 491: 490: 487: 484: 482: 479: 477: 474: 472: 469: 467: 464: 462: 459: 457: 454: 452: 449: 447: 444: 442: 439: 438: 436: 431: 428: 405: 401: 397: 394: 391: 388: 385: 382: 379: 376: 354: 350: 327: 323: 312:dihedral group 307: 304: 301: 300: 298: 293: 287: 286: 283: 280: 276: 275: 272: 269: 265: 264: 261: 258: 254: 253: 250: 247: 243: 242: 239: 236: 232: 231: 228: 225: 221: 220: 217: 214: 210: 209: 206: 203: 199: 198: 195: 192: 191:Other adjacent 188: 187: 184: 181: 177: 176: 173: 170: 166: 165: 162: 159: 158:Transpositions 156: 152: 151: 148: 145: 142: 138: 137: 134: 131: 128: 61:transpositions 47: 44: 15: 13: 10: 9: 6: 4: 3: 2: 3984: 3973: 3970: 3968: 3965: 3963: 3960: 3958: 3955: 3954: 3952: 3943: 3940: 3939: 3935: 3927: 3926:Verhoeff 1969 3922: 3919: 3915: 3914:Verhoeff 1969 3910: 3907: 3903: 3892: 3888: 3884: 3878: 3874: 3869: 3868: 3859: 3857: 3853: 3847: 3842: 3838: 3834: 3830: 3823: 3820: 3815: 3811: 3807: 3803: 3799: 3792: 3789: 3784: 3780: 3776: 3770: 3766: 3765: 3757: 3754: 3749: 3747:0-387-21245-0 3743: 3739: 3735: 3728: 3725: 3720: 3718:0-88385-720-0 3714: 3710: 3706: 3702: 3696: 3693: 3688: 3684: 3680: 3676: 3672: 3665: 3662: 3655: 3650: 3647: 3646: 3642: 3635: 3633: 3624: 3621: 3618: 3615: 3614: 3610: 3607: 3604: 3601: 3600: 3596: 3593: 3590: 3587: 3586: 3582: 3579: 3576: 3573: 3572: 3569: 3566: 3563: 3556: 3553: 3551: 3545: 3543: 3540: 3539: 3536: 3534: 3530: 3526: 3524: 3522: 3518: 3509: 3506: 3503: 3500: 3499: 3495: 3492: 3489: 3486: 3485: 3481: 3478: 3475: 3472: 3471: 3467: 3464: 3461: 3458: 3457: 3454: 3451: 3448: 3441: 3438: 3436: 3430: 3428: 3425: 3424: 3421: 3419: 3415: 3411: 3410: 3403: 3401: 3382: 3376: 3373: 3370: 3355: 3339: 3336: 3333: 3297: 3293: 3289: 3284: 3276: 3270: 3267: 3264: 3258: 3248: 3244: 3241:of the array 3240: 3236: 3233: 3229: 3223: 3219: 3215: 3214: 3213: 3210: 3208: 3204: 3200: 3196: 3192: 3188: 3184: 3180: 3176: 3168: 3164: 3163: 3157: 3155: 3151: 3147: 3143: 3139: 3138: 3132: 3130: 3126: 3122: 3118: 3114: 3110: 3106: 3102: 3098: 3094: 3086: 3085: 3074: 3066: 3063: 3060: 3057: 3054: 3051: 3048: 3045: 3042: 3039: 3036: 3031: 3028: 3025: 3022: 3019: 3016: 3013: 3010: 3007: 3004: 3001: 2996: 2993: 2990: 2987: 2984: 2981: 2978: 2975: 2972: 2969: 2966: 2961: 2958: 2955: 2952: 2949: 2946: 2943: 2940: 2937: 2934: 2931: 2926: 2923: 2920: 2917: 2914: 2911: 2908: 2905: 2902: 2899: 2896: 2891: 2888: 2885: 2882: 2879: 2876: 2873: 2870: 2867: 2864: 2861: 2856: 2853: 2850: 2847: 2844: 2841: 2838: 2835: 2832: 2829: 2826: 2821: 2818: 2815: 2812: 2809: 2806: 2803: 2800: 2797: 2794: 2791: 2786: 2776: 2773: 2770: 2767: 2764: 2761: 2758: 2755: 2752: 2749: 2745: 2723: 2720: 2717: 2714: 2711: 2708: 2705: 2699: 2686: 2679: 2676: 2671: 2668: 2663: 2660: 2655: 2652: 2647: 2644: 2639: 2636: 2631: 2628: 2623: 2620: 2615: 2612: 2607: 2604: 2603: 2583: 2577: 2574: 2571: 2562: 2560: 2557: 2553: 2546: 2543: 2540: 2537: 2534: 2531: 2528: 2525: 2522: 2519: 2516: 2511: 2508: 2505: 2502: 2499: 2496: 2493: 2490: 2487: 2484: 2481: 2476: 2473: 2470: 2467: 2464: 2461: 2458: 2455: 2452: 2449: 2446: 2441: 2438: 2435: 2432: 2429: 2426: 2423: 2420: 2417: 2414: 2411: 2406: 2403: 2400: 2397: 2394: 2391: 2388: 2385: 2382: 2379: 2376: 2371: 2368: 2365: 2362: 2359: 2356: 2353: 2350: 2347: 2344: 2341: 2336: 2333: 2330: 2327: 2324: 2321: 2318: 2315: 2312: 2309: 2306: 2301: 2298: 2295: 2292: 2289: 2286: 2283: 2280: 2277: 2274: 2271: 2266: 2263: 2260: 2257: 2254: 2251: 2248: 2245: 2242: 2239: 2236: 2231: 2228: 2225: 2222: 2219: 2216: 2213: 2210: 2207: 2204: 2201: 2199: 2191: 2188: 2185: 2182: 2179: 2176: 2173: 2170: 2167: 2164: 2160: 2138: 2135: 2132: 2126: 2113: 2112: 2108: 2106: 2102: 2098: 2090: 2088: 2086: 2063: 2059: 2042: 2039: 2036: 2035:lookup tables 2031: 2018: 2015: 2010: 2006: 2002: 1996: 1991: 1987: 1983: 1980: 1975: 1971: 1964: 1958: 1953: 1949: 1945: 1942: 1937: 1933: 1921: 1918: 1905: 1902: 1899: 1894: 1890: 1886: 1883: 1878: 1874: 1870: 1867: 1862: 1858: 1854: 1851: 1846: 1842: 1833: 1830: 1817: 1812: 1808: 1804: 1796: 1792: 1785: 1782: 1774: 1770: 1761: 1757: 1753: 1747: 1742: 1738: 1729: 1725: 1721: 1715: 1707: 1703: 1694: 1691: 1678: 1675: 1669: 1661: 1657: 1653: 1647: 1642: 1638: 1629: 1625: 1621: 1613: 1609: 1600: 1596: 1592: 1584: 1580: 1573: 1565: 1549: 1545: 1535: 1521: 1515: 1512: 1502: 1498: 1489: 1485: 1479: 1474: 1471: 1468: 1464: 1459: 1453: 1450: 1447: 1444: 1440: 1436: 1433: 1425: 1411: 1403: 1390: 1387: 1381: 1373: 1370: 1367: 1363: 1359: 1351: 1347: 1338: 1334: 1330: 1327: 1324: 1316: 1312: 1303: 1299: 1295: 1287: 1283: 1276: 1268: 1254: 1232: 1228: 1218: 1203: 1199: 1195: 1189: 1186: 1180: 1177: 1166: 1162: 1155: 1149: 1127: 1123: 1119: 1111: 1107: 1098: 1094: 1073: 1070: 1067: 1059: 1055: 1048: 1039: 1024: 1016: 1012: 1006: 1001: 997: 991: 984: 980: 974: 969: 965: 957: 953: 947: 944: 939: 934: 930: 924: 919: 912: 907: 903: 897: 892: 888: 882: 877: 873: 867: 864: 859: 852: 848: 840: 836: 828: 824: 818: 813: 807: 802: 799: 791: 776: 772: 763: 759: 755: 752: 743: 729: 724: 720: 716: 710: 704: 701: 696: 692: 671: 662: 648: 626: 622: 612: 597: 591: 586: 582: 576: 571: 567: 561: 556: 552: 546: 543: 538: 531: 527: 519: 515: 507: 503: 497: 492: 485: 480: 475: 470: 465: 460: 455: 450: 445: 440: 434: 429: 426: 418: 403: 399: 389: 386: 383: 377: 374: 352: 348: 325: 321: 313: 305: 299: 297: 292: 288: 277: 266: 255: 244: 234: 233: 223: 222: 212: 211: 201: 200: 190: 189: 179: 178: 168: 167: 157: 153: 144:Transcription 143: 140: 139: 135: 132: 129: 126: 122: 119: 116: 114: 110: 106: 102: 98: 94: 90: 86: 82: 78: 74: 70: 66: 62: 56: 54: 45: 43: 40: 38: 34: 30: 26: 22: 3928:, p. 83 3921: 3916:, p. 95 3909: 3901: 3894:. Retrieved 3866: 3839:(5): 10–12. 3836: 3832: 3822: 3805: 3801: 3791: 3763: 3756: 3737: 3727: 3708: 3695: 3670: 3664: 3631: 3630: 3567: 3558: 3554: 3546: 3541: 3532: 3528: 3527: 3520: 3516: 3515: 3452: 3443: 3439: 3431: 3426: 3417: 3413: 3412: 3356: 3323: 3246: 3242: 3238: 3231: 3221: 3217: 3211: 3206: 3202: 3198: 3194: 3190: 3186: 3182: 3178: 3174: 3161: 3160: 3158: 3153: 3149: 3145: 3141: 3136: 3135: 3133: 3128: 3124: 3120: 3116: 3112: 3108: 3104: 3100: 3093:Cayley table 3083: 3082: 3080: 3072: 2784: 2743: 2558: 2197: 2158: 2104: 2100: 2096: 2094: 2043: 2040: 2032: 1922: 1919: 1834: 1832:to get that 1831: 1695: 1692: 1566: 1536: 1426: 1404: 1269: 1219: 1041:For example 1040: 792: 744: 663: 613: 419: 309: 295: 290: 120: 117: 112: 108: 104: 100: 96: 92: 88: 84: 80: 76: 72: 68: 64: 60: 57: 49: 41: 20: 18: 3167:permutation 3097:commutative 306:Description 37:check digit 3951:Categories 3896:August 26, 3891:2008940386 3783:2005937266 3656:References 3165:applies a 1267:such that 213:Jump Twins 136:Frequency 105:jump twins 1984:⋅ 1965:⋅ 1946:⋅ 1887:⋅ 1871:⋅ 1855:⋅ 1654:⋅ 1622:⋅ 1593:⋅ 1513:− 1465:∏ 1451:− 1445:− 1360:⋅ 1331:⋅ 1328:… 1325:⋅ 1296:⋅ 769:→ 684:is 3 and 396:→ 79:→ 'bb'), 3703:(2001). 3643:See also 3529:Validate 3414:Generate 3404:Examples 3234:to zero. 3227:, etc.). 3156:)) = 0. 180:Phonetic 93:phonetic 25:checksum 3675:Bibcode 3398:⁠ 3363:⁠ 3352:⁠ 3326:⁠ 3318:⁠ 3251:⁠ 2787:(mod 8) 2739:⁠ 2692:⁠ 2599:⁠ 2564:⁠ 2154:⁠ 2119:⁠ 164:10.21% 150:79.05% 103:), and 3889:  3879:  3781:  3771:  3744:  3715:  3073: 1142:since 296:12,112 285:1.34% 274:1.81% 263:0.97% 252:1.40% 241:0.81% 230:0.36% 219:0.29% 208:0.82% 197:1.92% 186:0.49% 175:0.55% 133:Count 3249:with 291:Total 235:Other 169:Twins 161:1,237 147:9,574 73:twins 46:Goals 23:is a 3898:2011 3887:LCCN 3877:ISBN 3779:LCCN 3769:ISBN 3742:ISBN 3713:ISBN 3533:2363 3209:)). 3189:) = 3119:) ≠ 3103:and 27:for 19:The 3873:111 3841:doi 3810:doi 3683:doi 3559:i,n 3521:inv 3444:i,n 3418:236 3281:mod 3150:inv 3137:inv 3131:). 2785:pos 2744:num 2101:inv 742:. 282:162 271:219 260:118 249:169 194:232 113:cbc 109:aba 91:), 89:cba 85:abc 71:), 3953:: 3900:. 3885:. 3875:. 3855:^ 3835:. 3831:. 3806:31 3804:. 3800:. 3777:. 3736:. 3707:. 3681:. 3625:0 3611:4 3597:1 3583:3 3564:) 3535:: 3510:2 3496:1 3482:3 3468:0 3449:) 3420:: 3400:. 3354:. 3243:n, 3197:, 3148:, 3127:, 3107:, 3067:8 3037:7 3032:5 3002:6 2997:1 2967:5 2962:0 2932:4 2927:7 2897:3 2892:2 2862:2 2857:4 2827:1 2822:9 2792:0 2777:9 2774:8 2771:7 2768:6 2765:5 2762:4 2759:3 2756:2 2753:1 2750:0 2680:9 2677:9 2672:8 2669:8 2664:7 2661:7 2656:6 2653:6 2648:5 2645:5 2640:1 2637:4 2632:2 2629:3 2624:3 2621:2 2616:4 2613:1 2608:0 2605:0 2547:0 2517:9 2512:4 2482:8 2477:3 2447:7 2442:2 2412:6 2407:1 2377:5 2372:8 2342:4 2337:7 2307:3 2302:6 2272:2 2267:5 2237:1 2232:9 2202:0 2192:9 2189:8 2186:7 2183:6 2180:5 2177:4 2174:3 2171:2 2168:1 2165:0 2107:. 2064:10 661:. 238:98 227:43 216:35 205:99 183:59 172:67 111:→ 101:a0 99:→ 97:1a 87:→ 77:aa 69:ba 67:→ 65:ab 55:. 3849:. 3843:: 3837:1 3816:. 3812:: 3785:. 3750:. 3721:. 3689:. 3685:: 3677:: 3632:c 3622:1 3619:2 3616:3 3608:3 3605:3 3602:2 3594:3 3591:6 3588:1 3580:3 3577:3 3574:0 3568:c 3561:i 3557:( 3555:p 3549:i 3547:n 3542:i 3517:c 3507:1 3504:2 3501:3 3493:3 3490:3 3487:2 3479:3 3476:6 3473:1 3465:0 3462:0 3459:0 3453:c 3446:i 3442:( 3440:p 3434:i 3432:n 3427:i 3386:) 3383:c 3380:( 3377:v 3374:n 3371:i 3359:0 3340:0 3337:= 3334:c 3320:. 3306:) 3303:) 3298:i 3294:n 3290:, 3285:8 3277:i 3274:( 3271:p 3268:, 3265:c 3262:( 3259:d 3247:c 3239:i 3232:c 3225:0 3222:n 3218:n 3207:n 3205:, 3203:j 3201:( 3199:p 3195:i 3193:( 3191:p 3187:n 3185:, 3183:j 3181:+ 3179:i 3177:( 3175:p 3162:p 3154:j 3152:( 3146:j 3144:( 3142:d 3129:j 3125:k 3123:( 3121:d 3117:k 3115:, 3113:j 3111:( 3109:d 3105:k 3101:j 3089:5 3084:d 3064:5 3061:2 3058:3 3055:1 3052:9 3049:6 3046:4 3043:0 3040:7 3029:1 3026:4 3023:6 3020:0 3017:8 3014:3 3011:9 3008:7 3005:2 2994:0 2991:9 2988:3 2985:7 2982:5 2979:6 2976:8 2973:2 2970:4 2959:7 2956:8 2953:6 2950:2 2947:1 2944:3 2941:5 2938:4 2935:9 2924:2 2921:5 2918:3 2915:4 2912:0 2909:6 2906:1 2903:9 2900:8 2889:4 2886:1 2883:6 2880:9 2877:7 2874:3 2871:0 2868:8 2865:5 2854:9 2851:0 2848:3 2845:8 2842:2 2839:6 2836:7 2833:5 2830:1 2819:8 2816:7 2813:6 2810:5 2807:4 2804:3 2801:2 2798:1 2795:0 2727:) 2724:m 2721:u 2718:n 2715:, 2712:s 2709:o 2706:p 2703:( 2700:p 2587:) 2584:j 2581:( 2578:v 2575:n 2572:i 2559:j 2544:1 2541:2 2538:3 2535:4 2532:5 2529:6 2526:7 2523:8 2520:9 2509:0 2506:1 2503:2 2500:3 2497:9 2494:5 2491:6 2488:7 2485:8 2474:4 2471:0 2468:1 2465:2 2462:8 2459:9 2456:5 2453:6 2450:7 2439:3 2436:4 2433:0 2430:1 2427:7 2424:8 2421:9 2418:5 2415:6 2404:2 2401:3 2398:4 2395:0 2392:6 2389:7 2386:8 2383:9 2380:5 2369:7 2366:6 2363:5 2360:9 2357:3 2354:2 2351:1 2348:0 2345:4 2334:6 2331:5 2328:9 2325:8 2322:2 2319:1 2316:0 2313:4 2310:3 2299:5 2296:9 2293:8 2290:7 2287:1 2284:0 2281:4 2278:3 2275:2 2264:9 2261:8 2258:7 2255:6 2252:0 2249:4 2246:3 2243:2 2240:1 2229:8 2226:7 2223:6 2220:5 2217:4 2214:3 2211:2 2208:1 2205:0 2198:j 2159:k 2142:) 2139:k 2136:, 2133:j 2130:( 2127:d 2105:p 2097:d 2068:Z 2060:/ 2055:Z 2019:e 2016:= 2011:2 2007:e 2003:= 2000:) 1997:s 1992:2 1988:r 1981:s 1976:2 1972:r 1968:( 1962:) 1959:s 1954:2 1950:r 1943:s 1938:2 1934:r 1930:( 1906:e 1903:= 1900:s 1895:2 1891:r 1884:s 1879:2 1875:r 1868:s 1863:2 1859:r 1852:s 1847:2 1843:r 1818:s 1813:2 1809:r 1805:= 1802:) 1797:2 1793:r 1789:( 1786:f 1783:= 1780:) 1775:4 1771:r 1767:( 1762:2 1758:f 1754:= 1751:) 1748:s 1743:3 1739:r 1735:( 1730:3 1726:f 1722:= 1719:) 1716:s 1713:( 1708:4 1704:f 1679:e 1676:= 1673:) 1670:s 1667:( 1662:4 1658:f 1651:) 1648:s 1643:3 1639:r 1635:( 1630:3 1626:f 1619:) 1614:4 1610:r 1606:( 1601:2 1597:f 1590:) 1585:2 1581:r 1577:( 1574:f 1550:5 1546:D 1522:) 1516:1 1509:) 1503:n 1499:a 1495:( 1490:n 1486:f 1480:k 1475:1 1472:= 1469:n 1460:( 1454:k 1448:1 1441:f 1437:= 1434:c 1412:c 1391:e 1388:= 1385:) 1382:c 1379:( 1374:1 1371:+ 1368:k 1364:f 1357:) 1352:k 1348:a 1344:( 1339:k 1335:f 1322:) 1317:2 1313:a 1309:( 1304:2 1300:f 1293:) 1288:1 1284:a 1280:( 1277:f 1255:c 1233:5 1229:D 1204:3 1200:r 1196:= 1193:) 1190:s 1187:r 1184:( 1181:f 1178:= 1175:) 1172:) 1167:3 1163:r 1159:( 1156:f 1153:( 1150:f 1128:3 1124:r 1120:= 1117:) 1112:3 1108:r 1104:( 1099:2 1095:f 1074:s 1071:r 1068:= 1065:) 1060:3 1056:r 1052:( 1049:f 1025:) 1017:4 1013:r 1007:s 1002:4 998:r 992:e 985:3 981:r 975:s 970:3 966:r 958:2 954:r 948:s 945:r 940:s 935:2 931:r 925:s 920:r 913:s 908:4 904:r 898:s 893:3 889:r 883:s 878:2 874:r 868:s 865:r 860:s 853:4 849:r 841:3 837:r 829:2 825:r 819:r 814:e 808:( 803:= 800:f 777:5 773:D 764:5 760:D 756:: 753:f 730:s 725:3 721:r 717:= 714:) 711:8 708:( 705:m 702:= 697:3 693:a 672:k 649:k 627:n 623:a 598:) 592:s 587:4 583:r 577:s 572:3 568:r 562:s 557:2 553:r 547:s 544:r 539:s 532:4 528:r 520:3 516:r 508:2 504:r 498:r 493:e 486:9 481:8 476:7 471:6 466:5 461:4 456:3 451:2 446:1 441:0 435:( 430:= 427:m 404:5 400:D 393:] 390:9 387:, 384:0 381:[ 378:: 375:m 353:5 349:D 326:5 322:D 279:6 268:5 257:4 246:3 155:2 141:1 107:( 95:( 83:( 75:( 63:(

Index

checksum
error detection
Jacobus Verhoeff
check digit
ISBN check digit
dihedral group
lookup tables
Damm algorithm
Cayley table
commutative
permutation
Luhn algorithm
Bibcode
1971ZaMM...51..240N
doi
10.1002/zamm.19710510323
Kirtland, Joseph
"5. Group Theory and the Verhoeff Check Digit Scheme"
ISBN
0-88385-720-0
"§2.11 The Verhoeff Check Digit Method"
ISBN
0-387-21245-0
The Edge of the Universe: Celebrating Ten Years of Math Horizons
ISBN
978-0-88385-555-3
LCCN
2005937266
"A new class of check-digit methods for arbitrary number systems (Corresp.)"
doi

Text is available under the Creative Commons Attribution-ShareAlike License. Additional terms may apply.