US20150188579A1 - Efficient implementation to perform iterative decoding with large iteration counts - Google Patents

Efficient implementation to perform iterative decoding with large iteration counts Download PDF

Info

Publication number
US20150188579A1
US20150188579A1 US14/547,335 US201414547335A US2015188579A1 US 20150188579 A1 US20150188579 A1 US 20150188579A1 US 201414547335 A US201414547335 A US 201414547335A US 2015188579 A1 US2015188579 A1 US 2015188579A1
Authority
US
United States
Prior art keywords
iterations
decoder
elastic
code
buffer
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.)
Abandoned
Application number
US14/547,335
Inventor
Carl Scarpa
Edward Schell
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sirius XM Radio Inc
Original Assignee
Sirius XM Radio Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Sirius XM Radio Inc filed Critical Sirius XM Radio Inc
Priority to US14/547,335 priority Critical patent/US20150188579A1/en
Assigned to SIRIUS XM RADIO INC. reassignment SIRIUS XM RADIO INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SCARPA, CARL, SCHELL, EDWARD
Publication of US20150188579A1 publication Critical patent/US20150188579A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, 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/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error 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/11Error 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/1102Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
    • H03M13/1105Decoding
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, 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/65Purpose and implementation aspects
    • H03M13/6502Reduction of hardware complexity or efficient processing
    • H03M13/6505Memory efficient implementations
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, 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/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error 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
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, 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/37Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35
    • H03M13/3746Decoding methods or techniques, not specific to the particular type of coding provided for in groups H03M13/03 - H03M13/35 with iterative decoding

