/ProtographLDPC

Implementation of Protograph LDPC error correction codes

Primary LanguageJupyter NotebookMIT LicenseMIT

ProtographLDPC

Implementation of Protograph LDPC error correction codes
Roshan Prabhakar1, Shubham Chandak2, Kedar Tatwawadi2

1Fremont High School, Sunnyvale, CA, USA
2Stanford University, Stanford, CA, USA

DOI

Documentation: https://shubhamchandak94.github.io/ProtographLDPC/

LDPC codes are a class of linear error-correction codes on sparse bipartite graphs providing efficient decoding using message passing (between variable and check nodes on the graph) and excellent error correction performance. Among the various classes of LDPC codes, regular LDPC codes have fixed degree variable and check nodes and perform quite well in the high rate regimes for finite block lengths. Irregular LDPC codes can achieve performance closer to capacity but need some fixes to achieve good finite block length performance. Protograph LDPC codes offer the best of both worlds by lifting a small protograph with desirable properties. This work aims to provide an open-source library for protograph LDPC codes that is easy to use and extend. We hope this can be useful for researchers and practitioners in traditional and modern areas like DNA-based data storage. The library includes functionality for:

  • Generation of regular and protograph LDPC matrices using PEG and other construction methods.
  • Encoding and decoding of these codes, including support for puncturing.
  • Utility and test scripts to allow analysis of these codes.

This library heavily uses two prior libraries and we would like to thank the corresponding developers:

  • LDPC-codes: Library for construction, encoding, decoding of regular and irregular LDPC codes, also containing several utility scripts. This is a fork of Radford Neal's library available here.
  • peg: Implementation of the Progressive Edge Growth (PEG) algorithm used for parity check matrix construction. This was obtained from http://www.inference.org.uk/mackay/PEG_ECC.html.

See the documentation for details on the library including installation instructions, usage, examples, methods, simulation results, references and citation information.