Various embodiments of the present invention provide systems and methods for error recovery in a decoder including refreshing the decoder input and rerunning.
Various data processing systems have been developed including storage systems, cellular telephone systems, and radio transmission systems. In such systems data is transferred from a sender to a receiver via some medium. For example, in a storage system, data is sent from a sender (i.e., a write function) to a receiver (i.e., a read function) via a storage medium. As information is stored and transmitted in the form of digital data, errors can be introduced that, if not corrected, can corrupt the data and render the information unusable. The effectiveness of any transfer is impacted by any losses in data caused by various factors. Many types of error checking systems have been developed to detect and correct errors in digital data. For example, parity bits can be added to groups of data bits, ensuring that the groups of data bits (including the parity bits) have either even or odd numbers of ones. The parity bits may be used in error correction systems, including in Low Density Parity Check (LDPC) decoders. When errors are not corrected with normal error correction procedures, recovery features may be needed to correct stubborn errors.
Various embodiments of the present invention provide systems and methods for error recovery in a decoder including refreshing the decoder input and rerunning.
In some embodiments, a data processing system includes a likelihood input operable to receive encoded data, a decoder operable to apply a decoding algorithm to likelihood values for the received encoded data and to yield a decoded output, and a decoder input initialization circuit operable to generate new decoder input values based in part on the likelihood values for the received encoded data after the likelihood values for the received encoded data have failed to converge in the decoder.
This summary provides only a general outline of some embodiments of the invention. The phrases “in one embodiment,” “according to one embodiment,” “in various embodiments”, “in one or more embodiments”, “in particular embodiments” and the like generally mean the particular feature, structure, or characteristic following the phrase is included in at least one embodiment of the present invention, and may be included in more than one embodiment of the present invention. Importantly, such phrases do not necessarily refer to the same embodiment. This summary provides only a general outline of some embodiments of the invention. Additional embodiments are disclosed in the following detailed description, the appended claims and the accompanying drawings.
A further understanding of the various embodiments of the present invention may be realized by reference to the figures which are described in remaining portions of the specification. In the figures, like reference numerals may be used throughout several drawings to refer to similar components. In the figures, like reference numerals are used throughout several figures to refer to similar components.
Embodiments of the present invention are related to decoder error recovery, wherein after an initial decoding operation fails to correctly decode encoded data, one or more subsequent decoding runs are performed. If the decoder does not converge during the initial decoding operation, the decoder input is refreshed or initialized to a different initial state and at least one additional decoding run is performed. In some embodiments, multiple decoding runs are performed and the output of each run is aggregated with the aggregate used to generate a new initial decoder input. The refresh, run, aggregate recovery disclosed herein can be used with any suitable decoder, including, but not limited to, message-passing decoders such as low density parity check decoders.
Error floor is a phenomenon that stems from the interaction of the low density parity check code graph and the message passing decoder. Error floor is an abrupt drop in slope in the uncorrectable bit error rate (LIBER) curve or codeword failure rate (CWER) curve at medium-high and high signal to noise ratios (SNR). Such a change in slope can be attributed to trapping sets in the low density parity check code graph and the underlying decoder algorithm which result in an abrupt flattening in the uncorrectable bit error rate curve.
Such an abrupt flattening in the uncorrectable bit error rate curve is undesirable, particularly in flash memory systems designed to achieve an uncorrectable bit error rate as low as 1e−16. Each time data from a memory or transmission system fails to converge in a decoder, a recovery procedure is triggered, which can include soft reads, additional decoding iterations, etc., designed and ordered to effect decoder convergence with minimum latency. A high error floor results in frequent triggering of the recovery procedure which adds to the latency of the data processing system and is therefore undesirable. The refresh, run, aggregate decoder recovery disclosed herein addresses issues arising from trapping sets and reduces latency and enhances performance of the overall data processing system.
Decoder technology is applicable to transmission of information over virtually any channel or storage of information on virtually any media. Transmission applications include, but are not limited to, optical fiber, radio frequency channels, wired or wireless local area networks, digital subscriber line technologies, wireless cellular, Ethernet over any medium such as copper or optical fiber, cable channels such as cable television, and Earth-satellite communications. Storage applications include, but are not limited to, hard disk drives, compact disks, digital video disks, magnetic tapes and memory devices such as DRAM, NAND flash, NOR flash, other non-volatile memories and solid state drives.
Turning to
Turning to
In a typical read operation, read/write head assembly 220 is accurately positioned by motor controller 212 over a desired data track on disk platter 216. Motor controller 212 both positions read/write head assembly 220 in relation to disk platter 216 and drives spindle motor 214 by moving read/write head assembly 220 to the proper data track on disk platter 216 under the direction of hard disk controller 210. Spindle motor 214 spins disk platter 216 at a determined spin rate (RPMs). Once read/write head assembly 220 is positioned adjacent the proper data track, magnetic signals representing data on disk platter 216 are sensed by read/write head assembly 220 as disk platter 216 is rotated by spindle motor 214. The sensed magnetic signals are provided as a continuous, minute analog signal representative of the magnetic data on disk platter 216. This minute analog signal is transferred from read/write head assembly 220 to read channel circuit 202 via preamplifier 204. Preamplifier 204 is operable to amplify the minute analog signals accessed from disk platter 216. In turn, read channel circuit 202 digitizes and decodes the received analog signal, and performs refresh, run, aggregate decoder recovery where data fails to converge to recreate the information originally written to disk platter 216. This data is provided as read data 222 to a receiving circuit. A write operation is substantially the opposite of the preceding read operation with write data 224 being provided to read channel circuit 202. This data is then encoded and written to disk platter 216.
It should be noted that in some embodiments storage system 200 is integrated into a larger storage system such as, for example, a RAID (redundant array of inexpensive disks or redundant array of independent disks) based storage system. Such a RAID storage system increases stability and reliability through redundancy, combining multiple disks as a logical unit. Data can be spread across a number of disks included in the RAID storage system according to a variety of algorithms and accessed by an operating system as if it were a single disk. For example, data can be mirrored to multiple disks in the RAID storage system, or can be sliced and distributed across multiple disks in a number of techniques. If a small number of disks in the RAID storage system fail or become unavailable, error correction techniques can be used to recreate the missing data based on the remaining portions of the data from the other disks in the RAID storage system. The disks in the RAID storage system can be, but are not limited to, individual storage systems such storage system 200, and can be located in close proximity to each other or distributed more widely for increased security. In a write operation, write data is provided to a controller, which stores the write data across the disks, for example by mirroring or by striping the write data. In a read operation, the controller retrieves the data from the disks. The controller then yields the resulting read data as if the RAID storage system were a single disk.
In addition, it should be noted that in some embodiments storage system 200 is modified to include solid state memory that is used to store data in addition to the storage offered by disk platter 216. This solid state memory may be used in parallel to disk platter 216 to provide additional storage. In such a case, the solid state memory receives and provides information directly to read channel circuit 202. Alternatively, the solid state memory may be used as a cache where it offers faster access time than that offered by disk platter 216. In such a case, the solid state memory may be disposed between interface controller 206 and read channel circuit 202 where it operates as a pass through to disk platter 216 when requested data is not available in the solid state memory or when the solid state memory does not have sufficient storage to hold a newly written data set. Based upon the disclosure provided herein, one of ordinary skill in the art will recognize a variety of storage systems including both disk platter 216 and a solid state memory.
Turning to
The refresh, run, aggregate decoder recovery refreshes the decoder input to a different state than in a previous decoding run, then re-runs the decoder with the refreshed input. By running from a different initial state, the decoder can avoid trapping sets that caused the previous failure to converge. Several embodiments are disclosed herein for refreshing the decoder input to different states. In some embodiments, the decoder input comprises log likelihood values, which give the probability or likelihood for each value in a set of possible values for a particular bit or symbol that the bit or symbol has that value. The refresh operation in some embodiments alters the log likelihood ratio values in the decoder input, for example by dampening the log likelihood ratio values. A fresh set of decoding iterations are then run based on the refreshed decoder input.
In a message passing decoder, messages are passed back and forth between variable nodes and check nodes, updating the perceived value of variable nodes based on check node calculations, and performing parity check calculations based on the updated variable node values in an iterative manner. With different initial log likelihood ratio values in the decoder input, the variable node updates and check node calculations can arrive at different results and avoid trapping sets. For example, by dampening the log likelihood ratios before re-decoding, the confidence in the data values expressed by the log likelihood ratios is reduced, making it easier for the decoder to change those data values during decoding. This makes it less likely that an incorrect value in a trapping set will be stuck and unchangeable in the decoder because of a high initial confidence value. Furthermore, with a different initial state, trapping sets or local minima may be avoided, improving the probability of landing on the global minima of the cost function associated with the code. For a given initial state, the decoder traverses a specific path on the surface of the cost function, defined by the underlying message-passing algorithm. If one path from the initial state lands on a trapping set, refreshing the decoder input to a different and intelligently selected initial state will help the decoder traverse a different path that avoids the trapping set to converge to the correct codeword, i.e., one of the global minima.
The log likelihood ratios in the decoder input can be obtained in any suitable manner. In some embodiments based on a solid state flash memory, multiple reads with different cell reference voltages can be performed to generate log likelihood ratios. Turning to
The hard decisions of read operations can be converted into soft decisions (log likelihood ratio values) by performing multiple reads with different reference voltages based on the knowledge of the channel. Hard decision states can be divided into a number of soft decision states, and read data from those soft decision states is mapped to log likelihood ratios 414 in decision circuit 412 based on the likelihoods for each soft decision state that a bit in those states is correct.
In some other embodiments based on a magnetic hard drive, log likelihood ratio values can be generated by a soft output data detector such as, but not limited to, a Viterbi algorithm detector. Again, the refresh, run, aggregate decoder recovery is not limited to use in any particular application, and the decoder input can be obtained in any suitable manner and in any format that enables the initial state to be manipulated.
The following definitions apply to some embodiments using a fixed-point message-passing decoder using a variety of min-sum based decoding algorithm. However, refresh, run, aggregate decoder recovery is not limited to this particular application. Let c be a codeword (vector) transmitted over a flash channel or retrieved from another suitable source, r be the vector read out of the flash media or other storage or transmission medium, ĉ be an estimate of the decoder and a codeword but not necessarily c, {circumflex over (d)} be the output of the message-passing decoder after a fixed number of iterations and it need not be a codeword. Let Λ(.) be a log-likelihood ratio assignment function defined as follows:
Decoder states are defined as follows:
Assume that Λ(r) is the log likelihood ratio of the received vector and is the input to the soft decision decoder. Note that Λ(r) can be assigned after one or multiple reads of a flash page, or obtained from any other suitable source. After n iterations, limited to some maximum number, the decoder may converge to ĉ or not (yielding {circumflex over (d)}). If the decoder has converged then no recovery process is needed. The refresh, run, aggregate decoder recovery is initiated when an instance of Λ(r) fails to converge. The recovery process is comprised of the three following steps in some embodiments and the three steps are repeated iteratively until the decoder converges or an exit condition is met. A single round of the recovery process involves a single run of all three steps in some embodiments, where m is the current round.
Refreshing the decoder input involves initializing the decoder to a new and distinct start state. In some embodiments, the decoder input is refreshed according to one or more of the following:
In Refresh 1.1, the sign of each bit or symbol in the decoder input is retained from the log likelihood ratio vector r read from the storage medium or received from the transmission medium. The magnitude of bits or symbols in the decoder input is replaced by a value λ and the decoder is run with the refreshed decoder input. The value λ, begins at a preselected one of the possible log likelihood ratio values, generally at a value less than the greatest likelihood value. At each failure to converge, the value λ is decremented, indicating a lower confidence that the initial value (i.e., the initial sign in a binary decoder, or the initial Galois Field elements in a non-binary decoder) is correct. This lowered confidence makes it easier for the decoder to change values during decoding and take a different path across the cost function. The Refresh 1.1 algorithm can be continued until the λ reaches a value below which it cannot be reduced (e.g., 1, to avoid a 0 no confidence log likelihood ratio). The magnitude replacement by λ is performed in some embodiments uniformly for all bits or symbols in the decoder input. In other embodiments, the magnitude replacement by λ is performed for selected bits or symbols in the decoder input.
In Refresh 1.2, the log likelihood ratios Λ(r) of the received vector are scaled by a positive scaling factor α which is a positive scaling factor which takes a value less than 1. The scaling factor is reduced over decoding rounds, dampening the input log likelihood ratio values at the decoder input. The scaling by α is performed in some embodiments uniformly for all bits or symbols in the decoder input. In other embodiments, the scaling by α is performed for selected bits or symbols in the decoder input.
In Refresh 1.3, the dampening of Refresh 1.2 is applied to the end state ΛEnd,m-1(D) of the decoder from the previous round. In some embodiments, the log likelihood ratios in the soft decoder output from the previous decoding iteration are scaled and used as the decoder input. In some embodiments, all bits or symbols in the decoder input are taken from the previous round decoder output and scaled. In some other embodiments, a combination of channel input values and previous round decoder output are used in the decoder input. In some embodiments, only some of the bits or symbols in the decoder input are scaled.
In Refresh 1.4, the sign values sign(ΛEnd,m-1(D)) for the bits or symbols in the decoder input are taken from the previous round decoder output, and the magnitude values are replaced by a value λ, as in Refresh 1.1, where the value of λ is distinct for each round of the recovery operation.
In Refresh 1.5, the log likelihood ratios ΛAggregatȩm-1(D) used as the decoder input are computed using an aggregation function based on previous round decoder outputs. The computed log likelihood ratios ΛAggregatȩm-1(D) are scaled by a positive scaling factor α which is a positive scaling factor which takes a value less than 1, as in Refresh 1.2.
In some embodiments, the decoder input is refreshed using a single one of the refresh algorithms until the decoder converges or until the selected refresh algorithm has been completed without convergence, at which point another refresh algorithm can be selected. For example, if the technique of Refresh 1.1. is selected, replacing log likelihood ratio values at the decoder input by a value λ, then as long as the decoder fails to converge and the limit on total iterations or total latency has not been reached, decoding iterations will continue based on Refresh 1.1. At the start of each decoding iteration, log likelihood ratio values at the decoder input will be replaced by a different value λ, with λ decreasing at each refresh, until λ reaches a value below which it cannot be reduced (e.g., 1). If the decoder has failed to converge while exhausting the choices of start state using Refresh 1.1, then another refresh algorithm is selected, such as Refresh 1.2, 1.3, 1.4 or 1.5.
Each time the decoder input is refreshed, the run phase is initiated. In this phase, the decoder is re-started with input Λstart(D) and run for no more than a fixed number of maximum iterations. If the decoder converges, i.e., ΛEnd(D)=ĉ, then an exit condition has been reached and the recovery process is terminated. The decoded output can then be yielded from the decoder, such as, but not limited to, decoder hard decisions. If the decoder fails to converge, then the decoding is terminated after performing the specified maximum iterations with output ΛEnd(D).
In some embodiments, the decoder input is refreshed based on an aggregate of previous decoder outputs. In these embodiments, the soft decoder outputs ΛEnd(D) from the m-th round are stored in an aggregated matrix as shown below:
Λm=[Λ1End(D),Λ2End(D),Λ3End(D), . . . ΛmEnd(D)],
where each vector is a column vector and forms a matrix of size (code-length×m). From this matrix, a vector ΛAggregatȩm(D) is computed by post-processing the aggregate matrix. In some embodiments, the post-processor is implemented as follows:
ΛAggregatȩm=E[Λ1End(D),Λ2End(D),Λ3End(D), . . . ΛmEnd(D)]),
where E(.) is the expectation or averaging function operating across columns, i.e., averages entries along the first row to output expected log likelihood ratios for the first variable node. In some other embodiments, a simple majority-logic approach is taken to computing ΛAggregatȩm(D), which may be used in the Refresh step of the next round. Simple majority logic will choose a bit value, say for the first variable node, that a majority of the m runs had reported. Any other aggregation function may be used to compute a vector ΛAggregatȩm(D) based on previous decoder outputs. Based upon the disclosure provided herein, one of ordinary skill in the art will recognize a variety of aggregation functions that may be used to calculate vector ΛAggregatȩm(D).
In some embodiments, natural exit conditions exist. For example, in Refresh 1.1, the possible values of λ will be exhausted at some point as λ is decremented for each successive decoding round if the decoder fails to converge, and when λ reaches 0, a natural exit condition has been reached. Similarly, Refresh 1.2 will have a limited number of scaling factors a, based on the granularity of a and the highest and lowest value of α. Refresh 1.3 and Refresh 1.4 also have natural exit conditions. The total number of possible maximum iterations in these embodiments is governed by the size of sample sets of λ and α.
Aggregate-based Refresh 1.5 may not have an obvious exit condition in some embodiments. With each decoding run a new ΛAggregatȩm(D) is computed and this can be used to initialize the decoder. In some embodiments, the exit condition is defined as a too-small difference between ΛAggregatȩm-1(D) from round (m−1) and ΛAggregatȩm(D) from round m. In other words, if the difference between the computed aggregate is less than a threshold, the refresh process is terminated. The difference between the two vectors can be determined in any suitable manner, such as, but not limited to, the number of elements in the vector that differ by at least a specified amount.
Finally, the decoder recovery terminates once the decoder converges or in consideration of termination requirements, such as time bounds. According to various embodiments, the termination requirements include one or more of: a maximum number M of allowable rounds is reached; a maximum total number of iterations is used; and a maximum (real-time) latency elapses.
In some embodiments, side information is used in the design, selection and ordering of refresh algorithms. The term “side information” is used herein to refer to knowledge about the low density parity check code or other code structure, the underlying low density parity check code graph, the message-passing decoder, and the decoder progression. The side information can be used, for example, to perform selective scaling or dampening of log likelihood ratios during the refresh process. Side information can include one or more of the following or other pieces of information:
Sample sets of λ and a in Refresh step can be effectively populated and ordered with column weight and log likelihood ratio message-width information. For instance, with a 5-bit (4-bit+1 sign bit) fixed-point decoder on a low density parity check graph with column-weight 3, |λ|=5 is used in some embodiments for Refresh 1.1 and Refresh 1.4, and α=⅓ is used in some embodiments for Refresh 1.2 and Refresh 1.3.
When a list of small trapping sets is not available but the list of unsatisfied checks is available, variable nodes connected to larger number of unsatisfied checks are dampened or scaled in some embodiments.
Although storing a list of small trapping sets increases memory cost, a significant cost reduction can be achieved by exploiting symmetries or isomorphisms within the code graph. The knowledge of the unsatisfied checks and neighboring variable nodes can be considered in conjunction with the list of small trapping sets to select a subset of variable nodes that are likely to be in error. These select variable nodes are subjected to aggressive scaling with a and dampening with λ in the Refresh step in some embodiments.
Turning now to
Where the decoder 514 fails to converge on the refreshed decoder input 512, the decoder input initialization circuit 510 again refreshes the decoder input 512, staying within the same refresh scheme in some embodiments until it is exhausted before moving to another refresh scheme. In some refresh schemes, decoder input initialization circuit 510 computes refreshed decoder input 512 based on the decoder state 516 from the previous run, such as the log likelihood ratio values resulting from the decoder run. Where the refreshed decoder input 512 converges in decoder 514, the recovery operation is complete and hard decisions 520 or other suitable output is provided by decoder 514.
Decoder 514 can be any suitable message-passing decoder, such as, but not limited to, a low density parity check decoder.
Turning now to
The decoder input initialization circuit 610 is operable to refresh the decoder input during decoder recovery, after the log likelihood ratios Λ(r) from likelihood input 602 for vector r, or after previous refreshed decoder input 612 have failed to converge in the decoder 614. The decoder input initialization circuit 610 is operable in various embodiments to apply refresh algorithm Refresh 1.5 based on aggregate vector ΛAggregatȩm(D) 626. The decoder input initialization circuit 610 provides refreshed decoder input 612 to decoder 614 and initiates a decoder run in decoder 614.
Where the decoder 614 fails to converge on the refreshed decoder input 612, the soft decoder outputs ΛEnd(D) 622 is provided to decoder output aggregation circuit 624 and a new aggregate vector ΛAggregatȩm(D) 626 is computed. The decoder input initialization circuit 610 again refreshes the decoder input 612 and triggers another decoder run, until the decoder 614 converges or an exit condition is reached. Where the refreshed decoder input 612 converges in decoder 614, the recovery operation is complete and hard decisions 620 or other suitable output is provided by decoder 614.
In some embodiments, decoder input initialization circuit 610 also implements one or more of refresh algorithms Refresh 1.1, Refresh 1.2, Refresh 1.3, and/or Refresh 1.4, with decoder output aggregation circuit 624 aggregating some or all of the results for use in a later refresh algorithm Refresh 1.5.
The decoder input initialization circuit 610 can include any suitable circuitry to implement one or more of refresh algorithms Refresh 1.1, Refresh 1.2, Refresh 1.3, Refresh 1.4 and/or Refresh 1.5, such as, but not limited to, counters or registers to maintain values of λ and/or a, multiplexers or other selection or combination circuits to replace log likelihood ratios, multipliers to apply scaling factors, etc. Based upon the disclosure provided herein, one of ordinary skill in the art will recognize a variety of circuitry that may be included as part of decoder input initialization circuit 610 to implement one or more of refresh algorithms Refresh 1.1, Refresh 1.2, Refresh 1.3, Refresh 1.4 and/or Refresh 1.5. The decoder output aggregation circuit 624 can include any suitable circuitry to aggregate soft decoder outputs ΛEnd(D) 622 and from these, to compute an aggregate vector ΛAggregatȩm(D) 626, such as, but not limited to, a buffer or memory and average calculation circuit or comparators and selection circuits.
Turning to
Following flow diagram 700, input data is received. (Block 702) The input data can comprise log likelihood ratios Λ(r) for a vector r that is read from flash media or other another storage or transmission medium. Based upon the disclosure provided herein, one of ordinary skill in the art will recognize a variety of sources of the input data. The input data is decoded. (Block 704) The input data can be decoded using any message-passing decoding algorithm, such as, but not limited to, a low density parity check decoding algorithm. If the decoding succeeded or converged (Block 706), the decoded data is output. (Block 710) If, however, the decoding failed (Block 706), a recovery process is implemented.
A log likelihood ratio replacement value λ is initialized at a start value. (Block 712) The start value of the log likelihood ratio replacement value λ can be any suitable value selected from among the possible likelihood values, generally something less than the highest likelihood. The log likelihood ratio decoder input is initialized based on log likelihood ratio replacement value λ. (Block 714) In some embodiments, implementing Refresh 1.1, the sign values used in the initialized decoder input are obtained from the log likelihood ratios Λ(r) for channel vector r. In some embodiments, implementing Refresh 1.4, the sign values used in the initialized decoder input are obtained from the log likelihood ratios ΛEnd(D) in the end state or soft decoder output of a previous run of the decoder. Notably, in some cases, the log likelihood ratios ΛEnd(D) do not include the parity bits. In these cases, the sign values used for parity bits in the initialized decoder input are derived from the log likelihood ratios Λ(r) for channel vector r, while the sign values used for user data bits in the initialized decoder input are derived from the log likelihood ratios ΛEnd(D) in the end state or soft decoder output of a previous run of the decoder.
The initialized decoder input is decoded. (Block 716) Again, any message-passing decoder algorithm can be applied, such as, but not limited to, a min-sum based low density parity check decoding algorithm. If the decoding of the initialized decoder input succeeded or converged (Block 720), the decoded data is output. (Block 722) If, however, the decoding failed (Block 720), the recovery process continues. The log likelihood ratio replacement value λ is decremented. (Block 724) If the log likelihood ratio replacement value λ is 0 (Block 726), this particular Refresh scheme has been exhausted and the recovery process is terminated. (Block 730) If the likelihood ratio replacement value λ is greater than 0 (Block 726), the recovery process continues at Block 714.
In some embodiments, after the log likelihood ratio replacement value λ reaches 0, non-linear or non-uniform dampening is performed. Non-linear dampening is an instance of selective dampening based on side information about the symmetries or isomorphisms in the low density parity check code graph. In some embodiments, for example, nodes within a circulant of a low density parity check matrix follow a log likelihood ratio profile and this profile is preserved across all circulants in the code. The log likelihood ratio profile is generated by uniform random dampening. In some other embodiments, nodes within a circulant are dampened by the same amount that is randomly selected, with a different dampening factor selected for each circulant.
In some embodiments, the method for refreshing decoder input during recovery of flow diagram 700 is modified to perform selective dampening with side information. It is assumed that lists of variable nodes connected to unsatisfied parity check nodes are available from the previous run of the decoder, with a separate lists for variable nodes connected to 1 unsatisfied parity check node and for variable nodes connected to 2 unsatisfied parity check nodes. The log likelihood ratios for the variable nodes connected to 2 unsatisfied parity check nodes are dampened more aggressively than log likelihood ratios for the variable nodes connected to 1 unsatisfied parity check node. Other log likelihood ratios are left undampened.
Turning to
Following flow diagram 800, input data is received. (Block 802) The input data can comprise log likelihood ratios Λ(r) for a vector r that is read from flash media or other another storage or transmission medium. Based upon the disclosure provided herein, one of ordinary skill in the art will recognize a variety of sources of the input data. The input data is decoded. (Block 804) The input data can be decoded using any message-passing decoding algorithm, such as, but not limited to, a low density parity check decoding algorithm. If the decoding succeeded or converged (Block 806), the decoded data is output. (Block 810) If, however, the decoding failed (Block 806), a recovery process is implemented.
A log likelihood ratio scaling value a is initialized at a start value. (Block 812) The start value of the log likelihood ratio scaling value a is a positive scaling factor and takes a value less than 1, such as, but not limited to, ⅓. The log likelihood ratio decoder input is initialized based on log likelihood ratio scaling value a. (Block 814) The initial log likelihood ratio values are scaled by scaling value a. In some embodiments, implementing Refresh 1.2, the sign values and initial log likelihood ratio values used in the initialized decoder input are obtained from the log likelihood ratios Λ(r) for channel vector r. In some embodiments, implementing Refresh 1.3, the sign values and initial log likelihood ratio values used in the initialized decoder input are obtained from the log likelihood ratios ΛEnd(D) in the end state or soft decoder output of a previous run of the decoder. Notably, in some cases, the log likelihood ratios ΛEnd(D) do not include the parity bits. In these cases, the sign values used for parity bits in the initialized decoder input are derived from the log likelihood ratios Λ(r) for channel vector r, while the sign values used for user data bits in the initialized decoder input are derived from the log likelihood ratios ΛEnd(D) in the end state or soft decoder output of a previous run of the decoder.
The initialized decoder input is decoded. (Block 816) Again, any message-passing decoder algorithm can be applied, such as, but not limited to, a min-sum based low density parity check decoding algorithm. If the decoding of the initialized decoder input succeeded or converged (Block 820), the decoded data is output. (Block 822) If, however, the decoding failed (Block 820), the recovery process continues. The log likelihood ratio scaling value a is reduced. (Block 824) In some embodiments, the scaling value a is reduced by a predetermined, fixed amount, for example by subtracting a fixed fraction from the previous value of the scaling value a. If the log likelihood ratio scaling value a is 0 (Block 826), this particular Refresh scheme has been exhausted and the recovery process is terminated. (Block 830) If the likelihood ratio scaling value a is greater than 0 (Block 826), the recovery process continues at Block 814.
Turning to
The decoder soft output is stored as the decoder end state. (Block 912) An aggregate decoder end state is calculated. (Block 914) The aggregate decoder end state ΛAggregatȩm(D), is calculated in some embodiments using an averaging function operating across columns, i.e., averaging entries along the first row of the parity check matrix to output expected log likelihood ratios for the first variable node. In some other embodiments, a simple majority-logic approach is taken to computing the aggregate decoder end state by choosing a bit value, say for the first variable node, that a majority of the m runs had reported. Any other aggregation function may be used to compute the aggregate decoder end state based on previous decoder outputs.
The log likelihood ratio decoder input is initialized based on the aggregate decoder end state. (Block 916) The log likelihood ratio decoder input can be derived from the aggregate decoder end state in any suitable fashion, for example using the aggregate decoder end state as the initial value and performing log likelihood ratio replacement or scaling according to Refresh 1.1, Refresh 1.2, Refresh 1.3 or Refresh 1.4.
The initialized decoder input is decoded. (Block 920) Again, any message-passing decoder algorithm can be applied, such as, but not limited to, a min-sum based low density parity check decoding algorithm. If the decoding of the initialized decoder input succeeded or converged (Block 922), the decoded data is output. (Block 924) If, however, the decoding failed (Block 922), the recovery process continues. The decoder soft output is stored as the decoder end state. (Block 926) An aggregate decoder end state is calculated. (Block 930) It is determined whether an end condition has been reached. (Block 932) For example, if the change in the aggregate decoder end state was less than a threshold value, the end condition can be determined to have been reached. If the end condition has been reached (Block 932), the recovery process is terminated. (Block 934) Otherwise, the recovery process continues at Block 916.
Turning to
Turning to
Turning to
The log likelihood ratio magnitudes of the bits in {UB0} are mapped to ±λ, where λ is a dampening value or factor that is initialized at a particular value, such as, but not limited to, 6. The signs of the bits that determine the ±state or polarity of the log likelihood ratios are taken in some embodiments from the initial channel values, and in some other embodiments from the decoder output from a previous decoding. The log likelihood ratio magnitudes of the bits in {UB1} are mapped to ±Max(λ−1,1), or in other words, to ±(λ−1) or 1, whichever is greater. The log likelihood ratio magnitudes of the bits in {UB2} are mapped to ±Max(λ−2,1), or in other words, to ±(λ−2) or 1, whichever is greater. The log likelihood ratio magnitudes of the parity bits are also mapped to ±Max(λ−2,1). (Block 1204)
A number of local decoding iterations are performed, such as, but not limited to 100 iterations. (Block 1206) At each iteration, a determination is made as to whether the data converged. (Block 1208) If the data converged, the decoded data is output. (Block 1210) If, 30 however, the decoding failed (Block 1208), the recovery process continues. The log likelihood ratio replacement value λ is decremented. (Block 1212) If the log likelihood ratio replacement value λ is 0 (Block 1214), this particular recovery scheme has been exhausted and the recovery process is terminated. (Block 1216) If the likelihood ratio replacement value λ is greater than 0 (Block 1214), the recovery process continues at Block 1204.
It should be noted that the various blocks shown in the drawings and discussed herein can be implemented in integrated circuits along with other functionality. Such integrated circuits can include all of the functions of a given block, system or circuit, or a subset of the block, system or circuit. Further, elements of the blocks, systems or circuits can be implemented across multiple integrated circuits. Such integrated circuits can be any type of integrated circuit known in the art including, but are not limited to, a monolithic integrated circuit, a flip chip integrated circuit, a multichip module integrated circuit, and/or a mixed signal integrated circuit. It should also be noted that various functions of the blocks, systems or circuits discussed herein can be implemented in either software or firmware. In some such cases, the entire system, block or circuit can be implemented using its software or firmware equivalent. In other cases, the one part of a given system, block or circuit can be implemented in software or firmware, while other parts are implemented in hardware.
In conclusion, the present invention provides novel systems and methods for refresh, run, aggregate decoder recovery. While detailed descriptions of one or more embodiments of the invention have been given above, various alternatives, modifications, and equivalents will be apparent to those skilled in the art without varying from the spirit of the invention. Therefore, the above description should not be taken as limiting the scope of the invention, which is defined by the appended claims.
This application is a continuation of U.S. patent application Ser. No. 14/218,626, filed on 18 Mar. 2014 and entitled REFRESH, RUN, AGGREGATE DECODER RECOVERY, pending, which claims benefit of U.S. Provisional Patent Application No. 61/941,378, filed on 18 Feb. 2014 and entitled REFRESH, RUN, AGGREGATE DECODER RECOVERY, expired, the disclosures of which are incorporated in their entirety by this reference.
Number | Date | Country | |
---|---|---|---|
61941378 | Feb 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14218626 | Mar 2014 | US |
Child | 16389551 | US |