Definitions

  • the present invention relates to systems and methods for implementing iterative error correcting codes, and more particularly to systems and methods to improve the performance of a constant bit rate iterative decoder.
  • LDPC codes originally invented in 1962 by Gallagher, have recently been utilized in various communications applications. Because LDPC codes are based on an iterative decoding scheme, the performance of an LPDC decoder is highly dependent upon the number of iterations available to properly decode the information. Under poor signal conditions, a decode instance can consume hundreds of iterations and still be on the road to convergence. As a matter of implementation, designing decoder architectures capable of achieving large iteration counts can be quite difficult. Systems with large block sizes and/or high data rates can further exacerbate the problem, placing a physical limit on the number of iterations that can be performed between code blocks. However, some systems may not require that a consistently large number of iterations be available for each code block.
  • Decoder design could be made simpler for such systems provided that such design could also adequately support sporadic demands (which at some times are sustained over multiple code blocks) for high iteration counts.
  • an LDPC decoder can be designed, for example, to support less than the maximum possible number of iterations, and can be, for example, mated to elastic input and output buffers.
  • the decoder can, for example, run at such maximum number of iterations and the elastic input buffer can, for example, hold code blocks waiting to be processed so as to maintain a constant input rate.
  • the output buffer can store those code blocks once they have been processed so as to preserve a constant output rate.
  • FIG. 1 depicts an exemplary iterative decoder and exemplary input and output buffers after initialization according to an exemplary embodiment of the present invention
  • FIG. 2 depicts the exemplary iterative decoder and the exemplary input and output buffers of FIG. 1 after using two hundred iterations for one code block according to an exemplary embodiment of the present invention
  • FIG. 3 depicts the exemplary iterative decoder and the exemplary input and output buffers of FIG. 2 after an additional 200 iterations on one code block have been performed according to an exemplary embodiment of the present invention
  • FIG. 4 depicts the exemplary iterative decoder and the exemplary input and output buffers of FIG. 3 after two decode cycles have been completed according to an exemplary embodiment of the present invention.
  • LDPC Low Density Parity Code
  • Iterative codes include, amongst other examples, LDPC codes, turbo codes, and variantions of those.
  • Iterative algorithms are understood to be decoding algorithms that utilize a variable number of recursive steps, have some measure of convergence, and operate on blocks of data.
  • LDPC codes Simulations of certain LDPC codes, for example, have shown that an average of forty (40) iterations are required for decoding near the waterfall region, but as many as several hundreds are occasionally required to successfully converge. Because a decoder utilizing such an LDPC code seldom needs the full maximum number of iterations to converge properly, designing a decoder capable of supporting the maximum iterations on each code block can be highly inefficient, and in some cases may not even be possible. In exemplary embodiments of the present invention a more practical solution can be implemented. For example, a decoder can be designed with less than the maximum number of iterations, treating code blocks that need more iterations as special conditions. In so doing, the complexity of the decoder can be greatly reduced. Since such an exemplary decoder nominally uses less iterations than it is capable of, there is a potential for the wasted iterations to be saved for use on more difficult code blocks.
  • a decoder can, for example, be mated to elastic buffers at its input and output. After initialization, for example, the output buffer can be assumed to be running near capacity, and the input buffer can be assumed to be running near empty.
  • each code block handed to the decoder can, for example, be processed using a maximum number of iterations, M, spanning multiple code blocks, where M can be, for example, a number far greater than the number of iterations the decoder is capable of processing during the duration of one code block in time, which is the nominal iteration count, N, of the decoder.
  • M can be, for example, an integer multiple of N. If the decoder utilizes more than such N nominal iterations, an elastic input buffer can, for example, begin to fill up, while an elastic output buffer can begin to drain. Further code blocks may also be processed at more than the nominal number of iterations, as long as there is enough room left in the input buffer to queue subsequent code blocks.
  • code blocks requiring less than the nominal number of iterations of the decoder can be processed using such a lesser number of iterations, provided that there is enough storage at the output buffer.
  • This allows the datastream to propogate at a constant input and output rate through the decoder while the decoder processes individual code blocks at variable iteration counts, and thus at variable rates.
  • the buffers will reach their limit and the decoder will be limited to processing each code block at the nominal iteration count.
  • the buffers can begin to settle back towards their initial state.
  • the decoder can then, for example, simply hold off processing any data until the next code block arrives.
  • the sizes of the elastic buffers can, for example, be chosen based upon the generally expected number of consecutive code blocks that would need more than a nominal number of iterations.
  • the memory size can, for example, increase by a fixed number of code blocks, based on the ratio of maximum iterations to nominal iterations, which can be, for example, be kept to an integer relationship.
  • control of the elastic buffering can be greatly simplified to a decision as to whether the decoder may or may not use the maximum iterations. If there is not enough buffer space to use the full maximum iterations, then the decoder can, for example, resort to the nominal number of iterations.
  • the precision can be limited to a code block boundary, choosing the buffer size as a multiple of a single code block.
  • Decoding can then be permitted, for example, to use a multiple of the nominal iteration count, depending on how many code blocks can fit into the remaining input buffer space. This latter option, can, for example, allow for greater granularity in the allowed iterations.
  • multiple techniques can be implemented to allow the decoder to exit early (i.e., stop decoding the code block currently being processed). If, for example, a parity check indicates that a large portion of the bits of the currently processed code block are still in error after a pre-defined number of iterations, it can be assumed, for example, that the code block will most likely fail. Thus, additional time need not be wasted on any additional iterations for that code block.
  • Another indicator of non-convergence that can be used, for example, is a static parity error count.
  • a decoder can reach a certain parity error count and will not be able to get past it. On successive iterations, the parity error count will either remain the same or hover within a small delta in a varying, but non-converging cycle.
  • the decoder can, for example, be assumed to be not likely to converge for that code block, and can, for example, exit early, which may not necessarily produce bit errors. In fact, this condition usually occurs as a result of weakly protected parity bits, after the information bits have already converged.
  • an exemplary LDPC decoder can also exit early when the parity count is below some minimum threshold. This can be done in realization of the fact that an LDPC decoder can take several iterations trying to completely overcome the last few parity errors, sometimes unsuccessfully. If the parity sum gets below some minimum threshold, it is possible to exit early, relying on the outer code to correct any errors in the data. In general, the choice of such a threshold should be done with care, since it is unknown how many actual bits are in error relative to an individual parity error. In each case, for example, the unused iterations can be saved and be applied to a more worthy code block, thus allowing the input buffer to drain and thus prevent it from backing up unnecessarily.
  • FIGS. 1-4 illustrate the growth and reduction of exemplary elastic buffers according to an exemplary embodiment of the present invention as additional iterations are performed or as iterations less than the nominal number are deemed sufficient.
  • Each slot in the buffers of FIGS. 1-4 represents the size of a code block, where the lighter shading (light blue or white) represents an empty slot, and the darker shading (grey) represents an occupied slot.
  • the nominal iteration count N is fifty; the buffer is thus designed so that fifty iterations can be completed in the temporal duration of one code block.
  • FIG. 1 depicts the buffer states after initialization, where the input buffer has one code block and the output buffer is full.
  • FIG. 2 depicts the buffer state if, for example, the next code block were to require two hundred iterations, a factor of four times the nominal count.
  • FIG. 2 at the input one code block has been removed for decoding, while four more have arrived, creating an increase of three code blocks in the buffer relative to the input buffer's state as depicted in FIG. 1 .
  • four code blocks leave the buffer to maintain the constant output rate, while only one decoded block enters the output buffer.
  • FIG. 3 illustrates the consequence of, for example, a second code block also requiring two hundred iterations.
  • the input buffer is now near capacity and the output buffer is nearly depleted, thus limiting the allowable iterations for the next code block.
  • FIG. 4 illustrates the reduction in buffer size if, for example, the next two code blocks only require half the nominal iteration count.
  • the input buffer received only one additional code block, while the decoder consumed two during a single code block duration, reducing the level by one block.
  • a novel way to approach ideal decoding performance with the advantage of using a much simpler decoder architecture, can be implemented. Since input and output buffers are a natural part of any communications system, the additional control logic and memory requirements associated with the disclosed methods do not add any significant expense. In fact, in exemplary embodiments of the present invention, the benefits of allowing an iterative decoder to run at a much slower rate can far outweigh the cost of providing elastic buffers.
  • the methods of the present invention can be applied to any type of iterative decoding architecture, where the data rates are constant and the maximum possible iterations are not easily met.

