Apparatus and method for determining a precoding matrix

Information

  • Patent Grant
  • 8781027
  • Patent Number
    8,781,027
  • Date Filed
    Thursday, May 10, 2012
    12 years ago
  • Date Issued
    Tuesday, July 15, 2014
    10 years ago
Abstract
An apparatus for determining a target precoding matrix from a plurality of precoding matrix candidates is provided. The apparatus includes a covariance matrix value provider, a real part determiner and a precoding matrix determiner. The precoding matrix determiner is adapted to determine the target precoding matrix from the plurality of precoding matrix candidates, wherein the precoding matrix determiner is configured to determine the target precoding matrix based on at least one of the one or more real covariance values.
Description
FIELD

The present invention relates to an apparatus and method for determining a precoding matrix, and, in particular, to an apparatus and method for determining a target precoding matrix from a plurality of precoding matrix candidates, the precoding matrix candidates being adapted to be applied on a data stream, wherein the data stream is to be transmitted by a transmitter.


BACKGROUND

Long-Term Evolution (LTE) (see 3GPP. Evolved universal terrestrial radio access (e-utra); physical layer general description. Technical Specification 3GPP 36.201 Release-8, 3rd Generation Partnership Project, Sophia Antipolis, December 2009) is the trademark of the Third Generation Partnership Project (3GPP) and is aimed to become the next generation mobile network technology. In LTE, different transmission modes (TM) exist, see, for example, 3GPP. Evolved universal terrestrial radio access (e-utra); physical layer procedures. Technical Specification 3GPP 36.213 Release-8, 3rd Generation Partnership Project, Sophia Antipolis, December 2009, 3GPP. Evolved universal terrestrial radio access (e-utra); physical layer procedures. Technical Specification 3GPP 36.213 Release-9, 3rd Generation Partnership Project, Sophia Antipolis, March 2010, and 3GPP. Evolved universal terrestrial radio access (e-utra); physical layer procedures. Technical Specification 3GPP 36.213 Release-10, 3rd Generation Partnership Project, Sophia Antipolis, December 2010, which can be divided into open-loop and closed-loop transmission. In order to provide reliable communication, the user equipment (UE) has to estimate its channel. As indicated by the name ‘closed-loop’, the UE provides the eNodeB with information which is referred to as Channel State. Information (CSI). The CSI concerns the instantaneous state of the channel, see, for example 3GPP. Evolved universal terrestrial radio access (e-utra); physical channels and modulation. Technical Specification 3GPP 36.211 Release-8, 3rd Generation Partnership Project, Sophia Antipolis, December 2009, 3GPP. Evolved universal terrestrial radio access (e-utra); physical channels and modulation. Technical Specification 3GPP 36.211 Release-9, 3rd Generation Partnership Project, Sophia Antipolis, March 2010, and 3GPP. Evolved universal terrestrial radio access (e-utra); physical channels and modulation. Technical Specification 3GPP 36.211 Release-10, 3rd Generation Partnership Project, Sophia Antipolis, December 2010.


One parameter which may be fed back is the Precoding Matrix Index (PMI). Precoding vectors are a special kind of precoding matrices, wherein the precoding vectors are precoding matrices that only comprise a single column. The precoding matrices/precoding vectors are stored in a codebook and are known to both, eNodeB and UE, so it is sufficient to feed back only an index in order to save transmission bandwidth. In the following, reference is made to precoding vectors, while the concepts, explanations and teachings also apply to precoding matrices.


As already indicated, the precoding vector may be selected by the UE. Depending on the number of transmit antennas, several precoding vectors exist. It is a priori not known which of these precoding vectors maximizes the signal energy. According to the state of the art, at first, the signal energy is determined for all precoding vectors individually, and then, the signal energies of the precoding vectors are compared in order to feed back the most appropriate precoding vector index (or precoding matrix index, respectively). Such determination processes and comparisons are energy consuming and time consuming. It can be concluded that precious time and energy is wasted, which both are limited resources at each UE.


In the following, a complex baseband notation will be used, which deploys a matrix vector calculus for describing the system structure and the signal processing. Vectors and matrices may be denoted by lower case or upper case characters in bold face.


The matrix lk is the identity matrix of dimension k. Furthermore, (•)* and (•)H denote the conjugate and Hermitian operation, respectively. The magnitude of a scalar value is denoted by |•|, where the Euclidean norm ∥•∥2 will be used for vectors. The subscript of the Euclidean norm will be skipped in the following.


In the following, closed-loop transmission in LTE-Release 8, 9 or 10 systems using NT transmit antennas at eNodeB and NR receive antennas at UE is considered. The system model is defined by the formula:

r=Hcustom characterd+n  (1)

and describes the transmission of symbol dεcustom character using the channel Hεcustom characterNR×NT using the precoding vector custom characterεcustom characterNT. The UE receives rεCNR, where nεcustom characterNR, n˜CN (0, σ2INR) is the zero-mean circularly-symmetric complex Gaussian noise vector.


According to the state of the art, the UE reports the index i of the precoding vector from the set of available precoding vectors, which yields maximal signal energy ∥Hpi2. In order to obtain the best PMI for M subcarriers, according to the state of the art, the following has to be calculated:










arg







max

i


{

1
,





,
K

}





{




j
=
0


M
-
1








H
j



p
i




2


}



=


arg







max

i


{

1
,





,
K

}





{




j
=
0


M
-
1





p
i
H



H
j
H



H
j



p
i



}



=


arg







max

i


{

1
,





,
K

}





{



p
i
H



H
0
H



H
0



p
i


+

+


p
i
H



H

M
-
1

H



H

M
-
1




p
i



}



=

arg







max

i


{

1
,





,
K

}





{



p
i
H



(



H
0
H



H
0


+

+


H

M
-
1

H



H

M
-
1




)




p
i


}









(
2
)












=

arg







max

i


{

1
,





,
K

}





{



p
i
H

(





j
=
0


M
-
1





H
j
H



H
j






:=
R



)



p
i


}




,





(
3
)








where K=2NT is the number of precoding vectors and wherein NT is the number of transmit antennas at eNodeB. According to the state of the art, an exhaustive search is to be performed by analyzing all possible precoding vectors and searching for the appropriate index. For the case of NT=2 transmit antennas and NT=4 transmit antennas, four and sixteen different precoding vectors exist, respectively.


SUMMARY

An apparatus for determining a target precoding matrix from a plurality of precoding matrix candidates is provided. The precoding matrix candidates are adapted to be applied on a data stream, wherein the data stream is to be transmitted by a transmitter. The apparatus comprises a covariance matrix value provider, a real part determiner and a precoding matrix determiner.


The covariance matrix value provider is adapted to provide one or more complex covariance matrix values, wherein the one or more complex covariance matrix values are complex numbers, wherein each one of the one or more complex covariance matrix values is an off-diagonal coefficient of a channel covariance matrix or a combination of two or more off-diagonal coefficients of the channel covariance matrix.


The real part determiner is configured to determine a real part of at least one of the one or more complex covariance matrix values or to determine a real part of a combination of at least one of the one or more complex covariance matrix values and at least one component of the precoding matrix candidates to obtain one or more real covariance values, wherein the one or more real covariance values are real numbers.


The precoding matrix determiner is adapted to determine the target precoding matrix from the plurality of precoding matrix candidates, wherein the precoding matrix determiner is configured to determine the target precoding matrix based on at least one of the one or more real covariance values.


An algorithm that delivers the same result as the state of the art but which reduces the number of operation steps significantly is provided. In contrast to the state of the art, not all possible precoding vectors have to be analyzed. In modern Field Programmable Gate Arrays (FPGAs) or Digital Signal Processors (DSPs), the calculation of all combinations is feasible in real time, but each operation step uses energy, which is a limited resource in mobile devices. If the UE is operating in closed-loop, the index of the precoding vector may be calculated frequently, so applying an algorithm, which has a complexity of less than one third or one fourth compared to the state of the art solution results in considerable savings regarding the power consumption at the UE. Moreover, the computation time needed is reduced significantly.


Depending on number of transmit antennas, LTE specification for precoding based spatially multiplexing transmissions includes a total of 4 precoding vectors and 16 precoding vectors for two and four transmit antenna configurations, respectively. Proper selection of the optimal precoding vector requires knowledge of the current channel conditions at the transmitter. In an LTE precoded downlink closed-loop transmission, the mobile terminal or user equipment (UE) will measure the channel characteristics and determine the precoding matrix index (PMI), channel quality indicator (CQI) and/or Rank Index (RI). In this context, the name precoding matrix is a general denotation. In the following, the explanations refer to a precoding vector or to one of the columns of the precoding matrix, e.g. the first column of the precoding matrix, what also results in considering a precoding vector. However, other embodiments, wherein the precoding matrix has more than one column, take all columns of the precoding matrix into account, e.g. the other columns of the precoding matrix are processed in the same way as e.g. explained for the (column of the) precoding vector.


This most appropriate PMI will be sent to the base station (eNodeB) which would assist the eNodeB in selecting the precoding vector to improve overall system performance. As channel conditions may change rapidly over time, it is important for the system to avoid excessive delays in such a closed-loop system. Reduction of the signaling overhead and associated feedback delay is accomplished by restricting the number of codebook selections. However, reducing the number of selections may also limit the number of possible adjustments thus reducing the effectiveness of precoding. On the other hand, it is a priori not known which of these precoding vectors optimizes the performance, so all precoding vectors have to be evaluated individually first and all results have to be compared to each other in order to feed back the most appropriate PMI. This state-of-the-art procedure results in that precious energy is wasted, which results to a limited resource at each UE.


