Decoding method and system for real-time wireless channel estimation

Abstract
A decoding method and system for real-time wireless channel estimation, which decodes a received signal with a noise. The received signal is coded by a concatenation code. At first, the received signal is performed a certain amount of decoding by a Max-Log-MAP decoding procedure. Next, an estimated amplitude of the received signal and an estimated variance of a noise are computed. Then, the received signal is adjusted in accordance with the estimated amplitude and the estimated variance to thereby produce an adjusted received signal. Finally, the adjusted received signal is decoded by a Log-Map decoding procedure.
Description

BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a diagram of a typical configuration of communication system using a turbo code based on the UMTS WCDMA standard;



FIG. 2 is a block diagram of a typical turbo encoder;



FIG. 3 is a block diagram of a typical turbo decoder;



FIG. 4 is a schematic diagram of a wireless transmission system in accordance with the invention;



FIG. 5 is a block diagram of a decoding system for realtime wireless channel estimation in accordance with the invention;



FIG. 6 is a flowchart of a decoding method for realtime wireless channel estimation in accordance with the invention;



FIGS. 7-1 and 7-2 show tables of computed and simulated results of an estimated amplitude in accordance with the invention;



FIG. 8 is a schematic graph of a result of bit error rate (BER) and signal-to-noise ratio (SNR) comparison in accordance with the invention; and



FIG. 9 is a schematic graph of another result of bit error rate (BER) and signal-to-noise ratio (SNR) comparison data in accordance with the invention.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT


FIG. 4 is a schematic diagram of a wireless transmission system in accordance with the invention. In FIG. 4, the wireless transmission system includes a turbo encoder 410, a modulator 420, a demodulator 430 and a turbo decoder 440, in which Gc indicates a wireless channel gains, n indicates an additive white Gaussian noise (AWGN) existed in the wireless channel, Ga indicates a system gain in a receiving system before the turbo decoder, and y indicates a receiving signal. The gain Gc is a constant in a code block and independent to each other in different code blocks. The AWGN noise n is Gaussian distribution with zero mean and variance a The received signal y can be expressed by the following equation:






y
i
=G
a
G
c√{square root over (Es)}xi+Gan=Axi+n′,


where the amplitude A=GaGc√{square root over (Es)}, and the AWGN noise n′ is Gaussian distribution with zero mean and equivalent variance σ2, where σ2=Ga2Gc2. Therefore, the effective SNR is given by:








SNR
r

=



G
c
2



E
s



σ
c
2



,




and an effective noise variance σ2 is defined by:











σ
2



1

SNR
r



=



σ
c
2



G
c
2



E
s



.





(
1
)







Further, an input log-likelihood ratio (LLR) can be expressed by the following equation:







Λ


i





n

,
i


=


log



P


(



y
i

|

x
i


=

+
1


)



P


(



y
i

|

x
i


=

-
1


)




=




2


G
c




E
s





G
a



σ
c
2





r
i


=



2

A


σ
2





r
i

.









FIG. 5 is a block diagram of a decoding system 440 for real-time wireless channel estimation in accordance with the invention. The decoding system 440 decodes a received signal with a noise. The received signal y is coded by a concatenation code and has K message bits. The K message bits are grouped into systematic bits μ, first parity bits p and second parity bits q. The concatenation code is a turbo code. The LLRs Λin of the received signal y includes the LLRs of the system bits μ, first parity bits p and second parity bits q. Namely, we have Λin={Λμ, Λp, Λq}, where Λμ denotes the LLRs of the systematic bits μ, Λp denotes the LLRs of the first parity bits p, and Λq denotes the LLRs of the second parity bits q.


The system 440 includes a first decoder 510, an interleaver 520, a second decoder 530, a deinterleaver 540, a channel estimator 550, a controller 560 and a memory 570.


At the beginning of the decoding, the system 440 initializes an index to be 1 and the Prior1(i) to be 0, and sets s as a predetermined number of decoding.


