Katana VentraIP

Damm algorithm

In error detection, the Damm algorithm is a check digit algorithm that detects all single-digit errors and all adjacent transposition errors. It was presented by H. Michael Damm in 2004,[1] as a part of his PhD dissertation entitled Totally Antisymmetric Quasigroups.

Strengths and weaknesses[edit]

Strengths[edit]

The Damm algorithm is similar to the Verhoeff algorithm. It too will detect all occurrences of the two most frequently appearing types of transcription errors, namely altering a single digit or transposing two adjacent digits (including the transposition of the trailing check digit and the preceding digit).[1][2] The Damm algorithm has the benefit that it does not have the dedicatedly constructed permutations and its position-specific powers of the Verhoeff scheme. A table of inverses can also be dispensed with when all main diagonal entries of the operation table are zero.


The Damm algorithm generates only 10 possible values, avoiding the need for a non-digit character (such as the X in the 10-digit ISBN check digit scheme).


Prepending leading zeros does not affect the check digit (a weakness for variable-length codes).[1]


There are totally anti-symmetric quasigroups that detect all phonetic errors associated with the English language (13 ↔ 30, 14 ↔ 40, ..., 19 ↔ 90). The table used in the illustrating example is based on an instance of such kind.

Weaknesses[edit]

For all checksum algorithms, including the Damm algorithm, prepending leading zeroes does not affect the check digit,[1] so 1, 01, 001, etc. produce the same check digit. Consequently variable-length codes should not be verified together.

Damm validation & generation code in several programming languages

Practical application in Singapore

Quasigroups for the Damm algorithm up to order 64

At RosettaCode.org, Implementations of the Damm algorithm in many programming languages