UNPKG

@zxing/library

Version:

TypeScript port of ZXing multi-format 1D/2D barcode image processing library.

42 lines (41 loc) 2.12 kB
import GenericGF from './GenericGF'; /** * <p>Implements Reed-Solomon encoding, as the name implies.</p> * * @author Sean Owen * @author William Rucklidge */ export default class ReedSolomonEncoder { private field; private cachedGenerators; /** * A reed solomon error-correcting encoding constructor is created by * passing as Galois Field with of size equal to the number of code * words (symbols) in the alphabet (the number of values in each * element of arrays that are encoded/decoded). * @param field A galois field with a number of elements equal to the size * of the alphabet of symbols to encode. */ constructor(field: GenericGF); private buildGenerator; /** * <p>Encode a sequence of code words (symbols) using Reed-Solomon to allow decoders * to detect and correct errors that may have been introduced when the resulting * data is stored or transmitted.</p> * * @param toEncode array used for both and output. Caller initializes the array with * the code words (symbols) to be encoded followed by empty elements allocated to make * space for error-correction code words in the encoded output. The array contains * the encdoded output when encode returns. Code words are encoded as numbers from * 0 to n-1, where n is the number of possible code words (symbols), as determined * by the size of the Galois Field passed in the constructor of this object. * @param ecBytes the number of elements reserved in the array (first parameter) * to store error-correction code words. Thus, the number of code words (symbols) * to encode in the first parameter is thus toEncode.length - ecBytes. * Note, the use of "bytes" in the name of this parameter is misleading, as there may * be more or fewer than 256 symbols being encoded, as determined by the number of * elements in the Galois Field passed as a constructor to this object. * @throws IllegalArgumentException thrown in response to validation errros. */ encode(toEncode: Int32Array, ecBytes: number): void; }