Block code




In coding theory, block codes are a large and important family of error-correcting codes that encode data in blocks.
There is a vast number of examples for block codes, many of which have a wide range of practical applications. The abstract definition of block codes is conceptually useful because it allows coding theorists, mathematicians, and computer scientists to study the limitations of all block codes in a unified way.
Such limitations often take the form of bounds that relate different parameters of the block code to each other, such as its rate and its ability to detect and correct errors.


Examples of block codes are Reed–Solomon codes, Hamming codes, Hadamard codes, Expander codes, Golay codes, and Reed–Muller codes. These examples also belong to the class of linear codes, and hence they are called linear block codes. More particularly, these codes are known as algebraic block codes, or cyclic block codes, because they can be generated using boolean polynomials.


Algebraic block codes are typically hard-decoded using algebraic decoders.[jargon]


The term block code may also refer to any error-correcting code that acts on a block of k{displaystyle k}k bits of input data to produce n{displaystyle n}n bits of output data (n,k){displaystyle (n,k)}(n,k). Consequently, the block coder is a memoryless device. Under this definition codes such as turbo codes, terminated convolutional codes and other iteratively decodable codes (turbo-like codes) would also be considered block codes. A non-terminated convolutional encoder would be an example of a non-block (unframed) code, which has memory and is instead classified as a tree code.


This article deals with "algebraic block codes".




Contents






  • 1 The block code and its parameters


    • 1.1 The alphabet Σ


    • 1.2 The message length k


    • 1.3 The block length n


    • 1.4 The rate R


    • 1.5 The distance d


    • 1.6 Popular notation




  • 2 Examples


  • 3 Error detection and correction properties


  • 4 Lower and upper bounds of block codes


    • 4.1 Family of codes


    • 4.2 Hamming bound


    • 4.3 Singleton bound


    • 4.4 Plotkin bound


    • 4.5 Gilbert–Varshamov bound


    • 4.6 Johnson bound


    • 4.7 Elias–Bassalygo bound




  • 5 Sphere packings and lattices


  • 6 See also


  • 7 References


  • 8 External links





The block code and its parameters


Error-correcting codes are used to reliably transmit digital data over unreliable communication channels subject to channel noise.
When a sender wants to transmit a possibly very long data stream using a block code, the sender breaks the stream up into pieces of some fixed size. Each such piece is called message and the procedure given by the block code encodes each message individually into a codeword, also called a block in the context of block codes. The sender then transmits all blocks to the receiver, who can in turn use some decoding mechanism to (hopefully) recover the original messages from the possibly corrupted received blocks.
The performance and success of the overall transmission depends on the parameters of the channel and the block code.


Formally, a block code is an injective mapping



C:Σk→Σn{displaystyle C:Sigma ^{k}to Sigma ^{n}}C:Sigma ^{k}to Sigma ^{n}.

Here, Σ{displaystyle Sigma }Sigma is a finite and nonempty set and k{displaystyle k}k and n{displaystyle n}n are integers. The meaning and significance of these three parameters and other parameters related to the code are described below.



The alphabet Σ


The data stream to be encoded is modeled as a string over some alphabet Σ{displaystyle Sigma }Sigma . The size |{displaystyle |Sigma |}|Sigma | of the alphabet is often written as q{displaystyle q}q. If q=2{displaystyle q=2}q=2, then the block code is called a binary block code. In many applications it is useful to consider q{displaystyle q}q to be a prime power, and to identify Σ{displaystyle Sigma }Sigma with the finite field Fq{displaystyle mathbb {F} _{q}}mathbb {F} _{q}.



The message length k


Messages are elements m{displaystyle m}m of Σk{displaystyle Sigma ^{k}}Sigma ^{k}, that is, strings of length k{displaystyle k}k.
Hence the number k{displaystyle k}k is called the message length or dimension of a block code.



The block length n


The block length n{displaystyle n}n of a block code is the number of symbols in a block. Hence, the elements c{displaystyle c}c of Σn{displaystyle Sigma ^{n}}Sigma ^{n} are strings of length n{displaystyle n}n and correspond to blocks that may be received by the receiver. Hence they are also called received words.
If c=C(m){displaystyle c=C(m)}c=C(m) for some message m{displaystyle m}m, then c{displaystyle c}c is called the codeword of m{displaystyle m}m.



The rate R


The rate of a block code is defined as the ratio between its message length and its block length:



R=k/n{displaystyle R=k/n}R=k/n.