The first decoder 510 is a soft-input-soft-output (SISO) decoder to receive a systematic bit log-likelihood ratio (LLR) Λμ, a first parity bit LLR Λp and a first prior information Prior1(i), and accordingly performs a Max-Log-MAP decoding. If the Max-Log-MAP decoding is performed, the first decoder 510 produces a first extrinsic information E1(1) and a first output LLR Λout,1(1).


The interleaver 520 is connected to the first decoder 510 in order to receive the first extrinsic information (E1(1)) and the systematic bit LLR Λμ for re-arrangement to thereby produce a second prior information Prior2(1) and an interleaved systematic bit LLR Λμπ.


The second decoder 530 is a soft-input-soft-output decoder connected to the interleaver 520 in order to receive the interleaved systematic bit LLR Λμπ, a second parity bit LLR Λq and the second prior information Prior2(1), and accordingly performs the Max-Log-MAP decoding.


If the Max-Log-MAP decoding is performed, the second decoder 530 produces a second extrinsic information E2(1) and a second output LLR Λout,2(1).


The deinterleaver 540 is connected to the second decoder 530 in order to receive the second extrinsic information (E2(1)) for re-arrangement to thereby produce the first prior information Prior1(2). At this moment, the system 440 completes the first iteration of decoding and increases the index i with 1 to perform the second iteration of decoding.


The first stage decoding is performed with s iterations of iterative decoding. When the index i is increased to be equal to the predetermined decoding number s, the system 440 temporarily suspends the decoding and sends the LLRs (Λout,1(s), and Λout,2(s)) to the channel estimator 550 for channel estimation (Â and {circumflex over (σ)}).


The channel estimator 550 is connected to the first and the second decoders 510 and 530 in order to perform a channel estimation in accordance with the received signal, the first output LLR and the second output LLR to thereby produce estimated amplitude  and variance {circumflex over (σ)} of the received signal that are subsequently output to the first decode 510 and the second decoder 530.


The controller 560 is connected to the channel estimator 550, the first decoder 510 and the second decoder 530 in order to control the first and the second decoders 510 and 530 to perform a certain amount of decoding on the received signal by a Max-Log-MAP decoding procedure. Accordingly, the first extrinsic information and the first output LLR produced by the first decoder 510 are denoted by E1(s) and Λout,1(s) respectively. The second extrinsic information and the second output LLR produced by the second decoder 530 are denoted by E2(s) and Λout,2(s) respectively.


The controller 560 then controls the first decoder 510 and the second decoder 530 to use a Log-MAP decoding procedure in decoding. In this case, the controller 560 is based on a message length and a code rate to predetermine when the decoding procedure is changed from the Max-Log-MAP decoding procedure to the Log-MAP decoding procedure. Accordingly, the first extrinsic information and the first output LLR produced by the first decoder 510 are denoted by E1(i) and Λout,1(i) respectively. The second extrinsic information and the second output LLR produced by the second decoder 530 are denoted by E2(i) and Λout,2(i) respectively.


The memory 570 connected to the controller 560 stores a specific table. The controller 560 is based on the code rate of the concatenation code and the K value to look up the table and obtain the certain amount.


When the first decoder 510 and the second decoder 530 perform the Max-Log-MAP decoding procedure, there is no need to adjust the received signal in accordance with the estimated amplitude and variance A and a because of no need to understand the channel conditions. When the first decoder 510 and the second decoder 530 perform the Log-MAP decoding procedure, there is a need to adjust the received signal in accordance with the estimated amplitude and variance  and {circumflex over (σ)} because understanding the channel conditions is necessary, thereby producing an adjusted received signal. When the first decoder 510 and the second decoder 530 depends on the adjusted received signal to perform the Log-MAP decoding procedure, the first extrinsic information E1(i) produced by the first decoder 510 and the second extrinsic information E2(i) produced by the second decoder 530 are also adjusted in accordance with the estimated amplitude and variance  and {circumflex over (σ)} to further produce a scaled first extrinsic information and a scaled second extrinsic information.



