The present invention relates to a multi-code Chien's search circuit. More particularly, the present invention relates to a multi-code Chien's search circuit for BCH codes with various values of m in GF(2m).
Bose-Chaudhuri-Hocquenghem (BCH) code is one of the most widely used error correction code (ECC) techniques in the storage and communication devices. BCH code can detect and correct random errors occurred due to channel noises and defects within memory devices. The encoding procedures of BCH code word can be implemented by linear feedback shift register (LFSR) and some combination logics together. Comparing with encoding procedures of the BCH code words, decoding procedures of the BCH code words are much complicated as shown in
Conventionally, Peterson-Gorenstein-Zierler (PGZ) algorithm or Berlekamp-Massey (BM) algorithm can be used to find out the aforementioned error-location polynomial. Since the complexity of the PGZ algorithm is higher than the BM algorithm and the BM algorithm can process decoding with faster speed, the BM algorithm is more popular in hardware implementation. However, due to the multiplication inverse used in the BM algorithm, complexity of hardware of the circuit increases significantly.
According to the error-location polynomial λ(x)=λ0+λ1x+ . . . +λtxt, the roots of λ(x) can be found simply by substituting 1, α, α2, . . . , αn-1 (n=2m−1) into λ(x). Since αn=1, α−1=αn-1. Therefore, if α1 is an error-location number, αn-1 is another error-location number. Conventionally, this substitution procedure can be operated iteratively by Chien's search. However, this sequential circuit only can find one error location number per clock. In order to improve the throughput of BCH decoding per clock, parallel computation architecture can be applied in the step of Chien's search as shown in
Let λ1x+ . . . +λtxt in the error location polynomial λ(x) to be Y(x). If αi is a root of λ(x), we can have Y(αi)=1. Under an architecture of p parallel computations, Y(αup+i) can be reformed as:
Due to parallelization, the number of iterative operations becomes [n/p]. Numeral u represents the number of iterative operations currently and ωj is an updated value in each iterative operations, where 1≦i≦p and 1≦j≦t. When the order in Galois field in 2m, there are pt finite field multipliers, p t-input m-bit finite field adders, t m-bit registers and t m-bit multiplexers in the parallel computation architecture in
If ωjαij in the above function is expressed as a matrix, we can have
where Ωj and Aij are a binary m×m matrix and a binary 1×m matrix, respectively. ωjαij represents computed results from a finite field multiplexer the ith row and the jth column. Therefore, Y(αup+i) can be derived from:
Please notice that Y(αup+i) is a 1×m matrix. In order to express all outputs in
where Ω(u) is a 1×mt binary matrix, representing intermediate values of the uth iterative operation, Ay is constant and independent of the iterative operation. It should be noticed that computations of the Chien's search under the architecture of p parallel computations are all formulated in one single matrix from the multiplication of Ω(u) and Ay.
Further, updated values of Ω(u) can be used in the next iterative operations. Thus, Ω(u+1)=[ω1αp ω2α2p . . . ωtαtp] and
Finally, it is obtained that [Y(u) Ω(u+1)]=Ω(u)[Ay AΩ]. The Chien's search circuit having the architecture of p parallel computations for implementing the aforementioned formula is shown in
The circuit design mentioned above can only applied to a fixed code rate and coed length over the same GF(2m). For some applications requiring different code rates, coed lengths even different m in GF(2m), it is not applicable. Hence, a new Chien's search circuit is needed to fulfill the above requirement.
According to the description mentioned above, circuit designs for encoding BCH codes can only be applicable for the fixed code rate, fixed coed length and the same value of m in (2m). Therefore, a new Chien's search circuit is required for applications on different code rates, different coed lengths and different m in GF(2m)
Therefore, according to an aspect of the present invention, a multi-code Chien's search circuit for BCH codes with various values of m in GF(2m) is disclosed. The circuit includes: a combined matrix unit, for providing a number of Chien's search matrices, receiving a number of inputted values, multiplying the inputted values by partial or all elements in one or more Chien's search matrix to get first operation values and second operation values, outputting the first operation values, and outputting the second operation values according to different properties of the inputted values via one of a number of line groups; a number of first multiplexers, each first multiplexer connected with one line in each line group and receiving specific second operation values, for choosing the second operation values from the corresponding line group according to different properties of the inputted values, and outputting the second operation values; a number of registers, each register connected with a specific first multiplexer, for receiving the second operation values, and outputting the second operation values in a next clock; and a number of second multiplexers, each second multiplexer connected with a specific register, receiving a value of a specific coefficient except a constant coefficient in an error location polynomial and the second operation values from the register, for outputting the value of the specific coefficient as the inputted value to the combined matrix unit in the first iterative operation of Chien's search, and outputting the second operation values to the combined matrix unit as the inputted values in the rest iterative operations of Chien's search. Values of specific coefficients of the error location polynomial for the same Chien's search matrix and the second operation values obtained by processing the values of specific coefficients have the same properties of the inputted values.
The Chien's search matrix has a form of [Ay AΩ], where
where p is a number of parallel computations that the Chien's search circuit has; t is an error correction ability corresponding to the BCH code; α0, α1, . . . αm-1 form a standard basis in GF(2m); 1≦i≦p; 1≦j≦t.
Preferably, different Chien's search matrices correspond to different m and/or t. Each Chien's search matrix is equally divided into a number of portions in the row direction with the number of portions being the same as the number of the error correction ability of the corresponding BCH code. Each portion has sub-matrices in the corresponding Ay and AΩ. Each portion of one Chien's search matrix is aligned with that of another Chien's search matrix sequentially by a method. The method is aligning in one side, aligning centrally, or offsetting a certain amount from one side.
According to the present invention, the locations where are not covered by the portions of the Chien's search matrix are set to be elements of 0 in the combined matrix unit. The Chien's search matrices are separated by elements of 0. There are common sub-expressions in partial elements in two Chien's search matrices and one Chien's search matrix utilizes the common sub-expressions of the other Chien's search matrix. The first operation value further adds to a value of a constant coefficient of the error location polynomial; if the sum is 0, the corresponding element, αup+i where 1≦i≦p, is a root of the error location polynomial.
Hence, according to the description mentioned above, by designing the Chien's search circuit having several Chien's search matrices, with peripheral components, it is able to achieve applications for different code rates, different code lengths and even different m in GF(2m). Meanwhile, the complexity of hardware of the Chien's search circuit can be reduced.
The present invention will now be described more specifically with reference to the following embodiments.
Please refer to
The combined matrix unit 120 is the core element. It is used to provide two or more than two Chien's search matrices. In the present embodiment, the combined matrix unit 120 includes two Chien's search matrices, a Chien's search matrix A and a Chien's search matrix B. The Chien's search matrix A is used to find out the roots of an error location polynomial a. Coefficients of the error location polynomial a are found by receiving a BCH code C1 having t1-error correction ability, finding out syndromes and processing BM algorithm. Similarly, the Chien's search matrix B is used to find out the roots of an error location polynomial b. Coefficients of the error location polynomial b are found by receiving a BCH code C2 having t2-error correction ability, finding out syndromes and processing BM algorithm. Structures of the Chien's search matrix A and Chien's search matrix B will be introduced later. It should be noticed that the combined matrix unit 120 can be formed by any electronic components, such as /Read Only Memory (ROM) array, to keep the element of 0 or 1 in the Chien's search matrix.
The combined matrix unit 120 can receive a number of inputted values. As shown in
Here, the first operation values, are Y(αup+i) in the prior art mentioned in the BACKGROUND OF THE INVENTION, the outputs in each iterative operation (Numeral u is the number of iterative operations, Numeral p means the number of parallel computations of the combined matrix unit 120, αup+i is a potential root for Chien's search, 1≦i≦p). By judging if the sum of Y(αup+i) and value of a constant coefficient of the error location polynomial, λ0, to determine that if the corresponding element, αup+i, is a root of the error location polynomial. The second operation values are intermediate values in the iterative operations. They are inputted again to the combined matrix unit 120 for another operation. The combined matrix unit 120 can output the first operation values, and output the second operation values via one of two line groups according to different properties of the inputted values. Values of specific coefficients of the error location polynomial for the same Chien's search matrix and the second operation values obtained by processing the values of specific coefficients have the same properties of the inputted values. It is to say that when the values of coefficients for the same Chien's search matrix are inputted by the second multiplexer 180 in the clock of a first iterative operation and the second operation values computed later therefrom, all have the same properties of the inputted values. For the convenience of operation of the first multiplexer 140, each output of the second operation values for different properties of the inputted values uses a specified line. As shown in
In the present embodiment, the number of the first multiplexer 140 is t. Numeral t should be greater than or equal to the bigger one of t1 and t2 so that the BCH code having the maximum error correction ability can be decoded. Meanwhile, the Numeral t is the highest power of the error location polynomial in processed. As mentioned above, each first multiplexer 140 is connected with one line in each line groups and receives specific second operation values from the combined matrix unit 120. The first multiplexer 140 can choose the second operation values from the corresponding line group according to different properties of the inputted values. Then, output the second operation values to the connected register 160.
In the t registers 160, each register 160 is connected to a specific first multiplexer 140, respectively, to receive the second operation values and output the second operation values to the connected second multiplexer 180 in a next clock. Due to operation of the registers 160, the Chien's search circuit 100 can process one iterative operation per clock.
Each second multiplexer 180 is connected to a specific register 160, capable of receiving a value of a specific coefficient except a constant coefficient in an error location polynomial (e.g. λ1, λ2 . . . λn in
Here, the structures of the Chien's search matrix A and Chien's search matrix B are illustrated. The Chien's search matrix A has a form of [Ay AΩ], where
where p is the number of parallel computation that the Chien's search circuit has; t1 is the error correction ability corresponding to BCH code C1; α0, α1, . . . and αm1-1 form a standard basis in GF(2m1-1); 1≦i≦p; 1≦j≦t1. Chien's search matrix B has a form of [By BΩ], where
where t2 is the error correction ability corresponding to BCH code C2; α0, α1, . . . and αm2-1 form a standard basis in GF(2m2-1); 1≦j≦t2.
Since t1 is greater than t2, matrix Ay and matrix AΩ are inevitable larger than matrix By and matrix BΩ, respectively. Since the Chien's search matrix B uses partial elements in the Chien's search matrix A, for convenience of operation, arrangement of the Chien's search matrices should be different than other prior arts. Please see
It should be notice that
Each portion of the Chien's search matrix A is aligned with each portion of the Chien's search matrix B sequentially by a specific method. As shown in
From above, it is clear that in the Chien's search circuit 100, different Chien's search matrices correspond to different values of m (m1 and m2) or t (t1 and t2). In practice, only one of them is different is applicable. In addition, the combined matrix unit 120 can be designed by below steps: first, building Ay and AΩ; then building By and BΩ; last, finding common sub-expressions to build the combined matrix.
According to the spirit of the present invention, the Chien's search circuit can also include three or more line groups. Under such situation, the arrangement of Chien's search matrix is also different. Please refer to the illustration of another embodiment.
Please refer to
The combined matrix unit 220 is the core element. It includes three Chien's search matrices, a Chien's search matrix A, a Chien's search matrix B and a Chien's search matrix C. The Chien's search matrix A and the Chien's search matrix B are the same as that in the last embodiment. The Chien's search matrix C is used to find out the roots of an error location polynomial c. Coefficients of the error location polynomial c are found by receiving a BCH code C3 having t3-error correction ability, finding out syndromes and processing BM algorithm. The combined matrix unit 220 receives a number of inputted values from the second multiplexers 280. The combined matrix unit 220 multiplies the inputted values by partial or all elements in one or more Chien's search matrices to get first operation values and second operation values. In the present embodiment, the Chien's search matrix A and the Chien's search matrix B have common sub-expressions. The Chien's search matrix A and the Chien's search matrix C also have common sub-expressions. Therefore, the Chien's search matrix B and the Chien's search matrix C can all use partial elements in the Chien's search matrix A. However, there are no common sub-expressions in the Chien's search matrix B and the Chien's search matrix C.
Here, the first operation values and second operation values are the same as that defined in the previous embodiment. Different points are: the combined matrix unit 120 is replaced by the combined matrix unit 220; the combined matrix unit 220 can output the first operation values; and the combined matrix unit 220 can output the second operation values in one of the three line groups according to different properties of the inputted values. When the values of coefficients for the same Chien's search matrix are inputted by the second multiplexer 280 in the clock of a first iterative operation and the second operation values computed later therefrom, all have the same properties of the inputted values. For the convenience of operation of the first multiplexer 240, each output of the second operation values for different properties of the inputted values uses a specified line. As shown in
In the present embodiment, the number of the first multiplexer 240 is t. Numeral t should be greater than or equal to the bigger one of t1, t2 and t3 so that the BCH code having the maximum error correction ability can be decoded. Meanwhile, the Numeral t is the highest power of the error location polynomial in processed. As mentioned above, each first multiplexer 240 is connected with one line in each line groups and receives specific second operation values from the combined matrix unit 220. The first multiplexer 240 can choose the second operation values from the corresponding line group according to different properties of the inputted values. Then, output the second operation values to the connected register 260.
In the t registers 260, each register 260 is connected to a specific first multiplexer 240, respectively, to receive the second operation values and output the second operation values to the connected second multiplexer 280 in a next clock. Each second multiplexer 280 is connected to a specific register 260, capable of receiving a value of a specific coefficient except a constant coefficient in an error location polynomial (e.g. λ1, λ2 . . . λn, in
In this embodiment, structures of the Chien's search matrix A and the Chien's search matrix B are the same as that in the previous embodiment. Chien's search matrix C a form of [Cy CΩ], where
where p is the number of parallel computation that the Chien's search circuit has; t3 is the error correction ability corresponding to BCH code C3; α0, α1, . . . and αm3-1 form a standard basis in GF(2m3-1); 1≦i≦p; 1≦j≦t3.
Since t1 is greater than t3 and t3 is greater than t2, matrix Ay and matrix AΩ are inevitable larger than matrix Cy and matrix CΩ, respectively. Matrix Cy, and matrix CΩ are larger than matrix By and matrix BΩ, respectively. Arrangement of Chien's search matrices is shown in
The portions of Chien's search matrix C are like the portions of Chien's search matrix B which are aligned with portions of the Chien's search matrix A sequentially and respectively by a specific method. As shown in
In the present embodiment, two Chien's search matrices (the Chien's search matrix A and the Chien's search matrix B, or the Chien's search matrix A and the Chien's search matrix C) have common sub-expressions in partial elements. One Chien's search matrix can uses the common sub-expressions in the other Chien's search matrix. However, the Chien's search matrix B and the Chien's search matrix C don't have common sub-expressions. In practice, there can be common sub-expressions between the Chien's search matrix B and the Chien's search matrix C. Even there are common sub-expressions between any two Chien's search matrices of the three Chien's search matrices but all of the three Chien's search matrices have no common sub-expressions.
While the invention has been described in terms of what is presently considered to be the most practical and preferred embodiment, it is to be understood that the invention needs not be limited to the disclosed embodiment. On the contrary, it is intended to cover various modifications and similar arrangements included within the spirit and scope of the appended claims, which are to be accorded with the broadest interpretation so as to encompass all such modifications and similar structures.