According to embodiments, a new developed algorithm is provided which delivers the same result as the state of art approach, but reduces the number of operation steps (computation efforts) significantly. Instead of performing an exhaustive search over all precoding vectors, this algorithm exploits

    • mathematical properties of the precoding vectors (first element of precoding vector is always constant and other elements vary but they are limited to finite set of
    • different values),
    • the structure of the MIMO channel covariance matrix (Hermitian) and
    • alignment between the channel matrix and precoding vectors.


In an embodiment, in case of two transmit antennas the provided algorithm of an embodiment restricts on analysis of only one coefficient and determines the index of precoding vector maximizing the squared Euclidean. Moreover, in an embodiment, in case of four transmit antennas there may be four coefficients to be analyzed. The provided algorithms reduce the set of precoding vectors to be analyzed compared to the state of the art. Thus, the complexity can be reduced more than four times compared to the state-of-the-art approach for two transmit antennas and by three times for four transmit antennas. If the UE is operating in closed-loop, the PMI has to be calculated frequently, so applying the invented algorithm, which has a complexity of less than one third or even one fourth compared to the state of the art solution results in considerably savings regarding power consumption at the UE.


According to an embodiment, a mobile communication device is provided. The mobile communication device comprises a baseband processor, an antenna and an apparatus for determining a target precoding matrix from a plurality of precoding matrix candidates. The precoding matrix candidates are adapted to be applied on a data stream, wherein the data stream is to be transmitted by a transmitter. The apparatus for determining the target precoding matrix comprises a covariance matrix value provider, a real part determiner and a precoding matrix determiner.


The covariance matrix value provider is adapted to provide one or more complex covariance matrix values, wherein the one or more complex covariance matrix values are complex numbers, wherein each one of the one or more complex covariance matrix values is an off-diagonal coefficient of a channel covariance matrix or a combination of two or more off-diagonal coefficients of the channel covariance matrix.


The real part determiner is configured to determine a real part of at least one of the one or more complex covariance matrix values or to determine a real part of a combination of at least one of the one or more complex covariance matrix values and at least one component of the precoding matrix candidates to obtain one or more real covariance values, wherein the one or more real covariance values are real numbers.


The precoding matrix determiner is adapted to determine the target precoding matrix from the plurality of precoding matrix candidates, wherein the precoding matrix determiner is configured to determine the target precoding matrix based on at least one of the one or more real covariance values.


In another embodiment, a method for determining a target precoding matrix from a plurality of precoding matrix candidates is provided. The precoding matrix candidates are adapted to be applied on a data stream, wherein the data stream is to be transmitted by a transmitter. The method comprises providing one or more complex covariance matrix values, wherein the one or more complex covariance matrix values are complex numbers, wherein each one of the one or more complex covariance matrix values is an off-diagonal coefficient of a channel covariance matrix or a combination of two or more off-diagonal coefficients of the channel covariance matrix. The method further comprises determining a real part of at least one of the one or more complex covariance matrix values or determining a real part of a combination of at least one of the one or more complex covariance matrix values and at least one component of the precoding matrix candidates to obtain one or more real covariance values, wherein the one or more real covariance values are real numbers. Lastly, the method comprises determining the target precoding matrix from the plurality of precoding matrix candidates, wherein the precoding matrix determiner is configured to determine the target precoding matrix based on at least one of the one or more real covariance values.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates an apparatus for determining a target precoding matrix according to an embodiment,



FIG. 2 illustrates a setup of a communication system depicting a transmitter having three transmit antennas, a receiver having two receive antennas, a respective channel matrix, a respective precoding vector and a respective complex covariance matrix,



FIG. 3 illustrates the effect of applying a precoding vector on a component of a data stream, and



FIG. 4 illustrates a flow chart depicting steps of a method for determining a target precoding vector.





DETAILED DESCRIPTION


FIG. 1 illustrates an apparatus for determining a target precoding matrix from a plurality of precoding matrix candidates. The precoding matrix candidates are adapted to be applied on a data stream. Moreover, the data stream is to be transmitted by a transmitter. The apparatus comprises a covariance matrix value provider 110, a real part determiner 120 and a precoding matrix determiner 130.


The covariance matrix value provider 110 is adapted to provide one or more complex covariance matrix values, wherein the one or more complex covariance matrix values are complex numbers. Each one of the one or more complex covariance matrix values is an off-diagonal coefficient of a channel covariance matrix or a combination of two or more off-diagonal coefficients of the channel covariance matrix. For example, the channel covariance matrix may be a Multiple Input Multiple Output channel covariance matrix, being derived from a channel matrix H which represents a relation between the antennas of the transmitter and the antennas of a receiver. The channel covariance matrix may then be the matrix product of a Hermitian complex matrix of the channel matrix H and the channel matrix H itself. The covariance matrix value provider 110 may be adapted to provide the complex covariance matrix value to the real part determiner 120. This is indicated by arrow 115.



FIG. 1 moreover depicts the real part determiner 120. In an embodiment, the real part determiner 120 is configured to determine a real part of a combination of at least one of the complex covariance matrix values and at least one component of the precoding matrix candidates. For this, in such an embodiment, the precoding matrix candidates are available for the real part determiner 120, what is indicated by a dashed arrow 127. In both embodiments, the real part determiner 120 is configured to obtain one or more covariance values, wherein the one or more real covariance values are real numbers. Moreover, the real part determiner 120 is adapted to provide the one or more real covariance values to the precoding matrix determiner 130. This is indicated by arrow 125.


Furthermore, FIG. 1 illustrates the precoding matrix determiner 130. The precoding matrix determiner 130 is configured to determine the target precoding matrix from the plurality of precoding matrix candidates by comparing at least one of the real covariance values and at least one other value. For example, the at least one other value may be predetermined. According to another embodiment, one of the real covariance values is compared with all or at least some of the other real covariance values, for example, to determine a maximum of the real covariance values. In an embodiment, that precoding matrix candidate is selected as the target precoding matrix which has a real covariance value assigned to it that is a maximum covariance value. The precoding matrix determiner 130 may then be adapted to provide the target precoding matrix, as indicated by arrow 135.


A precoding matrix candidate may have a plurality of columns and a plurality of rows, wherein each coefficient may relate to one of the transmit antennas and possibly to a particular subband. Precoding vectors however, which are special kinds of precoding matrices, only have a single column. Their components relate to the transmit antennas of a transmitter.



FIG. 2 illustrates the channel matrix and the complex covariance matrix in more detail. Moreover, a transmitter 201 and a receiver 202 are depicted. The transmitter 201 comprises a first transmit antenna 211, a second transmit antenna 221 and a third transmit antenna 231. The receiver 202, for example, a mobile phone, e.g., a smartphone, comprises a first receive antenna 212 and a second receive antenna 222. The channel from the first transmit antenna 211 to the first receive antenna 212 is indicated by arrow h11. The channel from the first transmit antenna 211 to the second receive antenna 222 is indicated by h21. The other channels are indicated by h12, h22, h13 and h23. A channel matrix H which indicates the channels from the transmit antennas to the receive antennas is shown in box 240. The channel matrix has three columns, as there are three transmit antennas. Moreover, the channel matrix has two rows as there are two receive antennas. Thus, the matrix has six complex coefficients indicating the channels from the transmit antennas to the receive antennas.


Furthermore, FIG. 2 depicts a precoding vector in box 250. As there are three transmit antennas, the precoding vector comprises three components p11, p12 and p13.


Moreover, box 260 illustrates a complex covariance matrix R. In the example of FIG. 2, the complex covariance matrix R may be defined by the formula R=HHH. Such a complex covariance matrix R is referred to as a Multiple Input Multiple Output channel covariance matrix, as it is formed based on a channel matrix H which characterizes the channels from a transmitter having multiple transmit antennas to a receiver having multiple receive antennas.


Embodiments are based on the concept of reducing the complexity by making use of mathematical properties of the precoding vectors.


In the following, different embodiments are presented. A first group of embodiments relates to transmission on two antenna ports. Later, another group of embodiments is presented relating to the transmission on four antenna ports.


At first, transmission on two antenna ports is presented in more detail. The precoding vectors for transmission on two antenna ports may be described as:











p
1

=


1

2




(



1




1



)










p
2

=


1

2




(



1





-
1




)










p
3

=


1

2




(



1




j



)










p
4

=


1

2




(



1





-
j




)







(
4
)








or, in a more general form:








p
i

=


1

2




(



1





v
i




)



,





wherein

νi=(1,−1,j,−j)

with only one degree of freedom. νi is a component of the precoding vector. The matrix R in formula (3) can be written as












R
=






j
=
0


M
-
1





H
j
H



H
j









=






j
=
0


M
-
1






(




h
11




h
12






h
21




h
22




)

j
H




(




h
11




h
12






h
21




h
22




)

j









=






j
=
0


M
-
1






(




h
11
*




h
21
*






h
12
*




h
22
*




)

j




(




h
11




h
12






h
21




h
22




)

j









=






j
=
0


M
-
1





(








h
11



2

+




h
21



2







h
11
*



h
12


+


h
21
*



h
22










h
11



h
12
*


+


h
21



h
22
*










h
12



2

+




h
22



2





)

j








=



(




r
11




r
12






r
21




r
22




)








=



