The present invention relates to an encoding method, a decoding method, a system that has encoding capabilities and a system that has decoding capabilities.
A code rate is defined by the ratio of its information content to the overall size of the codeword. For example, for a code that contains k bits and r redundancy bits that rate is defined by k/(k+r). The common encoding methods are not very well suited to support high rate codes when both hard and soft decoding are considered. For example, for conventional low-density parity-check (LDPC codes) for very high rates (for example—0.95) the code length tends to be considerable resulting in a very complex and costly implementation.
BCH and RS (Reed-Solomon) are among the most widely used cyclic error correcting codes. They are used in various practical fields such as storage and communication. When these coding schemes are used in mobile applications, power consumption is a major design constraint which sometimes even affects the actual viability of the applicability of the schemes to the mobile applications.
The apparatus according to embodiments of the invention may include a flash memory that stores data encoded in accordance with a Reed-Solomon decoding algorithm and wherein the stored data is Reed-Solomon decoded by a decoder that comprises at least the first and second hardware circuits.
The apparatus according to embodiments of the invention may include a flash memory to store data encoded in accordance with a BCH encoding algorithm and a BCH decoder.
An encoding method is provided. The method may include: receiving data; generating a set of first codewords by applying a first encoding process on the received data; and performing a second encoding process on a folded version of each first codeword to provide a set of second codewords, wherein a folded version of a first codeword is representative of a storage of the first codeword in a two dimensional memory space, wherein first and second sets of codewords facilitate an error correction encoding of the data.
The method may include, according to an embodiment of the invention, storing each first codeword in multiple columns of a memory space; and performing the second encoding process on rows of the memory space.
The method may include, according to an embodiment of the invention, wherein the first error encoding process differs from the second encoding process.
The method may include, according to an embodiment of the invention, wherein at least two first codewords have different lengths.
The method may include, according to an embodiment of the invention, configuring an error correction capability of at least one of the first and second encoding processes based on a desired error correction capability.
The method may include, according to an embodiment of the invention, performing a third encoding process on a folded version of each second codeword to provide a set of third codewords, wherein a folded version of a second codeword is representative of storage of the second codeword in a two dimensional memory space.
The first, second and third error encoding processes may differ from each other. It is noted that the number of encoding processes can be higher than 3 or 4.
At least two codewords out of different sets of codewords may have different lengths.
At least two codewords of the same set of codewords may have different lengths.
The method may include, according to an embodiment of the invention, performing at least four encoding processes, wherein each encoding process except a first encoding process is applied on a folded version of a set of codewords obtained by applying a previous encoding process.
A method can be provided. The method may include applying every encoding process by encoding the whole data stream generated by all previous encoding processes (thus encoding systematic and redundancy bits).
A method can be provided. The method may include encoding by multiple encoding processes only systematic bits, and applying an additional encoding process (applying a different code) for the redundancy bits created by all encoding processes.
The method may include, according to an embodiment of the invention, performing at least three encoding processes, wherein each encoding process except a first encoding process is applied on a folded version of a set of codewords obtained by applying a previous encoding process, wherein at least one encoding process is applied only on redundancy bits generated by previous encoding processes.
The method may include, according to an embodiment of the invention, performing at least three encoding processes, wherein each encoding process—may be applied on a folded version of a set of codewords obtained by jointly encoding multiple rows/columns, wherein at least two encoding processes differ from each other (can be identical). Every two encoding processes may operate on a partially different subset of the input bits.
The method may include, according to an embodiment of the invention, generating the set of first codewords by a first encoder, providing the first codewords to a second encoder, and performing a second encoding process by a second encoder; wherein the second encoder starts to perform the second encoding process before the first encoder finished to generate a sub-set of the first codewords.
The method may include, according to an embodiment of the invention, generating the set of first codewords by a first linear feedback shift register of the first encoder, providing first codeword chunks to a second linear feedback shift register of the second encoder, and performing a second encoding process by a second encoder.
Each first codeword may be arranged in a set of consecutive columns of a matrix; and the method may include filling registers that correspond to rows of the matrix and performing the second decoding process on rows of the matrix.
The method may include, according to an embodiment of the invention, generating the set of first codewords by a first encoder, wherein a folded version of a first codeword is arranged in a set of consecutive columns of a matrix; filling registers of a second encoder, wherein the registers correspond to rows of the matrix and performing the second encoding process on rows of the matrix by the second encoder.
The method may include, according to an embodiment of the invention, configuring configurable linear feedback shift registers according to an encoding parameter of an encoding process selected from the first and second encoding processes.
The method may include, according to an embodiment of the invention, storing the set of second codewords in a flash memory; reading a content of the flash memory; and applying a decoding process on the content of the flash memory.
A decoding method, that includes: receiving information that comprises a final set of codewords that had undergone an error inducing process; reconstructing data by applying on the information a first decoding process to provide first results; and applying a second decoding process on folded versions of first results to provide second results; wherein a folded version of a first result is representative of a storage of the first result in a two dimensional memory space.
The method may include, according to an embodiment of the invention, storing each first result in multiple columns of a memory space; and performing the second decoding process on rows of the memory space.
The first error encoding process may differ from the second encoding process.
The method may include, according to an embodiment of the invention, configuring an error correction capability of at least one of the first and second decoding processes based on the required (also referred to as a desired) error correction capability.
The method may include, according to an embodiment of the invention, performing a third decoding process on a folded version of each second result to provide a set of third results, wherein a folded version of a second result is representative of storage of the second result in a two dimensional memory space.
The first, second and third error decoding processes may differ from each other.
At least two results out of different sets of results may have different lengths.
At least two results of the same set of result may have different lengths.
The method may include, according to an embodiment of the invention, performing at least four decoding processes, wherein each decoding process except a first decoding process is applied on a folded version of a set of results obtained by applying a previous decoding process. It is noted that each of the mentioned above encoding or decoding processes are applied on folded versions of the input data.
The method may include, according to an embodiment of the invention, performing at least three decoding processes, wherein each decoding process except a first decoding process is applied on a folded version of a set of results obtained by applying a previous decoding process, wherein at least one decoding process is applied only on redundancy bits generated by previous decoding processes.
The method may include, according to an embodiment of the invention, performing at least three decoding processes, wherein each decoding process except a first decoding process is applied on a folded version of a set of results obtained by applying a previous decoding process, wherein at least two decoding processes differ from each other.
The method may include, according to an embodiment of the invention, performing at least two decoding processes, wherein at least one decoding process is followed by determining whether to ignore the results of the decoding process.
The method may include, according to an embodiment of the invention, ignoring the results of an ignored decoding process by applying a next decoding process on a folded version of each result of a decoding process that preceded the ignored decoding process.
The method may include, according to an embodiment of the invention, determining to ignore the results of the decoding process if detecting a miss correction. A miss correction occurs when a decoder amends correct data. A miss correction may be detected if a decoder can identify its inability to correct errors in the input codeword.
The method may include, according to an embodiment of the invention, ignoring the results of the first decoding process by applying the second decoding process on a folded version of the information.
The method may include, according to an embodiment of the invention, performing at least two decoding processes, wherein at least one decoding process is followed by determining whether to skip at least one decoding process that follows the decoding process.
The method may include, according to an embodiment of the invention, determining to skip at least one decoding process if at least one decoding process that preceded the determination provided a result of a desired characteristic.
The method may include, according to an embodiment of the invention, ignoring the results of an ignored decoding process by applying a next decoding process on a folded version of each result of a decoding process that preceded the ignored decoding process.
The method may include, according to an embodiment of the invention, preventing a modification of at least one bit of a result by at least one decoding process if determined by at least one preceding decoding process that the at least one bit is correct.
The method may include, according to an embodiment of the invention, performing an error location search of a decoding process in response to error locations that were found during a previous decoding process.
The method may include, according to an embodiment of the invention, generating, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the generating comprises applying multiple decoding processes out of a group of information bits; and determining whether to modify each information bit based upon multiple indications associated with the information bit.
The method may include, according to an embodiment of the invention, generating, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the generating comprises applying multiple decoding processes out of a group of information bits; and determining whether to modify each information bit based upon a majority of indications associated with the information bit.
The method may include, according to an embodiment of the invention, generating, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the generating comprises applying multiple decoding processes out of a group of information bits; and determining to modify each information bit if at least a predetermined number of indications associated with the information bit indicate that the bit should be modified.
The method may include, according to an embodiment of the invention, generating, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the generating comprises applying multiple decoding processes out of a group of information bits; and determining whether to modify each information bit based upon confidence levels of different indications associated with the information bit.
Each decoding process may be characterized by correction threshold; wherein the method comprises preventing a modification of information bits if a decoding process indicates that errors occurred in more information bits than the correction threshold of the decoding process.
The method may include, according to an embodiment of the invention, performing multiple iterations of multiple decoding processes.
The method may include, according to an embodiment of the invention, performing an iteration of multiple decoding processes while allowing a correction of up to a predefined number of corrections; altering the predefined number of corrections; and performing another iteration of multiple decoding processes while allowing a correction of up to an altered predefined amount of corrections.
The method may include, according to an embodiment of the invention, performing multiple iterations of decoding processes to provide multiple decoding iteration results; wherein the decoding iterations differ from each other; and selecting a selected decoding iteration result out of the multiple decoding iterations results.
The method may include, according to an embodiment of the invention, performing a first iteration of decoding processes to provide a first decoding iteration result; and performing a second iteration of second processes if the first decoding iteration result does not satisfy a predefined criteria.
The method may include, according to an embodiment of the invention, performing a first iteration of decoding processes to provide a first decoding iteration result; and performing a second iteration of second processes if the first decoding iteration failed.
The method may include, according to an embodiment of the invention, performing multiple iterations of decoding processes wherein at least one iteration of decoding processes comprises multiple instances of a single decoding process.
A system may be provided. The system may include an encoding unit and a two dimensional memory array; wherein the encoding unit may be configured to receive data; generate a set of first codewords by applying a first encoding process on the received data; and perform a second encoding process on a folded version of each first codeword to provide a set of second codewords, wherein a folded version of a first codeword is representative of a storage of the first codeword in a two dimensional memory space, wherein the set of second codewords facilitates an error correction encoding of the data.
According to an embodiment of the invention the two dimensional memory array may be configured to store each first codeword in multiple columns of the two dimensional memory array; and wherein the encoding unit may be configured to perform the second encoding process on rows of the two dimensional memory array.
According to an embodiment of the invention the first encoding process differs from the second encoding process.
According to an embodiment of the invention at least two first codewords have different lengths.
According to an embodiment of the invention the encoding unit is configured to adjust an error correction capability of at least one of the first and second encoding processes based on a desired error correction capability.
According to an embodiment of the invention the encoding unit may be configured to perform a third encoding process on a folded version of each second codeword to provide a set of third codewords, wherein a folded version of a second codeword is representative of a storage of the second codeword in a two (or three) dimensional memory space.
According to an embodiment of the invention the encoding unit is configured to perform first, second and third encoding processes that differ from each other. It is noted that the different encoding processes may be the same.
According to an embodiment of the invention at least two codewords out of different sets of codewords have different lengths. This is not necessarily so and the length can also be the same.
According to an embodiment of the invention at least two codewords of the same set of codeword have different lengths. This is not necessarily so and the length can also be the same.
According to an embodiment of the invention the encoding unit may be configured to perform at least four encoding processes, wherein the encoding unit may be configured to perform each encoding process except a first encoding process is applied on a folded version of a set of codewords obtained by applying a previous encoding process. The encoding unit may apply encoding processes on folded versions of the input data. The encoding unit may apply an encoding process that encodes the whole data stream (encoding results and input data) generated by all previous encoding processes (thus encoding systematic and redundancy bits). In another embodiment, the encoding unit encodes only systematic bits by every encoding process, and applies an additional code for encoding the redundancy bits created by all encoding processes.
According to an embodiment of the invention encoding unit may be configured to perform at least three encoding processes, wherein the encoding unit may be configured to apply each encoding process except a first encoding process on a folded version of a set of codewords obtained by applying a previous encoding process, wherein the encoding unit may be configured to apply at least one encoding process only on redundancy bits generated by previous encoding processes.
According to an embodiment of the invention the encoding unit may be configured to perform at least three encoding processes, wherein each encoding process except a first encoding process is applied on a folded version of a set of codewords obtained by applying a previous encoding process, wherein at least two encoding processes differ from each other.
According to an embodiment of the invention the encoding unit comprises a first encoder and a second encoder; wherein the first encoder may be configured to generate the set of first codewords, provide the first codewords to the second encoder, and wherein the second encoder may be configured to perform a second encoding process; wherein the second encoder starts to perform the second encoding process before the first encoder finished to generate a sub-set of the first codewords.
According to an embodiment of the invention a first linear feedback shift register of the first encoder may be configured to generate the set of first, provide first codeword chunks to a second linear feedback shift register of the second encoder, and wherein the second encoder performs the second encoding.
According to an embodiment of the invention each first codeword is arranged in a set of consecutive columns of a matrix (if a single codeword captures more than one column the codeword is said to be folded); wherein the encoding unit comprises a second encoder that comprises registers correspond to rows of the matrix; wherein the second encoder may be configured to fill these registers and process the content of the registers.
According to an embodiment of the invention the encoding unit comprises a first encoder and a second encoder; wherein the first encoder may be configured to generate the set of first codewords, wherein a folded version of a first codeword is arranged in a set of consecutive columns of a matrix; wherein the second encoder comprises registers that correspond to rows of the matrix; wherein the second encoder may be configured to perform the second encoding process on rows of the matrix by the second encoder.
According to an embodiment of the invention the encoding unit comprises multiple configurable linear feedback shift registers that are configurable according to an encoding parameter of an encoding process selected from the first and second encoding processes.
According to an embodiment of the invention the system includes a flash memory configured to store the set of second codewords in a flash memory; and a memory controller configured to read a content of the flash memory; wherein the decoding unit may be configured to applying multiple decoding processes on the content of the flash memory.
A system may include a decoder and a two dimensional memory unit, the decoder is configured to receive information that comprises a final set of codewords that undergone an error inducing process; reconstruct data by applying on the information a first decoding process to provide first results; and apply a second decoding process on folded versions of first results to provide second results; wherein a folded version of a first result is representative of a storage of the first result in a two dimensional memory space.
According to an embodiment of the invention the two dimensional memory unit is configured to store each first result is stored in multiple columns; wherein the decoder is configured to perform the second decoding process on rows of the two dimensional memory unit.
According to an embodiment of the invention the first error encoding process differs from the second encoding process.
According to an embodiment of the invention at least two first results have different lengths.
According to an embodiment of the invention the decoder is configured to apply decoding processes of configurable error correction capability; wherein the configurable error correction capabilities are determined based on a desired error correction capability.
According to an embodiment of the invention decoder is adapted perform a third decoding process on a folded version of each second result to provide a set of third results, wherein a folded version of a second result is representative of a storage of the second result in a two dimensional memory space.
According to an embodiment of the invention the first, second and third error decoding process differ from each other but may be equal to each other.
According to an embodiment of the invention at least two results out of different sets of results have different lengths but may be equal.
According to an embodiment of the invention at least two results of the same set of result have different lengths.
According to an embodiment of the invention the decoder is configured to perform at least four decoding processes, wherein each decoding process except a first decoding process is applied on a folded version of a set of results obtained by applying a previous decoding process.
According to an embodiment of the invention the decoder is configured to perform at least three decoding processes, wherein the decoder is configured to apply each decoding process except a first decoding process on a folded version of a set of results obtained by applying a previous decoding process, wherein the decoder is configured to apply at least one decoding process only on redundancy bits generated by previous decoding processes.
According to an embodiment of the invention the decoder is configured to perform at least three decoding processes, wherein the decoder is configured to apply each decoding process except a first decoding process on a folded version of a set of results obtained by applying a previous decoding process, wherein at least two decoding processes differ from each other.
According to an embodiment of the invention the decoder is configured to perform at least two decoding processes, wherein the decoder is configured to determine, after completing at least one decoding process, whether to ignore the results of the decoding process.
According to an embodiment of the invention the decoder is configured to ignore the results of an ignored decoding process by applying a next decoding process on a folded version of each result of a decoding process that preceded the ignored decoding process.
According to an embodiment of the invention the decoder is configured to determine to ignore the results of the decoding process if detecting a miss correction.
According to an embodiment of the invention the decoder is configured to ignore the results of the first decoding process by applying the second decoding process on a folded version of the information.
According to an embodiment of the invention the decoder is configured to perform at least two decoding processes and to determine whether to skip at least one decoding process that follows a decoding process.
According to an embodiment of the invention the decoder is configured to perform at least two decoding processes and to determine whether to skip at least one decoding process that follows a decoding process if at least one decoding process that preceded the determination provided a result of a desired characteristic.
According to an embodiment of the invention the decoder is configured to ignore the results of an ignored decoding process and to apply a next decoding process on a folded version of each result of a decoding process that preceded the ignored decoding process.
According to an embodiment of the invention the decoder is configured to prevent a modification of at least one bit of a result by at least one decoding process if the decoder determines, by applying at least one preceding decoding process that the at least one bit is correct.
According to an embodiment of the invention the decoder is configured to perform an error location search of a decoding process in response to error locations that were found during a previous decoding process.
According to an embodiment of the invention the decoder is configured to generate, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the decoder is configured to generate the multiple indications by applying multiple decoding processes out of a group of information bits; and wherein the decoder is configured to determine whether to modify each information bit based upon multiple indications associated with the information bit.
According to an embodiment of the invention the decoder is configured to generate, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the decoder is configured to generate the multiple indications by applying multiple decoding processes out of a group of information bits; and wherein the decoder is configured to determine whether to modify each information bit based upon a majority of indications associated with the information bit. The decoder may compare the number of correct indications per bit with a threshold.
According to an embodiment of the invention the decoder is configured to generate, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the decoder is configured to generate the multiple indications by applying multiple decoding processes out of a group of information bits; and wherein the decoder is configured to determine whether to modify each information bit if at least a predetermined number of indications associated with the information bit indicate that the bit should be modified.
According to an embodiment of the invention the decoder is configured to generate, for each information bit out of multiple information bits, multiple indications about a correctness of the information bit, wherein the decoder is configured to generate the multiple indications by applying multiple decoding processes out of a group of information bits; and wherein the decoder is configured to determine whether to modify each information bit based upon confidence levels of different indications associated with the information bit.
According to an embodiment of the invention each decoding process is characterized by correction threshold; wherein the decoder is configured to prevent a modification of information bits if a decoding process indicates that errors occurred in more information bits than the correction threshold of the decoding process.
According to an embodiment of the invention the decoder is configured to perform multiple iterations of multiple decoding processes.
According to an embodiment of the invention the decoder is configured to perform an iteration of multiple decoding processes while allowing a correction of up to a predefined number of corrections; alter the predefined number of corrections; and perform another iteration of multiple decoding processes while allowing a correction of up to an altered predefined amount of corrections.
According to an embodiment of the invention the decoder may be configured to perform multiple iterations of decoding processes to provide multiple decoding iteration results; wherein the decoding iterations differ from each other; and select a selected decoding iteration result out of the multiple decoding iterations results.
According to an embodiment of the invention the decoder may be configured to perform a first iteration of decoding processes to provide a first decoding iteration result; and perform a second iteration of second processes if the first decoding iteration result does not satisfy a predefined criterion.
According to an embodiment of the invention the decoder may be configured to perform a first iteration of decoding processes to provide a first decoding iteration result; and perform a second iteration of second processes if the first decoding iteration failed.
According to an embodiment of the invention the decoder may be configured to perform multiple iterations of decoding processes wherein at least one iteration of decoding processes comprises multiple instances of a single decoding process.
The method according to embodiments of the invention may include retrieving data stored in a flash memory and performing Reed-Solomon decoding.
The method according to embodiments of the invention may comprise of retrieving data stored in a flash memory and performing BCH decoding per decoding process.
The subject matter regarded as the invention is particularly pointed out and distinctly claimed in the concluding portion of the specification. The invention, however, both as to organization and method of operation, together with objects, features, and advantages thereof, may best be understood by reference to the following detailed description when read with the accompanying drawings in which:
In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of the invention. However, it will be understood by those skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known methods, procedures, and components have not been described in detail so as not to obscure the present invention.
A folded version of a codeword is representation of the codeword as being stored in a two or higher-dimensional space. Thus, the folded version of the codeword represents a storage of the codeword as being stored in more than a single row and more than a single column.
Reference is now made to
In
The errors may stem from various physical processes such as thermal noise, deterioration of storage medium over time and, especially after many read/write operations, inaccuracies in the transmitter or receiver hardware. Each error occurs at a particular location within the message, which is assumed to comprise a sequence of bits or of symbols. In the former case, binary BCH code is typically used for encoding and decoding, whereas in the latter case, non-binary BCH code, or RS code is used. In the first, binary, instance, n is used in the foregoing discussion to indicate a bit of the data being read or received in which an error has occurred. In the second, non-binary, instance, n is used in the foregoing discussion to indicate a symbol of the data being read or received in which an error has occurred.
The received data r(x) equals the following: r(x)=c(x)+e(x). Received data r(x) is typically received by an error correcting decoder 130, also termed herein the “receiver”. ECC decoder 130, using the redundancy that was added to the message and the known codebook, is operative to substantially reconstruct the original message m′(x) and convey it to the intended target, message sink 140.
In flash memory applications, the channel 20 generally represents the deterioration in the data stored in memory over time and due to repeated cycling and retention, and the encoding and decoding (functionalities 10 and 30 in
Method 2000 starts by initialization stage 2002. Stage 2002 may include configuring an error correction capability of at least one of the first and second encoding processes based on a desired error correction capability.
Stage 2002 is followed by stage 2004 of receiving data. The data may also be referred to as data or information.
Stage 2004 is followed by stage 2010 of generating a set of first codewords by applying a first encoding process on the received data.
Stage 2010 is followed by stage 2020 of performing a second encoding process on a folded version of each first codeword to provide a set of second codewords. A folded version of a first codeword is representative of a storage of the first codeword in a two or higher dimensional memory space. The set of second codewords facilitates an error correction encoding of the data.
Stage 2010 may include of storing each first codeword in multiple columns of a memory space and stage 2020 may include performing the second encoding process on rows of the memory space.
The first error encoding process may or may not differ from the second encoding process. At least two first codewords may have different lengths.
Stage 2020 may be followed by stage 2030 of performing a third encoding process on a folded version of each second codeword to provide a set of third codewords. A folded version of a second codeword is representative of a storage of the second codeword in a two or higher dimensional memory space. A non-limiting example of a three dimensional folded code that may be generated by stages 2010, 2020 and 2030 is illustrated in
The first, second and third error encoding process may differ from each other. At least two codewords of the same set of codeword may have different lengths.
Method 2000 can include performing additional encoding processes, as illustrated by stage 2040 denoted “performing additional encoding processes”.
Method 2000 may include performing at least four encoding processes, wherein each encoding process except a first encoding process is applied on a folded version of a set of codewords obtained by applying a previous encoding process. The first encoding process is applied on the raw data. It is noted that folding depends on whether or not a codeword captures more than a single column/row, etc. There may be multiple (M) encoding processes, wherein M may differ from 4.
Method 2000 can include performing at least three encoding processes, wherein each encoding process except a first encoding process is applied on a folded version of a set of codewords obtained by applying a previous encoding process, wherein at least one encoding process is applied only on redundancy bits generated by previous encoding processes.
Method 2000 may include performing at least three encoding processes, wherein each encoding process except a first encoding process is applied on a folded version of a set of codewords obtained by applying a previous encoding process, wherein at least two encoding processes differ from each other.
Stage 2010 can be executed by a first encoder. Stage 2010 may also include providing the first codewords to a second encoder. Stage 2020 may be executed by the second encoder. The second encoder may start to perform the second encoding process before the first encoder finished to generate a sub-set of the first codewords.
Stage 2010 may include generating the set of first codewords by a first linear feedback shift register of the first encoder and may include providing first codeword chunks to a second linear feedback shift register of the second encoder. Stage 2020 may include performing a second encoding process by a second encoder.
Each first codeword may (but not limited to) be arranged in a set of consecutive columns of a matrix. Stage 2020 may include filling registers that correspond to rows of the matrix and performing the second decoding process on rows of the matrix.
Stage 2090 can include configuring a configurable linear feedback shift register according to an encoding parameter of an encoding process selected from the first and second encoding processes. A Non limiting example of a configurable linear feedback shift register is included in
Method 2000 may include stage 2070 of storing the set of second codewords in a flash memory, stage 2080 of reading a content of the flash memory, and stage 2090 of applying a encoding process on the content of the flash memory.
Method 2100 may start by an initialization stage 2102. Stage 2102 may include configuring an error correction capability of at least one of the first and second decoding processes based on a desired error correction capability.
Stage 2102 is followed by stage 2104 of receiving information that includes a final set of codewords that undergone an error inducing process. The error inducing process is illustrated in
Stage 2104 is followed by stage 2110 of reconstructing information by applying on the information a first decoding process to provide first results. The results can be penultimate codewords and errors (if these errors were not corrected during the first decoding process).
Stage 2110 is followed by stage 2120 applying a second decoding process on folded versions of first results to provide second results. A folded version of a first result is representative of storage of the first result in a two or higher dimensional memory space. The second result can be the message itself of antepenultimate codewords and errors (if these errors were not corrected during the first and second decoding processes). If, for example, the received information included one or more errors and a two dimensional folded code (such as illustrated in
Stage 2110 may include storing each first result in multiple columns of a memory space and stage 2120 may include performing the second decoding process on rows of the memory space.
The first error decoding process may differ from the second decoding process. At least two first results have different lengths. At least two second results may have different lengths (can also have same length as a special case).
Stage 2120 may be followed by stage 2130 of performing a third decoding process on a folded version of each second result to provide a set of third results. A folded version of a second result is representative of a storage of the second result in a two or higher dimensional memory space.
The first, second and third error decoding processes may differ from each other. At least two results out of different sets of results may have different lengths. At least two results of the same set of results may have different lengths.
Method 2100 may include performing more than three decoding processes as illustrated by stage 2140 of performing additional decoding processes.
Method 2100 may include performing at least four decoding processes, wherein each decoding process except a first decoding process is applied on a folded version of a set of results obtained by applying a previous decoding process. All decoding processes may be applied on codewords that are not folded.
Method 2100 may include performing at least three decoding processes, wherein each decoding process except a first decoding process is applied on a possibly folded version of a set of results obtained by applying a previous decoding process, wherein at least one decoding process is applied only on redundancy bits generated by previous decoding processes. For example, a fourth decoding process can be applied on a parity field (that is denoted D4 in
Method 2100 may include performing at least three decoding processes, wherein each decoding process except a first decoding process is applied on a folded version of a set of results obtained by applying a previous decoding process, wherein at least two decoding processes differ from each other.
Method 2102 differs from method 2100 by including stages 2012 and 2022. Equivalent stages may be applied in relation to additional (above three) decoding processes but for simplicity of explanation these stages are not shown.
Method 2102 includes performing at least two decoding processes, wherein at least one decoding process is followed by determining whether to ignore the results of the decoding process. The results of a decoding process can be ignored of if, for example, a miss-correction is detected or suspected. The ignoring can include applying a next decoding process on a folded version of each result of a decoding process that preceded the ignored decoding process. For example, assuming that the outcome of stage 2120 is suspected to include miss-correction (a correct bit was altered during stage 2120 to provide an erroneous bit) then stage 2130 may be applied on the outcome of stage 2110.
This determination (of whether to ignore) is illustrated by query stage 2012 that follows stage 2010 and by query stage 2022 that follows stage 2020. If stage 2012 determines to ignore then it is followed by stage 2014 of ignoring the results of the first decoding process or at least ignoring an amendment of some bits that were detected as errors by the first decoding process. Stage 2014 is followed by stage 2120. If stage 2022 determines to ignore then it is followed by stage 2024 of ignoring the results of the second decoding process or at least ignoring an amendment of some bits that were detected as errors by the second decoding process. Stage 2024 is followed by stage 2030.
Method 2102 may include ignoring the results of an ignored decoding process by providing to applying a next decoding process on a folded version of each result of a decoding process that preceded the ignored decoding process. Thus, stage 2024 may include providing to stage 2030 the results of stage 2010.
Method 2102 may include preventing a modification of at least one bit of a result by at least one decoding process if determining by at least one preceding decoding process that the at least one bit is correct. Thus, stage 2024 may involve providing to stage 2030 a modified outcome of stage 2020. The modified outcome does not include modification to one or more bits that were suggested or performed by stage 2020.
Each decoding process is characterized by correction threshold—the number of bits it can correct in a reliable manner. Method 2102 may include preventing a modification of information bits if a decoding process indicates that errors occurred in more information bits than the correction threshold of the decoding process.
Method 2104 differs from method 2100 by stages 2016 and 2026. Equivalent stages may be applied in relation to additional (above three) decoding processes but for simplicity of explanation these stages are not shown.
Method 2106 includes performing at least two decoding processes. At least one decoding process is followed by determining whether to skip at least one decoding process that follows the decoding process. If, for example, the outcome of a first decoding process (stage 2110) is more reliable than a predefined reliability threshold then method 2100 may skip stage 2120. The determining to skip at least one decoding process can be made if at least one decoding process that preceded the determination provided a result of a desired characteristic. This determination is illustrated by query stage 2016 located between stages 2110 and 2120 and by query stage 2026 located between stages 2020 and 2030. It is noted that the skipping may include skipping all remaining decoding stages or skipping only a portion of the remaining decoding processes.
According to an embodiment of the invention stage 2020 may benefit from the outcome of stage 2010. The same applied to each decoding process that follows one or more other decoding processes. For example, stage 2020 may include performing an error location search of a decoding process in response to error locations that were found during a previous decoding process—during stage 2010.
Method 2200 may start by an initialization stage 2202.
Stage 2202 is followed by stage 2204 of receiving information that includes a final set of codewords that undergone an error inducing process.
Stage 2204 is followed by stage 2210 of applying on the information a first decoding process to provide first results. The first results may include second codewords with possible errors and may include indications about correctness of information bits.
Stage 2210 is followed by stage 2220 of applying a second decoding process to provide second results. The second results may include second codewords with possible errors and may include indications about correctness of information bits.
Stage 2220 may include applying a second decoding process on the information, on first codewords with errors or on modified first codewords with errors. Modified first codewords are first codewords that may include at least one unmodified bit that was indicated by the first decoding process as an erroneous bit but was not amended. The bit is unmodified if there is a chance that its modification may result in a miss-correction.
Stage 2220 is followed by stage 2230 of applying a third decoding process to provide third results. The third results may include third codewords with possible errors and may include indications about correctness of information bits.
Stage 2230 may include applying a third decoding process on the information, on second codewords with errors or on modified second codewords with errors. Modified second codewords are second codewords that may include at least one unmodified bit that was indicated by the second decoding process as an erroneous bit but was not amended. The bit is unmodified if there is a chance that its modification may result in a miss-correction.
Stage 2230 may be followed by stage 2240 of determining whether to modify each information bit based upon multiple indications associated with the information bit.
Stage 2240 may include determining whether to modify each information bit based upon a majority of indications associated with the information bit.
Stage 2240 may include determining to modify each information bit if at least a predetermined number of indications associated with the information bit indicate that the bit should be modified.
Stage 2240 may be responsive to confidence levels of different indications associated with the information bit. A decoding process that has a stronger error correction capability may provide indications that are more confident. If a decoding process can detect up to X errors in a reliable manner then if it detects more errors (X+y) then the confidence level associated with its error detections may be lower. In soft decoding, every correction of X+y bits has a corresponding confidence level, since there is a reliability measure per bit. Thus the correction hypothesis is chosen to be the most likely one; and the decision whether to implement the correction or not depends on the reliability measure of the most likely hypothesis.
Stage 2240 is followed by stage 2250 of amending bits according to the determination.
Method 2200 may include additional (more than three) decoding processes and determining whether to modify bits based also upon these additional decoding processes but for simplicity of explanation these stages are not shown.
Method 2300 may start by initialization stage 2302.
Stage 2302 may be followed by stage 2304 of receiving information that may include errors. The information may be generated by either one of the encoding methods illustrated above.
Stage 2304 may be followed by stage 2310 of performing an iteration of multiple decoding processes.
Stage 2310 may include executing multiple decoding stages and optionally additional stages of either one of methods 2100, 2102, 2104 and 2200.
Stage 2310 may include performing multiple instances of a single decoding process.
Stage 2310 may be followed by stage 2320 of determining whether to perform another iteration of multiple decoding processes. If the answer is positive then stage 2320 is followed by either one of stages 2310 and 2330.
Stage 2310 may include determining to perform a second iteration of multiple decoding processes if the first iteration result does not satisfy a predefined criteria such as a reliability criteria.
Stage 2310 may include determining to perform a second iteration of multiple decoding processes if the first iteration failed.
Stage 2330 may include changing at least one parameter or characteristic of the current iteration so that the next iteration differs from the current iteration.
Stage 2330 may include altering a predefined number of corrections that can be made during the iteration, altering the order of decoding processes, altering the decoding processes that will participate in the next iteration, and the like.
For example, stage 2310 may include performing an iteration of multiple decoding processes while allowing a correction of up to a predefined number of corrections. Stage 2330 may include altering the predefined number of corrections. Stage 2330 will be followed by stage 2310 that will include allowing a correction of up to an altered predefined amount of corrections. The number of allowed corrections can increase as the number of iteration increases but this is not necessarily so.
Stage 2310 may include storing the results of the decoding process iteration. Stage 2310 may be followed by stage 2350 of selecting a selected decoding iteration result out of the multiple decoding iterations results. Thus, a decoding iteration that is most reliable can be selected and its output may be selected as the message.
The multi dimensional folded code may have p dimensions, wherein p is a positive integer. Each dimension may correspond a different ordering of the input data, and coded with BCH codes—each dimension is generated by applying a BCH code on data or on codewords of a previous dimension. The data to the codes may be folded over several columns or rows in order to obtain higher rate codes.
Matrix 100 of
Each first codeword is stored in a folded manner in matrix 100. In other words matrix 100—stores folded version of each first codeword.
A second encoding process is appended on the first twelve bits of each two adjacent rows of matrix 100 to provide second codewords. The redundancy bits are stored in the thirteenth column 100(13) of matrix 100.
By grouping together the columns of the resultant outer code a matrix is provided which is then divided into rows. Each one or more rows then constitute the data for another BCH encoding process to provide inner codewords. The redundancies of the inner code are grouped together and appended to the sequence of outer codewords.
It is noted that the inner codes and the outer codes may differ in that the redundancy of the outer code is also encoded by the inner code while the inner code's redundancy is not further encoded. Yet a further code may be appended to protect the redundancies of the inner codes.
The rate of the codes may be configured in several ways. For example, the length of the data/redundancy can differ from one code to another. The number of rows/columns for each code may be modified. Zero padding may be added to the matrix in order to complete the outer codes to full columns.
The following numerical example illustrates two codes that are referred to as outer code and inner code.
The outer Code is characterized by the following characteristics: BCH code over GF(215), data length: 2048 bytes, correction capability 32 errors, redundancy 60 bytes, codeword length 2108 bytes, folding—the codeword is folded into 17 columns of 124 bytes, number of outer code-words 4.
The inner code is characterized by the following: BCH code over GF(210), data length of 68 bytes, correction capability 1 error, redundancy 10 bits, codeword length 690 bits, folding—codeword uses full bytes from each column (no folding), number of inner code-words 124. The redundancy of the inner code is 1240 bits—155 bytes which are appended to the sequence of outer codes.
The rate of the code is determined by the redundancy added by each of the outer codes and the overall redundancy added by the inner codes. As will be shown, it is possible to construct the component codes in such a manner that the code rate and composition will be parametric and highly configurable.
The term encoding unit has the same meaning as the term encoder. It is used for simplicity of explanation and for differentiating between encoders 210 and 220 and encoding unit 200.
Encoding unit 200 is illustrated in
It is assumed that inner encoder 220 managed V-bits (for example 8 or 16 bits) at a time. Data is received at input port 202 and passes through outer encoder 210. Outer encoder 210 appends a redundancy to the data bits following every section of data bytes corresponding to the data length of the outer code (e.g. this would be 2048 bytes according to the numeric example discussed above). BCH encoding may be done by using a linear feedback shift register through which the data (so called systematic data) is passed. Therefore, the data simply passes through the outer encoder 210 without being modified while the linear feedback shift-register of outer encoder 210 advances. When the systematic data of the code completely passed through the linear feedback shift-register, the content of the linear feedback shift register is the redundancy of the code and is appended to the data stream. A similar principle works also for the inner encoder 220.
Inner encoder 220 includes state memory 250, counter 240 and V-step shift register logic 230. The inner encoder 220 works on the stream outputted by the outer encoder 210. The stream is parsed into V-bit sections and the inner encoder works on V bits at a time. Each section of V-bits is associated with a different inner code and is used to advance the state of the relevant inner code. Each state is stored in register out of registers 260(1)-260(N2) of V-step shift register logic 230 of inner encoder 220. Then, the state is stored in memory and the state of the next inner encoder is obtained from the state-memory 250 and is advanced according to the next set of V-bits. The counter determines the address of the inner code state to be used. When the entire stream of data and redundancy due to the outer code has passed, switches SW1212 and SW2214 change their stage to state B (up to this moment they were in state A) and the redundancy of the inner codes is flushed out sequentially from the state memory.
It is noted that the number of inner codes (and hence the number of rows in the code matrix) may be determined by the size of the state memory (or by the number of addresses iterated by the counter). Furthermore, the overall length of the data outputted from the outer encoder need not divide the number of inner codes as few of the inner codes may work on less data than the others (this is equivalent to zero padding some of the element in the matrix in
The outer code can be made configurable in several ways. The code length can be modified quite easily. By choosing to pass through a linear feedback shift register (of the BCH encoder) less or more of the information contents of the codeword can be encoded. By appending the contents of the linear feedback shift register to the information bits a legitimate BCH code word is provided. Thus, generalizing the length of the code may become an easy task. The operation of the decoder is hardly modified as the resultant codeword is a legitimate one. The decoder needs only to calculate the syndrome and perform the Chien-search on the bits generated by the codeword.
Linear feedback shift-register 300 allows to correct a single codeword for a code designed under the Galois field GF(215). It is noted that after the last information bit passes through storage element 306(15) then storage element 306(15) stores the single redundancy bit.
Linear feedback shift register 400 may allow a correction of more errors in comparison to linear feedback shift register 300. The maximum redundancy is denoted r. The number of errors that could be corrected will typically be r/m or more where m determines the Galois field GF(2m) over which the code operates. In
Codes with smaller redundancy (and lower correction capability) may be accommodated by setting the first c configuration storage elements to 0 and setting the rest of the configuration storage elements registers (DFc+1, . . . DFr) to the appropriate tap values.
The encoding may then proceed while the redundancy of the code will be present at the (c+1)′th storage element through the r′th storage element after that last data bit passed through register Dr. It is noted that the encoding process can be modified to advance v steps at a time with appropriate modifications to the logic function circuitry at the input of the data FFs. It is noted that that the number of registers 260(1)-260(N2) will still remain the same also for the V-step advance case.
The inner encoder 220 may be configured in the same way that the outer encoder 210 has been configured but can also be configured by modifying the number of states the counter will count over. This will essentially determine the number of rows in the code matrix.
A 3D encoding unit can be constructed on the basis of a two dimensional encoder such as encoding unit 200 of
It is well known that turbo product codes (TPC) achieve high performance for low and moderate code rates.
This invention discloses a method for obtaining high performance for high rate codes through folding of code components, as demonstrated for the 2D and 3D codes. Another example for multi-dimensional encoding is by encoding information bits separately in every dimension. The encoding scheme described in
In the encoding scheme presented in
Per dimension different component codes may used. This may allow variation in the folding ratio and in component code redundancy within every dimension. It is well known that irregular turbo product codes may achieve improved performance over conventional TPC, where in each dimension the same component code is used for all encoded lines.
By using different component codes a high coding diversity can be obtained over every dimension. As an example of simple irregular multi-dimensional encoding of folded BCH components, every component code may have same length (determined by number of planes per component code), and encode with variable redundancy size, thus some components will have higher error correction capabilities than other components of a certain dimension. The overall performance gain is provided from the iterative decoding process.
It is noted that for any carefully designed code the decoding can be done in several steps where success can be obtained already in the early steps. Thus the decoding delay may be small, e.g. in cases that only few errors occur.
In some cases only few of the decoding processes are applied and some other decoding processes are skipped. For example—only outer decoding can be applied (while skipping an inner decoding process)—especially where the outer code is stronger—capable of amending more errors. The outer code refers to the code component used for the 1st dimension of the multi-dimensional. The codes need not be symmetric and it may be the case that the outer code corrects a great many errors. In that case, it may be possible to read out the codeword and correct it only using the outer code decoder.
A decoding success (miss-correction) per outer codeword may be determined in several ways. For example—the data of each outer-codeword may contain a CRC which may be checked. Miss-correction in BCH code may also be determined during the Chien-search phase of the decoder. Primarily, if a smaller number of zeros is found than the degree of the ELP, a miss-correction is declared and no bit is corrected. Such miss-correction detection can be extremely reliable when the error correction capability is large enough and when the codeword length is smaller than the field size.
It should be noted that each codeword may include several outer codewords and it may be that some of the outer codewords are decoded correctly and for some, miss-correction has been detected and no correction is performed.
When applying multiple decoding processes the decoding can start by performing an outer decoding process alone. This can reduce the latency as only a part of the data matrix should be received before starting the decoding.
If an outer decoding process failed, an inner (2nd dimension) decoding process can be initiated.
All the inner codewords are decoded and corrected. When there is a high reliability miss-correction indication for outer codewords—only bits that belong only to outer codewords that were not successfully decoded during the previous phase (Outer only) are corrected. In fact, if a decoder of an inner codeword suggests to correct a bit that belongs to an outer codeword which is known to be correct, a miss-correction may be declared and non of the corrections suggested by that inner decoder are performed. This can be followed by applying the outer decoding process to correct any “left-over” errors.
Correction Without Re-Calculating the Entire Syndrome
During the decoding procedure of the BCH code it is typical to calculate a syndrome. The syndrome of the outer codeword (or the inner codeword in the following iterations) may be calculated by going over the entire information. However, this may not be necessary as the method may involve adding to the existing outer syndromes the effect of the corrections made by the inner codes. This may save a considerable time. This may be very noticeable when the decoding processes have a small correction capability (for example—1, 2 or 3 errors) as in these cases there exist methods of finding the errors positions directly from the syndrome, without performing a BM and a Chien-Search step.
Multiple iterations of multiple decoding processes can be applied during iterative decoding. An iteration can include, for example, an outer decoding process and an inner decoding process. The iterations can be stopped once a predefined iteration limit is reached, or when further iterations will not amend additional errors. Before a next iteration is executed outer codes that were not successfully decoded during a previous iteration may be amended by reversing the effect of the previous iteration or at least reversing the affect of an inner corrections done by the inner code (in the previous phase) on those outer codes that were not successfully decoded in the previous step.
Soft decoding may also be included in the iterative decoding process. Soft decoding of BCH codes is possible using sub-optimal decoding methods for BCH component codes with low hard decoding correction capabilities (for example—1, 2, or 3 errors). Soft decoding need not be applied for all decoding stages. For example, it may be used only during the inner codeword decoding process. In that case, an inner decoding process step can include a soft decoding step of a hard decoding step.
Decoding one Error Beyond the BCH Bound
Typically, a BCH decoder is only capable of correcting up to t=(D−1)/2 errors where D is the code minimum distance.
However, there are methods of decoding more than this limit or at least suggesting several possible candidates. The following illustrates a method of correcting t+1 errors (or suggesting several possible candidates) with a relatively low complexity.
A decoding process (or a decoder that implements such a decoding process) performs syndrome calculation, error location polynomial (ELP) calculation, and Chien search. The ELP is used during the Chien search step to identify error locations as these locations can be associated with x=α−i which nullify the ELP. The ELP calculation step illustrated below facilitates a recovery of an ELP of degree t+1 instead of just degree t.
On the other hand, if the value of element 2t+1 of the syndrome was known, just following encoding (bearing in mind that elements 2t+2 and 2t are 0), this element can be subtracted from the syndrome obtained after reading an erroneous codeword and continue the BM an additional iteration to recover an ELP of degree t+1 for locating t+1 errors.
However, during the time of decoding the post encoding value of element 2t+1 of the syndrome is not known. Therefore, the decoding process can enumerate over it. As Λ0=1, this is equivalent to enumerating over all possible values of Δ (during the last iteration). Thus, many candidates (2^m−1) for the degree t+1 ELP are obtained and are defined by Λ(x)=V1(x)−Δ·V2(x), where V1(x)=Λ(2t-1)(x), V2(x)=B(2t-1)(x)·x2, and Δ may be any element in GF(2m). ζ(2t-1)(x) and B(2t-1)(x) are the polynomials ζ(x) and B(x) in the algorithm of
However, not all choices of Δ will result in a legitimate ELP Λ(x). A legitimate ELP will be one which follows the following rules: Has t+1 zeros, All zeros correspond to elements that point to a bit within the codeword.
By calculating the proportion
the value of Δ which nullifies the ELP is found. By calculating a histogram of those Δs which result in t+1 errors, it is possible to find suitable candidate solutions. In
It is noted that all of the two-dimensional decoding processes described in this specification are applicable to p-dimensional codes, where p exceeds two.
There are BCH component codes, for which the miss-correction probability is non negligible. An example for such codes is a BCH code with T=1, and length equal to 2^m−1, where m is the field size (which is also known as a perfect code). In such cases it is required to take measures in order to decrease the probability of false miss-correction through the iterative decoding, especially since by code design it is expected that some component codes will not always be correctable on first iteration, and first dimension.
Then, in the next few iterations, the error correction is applied for every component code, however the number of corrections to be applied is restricted according to the code spectrum. These iterations are represented by stages 1140 and 1148.
Following decoding iterations include conventional BCH decoding processes per component, and applying the suggested corrections for every component code. In case that the number of iterations exceeds a certain threshold (denoted STANDARD_ITERS), the decoder tries to decode. These following decoding iterations are represented by stages 1152-1160.
These conventional BCH decoding processes can be followed by enhanced BCH decoding processes—in which an additional error may be amended for each BCH component, as illustrated by stages 1168 and 1178. An enhanced BCH decoding process is illustrated in
If these iterations did not yield successful decoding then the order of decoding dimensions may be changed (stage 1184) and the iterations may start over.
In general, the decoding may stop immediately after the information bits are successfully recovered. This can be implemented for example by using a CRC on the data, and checking the CRC validity after every iteration.
The number of allowed iterations is set in advance. Thresholds MAJORITY_ITER, T_LESS_ITER, STANDARD_ITERS and MAX_EBCH_ITER set the maximal allowable number of each set of iterations.
It is noted that although
On the first few iterations a majority decision error correction is used, in order to reduce probability of false miss-corrections. These few iterations provide a first decoding pass which does not apply the suggested BCH corrections on the input stream, but only marks their locations. More precisely, for every suggested correction save in a separate buffer the number of component codes which suggested this correction. Since multi-dimensional codes are used, every input bit is encoded by multiple codes (the number of codes is equal to the number of dimensions). Therefore, applying a bit-flip only to those bits which were suggested by a majority of component decoders, or by more than a certain threshold (not necessarily the majority of decoders) may increase the reliability of corrections, and overcome the problem of false miss-corrections.
A simple extension, which is suggested here, is to apply corrections not only to locations with sufficiently high scores, but also to all suggested corrections which are associated with the decoding processes that had high score locations. This is since the overlap between component codes on different dimension is usually small, depending on the folding ratio. Thus, the reliability of a suggested correction is already increased by requiring that its score will be greater than 1.
For the initial iterations, after the majority decision iterations, it is suggested to take further steps which reduce the probability of false corrections. Every component code has a code spectrum, which can be utilized for this purpose. Define a probability distribution, P(n,e), where T≧n≧0 is the number of (falsely) detected errors after the BCH decoding, and e is number of input errors.
The case that BCH components are uncorrectable is of interest in the context of miss-corrections, then it can be assumed that e>T, where T is the number of errors according to the BCH bound. After decoding a BCH component code, with e>T, there will be additional errors according to
where N is the code length (including parity) of a component code.
Accordingly, an iterative decoding iteration can be provided which restricts decoding to correction of only m errors, for values of m for which Pn(m) is sufficiently small.
At the expense of performing many iterations, the reliability of decoding can increase, since the more iterations with reliable decoding (and low rate of false miss-corrections) the higher is the probability for successful decoding.
Sometimes the decoding order of the different dimension may influence the final result (success/failure). This is once again a result of false miss-corrections. Consider for example a 3D code where the code on D1 (the first dimension) is relatively a strong code, i.e. low false correction probability. Then a decoding order of [d1,d2,d3] will not always be optimal, and there may be cases where a decoding order of [d1, d2, d1, d3] or [d1,d3,d1,d2] will be more efficient.
First initialize a final score matrix S with zeros, and let the matrix be of the exact size of the input information matrix. The first stage here to perform fast decoding adhering to the iterative hard decoding described in previous sections. During every iteration, a score matrix M is created. Every entry in M is denoted missCorrectionScore, and specifies the number of component codes reporting miss-correction on this entry.
When the number of fast decoding exceeds MAX_ITERS, the enhanced BCH decoding begins. For each BCH component, the enhanced BCH is attempted only if there are entries for this codeword in M which received a score greater than the thresholds denoted majorityScoreTH of the current iteration. If true, every candidate increments by 1 its corresponding entries in S.
Finally, after going over all candidates, the bits to be flipped correspond to those entries in S with score greater than the threshold FilpTH. This process is repeated until there are no further errors, or until a maximal number of iterations is reached.
Method 1300 of
When the number of fast decoding exceeds MAX_ITERS, the enhanced BCH decoding begins. For each BCH component, the enhanced BCH is attempted only if there are entries for this codeword in M which received a score greater than the thresholds denoted majorityScoreTH of the current iteration. If true, enhanced BCH is applied resulting with potentially multiple candidates. Then a candidate is selected only if there exists a single (unique) candidate which contains locations with associated missCorrectionScore (in M) greater than a predetermined threshold. This process is repeated until there are no further errors, or until a maximal number of iterations is reached.
The methods of
When both hard and soft decoding are used, it might not be advisable to use the enhanced BCH decoding, as it can be used for hard decoding only, and its improvement is usually more dramatic in cases of low frame error rate (FER), by achieving a steeper FER slope. Obviously, it depends on the system design parameters, which determine the working points.
According to the FER working point which will be the trigger for switching the decoding strategy from hard decoding to soft decoding, the additional benefit of enhanced BCH should be evaluated. The additional efficiency of correcting T+1, versus the implementation complexity should be weighed according to the specific system and components code which are used.
According to an embodiment of the invention a sub-optimal soft decoder can be used for some or all BCH components. Since the number of corrected errors increases to t+n, where n is the number of enumeration bits for soft decoding. The price of false correction can be severe here since a false correction may invert t+n bits, which will add on to the existing errors of a codeword.
The soft decoding of a BCH component code does not solely rely on the miss-correction indication from the BCH decoder. False corrections can be reduced by accounting for the reliability of the corrected codeword. In other words, since there is an LLR value per bit, the metric of the corrected codeword can be approximated by the sum of LLRs of the corrected bits. In case the sum-LLR, denoted by outLLR is greater than some threshold, it can be suspected to be a false correction.
This property is used in the iterative soft decoding process, to minimize the false correction probability at the expense of higher latency decoding (by multiple iterations). The threshold for outLLR, denoted by LLR_TH(iterCounter) is slightly increased every iteration, to allow more and more corrections to be applied, while minimizing false corrections.
In order to increase the convergence rate of the soft decoder with increasing LLR thresholds, it is advisable to use a set of fast increasing thresholds for LLR_TH(iterCounter), and only in cases of unsuccessful decoding after a maximal number of iterations, repeat the process with a different LLR_TH set, which increases much slower per iteration.
This allows reducing the average number of iterations for soft decoding, which is efficient in terms of power consumption for hardware implementation.
According to an embodiment of the invention a reduction of the average decoding latency can be achieved by varying the decoding complexity according to the decoding success. The parameters to control are the number of bits for enumeration in the sub-optimal soft decoding, and the error-span for each enumerated bit. That is, by using only few bits (e.g. 3) for enumeration and fixing a small error-span. The error-span is defined as the number of bits p with smallest absolute value of LLRs. The decoding complexity is determined by the product of error-spans for all enumerated bits.
On first soft decoding attempt, few bits are used with small enumeration spans, then in case of decoding failure the span is increased, or the number of enumerated bits (or both) is increased and iterative decoding is attempted once again. The average implementation complexity can be considerably reduced here.
Enhanced BCH decoders can be used to provide multiple candidates, and the likely candidate can be selected according to its sum-LLR. The methods of multi-dimensional decoding aided selection, as described for hard decoding, may as well be applied here.
Care is to be taken here, as the complexity of the enhanced BCH decoder is linear with the length of the code, this may sometimes be impractical for soft decoding for multiple enumeration bits.
According to an embodiment of the invention, a multi-dimensional code may have a growing codeword size with the number of dimensions. The motivation of such design is to enable graceful degradation of the latency in decoding as function of the input SNR. That is, in case there are few errors, only the code of the first dimension operates. With more errors, it would be possible to iteratively decode two dimensions, and only if this fails, the third dimension codewords are used.
The special coding structure enables gradually increasing the number of bits to be fetched from memory for decoding, depending on the number or errors. Assume that only a few bytes of the component in D2 are requested. The decoding process is as follows:
One property of multi-dimensional codes for high rates when using folded BCH is the possibility of using components with only few error correction capability, e.g. codes with T≦4. For such component codes a Chien search for BCH decoding is not necessary, and by solving a polynomial equation of order smaller or equal to 4 over GF(2m) is possible. It is known that solutions for quadratic, cubic and quadratic equations over GF(2m) is possible. This may considerably reduce the implementation complexity of a multi-dimensional iterative decoder.
In some applications, such as encoding for Nand Flash devices, the channel output can be either hard output or soft output. However, in order to obtain soft output multiple read operations have to be carried out, and this generally degrades the read time performance, regardless of the decoding time. Therefore some applications may consider designing systems with hard decoding until the device performance deteriorates, and only then perform soft decoding. In such applications it may be useful to use BCH codes with T≦4, and then apply soft decoding over all dimensions.
Certain operations are described herein as occurring in the microcontroller internal to a flash memory device. Such description is intended to include operations which may be performed by hardware which may be associated with the microcontroller such as peripheral hardware on a chip on which the microcontroller may reside. It is also appreciated that some or all of these operations, in any embodiment, may alternatively be performed by the external, host-flash memory device interface controller including operations which may be performed by hardware which may be associated with the interface controller such as peripheral hardware on a chip on which the interface controller may reside. Finally it is appreciated that the internal and external controllers may each physically reside on a single hardware device, or alternatively on several operatively associated hardware devices.
It is appreciated that the teachings of the present invention can, for example, be implemented by suitably modifying, or interfacing externally with, flash controlling apparatus. The flash controlling apparatus controls a flash memory array and may comprise either a controller external to the flash array or a microcontroller on board the flash array or otherwise incorporated therewithin. Examples of flash memory arrays include Samsung's K9XXG08UXM series, Hynix's HY27UK08BGFM Series, Micron's MT29F64G08TAAWP or other arrays such as but not limited to NOR or phase change memory. Examples of controllers which are external to the flash array they control include STMicroelectrocincs's ST7265x microcontroller family, STMicroelectrocincs's ST72681 microcontroller, and SMSC's USB97C242, Traspan Technologies' TS-4811, Chipsbank CBM2090/CBM1190. Examples of commercial IP software for Flash file systems are: Denali's Spectra™ NAND Flash File System, Aarsan's NAND Flash Controller IP Core and Arasan's NAND Flash File System. It is appreciated that the flash controller apparatus need not be NAND-type and can alternatively, for example, be NOR-type or phase change memory-type.
Flash controlling apparatus, whether external or internal to the controlled flash array, typically includes the following components: a Memory Management/File system, a NAND interface (or other flash memory array interface), a Host Interface (USB, SD or other), error correction circuitry (ECC) typically comprising an Encoder and matching decoder, and a control system managing all of the above.
The present invention may for example interface with or modify, as per any of the embodiments described herein, one, some or all of the above components and particularly with the ECC component.
It is appreciated that software components of the present invention including programs and data may, if desired, be implemented in ROM (read only memory) form including CD-ROMs, EPROMs and EEPROMs, or may be stored in any other suitable computer-readable medium such as but not limited to disks of various kinds, cards of various kinds and RAMs. Components described herein as software may, alternatively, be implemented wholly or partly in hardware, if desired, using conventional techniques.
Included in the scope of the present invention, inter alia, are electromagnetic signals carrying computer-readable instructions for performing any or all of the steps of any of the methods shown and described herein, in any suitable order; machine-readable instructions for performing any or all of the steps of any of the methods shown and described herein, in any suitable order; program storage devices readable by machine, tangibly embodying a program of instructions executable by the machine to perform any or all of the steps of any of the methods shown and described herein, in any suitable order; a computer program product comprising a computer useable medium having computer readable program code having embodied therein, and/or including computer readable program code for performing, any or all of the steps of any of the methods shown and described herein, in any suitable order; any technical effects brought about by any or all of the steps of any of the methods shown and described herein, when performed in any suitable order; any suitable apparatus or device or combination of such, programmed to perform, alone or in combination, any or all of the steps of any of the methods shown and described herein, in any suitable order; information storage devices or physical records, such as disks or hard drives, causing a computer or other device to be configured so as to carry out any or all of the steps of any of the methods shown and described herein, in any suitable order; a program pre-stored e.g. in memory or on an information network such as the Internet, before or after being downloaded, which embodies any or all of the steps of any of the methods shown and described herein, in any suitable order, and the method of uploading or downloading such, and a system including server/s and/or client/s for using such; and hardware which performs any or all of the steps of any of the methods shown and described herein, in any suitable order, either alone or in conjunction with software.
Features of the present invention which are described in the context of separate embodiments may also be provided in combination in a single embodiment. Conversely, features of the invention, including method steps, which are described for brevity in the context of a single embodiment or in a certain order may be provided separately or in any suitable subcombination or in a different order. “e.g.” is used herein in the sense of a specific example which is not intended to be limiting.
This application claims the benefit of U.S. Provisional Patent Application No. 61/166,834, filed Apr. 6, 2009, the entire contents of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4430701 | Christian et al. | Feb 1984 | A |
4463375 | Macovski | Jul 1984 | A |
4584686 | Fritze | Apr 1986 | A |
4589084 | Fling et al. | May 1986 | A |
4701885 | McElroy | Oct 1987 | A |
4777589 | Boettner et al. | Oct 1988 | A |
4866716 | Weng | Sep 1989 | A |
4875190 | Sakano | Oct 1989 | A |
5003597 | Merkle | Mar 1991 | A |
5077737 | Leger et al. | Dec 1991 | A |
5280445 | Shieh et al. | Jan 1994 | A |
5297153 | Baggen et al. | Mar 1994 | A |
5305276 | Uenoyama | Apr 1994 | A |
5592641 | Doyle et al. | Jan 1997 | A |
5623620 | Alexis et al. | Apr 1997 | A |
5640529 | Hasbun | Jun 1997 | A |
5657332 | Auclair et al. | Aug 1997 | A |
5663901 | Harari et al. | Sep 1997 | A |
5724538 | Morris et al. | Mar 1998 | A |
5729490 | Calligaro et al. | Mar 1998 | A |
5740395 | Wells et al. | Apr 1998 | A |
5745418 | Hu et al. | Apr 1998 | A |
5778430 | Ish et al. | Jul 1998 | A |
5793774 | Usui et al. | Aug 1998 | A |
5920578 | Zook et al. | Jul 1999 | A |
5926409 | Engh et al. | Jul 1999 | A |
5933368 | Hu et al. | Aug 1999 | A |
5956268 | Lee | Sep 1999 | A |
5956473 | Hu et al. | Sep 1999 | A |
5968198 | Balachandran | Oct 1999 | A |
5982659 | Irrinki et al. | Nov 1999 | A |
6011741 | Harari et al. | Jan 2000 | A |
6016275 | Han | Jan 2000 | A |
6038634 | Ji et al. | Mar 2000 | A |
6081878 | Estakhri et al. | Jun 2000 | A |
6094465 | Stein et al. | Jul 2000 | A |
6119245 | Hiratsuka | Sep 2000 | A |
6182261 | Haller et al. | Jan 2001 | B1 |
6192497 | Yang et al. | Feb 2001 | B1 |
6195287 | Hirano | Feb 2001 | B1 |
6199188 | Shen et al. | Mar 2001 | B1 |
6209114 | Wolf et al. | Mar 2001 | B1 |
6259627 | Wong | Jul 2001 | B1 |
6272052 | Miyauchi | Aug 2001 | B1 |
6278633 | Wong et al. | Aug 2001 | B1 |
6279133 | Vafai et al. | Aug 2001 | B1 |
6301151 | Engh et al. | Oct 2001 | B1 |
6370061 | Yachareni et al. | Apr 2002 | B1 |
6374383 | Weng | Apr 2002 | B1 |
6504891 | Chevallier | Jan 2003 | B1 |
6532169 | Mann et al. | Mar 2003 | B1 |
6532556 | Wong et al. | Mar 2003 | B1 |
6553533 | Demura et al. | Apr 2003 | B2 |
6560747 | Weng | May 2003 | B1 |
6637002 | Weng et al. | Oct 2003 | B1 |
6639865 | Kwon | Oct 2003 | B2 |
6674665 | Mann et al. | Jan 2004 | B1 |
6675281 | Oh et al. | Jan 2004 | B1 |
6704902 | Shinbashi et al. | Mar 2004 | B1 |
6751766 | Guterman et al. | Jun 2004 | B2 |
6772274 | Estakhri | Aug 2004 | B1 |
6781910 | Smith | Aug 2004 | B2 |
6792569 | Cox et al. | Sep 2004 | B2 |
6873543 | Smith et al. | Mar 2005 | B2 |
6891768 | Smith et al. | May 2005 | B2 |
6914809 | Hilton et al. | Jul 2005 | B2 |
6915477 | Gollamudi et al. | Jul 2005 | B2 |
6952365 | Gonzalez et al. | Oct 2005 | B2 |
6961890 | Smith | Nov 2005 | B2 |
6968421 | Conley | Nov 2005 | B2 |
6990012 | Smith et al. | Jan 2006 | B2 |
6996004 | Fastow et al. | Feb 2006 | B1 |
6999854 | Roth | Feb 2006 | B2 |
7010739 | Feng et al. | Mar 2006 | B1 |
7012835 | Gonzalez et al. | Mar 2006 | B2 |
7038950 | Hamilton et al. | May 2006 | B1 |
7068539 | Guterman et al. | Jun 2006 | B2 |
7079436 | Perner et al. | Jul 2006 | B2 |
7149950 | Spencer et al. | Dec 2006 | B2 |
7177977 | Chen et al. | Feb 2007 | B2 |
7188228 | Chang et al. | Mar 2007 | B1 |
7191379 | Adelmann et al. | Mar 2007 | B2 |
7196946 | Chen et al. | Mar 2007 | B2 |
7203874 | Roohparvar | Apr 2007 | B2 |
7212426 | Park et al | May 2007 | B2 |
7290203 | Emma et al. | Oct 2007 | B2 |
7292365 | Knox | Nov 2007 | B2 |
7301928 | Nakabayashi et al. | Nov 2007 | B2 |
7315916 | Bennett et al. | Jan 2008 | B2 |
7388781 | Litsyn et al. | Jun 2008 | B2 |
7395404 | Gorobets et al. | Jul 2008 | B2 |
7441067 | Gorobets et al. | Oct 2008 | B2 |
7443729 | Li et al. | Oct 2008 | B2 |
7450425 | Aritome | Nov 2008 | B2 |
7454670 | Kim et al. | Nov 2008 | B2 |
7466575 | Shalvi et al. | Dec 2008 | B2 |
7533328 | Alrod et al. | May 2009 | B2 |
7558109 | Brandman et al. | Jul 2009 | B2 |
7593263 | Sokolov et al. | Sep 2009 | B2 |
7610433 | Randell et al. | Oct 2009 | B2 |
7613043 | Cornwell et al. | Nov 2009 | B2 |
7619922 | Li et al. | Nov 2009 | B2 |
7697326 | Sommer et al. | Apr 2010 | B2 |
7706182 | Shalvi et al. | Apr 2010 | B2 |
7716538 | Gonzalez et al. | May 2010 | B2 |
7804718 | Kim | Sep 2010 | B2 |
7805663 | Brandman et al. | Sep 2010 | B2 |
7805664 | Yang et al. | Sep 2010 | B1 |
7844877 | Litsyn et al. | Nov 2010 | B2 |
7911848 | Eun et al. | Mar 2011 | B2 |
7961797 | Yang et al. | Jun 2011 | B1 |
7975192 | Sommer et al. | Jul 2011 | B2 |
8020073 | Emma et al. | Sep 2011 | B2 |
8108590 | Chow et al. | Jan 2012 | B2 |
8122328 | Liu et al. | Feb 2012 | B2 |
8159881 | Yang | Apr 2012 | B2 |
8190961 | Yang et al. | May 2012 | B1 |
8250324 | Haas et al. | Aug 2012 | B2 |
8300823 | Bojinov et al. | Oct 2012 | B2 |
8305812 | Levy et al. | Nov 2012 | B2 |
8327246 | Weingarten et al. | Dec 2012 | B2 |
8407560 | Ordentlich et al. | Mar 2013 | B2 |
8417893 | Khmelnitsky et al. | Apr 2013 | B2 |
8700970 | Steiner et al. | Apr 2014 | B2 |
20010034815 | Dugan et al. | Oct 2001 | A1 |
20020063774 | Hillis et al. | May 2002 | A1 |
20020085419 | Kwon et al. | Jul 2002 | A1 |
20020154769 | Petersen et al. | Oct 2002 | A1 |
20020156988 | Toyama et al. | Oct 2002 | A1 |
20020174156 | Birru et al. | Nov 2002 | A1 |
20030014582 | Nakanishi | Jan 2003 | A1 |
20030065876 | Lasser | Apr 2003 | A1 |
20030101404 | Zhao et al. | May 2003 | A1 |
20030105620 | Bowen | Jun 2003 | A1 |
20030177300 | Lee et al. | Sep 2003 | A1 |
20030192007 | Miller et al. | Oct 2003 | A1 |
20040015771 | Lasser et al. | Jan 2004 | A1 |
20040030971 | Tanaka et al. | Feb 2004 | A1 |
20040059768 | Denk et al. | Mar 2004 | A1 |
20040080985 | Chang et al. | Apr 2004 | A1 |
20040153722 | Lee | Aug 2004 | A1 |
20040153817 | Norman et al. | Aug 2004 | A1 |
20040181735 | Xin | Sep 2004 | A1 |
20040203591 | Lee | Oct 2004 | A1 |
20040210706 | In et al. | Oct 2004 | A1 |
20050013165 | Ban | Jan 2005 | A1 |
20050018482 | Cemea et al. | Jan 2005 | A1 |
20050083735 | Chen et al. | Apr 2005 | A1 |
20050117401 | Chen et al. | Jun 2005 | A1 |
20050120265 | Pline et al. | Jun 2005 | A1 |
20050128811 | Kato et al. | Jun 2005 | A1 |
20050138533 | Le-Bars et al. | Jun 2005 | A1 |
20050144213 | Simkins et al. | Jun 2005 | A1 |
20050144368 | Chung et al. | Jun 2005 | A1 |
20050169057 | Shibata et al. | Aug 2005 | A1 |
20050172179 | Brandenberger et al. | Aug 2005 | A1 |
20050213393 | Lasser | Sep 2005 | A1 |
20050243626 | Ronen | Nov 2005 | A1 |
20060059406 | Micheloni et al. | Mar 2006 | A1 |
20060059409 | Lee | Mar 2006 | A1 |
20060064537 | Oshima | Mar 2006 | A1 |
20060101193 | Murin | May 2006 | A1 |
20060195651 | Estakhri et al. | Aug 2006 | A1 |
20060203587 | Li et al. | Sep 2006 | A1 |
20060221692 | Chen | Oct 2006 | A1 |
20060248434 | Radke et al. | Nov 2006 | A1 |
20060268608 | Noguchi et al. | Nov 2006 | A1 |
20060282411 | Fagin et al. | Dec 2006 | A1 |
20060284244 | Forbes et al. | Dec 2006 | A1 |
20060294312 | Walmsley | Dec 2006 | A1 |
20070025157 | Wan et al. | Feb 2007 | A1 |
20070063180 | Asano et al. | Mar 2007 | A1 |
20070081388 | Joo | Apr 2007 | A1 |
20070098069 | Gordon | May 2007 | A1 |
20070103992 | Sakui et al. | May 2007 | A1 |
20070104004 | So et al. | May 2007 | A1 |
20070109858 | Conley et al. | May 2007 | A1 |
20070124652 | Litsyn et al. | May 2007 | A1 |
20070140006 | Chen et al. | Jun 2007 | A1 |
20070143561 | Gorobets | Jun 2007 | A1 |
20070150694 | Chang et al. | Jun 2007 | A1 |
20070168625 | Cornwell et al. | Jul 2007 | A1 |
20070171714 | Wu et al. | Jul 2007 | A1 |
20070171730 | Ramamoorthy et al. | Jul 2007 | A1 |
20070180346 | Murin | Aug 2007 | A1 |
20070223277 | Tanaka et al. | Sep 2007 | A1 |
20070226582 | Tang et al. | Sep 2007 | A1 |
20070226592 | Radke | Sep 2007 | A1 |
20070228449 | Takano et al. | Oct 2007 | A1 |
20070253249 | Kang et al. | Nov 2007 | A1 |
20070253250 | Shibata et al. | Nov 2007 | A1 |
20070263439 | Cornwell et al. | Nov 2007 | A1 |
20070266291 | Toda et al. | Nov 2007 | A1 |
20070271494 | Gorobets | Nov 2007 | A1 |
20070297226 | Mokhlesi | Dec 2007 | A1 |
20080010581 | Alrod et al. | Jan 2008 | A1 |
20080028014 | Hilt et al. | Jan 2008 | A1 |
20080049497 | Mo | Feb 2008 | A1 |
20080055989 | Lee et al. | Mar 2008 | A1 |
20080082897 | Brandman et al. | Apr 2008 | A1 |
20080092026 | Brandman et al. | Apr 2008 | A1 |
20080104309 | Cheon et al. | May 2008 | A1 |
20080112238 | Kim et al. | May 2008 | A1 |
20080116509 | Harari et al. | May 2008 | A1 |
20080126686 | Sokolov et al. | May 2008 | A1 |
20080127104 | Li et al. | May 2008 | A1 |
20080128790 | Jung | Jun 2008 | A1 |
20080130341 | Shalvi et al. | Jun 2008 | A1 |
20080137413 | Kong et al. | Jun 2008 | A1 |
20080137414 | Park et al. | Jun 2008 | A1 |
20080141043 | Flynn et al. | Jun 2008 | A1 |
20080148115 | Sokolov et al. | Jun 2008 | A1 |
20080158958 | Sokolov et al. | Jul 2008 | A1 |
20080159059 | Moyer | Jul 2008 | A1 |
20080162079 | Astigarraga et al. | Jul 2008 | A1 |
20080168216 | Lee | Jul 2008 | A1 |
20080168320 | Cassuto et al. | Jul 2008 | A1 |
20080181001 | Shalvi | Jul 2008 | A1 |
20080198650 | Shalvi et al. | Aug 2008 | A1 |
20080198652 | Shalvi et al. | Aug 2008 | A1 |
20080201620 | Gollub | Aug 2008 | A1 |
20080209114 | Chow et al. | Aug 2008 | A1 |
20080219050 | Shalvi et al. | Sep 2008 | A1 |
20080225599 | Chae | Sep 2008 | A1 |
20080250195 | Chow et al. | Oct 2008 | A1 |
20080263262 | Sokolov et al. | Oct 2008 | A1 |
20080282106 | Shalvi et al. | Nov 2008 | A1 |
20080285351 | Shlick et al. | Nov 2008 | A1 |
20080301532 | Uchikawa et al. | Dec 2008 | A1 |
20090024905 | Shalvi et al. | Jan 2009 | A1 |
20090027961 | Park et al. | Jan 2009 | A1 |
20090043951 | Shalvi et al. | Feb 2009 | A1 |
20090046507 | Aritome | Feb 2009 | A1 |
20090072303 | Prall et al. | Mar 2009 | A9 |
20090091979 | Shalvi | Apr 2009 | A1 |
20090103358 | Sommer et al. | Apr 2009 | A1 |
20090106485 | Anholt | Apr 2009 | A1 |
20090113275 | Chen et al. | Apr 2009 | A1 |
20090125671 | Flynn | May 2009 | A1 |
20090132755 | Radke | May 2009 | A1 |
20090144598 | Yoon et al. | Jun 2009 | A1 |
20090144600 | Perlmutter et al. | Jun 2009 | A1 |
20090150599 | Bennett | Jun 2009 | A1 |
20090150748 | Egner et al. | Jun 2009 | A1 |
20090157964 | Kasorla et al. | Jun 2009 | A1 |
20090158126 | Perlmutter et al. | Jun 2009 | A1 |
20090168524 | Golov et al. | Jul 2009 | A1 |
20090187803 | Anholt et al. | Jul 2009 | A1 |
20090199074 | Sommer | Aug 2009 | A1 |
20090213653 | Perlmutter et al. | Aug 2009 | A1 |
20090213654 | Perlmutter et al. | Aug 2009 | A1 |
20090228761 | Perlmutter et al. | Sep 2009 | A1 |
20090240872 | Perlmutter et al. | Sep 2009 | A1 |
20090282185 | Van Cauwenbergh | Nov 2009 | A1 |
20090282186 | Mokhlesi et al. | Nov 2009 | A1 |
20090287930 | Nagaraja | Nov 2009 | A1 |
20090300269 | Radke et al. | Dec 2009 | A1 |
20090323942 | Sharon et al. | Dec 2009 | A1 |
20100005270 | Jiang | Jan 2010 | A1 |
20100025811 | Bronner et al. | Feb 2010 | A1 |
20100030944 | Hinz | Feb 2010 | A1 |
20100058146 | Weingarten et al. | Mar 2010 | A1 |
20100064096 | Weingarten et al. | Mar 2010 | A1 |
20100088557 | Weingarten et al. | Apr 2010 | A1 |
20100091535 | Sommer et al. | Apr 2010 | A1 |
20100095186 | Weingarten | Apr 2010 | A1 |
20100110787 | Shalvi et al. | May 2010 | A1 |
20100115376 | Shalvi et al. | May 2010 | A1 |
20100122113 | Weingarten et al. | May 2010 | A1 |
20100124088 | Shalvi et al. | May 2010 | A1 |
20100131580 | Kanter et al. | May 2010 | A1 |
20100131806 | Weingarten et al. | May 2010 | A1 |
20100131809 | Katz | May 2010 | A1 |
20100131826 | Shalvi et al. | May 2010 | A1 |
20100131827 | Sokolov et al. | May 2010 | A1 |
20100131831 | Weingarten et al. | May 2010 | A1 |
20100146191 | Katz | Jun 2010 | A1 |
20100146192 | Weingarten et al. | Jun 2010 | A1 |
20100149881 | Lee et al. | Jun 2010 | A1 |
20100172179 | Gorobets et al. | Jul 2010 | A1 |
20100174853 | Lee et al. | Jul 2010 | A1 |
20100180073 | Weingarten et al. | Jul 2010 | A1 |
20100199149 | Weingarten et al. | Aug 2010 | A1 |
20100211724 | Weingarten | Aug 2010 | A1 |
20100211833 | Weingarten | Aug 2010 | A1 |
20100211856 | Weingarten | Aug 2010 | A1 |
20100241793 | Sugimoto et al. | Sep 2010 | A1 |
20100246265 | Moschiano et al. | Sep 2010 | A1 |
20100251066 | Radke | Sep 2010 | A1 |
20100253555 | Weingarten et al. | Oct 2010 | A1 |
20100257309 | Barsky et al. | Oct 2010 | A1 |
20100269008 | Leggette et al. | Oct 2010 | A1 |
20100293321 | Weingarten | Nov 2010 | A1 |
20100318724 | Yeh | Dec 2010 | A1 |
20110051521 | Levy et al. | Mar 2011 | A1 |
20110055461 | Steiner et al. | Mar 2011 | A1 |
20110093650 | Kwon et al. | Apr 2011 | A1 |
20110096612 | Steiner et al. | Apr 2011 | A1 |
20110099460 | Dusija et al. | Apr 2011 | A1 |
20110119562 | Steiner et al. | May 2011 | A1 |
20110153919 | Sabbag | Jun 2011 | A1 |
20110161775 | Weingarten | Jun 2011 | A1 |
20110194353 | Hwang et al. | Aug 2011 | A1 |
20110209028 | Post et al. | Aug 2011 | A1 |
20110214029 | Steiner et al. | Sep 2011 | A1 |
20110214039 | Steiner et al. | Sep 2011 | A1 |
20110246792 | Weingarten | Oct 2011 | A1 |
20110246852 | Sabbag | Oct 2011 | A1 |
20110252187 | Segal et al. | Oct 2011 | A1 |
20110252188 | Weingarten | Oct 2011 | A1 |
20110271043 | Segal et al. | Nov 2011 | A1 |
20110302428 | Weingarten | Dec 2011 | A1 |
20120001778 | Steiner et al. | Jan 2012 | A1 |
20120005554 | Steiner et al. | Jan 2012 | A1 |
20120005558 | Steiner et al. | Jan 2012 | A1 |
20120005560 | Steiner et al. | Jan 2012 | A1 |
20120008401 | Katz et al. | Jan 2012 | A1 |
20120008414 | Katz et al. | Jan 2012 | A1 |
20120017136 | Ordentlich et al. | Jan 2012 | A1 |
20120051144 | Weingarten et al. | Mar 2012 | A1 |
20120063227 | Weingarten et al. | Mar 2012 | A1 |
20120066441 | Weingarten | Mar 2012 | A1 |
20120110250 | Sabbag et al. | May 2012 | A1 |
20120124273 | Goss et al. | May 2012 | A1 |
20120246391 | Meir et al. | Sep 2012 | A1 |
Number | Date | Country |
---|---|---|
WO2009053963 | Apr 2009 | WO |
Entry |
---|
Search Report of PCT Patent Application WO 2009/118720 A3. |
Search Report of PCT Patent Application WO 2009/095902 A3. |
Search Report of PCT Patent Application WO 2009/078006 A3. |
Search Report of PCT Patent Application WO 2009/074979 A3. |
Search Report of PCT Patent Application WO 2009/074978 A3. |
Search Report of PCT Patent Application WO 2009/072105 A3. |
Search Report of PCT Patent Application WO 2009/072104 A3. |
Search Report of PCT Patent Application WO 2009/072103 A3. |
Search Report of PCT Patent Application WO 2009/072102 A3. |
Search Report of PCT Patent Application WO 2009/072101 A3. |
Search Report of PCT Patent Application WO 2009/072100 A3. |
Search Report of PCT Patent Application WO 2009/053963 A3. |
Search Report of PCT Patent Application WO 2009/053962 A3. |
Search Report of PCT Patent Application WO 2009/053961 A3. |
Search Report of PCT Patent Application WO 2009/037697 A3. |
Yani Chen, Kcshab K. Parhi, “Small Area Parallel Chien Search Architectures for Long BCH Codes”, IEEE Transactions on Very Large Scale Integration(VLSI) Systems, vol. 12, No. 5, May 2004. |
Yuejian Wu, “Low Power Decoding of BCH Codes”, Nortel Networks, Ottawa, Ont., Canada, in Circuits and systems, 2004. ISCAS '04. Proceeding of the 2004 International Symposium on Circuits and Systems, published May 23-26, 2004, vol. 2, pp. II-369-II-372 vol. 2. |
Michael Purser, “Introduction to Error Correcting Codes”, Artech House Inc., 1995. |
Ron M. Roth, “Introduction to Coding Theory”, Cambridge University Press, 2006. |
Akash Kumar, Sergei Sawitzki, “High-Throughput and Low Power Architectures for Reed Solomon Decoder”, (a.kumar at tue.nl, Eindhoven University of Technology and sergei.sawitzki at philips.com). |
Todd K.Moon, “Error Correction Coding Mathematical Methods and Algorithms”, A John Wiley & Sons, Inc., 2005. |
Richard E. Blahut, “Algebraic Codes for Data Transmission”, Cambridge University Press, 2003. |
David Esseni, Bruno Ricco, “Trading-Off Programming Speed and Current Absorption in Flash Memories with the Ramped-Gate Programming Technique”, IEEE Transactions on Electron Devices, vol. 47, No. 4, Apr. 2000. |
Giovanni Campardo, Rino Micheloni, David Novosel, “VLSI-Design of Non-Volatile Memories”, Springer Berlin Heidelberg New York, 2005. |
John G. Proakis, “Digital Communications”, 3rd ed., New York: McGraw-Hill, 1995. |
J.M. Portal, H. Aziza, D. Nee, “EEPROM Memory: Threshold Voltage Built in Self Diagnosis”, ITC International Test Conference, Paper 2.1. |
J.M. Portal, H. Aziza, D. Nee, “EEPROM Diagnosis Based on Threshold Voltage Embedded Measurement”, Journal of Electronic Testing: Theory and Applications 21, 33-42, 2005. |
G. Tao, A. Scarpa, J. Dijkstra, W. Stidl, F. Kuper, “Data retention prediction for modern floating gate non-volatile memories”, Microelectronics Reliability 40 (2000), 1561-1566. |
T. Hirncno, N. Matsukawa, H. Hazama, K. Sakui, M. Oshikiri, K. Masuda, K. Kanda, Y. Itoh, J. Miyamoto, “A New Technique for Measuring Threshold Voltage Distribution in Flash EEPROM Devices”, Proc. IEEE 1995 Int. Conference on Microelectronics Test Structures, vol. 8, Mar. 1995. |
Boaz Eitan, Guy Cohen, Assaf Shappir, Eli Lusky, Amichai Givant, Meir Janai, Ilan Bloom, Yan Polansky, Oleg Dadashev, Avi Lavan, Ran Sahar, Eduardo Maayan, “4-bit Cell NROM reliability”, Appears on the website of Saifun.com. |
Paulo Cappelletti, Clara Golla, Piero Olivo, Enrico Zanoni, “Flash Memories”, Kluwer Academic Publishers, 1999. |
JEDEC Standard, “Stress-Test-Driven Qualification of Integrated Circuits”, JEDEC Solid State Technology Association. JEDEC Standard No. 47F pp. 1-26. |
Dempster, et al., “Maximum Likelihood from Incomplete Data via the EM Algorithm”, Journal of the Royal Statistical Society. Series B (Methodological), vol. 39, No. 1 (1997), pp. 1-38. |
Mielke, et al., “Flash EEPROM Threshold Instabilities due to Charge Trapping During Program/Erase Cycling”, IEEE Transactions on Device and Materials Reliability, vol. 4, No. 3, Sep. 2004, pp. 335-344. |
Daneshbeh, “Bit Serial Systolic Architectures for Multiplicative Inversion and Division over GF (2)”, A thesis presented to the University of Waterloo, Ontario, Canada, 2005, pp. 1-118. |
Chen, Formulas for the solutions of Quadratic Equations over GF (2), IEEE Trans. Inform. Theory, vol. IT-28, No. 5, Sep. 1982, pp. 792-794. |
Berlekamp et al., “On the Solution of Algebraic Equations over Finite Fields”, Inform. Cont. 10, Oct. 1967, pp. 553-564. |
Number | Date | Country | |
---|---|---|---|
20100253555 A1 | Oct 2010 | US |
Number | Date | Country | |
---|---|---|---|
61166834 | Apr 2009 | US |