A large rate means that the amount of actual message per transmitted block is high. In this sense, the rate measures the transmission speed and the quantity 1−R{displaystyle 1-R}1-R measures the overhead that occurs due to the encoding with the block code.
It is a simple information theoretical fact that the rate cannot exceed 1{displaystyle 1}1 since data cannot in general be losslessly compressed. Formally, this follows from the fact that the code C{displaystyle C}C is an injective map.



The distance d


The distance or minimum distance d of a block code is the minimum number of positions in which any two distinct codewords differ, and the relative distance δ{displaystyle delta }delta is the fraction d/n{displaystyle d/n}d/n.
Formally, for received words c1,c2∈Σn{displaystyle c_{1},c_{2}in Sigma ^{n}}c_{1},c_{2}in Sigma ^{n}, let Δ(c1,c2){displaystyle Delta (c_{1},c_{2})}Delta (c_{1},c_{2}) denote the Hamming distance between c1{displaystyle c_{1}}c_{1} and c2{displaystyle c_{2}}c_{2}, that is, the number of positions in which c1{displaystyle c_{1}}c_{1} and c2{displaystyle c_{2}}c_{2} differ.
Then the minimum distance d{displaystyle d}d of the code C{displaystyle C}C is defined as



d:=minm1,m2∈Σkm1≠m2Δ[C(m1),C(m2)]{displaystyle d:=min _{m_{1},m_{2}in Sigma ^{k} atop m_{1}neq m_{2}}Delta [C(m_{1}),C(m_{2})]}{displaystyle d:=min _{m_{1},m_{2}in Sigma ^{k} atop m_{1}neq m_{2}}Delta [C(m_{1}),C(m_{2})]}.

Since any code has to be injective, any two codewords will disagree in at least one position, so the distance of any code is at least 1{displaystyle 1}1. Besides, the distance equals the minimum weight for linear block codes because:



minm1,m2∈Σkm1≠m2Δ[C(m1),C(m2)]=minm1,m2∈Σkm1≠m2Δ[0,C(m1)+C(m2)]=minm∈Σkm≠0w[C(m)]=wmin{displaystyle min _{m_{1},m_{2}in Sigma ^{k} atop m_{1}neq m_{2}}Delta [C(m_{1}),C(m_{2})]=min _{m_{1},m_{2}in Sigma ^{k} atop m_{1}neq m_{2}}Delta [mathbf {0} ,C(m_{1})+C(m_{2})]=min _{min Sigma ^{k} atop mneq mathbf {0} }w[C(m)]=w_{min }}{displaystyle min _{m_{1},m_{2}in Sigma ^{k} atop m_{1}neq m_{2}}Delta [C(m_{1}),C(m_{2})]=min _{m_{1},m_{2}in Sigma ^{k} atop m_{1}neq m_{2}}Delta [mathbf {0} ,C(m_{1})+C(m_{2})]=min _{min Sigma ^{k} atop mneq mathbf {0} }w[C(m)]=w_{min }}.

A larger distance allows for more error correction and detection.
For example, if we only consider errors that may change symbols of the sent codeword but never erase or add them, then the number of errors is the number of positions in which the sent codeword and the received word differ.
A code with distance d allows the receiver to detect up to d−1{displaystyle d-1}d-1 transmission errors since changing d−1{displaystyle d-1}d-1 positions of a codeword can never accidentally yield another codeword. Furthermore, if no more than (d−1)/2{displaystyle (d-1)/2}(d-1)/2 transmission errors occur, the receiver can uniquely decode the received word to a codeword. This is because every received word has at most one codeword at distance (d−1)/2{displaystyle (d-1)/2}(d-1)/2. If more than (d−1)/2{displaystyle (d-1)/2}(d-1)/2 transmission errors occur, the receiver cannot uniquely decode the received word in general as there might be several possible codewords. One way for the receiver to cope with this situation is to use list decoding, in which the decoder outputs a list of all codewords in a certain radius.



Popular notation


The notation (n,k,d)q{displaystyle (n,k,d)_{q}}(n,k,d)_{q} describes a block code over an alphabet Σ{displaystyle Sigma }Sigma of size q{displaystyle q}q, with a block length n{displaystyle n}n, message length k{displaystyle k}k, and distance d{displaystyle d}d.
If the block code is a linear block code, then the square brackets in the notation [n,k,d]q{displaystyle [n,k,d]_{q}}[n,k,d]_{q} are used to represent that fact.
For binary codes with q=2{displaystyle q=2}q=2, the index is sometimes dropped.
For maximum distance separable codes, the distance is always d=n−k+1{displaystyle d=n-k+1}d=n-k+1, but sometimes the precise distance is not known, non-trivial to prove or state, or not needed. In such cases, the d{displaystyle d}d-component may be missing.


