The present invention relates to an error correcting decoding apparatus and an error correcting decoding method using low-density parity check (LDPC) code.
In recent years, LDPC code is becoming a focus of attention as error correcting code that yields high error correcting performance. LDPC code is error correction code defined by a low-density parity check matrix.
Since the LDPC code has high error correcting performance and can be easily mounted, the LDPC code is being considered as an error correcting coding scheme for an IEEE802.11n high speed wireless LAN (Local Area Network) system, digital broadcasting system or large-capacity storage apparatus or the like.
One example of a conventional LDPC code decoding apparatus is disclosed in Patent Literature 1. The decoding apparatus described in Patent Literature 1 is a decoding apparatus adaptable to a plurality of check matrices and classifies check matrices so that edges are included in a unit region. Here, the “edge” refers to element “1” of a check matrix. In the case of LDPC code in binary notation, elements of a check matrix are “0” or “1.” The “elements of a matrix” represent components of the matrix. The decoding apparatus described in Patent Literature 1 stores edge arrangement information of edges located in a classified group and thereby reduces the memory capacity. Furthermore, Patent Literature 1 describes a method of simplifying connections between memory and calculation processors using the edge arrangement information.
PTL 1
NPL 1
However, the conventional configuration requires as many calculation processors mounted for a decoding process as row weight×the number of simultaneously processed rows. For this reason, a decoding apparatus adaptable to a plurality of check matrices requires a number of calculation processors that can support a check matrix having the largest row weight, resulting in a problem of increasing the circuit scale.
The present invention has been implemented in view of such a problem, and it is an object of the present invention to provide an error correcting decoding apparatus and an error correcting decoding method capable of performing LDPC decoding adaptable to a plurality of code rates while sharing circuits to suppress an increase in the circuit scale.
An aspect of an error correcting decoding apparatus of the present invention is an error correcting decoding apparatus that decodes a coded bit which is subjected to low-density parity check code of a code rate selected from among a plurality of code rates by using a check matrix adaptable to the selected code rate, the apparatus including a storage section that stores a likelihood obtained by receiving the coded bit, a calculation section that calculates a soft decision value by repeating column processing and row processing using the likelihood and a partial matrix corresponding to the check matrix adaptable to the selected code rate, and a decision section that decides the decoded bit using the soft decision value, in which the calculation section uses, when the selected code rate is a first code rate, a first partial matrix obtained by selecting and combining arbitrary columns from a first check matrix adaptable to the first code rate in accordance with the number of columns to be decoded in the column processing as the partial matrix, and uses, when the selected code rate is a second code rate greater than the first code rate, a distributed partial matrix obtained by selecting and combining arbitrary columns from a distributed check matrix in accordance with a second check matrix adaptable to the second code rate as the partial matrix in accordance with the number of columns making up the first partial matrix, and the distributed check matrix is a matrix in which the number of rows of the second check matrix is expanded so that elements of a row with a great row weight of the second check matrix are arranged to be distributed across the original row and the expanded row.
An aspect of an error correcting decoding method of the present invention is an error correcting decoding method for decoding a coded bit which is subjected to low-density parity check code of a code rate selected from among a plurality of code rates by using a check matrix adaptable to the selected code rate, the method including storing a likelihood obtained by receiving the coded bit, calculating a soft decision value by repeating column processing and row processing using the likelihood and a partial matrix corresponding to the check matrix adaptable to the selected code rate, and deciding a decoded bit using the soft decision value, in which when the selected code rate is a first code rate, a first partial matrix selected and combined from a first check matrix adaptable to the first code rate in accordance with the number of columns to be decoded in the column processing is used as the partial matrix, and when the selected code rate is a second code rate greater than the first code rate, a distributed partial matrix selected and combined from a distributed check matrix in accordance with a second check matrix adaptable to the second code rate in accordance with the number of columns making up the first partial matrix is used as the partial matrix, and the distributed check matrix is a matrix in which the number of rows of the second check matrix is expanded so that elements of a row with a large number of row weight of the second check matrix are arranged to be distributed across the original row and the expanded row.
According to these aspects of the present invention, it is possible to perform LDPC decoding adaptable to a plurality of code rates while sharing circuits to suppress an increase in the circuit scale.
According to the present invention, it is possible to perform LDPC decoding adaptable to a plurality of code rates while sharing circuits to suppress an increase in the circuit scale.
Hereinafter, an embodiment of the present invention will be described in detail with reference to the accompanying drawings.
The present embodiment will describe an error correcting decoding apparatus (hereinafter abbreviated as “decoder”) and an error correcting decoding method (hereinafter referred to as “LDPC decoding method or decoding algorithm”) capable of performing LDPC decoding adaptable to a plurality of code rates while sharing circuits to suppress an increase in the circuit scale.
First, an LDPC decoding method adaptable to a code rate arbitrarily selected from among a plurality of code rates will be described.
Decoder 100C shown in
Column processing/row processing calculation section 120 outputs extrinsic value 200 which is information obtained in the decoding process. Column processing/row processing calculation section 120 reuses outputted extrinsic value 200 as an input signal. In
Column processing/row processing calculation section 120 repeatedly performs the decoding process (iterative decoding process) using extrinsic value 200 and the read likelihood. After repeating the decoding process a predetermined number of iteration times, column processing/row processing calculation section 120 outputs a prior value to hard decision section 180. Hard decision section 180 makes a hard decision on the inputted prior value and outputs a decoded bit. Details of the likelihood, extrinsic value 200 and prior value are described in Non-Patent Literature 1.
Details of the LDPC decoding method in column processing/row processing calculation section 120 will be described below.
In
For example, the amount of cyclic shift “0” at row 0 and column 0 represents the unit matrix itself, and the amount of cyclic shift “9” at row 1 and column 2 represents a matrix resulting from cyclically shifting the unit matrix by 9. On the other hand, “-” represents a zero matrix and is not a matrix resulting from cyclically shifting the unit matrix.
A submatrix whose unit matrix has a size of 4×4 and whose amount of cyclic shift is 2 is expressed as shown in equation 1. As is clear from equation 1, a submatrix whose amount of cyclic shift is 2 is a matrix resulting from shifting element “1” of the unit matrix to the right by 2.
Hereinafter, a case will be described as an example where the submatrix in the check matrix in
Since the number of columns of the check matrix in
In the present embodiment, LDPC decoding corresponding to a check matrix is not performed on all columns of the check matrix all at once, but performed by dividing all the columns into blocks of a certain number of columns. To be more specific, in the present embodiment, a check matrix is divided into a plurality of submatrices, and a decoding process is performed for each partial matrix.
As an example, a case will be considered below where LDPC decoding corresponding to the check matrix in
A criteria for column selection in order to form submatrices from a check matrix is as follows.
In the present embodiment, columns are selected from a check matrix to generate submatrices so that row weights of the submatrices is minimized. In
When the decoding process is performed on two columns at a time, submatrices are formed by focusing, for example, on column numbers 9, 12 and 13 in the check matrix in
Thus, in the present embodiment, submatrices are generated from a check matrix by selecting columns so that row weights of the partial matrices is minimized according to the number of columns on which a decoding process is performed, that is, the number of columns making up the submatrix.
In the present embodiment, the following decoding process is performed after forming submatrices according to the above-described column selection. A case will be described below where, for example, logarithmic region min-sum decoding is used as the present decoding algorithm. Details of the logarithmic region min-sum decoding can be obtained by referring to Non-Patent Literature 1. In the present embodiment, the logarithmic region min-sum decoding is performed as follows.
Table 1 shows definitions of variables used for the present decoding algorithm.
The present decoding algorithm performs column processing based on the unit of the number of columns of a submatrix selected and formed from the check matrix as shown in
In the example of
[1] Start
After obtaining logarithmic likelihood ratios corresponding to all LDPC coded bits (1024 bits in the present embodiment), the present decoding algorithm starts LDPC decoding.
[2] Initial Setting (ST101)
The present decoding algorithm sets the update processing count as the 0-th time. Furthermore, the present decoding algorithm sets logarithmic extrinsic value ratios corresponding to all m and z in the 0-th update processing as follows. In this algorithm, m indicates the row number when the check matrix is represented by submatrices (subblocks) as shown in
The logarithmic extrinsic value (extrinsic value) indicates an improvement of decoding reliability of a bit to be decoded in iterative decoding. Referring to min-sum decoding, the logarithmic extrinsic value is an improvement of reliability obtained through row processing performed using a prior value corresponding to any bits other than bits to be decoded.
[2]
αmin(0,m,z)=0 (Equation 2-1)
α2nd(0,m,z)=0 (Equation 2-2)
αind(0,m,z)=0 (Equation 2-3)
αsig(0,m,z)=1 (Equation 2-4)
Furthermore, the present decoding algorithm sets signs of logarithmic prior value ratios for all m, n, z as follows. In this algorithm, n indicates a column number when the check matrix is represented by submatrices (subblocks) as shown in
[3]
βsig(m,n,z)=1 (Equation 3)
[3] i=1 (ST102)
The present decoding algorithm sets variable i for counting the number of times of update (hereinafter referred to as “update count”) to 1.
[4] Initialization of Extrinsic Value (ST103)
The present decoding algorithm sets the logarithmic extrinsic value ratio in the i-th update processing for all m and z as follows.
[4]
αmin(i,m,z)=qtmax−1 (Equation 4-1)
α2nd(i,m,z)=qtmax (Equation 4-2)
αind(i,m,z)=0 (Equation 4-3)
αsig(i,m,z)=1 (Equation 4-4)
where qtmax represents a maximum value in the processing system.
[5] j=0 (ST104)
The present decoding algorithm sets variable j representing the decoding order to 0. Decoding order j is a number assigned to a partial matrix (set of columns to which the decoding process is applied) as shown in
[6] Calculation of Prior Value (Column Processing) (ST105)
First, the present decoding algorithm obtains input extrinsic value eval (m, n, z1) to column processing corresponding to a partial matrix for all m, n, z0, from the logarithmic extrinsic value ratio obtained in (i−1)-th update processing as follows.
[5]
esig(m,n,z1)=αsig(i−1,m,z0)×βsig(m,n,z1) (Equation 5)
where Z is a submatrix size, and S(m, n) is the amount of cyclic shift corresponding to the submatrix on the m-th row, n-th column of the check matrix. Furthermore, z0=0, . . . , Z−1 and z1=(S(m, n)+z0) mod Z. Herein, X mod Y represents a remainder of Y divided by X.
[6]
eabs(m,n,z1)=αmin(i−1,m,z0) (when αind(i−1,m,z0)≠n) (Equation 6-1)
α2nd(i−1,m,z0) (when αind(i−1,m,z0)=n) (Equation 6-2)
[7]
eval(m,n,z1)=esig(m,n,z1)×eabs(m,n,z1) (Equation 7)
However, when S(m, n)=“-,” that is, when the submatrix indicated by S(m, n) is a zero matrix, the present decoding algorithm does not calculate the input extrinsic value, where S(m, n) represents the amount of cyclic shift for a submatrix on the m-th row, n-th column of the check matrix. As the in-submatrix index, index z0 corresponding to the logarithmic extrinsic value ratio differs from index z1 corresponding to the input extrinsic value because the processing order changes due to the cyclic shift of the submatrix.
The present decoding algorithm calculates a logarithmic prior value ratio using the input extrinsic value and the logarithmic likelihood ratio calculated as shown above. The logarithmic prior value ratio is calculated for all m, n, and z as shown in equation 8.
where, M represents the number of rows of the submatrix of the check matrix.
In equation 8, Σ is applied to the submatrix except row number m of the submatrix. In equation 8, 0 m indicates a “except row number m.” Furthermore, to generate input extrinsic value eval(m, n, z1) in the next update processing, the sign of the logarithmic prior value ratio is updated as shown in equation 9.
[9]
βsig(m,n,z)=SIGN(β(m,n,z)) (Equation 9)
where, SIGN(•) is a function that returns a sign.
[7] Calculation of Extrinsic Value (Row Processing) (ST106)
The present decoding algorithm performs successive row processing on a partial matrix made up of a set of submatrices selected as shown in
The present decoding algorithm also calculates a column number that provides a minimum value of the absolute value and a value whose absolute value is the second smallest (hereinafter referred to as “second value”) as ones for the aforementioned column processing in the minimum value search. Furthermore, the present decoding algorithm also updates the sign of the logarithmic extrinsic value ratio. The row processing can be expressed by the following equations.
where min(•) represents a function that returns a minimum value of the absolute value when the logarithmic prior value ratio corresponding to the column to be decoded is viewed in the row direction.
Furthermore, minind(•) represents a function that returns a column number of the submatrix that provides a minimum value of the absolute value.
[11]
z1=(S(m,n)+z0)mod Z (Equation 11-1)
αmin(i,m,z0)=min(αmin(i,m,z0),βmin(m,z1)) (Equation 11-2)
α2nd(i,m,z0)=min2(αmin(i,m,z0),α2nd(i,m,z0),βmin(m,z1)) (Equation 11-3)
αind(i,m,z0)=minind(αind(i,m,z0),βind(m,z1)) (Equation 11-4)
where min(•) represents a function that returns a minimum value, and min2(•) represents a function that returns a second value. Furthermore, minind(•) is a function that returns R when βind(m, z1) min function selects βmin(m, z1) as the minimum value, and returns αind(i, m, z0) otherwise.
[8] j+=1 (ST107)
The present decoding algorithm increments decoding order j by 1.
[9] j<=J (ST108)
The present decoding algorithm returns to “[6] Calculation of prior value” to perform column processing when j is equal to or less than last decoding order J or exits the loop when j exceeds J.
[10] i+=1 (ST109)
The present decoding algorithm increments update count i by 1.
[11] i<itmax (ST110)
The present decoding algorithm returns to “[4] Initialization of extrinsic value” to restart the decoding process when update count i is smaller than maximum update count itmax. On the other hand, the present decoding algorithm exits the loop when update count i is equal to or greater than maximum update count itmax.
[12] Calculation of Output Hard Decision Value (ST111)
The present decoding algorithm calculates an output soft decision value for all n, z according to the following equation.
When calculating the logarithmic prior value ratio, the present decoding algorithm does not add up eval corresponding to a submatrix having row number m to be decoded as shown in equation 8. However, in the calculation of the output soft decision value, the present decoding algorithm also considers the submatrix having row number m to be decoded.
The present decoding algorithm calculates an output hard decision value using the sign of the output soft decision value obtained. The sign of the output soft decision value and the output hard decision value depend on the way for calculating the logarithmic likelihood ratio. When the logarithmic likelihood ratio is calculated as shown in Non-Patent Literature 1, the present decoding algorithm outputs “0” as the decoding result if the sign of the output soft decision value is positive and outputs “1” if the sign is negative. The present decoding algorithm then outputs the decoding result corresponding to the information bit as a decoded bit and ends the LDPC decoding.
Decoder 100 according to the present embodiment includes likelihood storage section 110, column processing/row processing calculation section 120 and hard decision section 180.
Column processing/row processing calculation section 120 includes extrinsic value storage sections 130-0 to 130-7, row selection sections 140-0 to 140-3, prior value generation sections 150-0 to 150-3, column selection section 160 and extrinsic value update sections 170-0 to 170-7.
The partial matrix of the check matrix in
The number of columns making up a partial matrix is not limited to four, but decoder 100 may have as many matrix selection sections and prior value generation sections as columns making up a partial matrix. Since an increase in the number of columns making up a partial matrix requires the more matrix selection sections and prior value generation sections, the number of columns making up a partial matrix may be set based on a tradeoff with the circuit scale.
Likelihood storage section 110 stores a logarithmic likelihood ratio corresponding to LDPC coded bits, the logarithmic likelihood ratio being obtained from a received signal. When logarithmic likelihood ratios corresponding to all LDPC coded bits are stored in likelihood storage section 110, LDPC decoding starts.
Extrinsic value storage section 130-k (k=0 to 7) stores logarithmic extrinsic value ratios which is output from extrinsic value update section 170-k (k=0 to 7). When LDPC decoding starts, extrinsic value storage section 130-k (k=0 to 7) initializes a logarithmic extrinsic value ratio as mentioned in “[2] Initial setting” of the flowchart.
Extrinsic value storage section 130-k outputs the stored logarithmic extrinsic value ratio to row selection sections 140-0 to 140-3.
Row selection section 140-r (r=0 to 3) selects and outputs logarithmic extrinsic value ratios corresponding to rows having non-zero elements (rows in which the amount of cyclic shift is described) in the column of column number r of partial matrix #1-j corresponding to decoding order j shown in
Prior value generation section 150-r (r=0 to 3) calculates logarithmic prior value ratios using the logarithmic extrinsic value ratios which is input from row selection section 140-r and the logarithmic likelihood ratios which is input from likelihood storage section 110 as shown in “[6] Calculation of prior value (column processing)” of the flowchart.
Here, prior value generation section 150-r (r=0 to 3) calculates logarithmic prior value ratios corresponding to rows having non-zero elements in the column of column number r of partial matrix #1-j (columns to be decoded). For example, prior value generation section 150-0 calculates logarithmic prior value ratios corresponding to rows (rows 0, 1, 4, and 5) having non-zero elements of column number 0 of partial matrix #1-0 and outputs the calculated logarithmic prior value ratios to column selection section 160. Similarly, prior value generation sections 150-1, 150-2 and 150-3 calculate logarithmic prior value ratios corresponding to non-zero elements of column numbers 1, 2, and 3 of partial matrix #1-j respectively and outputs the calculated logarithmic prior value ratios to column selection section 160.
As shown in equation 8, logarithmic prior value ratios can be obtained by addition. Therefore, prior value generation section 150-r (r=0 to 3) includes an adder.
Here, prior value generation section 150-3 performs the decoding process a predetermined number of times (itmax) and then outputs logarithmic prior value ratios to hard decision section 180.
Column selection section 160 selects logarithmic prior value ratios corresponding to non-zero elements in each row of partial matrix #1-j corresponding to decoding order j shown in
Thus, column selection section 160 selects logarithmic prior value ratios corresponding to columns having non-zero elements, regarding each row of partial matrix #1-j as decoding target j, and outputs the selected logarithmic prior value ratios to extrinsic value update section 170-k (k=0 to 7).
Extrinsic value update section 170-k (k=0 to 7) updates logarithmic extrinsic value ratios corresponding to a k-th row using logarithmic prior value ratios, as “[7] Calculation of extrinsic value (row processing)” of the flowchart. For example, extrinsic value update section 170-0 updates logarithmic extrinsic value ratios corresponding to the 0-th row of partial matrix #1-j. Similarly, extrinsic value update section 170-k (k=1 to 7) updates logarithmic extrinsic value ratios corresponding to the k-th row of partial matrix #1-j.
As shown in equations 10-1, 10-2 and equations 11-1 to 11-4, logarithmic extrinsic value ratios can be obtained by comparison. For this reason, extrinsic value update section 170-k (k=0 to 7) includes a comparator. The number of comparators required corresponds to a row weight of a partial matrix.
After performing the decoding process a predetermined number of times (itmax), hard decision section 180 makes a hard decision on the logarithmic prior value ratios which is output from prior value generation section 150-3, acquires a hard decision value as a decoded bit and outputs the acquired decoded bit.
The operation of decoder 100 configured as described above will be described.
A logarithmic likelihood ratio corresponding to an LDPC coded bit is obtained from the received signal and is stored in likelihood storage section 110. When logarithmic likelihood ratios corresponding to all LDPC coded bits are stored, LDPC decoding starts. When LDPC decoding starts, the signs of the logarithmic extrinsic value ratios stored in extrinsic value storage section 130-k (k=0 to 7) and the logarithmic prior value ratios stored in prior value generation section 150-r (r=0 to 3) are initialized as described in “[2] Initial setting” of the flowchart.
The logarithmic extrinsic value ratios initialized by extrinsic value storage section 130-k (k=0 to 7) are inputted to row selection section 140-r (r=0 to 3). Row selection section 140-r (r=0 to 3) selects and outputs logarithmic extrinsic value ratios corresponding to rows having non-zero elements (rows in which the amount of cyclic shift is described) in the r-th column of the partial matrix (of the decoding unit of 4 columns) shown in
The selected logarithmic extrinsic value ratios are inputted to prior value generation section 150-r (r=0 to 3). Prior value generation section 150-r (r=0 to 3) calculates logarithmic prior value ratios using the inputted logarithmic extrinsic value ratios and the logarithmic likelihood ratio inputted from likelihood storage section 110 as shown in “[6] Calculation of prior value (column processing)” of the flowchart. The logarithmic prior value ratios obtained correspond to the rows having non-zero elements among the columns of the partial matrix to be decoded.
The logarithmic prior value ratios outputted from prior value generation section 150-r (r=0 to 3) are inputted to column selection section 160. Column selection section 160 selects and outputs logarithmic prior value ratios corresponding to non-zero elements of each row regarding each partial matrix composed of four columns to be decoded shown in
The logarithmic prior value ratios corresponding to non-zero elements of each row selected in column selection section 160 are inputted to extrinsic value update section 170-k (k=0 to 7). Extrinsic value update section 170-k (k=0 to 7) updates a logarithmic extrinsic value ratio corresponding to each row using the inputted logarithmic prior value ratios as shown in “[7] Calculation of extrinsic value (row processing)” of the flowchart. Thus, extrinsic value update section 170-k (k=0 to 7) has the function of updating a logarithmic extrinsic value ratio corresponding to each row of a partial matrix to be decoded.
As described above, the decoding process is performed in decoding order j in
Thus, decoder 100 performs the decoding process corresponding to decoding order j and updates logarithmic extrinsic value ratios. When last decoding order J (decoding order J=3 in
Decoder 100 then repeats the decoding process a predetermined number of times (itmax times). After performing the decoding process the predetermined number of times, prior value generation section 150-3 calculates an output soft decision value and outputs the output soft decision value calculated as shown in “[12] Calculation of output hard decision value” of the flowchart.
Hard decision section 180 acquires a hard decision value from the inputted soft decision value and outputs the hard decision value as a decoded bit.
Thus, in the present embodiment, decoder 100 performs decoding for each partial matrix. At this time, the number of logarithmic prior value ratios inputted to extrinsic value update section 170-k (k=0 to 7) is the same as a row weight of each partial matrix. Therefore, by dividing the check matrix to form partial matrices so that the row weight becomes a minimum, it is possible to minimize the number of logarithmic prior value ratios inputted to extrinsic value update section 170-k (k=0 to 7). This minimizes the number of inputs to a minimum value search and a second value search in “[7] Calculation of extrinsic value (row processing)” of the flowchart and as a result, can minimize the number of comparators making up extrinsic value update section 170-k (k=0 to 7).
The LDPC decoding algorithm and the configuration of the decoder adaptable to a code rate (hereinafter referred to as “first code rate”) arbitrarily selected from among a plurality of code rates have been descried so far. Next, an LDPC decoding algorithm and a decoder adaptable to a second code rate which is greater than the first code rate will be described.
The column weight represents the maximum number of elements “1” that exist in each column of the check matrix. For example, the column weight of the first check matrix shown in
A case will be described below where decoding using the second check matrix is performed when the first check matrix is used for the check matrix which becomes the base for circuit sharing. That is, a case will be described below where decoding corresponding to the second check matrix is performed using decoder 100 adaptable to the first check matrix as the basic configuration while achieving circuit sharing.
To achieve circuit sharing, the decoding algorithm adaptable to the second check matrix in
As described above, the number of prior value generation sections 150 required corresponds to the number of columns of the partial matrix. To suppress an increase in the circuit scale and perform decoding adaptable to a plurality of code rates, the present embodiment sets as many columns making up the second partial matrix as columns making up the first partial matrix. This allows prior value generation section 150-r (r=0 to 3) to be adaptable to both the first code rate and the second code rate.
Furthermore, as described above, extrinsic value update section 170-k (k=0 to 7) requires the same number of comparators as a row weight of the partial matrix
However, as shown in
Therefore, to be adaptable to both the first and second partial matrices, extrinsic value update section 170-k (k=0 to 7) needs to have four comparators. However, the circuit scale increases as the number of comparators increases.
Thus, the present embodiment distributes submatrices having row weights (that is, non-zero elements) in the second partial matrix so that the number of inputs to extrinsic value update section 170-k (k=0 to 7) becomes equal to or less than that when the first partial matrix is used. To be more specific, the number of rows of the second check matrix is expanded and non-zero elements of a row having a larger number of row weight of the second partial matrix are arranged in the expanded rows to distribute the row weights.
For example, non-zero element “10” in the 0-th column of the 0-th row of second partial matrix #2-0 and non-zero element “14” in the first column of the 0-th row of second partial matrix #2-0 are distributed to different rows. At this time, as shown in
Thus, row weights are distributed by expanding the number of rows of the second check matrix and arranging non-zero elements of a row with a larger number of row weights of the second partial matrix in the expanded row.
Hereinafter, a check matrix obtained by expanding the number of rows of the second check matrix and arranging non-zero elements of the row with a larger number of row weights of the second partial matrix in the expanded row will be called “distributed check matrix.” Suppose the number of rows of the distributed check matrix is equal to or less than the number of rows of the first check matrix which is the sharing source.
For example, the row weight of distributed partial matrix #2-0 after the distribution is 2 and can be made smaller than row weight 4 of the second partial matrix before the distribution.
As described above, the present embodiment uses the first check matrix whose column weight becomes the largest between the first and second check matrices adaptable to the first and second code rates respectively for the check matrix which becomes the source for circuit sharing (see
[13] Hierarchical Combination Processing: ST201
In order to be adaptable to the second check matrix, the present decoding algorithm adds hierarchical combination processing after ST108. The present decoding algorithm distributes matrix elements of the check matrix shown in
[13]
αmin(i,m,z)=min(αmin(i,a,z),αmin(i,b,z)) (Equation 13-1)
α2nd(i,m,z)=min2(αmin(i,a,z),α2nd(i,a,z),αmin(i,b,z),α2nd(i,b,z)) (Equation 13-2)
αind(i,m,z)=minind(αind(i,a,z),αind(i,b,z)) (Equation 13-3)
αsig(i,m,z)=αsig(i,a,z)×αsig(i,b,z) (Equation 13-4)
where a and b represent row numbers of the expanded rows obtained by decomposing the m-th row. Furthermore, minind(•) is a function that returns αind(i, a, z) when a min function selects αmin (i, a, z) as a minimum value and returns αind(i, b, z) otherwise.
The above-described hierarchical combination processing is performed after the column processing and row processing in last decoding order J of maximum update count itmax end (ST108: NO).
The decoding algorithm adaptable to the second check matrix has been described so far.
Next, the configuration of a decoder adaptable to the first code rate and the second code rate will be described.
Column processing/row processing calculation section 120A includes extrinsic value storage sections 130A-0 to 130A-7, row selection sections 140A-0 to 140A-3, prior value generation sections 150A-0 to 150A-3, column selection section 160A, extrinsic value update sections 170A-0 to 170A-7 and hierarchical combination section 190.
Row selection sections 140A-0 to 140A-3 are different from row selection sections 140-0 to 140-3 in the point that a partial matrix is set to either one of the first partial matrix or the distributed partial matrix according to information of input code rate. Once the partial matrix is set, row selection sections 140A-0 to 140A-3 thereafter select and output logarithmic extrinsic value ratios corresponding to non-zero elements of the corresponding partial matrix as in the case of row selection sections 140-0 to 140-3. In this way, row selection sections 140A-0 to 140A-3 perform row processing adaptable to different code rates.
Prior value generation sections 150A-0 to 150A-3 are different from prior value generation sections 150-0 to 150-3 in that a corresponding partial matrix is set to one of the first partial matrix and the distributed partial matrix according to information on the input code rate. Once the partial matrix is set, prior value generation sections 150A-0 to 150A-3 thereafter shift (rearrange) and output logarithmic prior value ratios according to the amount of cyclic shift of the corresponding partial matrix as in the case of prior value generation sections 150-0 to 150-3. In this way, row selection sections 140A-0 to 140A-3 output logarithmic extrinsic value ratios according to different code rates.
As in the case of prior value generation sections 150-0 to 150-3, prior value generation sections 150A-0 to 150A-3 each have an adder and calculate logarithmic prior value ratios using the adder. As described above, since the first partial matrix and the distributed partial matrix are composed of the same number of columns, decoder 100A needs only to include as many prior value generation sections as columns of the first partial matrix. Therefore, prior value generation sections 150A-0 to 150A-3 made up of adders are sharable with respect to different code rates.
Column selection section 160A is different from column selection section 160 in the point that a corresponding partial matrix is set to either one of the first partial matrix or the distributed partial matrix according to the information of a input code rate. Once the partial matrix is set, column selection section 160A thereafter selects and outputs logarithmic prior value ratios corresponding to non-zero elements of the partial matrix as in the case of column selection section 160. In this way, column selection section 160A performs column processing accommodating different code rates.
Extrinsic value update sections 170A-0 to 170A-7 are different from extrinsic value update sections 170-0 to 170-7 in the point that a corresponding partial matrix is set to either one of the first partial matrix or the distributed partial matrix according to information of a input code rate. Once the partial matrix is set, extrinsic value update sections 170A-0 to 170A-7 update logarithmic extrinsic value ratios corresponding to each row using logarithmic prior value ratios as in the case of extrinsic value update sections 170-0 to 170-7. In this way, extrinsic value update sections 170A-0 to 170A-7 update logarithmic extrinsic value ratios according to different code rates.
The row weight of the check matrix after distribution (distributed check matrix) is equal to or less than the row weight of the check matrix which is the sharing source (first check matrix). Thus, the number of inputs to extrinsic value update sections 170A-0 to 170A-7 is equal to or less than the row weight of the sharing source check matrix, and therefore extrinsic value update sections 170A-0 to 170A-7 can perform row processing for different code rates. That is, comparators making up extrinsic value update sections 170A-0 to 170A-7 are sharable with respect to different code rates.
Hierarchical combination section 190 receives the logarithmic extrinsic value ratios which is output from extrinsic value update sections 170A-0 to 170A-7. Hierarchical combination section 190 performs calculations shown in equations 13-1 to 13-4 using the input logarithmic extrinsic value ratios. Hierarchical combination section 190 performs the calculations shown in equations 13-1 to 13-4 to thereby obtain logarithmic extrinsic value ratios corresponding to the second check matrix before the distribution.
The logarithmic extrinsic value ratios corresponding to the second check matrix as shown in equations 13-1 to 13-4 are obtained by comparison. For that purpose, hierarchical combination section 190 includes a comparator.
Hierarchical combination section 190 distributes logarithmic extrinsic value ratios corresponding to rows of the second check matrix before the distribution as logarithmic extrinsic value ratios corresponding to rows of the distributed check matrix after the distribution and outputs the distributed logarithmic extrinsic value ratios to extrinsic value storage sections 130A-0 to 130A-7.
Extrinsic value storage sections 130A-0 to 130A-7 store the logarithmic extrinsic value ratios outputted from hierarchical combination section 190.
As described above, in the present embodiment, decoder 100A is a decoder that decodes a LDPC coded bit of a code rate selected from among a plurality of code rates by using the check matrix corresponding to its code rate. Column processing/row processing calculation section 120A then repeats column processing and row processing using likelihood and a partial matrix corresponding to the check matrix of its code rate to calculate a soft decision value. To be more specific, when the selected code rate is a first code rate, column processing/row processing calculation section 120A uses the first partial matrix selected and combined from the first check matrix of its first code rate according to the number of columns used in column processing. Here, the number of columns used in the column processing is equal to or more than one and is set in consideration of the circuit scale. On the other hand, when the set code rate is a second code rate, column processing/row processing calculation section 120A uses a distributed partial matrix resulting from selecting and combining the same number of columns as the columns making up the first partial matrix from the distributed check matrix in accordance with the second check matrix adaptable to the second code rate. Here, the second code rate is a code rate greater than the first code rate.
Here, the distributed check matrix is a matrix resulting from expanding the number of rows of the second check matrix, distributing and arranging elements of a row with a larger number of row weight of the second check matrix across the original row and the expanded row. At this time, column processing/row processing calculation section 120A uses a distributed partial matrix whose row weight is equal to or less than the row weight of the first partial matrix.
Thus, the number of logarithmic prior value ratios which is input to extrinsic value update section 170A-k (k=0 to 7) falls to or below a row weight of the first partial matrix regardless of the selected code rate. As a result, it is possible to share a comparator making up extrinsic value update section 170A-k (k=0 to 7) among different code rates (first code rate and second code rate).
Furthermore, in the present embodiment, the first check matrix and distributed check matrix are divided into the first partial matrix and distributed partial matrix, and column processing is performed using the divided first partial matrix and distributed partial matrix as a processing unit. Here, suppose the number of columns of the distributed partial matrix is equal to the number of columns of the first partial matrix. Thus, the number of prior value generation sections 150A-m (m=0 to 3) required is equal to the number of columns making up the first partial matrix and distributed partial matrix regardless of the set code rate. That is, it is possible to share, among different code rates, prior value generation section 150A-m (m=0 to 3) configured using an adder.
Furthermore, extrinsic value storage section 130A-k (k=0 to 7) receives the same number of logarithmic prior value ratios as rows making up the first check matrix as input. For this reason, it is possible to share extrinsic value storage section 130A-k (k=0 to 7) among different code rates by setting the number of rows of the distributed check matrix to a value equal to or less than the number of rows of the first check matrix.
Thus, according to the present embodiment, it is possible to share the storage apparatus (extrinsic value storage section) for logarithmic extrinsic value ratios, the adder (prior value generation section) for calculating logarithmic prior value ratios and the comparator (extrinsic value update section) for updating the logarithmic extrinsic value ratios.
Decoder 100A shown in
On the other hand, in a broadcasting system or in a one-to-multiple multicast data communication mode, the receiver need not send back any acknowledgment response to the transmitter. That is, there is no limitation on a processing delay required for decoding. In such a case, instead of independently providing hierarchical combination section 190, as in the case of decoder 100B shown in
As described above, the extrinsic value update sections and hierarchical combination section are each configured using a comparator. Therefore, the comparator of the extrinsic value update section can also be used for hierarchical combination processing. In this way, using the same comparator as the comparator making up the hierarchical combination section and as the comparator making up the extrinsic value update section makes it possible to reduce the circuit scale of decoder 100B.
Hereinafter, the decoding process in decoders 100A and 100B that adopt the configurations shown in
Extrinsic value update sections 170A-0 and 170A-1 update extrinsic values in the decoding order shown in
Decoder 100A shown in
On the other hand,
Extrinsic value update sections 170B-0 and 170B-1 update extrinsic values in the decoding order shown in
In
When a distributed check matrix is formed, if there are a plurality of rows whose row weight is distributed, extrinsic value update sections 170B-p and 170B-(p+1) (p is a positive even number) that calculate logarithmic extrinsic values corresponding to the rows perform hierarchical combination processing in the same way as extrinsic value update sections 170B-0 and 170B-1.
Extrinsic value update sections 170B-0 and 170B-1 distribute the logarithmic extrinsic value ratio obtained through a hierarchical combination to logarithmic extrinsic value ratios corresponding to the distributed rows, and extrinsic value update sections 170B-0 and 170B-1 output the distributed logarithmic extrinsic value ratios to extrinsic value storage sections 130A-0 and 130A-1.
Thus, decoder 100B shown in
Thus, decoder 100A in
The disclosure of Japanese Patent Application No. 2010-177538, filed on Aug. 6, 2010, including the specification, drawings and abstract is incorporated herein by reference in its entirety.
The error correcting decoding apparatus and error correcting decoding method according to the present invention are suitable for use in a communication apparatus using LDPC code or the like. Furthermore, the present apparatus and method are also applicable to a broadcasting receiving apparatus, storage media or the like.
Number | Date | Country | Kind |
---|---|---|---|
2010-177538 | Aug 2010 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2011/004396 | 8/3/2011 | WO | 00 | 2/4/2013 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2012/017652 | 2/9/2012 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5181207 | Chapman | Jan 1993 | A |
6628723 | Gerlach et al. | Sep 2003 | B1 |
6999531 | Jin | Feb 2006 | B2 |
7180952 | Gerlach et al. | Feb 2007 | B1 |
7224743 | Holmes et al. | May 2007 | B2 |
7421638 | Hewitt et al. | Sep 2008 | B2 |
8286050 | Murakami et al. | Oct 2012 | B2 |
20040170236 | Kajita et al. | Sep 2004 | A1 |
20070192670 | Ikeda et al. | Aug 2007 | A1 |
20110113300 | Murakami et al. | May 2011 | A1 |
20120324309 | Murakami et al. | Dec 2012 | A1 |
Number | Date | Country |
---|---|---|
2007110265 | Apr 2007 | JP |
2007215089 | Aug 2007 | JP |
2008011078 | Jan 2008 | JP |
2009060453 | Mar 2009 | JP |
2009147541 | Jul 2009 | JP |
Entry |
---|
Wadayama, “Low Density Parity Check Code and Decoding Method,” Tricepts Publishing, Jun. 5, 2002, pp. 92-99. |
International Search report dated Sep. 13, 2011, for corresponding International Application No. PCT/JP2011/004396, 4 pages. |
Liu et al.,“An LDPC Decoder Chip Based on Self-Routing Network for IEEE 802.16e Applications,” IEEE Journal of Solid-State Circuits 43(3):684-694, Mar. 2008. |
Extended European Search Report, dated Aug. 28, 2013, for corresponding European Application No. 11814289.2-1907, 5 pages. |
Number | Date | Country | |
---|---|---|---|
20130139038 A1 | May 2013 | US |