The field of the present disclosure is that of controlling a multiple input multiple output, MIMO, receiver. Specifically, calculations associated with determining the characteristics of the radio channel between a transmitter and the MIMO receiver in order to improve performance when demodulating received signals.
In mobile radio communication systems that use Multi-User MIMO, MU-MIMO, several users are scheduled to transmit simultaneously during the same time and frequency interval. These users can be distinguished by allocating different, and preferably orthogonal, reference signals to them such that all channels from all transmit antennas to all receive antennas can be estimated. The reference signals, or training sequence, are sequences known to the receiver and they are transmitted together with user signals such that the receiver can estimate distortions of the received signal after it is transmitted.
MU-MIMO forms part of, e.g., the third generation partnership project, 3GPP, standards including the global system for mobile communication, GSM, as well as the long term evolution, LTE, standard.
A radio communication between a UE and a base-station will be affected by multi path propagation, fading, frequency errors, round trip times etc. This communication channel is often referred to as an air interface, and causes bit and block errors on information transmitted. A receiver is designed in order to reduce bit error and block error rates, which among others, includes channel estimation, demodulation and decoding blocks. Other processing blocks commonly used in uplink receivers includes spatial and temporal whitening and pre-filtering, as illustrated in
The received signal in a MIMO system with N transmitters and M receiver antennas subject to an ISI channel can be described as
where W(n) is a M×1 vector with additive noise and interference, S(n) is a N×1 vector with transmitted signals
S(n)=[si(n) s2(n) K sN(n)]T (2)
and H(z−1) is an M×N channel matrix with polynomial entries in the unity delay operator z−1, z−1s(n)=s(n−1), such that the element in row i and column j equals
h
i,j(z−1)=hi,j,0+hi,j,1z−1+hi,j,2z−1+K+hi,j,Lz−L (3)
A polynomial in the unity delay operator is thus a compact description of a time invariant FIR filter.
Polynomial QR decomposition is described in the prior art:
Using polynomial QR decomposition, as described in the prior art, of the channel matrix results in
Q(z−1)R(z−1)=H(z−1) (4)
where R(z−) is an upper triangular polynomial matrix of size N×N
and Q(z−) is a paraunitary polynomial matrix of size M×N. A matrix Q(z−) is a paraunitary polynomial matrix if
Q(z−1)Q*T(z)=IM,
Q*
T(z)Q(z−1)=IN (6)
where IM and IN are unitary matrices of size M and N, respectively. The paraconjugate of a matrix is defined as
{tilde over (Q)}(z−1)Q*T(z) (7)
where Q*T(z) denotes a matrix with conjugate of the coefficients, z−1 replaced by z and transpose of the matrix Q(z−1). From (4) and (6) follows that a multiplication of (1) with {tilde over (Q)}(z−1) results in
Y
P(n)={tilde over (Q)}(z−1)Y(n)=R(z−1)S(n)+{tilde over (Q)}(z−1)W(n) (8)
i.e. a signal with upper triangular channel matrix R(z−1). The multiplication with the polynomial matrix {tilde over (Q)}(z−1) is referred to as a MIMO pre-filter.
Assume that the additive noise and interference W(n) is temporally white and uncorrelated between the antenna branches i.e.
E{W(n)W*T(n−m)}=IM·δ(m) (9)
This can e.g. be accomplished by spatial-temporal whitening prior to (1), as illustrated by the whitening function 302 in
E{{tilde over (Q)}(z−1)W(n)({tilde over (Q)}(z)W(n−m))*T}={tilde over (Q)}(z−1){tilde over (Q)}*T(z)·δ(m)=IN·δ(m) (10)
A turbo equalizer can now be used for equalization and demodulation of the transmitted symbols in S(n), e.g. as outlined in Davies et al.
A polynomial decomposition is proposed in Foster et al. which is based on Givens rotations. Here several iterations are needed in order for the QR decomposition to converge.
A polynomial QR-decomposition is also described in Cescato and Bölcskei. Here, the channel H(ωn)=H(z−1)|z=e
The complexity of a demodulator typically increases with the length of the radio channel. In order to reduce computational complexity, a short channel model is beneficial. With a minimum phase channel model, most of the energy is concentrated in the first taps of the channel. However a polynomial QR decomposition as done in Foster et al. is based upon Givens rotations which do not guarantee minimum phase channel after pre-filtering.
In order to mitigate at least some of the drawbacks as discussed above, there is provided in a first aspect a method in a radio receiver for demodulating data signals transmitted by a plurality of transmitting antennas over a radio channel. The method comprises receiving on a plurality of receiving antennas, a data signal and a reference signal, the contents of the reference signal being known a priori to the receiver. The contents of the reference signal are used for calculating an estimated polynomial channel matrix. A calculation is then made of a decomposition of the estimated polynomial channel matrix into a product of a paraunitary polynomial matrix and an upper triangular polynomial matrix with minimum phase filters on its main diagonal. A polynomial pre-filter matrix is calculated as the paraconjugate of this paraunitary polynomial matrix. The received data signal is demodulated where the received data signal is multiplied with the calculated polynomial pre-filter matrix.
In some embodiments, the calculation of the decomposition comprises:
In some embodiments, the calculation of the decomposition comprises:
In other words, is a MIMO pre-filter in a receiver is provided which results in a channel matrix which is upper triangular and with minimum phase filters on its main diagonal. A minimum phase polynomial has the following energy compaction property: for any the sum of the energy contained in the first k taps is larger than the energy contained in the first k taps of any other polynomial having the same spectrum. The polynomial coefficients correspond to channel tap values in the equalizer of a receiver in which the method is realized. Therefore, the MIMO pre-filter of the present disclosure reduces the channel to a triangular form while at the same time reshapes the diagonal entries by compacting the channel energy. Both triangularization and energy compaction are very useful properties in order to reduce the computational complexity of the demodulator of a receiver in which the method is realized.
Such a MIMO pre-filter is an essential component in many practical MIMO or MU-MIMO Joint Detection receivers. For example, it can be used in high performance joint detection UL and DL VAMOS receivers. Advantages that are provided by the present disclosure include the fact that it provides simultaneous triangularization and channel re-shaping for energy compaction. The latter property is a key in order to efficiently cope with ISI. Furthermore, low computational complexity is provided. More specifically, as will be elucidated further below, the calculations require only one spectral factorization and one long division per transmitted layer in order to calculate the pre-filter. It is to be noted that many of the algorithms available in the prior art are not practical for implementation in typical mobile communication terminal or radio base station digital signal processing hardware. The present disclosure provides algorithms that are readily implemented in fixed point digital signal processors.
In a second aspect there is provided a radio receiver for demodulating data signals transmitted by a plurality of transmitting antennas over a radio channel. The receiver comprises control and communication circuitry configured to receive, on a plurality of receiving antennas, a data signal and a reference signal, the contents of the reference signal being known a priori to the receiver, calculate, using the contents of the reference signal, an estimated polynomial channel matrix, calculate a decomposition of the estimated polynomial channel matrix into a product of a paraunitary polynomial matrix and an upper triangular polynomial matrix with minimum phase filters on its main diagonal, calculate a polynomial pre-filter matrix as the paraconjugate of the paraunitary polynomial matrix and demodulate the received data signal where the received data signal is multiplied with the calculated polynomial pre-filter matrix.
In a third aspect there is provided a computer program product comprising software instructions that are configured, when executed in a processing device, to perform the method of the first aspect.
The effects and advantages of the second and third aspects correspond to those summarized above in connection with the first aspect.
Turning now to
In a reception step 202, a data signal and a reference signal is received on a plurality of receiving antennas. The contents of the reference signal are known a priori to the receiver. For example, in an implementation in a GSM system, the reference signal can be the training sequence that is transmitted in a data burst and in a LTE system implementation it can be the reference signals that form part of a sub-frame. In a calculation step 204, a calculation of an estimated polynomial channel matrix is made using the contents of the reference signal. The calculation of the estimated polynomial channel matrix is followed by a calculation of a polynomial pre-filter matrix. A calculation is done of a decomposition 206 of the estimated polynomial channel matrix into a product of a paraunitary polynomial matrix and an upper triangular polynomial matrix with minimum phase filters on its main diagonal. The polynomial pre-filter matrix is then calculated 208 as the paraconjugate of the paraunitary polynomial matrix. The received data signal is then demodulated in a demodulation step 212, where the received data signal is multiplied with the calculated polynomial pre-filter matrix.
A calculation can be made, in an optional third calculation step 210 prior to the demodulation step 212, of a pre-filtered polynomial channel matrix by multiplying the estimated polynomial channel matrix with the polynomial pre-filter matrix, thereby making the pre-filtered polynomial channel matrix upper triangular and with minimum phase filters on its main diagonal. In such cases, the demodulation step 212 also includes using this pre-filtered polynomial channel matrix as the channel model in the demodulation. The use of the pre-filtered polynomial channel matrix as the channel model in the demodulation can involve calculating the difference between the received data signal and symbol candidates filtered with the pre-filtered polynomial channel matrix.
This method can be illustrated in a block function, as presented in
Turning now to
In an initialisation step 402, a column counter k is set to the first column.
In a column setting step 404, column k of the channel matrix is selected for processing.
In a first calculation step 406, the square of the second norm of one column is calculated.
In a second calculation step 408, spectral factorization is performed.
In a third calculation step 410, long division is performed.
In a fourth calculation step 412, column k of a paraunitary polynomial matrix is calculated.
If all columns have been considered, as checked in a decision step 414, the paraunitary polynomial matrix is available and used in a calculation step 415 where the pre-filter matrix is obtained as the paraconjugate of the paraunitary polynomial matrix. The channel after pre-filter is obtained in a fifth calculation step 416.
If it is found, in the checking step 414, that not all columns have been considered, preparations for processing the next column is performed in an updating step 418 where matrix values are updated in preparation for calculation of values for next column. k is then incremented in an increment step 420, whereupon the procedure returns to the column setting step 404.
In the following, details will be presented of the different steps in
Both in the CGS and in the MGS, spectral factorizations and long divisions are used. A short description of the spectral factorization is given below.
When multiplying polynomial, the polynomial degree of the result is the sum of the degrees of the involved polynomials. In both CGS and MGS, the degrees of the resulting polynomials increase with each new column of. Polynomial truncations are described below for both CGS and MGS.
The channel after pre-filter is calculated as a polynomial multiplication between the calculated pre-filter and the channel estimate as also illustrated in
The first column q1(z−1) of Q(z−1) is defined as a normalized version of the first column h1(z−1) of H(z−1). This normalization is done with a scalar minimum phase polynomial hMP,1(z−1), i.e. a polynomial with all roots located inside the unit circle. This minimum phase polynomial is calculated from a spectral factorization of the scalar squared second norm of the first column h1(z−1) of H(z−1), i.e.
such that
h
MP,1(z−1)=MinPhaseFactor{s1(z−1)}. (12)
See below for more details about spectral factorizations.
The inverse of this minimum phase polynomial in (12) is approximated by a finite impulse response, FIR, polynomial after long division,
Here, the length of the FIR approximation is considered as a design variable which must be selected with care. Now, the elements qi,1(z−1), for i=1, K, M, of the first column of Q(z−1) are calculated as
q
i,1(z−1)=hMPinv,1(z−1)hi1(z−1), (14)
for i=1, K, M, and
r
1,1(z−1)=hMP,1(z−1). (15)
The remaining columns of Q(z−1) should now be calculated. These columns qk(z−1) of Q(z−1) will be sequentially calculated, with k=2, K, N. Start by setting k=2 and calculate column k of R(z−1) as the projection of H(z−1) on the previously calculated column of Q(z−1) i.e.
r
j,k(z−1)=qj*T(z)hk(z−1) (16)
for j=1, K, k−1. Use these projections in order to calculate a polynomial vector ak(z−1) of the difference between column k of H(z−1) and (16) multiplied by previously calculated column of Q(z−1) i.e.
Column qk(z−1) of Q(z−1) is defined as a normalized version of aq(z−1) for k>2. This normalization is done with a scalar minimum phase polynomial aMP,k(z−1) which is calculated from a spectral factorization of the squared second norm of the column vector ak(z−1). Denote this squared second norm as
Also denote the minimum phase factor polynomial of (11) as
a
MP,k(z−1)=MinPhaseFactor{sk(z−1)} (19)
See below for more details about spectral factorizations.
The inverse of this minimum phase polynomial in (12) is approximated by a FIR polynomial after long division as
Since aMP,k(z−1) is minimum phase this FIR approximation is numerically good. Now, the elements of column k of Q(z−1) is calculated as
q
i,k(z−1)=aMPinv,k(z−1)ai,k(z−1) (21)
for i=1, K, M and
r
k,k(z−1)=aMP,k(z−1). (22)
Finally, repeat (16) to (22) for the remaining columns of Q(z−1).
Within the Modified Gram Schmidt, MGS, algorithm, the columns qk(z−1) of Q(z−1) are sequentially (k=1, K, N) calculated. Compare with the Classical Gram Schmidt, CGS, algorithm where also each column of Q(z−) is sequentially calculated. However, while CGS calculates each column of R(z−1) sequentially (see equation (16)), the MGS calculates each row of R(z−1) sequentially.
First, define the matrix
A
(k)(z−1)=└a1(k)(z−1) a2(k)(z−1) Λ an(k)(z−1)┘ (23)
with
A
(1)(z−1)=H(z−1) (24)
For k=1, the first column q1(z−1) of Q(z−1) is defined as a normalized version of the first column a1(1)(z−1) of A(1)(z−1). This normalization is done with a scalar minimum phase polynomial aMP,1(z−1), i.e. all roots of the polynomial are located inside the unit circle. A minimum phase polynomial is calculated from a spectral factorization of the squared second norm of the first column a1(1)(z−1) of A(1)(z−1). Then, a new polynomial matrix A(2)(z−1) will be calculated below, in which the projections of A(1)(z−1) on this first column of Q(z−1) is subtracted. The second column of Q(z−1) is then calculated as a normalized version of the second column of this A(2)(z−1). The remaining columns of Q(z−1) are sequentially calculated in the same fashion.
Below, a description is given for calculating column k of Q(z−1) and row k of R(z−1). This description is valid for k=1, K, N.
Denote the squared second norm of column k of A(k)(z−1) as
Also denote the minimum phase factor polynomial of (25) as
a
MP,k(z−1)=MinPhaseFactor{sk(z−1)}. (26)
See below for more details about spectral factorizations.
The inverse of this minimum phase polynomial in (26) is approximated by a FIR polynomial after long division as
Since aMP,k(z−1) is minimum phase (all roots inside the unit circle), this FIR approximation is numerically good. Here, the length of the FIR approximation is considered as a design variable which must be selected with care. Now, the elements of column k of Q(z−1) are calculated as
q
i,k(z−1)=aMPinv,k(z−1)ai,k(z−1) (28)
for i=1, K, M.
The diagonal element in row k and column k of R(z−1) is defined as
r
k,k(z−1)=aMP,k(z−1) (29)
and the off-diagonal elements of row k of R(z−1) is calculated as
for j=k+1, K, N.
In order to proceed with the next column of Q(z−1), a new polynomial matrix A(k+1)(z−1) is defined in which the projections of A(k)(z−1) on the recently calculated column k of Q(z−1) is subtracted. Thus, define column j of the matrix A(k+1)(z−1), for k≧1, as
a
j
(k+1)(z−1)=aj(k)(z−1)−qk(z−1)rk,j(z−1). (31)
for j=k+1, K, N.
The remaining columns of Q(z−1) are calculated by increasing k and repeat (25) to (31).
Consider the polynomial element in row i and in column j of a polynomial matrix A(z−1)
where
z
m
εQ
in
(i,j) if |zm|2<1 (33)
and
z
m
εQ
out
(i,j) if |zm|2≧1 (34)
The squared second norm of column k of A(z−1)
can then be modeled by the individual roots of the elements in A(z−1)
or by the roots of the polynomial
where
The spectral factorization of sk(z−1) into minimum phase polynomials equals
s
k(z−1)=aMP,k(z−1)aMP,k*(z). (40)
such that
where βk=√{square root over (αk)}. Thus, the polynomial aMP,k(z−1) has all roots inside the unit circle.
Several algorithms for calculation of this spectral factorization are available. For example, the roots of the polynomial sk(z−1) can be explicitly calculated such that the minimum phase spectral factorization is calculated from (41). Alternatively, the method as described in U.S. Pat. No. 6,826,226 can be used. The process of calculating the minimum phase factor aMP,k(z−1) from sk(z−1) is denoted as
a
MP,k(z−1)=MinPhaseFactor{sk(z−1)}. (42)
The polynomial multiplications included in the Classical Gram Schmidt algorithm are listed in table 1. The polynomial channel matrix H(z−1) is used as input.
The polynomial multiplications included in the Modified Gram Schmidt algorithm are listed in table 2. As input to this algorithm, the matrix A(1)(z−1) is defined as A(1)(z−1)=H(z−1).
The polynomial degree for each polynomial multiplication in CGS and MGS are given in table 1 and table 2, respectively. Here the minimum power of z−1 and maximum power of z−1 are listed as functions of the degrees of the polynomials involved in the multiplications. These values are referred to as unconstrained. A convention is also included in table 1 and table 2 of the polynomial powers after multiplication. If the introduced polynomial degree is smaller than the unconstrained value, then the result of the polynomial multiplication is truncated.
The parameters LQnc, LQc, LRnc, LRc, LAnc, and LAc are design variables, which should be selected with care.
Channel after Pre-Filtering
The channels after pre-filtering are illustrated in
The channels after pre-filtering above the main diagonal are not minimum phase after pre-filtering, and can thus have roots both inside and outside the unit circle, see
The channel after pre-filter is proposed to be calculated as a polynomial multiplication between the calculated pre-filter and the channel estimate, see illustration in the flow chart of
The channel after pre-filtering can thus be calculated as
g
i,j(z−1)=qi*T(z−1)hj(z−1) (43)
The result of this polynomial multiplication can be truncated as indicted in table 3.
An illustration of the whiteness of the noise after pre-filtering is given in
E{{tilde over (Q)}(z−1)W(n)({tilde over (Q)}(z)W(n−m))*T}=Q*T(z−1)Q(z)·δ(n)=I·δ(n). (44)
are illustrated which should be unity for time lag zero on the main diagonal and zero elsewhere.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/SE2012/050670 | 6/18/2012 | WO | 00 | 12/17/2014 |