WO2004093325A1 - An enhanced circuit for performing error correction and detection of bch codewords - Google Patents

An enhanced circuit for performing error correction and detection of bch codewords Download PDF

Info

Publication number
WO2004093325A1
WO2004093325A1 PCT/IL2003/000322 IL0300322W WO2004093325A1 WO 2004093325 A1 WO2004093325 A1 WO 2004093325A1 IL 0300322 W IL0300322 W IL 0300322W WO 2004093325 A1 WO2004093325 A1 WO 2004093325A1
Authority
WO
WIPO (PCT)
Prior art keywords
logic unit
outputs
error
multiplication
combinational logic
Prior art date
Application number
PCT/IL2003/000322
Other languages
French (fr)
Inventor
Idan Alrod
Yaron Bar
Danny Lahav
Aryeh Lezerovitz
Simon Litsyn
Original Assignee
Optix Networks, Ltd.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Optix Networks, Ltd. filed Critical Optix Networks, Ltd.
Priority to PCT/IL2003/000322 priority Critical patent/WO2004093325A1/en
Priority to AU2003222417A priority patent/AU2003222417A1/en
Publication of WO2004093325A1 publication Critical patent/WO2004093325A1/en

Links

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/13Linear codes
    • H03M13/15Cyclic codes, i.e. cyclic shifts of codewords produce other codewords, e.g. codes defined by a generator polynomial, Bose-Chaudhuri-Hocquenghem [BCH] codes

