The present invention relates to a soft output decoder, iterative decoding apparatus and soft decision value calculating method for decoding a digital signal encoded using a convolution code. More particularly, the present invention relates to a soft output decoder and soft decision value calculating method that are preferable for application to an iterative decoding apparatus that carries out decoding using a soft decision decoding result repeatedly.
It is well settled that the MAP (Maximum A posterior Probability) decoding scheme, which is the maximum a posterior probability decoding method, is presently the best soft output decoding algorithm used in decoding of turbo code. Further, there is a case where, for implementation of the circuit, the Max-log-MAP scheme is used. The Max-log-MAP scheme is similar to the MAP scheme to which log calculation is applied. As a soft decision decoding method for convolution code used inside a turbo decoder, Max-log-MAP and SOYA (Soft Output Viterbi Algorithm) are known to require a comparatively small amount of operation.
However, turbo decoding still requires a large amount of operation compared to other codes, and further reduction in the amount of operation is demanded.
In
There are three types of data sequences, systematic s(n), parity p(n) and a priori value e(n), inputted to Max-log-MAP decoder 1. Here, n=0 to K−1 hold, and K is a “block size (i.e. the number of transmission information bits).”
Max-log-MAP decoder 1 finds a soft output value Λ(n) from a received sequence y (including vectors s and p) and vector e of an extrinsic value. Λ(n) is also referred to as a “posteriori value” and is a log likelihood ratio (LLR) of transmission bits estimated by decoder 1. That is, Λ(n) is defined as in following equation 1, and, if Λ(n)>0, transmission data d(n) of the n-th bit is estimated “0” and, if Λ(n)<0, d(n) is estimated “1.” Further, the operation of acquiring the estimated value d by deciding the sign of LLR is referred to as “hard decision processing.”
With this example, two Max-log-MAP decoders 1 (hereinafter, “constituent decoders”) of
Max-log-MAP decoder 21 receives as input systematic s, first parity p1 and the extrinsic value e1 transmitted from Max-log-MAP decoder 22, and outputs Λ1 which is the first LLR.
As shown in following equation 2, a new extrinsic value e1′ is determined by subtracting systematic s and the extrinsic value e1 from Λ1.
e1′(n)=Λ1(n)−(s(n)+e1(n)) (Equation 2)
(e2) obtained by interleaving e1′, is used as an extrinsic value to input to Max-log-MAP decoder 22. Further, data obtained by interleaving systematic s and second parity p2 are inputted to Max-log-MAP decoder 22.
Based on these inputs, Max-log-MAP decoder 22 outputs Λ2 which is a second LLR. Similarly, as shown in following equation 3, a new extrinsic value e2′ is calculated by subtracting inputted systematic s(π(n)) interleaved and the extrinsic value e2 from Λ2.
e2′(n)=Λ2(n)−(s(π(n))+e2(n)) (Equation 3)
An input obtained by deinterleaving this new extrinsic value e2′ is used as a new input to Max-log-MAP decoder 21. Deinterleaving refers to “reverse rearrangement processing” corresponding to the above interleaving.
Accuracies of Λ1 and Λ2 are improved by repeating the above processings. The estimated value d̂ of the transmission bits can be acquired by carrying out a sufficient number of times of repetitions, then deciding the sign of Λ2 and carrying out deinterleaving.
Next, the detailed functions of Max-log-MAP decoding will be described. Here, all the following equations are used to decode turbo code disclosed in Non-Patent Document 1 and are only shown as examples. Generally, the following equations may be different respectively.
The α, β and γ in Max-log-MAP decoding include the following meanings. That is,
α: a total of likelihoods of a path reaching a certain state
β: a total of likelihoods of a path beyond a certain state
γ: likelihoods of branches.
γ calculation is carried out prior to α calculation and β calculation.
The following four γ's shown in following equation 4 are calculated from the n-th bit input values s (n), p (n), and e (n).
γ00(n)=(s(n)+e(n)+p(n))/2
γ01(n)=(s(n)+e(n)−p(n))/2
γ10(n)=(−s(n)−e(n)+p(n))/2
γ11(n)=(−s(n)−e(n)−p(n))/2 (Equation 4)
α is calculated according to the recurrence equation shown in following equation 5 using γ's determined as described above.
α0(n+1)=min{α0(n)+γ00(n),α4(n)+γ11(n)}
α1(n+1)=min{α4(n)+γ00(n),α0(n)+γ11(n)}
α2(n+1)=min{α1(n)+γ5(n),α5(n)+γ10(n)}
α3(n+1)=min{α5(n)+γ01(n),α1(n)+γ10(n)}
α4(n+1)=min{α2(n)+γ01(n),α6(n)+γ10(n)}
α5(n+1)=min{α6(n)+γ01(n),α2(n)+γ10(n)}α6(n+1)=min{α3(n)+γ00(n),α7(n)+γ11(n)}
α7(n+1)=min{α7(n)+γ00(n),α3(n)+γ11(n)} (Equation 5)
In above equation 5, min{a, b} represents an operation of selecting a smaller candidate from two candidates a and b. The initial value of the α is α0=0 and αi(0)=+∞(i>0). Further, the α is calculated from the smallest value of n to the largest value of n (i.e. in ascending order), and is referred to as a “forward probability.”
(3) β Calculation Similarly, the β is calculated according to the recurrence equation of following equation 6 using the γ.
β0(n)=min{β0(n+1)+γ00(n),β1(n+1)+γ11(n)}
β1(n)=min{β2(n+1)+γ01(n),β3(n+1)+γ10(n)}
β2(n)=min{β5(n+1)+γ01(n),β4(n+1)+γ10(n)}
β3(n)=min{β7(n+1)+γ00(n),β6(n+1)+γ11(n)}
β4(n)=min{β1(n+1)+γ00(n),β0(n+1)+γ11(n)}
β1(n)=min{β2(n+1)+γ01(n),β3(n+1)+γ10(n)}
β5(n)=min{β3(n+1)+γ01(n),β2(n+1)+γ10(n)}
β6(n)=min{β4(n+1)+γ01(n),β5(n+1)+γ10(n)}
β7(n)=min{β6(n+1)+γ00(n),β7(n+1)+γ11(n)} (Equation 6)
Further, the β is calculated from the largest value of n to the smallest value of n (i.e. in descending order). γ calculation carried out prior to β calculation is carried out according to the flow of β calculation. Then, s, p and e are rearranged by a FILO (First-In Last-Out) buffer and inputted to y calculating section 14a. Further, the β is referred to as the “backward probability.”
(4) Λ calculation
In A calculation, log likelihoods λ0(n) and λ1(n) are determined per bit using following equations 7 and 8. The difference between these is the log likelihood ratio (LLR) Λ(n) shown in following equation 9.
In λ calculation, α value is calculated using both α and β. The α is calculated in ascending order of n and the β is calculated in descending order of n, and so the α or β needs to be rearranged and used.
In
First, α(n) is calculated for n=0 to K−1 in steps ST1 and ST2. Here, calculation of α(n) means calculating eight values of α0(n) to α7(n). Calculated α(n) is stored in timing adjuster (i.e. FILO memory) 12.
Next, β(n) is calculated for n=K−1 to 0, insteps ST3 and ST4. After β(n) is calculated, λ0(n) and λ1(n) are calculated in step ST5 and Λ(n) is calculated in step ST6. α(n) stored in timing adjuster 12 is used to calculate λ0(n) and λ1(n). While the α is calculated in order from 0 to K−1, the λ is calculated in order from K−1 to 0, and so the timing adjuster is used.
Further, β calculation, λ calculation and Λ calculation are often pipelined. That is, while λ0(n) and λ1(n) are calculated, β(n−1) is calculated. Then, soon after calculation of λ0(n) and λ1(n) is finished, calculation of λ0(n−1) and λ1(n−1) can be started.
Non-Patent Document 1: “A comparison of optimal and sub-optimal MAP decoding algorithms operating in the log domain,” Robertson, P., Villebrun, E., Hoeher, P., IEEE International Conference on Communications, 1995. Page(s): 1009-1013 vol. 2
However, such a conventional Max-log-MAP decoding method requires a plurality of addition processings and comparison and selection processings as described above.
As shown in the table of
Further, though a Max-log-MAP decoding method needs to acquire only an estimated value of hard decision in the final stage of iterative decoding, the turbo decoder using a conventional Max-log-MAP decoding method needs to carry out hard decision after a soft decision value is determined once. Therefore, there is a problem that the large amount of operation is required and power consumption of the operation circuit cannot be reduced.
Further, there is a problem that the SOVA scheme is inferior to the Max-log-MAP scheme in error rate characteristics and involves the complex memory operation.
It is therefore an object of the present invention to provide a soft output decoder, iterative decoding apparatus and soft decision value calculating method for decreasing the amount of operation required for likelihood calculation and realizing a smaller operation circuit and reducing the processing delay time.
The soft output decoder according to the present invention that receives code words corresponding to a plurality of information words and calculates soft decision decoding results of the information words from a plurality of likelihood values corresponding to a plurality of candidate values adopted by the information words, employs a configuration including: a hard decision decoding section that decides one of the plurality of candidate values as an estimated value; and a likelihood calculating section that bans calculation of a likelihood value corresponding to the estimated value and calculates likelihood values corresponding to other candidate values in the plurality of likelihood values.
The iterative decoding apparatus according to the present invention is an iterative decoding apparatus that repeats soft output decoding and includes the soft output decoder according to the present invention, and this soft output decoder includes: a boundary likelihood calculating section that defines one of the information words as a boundary portion and finds a plurality of boundary likelihood values corresponding to the plurality candidate values adopted by the information words in the boundary portion; and an initial state number specifying section that specifies a state number to which a maximum likelihood branch is connected using the boundary likelihoods and the hard decision decoding section decides an estimated value for information words other than the boundary portion using the state number, and this iterative decoding apparatus further employs a configuration including a commanding section that, when repetition is final, commands the soft output decoder to output the hard decision value and to stop outputting the soft decision value.
The soft decision value calculating method according to the present invention for receiving code words corresponding to a plurality of information words and calculating soft decision decoding results of the information words from a plurality of likelihood values corresponding to a plurality of candidate values adopted by the information words, includes: deciding one of the plurality of candidate values as an estimated value; and banning calculation of a likelihood value corresponding to the estimated value and calculating likelihood values corresponding to other candidate values in the plurality of likelihood values.
The present invention is able to decrease the amount of operation required for likelihood calculation and realize a smaller operation circuit, lower power consumption and reduced processing delay time. By applying the present invention to the Max-log-MAP decoding method, the amount of operation in turbo decoding can be decreased significantly.
Embodiments of the present invention will be described below in detail with reference to the accompanying drawings.
First, the basic principle of the present invention will be described.
To describe the principle of the invention, illustration of a Max-log-MAP decoding method by a graph will be introduced. Hereinafter, in the drawings referred to in the embodiments, the solid lines in trellis diagrams are branches corresponding to transmissionbit=0 and the broken lines are branches corresponding to transmission bit=1.
λ0 is calculated by calculating α+β+γ corresponding to the eight solid lines shown in
Further, the number of nodes aligned vertically in the graph is referred to as “the number of states.” Here, the turbo coding scheme of Non-Patent Document 1 is used, and so the number of states is eight. Further, connections (branches) between nodes are determined depending on the coding scheme.
As shown in
In this way, according to the LLR calculating method, α+β+γ is calculated for total sixteen branches, the maximum likelihood value is selected from branches (eight branches) corresponding to transmission bit=0 and the maximum likelihood value is selected from branches (eight branches) corresponding to transmission bit=1. The difference between two maximum likelihood values λ0 and λ1 is the soft decision value.
The above is a general concept of Max-log-MAP decoding and the invention based on the inventor's observation and property found by this observation will be described.
Next, two consecutive time points will be discussed. Here, a time point refers to the period it takes to decode one bit, in the graph.
In
Here, the higher likelihood between “the maximum likelihood branch in solid lines” and “the maximum likelihood branch in broken lines” will be referred to as “the maximum likelihood branch.” For example, if λ0(n)>λ1(n) holds in
Now, the following assumption is provided.
[Assumption 1] The likelihood values in maximum likelihood branches are fixed values.
Further, although this is an assumption here, no calculation error has occurred when this assumption is actually evaluated based on <algorithm 1> described later. That is, with [assumption 1], practically, there is no problem.
Utilizing these assumptions, with the present invention, Max-log-MAP decoding is carried out as follows.
<Algorithm 1> (1) The type of the maximum likelihood branch (either 0: the solid line or 1: the broken line) is specified. (2) If the bit corresponding to the maximum likelihood branch is 0 (i.e. the solid line) in the time point n, assuming that λ0(n)=λwin, only λ1(n) is calculated using above equation 8. If the bit is 1, assuming that λ1(n)=λwin, only λ0(n) is calculated using above equation 7.
By so doing, the calculation of one of λ0(n) and λ1(n) can be omitted.
Next, the method of specifying the type of the maximum likelihood branch will be described. According to conventional Max-log-MAP decoding, it is not until both λ0(n) and λ1(n) are calculated that the maximum branch can be specified. However, if the maximum likelihood branch cannot be specified without calculating λ0(n) and λ1(n), the effect of reducing the amount of operation according to <algorithm 1> is not possible.
The following assumption is provided to think about the method of specifying the type of the maximum likelihood branch.
[Assumption 2] The maximum likelihood branch is connected continuously on the graph.
Further, although this is an assumption here, no calculation error has occurred when this assumption is actually evaluated based on <algorithm 1-A> described later. That is, with [assumption 2], practically, there is no problem.
Here, the series of the maximum likelihood branches will be referred to as a “maximum likelihood path.”
According to [assumption 2], all maximum likelihood branches can be specified by tracing the maximum likelihood path using one maximum likelihood branch as the base point. Further, a node through which the maximum likelihood path pass will be referred to as a “maximum likelihood path state.” The maximum likelihood path can be specified by specifying the maximum likelihood path states one after another using one maximum likelihood path state as the base point. This algorithm will be described below.
<Algorithm 1-A> (Method of specifying the type of a maximum likelihood branch) (1-1) The maximum likelihood path state initial value is specified. (1-2) By comparing the likelihoods of branches connected to the maximum likelihood path state, a branch having the highest likelihood is the maximum likelihood branch. Information showing whether the branch is a branch corresponding to 0 (i.e. a solid line) or a branch corresponding to 1 (i.e. a broken line) is outputted. (1-3) The connection destination of the maximum likelihood branch is specified as the next maximum likelihood path state.
Then, above (1-2) and (1-3) are repeated.
<Algorithm 1-A> will be described in detail using
In
Branches connected to S0 are only Y1 and Y2 and so the next maximum likelihood path state is one of S1 and S4.
α+β+γ is calculated to specify which one of Y1 and Y2 is the maximum likelihood branch is specified in step (1-2). The likelihood (λ[Y1]) of Y1 is calculated according to λ[Y1]=α2(n)+β4(n)+γ10(n) and the likelihood (λ[Y2]) of Y2 is calculated according to λ[Y2]=α6(n)+β4(n)+γ01(n). Then, λ[Y1] and λ[Y2] are compared, and, if the likelihood of X[Y1] is greater (if the value is smaller), Y1 is the maximum likelihood branch. Consequently, the value 1 corresponding to the maximum likelihood branch is outputted.
The maximum likelihood branch can be specified in above (1-2), so that, in step (1-3), S1, which is the connection destination, can be specified as the maximum likelihood path state.
In this case, only the relationship between sizes of λ[Y1] and λ[Y2] needs to be determined, and so β4(n), a common term, may be omitted and two of λ′[Y1]=α2(n)+γ10(n) and λ′[Y2]=α6(n)+γ01(n) may be compared.
S1 can be specified as the maximum likelihood path state, and, consequently, the next maximum likelihood path state S2 can be specified in the same steps.
As described above, <algorithm 1-A> makes it possible to acquire the same result as when hard decision is carried out after Max-log-MAP decoding is carried out, without calculating all likelihoods, and, consequently, Max-log-MAP decoding in which the amount of operation for likelihood calculation is reduced can be realized by utilizing the result in the above step (1) of <algorithm 1>.
By this means, Max-log-MAP decoding is different from the step referred to as “A operation (i.e. LLR operation)” in the conventional Max-log-MAP decoding method, and processing to calculate all branches (for example, sixteen branches) becomes unnecessary even though only two values are used finally, so that the amount of calculation is decreased.
By the way, <algorithm 1-A> does not aim to completely specify maximum likelihood branches, but requires only types of maximum likelihood branches. Consequently, instead of <algorithm 1-A>, a generally known hard decision decoding method (for example, the Viterbi decoding method) may be employed in the above step (1) of <algorithm 1-A>.
Although it is anticipated that an ideal Viterbi decoding result and an ideal Max-log-MAP decoding hard decision result match, simple implementation methods such as the register exchanging method for Viterbi decoding and the sliding window method for Max-log-MAP are employed in practice, and so the results are not likely to match. In this case, although the effect of reducing the amount of operation can be acquired by applying <algorithm 1>, some calculation errors occur.
Next, how to find the maximum likelihood path state initial value in <algorithm 1-A> will be described. Processing of calculating the maximum likelihood path state initial value in <algorithm 1-A> will be described in <algorithm 1-A-1>.
<Algorithm-A-1> (1-1-1) In the time point K-1 (that is, for the last bit of the decoding target), the likelihoods λ0(K−1) and λ1(K−1) are calculated in the same way as in general Max-log-MAP decoding. At this point, which branch is the maximum likelihood branch is stored. (1-1-2) The node to which the maximum likelihood branch is connected is made the maximum likelihood path state initial value. Using this node as the base point, processing of n=K−2 to 0 is carried out according to <algorithm 1-A>. (1-1-3) Further, in the likelihoods λ0(K−1) and λ1(K−1) determined in (1-1-1), the higher likelihood (i.e. the smaller value) is made λwin in algorithm 1.
As shown in
Then, the node S0 is decided as the maximum likelihood path state, and so <algorithm 1-A> is applied to n=K−2 to 0 using the node S0 as the base point.
By so doing, completely the same result as when hard decision is carried out after general Max-log-MAP decoding is carried out can be acquired, and, as a result, the amount of operation for likelihood calculation with respect to n=K−2 to 0 can be reduced according to algorithm 1.
Further, a method different from <algorithm 1-A> also makes it possible to acquire types of maximum likelihood branches (acquire the hard decision value). This method will be described.
Method in Place of <Algorithm 1-A>
To prepare description, α calculation is shown by the graph.
As shown in
By the way, according to (1-2) of <algorithm 1-A>, by selecting α+γ of the larger from branches connected to the left side of the maximum likelihood path state, the maximum likelihood branch is specified and the hard decision value is acquired.
Then, in α calculation, when the values of α+γ are compared, and information q showing which one of likelihoods is higher is stored, and, when the maximum likelihood branch is specified according to algorithm 1-A upon Λ calculation, by referring to information q, α+γ needs not to be calculated and compared again.
For example, in
<Algorithm 1-B> (1-0B) In α calculation, path selection information q is stored. (1-1) The maximum likelihood path state initial value is specified. (1-2B) Referring to path selection information q corresponding to the maximum likelihood path state, the maximum likelihood branch is specified from the branches to connect with. Information showing whether the branch is a branch corresponding to 0 (i.e. a solid line) or a branch corresponding to 1 (i.e. a broken line) is outputted. (1-3) The connection destination of the maximum likelihood branch is specified as the next maximum likelihood path state.
After (1-3), the processings of above (1-2B) and (1-3) are repeated.
As described above, compared to <algorithm 1-A>, according to <algorithm 1-B>, while the memory storing path selection information increases, the processing of the step (1-2) is simplified.
The same method as <algorithm 1-A> can be applied to specify the maximum likelihood path state initial value in the above step (1-1). That is, <algorithm 1-A-1 and <algorithm 1-B> can be used in combination. Details of this combination will be described in Embodiment 2.
In this way, the present invention is directed to reducing the amount of calculation by deciding branches of higher likelihoods in advance and by omitting calculation of branches of the same type as the branches of higher likelihoods.
The present embodiment shows examples of implementation of above <algorithm 1>, <algorithm 1-A> and <algorithm 1-A-1>.
In
The operation of soft output decoder 100 configured as described above will be described below.
First, α(n) is calculated for n=K−1 to 0 in steps ST11 and ST12. Here, calculation of α(n) means calculating eight values of α0(n) to α7(n). Calculated α(n) is stored in timing adjuster (i.e. the FILO memory) 102. α calculation in γα calculating section 101 is carried out in the same way as a conventional art.
Steps ST13 and ST14 are boundary processing in <algorithm 1-A-1>. The boundary processing is carried out in losing likelihood calculating section 112, the determined maximum likelihood path state is stored in hard decision decoding section 111 and λwin is stored in winning likelihood storing section 113.
Next, β(n) is calculated for n=K−1 to 0 in steps ST15 and ST16. β calculation in γβ calculating section 104 is carried out in the same way as a conventional art.
In step ST17, hard decision decoding section 111 calculates the hard decision bit d(n). Hard decision decoding section 111 calculates the hard decision value d(n) (corresponding to the type of the maximum likelihood branch) according to above (1-2) of <algorithm 1-A>.
In step ST18, hard decision decoding section 111 updates the maximum likelihood path state. Hard decision decoding section 111 specifies the next maximum likelihood path state according to above (1-3) of <algorithm 1-A>.
In step ST19, losing likelihood calculating section 112 calculates λlose(n) according to above (2) of <algorithm 1>.
Next, in step ST20, Λ(n) is calculated and the flow returns to above step ST15. By specifying the associations between λwin (n), λlose (n), λ0(n) and λ1(n) based on the hard decision value d(n), Λ(n)=λ0(n)−λ1(n) is calculated. This calculation is carried out by subtractor 114 with the sign operation functions.
Next, each block of soft output decoder 100 will be described.
[Losing Likelihood Calculating Section 112]
Losing likelihood calculating section 112 included in Λ calculating section 110 has following two functions. (1) Calculating λlose(n) in above step ST19. (2) Finding λwin and the maximum likelihood path state in above steps ST13 and ST14.
Of these, the main function of losing likelihood calculating section 112 is the processing of λlose(n) calculation in the above step of ST19. In view of the above, the functions of above (2) and (3) of <algorithm 1-A-1> can be realized by appropriating losing likelihood calculating section 112, so that this is employed with the present embodiment.
First, losing likelihood calculating section 112 that realizes only above step ST19 will be described.
Losing likelihood calculating section 112 calculates λlose(n) which is a value of either λ0(n) and λ1(n) having a smaller likelihood (a larger value). Which one of two likelihoods λ0(n) and λ1(n) is smaller is decided based on the output d(n) from hard decision decoding section 111. When the hard decision output d(n) is 1, λ0(n)>λ1(n) holds and so the likelihood value λ0(n) is calculated, and, when the hard decision output d(n) is 1, the likelihood value λ1(n) is calculated. The calculated value is inputted to subtractor 114.
The above processing can be represented by following equation 10.
In
In
Further, in
The above function corresponds to “calculation of λlose” of step ST19 in the flowchart of
Next, the method of realizing processing of finding λwin and the maximum likelihood path state in steps ST13 and ST14 in the flowchart of
In
As shown in
For example, when d (n)=1, although minimum value selector (min) 151 selects the minimum value from α0(n)+β0(n), α4(n)+β1(n), α7(n)+β6(n) and α3(n)+β7(n), if α4(n)+β1(n) is selected, the value “4” showing that the value related to α4(n) has been selected, is outputted to maximum likelihood path state candidate determining section 160.
Maximum likelihood path state candidate determining section 160 outputs the signal s(n) showing which value is finally selected. For example, when LL_lose=α2(n)+β4(n)+γ10(n) is selected, s(n)=2 is outputted.
Steps of finding λwin and the maximum likelihood path state using this losing likelihood calculating section 112B will be described.
Step ST21 to step ST23 correspond to step ST13 in
First, λ0 (K−1) is determined in step ST21 by fixing d(n)=1 in losing likelihood calculating section 112B. This value is stored in winning likelihood storing section 113 as a provisional winning likelihood λwin. Further, the maximum likelihood path state candidate s(n) in this case is transmitted to hard decision decoding section 111 (see
λ1 (K−1) is determined in step ST22 by fixing d(n)=0 in losing likelihood calculating section 112B. This is made the provisional λlose.
In step ST23, subtractor 114 calculates the difference between the provisional λwin and provisional λlose. This calculation result is the decoding result of n=K−1, A(K−1).
In step ST24, the sign of Λ(K−1) is decided, and, if the likelihood of the provisional λwin (λ0 (K−1)) is higher (A (K−1)>0), the provisional λwin is the true λwin, and so the λwin stored in step ST21 is left as is. On the other hand, if the likelihood of λlose (λ1(K−1)) is higher (Λ(K−1)>0), the provisional λlose is the true λwin. Then, the provisional λlose outputted from losing likelihood calculating section 112B is stored in winning likelihood storing section 113 (see
Similar to processing in step ST24, in step ST25, if the likelihood of λlose is decided to be higher, a signal to update the value of s (n) is transmitted to hard decision decoding section 111.
Next, hard decision decoding section 111 will be described. Hard decision decoding section 111 realizes <algorithm 1-A>.
[Hard Decision Decoding Section 111]
In
As shown in
Prior state selecting section 201 (prior state selecting section 0) finds the state number (S4) connected with the present maximum likelihood path state number (S0) by a solid line. Further, prior state selecting section 202 (prior state selecting section 1) finds the state number (S1) connected with the present maximum likelihood path state number (S0) by a broken line.
αγ selectors 211 and 212 select the α of the state number selected by prior state selecting section 201 (prior state selecting section 0) and the γ corresponding to the α, from inputted eight α's and four γ's (α6(n) and γ01(n)).
Adders 221 and 222 add outputs of αγ selector 211 (αγ selector 0) (γ′0(n)=α6(n)+γ01(n)).
Comparator 230 compares the outputs of two adders 221 and 222. If λ′0(n)>λ′1(n), d(n)=0 is outputted, and otherwise, d(1)=1 is outputted.
The above is the maximum likelihood branch specifying processing corresponding to above (1-2) of <algorithm 1-A>.
Further, state updating section 240 selects the state number finally decided by comparator 230 to have the higher likelihood in outputs of two prior state selecting sections 201 and 202, and transmits the state number to maximum likelihood path state storing section 200.
For example, if d(n)=0 is decided, the output of prior state selecting section 201 (prior state selecting section 0) is transmitted as a new maximum likelihood path state to maximum likelihood path state storing section 200.
As described above, according to the present embodiment, a plurality of likelihoods determined in the Max-log-MAP decoder are identified as either winning likelihoods or losing likelihoods and only the losing likelihoods are calculated, so that two likelihood calculating section required conventionally can be reduced to one and the circuit scale and power consumption can be reduced.
Further, hard decision decoding section 111 that sequentially specifies the states through which the maximum likelihood path passes is used for the method of identifying winning likelihoods and losing likelihoods, so that the Max-log-MAP decoder does not require a large circuit additionally and can be realized with a simple configuration.
Further, hard decision decoding section 111 employs the same method as general Max-log-MAP in the boundary between data processing units such as the end of data and carries subsequent processings with the above simple method using the result of Max-log-MAP as the initial value, so that exactly the same result as in Max-log-MAP decoding can be acquired with a small circuit scale and little power consumption.
As shown in the following table, compared to the conventional Max-log-MAP decoding method shown in the table of
An example of implementation of <algorithm 1-B> described in (basic principle) will be described with the present embodiment.
In
The difference from soft output decoder 100 of Embodiment 1 is as follows.
In soft output decoder 300 of the present embodiment, α calculating section 301a of γα calculating section 301 is configured to output path selection information q. Path selection information q is inputted to hard decision decoding section 311 by adjusting the timing by timing adjuster 302 composed of the FILO memory.
Further, the internal configuration of hard decision decoding section 311 in A calculating section 310 is different. The α and γ need not to be inputted to hard decision decoding section 311.
In
α calculating section 301a is an α calculating block and carries out calculation based on above equation 5. For two inputs a and b, size comparator 322 and selector 323 output “b” if a>b and outputs “a” otherwise.
As the value of q, 0 is outputted when the branch related to γ00 or γ01 is selected and 1 is outputted when the branch related to γ10 or γ11 is selected.
The overall processing flow is almost the same. In α calculation, different steps which are assigned “′” are step ST12′ for outputting q(n), step ST17′ of the calculating method for the hard decision bit d(n) and step ST18′ of the maximum likelihood updating method.
In
As shown in
Prior state selecting section 332 specifies state numbers ahead of the maximum likelihood branch according to the hard decision value d(n). Further, the configuration of losing likelihood calculating section 112, which is the feature of the present invention, is exactly the same as in Embodiments 1 and 2.
Furthermore, the principle of the present invention is applicable to the “sliding window scheme” and “subblock dividing scheme” known as schemes for efficient implementation of Max-log-MAP decoding, so that the amount of operation for likelihood calculation can be reduced without producing calculation errors.
Further, the principle of the present invention is applicable to general turbo code, and can be appropriated for, for example, turbo code referred to as “Duo-Binary Turbo” different from Non-Patent Document 1. That is, when there are two or more types of branches, one maximum likelihood branch is specified and likelihood calculation for the same type of branches as the maximum likelihood branch is omitted.
A case will be described below with Embodiment 3 as an example where the present invention is applied to the “sliding window scheme.”
A case will be described with the present embodiment where the above basic principle is applied to the “sliding window” scheme.
First, the sliding window scheme will be described.
The sliding window scheme is directed to dividing the data sequence of length K into small blocks (i.e. windows) of length L (L<K) and carries out α calculation, calculation and Λ calculation, per window (see Non-Patent Document 1). According to the sliding window scheme, α calculation and β calculation can be parallelized, thereby speeding up decoding processing, and the volume of a memory of the timing adjuster requires only the window length, thereby reducing the amount of memory.
Next, the calculation steps of the sliding window scheme will be described.
As shown in
As shown in
After α calculation for window 0 is finished, next, α calculation is carried out for window 1 and β calculation is carried out for window 0 at the same time. When β starts being outputted from the β calculating section, Λ calculation is carried out following β calculation (see the step (2) of
By the way, calculation of β(n) is sequentially carried out for n=K−1 to 0 using β (K−1) as the initial value. The value of β (L) is required as the initial value to carry out β calculation for window 0.
Then, while carrying out α calculation for window 0 in step (1) shown in
When α calculation for all windows (window 0 to window (J−1)) is finished, β calculation and Λ calculation are finished after time delay of one window.
As described above, according to the sliding window scheme, by carrying out α calculation, β·Λ calculation and derivation of the β boundary value in parallel, Max-log-MAP decoding is carried out at high speed.
In
β boundary value generating section 109 has the same function as β boundary value generating section 19 of
As shown in
The principle of the present invention is applicable as is to the sliding window scheme. There are the following two points.
That is, the value of λwin may vary between windows, and so λwin is calculated every time calculation in a new window starts. In the calculation method, the same operation carried out for the tail of data (n=K−1) may be carried out in the window boundary such as n=L−1.
Further, the maximum likelihood path state initial value is derived every time calculation in a new window starts.
Particularly, soft output decoder 400 carries out Max-log-MAP processing (that is, calculates two likelihoods λ0(n) and λ1(n)) only in the window boundary and carries out hard decision decoding processing using the values determined then as the initial value (i.e. maximum likelihood path state initial value). By this means, according to the present embodiment, when window division processing is carried out, the same hard decision result as when general Max-log-MAP is carried out, can be acquired.
Further, other than the sliding window scheme, the principle of the present invention is applicable likewise as long as the processing streamlining technique of Max-log-MAP is based on data division. That is, by applying <algorithm 1-A-1> described in the basic principle of the present invention to one of both ends of divided data, soft decision decoding can be carried out in the same processing steps as in streamlined Max-log-MAP, so that the amount of operation can be reduced and power consumption can be decreased compared to the processing streamlining technique of conventional Max-log-MAP.
As an example of the processing streamlining technique of Max-log-MAP based on above data division, there is parallelization using subblock division. Parallelization using subblock division refers to dividing input data into a plurality of blocks and carrying out decoding each block. Further, sliding windowing is often carried out in each block.
A method of further reducing the amount of operation and power consumption when hard decision decoding is carried out using the soft output decoder of the above Embodiments 1 to 3 will be described with the present embodiment.
Soft output decoder 500 of
Soft output decoder 500 outputs the output of hard decision decoding section 311 outside directly. When turbo decoding is carried out using soft output decoder 500, instead of carrying out hard decision of a soft output in the final stage of iterative decoding, by directly using the output of hard decision decoding section 311, the soft output needs not to be outputted and hard decision processing needs not to be carried out.
In this way, there are the following two points as features when soft output decoder 500 is used as the hard decision decoder.
First, soft output decoder 500 employs a configuration of carrying out Max-log-MAP processing (that is, calculate two likelihoods λ0(n) and λ1(n)) in the window boundary and carrying out hard decision decoding processing using the value determined then as the initial value (i.e. the maximum likelihood path state initial value), so that, compared to the Viterbi decoder, which is a conventional decoder, processing can be sped up, complicated memory operations such as the register exchange method are removed and power consumption can be reduced.
Second, when soft output decoder 500 is used as the hard decision decoder, losing likelihood calculating section 112 finds only the maximum likelihood path state initial value in the window boundary and stops the operation except in the window boundary.
By so doing, most of the time in which hard decision decoding is carried out, losing likelihood calculating section 112 stops the operation, so that power consumption can be reduced compared to the case where hard decision of the soft output is carried out using conventional Max-log-MAP decoder.
Further, when soft output decoder 500 is used as the hard decision decoder, power consumption can be reduced by further stopping the operations of timing adjuster 102, timing adjuster 103 and γβ calculating section 104.
Although losing likelihood calculating section 112 operates only in the window boundary portion, the value β used then is inputted from β boundary generating section 109. Further, although the value y may be inputted from γβ calculating section 104, by inputting the value γ from γα calculating section 301, γβ calculating section 104 is stopped completely and power consumption can be reduced.
Further, the value α is used only in the window boundary portion, so that the value α can be inputted to losing likelihood calculating section 112 without timing adjuster 102. As a result, the operation of timing adjuster 102 can be stopped and power consumption can be reduced.
As described above, soft output decoder 500 of the present invention employs a configuration of carrying out Max-log-MAP processing (that is, calculate two likelihoods λ0(n) and λ1(n)) in the window boundary and carrying out hard decision decoding processing using the value determined then as the initial value (i.e. the maximum likelihood path state initial value), so that processing can be sped up and power consumption can be reduced.
Further,
Turbo decoder 600 has interleaver 601, repetition count controlling section 602 and commanding section 603 in addition to soft output decoder 500.
Soft output decoder 500 inputs the soft input values s and β and soft input value e. In the beginning of repetition, the initial value such as 0 is inputted as the soft input e. After next repetition, the soft output value A of the soft output decoder rearranged by interleaver 601 is inputted as e.
Immediately before the prescribed repetition count is reached, repetition count controlling section 602 generates a signal showing that repetition is final and transmits the signal to commanding section 603.
Repetition count controlling section 602 decides that repetition is final according to the prescribed repetition count, and, in addition, may decide that repetition is final based on the state of the hard decision output or soft output value.
Receiving a signal showing that repetition is final from repetition count controlling section 602, commanding section 603 transmits an output stop command signal for a soft decision values.
Receiving the output stop command signal for a soft decision value, soft output decoder 500 carries out control to stop the operations of losing likelihood calculating section 112, timing adjuster 102, timing adjuster 103 and γβ calculating section 104 included inside soft output decoder 500.
In this way, commanding section 603 that, upon deciding that repetition is final, transmits an output stop command for the soft decision value to soft output decoder 500, is provided, so that power consumption required for turbo decoding can be reduced effectively.
Although soft output decoder 500 has been described with Embodiment 4 as an example, the same effect can be acquired in soft output decoder 400. However, the α and γ are used in hard decision decoding, and so only operations of losing likelihood calculating section 112 except in the window boundary portion and the β calculating section (no reference numeral) in the γβ calculation section can be stopped.
Further, in addition to the sliding window scheme, the principle of the present invention is applicable in the same way to the processing streamlining technique of Max-log-MAP based on data division. That is, hard decision decoding of one of both ends of divided data can be carried out in the same processing steps as in streamlined Max-log-MAP by applying <algorithm 1-A-1> described in the basic principle of the present invention, so that higher speed can be realized compared to Viterbi decoding and lower power consumption can be realized compared to the processing streamlining technique of conventional Max-log-MAP.
As an example of the processing streamlining technique of Max-log-MAP based on above data division, there is parallelization using subblock division. Parallelization using subblock division refers to dividing input data into a plurality of blocks and carrying out decoding each block. Further, sliding windowing is often carried out in each block.
The above description is an illustration of preferred embodiments of the present invention and the scope of the present invention is not limited to this.
Further, according to the above embodiments, smaller values of α, β, γ and Λ represent the higher likelihoods (more likely). Implementation is made possible such that, higher values represent higher likelihoods, and the present invention is also applicable in this case.
Further, a method of setting initial values of α and β to certain values or subtracting certain values corresponding to an input value in γ, α and β calculation may be adopted to adjust the winning likelihood to a desired value (for example, 0). By so doing, a configuration may be possible where winning likelihood storing section 113 and subtractor 114 are practically unnecessary.
Further, although, with the present embodiment, the terms “soft output decoder,” “iterative decoder,” and “soft decision value calculating method” have been used for ease of description, the terms “decoder,” “soft output Viterbi decoder,” “turbo decoder,” and “iterative decoding method” may be used.
Further, the present invention only needs to be realized by the soft output decoder, iterative decoder and soft decision value calculating method based on the algorithm, and the present invention can be realized naturally with a hardware configuration and also by a software for functioning the soft decision value calculating method. This software is stored in a computer readable recording medium.
Each function block employed in the description of each of the aforementioned embodiments may typically be implemented as an LSI constituted by an integrated circuit. These may be individual chips or partially or totally contained on a single chip. “LSI” is adopted here but this may also be referred to as “IC,” “system “LSI,” “super LSI,” or “ultra LSI” depending on differing extents of integration. Further, the method of circuit integration is not limited to LSI' s, and implementation using dedicated circuitry or general purpose processors is also possible. After LSI manufacture, utilization of a programmable FPGA (Field Programmable Gate Array) or a reconfigurable processor where connections and settings of circuit cells within an LSI can be reconfigured is also possible. Further, if integrated circuit technology comes out to replace LSI' s as a result of the advancement of semiconductor technology or a derivative other technology, it is naturally also possible to carry out function block integration using this technology. Application of biotechnology is also possible.
The disclosures of Japanese Patent Application No. 2006-225938, filed on Aug. 22, 2006, and Japanese Patent Application No. 2006-251873, filed on Sep. 15, 2006, including the specifications, drawings and abstracts, are incorporated herein by reference in their entirety.
The soft output decoder, iterative decoder and soft decision value calculating method according to the present invention are preferable for application to, for example, a turbo decoding apparatus that carries out decoding using a soft decision decoding result repeatedly. For example, the soft output decoder, iterative decoding apparatus and soft decision value calculating method are preferable at the receiving end for use in a soft output decoder such as a convolution code decoder or turbo decoder, a receiving apparatus using cyclic code for detecting whether or not there are transmission errors or a communication terminal apparatus such as a mobile telephone.
Number | Date | Country | Kind |
---|---|---|---|
2006-225938 | Aug 2006 | JP | national |
2006-251873 | Sep 2006 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2007/066154 | 8/21/2007 | WO | 00 | 2/11/2009 |