Alternate feedback types for downlink multiple user MIMO configurations
09629128 ยท 2017-04-18
Assignee
Inventors
- Sudhir Srinivasa (Campbell, CA)
- Hongyuan Zhang (Fremont, CA)
- Rohit U. Nabar (Sunnyvale, CA)
- Hyukjoon Kwon (San Diego, CA)
Cpc classification
H04W72/20
ELECTRICITY
H04W48/16
ELECTRICITY
International classification
H04L25/02
ELECTRICITY
Abstract
A method in a communication network includes obtaining descriptions of a plurality of communication channels each communication channel associated with a different one of a plurality of receivers; and generating a plurality of steering vectors, one for each of the plurality of receivers, using the descriptions of the plurality of communication channels; wherein each steering vector is used to transmit data to a corresponding one of the plurality receivers via a plurality of antennas and over a corresponding one of the communication channels simultaneously and wherein each steering vector is used to communicate data on a different one of the plurality of communication channels, and wherein each steering vector is generated to reduce interference on a corresponding communication channel caused by simultaneous transmission of data on other communication channels.
Claims
1. A method, comprising: receiving, at an access point device, a plurality of beamsteering feedback frames from a plurality of client devices in connection with a procedure for generating respective steering matrices for performing multiple user communications with the plurality of client devices, including receiving a first beamsteering feedback frame from a first client device, the first beamsteering feedback frame including i) first compressed beamsteering information corresponding to a first communication channel between the access point device and the first client device and ii) an indication of a preferred number of streams to be used when the access point performs single user beamformed communications with the first client device; generating, at the access point device, the respective steering matrices using compressed beamforming information included in the plurality of beamsteering feedback frames, including using the first compressed beamsteering information to generate a first steering matrix for transmitting to the first client device as part of a multiple user beamformed transmission to the plurality of client devices; generating, at the access point device, a second steering matrix for transmitting to the first client device as part of a single user beamformed transmission using the first compressed beamsteering information; and using, at the access point device, the indication of the preferred number of streams in the first beamsteering feedback frame to determine how many streams to utilize when transmitting to the first client device as part of a single user beamformed transmission.
2. The method of claim 1, wherein: the first compressed beamsteering information includes a first compressed beamsteering matrix; and the first beamsteering feedback frame further includes an indication of a number of columns of the first compressed beamsteering matrix.
3. The method of claim 1, wherein: the first compressed beamsteering information includes a first compressed beamsteering matrix corresponding to a singular value decomposition (SVD) of a channel estimation matrix corresponding to the first communication channel between the access point device and the first client device.
4. The method of claim 1, wherein: receiving the plurality of beamsteering feedback frames from the plurality of client devices further includes receiving one or more second beamsteering feedback frames from one or more second client devices, the one or more second beamsteering feedback frames including one or more respective second compressed beamsteering information corresponding to one or more respective second communication channels between the access point device and the one or more respective second client devices; and generating the first steering matrix includes using the one or more respective second compressed beamsteering information in order to reduce interference to the one or more respective second client devices when using the first steering matrix to transmit to the first client device as part of the multiple user beamformed transmission to the plurality of client devices.
5. The method of claim 1, further comprising: transmitting, by the access point device, a sounding packet to the plurality of client devices; wherein the plurality of beamsteering feedback frames from the plurality of client devices include compressed beamsteering information determined by the plurality of client devices based on reception of the sounding packet at the plurality of client devices.
6. An apparatus, comprising: a wireless network interface device of an access point device, the wireless network interface device configured to receive a plurality of beamsteering feedback frames from a plurality of client devices in connection with a procedure for generating respective steering matrices for performing multiple user communications with the plurality of client devices, including receiving a first beamsteering feedback frame from a first client device, the first beamsteering feedback frame including i) first compressed beamsteering information corresponding to a first communication channel between the access point device and the first client device and ii) an indication of a preferred number of streams to be used when the access point performs single user beamformed communications with the first client device; wherein the wireless network interface device includes a steering matrix controller configured to: generate the respective steering matrices using compressed beamforming information included in the plurality of beamsteering feedback frames, including using the first compressed beamsteering information to generate a first steering matrix for transmitting to the first client device as part of a multiple user beamformed transmission to the plurality of client device, and generate a second steering matrix for transmitting to the first client device as part of a single user beamformed transmission using the first compressed beamsteering information; and wherein the wireless network interface device is further configured to use the indication of the preferred number of streams in the first beamsteering feedback frame to determine how many streams to utilize when transmitting to the first client device as part of a single user beamformed transmission.
7. The apparatus of claim 6, wherein: the first compressed beamsteering information includes a first compressed beamsteering matrix; and the first beamsteering feedback frame further includes an indication of a number of columns of the first compressed beamsteering matrix.
8. The apparatus of claim 6, wherein: the first compressed beamsteering information includes a first compressed beamsteering matrix corresponding to a singular value decomposition (SVD) of a channel estimation matrix corresponding to the first communication channel between the access point device and the first client device.
9. The apparatus of claim 6, wherein: the wireless network interface device is further configured to receive one or more second beamsteering feedback frames from one or more second client devices, the one or more second beamsteering feedback frames including one or more respective second compressed beamsteering information corresponding to one or more respective second communication channels between the access point device and the one or more respective second client devices; and the steering matrix controller is further configured to use the one or more respective second compressed beamsteering information to generate the first steering matrix in order to reduce interference to the one or more respective second client devices when using the first steering matrix to transmit to the first client device as part of the multiple user beamformed transmission to the plurality of client devices.
10. The apparatus of claim 6, wherein: the wireless network interface device is further configured to transmit a sounding packet to the plurality of client devices; wherein the plurality of beamsteering feedback frames from the plurality of client devices include compressed beamsteering information determined by the plurality of client devices based on reception of the sounding packet at the plurality of client devices.
11. The apparatus of claim 6, wherein wireless network interface device comprises a plurality of transceivers.
12. The apparatus of claim 11, further comprising: a plurality of antennas coupled to the plurality of transceivers.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1)
(2)
(3)
(4)
(5)
(6)
(7)
DETAILED DESCRIPTION
(8) In embodiments described below, a wireless network device such as an access point (AP) of a wireless local area network (WLAN) transmits independent data streams to multiple client stations simultaneously via an antenna array. To reduce interference at a receiving station due to transmissions from the AP to one or more other stations, the AP develops respective transmit (Tx) beamsteering (hereinafter, steering) vectors for downlink transmissions to each station. In an embodiment, the AP develops a Tx steering vector for a certain station using a description of the wireless communication channel between the AP and the station, as well a description of at least one other wireless communication channel between the AP and another station. In another embodiment, the AP uses the description of the wireless channel between the AP and a plurality of stations to develop a Tx steering vector for each station. At various points throughout this description, examples are described using the term beamsteering. However, it will be appreciated that the these beamsteering techniques may alternatively or in some examples be characterized as beamforming techniques, and vice versa.
(9) Thus, in some embodiments, e.g., in some explicit beamforming embodiments, an AP obtains a description of several wireless communication channels (hereinafter, channel descriptions) through which the AP transmits data to corresponding stations. As discussed below, the AP uses the channel descriptions to generate Tx steering vectors so as to cancel or minimize known interference at each station as well as interference between space-time streams at each station. In at least some of these embodiments, the AP develops multiple Tx steering vectors corresponding to different stations at the same time. That is, the client device may feedback to the AP a channel estimation, i.e., some form of description of a channel estimate (including uncompressed/compressed steering vectors, null space vectors, etc.). The AP receives the information from all the clients and determines its final steering vectors.
(10) In other examples, e.g., in some implicit beamforming embodiments, each of the clients sends packet data to the AP, which then performs channel estimation for channels for each of the different clients, from which final steering vectors are determined.
(11)
(12) The WLAN 10 includes K client stations 25, each station 25-i equipped with N.sub.i antennas. Although three client stations 25 are illustrated in
(13) A client station 25-1 includes a host processor 26 coupled to a network interface 27. The network interface 27 includes a MAC unit 28 and a PHY unit 29. The PHY unit 29 includes N.sub.1 transceivers 30, and the N.sub.1 transceivers 30 are coupled to N.sub.1 antennas 34. Although three transceivers 30 and three antennas 34 are illustrated in
(14) In the illustrated embodiment, the AP 14 is configured to transmit multiple spatial streams simultaneously to the client stations 25-1, 25-2, and 25-3, so that each of client stations 25-i receives data via L.sub.i spatial streams. For example, the client station 25-1 receives data via three (i.e., L.sub.1=3) spatial streams. Although in this example L.sub.1=N.sub.1, a client station 25-i in general can utilize fewer spatial streams than the number of antennas with which the client station 25-i is equipped. Further, when space-time coding is employed, the multiple spatial streams are sometimes referred to as space-time streams. If the number of space-time streams is less than the number of transmit chains, spatial mapping is employed, in some embodiments.
(15) In an embodiment, the AP 14 communicates with the client station 25-1 over a multiple input, multiple output (MIMO) channel defined, at the one end, by the array including the antennas 24-1, 24-2, and 24-3 and, at the other end, by the array including the antennas 34-1, 34-2, and 34-3. For this example, the MIMO channel can be described by a three-by-three channel matrix H.sub.1 that specifies, in each element, a channel gain parameter for a stream defined by the corresponding transmit antenna and a receive antenna and a channel phase between the corresponding pairs of antennas. Similarly, the AP communicates with the clients 25-2 and 25-3 via MIMO channels described by matrices H.sub.2 and H.sub.3, respectively. In at least some embodiments, the dimensionality of a matrix H.sub.i describing a MIMO channel between the AP 14 and a client station 25-i is N.sub.iN.sub.T.
(16) For protocols like 802.11n, which support transmit beamforming in an optional mode, or protocols like 802.11ac, which support transmit beamforming to multiple users simultaneously, the AP 14 will steer the downlink channel, described by the channel descriptor, H.sub.i, to an intended receiver station using the one or more spatial streams (L.sub.i), where such steering improves the signal-to-noise ratio at the intended station. Beamforming generally requires (at least partial) channel knowledge at the AP, where that channel knowledge may be obtained at the AP through explicit beamforming, in which the receiver station communicates through a feedback packet the channel knowledge obtained from a sounding packet form the AP, or through implicit beamforming, in which the station sends a sounding packet on the reverse link to the AP, which then determines a steering matrix.
(17) With respect to
(18) Therefore, in an embodiment, communication is modeled as though the AP 14 would apply a respective steering vector W.sub.i of dimensionality N.sub.TL.sub.i to a transmit symbol vector x, for transmitting the signal via the corresponding channel H.sub.i. Thus, when the AP 14 simultaneously transmits data to stations 25-1, 25-2, . . . 25-K, the signal received at the client station 25-i can be expressed as
(19)
As illustrated by Eq. 1, the received signal would include an intended component, an interference component due to signals intended for other client stations, and a noise component (expressed as a vector n.sub.i of dimensionality N.sub.i1). Eq. 1 also can be written as
(20)
Further, the signals y.sub.1, y.sub.2, . . . y.sub.K can be stacked together to define an aggregate receive vector y:
(21)
(22) To improve the overall throughput of the WLAN 10, it is desirable to reduce the interference components as much as possible for as many stations as possible, preferably without attenuating the intended components. To this end, in other embodiments, the DL SDMA controller 19 develops the aggregate steering matrix W (that includes the individual vectors W.sub.i, W.sub.2, . . . W.sub.K) so as to achieve a configuration optimal for the overall group of K client stations 25, i.e., with a reduction in the interference between the AP and each station, based on simultaneous communications with the other stations. In other embodiments, the DL SDMA controller 19 develops vectors W.sub.i individually (e.g., sequentially), but still such that any interference from other stations is reduced or canceled. It is noted that the reduction of interference could be for all or fewer than all of the receiver stations. For example, the DL SDMA controller 19 may use channel information to reduce interference for only the highest priority user, those users having priority above a certain threshold level, or the users in their order of priority. That is, in some embodiments, the amount of interference reduction will depend upon how the interference reduction is executed. Further still, the reduction in interference described herein is but an example of how the channel information may be used. The DL SDMA controller 19 may use the channel information to optimize any suitable metric. Even further still, while these examples are discussed in reference to the DL SDMA controller 19, it will be understood that these techniques may be partially implemented at one or more of the client stations 25-i, i.e., in conjunction with the channel estimation controller 40.
(23) Referring to
(24) In an embodiment, a steering vector controller 60 receives channel descriptions from a channel estimation unit 62 to develop steering vectors W.sub.i, W.sub.2, . . . W.sub.K that are supplied to the spatial steering unit 64. According to an embodiment, each channel description includes channel gain parameters (which may be complex numbers) for various streams defined by transmit and receive antennas. A channel description in some embodiments is represented in a matrix format. In some embodiments, the multiple station channel estimation unit 62 performs measurement of one or several parameters associated with the physical channel to develop channel state information (CSI) or another metric used for determining steering vectors W.sub.i, W.sub.2, . . . W.sub.K. The AP 14 may obtain channel descriptions of a downlink channel between the AP 14 and each of the stations, 25-1 . . . 25-K, through obtaining a CSI feedback determined at and provided from each of the stations, 25-i. For example, for explicit beamforming, the channel estimation block 62 is implemented on the client station 25-I, e.g., through the channel estimation controller 40, where the channel estimation information is determined, for example, in response to a sounding packet from the AP. In some embodiments, the AP sends different sounding packets to each of the client devices, e.g., in a multicast manner. In any event, the client device 25-i transmits its determined channel estimation information to the AP 14, where the steering vector controller 60 is contained. For CSI feedback, for example, the AP 14 sounds a downlink channel, using one or more spatial streams, L.sub.i, to each of the stations separately, from which each client then estimates its own channel from the received sounding packet and feeds back a quantized version of the estimated channel. In some examples, for the channel estimation unit 62 and steering vector controller 60 to develop steering vectors W.sub.i, W.sub.2, . . . W.sub.K, in explicit beamforming, the channel estimation unit 62 receives feedback signals from each of the stations, so that the DL SDMA controller 19 can properly determine the appropriate steering vectors that minimize or reduce interference at each station. Therefore, in a CSI feedback implementation, the channel estimation unit 62 receives CSI feedback from all stations.
(25) For implicit beamforming, the channel estimation unit 62 is implemented at the AP. In an embodiment, each station 25-i sends an uplink sounding packet to the AP 14, which sounding packets are received at the channel estimation unit 62. The channel estimation unit 62 performs the channel estimation in response and communicates with the steering vector controller 60 directly, where the controller 60 determines the steering vectors for each client device for reduced interference. Thus, in an example implicit beamforming embodiment, the channel estimation unit 62 at the AP 14 estimates the downlink channel based on received uplink sounding packets from the stations 25-I, and without a feedback signal
(26) While CSI feedback does not involve the determination of any steering matrix computation at the station end, the amount of information fed back is generally quite large. Therefore, while CSI feedback is more useful in beamforming protocols like 802.11n, the throughput of CSI feedback may be considered prohibitively high for MUMIMO protocols, such as 802.11ac, which can have 8 or more transmit antennas and transmit to 4 or more receiver stations simultaneously.
(27) Therefore, in some examples, the multiple station channel estimation unit 62 develops steering vectors W.sub.i, W.sub.2, . . . W.sub.K based on feedback information other than CSI feedback. In general, the channel estimation unit 62 can implement any suitable technique for developing channel descriptions, including those currently known to those of ordinary skill in the art. Described below, however, are additional alternative feedback information types the channel estimation unit 62 receives, including steering matrix feedback, a null-space feedback, and a hybrid feedback scheme.
(28) Applying the techniques described herein, the steering vector controller 60 in an embodiment generates the steering vectors W.sub.i, W.sub.2, . . . W.sub.K concurrently in view of multiple channel descriptors H.sub.1, H.sub.2, . . . H.sub.K to minimize (or, at least, attempt to minimize) interference at each station, in particular interference from communication with other stations. With feedback information and channel estimation unit 62, the steering vector controller 60 can implement any known techniques to calculate the steering vectors, including a zero-forcing (ZF) technique, a minimum mean square error (MMSE) technique, a leakage suppression (LS) technique, and a block nullification (BN) technique. In embodiments where the AP is only communicating with a single station, the controller 60 may use a single-user beamforming (SU-BF) technique.
(29) With continued reference to
(30) In some embodiments, feedback information sent from the stations to the AP 14 is a feedback steering matrix, V.sub.k, sent either in a compressed or uncompressed form. After receiving a sounding packet on a downlink channel from the AP 14, the station computes the full channel estimate, e.g., through known techniques, from which each station computes the beamforming steering matrix, V.sub.k, for example at the channel estimation controller 40. Unlike 802.11n, however, in MUMIMO protocols, like 802.11ac, the AP 14 cannot directly apply the feedback steering matrix V.sub.k, as the steering matrix for a particular station K, because of the need for the AP to simultaneously communicate with other stations. Therefore, as illustrated in the example of
(31)
(32) At a block 102, the AP 14 transmits sounding packets on different spatial streams to multiple different stations. Two examples are discussed, one in which the AP 14 sends sounding packets to two stations, K=2, i.e., 25-1 and 25-2, and another in which the AP sends sounding packets to three stations, K=3, i.e., 25-1, 25-2, and 25-3. In other examples, the AP 14 transmits sounding packets to any number of users, K=3, 4, etc.
(33) In some embodiments, at a block 104, as may be implemented by the channel estimation controller 40, each of the stations 25-1 and 25-2 decomposes the received sounding packet, for example, using a singular value decomposition (SVD) on the received downlink channel. In other examples, other techniques for handling the received sounding packet may be used in place of SVD. Station 25-1 determines its feedback steering matrix V.sub.1; while station 25-3 determines its feedback steering matrix, V.sub.2. In some embodiments, the feedback steering matrices, V.sub.K, may be determined from all of the spatial streams, L.sub.i, used to send the sounding packet on the downstream link. In other embodiments, each station uses a subset of the spatial streams, L.sub.i, to determine its corresponding feedback steering matrix.
(34) The method 100 may operate in a compressed or uncompressed configuration. In an uncompressed configuration, the feedback steering matrices are sent to the AP 14 without compression; while in a compressed configuration, the matrices are sent to the AP 14 in the form of angles representing compressed versions of the feedback steering matrices. In either case, at the block 104, each of the stations, 25-1 and 25-2 in the 2 station example, sends their determined feedback steering matrix, V.sub.i, to the AP 14, which obtains descriptions of the downlink channels from each of the stations at a block 106 that is, in some embodiments, at least partially execute by the channel estimation unit 62.
(35) At a block 108, as may be implemented by the steering vector controller 60, he AP 14 determines steering vectors, W.sub.i,W.sub.2, . . . W.sub.K, based on the received feedback steering matrices, V.sub.K, from each of the stations. In an example implementation in which 2 stations, 25-1 and 25-2, provide feedback steering matrices, V.sub.1 and V.sub.2, respectively, the block 108 may determine the steering matrices as follows. A computer channel matrix, H.sub.K, for each of the stations is related to the feedback steering matrix, V.sub.K, as follows:
H.sub.1=U.sub.1D.sub.1V.sup.T.sub.1 and H.sub.2=U.sub.2D.sub.2V.sup.T.sub.2
The received signal at station 25-1 is y.sub.1 and at station 25-2 is y.sub.2, expressed as follows:
y.sub.1=H.sub.1(W.sub.1x.sub.1+W.sub.2x.sub.2)+n.sub.1=U.sub.1D.sub.1V.sup.T.sub.1(W.sub.1x.sub.1+W.sub.2x.sub.2)+n.sub.1 (Eq. 4)
y.sub.2=H.sub.2(W.sub.1x.sub.1+W.sub.2x.sub.2)+n.sub.2=U.sub.2D.sub.2V.sup.T.sub.2(W.sub.1x.sub.1+W.sub.2x.sub.2)+n.sub.2 (Eq. 5)
(36) To completely avoid interference at both the users, the AP 14 determines steering matrices that simultaneously satisfy the following conditions:
V.sup.T.sub.1W.sub.2=0 V.sup.T.sub.2W.sub.1=0
That is, the AP 14 selects the columns that lie in the null space of V.sub.1 and V.sub.2 and thereby null the interference at each of the users. For example, W.sub.1 will lie in the null space of V.sub.2 and vice versa.
(37) In another example implementation in which 3 stations, 25-1, 25-2, and 25-3, provide feedback back steering matrices, V.sub.1, V.sub.2, and V.sub.3 respectively, the block 108 may determine the steering matrices using the following expressions:
(38)
The AP 14 can thus determine the three steering matrices that simultaneously satisfy the following conditions:
(39) TABLE-US-00001 V.sup.T.sub.1[W.sub.2W.sub.3] = 0 V.sup.T.sub.2[W.sub.1W.sub.2] = 0 V.sup.T.sub.2[W.sub.1W.sub.2] = 0
The optimization metric applied at block 108 is interference nulling at each of the stations. The AP 14, however, may use any suitable optimization in response to the multiple received feedback steering matrices. In some examples, the AP 14 can use a more complicated decision metric, such as choosing steering vectors to maximize the sum capacity or minimize the average mean square error (MSE) at each receiver, etc. Other decision metrics including zero-forcing, and leakage suppression. The steering vector controller 60 at least partially executes the block 108, in some embodiments.
(40) At the block 108, the steering vectors for each of the stations W.sub.1, W.sub.2, . . . W.sub.K are concurrently generated in view of the multiple channel descriptions obtained at the block 106. In an example scenario, three steering vectors for use with three receiving stations are concurrently generated in view of the three channel descriptions corresponding to the three channels via which data is simultaneously transmitted to the stations.
(41) In the method 100, each station feeds back to the AP 14 the full set of vectors for the corresponding steering matrix, a ranging feedback. In other embodiments, instead of feeding back the entire steering matrix, the station will feed back a set of vectors, i.e., null-steering vectors, spanning the null space of the corresponding feedback steering matrix, V.sub.K, in particular, a null space feedback signal formed of a set of the vectors in the steering matrix, V. An example method 300 is illustrated in
(42)
(43) At block 202, an indication (e.g., mathematical description) of a first null-steering vector for a communication channel between the AP and the first station is received. The first null-steering vector corresponds to a null-space projection of the first communication channel. In other words, for a communication channel described by H.sub.1, the first null-steering vector is a vector that the AP 14 can apply to completely or nearly completely attenuate a signal a station will receive via the communication channel described by H.sub.1. The AP 14 thus can use the null-space steering vector for a first station to avoid having that first station interfere with communications to a second station. At block 204, an indication of a second null-steering vector for a communication channel between the AP and the second station is received. Similar to the first null-steering vector, the second null-steering vector is a vector that the AP can apply to completely or nearly completely attenuate a signal a station will receive via the communication channel described by H.sub.2. Both blocks 202 and 204 are illustrated separately but may be implemented simultaneously and at least partially using the channel estimation unit 62.
(44) At blocks 206 and 208, steering vectors for use in simultaneous downlink transmissions to the first station and the second station are generated using the first null-steering vector and the second null-steering vector. In particular, the steering vector W.sub.1 for use with the first station and the channel described by H.sub.1 is assigned the value of the second null-steering vector, and the steering vector W.sub.2 for use with the second station and the channel described by H.sub.2 is assigned the value of the first null-steering vector. In this manner, a pair of transmit steering vectors W.sub.1 and W.sub.2 is developed for simultaneous transmission of data to the first and second stations, without interference from the other station.
(45) The station can use any of numerous techniques to determine the null-steering vector fed back to the AP 14. In an embodiment, each station numerically determines the null space by computing the SVD of the channel matrix, SVD(H.sub.i), and then selects the eigenvectors with eigen-values smaller than a implementation dependent threshold. The set of collected vectors form the basis for the null space of the channel matrix. In other examples, such as with implicit beamforming, this same process can be performed at the AP, in response to CSI feedback from each of the clients.
(46) Another approach to determine the null space is to do a linear projection. For example, assuming V is a column-wise orthonormal matrix (e.g., the singular vectors of the channel matrix), then V.sub.null=Null(V)=a(I-VV*) W, where a is a normalization factor, W could be any matrix (e.g. a column-wise orthonormal matrix) with a number of columns equal to the dimension of the null space of V, and I is the identity matrix.
(47)
(48) In other embodiments, the AP can request that the stations provide a specific type of feedback, based on the AP's own estimate of the feedback amounts that would likely be needed for each feedback type.
(49) The type of feedback from the station, i.e., CSI, noncompressed beamforming, compressed beamforming, or null-space vector, can be identified as a steering subfield field of a 3 bit high-throughput (HT) control filed or a very high throughput (VHT) control field in a MAC header of the feedback frame.
(50) In all the previously introduced feedback methods 100, 200, and 300, (e.g., feedback steering matrix, null-steering vectors, or hybrid thereof), each station may optionally (or mandatorily) attach a number of spatial streams (Nss) subfield in the feedback frame, where the value Nss identifies the number of spatial streams that the AP should use in communicating with the particular station. The AP may use the identified number of spatial streams or few spatial streams, depending on conditions determined at the AP, including the feedback channel descriptions from each of the stations as well as interference avoidance determinations made at the AP. Each station determines its own suitable number of spatial streams (Nss).
(51) In some examples when the station sends a feedback steering matrix, the number of streams, Nss, is equal to or less than the number of columns (Nc) of the singular vector feedback matrix. In some examples of a null-steering vector feedback, the number of spatial streams Nss is equal to or less than (NrxNnull), where Nnull is the number of columns in the feedback and Nrx is the number of antenna at the station. For example, for a station having three antenna, such as 25-1, the station may choose to suggest 2 streams, Nss=2, for itself in the multiple station packet, so the extra receive antenna may be used for interference mitigation.
(52) In some embodiments, the station also optionally (or mandatory) attaches to the feedback signal substream signal-to-noise ratios (SNRs) averaged over the received downlink channels, i.e., tones. The number of SNRs used to determine a linear average, for example, may be equal to or less than Nc or (NrxNnull). In this way, for the null-steering vector feedback, the number of SNRs transmitted back to the AP, then implies the number of streams (Nss) preferred by the transmitting station.
(53) In some embodiments, the indicated number of spatial streams, Nss, can be extended by having multiple user (i.e., multiple station) feedback, as in 802.11ac, and single user (i.e., single station) feedback share the same feedback steering matrix, V, format. For example, a station may always feedback a V matrix, with the maximum possible channel rank (or maximum number of singular vectors).
(54) In some embodiments, in place of providing an Nss field, each station may include within the feedback frame, a desired number space-time streams, Nsts. For example, the station may provide a Nsts field for single user communication, discussed below, and/or multiple user communication, discussed above. Space-time streams refer to streams of modulation symbols created by applying a combination of spatial and temporal processing to one or more spatial streams of modulation symbols. The feedback frame includes subfields for both, indicating the preferred Nsts or num of columns in V if the feedback steering matrices V are used for single user beamforming and the preferred Nsts or num of columns in V if the feedback steering matrices V are used for multiple user precoding.
(55) The example method 200 of
V=(IV.sub.nullV.sub.null*)W, (Eq. 7)
where is a normalization factor, and W can be any matrix (e.g. column-orthonormal matrix) with number of columns equal to the desirable number of streams in the steered transmission, and I is the identity matrix. Once determined, the AP uses V as the single user steering matrix, W.sub.K.
(56) The null-space conversion may be implemented at either the station or the AP. For example, the station may convert a received range vector into a null-steering vector, which is fed back to the AP. The AP receiving the null-steering vectors converts them to range vectors. In other embodiments, for example, when the AP receives feedback steering vectors, V, the AP creates the null-steering vectors. That is, for Eq. 7, if V.sub.null is a ranging steering vector, instead of null-steering vector, then V in the expression becomes the null-steering vector of the ranging vector V.sub.null.
(57)
(58) At a block 402, the AP sends downlink channel signals to a station using a channel matrix, H. In the illustrated example, the channel matrix is a 34 matrix, having 3 spatial streams. At a block 404, after receiving the downlink channel signal, the station decomposes its own channel matrix to obtain its own steering matrix, V. At a block 406, the station extracts the null-steering vector V.sub.null, which in the discussed example is the last column of the V matrix 41. At a block 408, the station compresses the null-steering vector V.sub.null and feeds it back to the AP. At a block 410, the AP decompresses the feedback null-steering vector, V.sub.null (41) , from the station and applies a householder matrix conversion to convert the null-space signal to range-space vectors, {circumflex over (V)}, which in this example represent the first 3 columns of the steering matrix, V, i.e., {circumflex over (V)} (43). For downlink communications, the AP uses the determine ranging vectors, {circumflex over (V)}, as the steering vectors. The null-steering vector, V.sub.null, is not needed for single station communications.
(59) The following describes some example techniques for determining a Householder matrix as may be applied by the block 410, in determining determine {circumflex over (V)} from V.sub.null, such that the product of {circumflex over (V)} and V.sub.null equals 0, i.e., {circumflex over (V)}.Math.V.sub.null=0, where {circumflex over (V)} is the conjugate transpose of {circumflex over (V)}.
(60) Before discussing some general techniques for null-steering vector conversion, the method 400 is discussed for determining a 43 {circumflex over (V)} matrix from null-steering vector, 41, V.sub.null.
(61) The AP receives the null-steering vector, V.sub.null, and sets it to a vector, x=V.sub.null, such that a transformation vector, v, can be defined as follows:
v=x+sign(x(1))*norm(x)*e.sub.1 (Eq. 8)
where e.sub.1 is a vector [1 0 . . . 0]. Next the vector, v, is normalized according to:
v=v/norm(v) (Eq. 9)
From the normalized vector, v, the AP determines a Householder reflector matrix, HR, according to:
HR=I.sub.MT2vv(Eq. 10)
where I is an identity matrix and MT is the number of transmit antennas for the AP. The vector product HR.Math.x has all zero entries except the first, i.e., for a 43 matrix the 2.sup.nd through last columns of the householder reflect matrix HR are orthogonal to vector x. With orthogonality, the steering matrix, {circumflex over (V)}, that the AP will apply for communicating with the corresponding station is determined as follows:
{circumflex over (V)}=HR(:, 2:end), (Eq. 11)
where the steering matrix {circumflex over (V)} is a 43 matrix.
(62) More generally, the block 410 may implement the following processes to determine the steering matrix, {circumflex over (V)}, from a null-steering vector, V.sub.null, for any arbitrary mn matrix.
(63) A vector A is set equal to the received V.sub.null, A=V.sub.null, where [m,n]=size(A). An identity vector, Q, of m length is then determined, for example, applying Q=eye(m). For single station communication, the following expression is used to determine the minimum value for all but the last, m, column, i.e., for k=1:min(m1,n). A vector a.sub.k is defined as follows:
a.sub.k=A(k:end,k). (Eq. 12)
(64) This vector is zeroed out to determine a v.sub.k according to the following:
v.sub.k=a.sub.k+sign(a.sub.k(1)).Math.norm(a.sub.k).Math.[1;zeros(mk,1)]. (Eq. 13)
A Householder reflector matrix is then defined from v.sub.k as follows:
HR.sub.k=eye(mk+b 1)2v.sub.k.Math.v.sub.k/(v.sub.k.Math.v.sub.k). (Eq. 14)
From this Householder reflector matrix a matrix is determined as follows:
Q.sub.k=[eye(k1)zeros(k1,mk+1); zeros(mk+1,k1)HR.sub.k]; (Eq. 15)
The vector A is then updated by A=Q.sub.kA as is Q by Q=Q*Q.sub.k
The steering matrix, {circumflex over (V)} is then set as follows:
{circumflex over (V)}=Q(:,n+1:end) (Eq. 16)
The AP confirms that {circumflex over (V)}.Math.V.sub.null=0, so that all the columns of {circumflex over (V)} are orthogonal to V.sub.null.
(65)
(66)
(67) The Householder reflector, HR(v), is a unitary matrix to reflect x over the n1 dimensional subspace span{v}_null, as shown in
(68)
(69) The value {circumflex over (P)} x is a midpoint of x and the Household reflector of x, HR(v).Math.x. HR(v).Math.x is a multiplication of a matrix and a vector. Therefore, in order to get the null-space vector of x, the reflector HR(v) should map (project) x to the direction of e.sub.1=[1, 0, . . . , 0 ]. All the vectors of
(70)
(71) The suitable v to project HR(v)x into a base direction is
v=xx.sub.2e.sub.1 (Eq. 20)
Correspondingly, the midpoint of x and HR(v).Math.x is in the hyperplan of span{v}_null, as shown in
v=x+x.sub.2e.sub.1. (Eq. 21)
As a result, v=x+sign(x(1)).Math.norm(x).Math.e.sub.1, where sign(x)=x/abs(x), where
(72) The Householder reflector is used for QR decomposition. For example,
A=QR Q*A=R
Q can be decomposed into a series of Q.sub.k
(73)
where I is a (k1) by (k1) identity matrix, and HR(v.sub.k) is (nk+1) dimensional Householder reflector. Example resulting expressions are as follows:
(74) ##STR00001##
The number of floating point operation required for QR decomposition is
(75)
where n, m is the size of dimension of A c.sup.mn. However, to achieve the null-space vectors for a single vector, a single Householder transform is enough, i.e., n=1 is sufficient, thereby greatly reducing the QR decomposition calculation.
(76) At least some of the various blocks, operations, and techniques described above may be implemented utilizing hardware, a processor executing firmware instructions, a processor executing software instructions, or any combination thereof. When implemented utilizing a processor executing software or firmware instructions, the software or firmware instructions may be stored in any computer readable memory such as on a magnetic disk, an optical disk, or other storage medium, in a RAM or ROM or flash memory, processor, hard disk drive, optical disk drive, tape drive, etc. Likewise, the software or firmware instructions may be delivered to a user or a system via any known or desired delivery method including, for example, on a computer readable disk or other transportable computer storage mechanism or via communication media. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism. The term modulated data signal means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency, infrared and other wireless media. Thus, the software or firmware instructions may be delivered to a user or a system via a communication channel such as a telephone line, a DSL line, a cable television line, a fiber optics line, a wireless communication channel, the Internet, etc. (which are viewed as being the same as or interchangeable with providing such software via a transportable storage medium). The software or firmware instructions may include machine readable instructions that, when executed by the processor, cause the processor to perform various acts.
(77) When implemented in hardware, the hardware may comprise one or more of discrete components, an integrated circuit, an application-specific integrated circuit (ASIC), etc.
(78) While the present invention has been described with reference to specific examples, which are intended to be illustrative only and not to be limiting of the invention, changes, additions and/or deletions may be made to the disclosed embodiments without departing from the scope of the invention. For example, one or more operations in methods discussed above may be performed in a different order (or concurrently) and still achieve desirable results.