Definitions

  • the present invention relates generally to a syndrome computing apparatus used for the purpose of error detection and correction, and more particularly for the131 of error detection and correction of data coded in accordance with a Bose-Chaudh ⁇ ri- Hocquenghem (BCH) code.
  • BCH Bose-Chaudh ⁇ ri- Hocquenghem
  • a bit error is considered to have happened when the value received is different from the value sent, for example if a logical '0' is received when the transmitted value was a logical '1'.
  • One of the strategies used to overcome this problem is the introduction of error correcting codes.
  • a well- known member of the large family of such codes is the BCH encoding and decoding technique.
  • a BCH code can be used for correction of scattering of single error bits within an input data word.
  • the BCH code is used in satellite communication links, optical networks, etc., where error correction codes are often employed to mitigate the effects of noise interference.
  • An error correction procedure is described herein for a BCH code that corrects up to 't' bit errors, where 't' is a predetermined number.
  • a selection of a large 't' leads to increased length of the redundancy bits in a codeword, and therefore to a more complex decoding process.
  • a typical BCH decoder accomplishes the following steps:
  • step (b) a Berlekamp algorithm (US Patent Nos. 4,162,480 and 4,410,989) may be used.
  • step (c) a search algorithm proposed by Chien, as disclosed in US Patents No. 3,278,729 and 3,418,629, is known to be one of the popular methods.
  • Other relevant prior art may be found in US Patents 4,644,543 to Davis, 5,583,499 to Oh et al., 5,974,582 to Ly, 6,192,497 to Yang et al., 6,279,137 to Poeppelman et al., and 6,374,383 to Weng.
  • c(x) is a codeword if and only if ⁇ ; ° +1 , a h+3 , a i +5 , ..., a h+2t ⁇ l a ⁇ e roots of c(x), where ⁇ is a primitive element of a Galois field of power 2 (GF(2 m )), and where 'm' is the length of the syndrome coefficient (S j ).
  • a Galois field is an algebraic field having a finite number of elements. The number of elements is always of the form p m , where 'p' is a prime number and 'm' is a positive integer.
  • the maxima] length of c(x), including the redundancy bits, is (2 m -l) bits.
  • the value jo is a positive integer between 0 and 2 m -2.
  • a detailed description of the Galois field may be found in "Error Correcting Codes" by W. Wesley Peterson and E. J. Weldon, Jr., MIT 1972, pages 155-160.
  • Circuit 100 includes 't' registers 110-1 through 110-t, coupled to constant multipliers 120-1 through 120-t.
  • a multiplier 120-j multiplies the content of a register 110-j by a corresponding constant ⁇ J , and provides feedback into register 110-j.
  • Circuit 100 further includes 't-1' adders 130-1 through 130-t, serially connected to each other. Adders 130 are also connected to the outputs of registers 110 and to a comparator 140.
  • the corresponding coefficients of the error locator polynomial i.e., ⁇ (x)
  • ⁇ (x) The corresponding coefficients of the error locator polynomial
  • each coefficient ⁇ is multiplied by the appropriate ⁇ J using the corresponding multiplier 120 ? and the resulting value is stored in corresponding register 110.
  • the stored values are summed up by the corresponding adder 130 and compared to zero by comparator 140. If the result of comparator 140 indicates a value of zero, then that value of x is a root and therefore corresponds to an error at location 2 m -l-j bit in the received data word polynomial representation.
  • N is the length of the received input codeword.
  • Circuit 100 is a serial implementation of a Chien search algorithm. Therefore, a single error bit is detected in each pass. In order to detect more than one bit simultaneously, a parallel Chine search circuit is used.
  • Circuit 200 includes 't' ranks 210-1 through 210-t, capable of detecting 'p' error bits concurrently over a different set of values of ⁇ j through ⁇ i+p .
  • Each rank 210 includes a single register 220, 'p' constant multipliers 240-1 through 240-p, and 'p' adders 260-1 through 260-p.
  • the coefficients of ⁇ (x) are loaded to registers 220.
  • the length of each ⁇ (x) coefficient is 'm' bits.
  • each coefficient is also an element in GF(2 m ) .
  • constant multiplier 240-1 is coupled to register 220, to receive the contents of register 220 for multiplication with the constant ⁇ J , where j equals p, 2*p, 3*p,..., p*t.
  • the product is fed back to register 220.
  • the content of register 220 is fed to multipliers 240-2 through 240-p.
  • Each of multipliers 240-2 through 240-p multiplies the content of register 220 with its corresponding value of ⁇ r'k , for V starting at '2' and ending at 'p ⁇ where 'k' is the rank 210 index.
  • the multiplication result of each of multipliers 240-2 through 240-p is fed to its respective adder 260.
  • Comparator 280-i indicates if the i th bit in the received block is an error bit.
  • parameter 'p' defines the number of error bits that can be detected in each cycle
  • parameter 't' defines the total number of error bits that can be corrected in the entire received word.
  • a selection of large 'p ⁇ 'm' and 't' is essential.
  • the number of logic gates required to implement a circuit such as circuit 200, for large values of 'p ⁇ 't', and 'm' is practically impossible in current chip design and manufacturing technologies, due to the large number of gates involved.
  • the number of XOR gates required to implement the logic elements of circuit 200 is
  • the present invention is of a Chien type search apparatus used for the purpose of error detection and correction, and more particularly for the purpose of error detection and correction of data coded in accordance with a Bose-Chaudhuri-Hocquenghem (BCH) code.
  • BCH Bose-Chaudhuri-Hocquenghem
  • each logic rank further includes a constant multiplier used for multiplying a register content with the value of ⁇ F to obtain a product fed to the multiplication logic unit, and a register for holding the product.
  • each of the adders is a modulo-2 adder.
  • the ⁇ *p is an element in the Galois filed GF(2 m ).
  • each multiplication logic unit has 'm' inputs, wherein the plurality of outputs equals 'p*m' outputs, and wherein the outputs are constant functions of the inputs.
  • the multiplication logic unit includes at least a first combinational logic unit having at least m/2 inputs and at most 2 mJ2 outputs, wherein m/2 is an integer number, a second combinational logic unit having at least m/2 inputs and at most 2 /2 outputs, wherein m/2 is an integer number and a third combinational logic unit connected to both the first combinational logic unit and the second combinational logic unit, the third combination logic including p*m outputs.
  • the multiplication logic unit comprises a combinational logic at least
  • the error-locator circuit is configured to operate with a Bose-Chaudhuri-Hocquenghem decoder.
  • the error- locator circuit is configured to operate with a Bose-Chaudhuri-Hocquenghem decoder.
  • Figure 1 is an exemplary block diagram of a conventional serial Chien search circuit (prior art);
  • Figure 2 is an exemplary block diagram of a conventional parallel serial Chien search circuit
  • FIG. 3 is a block diagram of a preferred embodiment of an error-locator circuit, in accordance with one embodiment of the present invention.
  • Figure 4 shows an exemplary block diagram of a multiplication logic unit in accordance with another embodiment of the present invention.
  • Figure 5 is a detailed example showing a preferred implementation of the multiplication logic unit.
  • the present invention provides an apparatus and method capable of determining roots of an error-locator polynomial, where the possible roots are elements of a Galois field.
  • the present invention can be utilized to concurrently detect p' error bits in a received codeword.
  • the number of logic gates to implement the preferred apparatus may be significantly reduced by coupling parallel constant multipliers in each rank, and by replacing the constant multipliers with a unified combinational logic, hence reducing the number logic gates in each rank.
  • Circuit 300 includes 't' ranks 310-1 through 310-t.
  • Each rank 310 is correlated with a different value of ⁇ J and includes: a register 320, a multiplication logic unit (MLU) 330, and p' adders 340-1 through 340-p.
  • Adders 340 are modulo-2 adders, i.e., capable of performing a XOR operation.
  • each of ranks 310 includes a single constant multiplier 360 used for multiplying the content of register 320 with the appropriate value of ⁇ p* ⁇ where 'k' is the rank index.
  • circuit 300 In order to detect an input codeword having 6 N' bits, circuit 300 is clocked N/p times. Each clock, register 320 holds the product of the multiplication between the respective value of ⁇ k p and the previous content of register 320. At the first clock, register 320 loads the respective coefficient of an error correction polynomial ⁇ ;, i.e., the register is initially loaded with the value of ⁇ _.
  • MLU 330 replaces the 'p-l' parallel multipliers of the prior art circuit 200 in Fig. 2 (e.g. 240-2 through 240-t), with a unified combinational logic of XOR gates.
  • MLU 330 performs a constant multiplication between the content of register 320 and the value of ⁇ k where 'j' is an integer starting at 0 and ending at 'p-l', and 'k' is the rank index.
  • the number of XOR gates in MLU 330 is significantly lower than the number of gates required to implement multipliers 240-1 through 240-p.
  • MLU 330 is a key innovative element of the system of the present invention and is described in greater detail below.
  • the products of MLU 330 are grouped to 'p' outputs Y(k, 1) through Y(k, p), where each output includes 'm' bits and is coupled to one of adders 340.
  • parameter 'k' defines the rank index. Specifically, output Y(k, 1) is coupled to adder 340-1, output Y(k, 2) is coupled to adder 340-2 of rank 310-k and so on. The results from the respective adders 340 in each rank are aggregated and fed to the respective comparator 350.
  • outputs Y(l, 1) through Y(t, 1) are aggregated by adders 340-1 of ranks 310-1 through 310-t, and the result is fed to comparator 350-1; outputs Y(l, 2) through Y(t, 2) are aggregated using adders 340-2 of ranks 310-1 through 310-t, and the result is fed to comparator 350-2, and so on.
  • Comparator 350-i indicates if the i th bit in the received block is an error bit.
  • Circuit 300 is specially designed to operate at speeds of 10 GBPS and beyond. Furthermore, the design is suitable for any input codeword length of size of at least 1,000 bits.
  • Fig. 4 shows a block diagram of MLU 330, in accordance with one embodiment of the present invention.
  • MLU 330 is preferably comprised of three combinational logic units, 410, 420, and 430. MLU 330 has 'm' inputs marked as ai through a m and 'p*m' outputs marked as i through b p - m . These outputs are divided into 'p' groups, each having 'm' bits.
  • the inputs i.e., ai through a m are divided into two groups where the first group through am / 2 is connected to logic 410, and the second group awit, /2+ ⁇ through a m is connected to logic 420.
  • Each of these outputs is a binary combination of the 'm/2' inputs.
  • a combination is defined as a XOR operation from a subset of inputs.
  • the number of XOR gates required to implement each of logics 410 and 420 is:
  • combinational logic units 410 and 420 are connected to combinational logic unit 430 at its inputs.
  • MLU 330 A detailed example describing a preferred implementation of MLU 330 is provided below.
  • Fig. 5A shows a detailed example of an exemplary preferred implementation of MLU 330.
  • MLU 500 is performed as follows: first, dividing inputs ai through a 6 into two groups a ⁇ _ a and a 3) and a ⁇ as and a ⁇ where the first group is connected to combinational logic unit 510 and the second group is connected to combinational logic unit 520. Next, computing for each group of inputs all the possible combinations within the group. For each group there are eight possible combinations shown in Fig. 5B.
  • Fig 5B shows the outputs of combinational logic unit 510 (i.e., C] through c g ) and combinational logic unit 520 (i.e., dj through d 8 ) as a function of their inputs.
  • the XOR operations derived from the truth table shown in Fig. 5B are as follows:
  • combinational logic unit 530 is composed.
  • each of combinational logic unit's 530 outputs is a combination of two elements, one from combinational logic unit's 510 and the other from combinational logic unit's 520 outputs.
  • the number of XOR gates used to implement combinational logic unit 530 is at most the number of outputs, i.e., equals 60.
  • the total number of XOR gates required to implement a single MLU is at most 70 (i.e., 5*2+60) XOR gates.
  • an error locator circuit 300 is implemented for 'p', 'm', and 't' equaling 128, 14, and 73 respectively.

