Alternate feedback types for downlink multiple user MIMO configurations

09629128 ยท 2017-04-18

Assignee

Inventors

Cpc classification

International classification

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) FIG. 1 a block diagram of an example wireless local area network (WLAN) in which an access point (AP) utilizes downlink (DL) Spatial-Division Multiple Access (SDMA) steering techniques in accordance with an embodiment of the present disclosure;

(2) FIG. 2 is a block diagram of a DL SDMA controller that is used in an AP that implements steering techniques of the present disclosure, according to an embodiment;

(3) FIG. 3 is a flow diagram of an example method for generating steering vectors for use in simultaneous DL SDMA transmissions to multiple stations using a feedback steering matrix, according to an embodiment; and

(4) FIG. 4 is a flow diagram of an example method for generating a pair of steering vectors for use with two stations operating in an SDMA mode using a null-steering vector, according to an embodiment.

(5) FIG. 5 is a flow diagram of an example method for generating a pair of steering vectors using a hybrid feedback steering matrix or null-steering vector technique in an SDMA mode using a null-steering vector, according to an embodiment.

(6) FIG. 6 is a flow diagram of an example method for generating a steering vector for DL SDMA transmissions from a null-steering vector fed back from a station, according to an embodiment.

(7) FIGS. 7-10 illustrate geometrically steps of a Householder transformation used to transform a null-steering vector into a steering matrix for use in DL SDMA transmissions to a single station, according to an embodiment.

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) FIG. 1 is a block diagram of an example wireless local area network (WLAN) 10, according to an embodiment. An AP 14 includes a host processor 15 coupled to a network interface 16. The network interface 16 includes a medium access control (MAC) unit 18 and a physical layer (PHY) unit 20. The PHY unit 20 includes N.sub.T transceivers 21, and the transceivers are coupled to N.sub.T antennas 24. Although three transceivers 21 and three antennas 24 are illustrated in FIG. 1 (i.e., N.sub.T=3), the AP 14 can include different numbers (e.g., N.sub.T=2, 4, 5, 6, 7, 8, etc.) of transceivers 21 and antennas 24 in other embodiments. The PHY unit 20 also includes a downlink (DL) Spatial-Division Multiple Access (SDMA) controller 19 that implements one or several of the techniques for developing steering vectors described herein.

