The present invention relates generally to communications and, in particular, to interference cancellation in communication systems.
This section introduces aspects that may help facilitate a better understanding of the inventions. Accordingly, the statements of this section are to be read in this light and are not to be understood as admissions about what is prior art or what is not prior art.
Uplink transmissions (also referred to as reverse-link transmissions) in cellular networks comprising multiple base stations often suffer from excessive interference from out-of-cell transmissions. In such networks, typically, mobile stations (also referred to as, simply, mobiles) communicating with different base stations are scheduled for transmission independently by the respective base stations. We refer to the base station with which a mobile station is communicating as the latter's primary base station. When a mobile station is reasonably close to base stations other than its primary base station, it is likely to cause significant interference at those base station's receivers. The transmissions of the (interfering) mobile may not be decodable at the receivers of the base stations other than its primary base stations, which means that those receivers cannot employ local procedures to cancel the interference caused by the mobile. However, if the primary base station of the mobile station can decode the latter's transmissions, it can send the decoded information bits along with some additional information to the base stations where they are likely to have caused significant interference. Those base stations can then generate estimates of the signals received from the (interfering) mobile station and cancel them out from their respective aggregate received signals, thus improving the latter's decodability.
This, in essence, is what is involved in “successive interference cancellation,” which is presented in U.S. patent application Ser. No. 12/232,303, filed Sep. 15, 2008, entitled “Distributed Uplink Multi-Cell Successive Interference Cancellation for Cellular Networks,” naming inventors K. Balachandran, S. R. Kadaba, and K. Karakayali, hereinafter referred to as “[1]” and hereby incorporated by reference. One aspect of various embodiments presented in [1] is the assumption that there is a “global decoding order” that is known to and followed by the base stations constituting a cellular network. This global decoding order enables base stations with higher-quality received signals to decode their respective received signals first, so that they can send the decoded signals to other base stations for interference cancellation. However, such a global decoding order is often not available in cellular networks of even moderate sizes. Thus, an approach that is able to provide some of the benefits of successive interference cancellation but to larger networks would be desirable.
To address the need to provide improvements to known network interference cancellation techniques, methods and apparatuses are provided. In one method, a receiver attempts to decode a received signal which includes signaling from a wireless device transmission and at least one interfering transmission. If the receiver is unsuccessful in attempting to decode the received signal, decoded signaling that corresponds to the interfering transmission is requested. The receiver then uses the decoded signaling to decode the received signal. An article of manufacture is also provided, the article comprising a processor-readable storage medium storing one or more software programs which when executed by a processor perform the steps of this method. In addition, a receiving node of a communication system is provided. The receiving node is configured to communicate with other nodes of the system and is operative to perform this method as well.
Many embodiments are provided in which the method above is modified. In some embodiments, requesting decoded signaling comprises requesting decoded signaling from equipment associated with at least one cell/sector from a set of potentially interfering cells/sectors. In some embodiments, requesting decoded signaling comprises requesting decoded signaling from equipment associated with a cell/sector serving a wireless device corresponding to the at least one interfering transmission and having at least a threshold received signal strength at the receiver.
In some embodiments, requesting decoded signaling comprises sending a message to destination cell/sector equipment identifying at least one resource block in at least one slot for which decoded signaling is requested. This message may comprise a slot-index field which indicates a slot and a bit-map field having a bit for each resource block in the slot, and the bit value for each resource block may indicate whether decoded signaling is requested for that resource block or not requested for that resource block.
In some embodiments, the method further comprises receiving, at the receiver and in response to the requesting, decoded signaling from other cell/sector equipment that corresponds to the at least one interfering transmission. Here, receiving decoded signaling may comprise receiving, at the receiver and in response to the requesting, decoded signaling from a plurality of other cell/sector equipment that corresponds to the at least one interfering transmission, and using the decoded signaling to decode the received signal at the receiver may comprise using the decoded signaling from the plurality of other cell/sector equipment to decode the received signal at the receiver.
In some embodiments, requesting decoded signaling comprises determining an order of potential interferers corresponding to the at least one interfering transmission from strongest to weakest and requesting decoded signaling from equipment associated with a cell/sector serving the strongest potential interferer first.
Specific embodiments of the present invention are disclosed below with reference to
Simplicity and clarity in both illustration and description are sought to effectively enable a person of skill in the art to make, use, and best practice the present invention in view of what is already known in the art. One of skill in the art will appreciate that various modifications and changes may be made to the specific embodiments described below without departing from the spirit and scope of the present invention. Thus, the specification and drawings are to be regarded as illustrative and exemplary rather than restrictive or all-encompassing, and all such modifications to the specific embodiments described below are intended to be included within the scope of the present invention.
An allied set of issues addressed by embodiments of the present invention concerns the efficiency of the overall scheme for interference cancellation. Sending decoded information bits from one base station to another where they can potentially be used for interference cancellation increases the load carried by backhaul links. Since the capacity of backhaul links is an important consideration in the overall system design, it is imperative to ensure that the load on these links is kept to a minimum by sending the decoded information bits only to those base stations where they are likely to be useful for interference cancellation.
To that end, embodiments are presented herein that incorporate methods and protocols to determine when information bits decoded at a base station should be sent to another base station for interference cancellation. These methods and protocols may be implemented in a distributed manner, enabling a truly distributed scheme for network interference cancellation in which base stations carry out their actions independently, without relying on a global decoding order that directs them as to when they can begin to process their received signals.
The present invention can be more fully understood with reference to
The basic idea underlying many of the embodiments described herein is as follows. The receiver associated with each sector independently (in a totally distributed manner) attempts to decode the signals transmitted by mobile stations in that sector. In this, it uses only the signal samples collected by antennas associated with it. At the same time, it attempts to estimate channel coefficients associated with mobile stations in its own sector as well as those that are in its neighboring sectors. If the receiver is successful in decoding the signals transmitted by mobiles in its own sector, it passes them on to the higher layers and also holds on to them for some time in the expectation that they can be sent to receivers in its neighborhood to help them with interference cancellation. If the receiver is unsuccessful in decoding the signals transmitted by mobile stations in its own sector, it sends request messages to receivers in its neighborhood, asking them for their respective decoded signals. Such a request is sent to a receiver only if the channel estimate for the mobile station in the associated sector is of a good quality. (Since interference cancellation using a poor quality channel estimate does not lead to improved decodability, there is little point in requesting decoded data associated with mobile station whose channel estimate has a low signal-to-noise ratio.) This avoids movement of decoded data that is not useful for interference cancellation. In another embodiment of this invention, the determination of whether to pass decoded data from one sector to another is additionally based on the amount of decoded data to pass. In this way, one may achieve a desirable tradeoff between the benefit achieved by network interference cancellation and the backhaul capacity required to support it.
After receiving decoded data from one or more of neighboring base station receivers, the requesting receiver reconstructs the corresponding interfering signals using the associated channel estimates, and subtracts these reconstructed signals from the original signal samples to improve their Signal-to-Interference+Noise Ratio (SINR). The resulting samples are processed via standard decoding procedures to extract the signals transmitted by mobile stations in the associated sector. If this round of decoding is successful, the receiver, as in the previous round, passes on the decoded data to the higher protocol layers and saves a copy for interference cancellation at other receivers. Otherwise, as at the end of the previous round, it sends request messages to neighboring receivers. This procedure is repeated until either the signals are successfully decoded or the upper limit on decoding rounds is reached.
Note that this is a completely distributed procedure that does not require the presence of a global decoding order. As such, it can be implemented easily in a cellular network of any size. Also, because of the request-based protocol used in the opportunistic movement of decoded data, this approach substantially reduces the load on the backhaul links by avoiding the movement of data that is not likely to be useful for interference cancellation.
Once base station A decodes mobile station a's data signal, base station A may pass on the decoded data signal to base station B through backhaul links. Base station B (the base station performing cancellation) estimates the channel from mobile station a (an out-of-cell mobile), uses this channel estimate together with the decoded data signal (from mobile a) it receives from base station A to generate its estimate of the interference caused by mobile a, and then cancels this interference from its overall received signal to obtain an improved signal-to-noise ratio for mobile station b. This improvement is achieved at the cost of the additional backhaul overhead needed for base station A to exchange mobile station a's decoded data with base station B.
In order to implement successive interference cancellation (SIC) in multi-cell networks, an example embodiment in accordance with the description of [1] is provided below:
Consider a cellular network, such as the one illustrated in
Looking at
We assume that uplink transmissions use Orthogonal Frequency Domain Multiple Access (OFDMA) or Single Carrier-Frequency Domain Multiple Access (SC-FDMA) transmission technology. These technologies typically use slotted transmissions with at least loose synchronization between transmissions emanating from different devices participating in the system. Without loss of generality, the methods and apparatuses described herein may employ alternate methods of transmission. The spectrum available for uplink transmissions is divided into multiple sub-carriers or tones.
When a base station schedules uplink transmissions for a slot, it selects one or more mobile stations connected to it for transmission over that slot, and then allocates one or more resource blocks (associated with that slot) to each of them. For instance, as shown in diagram 400 of
Based on the transmission grants (for a given slot) received from their primary base stations, the mobile stations transmit their uplink signals as follows. Based on the MCS indicated in the transmission grant, the mobile station selects an appropriately sized chunk of information bits, and adds cyclic redundancy check (CRC) bits to it. The mobile station then encodes the information bits with CRC using the coding scheme indicated in the transmission grant, and uses the resulting coded symbols to modulate the modulation symbols in the resource blocks allocated to it. (Note that the modulation symbols in a resource block are divided into two subsets: bearer symbols and reference symbols. The reference symbols, also referred to as pilot symbols, are modulated with known signals (typically, symbols in a known sequence) and used by the base station receiver to generate channel estimates. The bearer symbols are the ones that are modulated by the coded symbols as described above.) The coded symbols may be interleaved before they are used to modulate modulation symbols. In an OFDMA system, the (possibly interleaved) coded symbols are used to directly modulate the bearer symbols in the frequency domain, whereas in an SC-FDMA system an extra processing step involving the computation of a Discrete Fourier Transform (DFT) is involved. Finally, in each symbol duration within the slot, the mobile station computes the time-domain representation of modulation symbols (modulated with coded symbols) associated with that symbol duration before transmitting the resulting signal waveform over the uplink channel.
Let us now consider the actions that take place at the various base station receivers in the cellular network over the course of a slot. During each symbol duration within a slot, the base station (i.e., the base station receiver) processes the received signal waveform by performing on it filtering, sampling and other processing operations to extract received signal samples corresponding to each modulation symbol associated with that symbol duration. These operations are repeated during each symbol period in the slot to extract received signal samples corresponding to modulation symbols transmitted in the slot. The received signal samples associated with all symbol durations within a slot are collected to form a received signal vector for the slot. Note that in the case of a base station with multiple receive antennas, a separate received signal vector is formed for each of its antennas. The operations involved in constructing a received signal vector are well known to those familiar with the art.
Before we describe the remaining actions carried out by a base station receiver in accordance with the present invention, we state what is assumed to be known to a base station receiver at this stage. Every base station, referred to by the index i, is assumed to have the following information at its disposal when it begins to process the received signal vector(s) associated with a slot:
At the end of a slot the base station receiver has constructed a received signal vector for each receive antenna of the base station. Each received signal vector has one entry for each modulation symbol in the slot; i.e. it has NT×NS entries since the uplink spectrum has been divided into NT tones and there are NS symbol durations within a slot.
At this stage, the base station receiver does the following: If resource block k (in the just-completed slot) has been assigned to mobile station j in its own cell, it processes the received signal samples corresponding to the reference symbols used by mobile station j and generates an estimate of the channel coefficient (see channel estimator 710, e.g.) for mobile station j over resource block k. The base station receiver generates such estimates of channel coefficients for every resource block in the just-completed slot which had been assigned to a mobile station in its own cell for uplink transmission. The example illustrated in
Let rj,k,i,q(RS) denote the (column) vector of received signal samples at receive antenna q of base station i corresponding to the reference symbols transmitted by mobile station j (in cell i) over resource block k during the just-completed slot, and let sj,k denote the (column) vector of reference symbols that were actually transmitted by mobile station j over resource block k. The channel estimate may be obtained from the vector of received signal samples corresponding to reference symbols using several well-known methods. In one such embodiment, the desired channel coefficient estimate ĥj,k,i,q is given by
ĥ
j,k,i,q
=s
j,k
†
·r
j,k,i,q
(RS)
/|s
j,k|2. (2)
where the symbol “†” represents the conjugate-transpose of the preceding vector.
Next, the base station receiver attempts to decode all of the coding blocks transmitted by mobile stations connected to it. Thus, referring to example of
In order to decode a coding block transmitted by one of the mobile stations in its cell, the base station receiver (see formatter 720 and MRC/MMSE processing unit 770, e.g.) first generates a vector of soft symbols from the corresponding received signal vector(s). The vector of soft symbols (sometimes also referred to as log-likelihood ratios) can be generated from the received signal vector(s) by processing the latter via well known techniques such as Maximal Ratio Combining (MRC), or Minimum Mean Squared Error (MMSE) processing, etc. All of these techniques use the channel coefficient estimates computed in the previous step.
The vector of soft symbols associated with a coding block along with details of the MCS used for that coding block are fed to a decoding device (see decoding engine 780, e.g.) to obtain an estimate of the information bits corresponding to the coding block. The base station receiver attempts to decode every one of the coding blocks transmitted by mobile stations connected to it. At this point, some of the coding blocks may be successfully decoded, while some may fail because of excessive noise or interference in the corresponding received signal. For a coding block, the failure to decode is indicated by the output of the decoder failing the CRC check. The information bits associated with successfully decoded coding blocks are passed on to higher protocol layers so that they can be forwarded to their ultimate destinations. At the same time, copies of these bits are kept in local buffers (see buffer 790, e.g.) so that they can be sent to neighboring base stations for interference cancellation as described later. As for the coding blocks that were not successfully decoded, the base station receiver stores the vectors of received signal samples associated with these coding blocks in local buffers (see buffer 730, e.g.). (Note that in the case of a base station with multiple receive antennas, vectors of received signal samples associated with each antenna are stored in local buffers.) The expectation is that it may be possible to refine these samples via interference cancellation if neighboring base stations are successful in decoding the signals causing interference to these samples.
Next, the base station receiver prepares a decoding state table for the just-completed slot. This table is essentially a column of integers with one entry for each resource block in the just-completed slot. The entries of this table are populated as follows: If a resource block in the just-completed slot was not used for transmission by any mobile station in the receiver's own cell, the corresponding entry is set to 0; if it fell within a coding block that was not successfully decoded, the entry corresponding to the resource block is set to 1; otherwise, i.e. if it fell in a coding block that was successfully decoded, the entry corresponding to the resource block is set to 2.
While the just-described decoding process is going on, for each resource block in the just-completed slot, the base station receiver tries to obtain estimates of channel coefficients for mobile stations belonging to its potentially interfering cells that might have been transmitting over that resource block. Recall that as stated previously, for each resource block, a base station is aware of the reference symbol sequences used by mobile stations in each of its potentially interfering cells when transmitting over that resource block. Using this information, a base station receiver, say the one associated with base station i, can obtain these estimates as follows: Let j be a mobile station in cell p that is in the set C(i), the set of potentially interfering cells from the standpoint of base station i. Let mobile station j be transmitting over resource block k in the just-completed slot. The (column) vector of received signals samples at antenna q of base station i that corresponds to the reference symbols transmitted by mobile station j over resource block k is denoted by rj,k,i,q(RS) whereas sj,k denotes the (column) vector of reference symbols that were actually transmitted by mobile station j over resource block k. Note that it is easy for base station i's receiver to construct the vectors rj,k,i,q(RS) and sj,k since, as stated earlier, it is aware of the reference symbol sequence used by mobile stations in cells belonging to set C(i) and how these reference symbols are transmitted. Once again, equation (1) can be used to obtain ĥj,k,i,q, an estimate of the channel coefficient for mobile station j transmitting over resource block k as seen at antenna q of base station i. Note that from the viewpoint of a base station receiver, the process of obtaining channel coefficients for mobile stations in other cells is no different from the process of obtaining channel coefficients for mobile stations in its own cell.
Next, for each resource block in the just-completed slot, the base station receiver computes an estimate of received signal strength for mobile stations in each potentially interfering cell transmitting over the resource block. Thus, for cell p, which is in the set C(i), the receiver device of base station i computes ŝp,k,i, its estimate of the received signal strength associated with the mobile in cell p that transmitted over resource block k, using the following relationship:
where R denotes the number of receive antennas at base station i, and the indicator j stands for the identifier of the mobile station in cell p that transmitted its data over resource block k. Note that in order to obtain the estimates ĥj,k,i,q and ŝp,k,i as shown above, base station i need not be aware of the actual identity of the mobile station j; all it needs to know is the reference symbol sequence being used by the mobile station in cell p that transmitted its data over resource block k. The base station repeats the above process (of computing estimates of received signal strength) for each resource block (represented by index k in equation (2)) and for each cell (represented by the index p in equation (2)) in its set of potentially interfering cells.
The base station receiver (corresponding to base station i) then prepares a “Request for Decoded Data” message (also referred to simply as request message) for cells in the set C(i). Each request message contains the following fields: an originating cell (i.e. base station) identifier, a destination cell identifier, a slot-index field and a bit-map with NR entries—one entry for each resource block in the slot. The meaning of the first two fields is clear. The third field, slot-index, contains the identifier of the slot whose received signals are being processed. Thus, in accordance with the present embodiment, when the receiver device associated with base station i prepares a request message meant for cell p in the set C(i), it fills the slot-index field with the identifier of the relevant slot. Entries of the bit-map are filled as follows: For resource block k, if ŝp,k,i, the estimate of the received signal strength from a mobile station in cell p transmitting over resource block k, is above an acceptance threshold T1 and if the entry corresponding to resource block k in the decoding state table associated with the just-completed slot is 1, the bit-map entry for resource block k in the request message is set to 1; otherwise, it is set to 0.
The idea here is that for any resource block, a base station should request signals for interference cancellation only if the corresponding received signal strength is not too low (as seen at the base station's receiver), and if the data associated with the resource block has not yet been decoded. The reason for imposing these conditions is the following: Clearly, if the data associated with a resource block is already decoded, there is no need for further processing the corresponding signals via interference cancellation or any other method. The reason for not asking for signals that are found to be weak at the base station's receiver is that when the received signal strength is low, the corresponding estimates of channel coefficients are likely to be rather noisy. As a result, an attempt at interference cancellation using these signals (in combination with the noisy channel estimates) is unlikely to lead to significant improvement in the signal-to-noise ratio (SNR) of the signals being decoded. By not requesting such signals from neighboring base stations, we reduce the load on the backhaul links, which is one of the objectives of various embodiments of the present invention.
In another embodiment of this invention, an additional field would indicate the maximum length of the decoded data. If the intended recipient of the message sees a 1 in the corresponding bit-map field, it would additionally compare the length of its decoded data to the value indicated in the field to determine if it should share its decoded data. The maximum length field may vary as a function of channel quality such that maximum values increase with improved channel qualities and vice versa. In this way, excessive backhaul is not wasted on links with relatively poor channel quality (and hence limited interference cancellation benefits).
The receiver device associated with base station i prepares a request message for each cell in C(i) as described above and sends it to the corresponding base station. While preparing a request message for a potentially interfering cell, if the base station finds that all entries in the bit-map contained in the message are zero, the base station does not send the message to that cell. This, too, helps reduce unnecessary traffic on the backhaul links as well as the wasting of processing capacity.
For each slot, a base station i also maintains a request table. This table contains a 2-dimensional integer array—it has one column for each cell p such that base station i is in C(p). That is, if base station (i.e., cell) i is a potentially interfering cell for cell p, then the request table maintained by cell i has a column associated with cell p. Each column of this table has NR entries, one for each resource block in the associated slot. At the end of a slot, when a base station receiver begins processing signal samples received over the slot, it creates a request table for that slot and initializes it by setting all entries in each column of the table to 0. (Note that the number of columns in this table as well as the association of columns with specific cells is static.)
The base station receiver now enters a wait state. In this wait state, it typically receives two kinds of messages: 1. Request messages from neighboring cells asking for decoded data that can be used for interference cancellation; and 2. Messages from neighboring cells carrying decoded data. We refer to the latter as decoded-data messages. (Note that the processing at different base stations does not take place in a synchronous manner. As a result, it is possible for a base station to receive a request message from another base station even before the former has finished the previously described processing and entered the wait state. The following will explain how a base station acts on receiving these messages in both cases—before entering the wait state and after entering the wait state.)
When a base station, say i, receives a request message from base station p, it knows that the latter is looking for decoded data for some of the resource blocks in the slot as indicated in the message. Specifically, if the entry corresponding to resource block k in the request message from base station p equals 1, it means that base station p is looking for decoded data for resource block k. Therefore, base station i will send the requested data to base station p if it has already decoded it and in some cases, based on the length of its decoded data. Since resource blocks do not always map to coding blocks in a one-to-one fashion, base station i responds to the request message from base station p in the following manner:
Consider the first case where base station i has not yet entered the wait state. In this case, using the bit-map contained in the request message from base station p, it updates the column of its own request table corresponding to base station p as follows: If the entry associated with a resource block in the column of the request table (corresponding to base station p) equals 2, it is left unchanged; otherwise it is set equal to the corresponding entry in the bit-map. After updating entries in the appropriate column of the request table, base station i continues with the processing it was engaged in before being interrupted by the arrival of the request message.
In the second case, i.e. where the request message from base station p arrives at base station i while the latter is in the wait state, base station i updates the entries of the appropriate column of the request table in the just-described manner, and then prepares a decoded-data message to be sent to base station p. We describe how base station i constructs this message using an illustrative example. To that end, consider the example shown in
In the example shown in
Diagram 510 indicates the state of the decoding state table of base station i after the first round of decoding. Clearly, since only the coding block spanning resource blocks 1 and 2 was successfully decoded at that stage, the entries corresponding to resource blocks 1 and 2 equal 2. The entries corresponding to resource blocks 4, 5 and 6 equal 1 because the corresponding coding block was not successfully decoded. The entry corresponding to resource block 3 equals 0 because that block was not used by any mobile station in cell i for transmission over the corresponding slot.
Diagram 520 shows the bit-map included in the request message received by base station i from base station p. Since base station p was unable to decode any coding block transmitted over the relevant slot, the entries corresponding to all resource blocks used by mobiles connected to base station p to transmit their data equal 1. The only entries that are 0 are the ones corresponding to unused resource blocks (in cell p).
Diagram 530 shows the column of base station i's request table corresponding to base station p immediately after base station i has received the request message from base station p. It can be seen that this diagram is identical to 520 because, since no coding blocks have been sent to base station p so far, base station i has merely copied the bit-map included in the request message received from base station p into the appropriate column of its request table before proceeding further.
Base station i, then, identifies all the coding blocks to be included in the decoded data message to be sent to base station p. In order to be included in the decoded data message, a coding block needs to meet three criteria: 1) It must include at least one resource block requested by base station p; 2) It must have been successfully decoded by base station i; and 3) It cannot have been previously delivered to base station p. Base station i uses the following procedure to identify such coding blocks: It compares its decoding state table (510) with the column of its request table corresponding to base station p (530), looking for resource block indices such that entries corresponding to them equal “2” in the decoding state table (510) and “1” in the appropriate column of the request table (530). In the example being considered, the only resource block that meets this requirement corresponds to resource block index 2. Since base station i is aware of the fact that this resource block was part of the coding block that spanned resource block indices 1 and 2, it decides to include that coding block in the decoded data message to be sent to base station p.
Thus, base station i prepares a decoded data message, including in it the information bits associated with the coding block that spanned resource blocks 1 and 2, wherein the information bits may be compressed to minimize the amount of data transmitted on backhaul links. It also includes the relevant details of the coding block (e.g., details of the MCS used) as well as its own identifier and the identifier of base station p in the appropriate fields of the message, and sends this message to base station p over the appropriate interface. After sending the message to base station p, base station i updates the entries in the column of the request table (540) corresponding to base station p as follows: For each coding block included in the just-sent decoded data message, set the entries corresponding to each resource block included in the coding block to 2; leave the rest of the entries unchanged.
The above procedure is followed to generate a decoded data message whenever a request message is received by a base station i in the “Wait” state. Also, after completing each round of decoding, base station i checks the status of all columns of its request table and the updated state of its decoding state table to see if it can send additional decoded data to one or more of the base stations that have unfulfilled or partially-fulfilled requests for decoded data. (This is done in order to respond to request messages that were received while the base station receiver was busy decoding its own coding blocks.) Once again, the procedure described above is followed to identify which, if any, coding blocks need to be sent to these base stations.
The other type of message that a base station may receive in the wait state is a decoded-data message from a base station to which it had, at some point in time in the past, sent a request message. When a base station, say base station i, receives a decoded-data message from another base station (say, p), it saves the message in a local buffer (see buffer 740, e.g.), referred to as decoded-data buffer, and goes back to the wait state. Note that in the embodiment of the invention being described here, by staying in the wait state for some time base station i attempts to collect decoded data associated with a number of potential interferers before attempting interference cancellation and decoding. This approach saves the number of decoding attempts a base station receiver makes before meeting with success.
In alternative embodiments, base station i may order the potential interferers from the strongest to the weakest based on their respective channel estimates and send request messages to the corresponding base stations one at a time in that order. After each such transmission of a request message, base station i may wait a certain amount of time to receive the corresponding decoded data. If the decoded data is received during that time, base station i immediately attempts interference cancellation (using the just received decoded data), followed by a decoding attempt. Base station i sends a request message to the base station corresponding to the next highest interferer only if the decoding attempt is unsuccessful or if base station i did not receive the decoded data before the end of the waiting period. These embodiments attempt to reduce the backhaul load at the expense of a few additional decoding attempts.
When base station i comes out of the wait state (such as on the expiry of a timer, referred to as a decoding timer), it begins a round of interference cancellation, followed by an attempt at decoding all of the coding blocks that were left in an undecoded state at the end of the previous round of decoding.
Let us consider how a base station (say, i) performs a round of interference cancellation followed by decoding. Base station i maintains a “cancellation table” for each slot. This cancellation table has as many rows as there are resource blocks in a slot and as many columns as there are potentially interfering cells from the viewpoint of cell i (i.e., one for each cell in the set C(i)). The cancellation table associated with a slot is initialized (by setting all entries to 0) at the end of the slot when the first round of decoding for the slot begins. If an entry in this table equals 1, it means that the corresponding resource block has been used for interference cancellation. (Conversely, if an entry equals 0, it means that the corresponding resource block is yet to be used for interference cancellation.) Because a coding block is used as a unit for decoding and coding blocks transmitted by mobile stations in different cells do not always line up exactly, base station i performs interference cancellation as described below.
Recall that the base station receiver had stored the received signal samples for all coding blocks that were not successfully decoded at the end of the previous round of decoding. Using the decoded data (from other base stations) received since the end of the previous round of decoding (and stored in the decoded data buffer), the base station receiver attempts to cancel interference from each of these undecoded coding blocks. The following example illustrates how this interference cancellation is carried out.
Consider the example illustrated by
Interference cancellation is performed separately on each undecoded coding block (of base station i). To show how it is done, consider the coding block spanning resource blocks 2, 3, and 4. Let us refer to this coding block as A. As one can see in
Let x(α) denote the vector of coded symbols associated with coding block α. Clearly, x(α) spans resource blocks 1 and 2. Let x(α)(1) and x(α)(2) denote the restrictions of x(α) to resource blocks 1 and 2, respectively. (That is, x(α)(1) is the part of x(α) that spans resource block 1 and x(α)(2) is the part that spans resource block 2.) Let ĥ(α)(1) and ĥ(α)(2) respectively denote the estimates of channel coefficients corresponding to resource blocks 1 and 2 for the channel between the mobile station that transmitted coding block α and base station i. Then, the vector of estimates of received signal values that can be attributed to coding block a can be written as
ŕ
(α)
=[ĥ
(α)(1) x(α)(1)|ĥ(α)(2) x(α)(2)], (3)
where the symbol “|” denotes the concatenation of the two vectors “ĥ(α)(1) x(α)(1)” and “ĥ(α)(2) x(α)(2).” Now, only the second part of the vector ŕ(α), namely ĥ(α)(2) x(α)(2), overlaps with the coding block A. Moreover, coding block A extends over resource blocks 2, 3 and 4, the latter two of which are free of any interference from coding block α. As a consequence, by adding all-zero vectors of suitable lengths to the part of {circumflex over (r)}(α) that overlaps with coding block A, the base station receiver constructs a cancellation vector v(α), given by
v
(α)
=[ĥ
(α)(2) x(α)(2)|0|0], (4)
where “0” represents an all-zero vector of suitable length. (In this case the two all-zero vectors in eq. (4) extend over resource blocks 3 and 4 respectively.) Note that the cancellation vector v(α) extends over resource blocks 2, 3 and 4 exactly as the coding block A does. Since the estimate of channel coefficient, ĥ(α)(2), is not perfect (because of the presence of noise and interference), one may use a suitable de-emphasis factor η(α)(2) to suppress the effect of noise and interference. In general, the de-emphasis factor is a monotonic function of the Signal-to-Interference+Noise-Ratio (SINR) associated with the channel estimate, approaching the limit of 1 for large SINR values. If a de-emphasis factor is used, the cancellation vector takes the form:
v
(α)=[η(α)(2) ĥ(α)(2) x(α)(2)|0|0]. (5)
In a similar manner, the base station receiver computes cancellation vectors v(β) and v(γ), respectively associated with the other two coding blocks (β and γ) that overlap with coding block A.
The base station receiver then cancels the interference (see interference cancellation engine 760, e.g.) caused by coding blocks α, β and γ from r(A), the vector of received samples associated with coding block A:
r(A)←r(A)−(v(α)+v(β)+v(γ)). (6)
We refer to the above vector as post-cancellation vector of received signal samples associated with coding block A. (Note that in case the base station has multiple receive antennas, it obtains such post-cancellation vectors of received signal samples for each of the receive antennas.)
Next, the base station receiver processes the post-cancellation vector of received signals (see MRC/MMSE processing unit 770, e.g.) via any one of the many well-known techniques (e.g. MMSE, MRC, etc.) to obtain a vector of soft symbols associated with the coding block A. The vector of soft symbols, along with details of the MCS used for that coding block, is then fed to the decoding device (see decoding engine 780, e.g.) to obtain an estimate of the information bits corresponding to coding block A. These two steps—obtaining the vector of soft symbols and decoding it—are identical to the corresponding steps performed by the receiver in the previous round of decoding. The only difference is that in the previous round of decoding the receiver had used the original vector of received signal samples associated with the coding block whereas in the current round of decoding the post-cancellation vector of received signal samples is used. Since the latter has an improved SINR (because of the cancellation of at least a part of the interfering signals), it is more likely to be successfully decoded.
Once again, when the receiver attempts decoding coding block A, there are two possible outcomes: 1) The decoding is successful, and 2) The decoding fails. If the base station receiver succeeds in decoding the coding block, it passes the information bits associated with the coding block to the higher protocol layers for forwarding them to the destination, saves a copy (see buffer 790, e.g.) of these bits (and details of the associated MCS) for including them in decoded-data messages that may have to be sent to other base stations, and updates the entries in the decoding-state table corresponding to the resource blocks associated with the coding block. (The last step involves setting these entries to 2.) If, on the other hand, the decoding fails, the receiver merely stores (see buffer 730, e.g.) the post-cancellation vector(s) of received signal samples associated with the coding block in place of the original vector(s) of received signal samples. (The post-cancellation vector(s) replaces the previously stored vector(s) of received signal samples in the local buffers.)
The above steps (of interference cancellation, decoding and post-decoding processing) are repeated for every coding block that was not successfully decoded in the previous round of decoding. At the end of the current round of decoding, for each of the potentially interfering cells, the base station receiver prepares a new request message exactly as before except that in this new message the bit-map entry corresponding to a resource block is 1 only if that resource block belongs to a coding block that has not been successfully decoded even after the current round of decoding. The rest of the bit-map entries are all equal to 0. The base station receiver sends these request messages to the corresponding base stations and enters the wait state. Note that the request messages sent after this round of decoding inform the base stations associated with potentially interfering cells of coding blocks that were successfully decoded in this round. This helps them avoid sending decoded data that is no longer needed (for interference cancellation).
Once again, as described earlier, the base station receiver receives decoded-data messages and request messages during the wait state. (It can receive these messages even while it is busy decoding its own coding blocks.) It responds to these messages as described earlier. At the end of the wait state, it attempts a new round of decoding on those coding blocks that were not successfully decoded during the previous round of decoding. This whole cycle is repeated a few times until either all coding blocks are successfully decoded or the number of cycles reaches a previously determined upper limit. At this point, the receiver clears all data, tables, buffers, etc., associated with the slot and informs the higher layers of coding blocks that could not be successfully decoded, thus ending all the physical layer processing associated with the slot being considered.
While the above description assumes that a particular mobile station's transmission is decoded at its primary base station, it is straightforward to generalize this opportunistic network interference cancellation method to the case where a plurality of serving base stations attempt to decode the mobile station's transmission. If any one of these plurality of base stations succeeds in decoding the mobile station's transmission, the decoded information may forwarded to upper layers either directly or via the primary serving base station. Furthermore, once the information is decoded by a base station, the rest of the serving base stations are notified to stop any further decoding attempts for the information that has already been decoded and the mobile station's transmission is then acknowledged.
The detailed and, at times, very specific description above is provided to effectively enable a person of skill in the art to make, use, and best practice the present invention in view of what is already known in the art. In the examples, specifics are provided for the purpose of illustrating possible embodiments of the present invention and should not be interpreted as restricting or limiting the scope of the broader inventive concepts.
Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments of the present invention. However, the benefits, advantages, solutions to problems, and any element(s) that may cause or result in such benefits, advantages, or solutions, or cause such benefits, advantages, or solutions to become more pronounced are not to be construed as a critical, required, or essential feature or element of any or all the claims.
As used herein and in the appended claims, the term “comprises,” “comprising,” or any other variation thereof is intended to refer to a non-exclusive inclusion, such that a process, method, article of manufacture, or apparatus that comprises a list of elements does not include only those elements in the list, but may include other elements not expressly listed or inherent to such process, method, article of manufacture, or apparatus. The terms a or an, as used herein, are defined as one or more than one. The term plurality, as used herein, is defined as two or more than two. The term another, as used herein, is defined as at least a second or more. Unless otherwise indicated herein, the use of relational terms, if any, such as first and second, top and bottom, and the like are used solely to distinguish one entity or action from another entity or action without necessarily requiring or implying any actual such relationship or order between such entities or actions.
The terms including and/or having, as used herein, are defined as comprising (i.e., open language). The term coupled, as used herein, is defined as connected, although not necessarily directly, and not necessarily mechanically. Terminology derived from the word “indicating” (e.g., “indicates” and “indication”) is intended to encompass all the various techniques available for communicating or referencing the object/information being indicated. Some, but not all, examples of techniques available for communicating or referencing the object/information being indicated include the conveyance of the object/information being indicated, the conveyance of an identifier of the object/information being indicated, the conveyance of information used to generate the object/information being indicated, the conveyance of some part or portion of the object/information being indicated, the conveyance of some derivation of the object/information being indicated, and the conveyance of some symbol representing the object/information being indicated. The terms program, computer program, and computer instructions, as used herein, are defined as a sequence of instructions designed for execution on a computer system. This sequence of instructions may include, but is not limited to, a subroutine, a function, a procedure, an object method, an object implementation, an executable application, an applet, a servlet, a shared library/dynamic load library, a source code, an object code and/or an assembly code.