IT++ Logo
Generation of LDPC codes
// Generate some example LDPC codes
#include <itpp/itcomm.h>
using namespace itpp;
using namespace std;
int main(int argc, char **argv)
{
{ // This generates a random regular (3,6) code with 500 bits
cout << "========= RANDOM (3,6) CODE ==========" << endl;
H.generate(500, 3, 6,
"rand", // random unstructured matrix
"500 10"); // optimize girth
LDPC_Code C1(&H);
C1.save_code("random_3_6_code.it");
}
{ // This is the code "204.33.484 (N=204, K=102, M=102, R=0.5)" from
// David MacKay's database over sparse-graph code. It can be obtained
// using the following URL:
// http://www.inference.phy.cam.ac.uk/mackay/codes/EN/C/204.33.484
cout << "========= MACKAY CODE ==========" << endl;
H.load_alist("204.33.484");
LDPC_Code C(&H, &G);
C.save_code("mackay_204.33.484.it");
// Now produce a girth-optimized version of this code by removing
// cycles. This slightly improves the performance at high SNR.
// Cycle removal procedure is only available for unstructured LDPC
// parity check matrices, represented by either LDPC_Parity_Regular or
// LDPC_Parity_Irregular classes.
LDPC_Code C1(&H, &G1);
C1.save_code("mackay_204.33.484_opt.it");
}
// Irregular 1/2-rate codes optimized for the AWGN channel. The
// degree distributions are taken from Richardson & Urbanke,
// Trans. IT 2001.
{ // 1000 bits
cout << "========= IRREGULAR CODE 1000 BITS ==========" << endl;
H.generate(1000,
"0 0.27684 0.28342 0 0 0 0 0 0.43974",
"0 0 0 0 0 0.01568 0.85244 0.13188",
"rand", // random unstructured matrix
"500 8"); // optimize girth
LDPC_Code C(&H);
C.save_code("RU_1000.it");
}
{ // 10000 bits (takes a few minutes to run)
cout << "========= IRREGULAR CODE 10000 BITS ==========" << endl;
H.generate(10000,
"0 0.21991 0.23328 0.02058 0 0.08543 0.06540 0.04767 0.01912 "
"0 0 0 0 0 0 0 0 0 0.08064 0.22798",
"0 0 0 0 0 0 0 0.64854 0.34747 0.00399",
"rand", // random unstructured matrix
"150 8"); // optimize
LDPC_Code C(&H);
C.save_code("RU_10000.it");
}
{ // 100000 bits (takes a while to run)
cout << "========= IRREGULAR CODE 100000 BITS ==========" << endl;
H.generate(100000,
"0 0.1712 0.21053 0.00273 0 0 0.00009 0.15269 0.09227 "
"0.02802 0 0 0 0 0.01206 0 0 0 0 0 0 0 0 0 0 0 0 0 0 "
"0.07212 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25830",
"0 0 0 0 0 0 0 0 0.33620 0.08883 0.57497",
"rand",
"40 4"); // less aggressive optimization
LDPC_Code C(&H);
C.save_code("RU_100000.it");
}
return 0;
{ // 1000000 bits (THIS CODE REQUIRES ABOUT 450 MB TO STORE AND 2GB
// INTERNAL MEMORY TO GENERATE)
cout << "========= IRREGULAR CODE 1000000 BITS ==========" << endl;
H.generate(1000000,
"0 0.1712 0.21053 0.00273 0 0 0.00009 0.15269 0.09227 "
"0.02802 0 0 0 0 0.01206 0 0 0 0 0 0 0 0 0 0 0 0 0 0 "
"0.07212 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25830",
"0 0 0 0 0 0 0 0 0.33620 0.08883 0.57497",
"rand",
"0 0"); // no optimization here
LDPC_Code C(&H);
C.save_code("RU_1000000.it");
}
}
Low-density parity check (LDPC) codec.
Definition ldpc.h:732
Systematic LDPC Generator class.
Definition ldpc.h:571
Irregular LDPC code generator class.
Definition ldpc.h:333
void generate(int Nvar, const vec &var_deg, const vec &chk_deg, const std::string &method="rand", const ivec &options="200 6")
Generate an irregular LDPC code.
Definition ldpc.cpp:703
Regular LDPC code generator class.
Definition ldpc.h:398
void display_stats() const
Display some information about the matrix.
Definition ldpc.h:430
void generate(int Nvar, int k, int l, const std::string &method="rand", const ivec &options="200 6")
Generate a (k,l) regular LDPC code.
Definition ldpc.cpp:667
int cycle_removal_MGW(int L)
Remove cycles (loops) from unstructured parity check matrix.
Definition ldpc.cpp:292
void load_alist(const std::string &alist_file)
Load matrix from alist_file text file in alist format.
Definition ldpc.cpp:155
Include file for the IT++ communications module.
itpp namespace
Definition itmex.h:37
STL namespace.
SourceForge Logo

Generated on Tue Dec 10 2024 04:49:37 for IT++ by Doxygen 1.12.0