Sometimes, especially for non-block codes, the notation (n,M,d)q{displaystyle (n,M,d)_{q}}(n,M,d)_{q} is used for codes that contain M{displaystyle M}M codewords of length n{displaystyle n}n. For block codes with messages of length k{displaystyle k}k over an alphabet of size q{displaystyle q}q, this number would be M=qk{displaystyle M=q^{k}}M=q^{k}.



Examples


As mentioned above, there are a vast number of error-correcting codes that are actually block codes.
The first error-correcting code was the Hamming(7,4) code, developed by Richard W. Hamming in 1950. This code transforms a message consisting of 4 bits into a codeword of 7 bits by adding 3 parity bits. Hence this code is a block code. It turns out that it is also a linear code and that it has distance 3. In the shorthand notation above, this means that the Hamming(7,4) code is a [7,4,3]2{displaystyle [7,4,3]_{2}}[7,4,3]_{2} code.


Reed–Solomon codes are a family of [n,k,d]q{displaystyle [n,k,d]_{q}}[n,k,d]_{q} codes with d=n−k+1{displaystyle d=n-k+1}d=n-k+1 and q{displaystyle q}q being a prime power. Rank codes are family of [n,k,d]q{displaystyle [n,k,d]_{q}}[n,k,d]_{q} codes with d≤n−k+1{displaystyle dleq n-k+1}dleq n-k+1. Hadamard codes are a family of [n,k,d]2{displaystyle [n,k,d]_{2}}[n,k,d]_{2} codes with n=2k−1{displaystyle n=2^{k-1}}n=2^{k-1} and d=2k−2{displaystyle d=2^{k-2}}d=2^{k-2}.



Error detection and correction properties


A codeword c∈Σn{displaystyle cin Sigma ^{n}}cin Sigma ^{n}could be considered as a point in the n{displaystyle n}n-dimension space Σn{displaystyle Sigma ^{n}}Sigma ^{n} and the code C{displaystyle {mathcal {C}}}{mathcal {C}} is the subset of Σn{displaystyle Sigma ^{n}}Sigma ^{n}. A code C{displaystyle {mathcal {C}}}{mathcal {C}} has distance d{displaystyle d}d means that c∈C{displaystyle forall cin {mathcal {C}}}forall cin {mathcal {C}}, there is no other codeword in the Hamming ball centered at c{displaystyle c}c with radius d−1{displaystyle d-1}d-1, which is defined as the collection of n{displaystyle n}n-dimension words whose Hamming distance to c{displaystyle c}c is no more than d−1{displaystyle d-1}d-1. Similarly, C{displaystyle {mathcal {C}}}{mathcal {C}} with (minimum) distance d{displaystyle d}d has the following properties:




  • C{displaystyle {mathcal {C}}}{mathcal {C}} can detect d−1{displaystyle d-1}d-1 errors : Because a codeword c{displaystyle c}c is the only codeword in the Hamming ball centered at itself with radius d−1{displaystyle d-1}d-1, no error pattern of d−1{displaystyle d-1}d-1 or fewer errors could change one codeword to another. When the receiver detects that the received vector is not a codeword of C{displaystyle {mathcal {C}}}{mathcal {C}}, the errors are detected (but no guarantee to correct).


  • C{displaystyle {mathcal {C}}}{mathcal {C}} can correct ⌊d−12⌋{displaystyle textstyle leftlfloor {{d-1} over 2}rightrfloor }textstyle leftlfloor {{d-1} over 2}rightrfloor errors. Because a codeword c{displaystyle c}c is the only codeword in the Hamming ball centered at itself with radius d−1{displaystyle d-1}d-1, the two Hamming balls centered at two different codewords respectively with both radius ⌊d−12⌋{displaystyle textstyle leftlfloor {{d-1} over 2}rightrfloor }textstyle leftlfloor {{d-1} over 2}rightrfloor do not overlap with each other. Therefore, if we consider the error correction as finding the codeword closest to the received word y{displaystyle y}y, as long as the number of errors is no more than ⌊d−12⌋{displaystyle textstyle leftlfloor {{d-1} over 2}rightrfloor }textstyle leftlfloor {{d-1} over 2}rightrfloor , there is only one codeword in the hamming ball centered at y{displaystyle y}y with radius ⌊d−12⌋{displaystyle textstyle leftlfloor {{d-1} over 2}rightrfloor }textstyle leftlfloor {{d-1} over 2}rightrfloor , therefore all errors could be corrected.

  • In order to decode in the presence of more than (d−1)/2{displaystyle (d-1)/2}(d-1)/2 errors, list-decoding or maximum likelihood decoding can be used.


  • C{displaystyle {mathcal {C}}}{mathcal {C}} can correct d−1{displaystyle d-1}d-1 erasures. By erasure it means that the position of the erased symbol is known. Correcting could be achieved by q{displaystyle q}q-passing decoding : In ith{displaystyle i^{th}}i^{th} passing the erased position is filled with the ith{displaystyle i^{th}}i^{th} symbol and error correcting is carried out. There must be one passing that the number of errors is no more than ⌊d−12⌋{displaystyle textstyle leftlfloor {{d-1} over 2}rightrfloor }textstyle leftlfloor {{d-1} over 2}rightrfloor and therefore the erasures could be corrected.