FIG. 6 is a flowchart of a decoding method for real-time wireless channel estimation in accordance with the invention. The decoding method decodes a code division multiple access (CDMA) signal with a noise. The received signal is coded by a concatenation code. The concatenation code is a turbo code. Step (A) receives the received signal y with K message bits.


Step (B) performs a certain amount of decoding on the received signal y by the Max-Log-MAP decoding procedure. The certain amount is obtained by looking up a specific table based on the code rate of the concatenation code and the K value.


Step (C) uses the temporary LLR of each message bit of the received signal to compute the hard decision of each message bit of the received signal. Since step (B) performs the certain amount of Max-Log-MAP decoding procedure, the temporary LLR of i-th message bit is denoted by Λi(s). The hard decision ûi(s) of the i-th message bit in step (C) can be expressed by





ûi(s)=0, if Λi(s)≧0; and





ûi(s)=1, if Λi(s)<0,


where Λi(s) indicates the temporary LLR.


Step (D) depends on the K message bits and the hard decision ûi(s) of each message bit to compute an ensemble average of the K message bits. The ensemble average of the K message bits is regarded as an estimated amplitude  of the received signal. In this case, the estimated amplitude  of the received signal in step (D) is expressed by:











A
^

=





i

K





(

-
1

)



u
^

i

(
s
)



×

y

u
,
i




K


,




(
2
)







where ûi(s) indicates a hard decision of i-th message bit, and yu,i indicates the i-th message bit.


In this embodiment, the entire K message bits are used in step (D). However, in other embodiments, the partial message bits can be used in step (D). For example, the partial message bits K/2, K/3, 100, . . . are used to compute the estimated amplitude Â. The partial message bits can be any message bits or highest reliable values selected from the K message bits. Namely, if the partial message bits are used in step (D), the estimated amplitude  of the received signal is expressed by:











A
^

=




i
K





(

-
1

)



u
^

i

(
s
)



×

y

u
,
i





K




,




(

2


)







where K′ can be K/2, K/3, . . . .


In step (E), the ensemble average of a first momentum is computed in accordance with an absolute of the K message bits. The ensemble average W of the first momentum is expressed by:










W
=




i
K





y

u
,
i





K


,




(
3
)







where |yu,i| is an absolute of i-th message bit. If the partial message bits are used in step (D), the ensemble average W of the first momentum is expressed by










W
=




i
K





y

u
,
i






K




,




(

3


)







Step (F) depends on the ensemble average W of the first momentum and the estimated amplitude  of the received signal to compute a ratio a, and computes the estimated variance {circumflex over (σ)} of the noise in accordance with the ratio a. The ratio a in step (F) is expressed by:







a
=

W

A
^



,




where W indicates the ensemble of the first momentum, and  indicates the estimated amplitude of the received signal. The estimated variance {circumflex over (σ)} is computed by a polynomial, for example,





{circumflex over (σ)}2=−1.8833×a2+8.6671×a−6.5398,  (4)


where a is the ratio. In this embodiment, a second-order polynomial is used. However, in other embodiments, a polynomial of different order or a polynomial with coefficients approximated to those in equation (4) can be used.


When the estimated variance {circumflex over (σ)} of the noise is obtained in step (F), the channel quality is determined accordingly. Namely, the invention can be applied in a wireless channel estimation. Therefore, the invention has a considerably reduced computational complexity in comparison with the U.S. Pat. No. 6,393,257.


Step (G) depends on the estimated variance {circumflex over (σ)} of the noise and the estimated amplitude  of the received signal to adjust the received signal to thereby obtain an adjusted received signal y′. Subsequently, the Log-MAP decoding procedure is used to decode the adjusted received signal.