Abstract

Systems and methods are presented to improve the performance of a constant bit rate iterative decoder by providing elastic buffering, while utilizing a relatively simple decoder architecture capable of maintaining a fixed number of iterations of a lower value. An LDPC decoder can be designed, for example, to support less than the maximum possible number of iterations, and can, for example, be mated to elastic input and output buffers. If a given code block, or succession of code blocks, requires the maximum number of iterations for decoding, the decoder can, for example, run at such maximum number of iterations and the elastic input buffer can, for example, hold code blocks waiting to be processed so as to maintain a constant input rate. Alternatively, if one or more code blocks requires less than the nominal number of iterations, the output buffer can store those code blocks so as to preserve a constant output rate. It is emphasized that this abstract is provided to comply with the rules requiring an abstract, and is submitted with the understanding that it will not be used to interpret or limit the scope or the meaning of the claims.

Description

    CROSS-REFERENCE TO OTHER APPLICATIONS
  • This application is a continuation of U.S. application Ser. No. 13/690,775, filed on Nov. 30, 2012, which is a continuation of U.S. application Ser. No. 12/079,467, filed on Mar. 26, 2008 which is now granted as U.S. Pat. No. 8,332,718, issued on Dec. 11, 2012, which claims the benefit of and incorporates by reference U.S. Provisional Patent Application No. 60/920,919, entitled “EFFICIENT IMPLEMENTATION TO PERFORM ITERATIVE DECODING WITH LARGE ITERATION COUNTS,” filed on Mar. 29, 2007.
  • TECHNICAL FIELD
  • The present invention relates to systems and methods for implementing iterative error correcting codes, and more particularly to systems and methods to improve the performance of a constant bit rate iterative decoder.
  • BACKGROUND INFORMATION
  • Low Density Parity Check (“LDPC”) codes, originally invented in 1962 by Gallagher, have recently been utilized in various communications applications. Because LDPC codes are based on an iterative decoding scheme, the performance of an LPDC decoder is highly dependent upon the number of iterations available to properly decode the information. Under poor signal conditions, a decode instance can consume hundreds of iterations and still be on the road to convergence. As a matter of implementation, designing decoder architectures capable of achieving large iteration counts can be quite difficult. Systems with large block sizes and/or high data rates can further exacerbate the problem, placing a physical limit on the number of iterations that can be performed between code blocks. However, some systems may not require that a consistently large number of iterations be available for each code block. Nominally, these systems could be expected to converge in a much shorter number of cycles, and may only require additional iterations at sporadic instances. Decoder design could be made simpler for such systems provided that such design could also adequately support sporadic demands (which at some times are sustained over multiple code blocks) for high iteration counts.
  • What is thus needed in the art are systems and methods that can support a large number of iterations for decoding when necessary, but that also avoid a complex decoder design.
  • SUMMARY
  • Systems and methods are presented to improve the performance of a constant bit rate iterative decoder by supporting a large number of decoding iterations at needed instances through elastic buffering, while utilizing a relatively simple decoder architecture capable of maintaining a fixed number of iterations of a lower value. In exemplary embodiments of the present invention, an LDPC decoder can be designed, for example, to support less than the maximum possible number of iterations, and can be, for example, mated to elastic input and output buffers. If a given code block, or succession of code blocks, requires, for example, a maximum number of iterations for decoding, the decoder can, for example, run at such maximum number of iterations and the elastic input buffer can, for example, hold code blocks waiting to be processed so as to maintain a constant input rate. Alternatively, for example, if one or more code blocks requires less than the nominal number of iterations, the output buffer can store those code blocks once they have been processed so as to preserve a constant output rate.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 depicts an exemplary iterative decoder and exemplary input and output buffers after initialization according to an exemplary embodiment of the present invention;
  • FIG. 2 depicts the exemplary iterative decoder and the exemplary input and output buffers of FIG. 1 after using two hundred iterations for one code block according to an exemplary embodiment of the present invention;
  • FIG. 3 depicts the exemplary iterative decoder and the exemplary input and output buffers of FIG. 2 after an additional 200 iterations on one code block have been performed according to an exemplary embodiment of the present invention; and
  • FIG. 4 depicts the exemplary iterative decoder and the exemplary input and output buffers of FIG. 3 after two decode cycles have been completed according to an exemplary embodiment of the present invention.
  • It is further noted that the patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawings will be provided by the U.S. Patent Office upon request and payment of the necessary fees.
  • DETAILED DESCRIPTION
  • For ease of illustration, the following description will assume a Low Density Parity Code (“LDPC”) code is utilized in an exemplary decoder, it being understood that the systems and methods of the present invention can be applied to any iterative code, utilitzed in any iterative decoder. Iterative codes, include, amongst other examples, LDPC codes, turbo codes, and variantions of those. Iterative algorithms are understood to be decoding algorithms that utilize a variable number of recursive steps, have some measure of convergence, and operate on blocks of data.
  • Simulations of certain LDPC codes, for example, have shown that an average of forty (40) iterations are required for decoding near the waterfall region, but as many as several hundreds are occasionally required to successfully converge. Because a decoder utilizing such an LDPC code seldom needs the full maximum number of iterations to converge properly, designing a decoder capable of supporting the maximum iterations on each code block can be highly inefficient, and in some cases may not even be possible. In exemplary embodiments of the present invention a more practical solution can be implemented. For example, a decoder can be designed with less than the maximum number of iterations, treating code blocks that need more iterations as special conditions. In so doing, the complexity of the decoder can be greatly reduced. Since such an exemplary decoder nominally uses less iterations than it is capable of, there is a potential for the wasted iterations to be saved for use on more difficult code blocks.
  • In order to handle code blocks that require more iterations, in exemplary embodiments of the present invention, a decoder can, for example, be mated to elastic buffers at its input and output. After initialization, for example, the output buffer can be assumed to be running near capacity, and the input buffer can be assumed to be running near empty.
  • In exemplary embodiments of the present invention, each code block handed to the decoder can, for example, be processed using a maximum number of iterations, M, spanning multiple code blocks, where M can be, for example, a number far greater than the number of iterations the decoder is capable of processing during the duration of one code block in time, which is the nominal iteration count, N, of the decoder. In general, M can be, for example, an integer multiple of N. If the decoder utilizes more than such N nominal iterations, an elastic input buffer can, for example, begin to fill up, while an elastic output buffer can begin to drain. Further code blocks may also be processed at more than the nominal number of iterations, as long as there is enough room left in the input buffer to queue subsequent code blocks. Similarly, code blocks requiring less than the nominal number of iterations of the decoder can be processed using such a lesser number of iterations, provided that there is enough storage at the output buffer. This allows the datastream to propogate at a constant input and output rate through the decoder while the decoder processes individual code blocks at variable iteration counts, and thus at variable rates. Eventually, the buffers will reach their limit and the decoder will be limited to processing each code block at the nominal iteration count. However, as code blocks are subsequently processed that require less than the nominal number of iterations, the buffers can begin to settle back towards their initial state. Thus, in order to drain the input buffer it is necessary to process data faster than the fill rate of the buffer. If, as the result of such processing the input buffer becomes empty, the decoder can then, for example, simply hold off processing any data until the next code block arrives.
  • In exemplary embodiments of the present invention, the sizes of the elastic buffers can, for example, be chosen based upon the generally expected number of consecutive code blocks that would need more than a nominal number of iterations. For each such consecutive code block, the memory size can, for example, increase by a fixed number of code blocks, based on the ratio of maximum iterations to nominal iterations, which can be, for example, be kept to an integer relationship. In exemplary embodiments of the present invention, control of the elastic buffering can be greatly simplified to a decision as to whether the decoder may or may not use the maximum iterations. If there is not enough buffer space to use the full maximum iterations, then the decoder can, for example, resort to the nominal number of iterations. Or, for example, in a slightly more advanced approach, the precision can be limited to a code block boundary, choosing the buffer size as a multiple of a single code block. Decoding can then be permitted, for example, to use a multiple of the nominal iteration count, depending on how many code blocks can fit into the remaining input buffer space. This latter option, can, for example, allow for greater granularity in the allowed iterations.
  • To prevent wasted iterations on code blocks that would never converge, or may not need to, in exemplary embodiments of the present invention multiple techniques can be implemented to allow the decoder to exit early (i.e., stop decoding the code block currently being processed). If, for example, a parity check indicates that a large portion of the bits of the currently processed code block are still in error after a pre-defined number of iterations, it can be assumed, for example, that the code block will most likely fail. Thus, additional time need not be wasted on any additional iterations for that code block.
  • Another indicator of non-convergence that can be used, for example, is a static parity error count. Sometimes a decoder can reach a certain parity error count and will not be able to get past it. On successive iterations, the parity error count will either remain the same or hover within a small delta in a varying, but non-converging cycle. In exemplary embodiments of the present invention, if this condition persists for a pre-defined number of iterations, the decoder can, for example, be assumed to be not likely to converge for that code block, and can, for example, exit early, which may not necessarily produce bit errors. In fact, this condition usually occurs as a result of weakly protected parity bits, after the information bits have already converged. Using a weak outer code, such as, for example, BCH, residual errors in the data can be corrected. In exemplary embodiments of the present invention, depending on the correction ability of the outer code, an exemplary LDPC decoder can also exit early when the parity count is below some minimum threshold. This can be done in realization of the fact that an LDPC decoder can take several iterations trying to completely overcome the last few parity errors, sometimes unsuccessfully. If the parity sum gets below some minimum threshold, it is possible to exit early, relying on the outer code to correct any errors in the data. In general, the choice of such a threshold should be done with care, since it is unknown how many actual bits are in error relative to an individual parity error. In each case, for example, the unused iterations can be saved and be applied to a more worthy code block, thus allowing the input buffer to drain and thus prevent it from backing up unnecessarily.
  • FIGS. 1-4 illustrate the growth and reduction of exemplary elastic buffers according to an exemplary embodiment of the present invention as additional iterations are performed or as iterations less than the nominal number are deemed sufficient. Each slot in the buffers of FIGS. 1-4 represents the size of a code block, where the lighter shading (light blue or white) represents an empty slot, and the darker shading (grey) represents an occupied slot. In the example depicted in FIGS. 1-4 the nominal iteration count N is fifty; the buffer is thus designed so that fifty iterations can be completed in the temporal duration of one code block.
  • FIG. 1 depicts the buffer states after initialization, where the input buffer has one code block and the output buffer is full. FIG. 2 depicts the buffer state if, for example, the next code block were to require two hundred iterations, a factor of four times the nominal count. With reference to FIG. 2, at the input one code block has been removed for decoding, while four more have arrived, creating an increase of three code blocks in the buffer relative to the input buffer's state as depicted in FIG. 1. At the output, four code blocks leave the buffer to maintain the constant output rate, while only one decoded block enters the output buffer.
  • FIG. 3 illustrates the consequence of, for example, a second code block also requiring two hundred iterations. The input buffer is now near capacity and the output buffer is nearly depleted, thus limiting the allowable iterations for the next code block.
  • FIG. 4 illustrates the reduction in buffer size if, for example, the next two code blocks only require half the nominal iteration count. The input buffer received only one additional code block, while the decoder consumed two during a single code block duration, reducing the level by one block. Thus, only one code block left the output buffer, while two code blocks have entered, leaving a surplus of one code block.
  • Thus, in exemplary embodiments of the present invention, a novel way to approach ideal decoding performance, with the advantage of using a much simpler decoder architecture, can be implemented. Since input and output buffers are a natural part of any communications system, the additional control logic and memory requirements associated with the disclosed methods do not add any significant expense. In fact, in exemplary embodiments of the present invention, the benefits of allowing an iterative decoder to run at a much slower rate can far outweigh the cost of providing elastic buffers.
  • As noted above, the methods of the present invention can be applied to any type of iterative decoding architecture, where the data rates are constant and the maximum possible iterations are not easily met.
  • While the present invention has been described with reference to certain exemplary embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the invention. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the invention without departing from its scope. Therefore, it is intended that the invention not be limited to the particular embodiment disclosed, but that the invention will include all embodiments falling within the scope of the appended claims.

