How is Data Matrix created?
data:image/s3,"s3://crabby-images/ae138/ae13890df628313a0c5b8e20361c48e4d924c008" alt=""
There are many sites for creating such codes, but I was always wondering how the text turns into a set of black and white squares. Should there be some kind of algorithm?
When creating the Data Matrix, we need to turn to the arithmetic of Galois fields and Reed-Solomon codes. Consider this process with a simple example.
First of all, let's look at the structure of the matrix:
data:image/s3,"s3://crabby-images/8a747/8a747a1263ce87e4b1516103299b97e8d31d7174" alt=""
Our matrix consists of two parts: a search pattern and encoded data. Of course, the size of the matrix is directly proportional to the size of the input data. Around our code, there must be a free zone separating the code from the rest of the image.
Take a short word, for example, “Habr” (without quotes) and create a Data Matrix for it. The process consists of two stages: at the high-level coding stage, you need to obtain a sequence of data codes and error correction codes, and at the low-level coding stage, you need to depict a binary representation of these codes in the matrix.
High level coding
In the Data Matrix, as in the QR code, Reed-Solomon codes are used above the Galois field
data:image/s3,"s3://crabby-images/205f6/205f69097488afa829b3d7ba44f1e69c0b172c55" alt=""
data:image/s3,"s3://crabby-images/31d10/31d10f229fcbfd6539c42b6edb1f244a751935a8" alt=""
data:image/s3,"s3://crabby-images/6ffda/6ffda5679c6bd78d8b8d0f660f6ab5ee5fe7263a" alt=""
For calculations, we need a table of powers of two for each element of the field. This table is created quite simply: if the exponent
data:image/s3,"s3://crabby-images/87b47/87b4736865fae7ad2508a343158dd5f4c8b23484" alt=""
data:image/s3,"s3://crabby-images/7000a/7000a192ca84bba978d3c1c073da9e4189d2c56b" alt=""
data:image/s3,"s3://crabby-images/86dd5/86dd5b09051ea075ff5cd1ce5f7c0bea0f5b64d5" alt=""
data:image/s3,"s3://crabby-images/70b84/70b847e39526cbdfe110f11db1060a759aa731c7" alt=""
data:image/s3,"s3://crabby-images/f9cc0/f9cc0d8b81053ba012f2690f424718bfc258d84a" alt=""
It is necessary to obtain a codeword
data:image/s3,"s3://crabby-images/87437/8743735881ab83c0af79359473de728f294c577a" alt=""
where
data:image/s3,"s3://crabby-images/836a3/836a3eed7d2477c1d53af98e9429bd5fa861983d" alt=""
data:image/s3,"s3://crabby-images/4d6b1/4d6b1749938428654a6141f5a0b1883a03e16609" alt=""
data:image/s3,"s3://crabby-images/ffa49/ffa493ccb0b0509a78cc11f73fa8e37ae343f459" alt=""
data:image/s3,"s3://crabby-images/62e33/62e33de69c8643c3e38ec8390e9630b77ee53c0e" alt=""
data:image/s3,"s3://crabby-images/14155/1415503baed3de94d8cbce9fab4a2e15c706e97a" alt=""
First, we create an information polynomial. To do this, we need to know what size the matrix should be so that all information codes can be placed:
data:image/s3,"s3://crabby-images/55737/557374226e22339632c2aefa279efdb7bdfb79fa" alt=""
From the table it can be seen that to encode a row of 4 elements, we need to take a 12x12 matrix (“useful” area is 10x10), which contains 5 codes data and 7 correction codes.
For ASCII table characters, the code is as follows: C = ASCII value + 1. For example, for the character 'H' C = 72 + 1 = 73.
The running numbers are combined in pairs, and for them C = N + 130, where N is the number obtained as a result of grouping. For example, if the numbers 2 and 5 are nearby, then C = 25 + 130 = 155.
Since we have fewer elements than it should be (instead of five, only four), you need to add special indent codes. The first such code is always 129. The subsequent indent codes, up to the first error correction code, are calculated as follows:,
data:image/s3,"s3://crabby-images/ef816/ef816735b262b7934ad2e499ebc844eac6d12f3e" alt=""
data:image/s3,"s3://crabby-images/716ae/716ae571bf685b292f6e84323a25a02d1109f323" alt=""
data:image/s3,"s3://crabby-images/d4820/d4820d5f645202bf6851bbf2a6d877fd6e7f934a" alt=""
For the word “Habr” we get the following sequence of codes: 73, 98, 99, 115, 129.
Now we can write the information polynomial:
data:image/s3,"s3://crabby-images/60ae4/60ae463bb803aea8e4a8a8fb5ad11ba11f29f3b1" alt=""
and multiply it by
data:image/s3,"s3://crabby-images/f5ab7/f5ab7ff564ec0cfc9d54e5769afa68c7d4f1602b" alt=""
data:image/s3,"s3://crabby-images/a6faa/a6faa28300f3684de72407390e3c88bc821f71b2" alt=""
data:image/s3,"s3://crabby-images/e38c2/e38c2887f0b9f3b307fce23f2a102ec454f12d07" alt=""
We now proceed to create the generating polynomial. It is calculated by the following formula:
data:image/s3,"s3://crabby-images/7e0af/7e0af7249c9614835929aba92da03805715ed640" alt=""
We start to multiply the brackets:
data:image/s3,"s3://crabby-images/34bf7/34bf75bbc7e851d3e7d416bfc0b759a465e418f6" alt=""
data:image/s3,"s3://crabby-images/070ad/070adb5239ade20d919ba4ee7ffb60b5d10c5006" alt=""
Addition in our field is defined as bitwise addition modulo 2. First, raising to a power using a table is performed, then adding them and finding the “logarithm” of the resulting number to return to powers of two. If, after adding the degrees, a number greater than 254 is obtained, take its remainder from dividing by
data:image/s3,"s3://crabby-images/27027/27027330c0b4f3c4c5180415b754a88188956dfd" alt=""
After multiplying all the brackets and raising to the power we get:
data:image/s3,"s3://crabby-images/63206/63206888b6e846820a14860728962bf93163b593" alt=""
The last operation that completes the high-level coding, and perhaps the most difficult, is finding the remainder of the division
data:image/s3,"s3://crabby-images/c8bcc/c8bcc5a48786cf7130d978d56dc32d1c73df577f" alt=""
data:image/s3,"s3://crabby-images/4d6b1/4d6b1749938428654a6141f5a0b1883a03e16609" alt=""
data:image/s3,"s3://crabby-images/9eb12/9eb125e922edd026da1f40f48a4006677c8cc5e5" alt=""
The polynomials are divided into columns, but taking into account the fact that the subtraction defined in the same way as addition and multiplication are performed in the Galois field.
Now we can write the codeword
data:image/s3,"s3://crabby-images/4d883/4d883ad933e861af90fadf707b2ae1d21ed30579" alt=""
data:image/s3,"s3://crabby-images/65051/65051c368ea4106f5b32d65c5dcc07583eb70d94" alt=""
Low level coding
data:image/s3,"s3://crabby-images/5f768/5f76862b1f890f4a081095b07c3a6c02d1a16a52" alt=""
data:image/s3,"s3://crabby-images/98a3c/98a3cdfcca1754c727874f74720becd2e39afa26" alt=""
The remaining elements are placed in a similar way, but before drawing them, it is necessary to note several special cases associated with the corners of the matrix.
If
data:image/s3,"s3://crabby-images/ed34d/ed34defba589bb2d63cb04af897f6694e5559573" alt=""
If
data:image/s3,"s3://crabby-images/7d91b/7d91bb3f3485810ca24607c55e6cf517e88e19cf" alt=""
data:image/s3,"s3://crabby-images/5231b/5231beebf12d76ea509cc120f626a0c8dd2cc614" alt=""
If
data:image/s3,"s3://crabby-images/72584/7258416f5f616c92bf0f162d8fbefeaa71497747" alt=""
data:image/s3,"s3://crabby-images/08227/08227ccb95651ebe56141ef4697c63585170c265" alt=""
data:image/s3,"s3://crabby-images/0e462/0e4627a4b22869e7edb1e725890545ace0814a89" alt=""
There are two more cases that arise only when constructing rectangular matrices, so we omit them.
Let's go back to our matrix and add all the other elements, and also indicate which codeword each element corresponds to. The arrows show how the numbering is done:
data:image/s3,"s3://crabby-images/f90ed/f90ed3d586e6ccbe985cfbe8d2d52c7543dd7105" alt=""
After transferring the non-placed elements, we get:
data:image/s3,"s3://crabby-images/986fb/986fb040811da9ad6dfea1552a1819d43a8b787c" alt=""
In the lower right corner there was an unoccupied square (
data:image/s3,"s3://crabby-images/31473/3147348101853fbe481324ec7f56d252954538ce" alt=""
data:image/s3,"s3://crabby-images/4d883/4d883ad933e861af90fadf707b2ae1d21ed30579" alt=""
data:image/s3,"s3://crabby-images/46755/467556ef1c62658bcf1659260e9876e9510664c8" alt=""
Carefully fill the matrix. Let's start with the search template and the bottom square, and then we add each code in turn:
data:image/s3,"s3://crabby-images/8faef/8faef4601a0999499148dc6e956d3dcee2eb58e2" alt=""
data:image/s3,"s3://crabby-images/522ff/522ff3b9c1b49a3e55f18b5d2e23abfbb4eb7f2d" alt=""
data:image/s3,"s3://crabby-images/c13d5/c13d52ee1d014da31fd2c4a6c9320c5b3dfb55e6" alt=""
data:image/s3,"s3://crabby-images/34f89/34f89d52e34f2d9dab7a9f8ce88c8ea6f2b5d777" alt=""
So, our Data Matrix code is ready:
data:image/s3,"s3://crabby-images/14ce0/14ce003db4887c165393a1acee6d8eb9b5abdfd2" alt=""