US6304995B1 - Pipelined architecture to decode parallel and serial concatenated codes - Google Patents
Pipelined architecture to decode parallel and serial concatenated codes Download PDFInfo
- Publication number
- US6304995B1 US6304995B1 US09/237,714 US23771499A US6304995B1 US 6304995 B1 US6304995 B1 US 6304995B1 US 23771499 A US23771499 A US 23771499A US 6304995 B1 US6304995 B1 US 6304995B1
- Authority
- US
- United States
- Prior art keywords
- decoder
- data
- processor
- cascaded
- 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 - Lifetime
Links
- 238000000034 method Methods 0.000 claims abstract description 47
- 230000009897 systematic effect Effects 0.000 claims description 16
- 238000012545 processing Methods 0.000 abstract description 20
- 230000008569 process Effects 0.000 abstract description 8
- URWAJWIAIPFPJE-YFMIWBNJSA-N sisomycin Chemical compound O1C[C@@](O)(C)[C@H](NC)[C@@H](O)[C@H]1O[C@@H]1[C@@H](O)[C@H](O[C@@H]2[C@@H](CC=C(CN)O2)N)[C@@H](N)C[C@H]1N URWAJWIAIPFPJE-YFMIWBNJSA-N 0.000 description 24
- 238000004891 communication Methods 0.000 description 14
- 238000012937 correction Methods 0.000 description 13
- 238000002360 preparation method Methods 0.000 description 3
- 238000013461 design Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000002411 adverse Effects 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 230000000063 preceeding effect Effects 0.000 description 1
- 230000008707 rearrangement Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 230000000717 retained effect Effects 0.000 description 1
- 238000001228 spectrum Methods 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 238000012360 testing method Methods 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/29—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 combining two or more codes or code structures, e.g. product codes, generalised product codes, concatenated codes, inner and outer codes
- H03M13/2957—Turbo codes and decoding
- H03M13/2978—Particular arrangement of the component decoders
- H03M13/2987—Particular arrangement of the component decoders using more component decoders than component codes, e.g. pipelined turbo 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/29—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 combining two or more codes or code structures, e.g. product codes, generalised product codes, concatenated codes, inner and outer codes
- H03M13/2957—Turbo codes and decoding
Definitions
- the present invention generally relates to the decoding of parallel and serial concatenated codes. More specifically, the present invention relates to a pipelined architecture and method for iteratively decoding parallel and serial concatenated codes in order to minimize the effects of decoding processing speed on overall data communication rate.
- Error correction coding generally involves representing digital data in ways designed to be robust with respect to bit errors. Error correction coding enables a communication system to recover original data from a signal that has been corrupted. Typically, the greater the expected BER of a particular communication link, the greater the complexity of the error correction coding necessary to recover the original data.
- the greater the complexity of the error correction coding the greater the inefficiency of the data communication.
- the greater inefficiency results from a reduction of the ratio of information bits to total bits communicated as the complexity of the error correction coding increases.
- the additional information introduced into the original body of data by error correction coding consumes spectrum bandwidth and processor cycles on both the transmitting and receiving ends of the communication.
- Concatenated error correction coding refers to sequences of coding in which at least two encoding steps are performed on a data stream. Concatenated coding may be performed in series, where encoded data is subjected to further encoding, or in parallel where the original data is subjected to different encoding schemes to perform intermediate codes which are then further processed and combined into a serial stream.
- serially concatenated coding where two error correction codes are concatenated, an “outer code” is applied to the original data followed by an “inner code” which is then applied to the original data already encoded with the outer code.
- Serially concatenated coded data may become quite complex, even in an error correction scheme involving the application of only two concatenated error correction codes.
- An outer code may take the form of a block code, such as a Reed-Solomon code
- an inner code may take the form of a convolutional code.
- Reed-Solomon block codes are organized on the basis of groups of bits referred to as symbols. To form symbols, an incoming serial bit stream may be stored as sequences of m individual bits (a symbol).
- a convolutional code is a type of error correcting code which transforms an input sequence of bits into an output sequence of bits through the use of a finite-state machine, where additional bits are added to the data stream to allow for error-correcting capability.
- the amount of error-correction capability is proportional to the amount of additional bits added and the amount of memory preset in the finite-state machine encoder.
- the constraint length, K, of a convolutional code is proportional to the finite-state machine's memory, and the rate of the convolutional code (e.g. m/n with m ⁇ n) describes how many additional bits are added for every m information bits input (i.e., n ⁇ m bits added for each m information bits).
- the decoding complexity of a convolutional code increases exponentially with the constraint length.
- a block of data may be encoded with a particular coding method resulting in systematic bits and parity bits. Additionally, the original block of data may be rearranged with a permuter and then encoded with the same method as that applied to the original data resulting in systematic bits (which may be discarded) and parity bits. The two sets of encoded data are then further processed and merged into a serial bit stream. As with the case of serially concatenated coding, the complexity of parallel concatenated coding depends on the chosen encoding scheme, and can become significantly complex.
- Parallel and serial concatenated codes are sometimes decoded using iterative decoding algorithms.
- One commonly employed method of iterative decoding utilizes a single decoder processor where the decoder output metrics are fed back to the input of the decoder processor. Decoding is performed in an iterative fashion until the desired number of iterations have been performed. In order for the decoder processor to decode the encoded input data at the same rate as the input data is arriving, the decoder processor must process the encoded data at a rate faster than the rate of the incoming data by a factor at least equal to the number of iterations necessary. With this method of iterative decoding, the speed of the decoder processor becomes a significantly limiting factor in the system design.
- Another method of iterative decoding utilizes a number of decoder processors equal to the number of processing iterations necessary, each decoder processor operating independently and in parallel with the others.
- Each decoder processor iteratively decodes its own block of data from start to finish.
- the decoder processors take turns processing incoming blocks of data. For example, in a system with three independent decoders operating in parallel, decoder one may decode blocks n, n+3, n+6, etc., decoder two may decode blocks n+1, n+4, n+7, etc., and decoder three may decode blocks n+2, n+5, n+8, etc.
- Each decoder processor may either have multiple blocks of dedicated memory or a complex multiplexing/demultiplexing scheme allowing decoder processors to share memory.
- Each parallel decoder processor also has its own data decision element. The outputs from the parallel decoder processors are multiplexed to form a serial bit stream. It is apparent from the above discussion that with the parallel decoder processor method of iterative decoding, the quantity of hardware necessary to implement the method becomes a significantly limiting factor in the system design.
- a preferred embodiment of the present invention provides an apparatus and method for iteratively decoding data.
- the apparatus includes pipelined and cascaded decoder processors, each of which perform an iteration, or subset of the total iterations, of an iterative decoding scheme.
- a multiple block memory device which stores the input encoded data while the data is being processed by the decoder processors.
- the input encoded data is stored in blocks so that individual input encoded data blocks may be selectively accessed by different decoder processors.
- Multiplexers are implemented to provide the decoder processors selective access to specific input encoded data blocks.
- a data decision element is provided for generating decoded output data and is connected to the output of the last decoder processor in the cascade of decoder processors.
- the method for iteratively decoding data includes receiving blocks of encoded input data into available memory blocks while cascaded decoder processors are simultaneously performing their respective decoding iterations on encoded data previously received and stored in occupied data blocks.
- the decoder processors provide output information, also known as metrics, to their respective successor decoder processors in the cascade.
- the decoder processors then proceed to perform their respective iterations on their next respective blocks of encoded input data based on metrics that have been received from their respective predecessor decoder processors in the cascade.
- the method further includes generating output decoded data with a data decision element based on metrics information received from the last decoder processor in the cascade.
- FIG. 1 illustrates the structure of a basic turbo-coding system.
- FIG. 2 illustrates the structure of a basic turbo-decoding system.
- FIG. 3 illustrates an iterative turbo-decoding system with a single decoder processor.
- FIG. 4 illustrates a pipelined iterative turbo-decoding system according to a preferred embodiment of the present invention.
- FIG. 5 illustrates a method for iteratively decoding encoded data performed by a first cascaded decoder processor according to a preferred embodiment of the present invention.
- FIG. 6 illustrates a method for iteratively decoding encoded data performed by a middle cascaded decoder processor according to a preferred embodiment of the present invention.
- FIG. 7 illustrates a method for iteratively decoding encoded data performed by a last cascaded decoder processor according to a preferred embodiment of the present invention.
- FIG. 8 illustrates a method for iteratively decoding a block of encoded data according to a preferred embodiment of the present invention.
- FIG. 1 illustrates a basic turbo-coding system 100 .
- Data to be encoded (“raw data”) is applied to the input 102 of a first encoder 104 .
- the first encoder 104 performs a chosen type of encoding on the raw data bits and outputs two sets of bits.
- the first set of bits output from the first encoder 104 are commonly referred to as systematic bits, which are output from the systematic bit output 106 of the first encoder 104 .
- Systematic bits are directly representative of the information contained in the raw data.
- the systematic bits output from the first encoder 104 will also be referred to as the C1 bits.
- the second set of bits output from the first encoder 104 are commonly referred to as parity bits, which are output from the parity bit output 108 of the first encoder 104 . Parity bits are a function of the states of the raw data bits.
- the raw data is also applied to the input 110 of a permuter 112 .
- a permuter is a device which rearranges bits, typically in a random manner.
- the permuter 112 rearranges the raw data bits.
- the rearranged raw data bits output from the permuter 112 are then applied to the input 114 of a second encoder 116 .
- the second encoder 116 may be the same type of encoder as the first encoder 104 .
- the second encoder 116 outputs two sets of bits.
- Systematic bits are output from the systematic bit output 118 of the second encoder 116
- parity bits are output from the parity bit output 120 of the second encoder 116 .
- the systematic bits output from the second encoder 116 are typically discarded since they generally contain the same information as the systematic bits output from the first encoder 104 .
- the parity bits are retained since they represent unique and important information.
- the parity bits output from the first encoder 104 parity bit output 108 are input to a puncturer 122 .
- the parity bits output from the second encoder 116 parity bit output 120 are input to the puncturer 122 .
- a puncturer is a device which compresses data, thereby eliminating unnecessary information.
- the puncturer 122 compresses the input parity bits in order to make more efficient use of communication channel bandwidth.
- the puncturer 122 output bits corresponding to compressed parity bits from the first encoder 104 are output from the first puncturer output 124 .
- the puncturer 122 output bits corresponding to compressed parity bits from the first encoder 104 will also be referred to as “the C2 bits”.
- the puncturer 122 output bits corresponding to compressed parity bits from the second encoder 116 are output from the second puncturer output 126 .
- the puncturer 122 output bits corresponding to compressed parity bits from the second encoder 116 will also be referred to as “the C3 bits”. Prior to being modulated and transmitted over a communication channel, the C1 bits, C2 bits and C3 bits will be combined in some manner to form a serial bit stream.
- FIG. 2 illustrates a basic turbo decoder 200 that will serve to develop basic turbo decoder concepts, an understanding of which will assist in understanding the subsequent discussion.
- the systematic bits (C1 bits) and first set of parity bits (C2 bits) of turbo-encoded data are applied to the data input 202 of a first Soft-Input-Soft-Output (“SISO”) decoder 204 .
- the metrics input 206 of the first SISO decoder 204 has a null input applied.
- the data output 208 of the first SISO decoder 204 is discarded.
- the metrics output 210 of the first SISO decoder 204 is applied to the input of a permuter 211 .
- the permuter 211 rearranges the bits of the input metric and applies the result to the metrics input 212 of a second SISO decoder 214 .
- the second set of parity bits are applied to the data input 216 of the second SISO decoder 214 .
- the second SISO decoder 214 performs a decoding operation based on the C3 bits and the metric bits from the permuter 211 , which are permuted metric bits, originally output from the first SISO decoder 204 .
- the data output 218 of the second SISO decoder 214 is discarded.
- the metrics output 219 of the second SISO decoder 214 is applied to the input of an inverse-permuter 220 .
- An inverse-permuter is in essence a permuter set up to restore permuted bits to their pre-permuted order. For example, if bit sequence A is permuted by a permuter to form bit sequence B, an inverse permuter would restore bit sequence B back to bit sequence A.
- the metrics output 210 of the first SISO decoder 204 is applied to a delay circuit 222 .
- the output of the delay circuit 222 and the output of the inverse-permuter 220 are applied to inputs of an adder 224 .
- the output of the adder 224 is applied to the input of a data decision processor 226 which outputs a bit stream of decoded data corresponding to the original raw data.
- an output metric resulting from a decoding iteration will typically be fed back to the metrics input of a decoder.
- the encoded data will then be decoded repeatedly with better and better metrics until the metrics converge to values corresponding to high confidence levels.
- the total number of decoding iterations necessary to achieve the desired confidence level is typically a predetermined value.
- the only architectural difference is a metric feedback path from the output of the inverse-permuter ( 220 in FIG. 2, 320 in FIG. 3) to the input of the first SISO decoder ( 206 in FIG. 2, 306 in FIG. 3 ).
- the systematic bits (C1 bits) and first set of parity bits (C2 bits) of turbo-encoded data are applied to the data input 302 of a first Soft-Input-Soft-Output (“SISO”) decoder 304 .
- the metrics input 306 of the first SISO decoder 304 is connected to the output from the inverse-permuter 320 .
- the data output 308 of the first SISO decoder 304 is discarded.
- the metrics output 310 of the first SISO decoder 304 is applied to the input of a permuter 311 .
- the permuter 311 rearranges the bits of the input metric and applies the result to the metrics input 312 of a second SISO decoder 314 .
- the second set of parity bits (C3 bits) are applied to the data input 316 of the second SISO decoder 314 .
- the second SISO decoder 314 performs a decoding operation based on the C3 bits and the metric bits from the permuter 311 , which are permuted metric bits from the first SISO decoder 304 .
- the data output 318 of the second SISO decoder 314 is discarded.
- the metrics output 319 of the second SISO decoder 314 is applied to the input of the inverse-permuter 320 .
- the metrics output 310 of the first SISO decoder 304 is applied to a delay circuit 322 .
- the output of the delay circuit 322 and the output of the inverse-permuter 320 are applied to inputs of an adder 324 .
- the output of the adder 324 is applied to the input of a data decision processor 326 which outputs a bit stream of decoded data corresponding to the original raw data.
- the output of the inverse-permuter 320 is connected to the metrics input 306 of the first SISO decoder 304 .
- the decoder processor 300 performs the nth decoding iteration with an input metric resulting from the (n ⁇ 1)th decoding iteration.
- the total number of iterations is typically pre-determined. However, there may be instances where flexibility is designed into an architecture to enable an adaptable number of iterations to be performed.
- a weakness of the single decoder processor/multiple iteration decoding scheme is that the decoder processor 300 must complete the iterative decoding processing as fast as the encoded data is arriving.
- the decoder processor 300 must process a decoding iteration n-times as fast as the data is arriving.
- FIG. 4 A pipelined solution to this problem utilizing cascaded decoder processors is illustrated in FIG. 4 .
- FIG. 4 illustrates an embodiment 400 of the present invention applied to the particular problem of iteratively decoding data encoded with turbo coding.
- the particular embodiment 400 illustrated is for iteratively decoding data by performing three decoding iterations.
- the example may be extended to include as many decoding iterations and cascaded decoder processors as necessary.
- Encoded data may be stored in consecutive data blocks as the encoded data arrives.
- the multiple-block memory 402 of the embodiment illustrated in FIG. 4 is divided into four data blocks, Data Block 1, Data Block 2, Data Block 3 and Data Block 4.
- Each data block is logically and/or physically divided into three sections, C1, C2 and C3.
- C1 sections store systematic bits
- C2 sections store first sets of parity bits
- C3 sections store second sets of parity bits.
- a multiplexing and data control block 404 controls decoder processor access to the encoded data in the memory 402 .
- the multiplexing and data control block 404 is divided into three sections.
- the first section, C1 MUX controls access to C1 sets of systematic bits.
- the second section, C2 MUX controls access to C2 first sets of parity bits.
- the third section, C3 MUX controls access to C3 second sets of parity bits.
- the embodiment illustrated in FIG. 4 shows three cascaded decoder processors ( 406 , 430 , and 436 ).
- the data input 408 of the first decoder SISO-1.1 of the first decoder processor 406 initially receives data from the C1 and C2 sections of Data Block 1, via C1 MUX and C2 MUX respectively.
- the metric input 410 of SISO-1.1 receives a null input since the first decoder processor 406 is the first decoder processor in the cascade of decoder processors.
- SISO-1.1 performs a decoding operation and produces two outputs, a data output 412 and a metric output 414 .
- the data output 412 from SISO-1.1 is discarded.
- the metric output 414 from SISO-1.1 is input to the permuter 416 of the first decoder processor 406 .
- the permuter 416 rearranges its input bits and sends them to the metric input 418 of the second decoder SISO-1.2 of the first decoder processor 406 .
- the data input 420 of SISO-1.2 initially receives data from the C3 section of Data Block 1 via C3 MUX.
- SISO-1.2 performs a decoding operation and produces two outputs, a data output 422 and a metric output 424 .
- Thc data output 422 from SISO-1.2 is discarded.
- the metric output 424 of SISO-1.2 is input to the inverse-permuter 426 of the first decoder processor 406 .
- the inverse-permuter 426 rearranges its input bits, which are the metric bits output from SISO-1.2, in a manner that is inverse to the bit rearrangement performed by the permuter 416 and sends the rearranged input metric bits to the metric input 428 of SISO-2.1 of the second decoder processor 430 .
- the multiplexing and data control block 404 now grants the second decoder processor 430 access to Data Block 1 and grants the first decoder processor 406 access to a new block of data, Data Block 2.
- the first decoder processor 406 performs the first decoding iteration to be performed on the encoded data in Data Block 2.
- the decoding iteration performed by the first decoder processor 406 on the encoded data in Data Block 2 follows the discussion above regarding the decoding iteration performed by the first decoder processor 406 on Data Block 1.
- the second decoder processor 430 performs the second decoding iteration to be performed on the encoded data in Data Block 1 in a manner similar to the first decoding iteration performed by the first decoder processor 406 .
- An important difference between the first decoder processor 406 and the second decoder processor 430 is that the metric input 410 of the first decoder, SISO-1.1, of the first decoder processor 406 received a null input.
- the reason for this is that the first decoder processor 406 is the first decoder processor in the cascade, and therefore has no preceeding decoder processor from which to receive metric information.
- the metric input 428 of the first decoder, SISO-2.1, of the second decoder processor 430 receives metric information output from the inverse permuter 426 of the first decoder processor 406 . Except for the metric input difference just discussed, the second decoder processor 430 performs the second decoding iteration on the encoded data in Data Block 1 in the same manner as discussed previously regarding the first decoder processor 406 .
- first decoder processor 406 While the first decoder processor 406 is performing its respective decoding iteration on the encoded data in Data Block 2 and the second decoder processor 430 is performing its respective decoding iteration on the encoded data in Data Block 1, newly arriving encoded data is stored in Data Block 3.
- first decoder processor 406 completes the first decoding iteration on the encoded data in Data Block 2
- the second decoder processor 430 completes the second decoding iteration on the encoded data in Data Block 1
- the output metrics from the inverse-permuter 426 of the first decoder processor 406 are applied to the metrics input 428 of the first decoder, SISO-2.1, of the second decoder processor 430 .
- the output metrics from the inverse-permuter 432 of the second decoder processor 430 are applied to the metrics input 434 of the first decoder, SISO-3.1, of the third decoder processor 436 .
- the multiplexing and data control block 404 now grants the third decoder processor 436 access to Data Block 1, grants the second decoder processor 430 access to Data Block 2, and grants the first decoder processor 406 access to a new block of data, Data Block 3.
- the third decoder processor 436 performs the third decoding iteration to be performed on the encoded data in Data Block 1
- the second decoder processor 430 performs the second decoding iteration to be performed on the encoded data in Data Block 2
- the first decoder processor 406 performs the first decoding iteration to be performed on the encoded data in Data Block 3.
- the decoding iteration performed by the first decoder processor 406 on the encoded data in Data Block 3 follows the discussion above for the decoding iteration performed by the first decoder processor 406 on Data Block 1.
- the decoding iteration performed by the second decoder processor 430 on the encoded data in Data Block 2 follows the discussion above for the decoding iteration performed by the second decoder processor 430 on Data Block 1.
- the third decoder processor 436 performs the third decoding iteration to be performed on the encoded data in Data Block 1 in a manner very similar to the second decoding iteration performed by the second decoder processor 430 on Data Block 1.
- An important difference is that the metric input 428 of the first decoder, SISO-2.1, of the second decoder processor 430 receives the output metric from the inverse-permuter 426 of the first decoder processor 406 , and the metric input 434 of the first decoder, SISO-3.1, of the third decoder processor 436 receives the output metric from the inverse permuter 432 of the second decoder processor 430 . Except for the metric input difference just discussed, the third decoder processor 436 performs the third decoding iteration on the encoded data in Data Block 1 in the same manner as discussed previously regarding the second decoder processor 430 .
- the third decoder processor 436 performs the third decoding iteration on Data Block 1
- the metric output data from SISO-3.1 and the metric output data from SISO-3.2 (through inverse-permuter 442 ) is synchronized, added, and analyzed by a data decision element 437 to produce the final set of decoded data corresponding to the encoded data in Data Block 1.
- the metric output 438 from SISO-3.1 is connected to a delay element 444 .
- the metric output 440 from SISO-3.2 is connected to the inverse-permuter 442 of the third decoder processor 436 .
- the delay element 444 output 446 and the inverse-permuter 442 output 448 are connected to an adder 450 .
- the adder 450 output 452 is connected to the input of a decision processor 454 .
- the output of the decision processor 454 is the decoded data corresponding to the encoded data in Data Block 1. Now that the encoded data in Data Block 1 has been decoded, the memory space in Data Block 1 is made available for storing the next block of encoded data received.
- first decoder processor 406 is performing its respective decoding iteration on the encoded data in Data Block 3
- the second decoder processor 430 is performing its respective decoding iteration on the encoded data in Data Block 2
- the third decoder processor 436 is performing its respective decoding iteration on the encoded data in Data Block 1
- newly arriving encoded data is stored in Data Block 4.
- first decoder processor 406 completes the first decoding iteration on the encoded data in Data Block 3
- the second decoder processor 430 completes the second decoding iteration on the encoded data in Data Block 2
- the third decoder processor 436 completes the third decoding iteration on the encoded data in Data Block 1
- the decoder processing of a next iteration begins.
- the multiplexing and data control block 404 now grants the third decoder processor 436 access to Data Block 2, grants the second decoder processor 430 access to Data Block 3, and grants the first decoder processor 406 access to a new block of data, Data Block 4.
- the third decoder processor 436 performs the third decoding iteration to be performed on the encoded data in Data Block 2
- the second decoder processor 430 performs the second decoding iteration to be performed on the encoded data in Data Block 3
- the first decoder processor 406 performs the first decoding iteration to be performed on the encoded data in Data Block 4.
- the decoding iterations and final data decision processing follow the previous discussion. While this next round of decoding iterations are performed on the encoded data in Data Block 2, Data Block 3 and Data Block 4, newly arriving encoded data is stored in Data Block 1.
- the iterative decoding cycle discussed above continues until all of the encoded data received is decoded.
- FIGS. 5, 6 , 7 and 8 illustrate a method according to a preferred embodiment of the present invention for iteratively decoding encoded data using cascaded decoder processors.
- FIG. 5 illustrates the method 500 followed by the first decoder processor in the cascade.
- the first decoder processor in the cascade acquires access 502 to the memory block in which the encoded data is stored.
- the first decoder processor in the cascade then performs the first decoding iteration 504 on the block of data.
- the metrics resulting from the first decoding iteration are then sent 506 to the second decoder processor in the cascade. A decision 508 is then made.
- the process begins again at the data access acquisition step 502 . If there are no more blocks of encoded data to be decoded with the first decoding iteration, the processing of first decoding iterations is complete 510 .
- FIG. 6 illustrates the method 600 followed by the nth decoder processor in the cascade, where the nth decoder processor is not the first or last decoder processor in the cascade.
- the nth decoder processor receives metrics 602 from the (n ⁇ 1)th decoder processor in the cascade.
- the nth decoder processor acquires access 604 to the data block corresponding to the received metrics.
- the nth decoder processor in the cascade then performs the nth decoding iteration 606 on the block of data.
- the metrics resulting from the nth decoding iteration are then sent 608 to the (n+1)th decoder processor in the cascade.
- a decision 610 is then made.
- the process begins again at the metrics receiving step 602 . If there are no more blocks of encoded data to be decoded with the nth decoding iteration, the processing of nth decoding iterations is complete 612 .
- FIG. 7 illustrates the method 700 followed by the last decoder processor in the cascade.
- the last decoder processor receives metrics 702 from the next-to-last decoder processor in the cascade.
- the last decoder processor acquires access 704 to the data block corresponding to the received metrics.
- the last decoder processor in the cascade then performs the last decoding iteration 706 on the block of data.
- the metrics resulting from the last decoding iteration are then sent 708 to a data decision element.
- a decision 710 is then made. If there are more blocks of encoded data to be decoded with the last decoding iteration, the process begins again at the metrics receiving step 702 . If there are no more blocks of encoded data to be decoded with the last decoding iteration, the processing of last decoding iterations is complete 712 .
- first cascaded decoder processor nth cascaded decoder processor, and last cascaded decoder processor were discussed separately. However, it should be understood that although the decoding iterations on a given block of data are performed sequentially, decoding iterations are performed on different blocks of data simultaneously. For example, while a first block of data is being decoded with a third decoding iteration, a second block of data is being decoded with a second decoding iteration, and a third block of data is being decoded with a first iteration.
- the metrics resulting from the last decoding iteration that are sent 708 to the data decision element are analyzed by the data decision element to produce the final output decoded data.
- the analysis performed by the data decision element may consist of a parity test, where the arithmetic sign of a metric indicates the bit value of the corresponding decoded output bit.
- the output of the data decision element is preferably a bit stream of decoded data.
- FIGS. 5, 6 and 7 illustrate a method for iteratively decoding encoded data using cascaded decoder processors from the perspective of the cascaded decoder processors.
- FIG. 8 illustrates the method 800 for iteratively decoding encoded data using cascaded decoder processors from the perspective of a block of encoded data.
- the arrival of a block of encoded data 802 initiates the decoding process.
- a first decoding iteration 804 is performed on the block of encoded data using a first decoder processor.
- a done decision 806 is then made based on the number of decoding iterations performed so far on the block of encoded data relative to the predetermined total number of decoding iterations that are to be performed.
- preparations 808 are made for the next decoding iteration to be performed.
- the preparations consist of providing the next cascaded decoder processor performing the next decoding iteration with the output metrics from the most recent decoding iteration and with access to the encoded data block being decoded.
- the next decoding iteration 810 is then performed on the block of encoded data.
- the done decision 806 is then made again.
- the preparation 808 and decoding iteration 810 steps are performed repeatedly until the done decision 806 determines that the predetermined total number of decoding iterations to be performed on the encoded data block have been performed.
- the metrics from the last decoding iteration are passed 812 to a data decision element.
- Decoded output data is then generated 814 by the data decision element based on the metrics passed to it. Since the encoded data is no longer needed after it is decoded, the memory block containing the encoded data is made available for other data 816 .
- the decoding iteration step 810 , last metric passing step 812 , and output generating step 814 are illustrated sequentially in FIG. 8 for a block of encoded data, the metric passing step 812 and output generating step 814 preferably occur simultaneously with the last decoding iteration. This simultaneous processing is possible, because the metrics output from the last decoding iteration are preferably generated in the form of a sequential stream of metrics.
Landscapes
- Physics & Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Error Detection And Correction (AREA)
- Complex Calculations (AREA)
- Image Processing (AREA)
Abstract
Description
Claims (18)
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/237,714 US6304995B1 (en) | 1999-01-26 | 1999-01-26 | Pipelined architecture to decode parallel and serial concatenated codes |
EP01123870A EP1175014A3 (en) | 1999-01-26 | 2000-01-25 | Pipelined architecture to decode parallel and serial concatenated codes |
EP00101241A EP1024601A1 (en) | 1999-01-26 | 2000-01-25 | Pipelined architecture to decode parallel and serial concatenated codes (turbo codes) |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/237,714 US6304995B1 (en) | 1999-01-26 | 1999-01-26 | Pipelined architecture to decode parallel and serial concatenated codes |
Publications (1)
Publication Number | Publication Date |
---|---|
US6304995B1 true US6304995B1 (en) | 2001-10-16 |
Family
ID=22894852
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/237,714 Expired - Lifetime US6304995B1 (en) | 1999-01-26 | 1999-01-26 | Pipelined architecture to decode parallel and serial concatenated codes |
Country Status (2)
Country | Link |
---|---|
US (1) | US6304995B1 (en) |
EP (2) | EP1024601A1 (en) |
Cited By (47)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20010004390A1 (en) * | 1999-12-15 | 2001-06-21 | Nokia Mobile Phones Ltd. | Method and arrangement for iteratively improving a channel estimate |
US20010052099A1 (en) * | 1999-03-01 | 2001-12-13 | Tetsuya Yano | Turbo decoder |
US20020062471A1 (en) * | 2000-05-12 | 2002-05-23 | Nec Corporation | High-speed turbo decoder |
US20020080510A1 (en) * | 2000-06-29 | 2002-06-27 | Nec Corporation | Method of decoding turbo-encoded data and receiver for decoding turbo-encoded data |
US20030028843A1 (en) * | 2001-08-03 | 2003-02-06 | Hyokang Chang | Memory configuration scheme enabling parallel decoding of turbo codes |
US20030126538A1 (en) * | 2001-12-20 | 2003-07-03 | Philippe Mejean | High-efficiency compact turbo-decoder |
US6604220B1 (en) * | 2000-09-28 | 2003-08-05 | Western Digital Technologies, Inc. | Disk drive comprising a multiple-input sequence detector selectively biased by bits of a decoded ECC codedword |
US6606724B1 (en) * | 2000-01-28 | 2003-08-12 | Conexant Systems, Inc. | Method and apparatus for decoding of a serially concatenated block and convolutional code |
US6654924B1 (en) * | 2000-09-29 | 2003-11-25 | International Business Machines Corporation | System and method for error correction of digitized phase signals from MR/GMR head readback waveforms |
US6665357B1 (en) * | 1999-01-22 | 2003-12-16 | Sharp Laboratories Of America, Inc. | Soft-output turbo code decoder and optimized decoding method |
US6678843B2 (en) * | 1999-02-18 | 2004-01-13 | Interuniversitair Microelektronics Centrum (Imec) | Method and apparatus for interleaving, deinterleaving and combined interleaving-deinterleaving |
US20040010743A1 (en) * | 2002-07-11 | 2004-01-15 | Lee Jae Hong | Turbo encoded hybrid automatic repeat request system and error detection method |
US20040025106A1 (en) * | 2002-06-24 | 2004-02-05 | Massey Peter C. | Method of decoding utilizing a recursive table-lookup decoding method |
US6697985B1 (en) * | 2000-10-04 | 2004-02-24 | Actelis Networks Inc. | Predictive forward error correction redundancy |
US20040054954A1 (en) * | 2000-11-10 | 2004-03-18 | Patrick Adde | High-speed module, device and method for decoding a concatenated code |
US20040111659A1 (en) * | 2002-12-06 | 2004-06-10 | Sandbridge Technologies Inc. | Turbo decoder using parallel processing |
US6760879B2 (en) * | 1999-02-18 | 2004-07-06 | Interuniversitair Microelektronica Centrum (Imec) | System and method of turbo decoding |
US20040168001A1 (en) * | 2003-02-24 | 2004-08-26 | Piotr Szabelski | Universal serial bus hub with shared transaction translator memory |
US6795507B1 (en) * | 1999-09-30 | 2004-09-21 | Skyworks Solutions, Inc. | Method and apparatus for turbo decoding of trellis coded modulated signal transmissions |
US6799295B2 (en) * | 2001-01-02 | 2004-09-28 | Icomm Technologies, Inc. | High speed turbo codes decoder for 3G using pipelined SISO log-map decoders architecture |
US20050022099A1 (en) * | 2003-07-22 | 2005-01-27 | Ayumu Yagihashi | Data decoding method and apparatus and receiver and communication system applying the same |
US6859906B2 (en) * | 2000-02-10 | 2005-02-22 | Hughes Electronics Corporation | System and method employing a modular decoder for decoding turbo and turbo-like codes in a communications network |
US20050071728A1 (en) * | 2001-08-27 | 2005-03-31 | Yan-Xiu Zheng | Encoding and decoding apparatus and method |
US6959355B2 (en) * | 2003-02-24 | 2005-10-25 | Standard Microsystems Corporation | Universal serial bus hub with shared high speed handler |
US20060059293A1 (en) * | 2004-09-14 | 2006-03-16 | Henry Wurzburg | Universal serial bus switching hub |
US20060161830A1 (en) * | 2005-01-14 | 2006-07-20 | Yedidia Jonathan S | Combined-replica group-shuffled iterative decoding for error-correcting codes |
US20060218458A1 (en) * | 2005-03-25 | 2006-09-28 | Teranetics, Inc. | Efficient decoding |
US20060227759A1 (en) * | 2004-09-14 | 2006-10-12 | Bohm Mark R | Peripheral Sharing USB Hub |
US20070174534A1 (en) * | 2006-01-24 | 2007-07-26 | Standard Microsystems Corporation | Transferring system information via universal serial bus (USB) |
US20070245057A1 (en) * | 2006-04-14 | 2007-10-18 | Bohm Mark R | Multi-Host USB Device Controller |
US20070255885A1 (en) * | 2006-04-27 | 2007-11-01 | Standard Microsystems Corporation | System and method for universal serial bus hub port reversal |
US20080005262A1 (en) * | 2006-06-16 | 2008-01-03 | Henry Wurzburg | Peripheral Sharing USB Hub for a Wireless Host |
US20080229172A1 (en) * | 2005-07-04 | 2008-09-18 | Christophe Jego | High Rate Turbo Encoder and Recoder for Product Codes |
US20080304576A1 (en) * | 2005-03-25 | 2008-12-11 | Teranetics, Inc. | Efficient decoding |
US20090063717A1 (en) * | 2007-08-28 | 2009-03-05 | Bohm Mark R | Rate Adaptation for Support of Full-Speed USB Transactions Over a High-Speed USB Interface |
US7568147B2 (en) | 2000-01-28 | 2009-07-28 | Nxp B.V. | Iterative decoder employing multiple external code error checks to lower the error floor |
US20090285320A1 (en) * | 2000-09-12 | 2009-11-19 | Broadcom Corporation | Parallel concatenated code with soft-in soft-out interactive turbo decoder |
US20110202819A1 (en) * | 2010-02-12 | 2011-08-18 | Yuan Lin | Configurable Error Correction Encoding and Decoding |
US8719670B1 (en) * | 2008-05-07 | 2014-05-06 | Sk Hynix Memory Solutions Inc. | Coding architecture for multi-level NAND flash memory with stuck cells |
US8799532B2 (en) | 2011-07-07 | 2014-08-05 | Smsc Holdings S.A.R.L. | High speed USB hub with full speed to high speed transaction translator |
US9165597B2 (en) | 2013-06-28 | 2015-10-20 | Seagate Technology Llc | Time-multiplexed single input single output (SISO) data recovery channel |
US20160043742A1 (en) * | 2012-05-29 | 2016-02-11 | International Business Machines Corporation | Partial reverse concatenation for data storage devices using composite codes |
US9558782B2 (en) | 2012-05-29 | 2017-01-31 | International Business Machines Corporation | Partial reverse concatenation for data storage devices using composite codes |
CN103513961B (en) * | 2012-06-18 | 2017-07-11 | 中兴通讯股份有限公司 | On-chip buffering method and device |
JP2017531392A (en) * | 2014-09-29 | 2017-10-19 | アルカテル−ルーセント | Optical coherent receiver with forward error correction and parallel decoding |
CN107733445A (en) * | 2017-09-07 | 2018-02-23 | 中国科学院微电子研究所 | Turbo code word generating method and decoding method |
CN113642709A (en) * | 2021-08-16 | 2021-11-12 | 扬州大学 | Data reconstruction method based on self-encoder |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2001086821A2 (en) * | 2000-05-05 | 2001-11-15 | Icoding Technology, Inc. | Improved error floor turbo codes |
US6480125B2 (en) | 2000-06-09 | 2002-11-12 | Seagate Technology Llc | Method and apparatus for efficient encoding of large data words at high code rates |
JP2002009633A (en) * | 2000-06-19 | 2002-01-11 | Mitsubishi Electric Corp | Decoding circuit and decoding method, and coding circuit and coding method |
KR20030005294A (en) * | 2001-02-23 | 2003-01-17 | 코닌클리즈케 필립스 일렉트로닉스 엔.브이. | Turbo decoder system comprising parallel decoders |
WO2004059647A1 (en) * | 2002-12-30 | 2004-07-15 | Koninklijke Philips Electronics N.V. | Coding system |
US7236546B2 (en) * | 2003-09-10 | 2007-06-26 | Bae Systems Information And Electronic Systems Integration Inc. | Pipelined turbo multiuser detection |
US7702968B2 (en) | 2004-02-27 | 2010-04-20 | Qualcomm Incorporated | Efficient multi-symbol deinterleaver |
JP2006115145A (en) | 2004-10-14 | 2006-04-27 | Nec Electronics Corp | Decoding device and decoding method |
Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4730322A (en) * | 1985-09-27 | 1988-03-08 | California Institute Of Technology | Method and apparatus for implementing a maximum-likelihood decoder in a hypercube network |
US5446747A (en) * | 1991-04-23 | 1995-08-29 | France Telecom | Error-correction coding method with at least two systematic convolutional codings in parallel, corresponding iterative decoding method, decoding module and decoder |
US5721745A (en) * | 1996-04-19 | 1998-02-24 | General Electric Company | Parallel concatenated tail-biting convolutional code and decoder therefor |
US5729560A (en) * | 1995-06-12 | 1998-03-17 | Siemens Aktiengesellschaft | Method and coding means for protected transmission of data on the basis of multi-component coding |
US5761248A (en) * | 1995-07-19 | 1998-06-02 | Siemens Aktiengesellschaft | Method and arrangement for determining an adaptive abort criterion in iterative decoding of multi-dimensionally coded information |
US5983385A (en) * | 1997-08-14 | 1999-11-09 | Ericsson Inc. | Communications systems and methods employing parallel coding without interleaving |
US5996104A (en) * | 1996-09-13 | 1999-11-30 | Herzberg; Hanan | System for coding system |
US6014411A (en) * | 1998-10-29 | 2000-01-11 | The Aerospace Corporation | Repetitive turbo coding communication method |
US6023783A (en) * | 1996-05-15 | 2000-02-08 | California Institute Of Technology | Hybrid concatenated codes and iterative decoding |
US6028897A (en) * | 1998-10-22 | 2000-02-22 | The Aerospace Corporation | Error-floor mitigating turbo code communication method |
US6044116A (en) * | 1998-10-29 | 2000-03-28 | The Aerospace Corporation | Error-floor mitigated and repetitive turbo coding communication system |
-
1999
- 1999-01-26 US US09/237,714 patent/US6304995B1/en not_active Expired - Lifetime
-
2000
- 2000-01-25 EP EP00101241A patent/EP1024601A1/en not_active Withdrawn
- 2000-01-25 EP EP01123870A patent/EP1175014A3/en not_active Withdrawn
Patent Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4730322A (en) * | 1985-09-27 | 1988-03-08 | California Institute Of Technology | Method and apparatus for implementing a maximum-likelihood decoder in a hypercube network |
US5446747A (en) * | 1991-04-23 | 1995-08-29 | France Telecom | Error-correction coding method with at least two systematic convolutional codings in parallel, corresponding iterative decoding method, decoding module and decoder |
US5729560A (en) * | 1995-06-12 | 1998-03-17 | Siemens Aktiengesellschaft | Method and coding means for protected transmission of data on the basis of multi-component coding |
US5761248A (en) * | 1995-07-19 | 1998-06-02 | Siemens Aktiengesellschaft | Method and arrangement for determining an adaptive abort criterion in iterative decoding of multi-dimensionally coded information |
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 |
US5996104A (en) * | 1996-09-13 | 1999-11-30 | Herzberg; Hanan | System for coding system |
US5983385A (en) * | 1997-08-14 | 1999-11-09 | Ericsson Inc. | Communications systems and methods employing parallel coding without interleaving |
US6028897A (en) * | 1998-10-22 | 2000-02-22 | The Aerospace Corporation | Error-floor mitigating turbo code communication method |
US6014411A (en) * | 1998-10-29 | 2000-01-11 | The Aerospace Corporation | Repetitive turbo coding communication method |
US6044116A (en) * | 1998-10-29 | 2000-03-28 | The Aerospace Corporation | Error-floor mitigated and repetitive turbo coding communication system |
Non-Patent Citations (12)
Title |
---|
Benedetto, S., Divsalar, D., Montorsi, G., and Pollara F., "Continuous Map Algorithms and Their Applications to Decode Pareallel and Serial Code Concatenations", Proceedings of the Fifth European Space Agency Workshop on Digital Signal Processing Techniques Applied to Space Communications, Sep. 1996, pp. 8.10-8.24. |
Blazek Z et al: "A DSP-Based Implementation of a Turbo-Decoder" IEEE Global Telecommunications Conference, US, New York, NY; IEEE, 1998, pp. 2751-2755, XP000801545 ISBN: 0-7803-4985-7, p. 2751, right-hand col., line 6-p. 2752, left-hand col., line 10; figure 1, p. 2753, paragraph 4-last paragraph. |
D. Divsalar and F. Pollara, "Hybrid Concatenated Codes and Iterative Decoding", Communications Systems and Research Section, TDA Progress Report 42-130, Jet Propulsion Lab, NASA, Aug. 15, 1997.* |
D. Divsalar and F. Pollara, "Multiple Turbo Codes for Deep-Space Communications", Communications Systems and Research Section, TDA Progress Report 42-121, Jet Propulsion Lab, NASA, May 15, 1995.* |
D. Divsalar and F. Pollara, "On the Design of Turbo Codes", Communications Systems and Research Section, TDA Progress Report 42-123, Jet Propulsion Lab, NASA, Nov. 15, 1995.* |
D. Raphaeli anfd Y Zarai, "Combined Turbo Equalization and Turbo Decoding", IEEE, 1997.* |
L. Papke and K. Fazel, "Combined Multilevel Turbo-code with MR-modulation", IEEE, 1995.* |
S. Benedetto, D. Divsalar, G. Montorsi, and F. Pollara, "A Soft-Input Soft-Out-put APP Module for Iterative Decoding of Concatenated Codes", IEEE, 1997.* |
S. Benedetto, D. Divsalar, G. Montorsi, and F. Pollara, "A Soft-Input Soft-Output Maximum A Posteriori (MAP) Module to Decode Parallel and Serial Concatenated Codes", TDA Progress Report 42-127, Jet Propulsion Lab, NASA, Nov. 15, 1996.* |
S. Benedetto, D. Divsalar, G. Montorsi, and F. Pollara, Soft-Output Decoding Algorithms in Iterative Decoding of Turbo Codes, TDA Progress Report 42-124, Jet Propulsion Lab, NASA, Feb. 15, 1996.* |
Sklar B; "Turbo Code Concepts Made Easy, or How I Learned to communicate and Reiterate" Annual Military Communications Conference, US, New York, NY: IEEE, 1997, pp. 20-26, XP000799643 ISBN: 0-7803-4250-X. |
V. Franz and J. Anderson, "Concatenated Decoding with a Reduced-Search BCJR Algorithm", IEEE 1998.* |
Cited By (90)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6665357B1 (en) * | 1999-01-22 | 2003-12-16 | Sharp Laboratories Of America, Inc. | Soft-output turbo code decoder and optimized decoding method |
US6760879B2 (en) * | 1999-02-18 | 2004-07-06 | Interuniversitair Microelektronica Centrum (Imec) | System and method of turbo decoding |
US6678843B2 (en) * | 1999-02-18 | 2004-01-13 | Interuniversitair Microelektronics Centrum (Imec) | Method and apparatus for interleaving, deinterleaving and combined interleaving-deinterleaving |
US20010052099A1 (en) * | 1999-03-01 | 2001-12-13 | Tetsuya Yano | Turbo decoder |
US7096402B2 (en) * | 1999-03-01 | 2006-08-22 | Fujitsu Limited | Turbo decoder |
US6795507B1 (en) * | 1999-09-30 | 2004-09-21 | Skyworks Solutions, Inc. | Method and apparatus for turbo decoding of trellis coded modulated signal transmissions |
US6996194B2 (en) * | 1999-12-15 | 2006-02-07 | Nokia Mobile Phones, Ltd. | Method and arrangement for iteratively improving a channel estimate |
US20010004390A1 (en) * | 1999-12-15 | 2001-06-21 | Nokia Mobile Phones Ltd. | Method and arrangement for iteratively improving a channel estimate |
US7568147B2 (en) | 2000-01-28 | 2009-07-28 | Nxp B.V. | Iterative decoder employing multiple external code error checks to lower the error floor |
US6606724B1 (en) * | 2000-01-28 | 2003-08-12 | Conexant Systems, Inc. | Method and apparatus for decoding of a serially concatenated block and convolutional code |
US6859906B2 (en) * | 2000-02-10 | 2005-02-22 | Hughes Electronics Corporation | System and method employing a modular decoder for decoding turbo and turbo-like codes in a communications network |
US7133472B2 (en) * | 2000-05-12 | 2006-11-07 | Nec Corporation | High-speed turbo decoder |
US20020062471A1 (en) * | 2000-05-12 | 2002-05-23 | Nec Corporation | High-speed turbo decoder |
US20020080510A1 (en) * | 2000-06-29 | 2002-06-27 | Nec Corporation | Method of decoding turbo-encoded data and receiver for decoding turbo-encoded data |
US7075970B2 (en) * | 2000-06-29 | 2006-07-11 | Nec Corporation | Method of decoding turbo-encoded data and receiver for decoding turbo-encoded data |
US7715503B2 (en) * | 2000-09-12 | 2010-05-11 | Broadcom Corporation | Parallel concatenated code with soft-in soft-out interactive turbo decoder |
US20090285320A1 (en) * | 2000-09-12 | 2009-11-19 | Broadcom Corporation | Parallel concatenated code with soft-in soft-out interactive turbo decoder |
US6604220B1 (en) * | 2000-09-28 | 2003-08-05 | Western Digital Technologies, Inc. | Disk drive comprising a multiple-input sequence detector selectively biased by bits of a decoded ECC codedword |
US6654924B1 (en) * | 2000-09-29 | 2003-11-25 | International Business Machines Corporation | System and method for error correction of digitized phase signals from MR/GMR head readback waveforms |
US6697985B1 (en) * | 2000-10-04 | 2004-02-24 | Actelis Networks Inc. | Predictive forward error correction redundancy |
US7219291B2 (en) * | 2000-11-10 | 2007-05-15 | France Telecom | High-speed module, device and method for decoding a concatenated code |
US20040054954A1 (en) * | 2000-11-10 | 2004-03-18 | Patrick Adde | High-speed module, device and method for decoding a concatenated code |
US6799295B2 (en) * | 2001-01-02 | 2004-09-28 | Icomm Technologies, Inc. | High speed turbo codes decoder for 3G using pipelined SISO log-map decoders architecture |
US6996767B2 (en) | 2001-08-03 | 2006-02-07 | Combasis Technology, Inc. | Memory configuration scheme enabling parallel decoding of turbo codes |
US20030028843A1 (en) * | 2001-08-03 | 2003-02-06 | Hyokang Chang | Memory configuration scheme enabling parallel decoding of turbo codes |
US20050071728A1 (en) * | 2001-08-27 | 2005-03-31 | Yan-Xiu Zheng | Encoding and decoding apparatus and method |
US7434115B2 (en) * | 2001-08-27 | 2008-10-07 | Industrial Technology Research Institute | Encoding and decoding apparatus and method |
US20050076286A1 (en) * | 2001-08-27 | 2005-04-07 | Yan-Xiu Zheng | Encoding and decoding apparatus and method |
US20080141096A1 (en) * | 2001-08-27 | 2008-06-12 | Industrial Technology Research Institute | Decoding apparatus and method |
US8020064B2 (en) | 2001-08-27 | 2011-09-13 | Industrial Technology Research Institute | Decoding apparatus and method |
US7594156B2 (en) * | 2001-12-20 | 2009-09-22 | Philippe Mejean | High-efficiency compact turbo-decoder |
US20030126538A1 (en) * | 2001-12-20 | 2003-07-03 | Philippe Mejean | High-efficiency compact turbo-decoder |
US7073114B2 (en) | 2002-06-24 | 2006-07-04 | Massey Peter C | Method of decoding utilizing a recursive table-lookup decoding method |
US20040025106A1 (en) * | 2002-06-24 | 2004-02-05 | Massey Peter C. | Method of decoding utilizing a recursive table-lookup decoding method |
US20040010743A1 (en) * | 2002-07-11 | 2004-01-15 | Lee Jae Hong | Turbo encoded hybrid automatic repeat request system and error detection method |
US7234095B2 (en) * | 2002-07-11 | 2007-06-19 | Dept. Of Management: Seoul National University | Turbo encoded hybrid automatic repeat request system and error detection method |
US20040111659A1 (en) * | 2002-12-06 | 2004-06-10 | Sandbridge Technologies Inc. | Turbo decoder using parallel processing |
US7055102B2 (en) | 2002-12-06 | 2006-05-30 | Sandbridge Technologies, Inc. | Turbo decoder using parallel processing |
US20040168001A1 (en) * | 2003-02-24 | 2004-08-26 | Piotr Szabelski | Universal serial bus hub with shared transaction translator memory |
US7185126B2 (en) | 2003-02-24 | 2007-02-27 | Standard Microsystems Corporation | Universal serial bus hub with shared transaction translator memory |
US20060020737A1 (en) * | 2003-02-24 | 2006-01-26 | Standard Microsystems Corporation | Universal serial bus hub with shared high speed handler implementing respective downstream transfer rates |
US20090100209A1 (en) * | 2003-02-24 | 2009-04-16 | Piotr Szabelski | Universal serial bus hub with shared high speed handler |
US7484018B2 (en) | 2003-02-24 | 2009-01-27 | Standard Microsystems Corporation | Universal serial bus hub with shared high speed handler implementing respective downstream transfer rates |
US6959355B2 (en) * | 2003-02-24 | 2005-10-25 | Standard Microsystems Corporation | Universal serial bus hub with shared high speed handler |
US7975211B2 (en) | 2003-07-22 | 2011-07-05 | Nec Corporation | Data decoding method and apparatus and receiver and communication system applying the same |
US20070245219A1 (en) * | 2003-07-22 | 2007-10-18 | Ayumu Yagihashi | Data Decoding Method and Apparatus and Receiver and Communication System Applying the Same |
US8595599B2 (en) | 2003-07-22 | 2013-11-26 | Nec Corporation | Data decoding method and apparatus and receiver and communication system applying the same |
US20050022099A1 (en) * | 2003-07-22 | 2005-01-27 | Ayumu Yagihashi | Data decoding method and apparatus and receiver and communication system applying the same |
US20110214035A1 (en) * | 2003-07-22 | 2011-09-01 | Ayumu Yagihashi | Data Decoding Method and Apparatus and Receiver and Communication System Applying the Same |
US7281198B2 (en) * | 2003-07-22 | 2007-10-09 | Nec Corporation | Data decoding method and apparatus and receiver and communication system applying the same |
US20060059293A1 (en) * | 2004-09-14 | 2006-03-16 | Henry Wurzburg | Universal serial bus switching hub |
US20060227759A1 (en) * | 2004-09-14 | 2006-10-12 | Bohm Mark R | Peripheral Sharing USB Hub |
US7373585B2 (en) * | 2005-01-14 | 2008-05-13 | Mitsubishi Electric Research Laboratories, Inc. | Combined-replica group-shuffled iterative decoding for error-correcting codes |
US20060161830A1 (en) * | 2005-01-14 | 2006-07-20 | Yedidia Jonathan S | Combined-replica group-shuffled iterative decoding for error-correcting codes |
US20080304576A1 (en) * | 2005-03-25 | 2008-12-11 | Teranetics, Inc. | Efficient decoding |
US8234550B2 (en) | 2005-03-25 | 2012-07-31 | Plx Technology, Inc. | Efficient decoding |
US7461328B2 (en) * | 2005-03-25 | 2008-12-02 | Teranetics, Inc. | Efficient decoding |
US20100058143A1 (en) * | 2005-03-25 | 2010-03-04 | Teranetics, Inc. | Efficient Decoding |
US7634710B2 (en) | 2005-03-25 | 2009-12-15 | Teranetics, Inc. | Efficient decoding |
US20060218458A1 (en) * | 2005-03-25 | 2006-09-28 | Teranetics, Inc. | Efficient decoding |
US8332716B2 (en) * | 2005-07-04 | 2012-12-11 | Groupe Des Ecoles Des Telecommunications (Enst Bretagne) | High rate turbo encoder and decoder for product codes |
US20080229172A1 (en) * | 2005-07-04 | 2008-09-18 | Christophe Jego | High Rate Turbo Encoder and Recoder for Product Codes |
US7433990B2 (en) | 2006-01-24 | 2008-10-07 | Standard Microsystems Corporation | Transferring system information via universal serial bus (USB) |
US20070174534A1 (en) * | 2006-01-24 | 2007-07-26 | Standard Microsystems Corporation | Transferring system information via universal serial bus (USB) |
US20090106474A1 (en) * | 2006-04-14 | 2009-04-23 | Bohm Mark R | Multi-Host USB Device |
US20070245057A1 (en) * | 2006-04-14 | 2007-10-18 | Bohm Mark R | Multi-Host USB Device Controller |
US7523243B2 (en) | 2006-04-14 | 2009-04-21 | Standard Microsystems Corporation | Multi-host USB device controller |
US7627708B2 (en) | 2006-04-14 | 2009-12-01 | Standard Microsystems Corporation | Multi-host USB device |
US7480753B2 (en) | 2006-04-27 | 2009-01-20 | Standard Microsystems Corporation | Switching upstream and downstream logic between ports in a universal serial bus hub |
US20070255885A1 (en) * | 2006-04-27 | 2007-11-01 | Standard Microsystems Corporation | System and method for universal serial bus hub port reversal |
US20080005262A1 (en) * | 2006-06-16 | 2008-01-03 | Henry Wurzburg | Peripheral Sharing USB Hub for a Wireless Host |
US20090063717A1 (en) * | 2007-08-28 | 2009-03-05 | Bohm Mark R | Rate Adaptation for Support of Full-Speed USB Transactions Over a High-Speed USB Interface |
US20140281791A1 (en) * | 2008-05-07 | 2014-09-18 | Sk Hynix Memory Solutions Inc. | Coding architecture for multi-level nand flash memory with stuck cells |
US8719670B1 (en) * | 2008-05-07 | 2014-05-06 | Sk Hynix Memory Solutions Inc. | Coding architecture for multi-level NAND flash memory with stuck cells |
US9047213B2 (en) * | 2008-05-07 | 2015-06-02 | Sk Hynix Memory Solutions Inc. | Coding architecture for multi-level NAND flash memory with stuck cells |
US20110202819A1 (en) * | 2010-02-12 | 2011-08-18 | Yuan Lin | Configurable Error Correction Encoding and Decoding |
US8799532B2 (en) | 2011-07-07 | 2014-08-05 | Smsc Holdings S.A.R.L. | High speed USB hub with full speed to high speed transaction translator |
US10680655B2 (en) * | 2012-05-29 | 2020-06-09 | International Business Machines Corporation | Partial reverse concatenation for data storage devices using composite codes |
US20160043742A1 (en) * | 2012-05-29 | 2016-02-11 | International Business Machines Corporation | Partial reverse concatenation for data storage devices using composite codes |
US9558782B2 (en) | 2012-05-29 | 2017-01-31 | International Business Machines Corporation | Partial reverse concatenation for data storage devices using composite codes |
US10484018B2 (en) | 2012-05-29 | 2019-11-19 | International Business Machines Corporation | Partial reverse concatenation for data storage devices using composite codes |
US11381258B2 (en) | 2012-05-29 | 2022-07-05 | Awemane Ltd. | Partial reverse concatenation for data storage devices using composite codes |
CN103513961B (en) * | 2012-06-18 | 2017-07-11 | 中兴通讯股份有限公司 | On-chip buffering method and device |
US9165597B2 (en) | 2013-06-28 | 2015-10-20 | Seagate Technology Llc | Time-multiplexed single input single output (SISO) data recovery channel |
JP2017531392A (en) * | 2014-09-29 | 2017-10-19 | アルカテル−ルーセント | Optical coherent receiver with forward error correction and parallel decoding |
US10193568B2 (en) * | 2014-09-29 | 2019-01-29 | Alcatel Lucent | Optical coherent receiver with forward error correction |
CN107733445A (en) * | 2017-09-07 | 2018-02-23 | 中国科学院微电子研究所 | Turbo code word generating method and decoding method |
CN107733445B (en) * | 2017-09-07 | 2021-07-09 | 中国科学院微电子研究所 | Turbo code word generating method and decoding method |
CN113642709A (en) * | 2021-08-16 | 2021-11-12 | 扬州大学 | Data reconstruction method based on self-encoder |
CN113642709B (en) * | 2021-08-16 | 2023-11-10 | 扬州大学 | Data reconstruction method based on self-encoder |
Also Published As
Publication number | Publication date |
---|---|
EP1175014A2 (en) | 2002-01-23 |
EP1175014A3 (en) | 2003-09-17 |
EP1024601A1 (en) | 2000-08-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6304995B1 (en) | Pipelined architecture to decode parallel and serial concatenated codes | |
EP0682415B1 (en) | Punctured convolutional encoder | |
US5414738A (en) | Maximum likelihood paths comparison decoder | |
JP3791013B2 (en) | Data block convolutional encoding method and apparatus and corresponding decoding method and apparatus | |
KR100803957B1 (en) | Highly parallel map decoder | |
US6233711B1 (en) | Turbo coding, decoding devices and turbo coding, decoding methods | |
US6996767B2 (en) | Memory configuration scheme enabling parallel decoding of turbo codes | |
JP3274627B2 (en) | Method for encoding a stream of input signals and method for generating an output signal stream | |
JP3898129B2 (en) | High speed module, device and method for decoding concatenated codes | |
JP2000216689A (en) | Repetitive turbo code decoder and method for optimizing performance of the decoder | |
US20070067696A1 (en) | System, transmitter, receiver, method, and computer program product for structured interleaved Zigzag coding | |
US8250448B1 (en) | Method of and apparatus for implementing a decoder | |
US8009769B2 (en) | Method and a device for decoding slice codes | |
US20030188248A1 (en) | Apparatus for iterative hard-decision forward error correction decoding | |
US8024636B2 (en) | Serially concatenated convolutional code decoder with a constrained permutation table | |
KR101051933B1 (en) | Metric Computation for Map Decoding Using Trellis' Butterfly Structure | |
EP1775842A2 (en) | Communications device and wireless communications system | |
KR100628201B1 (en) | Method for Turbo Decoding | |
EP2174422B1 (en) | Decoding of recursive convolutional codes by means of a decoder for non-recursive convolutional codes | |
US7178090B2 (en) | Error correction code decoding device | |
CN101411071A (en) | MAP decoder with bidirectional sliding window architecture | |
CN112534724B (en) | Decoder and method for decoding polarization code and product code | |
US7120851B2 (en) | Recursive decoder for switching between normalized and non-normalized probability estimates | |
US20040163030A1 (en) | Iterative error correcting system | |
Benedetto et al. | Performance evaluation of parallel concatenated codes |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: TRW INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:SMITH, RONALD P.;SAUNDERS, OLIVER W.;REEL/FRAME:009732/0808 Effective date: 19990125 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: NORTHROP GRUMMAN CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:TRW, INC. N/K/A NORTHROP GRUMMAN SPACE AND MISSION SYSTEMS CORPORATION, AN OHIO CORPORATION;REEL/FRAME:013751/0849 Effective date: 20030122 Owner name: NORTHROP GRUMMAN CORPORATION,CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:TRW, INC. N/K/A NORTHROP GRUMMAN SPACE AND MISSION SYSTEMS CORPORATION, AN OHIO CORPORATION;REEL/FRAME:013751/0849 Effective date: 20030122 |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
AS | Assignment |
Owner name: NORTHROP GRUMMAN SPACE & MISSION SYSTEMS CORP.,CAL Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NORTHROP GRUMMAN CORPORTION;REEL/FRAME:023699/0551 Effective date: 20091125 Owner name: NORTHROP GRUMMAN SPACE & MISSION SYSTEMS CORP., CA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NORTHROP GRUMMAN CORPORTION;REEL/FRAME:023699/0551 Effective date: 20091125 |
|
AS | Assignment |
Owner name: NORTHROP GRUMMAN SYSTEMS CORPORATION,CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NORTHROP GRUMMAN SPACE & MISSION SYSTEMS CORP.;REEL/FRAME:023915/0446 Effective date: 20091210 Owner name: NORTHROP GRUMMAN SYSTEMS CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NORTHROP GRUMMAN SPACE & MISSION SYSTEMS CORP.;REEL/FRAME:023915/0446 Effective date: 20091210 |
|
FPAY | Fee payment |
Year of fee payment: 12 |