The present invention relates to a prime interleaver used for W-CDMA in the IMT 2000 (third-generation mobile communication system), and more particularly, to an interleaving sequence generator, an interleaver, a turbo encoder, and a turbo decoder, having a reduced memory for the interleaving sequence generator.
The wideband CDMA (W-CDMA) is standardized as one of radio access networks (RANs) in the third-generation mobile communication system (IMT 2000). An internal interleaver for turbo coding, so-called prime interleaver is standardized. This primer interleaver is disclosed in detail in “3rd Generation Partnership Project; Technical Specification Group Radio Access Network; Multiplexing and channel coding (FDD) (Release 1999) 3G TS25.212 V3.3.0 (2000-06), Section 4.2.3.2.3 “Turbo code internal interleaver” pp. 16–20”.
The turbo encoder comprises a plurality of component encoders. The interleaver decorrelation the parity sequences from the component encoders. The component encoders are concatenated via the interleaver. The interleaver plays an important role in achieving good performance of turbo coding.
As shown by reference numeral 1702, in the relationship between an output of the RAM 1702 and the interleaving pattern table, from the pattern table having R blocks with a length p based on a prime p, data is read in accordance with the longitudinal sequence of 0, 8, 4, 12, 2, . . . as shown by an arrow so as to obtain the data series 1703 after interleaving.
According to the standard 3G TS 25.212 V3.3.0 (2000-06) of the IMT 2000 (W-CDMA), 5075 types of interleaving patterns must be provided with the interleaving length of 1 to 40 to 5114 bits based on the unit of bit for various multi-media service. The pattern table corresponding to the entire interleaving lengths requires the numerous memory capacity and this it not realistic. The particle “3G TS25.212 V3.3.0 (2000-06) or Turbo code internal interleaver p. 16 to p. 20 in 4.2.3.2.3 section” discloses a scheme for generating the patterns by a predetermined operation in accordance with the interleaving lengths, instead of storing the entire types of patterns.
In the prime interleaver disclosed in the particle “3rd Generation Partnership Project; Technical Specification Group Radio Access Network; Multiplexing and channel coding (FDD) (Release 1999) 3G TS 25.212 V3.3.0 (2000-06) or V4.0.0 (2000-12) (Section 4.2.3.2.3 “Turbo code internal interleaver” pp. 16–20)”, when the data length is p based on the prime p and the number of blocks is R, and the base sequence S(j) for intra-row sequence permutation is obtained as follows by using a characteristic p and a primitive root ν on the finite field (intra-row permutation processing).
s(j)=[ν·s(j−1)]mod p, j=1,2, . . . (p−2), and s(0)=1 (1)
This is shown as Table. Next, R numbers of q(i) relatively prime to a number (p−1) obtained by subtracting one from the characteristic on the finite field are obtained. Finally, the sequence of rows is permuted based on the unit of row (inter-row permutation processing). The inter-row permutation is executed based on a predetermined pattern T(i). As the interlacing pattern in this case, a lattice pattern for increasing the free distance of the intra-rows is used.
In the i-th intra-row permutation, the following processing is executed.
Ui(j)=s([j·ri]mod(p−1)), j=0, 1, 2, . . . , (p−2), and Ui(p−1)=0, (2)
where, Ui(j) indicates the bit position before permutation, corresponding to the output position after the j-th intra-row permutation of the i-th row before the permutation, an equation of rT(i)=q(i) is established, and T(i) is the position of the i-th row before the above-defined permutation.
One example of the data length K=257 will be described. When the number of rows R in the two-dimensional matrix is 20, the number of columns p expressed by the prime p is 257/20=12.85. Consequently, the prime p that is not less than 12.85 and is the closet is 13. When the characteristic is 13, a primitive root ν is 2 on the finite field.
Then, the base sequence S(j) for inter-row permutation is derived by using the primitive root ν=2 based on the formula (1). If p=13 and ν=2, then,
{s(j)}={1, 2, 4, 8, 3, 6, 12, 11, 9, 5, 10, 7, 0}
Finally, zero is inserted.
Next, in the above-mentioned example in the case of p=13, R=20 numbers of q(i) relatively prime to the number (p−1) obtained by subtracting one from the characteristic on the finite field are obtained. Consequently, the following result is obtained.
{q(i)}={1, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79}
Finally, based on the above formula (2), the inter-row permutation processing is performed with the row as a unit based on the predetermined pattern. The permutation pattern between the rows is obtained for increasing the free distance in the case of R=20. That is,
Par1:{T(i)}={19, 9, 14, 4, 0, 2, 5, 7, 12, 18, 10, 8, 13, 17, 3, 1, 16, 6, 15, 11}.
Further, rT(i)=q(i), then,
rT(1)=q(1)=1=r19
rT(2)=q(2)=7=r9
rT(3)=q(3)=11=r14
:
rT(19)=q(19)=73=r15
rT(20)=q(20)=79=r11
The bit position Ui(j) is obtained by substituting the above values into the formula (2).
According to the above-mentioned conventional art, the bit position Ui(j) is calculated by software processing such as DSP (digital signal processor) or the like. In addition, the resultant data is transferred to the large-scale RAM 1702 shown in
Meanwhile, in the turbo decoder, the iterated decoding is performed. For example, in the case of decoding the received data of 2 Mbps with 8 iterations, the access to the above-mentioned interleaving sequence requires the fast operation, e.g., tens MHz. In order to respond to the requirement, the pattern generated in accordance with the above calculations is temporarily stored in a fast memory, and the memory structure needs the access having tens MHz.
However, the capacity of the memory (RAM) requires 66,482 bits (=5,114×13 bits), and greatly shares the turbo decoder. Further, it is necessary to transfer the data to the RAM for interleaving in the turbo decoder which actually performs the processing of the patterns generated based on the above calculations and the interface further needs the transfer of another data. Thus, there is a bottleneck on the interface.
Further, when the variable-rate function is provided, the interleaving length is frequently changed. In this case, the bottle neck on the interface further becomes serious and there is a problem that the rate does not follow the transfer rate in the multi-media service.
As mentioned above, the internal interleaver in the turbo decoder used for the mobile communication system corresponding to various multi-media services needs various interleaving lengths. Therefore, various interleaving patterns are necessary and a numerous memory capacity is required. Further, the fast data needs to temporarily store the interleaving pattern in a fast memory and, then, the fast memory capacity is necessary. This increases the circuit scale. Further, the service having a variable-rate function has the interface congestion due to the parameter transfer.
In consideration of the above-mentioned problems, and it is one object of the present invention to provide an interleaving sequence generator, an interleaver, a turbo encoder, and a turbo decoder, in which various interleaving-lengths and the transfer rates thereof in the multi-media service are realized with the small RAM-capacity for interleaver. Further, it is another object of the present invention to provide means, by which the load for interface is suppressed and which enables the operation for following the transfer rate in accordance with the multi-media service when the variable-rate function is provided.
According to the first aspect of the present invention, an interleaving sequence generator comprises means which sets R blocks with a data length p based on a prime p and generates R different integers q0, q1, q2, . . . , qR−1 relatively prime to (p−1), means which calculates the element on the finite field when a characteristic is the prime p by raising a primitive root ν to the powers of q0, q1, q2, . . . , qR−1, thus to generate and store values ν^q0(mod p), ν^q1(mod p), ν^q2(mod p), . . . , ν^qR−1(mod p), means which raises the values ν^q0, ν^q1, ν^q2, . . . , ν^qR−1(mod p) to the power of j on the finite field, thus to generate values (ν^q0)^j(mod p), (ν^q1)^j(mod p), (ν^q2)^j(mod p), . . . , (ν^qR−1)^j(mod p), means which generates or records a block permutation pattern that is predetermined for permuting the blocks, and means iterates, when j=1 to (p−2), such an operation that one is sequentially added to a value obtained by multiplying, by p, an output from the means for generating or recording the block permutation pattern in the 0-th permutation and such an operation that the generated values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) are sequentially added to a value obtained by multiplying, by p, an output from the means for generating or recording the block permutation pattern in the j-th permutation.
According to the second aspect of the present invention, the interleaving sequence generator further comprises: means which sequentially updates the values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) by sequentially inputting the generated and stored values ν^q0, ν^q1, ν^q2, . . . , ν^qR−1(mod p) to a fast finite field multiplier in the iteration when j=1 to (p−2).
According to the third aspect of the present invention, in the interleaving sequence generator the entire values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) are set to zero when j=p−1.
According to the fourth aspect of the present invention, an interleaving sequence generator comprises means which sets R blocks with a data length (p−1) based on a prime p and generates R different integers q0, q1, q2, . . . , qR−1 relatively prime to (p−1). In the interleaving sequence generator, the element on the finite field is calculated when a characteristic is the prime p by raising a primitive root ν to the powers of 0, q1, q2, . . . , qR−1, thus to generate and store values ν^q0(mod p), ν^q1(mod p), ν^q2(mod p), . . . , ν^qR−1(mod p) and the values ν^q0, ν^q1, ν^q2, . . . , ν^qR−1(mod p) are raised to the power of j on the finite field, thus to generate values (ν^q0)^j(mod p), (ν^q1)^j(mod p), (ν^q2)^j(mod p), . . . , (ν^qR−1)^j(mod p), a block permutation pattern that is predetermined for permuting the blocks is generated or recorded, and, when j=1 to (p−2), the iteration is performed by such an operation that one is sequentially added to a value obtained by multiplying, by p−1, an output from the means for generating or recording the block permutation pattern in the 0-th permutation and such an operation that the generated values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) are sequentially added to a value obtained by multiplying, by p−1, an output from the means for generating or recording the block permutation pattern in the j-th permutation.
According to the fifth aspect of the present invention, in the interleaving sequence generator, one is subtracted from the value that is obtained by sequential addition.
According to the sixth aspect of the present invention, the interleaving sequence generator further comprises means for generating and storing the value (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) in the iteration when j=1 to (p−2). In the interleaving sequence generator, the generated and stored values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) are sequentially updated by sequentially inputting, to a fast finite field multiplier, the values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p).
According to the seventh aspect of the present invention, an interleaving sequence generator comprises means which sets R blocks with a data length (p+1) based on a prime p and generates R integers q0, q1, q2, . . . , qR−1, relatively prime to p−1, and means which calculates elements on the finite field with the characteristic of prime p by raising a primitive root ν to the powers of q0, q1, q2, . . . , qR−1, thus to generate and store values ν^q0, ν^q1, ν^q2, . . . , ν^qR−1(mod p). In the interleaving sequence generator, the values ν^q0, ν^q1, ν^q2, . . . , ν^qR−1(mod p) are raised to the power of j on the finite field, thus to generate values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p), a block permutation pattern that is predetermined for permuting the blocks is generated or recorded, and the iteration is performed when j=1 to (p−2) by such an operation that one is sequentially added to a value obtained by multiplying, by p+1, an output from the means for generating or recording the block permutation pattern in the 0-th permutation and such an operation that the generated values (ν^q0)^j, (ν^q1)^j, (ν^q0)^j, . . . , (ν^qR−1)^j(mod p) are sequentially added to a value obtained by multiplying, by p, an output from the means for generating or recording the block permutation pattern in the j-th permutation.
According to the eighth aspect of the present invention, the interleaving sequence generator further comprises means which generates and stores the values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) in the iteration when j=1 to (p−2). In the interleaving sequence generator, the stored values are sequentially inputted to a fast finite field multiplier, thus to sequentially update the values (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p).
According to the ninth aspect of the present invention, in the interleaving sequence generator, the entire values (ν^q0)^j, (ν^q1)^j, (νq2)^j, . . . , (ν^qR−1)^j(mod p) are set to 0 when j=p−1.
According to the tenth aspect of the present invention, in the interleaving sequence generator, the entire values (ν^q0)^j, (ν^q1)^j, (νq2)^j, . . . , (ν^qR−1)^j(mod p) are set to p when j=p.
According to the eleventh aspect of the present invention, in the interleaving sequence generator, when an output signal of the interleaving sequence generator is over an interleaver target range, the signal is skipped a next signal within the range is used.
According to the twelfth aspect of the present invention, a plurality of fast multipliers on the finite field are provided, a plurality of values (ν^q0)^j, (ν^q1)^j, (νq2)^j, . . . , (ν^qR−1)^j(mod p) are simultaneously updated by sharing with the plurality of fast multipliers on the finite field upon updating of the value (ν^q0)^j, (ν^q1)^j, (ν^q2)^j, . . . , (ν^qR−1)^j(mod p) and, when an output of the interleaving sequence generator is over an interleaver target range, the signal is skipped a next signal within the range is used to continuously generate the signal.
According to the thirteenth aspect of the present invention, in the interleaving sequence generator, two fast multipliers on the finite field are provided, the two fast multipliers are assigned to values ν^q0, ν^q2, ν^q4, . . . , ν^q2n(mod p) (n is a natural number) as an even number and values ν^q1, ν^q3, ν^q5, . . . , ν^q2n−1 (mod p) as an odd number that are obtained by splitting the generated and stored values ν^q0, ν^q1, ν^q2, . . . , ν^qR−1(mod p), and simultaneously updates in parallel the values (ν^q0)^j, (ν^q2)^j, . . . , ν^q2n(mod p) and (ν^q1)^j, (ν^q3)^j, . . . , ν^q2n−1(mod p) by the j-th power on the finite field.
According to the fourteenth aspect of the present invention, in the interleaver, data are read from a memory by an output of the interleaving sequence generating circuit referred to as an address signal indicating the address of the memory in which the data is stored, thus to permute the data sequence.
According to the fifteenth aspect of the present invention, in the interleaver, data are written in a memory by an output of the interleaving sequence generating circuit referred to as an address signal indicating the address of the memory in which the data is to be stored, thus to permute the data sequence.
According to the sixteenth aspect of the present invention, in a turbo encoder, the interleaver is an internal interleaver in the turbo encoder.
According to the seventeenth aspect of the present invention, in a turbo decoder, one of the interleavers (fourteenth aspect & fifteenth aspect) is an internal interleaver in the turbo decoder and the other is an internal deinterleavers.
According to the eighteenth aspect of the present invention, in a turbo decoder, an output of an interleaving sequence generator is used as an address signal for reading a dual-port memory for storing data, and the address signal subjected to the delay operation with a predetermined value is used as an address signal for writing, thus simultaneously realizing an internal interleaver and an internal deinterleavers in the turbo decoder.
According to the nineteenth aspect of the present invention, in an interleaving sequence generating circuit for providing R blocks with a data length p based on a prime p, and obtaining an output position Ui(j) after j-th intra-row permutation of an i-th row before row permutation, by using a primitive root ν on the finite field with a characteristic p, R table are generated, thus to obtain the Ui(j).
According to the present invention, in the mobile communication system corresponding to various multi-media services, the interleaver using the prime number used for the turbo decoder can respond to various interleaving lengths without the increase in circuit scale. Further, in the interleaving sequence generator, interleaver, turbo encoder, and turbo decoder, a small RAM-capacity for interleaver is realized and the load for the interface is reduced. Thus, even in the multi-media services having a variable-rate function, the transfer rate is easily followed.
Next, embodiments of the present invention will be described with reference to the drawings.
Referring to
An interleaving method according to the present invention is basically similar to the above-mentioned prime interleaver. However, according to the present invention, a position Ui(j) is generated in the real time and the interleaving processing is performed without conventionally pre-calculating the position Ui(j) and transferring it to the RAM or the like. Thus, the large-scale RAM which is conventionally necessary is not required. Hereinbelow, its method will be described.
First, the following equation is obtained by the formula (1).
s(0)=1
s(1)=ν mod p
s(2)=ν^2 mod p
:
s(j)=ν^j mod p
Incidentally, a relation of (ν^j)≡νi is obtained. In the above formula, reference symbol ν denotes a primitive root and thus the entire elements on the finite field plane (mod p) are spanned by iterate ν multiplying processing on mod p.
This result is applied to the formula (2) and then the following is obtained.
Ui(j)=s{[j·ri] mod(p−1)}=[ν^{([j·ri] mod(p−1)}] mod p
Here, in place of [j·ri]mod(p−1)=j·ri−n·(p−1), the following is obtained.
Ui(j)=[ν^{j·ri−n·(p−1)}]mod p=(ν^ri)^j·(ν^(p−1))^(−n) mod p={(ν^ ri)^ j mod p}·{(ν^(p−1))^(−n) mod p}mod p
Incidentally, based on the Fermat_s Theorem, the following relation is obtained for the whole elements a.
a^(p−1)≡1 (mod p), where p: prime
Consequently, the following is obtained.
(ν^(p−1))^(−n) mod p=1
Hence, the foregoing formula is as follows.
Ui(j)=(ν^ri)^j mod p(3)
Based on the above description, rT(i)=qi and the following is obtained between the permutation patterns between the rows in the case of R=20.
Pat1:{T(0), T(1), . . . , T(R−1)}={19, 9, 14, 4, 0, 2, 5, 7, 12, 18, 10, 8, 13, 17, 3, 1, 16, 6, 15, 11}
In this case, the row position T(0) at the 0-th row (j=0) is 19 and q0 (=r19) is selected as a value of the row. Similarly, in the case of the first row (i=1), the row position T(1) is 9 and q, (=r9) is selected as a value of the row.
As mentioned above, the row position ri is set to different values. Consequently, the relation (ν^ri) in the formula (3) have varied values depending on the rows. The intra-row sequence every row is varied depending on the rows and becomes random. The value qi given by the equation rT(i)=qi is selected by the relation relatively prime to (p−1). The symbol ν is the primitive root so the order of a is (p−1).
Reference symbol a denotes an arbitrary element in the set defined by mod p. Then, the value p−1 is maximum order in mod p and, hence, the following relation is established.
a^(n·(p−1)=(mod p)
Therefore, the condition that the formula (3) is (ν^ri)^j=1 (mod p) requires ri.j=n·(p−1) and (p−1)|ri.j.
On the other hand, the value ri is relatively prime to (p−1) and the value ri does not include any factor of (p−1), and this indicates (p−1)|j, namely, the order of (ν^ri) is (p−1) which means the value (ν^ri) is also primitive root under the condition of (mod p).
Therefore, the following relation is obtained.
Ui(j)=(ν^ri)^j mod p, where j=0, 1, 2, . . . , (p−2)
The above relation forms a random-sequence generating algorithm using the congruential method as one of the linear congruential methods having a multiplier of a different primitive root (ν^ri) every row. The (ν^ri) is the primitive root on the prime field and therefore a value (ν^ri)^j which is expressed by the power spans the whole element of the prime field and it keeps the one-to-one mapping relationship which needs interleaver design.
This indicates the acquisition of the value Ui(j) without the table generated by the formula (1) of {s(j)=[ν·s(j−1)]mod p, j=1, 2, . . . (p−2), and s(0)=1} by recursively multiplying the value (ν^ri) as a multiplier in the formula (3).
In the case of the data length k=5114 bits, the number of columns p expressed by the prime number is 5114/20 (=255.7) for 20 as the number of rows in the two-dimensional matrix and the closest prime number p is 257 as the number of columns. As a comparison using the number, the number of tables generated by {s(j)=[ν·s(j−1)]mod p, j=1, 2, . . . , (p−2), and s(0)=1} must be 257. On the contrary, the number of tables is (ν^ri) mod p, (i=0, . . . , 19), namely, 20. The memory capacity is reduced to 1/10 or less.
As will be understood by the foregoing, according to the present invention, it is more advantageous as the data length is longer in the case of the same number of rows. The turbo coding has an interleaver gain as a feature and the higher codin-gain is obtained as the data length is longer. That is, the present invention is preferable to the turbo coding. Although the short data-length is described because of a brief description according to the following embodiment, the data length may have an arbitrary one.
At the 0-th row after (ν^ri) permutation used for the foregoing, an equation of (ν^r19)=(ν^q0) is established. At the first row after the permutation, an equation of (ν^r9)=(ν^q1) is obtained. That is, at the row (i) (=0 to 19), an equation of (ν^rT(i))=(ν^qi) is obtained. This indicates that the multiple for the row number i after the permutation may be (ν^qi).
Here, it is necessary to pay attention to the intra-row relation and the row position before row permutation must be added. In this case, the row is permuted from T(i) to i and therefore, if the number of columns p=13, then, p×T(i) must be added.
Referring to
The selectors 104, 105, and 106 are controlled for the interlocking selection and, for the row number i=0 to R−1, the selector 104 selects ν^q0 (mod p) to ν^qR−1 (mod p) and the selectors 105 and 106 select (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p).
The selector is alternately address-controlled and the register is replaced with the RAM so as to realize the similar structure. Hereinbelow, a description is given of the operation for generating the interleaving sequence according to the present invention with reference to
First, the operation for the 0-th permutation will be described. The entire initial values of the register 102 are preset to ‘1’. In the transition from the 0-th permutation corresponding to J=0 to the first permutation corresponding to j=1, the entire selected values of the selector 106 are ‘1’. This value is inputted to one input-terminal of the multiplier 103 and is output from an output terminal 107. That is, in the case of the 0-th permutation corresponding to j=0, the entire values of the output terminal 107 are ‘1’.
In this case, the selector 104 sequentially selects ν^q0 (mod p) to ν^qR−1 (mod p). The output of the multiplier 103 is ν^q0 (mod p) to ν^qR−1 (mod p) and the selector 105 interlocking thereto sequentially updates ν^q0 (mod p) to ν^qR−1 (mod p) in the register 102, in place of the initial value ‘1’.
Next, in the first permutation corresponding to j=1, the selected value of the selector 106 is ν^q0 (mod p) to ν^qR−1 (mod p). When this value is inputted to the one input-terminal of the multiplier 103, ν^q0 (mod p) to ν^qR−1 (mod p) is transmitted from the output terminal 107.
Then, the selector 104 sequentially selects ν^q0 (mod p) to ν^qR−1 (mod p) and the output of the multiplier 103 is (ν^q0)^2 (mod p) to (ν^qR−1)^2 (mod p). The selector 105 interlocking operation thereto inputs and sequentially updates, in the register 102, (ν^q0)^2 (mod p) to (ν^qR−1)^2 (mod p) in place of ν^q0 (mod p) to ν^qR−1 (mod p).
The similar operation continues. Then, in the j-th permutation, the selected value of the selector 106 is (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p). This value is inputted to the one input terminal of the multiplier 103 and then (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p) are transmitted from the output terminal 107. In this case, the selector 104 sequentially selects ν^q0 (mod p) to ν^qR−1 (mod p) and the output of the multiplier 103 is (ν^q0)^(j+1) (mod p) to (ν^qR−1)^(j+1) (mod p). The selector 105 interlocking operating thereto inputs, to the register 102, (ν^q0)^(j+1) (mod p) to (ν^qR−1)^(j+1) (mod p) which are sequentially updated in place of (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p).
The above-generated (ν^q0)^j (mod p) to (ν^qR−1)^ j (mod p) are values which are read in the column direction of the two-dimensional matrix after the intra-row permutation in the formula (3) of Ui(j)=(ν^ri)^j mod p.
As mentioned above, the row position before the row permutation needs to be added. That is, when the row is permuted from T(i) to i, p×T(i) needs to be added.
Referring to
A selector 204 selects a (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p) generating portion 201 (where j=0 to p−2). However, finally, when j=p−1, the selector 204 selects a zero output portion 202 for outputting a zero output. For the final column, a value of p×T(i) (i=0 to R−1) is transmitted from an output terminal 209 as the interleaving sequence output.
A set value of a column number setting portion 206 for setting the number of columns in the two-dimensional matrix is p according to the first embodiment. A multiplier 207 generates p×T(i). An adder 208 adds the value of p×T(i) and the value selected by the selector 204.
The transition timing from a value of (ν^q0)^j (mod p) when i=0 to a value of (ν^qR−1)^j (mod p) when i=R−1 in the (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p) generating portion 201 is synchronous to the transition timing for outputting the block permutation pattern T(i) (i=0 to R−1) from the table 205. Thus, the output of the adder 208 becomes a value read in the column direction of the two-dimensional matrix using Ui(j)=(ν^ri)^j mod p after the intra-row permutation.
Next, the case of data length K=280 will be described. The row number R in the two-dimensional matrix is 20. Since 280 divided by 20 equals 14, the closest prime more than 14 should be selected. However, if the column number C=p+1 and the prime p=13, then, the two-dimensional matrix can be used. Then, the two-dimensional matrix of 14×20 is considered. If C=p+1, then, the primitive root is similarly used. The primitive root on the finite field with the characteristic of 13 is 2. A formula for intra-row permutation is shown as follows by using the primitive root ν=2.
The formula for the intra-row permutation is as follows.
Ui(j)=(ν^ri)^j mod p, where j=0, 1, 2, . . . , (p−2)
The above formula is derived because of the above-mentioned reason when the column number C=p. Hereinbelow, a description will be given of the interleaving sequence generator when C=p+1 according to the present invention.
Similarly to the case of C=p, (ν^rT(i))=(ν^qi) (i=0 to 19) after permutation is obtained. Therefore, the multiple for the row number i after permutation may be (ν^qi). Since the row is permuted from the T(i) to i, the number of columns C is p+1=13+1=14. Then, a value of (p+1)×T(i) must be added.
The processing is executed by the interleaving sequence generator shown in
Finally, when j=p, the selector 204 selects a value of p set by a p-setting portion 203. At the final column, the addition of the value of p and the value of (p+1)×T(i) where i=0 to R−1 is transmitted from the output terminal 209 as the interleaving sequence output. Here, from the table 205, the block permutation pattern T(i) where i=0 to R−1 is output in accordance with the row updating.
In this case, the column number setting portion 206 sets a column number set value in the two-dimensional matrix to p+1, the multiplier 207 generates, and the adder 208 adds the value of (p+1)×T(i) and the value selected by the selector 204.
The transition timing from a value of (ν^q0)^j (mod p) when i=0 to a value of (ν^qR−1)^j (mod p) when i=R−1 in the (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p) generating portion 201 is synchronous to the transition timing for outputting the block permutation pattern T(i) (i=0 to R−1) from the table 205. Thus, the output of the adder 208 becomes the value read in the column direction of the two-dimensional matrix using Ui(j)=(ν^ri)^j mod p after the intra-row permutation, similarly to the case of C=p.
Next, an example of the data length K=320 will be described. The number of rows R in the two-dimensional matrix is 20. Since 320/20=16, the column number C is the closest prime p=17. However, if the column number C=p−1=16, then, the two-dimensional matrix can be used. Then, the application of the two-dimensional matrix 16×20 is considered. In the case of C=p−1, the primitive root is similarly used. The primitive root on the finite field with the characteristic of 17 is 3.
The formula for intra-row permutation with the primitive root ν=3 is as follows.
Ui(j)=(ν^ri)^j mod p, where j=0, 1, 2, . . . , (p−2)
The above formula is derived because of the above-mentioned reason in the case of the column number C=p.
Hereinbelow, a description is given of the case of applying, to the column number C=p−1, the interleaving sequence generator according to the present invention with reference to
The interleaving sequence generator shown in
Outputs from a (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p) generating block 301 are directly inputted to an adder 308. The adder 308 receives a value of (−1) from a constant generating portion 310 which outputs a value of (−1) for subtraction. A multiplier 307 multiplies the number of columns C=p−1 in the two-dimensional matrix from a column number setting portion 306 to a block permutation pattern T(i) in a table 305. This result (p−1)×T(i) is inputted to the adder 308. These adding results are transmitted from an output terminal 309 as the interleaving sequence outputs.
When the output signal from the interleaving sequence generator is over the interleaver target range, the signal is skipped. However, according to the second embodiment, upon the signal skipping, the above-mentioned two fast multipliers on the finite field are provided so as continuously generate the signal.
Referring to
Two fast multipliers 403 and 413 are on the finite field and obtain one multiplier-input from the registers that store the multipliers 401 and 411 via selectors 404 and 414. The multiplier outputs are connected to registers 402 and 403 which temporarily store multiplying results via selectors 405 and 415.
Outputs from the registers 402 and 412 are output to output terminals 407 and 417 via selectors 406 and 416, add are connected to one of input terminals of the multipliers 403 and 413. The selectors 404 to 406 and the selectors 414 to 416 are controlled for the interlocking selection and thus the similar calculation result described with reference to
Alternately, the selector may be address-controlled and a dual-port RAM further may simultaneously execute the access corresponding to the even number and the access corresponding to the odd number. One RAM can execute the same operation of the two registers.
According to the second embodiment, by providing the two split (ν^q0)^j (mod p) to (ν^qR−1)^j (mod p) generating blocks shown in
Referring to
The column number setting portion 506 and the block permutation pattern T(i) generating portion 505 form a single portion because they are shared for both the even one and the odd one. The adder 508 outputs the interleaving sequence corresponding to the even number from an even output terminal 509 and an adder 518 outputs the interleaving sequence corresponding to the odd number from an odd output terminal 519.
In a block shown in
The above-generated interleaving sequence signals within the interleaver range are permuted to the original sequence by a switch 608, and are inputted to an FIFO 609. When the FIFO is full, the FIFO 609 outputs a buffer-full signal. Although not shown, the buffer-full signal becomes a halt signal 610 for each block and the operation of the blocks temporarily stops.
The final interleaving sequence output is read from the FIFO 609 and the signal is output from a terminal 611. Then, the halt signal is reset and the operation of the blocks restarts. That is, the buffering function of the FIFO 609 enables the continuous signal-generation of the interleaving sequence output 611.
Referring to
The interleaving sequence generator is described above according to the second embodiment. Next, a description is given of the processing for actually permuting the data sequence by using the interleaving sequence generator.
For example, the above-mentioned interleaved data is inputted to the RAM 1102 in the order of the 0-th data, the eighth data, . . . The same series of 0, 8, 4, 12, 2, . . . , 7, and 15 as those shown in
Both the deinterleaving and the interleaving can be exchangeable depending on the patterns. One is called the interleaving and then the other is called the deinterleaving. On the contrary, one is called the deinterleaving and then the other is called the interleaving. As mentioned above, both the interleaving and the deinterleaving can be realized by using the same interleaving sequence generator.
Referring to
The interleaved data is processed by a turbo decoder, which will be described later. Thereafter, the processed data needs the deinterleaving for returning to the original order. Then, a delay element 1203 is inserted, the time is delayed by the processing time of the turbo decoder, and the deinterleaving processing is performed.
For example, it is assumed that the processed data is inputted to the RAM 1202 in the order of the 0-th data, the eighth data, . . . The write-address signals from the interleaving sequence generator 1201 via the delay element 1203 are 0, 8, 4, 12, 2 . . . , 7, and 15. In the RAM 1202, the addresses 0, 1, 2, . . . are restored in the order of the 0-th data, the first data, the second data, . . . and the deinterleaving is executed.
Similarly to the conventional turbo encoder shown in
An output of an up counter 1302 is inputted as the address input RD Adr1 of the dual-port RAM 1303 and an output of the interleaving sequence generator 1301 is inputted as an address input RD Adr2 of the dual-port RAM 1303. Based on an address input RD Adr1 from the up counter 1302, the read information series in the dual-port RAM 1303 is inputted to the component encoder 1304. Based on the address input RD Adr2 from the interleaving sequence generator 1301, the read interleaved information series in the dual-port RAM 1303 is inputted to the component encoder 1305.
An up counter 1401 or an interleaving sequence generator 1402 is connected via a selecting switch 1403 to the read-address in the dual-port RAM 1406 which stores the information series. The iteration processing in the turbo decoding has decoding using a parity bit 1 corresponding to the non-interleaving processing and decoding using a parity bit 2 corresponding to the interleaving processing. The selecting switches 1403 and 1404 are switches for switching the decoding, and are controlled by a switching signal 1405 for half iteration at the odd times or even times.
In the non-interleaving processing, the selecting switch 1403 selects the up counter 1401 and the selecting switch 1404 selects the parity bit 1.
The up counter 1401 is connected to the read-address of the dual-port RAM 1406 which stores the information sequence and therefore the dual-port RAM 1406 outputs the non-interleaved information sequence. Simultaneously, the up counter 1401 is connected to the read-address in a dual-port RAM 1407 via the switch 1403 and therefore the dual-port RAM 1407 outputs the non-interleaved a-priori data.
The two signals are added by an adder 1408, and are inputted to a soft-in soft-out decoder (SISO) 1410. The SISO 1410 comprises a so-called LogMAP or Max-LogMAP which performs MAP decoding logarithmically. The addition processing of the adder 1408 corresponds to the multiplication in the probability calculation.
The MAP algorithm is executed by the calculation result of the adder 1408 and the parity bit 1 selected by the switch 1404 and, based on the result, the addition value at the same timing of a register 1411 is subtracted by the adder 1412 and is inputted to the dual-port RAM 1407 as the next apriori data. The same read-address is inputted to the write-address of the dual-port RAM 1407 via a register 1409 at the same timing and therefore the apriori data is stored at the address corresponding to the symbol position of the information series.
Next, in the interleaving processing for half iteration, the selecting switch 1403 selects the interleaving sequence generator 1402, and the selecting switch 1404 selects the parity bit 2.
The interleaving sequence generator 1402 is connected to the read-address of the dual-port RAM 1406 which stores the information series and therefore the dual-port RAM 1406 outputs the interleaved information series. Simultaneously, the interleaving sequence generator 1402 is connected to the read-address of the dual-port RAM 1407 via the switch 1403 and, therefore, the dual-port RAM 1407 outputs the interleaved apriori data.
The adder 1408 adds the two signals and the resultant data is inputted to the soft-in soft-out decoder (SISO) 1410. The addition processing of the adder 1408 corresponds to the multiplying operation in the possibility calculation.
The MAP algorithm is executed by the calculation result of the adder 1408 and the parity bit 2 selected by the switch 1404 and, based on the result, the addition value at the same timing of the register 1411 is subtracted by the adder 1412 and is inputted to the dual-port RAM 1407 as the next apriori data. At the write-address of the dual-port RAM 1407, the same read-address is inputted at the same timing via the register 1409 and therefore the apriori data is stored at the original address position. That is, the data is subjected to the deinterleaving processing.
According to the feature of the turbo encoder, the iteration processing greatly improves the decoding performance. Finally, a detector 1413 implements the hard decision and, from an output terminal 1414, the decoding data is output.
Number | Date | Country | Kind |
---|---|---|---|
2001-353675 | Nov 2001 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP02/12082 | 11/19/2002 | WO | 00 | 11/9/2004 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO03/044965 | 5/30/2003 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6233711 | Murayama et al. | May 2001 | B1 |
6347385 | Cui et al. | Feb 2002 | B1 |
6442728 | Cui et al. | Aug 2002 | B1 |
6553516 | Suda et al. | Apr 2003 | B1 |
6598202 | Kim et al. | Jul 2003 | B1 |
Number | Date | Country |
---|---|---|
1195910 | Apr 2002 | EP |
2002-190743 | Jul 2002 | JP |
2002-522945 | Jul 2002 | JP |
2002-535867 | Oct 2002 | JP |
WO-9912265 | Mar 1999 | WO |
WO-9925069 | May 1999 | WO |
WO-0008770 | Feb 2000 | WO |
WO-0042709 | Jul 2000 | WO |
WO-0062426 | Oct 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20050154954 A1 | Jul 2005 | US |