(




r
11




r
12






r
12
*




r
22




)


,







(
5
)








by using the symmetry of Hermitian matrix operation, where Hj denotes the channel matrix for subcarrier j. The precoding vector p and pH is denoted by









p
=



(




p
1






p
2




)






and






p
H


=

(


p
1
*







p
2
*


)






(
6
)








respectively. Calculating the matrix vector product pHRp and applying the symmetry of matrix R, yields













arg







max

i


{

1
,





,
4

}






p
i
H



Rp
i




=



arg







max

i


{

1
,





,
4

}






1
2



(


r
11

+


r
12



v
i


+


v
i
*



(


r
12
*

+


r
22



v
i



)



)










=



arg







max

i


{

1
,





,
4

}






1
2



(


r
11

+


r
12



v
i


+


r
12
*



v
i
*


+


r
22






v
i






=
1





)










=



arg







max

i


{

1
,





,
4

}






1
2



(



r
12



v
i


+


r
12
*



v
i
*



)










=



arg







max

i


{

1
,





,
4

}








{


r
12



v
i


}

.











(
7
)







As can be seen in formula (7), it is sufficient to only analyze one coefficient r12 of R. The algorithm to determine the precoding vector is given in Table 1. The same concept can also be employed for the case of four transmit antenna ports at eNodeB.









TABLE 1





algorithm for νi



















function [νi] = estimate_PMI (r12)












 if (| custom character  {r12} | > |ℑ {r12} |)
(1)




 if ( custom character  {r12} > 0) then νi ← 1
(2)




 else νi ← −1
(3)




 endif
(4)




else
(5)




 if (ℑ {r12} > 0) then νi ← −j
(6)




 else νi ← j
(7)




 endif
(8)




 endif
(9)











 return νi




end









i.










In some of the above-described embodiments, the target precoding matrix is a target precoding vector and is selected from the precoding vector candidates presented in formula (4):











p
1

=


1

2




(



1




1



)










p
2

=


1

2




(



1





-
1




)










p
3

=


1

2




(



1




j



)










p
4

=


1

2




(



1





-
j




)







(
4
)







The symbol dεcustom character in formula (1):

r=Hcustom characterd+n  (1)

that may also apply for the above-described embodiments is a symbol of a data stream to be transmitted.


Moreover, in the above-described embodiments, the matrix R as defined in formula (5) may be a Multi Input Multi Output channel covariance matrix having two rows and two columns. The off-diagonal element r12 in the formula (5) and in formula (7) or in Table 1 may be provided as one of the complex covariance matrix values and may be a complex number.


In an embodiment, a real part determiner may be configured to determine a real part of the off-diagonal element r12 as one of the one or more real covariance values. In such an embodiment, the precoding matrix determiner may be configured to determine the target precoding vector based on the real part of the off-diagonal element r12 as one of the one or more real covariance values. According to an embodiment, this determination is conducted according to the algorithm provided in Table 1.


In Table 1, a first absolute value of the real covariance value and a second absolute value of an imaginary number of one of the complex covariance matrix value r12 are compared;

|custom character{r12}|>|ℑ{r12}|

(see line 1 of the algorithm of table 1).


According to another embodiment, a real part determiner may be configured to determine a real part of a combination of the complex covariance matrix value r12 and the component νi of each of the precoding matrix candidates to obtain four real covariance values custom character{r12 νi}. In such an embodiment, the precoding matrix determiner may be configured to determine the target precoding matrix based on the four real covariance values by applying the last line of formula (7):






:

arg







max

i


{

1
,





,
4

}







{


r
12



v
i


}








In one embodiment, no main-diagonal coefficient of the Multi Input Multi Output channel covariance matrix R of formula (5) is determined, e.g. the coefficients of the matrix R which have a column index that is the same as the row index are not determined, e.g. the coefficients r11 and r22 of the matrix R in formula (5) are not determined.


In an embodiment, each one of the one or more off-diagonal coefficients of the Multi Input Multi Output channel covariance matrix is a coefficient of a product of a group of one or more matrix products, e.g. if R=HHH


And if H is defined as:










(




h
11




h
12






h
21




h
22




)






then HH which is the conjugate transpose matrix of matrix H is defined by:










(




h
11
*




h
21
*






h
12
*




h
22
*




)






and the matrix product R of both matrices is:










(




h
11
*




h
21
*






h
12
*




h
22
*




)


   


(




h
11




h
12






h
21




h
22




)






In another embodiment, each one of the one or more off-diagonal coefficients of the Multi Input Multi Output channel covariance matrix is a sum of coefficients of products of the group of matrix products.


E.g., see line 3 of formula (5):









j
=
0


M
-
1






(




h
11
*




h
21
*






h
12
*




h
22
*




)

j


   



(




h
11




h
12






h
21




h
22




)

j






There, the group of channel matrices comprises the channel matrices:










(




h
11




h
12






h
21




h
22




)

j






of each subcarrier j. Moreover, the group of matrix products comprises the matrix products








(




h
11
*




h
21
*






h
12
*




h
22
*




)

j


   



(




h
11




h
12






h
21




h
22




)

j






of each subcarrier j. Furthermore, the off-diagonal coefficients of the Multi Input Multi Output channel covariance matrix R of formula (5) are therefore a sum of coefficients of products of the group of matrix products.


In the following, an example is presented. Assume for simplicity M=1, so R=HHH. A possible realization of H and R may be






H
=

(





-
1.5972

-

0.3066





j





0.2254
+

2.5303





j







0.6096
+

0.2423





j






-
0.9247

+

1.9583





j





)







and





hence






R
=


(



3.0756




-
1.2251

-

2.5545





j








-
1.2251

+

2.5545





j




11.1432



)

.





The classic approach aims to analyze all possible precoding vectors custom characteri, iε{1, . . . , 4}, and reports the index i with maximal squared Euclidean norm ∥Hcustom characteri2, done as follows:











1
2






H


(



1




1



)




2


=




1
2






(





-
1.3718

+

2.2237





j








-
0.3150

+

2.2006





j





)



2








=



5.8843






(

i
=
1

)
















1
2






H


(



1





-
1




)




2


=




1
2






(





-
1.8226

-

2.8369





j








-
1.5343

-

1.7160





j





)



2








=



8.3345






(

i
=
2

)
















1
2






H


(



1




j



)




2


=




1
2






(





-
4.1276

-

0.0812





j








-
1.3486

-

0.6824





j





)



2








=



9.6639






(

i
=
3

)


















1
2






H


(



1





-
j




)




2


=




1
2






(




0.6598
-

0.3762





j







1.8158
+

0.8252





j





)



2








=



4.5548






(

i
=
4

)












max


{

5.8843
,
8.3345
,
9.6639
,
4.5548

}



=

9.6639






(

i
=
3

)






The precoding vector which maximizes the energy given the matrix H is p3. The same result is obtained by using the algorithm described in Table 1, which restricts on coefficient r12=−1.2251−2.5545j of matrix R. Obviously |custom character{r12}|=1.2251 and |ℑ{r12}|=2.5545. Hence line (1) of Table 1 is not fulfilled and the algorithm proceeds with line (5) of Table 1. By the reason of ℑ{r12}=−2.5545<0, set v=j according to line (7) and return v.



FIG. 3 illustrates a geometric representation of formula (7). Geometrically, the product of r12 and ν, νε{1, j, −1, −j} is equivalent to turn r12 through 0°, 90°, 180° and 270°, respectively. Regarding r12=−1.2251−2.5545j, the coefficient lies in quadrant Q3. Due to formula (7) and |ℑ{r12}|>|custom character{r12}|, the best solution is to turn r12 through 90° what is equivalent to multiply r12 with j. Hence, r12 is transformed into quadrant Q4.



FIG. 4 illustrates a flow chart depicting steps of a method for determining a target precoding vector. The method is similar to the algorithm presented in table 1. In step 410, a real part and an imaginary part of the complex covariance matrix value r12 is provided. Then, in step 420, it is determined, whether |custom character{r12}| is greater than |ℑ{r12}|. If this is the case, then, in step 430, it is determined, whether |custom character{r12}| is greater than 0. If this is also the case, then νi is set to 1 (step 440), otherwise νi is set to −1 (step 450). If, however, it is determined in step 420 that |custom character{r12}| is not greater than |ℑ{r12}|, then it is checked in step 460, whether |ℑ{r12}| is greater than 0. If this is the case, then νi is set to −j (step 470), otherwise νi is set to j (step 480).


In the following, complexity is considered. The custom character(n) notation is used to express the complexity for an operation. With reference to modern Digital Signal Processors (DSPs), the following operations and their complexities are identified. Regarding the classic approach, we first calculate the matrix vector product.












Hp
i

=




(




h
11




h
12






h
21




h
22




)



(




p
1






p
2




)








=



(






h
11



p
1


+


h
12



p
2










h
21



p
1


+


h
22



p
2






)







=



(




g
1






g
2




)







=


g










𝒪


(

Hp
i

)



=



4
·
MUL

+

2
·
ADD


=



4
·

𝒪


(
1
)



+

2
·

𝒪


(
1
)




=

6
·

𝒪


(
1
)










and









g


2

=



g
H


g

=




(


g
1
*

,

g
2
*


)



(




g
1






g
2




)








𝒪


(



g


2

)



=



2
·
CONJ

+
TRANSP
+

2
·
MUL

+
ADD

=

6
·

𝒪


(
1
)







,