(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 FIG. 1 (i.e., K=3), the WLAN 10 can include different numbers (e.g., K=2, 4, 5, 6, etc.) of client stations 25 in various scenarios and embodiments. Two or more of the client stations 25 are configured to receive corresponding data streams having been simultaneously transmitted from the AP 14.

(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 FIG. 1 (i.e., N.sub.1=3), the client station 25-1 can include different numbers of transceivers 30 and antennas 34 (e.g., N.sub.1=1, 2, 4, 5, etc.) in other embodiments. The PHY unit 27 may include, in some embodiments, a channel estimation controller 40 that implements portions of the techniques for developing steering vectors described herein. The client stations 25-2 and 25-3 have a structure that is the same as or generally similar to the client station 25-1. In an embodiment, each of the client stations 25-2 and 25-3 is structured like the client station 25-1 but has only two transceivers and two antennas (i.e., N.sub.2=N.sub.3=2). In other embodiments, the client stations 25-2, and 25-3 can include different numbers of antennas (e.g., 1, 3, 4, 5, 6, 7, 8, etc.). Although, only an example implementation, in the IEEE 802.11ac Standard, it is believed that the AP will have up to 8 antennas and support simultaneously communication with up to 4 stations.

(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 FIG. 1, to develop the steering matrices for each station, the system can be modeled as though the AP 14 is transmitting a symbol to a client station 25-i as a transmit symbol vector x.sub.i of dimensionality L.sub.i1, and the client station 25-i receives a signal that can be represented as a vector y.sub.i of dimensionality N.sub.i1.

(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) y i = H i W i x i intended + H i .Math. k i W k x k interference + n i noise ( Eq . 1 )
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) y i = H i W i x i + H i .Math. k i W k x k + n i = H i [ W 1 W 2 .Math. W K ] [ x 1 x 2 .Math. x K ] + n i = = H i Wx + n i , i = 1 .Math. , K where .Math. W = [ W 1 W 2 .Math. W K ] , x = [ x 1 x 2 .Math. x K ] ( Eq . 2 )
Further, the signals y.sub.1, y.sub.2, . . . y.sub.K can be stacked together to define an aggregate receive vector y:

(21) y = [ y 1 y 2 .Math. y K ] = H T Wx = [ x 1 x 2 .Math. x K ] + x = [ n 1 n 2 .Math. n K ] = H W x + n where H T = [ H 1 H 2 .Math. H K ] , H W = [ H 1 W 1 H 1 W 2 .Math. H 1 W K H 2 W 1 H 2 W 2 .Math. H 2 W K .Math. .Math. .Math. .Math. H K W 1 H K W 2 .Math. H K W K ] , and .Math. n = [ n 1 n 2 .Math. n K ] . ( Eq . 3 )

(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 FIG. 2, an SDMA controller 50 illustrates operation of the DL SDMA controller 19, according to an embodiment, and operation of the DL SDMA controller 19 and the channel estimation controller 40 according to another embodiment. That is, the techniques herein described may be implemented at the AP or partially at the AP and the client device. Implemented in the AP 14, the SDMA controller 50 receives a plurality data streams DATA.sub.1, DATA.sub.2, . . . DATA.sub.K to be simultaneously transmitted to respective client stations. Depending on the embodiment, the data streams DATA.sub.1, DATA.sub.2, . . . DATA.sub.K include packets, frames, or other data units. A set of K forward error correction (FEC) and modulation units 54 processes the data streams DATA.sub.1, DATA.sub.2, . . . DATA.sub.K to generate transmit symbol vectors x.sub.i, x.sub.2, . . . x.sub.K. A spatial steering unit 64 then applies a respective steering vector W.sub.i to each transmit symbol vector x.sub.i. In an embodiment, an adder 66 combines the resulting product vectors into an aggregate product vector.

(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 FIG. 2, the output of the adder 66 (e.g., an aggregate product vector P) is supplied to an inverse discrete Fourier transform module (e.g., an inverse fast Fourier transform (IFFT) module) 72, according to an embodiment. The IFFT module 72 in turn is coupled to a digital filtering and RF module 74. Once processed by the IFFT module 72 and the digital filtering and RF module 74, the data corresponding to the aggregate product vector is transmitted via an antenna array. As indicated above, an efficient set of steering vectors W.sub.i, W.sub.2, . . . W.sub.K results in a transmission pattern such that the intended components of the transmitted signals are transmitted to the corresponding receiving stations simultaneously, while the interference components at each station are minimized, e.g., reduced to zero or nearly zero.

(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 FIG. 3, after receiving the steering matrix feedback from all K stations, the AP 14 will compute the steering matrices to be used for each station, to avoid or mitigate multi-station, also termed multi-user, interference at each of the stations.

(31) FIG. 3 illustrates an example method 100 for developing steering vectors for simultaneous transmission of data to two or more stations. The DL SDMA controller 19 or the SDMA controller 50, for example, are configured to implement at least partially the method 100, according to some embodiments, where some of the functionality may be implemented by the channel estimation controller 40 on the client device 25-i. In the method 100, each of the stations, 25-1 . . . 25-K, determine their respective feedback steering matrix, V.sub.1 . . . V.sub.K, and feedback their matrix to the AP 14, and more specifically to the channel estimation unit 62, for determining steering vectors W.sub.i, W.sub.2, . . . W.sub.K. Because, in this embodiment, the stations feedback matrices that span the entire downlink channel space, this technique is termed range feedback herein.

(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) H 1 = U 1 D 1 V 1 T , H 2 = U 2 D 2 V 2 T and H 3 = U 3 D 3 V 3 T y i = U i D i V i T ( .Math. k = 1 3 W k x k ) + n k ( Eq . 6 )
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 FIG. 4.

(42) FIG. 4 is a flow diagram of an example method 200 that an AP implements to generate a pair of transmit steering vectors for simultaneous transmission of data to a corresponding pair of stations, according to an embodiment. The method 200 yields steering vectors that form an aggregate steering vector similar to a block-nullified aggregate steering vector, for example. The DL SDMA controller 19 or the SDMA controller 50, for example, is configured to implement the method 200, according to some embodiments.

(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) FIGS. 3 and 4 illustrate examples of a station determining a feedback steering matrix and a feedback null-steering vector, respectively. In other embodiments, the station may determine both. For both the range feedback and null space feedback schemes, the amount of feedback depends on the number of transmit antennas at the AP and the number of receive antennas at the client. FIG. 5 illustrates another feedback method 300, which is a hybrid feedback scheme. After the AP transmits the sounding packets at a block 302, at a block 304, each station computes the amount of feedback in the feedback schemes discussed earlier. That is, at the block 304, each station determines a full feedback steering matrix, V.sub.K, and a null-steering vector. At a block 306, the station determines which of the two feedback signals result in the least amount of size on the feedback signal, and at a block 308, the station feeds back the corresponding feedback signal to the AP 14, where the type of feedback sent by the client to the AP may be indicated in the category field of a management action frame, in some embodiments. Depending on the type of fed back signal, either method 100 or 200 may be implemented to determine the steering vectors at a block 310, executed by the AP.

(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 FIG. 3 describes a null-space vector feedback that is used by the AP to determine steering vectors, W.sub.1, W.sub.2, . . . W.sub.K, for simultaneously multiple station beamforming. In some examples, however, the AP uses the null-space vector(s) for single station beamforming, e.g., when there is no simultaneous communication with other stations. In such examples, the AP uses the null-space feedback, Null(V), to compute a steering matrix V and steer to the particular station using that matrix. The AP may use numerous different approaches to determine V. In some examples, the AP directly converts received null-steering vectors to range vectors. If V.sub.null=Null(V) is the fed back vectorthe vectors are to be column-wise orthonormalthen the AP determines ranging vectors, V, according to the following:
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) FIG. 6 illustrates a method 400 providing another technique for null-space conversion, from null-steering vectors to ranging steering vector, to produce steering vectors for single station communication between the AP and one of the stations. While numerous conversion techniques may be used, the method 400 applies a Householder transform, which is at least partially implemented by the DL SDMA controller 19. The illustrated example is described in the context of single station communication; however, in other embodiments the techniques can be used for simultaneous communication with different stations and with reduced potential interference for each communication channel.

(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) FIGS. 7-10 illustrate geometrically the Householder transform of null-steering vectors for an arbitrary vector. A matrix P is a projector provided by P.sup.2=P, where if P is also Hermitian, then P is an orthogonal projector. As shown in FIG. 7, a vector x can be projected into the direction of span{v} and into the direction of span{v}_null, by using P, where both vectors are orthogonal to each other as shown. Generally, P satisfies the following conditions

(66) P = vv * v * v P ^ = I - P = I - vv * v * v ( Eq . 17 )

(67) The Householder reflector, HR(v), is a unitary matrix to reflect x over the n1 dimensional subspace span{v}_null, as shown in FIG. 8. HR(v) can be determined, as follows from the above, from the following:

(68) HR ( v ) x = x - 2 Px = ( I - 2 P ) x = ( I - 2 vv * v * v ) x ( Eq . 18 )

(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 FIG. 8, are rotated in FIG. 9. That is, as shown in FIG. 9, the columns from 2.sup.nd to the end of HR(v) will be orthogonal to x, i.e., will be in the null-space of x, thus rending the expression:

(70) HR ( v ) x = [ .Math. x .Math. 2 0 .Math. 0 ] ( Eq . 19 )

(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 FIG. 10. The vector v is normalized and is used to derive HR(v)=I2vv. In this example, HR(v).Math.x is mapped into e.sub.1. However, in other examples, HR(v).Math.x could be mapped into e.sub.1, then, the sign will be changed as follows:
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 FIG. 10 illustrates the resulting projections of v.

(72) The Householder reflector is used for QR decomposition. For example,
A=QR custom character Q*A=R
Q can be decomposed into a series of Q.sub.k

(73) Q n Q n - 1 .Math.Q 1 A = R , where Q k = ( I 0 0 H ( v k ) ) ,
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) .Math. k = 1 n 4 ( m - k + 1 ) ( n - k + 1 ) 2 mn z - 2 n 3 3 ( Eq . 22 )
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.