Claims (27)

1. A method of efficiently performing iterative decoding in a decoder, comprising:
operating at a nominal iteration rate N;
changing the iteration rate by either:
(i) increasing the number of iterations as needed, if sufficient buffer space is available,
(ii) decreasing the number of iterations of a current code block being processed, or
(iii) stopping decoding of a current code block being processed; and
storing a queue of code blocks in each of an elastic input buffer and an elastic output buffer.
wherein the input rate of code blocks to the input buffer and the output rate of code blocks from the output buffer is constant, and
wherein the elastic buffer size is a multiple of a single code block.
2. The method of claim 1, wherein the decoder can increase to a maximum number of iterations M.
3. The method of claim 2, wherein M is an integer multiple of N.
4. The method of claim 1, wherein the decoder implements one of a Low Density Parity Code, a Turbo code and a modification of either of them.
5-6. (canceled)
7. The method of claim 1, wherein the size of the elastic output buffer is a function of the expected number of sequential code blocks that can be processed with less than N iterations.
8. The method of claim 1, wherein if the elastic input buffer is filled, the decoder operates at a multiple of N, depending upon how many code blocks can fit into the remaining input buffer space.
9. The method of claim 1, wherein the decoder can exit processing of a code block upon the detection of one of a defined set of termination indicators, including (i) large portion of bits still in error after a defined number of iterations, (ii) static parity error count, (iii) parity sum below a defined minimum threshold, or(iv) any combination of these.
10. (canceled)
11. A system for efficient iterative decoding, comprising:
a decoder set to operate at a nominal iteration rate N; and
an elastic input buffer and an elastic output buffer each coupled to the decoder, wherein the input rate of code blocks to the input buffer and the output rate of code blocks from the output buffer is constant, and wherein in operation, the decoder can
change the iteration rate by either:
(ii) increasing the number of iterations, as needed, if sufficient buffer space is available,
(ii) decreasing the number of iterations of a current code block being processed, or
(iii) stopping decoding of a current code block being processed; and
wherein the elastic buffer size is a multiple of a single code block.
12. (canceled)
13. The system of claim 12, wherein the decoder can increase to a maximum number of iterations M, where M is a multiple of N.
14. (canceled)
15. The system of claim 11, wherein the decoder implements one of a Low Density Parity Code, a Turbo code and a modification of one of them.
16. The system of claim 13, wherein at least one of:
the size of the elastic input buffer is a function of the expected number of sequential code blocks that can require M iterations, and
the size of the elastic output buffer is a function of the expected number of sequential code blocks that can be processed with less than N iterations.
17-18. (canceled)
19. The system of claim 11, wherein the decoder can exit stop processing of a current code block upon the detection of one of a defined set of termination indicators.
20. A program storage device readable by a processing unit, tangibly embodying a program of instructions executable by the processing unit to implement a method of efficiently performing iterative decoding, said method comprising:
operating at a nominal iteration rate N;
changing the iteration rate by either:
(i) increasing the number of iterations as needed, if sufficient buffer space is available,
(ii) decreasing the number of iterations of a current code block being processed, or
(iii) stopping decoding of a current code block being processed; and
storing a queue of code blocks in each of an elastic input buffer and an elastic output buffer,
wherein the input rate of code blocks to the input buffer and the output rate of code blocks from the output buffer is constant, and
wherein the elastic buffer size is a multiple of a single code block.
21. The programmable storage device of claim 20, wherein in said method the decoder can increase to a maximum number of iterations M.
22. The programmable storage device of claim 20, wherein in said method M is an integer multiple of N.
23. The programmable storage device of claim 20, wherein in said method the decoder implements one of a Low Density Parity Code, a Turbo code and a modification of either of them.
24. (canceled)
25. The programmable storage device of claim 20, wherein in said method, at least one of:
the size of the elastic input buffer is Nseq multiplied by the size of a code block multiplied by M/N, or Nseq*M/N*Block_size, and
the size of the elastic output buffer is a function of the expected number of sequential code blocks that can be processed with less than N iterations.
26. (canceled)
27. The programmable storage device of claim 20, wherein in said method if the elastic input buffer is filled, the decoder operates at a multiple of N, depending upon how many code blocks can fit into the remaining input buffer space.
28. The programmable storage device of claim 20, wherein in said method the decoder can exit processing of a code block upon deciding that the currently processed code block will either (i) not converge, or (ii) does not need to.
29. (canceled)
US14/547,335 2007-03-29 2014-11-19 Efficient implementation to perform iterative decoding with large iteration counts Abandoned US20150188579A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/547,335 US20150188579A1 (en) 2007-03-29 2014-11-19 Efficient implementation to perform iterative decoding with large iteration counts

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US92091907P 2007-03-29 2007-03-29
US12/079,467 US8332718B2 (en) 2007-03-29 2008-03-26 Efficient implementation to perform iterative decoding with large iteration counts
US13/690,775 US8910015B2 (en) 2007-03-29 2012-11-30 Efficient implementation to perform iterative decoding with large iteration counts
US14/547,335 US20150188579A1 (en) 2007-03-29 2014-11-19 Efficient implementation to perform iterative decoding with large iteration counts

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US13/690,775 Continuation US8910015B2 (en) 2007-03-29 2012-11-30 Efficient implementation to perform iterative decoding with large iteration counts