resulting in 12·custom character(1) operations for a single precoding vector. Due to four different precoding vectors custom characteri, iε{1, . . . , 4}, the operations have to be repeated four times, yielding 4·12·custom character(1)=48·custom character(1) operations. Finally the index corresponding to the precoding vector maximizing the energy has to be searched and reported. Assuming the worst case for the search procedure custom character(n) can be rated to 3·custom character(1) comparisons. Hence, the classic approach needs 51·custom character(1) operations in total.


Regarding the complexity reduced approach of the above embodiment, first precompute:

r12=h11*h12+h12*h22
custom charactercustom character(r12)=2·CONJ+2·MUL+ADD=5·custom character(1).


The complexity of algorithm in Table 1 is summarized in Table 3, taking into account the complexities for each operation given in Table 2.









TABLE 1





algorithm for vi




















function [vi] = estimate_PMI (r12)





 if (| custom character  {r12} | > |ℑ {r12} |)
(1)




  if ( custom character  {r12 } > 0) then vi ← 1
(2)




  else vi ← −1
(3)




  endif
(4)




 else
(5)




  if (ℑ {r12} > 0) then vi ← −j
(6)




  else vi ← j
(7)




  endif
(8)




 endif
(9)




 return vi





end

















TABLE 2





complexity of used operations





















addition
ADD

custom character  (1)





multiplication
MUL

custom character  (1)





conjugate
CONJ

custom character  (1)





transpose
TRANSP

custom character  (1)





comparison
COMP

custom character  (1)






custom character  {·}

REAL

custom character  (1)





ℑ{·}
IMAG

custom character  (1)





|·|
MAGN

custom character  (1)





switch
SWITCH

custom character  (1)





case
CASE

custom character  (1)





search
SEARCH

custom character  (n)











The complexity reduced algorithm of the above embodiments has a total complexity 12·custom character(1), which is more than four times lower than the state of the art.









TABLE 3







complexities for algorithm in Table 1









line
operation(s)
complexity





1

custom character  {·}, ℑ{·}, 2 · MAGN, COMP

5 · custom character  (1)


2

custom character  {·}, COMP

2 · custom character  (1)


3




4




5
see above
see above


6




7




8




9




Σ

7 · custom character  (1)









In the following, embodiments are presented relating to the transmission on four antenna ports.


Calculating the precoding vectors for transmission on four antenna ports on one layer at eNodeB, the following precoding vectors can be obtained for s=1, using







W
n

{
s
}


=


I
4

-


2
·

u
n





u
n
H

/

u
n
H




u
n










W
n

{
s
}


=

(


p
n

,

p
n


,

p
n


,

p
n
′″


)









p
1

=

(



0.5




0.5




0.5




0.5



)













p
2

=

(



0.5





0.5





j






-
0.5







-
0.5






j




)









p
3

=

(



0.5





-
0.5





0.5





-
0.5




)













p
4

=

(



0.5






-
0.5






j






-
0.5






0.5





j




)








p
5

=

(



0.5






1

2


2



+


1

2


2




j







0.5





j







-

1

2


2




+


1

2


2




j





)








p
6

=

(



0.5






-

1

2


2




+


1

2


2




j








-
0.5






j







1

2


2



+


1

2


2




j





)








p
7

=

(



0.5






-

1

2


2




-


1

2


2




j







0.5





j







1

2


2



-


1

2


2




j





)








p
8

=

(



0.5






1

2


2



-


1

2


2




j







-
0.5







-

1

2


2




-


1

2


2




j





)













p
9

=

(



0.5




0.5





-
0.5






-
0.5




)














p
10

=

(



0.5





0.5





j





0.5





0.5





j




)














p
11

=

(



0.5





-
0.5






-
0.5





0.5



)









p
12

=

(



0.5






-
0.5






j





0.5






-
0.5






j




)








p
13

=

(



0.5




0.5




0.5





-
0.5




)








p
14

=

(



0.5




0.5





-
0.5





0.5



)








p
15

=

(



0.5





-
0.5





0.5




0.5



)








p
16

=

(



0.5





-
0.5






-
0.5






-
0.5




)






where s=1 is the column vector pn of matrix Wn.


The best PMI custom characteri, iε{1, . . . , 16} maximizes the received signal energy ∥Hcustom characteri2. Depending on the number of receive antennas NR at UE, different channel matrices HNR can be obtained:










H


N
R

=
1


=

(


h
11







h
12







h
13







h
14


)









1
×
4









H


N
R

=
2


=

(




h
11




h
12




h
13




h
14






h
21




h
22




h
23




h
24




)









2
×
4









H


N
R

=
4


=

(




h
11




h
12




h
13




h
14






h
21




h
22




h
23




h
24






h
31




h
32




h
33




h
34






h
41




h
42




h
43




h
44




)









4
×
4










for one, two or four receive antennas at the UE. The matrix R in formula (3) can be written as







R
=




j
=
0


M
-
1





H
j
H



H
j




,





where


HjHεcustom character4×NR and Hjεcustom characterNR×4,


so


custom character4×4

independent from the number of receive antennas NR at UE.


Thus, we set









R
=






j
=
0


M
-
1





H
j
H



H
j









=






j
=
0


M
-
1






(




h
11







h
14

















h


N
R


1








h


N
R


4





)

j
H




(




h
11







h
14

















h


N
R


1








h


N
R


4





)

j









=






j
=
0


M
-
1






(




h
11
*







h


N
R


1

*

















h
14
*







h


N
R


4

*




)

j




(




h
11







h
14

















h


N
R


1








h


N
R


4





)

j









=



(




r
11




r
12




r
13




r
14






r
21




r
22




r
23




r
24






r
31




r
32




r
33




r
34






r
41




r
42




r
43




r
44




)








=



(




r
11




r
12




r
13




r
14






r
12
*




r
22




r
23




r
24






r
13
*




r
23
*




r
33




r
34






r
14
*




r
24
*




r
34
*




r
44




)


,








by using the symmetry of Hermitian matrix operation. The precoding vector p and pH is denoted by









p
=



(




p
1






p
2






p
3






p
4




)






and






p
H


=

(


p
1
*







p
2
*







p
3
*







p
4
*


)






(
8
)








respectively. Calculating the matrix vector product pHRp and applying the symmetry of matrix R, yields














i
=
1

4




r
ii






p
i



2






=
const



+

2








{



r
12



p
1
*



p
2


+


r
13



p
1
*



p
3


+


r
14



p
1
*



p
4


+


r
23



p
2
*



p
3


+


r
24



p
2
*



p
4


+


r
34



p
3
*



p
4



}

.






(
9
)







The sum on the left hand side is real valued and does no play a role for maximizing the equation, as will be shown in the following. For each element pm, mε{1, . . . , 4}, the magnitude |pm| is constant and does not depend on m. Further all diagonal elements rii of matrix R are real valued, so the sum will be neglected due to no contribution for maximization. Regarding the first entry of pi, we recognize that custom character1=custom character1*=0.5 is constant and real valued for all iε{1, . . . , 16}. The maximization problem can be simplified to










arg







max

i


{

1
,





,
16

}





{




j
=
0


M
-
1








H
j



p
i




2


}



=

2








{



1
2



r
12



p
2


+


1
2



r
13



p
3


+


1
2



r
14



p
4


+


r
23



p
2
*



p
3


+


r
24



p
2
*



p
4


+


r
34



p
3
*



p
4



}

.






(
10
)







Next, all four possible values from the codebook for p3ε{±0.5, ±0.5j} are inserted into formula (10) and four equations are obtained, which have to be maximized separately.












(
A
)



p
3


=

0.5



:










2







{



1
2



r
12



p
2


+


1
4



r
13


+


1
2



r
14



p
4


+


1
2



r
23
*



p
2


+


r
24
*



p
2



p
4
*


+


1
2



r
34



p
4



}















{



(


r
12

+

r
23
*


)



p
2


+


(


r
14

+

r
34


)



p
4


+

2






r
24



p
2
*



p
4



}



max
















(
B
)



p
3


=


-
0.5




:










2







{



1
2



r
12



p
2


-


1
4



r
13


+


1
2



r
14



p
4


-


1
2



r
23
*



p
2


+


r
24
*



p
2



p
4
*


-


1
2



r
34



p
4



}















{



(


r
12

-

r
23
*


)



p
2


+


(


r
14

-

r
34


)



p
4


+

2






r
24



p
2
*



p
4



}



max
















(
C
)



p
3


=


0.5





j




:










2







{



1
2



r
12



p
2


+


1
4



r
13


j

+


1
2



r
14



p
4


-


1
2



r
23
*



p
2


j

+


r
24
*



p
2



p
4
*


-


1
2



r
34



p
4


j


}















{



(


r
12

-


r
23
*


j


)



p
2


+


(


r
14

-


r
34


j


)



p
4


+

2






r
24



p
2
*



p
4



}



max
















(
D
)



p
3


=



-
0.5






j




:










2







{



1
2



r
12



p
2


-


1
4



r
13


j

+


1
2



r
14



p
4


+


1
2



r
23
*



p
2


j

+


r
24
*



p
2



p
4
*


+


1
2



r
34



p
4


j


}















{



(


r
12

+


r
23
*


j


)



p
2


+


(


r
14

+


r
34


j


)



p
4


+

2






r
24



p
2
*



p
4



}



max




















For case (A) there are six precoding vectors which fulfill p3=0.5, namely custom characterSA, SAε{3, 10, 12, 13, 15}, summarized in Table 4. All other precoding vectors are listed in the corresponding tables.