In step (G), the adjusted received signal is obtained by dividing the received signal or the last adjusted received signal y′ by









A
^



σ
2


2

,




where σ2 indicates the variance, and  indicates the amplitude of the received signal.



FIGS. 7-1 and 7-2 show tables of computed and simulated results of the estimated amplitude  in accordance with the invention. The values of weighted extrinsic field and weighted LLR field in FIGS. 7-1 and 7-2 are obtained by the Monte Carlo simulation. As shown in FIGS. 7-1 and 7-2, the simulated results of the estimated amplitude  are very close to a true value A=1. In addition, the ones that are selected from the simulated results and have the highest accuracy can be regarded as the certain amount at different conditions.



FIG. 8 is a schematic graph of a bit error rate (BER) and signal-to-noise ratio (SNR) comparison in accordance with the invention. As shown in FIG. 8, the simulated results are obtained under the gains Gc and Ga to have a change range from −6 dB to +6 dB for rate ⅓ turbo codes with K=300, 1600, 5000 respectively, and the certain amount s=0.5, 1.0, 1.5, 2.0 respectively.



FIG. 9 is a schematic graph of another result of bit error rate (BER) and signal-to-noise ratio (SNR) comparison data in accordance with the invention. In this case, the simulated results are obtained under the gains Gc and Ga to have a change range from −6 dB to +6 dB for rate 3/5 turbo codes with K=300, 1600, 5000 respectively, and the certain amount s=0.5, 1.0, 1.5, 2.0 respectively.


As shown in FIGS. 8 and 9, it is known that the certain amount s=1.0 is the best choice for code rates ⅓ and ⅗ and K=1600 and 5000 respectively. In addition, the performance is reduced to a value below 0.1 dB at different certain amount s, which is caused by the difference between the Max-Log-MAP decoding procedure and the Log-MAP decoding procedure, but not by the accuracy of the estimated amplitude  in the invention.


In view of forgoing, it is known that, in the invention, when the first and second decoders 510 and 530 perform the Log-MAP decoding procedure, the channel conditions  and {circumflex over (σ)} are known, and accordingly it is able to avoid that the Log-MAX decoding has a poor performance in comparison with the Max-Log-MAX decoding when the inaccurate channel estimation occurs.


Although the present invention has been explained in relation to its preferred embodiment, it is to be understood that many other possible modifications and variations can be made without departing from the spirit and scope of the invention as hereinafter claimed.