Landscapes

  • Physics & Mathematics (AREA)
  • Algebra (AREA)
  • General Physics & Mathematics (AREA)
  • Mathematical Physics (AREA)
  • Pure & Applied Mathematics (AREA)
  • Probability & Statistics with Applications (AREA)
  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Error Detection And Correction (AREA)

Abstract

An apparatus for detecting and correcting error bit in an input word, comprising a plurality of 'k' logic ranks, each rank including a mulitplication logic unit, each multiplication logic unit outputting a plurality of outputs, and a method for performing same. Each logic rank further includes a register for receiving a respective coefficient of an error correcting polynomial to produce a register content, a constant multiplier coupled to the register and used for multiplying the register content with an appropriate value to obtain a product fed into the multiplication logic unit, and a plurality of 'p' adders, each operative to receive a respective output Y(k,i) from the abovementioned plurality of outputs. The apparatus furtehr comprises a pluyrality of comparators, each operative to receive an aggregated input from all adders having the same'i', whereby each comparatos indicates if the received ith bit in the input block is an error bit.

Description

AN ENHANCED CIRCUIT FOR PERFORMING ERROR CORRECTION AND DETECTION OF BCH CODEWORDS
HELD AND BACKGROUND OF THE INVENTION
The present invention relates generally to a syndrome computing apparatus used for the purpose of error detection and correction, and more particularly for the puipose of error detection and correction of data coded in accordance with a Bose-Chaudhυri- Hocquenghem (BCH) code.
In a digital data communication system, digital information is transmitted through a channel to a receiver. Due to noises and/or distortions, the received digital information often contains a number of bit errors. A bit error is considered to have happened when the value received is different from the value sent, for example if a logical '0' is received when the transmitted value was a logical '1'. One of the strategies used to overcome this problem is the introduction of error correcting codes. A well- known member of the large family of such codes is the BCH encoding and decoding technique. A BCH code can be used for correction of scattering of single error bits within an input data word. The BCH code is used in satellite communication links, optical networks, etc., where error correction codes are often employed to mitigate the effects of noise interference. An error correction procedure is described herein for a BCH code that corrects up to 't' bit errors, where 't' is a predetermined number. A selection of a large 't' leads to increased length of the redundancy bits in a codeword, and therefore to a more complex decoding process.
A typical BCH decoder accomplishes the following steps:
(a) calculation of the syndrome coefficient values Sj, for j= 0, 1, 2, . . . , t-1, where 't' is the maximum number of bit errors to be corrected, within each received word;
(b) determination of an error-locator polynomial σ(x) from the syndrome values Sj, for j=0,l,2, . . . , t-l ; and
(c) determination of the location of the erroneous bit(s) by finding the roots of σ(x)=0.
For step (b), a Berlekamp algorithm (US Patent Nos. 4,162,480 and 4,410,989) may be used. For step (c), a search algorithm proposed by Chien, as disclosed in US Patents No. 3,278,729 and 3,418,629, is known to be one of the popular methods. Other relevant prior art may be found in US Patents 4,644,543 to Davis, 5,583,499 to Oh et al., 5,974,582 to Ly, 6,192,497 to Yang et al., 6,279,137 to Poeppelman et al., and 6,374,383 to Weng. In a BCH code, c(x) is a codeword if and only if α;°+1 , ah+3 , ai +5 , ..., ah+2t~l aιe roots of c(x), where α is a primitive element of a Galois field of power 2 (GF(2m)), and where 'm' is the length of the syndrome coefficient (Sj). A Galois field is an algebraic field having a finite number of elements. The number of elements is always of the form pm, where 'p' is a prime number and 'm' is a positive integer. The maxima] length of c(x), including the redundancy bits, is (2m-l) bits. The value jo is a positive integer between 0 and 2m-2. A detailed description of the Galois field may be found in "Error Correcting Codes" by W. Wesley Peterson and E. J. Weldon, Jr., MIT 1972, pages 155-160.
The mathematics underlying the BCH decoding are known to those skilled in the art of coding, and are described in detail in "Error Correcting Codes" by W. Wesley Peterson and E. J. Weldon, Jr., MIT 1972 pages 283-288.
As mentioned above, the determination of the location of the erroneous bit(s) is achieved by finding the roots of σ(x). The polynomial σ(x) is defined as follows:
σ{x) = l + γjσixi ; (1)
)'=!
where 't' is as defined above. The roots of the polynomial σ(x) are αJ , which are elements in the GF(2m).
Reference is now made to Fig. 1, which shows an exemplary block diagram of a conventional search circuit 100 for finding a set of error locations according to Chien above. Circuit 100 includes 't' registers 110-1 through 110-t, coupled to constant multipliers 120-1 through 120-t. A multiplier 120-j multiplies the content of a register 110-j by a corresponding constant αJ, and provides feedback into register 110-j. Circuit 100 further includes 't-1' adders 130-1 through 130-t, serially connected to each other. Adders 130 are also connected to the outputs of registers 110 and to a comparator 140. The corresponding coefficients of the error locator polynomial (i.e., σ(x)) are parallel-loaded into their corresponding registers 110. Subsequently, each coefficient η is multiplied by the appropriate αJ using the corresponding multiplier 120? and the resulting value is stored in corresponding register 110. The stored values are summed up by the corresponding adder 130 and compared to zero by comparator 140. If the result of comparator 140 indicates a value of zero, then that value of x is a root and therefore corresponds to an error at location 2m-l-j bit in the received data word polynomial representation.
Circuitry 100 is clocked N times to evaluate the locator polynomial at all possible values of x, i.e., x = (αj)°, (αJ)!' (α )2 . . . , (αJ)n"!, for all powers of α. N is the length of the received input codeword. Thus, the next clocking of coefficients through the circuit multiplies αJ times the contents of the particular register 110, e.g., α1 is multiplied by the stored σι(α') to give σι(α2).
Circuit 100 is a serial implementation of a Chien search algorithm. Therefore, a single error bit is detected in each pass. In order to detect more than one bit simultaneously, a parallel Chine search circuit is used.
Reference is now made to Fig. 2, which shows a schematic block diagram of a parallel Chien search circuit 200. Circuit 200 includes 't' ranks 210-1 through 210-t, capable of detecting 'p' error bits concurrently over a different set of values of αj through αi+p . Each rank 210 includes a single register 220, 'p' constant multipliers 240-1 through 240-p, and 'p' adders 260-1 through 260-p. Initially, the coefficients of σ(x) are loaded to registers 220. The length of each σ(x) coefficient is 'm' bits. As mentioned above, each coefficient is also an element in GF(2m) .
In each rank, constant multiplier 240-1 is coupled to register 220, to receive the contents of register 220 for multiplication with the constant αJ, where j equals p, 2*p, 3*p,..., p*t. The product is fed back to register 220. In addition, the content of register 220 is fed to multipliers 240-2 through 240-p. Each of multipliers 240-2 through 240-p multiplies the content of register 220 with its corresponding value of αr'k, for V starting at '2' and ending at 'p\ where 'k' is the rank 210 index. The multiplication result of each of multipliers 240-2 through 240-p is fed to its respective adder 260. Namely, the product of multiplier 240-2 is fed to adder 260-2, the product of multiplier 240-3 is fed to adder 260-3, and so on. Subsequently, the result of adders 260-1 in ranks 210-1 through 210-t are aggregated and sent to comparator 280-1, the result of adders 260-2 in ranks 210-1 through 210-t are aggregated and sent to comparator 280-2, etc. The same is true for the other comparators in circuit 200. Comparator 280-i indicates if the ith bit in the received block is an error bit. The parameters sp', 'm', and ct' mentioned above determine the decoder performance.
Specifically, parameter 'p' defines the number of error bits that can be detected in each cycle, while parameter 't' defines the total number of error bits that can be corrected in the entire received word. Hence, in order to ensure good performance, a selection of large 'p\ 'm' and 't' is essential. However, the number of logic gates required to implement a circuit such as circuit 200, for large values of 'p\ 't', and 'm', is practically impossible in current chip design and manufacturing technologies, due to the large number of gates involved. For example, the number of XOR gates required to implement the logic elements of circuit 200 is
at least: p - m - (m-\X - t XOR gates. Selecting 'p\ 't\ and 'm' equal to 128, 73, and 14 v 2 J respectively, requires close to one million XOR gates, which are more complex gates than regular logic gates, either requiring multiple transistors or a lower level implementation of several basic logic gates.
Therefore, it would be advantageous to provide a parallel error-locator (i.e., Chien search) circuit with a minimal number of logic gates. In particular, it would be advantageous to provide an apparatus and method capable of determining roots of an error-locator polynomial, and to concurrently detect 'p' error bits in a received codeword.
SUMMARY OF THE INVENTION
The present invention is of a Chien type search apparatus used for the purpose of error detection and correction, and more particularly for the purpose of error detection and correction of data coded in accordance with a Bose-Chaudhuri-Hocquenghem (BCH) code.
According to the present invention there is provided an error-locator circuit capable of detecting and correcting error bits in an input word, the circuit detecting, per cycle, an input block of 'p' bits belonging to the input word, the circuit comprising: a plurality of 't' logic ranks of index 'k' wherein k=l, 2,...t, each logic rank including a multiplication logic unit, each multiplication logic unit outputting a plurality of i=l,2,..p outputs; a plurality of p' adders included in each logic rank 'k', each of the adders operative to receive a respective output Y(k, i) of the plurality of outputs; and a plurality of 'p' comparators, each of the comparators operative to receive an aggregated input from all adders of the 't' ranks having the same 'i', whereby each comparator indicates if the received il bit in the input block is an error bit.
According to one feature in the error-locator circuit of the present invention, each logic rank further includes a constant multiplier used for multiplying a register content with the value of α F to obtain a product fed to the multiplication logic unit, and a register for holding the product. According to another feature in the error-locator circuit of the present invention, each of the adders is a modulo-2 adder.
According to yet another feature in the error-locator circuit of the present invention, the α *pis an element in the Galois filed GF(2m).
According to yet another feature in the error-locator circuit of the present invention, each multiplication logic unit has 'm' inputs, wherein the plurality of outputs equals 'p*m' outputs, and wherein the outputs are constant functions of the inputs.
According to yet another feature in the error-locator circuit of the present invention, the multiplication logic unit includes at least a first combinational logic unit having at least m/2 inputs and at most 2mJ2 outputs, wherein m/2 is an integer number, a second combinational logic unit having at least m/2 inputs and at most 2 /2 outputs, wherein m/2 is an integer number and a third combinational logic unit connected to both the first combinational logic unit and the second combinational logic unit, the third combination logic including p*m outputs.
According to yet another feature in the error-locator circuit of the present invention, the multiplication logic unit comprises a combinational logic at least
• 2 + p * m of exclusive-or (XOR) gates.
Figure imgf000006_0001
According to yet another feature in the error-locator circuit of the present invention, the error-locator circuit is configured to operate with a Bose-Chaudhuri-Hocquenghem decoder.
According to the present invention there is provided an integrated circuit (IC) capable of detecting and correcting error bits in an input word, the integrated circuit detecting, per cycle, an input block of 'p' bits belonging to the input word, comprising: a plurality of 't' logic ranks of index 'k' wherein k=l, 2,...t, each of the logic ranks including a multiplication logic unit, each multiplication logic unit outputting a plurality of i=l,2,..p outputs, each logic rank further including a register for receiving a respective coefficient of an error correcting polynomial to produce a register content, the register coupled to the multiplication logic unit, a constant multiplier coupled to the register and used for multiplying the register content with an appropriate value to obtain a product fed to the multiplication logic unit, and a plurality of 'p' adders, each of the adders operative to receive a respective output Y(k, i) of the plurality of outputs; and a plurality of p' comparators, each of the comparators operative to receive an aggregated input from all adders of the 't' ranks having the same 'i', whereby each comparator indicates if the received ilh bit in the input block is an error bit.
According to a feature in the integrated circuit of the present invention, the error- locator circuit is configured to operate with a Bose-Chaudhuri-Hocquenghem decoder.
According to the present invention there is provided a multiplication logic unit (MLU) comprising: at least one first combinational logic unit having at least m/2 first inputs and at most 2m 2 first outputs, wherein m/2 is an integer number at least one second combinational logic unit having at least m/2 second inputs and at most 2m/2 second outputs, and at least one third combinational logic unit connected to the first and the second combinational logic units, the third combination logic including 'p*m' outputs, whereby the MLU is capable of multiplying between 'm' input bits and j= p-l ' different values of an element αk*j.
According to the present invention there is provided a method for detecting and correcting error bits in an input word, comprising the steps of: per cycle, detecting an input block of p' bits belonging to the input word, multiplying between a respective value αk*p and a register content to obtain a multiplication product, and saving the multiplication product in the register; providing a plurality of 't' logic ranks of index 'k' wherein k=l, 2,...t, each of the logic ranks operative to output a plurality of p' outputs, each output including a respective multiplication product; adding a respective output Y(k, i) of the plurality of outputs in an adder 'i' of a plurality of p' adders included in each logic rank 'k'; forming an aggregate input from all adders of the 't' ranks having the same 'i'; and providing the aggregate input to a comparator operative to indicate if the received il bit in the input block is an error bit.
BRIEF DESCRIPTION OF THE DRAWINGS
The invention is herein described, by way of example only, with reference to the accompanying drawings, wherein: Figure 1 is an exemplary block diagram of a conventional serial Chien search circuit (prior art);
Figure 2 is an exemplary block diagram of a conventional parallel serial Chien search circuit
(prior art);
Figure 3 is a block diagram of a preferred embodiment of an error-locator circuit, in accordance with one embodiment of the present invention; '
Figure 4 shows an exemplary block diagram of a multiplication logic unit in accordance with another embodiment of the present invention;
Figure 5 is a detailed example showing a preferred implementation of the multiplication logic unit.
DESCRIPTION OF THE PREFERRED EMBODIMENTS
The present invention provides an apparatus and method capable of determining roots of an error-locator polynomial, where the possible roots are elements of a Galois field. The present invention can be utilized to concurrently detect p' error bits in a received codeword. In accordance with the present invention, the number of logic gates to implement the preferred apparatus may be significantly reduced by coupling parallel constant multipliers in each rank, and by replacing the constant multipliers with a unified combinational logic, hence reducing the number logic gates in each rank.
Reference is now made to Fig. 3, which shows a block diagram of an error-locator circuit 300, implemented in accordance with the present invention. Circuit 300 includes 't' ranks 310-1 through 310-t. Each rank 310 is correlated with a different value of αJ and includes: a register 320, a multiplication logic unit (MLU) 330, and p' adders 340-1 through 340-p. Adders 340 are modulo-2 adders, i.e., capable of performing a XOR operation. Further, each of ranks 310 includes a single constant multiplier 360 used for multiplying the content of register 320 with the appropriate value of αp*\ where 'k' is the rank index. In order to detect an input codeword having 6N' bits, circuit 300 is clocked N/p times. Each clock, register 320 holds the product of the multiplication between the respective value of αk p and the previous content of register 320. At the first clock, register 320 loads the respective coefficient of an error correction polynomial σ;, i.e., the register is initially loaded with the value of σ_. MLU 330 replaces the 'p-l' parallel multipliers of the prior art circuit 200 in Fig. 2 (e.g. 240-2 through 240-t), with a unified combinational logic of XOR gates. MLU 330 performs a constant multiplication between the content of register 320 and the value of αk where 'j' is an integer starting at 0 and ending at 'p-l', and 'k' is the rank index. The number of XOR gates in MLU 330 is significantly lower than the number of gates required to implement multipliers 240-1 through 240-p. The inventors have found that replacing the 'p-l' constant multipliers by an improved combinational logic (i.e., MLU 330) is possible, since the outputs of MLU 330 are constant functions of its inputs. MLU 330 is a key innovative element of the system of the present invention and is described in greater detail below.
The products of MLU 330 are grouped to 'p' outputs Y(k, 1) through Y(k, p), where each output includes 'm' bits and is coupled to one of adders 340. As mentioned, parameter 'k' defines the rank index. Specifically, output Y(k, 1) is coupled to adder 340-1, output Y(k, 2) is coupled to adder 340-2 of rank 310-k and so on. The results from the respective adders 340 in each rank are aggregated and fed to the respective comparator 350. That is, outputs Y(l, 1) through Y(t, 1) are aggregated by adders 340-1 of ranks 310-1 through 310-t, and the result is fed to comparator 350-1; outputs Y(l, 2) through Y(t, 2) are aggregated using adders 340-2 of ranks 310-1 through 310-t, and the result is fed to comparator 350-2, and so on. Comparator 350-i indicates if the ith bit in the received block is an error bit.
Circuit 300 is specially designed to operate at speeds of 10 GBPS and beyond. Furthermore, the design is suitable for any input codeword length of size of at least 1,000 bits. Reference is now made to Fig. 4, which shows a block diagram of MLU 330, in accordance with one embodiment of the present invention. MLU 330 is preferably comprised of three combinational logic units, 410, 420, and 430. MLU 330 has 'm' inputs marked as ai through am and 'p*m' outputs marked as i through bp-m. These outputs are divided into 'p' groups, each having 'm' bits. The inputs, i.e., ai through am are divided into two groups where the first group
Figure imgf000010_0001
through am/2 is connected to logic 410, and the second group a„,/2+ι through am is connected to logic 420. Each of logics 410 and 420 includes 2(m/2) outputs marked as ci through cr and di through dr, respectively, where r=2( '. Each of these outputs is a binary combination of the 'm/2' inputs. A combination is defined as a XOR operation from a subset of inputs. Hence, the number of XOR gates required to implement each of logics 410 and 420 is:
Figure imgf000010_0002
(or 420) inputs, i.e. the number of '1' in a truth table for the inputs i _ am/2- Since, two
inputs require a single XOR gate, the quantity 1 is subtracted from the first quantity.
Figure imgf000010_0003
Notice that only the 1st row in the truth table does not have any '1'. This is the reason for the '-1' in the formula.
The outputs of combinational logic units 410 and 420 are connected to combinational logic unit 430 at its inputs. Each of combinational logic unit's 430 outputs is a combination of at most two inputs, one from logic 410 and the other from logic 420. That is, b = Cj + d] where 'bk', 'CJ', and 'di' are one of combinational logic units' 430, 410, and 420 outputs respectively. Since each output of combinational logic unit 430 requires one XOR gate, a total of at most 'p*m' XOR gates are required to utilize combinational logic unit 430. A detailed example describing a preferred implementation of MLU 330 is provided below.
The total number of XOR gates required to implement MLU is:
Figure imgf000011_0001
where 'p' and 'm' are as defined above.
Reference is now made to Fig. 5A, which shows a detailed example of an exemplary preferred implementation of MLU 330. The example shows an exemplary MLU 500 having six inputs (i.e., m=6) marked as aj through a6. With a 'p' equal to 10, there are 60 outputs (i.e. p*m= 10*6=60') marked as d] through d60.
The implementation of MLU 500 is performed as follows: first, dividing inputs ai through a6 into two groups aι_ a and a3) and a^ as and a^ where the first group is connected to combinational logic unit 510 and the second group is connected to combinational logic unit 520. Next, computing for each group of inputs all the possible combinations within the group. For each group there are eight possible combinations shown in Fig. 5B. Fig 5B shows the outputs of combinational logic unit 510 (i.e., C] through cg) and combinational logic unit 520 (i.e., dj through d8) as a function of their inputs. The XOR operations derived from the truth table shown in Fig. 5B are as follows:
For combinational logic unit 510,
cι = 0; c2 = a3; c3 = a2; c4= a2 θ a3; c6= a] © a3; c7 = aι © a2;
Figure imgf000011_0002
For combinational logic unit 520,
d4= 0; d5 = a6; 6 = a5; d = a5 θ a6; 5= ^; d6= a4 θ a6; d7= a4θ a5; d8 = a4θ a5θ ag.
Hence, in order to implement combinational logic units 510 and 520 ten XOR gates are required. Finally, combinational logic unit 530 is composed. As mentioned above, each of combinational logic unit's 530 outputs is a combination of two elements, one from combinational logic unit's 510 and the other from combinational logic unit's 520 outputs. For example, b may be a combination of al , a3, a5 and a6, i.e., b = aj θ a3 θ a5 θ a6. As, &\ θ a3 equals to c6 and a5 θ a6 equals d , b may be presented as c6 Φ d , i.e., b = c6 θ d . This process repeats for all the outputs of combinational logic unit 530. The number of XOR gates used to implement combinational logic unit 530 is at most the number of outputs, i.e., equals 60. The total number of XOR gates required to implement a single MLU is at most 70 (i.e., 5*2+60) XOR gates.
In order to implement an error-locator circuit (e.g., circuit 300) using MLU 500, only 70*t + C XOR gates are required, as opposed to prior art approaches where [10*6*(6- l)/2]*t + C = 150*t + C XOR gates. The parameter 'C is a constant number of logic gates required to implement the other components of the circuit, e.g., registers, adders, and comparators. As can be seen the total saving is about 80*t XOR gates. It should be appreciated by a person skilled in the art that the total saving of XOR gates is extensively increased for larger values of p', 'm' and 't\
In another embodiment of the present invention, an error locator circuit 300 is implemented for 'p', 'm', and 't' equaling 128, 14, and 73 respectively. In such an embodiment the total number of XOR gates for circuit 300 is: 2434*t + C = 177,682 + C. In order to implement circuit 300 using the approach shown in the prior art
p - m - fm -lλ \ - t + C = 850, 304 +C XOR gates are required. Obviously, the apparatus
\ ' ) disclosed herein significantly reduces the required XOR gates count. All publications, patents and patent applications mentioned in this specification are herein incorporated in their entirety by reference into the specification, to the same extent as if each individual publication, patent or patent application was specifically and individually indicated to be incorporated herein by reference. In addition, citation or identification of any reference in this application shall not be construed as an admission that such reference is available as prior art to the present invention.