TABLE 4







set of precoding vectors for custom character3 = 0.5













custom character
3 = 0.5


custom character
2


custom character
4

2 custom character2 * custom character4
















A1
0.5
0.5
0.5



A2
−0.5
−0.5
0.5



A3
0.5j
0.5j
0.5



A4
−0.5j
−0.5j
0.5



A5
0.5
−0.5
−0.5



A6
−0.5
0.5
−0.5

















TABLE 5







set of precoding vectors for p3 = 0.5i












p3 = 0.5i
p2
p4
2p2*p4







C1





1

2











2




+


1

2











2





j










-

1

2











2





-


1

2











2





j










1
2


j











C2





-

1

2











2





-


1

2











2





j










1

2











2




-


1

2











2





j










1
2


j





















TABLE 6







set of precoding vectors for custom character3 = −0.5













custom character
3 = −0.5


custom character
2


custom character
4

2 custom character2 * custom character4
















B1
0.5j
−0.5j
−0.5



B2
−0.5j
0.5j
−0.5



B3
0.5
−0.5
−0.5



B4
−0.5
0.5
−0.5



B5
0.5
0.5
0.5



B6
−0.5
−0.5
0.5

















TABLE 7







set of precoding vectors for p3 = −0.5j










p3 = −0.5i
p2
p4
2p2*p4





D1





-

1

2











2





+


1

2











2





j










1

2











2




-


1

2











2





j









-

1
2










D2





1

2











2




+


1

2











2





j










-

1

2











2





-


1

2











2





j









-

1
2














Regarding Table 4, it can be recognized that the first four cases (A1, . . . , A4) hold the same value for the sum 2custom character2*custom character4 on the right hand side. Further p2=p4 holds. The former property allows to disregard the sum 2custom character2*custom character4 for maximization purpose, while the latter one reduces the two dimensional optimization problem to a one dimensional optimization problem, leading to a simplified solution:

custom character{(r12+r23*)custom character2+(r14+r34)custom character4+2r24custom character2*custom character4}→max
custom charactercustom character{(r12+r23*)custom character2+(r14+r34)custom character2}→max
custom charactercustom character{(r12+r14+r23*+r34)custom character2}→max
custom charactercustom character{(r12+r14+r23*+r34i)}→max,  (11)

where viε{±1±j}. The solution corresponds to the solution presented above. Due to the same approach, we just have to define {tilde over (r)}12:=r12+r14+r23*+r34, run function estimate −PMI({tilde over (r)}12) in Table 1 and obtain vi with the mapping

νi=1→A1
νi=−1→A2
νi=j→A3
νi=−j→A4,

as defined in Table 4. Applying vi into the equation of optimization problem (A) for the cases custom characterA1, . . . , A4custom character, formula (12) is obtained:













max


{




A
1

,





,

A
4




}


=





{



(


r
12

+

r
23
*


)



v
i


+


(


r
14

+

r
34


)



v
i


+

2


1
4



r
24







v
i



2




=
1





}








=





{



(


r
12

+

r
14

+

r
23
*

+

r
34


)



v
i


+


1
2



r
24



}









(
12
)







The sum on the right hand side for the two remaining cases custom characterA5, A6custom character is also constant and the assumption p4=−p2 holds, so formula (13) is obtained:

custom character{(r12+r23*)custom character2+(r14+r34)custom character4+2r24custom character2*p4}→max
custom charactercustom character{(r12+r23*)custom character2−(r14+r34)custom character2}→max
custom charactercustom character{(r12−r14+r23*−r34)custom character2}→max
custom charactercustom character{(r12−r14+r23*−r34i)}→max,  (13)

where ωiε{±1} and, moreover, the mapping

ωi=1→A5
ωi=−1→A6.

is obtained. Applying ωi into the equation of optimization problem (A) for the cases custom characterA5, A6custom character, formula (14) is obtained:













max


{




A
5

,

A
6




}


=





{



(


r
12

+

r
23
*


)



ω
i


-


(


r
14

+

r
34


)



ω
i


-

2


1
4



r
24







ω
i



2




=
1





}








=






{



(


r
12

-

r
14

+

r
23
*

+

r
34


)



ω
i


-


1
2



r
24



}

.









(
14
)







If the maximum value of the first set max {custom characterA1, . . . , A4custom character} is greater than the maximum value of the second set max {custom characterA5, A6custom character}, we have to look for the best index in the first set, otherwise in the second one. Using

Ai=arg max{arg max{custom characterA1, . . . ,A5custom character},arg max{custom characterA5,A6custom character}},  (15)

we set the value of the possible candidate from (A) is set to











Ω
A

=



{



(


r
12

+

r
23
*


)



p
2




|

A
i





+

(


r
14

+

r
34


)




p
4




|

A
i





+
2







r
24



p
2




|

A
i




p
4



|

A
i





+

1
2




r
13



}



,




(
16
)








where the index i is the corresponding line number in Table 4 for p2 and p4.


The procedure for optimization problem (B) is analog and the detailed description will be omitted. Instead, the algorithm is shown in Table 8.


Regarding Table 5, no symmetry can be used apart from the case that the sum 2custom character2*custom character4 can be neglected. Hence










{



(


r
12

-


r
23
*


j


)



(

1
+
j

)


+


(


r
14

-


r
34


j


)



(


-
1

+
j

)



}






>

C
1







<

C
2















{


(


r
12

-


r
23
*


j


)



(


-
1

-
j

)


}


+


(


r
14

-


r
34


j


)



(

1
+
j

)




}





is obtained and is simplified to








{


(


r
12

-

r
14

+

r
23
*

+

r
34


)

+

j


(


r
12

+

r
14

-

r
23
*

+

r
34


)



}






>

C
1







<

C
2






0










{


r
12

-

r
14

+

r
23
*

+

r
34


)


+



(


r
12

+

r
14

-

r
23
*

+

r
34


}






>

C
1







<

C
2






0


,





using

custom character{z1+jz2}=custom character{z1}−ℑ{z2},z1,z2εcustom character

and C is set to C1 or C2. The value of the possible candidate from C calculates to










Ω
A

=




{



(


r
12

-


r
23
*


j


)



p
2




|
C




+

(


r
14

-


r
34


j


)




p
4




|
C




+
2







r
24



p
2




|
C



p
4



|
C




+

1
2




r
13


j


}

.






(
17
)







The procedure for optimization problem (D) is analog and the detailed description will be omitted. Instead, the algorithm is shown in Table 11


Executing all four algorithm for p3ε{±0.5, ±0.5j} results in a set real values


Ωψ=(ΩA, ΩB, ΩC, ΩD). Finally we have to choose











p
~

ψ

=

arg







max

ψ


{

A
,
B
,
C
,
D

}





{

Ω
ψ

}







(
18
)








and obtain p3 directly from ψ. In the last step we have to look up p2 and p4 in the corresponding table.


According to those above-described embodiments which describe transmission on four antenna ports, a target precoding vector is determined as target precoding matrix from the plurality of 16 precoding vector candidates p1 to p16 depicted above.


Each one of the one or more complex covariance matrix values may be a combination of two or more off-diagonal coefficients of the channel covariance matrix, for example, the combination of the last line of formula (11):

(r12+r14+r23*+r34)


A real part determiner may be configured to determine a real part of a combination of at least one of the complex covariance matrix values and at least one component of the precoding matrix candidates to obtain one or more real covariance values. In the last line of formula (11), the above complex covariance matrix value is combined with a component of each precoding vector candidate, and a real covariance value for each precoding vector candidate is determined, see, again, the last line of formula (11):

custom character{(r12+r14+r23*+r34i)}


Moreover, a precoding matrix determiner may be configured to determine the target precoding vector based on the one or more real covariance values.


In the following, an example for determining a target precoding vector in the four antenna ports case is presented.


Assume for simplicity M=1, so R=HHH. A possible realization of H and R may be






H
=


(





-
0.9545

+

0.5140





j





0.5054
+

0.6282





j





0.9963
-

2.0819





j





0.5072
+

0.9689





j







2.1460
-

0.2146





j






-
0.1449

-

0.8111





j





1.0021
+

1.0171





j





1.1528
-

1.2102





j







0.5129
+

0.2078





j






-
0.0878

-

0.7558





j





0.4748
+

0.2299





j





0.3457
-

0.0723





j








-
0.0446

-

0.5567





j





1.0534
-

0.5724





j






-
0.8538

-

0.5338





j





0.7316
-

0.1707





j





)






and







R
=

(



6.4449




-
0.2269

-

2.3886





j





0.5378
+

3.4406





j





2.9721
-

3.2294





j








-
0.2269

+

2.3886





j




3.3451




-
2.5838

-

1.7250





j





2.5723
+

1.7881





j







0.5378
-

3.4406





j






-
2.5838

+

1.7250





j




8.6581




-
1.9737

+

0.0586





j







2.9721
+

3.2294





j





2.5723
-

1.7881





j






-
1.9737

-

0.0586





j




4.6787



)






respectively. The classic approach is to analyze all possible precoding vectors pi, iε{1, . . . , 16}, and report the index i with maximal squared Euclidean norm ∥Hpi2. The squared Euclidean norm for precoding vector p1 given the channel matrix H has been calculated as










H



(



0.5




0.5




0.5




0.5



)




p
1






2

=





(




0.5272
+

0.0146





j







2.0780
-

0.6094





j







0.6228
-

0.1952





j







0.4433
-

0.9168





j





)



