The present invention relates to a turbo encoder and an HARQ (Hybrid Automatic Repeat reQuest) processing method applied therefor, and more particularly to an HARQ processing method in the turbo encoder.
At present, in 3GPP (3rd Generation Partnership Project), standardization is in progress with respect to a W-CDMA (Wideband-Code Division Multiple Access) technique that is one of third-generation mobile communication systems. Moreover, as one theme for the standardization, there is specified an HSDPA (High Speed Downlink Packet Access) system that provides a high-speed packet transfer of maximum approx. 14 Mbps in a downlink.
The HSDPA employs an adaptive coding modulation technique, and, for example, is characterized in that switching between a QPSK (Quadrature Phase Shift Keying) modulation technique and a 16 QAM (16 Quardrature Amplitude Modulation) technique is made in accordance with radio environments between a base station and a mobile station. Moreover, the HSDPA employs an HARQ (Hybrid Automatic Repeat reQuest) technique.
The HSDPA is characterized in that, when a mobile station has detected an error with respect to reception data from a base station, the data is retransmitted from the base station in response to a request from the mobile station and the mobile station carries out error correction decoding by employing both the already received data and the retransmitted reception data. Thus, the HARQ effectively utilizes the already received data even if an error exists, thereby enhancing a gain of the error correction decoding and suppressing an increase in the number of times of retransmission.
As a principal transport channel for use in the HSDPA, there exists HS-DSCH (High Speed-Downlink Shared Channel). In the HS-DSCH, a data arrives at a coding unit as at most one transport block TTI (Transmission Time Interval) by TTI. As a process of coding the HS-DSCH, there exist CRC (Cyclic Redundancy Check) addition, turbo coding, HARQ, modulation (16 QAM/QPSK), etc (for example, see Non-patent document 1).
The conventional (3GPP-Standard) output device of the turbo encoder as mentioned above includes two constituent encoders (1st constituent encoder 100 and 2nd constituent encoder 200) as shown in
One constituent encoder (the 1st constituent encoder 100) directly inputs a data coding sequence Xk, whereas the other constituent encoder (the 2nd constituent encoder 200) inputs a sequence (a data coding sequence X′k) mixed with the data coding sequence by an interleaver (Turbo Code internal interleaver) 300.
Specifically, the data coding sequence (Systematic Bits) Xk is redundant data sequences Zk and Z′k that are output by two constituent encoders (the 1st constituent encoder 100 and the 2nd constituent encoder 200), respectively. Information X′k obtained by performing an interleaving process for the data coding sequence Xk is not outputted. The reason is that if a decoding side can decode the data coding sequence Xk, performing the interleaving process therefor makes it possible to obtain the information X′k for which the interleaving process has been performed.
A tail bit is an end bit for setting the bit held by each constituent encoder (the 1st constituent encoder 100 and the 2nd constituent encoder 200) back to zero after finishing the coding of the data sequence. A rate of the turbo Code is ⅓, and the output order is an order of X1, Z1, Z′1, X2, Z2, Z′2, . . . , Xn, Zn, and Z′n [where n=a code block size of the turbo coding], However, with normal coding of the data sequence, three kinds of codes are outputted, whereas, with coding of the tail bit, four kinds of codes are outputted. That is, according to a route of a signal line shown by dotted lines of
In bit separation of the HRAQ, the turbo-coded data sequence, as shown in
a 1st sequence 401: (all Systematic bits)+(some tail bits of Systematic & Parity 1 & Parity 2),
a 2nd sequence 402: (all Parity 1 bits)+(some tail bits of Systematic & Parity 1 & Parity 2), and
a 3rd sequence 403: (all Parity 2 bits)+(some tail bits of Systematic & Parity 1 & Parity 2).
The HARQ process is for causing the output bit number of the turbo code to match with a total bit number of a physical channel that is mapped to the HS-DSCH.
A Hybrid ARQ functionality, as shown in
Further, the 1st rate matching 620 includes a rate matching (RM_P1_1) 621 and a rate matching (RM_P2_1) 622, and the 2nd rate matching 640 includes a rate matching (RM_S) 641 and a rate matching (RM_P1_2) 642, and a rate matching (RM_P2_2) 643.
The 1st rate matching 620 (1st rate matching stage) causes the input bit number to match with the number of the bits (which are given by a higher layer) of the virtual IR buffer 630. However, when the input bit number does not exceed a capacity (bit number) of the virtual IR buffer 630, no process is performed for the data even though this 1st rate matching 620 is transparent hereto.
The 2nd rate matching 640 (2nd rate matching stage) causes the number of the bits subsequent to the process of the 1st rate matching 620 to match with a physical channel bit number at its TTI.
The 1st rate matching 620 of the HARQ, when the input bit number exceeds a capacity (bit number) of the virtual IR buffer 630, removes bits that are located at an appropriate position in sequences of the Parity 1 (2nd Sequence) and the Parity 2 (3rd Sequence). The removal position is decided with computation using a rate matching parameter. The data coding sequence (1st Sequence), which is not punctured, is directly inputted into the virtual IR buffer 630. The so-called puncturing process is a process of extracting the bit from the bit sequence at a constant period.
Next, how to calculate the 1st rate matching parameter in accordance with the conventional method will be explained.
(2) Set a=2 when b=2;
a=1 when b=3
In a case of puncturing the Parity 1 bit, it follows that b=2.
In a case of puncturing the Parity 2 bit, it follows that b=3.
(3) Set
where,
A function ┌y┐: an integral value is obtained, that is, y≦┌y┐<y+1
A function └y┘: an integral value is obtained, that is, y−1<└y┘≦y [Numerical equation 3]
(4) Computation of the rate matching parameter
Ki=NTTI/3
eini=Ki
eplus=α×Ki
eminus=α×|ΔNi|
One example of the 1st rate matching process of the HARQ that is performed for the output of the turbo encoder shown in
In HARQ bit separation, the turbo-coded data is separated into three sequences of a data coding sequence (Systematic), a Parity 1 sequence (1st parity), and a Parity 2 sequence (2nd parity). Each of the data coding sequence, the Parity 1 sequence, and the Parity 2 sequence is configured of 496-bit code information and 4-bit tail bit information. The 4-bit tail bit information of each sequence has one part of the data coding sequence and each tail bit of the Parity 1 sequence and the Parity 2 sequence mixed.
Next, in the HARQ 1st rate matching, the rate matching with the capacity NIR=1500 of the virtual IR buffer 630 is carried out (it is only the parity bit that is punctured).
Upon computing the 1st rate matching parameter in accordance with the conventional,
ΔNilTTI=1200−1500=−300 [Numerical equation 4]
Ki=1500/3=500
The rate matching parameter of the Parity 1 is as follows.
eini=500
eplus=2×500=1000
eminus=2×|ΔNi|=2×150=300
And, the rate matching parameter of the Parity 2 is as follows.
eini=500
eplus=500
eminus=|ΔNi|=150
Non-patent document: “Multiple and channel coding 4.2.3.2 Turbo coding” [3GPP TS 25.212 V7.0.0 (2006-03) p. 16-21]
The conventional HARQ processing method described above causes a problem that the tail bits of the data coding sequence partially exist in the sequence of the Parity 1 and the Parity 2, whereby the above tail bit could be removed, depending upon a rate matching parameter, when the 1st rate matching process is performed.
In the conventional method, trellis termination of the decoding becomes impossible at the time of turbo decoding due to loss of the tail bit of this data coding sequence, and resultantly a decoding performance declines. In particular, when a code redundancy is low (when a large number of the parity bits are punctured), a decline in the performance becomes conspicuous. This demands a configuration such that tail bits of all data coding sequences of the turbo encoder are prevented from being punctured when the bit separation and the 1st rate matching of the HARQ are carried out.
Thereupon, an object of the present invention is to provide a turbo encoder that is capable of releasing the above-mentioned points at issue and improving a performance of an encoder when a redundancy is low, and an HARQ processing method applied therefor.
The turbo encoder in accordance with the present invention, which is a turbo encoder for, as a coding output of a data sequence, sequentially outputting a data coding sequence obtained by coding the data sequence, a 1st redundant data sequence, which is outputted from a 1st constituent encoder, with the data coding sequence assumed to be an input, and a 2nd redundant data sequence, which is outputted from a 2nd constituent encoder, with the sequence obtained by interleaving the data coding sequence assumed to be an input, includes a holding means for holding the sequence obtained by interleaving the data coding sequence, and adds a tail bit, being an end bit for setting the bits held by the 1st constituent encoder and the 2nd constituent encoder back to zero in the interleaved sequence held by the holding means, to an end of the coding output.
The HARQ processing method in accordance with the present invention is an HARQ (Hybrid Automatic Repeat reQuest) processing method that is employed for a turbo encoder for, as a coding output of a data sequence, sequentially outputting a data coding sequence obtained by coding the data sequence, a 1st redundant data sequence, which is outputted from a 1st constituent encoder, with the data coding sequence assumed to be an input, and a 2nd redundant data sequence, which is outputted from a 2nd constituent encoder, with the sequence obtained by interleaving the data coding sequence assumed to be an input, wherein a tail bit, being an end bit for setting the bits held by the 1st constituent encoder and the 2nd constituent encoder back to zero in the sequence obtained by interleaving the data coding sequence, is added to an end of the coding output.
That is, the turbo encoder of the present invention is characterized in improving a performance of the turbo code by improving the 1st rate matching processing method at the time of carrying out the process of outputting the tail bit that is added to an end of the data coding sequence (Systematic sequence), and the HARQ (Hybrid Automatic Repeat reQuest).
Namely, in an output device of the turbo encoder of the present invention, the 1st constituent encoder directly inputs a data coding sequence Xk and outputs a redundant data sequence Zk, the 2nd constituent encoder inputs a data coding information X′k mixed with the data coding sequence by the interleaver, and outputs a redundant data sequence Z′k, and a buffer holds the data coding information X′k mixed with the data coding sequence by the interleaver. Thus, the data coding sequence Xk, the redundant data sequences Zk and Z′k, and the data coding information X′k held by the buffer 4 are outputted in this order from the above-mentioned output device.
In the turbo encoder of the present invention, the order in which the tail bit of not-interleaved data coding sequence, the tail bit of the Parity 1 and the tail bit of the Parity 2 are output is identical to the normal order of the coding output, and the tail bit of the interleaved data coding sequence is outputted lastly. In this case, the tail bit of the interleaved data coding sequence is stored in the buffer, and is added to an end of the coding output.
Further, the turbo encoder of the present invention, in the bit separation that is a process subsequent to the turbo coding, adds the tail bits of all data coding sequences to the data coding sequence, adds the tail bits of all Parity 1 to the Parity 1 sequence, and adds the tail bits of all Parity 2 to the Parity 2 sequence.
In addition hereto, the turbo encoder of the present invention computes the rate matching parameter when carrying out the 1st rate matching of the HARQ.
In addition hereto, the turbo encoder of the present invention decides the position in which the parity bit is removed according to the method of computing the above-mentioned rate matching parameter when carrying out the 1st rate matching of the HARQ.
In the turbo encoder of the present invention, this prevents the tail bit of the data coding sequence from being punctured when the 1st rate matching of the HARQ is carried out, thereby enabling a performance of the encoder to be improved in particular when the redundancy is low (when a large number of the parity bits are punctured).
Further, in the turbo encoder of the present invention, the above-mentioned process can be realized by adding a simplified circuit, which enables an improvement in the performance of the encoder to be easily realized. Such a decoding process is demanded in particular when a turbo encoding/decoding device has been installed into an appliance such as a portable telephone that is strictly requested to have an error correcting ability.
In the present invention, an effect that assuming the above-mentioned configuration and operation enables a performance of the encoder to be improved when the redundancy is low (when a large number of the parity bits are punctured).
Next, an example of the present invention will be explained by making a reference to the accompanied drawings.
The 1st constituent encoder 1 is configured of a switch 11, operators (adders) 12 to 15, and delay circuits (D) 16 to 18, and the 2nd constituent encoder 2 is configured of a switch 21, operators (adders) 22 to 25, and delay circuits (D) 26 to 28.
The end bit for setting the bit held by each constituent encoder (the 1st constituent encoder 1 and the 2nd constituent encoder 2) back to zero after finishing the turbo coding of the data sequence is called a tail bit. A performance of the turbo encoder in accordance with one embodiment of the present invention is improved with the process such that the tail bit of the data coding sequence (Systematic sequence) is prevented from being punctured when the rate matching is carried out. The so-called puncturing process is a process of extracting the bit from the bit sequence at a constant period.
In this example, the bit separating process that is performed at the time of carrying out the HARQ (Hybrid Automatic Repeat reQuest) with the tail bit process of the turbo encoder, and the 1st rate matching processing technique will be described. At first, a configuration of the turbo encoder in accordance with one example of the present invention will be explained.
The turbo encoder includes two constituent encoders (the 1st constituent encoder 1 and the 2nd constituent encoder 2). One constituent encoder (the 1st constituent encoder 1) directly inputs a data coding sequence, whereas the other constituent encoder (the 2nd constituent encoder 2) inputs a sequence mixed with the data coding sequence by the interleaver 3.
Specifically, the data coding sequence (Systematic Bits) Xk is redundant data sequences Zk and Z′k that are output from two constituent encoders (the 1st constituent encoder 1 and the 2nd constituent encoder 2). Data coding information X′k obtained by performing an interleaving process for the data coding sequence is not outputted. The reason is that if the decoding side can decode the data coding sequence Xk, performing the interleaving process for its decoding result enables X′k to be obtained. However, in the case of encoding the tail bit, information X′k as well obtained by performing an interleaving process for the tail bit has to be outputted.
At this time, the tail bit information of the interleaved information X′k is stored temporarily into the buffer 4 in order to easily perform the HARQ process that is later performed. A code rate of the turbo code is ⅓, and the output order is an order of X1, Z1, Z′1, X2, Z2, Z′2, . . . , Xn, Zn and Z′n [where n=a code block size of the turbo coding]. However, with the coding of the tail bit, according to a route of a signal line shown by dotted lines of
The turbo-coded data sequence basically lines up in an order of the data coding bit (Systematic bit), the Parity 1 bit, and the Parity 2 bit, whereby sequentially separating them makes it possible to separate them into three sequences of the Systematic, the Parity 1, and the Parity 2. However, the tail bit information X′ existing in an end of the data sequence lines up in the last of the Systematic sequence.
That is, it follows that
the 1st sequence 51: (all Systematic bits)+(all Systematic tail bits),
the 2nd sequence 52: (all Parity 1 bits)+(all Parity 1 tail bits), and
the 3rd sequence 53: (all Parity 2 bits)+(all Parity 2 tail bits).
Next, the 1st rate matching process of the HARQ process will be explained. In the 1st rate matching process, the number NTTI per TTI (Transmission Timing Interval) of the bits subsequent to the turbo coding is caused to match with the bit number NIR of a virtual IR buffer (not shown in the figure) that can be utilized for the above HARQ process.
When NIR≧NTTI, no process is performed for the data even though the 1st rate matching stage is transparent hereto.
When NIR<NTTI the number of the bits that should be punctured.
ΔNilTTI=NIR−NTTI [Numerical equation 5]
is computed, thereby to perform a puncturing process.
The rate matching parameters of the Parity 1 bit and the Parity 2 bit are computed as follows.
(1) Set a=2 when b=2;
a=1 when b=3
In a case of puncturing the Parity 1 bit, it follows that b=2.
In a case of puncturing the Parity 2 bit, it follows that b=3.
(2) Set
where,
A function ┌y┐: an integral value is obtained that is, y≦┌y┐<y+1
A function └y┘: an integral value is obtained, that is, y−1<└y┘≦y [Numerical equation 7]
(3) Computation of the rate matching parameter
Ki=NTTI−L)/3
eini=Ki
eplus=α×Ki
eminus=α×|ΔNi|
where, L is data coding information obtained by interleaving the tail bit, and it follows that L=3 (that is, X′n+1, X′n+2, and X′n+3) with the turbo encoder shown in
The 1st rate matching process of the HARQ process is performed according to the above-mentioned rate matching parameter. In this example, similarly to the conventional method described above, the number of the input bit from the turbo encoder is caused to match with the number (NIR) of the bits allocated the virtual IR buffer. Also in the 2nd rate matching process of the HARQ process, similarly to the conventional method described above, the bit number subsequent to the 1st rate matching process is caused to match with the total bit number of HS-PDSCH (High Speed-Physical Downlink Shared Channel) to which HS-DSCH (High Speed-Downlink Shared Channel) is mapped at its TTI.
In the bit separation of the HARQ process, the turbo-coded data is separated into three sequences of the data coding (Systematic) sequence, the Parity 1 sequence, and the Parity 2 sequence. In this case, the data coding sequence is configured of 496-bit code information and 6-bit tail bit information, and each of the Parity 1 sequence and the Parity 2 sequence is configured of 496-bit code information and 3-bit tail bit information.
Next, in the 1st rate matching of the HARQ process, the rate matching with a capacity NIR=1500 of the virtual IR buffer is carried out (it is only the parity bit that is punctured).
Upon calculating the 1st rate matching parameter with the above-described method,
ΔNilTTI=1200−1500=−300 [Numerical equation 8]
Ki=(1500−3)/3=499
The rate matching parameter of the Parity 1 is as follows.
eini=499
eplus=2×499=998
eminus=2×|ΔNi|=2×150=300
And, the rate matching parameter of the Parity 2 is as follows.
eini=499
eplus=499
eminus=|ΔNi|=150
The position in which the bits of the Parity 1 and the Parity 2 are removed is decided according to the above-mentioned rate matching parameters.
In such a manner, in this example, preventing the tail bit of the data coding sequence from being punctured at the time of carrying out the 1st rate matching of the HARQ process makes it possible to improve a performance in the encoder in particular when the redundancy is low (a large number of the parity bits are punctured).
Further, in this example, an improvement in the performance of the encoder can be easily realized because an improvement in the performance of the encoder can be realized by adding a simplified circuit. Such a decoding process is demanded in particular when a turbo encoding/decoding device has been installed into an appliance such as a portable telephone that is strictly requested to have an error correcting ability.
Additionally, while the present invention has been disclosed with respect to the illustrative embodiments and use methods thereof, it will be appreciated that those skilled in the art may readily conceive of alterations to, variations of, and equivalents to these embodiments without departing from a scope of the present invention. For example, while it is envisaged that the tail bit process of the present invention and the rate matching process subsequent to it are applied to the wireless communication system into which an HSDPA (High Speed Downlink Packet Access) function has been installed in W-CDMA (Wideband-Code Division Multiple Access), they are applicable to all wireless communication systems utilizing the turbo coding.
This application is based upon and claims the benefit of priority from Japanese patent application No. 2006-137145, filed on May 17, 2006, the disclosure of which is incorporated herein in its entirety by reference.
Number | Date | Country | Kind |
---|---|---|---|
2006-137145 | May 2006 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2007/060097 | 5/17/2007 | WO | 00 | 11/17/2008 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2007/132912 | 11/22/2007 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
7827465 | Eroz et al. | Nov 2010 | B2 |
7873893 | Nimbalker et al. | Jan 2011 | B2 |
RE42675 | You et al. | Sep 2011 | E |
20020004924 | Kim et al. | Jan 2002 | A1 |
20020163880 | Matsumoto | Nov 2002 | A1 |
20030028838 | Chang et al. | Feb 2003 | A1 |
20040025103 | Obuchii et al. | Feb 2004 | A1 |
20050110286 | Zhang | May 2005 | A1 |
20060069978 | Soogoori | Mar 2006 | A1 |
20070082696 | Wang | Apr 2007 | A1 |
20080016425 | Khan et al. | Jan 2008 | A1 |
20080065954 | Eroz et al. | Mar 2008 | A1 |
20080098273 | Blankenship et al. | Apr 2008 | A1 |
20100031125 | Shen et al. | Feb 2010 | A1 |
20110038438 | Kim et al. | Feb 2011 | A1 |
20110197104 | Nimbalker et al. | Aug 2011 | A1 |
Number | Date | Country |
---|---|---|
2004096769 | Mar 2004 | JP |
2004-007028 | Aug 2004 | JP |
2005073266 | Mar 2005 | JP |
Number | Date | Country | |
---|---|---|---|
20090106618 A1 | Apr 2009 | US |