Embodiments described herein relate to methods and systems for transmitting information across a MIMO channel from a transmitter to a receiver.
MIMO (Multiple Input Multiple Output) precoding is an efficient method for increasing system capacity in radio communication systems that comprise an array of transmitting antennas and/or receiving antennas. MIMO precoding requires that knowledge of the channel quality between the transmitter and the receiver is available at the transmitter. In a time-division duplex (TDD) system, knowledge of the channel quality can be acquired through measurements of the reciprocal channel; in a frequency-division duplex (FDD) system, feedback from the receiver may be used. The precoding technique can be used for both single-user MIMO systems in which there is only one receiver, and multiuser MIMO systems in which there are multiple receiver antennas that share the available frequency-time resources by being spatially multiplexed.
When implementing a MIMO communications link, it is possible to impose the restriction that all transmitting antennas have the same power. Doing so is advantageous since it can help to improve the performance of power amplifiers, for example. However, applying this constraint carries a drawback that numerical methods may then be required in order to determine the precoding for each transmitting antenna. Such numerical methods can increase the computational burden on the transmitter, this being particularly true in OFDM systems where a precoder must be computed for each individual subcarrier.
One solution for reducing the computational complexity is to group neighbouring subcarriers together and compute a single precoder for them. However, such an approach can lead to interuser interference and resultant performance degradation, since the precoder will not be ideally matched to each individual subcarrier.
Embodiments will now be described by way of example with reference to the accompanying drawings in which:
According to a first embodiment, there is provided a method of transmitting information across a MIMO channel from a transmitter to a receiver, the transmitter comprising an array of antennas and the information comprising a plurality of data streams, the method comprising precoding the information prior to its transmission;
The data streams may be mapped across the array of antennas in such a way as to minimise interference between the data streams at the receiver.
In some embodiments, determining the mapping comprises determining a channel state matrix for each subcarrier frequency based on the channel state information.
In some embodiments, the method further comprises determining a pseudo-inverse matrix of the channel state matrix for each subcarrier frequency.
In some embodiments, the measure of throughput is the sum-rate of data transmission across all data streams or the largest possible minimum data rate for an individual data stream.
According to a second embodiment, there is provided a transmitter for establishing a MIMO channel for communicating information comprising a plurality of data streams to a receiver, the transmitter comprising:
The precoder may be configured to map the data streams across the array of antennas in such a way as to minimise interference between the data streams at the receiver.
The precoder may be configured to determine the mapping by determining a channel state matrix for each subcarrier frequency based on the channel state information.
The precoder may be configured to determine a pseudo-inverse matrix of the channel state matrix for each subcarrier frequency.
In some embodiments, the measure of throughput is the sum-rate of data transmission across all data streams or the largest possible minimum data rate for an individual data stream.
According to a third embodiment, there is provided a non-transient computer readable storage medium comprising computer executable instructions that when executed by a computer will cause the computer to carry out a method according to the first embodiment.
It will be understood that the receiver itself may comprise an array of antennas. The plurality of data streams may be associated with different, respective users, or a single user; that is, a single user may receive multiple data streams at the receiver, or alternatively, there may be multiple users, each receiving one or more data streams at the receiver. The number of receive antennas per user will be at least as many as the number of data streams that the user is receiving.
An issue encountered with the above described method is that the power levels assigned to the different transmitting antennas may vary significantly, which is undesirable since such power fluctuations may cause problems with power amplifiers, for example. Conventionally, this problem has been addressed by using a ZF sum-rate precoder with per-antenna power control. This can be explained by considering a system that comprises N transmit antennas, K data streams (belonging to one or more users) and S subcarriers. Given the channel state matrix H∈, the pseudoinverse G=HH(HHH)−1∈ is first computed. The objective then is, for each subcarrier i−1, . . . S, to maximise the sum rate (across all data streams), with the constraint that the power in each transmit antenna n and subcarrier i is limited to P. The objective can be expressed as the following optimisation problem:
where pk(i) is the power on the kth stream and the ith subcarrier and G(i)n,k is the pseudoinverse (H(i)G(i)=IK) on the ith subcarrier, indicating how the kth data stream is mapped to the nth transmit antenna. By deriving the pseudoinverse matrix for each subcarrier frequency, it is possible to determine a respective group of antennas to use in transmitting each data stream and to determine, for each one of the antennas in the respective group, which subcarrier frequencies are to be used for transmitting symbols in the data stream.
The optimisation can be written as S separate problems, which can be solved independently. If xk(i) is the kth data symbol on the ith subcarrier, the transmitted signal on the nth antenna and ith subcarrier will be:
This ensures that a (nonnegative) power pk is assigned to each stream k such that the transmit power per antenna is not larger than a prescribed level P. The method must be performed separately for all subcarriers, as illustrated in
If N>K (i.e. there are more transmit antennas than data streams), the extra degree of freedom can be exploited to further enhance the performance. In this case, the pseudoinverse is not unique and can be written as G=H++VC, where H+=HH(HHH)−1∈ and V∈ is the nullspace of H, i.e., HV=0, and C∈ is an arbitrary matrix; this ensures that HG=I.
In contrast to the conventional method discussed above, in embodiments described herein, the pseudoinverses are computed separately for each subcarrier but a joint power loading is applied to all S subcarriers in a group of subcarriers; this is shown pictorially in
In more detail, the power loading for the data stream k is assumed to be the same for all subcarriers in the group i.e. pk(i)=pk. The sum-rate (across all streams and carriers) is maximised with the constraint that the power in each transmit antenna is limited to P. This optimisation can be expressed as:
Thus, the optimisation is a joint optimisation for all S subcarriers. The transmitted signal on the nth antenna and ith subcarrier will be:
Since each subcarrier in the group uses its own pseudoinverse, interuser interference can be reduced or eliminated. In turn, use of the joint power loading means that the optimisation problem becomes much simpler since there are fewer variables to optimise over. It will be understood that the same principle (individual linear filters and joint power loading) can be applied to other scenarios as well, e.g., when maximising the minimum data rate over the streams.
In what follows, the performance of an embodiment will be illustrated by considering an OFDM system with 64 subcarriers, N=4 transmit antennas and K=4 data streams. Since it is difficult to estimate the complexity of numerical optimisation, the complexity will be modeled based on the average execution time of the software package MATLAB's™ function fmincon; this is an efficient implementation which reflects the computational complexity of finding the optimal precoder. By varying the group size, it is possible to plot the sum-rate as a function of computational complexity.
Whilst the above described embodiments have each made use of a pseudoinverse matrix for determining the mapping of data streams to each antenna, it will be appreciated that regularised versions of the pseudoinverse (such as a minimum mean square error MMSE solution, for example) may also be used. In such a case, the interference between data streams may still be reduced (without being entirely eliminated), with a further reduction in the overall complexity of precoding.
Thus, embodiments described herein can provide a balance between performance and complexity.
The reader will appreciate that the actual implementation of the wireless communication device is non-specific, in that it could be a base station or a user terminal. Depending on the particular implementation, the multiple data streams may be associated with different respective users and/or may be associated with different applications hosted by the device.
The device 500 comprises a processor 501 operable to execute machine code instructions stored in a working memory 502 and/or retrievable from a mass storage unit 503. By means of a general purpose bus 504, user operable input units 505 are capable of communication with the processor 501. The user operable input units 505 comprise, in this example, a keyboard and a mouse though it will be appreciated that any other input devices could also or alternatively be provided, such as another type of pointing device, a writing tablet, speech recognition means, or any other means by which a user input action can be interpreted and converted into data signals. User output unit(s) 506 are also connected to the general purpose bus 501, for the output of information to a user. The output unit(s) may take the form of audio/video output hardware devices including a visual display unit, a speaker or any other device capable of presenting information to a user.
Antennas 508 form a MIMO array for wireless transmission of data from the device. A communications unit 507 is connected to the general purpose bus 501 and to antennas 508. Communications unit comprises a precoder for precoding information to be transmitted using the MIMO array.
In the illustrated embodiment in
Also stored in the working memory 502 is communications controller software 510, for establishing a communications protocol to enable data generated in the execution of one of the applications 509 to be processed and then passed to the communications unit for transmission. It will be understood that the software defining the applications 509 and the communications controller software 510 may be partly stored in the working memory 502 and the mass storage unit 503, for convenience. A memory manager could optionally be provided to enable this to be managed effectively, to take account of the possible different speeds of access to data stored in the working memory 502 and the mass storage unit 503.
In operation, the communications unit 507 receives, via the antennas 508, channel state information from the other device(s) that form the MIMO communication link (in some alternative embodiments, the channel state information may be obtained based on reverse-link estimation at the transmitter). The channel state information indicates the quality of channels between respective antennas 508 of the transmitter and the antennas of the other device(s) for different subcarrier frequencies, taking into account the effects of e.g. scattering, fading and power decay between the transmitter and receiver. The channel quality may be expressed, for example, as a signal to noise SNR ratio or by any one of a number of metrics used in the art for this purpose. The channel state information may be updated at intervals. In accordance with embodiments previously described, the precoder is operable, on the basis of the channel state information, to determine a precoding to be used in transmitting the multiple data streams.
While certain embodiments have been described, these embodiments have been presented by way of example only and are not intended to limit the scope of the invention. Indeed, the novel methods, devices and systems described herein may be embodied in a variety of forms; furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit of the invention. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/GB2015/050305 | 2/4/2015 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2016/124876 | 8/11/2016 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
8442142 | Ojard et al. | May 2013 | B2 |
8649796 | Zirwas | Feb 2014 | B2 |
20090207829 | Peng | Aug 2009 | A1 |
20100202431 | Kazmi | Aug 2010 | A1 |
20100266054 | Mielczarek et al. | Oct 2010 | A1 |
20110131461 | Schulz | Jun 2011 | A1 |
Entry |
---|
International Preliminary Report on Patentability and Written Opinion issued by the International Bureau of WIPO dated Aug. 17, 2017, for International Appl. No. PCT/GB2015/050305. |
Zhao et al., “Optimizing Sum-Capacity Through Power Allocation for SLNR-precoding-based Cognitive Networks,” Asia Pacific Conference on Communications, IEEE (Oct. 2012), pp. 927-932. |
Boccardi et al., “Zero-Forcing Precoding for the MIMO Broadcast Channel Under Per-Antenna Power Constraints,” IEEE 7th Workshop on Signal Processing Advances in Wireless Communications (Jul. 2006), 5 pages. |
Tosato et al., “Codeword based power loading in MU-MIMO,” Workshop on Novel Waveform and MAC Design for 5G (Jun. 4, 2016), 6 pages. |
Number | Date | Country | |
---|---|---|---|
20170373742 A1 | Dec 2017 | US |