2

=
6.4306






and is summarized upon the other squared Euclidean norms for precoding vectors pi, iε{1, . . . , 16} in Table 15. The precoding vector which maximizes the energy given the matrix H is p6. The same result using the algorithm described in Tables 8-11 is obtained, which restricts on the set of coefficients {r12, r13, r14, r23, r24, r34} of matrix R. The algorithms in Table 8 and Table 9 are very similar, so only the first one will be discussed in detail. As

r′A=r12+r23*+r14+r34=−1.8123−3.8344j  (line 1),
So it can be seen that
|custom character{r′A}|<|ℑ{r′A}|
and
ℑ{r′A}<0,

so vi=j and A′ is set to A′=A3. For the next if clause (line 10 of Table 8), set

r″A=r12−r14+r23*−r34=−3.8091+2.5072j  (line 2)

and obtain custom character{r″A}=−3.8091<0 (line 11 of Table 8), so A″=A6. As already mentioned, the first four and last two cases in Table 4 have different signs, so they have to be evaluated separately

custom character{(r12+r23*)custom character2|A′+(r14+r34*)custom character4|A′+2r24custom character2*|A′custom character4|A′}=3.2033
>custom character{(r12+r23*)custom character2|A″+(r14+r34*)custom character4|A″+2r24custom character2*|A″custom character4|A″}=0.6184
so A=A′=A3 and
ΩA=custom character{(r12+r23*)custom character2|A+(r14+r34)custom character4|A+2r24custom character2*|Acustom character4|A+0.5r13}=3.4722 (line 16)  (19)
with
custom character2|A=0.5j
custom character4|A=0.5j.


Due to similarity of algorithm in Table 8 and Table 9, only the result ΩB=4.6686 is given. The algorithm in Table 10 and Table 11 are very similar, so only the first one will be discussed in detail. As

r′C=r12−r14+r23*+r34=−7.7566+2.6244j  (line 1)
custom character{r′C}=−7.7566 and
r″C=r12+r14+r23*+r34=3.3553−7.2845j  (line 2)
ℑ{r″C}=−7.2845 so
custom character{r′C}−ℑ{r″C}=−7.7566+7.2845=−0.4721<0 (line 4). Hence we conclude C=C2. For

ΩC=custom character{(r12−r23*j)custom character2|C+(r14−r34j)custom character4|C+2r24custom character2*|Ccustom character4|C+0.5r13j}=−2.4474  (20)

(line 5) holds with








p
2



|
C


=


-

1

2


2




-


1

2


2




j










p
4



|
C


=


1

2


2



-


1

2


2




j






Due to similarity of the algorithm in Table 10 and Table 11, only the result ΩD=7.9322 is given. The set Ψψ=(ΩA, ΩB, ΩC, ΩD)=(3.4722, 4.6686, −2.4474, 7.9322) has the maximal values for p3={±0.5, ±0, 5j}. The maximal value is at fourth position and D=D1 holds, so we obtain the precoding vector from Table 7 with







p
1

=
0.5







p
2

=


-

1

2


2




+


1

2


2




j









p
3

=


-
0.5






j








p
4

=


1

2


2



+


1

2


2




j







and hence, the index of precoding vector p6 is reported.









TABLE 8





algorithm for p3 = 0.5




















rA′ ← r12 + r14 + r23* + r34
(1)




rA″ ← r12 − r14 + r23* − r34
(2)




νi = estimate_PMI(rA′)
(3)




switch (νi)
(4)












case 1: A′ ← A1
(5)




case −1: A′ ← A2
(6)




case j: A′ ← A3
(7)




case −j: A′ ← A4
(8)












end
(9)




 if ( custom character  {rA″} > 0) then A″ ← A5
 (10)




 else A″ ← A6
 (11)




 endif
 (12)











custom character  {(r12 + r23*) p2|A″ +












(r14 + r34) p4|A″ +





2 r24 p2|A″* p4|A″}
 (13)














A ← A′
 (14)




else
A ← A″
 (15)











ΩA = custom character  {(r12 + r23*) p2|A +












(r14 + r34) p4|A +





2 r24 p2|A* p4|A +





0.5 r13}
 (16)

















TABLE 9





algorithm for p3 = −0.5



















rB′ ← r12 − r14 − r23* + r34




rB″ ← r12 + r14 − r23* − r34




νi = estimate_PMI(rB′)




switch (νi)




case 1: B′ ← B3




case −1: B′ ← B4




case j: B′ ← B1




case −j: B′ ← B2




end




 if { custom character  {rB″} > 0) then B″ ← B5




 else B″ ← B6




 endif




custom character  {(r12 − r23*) p2|B″ +











(r14 − r34) p4|B″ +




2 r24 p2|B″* p24|B″}











B ← B′












 else
B ← B″











ΩB = custom character  {(r12 − r23*) p2|B +











(r14 − r34) p4|B +




2 r24 p2|B* p4|B




0.5 r13}

















TABLE 10





algorithm for p3 = 0.5 j




















rC′ ← r12 − r14 + r23* + r34
(1)




rC″ ← r12 + r14 − r23* + r34
(2)




if ( custom character  [rC′} − ℑ{rC″}) > 0
(3)




then C ← C1





else C ← C2
(4)




endif





ΩC = custom character  {(r12 − r23* j) p2|C +





  (r14 − r34 j) p4|C +





  2 r24 p2|C* p4|C +





  0.5 r13 j}
(5)

















TABLE 11





algorithm for p3 = −0.5 j



















rD′ ← −r12 + r14 − r23* − r34




rD″ ← r12 + r14 − r23* + r34




if ( custom character  {rD′} − ℑ{rD″}) > 0




then D ← D1




else D ← D2




endif




ΩD = custom character  {(r12 + r23* j) p2|D +




  (r14 + r34 j) p4|D +




  2 r24 p2|D* p4|D




  0.5 r13 j}










In the following, a complexity analysis is provided. In the same way as presented above, the complexity of the classic and improved approach will be analyzed, assuming NR=4. The complexities of the operations can be found in Table 2.


First the matrix vector product is calculated:












Hp
i

=




(




h
11




h
12




h
13




h
14






h
21




h
22




h
23




h
24






h
31




h
32




h
33




h
34






h
41




h
42




h
43




h
44




)



(




p
1






p
2






p
3






p
4




)








=



(






h
11



p
1


+


h
12



p
2


+


h
13



p
3


+


h
14



p
4










h
21



p
1


+


h
22



p
2


+


h
23



p
3


+


h
24



p
4










h
31



p
1


+


h
32



p
2


+


h
33



p
3


+


h
34



p
4










h
41



p
1


+


h
42



p
2


+


h
43



p
3


+


h
44



p
4






)







=



(




g
1






g
2






g
3






g
4




)







=


g










𝒪


(

Hp
i

)



=


4


(


4
·
MUL

+

3
·
ADD


)


=

28
·

𝒪


(
1
)









and








g


2

=



g
H


g

=




(


g
1
*

,

g
2
*

,

g
3
*

,

g
4
*


)



(




g
1






g
2






g
3






g
4




)








𝒪


(



g


2

)



=



4
·
MUL

+

3
·
ADD

+

4
·
CONJ


=

11
·

𝒪


(
1
)











resulting in 39custom character(1) operations for a single precoding vector. Due to 16 different precoding vectors pi, iε{1, . . . , 16}, the operations have to be repeated 16 times, yielding 16·39·custom character(1)=624·custom character(1) operations. Finally the index corresponding to the precoding vector maximizing the energy has to be searched and reported. Assuming the worst case for the search procedure custom character(n) can be rated 15·custom character(1) comparisons. In total the classic approach needs 639·custom character(1) operations.


Regarding the complexity reduced approach, at first, precompute