Lower and upper bounds of block codes




Hamming limit




There are theoretical limits (such as the Hamming limit), but another question is which codes can actually constructed. It is like packing spheres in a box in many dimensions. This diagram shows the constructible codes, which are linear and binary. The x axis shows the number of protected symbols k, the y axis the number of needed check symbols n–k. Plotted are the limits for different Hamming distances from 1 (unprotected) to 34. Marked with dots are perfect codes:

  • light orange on x axis: trivial unprotected codes

  • orange on y axis: trivial repeat codes

  • dark orange on data set d=3: classic perfect Hamming codes

  • dark red and larger: the only perfect binary Golay code





Family of codes


C={Ci}i≥1{displaystyle C={C_{i}}_{igeq 1}}C={C_{i}}_{igeq 1} is called family of codes, where Ci{displaystyle C_{i}}C_{i} is an (ni,ki,di)q{displaystyle (n_{i},k_{i},d_{i})_{q}}(n_{i},k_{i},d_{i})_{q} code with monotonic increasing ni{displaystyle n_{i}}n_{i}.


Rate of family of codes C is defined as R(C)=limi→kini{displaystyle R(C)=lim _{ito infty }{k_{i} over n_{i}}}R(C)=lim _{ito infty }{k_{i} over n_{i}}


Relative distance of family of codes C is defined as δ(C)=limi→dini{displaystyle delta (C)=lim _{ito infty }{d_{i} over n_{i}}}delta (C)=lim _{ito infty }{d_{i} over n_{i}}


To explore the relationship between R(C){displaystyle R(C)}R(C) and δ(C){displaystyle delta (C)}delta (C), a set of lower and upper bounds of block codes are known.



Hamming bound



R≤1−1n⋅logq⋅[∑i=0⌊δn−12⌋(ni)(q−1)i]{displaystyle Rleq 1-{1 over n}cdot log _{q}cdot left[sum _{i=0}^{leftlfloor {{delta cdot n-1} over 2}rightrfloor }{binom {n}{i}}(q-1)^{i}right]}{displaystyle Rleq 1-{1 over n}cdot log _{q}cdot left[sum _{i=0}^{leftlfloor {{delta cdot n-1} over 2}rightrfloor }{binom {n}{i}}(q-1)^{i}right]}


Singleton bound



The Singleton bound is that the sum of the rate and the relative distance of a block code cannot be much larger than 1:



R+δ1+1n{displaystyle R+delta leq 1+{frac {1}{n}}}R+delta leq 1+{frac {1}{n}}.

In other words, every block code satisfies the inequality k+d≤n+1{displaystyle k+dleq n+1}k+dleq n+1.
Reed–Solomon codes are non-trivial examples of codes that satisfy the singleton bound with equality.



Plotkin bound



For q=2{displaystyle q=2}q=2, R+2δ1{displaystyle R+2delta leq 1}R+2delta leq 1. In other words, k+2d≤n{displaystyle k+2dleq n}{displaystyle k+2dleq n}.


