Ranjan Bose’s chapter about cyclic codes begins with a riveting quote by Pascal, Blaise “We arrive at the truth, not by reason only, but also by the heart.” Quotes like this make a comprehensive book about information theory even more captivating.

Linear Block Codes, block codes –every message m (size k) corresponds to a codeword c (size n), and follows a one-to-one relation— follows linearity property. According to the linearity property, a new code word generated by linear addition of two code word should belong to the set of all the defined code words.

Cyclic block codes: Cyclic shift of a codeword results in another valid codeword. We use Galois Field representation os cyclic codes to lower the complexity encoding and encoding algorithms.

Here the first thing we would like to do is check if the code is liner and then cyclic. Let’s take a code C= {0000, 0101, 1010, 1111}. Now to check linearity we will ex-or two codewords. 1010 + 0101 = 1111 C 1010 + 1111 = 0101 C

For Cyclic property, let’s circularly right shift every code word by 1

= {0000, 1010, 0101, 1111} which is equivalent to C

Coefficients in a polynomial are elements of GF(q) and highest power is called the degree of a polynomial. Interesting fact: F[x] (polynomial) is a ring and not a field because polynomials of degree greater than zero do not have a multiplicative inverse.

Given this, How does one generate a cyclic code.

Take a polynomial in .

Obtain a set of polynomials by multiplying by all possible polynomials in .

The ser of polynomials obtained above corresponds to the set of codewords belonging to a cyclic code.

Nice blog! Can we have a collaboration?

Please share your contact details to discuss.

Definitely, you can contact me in meghana@megstalks.com

Thank you.