r12=h11*h12+h21*h22+h31*h32+h41*h42
r13=h11*h13+h21*h23+h31*h33+h41*h43
r14=h11*h14+h21*h24+h31*h34+h41*h44
r23=h12*h13+h22*h23+h32*h33+h42*h43
r24=h12*h14+h22*h24+h32*h34+h42*h44
r34=h13*h14+h23*h24+h33*h34+h43*h44
custom charactercustom character(rij)=4·MUL+3·ADD+4·CONJ=11·custom character(1

what results in 6·11·custom character(1)=66·custom character(1) operations. The complexities of the algorithms in Tables 8/9 and Tables 10/11 are shown in Table 12 and 13 respectively. The algorithms in Tables 8 and 9 are identical regarding complexity. Furthermore the algorithms in Tables 10 and 11 are identical as well, regarding complexity. The values obtained in line 16 and line 5 in the algorithm in Table 8, 9 and 10, 11 respectively will be evaluated later in (18). In the worst case, 3 comparisons have to be made, resulting in 3·custom character(1) to determine the maximal index of four values. Summing up the single complexities of all subroutines yields 217·custom character(1) computations and is much better than the classic approach.









TABLE 12







complexities for algorithms in Tables 8 and 9













line
operation(s)
complexity








 (1)
3 · ADD, CONJ
4 · custom character  (1)




 (2)
3 · ADD, CONJ
4 · custom character  (1)




 (3)
estimate_PMI(r12)
7 · custom character  (1)




 (4)
SWITCH
1 · custom character  (1)




 (5)
CASE
1 · custom character  (1)




 (6)
CASE
1 · custom character  (1)




 (7)
CASE
1 · custom character  (1)




 (8)
CASE
1 · custom character  (1)




 (9)






(10)

custom character  {·}, COMP

2 · custom character  (1)




(11)






(12)






(13)
6 · ADD, 4 · MUL, 2 · CONJ






COMP, 2 · custom character  {·}
15 · custom character  (1) 




(14)






(15)






(16)
2·ADD, 4·MUL, CONJ, custom character  {·}
8 · custom character  (1)












Σ
45 · custom character  (1) 

















TABLE 13







complexities for algorithms in Tables 10 and 11











line
operation(s)
complexity






(1)
3 · ADD, CONJ
4 · custom character  (1)



(2)
3 · ADD, CONJ
4 · custom character  (1)



(3)
custom character  {·}, ℑ{·}, ADD, COMP
4 · custom character  (1)



(4)





(5)
5 · ADD, 9 · MUL, 2 ·
17 · custom character  (1) 




CONJ, custom character  {·}











Σ
29 · custom character  (1) 
















TABLE 14







sub-complexities for complexity reduced algorithm










subroutine
complexity






precomputation
66 · custom character  (1)



algorithm in Table 8
45 · custom character  (1)



algorithm in Table 9
45 · custom character  (1)



algorithm in Table 10
29 · custom character  (1)



algorithm in Table 11
29 · custom character  (1)



search procedure
 3 · custom character  (1)



Σ
217 · custom character  (1) 
















TABLE 15





Squared Euclidean norm of channel matrix multiplied with precoding vectors

















i
















1
2
3
4
5
6
7
8





∥Hpi2
6.4306
4.6395
8.2429
3.8138
3.0005
13.7139
3.3343
3.0782












i
















9
10
11
12
13
14
15
16





∥Hpi2
2.9322
9.2539
5.5212
5.4195
2.8599
10.4503
6.6690
3.1476









Above, the complexity of determining the precoding vector which maximizes energy given channel matrix H in LTE systems operating in closed-loop has been analyzed. Squared Euclidean norm has been chosen as a proper criterion to determine the precoding vector pi with index i, given the channel matrix H, assuming transmission on one layer. First, the case of two antenna ports at eNodeB has been assumed. The classic approach performs an exhaustive search, iterating over all possible precoding vectors and reporting the index with corresponding precoding vector maximizing the squared Euclidean norm. In case of two or four transmit antenna ports at eNodeB, four or sixteen possible precoding vectors have to be analyzed. The mathematical procedure for both cases has been described in detail accompanied by examples. Exploiting the mathematical properties of the precoding vectors, it is possible to develop a complexity reduced algorithm for precoding vector selection. In case of two transmit antennas at eNodeB, this algorithm restricts on an analysis of one coefficient r12 and determines the index of the target precoding vector by maximizing the squared Euclidean norm as described above. It is no longer necessary to iterate through all possible precoding vector candidates, resulting in a reduction of operations and, thus, saving power at the UE. In case of four antenna ports at eNodeB, the procedure is split up into four sub-routines, which analyze six coefficients r12, r13, r14, r23, r24, r34 and determine the index of the target precoding vector by maximizing the squared Euclidean norm. The developed algorithm for transmission on two antenna ports can be used for transmission on four antenna ports as well. Finally the overall complexities of both approaches have been analyzed. In case of two antenna ports at eNodeB, corresponding to four precoding vectors, the classic approach and the complexity reduced approach have a complexity of 51·custom character(1) and 12·custom character(1), respectively. The complexity of the novel approach could be reduced for more than four times. In case of four antenna ports at eNodeB, corresponding to sixteen precoding vectors, the classic approach and the complexity reduced approach have a complexity of 639·custom character(1) and 217·custom character(1)·, respectively. The complexity of the novel approach could be reduced for approximately three times. Hence, the overall complexity in both cases could be significantly outperformed, leading to reduced power consumption at the UE.


A low complexity PMI selection in LTE Systems with two transmit antenna ports at eNodeB has been provided. Moreover, a low complexity PMI selection in LTE Systems with four transmit antenna ports at eNodeB has been provided.


Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding block or item or feature of a corresponding apparatus.


The inventive decomposed signal can be stored on a digital storage medium or can be transmitted on a transmission medium such as a wireless transmission medium or a wired transmission medium such as the Internet.


Depending on certain implementation requirements, embodiments of the invention can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a CD, a ROM, a PROM, an EPROM, an EEPROM or a FLASH memory, having electronically readable control signals stored thereon, which cooperate (or are capable of cooperating) with a programmable computer system such that the respective method is performed.


Some embodiments according to the invention comprise a non-transitory data carrier having electronically readable control signals, which are capable of cooperating with a programmable computer system, such that one of the methods described herein is performed.


Generally, embodiments of the present invention can be implemented as a computer program product with a program code, the program code being operative for performing one of the methods when the computer program product runs on a computer. The program code may for example be stored on a machine readable carrier.


Other embodiments comprise the computer program for performing one of the methods described herein, stored on a machine readable carrier.


In other words, an embodiment of the inventive method is, therefore, a computer program having a program code for performing one of the methods described herein, when the computer program runs on a computer.


A further embodiment of the inventive methods is, therefore, a data carrier (or a digital storage medium, or a computer-readable medium) comprising, recorded thereon, the computer program for performing one of the methods described herein.


A further embodiment of the inventive method is, therefore, a data stream or a sequence of signals representing the computer program for performing one of the methods described herein. The data stream or the sequence of signals may for example be configured to be transferred via a data communication connection, for example via the Internet.


A further embodiment comprises a processor, for example a computer, or a programmable logic device, configured to or adapted to perform one of the methods described herein.


A further embodiment comprises a computer having installed thereon the computer program for performing one of the methods described herein.


In some embodiments, a programmable logic device (for example a field programmable gate array) may be used to perform some or all of the functionalities of the methods described herein. In some embodiments, a field programmable gate array may cooperate with a microprocessor in order to perform one of the methods described herein. Generally, the methods are advantageously performed by any hardware apparatus.


While this invention has been described in terms of several embodiments, there are alterations, permutations, and equivalents which fall within the scope of this invention. It should also be noted that there are many alternative ways of implementing the methods and compositions of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations and equivalents as fall within the true spirit and scope of the present invention.

Claims
  • 1. An apparatus for determining a target precoding matrix from a plurality of precoding matrix candidates, the precoding matrix candidates being adapted to be applied on a data stream, wherein the data stream is to be transmitted by a transmitter, and wherein the apparatus comprises: a covariance matrix value provider for providing one or more complex covariance matrix values, wherein the one or more complex covariance matrix values are complex numbers, wherein each one of the one or more complex covariance matrix values is an off-diagonal coefficient of a multiple input multiple output channel covariance matrix or a combination of two or more off-diagonal coefficients of the multiple input multiple output channel covariance matrix,a real part determiner being configured to determine a real part of at least one of the one or more complex covariance matrix values or to determine a real part of a combination of at least one of the one or more complex covariance matrix values and at least one component of the precoding matrix candidates to obtain one or more real covariance values, wherein the one or more real covariance values are real numbers, anda precoding matrix determiner for determining the target precoding matrix from the plurality of precoding matrix candidates, wherein the precoding matrix determiner is configured to determine the target precoding matrix based on at least one of the one or more real covariance values.
  • 2. An apparatus according to claim 1, wherein the apparatus is configured to determine a target precoding vector as the target precoding matrix from a plurality of precoding vector candidates,wherein the plurality of precoding vector candidates is the plurality of precoding matrix candidates,wherein each one of the precoding vector candidates is a matrix having one or more rows and exactly one column or a matrix having exactly one row and one or more columns, andwherein the precoding matrix determiner is adapted to determine the target precoding vector as the target precoding matrix from the plurality of precoding vector candidates.
  • 3. An apparatus according to claim 1, wherein, the precoding matrix determiner is adapted to determine the target precoding matrix from the plurality of precoding matrix candidates by comparing a first absolute value of one of the one or more real covariance values and a second absolute value of an imaginary number of one of the one or more complex covariance matrix values.
  • 4. An apparatus according to claim 1, wherein the channel covariance matrix is a Multi Input Multi Output channel covariance matrix having at least two rows and at least two columns, andwherein the covariance matrix value provider is adapted to provide the one or more complex covariance matrix values such that each one of the one or more complex covariance matrix values is an off-diagonal coefficient of the Multi Input Multi Output channel covariance matrix or a combination of two or more off-diagonal coefficients of the Multi Input Multi Output channel covariance matrix.
  • 5. An apparatus according to claim 1, wherein the covariance matrix value provider is configured to provide the one or more complex covariance matrix values without determining any main-diagonal coefficient of the channel covariance matrix.
  • 6. An apparatus according to claim 2, wherein the covariance matrix value provider is configured to provide one or more off-diagonal coefficients of the channel covariance matrix,wherein each one of the one or more off-diagonal coefficients of the channel covariance matrix is a coefficient of a product of a group of one or more matrix products or a sum of coefficients of products of the group of one or more matrix products,wherein each product of the group of one or more matrix products is a product of a channel matrix and a conjugate transpose matrix of said channel matrix, wherein each coefficient of said channel matrix indicates a channel between a transmit antenna of the transmitter and a receive antenna of a receiver.
  • 7. An apparatus according to claim 2, wherein the channel covariance matrix is defined by the formula:
  • 8. An apparatus according to claim 2, wherein the channel covariance matrix has exactly two rows and exactly two columns, wherein the channel covariance matrix is defined by the formula:
  • 9. An apparatus according to claim 8, wherein the covariance matrix value provider is configured to provide the coefficient r12 or the coefficient r21 as the exactly one off-diagonal coefficient of the channel covariance matrix,wherein the first off-diagonal covariance coefficient r12 is defined by h*11h12+h*21h22 wherein the second off-diagonal covariance coefficient r21 is defined by h11h*12+h21h*22 wherein the real part determiner is adapted to determine a real part of the first off-diagonal covariance coefficient r12 or a real part of the second off-diagonal covariance coefficient r21.
  • 10. An apparatus according to claim 8, wherein the precoding matrix determiner is furthermore configured to determine an imaginary part of the first off-diagonal covariance coefficient r12 or of the second off-diagonal covariance coefficient r21, to obtain an imaginary covariance value, andwherein the precoding matrix determiner is configured to determine the target precoding vector based on one of the one or more real covariance values and the imaginary covariance value.
  • 11. An apparatus according to claim 10, wherein the precoding matrix determiner is configured to determine the target precoding vector by determining a first absolute value of said one of the one or more real covariance values, by determining a second absolute value of the imaginary covariance value and by comparing the first and the second absolute value.
  • 12. An apparatus according to claim 2, wherein the apparatus is adapted to determine the target precoding vector from the plurality of precoding vector candidates, the plurality of precoding vector candidates comprising a first precoding vector p1, a second precoding vector p2, a third precoding vector p3 and a fourth precoding vector p4,wherein the first precoding vector p1, the second precoding vector p2, the third precoding vector p3 and the fourth precoding vector p4 are defined by
  • 13. An apparatus according to claim 2, wherein the covariance matrix value provider is configured to determine more than one off-diagonal coefficient of the channel covariance matrix, wherein the channel covariance matrix has exactly four rows and exactly four columns, wherein the channel covariance matrix is defined by the formula:
  • 14. An apparatus according to claim 2, wherein the covariance matrix value provider is configured to determine at least three off-diagonal coefficients of the channel covariance matrix as at least three determined coefficients and at least one conjugate value of a further off-diagonal coefficient of the channel covariance matrix as at least one determined conjugate value, andwherein the covariance matrix value provider is configured to provide the one or more complex covariance matrix values such that each of the one or more complex covariance matrix values is a combination of at least two values of the at least three determined coefficients and the at least one determined conjugate value.
  • 15. An apparatus according to claim 13, wherein the covariance matrix value provider is configured to determine the off-diagonal coefficients r12, r14 and r34 of the channel covariance matrix,wherein the covariance matrix value provider is configured to determine a conjugate value r*23 of the off-diagonal coefficient r23 of the channel covariance matrix, andwherein the covariance matrix value provider is configured to provide the sum r12+r14+r*23+r34 to determine the target precoding vector.
  • 16. An apparatus according to claim 13, wherein the apparatus is configured to determine the target precoding vector from the at least 16 precoding vector candidates,wherein the covariance matrix value provider is configured to form at least two precoding vector groups, and wherein the covariance matrix value provider is configured to assign each of the 16 precoding vector candidates to exactly one of the precoding vector groups,wherein the precoding matrix determiner is configured to determine a target group vector for each of the precoding vector groups, andwherein the precoding matrix determiner is configured to determine one of the target group vectors as the target precoding vector.
  • 17. A mobile communication device comprising: a baseband processor;an apparatus for determining a target precoding matrix from a plurality of precoding matrix candidates, the precoding matrix candidates being adapted to be applied on a data stream, wherein the data stream is to be transmitted by a transmitter, and wherein the apparatus for determining the target precoding matrix comprises:a covariance matrix value provider for providing one or more complex covariance matrix values, wherein the one or more complex covariance matrix values are complex numbers, wherein each one of the one or more complex covariance matrix values is an off-diagonal coefficient of a multiple input multiple output channel covariance matrix or a combination of two or more off-diagonal coefficients of the multiple input multiple output channel covariance matrix,a real part determiner being configured to determine a real part of at least one of the one or more complex covariance matrix values or to determine a real part of a combination of at least one of the one or more complex covariance matrix values and at least one component of the precoding matrix candidates to obtain one or more real covariance values, wherein the one or more real covariance values are real numbers, anda precoding matrix determiner for determining the target precoding matrix from the plurality of precoding matrix candidates, wherein the precoding matrix determiner is configured to determine the target precoding matrix based on at least one of the one or more real covariance values.
  • 18. A mobile communication device according to claim 17, wherein the apparatus is configured to determine a target precoding vector as the target precoding matrix from a plurality of precoding vector candidates,wherein the plurality of precoding vector candidates is the plurality of precoding matrix candidates,wherein each one of the precoding vector candidates is a matrix having one or more rows and exactly one column or a matrix having exactly one row and one or more columns, andwherein the precoding matrix determiner is adapted to determine the target precoding vector as the target precoding matrix from the plurality of precoding vector candidates.
  • 19. A method for determining a target precoding matrix from a plurality of precoding matrix candidates, the precoding matrix candidates being adapted to be applied on a data stream, wherein the data stream is to be transmitted by a transmitter, and wherein the method comprises: providing one or more complex covariance matrix values to a programmable computer system, wherein the one or more complex covariance matrix values are complex numbers, wherein each one of the one or more complex covariance matrix values is an off-diagonal coefficient of a multiple input multiple output channel covariance matrix or a combination of two or more off-diagonal coefficients of the multiple input multiple output channel covariance matrix,determining, using the programmable computer system, a real part of at least one of the one or more complex covariance matrix values or determining a real part of a combination of at least one of the one or more complex covariance matrix values and at least one component of the precoding matrix candidates to obtain one or more real covariance values, wherein the one or more real covariance values are real numbers, anddetermining, using the programmable computer system, the target precoding matrix from the plurality of precoding matrix candidates by comparing one of the one or more real covariance values and at least one other value.
US Referenced Citations (8)
Number Name Date Kind
8396438 Akkarakaran et al. Mar 2013 B2
20110002414 Coldrey et al. Jan 2011 A1
20110085627 Kangas et al. Apr 2011 A1
20120021688 Bhattad et al. Jan 2012 A1
20120052875 Kangas et al. Mar 2012 A1
20120113897 Thiele et al. May 2012 A1
20130002475 Keranen et al. Jan 2013 A1
20130301756 Badic et al. Nov 2013 A1
Non-Patent Literature Citations (16)
Entry
U.S. Appl. No. 13/468,133, filed May 10, 2012 with USPTO.
3GPP. Evolved universal terrestrial radio access (e-utra); physical channels and modulation. Technical Specification 3GPP 36.211 Release-8, 3rd Generation Partnership Project, Sophia Antipolis, Dec. 2009.
3GPP. Evolved universal terrestrial radio access (e-utra); physical layer general description. Technical Specification 3GPP 36.201 Release-8, 3rd Generation Partnership Project, Sophia Antipolis, Dec. 2009.
3GPP. Evolved universal terrestrial radio access (e-utra); physical layer procedures. Technical Specification 3GPP 36.213 Release-8, 3rd Generation Partnership Project, Sophia Antipolis, Dec. 2009.
3GPP. Evolved universal terrestrial radio access (e-utra); physical channels and mod-ulation. Technical Specification 3GPP 36.211 Release-9, 3rd Generation Partnership Project, Sophia Antipolis, Mar. 2010.
3GPP. Evolved universal terrestrial radio access (e-utra); physical channels and modulation. Technical Specification 3GPP 36.211 Release-10, 3rd Generation Partnership Project, Sophia Antipolis, Dec. 2010.
3GPP. Evolved universal terrestrial radio access (e-utra); physical layer procedures. Technical Specification 3GPP 36.213 Release-9, 3rd Generation Partnership Project, Sophia Antipolis, Mar. 2010.
3GPP. Evolved universal terrestrial radio access (e-utra); physical layer procedures. Technical Specification 3GPP 36.213 Release-10, 3rd Generation Partnership Project, Sophia Antipolis, Dec. 2010.
J. Duplicy, B. Badic, R. Balraj, P. Horvath, F. Kaltenberger, R. Knopp, I. Kovacs, H. Nguyen, D. Tandur and G. Vivier, “MU-MIMO in LTE Systems,” EURASIP Journal on Wireless Communications and Networking, vol. 2011, pp. 1-13, Nov. 2010.
Bai et al., “Receiver Performance in MU-MIMO Transmission in LTE”, ICWMC'11, Luxembourg, Jun. 2011.
E. Larsson, “Robust structured interference rejection combining” in Proceedings of IEEE Wireless Communications and Networking Conference 2005, vol. 2, New Orleans, LA USA, Mar. 2005, pp. 922-926.
O. Renaudin, V.-M. Kolmonent, P. Vainikainent, and C. Oestges, “Impact of correlation matrix estimation accuracy on the computation of stationarity intervals”, EuCAP'10 (Barcelona, Spain), Apr. 2010.
Final Office Action dated Feb. 24, 2014 U.S. Appl. No. 13/468,133.
Karlsson, et al. “Interference Rejection Combining for GSM.” IEEE published in 1996. 5 Pages.
Cassio, et al. “Performance of Linear Multi-User MIMO Precoding in LTE System” IEEE published in 2008. 5 Pages.
Non-Final Office Action dated Nov. 4, 2013 for U.S. Appl. No. 13/468,133. 16 Pages.
Related Publications (1)
Number Date Country
20130301751 A1 Nov 2013 US