Publications (1)

Publication Number Publication Date
US20150188579A1 true US20150188579A1 (en) 2015-07-02

Family

ID=39808608

Family Applications (3)

Application Number Title Priority Date Filing Date
US12/079,467 Expired - Fee Related US8332718B2 (en) 2007-03-29 2008-03-26 Efficient implementation to perform iterative decoding with large iteration counts
US13/690,775 Expired - Fee Related US8910015B2 (en) 2007-03-29 2012-11-30 Efficient implementation to perform iterative decoding with large iteration counts
US14/547,335 Abandoned US20150188579A1 (en) 2007-03-29 2014-11-19 Efficient implementation to perform iterative decoding with large iteration counts

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US12/079,467 Expired - Fee Related US8332718B2 (en) 2007-03-29 2008-03-26 Efficient implementation to perform iterative decoding with large iteration counts
US13/690,775 Expired - Fee Related US8910015B2 (en) 2007-03-29 2012-11-30 Efficient implementation to perform iterative decoding with large iteration counts

Country Status (3)

Country Link
US (3) US8332718B2 (en)
CA (1) CA2682518A1 (en)
WO (1) WO2008121372A1 (en)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9202519B2 (en) 2014-03-28 2015-12-01 Avago Technologies General Ip (Singapore) Pte. Ltd. Adaptive calibration of noise predictive finite impulse response filter based on decoder convergence
US9966972B1 (en) 2014-09-02 2018-05-08 Marvell International Ltd. Systems and methods for dynamic iteration control in a low-density parity-check (LDPC) decoder

