The present invention relates to feed-forward decoders generally and, more particularly, to a method and/or apparatus for implementing a configurable Reed-Solomon decoder based on modified Forney syndromes.
Reed-Solomon (RS) codes are a well-known and powerful class of error-correcting codes with various areas of application. Error correction is achieved by appending extra parity (or check) symbols to a block of information symbols (i.e., an information message), thus obtaining a codeword (i.e., an encoded message). When the codeword is transmitted through a channel, some symbols often become corrupted. However, the information from the parity symbols allows a decoder to reconstruct the original information message if the total number of errors induced by the channel is no more than a maximum error limit predetermined for the RS encoder and the RS decoder.
The maximum error limit is a construction parameter for the RS encoder and the RS decoder. Successful decoding is possible only if the number of errors added to the codeword by the channel is no more than the maximum error limit. Otherwise, the RS decoder can either decline to perform the correction or can provide incorrect results. If the maximum error limit has a value (i.e., T), the number of extra parity symbols that are appended to the information message is 2T. The appended parity symbols give a relation between a length of the information message (e.g., INFO_LEN) and a total length of the codeword (i.e., LEN) of LEN=INFO_LEN+2T.
Many conventional hardware implementations of RS encoders and RS decoders deal with fixed maximum error limit values. Therefore, the maximum error limit parameter is considered at instantiation time of the RS encoders and the RS decoders and cannot be changed at runtime. It is desirable for the maximum error limit of the RS encoders and the RS decoders to be variable at runtime.
The present invention concerns a method of configurable decoding. The method generally comprises the steps of (A) receiving a variable value in a configuration signal, (B) calculating a plurality of first syndromes corresponding to a particular codeword of a plurality of codewords received in an input signal, the particular codeword having a plurality of information symbols and a plurality of parity symbols coded such that up to a fixed value of a plurality of errors in the particular codeword are correctable, the fixed value being greater than the variable value, (C) transforming the first syndromes into a plurality of second syndromes such that no greater than the variable value of the errors in the particular codeword are correctable and (D) generating an intermediate signal carrying the second syndromes.
The objects, features and advantages of the present invention include providing a method and/or apparatus for implementing a configurable Reed-Solomon decoder based on modified Forney syndromes that may (i) implement a variable maximum error limit decoding, (ii) enable changes at runtime of the maximum number of errors that may be corrected, (iii) adapt to error rate changes over time, (iv) reduce parity data in a storage medium, (v) enable faster data transfers by transmitting reduced parity data and/or (vi) process conventional Reed-Solomon codewords.
These and other objects, features and advantages of the present invention will be apparent from the following detailed description and the appended claims and drawings in which:
Operating with a runtime variable value for a maximum error limit to correct errors may be beneficial in cases where fewer errors than the maximum error limit are expected in a received codeword. A reduction in the maximum error limit generally reduces a number of parity symbols to be transmitted, stored and processed. Fewer syndromes may be used in correcting the fewer errors thereby saving on computational resources.
A variable maximum error limit may allow an encoder and/or a decoder to use a transmission channel and/or storage channel (or medium) in an efficient way. If the channel properties (e.g., Signal-to-Noise Ratio, SNR) change with time, the variable error limit may continuously accommodate the property changes. In some technology areas, for instance in storage devices, the expense of extra bits that do not carry customer information is high. If the storage channel SNR is better than expected, saving on a number of parity symbols being stored may bring significant revenue.
Reed-Solomon codes generally include a notion of erasure in the transmission/storage channel and a notion of decoding with both errors and erasures. An erasure may be an error in a symbol position that is known to the decoder before the codeword is processed. As such, the decoder knows a priori that a received codeword contains errors in the erasure positions. Therefore, the decoder may calculate only the error values in the erasure positions to restore the original data values. For other errors, the decoder generally calculate both the error positions and the error values to restore the original data values. Furthermore, G.
D. Forney Jr. presented methods to extend a typical Reed-Solomon decoding to deal with errors and erasures rather than errors only. Among the methods are modified Forney Syndromes and a modified Forney algorithm for evaluating the error magnitudes in positions of errors and erasures. See (i) “On Decoding BCH Codes”, by G. D. Forney Jr., IEEE Transactions on Information Theory, volume IT-11, pages 543-557, October 1965, New York, N.Y. and (ii) “The Art of Error Correcting Coding”, by Robert H. Morelos-Zaragoza, paragraph 4.3.2, John Wiley & Sons, 2002, West Sussex, England, which are hereby incorporated by reference as cited.
Referring to
The apparatus 100 generally comprises a module (or circuit) 102, a module (or circuit) 104, a module (or circuit)) 106, a module (or circuit) 108 and a module (or circuit) 110. A signal (e.g., CDW_IN) may be received by the module 102 and the module 110. A signal (e.g., MAX_ERR_LIMIT) may be received by the module 102 and the module 104. The module 102 may generate and present a signal (e.g., SYN) to the module 104. The module 104 may generate and present a signal (e.g., MS) to the module 106. A signal (e.g., MAG) may be generated by the module 106 and presented to the module 108. The module 106 may also generate and present a signal (e.g., LOC) to the module 108. A signal (e.g., INFO_IN) may be presented from the module 110 to the module 108. A signal (e.g., INFO_OUT) may be generated and presented by the module 108.
The signal CDW_IN may carry a sequence of codewords encoded to enable error detection and correction. The error correction aspect of the encoding generally permits up to the maximum error limit (e.g., a fixed value “T”) of errors to be corrected. Each of the received codewords may include multiple information symbols (INFO SYM) and multiple parity symbols (PARITY SYM), as illustrated in
The signal MAX_ERR_LIMIT may carry a configuration value (e.g., a variable value “H”). The value H may program decoding operations of the apparatus 100 such that at most only H errors may be subject to error position detection and error value correction. The variable value H may range from zero to the fixed value T (0≦H≦T).
The signal INFO_OUT may carry information values (or data messages) recovered from the codewords. Each of the information values generally comprises a multi-bit value (e.g., an 8-bit value). Other bit sizes of the information values may be implemented to meet the criteria of a particular application.
The module 102 generally implements a syndrome calculation module. The module 102 may be operational to generate sets of 2T syndromes in the signal SYN based on the symbols received in the codewords. One set of syndromes may be calculated for each of the codewords. The number of parity symbols used by the module 102 from each codeword may be controlled by the variable value H received in the signal MAX_ERR_LIMIT. Generally, only 2H parity symbols may be accepted from each codeword. The remaining 2T-2H parity symbol locations may not read by the module 102 (e.g., treated as if filled with zeros), as shown in
The module 104 may implement a syndrome transformation module. The module 104 is generally operational to transform the set of 2T syndromes received from the module 102 to create a set of 2H modified Forney syndromes in the signal MS. The number of modified Forney syndromes created by the module 104 may be controlled by the variable value H received in the signal MAX_ERR_LIMIT. The transformation may be performed by formula Eq. 3 in
The module 106 may implement a key equation solver module. The module 106 may be operational to calculate error evaluator polynomials in the signal MAG based on the modified syndromes. The module 106 may also be operational to calculate error location polynomials in the signal LOC based on the modified syndromes.
The module 108 generally implements an error correction module. The module 108 may be operational to correct errors in the information symbols received in the signal INFO_IN based on the error location polynomials and the error evaluator polynomials. The magnitudes of the errors may be calculated by the module 108 on-the-fly. The error corrected information symbols may be presented in the signal INFO_OUT as a sequence of decoded information values.
The module 110 may implement a buffer module. The module 110 may be operational to store only the information symbols of each codeword received in the signal CDW_IN. A capacity of the module 110 may be sufficient to store the information symbols of a single codeword to a few codewords. Other memory sizes may be implemented to meet the criteria of a particular application. Buffing of the information symbols generally allows time for the modules 102, 104 and 106 to process the codewords to create the signal LOC and the signal MAG. The module 110 may present the information symbols to the module 108 in the signal INFO_IN, symbol by symbol. Since the signal INFO_IN does not include the parity symbols from the signal CDW_IN, errors in the parity symbols may be left uncorrected and thus may be absent from the signal INFO_OUT.
Referring to
The method 120 may begin with the reception of the encoded codewords by the modules 102 and 110 and reception of the variable configuration value H by the modules 104 and 106 in the step 122. The module 110 may buffer only the information symbols from the codewords in the step 124. In the step 126, the module 102 may generate the syndromes corresponding to the information symbols and the first 2H parity symbols received codewords.
Consider a Galios Field GF(2d) having 2d elements. Let a variable n=2d−1, where T may be the maximum error limit for decoding. A sequence W (e.g., W=(W0, W1, . . . , Wn-1)) is generally defined with elements from GF(2d) to be the codeword received in the signal CDW_IN. The sequence W may be considered a polynomial W(X) (e.g., W(X)=W0+W1X+ . . . +Wn-1Xn-1). An element a may be considered a primitive element of GF(2d). An element αi for i=i0, . . . , i0+2T−1 may be considered roots of a generator polynomial for the code. As such, if no errors are present in the codeword, W(αi)=0 for i=i0, . . . , i0+2T−1. For simplification, i0 may be defaulted to unity (e.g., i0=1). A set of syndromes S (e.g., S={S0, . . . , S2T-1}) may be calculated by the module 102 per equation 1, as shown in
The module 104 may modify the syndromes S received from the module 102. The transformation generally reconfigures the number of errors that may be corrected by the apparatus 100 to no more than H errors, where 0≦H≦T. Consider a decoding that may involve errors and erasures, for example H errors and 2T-2H erasures. The 2T-2H positions of erasures (e.g., positions B1, . . . , B2T-2H) may be known in advance since such erasure positions may not depend on the codeword. Therefore, a goal may be to find both the positions and the error values in the H errors. Furthermore, the error values for the erasure positions may be treated as don't care values.
In the step 128, the module 104 may calculate an erasure polynomial per equation 2, as shown in
The module 106 may run a key equation solving procedure over the modified syndromes. The key equation solving procedure generally takes a sequence of modified syndromes S′ and calculates both (i) an error locator polynomial (e.g., Λ(X)) of degree DEG_LOC in the step 132, where DEG_LOC<H and (ii) an error evaluator polynomial (e.g., Ω(X)) of degree DEG_VAL in the step 132, where DEG_VAL<H. Calculations of the polynomials may be implemented in any one or more of several ways. For example, a Berlekamp-Massey method and/or a Euclidian method may be used to determine the polynomials. Other methods may be implemented to meet the criteria of a particular application. The error locator polynomial Λ(X) may be transferred to the module 108 in the signal LOC. The error evaluator polynomial Ω(X) may be transferred to the module 108 in the signal MAG.
In the step 134, the module 106 may use both the error locator polynomial Λ(X) and the error evaluator polynomial Ω(X) to correct actual errors in the codeword. Since the apparatus 100 receives the signal MAX_ERR_LIMIT carrying the limit value H, the limit value H may be changed at runtime. The correction generally restores any corrupted information symbols back into the original information symbols. The module 108 generally corrects, if appropriate, the information symbols buffered in the module 110 in the step 136 and then presents the information symbols in the signal INFO_OUT.
Operationally, the last 2T-2H symbols of each codeword in the signal CDW_IN may not be processed by the apparatus 100 as if the last 2T-2H symbols were not transmitted or stored. Thus, an effective length of the codewords may be INFO_LEN+2H. The 2H parity symbols are generally enough to recover from H errors.
A correctness of the method 120 may be given as follows. The value T may be the constructive maximum error limit for decoding where a practical decoding limit may be implemented to correct only H errors and 2T-2H erasures. Let
be the original codeword transmitted by an encoder and
be the corrupted codeword on an output end of a channel. Thus, W(X)=C(X)+E(X), were
may be an error polynomial. Let {L1, . . . , Lk} be a set of the positions of errors and {M1, . . . , M2T-2H} be a set of the erasure positions. Denote by Ai=αL
The erasure polynomial may be defined by equation 2 with coefficients ψr, for r=0, . . . , 2T−2H. The key equation system may be modified by replacing each of the equations Si, for i=0, . . . , 2T−1 by a linear combination of equations, as shown in equation 5 of
The original key equation system of equation 4 may be reduced to the system of equation 11. From equation 11, (i) locators of the error positions Ai, for i=1, . . . , H and (ii) new error values for the error positions E′i, for i=1, . . . , H may all be defined by applying the standard key equation solver procedure to the last system of equation 11. Since the error values Ei, for i=H+1, . . . , 2T−H may be ignored in the positions of erasures, sufficient data generally exist to recover from up to H errors.
The functions performed by the diagrams of
The present invention may also be implemented by the preparation of ASICs, FPGAs, or by interconnecting an appropriate network of conventional component circuits, as is described herein, modifications of which will be readily apparent to those skilled in the art(s).
The present invention thus may also include a computer product which may be a storage medium including instructions which can be used to program a computer to perform a process in accordance with the present invention. The storage medium can include, but is not limited to, any type of disk including floppy disk, optical disk, CD-ROM, magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, Flash memory, magnetic or optical cards, or any type of media suitable for storing electronic instructions.
While the invention has been particularly shown and described with reference to the preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made without departing from the scope of the invention.