This is a python module for encoding and correcting data using BCH codes. This is a fork of https://github.com/jkent/python-bchlib that extends support for Galois Field orders up to 31 (previous implementation supported up to 15). And also update bch source code from kernel source tree.
For Windows, python3.5 or greater required.
For Linux and MacOS, python2.7 or python3.4 or greater required.
Make sure you have python-dev setup. For Windows, this means you need Visual Studio 2015.
$ git clone https://github.com/EgorKin/python-bchlib
$ cd python-bchlib
$ python3 ./setup.py build
$ python3 ./setup.py install
bchlib.BCH( polynomial, t[, reverse] ) → bch
Constructor creates a BCH object with given
polynomial
andt
bit strength,reverse
is an optional boolean that flips the bit order of data. The Galois field order is automatically determined from thepolynomial
.
bch.encode( data[, ecc] ) → ecc
Encodes
data
with an optional startingecc
and returns an ecc.
bch.decode( data, ecc ) → ( bitflips, data, ecc )
Corrects
data
usingecc
and returns a tuple.
bch.decode_inplace( data, ecc ) → bitflips
Corrects
data
usingecc
in place, returning the number of bitflips.
bch.decode_syndromes( data, syndromes ) → ( bitflips, data )
Corrects
data
using a sequence ofsyndromes
, of t*2 elements, returning a tuple.
bch.compute_even_syndromes( syndromes ) → syndromes
Computes even syndromes from odd ones. Takes and returns a sequence of t*2 elements.
bch.ecc_bytes
A readonly field; the number of bytes an ecc takes up.
bch.ecc_bits
A readonly field; the number of bits an ecc takes up.
bch.m
A readonly field; the Galois field order.
bch.n
A readonly field; the maximum codeword size in bits.
bch.syndromes
A readonly field; a tuple of syndromes after performing a correct operation.
bch.t
A readonly field; the number bit errors that can be corrected.
Look at test.py