Claims
  • 1. A decoding method for real-time wireless channel estimation, which decodes a received signal with a noise, the received signal being coded by a turbo code, the method comprising the steps: (A) receiving the received signal with K message bits transmitted between a base station and corresponding stations;(B) applying a Max-Log-MAP decoding procedure to perform a predetermined amount of decoding on the received signal;(C) using temporary log-likelihood ratios (LLRs) to compute hard decisions of the K message bits of the received signal;(D) computing an ensemble average of the K message bits based on the hard decisions and the K message bits, and accordingly assigning the ensemble average to an estimated amplitude of the received signal;(E) computing an ensemble average of a first momentum based on absolute values of the K message bits; and(F) computing a ratio based on the ensemble average of the first momentum and the estimated amplitude of the received signal, and computing an estimated variance of the noise based on the ratio.
  • 2. The method as claimed in claim 1, further comprising the step of: (G) adjusting the received signal in accordance with the estimated amplitude of the received signal and the estimated variance of the noise to thereby produce an adjusted received signal, and decoding the adjusted received signal by a Log-Map decoding procedure.
  • 3. The method as claimed in claim 2, wherein the predetermined amount in step (B) is obtained by looking up a table in accordance with a code rate of the concatenation code and a value of K.
  • 4. The method as claimed in claim 3, wherein the hard decision of i-th message bit in step (C) is computed by: ûi(s)=0, if Λi(s)≧0; andûi(s)=1, if Λi(s)<0,
  • 5. The method as claimed in claim 4, wherein the estimated amplitude  in step (D) is expressed by:
  • 6. The method as claimed in claim 5, wherein the ensemble average W of the first momentum in step (E) is expressed by:
  • 7. The method as claimed in claim 4, wherein the estimated amplitude  in step (D) is expressed by
  • 8. The method as claimed in claim 7, wherein the ensemble average W of the first momentum in step (E) is expressed by:
  • 9. The method as claimed in claim 6, wherein the ratio a in step (F) is expressed by
  • 10. The method as claimed in claim 9, wherein the estimated variance σ2 in step (F) is determined based on a polynomial of the ratio a.
  • 11. The method as claimed in claim 10, wherein the estimated variance σ2 in step (F) is computed as follows: σ2=−1.8833×a2+8.6671×a−6.5398.
  • 12. The method as claimed in claim 1, wherein the adjusted received signal in step (G) is obtained by dividing the received signal by
  • 13. A decoding system for real-time wireless channel estimation, which decodes a received signal with a noise, the received signal being coded by a concatenation code and containing K message bits, the K message bits being grouped into systematic bits, first parity bits and second parity bits, the system comprising: a first decoder, which receives a systematic bit log-likelihood ratio (LLR), a first parity bit LLR and a first prior information and accordingly produces a first extrinsic information and a first output LLR by selectively performing a Max-Log-MAP decoding or a Log-MAP decoding;an interleaver, which is connected to the first decoder, in order to receive the systematic bit LLR and the first extrinsic information for re-arrangement to thereby produce a second prior information and an interleaved systematic bit LLR;a second decoder, which is connected to the interleaver, in order to receive the interleaved systematic bit LLR, a second parity bit LLR and the second prior information and selectively performs the Max-Log-MAP decoding or the Log-MAP decoding for producing a second extrinsic information and a second output LLR;a deinterleaver, which is connected to the second decoder, in order to receive the second extrinsic information for re-arrangement to thereby produce the first prior information;a channel estimator, which is connected to the first decoder and the second decoder, in order to perform a channel estimation in accordance with the received signal, the first output LLR and the second output LLR to thereby produce an estimated amplitude of the received signal and an estimated variance to the first decoder and the second decoder; anda controller, which is connected to the channel estimator, the first decoder and the second decoder in order to control the first decoder and the second decoder to first perform a predetermined amount of decoding on the received signal by a Max-Log-MAP decoding procedure, and then control the first decoder and the second decoder to perform a decoding on the received signal by a Log-MAP decoding procedure;wherein the first decoder and the second decoder adjust the received signal in accordance with the estimated amplitude and the estimated variance when the Log-MAP decoding procedure is performed, and therefore produce an adjusted received signal.
  • 14. The system as claimed in claim 13, further comprising a memory, which is connected to the controller, in order to store a specific table such that the controller depends on a code rate of the concatenation code and a value of K to look up the specific table and thereby obtain the predetermined amount.
  • 15. The system as claimed in claim 13, wherein the first decoder and the second decoder adjust the first extrinsic information and the second extrinsic information in accordance with the estimated amplitude and the estimated variance when the Log-MAP decoding procedure is performed, and therefore produce a scaled first extrinsic information and a scaled second extrinsic information respectively.
  • 16. The system as claimed in claim 13, wherein the adjusted received signal is obtained by dividing the received signal by
  • 17. The system as claimed in claim 15, wherein the scaled first extrinsic information is obtained by dividing the first extrinsic information by
  • 18. The system as claimed in claim 15, wherein the scaled second extrinsic information is obtained by dividing the second extrinsic information by
  • 19. The system as claimed in claim 13, wherein the first decoder is a soft-input-soft-out (SISO) decoder and the second decoder is a soft-input-soft-out decoder.
  • 20. The system as claimed in claim 13, wherein the concatenation code is a turbo code.
Priority Claims (1)
Number Date Country Kind
095135411 Sep 2006 TW national