For the general case, the following Plotkin bounds holds for any C⊆Fqn{displaystyle Csubseteq mathbb {F} _{q}^{n}}Csubseteq mathbb {F} _{q}^{n} with distance d:



  1. If d=(1−1q)n,|C|≤2qn{displaystyle d=left(1-{1 over q}right)n,|C|leq 2qn}{displaystyle d=left(1-{1 over q}right)n,|C|leq 2qn}

  2. If d>(1−1q)n,|C|≤qdqd−(q−1)n{displaystyle d>left(1-{1 over q}right)n,|C|leq {qd over {qd-left(q-1right)n}}}{displaystyle d>left(1-{1 over q}right)n,|C|leq {qd over {qd-left(q-1right)n}}}


For any q-ary code with distance δ{displaystyle delta }delta , R≤1−(qq−1)δ+o(1){displaystyle Rleq 1-left({q over {q-1}}right)delta +oleft(1right)}{displaystyle Rleq 1-left({q over {q-1}}right)delta +oleft(1right)}



Gilbert–Varshamov bound



R≥1−Hq(δ)−ϵ{displaystyle Rgeq 1-H_{q}left(delta right)-epsilon }{displaystyle Rgeq 1-H_{q}left(delta right)-epsilon }, where 0≤δ1−1q,0≤ϵ1−Hq(δ){displaystyle 0leq delta leq 1-{1 over q},0leq epsilon leq 1-H_{q}left(delta right)}{displaystyle 0leq delta leq 1-{1 over q},0leq epsilon leq 1-H_{q}left(delta right)},
Hq(x) =def −x⋅logq⁡xq−1−(1−x)⋅logq⁡(1−x){displaystyle H_{q}left(xright)~{overset {underset {mathrm {def} }{}}{=}}~-xcdot log _{q}{x over {q-1}}-left(1-xright)cdot log _{q}{left(1-xright)}}{displaystyle H_{q}left(xright)~{overset {underset {mathrm {def} }{}}{=}}~-xcdot log _{q}{x over {q-1}}-left(1-xright)cdot log _{q}{left(1-xright)}} is the q-ary entropy function.



Johnson bound



Define Jq(δ) =def (1−1q)(1−1−q−1){displaystyle J_{q}left(delta right)~{overset {underset {mathrm {def} }{}}{=}}~left(1-{1 over q}right)left(1-{sqrt {1-{qdelta over {q-1}}}}right)}{displaystyle J_{q}left(delta right)~{overset {underset {mathrm {def} }{}}{=}}~left(1-{1 over q}right)left(1-{sqrt {1-{qdelta  over {q-1}}}}right)}.

Let Jq(n,d,e){displaystyle J_{q}left(n,d,eright)}{displaystyle J_{q}left(n,d,eright)} be the maximum number of codewords in a Hamming ball of radius e for any code C⊆Fqn{displaystyle Csubseteq mathbb {F} _{q}^{n}}Csubseteq mathbb {F} _{q}^{n} of distance d.


Then we have the Johnson Bound : Jq(n,d,e)≤qnd{displaystyle J_{q}left(n,d,eright)leq qnd}{displaystyle J_{q}left(n,d,eright)leq qnd}, if en≤q−1q(1−1−qq−1⋅dn)=Jq(dn){displaystyle {e over n}leq {{q-1} over q}left({1-{sqrt {1-{q over {q-1}}cdot {d over n}}}},right)=J_{q}left({d over n}right)}{displaystyle {e over n}leq {{q-1} over q}left({1-{sqrt {1-{q over {q-1}}cdot {d over n}}}},right)=J_{q}left({d over n}right)}



Elias–Bassalygo bound



R=logq⁡|C|n≤1−Hq(Jq(δ))+o(1){displaystyle R={log _{q}{|C|} over n}leq 1-H_{q}left(J_{q}left(delta right)right)+oleft(1right)}{displaystyle R={log _{q}{|C|} over n}leq 1-H_{q}left(J_{q}left(delta right)right)+oleft(1right)}


Sphere packings and lattices


Block codes are tied to the sphere packing problem which has received some attention over the years. In two dimensions, it is easy to visualize. Take a bunch of pennies flat on the table and push them together. The result is a hexagon pattern like a bee's nest. But block codes rely on more dimensions which cannot easily be visualized. The powerful Golay code used in deep space communications uses 24 dimensions. If used as a binary code (which it usually is), the dimensions refer to the length of the codeword as defined above.


