US8458555B2 - Breaking trapping sets using targeted bit adjustment - Google Patents
Breaking trapping sets using targeted bit adjustment Download PDFInfo
- Publication number
- US8458555B2 US8458555B2 US12/827,652 US82765210A US8458555B2 US 8458555 B2 US8458555 B2 US 8458555B2 US 82765210 A US82765210 A US 82765210A US 8458555 B2 US8458555 B2 US 8458555B2
- Authority
- US
- United States
- Prior art keywords
- output values
- stage
- values
- error correction
- correction decoding
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related, expires
Links
- 238000000034 method Methods 0.000 claims abstract description 73
- 238000009738 saturating Methods 0.000 abstract description 4
- 239000011159 matrix material Substances 0.000 description 39
- 125000004122 cyclic group Chemical group 0.000 description 20
- 229920006395 saturated elastomer Polymers 0.000 description 16
- 238000012545 processing Methods 0.000 description 14
- 238000012805 post-processing Methods 0.000 description 11
- 238000010586 diagram Methods 0.000 description 9
- 208000011580 syndromic disease Diseases 0.000 description 6
- 238000001514 detection method Methods 0.000 description 4
- 238000004891 communication Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 230000001788 irregular Effects 0.000 description 2
- 238000002372 labelling Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/37—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
- H03M13/3707—Adaptive decoding and hybrid decoding, e.g. decoding methods or techniques providing more than one decoding algorithm for one code
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/11—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
- H03M13/1102—Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
- H03M13/1105—Decoding
- H03M13/1108—Hard decision decoding, e.g. bit flipping, modified or weighted bit flipping
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/11—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
- H03M13/1102—Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
- H03M13/1105—Decoding
- H03M13/1111—Soft-decision decoding, e.g. by means of message passing or belief propagation algorithms
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/11—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
- H03M13/1102—Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
- H03M13/1105—Decoding
- H03M13/1128—Judging correct decoding and iterative stopping criteria other than syndrome check and upper limit for decoding iterations
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/11—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
- H03M13/1102—Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
- H03M13/1105—Decoding
- H03M13/1142—Decoding using trapping sets
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/37—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
- H03M13/3723—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35 using means or methods for the initialisation of the decoder
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/37—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
- H03M13/373—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35 with erasure correction and erasure determination, e.g. for packet loss recovery or setting of erasures for the decoding of Reed-Solomon codes
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/37—Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
- H03M13/45—Soft decoding, i.e. using symbol reliability information
- H03M13/451—Soft decoding, i.e. using symbol reliability information using a set of candidate code words, e.g. ordered statistics decoding [OSD]
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/63—Joint error correction and other techniques
- H03M13/6306—Error control coding in combination with Automatic Repeat reQuest [ARQ] and diversity transmission, e.g. coding schemes for the multiple transmission of the same information or the transmission of incremental redundancy
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/65—Purpose and implementation aspects
- H03M13/6577—Representation or format of variables, register sizes or word-lengths and quantization
- H03M13/6591—Truncation, saturation and clamping
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/09—Error detection only, e.g. using cyclic redundancy check [CRC] codes or single parity bit
Definitions
- the present invention relates to signal processing, and, more specifically but not exclusively, to error-correction encoding and decoding techniques such as low-density parity-check (LDPC) encoding and decoding.
- LDPC low-density parity-check
- an LDPC decoder may encounter one or more trapping sets that prevent the decoder from properly decoding the codeword. Trapping sets, which represent subgraphs in a Tanner graph of an LDPC code, typically have a strong influence on error-floor characteristics of the LDPC code because a trapping set may force the decoder to converge to an incorrect result. To improve error-floor characteristics, an LDPC decoder may employ different techniques to, for example, (i) break the trapping sets and/or (ii) prevent the LDPC decoder from converging on trapping sets.
- LDPC low-density parity-check
- the present invention is a receiver-implemented method for recovering an EC-encoded codeword.
- the method comprises performing a first stage of EC decoding on a first set of input values to generate a first set of output values, one or more of which correspond to one or more first-stage unsatisfied check nodes (USCs). Further, a second stage of EC decoding is performed on a second set of input values to generate a second set of output values, one or more of which correspond to one or more second-stage USCs.
- the second set of input values is based on the first set of output values.
- one or more of the input values of the second set of input values are generated by adjusting one or more corresponding output values of the first set of output values, wherein each of the one or more corresponding output values of the first set of output values is associated with a first-stage USC.
- a difference of (i) the number of first-stage USCs and (ii) the number of second-stage USCs is compared to a specified threshold value, and a subsequent stage of EC decoding is selected based on the comparison. The selected subsequent stage of EC decoding is then performed.
- the present invention is an apparatus for recovering an EC-encoded codeword.
- the apparatus comprises an EC decoder and a controller that controls the EC decoder.
- the EC decoder performs a first stage of EC decoding on a first set of input values to generate a first set of output values, one or more of which correspond to one or more first-stage unsatisfied check nodes (USCs). Further, the EC decoder performs a second stage of EC decoding on a second set of input values to generate a second set of output values, one or more of which correspond to one or more second-stage USCs.
- the second set of input values is based on the first set of output values.
- one or more of the input values of the second set of input values are generated by adjusting one or more corresponding output values of the first set of output values, wherein each of the one or more corresponding output values of the first set of output values is associated with a first-stage USC.
- the controller compares a difference of (i) the number of first-stage USCs and (ii) the number of second-stage USCs to a specified threshold value, and selects a subsequent stage of EC decoding based on the comparison.
- the EC decoder then performs the selected subsequent stage of EC decoding.
- FIG. 1 shows one implementation of a parity-check matrix that may be used to implement a regular, quasi-cyclic (QC) low-density parity-check (LDPC) code;
- QC quasi-cyclic
- LDPC low-density parity-check
- FIG. 2 shows a simplified block diagram of a portion of a receiver 200 according to one embodiment of the present invention
- FIG. 3 shows a simplified flow diagram of a turbo-equalization method 300 that may be performed by a receiver that employs LDPC decoding according to one embodiment of the present invention
- FIG. 4A shows a simplified flow diagram of a first stage of processing according to one embodiment of the present invention that may be performed by a post processor such as the post processor in FIG. 2 ;
- FIG. 4B shows a simplified flow diagram of a second stage of processing according to one embodiment of the present invention that may be performed by a post processor such as the post processor in FIG. 2 .
- FIG. 1 shows one implementation of a parity-check matrix 100 that may be used to implement a regular, quasi-cyclic (QC) LDPC code.
- a circulant is a sub-matrix that is either an identity matrix or is obtained by cyclically shifting an identity matrix
- a quasi-cyclic LDPC code is an LDPC code in which all of the sub-matrices are circulants.
- each circulant B j,k is a permutation of an identity matrix
- the hamming weight i.e., the number of entries having a value of one
- Each of the 288 rows of H-matrix 100 corresponds to an m th check node, where m ranges from 0, . . .
- H-matrix 100 may be described as a regular LDPC code since all rows of H-matrix 100 have the same hamming weight w r and all columns of H-matrix 100 have the same hamming weight w c .
- FIG. 2 shows a simplified block diagram of a portion of a receiver 200 according to one embodiment of the present invention.
- Receiver 200 which includes LDPC decoder 201 and controller 202 , may be implemented in, for example, hard-disk drive electronics or any other suitable signal processing device. Further, receiver 200 may comprise other circuitry that is not shown such as a channel detector, an analog front end, and any other suitable circuitry.
- LDPC decoder 201 may be used to decode codewords encoded using an H-matrix such as H-matrix 100 of FIG. 1 .
- LDPC decoder 200 receives 720 channel soft-output values (e.g., log-likelihood ratios (LLR)) La n (0) from a channel detector such as a soft-output Viterbi detector and stores these channel soft-output values La n (0) in soft-value memory 204 .
- channel soft-output value La n (0) corresponds to one bit of the codeword, and each codeword is decoded iteratively using a message-passing algorithm.
- soft-output value refers to a value having a hard-decision bit (i.e., the most-significant bit) and one or more confidence-value bits (i.e., the least significant bits).
- LDPC decoder 200 decodes the 720 channel soft-output values) L n (0) (i.e., messages) using a block-serial message-passing schedule.
- the messages are updated using (i) 288 check-node units (CNUs) 214 , where each CNU 214 performs check-node updates for one row (i.e., the m th check node) of H-matrix 100 and (ii) 72 variable-node units (VNUs) 208 , where each VNU 208 performs the variable-node updates for ten columns (i.e., the n th variable nodes) of H-matrix 100 .
- CNUs check-node units
- VNUs variable-node units
- CNUs 214 ( 0 )-( 287 ) perform the check-node (i.e., row) updates for the 288 rows of H-matrix 100 , one block column at a time, such that the check-node updates for the first block column (i.e., circulants B 1,1 , B 2,1 , B 3,1 , and B 4,1 ) are performed, followed by the check-node updates for the second block column (i.e., circulants B 1,2 , B 2,2 , B 3,2 , and B 4,2 ), followed by the check-node updates for the third block column (i.e., circulants B 1,3 , B 2,3 , B 3,3 , and B 4,3 ), and so forth.
- the check-node updates for the first block column i.e., circulants B 1,1 , B 2,1 , B 3,1 , and B 4,1
- the check-node updates for the second block column i.e., circulants B
- VNUs 208 ( 0 )-( 71 ) then perform the variable-node (i.e., column) updates for the 720 columns of H-matrix 100 , one block column at a time, such that the variable-node updates for the first block column (i.e., circulants B 1,1 , B 2,1 , B 3,1 , and B 4,1 ) are performed, followed by the variable-node updates for the second block column (i.e., circulants B 1,2 , B 2,2 , B 3,2 , and B 4,2 ), followed by the variable-node updates for the third block column (i.e., circulants B 1,3 , B 2,3 , B 3,3 , and B 4,3 ), and so forth.
- the variable-node updates for the first block column i.e., circulants B 1,1 , B 2,1 , B 3,1 , and B 4,1
- the variable-node updates for the second block column i.e., circulants
- a local iteration of LDPC decoder 200 is complete after all check-node updates and variable-node updates have been performed (i.e., one pass through LDPC decoder 200 has been performed).
- the term “local iteration” refers to one iteration internal to the LDPC decoder itself.
- 720 channel soft-output values La n (0) are provided to multiplexer 206 .
- Multiplexer 206 may also receive 720 soft values L n , as discussed below in relation to post processor 218 , during subsequent iterations.
- the 720 channel soft-output values La n (0) are provided to multiplexers 210 ( 0 )-( 3 ) at a rate of 72 channel soft-output values La n (0) per clock cycle such that each multiplexer 210 receives all 72 channel soft-output values La n (0) in the set.
- Each multiplexer 210 also receives 72 variable-node messages (herein referred to as Q messages) that are generated as discussed in further detail below from VNUs 208 ( 0 )-( 71 ).
- Q messages 72 variable-node messages
- multiplexers 210 ( 0 )-( 3 ) select the sets of 72 channel soft-output values La n (0) that they receive to output to 72-way cyclic shifters 212 ( 0 )-( 3 ), respectively.
- the initial Q messages, which are not selected, may be Q messages generated for a previously considered codeword.
- multiplexers 210 ( 0 )-( 3 ) select the sets of 72 Q messages that they receive from VNUs 208 ( 0 )-( 71 ) to output to 72-way cyclic shifters 212 ( 0 )-( 3 ), respectively.
- any reference to Q messages applies to channel soft-output values La n (0) during the first iteration of LDPC decoder 200 .
- Cyclic shifters 212 ( 0 )-( 3 ) cyclically shift the sets of 72 Q messages that they receive based on a cyclic-shift signal that may be received from, for example, controller 202 .
- Controller 202 may be implemented as an integral component to LDPC decoder 200 or may be implemented as a component that is separate from LDPC decoder 200 .
- the cyclic-shift signal corresponds to cyclic-shift factors of the circulants of H-matrix 100 of FIG. 1 .
- cyclic shifters 212 ( 0 )-( 3 ) may shift their respective sets of 72 Q messages based on the shift factors of circulants B 1,1 , B 2,1 , B 3,1 , and B 4,1 of H-matrix 100 of FIG. 1 , respectively.
- cyclic shifters 212 ( 0 )-( 3 ) may shift their respective sets of 72 Q messages based on the shift factors of circulants B 1,2 , B 2,2 , B 3,2 , and B 4,2 , respectively.
- Cyclic shifters 212 ( 0 )-( 3 ) then provide their respective 72 cyclically shifted Q messages to CNUs 214 ( 0 )-( 287 ), such that each CNU 214 receives a different one of the Q messages.
- Each CNU 214 receives a number of Q messages equal to the hamming weight w r of a row of H-matrix 100 (e.g., 10) at a rate of one Q message per clock cycle and (ii) generates w r check-node messages (herein referred to as R messages).
- R messages may be generated using a suitable check-node algorithm, such as the offset min-sum algorithm, characterized by Equations (1), (2), and (3) shown below:
- min n ′ ⁇ N ⁇ ( m ) ⁇ / ⁇ n ⁇
- ( 2 ) ⁇ mn ( i ) ( ⁇ n ′ ⁇ N ⁇ ( m ) ⁇ / ⁇ n ⁇ sign ⁇ ( Q n ′ ⁇ m ( i - 1 ) ) ) , ( 3 ) where (i) R mn (i) represents the R message corresponding to m th check node (i.e., row) and the n th variable node (i.e., column) of H-matrix 100 of FIG.
- Q nm (i-1) represents the Q message corresponding to the n th variable node and the check node of H-matrix 100 for the (i ⁇ 1) th iteration
- ⁇ represents an offset value that varies with code parameters
- the function sign indicates that the multiplication operation (i.e., ⁇ ) is performed on the signs of the Q nm (i-1) messages.
- n′ is a variable node in the set N(m)/n of all variable nodes connected to the m th check node except for the n th variable node (i.e., n′ ⁇ N(m)/n).
- the CNU 214 corresponding to the m th check node (i.e., row) generates message R mn (i) based on all Q messages received during the previous (i ⁇ 1) th iteration from the set N(m)/n.
- Cyclic shifters 216 ( 0 )-( 3 ) receive sets of 72 R messages from their respective CNUs 214 and cyclically shift the sets of 72 R messages according to the cyclic shifts of the circulants B j,k of H-matrix 100 of FIG. 1 .
- cyclic shifters 216 ( 0 )-( 3 ) reverse the cyclic shifting of cyclic shifters 212 ( 0 )-( 3 ). For example, if cyclic shifters 212 ( 0 )-( 3 ) perform cyclic upshifting, then cyclic shifters 216 ( 0 )-( 3 ) may perform cyclic downshifting.
- Cyclic shifters 216 ( 0 )-( 3 ) provide 4 ⁇ 72 cyclically shifted R messages to VNUs 208 ( 0 )-( 71 ), such that each VNU 208 receives four of the R messages, one from each cyclic shifter 216 .
- Each VNU 208 updates each of the four Q messages that it generates as shown in Equation (4):
- the n th variable node generates message Q nm (i) based on (i) all R messages received during the previous (i ⁇ 1) th iteration from the set M(n)/m and (ii) an initial channel soft-output value La n (0) received from soft-output value memory 204 that corresponds to the n th variable node.
- Each VNU 208 which may be implemented using adder circuits, outputs the four updated Q messages that it generates, such that a different one of the four messages is provided to a different corresponding MUX 210 .
- each VNU 208 outputs (i) a multi-bit extrinsic LLR value, (ii) a hard-decision output bit, and (iii) a multi-bit P value.
- Each extrinsic LLR value may be represented as shown in Equation (5):
- P n is determined for each variable node by adding the extrinsic value from Equation (5) to the initial channel soft-output value La n (0) received from soft-value memory 204 via MUX 206 that corresponds to the n th variable node. If P n is greater than or equal to zero, then the hard-decision bit ⁇ circumflex over (x) ⁇ n is equal to zero, as shown in Equation (7). If P n is less than zero, then the hard-decision bit ⁇ circumflex over (x) ⁇ n is equal to one, as shown in Equation (8).
- An iteration of LDPC decoding (herein referred to as a local iteration) is complete when 720 hard-decision bits ⁇ circumflex over (x) ⁇ n have been generated (i.e., after all check nodes and bit nodes of H-matrix 100 have been updated), where each hard-decision bit ⁇ circumflex over (x) ⁇ n corresponds to a bit of the LDPC-encoded codeword.
- a local iteration An iteration of LDPC decoding (herein referred to as a local iteration) is complete when 720 hard-decision bits ⁇ circumflex over (x) ⁇ n have been generated (i.e., after all check nodes and bit nodes of H-matrix 100 have been updated), where each hard-decision bit ⁇ circumflex over (x) ⁇ n corresponds to a bit of the LDPC-encoded codeword.
- FIG. 3 To further understand the operation of LDPC decoders in the context of
- FIG. 3 shows a simplified flow diagram of a turbo-equalization method 300 that may be performed by a receiver that employs LDPC decoding according to one embodiment of the present invention.
- Turbo-equalization method 300 may be implemented using LDPC decoder 200 or any other suitable LDPC decoder; however, for ease of discussion, turbo-equalization method 300 is described relative to its use with LDPC decoder 200 .
- turbo-equalization method 300 Upon start-up, turbo-equalization method 300 stores y-samples (action 302 ) that are received from, for example, a hard disk platter or other communications device. The y-samples are provided to a channel detector, which implements a channel detection method (action 304 ), such as Viterbi soft-output detection or any other suitable channel detection method.
- a channel detection method action 304
- the channel detector provides soft-output values to soft-value memory 204 of LDPC decoder 200 .
- LDPC decoder 200 performs a local iteration of LDPC decoding (action 306 ) as described above in relation to LDPC decoder 200 .
- the turbo-equalizer After 720 hard-decision bits ⁇ circumflex over (x) ⁇ n have been generated, the turbo-equalizer performs decision 308 to determine whether or not LDPC decoder 200 has converged on a valid codeword.
- a parity check is performed by, for example, a syndrome check calculator (not shown), using the hard-decision bits ⁇ circumflex over (x) ⁇ n .
- the syndrome check calculator may be implemented as part of controller 202 or as a separate logic circuit.
- the 720-element vector ⁇ circumflex over (x) ⁇ formed from 720 hard-decision bits ⁇ circumflex over (x) ⁇ n output from VNUs 208 ( 0 )-( 71 ) is multiplied by the transpose H T of H-matrix 100 of FIG. 1 (assuming binary summation) to generate a 288-bit vector (i.e., syndrome), where each bit of the 288-bit syndrome corresponds to one of the 288 check nodes (i.e., rows) of H-matrix 100 .
- LDPC decoder 200 has converged on a valid codeword and a cyclic-redundancy check (CRC) (action 310 ) may be performed by, for example, controller 202 to determine whether the valid codeword is the correct codeword (i.e., the codeword that was transmitted).
- CRC cyclic-redundancy check
- CRC check is part of the encoding scheme
- typically a number r of CRC check bits are appended to the user data at the transmitter before LDPC encoding such that, upon decoding, the 720-element vector ⁇ circumflex over (x) ⁇ output from VNUs 208 ( 0 )-( 71 ) comprises (i) the user data transmitted by the transmitter and (ii) the r CRC check bits.
- the user data may be divided by a keyword that is known a priori by the receiver and the remainder of the division process may be compared to the r CRC check bits.
- the CRC check has passed indicating that LDPC decoder 200 has converged on the correct codeword and decoding for the subject codeword is stopped. If the remainder is not equal to the r CRC check bits, then the CRC check has failed indicating that LDPC decoder 200 has converged on a valid codeword that is not the correct codeword (i.e., the valid codeword has one or more missatisfied check nodes). In this case, further actions 312 may be taken to recover the correct codeword, such as a retransmission of the data. Re-transmission of the data corresponds to re-execution of method 300 from the start.
- LDPC decoder 200 has not converged on a valid codeword.
- Each element of the 288-bit vector that has a value of one is considered an unsatisfied check node (USC), and each element of the 288-bit vector that has a value of zero is either (i) a satisfied check node or (ii) a missatisfied check node (MSC) (i.e., a check node that falsely shows as satisfied).
- controller 202 determines whether or not to perform another local iteration of LDPC decoding (decision 314 ).
- Decision 314 may involve performing one or more suitable methods.
- controller 202 may determine whether a trapping set (a,b) has been encountered, where b is the number of unsatisfied check nodes in the trapping set, and a is the number of erroneous bit nodes (EBNs) associated with those unsatisfied check nodes.
- the majority of trapping sets typically comprise fewer than five unsatisfied check nodes and fewer than ten erroneous bit nodes.
- Determining whether LDPC decoder 200 has encountered a trapping set may be performed using any suitable method. For example, the decoder could track the number (b observed ) of unsatisfied check nodes over several iterations.
- Determining whether the number of unsatisfied check nodes is relatively stable may be performed by tracking the variance of the number of unsatisfied check nodes over several iterations.
- LDPC decoder 200 could determine whether (i) the vector resulting from ⁇ circumflex over (x) ⁇ H T possesses a number (b observed ) of unsatisfied check nodes that is greater than zero and less than a specified number (b max ) of unsatisfied check nodes (e.g., 16) and (ii) the particular configuration of unsatisfied check nodes has remained relatively stable (i.e., the number and locations of the unsatisfied check nodes have not changed) for several local iterations of LDPC decoder 200 (e.g., two or three iterations).
- LDPC decoder 200 could just consider whether the configuration of unsatisfied check nodes has remained relatively stable.
- controller 200 may compare the number of local iterations performed by LDPC decoder 200 to a specified number of iterations (i.e., an iteration threshold). Note that this method could be used in conjunction with the above-mentioned method for determining whether a trapping set has been encountered. For example, LDPC decoder 200 could continue decoding as long as (i) a trapping set has not been encountered, and (ii) LDPC decoder 200 has not performed the specified number of iterations. If either (i) a trapping set is encountered, or (ii) LDPC decoder 200 has performed the specified number of iterations, then decoding is discontinued.
- a specified number of iterations i.e., an iteration threshold
- the first method may be advantageous when LDPC decoder 200 converges on a trapping set before the specified number of iterations has been reached. By identifying a trapping set before the specified number of iterations, the decoder can avoid performing unnecessary iterations.
- the second method may be advantageous when the number and/or configuration of trapping sets do not stabilize after a specified number of iterations. This may prevent LDPC decoder 200 from running for extended periods of time, resulting in increased latency of LDPC decoder 200 .
- controller 202 determines that LDPC decoder 200 has (i) not reached the specified iteration threshold and (ii) not converged on a trapping set, then processing returns to action 306 to perform another local LDPC decoding iteration. If, on the other hand, controller 202 determines that LDPC decoder 200 has either (i) reached the specified iteration threshold or (ii) converged on a trapping set, then controller 202 determines whether or not to perform further actions to improve the chances of recovering a valid codeword.
- the turbo equalizer may perform (i) LDPC decoding using a suitable post-processing method (decision 316 ), (ii) one or more additional global iterations (decision 320 ), or (iii) any combination of post-processing, global iterations, and local iterations.
- a global iteration is an iteration that includes channel detection and one or more local iterations of the LDPC decoder.
- Controller 204 may determine whether or not to perform one of these actions by, for example, determining whether the number (b observed ) of unsatisfied check nodes exceeds a specified number (b max ) of unsatisfied check nodes (e.g., 16), where b max may be determined experimentally. If the number (b observed ) of unsatisfied check nodes is less than or equal to the specified number (b max ) of unsatisfied check nodes, then it is likely that LDPC decoder 200 has converged on a trapping set (i.e., an observed trapping set) that may be broken.
- the order in which post-processing methods and global iterations are performed may vary from one embodiment to the next.
- the turbo equalizer could perform a maximum number of global iterations. If LDPC decoder 200 does not converge within the maximum number of global iterations, then the turbo equalizer could perform one or more post-processing methods to converge on a valid codeword. As another example, the turbo equalizer could perform a post-processing method before performing further global iterations.
- a number of different post-processing methods may be used to break the observed trapping set.
- the observed trapping set is matched against a database of trapping sets known a priori by the decoder.
- list decoding the observed trapping set is compared to the known trapping sets in the database until either (i) a match is found or (ii) it is determined that none of the known trapping sets match the observed trapping set. If a known trapping set is found in the database that matches the observed trapping set, then erroneous bit node index value(s) corresponding to the trapping set are retrieved from the trapping-set database.
- the channel soft-output values La n corresponding to the erroneous bit node index value(s) are adjusted, and the decoder is restarted using the adjusted channel soft-output values La n .
- adjusting one or two channel soft-output values La n is sufficient to break the trapping set, and the re-started decoder will converge on the correct codeword. More detailed discussions of list-decoding methods are provided in PCT patent application no. PCT/US08/86523, PCT patent application no. PCT/US08/86537, and U.S. patent application Ser. No. 12/540,002.
- an observed trapping set might not be known a priori by the LDPC decoder (i.e., not stored in the database), and thus, methods other than list decoding might be needed to break the trapping set.
- LDPC decoder 200 could implement a targeted-bit adjustment technique that does not rely on a priori knowledge of trapping sets. As an example, consider the technique represented in FIG. 4 below.
- controller 204 determines that the number (b observed ) of unsatisfied check nodes exceeds a specified number (b max ) of unsatisfied check nodes, then it is likely that LDPC decoder 200 has experienced an error in the communication channel, such as a scratch on the surface of a hard disk. In such a case, it is not likely that a post-processing method or another global iteration would be suitable for recovering a valid codeword.
- the turbo-equalizer may decide to retransmit (or reread in the case of a hard-disk drive) the data (decision 322 ) and return to action 302 . Alternatively, if the turbo-equalizer is not able to recover a valid codeword, the turbo-equalizer might stop processing for the subject codeword altogether.
- FIG. 4 shows a simplified flow diagram of a two-stage targeted bit-adjustment technique according to one embodiment of the present invention that may be implemented by an LDPC decoder.
- FIG. 4A shows a simplified flow diagram of a first stage 400 of the two-stage targeted bit-adjustment technique
- FIG. 4B shows a simplified flow diagram of a second stage 450 of the two-stage targeted bit-adjustment technique.
- the two-stage bit-adjustment technique of FIG. 4 may be implemented using any suitable error-correction decoder, including layered-LDPC decoders.
- the technique of FIG. 4 is discussed in the context of LDPC decoder 200 of FIG. 2 .
- first stage 400 performs one or more two-bit targeted-bit adjustment trials based on the output of the last (i.e., failed) LDPC decoding iteration, where two bits of the LDPC-encoded codeword are adjusted in each two-bit trial.
- second stage 450 performs one or more single-bit targeted bit adjustment trials based on the output of first stage 400 , where one bit of the LDPC-encoded codeword is adjusted in each single-bit trial.
- post processor 218 of LDPC decoder 200 performs first stage 400 of the two-stage targeted-bit adjustment technique.
- post processor 218 performs action 402 to store (i) the indices of the unsatisfied check nodes (USCs) as set USC 1 and (ii) the number of unsatisfied check nodes as parameter USCN 1 .
- the indices of unsatisfied check nodes and number of unsatisfied check nodes are determined from the syndrome of the last (i.e., failed) decoder iteration. Note that any reference herein to an iteration also applies to a sub-iteration in the case of a layered-LDPC decoder, where a sub-iteration corresponds to the processing of one layer of the H-matrix.
- post processor 218 performs action 404 to initialize LDPC decoder 200 to State 0.
- post processor 218 which receives 720 P n values from VNUs 208 ( 0 )-( 71 ) during the last decoder iteration at a rate of 72 P n values per clock cycle, sets all 720 P n values to a relatively small value by, for example, saturating the P n values to approximately 15% of the largest positive or negative LLR values.
- the P n values are represented using 5 bits, where the most-significant bit (MSB) is a hard-decision bit, and the four least-significant bits (LSBs) form a 4-bit confidence value.
- MSB most-significant bit
- LSBs least-significant bits
- the 720 P n values initialized to State 0 are then stored in memory for possible future use.
- post processor 218 selects an unsatisfied check node U 1 from the set USC 1 of unsatisfied check nodes (action 406 ), and (ii) selects a saturated P n value corresponding to a bit B 1 connected to unsatisfied check node U 1 (action 408 ).
- Check node U 1 may be selected sequentially from the set USC 1 of unsatisfied check nodes and P n may be selected sequentially from the bits connected to unsatisfied check node U 1 .
- Post processor 218 adjusts the selected saturated P n value by flipping the hard-decision bit (a.k.a.
- the adjusted P n value replaces the corresponding saturated P n value in memory.
- Post processor 218 also performs action 410 to select a second unsatisfied check node U 2 from the set USC 1 of unsatisfied check nodes.
- the second unsatisfied check node U 2 is selected to be different from the first unsatisfied check node U 1 (i.e., U 1 ⁇ U 2 ).
- post processor 218 (i) selects a P n value corresponding to a bit B 2 connected to unsatisfied check node U 2 , and (ii) adjusts the P n value.
- the adjusted P n value replaces the corresponding saturated P n value in memory.
- 718 saturated P n values, one adjusted P n value corresponding to U 1 , and one adjusted P n value corresponding to U 2 are stored in memory.
- Post processor 218 provides 720 P′ n values (i.e., 718 saturated P n values from action 404 and two adjusted P n values from actions 406 and 412 ) to VNUs 208 ( 0 )-( 71 ) and multiplexers 210 ( 0 )-( 3 ) via multiplexer 206 and performs decoding (action 414 ) as described above in relation to FIG. 2 using the P′ n values in lieu of the channel soft-input values La n (0) . Note that the 720 P′ n values stored in memory are not modified during a local iteration of LDPC decoding.
- LDPC decoder 200 converges on a valid codeword within a specified number of iterations (decision 416 ), then a CRC check (action 418 ) is performed in a manner analogous to that described above. If the CRC check passes, then decoding is stopped for the subject codeword. If the CRC check fails, then further actions 420 may be performed as discussed above, such as a retransmission of the data or performance of one or more global iterations of the turbo decoder.
- post processor 218 performs action 422 to store (i) the indices of the unsatisfied check nodes as set USC 2 and (ii) the number of unsatisfied check nodes as parameter USCN 2 .
- the indices of unsatisfied check nodes in the set USC 2 and number USCN 2 of unsatisfied check nodes are determined from the syndrome of the last (i.e., failed) decoder iteration of first stage 400 .
- Post processor 218 determines (i) the difference between the number USCN 1 of check nodes in set USC 1 and the number USCN 2 of check nodes in USC 2 and (ii) whether the magnitude of that difference is less than or equal to a specified threshold (e.g., 2) (action 424 ). If the magnitude is not less than or equal to the threshold, then post processor 218 determines whether all of the possible B 1 and B 2 bit combinations have been considered (decision 426 ) (i.e., all possible pairs of bits connected to the USCs in the set USC 1 ).
- a specified threshold e.g., 2
- post processor 218 resets the adjusted P n values corresponding to bits B 1 and B 2 to their saturated values in State 0 (action 428 ).
- processing returns to action 406 to perform another iteration of first stage 400 in which a different pair of bits B 1 and B 2 is selected.
- post processor 218 initializes LDPC decoder 200 to State 1 (action 452 ). In so doing, post processor 218 , which receives 720 P n values output from VNUs 208 ( 0 )-( 71 ) during the last decoder iteration of first stage 400 at a rate of 72 P n values per clock cycle, sets all 720 P n values to a relatively small value in a manner analogous to that described above for action 404 (e.g., saturating each P n value to ⁇ 2).
- the 720 initialized State 1 P n values are stored in memory for possible future use.
- post processor 218 selects an unsatisfied check node U 3 from the set USC 2 of unsatisfied check nodes (action 454 ), and (ii) selects a P n value corresponding to a bit B 3 connected to unsatisfied check node U 3 (action 456 ).
- Bit B 3 could be the same as bit B 1 or B 2 .
- post processor 218 could disqualify any bits selected as bit B 1 or B 2 from being selected as bit B 3 .
- the adjusted P n value replaces the corresponding saturated P n value in memory.
- 719 saturated P n values and one adjusted P n value corresponding to U 3 are stored in memory.
- Post processor 218 provides 720 P′ n values (i.e., 719 saturated P n values and one adjusted P n value) to VNUs 208 ( 0 )-( 71 ) and multiplexers 210 ( 0 )-( 3 ) via multiplexer 206 and performs decoding (action 458 ) as described above in relation to FIG. 2 using the P′ n values in lieu of the channel soft-input values La n (0) . Note that the 720 P′ n values stored in memory are not modified during a local iteration of LDPC decoding.
- LDPC decoder 200 converges on a valid codeword within a specified number of iterations (decision 460 ), then a CRC check (action 462 ) is performed in a manner analogous to that described above. If the CRC check passes, then decoding is stopped for the subject codeword. If the CRC check fails, then further actions 464 may be performed as discussed above, such as a retransmission of the data or performance of one or more global iterations of the turbo decoder.
- post processor 218 performs action 466 to determine whether all of the possible bits B 3 have been considered (i.e., all bits connected to the USCs in the set USC 2 ). If all of the possible bits B 3 have not been considered, then post processor 218 resets the adjusted P′ n value corresponding to bit B 3 to its saturated value in State 1 (action 468 ).
- processing returns to action 454 to perform another iteration of second stage 450 in which a different bit B 3 is selected. This process may be repeated until all possible bits B 3 have been considered. If all possible bits have been considered (decision 466 ), then processing returns to action 404 of first stage 400 to perform another two-bit targeted bit adjustment trial.
- post processor 218 may select bits B 1 and B 2 from a set of suspicious bit nodes (SBNs), rather than from all bit nodes associated with the unsatisfied check nodes in set USC 1 (i.e., all associated bit nodes (ABNs)).
- a set of suspicious bit nodes corresponding to USC 1 is a subset of set USC 1 , where each suspicious bit node in the set is a bit node that is most likely to be an erroneous bit node. Thus, any bit nodes that are not likely to be erroneous are excluded from the set of suspicious bit nodes.
- post processor 218 may select bit B 3 from a set of suspicious bit nodes corresponding to set USC 2 .
- Suspicious bit nodes may be identified using any suitable method.
- post processor 218 selects a set (i.e., node set) of one or more unsatisfied check nodes (e.g., USC 1 or USC 2 ) and/or associated bit nodes.
- Post processor 218 selects a first node from the node set, and takes a first value associated with the first node, e.g., an R mn message value, and compares it a second value of a like kind, e.g., another R mn message value, associated with the same node.
- the second value can be from the same iteration/sub-iteration, or it can be from another iteration/sub-iteration. If the difference between compared values exceeds a specified threshold, then either the bit node associated with the first value or the bit node associated with the second value is added to the set of suspicious bit nodes. This process is repeated for each additional node in the node set.
- the node selected from the node set is an associated bit node.
- the values available for comparison are the R mn message values, Q nm message values, and P n values corresponding to the associated bit node.
- the comparison is between the complete values, i.e., both the sign bit and magnitude bits. If the difference between compared values exceeds a specified threshold, then the associated bit node is added to the set of suspicious bit nodes.
- the node selected from the node set is an unsatisfied check node.
- the values available for comparison are the R mn and Q nm message values (i.e., not P n values). Furthermore, the comparison is between only the magnitudes of the two LLRs. If the difference between compared values exceeds a specified threshold, then either the bit node associated with the first value or the bit node associated with the second value is added to the set of suspicious bit nodes.
- the values compared in the ABN-based or USC-based value-comparison methods may be values corresponding to the same iteration, the same sub-iteration, different iterations, or different sub-iterations.
- an inter-iteration comparison may be made by comparing an R message R 25 7 corresponding check node 2 to bit node 5 in decoding iteration 7 to an R message R 25 6 corresponding to check node 2 to bit node 5 in decoding iteration 6 .
- an intra-iteration comparison may be made by comparing an R message R 25 7 corresponding check node 2 to bit node 5 in decoding iteration 7 to an R message R 28 7 corresponding to check node 2 to bit node 8 in the same decoding iteration.
- a set of suspicious bit nodes may be selected from the associated bit nodes whose corresponding P n values grow so large that they are saturated within a specified number of decoding iterations.
- a set of suspicious bit nodes may be selected from the associated bit nodes whose corresponding P n values and extrinsic LLR values have opposite signs, e.g., a positive P n value and a negative extrinsic LLR value, or vice versa.
- a set of suspicious bit nodes may be selected from the associated bit nodes whose corresponding P n values and channel input values La n (0) values have opposite signs.
- first and second stages 400 and 450 were described as performing two-bit and single-bit targeted bit adjustment trials, respectively, the present invention is not so limited.
- First stage 400 may perform single-bit or multi-bit targeted bit adjustment trials, where one or more bits are adjusted in each trial.
- second stage 450 may perform single-bit or multi-bit targeted bit adjustment trials.
- Embodiments of the present invention have been described in the context of LDPC codes, the present invention is not so limited. Embodiments of the present invention could be implemented for any code which can be defined by a graph, e.g., tornado codes, structured IRA codes, since it is graph-defined codes which suffer from trapping sets.
- a graph e.g., tornado codes, structured IRA codes, since it is graph-defined codes which suffer from trapping sets.
- the present invention has been described relative to the specific non-layered LDPC decoder configuration 200 of FIG. 2 , the present invention is not so limited. Various embodiments of the present invention may also be envisioned for other LDPC decoder structures that employ message passing. For example, the technique of FIG. 4 may be implemented for other non-layered or for layered decoder structures, and decoders that use message-passing schedules other than a block-serial message-passing schedule. An example of a layered-LDPC decoder may be found in, for example, U.S. patent application Ser. No. 12/475,786.
- the present invention may be implemented using check-node algorithms other than the offset min-sum algorithm.
- such embodiments may use a scaled min-sum algorithm, or any soft-input/soft-output algorithms other than the min-sum algorithm, such as a sum-product algorithm (SPA) or the Bahl-Cocke-Jelinek-Raviv (BCJR) algorithm.
- SPA sum-product algorithm
- BCJR Bahl-Cocke-Jelinek-Raviv
- Embodiments of the present invention may be performed using erasing in lieu of the adjustment method described above in relation to actions 408 , 412 , and 456 .
- Erasing is another process for altering bit-node values. Erasing a bit node comprises (i) setting the hard-decision value of that bit node's L ch value to 0 and (ii) setting the magnitude bits, i.e., the confidence, of that same L ch value to 0, i.e., no confidence.
- Some trapping sets can be broken by flipping or erasing a single EBN.
- flipping or erasing a single erroneous bit nodes may reduce the number of unsatisfied check nodes, but not break the trapping set entirely, yielding a second, different trapping set.
- Yet other trapping sets can be broken only by flipping or erasing two or more EBNs at the same time.
- the present invention was described relative to the specific H-matrix 100 of FIG. 1 , the present invention is not so limited.
- the present invention may be implemented for various H-matrices that are suitable for message-passing decoding and that are the same size as or a different size from matrix 100 of FIG. 1 .
- the present invention may be implemented for H-matrices in which the number of columns, block columns, rows, block rows, layers (including implementations having only one layer), messages processed per clock cycle, the size of the sub-matrices, the size of the layers, and/or the column and/or row hamming weights differ from that of H-matrix 100 .
- Such H-matrices may be, for example, cyclic, quasi-cyclic, non-cyclic, regular, or irregular H-matrices.
- H-matrices that are non-cyclic do not have any sub-matrices that are obtained by cyclically shifting an identity matrix.
- H-matrices that are irregular do not have the same hamming weight w r for all rows and/or the same hamming weight w, for all columns.
- such H-matrices may comprise sub-matrices other than circulants including zero matrices. Note that the number of VNUs, barrel shifters, and/or CNUs may vary according to the characteristics of the H-matrix.
- the present invention may be implemented as circuit-based processes, including possible implementation as a single integrated circuit (such as an ASIC or an FPGA), a multi-chip module, a single card, or a multi-card circuit pack.
- various functions of circuit elements may also be implemented as processing blocks in a software program.
- Such software may be employed in, for example, a digital signal processor, micro-controller, or general-purpose computer.
- the present invention can be embodied in the form of methods and apparatuses for practicing those methods.
- the present invention can also be embodied in the form of program code embodied in tangible media, such as magnetic recording media, optical recording media, solid state memory, floppy diskettes, CD-ROMs, hard drives, or any other non-transitory machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the invention.
- the present invention can also be embodied in the form of program code, for example, stored in a non-transitory machine-readable storage medium including being loaded into and/or executed by a machine, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the invention.
- program code segments When implemented on a general-purpose processor, the program code segments combine with the processor to provide a unique device that operates analogously to specific logic circuits.
- the present invention can also be embodied in the form of a bitstream or other sequence of signal values stored in a non-transitory recording medium generated using a method and/or an apparatus of the present invention.
- each numerical value and range should be interpreted as being approximate as if the word “about” or “approximately” preceded the value of the value or range.
- figure numbers and/or figure reference labels in the claims is intended to identify one or more possible embodiments of the claimed subject matter in order to facilitate the interpretation of the claims. Such use is not to be construed as necessarily limiting the scope of those claims to the embodiments shown in the corresponding figures.
Landscapes
- Physics & Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Error Detection And Correction (AREA)
Abstract
Description
-
- U.S. patent application Ser. No. 12/113,729 filed May 1, 2008,
- U.S. patent application Ser. No. 12/113,755 filed May 1, 2008,
- U.S. patent application Ser. No. 12/323,626 filed Nov. 26, 2008,
- U.S. patent application Ser. No. 12/401,116 filed Mar. 10, 2009,
- U.S. patent application Ser. No. 12/675,981 filed on Mar. 2, 2010,
- U.S. patent application Ser. No. 12/677,322 filed Mar. 10, 2010,
- U.S. patent application Ser. No. 12/680,810 filed Mar. 30, 2010,
- U.S. application Ser. No. 12/524,418 filed on Jul. 24, 2009,
- U.S. patent application Ser. No. 12/420,535 filed Apr. 8, 2009,
- U.S. patent application Ser. No. 12/475,786 filed Jun. 1, 2009,
- U.S. patent application Ser. No. 12/260,608 filed on Oct. 29, 2008,
- PCT patent application no. PCT/US09/41215 filed on Apr. 21, 2009,
- U.S. patent application Ser. No. 12/427,786 filed on Apr. 22, 2009,
- U.S. patent application Ser. No. 12/492,328 filed on Jun. 26, 2009,
- U.S. patent application Ser. No. 12/492,346 filed on Jun. 26, 2009,
- U.S. patent application Ser. No. 12/492,357 filed on Jun. 26, 2009,
- U.S. patent application Ser. No. 12/492,374 filed on Jun. 26, 2009,
- U.S. patent application Ser. No. 12/538,915 filed on Aug. 11, 2009,
- U.S. patent application Ser. No. 12/540,078 filed on Aug. 12, 2009,
- U.S. patent application Ser. No. 12/540,035 filed on Aug. 12, 2009,
- U.S. patent application Ser. No. 12/540,002 filed on Aug. 12, 2009,
- U.S. patent application Ser. No. 12/510,639 filed on Jul. 28, 2009,
- U.S. patent application Ser. No. 12/524,418 filed on Jul. 24, 2009,
- U.S. patent application Ser. No. 12/510,722 filed on Jul. 28, 2009,
- U.S. patent application Ser. No. 12/510,667 filed on Jul. 28, 2009,
- U.S. patent application Ser. No. 12/644,622 filed on Dec. 22, 2009,
- U.S. patent application Ser. No. 12/644,181 filed on Dec. 22, 2009, and
- U.S. patent application Ser. No. 12/766,038 filed on Apr. 23, 2010,
the teachings of all of which are incorporated herein by reference in their entirety.
where (i) Rmn (i) represents the R message corresponding to mth check node (i.e., row) and the nth variable node (i.e., column) of H-
where m′ is a check node in the set M(n)/m of all check nodes connected to the nth variable node except the mth check node (i.e., m′εM(n)/m). The nth variable node generates message Qnm (i) based on (i) all R messages received during the previous (i−1)th iteration from the set M(n)/m and (ii) an initial channel soft-output value Lan (0) received from soft-
where m is a check node in the set M(n) of all check nodes connected to the nth variable node (i.e., mεM(n)). Each P value may be generated using Equation (6) as follows:
each hard-decision bit {circumflex over (x)}n may be generated based on Equations (7) and (8) below:
{circumflex over (x)}n=0 if Pn≧0 (7)
{circumflex over (x)}n=1 if Pn<0. (8)
Pn is determined for each variable node by adding the extrinsic value from Equation (5) to the initial channel soft-output value Lan (0) received from soft-
Claims (21)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/827,652 US8458555B2 (en) | 2010-06-30 | 2010-06-30 | Breaking trapping sets using targeted bit adjustment |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/827,652 US8458555B2 (en) | 2010-06-30 | 2010-06-30 | Breaking trapping sets using targeted bit adjustment |
Publications (2)
Publication Number | Publication Date |
---|---|
US20120005551A1 US20120005551A1 (en) | 2012-01-05 |
US8458555B2 true US8458555B2 (en) | 2013-06-04 |
Family
ID=45400686
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/827,652 Expired - Fee Related US8458555B2 (en) | 2010-06-30 | 2010-06-30 | Breaking trapping sets using targeted bit adjustment |
Country Status (1)
Country | Link |
---|---|
US (1) | US8458555B2 (en) |
Cited By (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20130283114A1 (en) * | 2012-04-18 | 2013-10-24 | Lsi Corporation | Systems and Methods for Locating and Correcting Decoder Mis-Corrections |
US8782488B2 (en) * | 2012-04-20 | 2014-07-15 | Lsi Corporation | Systems and methods for back step data decoding |
US8817404B1 (en) | 2013-07-18 | 2014-08-26 | Lsi Corporation | Systems and methods for data processing control |
US8908307B1 (en) | 2013-08-23 | 2014-12-09 | Lsi Corporation | Systems and methods for hard disk drive region based data encoding |
US8917466B1 (en) | 2013-07-17 | 2014-12-23 | Lsi Corporation | Systems and methods for governing in-flight data sets in a data processing system |
US8959414B2 (en) | 2013-06-13 | 2015-02-17 | Lsi Corporation | Systems and methods for hybrid layer data decoding |
US9196299B2 (en) | 2013-08-23 | 2015-11-24 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for enhanced data encoding and decoding |
US9219503B2 (en) | 2013-10-16 | 2015-12-22 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for multi-algorithm concatenation encoding and decoding |
US9274889B2 (en) | 2013-05-29 | 2016-03-01 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for data processing using global iteration result reuse |
US9298720B2 (en) | 2013-09-17 | 2016-03-29 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for fragmented data recovery |
US9323606B2 (en) | 2013-11-21 | 2016-04-26 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for FAID follower decoding |
US9331716B2 (en) | 2014-02-10 | 2016-05-03 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for area efficient data encoding |
US9378765B2 (en) | 2014-04-03 | 2016-06-28 | Seagate Technology Llc | Systems and methods for differential message scaling in a decoding process |
US20210288746A1 (en) * | 2020-03-10 | 2021-09-16 | Tesat-Spacecom Gmbh & Co. Kg | Error Correction for LDPC Decoders |
US11626889B1 (en) * | 2021-11-16 | 2023-04-11 | L3Harris Technologies, Inc. | Partial update sharing in joint LDPC decoding and ancillary processors |
Families Citing this family (41)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8650459B1 (en) * | 2011-02-16 | 2014-02-11 | Sk Hynix Memory Solutions Inc. | Soft input, soft ouput mappers and demappers for block codes |
US10063262B2 (en) | 2011-02-28 | 2018-08-28 | Inphi Corporation | Non-concatenated FEC codes for ultra-high speed optical transport networks |
WO2012118766A1 (en) * | 2011-02-28 | 2012-09-07 | Clariphy Communications, Inc. | Non-concatenated fec codes for ultra-high speed optical transport networks |
US10103751B2 (en) * | 2011-02-28 | 2018-10-16 | Inphi Corporation | Non-concatenated FEC codes for ultra-high speed optical transport networks |
US8819527B2 (en) * | 2011-07-19 | 2014-08-26 | Lsi Corporation | Systems and methods for mitigating stubborn errors in a data processing system |
US8854754B2 (en) * | 2011-08-19 | 2014-10-07 | Lsi Corporation | Systems and methods for local iteration adjustment |
US8543891B2 (en) * | 2011-09-21 | 2013-09-24 | Apple Inc. | Power-optimized decoding of linear codes |
US8768990B2 (en) | 2011-11-11 | 2014-07-01 | Lsi Corporation | Reconfigurable cyclic shifter arrangement |
US8850295B2 (en) | 2012-02-01 | 2014-09-30 | Lsi Corporation | Symbol flipping data processor |
US12212341B2 (en) * | 2012-02-27 | 2025-01-28 | Marvell Asia Pte Ltd | Decoding FEC codewords using LDPC codes defined by a parity check matrix which is defined by RPC and QC constraints |
US8949704B2 (en) | 2012-03-22 | 2015-02-03 | Lsi Corporation | Systems and methods for mis-correction correction in a data processing system |
US8739004B2 (en) | 2012-05-10 | 2014-05-27 | Lsi Corporation | Symbol flipping LDPC decoding system |
US8689076B2 (en) * | 2012-07-02 | 2014-04-01 | Lsi Corporation | Systems and methods for enhanced bit correlation usage |
US8640002B1 (en) * | 2012-07-10 | 2014-01-28 | Micron Technology, Inc. | Resolving trapping sets |
US9112539B2 (en) | 2012-10-18 | 2015-08-18 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for iterative data processing using feedback iteration |
US8724243B1 (en) | 2012-12-07 | 2014-05-13 | Lsi Corporation | Systems and methods for run length limited encoding |
US8996969B2 (en) | 2012-12-08 | 2015-03-31 | Lsi Corporation | Low density parity check decoder with miscorrection handling |
TWI619353B (en) * | 2013-07-03 | 2018-03-21 | Lsi公司 | Log-likelihood ratio (llr) dampening in low-density parity-check (ldpc) decoders |
FR3009462B1 (en) * | 2013-08-02 | 2019-08-23 | Thales | IMPROVED METHOD OF DECODING A CORRECTING CODE WITH MESSAGE PASSAGE, ESPECIALLY FOR DECODING LDPC CODES OR TURBO CODES |
US9094046B2 (en) | 2013-09-03 | 2015-07-28 | Lsi Corporation | Systems and methods for variable sector count spreading and de-spreading |
US8976471B1 (en) | 2013-09-05 | 2015-03-10 | Lsi Corporation | Systems and methods for two stage tone reduction |
US9436550B2 (en) | 2013-10-31 | 2016-09-06 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for internal disk drive data compression |
US9281840B2 (en) * | 2013-12-30 | 2016-03-08 | Saankhya Labs Private Limited | System and method for multi standard programmable LDPC decoder |
US9306600B2 (en) | 2014-01-06 | 2016-04-05 | Micron Technology, Inc. | Read threshold calibration for LDPC |
CN104834476B (en) | 2014-02-10 | 2016-10-19 | 安华高科技通用Ip(新加坡)公司 | The system and method for data alignment based on section end mark |
US10205470B2 (en) | 2014-02-14 | 2019-02-12 | Samsung Electronics Co., Ltd | System and methods for low complexity list decoding of turbo codes and convolutional codes |
KR102212163B1 (en) * | 2014-03-27 | 2021-02-04 | 삼성전자주식회사 | Decoding apparatus and method in mobile communication system using non-binary low-density parity-check codes |
US9184954B1 (en) | 2014-07-02 | 2015-11-10 | Seagate Technology Llc | Systems and methods for directed soft data perturbation in layered decoding |
US20160182083A1 (en) * | 2014-12-23 | 2016-06-23 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and Methods for Decoder Scheduling With Overlap and/or Switch Limiting |
US9384761B1 (en) | 2015-04-09 | 2016-07-05 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for flexible variable code rate support |
US10177787B1 (en) * | 2015-09-17 | 2019-01-08 | Seagate Technology Llc | Mitigation of error correction failure due to trapping sets |
US9911466B2 (en) | 2016-02-16 | 2018-03-06 | Micron Technology, Inc. | Read threshold voltage selection |
US10164656B2 (en) * | 2016-03-30 | 2018-12-25 | Silicon Motion Inc. | Bit flipping algorithm for providing soft information during hard decision hard decoding |
KR102559925B1 (en) * | 2016-07-21 | 2023-07-26 | 에스케이하이닉스 주식회사 | Ldpc decoder, semiconductor memory system and operating method thereof |
US10700706B2 (en) * | 2017-09-22 | 2020-06-30 | SK Hynix Inc. | Memory system with decoders and method of operating such memory system and decoders |
KR102582326B1 (en) * | 2018-09-20 | 2023-09-26 | 에스케이하이닉스 주식회사 | Error correction circuit and operating method thereof |
KR102643457B1 (en) * | 2018-11-19 | 2024-03-06 | 에스케이하이닉스 주식회사 | Ldpc decoder, semiconductor memory system and operating method thereof |
US10872013B2 (en) * | 2019-03-15 | 2020-12-22 | Toshiba Memory Corporation | Non volatile memory controller device and method for adjustment |
US11424766B1 (en) | 2020-01-31 | 2022-08-23 | Marvell Asia Pte Ltd. | Method and device for energy-efficient decoders |
TWI812411B (en) * | 2022-08-18 | 2023-08-11 | 慧榮科技股份有限公司 | Memory controller and method for bit flipping in low density parity codes |
TWI831333B (en) * | 2022-08-18 | 2024-02-01 | 慧榮科技股份有限公司 | Memory controller and method for accessing flash memory |
Citations (103)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3755779A (en) | 1971-12-14 | 1973-08-28 | Ibm | Error correction system for single-error correction, related-double-error correction and unrelated-double-error detection |
US4295218A (en) | 1979-06-25 | 1981-10-13 | Regents Of The University Of California | Error-correcting coding system |
US5048060A (en) | 1987-11-16 | 1991-09-10 | Nec Corporation | Digital signal receiving circuit with means for controlling a baud rate sampling phase by a power of sampled signals |
US5721745A (en) | 1996-04-19 | 1998-02-24 | General Electric Company | Parallel concatenated tail-biting convolutional code and decoder therefor |
US5734962A (en) | 1996-07-17 | 1998-03-31 | General Electric Company | Satellite communications system utilizing parallel concatenated coding |
US6023783A (en) | 1996-05-15 | 2000-02-08 | California Institute Of Technology | Hybrid concatenated codes and iterative decoding |
US6236686B1 (en) | 1997-02-27 | 2001-05-22 | Nec Corporation | Data processing equipment and method |
US6307901B1 (en) | 2000-04-24 | 2001-10-23 | Motorola, Inc. | Turbo decoder with decision feedback equalization |
US20020062468A1 (en) | 2000-09-29 | 2002-05-23 | Taku Nagase | Decoding apparatus and decoding method, and data receiving apparatus and data receiving method |
US20020166095A1 (en) | 2001-03-15 | 2002-11-07 | 3G.Com, Inc. | Mechanism for turbo decoding when CRC for partial blocks is provided |
US6550023B1 (en) | 1998-10-19 | 2003-04-15 | Hewlett Packard Development Company, L.P. | On-the-fly memory testing and automatic generation of bitmaps |
WO2003092170A1 (en) | 2002-04-26 | 2003-11-06 | Kongsberg Defence Communications As | Method and apparatus for the reception of digital communication signals |
US6678843B2 (en) | 1999-02-18 | 2004-01-13 | Interuniversitair Microelektronics Centrum (Imec) | Method and apparatus for interleaving, deinterleaving and combined interleaving-deinterleaving |
US6745157B1 (en) | 2000-06-02 | 2004-06-01 | Mitsubishi Electric Research Laboratories, Inc | Super-node normalized belief propagation for probabilistic systems |
US6760879B2 (en) | 1999-02-18 | 2004-07-06 | Interuniversitair Microelektronica Centrum (Imec) | System and method of turbo decoding |
WO2004079563A1 (en) | 2003-02-26 | 2004-09-16 | Flarion Technologies, Inc. | Soft information scaling for iterative decoding |
US6888897B1 (en) | 2000-04-27 | 2005-05-03 | Marvell International Ltd. | Multi-mode iterative detector |
US6910000B1 (en) | 2000-06-02 | 2005-06-21 | Mitsubishi Electric Research Labs, Inc. | Generalized belief propagation for probabilistic systems |
US20050193320A1 (en) | 2004-02-09 | 2005-09-01 | President And Fellows Of Harvard College | Methods and apparatus for improving performance of information coding schemes |
US20050204255A1 (en) | 2004-03-12 | 2005-09-15 | Nan-Hsiung Yeh | Cyclic redundancy check based message passing in Turbo Product Code decoding |
US20050283707A1 (en) | 2004-06-22 | 2005-12-22 | Eran Sharon | LDPC decoder for decoding a low-density parity check (LDPC) codewords |
US20060013306A1 (en) | 2004-07-15 | 2006-01-19 | Samsung Electronics Co., Ltd. | Motion information encoding/decoding apparatus and method and scalable video encoding/decoding apparatus and method employing them |
US20060036928A1 (en) | 2004-08-13 | 2006-02-16 | The Directv Group, Inc. | Code design and implementation improvements for low density parity check codes for multiple-input multiple-output channels |
US20060107181A1 (en) | 2004-10-13 | 2006-05-18 | Sameep Dave | Decoder architecture system and method |
US20060115802A1 (en) | 2000-05-11 | 2006-06-01 | Reynolds Thomas J | Interactive method and system for teaching decision making |
US7143333B2 (en) | 2004-08-09 | 2006-11-28 | Motorola, Inc. | Method and apparatus for encoding and decoding data |
US20060285852A1 (en) | 2005-06-21 | 2006-12-21 | Wenze Xi | Integrated maximum a posteriori (MAP) and turbo product coding for optical communications systems |
US20070011586A1 (en) | 2004-03-31 | 2007-01-11 | Belogolovy Andrey V | Multi-threshold reliability decoding of low-density parity check codes |
US20070011569A1 (en) | 2005-06-20 | 2007-01-11 | The Regents Of The University Of California | Variable-rate low-density parity check codes with constant blocklength |
US20070011573A1 (en) | 2005-05-27 | 2007-01-11 | Ramin Farjadrad | Method and apparatus for extending decoding time in an iterative decoder using input codeword pipelining |
JP2007036495A (en) | 2005-07-25 | 2007-02-08 | Sharp Corp | Reproducer, compressor, recorder and reproducing method |
US7181676B2 (en) | 2004-07-19 | 2007-02-20 | Texas Instruments Incorporated | Layered decoding approach for low density parity check (LDPC) codes |
US20070044006A1 (en) | 2005-08-05 | 2007-02-22 | Hitachi Global Technologies Netherlands, B.V. | Decoding techniques for correcting errors using soft information |
US20070071009A1 (en) | 2005-09-28 | 2007-03-29 | Thadi Nagaraj | System for early detection of decoding errors |
US20070089019A1 (en) | 2005-10-18 | 2007-04-19 | Nokia Corporation | Error correction decoder, method and computer program product for block serial pipelined layered decoding of structured low-density parity-check (LDPC) codes, including calculating check-to-variable messages |
US20070089018A1 (en) | 2005-10-18 | 2007-04-19 | Nokia Corporation | Error correction decoder, method and computer program product for block serial pipelined layered decoding of structured low-density parity-check (LDPC) codes, including reconfigurable permuting/de-permuting of data values |
US7219288B2 (en) | 2002-11-27 | 2007-05-15 | Koninklijke Philips Electronics N.V. | Running minimum message passing LDPC decoding |
US20070124652A1 (en) | 2005-11-15 | 2007-05-31 | Ramot At Tel Aviv University Ltd. | Method and device for multi phase error-correction |
US7237181B2 (en) | 2003-12-22 | 2007-06-26 | Qualcomm Incorporated | Methods and apparatus for reducing error floors in message passing decoders |
US20070147481A1 (en) | 2005-12-22 | 2007-06-28 | Telefonaktiebolaget Lm Ericsson (Publ) | Linear turbo equalization using despread values |
US20070153943A1 (en) | 2005-12-30 | 2007-07-05 | Nokia Corporation | Turbo equalization scheme |
US20070162788A1 (en) | 2003-12-30 | 2007-07-12 | Dignus-Jan Moelker | Method and device for calculating bit error rate of received signal |
US20070220408A1 (en) | 2004-05-26 | 2007-09-20 | Huggett Anthony R | Decoding a Concatenated Convolutional-Encoded and Block Encoded Signal |
US20070234178A1 (en) | 2003-02-26 | 2007-10-04 | Qualcomm Incorporated | Soft information scaling for interactive decoding |
WO2007114724A1 (en) | 2006-03-31 | 2007-10-11 | Intel Corporation | Layered decoder and method for performing layered decoding |
US7296216B2 (en) * | 2003-01-23 | 2007-11-13 | Broadcom Corporation | Stopping and/or reducing oscillations in low density parity check (LDPC) decoding |
WO2008004215A2 (en) | 2006-07-06 | 2008-01-10 | Provigent Ltd. | Communication link control using iterative code metrics |
US20080049869A1 (en) | 2006-08-24 | 2008-02-28 | Stmicroelectronics Sa | Method and device for layered decoding of a succession of blocks encoded with an ldpc code |
US7340671B2 (en) | 2003-10-10 | 2008-03-04 | Regents Of The University Of California | Decoding low density parity codes |
US7353444B2 (en) | 2004-05-07 | 2008-04-01 | Comtech Aha Corporation | LDPC architecture |
US20080082868A1 (en) | 2006-10-02 | 2008-04-03 | Broadcom Corporation, A California Corporation | Overlapping sub-matrix based LDPC (low density parity check) decoder |
US20080104485A1 (en) | 2005-01-19 | 2008-05-01 | Mikhail Yurievich Lyakh | Data Communications Methods and Apparatus |
US20080109701A1 (en) | 2006-10-30 | 2008-05-08 | Motorola, Inc. | Turbo Interference Suppression in Communication Systems |
US20080126910A1 (en) | 2006-06-30 | 2008-05-29 | Microsoft Corporation | Low dimensional spectral concentration codes and direct list decoding |
US20080148129A1 (en) | 2006-12-14 | 2008-06-19 | Regents Of The University Of Minnesota | Error detection and correction using error pattern correcting codes |
US20080163032A1 (en) | 2007-01-02 | 2008-07-03 | International Business Machines Corporation | Systems and methods for error detection in a memory system |
US20080235561A1 (en) | 2007-03-23 | 2008-09-25 | Quantum Corporation | Methodology and apparatus for soft-information detection and LDPC decoding on an ISI channel |
US20080276156A1 (en) | 2007-05-01 | 2008-11-06 | Texas A&M University System | Low density parity check decoder for regular ldpc codes |
US7457367B2 (en) | 2004-07-07 | 2008-11-25 | University Of Utah Research Foundation | Detector and method for estimating data probability in a multi-channel receiver |
US20080301517A1 (en) * | 2007-06-01 | 2008-12-04 | Agere Systems Inc. | Systems and methods for ldpc decoding with post processing |
US20090063931A1 (en) | 2007-08-27 | 2009-03-05 | Stmicroelectronics S.R.L | Methods and architectures for layered decoding of LDPC codes with minimum latency |
US20090083609A1 (en) | 2007-09-24 | 2009-03-26 | Nec Laboratories America, Inc. | Efficient low complexity high throughput ldpc decoding method and optimization |
JP2009100222A (en) | 2007-10-16 | 2009-05-07 | Toshiba Corp | Device and method for decoding low density parity check code |
US20090132897A1 (en) | 2007-11-19 | 2009-05-21 | Seagate Technology Llc | Reduced State Soft Output Processing |
US20090150745A1 (en) * | 2007-12-05 | 2009-06-11 | Aquantia Corporation | Trapping set decoding for transmission frames |
US20090235146A1 (en) | 2008-03-17 | 2009-09-17 | Agere Systems Inc. | Systems and Methods for Using Intrinsic Data for Regenerating Data from a Defective Medium |
US20090259912A1 (en) | 2008-04-11 | 2009-10-15 | Nec Laboratories America, Inc. | Ldpc codes and stochastic decoding for optical transmission |
US20090273492A1 (en) | 2008-05-02 | 2009-11-05 | Lsi Corporation | Systems and Methods for Queue Based Data Detection and Decoding |
US20090307566A1 (en) * | 2008-06-05 | 2009-12-10 | Samsung Electronics Co., Ltd. | Iterative decoding method and apparatus |
US20090319860A1 (en) * | 2008-06-23 | 2009-12-24 | Ramot At Tel Aviv University Ltd. | Overcoming ldpc trapping sets by decoder reset |
US20100037121A1 (en) | 2008-08-05 | 2010-02-11 | The Hong Kong University Of Science And Technology | Low power layered decoding for low density parity check decoders |
WO2010019168A1 (en) | 2008-08-15 | 2010-02-18 | Lsi Corporation | Ram list-decoding of near codewords |
US20100042806A1 (en) | 2008-08-15 | 2010-02-18 | Lsi Corporation | Determining index values for bits of a binary vector |
US20100050043A1 (en) | 2006-12-01 | 2010-02-25 | Commissariat A L'energie Atomique | Method and device for decoding ldpc codes and communication apparatus including such device |
US20100058152A1 (en) | 2008-09-04 | 2010-03-04 | Kabushiki Kaisha Toshiba | Decoding apparatus and method |
US7689888B2 (en) | 2005-02-07 | 2010-03-30 | Sony Corporation | Decoding apparatus and method and program |
US20100088575A1 (en) | 2008-10-07 | 2010-04-08 | Eran Sharon | Low density parity code (ldpc) decoding for memory with multiple log likelihood ratio (llr) decoders |
US7730377B2 (en) | 2004-07-22 | 2010-06-01 | Texas Instruments Incorporated | Layered decoding of low density parity check (LDPC) codes |
US7739558B1 (en) | 2005-06-22 | 2010-06-15 | Aquantia Corporation | Method and apparatus for rectifying errors in the presence of known trapping sets in iterative decoders and expedited bit error rate testing |
US7752523B1 (en) | 2006-02-13 | 2010-07-06 | Marvell International Ltd. | Reduced-complexity decoding of parity check codes |
US20100192043A1 (en) * | 2008-06-23 | 2010-07-29 | Ramot At Tel Aviv University Ltd. | Interruption criteria for block decoding |
US7770090B1 (en) | 2005-09-14 | 2010-08-03 | Trident Microsystems (Far East) Ltd. | Efficient decoders for LDPC codes |
US7805642B1 (en) | 2006-02-17 | 2010-09-28 | Aquantia Corporation | Low power iterative decoder using input data pipelining and voltage scaling |
US20110041029A1 (en) | 2009-08-14 | 2011-02-17 | Yedidia Jonathan S | Method and System for Decoding Graph-Based Codes Using Message-Passing with Difference-Map Dynamics |
US7895500B2 (en) | 2006-07-28 | 2011-02-22 | Via Telecom Co., Ltd. | Systems and methods for reduced complexity LDPC decoding |
US7904793B2 (en) | 2007-03-29 | 2011-03-08 | Sandisk Corporation | Method for decoding data in non-volatile storage using reliability metrics based on multiple reads |
US7941737B2 (en) | 2006-04-19 | 2011-05-10 | Tata Consultancy Services Limited | Low density parity check code decoder |
US7949927B2 (en) | 2006-11-14 | 2011-05-24 | Samsung Electronics Co., Ltd. | Error correction method and apparatus for predetermined error patterns |
US8010869B2 (en) | 2005-04-29 | 2011-08-30 | Stmicroelectronics N.V. | Method and device for controlling the decoding of a LDPC encoded codeword, in particular for DVB-S2 LDPC encoded codewords |
US8037394B2 (en) | 2007-06-29 | 2011-10-11 | Hitachi Global Storage Technologies Netherlands, B.V. | Techniques for generating bit reliability information in a post-processor using an error correction constraint |
US8046658B2 (en) | 2006-08-24 | 2011-10-25 | Stmicroelectronics Sa | Method and device for decoding blocks encoded with an LDPC code |
US8051363B1 (en) | 2007-01-16 | 2011-11-01 | Marvell International Ltd. | Absorb decode algorithm for 10GBase-T LDPC decoder |
US8103931B2 (en) | 2008-08-27 | 2012-01-24 | Mitsubishi Electric Research Laboratories, Inc. | Method for constructing large-girth quasi-cyclic low-density parity-check codes |
US8127209B1 (en) * | 2007-07-30 | 2012-02-28 | Marvell International Ltd. | QC-LDPC decoder with list-syndrome decoding |
US8151171B2 (en) | 2007-05-07 | 2012-04-03 | Broadcom Corporation | Operational parameter adaptable LDPC (low density parity check) decoder |
US8156409B2 (en) | 2008-02-29 | 2012-04-10 | Seagate Technology Llc | Selectively applied hybrid min-sum approximation for constraint node updates of LDPC decoders |
US8161345B2 (en) * | 2008-10-29 | 2012-04-17 | Agere Systems Inc. | LDPC decoders using fixed and adjustable permutators |
US8171367B2 (en) * | 2005-06-27 | 2012-05-01 | Thomson Licensing | Stopping criteria in iterative decoders |
US8205134B2 (en) | 2007-10-31 | 2012-06-19 | Hewlett-Packard Development Company, L.P. | Error detection method and apparatus |
US8205144B1 (en) | 2008-10-13 | 2012-06-19 | Marvell International Ltd. | Error event processing methods and systems |
US8214719B1 (en) | 2007-07-26 | 2012-07-03 | Marvell International Ltd. | Long latency protocol for hard disk controller interface |
US8219878B1 (en) * | 2007-12-03 | 2012-07-10 | Marvell International Ltd. | Post-processing decoder of LDPC codes for improved error floors |
US8255763B1 (en) | 2006-11-08 | 2012-08-28 | Marvell International Ltd. | Error correction system using an iterative product code |
-
2010
- 2010-06-30 US US12/827,652 patent/US8458555B2/en not_active Expired - Fee Related
Patent Citations (109)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3755779A (en) | 1971-12-14 | 1973-08-28 | Ibm | Error correction system for single-error correction, related-double-error correction and unrelated-double-error detection |
US4295218A (en) | 1979-06-25 | 1981-10-13 | Regents Of The University Of California | Error-correcting coding system |
US5048060A (en) | 1987-11-16 | 1991-09-10 | Nec Corporation | Digital signal receiving circuit with means for controlling a baud rate sampling phase by a power of sampled signals |
US5721745A (en) | 1996-04-19 | 1998-02-24 | General Electric Company | Parallel concatenated tail-biting convolutional code and decoder therefor |
US6023783A (en) | 1996-05-15 | 2000-02-08 | California Institute Of Technology | Hybrid concatenated codes and iterative decoding |
US5734962A (en) | 1996-07-17 | 1998-03-31 | General Electric Company | Satellite communications system utilizing parallel concatenated coding |
US6236686B1 (en) | 1997-02-27 | 2001-05-22 | Nec Corporation | Data processing equipment and method |
US6550023B1 (en) | 1998-10-19 | 2003-04-15 | Hewlett Packard Development Company, L.P. | On-the-fly memory testing and automatic generation of bitmaps |
US6678843B2 (en) | 1999-02-18 | 2004-01-13 | Interuniversitair Microelektronics Centrum (Imec) | Method and apparatus for interleaving, deinterleaving and combined interleaving-deinterleaving |
US6760879B2 (en) | 1999-02-18 | 2004-07-06 | Interuniversitair Microelektronica Centrum (Imec) | System and method of turbo decoding |
US6307901B1 (en) | 2000-04-24 | 2001-10-23 | Motorola, Inc. | Turbo decoder with decision feedback equalization |
US6888897B1 (en) | 2000-04-27 | 2005-05-03 | Marvell International Ltd. | Multi-mode iterative detector |
US20060115802A1 (en) | 2000-05-11 | 2006-06-01 | Reynolds Thomas J | Interactive method and system for teaching decision making |
US6910000B1 (en) | 2000-06-02 | 2005-06-21 | Mitsubishi Electric Research Labs, Inc. | Generalized belief propagation for probabilistic systems |
US6745157B1 (en) | 2000-06-02 | 2004-06-01 | Mitsubishi Electric Research Laboratories, Inc | Super-node normalized belief propagation for probabilistic systems |
US20020062468A1 (en) | 2000-09-29 | 2002-05-23 | Taku Nagase | Decoding apparatus and decoding method, and data receiving apparatus and data receiving method |
US20020166095A1 (en) | 2001-03-15 | 2002-11-07 | 3G.Com, Inc. | Mechanism for turbo decoding when CRC for partial blocks is provided |
WO2003092170A1 (en) | 2002-04-26 | 2003-11-06 | Kongsberg Defence Communications As | Method and apparatus for the reception of digital communication signals |
US7219288B2 (en) | 2002-11-27 | 2007-05-15 | Koninklijke Philips Electronics N.V. | Running minimum message passing LDPC decoding |
US7296216B2 (en) * | 2003-01-23 | 2007-11-13 | Broadcom Corporation | Stopping and/or reducing oscillations in low density parity check (LDPC) decoding |
US20070234178A1 (en) | 2003-02-26 | 2007-10-04 | Qualcomm Incorporated | Soft information scaling for interactive decoding |
WO2004079563A1 (en) | 2003-02-26 | 2004-09-16 | Flarion Technologies, Inc. | Soft information scaling for iterative decoding |
US7340671B2 (en) | 2003-10-10 | 2008-03-04 | Regents Of The University Of California | Decoding low density parity codes |
US20070234184A1 (en) | 2003-12-22 | 2007-10-04 | Qualcomm Incorporated | Methods and apparatus for reducing error floors in message passing decoders |
US7237181B2 (en) | 2003-12-22 | 2007-06-26 | Qualcomm Incorporated | Methods and apparatus for reducing error floors in message passing decoders |
US20070162788A1 (en) | 2003-12-30 | 2007-07-12 | Dignus-Jan Moelker | Method and device for calculating bit error rate of received signal |
US20050193320A1 (en) | 2004-02-09 | 2005-09-01 | President And Fellows Of Harvard College | Methods and apparatus for improving performance of information coding schemes |
US20050204255A1 (en) | 2004-03-12 | 2005-09-15 | Nan-Hsiung Yeh | Cyclic redundancy check based message passing in Turbo Product Code decoding |
US20070011586A1 (en) | 2004-03-31 | 2007-01-11 | Belogolovy Andrey V | Multi-threshold reliability decoding of low-density parity check codes |
US7353444B2 (en) | 2004-05-07 | 2008-04-01 | Comtech Aha Corporation | LDPC architecture |
US20070220408A1 (en) | 2004-05-26 | 2007-09-20 | Huggett Anthony R | Decoding a Concatenated Convolutional-Encoded and Block Encoded Signal |
US20050283707A1 (en) | 2004-06-22 | 2005-12-22 | Eran Sharon | LDPC decoder for decoding a low-density parity check (LDPC) codewords |
US7457367B2 (en) | 2004-07-07 | 2008-11-25 | University Of Utah Research Foundation | Detector and method for estimating data probability in a multi-channel receiver |
US20060013306A1 (en) | 2004-07-15 | 2006-01-19 | Samsung Electronics Co., Ltd. | Motion information encoding/decoding apparatus and method and scalable video encoding/decoding apparatus and method employing them |
US7181676B2 (en) | 2004-07-19 | 2007-02-20 | Texas Instruments Incorporated | Layered decoding approach for low density parity check (LDPC) codes |
US7730377B2 (en) | 2004-07-22 | 2010-06-01 | Texas Instruments Incorporated | Layered decoding of low density parity check (LDPC) codes |
US7143333B2 (en) | 2004-08-09 | 2006-11-28 | Motorola, Inc. | Method and apparatus for encoding and decoding data |
US20060036928A1 (en) | 2004-08-13 | 2006-02-16 | The Directv Group, Inc. | Code design and implementation improvements for low density parity check codes for multiple-input multiple-output channels |
US20060107181A1 (en) | 2004-10-13 | 2006-05-18 | Sameep Dave | Decoder architecture system and method |
US20080104485A1 (en) | 2005-01-19 | 2008-05-01 | Mikhail Yurievich Lyakh | Data Communications Methods and Apparatus |
US7689888B2 (en) | 2005-02-07 | 2010-03-30 | Sony Corporation | Decoding apparatus and method and program |
US8010869B2 (en) | 2005-04-29 | 2011-08-30 | Stmicroelectronics N.V. | Method and device for controlling the decoding of a LDPC encoded codeword, in particular for DVB-S2 LDPC encoded codewords |
US20070011573A1 (en) | 2005-05-27 | 2007-01-11 | Ramin Farjadrad | Method and apparatus for extending decoding time in an iterative decoder using input codeword pipelining |
US20070011569A1 (en) | 2005-06-20 | 2007-01-11 | The Regents Of The University Of California | Variable-rate low-density parity check codes with constant blocklength |
US20060285852A1 (en) | 2005-06-21 | 2006-12-21 | Wenze Xi | Integrated maximum a posteriori (MAP) and turbo product coding for optical communications systems |
US7739558B1 (en) | 2005-06-22 | 2010-06-15 | Aquantia Corporation | Method and apparatus for rectifying errors in the presence of known trapping sets in iterative decoders and expedited bit error rate testing |
US8171367B2 (en) * | 2005-06-27 | 2012-05-01 | Thomson Licensing | Stopping criteria in iterative decoders |
JP2007036495A (en) | 2005-07-25 | 2007-02-08 | Sharp Corp | Reproducer, compressor, recorder and reproducing method |
US20070044006A1 (en) | 2005-08-05 | 2007-02-22 | Hitachi Global Technologies Netherlands, B.V. | Decoding techniques for correcting errors using soft information |
US7725800B2 (en) | 2005-08-05 | 2010-05-25 | Hitachi Global Stroage Technologies Netherlands, B.V. | Decoding techniques for correcting errors using soft information |
US7770090B1 (en) | 2005-09-14 | 2010-08-03 | Trident Microsystems (Far East) Ltd. | Efficient decoders for LDPC codes |
US20070071009A1 (en) | 2005-09-28 | 2007-03-29 | Thadi Nagaraj | System for early detection of decoding errors |
US20070089019A1 (en) | 2005-10-18 | 2007-04-19 | Nokia Corporation | Error correction decoder, method and computer program product for block serial pipelined layered decoding of structured low-density parity-check (LDPC) codes, including calculating check-to-variable messages |
US20070089018A1 (en) | 2005-10-18 | 2007-04-19 | Nokia Corporation | Error correction decoder, method and computer program product for block serial pipelined layered decoding of structured low-density parity-check (LDPC) codes, including reconfigurable permuting/de-permuting of data values |
US20070124652A1 (en) | 2005-11-15 | 2007-05-31 | Ramot At Tel Aviv University Ltd. | Method and device for multi phase error-correction |
US20070147481A1 (en) | 2005-12-22 | 2007-06-28 | Telefonaktiebolaget Lm Ericsson (Publ) | Linear turbo equalization using despread values |
US20070153943A1 (en) | 2005-12-30 | 2007-07-05 | Nokia Corporation | Turbo equalization scheme |
US7752523B1 (en) | 2006-02-13 | 2010-07-06 | Marvell International Ltd. | Reduced-complexity decoding of parity check codes |
US7805642B1 (en) | 2006-02-17 | 2010-09-28 | Aquantia Corporation | Low power iterative decoder using input data pipelining and voltage scaling |
WO2007114724A1 (en) | 2006-03-31 | 2007-10-11 | Intel Corporation | Layered decoder and method for performing layered decoding |
US7941737B2 (en) | 2006-04-19 | 2011-05-10 | Tata Consultancy Services Limited | Low density parity check code decoder |
US20080126910A1 (en) | 2006-06-30 | 2008-05-29 | Microsoft Corporation | Low dimensional spectral concentration codes and direct list decoding |
WO2008004215A2 (en) | 2006-07-06 | 2008-01-10 | Provigent Ltd. | Communication link control using iterative code metrics |
US7895500B2 (en) | 2006-07-28 | 2011-02-22 | Via Telecom Co., Ltd. | Systems and methods for reduced complexity LDPC decoding |
US20080049869A1 (en) | 2006-08-24 | 2008-02-28 | Stmicroelectronics Sa | Method and device for layered decoding of a succession of blocks encoded with an ldpc code |
US8046658B2 (en) | 2006-08-24 | 2011-10-25 | Stmicroelectronics Sa | Method and device for decoding blocks encoded with an LDPC code |
US20080082868A1 (en) | 2006-10-02 | 2008-04-03 | Broadcom Corporation, A California Corporation | Overlapping sub-matrix based LDPC (low density parity check) decoder |
US20080109701A1 (en) | 2006-10-30 | 2008-05-08 | Motorola, Inc. | Turbo Interference Suppression in Communication Systems |
US8255763B1 (en) | 2006-11-08 | 2012-08-28 | Marvell International Ltd. | Error correction system using an iterative product code |
US7949927B2 (en) | 2006-11-14 | 2011-05-24 | Samsung Electronics Co., Ltd. | Error correction method and apparatus for predetermined error patterns |
US20100050043A1 (en) | 2006-12-01 | 2010-02-25 | Commissariat A L'energie Atomique | Method and device for decoding ldpc codes and communication apparatus including such device |
US20080148129A1 (en) | 2006-12-14 | 2008-06-19 | Regents Of The University Of Minnesota | Error detection and correction using error pattern correcting codes |
US20080163032A1 (en) | 2007-01-02 | 2008-07-03 | International Business Machines Corporation | Systems and methods for error detection in a memory system |
US8051363B1 (en) | 2007-01-16 | 2011-11-01 | Marvell International Ltd. | Absorb decode algorithm for 10GBase-T LDPC decoder |
US20080235561A1 (en) | 2007-03-23 | 2008-09-25 | Quantum Corporation | Methodology and apparatus for soft-information detection and LDPC decoding on an ISI channel |
US7904793B2 (en) | 2007-03-29 | 2011-03-08 | Sandisk Corporation | Method for decoding data in non-volatile storage using reliability metrics based on multiple reads |
US20080301521A1 (en) | 2007-05-01 | 2008-12-04 | Texas A&M University System | Low density parity check decoder for irregular ldpc codes |
US20080276156A1 (en) | 2007-05-01 | 2008-11-06 | Texas A&M University System | Low density parity check decoder for regular ldpc codes |
US8151171B2 (en) | 2007-05-07 | 2012-04-03 | Broadcom Corporation | Operational parameter adaptable LDPC (low density parity check) decoder |
US20080301517A1 (en) * | 2007-06-01 | 2008-12-04 | Agere Systems Inc. | Systems and methods for ldpc decoding with post processing |
US8037394B2 (en) | 2007-06-29 | 2011-10-11 | Hitachi Global Storage Technologies Netherlands, B.V. | Techniques for generating bit reliability information in a post-processor using an error correction constraint |
US8214719B1 (en) | 2007-07-26 | 2012-07-03 | Marvell International Ltd. | Long latency protocol for hard disk controller interface |
US8301984B1 (en) | 2007-07-30 | 2012-10-30 | Marvell International Ltd. | QC-LDPC decoder with list-syndrome decoding |
US8127209B1 (en) * | 2007-07-30 | 2012-02-28 | Marvell International Ltd. | QC-LDPC decoder with list-syndrome decoding |
US20090063931A1 (en) | 2007-08-27 | 2009-03-05 | Stmicroelectronics S.R.L | Methods and architectures for layered decoding of LDPC codes with minimum latency |
US20090083609A1 (en) | 2007-09-24 | 2009-03-26 | Nec Laboratories America, Inc. | Efficient low complexity high throughput ldpc decoding method and optimization |
JP2009100222A (en) | 2007-10-16 | 2009-05-07 | Toshiba Corp | Device and method for decoding low density parity check code |
US8205134B2 (en) | 2007-10-31 | 2012-06-19 | Hewlett-Packard Development Company, L.P. | Error detection method and apparatus |
US20090132897A1 (en) | 2007-11-19 | 2009-05-21 | Seagate Technology Llc | Reduced State Soft Output Processing |
US8219878B1 (en) * | 2007-12-03 | 2012-07-10 | Marvell International Ltd. | Post-processing decoder of LDPC codes for improved error floors |
US8020070B2 (en) | 2007-12-05 | 2011-09-13 | Aquantia Corporation | Trapping set decoding for transmission frames |
US20090150745A1 (en) * | 2007-12-05 | 2009-06-11 | Aquantia Corporation | Trapping set decoding for transmission frames |
US8156409B2 (en) | 2008-02-29 | 2012-04-10 | Seagate Technology Llc | Selectively applied hybrid min-sum approximation for constraint node updates of LDPC decoders |
US20090235146A1 (en) | 2008-03-17 | 2009-09-17 | Agere Systems Inc. | Systems and Methods for Using Intrinsic Data for Regenerating Data from a Defective Medium |
US20090259912A1 (en) | 2008-04-11 | 2009-10-15 | Nec Laboratories America, Inc. | Ldpc codes and stochastic decoding for optical transmission |
US20090273492A1 (en) | 2008-05-02 | 2009-11-05 | Lsi Corporation | Systems and Methods for Queue Based Data Detection and Decoding |
US20090307566A1 (en) * | 2008-06-05 | 2009-12-10 | Samsung Electronics Co., Ltd. | Iterative decoding method and apparatus |
US20100192043A1 (en) * | 2008-06-23 | 2010-07-29 | Ramot At Tel Aviv University Ltd. | Interruption criteria for block decoding |
US20090319860A1 (en) * | 2008-06-23 | 2009-12-24 | Ramot At Tel Aviv University Ltd. | Overcoming ldpc trapping sets by decoder reset |
US20100037121A1 (en) | 2008-08-05 | 2010-02-11 | The Hong Kong University Of Science And Technology | Low power layered decoding for low density parity check decoders |
US20100042806A1 (en) | 2008-08-15 | 2010-02-18 | Lsi Corporation | Determining index values for bits of a binary vector |
US20100042890A1 (en) | 2008-08-15 | 2010-02-18 | Lsi Corporation | Error-floor mitigation of ldpc codes using targeted bit adjustments |
WO2010019168A1 (en) | 2008-08-15 | 2010-02-18 | Lsi Corporation | Ram list-decoding of near codewords |
US8103931B2 (en) | 2008-08-27 | 2012-01-24 | Mitsubishi Electric Research Laboratories, Inc. | Method for constructing large-girth quasi-cyclic low-density parity-check codes |
US20100058152A1 (en) | 2008-09-04 | 2010-03-04 | Kabushiki Kaisha Toshiba | Decoding apparatus and method |
US20100088575A1 (en) | 2008-10-07 | 2010-04-08 | Eran Sharon | Low density parity code (ldpc) decoding for memory with multiple log likelihood ratio (llr) decoders |
US8205144B1 (en) | 2008-10-13 | 2012-06-19 | Marvell International Ltd. | Error event processing methods and systems |
US8161345B2 (en) * | 2008-10-29 | 2012-04-17 | Agere Systems Inc. | LDPC decoders using fixed and adjustable permutators |
US20110041029A1 (en) | 2009-08-14 | 2011-02-17 | Yedidia Jonathan S | Method and System for Decoding Graph-Based Codes Using Message-Passing with Difference-Map Dynamics |
Non-Patent Citations (55)
Title |
---|
Alghonaim, E., et al., "Improving BER Performance of LDPC codes Based on Intermediate Decoding Results," Signal Processing and Communications; 2007; ICSPC, 2007; IEEE International Conference; IEEE; Piscataway, NJ; USA; Nov. 24, 2007; pp. 1547-1550; XP031380831. |
Amin Shokrollahi-"LDPC Codes: An Introduction, in Coding, Cryptography and Combinatorics",Computer Science and Applied Logic, Birkhauser, Basel, 2004, pp. 85-110, vol. 23. |
Andrew J. Blanksby and Chris J. Howland-"A 690-mW 1-Gb/s 1024-b, Rate-1/2 Low-Density Parity-Check Code Decoder", IEEE Journal of Solid-State Circuits, Mar. 2002.pp. 404-412,vol. 37, No. 3. |
Badri N. Vellambi R, and Faramarz Fekri, "An Improved Decoding Algorithm for Low-Density Parity-Check Codes over the Binary Erasure Channel", IEEE Globecom 2005 proceedings, pp. 1182-1186. |
Casado, V., et al., "Informed Dynamic Scheduling for Belief-Propagation Decoding of LDPC Codes," IEEE International Conference on Communications, Jun. 24-28, 2007, pp. 932-937. |
Cavus et al., "A Performance Improvement and Error Floor Avoidance Technique for Belief Propagation Decoding of LDPC Codes," IEEE 16th International Symposium, Personal, Indoor & Mobile Radio Communications (PIMRC), Berlin, Germany Sep. 11-14, 2005, pp. 2386-2390. |
Cavus, Enver et al., "An IS Simulation Technique for Very Low BER Performance Evaluation of LDPC Codes," IEEE International Conference on Communications, Jun. 1, 2006, pp. 1095-1100. |
Cole, Chad A. and Hall, Eric K., "Analysis and Design of Moderate Length Regular LDPC Codes with Low Error Floors," Proc, 40th Conf. Information Sciences and Systems, Princeton, NJ, 2006, 6 pgs. |
D.J.C. Mackay and R.M. Neal-"Near Shannon limit performance of low density parity check codes", Electronics Letters Mar. 13, 1997, pp. 458-459, vol. 33 No. 6. |
Dale E. Hocevar-"A Reduced Complexity Decoder Architecture Via Layered Decoding of LDPC Codes", IEEE Workshop on Signal Processing Systems, 2004, pp. 107-112. |
David J.C. Mackay-"Information Theory, Inference, and Learning Algorithms", Cambridge University Press Sep. 2003, pp. 640. |
Dehkordi, M.K,; Banihashemi, A.H.;, "An Efficient Algorithm for Finding Dominant Trapping Sets of LDPC Codes," Turbo Codes and Iterative Information Processing (ISTC), 2010 6th International Symposium on, pp. 444-448, Sep. 6-10, 2010. |
E. Papagiannis, C. Tjhai, M. Ahmed, M. Ambroze, M. Tomlinson-"Improved Iterative Decoding for Perpendicular Magnetic Recording", The ISCTA 2005 Conference on Feb. 4, 2005,pp. 1-4. |
Gunnam, Kiran K., Choi, Gwan S., and Yeary, Mark B., "Technical Note on Iterative LDPC Solutions for Turbo Equalization," Texas A&M Technical Note, Department of ECE, Texas A&M University, College Station, TX 77843, Jul. 2006 (available online at http://dropzone.tamu.edu), pp. 1-5. |
Hao Zhong,Tong Zhang-"Block-LDPC: A Practical LDPC Coding System Design Approach", IEEE transactions on circuits and systems-I: Regular Papers, Apr. 2005, pp. 766-775, vol. 52. |
Jinghu Chen, Ajay Dholakia, Evangelos Eleftheriou, Marc P. C. Fossorier, Xiao-Yu Hu, "Reduced-Complexity Decoding of LDPC Codes", IEEE Transactions on Communications, Aug. 2005, pp. 1288-1299,vol. 53, No. 8. |
K. Gunnam "Area and Energy Efficient VLSI Architectures for Low-Density Parity-Check Decoders Using an On-The-Fly Computation" dissertation at Texas A&M University, Dec. 2006. |
K. Gunnam et al., "Value-Reuse Properties of Min-Sum for GF (q)" (dated Jul. 2008) Dept. of ECE, Texas A&M University Technical Note, published about Aug. 2010. |
K. Gunnam et al., "Value-Reuse Properties of Min-Sum for GF(q)" (dated Oct. 2006) Dept. of ECE, Texas A&M University Technical Note, published about Aug. 2010. |
Kiran Gunnam, Gwan Choi, Mark Yeary-"An LDPC decoding schedule for memory access reduction", IEEE International Conference on Acoustics, Speech, and Signal Processing (ICASSP) 2004, pp. 173-176, vol. 15. |
Kiran Gunnam, Gwan Choi, Weihuang Wang, Mark Yeary-"Multi-Rate Layered Decoder Architecture for Block LDPC Codes of the IEEE 802, 11n Wireless Standard", IEEE International Symposium on Circuits and Systems (ISCAS) 2007, pp. 1645-1648. |
Kiran Gunnam, Weihuang Wang, Gwan Choi, Mark Yeary-"VLSI Architectures for Turbo Decoding Message Passing Using Min-Sum for Rate-Compatible Array LDPC Codes", 2nd International Symposium on Wireless Pervasive Computing (ISWPC), 2007, pp. 561-566. |
Kiran K. Gunnam, Gwan S. Choi, and Mark B. Yeary-"A Parallel VLSI Architecture for Layered Decoding for Array LDPC Codes", 20th International Conference on VLSI Design, 2007,6th International Conference on Embedded Systems, Jan. 2007 pp.738-743. |
Kiran K. Gunnam, Gwan S. Choi, Mark B. Yeary and Mohammed Atiquzzaman-"VLSI Architectures for Layered Decoding for Irregular LDPC Codes of WiMax", IEEE International Conference on Communications (ICC), 2007, pp. 4542-4547. |
Kiran K. Gunnam, Gwan S. Choi, Mark B. Yeary, Shaohua Yang and Yuanxing Lee- "Next Generation Iterative LDPC Solutions for Magnetic Recording Storage", 42nd Asilomar Conference on Signals, Systems and Computers, 2008, pp. 1148-1152. |
Kiran K. Gunnam, Gwan S. Choi, Weihuang Wang, and Mark B. Yeary-"A Parallel VLSI Architecture for Layered Decoding",Proceedings of the 20th International Conference on VLSI Design, 6th International Conference: Embedded Systems, 2007, pp. 738-743. |
Kiran K. Gunnam, Gwan S. Choi, Weihuang Wang, Euncheol Kim, and Mark B. Yeary-"Decoding of Quasi-cyclic LDPC Codes Using an On-the-Fly Computation", Fortieth Asilomar Conference on Signals, Systems and Computers (ACSSC), 2006, pp. 1192-1199. |
Laendner, S.; Milenkovic, O.;, "LDPC Codes Based on Latin Squares: Cycle Structure, Stopping Set, and Trapping Set Analysis," Communications, IEEE Transactions on, vol. 55, No. 2, pp. 303-312, Feb. 2007. |
Mohammad M. Mansour and Naresh R. Shanbhag- "Low Power VLSI decoder architectures for LDPC codes" International Symposium on Low Power Electronics and Design Proceedings of the 2002 , ICIMS Research Center, 2002, pp. 284-289. |
Mohammad M. Mansour, and Naresh R. Shanbhag-"A 640-Mb/s 2048-Bit Programmable LDPC Decoder Chip", IEEE Journal of Solid-State Circuits, Mar. 2006, pp. 684-698,vol. 41, No. 3. |
PCT International Search Report dated Feb. 12, 2009 from International Application No. PCT/US 08/86523. |
PCT International Search Report dated Feb. 9, 2009 from International Application No. PCT/US 08/86537. |
PCT International Search Report dated May 15, 2009 from International Application No. PCT/US 09/39279. |
PCT International Search Report dated May 15, 2009 from International Application No. PCT/US 09/39918. |
PCT International Search Report dated May 28, 2009 from International Application No. PCT/US 09/41215. |
Presman, N., et al., "Efficient Layers-based Schedules for Iterative Decoding of LDPC Codes," IEEE International Symposium on Information Theory, Jul. 6-11, 2008, pp. 1148-1152. |
Pusane, A.E.; Costello, D.J.; Mitchell, D.G.M;, "Trapping Set Analysis of Protograph-Based LDPC Convolutional Codes," Information Theory, 2009. ISIT 2009. IEEE International Symposium on, vol., No., pp. 561-565, Jun. 28, 2009-Jul. 3, 2009. |
R. Michael Tanner, Deepak Sridhara, Arvind Sridharan, Thomas E. Fuja, and Daniel J. Costello, Jr-"LDPC Block and Convolutional Codes Based on Circulant Matrices", IEEE Transactions on Information Theory, Dec. 2004, pp. 2966-2984, vol. 50, No. 12. |
R.Michael Tanner-"A Recursive Approach to Low Complexity Codes",IEEE transaction on Information Theory, Sep. 1981,pp. 533-547,vol. IT-27, No. 5. |
Radosavljevic, P., et al., "Optimized Message Passing Schedules for LDPC Decoding," Conference Record of the Thirty-Ninth Asilomar conference on Signals, Systems and Computers, Oct. 28, 2005-Nov. 1, 2005, pp. 591-595. |
Richardson, Tom, "Error Floors of LDPC Codes," Allerton Conf. on Communication, Control and Computing, (Monticello, Illinois), Oct. 2003, pp. 1426-1435. |
Robert G. Gallager-"Low Density Parity-Check Codes",Cambridge Mass Jul. 1963,pp. 90. |
Sakai, R., et al., "Reduced Complexity Decoding Based on Approximation of Update Function for Low-Density Parity-Check Codes," Transactions of the Institute of Electronics, Information and Communication Engineers, Feb. 1, 2007, vol. J90-A, No. 2, pp. 83-91. |
Sripimanwat, K., "Turbo Code Applications: A Journey From a Paper to Realization", Oct. 26, 2005, Springer, p. 27. |
Stefan Landner, Olgica Milenkovic-"Algorithmic and Combinatorial Analysis of Trapping Sets in Structured LDPC Codes", International Conference on Wireless Networks, Communications and Mobile Computing, 2005, pp. 630-635, vol. 1. |
T. Richardson and R. Urbanke-"Modern Coding Theory", Cambridge University Press, Preliminary version-Oct. 18, 2007, pp. 590. |
Thomas J. Richardson and Rudiger L. Urbanke-"Efficient Encoding of Low-Density Parity-Check Codes", IEEE Transactions on Information Theory, Feb. 2001,pp. 638-656,vol. 47, No. 2. |
Tom Richardson-"Error Floors of LDPC Codes", IEEE Transactions on Information Theory, Feb. 2001, pp. 1426-1435,vol. 47, No. 2. |
Tuchler, M., et al., "Improved Receivers for Digital High Frequency Waveforms Using Turbo Equalization," Military Communications Conference; Milcom 2002 Proceedings; Anaheim, CA, Oct. 7-10, 2002; IEEE Military Communications Conference, New York, NY; IEEE; US, vol. 1, Oct. 7, 2002; pp. 99-104; XP002966498. |
Vila Casado, Andres I. "Variable-rate Low-denisty Parity-check Codes with Constant Blocklength," UCLA Technologies Available for Licensing Copyright © 2009 The Regents of the University of California. http://www.research.ucla.edu/tech/ucla05-074.htm (2 pages). |
Vila Casado, Andres I., Weng, Wen-Yen and Wesel, Richard D. "Multiple Rate Low-Density Parity-Check Codes with Constant Blocklength," IEEE 2004, pp. 2010-2014. |
Vila Casado, Andres I., Weng, Wen-Yen, Valle, Stefano and Wesel, Richard D. "Multiple-Rate Low-Density Parity-Check Codes with Constant Blocklength," IEEE Transactions on Communications, vol. 57, No. 1, Jan. 2009; pp. 75-83. |
Yang Han and William E. Ryan-"LDPC Decoder Strategies for Achieving Low Error Floors", Proceedings of Information Theory and Applications Workshop, San Diego, CA, Jan. 2008, pp. 1-10. |
Yang Han, William E. Ryan-"Low-Floor Decoders for LDPC Codes", IEEE Transactions on Communications, vol. 57, No. 6, Jun. 2009, pp. 1663-1673. |
Zheng, H., et al., "MMSE-Based Design of Scaled and Offset BP-Based Decoding Algorithms on the Fast Rayleigh Fading Channel," IEEE International Symposium on Circuits and Systems, May 24, 2006, pp. 2061-2064. |
Cited By (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8782487B2 (en) * | 2012-04-18 | 2014-07-15 | Lsi Corporation | Systems and methods for locating and correcting decoder mis-corrections |
US20130283114A1 (en) * | 2012-04-18 | 2013-10-24 | Lsi Corporation | Systems and Methods for Locating and Correcting Decoder Mis-Corrections |
US8782488B2 (en) * | 2012-04-20 | 2014-07-15 | Lsi Corporation | Systems and methods for back step data decoding |
US9274889B2 (en) | 2013-05-29 | 2016-03-01 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for data processing using global iteration result reuse |
US8959414B2 (en) | 2013-06-13 | 2015-02-17 | Lsi Corporation | Systems and methods for hybrid layer data decoding |
US8917466B1 (en) | 2013-07-17 | 2014-12-23 | Lsi Corporation | Systems and methods for governing in-flight data sets in a data processing system |
US8817404B1 (en) | 2013-07-18 | 2014-08-26 | Lsi Corporation | Systems and methods for data processing control |
US8908307B1 (en) | 2013-08-23 | 2014-12-09 | Lsi Corporation | Systems and methods for hard disk drive region based data encoding |
US9196299B2 (en) | 2013-08-23 | 2015-11-24 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for enhanced data encoding and decoding |
US9400797B2 (en) | 2013-09-17 | 2016-07-26 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for recovered data stitching |
US9298720B2 (en) | 2013-09-17 | 2016-03-29 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for fragmented data recovery |
US9219503B2 (en) | 2013-10-16 | 2015-12-22 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for multi-algorithm concatenation encoding and decoding |
US9323606B2 (en) | 2013-11-21 | 2016-04-26 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for FAID follower decoding |
US9331716B2 (en) | 2014-02-10 | 2016-05-03 | Avago Technologies General Ip (Singapore) Pte. Ltd. | Systems and methods for area efficient data encoding |
US9378765B2 (en) | 2014-04-03 | 2016-06-28 | Seagate Technology Llc | Systems and methods for differential message scaling in a decoding process |
US10164657B2 (en) | 2014-04-03 | 2018-12-25 | Seagate Technology Llc | Systems and methods for differential message scaling in a decoding process |
US20210288746A1 (en) * | 2020-03-10 | 2021-09-16 | Tesat-Spacecom Gmbh & Co. Kg | Error Correction for LDPC Decoders |
US11626889B1 (en) * | 2021-11-16 | 2023-04-11 | L3Harris Technologies, Inc. | Partial update sharing in joint LDPC decoding and ancillary processors |
Also Published As
Publication number | Publication date |
---|---|
US20120005551A1 (en) | 2012-01-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8458555B2 (en) | Breaking trapping sets using targeted bit adjustment | |
US8464128B2 (en) | Breaking unknown trapping sets using a database of known trapping sets | |
US8464142B2 (en) | Error-correction decoder employing extrinsic message averaging | |
US8499226B2 (en) | Multi-mode layered decoding | |
EP2307960B1 (en) | Error-floor mitigation of codes using write verification | |
KR101473046B1 (en) | Improved turbo-equalization methods for iterative decoders | |
US8578256B2 (en) | Low-latency decoder | |
US9356623B2 (en) | LDPC decoder variable node units having fewer adder stages | |
CN104052501B (en) | The m-ary LDPC code coding method of low complex degree | |
Zimmermann et al. | Reduced complexity LDPC decoding using forced convergence | |
US8489973B1 (en) | Numerical solution on LLR exchange in turbo equalization | |
Lim et al. | A novel bit flipping decoder for systematic LDPC codes |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: LSI CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GUNNAM, KIRAN;REEL/FRAME:024618/0917 Effective date: 20100629 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AG Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:LSI CORPORATION;AGERE SYSTEMS LLC;REEL/FRAME:032856/0031 Effective date: 20140506 |
|
AS | Assignment |
Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LSI CORPORATION;REEL/FRAME:035390/0388 Effective date: 20140814 |
|
AS | Assignment |
Owner name: AGERE SYSTEMS LLC, PENNSYLVANIA Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENT RIGHTS (RELEASES RF 032856-0031);ASSIGNOR:DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AGENT;REEL/FRAME:037684/0039 Effective date: 20160201 Owner name: LSI CORPORATION, CALIFORNIA Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENT RIGHTS (RELEASES RF 032856-0031);ASSIGNOR:DEUTSCHE BANK AG NEW YORK BRANCH, AS COLLATERAL AGENT;REEL/FRAME:037684/0039 Effective date: 20160201 |
|
AS | Assignment |
Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH CAROLINA Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD.;REEL/FRAME:037808/0001 Effective date: 20160201 Owner name: BANK OF AMERICA, N.A., AS COLLATERAL AGENT, NORTH Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD.;REEL/FRAME:037808/0001 Effective date: 20160201 |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
SULP | Surcharge for late payment | ||
AS | Assignment |
Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD., SINGAPORE Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS;ASSIGNOR:BANK OF AMERICA, N.A., AS COLLATERAL AGENT;REEL/FRAME:041710/0001 Effective date: 20170119 Owner name: AVAGO TECHNOLOGIES GENERAL IP (SINGAPORE) PTE. LTD Free format text: TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS;ASSIGNOR:BANK OF AMERICA, N.A., AS COLLATERAL AGENT;REEL/FRAME:041710/0001 Effective date: 20170119 |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20210604 |