Claims

WHAT IS CLAIMED IS
1. An error-locator circuit capable of detecting and correcting error bits in an input word, the circuit detecting, per cycle, an input block of 'p' bits belonging to the input word, comprising: a. a plurality of 't' logic ranks of index 'k' wherein k=l, 2,...t, each of said logic ranks including a multiplication logic unit, each said multiplication logic unit outputting a plurality of i=l,2,..p outputs, each of said outputs is of 'm' bits; b. a plurality of p' adders included in each said logic rank 'k', each of said adders operative to receive a respective output Y(k, i) of said plurality of outputs; and c. a plurality of 'p' comparators, each of said comparators operative to receive an aggregated input from all adders of said 't' ranks having the same , whereby each said comparator indicates if the received iΛ bit in the input block is an error bit.
2. The error locating circuit of claim 1, wherein each said logic rank further includes: i. a constant multiplier used for multiplying a register content with the value of αk*p to obtain a product fed to said multiplication logic unit; and, ii. a register for holding said product.
3. The error locating circuit of claim 2, wherein said register content includes an initial content identical with a value of a respective coefficient of an error locator polynomial σj.
4. The error-locator circuit of claim 1, wherein each of said adders is a modulo-2 adder.
5. The error-locator circuit of claim 2, wherein said αk*p is an element in the Galois filed GF(2m).
6. The error-locator circuit of claim 5, wherein said αk p includes *m' bits.
7. The error-locator circuit of claim 5, wherein said αk^phas a constant value.
8. The error-locator circuit of claim 1, wherein said multiplication logic unit has 'm' inputs, wherein said plurality of outputs equals 'p*m' outputs, and wherein said outputs are constant functions of said inputs.
9. The error-locator circuit of claim 8, wherein said multiplication logic unit is capable of multiplying the content of said register with 'p-l' different values of α k*j
10. The error-locator circuit of claim 1, wherein said multiplication logic unit comprises a combinational logic of exclusive-or (XOR) gates.
11. The error-locator circuit of claim 10, wherein the number of XOR gates is at most
Figure imgf000015_0001
12. The error-locator circuit of claim 8, wherein said multiplication logic unit includes at least: i. a first combinational logic unit having at least m 2 inputs and at most 2 ,m/2 outputs, wherein said m/2 is an integer number ii. a second combinational logic unit having at least m/2 inputs and at most 2m/2 outputs, wherein said m/2 is an integer number;and, iii. a third combinational logic unit connected to both said first combinational logic unit and said second combinational logic unit, said third combinational logic including said p*m outputs.
13. The error-locator circuit of claim 12, wherein said outputs of said first combinational logic unit are binary combinations of said inputs of said first combinational logic.
14. The error-locator circuit of claim 12, wherein said outputs of said second combinational logic unit are binary combinations of said inputs of said second combinational logic.
15. The error-locator circuit of claim 12, wherein each of said outputs of said third combinational logic is a binary combinational of a single output of said second combinational logic unit and a single output of said first combinational logic unit.
16. The error-locator circuit of claim 15, wherein said binary combination is defined as a XOR operation.
17. The error-locator circuit of claim 1, designed to operate at rates in excess of 10 gigabit per second.
18. The error-locator circuit of claim 1, wherein said parameter 't' is the number of correctable bits in each input word.
19. The error-locator circuit of claim 1, wherein said parameters p' and 't' equal to 128 and 73 respectively.
20. The error-locator circuit of claim 1, wherein said error-locator circuit is configured to operate with a Bose-Chaudhuri-Hocquenghem decoder.
21. An integrated circuit (IC) capable of detecting and correcting error bits in an input word, the integrated circuit detecting, per cycle, an input block of 'p' bits belonging to the input word, comprising: a. a plurality of 't' logic ranks of index 'k' wherein k=l, 2,...t, each of said logic ranks including a multiplication logic unit, each said multiplication logic unit outputting a plurality of i=l,2,..p outputs, each said logic rank further including: i. a register for receiving a respective coefficient of an error correcting polynomial to produce a register content, said register coupled to said multiplication logic unit; ii. a constant multiplier coupled to said register and used for multiplying said register content with an appropriate value to obtain a product fed to said multiplication logic unit; and iii. a plurality of p' adders, each of said adders operative to receive a respective output Y(k, i) of said plurality of outputs; and
b. a plurality of p' comparators, each of said comparators operative to receive an aggregated input from all adders of said ranks having the same T, whereby each said comparator indicates if the received ith bit in the input block is an error bit.
22. The integrated circuit of claim 21, wherein each of said adders is a modulo-2 adder.
23. The integrated circuit of claim 21, wherein said value is a value αk p, and wherein said register is configured to also hold a product of the multiplication between said α p value and a previous register content.
24. The integrated circuit of claim 23, wherein said αk"p is an element in the Galois field GF(2m).
25. The integrated circuit of claim 24, wherein said αk p includes 'm' bits.
26. The integrated circuit of claim 24, wherein said αk phas a constant value.
27. The integrated circuit of claim 21, wherein said multiplication logic unit has 'm' inputs, wherein said plurality of outputs equals 'p*m' outputs, and wherein said outputs are constant functions of said inputs.
28. The integrated circuit of claim 21, wherein said multiplication logic unit is capable of multiplying the content of said register with 'p-l' different values of αk*j.
29. The integrated circuit of claim 21, wherein said multiplication logic unit includes a combinational logic of exclusive-or (XOR) gates.
30. The integrated circuit of claim 29, wherein the number of said XOR gates
Figure imgf000018_0001
31. The integrated circuit of claim 27, wherein said multiplication logic unit includes at least: i. a first combinational logic unit having at least m 2 inputs and at most 2 outputs, wherein said m/2 is an integer number ii. a second combinational logic unit having at least m/2 inputs and at most 2m/2 outputs, wherein said m/2 is an integer number, and, iii. a third combinational logic unit connected to both said first combinational logic unit and said second combinational logic unit, said third combination logic including said 'p*m' outputs.
32. The integrated circuit of claim 31 , wherein said outputs of said first combinational logic unit are binary combinations of said inputs of said first combinational logic.
33. The integrated circuit of claim 31, wherein said outputs of said second combinational logic unit are binary combinations of said inputs of said second combinational logic.
34. The integrated circuit of claim 31, wherein each of said outputs of said third combinational logic is a binary combinational of a single output of said second combinational logic unit and a single output of said first combinational logic unit.
35. The integrated circuit of claim 34, wherein said binary combination is defined as a XOR operation.
36. The integrated circuit of claim 21, designed to operate at rates in excess of 10 gigabit per second.
37. The integrated circuit of claim 21 , wherein said parameter 't' is the number of correctable bits in each codeword.
38. The integrated circuit of claim 21, wherein said parameters 'p' and Y equal to 128 and 73 respectively.
39. The integrated circuit of claim 21, wherein said integrated circuit is capable to operate with a Bose-Chaudhuri-Hocquenghem decoder.
40. A multiplication logic unit (MLU) comprising: a. at least one first combinational logic unit having at least m/2 first inputs and at most 2 first outputs, wherein said m/2 is an integer number-. b. at least one second combinational logic unit having at least m/2 second inputs and at most 2 second outputs, wherein said m 2 is an integer number-, and, c. at least one third combinational logic unit connected to said first combination logic unit and said second combinational logic unit, said third combination logic including p*m' outputs, whereby the MLU is capable of multiplying between 'm' input bits and j= 'p-l ' different values of an element αk
41. The multiplication logic unit of claim 40, wherein said first outputs of said first combinational logic unit are binary combinations of said first inputs, wherein said second outputs of said second combinational logic unit are binary combinations of said second inputs, and wherein each of said third outputs of said third combinational logic is a binary combination of a single said first output and of a single said second output.
42. The multiplication logic unit circuit of claim 41, wherein each said binary combination is defined as an XOR operation.
43. The multiplication logic unit of claim 40, wherein said 'p*m' outputs are divided to 'p' groups.
44. The multiplication logic unit of claim 40, wherein said αk*j is a term in the Galois field GF(2m).
45. The multiplication logic unit of claim 44, wherein said 'm' is the length of said αk*j.
46. The multiplication logic unit of claim 44, wherein said αk J has a constant value.
47. The multiplication logic unit of claim 40, wherein said MLU includes a combinational logic of exclusive or (XOR) gates.
48. The multiplication logic unit of claim 47, wherein the number of said
Figure imgf000021_0001
49. A method for detecting and correcting error bits in an input word, comprising the steps of: a. per cycle, detecting an input block of 'p' bits belonging to the input word, b. multiplying between a respective value α p and a register content to obtain multiplication product, and saving said multiplication product in said register; c. providing a plurality of 't' logic ranks of index 'k' wherein k=l, 2,...t, each of said logic ranks operative to output a plurality of 'p' outputs, each said output including a respective Y(k i) product; d. adding said respective product Y(k, i) of said plurality of outputs in an adder 'i' of a plurality of p' adders included in each said logic rank 'k'; e. forming an aggregate input from all adders of said 't' ranks having the same ; and f. providing said aggregate input to a comparator operative to indicate if the received il bit in said input block is an error bit.
50. The method of claim 49, wherein said operativeness to output a plurality of 'p' outputs is facilitated by a multiplication logic unit included in each said rank.
51. The method of claim 49, wherein said register content includes an initial content having the value of a respective coefficient of an error correcting polynomial øj.
52. The method of claim 49, wherein said αk"p is an element in the Galois filed GF(2m).
53. The method of claim 49, wherein said a1 p includes 'm' bits.
54. The method of claim 49, wherein said ak phas a constant value.
PCT/IL2003/000322 2003-04-16 2003-04-16 An enhanced circuit for performing error correction and detection of bch codewords WO2004093325A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
PCT/IL2003/000322 WO2004093325A1 (en) 2003-04-16 2003-04-16 An enhanced circuit for performing error correction and detection of bch codewords
AU2003222417A AU2003222417A1 (en) 2003-04-16 2003-04-16 An enhanced circuit for performing error correction and detection of bch codewords

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/IL2003/000322 WO2004093325A1 (en) 2003-04-16 2003-04-16 An enhanced circuit for performing error correction and detection of bch codewords

