Unless otherwise indicated herein, the materials described in this section are not prior art to the claims in this application and are not admitted to being prior art by inclusion in this section.
The subject matter in general relates to LTE network systems. More particularly, but not exclusively, the subject matter is directed to reduction of interference and improvement of signal strength in an LTE system.
Long-Term Evolution (LTE) is standard for high-speed wireless communication for mobile phones. It increases the capacity and speed using different radio interface together with core network improvements. In LTE, new technologies have recently been adapted where there is co-operation between base station and the user signals received by these base stations are processed by a Central Processing Unit (CPU). Pertaining to cellular networks, the radio uplink is the transmission path from the mobile station (cell phone) to a base station (cell site). Physical uplink shared channel is used to carry the uplink user's information data.
Signal to Noise Ratio (SNR) is one of the most important indicators to represent signal strength in LTE systems. As SNR decreases, the quality of the signal gets poorer which means higher interference or noise level in any network systems. As SNR goes lower, the probability of error goes higher leading to poor network throughput.
Traditionally, signals from one user in one subcarrier face interference from the signals from the other users in the same subcarrier which decreases the network throughput of the wireless network systems.
Further, MIMO (Multiple Input Multiple Output) is another of the LTE major technology innovations used to improve the performance of the system. MIMO systems use more than one transmit antenna to send a signal on the same frequency to more than one receiving antenna. This technology provides LTE with the ability to further improve its data throughput. Although, it enables far high data rates to be achieved but ends up adding complexity to the system in terms of processing and the number of antennas required.
When multiple users access the LTE base station simultaneously, then the available data throughput is shared among them. Different users will typically place different throughput demands on a LTE base station at a given time, but at times when the aggregate throughput demands exceed the available throughput from the LTE base station to the users, then some or all users will receive less data throughput than they are seeking.
In light of the above drawbacks, a system and method for reducing interference and improving signal strength in an LTE system is required.
In an aspect, a method is provided for improving signal to noise ratio in an uplink transmission. The method includes determining a plurality of combinations of “N” possible users to be selected among “X” users that are transmitting signals to a base station comprising “n” number of antennas, where n>=N, wherein selected “N” users transmit on a same sub-carrier; computing signal to noise ratio (SNR) of the signals received from each of the users among the determined combination of “N” possible users; and selecting at least one combination among the plurality of combinations of “N” possible users, such that, a combined signal to noise ratio of the selected combination is maximum among all combinations.
In another aspect, a method is provided for improving signal to noise ratio in an uplink transmission. The method includes receiving signals from “X” users at a plurality of antennas present in a plurality of base stations; determining a plurality of combinations of “N” possible users to be selected among the “X” users, wherein each of the “N” users is associated with one base station, such that each of the “N” users transmit to all the base stations, each comprising at least “n” number of antennas, where n>=N, wherein each of the “N” users transmit on a same sub-carrier; computing signal to noise ratio for each of the users among the determined combinations of “N” possible users by using signals received by all the antennas of all the base stations; and selecting at least one combination among the plurality of combinations of “N” possible users, such that, a combined signal to noise ratio of the selected combination is maximum among all combinations.
In yet another aspect, a method is provided for improving signal to noise ratio in an uplink transmission. The method includes receiving signals from “X” users, each of the “X” users comprising two antennas, at a plurality of antennas present in a plurality of base stations; determining a plurality of combinations of “N” possible users to be selected among the “X” users, wherein each of the “N” users is associated with one base station, such that each of the “N” users transmit to all the base stations, each comprising at least “n” number of antennas, where n>=N, wherein each of the “N” users transmit on a same sub-carrier; computing signal to noise ratio for each of the users among the determined combinations of “N” possible users; and selecting at least one combination among the plurality of combinations of “N” possible users, such that, a combined signal to noise ratio of the selected combination is maximum among all combinations.
In still another aspect, a method is provided for accommodating multiple users transmitting on a same sub-carrier to a base station comprising n antennas. The method includes enabling a first user to transmit two bits through two antennas of a user equipment of the first user; decomposing a (n×2) channel matrix of the first user using Singular Value Decomposition (SVD), into three matrices, wherein the matrices are a (n×n) unitary matrix which is denoted by “U”, a (n×2) partial diagonal matrix which is denoted by “S” and a precoder (2×2) unitary matrix which is denoted by “VH”; enabling other (n−2) users in the base station to transmit one data bit each through two antennas to the base station on same sub-carrier as the first user; computing effective channel matrix of the first user; computing effective channel vectors of the (n−2) users using “U”; computing transmit precoders of the (n−2) users using “U”; and computing signal to noise ratio and decoding the input bits of the users by applying Interference Rejection Combining (IRC) function using the signals received by the n antennas of the base station and effective channel vectors of the first user and the (n−2) users.
In still another aspect, a method is provided for accommodating multiple users transmitting on a same sub-carrier to a base station comprising n antennas. The method includes computing precoder determination algorithm (PDA) values corresponding to “X” users, wherein for each of the “X” users “n” such PDA values are computed, wherein the PDA values [V, Θ]=ψ[U, h, k] where “V” is a precoder matrix used for transmitting bits, “Θ” is a scalar value, “U” is a unitary matrix, “h” is a channel matrix of that user and “k” is a value from 1 to “n”, thereby resulting in X*n PDA values; identifying a maximum value of “Θ” for each value of “k”, thereby resulting in “n” maximum values of “Θ” from the X*n PDA values; and selecting the users to which the “n” maximum values of “Θ” correspond, to transmit to a base station through two antennas in a same sub-carrier, wherein each of the selected users is allowed to transmit “m” number of bits to the base station, where “m” is the number of maximum values of “Θ” out of “n” maximum values of “Θ”, corresponding to respective selected user.
Embodiments are illustrated by way of example and not limitation in the Figures of the accompanying drawings, in which like references indicate similar elements and in which:
The following detailed description includes references to the accompanying drawings, which form part of the detailed description. The drawings show illustrations in accordance with example embodiments. These example embodiments are described in enough detail to enable those skilled in the art to practice the present subject matter. However, it will be apparent to one of ordinary skill in the art that the present invention may be practiced without these specific details. In other instances, well-known methods, procedures and components have not been described in detail so as not to unnecessarily obscure aspects of the embodiments. The embodiments can be combined, other embodiments can be utilized or structural and logical changes can be made without departing from the scope of the invention. The following detailed description is, therefore, not to be taken as a limiting sense.
In this document, the terms “a” or “an” are used, as is common in patent documents, to include one or more than one. In this document, the term “or” is used to refer to a nonexclusive “or,” such that “A or B” includes “A but not B,” “B but not A,” and “A and B,” unless otherwise indicated. Throughout the document, the word “bits” may mean symbols as in constellation mapping in digital communications.
Embodiments provide a system and method for improving strength of signals in uplink transmission. Embodiments, further, provide methods for increasing the overall spectral efficiency in an uplink transmission. The system includes a processor which communicates with the base stations. The processor is configured to process the received signals in order to improve the SNR of the signals. The system includes a memory unit, communication module, and an IRC unit. The IRC unit is responsible for computing the signal to noise ratio of the uplink signals received at one or more antennas of one or more base station in the system. Methods are provided for determining a plurality of combinations of N possible users (users may refer to user equipments) to be selected among X users that are transmitting signals to one or more base stations each comprising “n” number of antennas, where generally, though not necessarily, n>=N. The IRC unit is configured to compute signal to noise ratio (SNR) of the signals received from each of the users among the determined combinations of N possible users and selecting at least one combination among the plurality of combinations of N possible users. The combination is selected, such that, a consolidated signal to noise ratio of the selected combination is maximum among all combinations. Methods are provided for efficiently computing the SNR of the signals received at the antennas of the base station. The IRC unit is configured to compute signal to noise ratio for at least a predetermined number of users in one or more of the combination of N possible users. The calculated signal to noise ratio for the predetermined number of users are recorded in the memory unit of the system. Further, signal to noise ratios, which are calculated previously, are used in the calculation of SNRs of the subsequent combinations of N possible users. Methods are provided for increasing the performance of the user equipment's communicating to the base stations. Furthermore, to elevate the network capacity i.e. the number of users for the network is equally taken into consideration. In an uplink transmission, the uplink shared channel is used to carry the uplink's information data over a subcarrier. The scenario wherein there is a communication between the user equipment's and the respective base station at the same time, there is a huge possibility of the interference among the user equipment's communicating simultaneously. The processor determines the best user to be selected among all the user communicating to the base station at the same time which can be allowed for the transmission without interfering with the communication of the other users. The system makes use of simplified algorithms which increases the processing and elevates overall throughput of the network mitigating the loss which can be caused by the interference when the user equipment's are communicating to the base station at the same time. Embodiments provide methods for selecting the best possible antennas of the base stations. Embodiments further provide methods for estimating the channel values of the user equipment's if they occur to carry out the uplink transmission over “N” number of subcarriers. While considering the transmission across the set of subcarriers, the reception of the data at each subcarrier will be the summation of the transmission by the all user equipment's. The processor estimates the channel values of each user equipment's for the given output signal received at base station where channel values vary when transmitted over “N” number of subcarriers.
Referring to the figures, more particularly to
The system 100 includes, but not limited to, a processor 102, a memory unit 104 and a network communication module 106. System 100 may further include an interference rejection combining unit 108 or an IRC unit 108. System 100 may include provisions for receiving signals from a plurality of base stations 110 of cellular networks, wherein base stations may belong to one or more small cells. Base stations 110 may be included as part of the system 100. The system 100 may further include a memory unit 104, wherein the memory unit 104 is configured to store or keep records of the computations which aids in further computations and making the processing much faster. A communication interface may be present which helps to communicate with the plurality of the base stations. A Central Processing Unit (CPU) 112 includes, but not limited to, the processor 102, the memory unit 104, the communication module 106, the IRC unit 108. The communication module(s) 106 may interact with base stations 110 and all the base stations may be connected to the Central Processing Unit where the received signals are processed. There may be multiple communication modules in the Central Processing Unit (CPU) 112 which may communicate to plurality of base stations (110) which may further communicate to the Central Processing Unit (CPU) 112.
The processor 102, returns output by accepting signals, such as electrical signals as input. In one embodiment, processor 102 may include one or more processing units Processor(s) may be implemented as appropriate in hardware, computer-executable instructions, firmware, or combinations thereof. Computer-executable instruction or firmware implementations of the processor 102 may include computer-executable or machine-executable instructions written in any suitable programming language to perform the various functions described.
The memory units/devices 104 may store data and program instructions that are loadable and executable on processor(s) 102 as well as data generated during the execution of these programs. The memory may be volatile, such as random-access memory and/or a disk drive or non-volatile memory.
One or more base stations 110 from one or more cells may be configured to communicate with the processor 102. Communication is enabled by the communication module 106. The processor 102 receives signals from the base stations 110 and communicates the signals to the IRC unit 108, where the interference of the received signal is suppressed and the signal to noise ratio (SNR) is maximized.
The IRC unit 108 is configured to receive instructions from the processor 102. The IRC unit 108 is configured to emulate interferences occurring from one or more user equipments (mobile communicating devices) transmitting data bits using multiple channels. The IRC unit 108 utilizes the characteristics of inter-cell interference to determine the power of the interfering user equipment's which belongs to another cell. Once the pattern and power level is determined, the interfering signal can be reduced/removed from the received signals of the desired user equipment. The IRC unit 108 is further configured to maximize the signal to noise ration of the received signals. IRC unit 108 receives instructions from the processor 102 to suppress interference while maximizing signal to noise ratio (SNR) of the received signals. It may be noted that users may refer to user equipment's as user equipment's are communicating with the base stations which are carried by users.
The IRC unit 108 of the system 100 is configured to estimate the input data bits (signals) received from user equipments at the antennas of the base stations 110. The signals received at the antennas of the base stations 110 may be communicated to the processor 102, where the processor 102 instructs the IRC unit 108 to estimate the input data signal using a Hermitian function. The second function expresses the input data signal “x” as a product of a Hermitian Matrix “WH” and a received signal “Y” at all the antennas of base station 110 as shown below.
x=wHy
The output/received signal is expressed as Y=hx+h1x1+n, where h is the channel through which the input signal “x” of the desired user is transmitted and “n” is the noise, h1 is the channel of the interfering user which is transmitting input signal x1. The IRC unit 108 of the system 100 is further configured to compute the Hermitian Matrix “WH” using a Hermitian function as shown below.
WH=hHR−1
where R=h1h1H+Δ2I
R is a covariance matrix corresponding to the interfering user and AWGN (additive white gaussian noise) and Δ2 is variance of AWGN and I is an identity matrix. The IRC unit 108 of the system 100 is further configured to compute the SNR of the uplink signal which is mentioned in detail in the later concepts pertaining to computing the signal to noise ratios (SNR). The method to improve the signal to noise ratio in different scenarios is explained in detail in further descriptions.
Referring to
At step 202, the processor 102 determines a plurality of combinations of N possible users to be selected among X users that are transmitting signals through N vector channel to a base station comprising n number of antennas. At step 204, input data signal is determined from the N channels and the signals received at the “n” antennas of the base station using an Interference Rejection Combining (IRC) function. The IRC function may be carried out in the IRC unit 108. At step 206, the IRC unit 108, determines a matrix of the channel value using a Hermitian function. The Hermitian function may be a function that computes a Hermitian Matrix from the channel vector, where the channel vector is a matrix comprising one column and n rows. The output matrix of the Hermitian function or the Hermitian matrix may be an n column and one row matrix. At step 208, the IRC unit 108 calculates the input data signal using the received signal and the matrix obtained using the IRC function on the channel value and the signal to noise ratio (SNR) using the channel vector. At step 210, the IRC unit 108 calculates the SNR of all users among the determined combination of N possible users. At step 212, the processor 102 selects at least one combination of N users among the plurality of combinations of N possible users, such that, the Nth root of the product of the signal to noise ratios (SNR) of the selected N users is maximum among all combinations.
Referring to
The processor 102 instructs the IRC unit 108 to estimate the input data signal using a second function. The base station may receive 4 bits of data at each antenna through 4 scalar channels such that one user equipment transmits 1 bit of data. Let the users be denoted by “i”, “j”, “k”, “l” such that the selected users are the ith, jth, kth and the lth users in the base station 110. Let the input signal transmitted by the ith user be xi, input signal transmitted by the jth user be xj, input signal transmitted by the kth user be xk and input signal transmitted by the jth user be xl. Likewise, let the output signal received at all the four antennas of base station 110 be Y.
The IRC function expresses the input data signals “xi” as the product of a Hermitian Matrix “WiH” and a received signal Y, “xj” as the product of a Hermitian Matrix “WjH” and a received signal Y, “xk” as the product of a Hermitian Matrix “WkH” and a received signal Y and “xl” as the product of a Hermitian Matrix “WlH” and a received signal “Y” across all the four antennas of the base station 110 as shown below.
xi=WiHY
xj=WjHY
xk=WkHY
xl=WlHY
The IRC unit 108 of the system 100 is further configured to compute the Hermitian matrices “WiH”, WjH, WkH and WlH using the first function as shown below.
WiH=hiHRi−1
WjH=hjHRj−1
WkH=hkHRk−1
Let the 4 channels used by the 4 users be denoted by hi, hj, hk, hl corresponding to all the “n” antennas comprising n rows and one column. The SNRs of the signals received from user equipments of the “i”, “j”, “k” and “l” users are respectively denoted by SNRi, SNRj, SNRk and SNRl. The signal to noise ratios SNRi, SNRj, SNRk and SNRl may be expressed using the equation as provided below,
SNRi=hiHRi−1hi, where Ri=hjhjH+hkhkH+hlhlH+Δ2I
SNRj=hjHRj−1hj, where Rj=hihiH+hkhkH+hlhlH+Δ2I
SNRk=hkHRk−1hk, where Rk=hihiH+hjhjH+hlhlH+Δ2I
SNRl=hlHRl−1hl, where Rl=hihiH+hjhjH+hlhlH+Δ2I
where Δ2 is the variance of AWGN (additive white gaussian noise) variance, Ri, Rj, Rk and Ri are covariance matrices for all the user equipments and I is 4×4 identity matrix.
The processor 102 is configured to calculate SNRs of each user among the 4 possible users in the 210 combinations. The processor 102 selects at least one combination of 4 users among the plurality of 210 combinations of 4 possible users, such that, the 4th root of the product of the signal to noise ratios (SNRi, SNRj, SNRk and SNRl) of the selected 4 users is maximum among all combinations. In other words, a combination of 4 users among the plurality of 210 combinations of 4 possible users is selected, such that,
is maximum among all combinations.
The processor 102 is further configured to calculate signal to noise ratio for at least a predetermined number of users in one or more of the plurality of combinations of N users. For example, the processor 102 may calculate SNRs of at least the ith user and the jth user in the 210 combinations of 4 users. In other words, the processor 102 may calculate SNRi, SNRj to begin with. Further, the processor 102 may be configured to reuse or utilize the computations used for the previously calculated SNRs to compute
in the subsequent combinations of N possible users. The calculated SNRs are stored within the memory unit 104 of system 100. The above computations are carried out using Woodbury's identity algorithm. A method to compute the signal to noise ratios for the selected users is explained in detail in later concept.
Referring to
Referring to
Referring to
Referring to
The processor 102 instructs the IRC unit 108 to estimate the input data signal using the Interference Rejection Combining (IRC) function. The base station 110a may receive 4 bits of data at each antenna through 4 scalar channels. In an embodiment, the bits may refer to symbols. One user equipment transmits signal through each of the 16 scalar channels to the 16 antennas of all the N base stations 110. Likewise, all the remaining 3 user equipment's transmit signal through each of the 16 scalar channels to the 16 antennas of all the N base stations 110. Hence, one base station receives data through 16 scalar channels. Similarly, all 4 users may transmit to all base stations 110. Let the users be denoted by “i”, “j”, “k”, “l” such that the selected users are the ith, jth, kth and the lth users in the base stations 110a, 110b, 110c and 110d respectively. Each ith, jth, kth and the lth users transmits to all the base stations 110a, 110b, 110c and 110d through 16 scalar channels. Hence, one base station e.g. 110a receives 16 signals or 4 data bits from the ith, jth, kth and the lth users. It may be noted that number of base stations are N=4 and the number selected users N=4 such that each user is associated with one base station.
Let the input signal transmitted by the ith user be xi, input signal transmitted by the jth user be xj, input signal transmitted by the kth user be xk, and input signal transmitted by the 1th user be xi. Let the consolidated channel for ith user from the Cell1 transmitting to all the base stations 110 be hi. Similarly, a consolidated channel for jth user from Cell2 transmitting to all the base stations 110 is denoted by h1, a consolidated channel for kth user from Cell3 transmitting to all the base stations 110 be hk and a consolidated channel for lth user from Cell4 transmitting to all the base stations 110 be hl. Each of the consolidated channel vectors is a 16×1 matrix.
For the ith user equipment, the second function (Hermitian function) expresses the input data signal xi as the product of Hermitian Matrix “WiH” and a received signal “Y”, for jth user equipment, the Hermitian function expresses the input data signal xj as the product of Hermitian Matrix “WjH” and a received signal “Y”, for kth user equipment, the Hermitian function expresses the input data signal xk as the product of Hermitian Matrix “WkH” and a received signal “Y”, and for the fuser equipment, the Hermitian function expresses the input signal xl as the product of Hermitian Matrix “WlH” and a received signal “Y” as shown below.
xi=WiHY
xj=WjHY
xk=WkHY
xl=WlHY
where Y is the signal received across 16 antennas of all the four base stations.
The IRC unit 108 of the system 300 is further configured to compute the Hermitian matrices “WiH”, WjH, WkH and WlH using the Hermitian function as shown below.
WiH=HiHRi−1
WjH=HjHRj−1
WkH=HkHRk−1
WlH=HlHRl−1
where Ri=hjHhjH+hkHhkH+hlHhlH+Δ2I
Rj=hiHhiH+hkHhkH+hlHhlH+Δ2I
Rk=hiHhiH+hjHhjH+hlHhlH+Δ2I
Rl=hiHhiH+hjHhjH+hkHhkH+Δ2I
Δ2 is AWGN (additive white gaussian noise) variance, Ri, Rj, Rk and Rl are covariance matrices corresponding to ith, jth, kth and lth user equipments and I is a 16*16 identity matrix. The SNRs of the ith,jth, kth and lth user equipments are denoted as SNRi, SNRj, SNRk and SNRl may be expressed using the equation as provided below.
SNRi=hiHRi−1hi
SNRj=hjHRj−1hj
SNRk=hkHRk−1hk
SNRl=hlHRl−1hl
Similarly, SNRs of jth, kth and lth users transmitting to all the base stations 110a, 110b, 110c and 110d respectively are calculated using the above formula. The processor 102 selects at least one combination of 4 users (ith, jth, kth and lth users) among the plurality of 10000 combinations of 4 possible users, such that, the 4th root of the product of the signal to noise ratios (e.g. SNRi, SNRj, SNRk and SNRl) of the selected 4 users is maximum among all combinations. In other words, a combination of 4 users among the plurality of combinations is selected, such that,
is maximum among all combinations.
The processor 102 is further configured to calculate signal to noise ratio for at least a predetermined number of users in one or more of the plurality of combinations of N users. For example, the processor 102 may calculate SNRs of at least the ith user and the jth user in the 10000 combinations of 4 users. In other words, the processor 102 may calculate SNRi, SNRj to begin with. Further, the processor 102 may be configured to reuse or utilize the previously calculated SNRs to compute
in the subsequent combinations of N possible users. The calculated SNRs are stored within the memory unit 104 of system 300. The above computations are carried out using Woodbury's identity algorithm. A method to compute the signal to noise ratios for the selected users is explained in detail in later context.
Referring to
Referring to
The processor 102 may be configured to select “N” users among X users for which the SNRs may be calculated (X user equipment's may be distributed equally among N cells) wherein each user belongs to one base station. There are about (X/N)N possible combination using which N users are selected. It may be noted that processor 102 determines the plurality of combinations of N possible users among the X users using (X1*X2 . . . XN), where X1 is the number of users in the first base station, X2 is the number of users in the second base station and XN is the number of users in the Nth base station, where X1+X2+ . . . XN=X. Each base station 110 may comprise “n” antennas, where generally, though not necessarily, n>=N. The number of “N” user equipment's may be equal to the “n” number of antennas. Each of the N users transmits signals to each of the base stations 110. Each of the user equipment's may transmit through two antennas. Hence one base station 110 receives signals through 2nscalar channels. Each of the N users transmits using 2 antennas to the n*N antennas of all the base stations. Each of the base stations may receive signal from one user equipment through 2nchannels. The vector channel of each user to all the antennas of all the base station is expressed as a matrix comprising two columns and n*N rows. All users transmit uplink signals to base stations 110 on same subcarrier. Each of the user equipment's uses transmit precoders for multi-antenna transmission. It may be noted that each of the N users belong to each of the N base stations.
Referring to
Referring to
Each user equipment has at least two transmitting antennas, such that each of the 4 users transmit two uplink signals through two channels to the 4 antennas of each of the base stations 110a, 110b, 110c and 110d at the same time. There may be 104 i.e. 10000 ways in which 4 users may be selected among 40 user equipment's.
Let the users be denoted by “i”, “j”, “k”, “l” such that the selected users are the ith user in the first cell, jth user in the second cell, kth user in the third cell and the lthuser in the fourth cell. Each of the ithuser, jth user, kth user and lth user transmits two signals (two bits) through 32 (16*2) scalar channels to 16 antennas of all the base station 110a, 110b, 110c, 110d respectively. Let the input signal transmitted by the ith user be xi, input signal transmitted by the jth user be xj, input signal transmitted by the kth user be xk and input signal transmitted by the lth user be xl, xi may be expressed as xi1, xi2, xj may be expressed as xj1, xj2, xk may be expressed as xk1, xk2 and xl may be expressed as xl1, xl2
Let the output signal received at all the antennas of all the base stations be Y where the received signal Y is a 16*1 matrix. Further, let's assume that the channel used by the ith user in the first cell is hi, the channel used by the jth user in the second cell is hj, the channel used by the kthuser in the third cell is hk and the channel used by the lthuser in the fourth cell is h1. Each of hi, hj, hk and hl is a 2 column16 row matrix (16*2 matrix, as the 16*2 channels transmit input from two antennas of the user equipment to 16 antennas of the four base stations 110). In other words, h1 may be expressed as hi1, hi2, hj may be expressed as hj1, hj2, hk may be expressed as hk1, hk2 and hl may be expressed as hl1, hl2.
The output/received signal across all 16 antennas of four base stations 110a, 110b, 110c and 110d is expressed as Y=hi xi+hj xj+hkxk+hlxl
In an embodiment, the processor 102 is configured to decompose the 16×2 channel matrix into three matrices using singular value decomposition or SVD. A first matrix may be a 16*2 matrix, a second matrix S may be a 2*2 matrix and a third matrix may be a 2*2 matrix. The decomposition outputs are provided below.
SVD(hi)=UiSiViH
SVD(hj)=UjSjVjH
SVD(hk)=UkSkVkH
SVD(hl)=UlSlVlH
where Ui=[Ui1, Ui2] and Si is a diagonal matrix with Si1 and Si2 as diagonal elements.
Similarly, Uj, Uk and Ul may be defined.
where Ui, Uj, Uk, Ui is used by the processor 102 and Vi, Vj, Vk, Vl are precoder values to be sent to the two-antenna transmitter of the user equipment. Si, Sj, Sk, Sl are diagonal matrices.
The output/received signal across all 16 antennas with the new effective channel matrices of four base stations 110a, 110b, 110c and 110d is:
Y=
Y=Ui1Si1xi1+Ui2Si2xi2+Uj1Sj1xj1+Uj2Sj2xj2+Uk1Sk1xk1+Uk2Sk2xk2+Ul1Sl1xl1+Ul2Sl2xl2
The input data bits xi1, xi2, Xj1, Xj2, Xk1, Xk2, Xl1, xl2 can be decoded from the relation as provided below.
xi1=Wi1HY
xi2=Wi2HY
xj1=Wj1HY
xj2=Wj2HY
xk1=Wk1HY
xk2=Wk2HY
xl1=Wl1HY
xl2=Wl2HY
The IRC unit 108 of the system 400 computes the Hermitian matrices Wi1H, Wi2H, Wj1H, Wj2H, Wk1H, Wk2H, Wl2H, Wl2H and W12H using the first function as shown below.
Wj1H=
Wj2H=
where Rj1−1=(R−
Wj1H=
Wj2H=
where Ri1−1=(R−
Wk1H=
Wk2H=
where Rk1−1=(R−
Wl1H=hl1HRl1−1
Wl2H=hl2HRl2−1
where Rl1−1=(R−
where R is given by the equation given below:
R=hi1hi1H+hi2hi2H+hj1hj1H+hj2hj2H+hk1hk1H+hk2hk2H+hl1hl1H+hl2hl2H+Δ2I
where Δ2 is AWGN (additive white gaussian noise) variance, Ri1, Ri2, Rj1, Rj2, Rk1, Rk2, Rl1, Rl2 are covariance matrices corresponding to ith,jth,kth and lth user equipments comprising two antennas each and I is 16*16 identity matrix.
The SNRs of the signals received from each of the two antennas of the user equipment's of the “i”, “j”, “k” and “1” users are respectively denoted by SNRi1, SNRj1, SNRk1 and SNRl1, SNRi2, SNRj2, SNRk2 and SNRl2 which are computed by the relation expressed below:
SNRi1=
Likewise using the above relation SNRj1, SNRj2, SNRk1, SNRk2, SNRl1, SNRl2 can be computed. The processor 102 is configured to select at least one combination of 4 users among the plurality of 10000 combinations of 4 possible users, such that, the 8th root (each of the 4 user equipments has two antennas) of the product of the signal to noise ratios (e.g. SNRi1, SNRj1, SNRk1 and SNRl1, SNRi2, SNRj2, SNRk2 and SNRl2) of the selected 4 users is maximum among all combinations. In other words, a combination of 4 users among the plurality of 10000 combinations of 4 possible users is selected, such that,
is maximum among all combinations.
The processor 102 is further configured to calculate signal to noise ratio for at least a predetermined number of users in one or more of the plurality of combinations of N users. For example, the processor 102 may calculate SNRs of at least the ith user and the jthuser in the 10000 combinations of 4 users. In other words, the processor 102 may calculate SNRi, SNRj to begin with. Further, the processor 102 may be configured to reuse or utilize the previously calculated SNRs (i.e. SNRi, SNRj) to compute
in the subsequent combinations of N possible users. The calculated SNRs are stored within the memory unit 104 of system 400. The above computations are discussed in detail in later concepts and are carried out using Woodbury's identity algorithm. The above method to compute the signal to noise ratios is discussed in detail later.
Referring to
Multiple users may be transmitting to a base station within a cell on the same subcarrier. The uplink subcarrier is shared among multiple users transmitting signals at the same time. Hence, there may be loss of signal in the uplink transmission and the spectral efficiency of the system 100 may be reduced. Referring to
The processor 102 is configured to add N users among a plurality of X users such that N users transmit bits equal to or less than the number of antennas “n” of a base station 110. The processor 102 is configured to decode the data bits of each of the selected users received at the “n” antennas.
In an embodiment, method to reduce the loss, illustrated in flowchart, involves one small cell, one base station 110 within the cell and “n” antennas per base station 110. “X” user equipment's are associated with the base station 110. These “X” users may belong to the cell to which the base station 110 belongs. The system 100 accommodates, in each of the base stations 110, one or more user equipments transmitting on the same subcarrier such that transmission of uplink signals by one user equipment does not result in significant loss of performance of the other user equipment's transmitting on the same subcarrier.
The processor 102 is configured to compute the singular value decomposition (SVD) of the signal transmitted by the existing or first user equipment to the base station 110 through a channel “h1”, such that h1=[U1S1V1H], where U1 S1 and V1H are 4*4, 4*2 and 2*2 matrices respectively assuming there may be four antennas of base stations. The processor 102 is further configured to determine a precoder determination algorithm (PDA) values (V) for each of the additional users using the relation
[V,Θ]=ψ[U,h,k]
where V is a precoder matrix, Θ is a scalar value, U is a unitary matrix, h is channel matrix, k is a scalar value between 3 and number of columns of unitary matrix U. The precoder determination algorithm (PDA) is computed as expressed below.
U1 is determined by the kth column of the unitary matrix U which is followed by computing the value of m which is given as expressed below:
M=u1u1H
where u1 is represents the kth column of the Unitary Matrix U and u1H is Hermitian function of u1. Further, the processor 102 computes the eigen vector v1 of M with the highest eigen value such that it maximizes
by using Rayleigh-Ritz Ratio theorem. The value of Vp is computed by using relation as expressed below.
Vp=(hHh)−1hHv1
where h is channel matrix and hH is Hermitian function of channel matrix h and v1 is the eigen vector of M corresponding to the with largest eigen value.
where Vp corresponds to the above computed value of V with n as number of transmit antennas. The processor 102 is configured to compute the value of Θ which is given by the relation as given below.
Where Vmax corresponds to eigen vector v1 of M with the highest eigen value such that it maximizes the ratio
by using Rayleigh-Ritz Ratio theorem
“k” is a scalar value which indicates the 3rd and the 4th columns of the 4×4 input data matrix U1. The processor 102 is configured to select “k” in such a way that h2 V2 has the best alignment with the third or fourth column of the input signal matrix U1. The processor 102 is configured to compute the best value of “V2” using a precoder determination algorithm (PDA). It selects the best “V2” for the second user equipment which is computed using precoder determination algorithm (PDA), which decides the signal of the respective user to be allowed for the transmission to the base station 110. The data bits received across the n antennas of the base station is decoded. Further the IRC unit calculates the SNR of the received signals.
As an example, let's consider the system 500 of
At step 502, the processor 102 computes the singular value decomposition (SVD) of the channel matrix of the first user equipment after enabling the first user to transmit two bits through two antennas i.e. h1 as shown below.
SVD(h1)=[U1S1V1H]
where U1 S1 and V1H are 4*4, 4*2 and 2*2 matrices respectively. At step 504, the 4*4U1 matrix is obtained as a result of decomposition, such that the 4*4 matrix U1 multiplied by S1 becomes the effective 4*2 channel matrix for the first user for transmission where effective channel matrix is given as x=[x1, x2]=U1S1. It may be noted that bottom half of S1 is all-zero matrix, and upper half is a diagonal matrix.
The processor 102 is configured to allow first user equipment to transmit two bits d1 and d2 after being multiplied by V1. Let d1′ and d2′ represents the data bits d1 and d2 which upon transmission are multiplied by V1 which is given below.
At step 506, the processor 102 enables other (n−2) users i.e. second and third user in the base station to transmit one data bit each through two antennas to the base station on the same sub-carrier as the first user and computes the effective channel matrix for (n−2) users using unitary matrix of the first user. The processor 102 computes the precoder determination algorithm (PDA) value say V2 for the second user equipment. V2 is expressed as,
[V2,θ]=ψ[U1,h2,k]
where h2 is a vector representing a 4*2 channel matrix for the second user equipment. It may be noted that precoders V2 and V3 corresponds to second and third user equipment are 2×1 matrices.
The processor 102 is configured to compute the scalar value k. If k=3, the precoder determination algorithm (PDA) computes V2 such that h2V2 aligns as much as possible with the third column of the 4×4 matrix of “U1” obtained from the singular value decomposition of the channel value h1 of the first user equipment. If k=4, the precoder determination algorithm (PDA) computes V2 such that h2V2 aligns as much as possible with the fourth column of the 4×4 matrix of “U1” as much as possible. At step 508, the best value of precoder determination algorithm (PDA) “V2” is computed for the second user equipment using the precoder determination algorithm (PDA), as shown below.
[V2(1),Θ(1))]=ψ[U1,h2,3]
[V2(2),Θ(2))]=ψ[U1,h2,3]
where h2 is a vector representing a 4×2 channel matrix of the second user equipment The best value among V2(1) and V2(2) is considered to be the precoder determination algorithm (PDA) value for the second user equipment.
At step 508, the best “V2” will be used for the transmission for the second user equipment. As an example, if Θ(2)>θ(1) which implies V2 to be selected is V2(2) or vice versa. If Θ(2)>Θ(1), the second user equipment uses precoder value V2=V2(2) which is computed by the processor 102 using the precoder determination algorithm (PDA). The second user equipment then transmits one bit d3 across two antennas as represented as V2d3. The processor 102 computes the precoder value for the third user equipment by using precoder determination algorithm (PDA) which can be expressed as given below.
[V3,Θ]=ψ[U1,h3,3]
If Θ(1)>Θ(2), the second user equipment uses precoder value V2=V2(1) which is computed by the processor 102 using the precoder determination algorithm (PDA). The processor 102 computes the precoder value for the third user equipment by using precoder determination algorithm (PDA) which can be expressed as given below.
[V3,Θ]=ψ[U1,h3,4]
At step 510, the processor is configured to allow the second user equipment possessing the best precoder determination algorithm (PDA) value for the transmission. The second user equipment then transmits one bit d3 across two antennas as V2d3. At step 512, determine a precoder transmitter for a third user equipment using Precoder Determination Algorithm (PDA) such that number of users are less than or equal to the number of antennas.
It may be noted that, once the second user equipment transmits the corresponding bits then a third user equipment transmits one bit d4 across two antennas as V3d4. The received signal across the four antennas of base station is expressed as follows.
Y=x1d1+x2d2+x3d3+x4d4
where x3=h2V2 and x4=h3V3
At step 514, the signal bits d1, d2, d3, d4 are decoded at the processor 102 using interference rejection algorithm (IRC) function discussed previously. The signal bits can be decoded as given below.
d1=w1Hywhere w1H=x1HR1−1
where R1=x2x2H+x3x3H+x4x4H+Δ2I
d2=w2Hywhere w2H=x2HR2−1
where R2=x1x1H+x3x3H+x4x4H+Δ2I
d3=w3Hywhere w3H=x3HR3−1
where R3=x2x2H+x1x1H+x4x4H+Δ2I
d4=w4Hywhere w4H=x4HR4−1
where R4=x2x2H+x3x3H+x1x1H+Δ2I
where Δ2 is AWGN (additive white gaussian noise) variance, R1, R2, R3 and R4 are covariance matrices corresponding to the first, second and third user respectively and I is a 4×4 identity matrix.
It may be noted that, the precoder value V2 is computed using the precoder determination algorithm (PDA) configured in the processor 102 as discussed previously.
Referring to
Referring to
In an embodiment, the method for selecting the best possible users to be accommodated in a cell involves one cell, one base station 110 within a cell and “n” antennas of the base station 110. “X” user equipment's are associated with the base station 110. These “X” users may belong to the cell to which the base station 110 belongs. The system 100 accommodates, in each of the base stations 110, one or more user equipments such that transmission of uplink signals by all the user equipment's on the same subcarrier doesn't result in significant loss of signal in the uplink transmission of other users transmitting on same subcarrier. Each user equipment associated to a base station is embedded with two antennas. The total number of users is less than or equal to “n”, the number of antennas.
Referring to the flowchart 516, at step 518, the processor 102 is configured to construct a table, wherein the columns represent the X number of users (may be referred to a user equipment carried by user) and the rows represent the n number of n antennas of the base station 110. At step 520, the precoder determination algorithm (PDA) value is determined, for each of these n*X locations of table, using [V,Θ]=ψ[U, h, k], where V is a precoder matrix used for transmitting bits, Θ.is a scalar value, U is a unitary matrix, h is a channel matrix of that user and k is a value from 1 to n, which gives X*n PDA values which corresponds to n*X locations of the table. At step 522, the processor 102 selects at least n Precoder Determination Algorithm (PDA) values such that the number of selected precoder determination algorithm (PDA) values are less than or equal to the number of antennas of the base station 110. At step 524, based on the value of the precoder determination algorithm (PDA) values, the location of the users in the table is determined. At step 526, the IRC unit decodes the input data bits for the selected best users of the table using the Interference Rejection Combining (IRC) function. Steps are similar in nature from 510 till 514 of
As an example, let's consider system 560 of
A Table 1 corresponds to row values which are represented by i and column values which are represented by j. The i values represent the orthogonal vector U where values of i ranges from 1 to 4 which represents the four antennas of the base station 110. The j values represent the six user equipment's associated with the base station 110. The Table 1 is given below.
The processor 102 is configured to compute the entry for (i,j) i.e. ith row and jth column is computed by the precoder determination algorithm (PDA) corresponding to the user equipment and the column of the orthogonal vectors U which is given in the Table 1 which corresponds to the jth user equipment and ith column of U. Entries of the user equipment's are computed for 4*X i.e. 4*6 which are 24 locations of the Table 1. As an example, entry for the first user equipment corresponding to first row and first column of the table can be represented as [V1l, Θ1l], first user equipment corresponding to second row and first column can be represented as [V2l, Θ2l] where entries represent the outputs obtained by using precoder determination algorithm (PDA). Likewise, there are 22 more locations of the user equipment's which can be represented corresponding to their respective rows and columns in the table. The precoder determination algorithm (PDA) value for all the 24 entries is computed by the processor 102 which is configured with the precoder determination algorithm (PDA) by the following equation—
[VijΘij]=ψ[U,hj,i]
where hj is a channel matrix of user equipment j where hj represents a 4×2 matrix.
As an example, location for the user located in the first row and second column can be represented as below.
[V12Θ12]ψ[U,h2,1]
where j=2 represents second user equipment and i (i=1) is the parameter which represents the first column of the U matrix. Likewise, all other 23 locations can be represented by the precoder determination algorithm (PDA).
“[Vij,Θij]” is computed by precoder determination algorithm (PDA) for all 24 locations of the user equipment's in the table Out of 24 entries of the user equipment's the maximum entry Θij in each row of the table is selected and the corresponding bits transmitted by the user equipment's are decided as shown in the Table 2. In all the locations of the table, 4 maximum entries may be selected.
The Table 2 implies user equipment's with the maximum value of “®” are user equipment first, third and the sixth user corresponding to the locations are also marked. Each of the selected users is allowed to transmit “m” number of bits to the base station, where “m” is the number of maximum values of Θ out of “n” maximum values of Θ, corresponding to respective selected user. Further the Table 2 implies the first user equipment is transmitting two bits and the user equipment's third and sixth are transmitting one bit to the base station.
The transmit precoder of each of the selected users is a concatenation into column of precoder values of V corresponding to the “m” number of values of Θ. The precoder determination algorithm (PDA) value corresponding to the first user equipment which is transmitting two bits (m=2) to the base station is given below which is a 2*2 matrix:
V1=[V11V21]
The first user equipment which transmits two bits through two antennas to the base station is given below which is represented as a 2*1 matrix. The bits (m=1) transmitted by the first user equipment is can be decoded as below.
where d1,1 and d1,2 are the two bits transmitted by the first user equipment to the base station. The first user equipment transmits two bits through two antennas as V1d1.
The third user equipment transmits only one bit through precoder V43 as V43d3 through two antennas. Likewise, the sixth user equipment transmits only one bit through precoder V36 as V36d6 through two antennas. After selecting the best user equipment's, the IRC unit 108 uses the interference rejection combining (IRC) on the received signal Y at the base station across the four antennas which is given below.
Y=x1d1,1+x2d1,2+x3d3+x6d6
where x1=h1v11,
where x2=h1v21
where x3=h3v43
where x6=h6v36
d1,1=W1,1HY where W1,1H=x1HR1,1−1and R1,1=R−x1x1H
d1,2=W1,2HY where W1,2H=x2HR1,2−1and R1,2=R−x2x2H
d3=W3HY where W3H=x3HR3−1and R3=R−x3x3H
d6=W6HY where W6H=x6HR6−1and R6=R−x6x6H
where R=x1x1H+x2x2H+x3x3H+x6x6H+Δ2I
As discussed above, the processor is configured to accommodate more users in a base station transmitting on the same subcarrier. Likewise, the processor may be configured to accommodate more users wherein users from a plurality of base stations may be selected to transmit to the plurality of base stations in a same sub-carrier, wherein the plurality of base stations may be considered as a virtual single base station, whose number of antennas is a summation of the antennas of the plurality of base stations and users are a summation of the users of the individual base stations, wherein the above discussed method is applied to the virtual base station for selection of users. Further, upon selection of the best users, the IRC unit computes signal to noise ratio and decodes the input bits of each user in each of the plurality of base stations by applying Interference Rejection Combining function on “n1” signals received by the plurality of antennas of the plurality of base station and effective channel matrices of the selected users across the plurality of base station.
As an example, consider a scenario comprising 4 base stations wherein each base station comprises 4 antennas. There may be X user equipments associated with all the base stations where each user equipment comprises two antennas. Selection of maximum 16 users distributed across all the base stations may be considered wherein each user equipment is transmitting on a same sub-carrier. The selected users may transmit 16 bits on the same subcarrier. It may be noted that, each user equipment comprises two antennas and selected users may transmit one or more bits through two antennas. As discussed above, the U vector corresponding to 4 antennas was taken into consideration. Likewise, let a U vector corresponding to all 16 antennas of virtual base station be represented as U=[U1 U2 U3 . . . U16]. The Table 1 as discussed previously may be extended to 16 rows and there may be X columns corresponding to X users associated with all base stations. As discussed above, the channel matrix hj of jthuser is associated with all 16 antennas of all four base stations. The corresponding effective channel vectors of selected users may be computed considering channels to all the 16 antennas of all the base stations. The IRC unit uses the received signal Y across all 16 antennas and effective channel vectors of selected users to calculate SNR and decode bits transmitted by each selected user. It may be noted that selected users are distributed among all the four base stations.
In an embodiment, wherein all the four base stations wherein each base station comprising 4 antennas may be considered as a super base station (may refer to virtual base station) with 16 antennas. The X users distributed among 4 base stations may be considered to be associated with the super base station of 16 antennas. The steps 518-526 may be performed for the super base station comprising 16 antennas with associated X users.
In another embodiment, the vector U may be represented as U=[U1 U2 U3 U4] and
The column vector U1 U2 U3 U4 corresponding to a first base station of the super base station may be represented as follows.
where 0x is a column vector with x zero elements. The steps 518-526 may be performed considering the vector U and users for first base station may be selected after obtaining their effective channel matrices and precoder matrices using PDA. It may be noted that the channel matrix hj for this scenario corresponds to all the 16 antennas of all the four base stations. Likewise, the column vector U corresponding to a second base station may be represented as follows where U=[U1U2 U3 U4].
Likewise, the users from the second base station may be selected. The steps 518-526 may be performed to obtain their precoders V and to compute effective channel vectors. Likewise, users from other base stations may be selected and effective channel vectors are computed for all the selected users from all the base stations.
As discussed in previous scenario, IRC unit uses received signal Y across all the 16 antennas of 4 base stations to compute the SNR of all the selected users and their transmitted input bits may be decoded using effective channel vectors of all users.
As discussed above, the processor 102 is configured to calculate signal to noise ratio for at least a predetermined number of users in one or more of the plurality of combinations of N users. The processor 102 is further configured to reuse signal to noise ratios and associated calculations, which are previously calculated for the predetermined number of users, in the subsequent calculation of SNRs in the combinations of N possible users. Reusing previously calculated values of SNRs in subsequent calculations may reduce the need of complex computation algorithms and processing speed and memory.
The processor 102 may select N users among total X users associated with either one base station 110 or associated with all the base stations 110. Among XCN or XN combinations some of the users in one or more combinations may be repeated. The SNRs of the users repeated in a subsequent combination may be reused in a subsequent step to save memory and to restore processing capabilities of the processor 102. As an example, there may be two combinations of users, such as, SNRi, SNRj, SNRk, SNRl and SNRi, SNRj, SNRm, SNRn. The processor 102 may calculate SNRm, SNRn using IRC function while computing SNR of the first combination. Subsequently, the processor 102 may be configured to reuse or utilize the SNRs (i.e. SNRi, SNRj) in the computation of SNR for the second combination. The calculated SNRs are stored within the memory unit 104 of system 100.
Among a group of z users including users in one or more cells channel vectors corresponding to z user equipments are concatenated into the channel matrix H which is represented as H=[h1, h2, h3, h4 . . . hz]. The channel H is applied to a decomposition function (QR decomposition). The QR decomposes the channel matrix H as H=VG where G=[g1g2g3 . . . gz] where G is a column vector Using G's value, a value ψz is computed as provided below.
ψz=Σk=1zgkgkH+Δ2I.
ψi,z−1 is computed (as a result of Woodbury's identity) subsequently as provided below (for the ith user).
SNRi for the ith user is given below.
SNRi=giHψi,z−1gi
where i represents users wherein i=1, 2 . . . i−1,i, i+1, . . . z. Likewise, above computations are repeated for all the remaining users of the group z.
There may be the scenarios wherein number of antennas of the base station 110 may be greater than the number of users in the group z or number of users in the group z may be greater than the number of antennas. The processor 102 is configured to compute for both the scenarios. Now, consider the scenario where among the group of z users, one more user is added into the group. The group size z changes to (z+1) wherein one more user is added to the group of z users. Let's consider the scenario wherein the group size z is less than the number of antennas n i.e. z<n. The column vector gz+1 is computed as given below:
where gtemp is the temporary value of the vector g which is used to determine value of column vector g for the further computations corresponding to the (z+1) users and <hz+1, Vk> represents the dot product of the vectors wherein Vk is the kth column of V.
Now, let's consider the scenario wherein the number of users in a group are more than the number of antennas n of the base station 110 i.e. z≥n. The column vector gz+1 is computed as given below.
gz+1=VHhz+1
Once the required column vector gz+1 is computed then the IRC unit 108 is configured to compute SNR of the (z+1)thuser, where
SNRz+1=gz+1Hψz−1gz+1
The updated SNR values for the ith user in the group z when the group size increases to (z+1) is computed using Woodbury identity,
where SNR of ith user is computed as given below.
SNRi=giHψi,z+1−1gi
where i corresponds to number of users in the group z i.e. i=1, 2 . . . z. Likewise, SNRs are computed for all the users belonging to the group z. Finally, SNR is updated as
Consider the first exemplary system as discussed earlier wherein there is one base station 110 comprising four antennas. As an example, if we consider computation of SNRs for group size of 2 i.e. z=2 which implies there are 2 users belonging to the base station 110. There are xC2 such groups. Each group is represented as (a,b) such that a<b wherein a and b are user indices.
Now, consider the second exemplary system as we discussed earlier wherein there are four base stations 110a, 110b, 110c and 110d and each base station comprises four antennas and there may be one user in each base station and each base station belongs to a single cell. As an example, if we consider computation of SNRs for a group size z=2 i.e. number of users in the group z are 2 and number of base stations selected are 2. There may be X2 such groups. Each group is represented as (a,b) wherein a and b are user indices. It may be noted that a can be equal to b wherein a is user index corresponding to first cell and b is user index corresponding to second cell. It may be noted that number of users' in the group z are less than the number of antennas of the base station 110 i.e. z<n. The SNRs of users in the group z for this scenario can be computed using the methods discussed previously. Subsequently, group size is increased to 3 (a, b, c) and z=3 in this instance. The computation of SNRs is discussed for the scenario when the group size z increases which can be applied to compute SNRs for this scenario. The new user c is added from the third cell with the base station 110c.It may be noted that there are X3 such groups and group size z=3. Now, consider the scenario where group size z is increased from 3 to 4, N=4 (a, b, c, d) and z=4. It may be noted that in this scenario number of users in the group z are equal to the number of antennas of base station 110 i.e. z=n. This computations of SNRs for this scenario is discussed previously. Using these methods, we add a new user d from the fourth base station 110d corresponding to the fourth cell. It may be further noted that now there are X4 such groups where N=4. After determining the X4 groups, the SNRs for all the users in the X4 groups are computed.
The processor 102 is configured with the above discussed algorithm considering all the scenarios discussed which computes signal to noise ratio in such a way that overall signal to noise ratio for overall system is increased and increase in number of user equipment's communicating with the base stations should not result in significant loss of existing user equipment's in uplink transmission.
Referring to
As an example, let's consider the system 600 of
Now referring to step 602, considering the first user equipment belonging to the base station 110a with the channel vector g1 with the corresponding channel values as a, b, c and d associated with four antennas of the first base station 110a belonging to the first cell which can be represented as channel vector g1 as below. Likewise, channel vector
where a, b, c and d are channel values of the channel vector g1.
Now referring to step 604, the processor 102 determines at least 6 combinations (4C2=6) of 2 selected antennas to be selected from among 4 antennas from the base station 110a.The binary representation for the possible combinations of 2 antennas selected from 4 antennas for the first user equipment is given by ψ. Let the possible binary values for the 6 possible combinations are ψ1, ψ2, ψ3, ψ4, ψ5, Ω6 where ψ1=1100, ψ2=1010, ψ3=1001, ψ4=0110, ψ5=0101, ψ6=0011 and corresponding values of P with respect to binary values ψ1, ψ2, ψ3, ψ4, ψ5, ψ6 of 6 possible combinations of antennas be denoted by P1, P2, P3, P4, P5 and P6 where can be computed as P1=|a|2+|b|2 for ψ1=1100, P2=|a|2+|c|2 for ψ2=1010, P3=|a|2+|d|2 for ψ3=1001, P4=|b|2+|c|2 for ψ4=0110, P5=|b|2+|d|2 for Ψ5=0101, P6=|c|2+|d|2 for ψ6=0011. Let the maximum value among P1, P2, P3, P4, P5 and P6 be Pi. Assuming the maximum value Pi among the six values is P1 with the ψ1=1100. The antenna configuration among 16 antennas of all the base stations maybe denoted as X which can be represented as X=ABCD where A corresponds to the first base station, B corresponds to the second base station, C corresponds to the third base station and D corresponds to the fourth base station. If all the antennas of base station 110b are selected then B=F and if none of the antennas of the base station 110b are selected then B=0. Likewise, C and D can be represented as antenna configurations for the base stations 110c and 110d respectively. The maximum value of P1 with the value ψ1=1100 indicates that the antennas with the channel values as a and b are to be selected among the other possible combinations of antennas which gives the first set of antennas for the first user equipment belonging to the first base station as A=ψ1=1100.
Now referring to step 604, the processor may select more than one base stations other than the base station A wherein the antenna configuration for the base station A is already computed at step 604. The processor may select from the base stations B, C, D as the base station A is already selected. It may be noted that the processor is configured in such a way that while selecting the antennas from the B, C and D base stations, all the antennas of the corresponding selected base station are selected. As an example, if B is selected as the base station then antenna configuration for the base station B may be represented as X=For X=0. This concept is explained in detail in later steps.
Referring to step 608, the processor 102 is configured to compute the correlation function values for all the possible combination of values of channel vector for user equipment's of i and j for each user equipment belonging to one base station, where i=1,2,3,4 and j=1,2,3,4 where combination of values of (i,j) represent each user equipment for each of the base stations 110a, 110b, 110c and 110d.There can be 16 combination of values of (i,j) for each user equipment for each base station as (1, 1),(1,2),(1,3),(1,4),(2,1),(2,2),(2,3),(2,4),(3, 1),(3,2),(3,3),(3,4),(4, 1),(4,2),(4,3),(4,4) for which combination of values correlation function is computed by the processor 102. The channel vectors for each user equipment is represented as h1(X), h2(X), h3(X) and h4(X) corresponding to user equipment's first, second, third and fourth respectively with the combinations of antenna configuration (X) represents antenna selection from first, second, third and fourth base stations. The processor 102 may be configured to compute correlation function values for all the combination of values of (i,j) which is given as dot product of channel vectors hj(X) and hi(X) where X corresponds to base stations 110a, 110b, 110c and 110d which are represented as ABCD respectively. A set of antennas from the first base station 110a is represented by A=1100 corresponding to ψ1=1100 which depicts the antennas of the first base station are selected. The corresponding value of X which represents antenna configuration for the first base station is X=A000 which is computed at the step 604. It may be noted that the antenna configuration where antennas of the second base station are selected is given as X=0F00. Likewise, the antenna configuration where only antennas of the third base station 110c are selected is given as X=00F0 and for the antenna configuration for the fourth base station, antenna configuration is given as X=000F. The correlation function can be expressed by the relation as given below.
corr(i,j,X)=(hj(X)·hi(X)) is a dotproduct
The processor 102 may be further configured to compute 64 (16*4) correlation functions corresponding to 16 combinations of (i,j) corresponding to all the four antenna configurations (X) as discussed above which may be represented as (X=A000, X=0F00, X=00F0, X=000F) corresponding to base stations A, B, C and D respectively. Referring to step 610, the processor 102 may compute the correlation function values for other possible combinations of antenna configurations where possible combinations are represented by θ. The processor 102 may select the combination of values of θ such that θ corresponds to the possible (N-1)Cy combinations where (N−1) represents the number of base stations other than the selected first base station as the first base station is always selected assuming the user equipment belongs to the first station) where y corresponds to the number of base stations to be selected from (N−1) base stations. As an example, N corresponds to the number of base stations i.e. N=4 and (N−1) indicates the antenna configuration to be selected remaining (4-1) base stations where antenna configuration for the first base station is selected at step 604 and y(y=2) corresponds to the number of base stations to be selected from 3 base stations. The processor is configured to select antennas from the remaining (4-1) base stations. The number of combinations of θ can be (4-1)C2 combinations which gives 3 combinations where it indicates there may be two base stations to be selected from 3(4-1) remaining base stations in the system comprising four base stations where the first base is already selected belonging to the first base station. The possible combinations of values of θ representing the possible antenna configurations for the selected base stations are given below.
θ={X=AFF0,X=A0FF,X=AF0F}
It may be noted that if a base station other than the first base station is selected, all the antennas of that base station are also selected. As an example, the first value of θ where X=AFF0, clearly indicates that the first base station is selected and antenna configuration corresponding to the first base station is computed at step 604. For the base stations B (110b) and C (110c) all the antennas are selected. Likewise, it may be applied to all the values of θ with their respective antenna configurations X.
Referring to step 612, the processor 102 may be configured to split the correlation function for the first value of 0 given as the sum of correlation function values where the output of splitting the correlation function for the first value of 0 for X=AFF0 can be expressed as below.
corr(i,j,X=AFF0)=corr(i,j,A000)+corr(i,j,0F00)+corr(i,j,00F0)
The processor 102 may be configured to split the correlation function for all the 0 values into (y+1) correlation functions. There may be (2+1) 3 number of correlation functions. The three correlation functions obtained may be computed by reusing the recorded values of the correlation functions for all the possible 64(16*4) values which are computed at step 606. The Gram determinant matrices Dj for all values of j=1,2,3,4 may be computed by the processor 102 where Dj is determinant of a j×j matrix for all the values of j=1,2,3,4 wherein the (i,k)th elements of matrices are obtained by the dot product of (hk(X),hi(X)) where D1 is a 1×1 matrix, D2 is a 2×2 matrix, D3 is 3×3 matrix and D4 is a 4×4 matrix. D0=1.
Further, using the correlation and the determinant of the channel vectors, Gram determinant (ej) of the channel vectors may be computed and obtained using the expression as shown below.
Referring to step 614, Gram determinant (ej) of the channel vectors may be used to compute the SNR of the signals received at the base stations 110, transmitted through the channels. SNR is expressed in terms of G, where G=[g1, g2, g3, g4] and G=eH h, where e=[e1, e2, e3, e4] and h=[h1(X), h2(X), h3(X), h4(X)]. The SNR (z1) of a first user belonging to base station 110a may be computed using an IRC (interference rejection combining) unit 108 is expressed as shown below.
z1=SNR(1,X)=g1H[g2g2H+g3g3H+g4g4H+Δ2I]
where Δ2 is AWGN (additive white gaussian noise) and I is an Identity matrix of appropriate dimension.
Likewise, for the antenna configurations with X=A0FF, AF0F signal to noise ratios (SNR) Z2 and z3 may be computed. The maximum value among z1, z2 and z3 may be considered and the antenna configuration X corresponding to the maximum value among z1, z2 and z3 may be selected as the best configuration of antennas among the other antenna configurations.
Above computations may be provided for the first user equipment belonging to the first base station. Likewise, computations may be performed to select the best possible antenna configuration for all the user equipment's belonging to their respective base station.
Referring to
Considering N subcarriers, the processor 102 may be configured to compute Y1 and Y2 by using FFT matrix algorithm. A vector YF may be obtained by vector multiplication of conjugate of their data bits with the received signals over N subcarriers. YF is a column vector which is represented in such a way Y1 and Y2 form a 2×1 block column matrix. Further, the processor 102 may be configured to compute inverse of λ using block matrix inverse formula. The exemplary system may be configured to compute estimate of a vector H to decompose the vector into diagonal matrices. The vector H may be represented as a column matrix comprising H1, H2 to compute h1 and h2 over N subcarriers.
The channel values for the first user equipment across subcarriers 1, 2 . . . N may be a, b . . . d respectively. Likewise, channel values for a second user equipment across subcarriers 1, 2 . . . N may be a′, b′ . . . d′. In LTE, a Resource Block has N=12 subcarriers. If we consider two Resource blocks, then we have N=24 subcarriers. As an example, if one user equipment is transmitting through a set of subcarriers and if another user transmits across the same set of subcarriers which means at each subcarrier we have sum of the transmission by the two user equipment's.
At step 702, a first user equipment may transmit symbols across subcarriers 1, 2 . . . N. Likewise, the second user equipment may transmit symbols across subcarriers 1, 2 . . . N. At step 704, the received signal at subcarriers 1, 2 . . . N may be denoted as Y=h1 ⊗d1+h2 ⊗d2+n where ⊗ represents element by element multiplication of two vectors. The symbols across N subcarriers may be stacked into a vector which is denoted as d1. Similarly, for the second user equipment these symbols may be stacked into a vector which is denoted as d2.
Let the channel values for the first user equipment across subcarriers 1, 2 . . . N are a, b . . . d respectively and are stacked into a channel vector h1. Similarly, the channel values for the second user equipment across subcarriers 1, 2 . . . N are a′, b′ . . . d′ respectively and stacked into a channel vector h2. The processor 102 may be configured to estimate the channel values for the first and the second user equipment represented by h1 and h2 respectively on the received signal Y where the channel values of the first equipment i.e. (a, b . . . d) and the second user equipment i.e. (a′, b′, . . . d′) varies slowly across the subcarriers 1, 2, . . . N. The algorithm for estimating the channel values in such scenarios is discussed in detail.
At step 704, the processor 102 may be configured to compute the FFT of the N×1 subcarrier matrix for all the users. Let the FFT matrix function be denoted as F. At step 704, the processor 102 computes signals Y1 and Y2 using the FFT algorithm, by using the received signal “Y” across the subcarriers of the base station 110. Y1 and Y2 are provided below.
Y1=F*(Y⊗d1*)
Y2=F*(Y⊗d2*)
where d1* and d2* corresponds to conjugate of the data symbols transmitted by the first user equipment and the second user equipment respectively.
At step 706, the signals Y1 and Y2 computed in the previous step may be aligned as 2×1 block column matrices comprising Y1 and Y2. The output of this column matrix be denoted as YF which is expressed below.
At step 708, obtained column vector YF may be represented in terms of block diagonal matrices F1, F2 and λ where the matrices can be represented as given below.
where F1, F2 and λ are block diagonal matrices wherein element
is along diagonal for the F1 matrix and element F is along diagonal for the F2 matrix. ℏ is a block diagonal matrix wherein the sub blocks not along main diagonals are obtained by element by element multiplication of the data symbol transmitted by second user equipment d2 to the conjugate of the symbol ditransmitted by the first user. Identity matrix is along the diagonals of the block diagonal matrix of ℏ. The bar on d1 ⊗d2* is representation of the block matrix wherein first element obtained by the computation is not altered but remaining elements thus obtained by the computation are flipped, such that, last element of the matrix occupies the second place and thereby arranged in decreasing order of the column number it has occupied. As an example, if vector
then
where the second element of the matrix is flipped till the last element of the matrix whereas the first element of the matrix is not altered. Similarly,
At step 710, the processor 102 may use block matrix inversion algorithm and inverse of diagonal matrix to compute inverse of λ efficiently. It may be noted that the inverse of a diagonal matrix is a diagonal matrix where the diagonal elements are reciprocal of the elements of the diagonal of the original matrix. Similarly, matrix multiplication of the two diagonal matrices is the multiplication of both the diagonals. Similarly, addition of two diagonal matrices is the sum of the two diagonals is the sum of the diagonals.
At step 712, the channel vector H is estimated as follows:
At step 714, the channel value H may be represented as the 2×1 block column matrix with H1 and H2 as the elements of the block column matrix to compute the channel value h1 and h2 of the first user equipment and the second user equipment respectively which may be expressed as shown below.
h1 and h2 are the required channel values for the first user equipment and the second user equipment respectively estimated over the N subcarriers of the LTE system.
The processes described above is described as sequence of steps, this was done solely for the sake of illustration. Accordingly, it is contemplated that some steps may be added, some steps may be omitted, the order of the steps may be re-arranged, or some steps may be performed simultaneously.
The example embodiments described herein may be implemented in an operating environment comprising software installed on a computer, in hardware, or in a combination of software and hardware.
Although embodiments have been described with reference to specific example embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the system and method described herein. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.
Many alterations and modifications of the present invention will no doubt become apparent to a person of ordinary skill in the art after having read the foregoing description. It is to be understood that the phraseology or terminology employed herein is for the purpose of description and not of limitation. It is to be understood that the description above contains many specifications, these should not be construed as limiting the scope of the invention but as merely providing illustrations of some of the personally preferred embodiments of this invention.
Number | Date | Country | Kind |
---|---|---|---|
201641025446 | Jul 2016 | IN | national |
Number | Name | Date | Kind |
---|---|---|---|
8730788 | Dao | May 2014 | B2 |
20090252091 | Tang | Oct 2009 | A1 |
20130287132 | Taoka | Oct 2013 | A1 |
20150131753 | Maruta | May 2015 | A1 |
Number | Date | Country |
---|---|---|
WO-2016155758 | Oct 2016 | WO |
Number | Date | Country | |
---|---|---|---|
20200162116 A1 | May 2020 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15767356 | Apr 2018 | US |
Child | 16752707 | US |