Type Linear block code | ||
![]() | ||
Block length n {displaystyle n} Message length Rate 1 − m / n {displaystyle 1-m/n} Distance 2 ( 1 − ϵ ) γ ⋅ n {displaystyle 2(1-epsilon )gamma cdot n} Alphabet size 2 {displaystyle 2} |
In coding theory, expander codes form a class of error-correcting codes that are constructed from bipartite expander graphs. Along with Justesen codes, expander codes are of particular interest since they have a constant positive rate, a constant positive relative distance, and a constant alphabet size. In fact, the alphabet contains only two elements, so expander codes belong to the class of binary codes. Furthermore, expander codes can be both encoded and decoded in time proportional to the block length of the code. Expander codes are the only known asymptotically good codes which can be both encoded and decoded from a constant fraction of errors in polynomial time.
Contents
Expander codes
In coding theory, an expander code is a
Definition
Consider a bipartite graph
Since
It has been shown that nontrivial lossless expander graphs exist. Moreover, we can explicitly construct them.
Rate
The rate of
Distance
Suppose
Proof
Note that we can consider every codeword
Lemma 1
For every
Proof
Trivially,
Corollary
Every sufficiently small
Lemma 2
Every subset
Proof
Lemma 1 proves the case
Corollary
Note that if a
Encoding
The encoding time for an expander code is upper bounded by that of a general linear code -
Decoding
Decoding of expander codes is possible in
Let
Input: received codeword
initialize y' to ywhile there is a v in R adjacent to an odd number of vertices in V(y') if there is an i such that o(i) > e(i) flip entry i in y' else fail
Output: fail, or modified codeword
Proof
We show first the correctness of the algorithm, and then examine its running time.
Correctness
We must show that the algorithm terminates with the correct codeword when the received codeword is within half the code's distance of the original codeword. Let the set of corrupt variables be
Lemma 3
If
Proof
By Lemma 1, we know that
So, if we have not yet reached a codeword, then there will always be some vertex to flip. Next, we show that the number of errors can never increase beyond
Lemma 4
If we start with
Proof
When we flip a vertex
Lemmas 3 and 4 show us that if we start with
Complexity
We now show that the algorithm can achieve linear time decoding. Let
- Pre-processing: It takes
O ( m r ) time to compute whether each vertex in R has an odd or even number of neighbors. - Pre-processing 2: We take
O ( d n ) = O ( d m r ) time to compute a list of vertices v i in L which have o ( i ) > e ( i ) . - Each Iteration: We simply remove the first list element. To update the list of odd / even vertices in
R , we need only update O ( d ) entries, inserting / removing as necessary. We then update O ( d r ) entries in the list of vertices in L with more odd than even neighbors, inserting / removing as necessary. Thus each iteration takes O ( d r ) time. - As argued above, the total number of iterations is at most
m .
This gives a total runtime of