Publications (1)

Publication Number Publication Date
WO2004093325A1 true WO2004093325A1 (en) 2004-10-28

Family

ID=33187207

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/IL2003/000322 WO2004093325A1 (en) 2003-04-16 2003-04-16 An enhanced circuit for performing error correction and detection of bch codewords

Country Status (2)

Country Link
AU (1) AU2003222417A1 (en)
WO (1) WO2004093325A1 (en)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5416786A (en) * 1991-06-28 1995-05-16 Industrial Technology Research Institute Error correction circuit for BCH codewords
US6263471B1 (en) * 1999-03-05 2001-07-17 Industrial Technology Research Institute Method and apparatus for decoding an error correction code
US6374383B1 (en) * 1999-06-07 2002-04-16 Maxtor Corporation Determining error locations using error correction codes
US6449746B1 (en) * 1998-08-17 2002-09-10 T. K. Truong Decoding method for correcting both erasures and errors of reed-solomon codes
US6539516B2 (en) * 1998-11-09 2003-03-25 Broadcom Corporation Forward error corrector

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5416786A (en) * 1991-06-28 1995-05-16 Industrial Technology Research Institute Error correction circuit for BCH codewords
US6449746B1 (en) * 1998-08-17 2002-09-10 T. K. Truong Decoding method for correcting both erasures and errors of reed-solomon codes
US6539516B2 (en) * 1998-11-09 2003-03-25 Broadcom Corporation Forward error corrector
US6263471B1 (en) * 1999-03-05 2001-07-17 Industrial Technology Research Institute Method and apparatus for decoding an error correction code
US6374383B1 (en) * 1999-06-07 2002-04-16 Maxtor Corporation Determining error locations using error correction codes