The theory of coding uses the N-dimensional sphere model. For example, how many pennies can be packed into a circle on a tabletop or in 3 dimensions, how many marbles can be packed into a globe. Other considerations enter the choice of a code. For example, hexagon packing into the constraint of a rectangular box will leave empty space at the corners. As the dimensions get larger, the percentage of empty space grows smaller. But at certain dimensions, the packing uses all the space and these codes are the so-called perfect codes. There are very few of these codes.


Another property is the number of neighbors a single codeword may have.[1]
Again, consider pennies as an example. First we pack the pennies in a rectangular grid. Each penny will have 4 near neighbors (and 4 at the corners which are farther away). In a hexagon, each penny will have 6 near neighbors. Respectively, in three and four dimensions, the maximum packing is given by the 12-face and 24-cell with 12 and 24 neighbors, respectively. When we increase the dimensions, the number of near neighbors increases very rapidly. In general, the value is given by the kissing numbers.


The result is that the number of ways for noise to make the receiver choose
a neighbor (hence an error) grows as well. This is a fundamental limitation
of block codes, and indeed all codes. It may be harder to cause an error to
a single neighbor, but the number of neighbors can be large enough so the
total error probability actually suffers.[1]



See also



  • Channel capacity

  • Shannon–Hartley theorem

  • Noisy channel

  • List decoding

  • Sphere packing



References





  1. ^ ab
    Christian Schlegel and Lance Pérez (2004). Trellis and turbo coding. Wiley-IEEE. p. 73. ISBN 978-0-471-22755-7..mw-parser-output cite.citation{font-style:inherit}.mw-parser-output .citation q{quotes:"""""""'""'"}.mw-parser-output .citation .cs1-lock-free a{background:url("//upload.wikimedia.org/wikipedia/commons/thumb/6/65/Lock-green.svg/9px-Lock-green.svg.png")no-repeat;background-position:right .1em center}.mw-parser-output .citation .cs1-lock-limited a,.mw-parser-output .citation .cs1-lock-registration a{background:url("//upload.wikimedia.org/wikipedia/commons/thumb/d/d6/Lock-gray-alt-2.svg/9px-Lock-gray-alt-2.svg.png")no-repeat;background-position:right .1em center}.mw-parser-output .citation .cs1-lock-subscription a{background:url("//upload.wikimedia.org/wikipedia/commons/thumb/a/aa/Lock-red-alt-2.svg/9px-Lock-red-alt-2.svg.png")no-repeat;background-position:right .1em center}.mw-parser-output .cs1-subscription,.mw-parser-output .cs1-registration{color:#555}.mw-parser-output .cs1-subscription span,.mw-parser-output .cs1-registration span{border-bottom:1px dotted;cursor:help}.mw-parser-output .cs1-ws-icon a{background:url("//upload.wikimedia.org/wikipedia/commons/thumb/4/4c/Wikisource-logo.svg/12px-Wikisource-logo.svg.png")no-repeat;background-position:right .1em center}.mw-parser-output code.cs1-code{color:inherit;background:inherit;border:inherit;padding:inherit}.mw-parser-output .cs1-hidden-error{display:none;font-size:100%}.mw-parser-output .cs1-visible-error{font-size:100%}.mw-parser-output .cs1-maint{display:none;color:#33aa33;margin-left:0.3em}.mw-parser-output .cs1-subscription,.mw-parser-output .cs1-registration,.mw-parser-output .cs1-format{font-size:95%}.mw-parser-output .cs1-kern-left,.mw-parser-output .cs1-kern-wl-left{padding-left:0.2em}.mw-parser-output .cs1-kern-right,.mw-parser-output .cs1-kern-wl-right{padding-right:0.2em}






  • J.H. van Lint (1992). Introduction to Coding Theory. GTM. 86 (2nd ed.). Springer-Verlag. p. 31. ISBN 3-540-54894-7.


  • F.J. MacWilliams; N.J.A. Sloane (1977). The Theory of Error-Correcting Codes. North-Holland. p. 35. ISBN 0-444-85193-3.


  • W. Huffman; V.Pless (2003). Fundamentals of error-correcting codes. Cambridge University Press. ISBN 978-0-521-78280-7.


  • S. Lin; D. J. Jr. Costello (1983). Error Control Coding: Fundamentals and Applications. Prentice-Hall. ISBN 0-13-283796-X.



External links


  • Charan Langton (2001) Coding Concepts and Block Coding



Popular posts from this blog

Guess what letter conforming each word

Run scheduled task as local user group (not BUILTIN)

Port of Spain