The present disclosure relates generally to digital communications, and more particularly to a system and method for large scale multiple input multiple output (MIMO) communications.
In general, multiple input multiple output (MIMO) increases the capacity of a radio link through the use of multiple transmit antennas and multiple receive antennas. MIMO exploits multipath propagation to increase the capacity of the radio link. MIMO has proven to be effective at increasing the capacity of the radio link and has been accepted into a variety of technical standards, including WiFi or Wireless LAN: IEEE 802.11n, and IEEE 802.11ac; Evolved High-Speed Packet Access (HSPA+); Worldwide Interoperability for Microwave Access (WiMAX); and Third Generation Partnership Project (3GPP) Long Term Evolution (LTE) Advanced.
Increasing the number of transmit antennas and receive antennas from a relatively small number (on the order of 10 or fewer) to a significantly larger number (on the order of 100, 1000, 10000, or more) can lead to even greater increases in the capacity of the radio link. However, dramatically increasing the number of transmit antennas and receive antennas also greatly increases the computational complexity involved in signal processing, as well as the amount of data exchanged between the antennas and a processing unit supporting MIMO communications. Therefore, there is a need for systems and methods for supporting large scale MIMO communications.
Example embodiments provide a system and method for large scale multiple input multiple output (MIMO) communications.
In accordance with an example embodiment, a large scale multiple input multiple output (MIMO) communications device adapted to receive transmissions is provided. The large scale MIMO communications device includes a first plurality of antenna units (AUs) arranged in an array, and a central processing unit operatively coupled to a first end AU in the first plurality of AUs. Each AU in the first plurality of AUs is operatively coupled to at least two neighboring AUs. Each AU receives wireless signals, receives neighbor information from at least a first neighboring AU, generates local information associated with the AU in accordance with the received wireless signals and the neighbor information, and sends the local information associated with the AU to a second neighboring AU. The central processing unit receives local information associated with the first end AU, and generates estimates of the received transmissions in accordance with the local information associated with the first end AU.
In accordance with another example embodiment, a large scale multiple input multiple output (MIMO) communications device adapted to send transmissions is provided. The large scale MIMO communications device includes a central processing unit, and a first plurality of antenna units (AU) arranged in an array. The first plurality of AUs is operatively coupled to the central processing unit, and each AU in the first plurality of AUs is operatively coupled to at least two neighboring AUs and includes an AU processing unit. Each AU receives local information associated with the AU from the central processing unit, and generates data in accordance with the local information associated with the AU.
In accordance with another example embodiment, a method for operating a large scale multiple input multiple output (MIMO) communications device is provided. The method includes measuring received energy levels in portions of a search space using antenna beams generated by independent antenna arrays partitioned from an antenna array, where each independent antenna array is assigned to at least one portion of the search space, and selecting received energy levels meeting a specified threshold. The method includes communicating using antenna beams generated by the antenna array, where the antenna beams are associated with the selected received energy levels.
In accordance with another example embodiment, a large scale multiple input multiple output (MIMO) communications device is provided. The large scale MIMO communications device includes an antenna array, a processor operatively coupled to the antenna array, and a computer readable storage medium storing programming for execution by the processor. The programming including instructions configuring the large scale MIMO communications device to measure received energy levels in portions of a search space using antenna beams generated by independent antenna arrays partitioned from the antenna array, where each independent antenna array is assigned to at least one portion of the search space, select received energy levels meeting a specified threshold, and communicate using antenna beams generated by the antenna array, where the antenna beams are associated with the selected received energy levels.
Practice of the foregoing embodiments enable large scale MIMO communications with reduced computational overhead at a processing unit supporting MIMO communications and data exchanged between the antennas and the processing unit.
Moreover, the embodiments provide for a system and method for fast acquisition of beams in a large scale MIMO communications system.
For a more complete understanding of the present disclosure, and the advantages thereof, reference is now made to the following descriptions taken in conjunction with the accompanying drawing, in which:
The operating of the current example embodiments and the structure thereof are discussed in detail below. It should be appreciated, however, that the present disclosure provides many applicable inventive concepts that can be embodied in a wide variety of specific contexts. The specific embodiments discussed are merely illustrative of specific structures of the embodiments and ways to operate the embodiments disclosed herein, and do not limit the scope of the disclosure.
One embodiment relates to large scale multiple input multiple output (MIMO) communications. For example, a large scale multiple input multiple output (MIMO) communications device includes a first plurality of antenna units (AUs) arranged in an array, and a central processing unit operatively coupled to a first end AU in the first plurality of AUs. Each AU in the first plurality of AUs is operatively coupled to at least two neighboring AUs, and wherein each AU receives wireless signals, receives neighbor information from at least a first neighboring AU, generates local information associated with the AU in accordance with the received wireless signals and the neighbor information, and sends the local information associated with the AU to a second neighboring AU. The central processing unit receives local information associated with the first end AU, and generates estimates of the received transmissions in accordance with the local information associated with the first end AU.
The embodiments will be described with respect to example embodiments in a specific context, namely MIMO communications systems that support very large numbers of transmit antennas and receive antennas. The embodiments may be applied to standards compliant FD communications systems, such as those that are compliant with Third Generation Partnership Project (3GPP), IEEE 802.11, WiMAX, HSPA, and the like, technical standards, and non-standards compliant MIMO communications systems, that support very large numbers of transmit antennas and receive antennas.
While it is understood that communications systems may employ multiple base stations capable of communicating with a number of users, only one base station, and a number of users are illustrated for simplicity.
In communications system 100, the K users share the same communications system resources (such as time-frequency resources). To simplify discussion, each user is equipped with only one antenna. However, the example embodiments presented herein are operable with users with any number of antennas. Each of the M receive antennas at MIMO base station 105 are equipped with its own radio frequency (RF) hardware (such as filters, amplifiers, mixers, modulators, demodulators, constellation mappers, constellation demappers, and the like), analog to digital (A/D) converters, digital to analog (D/A) converters, as well as a local processing unit that is capable of performing a limited amount of processing. The local processing unit, the antenna and the associated hardware may be referred to as an antenna unit (AU). The local processing unit is referred to herein as an AU processing unit.
Communications system 100 may be represented as a mathematical model expressible as:
where X is a transmitted symbol vector of length K in which each element xk represents a data symbol associated with user k; Y is a received sample vector of length M in which each element ym, represents a sample of receive antenna in; N is a receiver noise sample vector of length M in which each element nm represents the noise receive on receive antenna in, it is assumed that N is additive white Gaussian noise (AWGN); A is a channel matrix of size M by K in which each element am,k represents a channel transfer function between user k and receive antenna in; K is the number of users served by MIMO base station 105; and M is the number of receive antennas of MIMO base station 105. In general, a MIMO receiver has to resolve the above expression and given the received sample vector Y, find an estimate of the transmitted symbol vector X (denoted {circumflex over (X)}) that is as close as possible to the transmitted symbol vector X.
There is a plurality of techniques that a MIMO receiver, such as one implemented in a central processing unit located in a MIMO base station, can use to solve the above expression. A first MIMO decoder technique that may be used is referred to as a maximum likelihood (ML) decoder. A ML decoder searches for a solution that as minimum distance D between the received sample vector Y and the estimate of the transmitted symbol vector {circumflex over (X)}, which may be expressed mathematically as:
where R=AT·Y is a maximum ratio combining (MRC) vector of length K, Acor is an autocorrelation matrix with dimension K by K., and (.)T is a transpose operator.
A second MIMO decoder technique that may be used is referred to as an interference cancelling (IC) decoder. An IC decoder checks all possible combinations of the estimate of the transmitted symbol vector {circumflex over (X)} to find the solution. The IC decoder iteratively searches for a ML solution that has the minimum distance by taking a gradient of the distance, which is a highly computationally intensive process. The IC decoder may be expressed mathematically as:
where Acor is an autocorrelation matrix with dimension K by K.
A third MIMO decoder technique that may be used is referred to as a MRC decoder. A MRC decoder attempts to find the solution by minimizing a signal to additive noise ratio. The MRC decoder may be expressed mathematically as:
where Es is symbol energy and are diagonal elements of the autocorrelation matrix Acor.
A fourth MIMO decoder technique that may be used is referred to as a zero forcing (ZF) decoder. A ZF decoder attempts to find the solution by minimizing multi-user interference. The ZF decoder may be expressed mathematically as:
X
ZF
=inv(Acor)·R.
A fifth MIMO decoder technique that may be used is referred to as a minimum mean square error (MMSE) decoder. A MMSE decoder is a compromise between MRC and ZF decoders and attempts to find the solution by minimizing a common mean square error. The MMSE decoder may be expressed mathematically as:
It is noted that each of the five MIMO decoder techniques presented above have only two inputs:
R=A
T
·Y(where R is a MRC vector of length K),
and
Acor=AT·A (where Acor is an autocorrelation matrix with dimension K by K). The dimensions of both of the two inputs are dependent only on the number of users K and not on the number of receive antennas M. The number of users K places demands on the bit rate of the communications system, while the number of receive antennas M is representative of the number of receive antennas that can be associated with a base station (either actually located at the base station or controlled by the base station but remotely located). It is expected that both K and M will continue to grow, but M is expected to grow faster than K. In other words, M>>K. A summary of the five MIMO decoder techniques in equation form and their respective algorithm complexity is presented in tabular form.
Additionally, in the five MIMO decoder techniques presented above, a central processing unit located in the MIMO base station that is implementing one or more of the five MIMO decoder techniques does not need to know all inputs Y and channel estimates A of all of the M receive antennas. It is sufficient that the central processing unit has knowledge of the MRC vector R and the autocorrelation matrix Acor (with dimension K and K by K, respectively) to implement any and all of the five MIMO decoder techniques.
According to an example embodiment, each receive AU includes an AU processing unit which implement distributed computing to reduce computational load at the central processing unit, as well as the amount of data exchanged between the AUs and the central processing unit. Since the central processing unit that is implementing one or more of the five MIMO decoder techniques does not need to know all inputs Y and channel estimates A of all of the M receive antennas, it is possible to utilize AU processing units in the AUs to implement distributed (or cloud) computing. Results of the distributed computing performed at individual AUs are shared with other AUs, and eventually, the central processing unit where the results are used to estimate the received transmissions.
According to an example embodiment, a MRC vector R is represented as an accumulation of increments from the M receive antennas. The MRC vector R is expressible as
where Rm is the component of the MRC vector R that is associated with receive antenna # m and is a vector of length K, ym is a sample that is received by receive antenna # m, and Am is an m-th row of channel matrix A that is associated with receive antenna # m and is a vector of length K. Therefore, the MRC vector R may be simply generated by summing individual Rm components received from each of the M receive antennas. If the summation is performed at the AU processing units, the central processing unit may not need to perform significant processing to determine the MRC vector R.
According to an example embodiment, an autocorrelation matrix Acor is represented as an accumulation of increments from the M receive antennas. The autocorrelation matrix Acor is expressible as
where Acorm is a component of the autocorrelation matrix that is associated with receive antenna # m, and Am is an m-th row of channel matrix A that is associated with receive antenna # m and is a vector of length K. Therefore, the autocorrelation matrix Acor may be simply generated by summing individual Acorm components received from each of the M receive antennas. If the summation is performed at the AUs, the central processing unit may not need to perform significant processing to determine the autocorrelation matrix Acor.
MIMO operations also include MIMO transmission. In MIMO transmission, 2 or more transmit antenna transmit to a single user.
Communications system 400 may be represented as a mathematical model expressible as:
where X is a transmitted symbol vector of length K in which each element xk represents a symbol of user k; R is a received sampled vector of length K in which each element rk represents a sample received by user k; N is a received noise vector of length K in which each element nk represents noise received by user k (it is assumed that N is AWGN); A is a channel matrix of size M by K in which each element am,k represents the channel transfer function between user k and transmit antenna m; and W is a precoding matrix of size K by M.
There are several ways to define the precoding matrix W. A ZF precoding matrix fully removes multi-user interference and is expressible as
W=A
T
·inv(A·AT)=AT·inv(Acor)
where AT is a transposed channel matrix of size K by M, and inv(Acor) is an inverse autocorrelation matrix of size M by M.
It is possible to re-express the above expression for R as
R=A·W·X+N=A·A
T
·inv(Acor)·X+N=A·AT·S+N
where S=inv(Acor)·X is a precoded symbol vector of length K. If M is sufficiently large, the autocorrelation matrix converges to an identify matrix (Acor=inv(Acor)=I). Therefore, it is possible to skip the multiplication by inv(Acor). Such a transmitter may be referred to as a MRC transmitter.
According to an example embodiment, it is also possible to perform MIMO precoding in a distributed computing manner. It is possible to make the following conclusions:
1. A central processing unit does not have to know channel matrix A with size M by K. It is sufficient to know a much smaller autocorrelation matrix Acor with size M by M.
2. Multiplication with the transposed channel matrix AT with size K by M may be performed independently in each AU by the individual AU processing units, for example. Each AU may multiply precoded symbols vector S with a vector AmT that represents row # m of channel matrix A as related to transmit antenna m.
3. If the communications system is operating in time division duplexed (TDD) mode, an uplink channel estimate may be used as the downlink channel estimate.
As discussed previously, a central processing unit does not need to know channel information of each transmit antenna. It is sufficient to know only accumulated autocorrelation matrix with a smaller size of K by K. Therefore, each AU may be able to maintain its own channel information without having to transfer the channel information to the central processing unit.
When dealing with the uplink (a transmission from a user to a base station), each user transmits its own reference signal for use in channel estimation. Therefore, the total number of reference signals is equal to the number of users K. Each AU (e.g., AU #m) may use the K reference signals to estimate channel vector Am with length K. If a least mean squared (LMS) algorithm is used in the estimation, the estimated channel vector is expressible as
where N is the length of the reference sequence (also referred to as accumulation length), ym is a sample that is received by receive antenna # m, and refk(n) is the reference signal for user k.
According to an example embodiment, a MIMO communications device with an array of AUs is presented. The MIMO communications device includes a central processing unit includes an array of AUs, where the AUs in the array are arranged as an array. Each AU includes a transmit antenna, a receive antenna, and associated RF hardware. Each AU also includes an AU processing unit configured to process information in a distributed computing manner. The AU processing units may process only information associated with AU or the AU processing unit may process information associated with the AU as well as share information with neighboring AUs. The distributed processing performed by the AU processing units may help to reduce computational load at the central processing unit as well as data bandwidth requirements for buses connecting the central processing units to the AUs.
Array of AUs 710 may be arranged in a mesh configuration. Each AU in array of AUs 710 are connected to a subset of neighboring AUs. As an illustrative example, AU 715 is located at a vertex and is connected to two neighboring AUs (AU 717 and AU 721). While AU 717 is located on an edge and is connected to three neighboring AUs (AU 715, AU 719, and AU 723) and AU 719 is located in a field of AUs and is connected to four neighboring AUs (AU 717, AU 721, AU 725, and AU 727). The AUs in array of AUs 710 may be connected to central processing unit 705 by one or more buses. Alternatively, central processing unit 705 may be connected to a subset of the AUs in array AUs 710. As an illustrative example, array of AUs 710 may include an end AU 730 that is connected to a subset of neighboring AUs (two neighboring AUs as shown in
The AUs in array of AUs 710 may be spaced regularly apart from one another, e.g., the AUs (or the antennas therein) are spaced one-half wavelength apart. Alternatively, the AUs in array of AUs 710 may be irregularly spaced apart from one another, e.g., some AUs may be spaced regularly apart while others may be irregularly spaced apart, or none of the AUs are spaced apart by the same amount.
Autocorrelation connection 820 allows for the exchange of the accumulated autocorrelation matrix and has sufficient bandwidth to support the transfer of K by K-sized matrices. MRC connection 825 allows for the exchange of the accumulated MRC vector and has sufficient bandwidth to support the transfer of K-sized vectors. Reference connection 830 allows for the exchange of reference signals for use in channel estimation and has sufficient bandwidth to support the transfer of K-sized vectors. TX symbols connection 835 allows for the exchange of TX symbols for transmission precoding and transmission and has sufficient bandwidth to support the transfer of K-sized vectors. The connections may be bi-directional in nature, allowing the AUs in the plurality of AUs to exchange information with one another. A control bus allows for the exchange of control signals regulating the operation of MIMO communications device.
MIMO communications device 800 includes a plurality of adders (such as adders 845 and 850) to accumulate information from neighboring AUs. As shown in
A positioning unit 918 is configured to assist in determining a position of AU 900 using received reference signals, while a multiply unit 922 is configured to multiply coefficients provided by coefficients unit 920 with signals provided by the central processing unit. As an illustrative example, multiply unit 922 may multiply transmission symbols provided by the central processing unit with channel transfer functions. An adder 928 combines the outputs of multiplier 928 and provides the combine value to a D/A converter 920. AU 900 also includes transmitter RF circuitry 932, which may include filters, modulators, constellation mappers, and so on.
In
According to an example embodiment, a MIMO communications device with a distributed array of AUs is presented. The example MIMO communications devices discussed in
The leaves may be coupled to each other (and the central processing unit) by way of a high speed bus or connection. As shown in
In a typical massive MIMO implementation, a large number (M×N) omni-directional antennas are mounted on a flat surface with a consistent spacing between antennas (a·λ×b·λ), where N and M are integer values and l is wavelength of a signal.
Therefore, the beam arrives at antenna #n 1205 with a complex gain expressible as
Hence, antenna arrays that are tuned to the receive the signal from direction a may be configured with coefficients that match the complex gain Hn*(α).
Therefore, the beam arrives at antenna (n, m) 1255 with a complex gain expressible as
Hence, antenna arrays that are tuned to the receive the signal from direction a may be configured with coefficients that match the complex gain Hn,m*(α, β).
The discussion regarding
In general, the coefficients for receive antenna unit #P 1409 for a single antenna beam with angle (α, β) is expressible as
where (x, y, z)p is the coordinates of receive antenna unit #p 1409, and (x0, y0, z0)P is the reference coordinates of massive MIMO multi-beam receiver 1400. Similarly, the coefficients for receive antenna unit #P 1409 for multiple beams with multiple angles is expressible as
However, determining the angles for the multiple beams may be a difficult task since a search space to determine the angles is very large. Therefore, the scanning of the search space to find the angles with the most energy can take an extended amount of time. Furthermore, since the beam width of antenna beams generated by a communications device (e.g., a massive MIMO multi-beam receiver) is inversely proportional to the number of antennas, the scan of the search space takes an even greater amount of time due to the narrow beam width of the antenna beams generated by the massive MIMO multi-beam receiver.
According to an example embodiment, a distributed approach is applied to the scanning of the search space to find the angles with the most energy. The search space is partitioned into a plurality of independent portions that may be separately scanned. Since each independent portion is smaller, the scan of each independent portion will take less time.
According to an example embodiment, the inverse relationship between the beam width of antenna beams generated by a communications device and the number of antennas of the communications device used to generate the antenna beams is exploited. Since the beam width of the antenna beams will generally increase as the number of antennas used to generate the antenna beams, the number of antennas used to generate the antenna beams that are used in the scanning of the search space is decreased to increase the beam width of the antenna beams. The greater beam width of the resulting antenna beams may shorten the amount of time to scan the search space due to increased search granularity.
According to an example embodiment, both the distributed approach and the antenna beam width are used to help accelerate the scan of the search space. The combining of both techniques may help further speed up the finding of the angles of the antenna beams.
According to an example embodiment, once the angles of the antenna beams are found, antenna beams with narrower beam widths are used to increase precision. A two-stage process is used to increase performance. In a first stage, the finding of the angles of the antenna beams is performed quickly with smaller search spaces and wider beam widths, while in a second stage, after the angles have been found increased precision is achieved by using antenna beams with narrower beam widths.
Operations 1500 may begin with a partitioning of an antenna array into a plurality of independent antenna array portions (block 1505). The antenna array may be partitioning into an integer number of independent antenna array portions. As illustrative examples, the antenna array is partitioned into 2, 4, 8, 16, and so on, independent antenna array portions. In general, as the number of antennas in the independent antenna array portions decreases as the number of independent antenna array portions increases. However, overhead also increases. Each independent antenna array portion may contain about the same number of antennas to simplify implementation. Each independent antenna array portion is assigned to scan a different part of the search space (block 1510). The search space may be partitioned into a plurality of search space portions. The number of search space portions may be equal to the number of independent antenna array portions. Alternatively, there may be more search space portions than the number of independent antenna array portions. In such a situation, each independent antenna array portion scans one or more search space portions.
Each independent antenna array portion measures received energy from the search space portion(s) assigned to it (block 1515). Since the independent array portions comprise a smaller number of antennas than the antenna array, the beam widths of the antenna beams will be greater, thereby speeding up the scan of the search space portion(s). As an illustrative example, a measurement process includes a central processing unit associated with an independent antenna array portion configures an antenna beam so that it is directed inside the search space portion assigned to the independent antenna array portion and measures an energy level associated by the antenna beam. The central processing unit continues the measurement process with other antenna beams until the search space portion has been measured. If the independent antenna array portion has been assigned multiple search space portions, the measurement process may continue until all assigned multiple search space portions have been scanned.
The antenna beam(s) associated with the highest energy levels are selected (block 1520). The number of antenna beams selected may be a configurable number. As an illustrative example, if there is a large number of search space portions, only a relatively small number of antenna beams are selected (for example, 1 or 2 antenna beams per search space portion). While, if there is a small number of search space portions, a relatively large number of antenna beams are selected (for example, 4 or 5 antenna beams per search space portion). Alternatively, every antenna beam with a measured energy level exceeding a threshold is selected. Alternatively, a combination of a number of antenna beams and a threshold is used in the selection of antenna beams. The selected antenna beams from different search space portion is combined (block 1525). The antenna array, in its entirety, is used with the selected antenna beams to communicate (block 1530). The use of the antenna array, with its larger number of antennas, results in narrower beam width antenna beams. The narrower beam width antenna beams provide greater precision, such as in receiving more of a transmission to the massive MIMO communications device while receive less noise and/or interference since the transmission encompasses a larger percentage of the narrower beam width antenna beam.
In some embodiments, the processing system 1800 is included in a network device that is accessing, or part otherwise of, a telecommunications network. In one example, the processing system 1800 is in a network-side device in a wireless or wireline telecommunications network, such as a base station, a relay station, a scheduler, a controller, a gateway, a router, an applications server, or any other device in the telecommunications network. In other embodiments, the processing system 1800 is in a user-side device accessing a wireless or wireline telecommunications network, such as a mobile station, a user equipment (UE), a personal computer (PC), a tablet, a wearable communications device (e.g., a smartwatch, etc.), or any other device adapted to access a telecommunications network.
In some embodiments, one or more of the interfaces 1810, 1812, 1814 connects the processing system 1800 to a transceiver adapted to transmit and receive signaling over the telecommunications network.
The transceiver 1900 may transmit and receive signaling over any type of communications medium. In some embodiments, the transceiver 1900 transmits and receives signaling over a wireless medium. For example, the transceiver 1900 may be a wireless transceiver adapted to communicate in accordance with a wireless telecommunications protocol, such as a cellular protocol (e.g., long-term evolution (LTE), etc.), a wireless local area network (WLAN) protocol (e.g., Wi-Fi, etc.), or any other type of wireless protocol (e.g., Bluetooth, near field communication (NFC), etc.). In such embodiments, the network-side interface 1902 comprises one or more antenna/radiating elements. For example, the network-side interface 1902 may include a single antenna, multiple separate antennas, or a multi-antenna array configured for multi-layer communication, e.g., single input multiple output (SIMO), multiple input single output (MISO), multiple input multiple output (MIMO), etc. In other embodiments, the transceiver 1900 transmits and receives signaling over a wireline medium, e.g., twisted-pair cable, coaxial cable, optical fiber, etc. Specific processing systems and/or transceivers may utilize all of the components shown, or only a subset of the components, and levels of integration may vary from device to device.
Although the present disclosure and its advantages have been described in detail, it should be understood that various changes, substitutions and alterations can be made herein without departing from the spirit and scope of the disclosure as defined by the appended claims.