Also Published As

Publication number Publication date
AU2003222417A1 (en) 2004-11-04

Similar Documents

Publication Publication Date Title
US6539515B1 (en) Accelerated Reed-Solomon error correction
JP3256517B2 (en) Encoding circuit, circuit, parity generation method, and storage medium
US6374383B1 (en) Determining error locations using error correction codes
FI114515B (en) Method and apparatus for optimizing a decoder
US20020023246A1 (en) Combination reed-solomon and turbo coding
US5440570A (en) Real-time binary BCH decoder
US6920600B2 (en) Dual chien search blocks in an error-correcting decoder
US20080040644A1 (en) Method of correcting message errors using cyclic redundancy checks
EP1464121A2 (en) Erasure-and-single-error correction decoder for linear block codes
US8700971B2 (en) Parallel residue arithmetic operation unit and parallel residue arithmetic operating method
MXPA04007076A (en) Intra-decoder component block messaging.
Shrivastava et al. Error detection and correction using Reed Solomon codes
KR20030095249A (en) Reed-solomon decoder
US20030140302A1 (en) Chien search cell for an error-correcting decoder
US8631307B2 (en) Method for encoding and/or decoding multimensional and a system comprising such method
US6735737B2 (en) Error correction structures and methods
US20080270873A1 (en) Decoding Method for Algebraic Geometric Codes and Associated Device
CN108574490B (en) Method and device for calculating Cyclic Redundancy Check (CRC) code
US20030041300A1 (en) Universal device for processing Reed-Solomon forward error-correction encoded messages
WO2009018184A1 (en) Syndrome-error mapping method for decoding linear and cyclic codes
WO2004093325A1 (en) An enhanced circuit for performing error correction and detection of bch codewords
Kaabouch et al. Improvement of the Orthogonal Code Convolution capabilities using FPGA implementation
US7155656B1 (en) Method and system for decoding of binary shortened cyclic code
US9032277B1 (en) Parallel low and asymmetric rate Reed Solomon coding
JP3268926B2 (en) Error correction circuit

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NI NO NZ OM PH PL PT RO RU SC SD SE SG SK SL TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
32PN Ep: public notification in the ep bulletin as address of the adressee cannot be established

Free format text: NOTING OF LOSS OF RIGHTS PURSUANT TO RULE 69(1) EPC. EPO FORM 1205A DATED 01-02-06

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: JP

WWW Wipo information: withdrawn in national office

Country of ref document: JP