Family Cites Families (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6292918B1 (en) * 1998-11-05 2001-09-18 Qualcomm Incorporated Efficient iterative decoding
JP3683497B2 (en) * 2000-11-30 2005-08-17 松下電器産業株式会社 Decoding device and decoding method
KR100444571B1 (en) * 2002-01-11 2004-08-16 삼성전자주식회사 Decoding device having a turbo decoder and an RS decoder concatenated serially and a decoding method performed by the same
KR100703307B1 (en) * 2002-08-06 2007-04-03 삼성전자주식회사 Turbo decoding apparatus and method
US7395487B2 (en) 2002-08-15 2008-07-01 Broadcom Corporation Common circuitry supporting both bit node and check node processing in LDPC (Low Density Parity Check) decoder
US7343530B2 (en) 2004-02-10 2008-03-11 Samsung Electronics Co., Ltd. Turbo decoder and turbo interleaver
EP1667353A1 (en) 2004-12-03 2006-06-07 STMicroelectronics N.V. Method and device for decoding packets of data within an hybrid ARQ scheme
US7577891B2 (en) * 2005-05-27 2009-08-18 Aquantia Corporation Method and apparatus for extending decoding time in an iterative decoder using input codeword pipelining
CN101194428A (en) * 2005-06-27 2008-06-04 汤姆森许可贸易公司 Stop rule in iterative decoder
US7765453B2 (en) * 2006-12-13 2010-07-27 Nortel Networks Limited Early termination controller for iterative FEC decoders and method therefor
US7770087B2 (en) * 2007-01-19 2010-08-03 Harris Corporation Serial concatenated convolutional code decoder

Also Published As

Publication number Publication date
US8332718B2 (en) 2012-12-11
CA2682518A1 (en) 2008-10-09
US8910015B2 (en) 2014-12-09
US20130166984A1 (en) 2013-06-27
US20080307294A1 (en) 2008-12-11
WO2008121372A1 (en) 2008-10-09

Similar Documents

Publication Publication Date Title
US7805642B1 (en) Low power iterative decoder using input data pipelining and voltage scaling
CN101194451B (en) Method and device for power reduction in iterative decoders
US10417087B2 (en) System and method for adaptive multiple read of NAND flash
JP5384187B2 (en) Queue-based data detection and decoding system and method
JP5364911B2 (en) Dynamic ECC coding rate adjustment method, apparatus, and system
CN107425856B (en) Low density parity check decoder and method for saving power thereof
US20160336966A1 (en) System and method for dynamic scaling of ldpc decoder in a solid state drive
US8527849B2 (en) High speed hard LDPC decoder
KR20090019819A (en) Error correction decoding by trial and error
US8572471B2 (en) SOVA sharing during LDPC global iteration
US10216572B2 (en) Flash channel calibration with multiple lookup tables
US8606992B2 (en) Dynamically switching command types to a mass storage drive
CN103262425A (en) System and method for contention-free memory access
US20150188579A1 (en) Efficient implementation to perform iterative decoding with large iteration counts
US8234536B1 (en) Iterative decoder using input data pipelining and time-interleaved processing
CN102414991B (en) Data rearrangement for decoder
US9276614B2 (en) Buffer management in a turbo equalization system
CN101442677A (en) Hardware architecture for decoding FEC of DMB-T demodulation chip and decoding method
US11750219B2 (en) Decoding method, decoder, and decoding apparatus
US10171110B1 (en) Sequential power transitioning of multiple data decoders
EP2819310A1 (en) Iterative error decoder with cascaded decoding blocks and a feedback decoding block
EP3331180B1 (en) Flexible fec decoder for high speed wdm transmission
Luby et al. Distributed storage algorithms with optimal tradeoffs
CN105306076A (en) MAP algorithm based Turbo decoding method and device
Salmela et al. On allocation of turbo decoder iterations

Legal Events

Date Code Title Description
AS Assignment

Owner name: SIRIUS XM RADIO INC., NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SCARPA, CARL;SCHELL, EDWARD;REEL/FRAME:034208/0217

Effective date: 20080730

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION