Multi-stage receiver for wireless communication

Abstract
Techniques for receiving a MIMO transmission are described. A receiver processes received data from multiple receive antennas in multiple stages. A first stage performs front-end filtering/equalization on the received data with a front-end filter to process non on-time signal components in the multiple received signals. A second stage processes the filtered data with one or more combiner matrices to combine on-time signal components for multiple transmitted signals. For a MIMO-CDM transmission, a single front-end filter may be used for all channelization codes, and a different combiner matrix may be used for each channelization code. Partitioning the receiver processing into multiple stages simplifies derivation of the front-end filter and combiner matrices while achieving good performance. The front-end filter and combiner matrices may be updated separately at the same or different rates.
Description
BACKGROUND

1. Field


The present disclosure relates generally to communication, and more specifically to techniques for receiving a multiple-input multiple-output (MIMO) transmission.


2. Background


A MIMO transmission is a transmission from multiple (M) transmit antennas to multiple (N) receive antennas. For example, a transmitter may simultaneously transmit M data streams from the M transmit antennas. These data streams are distorted by the wireless environment and further degraded by noise and interference. A receiver receives the transmitted data streams via the N receive antennas. The received signal from each receive antenna contains scaled and delayed versions of the transmitted data streams. The transmitted data streams are thus dispersed among the N received signals from the N receive antennas. The receiver may then process the N received signals with a space-time equalizer to recover the transmitted data streams.


The receiver may dynamically derive coefficients for the space-time equalizer to account for variations in signal properties. These signal properties may relate to channel and interference statistics, spatio-temporal processing of the transmitted data streams, etc. The derivation of the equalizer coefficients is computationally intensive. Updating these equalizer coefficients to match the fastest changes in the signal properties may result in a very complex receiver. Updating these equalizer coefficients at a slower rate may result in performance degradation.


There is therefore a need in the art for techniques to efficiently receive a MIMO transmission.


SUMMARY

Techniques for efficiently receiving a MIMO transmission are described herein. A receiver receives multiple signals transmitted by a transmitter and processes multiple received signals to obtain received data. The receiver may process the received data in multiple stages. A first stage may perform filtering/equalization on the received data with a front-end filter to process (e.g., compensate for, suppress, or mitigate) non on-time signal components. A second stage may process filtered data from the first stage with one or more combiner matrices to combine on-time signal components. The on-time and non on-time signal components may be distinguished based on the transmit time. At the receiver, the on-time signal components may comprise signal components tracing back to a desired symbol to be recovered as well as other symbols transmitted at the same time as the desired symbol. The non on-time signal components may comprise signal components that are not on-time signal components, such as signal components tracing back to other symbols transmitted before and after the desired symbol.


The front-end filter is not dependent on data-specific processing at the transmitter whereas the combiner matrices may be functions of data-specific processing at the transmitter. The data-specific processing may correspond to, e.g., channelization codes, transmit matrices, gains, etc., used to send data. For example, in a MIMO transmission that utilizes code division multiplexing (CDM), a single front-end filter may be derived and used for all channelization codes, and a different combiner matrix may be derived for each channelization code. Partitioning the receiver processing into multiple stages simplifies the derivation of the front-end filter and the combiner matrices while achieving good performance. The front-end filter and combiner matrices may be updated separately at the same or different rates.


According to an aspect, an apparatus is described which includes at least one processor and a memory. The processor(s) filter received data to process non on-time signal components in multiple received signals and obtain filtered data. The processor(s) also process the filtered data to combine on-time signal components for multiple transmitted signals.


According to another aspect, an apparatus is described which includes at least one processor and a memory. The processor(s) derive a front-end filter for processing non on-time signal components in multiple received signals and also derive multiple combiner matrices for combining on-time signal components for multiple transmitted signals sent with multiple channelization codes. The processor(s) filter received samples with the front-end filter and obtain filtered symbols for the multiple channelization codes. The processor(s) further process the filtered symbols for each channelization code with a combiner matrix for the channelization code to obtain output symbols for the channelization code.


Various aspects and features of the disclosure are described in further detail below.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 shows a block diagram of a transmitter and a receiver.



FIG. 2 illustrates a MIMO-CDM transmission.



FIG. 3 shows a block diagram of a CDMA modulator.



FIG. 4 shows a design of various blocks within the receiver.



FIG. 5 shows a process for recovering a MIMO transmission at the receiver.





DETAILED DESCRIPTION

The receiver processing techniques described herein may be used for various communication systems such as Code Division Multiple Access (CDMA) systems, Time Division Multiple Access (TDMA) systems, Frequency Division Multiple Access (FDMA) systems, Orthogonal FDMA (OFDMA) systems, Single-Carrier FDMA (SC-FDMA) systems, etc. A CDMA system utilizes code division multiplexing (CDM) and transmits modulation symbols in parallel using different channelization codes. A CDMA system may utilize a radio technology such as Wideband-CDMA (W-CDMA), cdma2000, etc. cdma2000 covers IS-2000, IS-856, and IS-95 standards. A TDMA system may utilize a radio technology such as Global System for Mobile Communications (GSM). W-CDMA and GSM are described in documents from an organization named “3rd Generation Partnership Project” (3GPP). cdma2000 is described in documents from an organization named “3rd Generation Partnership Project 2” (3GPP2). 3GPP and 3GPP2 documents are publicly available. An OFDMA system utilizes orthogonal frequency division multiplexing (OFDM) and transmits modulation symbols in the frequency domain on orthogonal subcarriers. An SC-FDMA system utilizes single-carrier frequency division multiplexing (SC-FDM) and transmits modulation symbols in the time domain on orthogonal subcarriers.


The techniques described herein may also be used for MIMO transmissions on the downlink as well as the uplink. The downlink (or forward link) refers to the communication link from base stations to wireless devices, and the uplink (or reverse link) refers to the communication link from the wireless devices to the base stations. For clarity, the techniques are described below for a MIMO transmission in a CDMA system, which may utilize W-CDMA, cdma2000, or some other CDMA radio technology.



FIG. 1 shows a block diagram of a transmitter 110 and a receiver 150 for a MIMO transmission. For downlink transmission, transmitter 110 is part of a base station, and receiver 150 is part of a wireless device. For uplink transmission, transmitter 110 is part of a wireless device, and receiver 150 is part of a base station. A base station is typically a fixed station that communicates with the wireless devices and may also be called a Node B, an access point, etc. A wireless device may be stationary or mobile and may also be called a user equipment (UE), a mobile station, a terminal, a station, a subscriber unit, etc. A wireless device may be a cellular phone, a personal digital assistant (PDA), a wireless modem, a laptop computer, a handheld device, etc.


At transmitter 110, a transmit data processor (TX Data Proc) 112 receives traffic data and signaling, processes (e.g., encodes, interleaves, and symbol maps) the received data, and provides data symbols. Processor 112 also generates and multiplexes pilot symbols with the data symbols. As used herein, a data symbol is a symbol for traffic data or signaling, a pilot symbol is a symbol for pilot, and a symbol is typically a complex value. The data symbols and pilot symbols may be modulation symbols from a modulation scheme such as PSK or QAM. Pilot is data that is known a priori by both the transmitter and receiver. A TX MIMO processor 114 performs spatial or spatio-temporal processing on the data and pilot symbols as described below and provides output symbols to multiple (M) CDMA modulators 116a through 116m. Each CDMA modulator 116 processes its output symbols as described below and provides output chips to an associated transmitter unit (TMTR) 118. Each transmitter unit 118 processes (e.g., converts to analog, amplifies, filters, and frequency upconverts) its output chips and generates a modulated signal. M modulated signals from M transmitter units 118a through 118m are transmitted from M antennas 120a through 120m, respectively.


At receiver 150, multiple (N) antennas 152a through 152n receive the transmitted signals via various propagation paths in the wireless environment and provide N received signals to N receiver units (RCVR) 154a through 154n, respectively. Each receiver unit 154 processes (e.g., filters, amplifies, frequency downconverts, and digitizes) its received signal and provides received samples to a channel processor 156 and an equalizer/CDMA demodulator 160. Processor 156 derives coefficients for a front-end filter/equalizer and coefficients for one or more combiner matrices as described below. Unit 160 performs equalization with the front-end filter and CDMA demodulation and provides filtered symbols. A receive (RX) MIMO processor 170 combines the filtered symbols across spatial dimension and provides detected symbols, which are estimates of the transmitted data symbols. An RX data processor 172 processes (e.g., symbol demaps, deinterleaves, and decodes) the detected symbols and provides decoded data. In general, the processing by equalizer/CDMA demodulator 160, RX MIMO processor 170, and RX data processor 172 is complementary to the processing by CDMA modulator 116, TX MIMO processor 114, and TX data processor 112, respectively, at transmitter 110.


Controllers/processors 130 and 180 direct operation of various processing units at transmitter 110 and receiver 150, respectively. Memories 132 and 182 store data and program codes for transmitter 110 and receiver 150, respectively.



FIG. 2 illustrates a MIMO-CDM transmission. For CDM, up to C symbols may be sent simultaneously via one transmit antenna with C channelization codes, where in general C≧1. These channelization codes may be orthogonal variable spreading factor (OVSF) codes in W-CDMA, Walsh codes in cdma2000, other orthogonal codes or quasi-orthogonal codes, pseudo-random codes, etc. Each channelization code is a specific sequence of chips. The number of chips in the sequence is the length or spreading factor of the channelization code. In general, any set of one or more channelization codes may be used for each transmit antenna, and the channelization codes may have the same or different spreading factors. For simplicity, the following description assumes that the channelization codes have the same spreading factor. The same set of C channelization codes may be reused for each of the M transmit antennas. For MIMO, up to M symbols may be sent simultaneously via M transmit antennas. For MIMO-CDM, up to C·M symbols may be sent simultaneously via M transmit antennas with C channelization codes. MIMO processing may be performed separately for each of the C channelization codes. MIMO processing is performed across all M transmit antennas for each channelization code. CDM processing may be performed separately for each of the M transmit antennas. CDM processing is performed for all C channelization codes for each transmit antenna.



FIG. 3 shows a block diagram of a CDMA modulator 116 for one transmit antenna m, where mε={1, . . . M}. CDMA modulator 116 may be used for each of CDMA modulators 116a through 116m in FIG. 1. CDMA modulator 116 includes a data processor 310 for each channelization code used for traffic data and/or signaling and a pilot processor 320 for pilot.


Within data processor 310, a spreader 312 spreads output symbols dm,c(s) for data with channelization code c having a chip sequence of νc(k), where s is symbol index and k is chip index. A multiplier 314 scales the output of spreader 312 with a gain gm,c and provides data chips for channelization code c. Within pilot processor 320, a spreader 322 spreads output symbols dm,p(s) for pilot with channelization code p for pilot. A multiplier 324 scales the output of spreader 322 with a gain gm,p and provides pilot chips. The gains gm,c and gm,p determine the amount of transmit power used for channelization code c and pilot, respectively. A summer 330 sums the data and pilot chips for all channelization codes. A scrambler 332 multiplies the output of summer 330 with a scrambling sequence p(k) for transmitter 110 and provides output chips ym(k) for transmit antenna m.


In general, any number and any ones of the C channelization codes may be used for each of the M transmit antennas. In one design, the same channelization code is used for pilot for all M transmit antennas. In another design, M channelization codes are used for pilot for the M transmit antennas, and the remaining C-M channelization codes may be reused for each of the M transmit antennas. The same scrambling sequence may be used for all M transmit antennas, as shown in FIG. 3. Alternatively, a different scrambling sequence may be used for each transmit antenna. The spreading and scrambling may also be performed in other manners.


A MIMO channel is formed by the propagation environment between the M transmit antennas at transmitter 110 and the N receive antennas at receiver 150. L data symbols may be sent in parallel from the M transmit antennas for each channelization code, where 1≦L≦min {M, N}. Receiver 150 may analyze the performance (e.g., throughput) of the MIMO channel for different values of L (and possibly different transmit matrices/vectors) and may select the L value (and transmit matrix/vector) that achieves the best performance.


Transmitter 110 may perform transmitter spatial processing for each channelization code c in each symbol period s, as follows:

dc(s)=Bcbc(s), for c=1, . . . , C,  Eq (1)

where bc(s)=[b1,c(s) b2,c(s) . . . bL,c(s)]T is an L×1 vector of data symbols,



B
c is an L×M transmit matrix for channelization code c,



d
c(s)=[d1,c(s) d2,c(s) . . . dM,c(s)]T is an M×1 vector of output symbols, and


T” denotes a transpose.


Each element of bc(s) may correspond to a different data stream. The data streams may have different gains, in which case matrix Bc may have different column norms for different data streams. Equation (1) shows spatial encoding with Bc. Spatio-temporal encoding such as, e.g., space-time transmit diversity (STTD) may also be performed but is not shown in equation (1).


Different transmit matrices may be used for different MIMO modes such as closed loop transmit diversity (CLTD), per antenna rate control (PARC), code reuse Bell Labs layered space-time (CRBLAST), double-transmit adaptive array (D-TXAA), etc. Table 1 lists some MIMO modes and, for each mode, gives L, M, Bc and the source of the data symbols. In Table 1, Bcltd may be a 2×1 vector selected from the set {[1 ejπ/4]T, [1 e−j3π/4]T, [1 ej3π/4]T, [1 e−jπ/4]T}. Bd−txaa may be a 2×2 matrix selected from the set







{


[



1


1








/
4








-
j3π

/
4





]

,

[



1


1







j3π
/
4








-


/
4





]


}

.





I is an identity matrix with ones along the diagonal and zeros elsewhere.













TABLE 1









Source of


MIMO Mode
L
M
Bc
Data Symbols



















CLTD
1
2
Bc = Bcltd
From a single






encoded frame.


PARC
L = M
≧2
Bc = I
From L different






encoded frames.


CRBLAST
L = M
≧2
Bc = I
From a single






encoded frame.


D-TXAA
L = M
=2
Bc = Bd-txaa
From up to L






encoded frames.









Transmitter 110 may perform CDMA processing for each transmit antenna m in each symbol period s, as follows:












y
m



(
k
)


=


(




c
=
1

C




g

m
,
c


·


v
c



(

k





mod





C

)


·


d

m
,
c




(

k





div





C

)




)

·

p


(
k
)




,






for





m

=
1

,






.
M

,




Eq






(
2
)









where symbol period s corresponding to chip period k is given by s=k div C=└k/C┘. The gain gm,c may be set equal to zero for each channelization code that is not used.


If channelization codes with different spreading factors are used, then the CDMA processing for transmit antenna m may be expressed as:









y
m



(
k
)


=


(




c
=
1


N
pc





g

m
,
c


·


v
c



(

k





mod






C
c


)


·


d

m
,
c




(

k





div






C
c


)




)

·

p


(
k
)




,





where Cc is the spreading factor of channelization code c, and


Npc is the number of channelization codes used for transmit antenna m.


For simplicity, the following description assumes that channelization codes with spreading factor of C is used for each transmit antenna. In equation (2), output symbol dm,c(s) is spread with channelization code c with spreading factor C and scaled by gain gm,c to obtain data chips. The spreading is achieved by replicating output symbol dm,c(s) a number of C times and multiplying the C output symbol copies with the C(c) chips νc(k) of channelization code c. The data and pilot chips for all C channelization codes are summed and further scrambled with scrambling sequence p(k) to obtain output chips ym(k) for transmit antenna m. The same CDMA processing is performed for each of the M transmit antennas.


The received samples at receiver 150 in each chip period k may be expressed as:

x(k)=Hy(k)+n(k),  Eq (3)

where y(k) is a T×1 vector of output chips, where T is described below,



H is an R×T channel response matrix, where R is described below,



x(k) is an R×1 vector of received samples, and



n(k) is an R×1 noise vector.


Receiver 150 may digitize the received signal from each receive antenna at K times the chip rate, where K is an oversampling ratio and in general K≧1. In each chip period k, receiver 150 may obtain E·K samples from each receiver 154 and form x(k) by stacking N·E·K samples from N receivers 154a through 154n. E is the length of the front-end equalizer at receiver 150, in number of chips. In general, E≧1 and may be selected based on a tradeoff between receiver complexity and performance. x(k) includes R received samples from N receive antennas for E chip periods, where R=N·E·K.


Matrix H contains time-domain channel impulse responses for all transmit and receive antenna pairs. As shown in FIG. 1, there is a propagation channel between each transmit antenna and each receive antenna, or a total of M·N propagation channels between the M transmit antennas and N receive antennas. Each propagation channel has a particular impulse response determined by the wireless environment. The response of a single-input multiple-output (SIMO) channel between each transmit antenna m and the N receive antennas may be given by an R×Tm submatrix Hm. The number of rows in Hm is determined by the number of entries in x(k). The number of columns in Hm is determined by the equalizer length E as well as the time span of the impulse responses between transmit antenna m and the N receive antennas. Tm may be given as follows:











T
m

=



E
+


max
n



{



m
,
n


}






,




Eq






(
4
)









where lm,n is the time span of the impulse response between transmit antenna m and receive antenna n, in number of chips.


Matrix H is composed of M submatrices Hm, for m=1, . . . M, as follows:

H=[H1 H2 . . . HM].  Eq (5)
H has a dimension of R×T, where T=T1+T2+ . . . +TM.


Vector y(k) is composed of M subvectors ym(k), for m=1, . . . , M, for the M transmit antennas. Each subvector ym(k) includes Tm output chips from one transmit antenna m centered at chip period k. Vector y(k) and subvector ym(k) may be expressed as:












y
_



(
k
)


=

[






y
_

1



(
k
)









y
_

2



(
k
)














y
_

M



(
k
)





]











and

















y
_

m



(
k
)


=


[





y
m



(

k
-





T
m

/
2

-
1




)













y
m



(
k
)













y
m



(

k
+





T
m

/
2

-
1




)





]

.






Eq






(
6
)








Equation (3) may also be expressed as:











x
_



(
k
)


=





m
=
1

M





H
_

m





y
_

m



(
k
)




+



n
_



(
k
)


.






Eq






(
7
)








For the model shown in equation (7), in each chip period k, Tm output chips are sent from each transmit antenna m and via a SIMO channel with a response of Hm to the N receive antennas. The received samples in x(k) include contributions from all M transmit antennas. x(k), y(k), and H may be relatively large. As an example, with M=2, N=2, K=2, E=20, T=48, and R=80, y(k) would be a 48×1 vector, H would be an 80×48 matrix, and x(k) would be an 80×1 vector.


The noise may be assumed to be stationary complex random vector with

E{n(k)}=0, and  Eq (8)
E{n(k)nH(k)}=Rnn,  Eq (9)

where E{ } is an expectation operation, 0 is a vector of all zeros, Rnn is an R×R noise covariance matrix, and “H” denotes a conjugate transpose. Equations (8) and (9) indicate that the noise has zero mean and a covariance matrix of Rnn.


Receiver 150 may recover the data symbols in bc(s) for each channelization code c by filtering the received samples in x(k) with a bank of L filters for channelization code c and then despreading and descrambling the filtered samples, as follows:

















b
_

^

c



(
s
)


=


1

C


·




k
=
sC




(

s
+
1

)


C

-
1






W
_

c
H





x
_



(
k
)


·


[



y
c



(

k





mod





C

)


·

p


(
k
)



]

*











=



W
_

c
H



(


1

C


·




k
=
sC




(

s
+
1

)


C

-
1





[



H
_




y
_



(
k
)



+


n
_



(
k
)



]

·


[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*




)








=



W
_

c
H



[



H
_





Θ
_

c



(
s
)



+



n
_

c



(
s
)



]








=



W
_

c
H





χ
_

c



(
s
)












where




Eq






(
10
)











Θ
_

c



(
s
)


=

(


1

C


·




k
=
sC




(

s
+
1

)


C

-
1






y
_



(
k
)


·


[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*




)


,




Eq






(
11
)











n
_

c



(
s
)


=

(


1

C


·




k
=
sC




(

s
+
1

)


C

-
1






n
_



(
k
)


·


[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*




)


,




Eq






(
12
)













χ
_

c



(
s
)


=

(


1

C


·




k
=
sC




(

s
+
1

)


C

-
1






x
_



(
k
)


·


[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*




)








=



H
_





Θ
_

c



(
s
)



+



n
_

c



(
s
)




,







Eq






(
13
)









W
c is an L×R overall filter for channelization code c,



{circumflex over (b)}
c(s) is an estimate of bc(s), and


“*” denotes a complex conjugate.



Θ
c(s) is a T×1 vector of despread symbols for channelization code c and is obtained based on the transmitted chips. nc(s) is an R×1 noise vector for channelization code c after descrambling and despreading. nc(s) conserves the statistics of n(k), which are independent of channelization code c. χc(s) is an R×1 vector of despread symbols for channelization code c and is obtained based on the received samples. Wc includes the bank of L filters for channelization code c. Equation (10) indicates that the processing with Wc may equivalently be performed on the symbols in χc(s) instead of the received samples in x(k).


Filter Wc may be a Weiner filter, which may be derived as:















W
_

c

=

E




{




χ
_

c



(
s
)






χ
_

c
H



(
s
)



}


-
1


·
E



{




χ
_

c



(
s
)






b
_

c
H



(
s
)



}








=



[



H
_


E


{




Θ
_

c



(
s
)






Θ
_

c
H



(
s
)



}




H
_

H


+


R
_

nn


]


-
1


·

[


H
_


E


{




Θ
_

c



(
s
)






b
_

c
H



(
s
)



}


]








=



[



H
_




Γ
_

c




H
_

H


+


R
_

nn


]


-
1




H
_




γ
_

c








=



R
_

c

-
1




H
_




γ
_

c








=



R
_

c

-
1





Φ
_

c











where




Eq






(
14
)










Γ
_

c

=

E


{




Θ
_

c



(
s
)






Θ
_

c
H



(
s
)



}



,




Eq






(
15
)










γ
_

c

=

E


{




Θ
_

c



(
s
)






b
_

c
H



(
s
)



}



,




and




Eq






(
16
)









R
_

c

=



H
_




Γ
_

c




H
_

H


+



R
_

nn

.






Eq






(
17
)








Γc is a T×T covariance matrix of Θc(s). γc is a T×L correlation matrix of Θc(s) and bc(s) and is indicative of the transmitted signal characteristic. Rc is an R×R correlation matrix for the wireless channel, signal, and noise statistics. Matrices Γc, γc, and Rc are dependent on channelization code c through transmit matrix Bc and gain gm,c.


Matrix Γc may be expressed as:

Γc={tilde over (Γ)}+γcγcH,  Eq (18)

where {tilde over (Γ)} is a part of Γc that is not dependent on channelization code c. It can be shown that only M elements of γc are non-zero. The indices of the non-zero elements of γc are such that the R×L matrix Φc may be expressed as:

Hγc=Φc={tilde over (H)}GcBc,  Eq (19)

where {tilde over (H)} is an R×M matrix containing M “on-time” columns of H, and

    • Gc is an M×M diagonal matrix containing √{square root over (C)}·gm,c, for m=1, . . . , M, along the diagonal and zeros elsewhere.


As shown in equation (5), H contains T=T1+T2+ . . . +TM columns for the M transmit antennas. {tilde over (H)} contains M columns of H, or one column for each transmit antenna. The M columns of {tilde over (H)} multiply the M elements in y(k) that have their chip time aligned with the despreader operation in equation (10). These M columns may be identified as described below.


Matrix Rc in equation (17) may then be expressed as:















R
_

c

=



H
_




Γ
_

c




H
_

H


+


R
_

nn








=



H
_




Γ
~

_




H
_

H


+


R
_

nn

+


H
_




γ
_

c




γ
_

c
H




H
_

H









=



R
_

~

+



Φ
_

c




Φ
_

c
H












where




Eq






(
20
)









R
_

~

=



H
_




Γ
_

~




H
_

H


+



R
_

nn

.






Eq






(
21
)








Matrix Wc in equation (14) may then be expressed as:















W
_

c

=



R
_

c

-
1





H
_

~




G
_

c




B
_

c








=



[


R
_
~

+



Φ
_

c




Φ
_

c
H



]


-
1





H
_

~




G
_

c




B
_

c








=



R
_
~


-
1





H
_

~




G
_

c






B
_

c



(


I
_

+



B
_

c
H




G
_

c




H
_
~

H




R
_
~


-
1





H
_

~




G
_

c




B
_

c



)



-
1









=


F
_




Δ
_

c











where




Eq






(
22
)









F
_

=




R
~

_


-
1





H
~

_



,




and




Eq






(
23
)









Δ
_

c

=



G
_

c







B
_

c



(


I
_

+



B
_

c
H




G
_

c





H
~

_

H





R
~

_


-
1





H
~

_




G
_

c




B
_

c



)



-
1


.






Eq






(
24
)








In equation (23), F is a relatively large R×M matrix that is not dependent on channelization code. In equation (24), Δc is a small M×L matrix that contains all of the code dependent matrices in Wc.


Equations (10) through (24) indicate that the processing at receiver 150 may be performed in two stages. The first stage filters the received samples x(k) with a front-end filter F that is not dependent on channelization code and further despreads and descrambles the filtered samples to obtain filtered symbols. A single front-end filter may be used for all channelization codes. The second stage combines the filtered symbols with a combiner matrix Δc for each channelization code c to obtain detected symbols for that channelization code. The front-end filter and combiner matrices may be updated separately at the same rate or different rates.


The multi-stage receiver processing may be performed in various manners. In the following description, pilot symbols are assumed to be sent with a transmit matrix of Bc=I and using the same channelization code p for each of the M transmit antennas. The pilot symbols are also assumed to be uncorrelated or orthogonal so that E{bp(s)bpH(s)}=I, where bp(s) is an M×1 vector of pilot symbols sent from the M transmit antennas in symbol period s.


In one receiver design, front-end filter F is derived and used for the first stage (e.g., for block 160 in FIG. 1), and combiner matrix Δc is computed for each channelization code and used for the second stage (e.g., for block 170 in FIG. 1).


For symbol level training, a filter may be derived based on pilot symbols using least squares criterion, as follows:












W
_

p

=


min


W
_

h







s
=

s
0




s
0

+
P
-
1










W
_

h
H





χ
_

p



(
s
)



-



b
_

p



(
s
)





2




,




Eq






(
25
)









where χp(s) is an R×1 vector of despread pilot symbols,



W
h is an R×M candidate filter matrix,



W
p is an R×M filter matrix derived based on pilot symbols, and


P is the number pilot symbols used to derive Wp.


The despread pilot symbols in χp(s) may be obtained as shown in equation (13), albeit with pilot channelization code p instead of channelization code c. The least squares criterion selects a candidate filter matrix from among all candidate filter matrices such that the quantity on the right hand side is minimized. The selected filter matrix is provided as the least squares filter matrix Wp.


In the limit, with P→∞ in equation (25), Wp may be expressed as:

Wp=[E{χp(s)χpH(s)}]−1 E{χp(s)bpH(s)}.  Eq (26)


For symbol level training, Wp may be derived as follows. Despread pilot symbols in χp(s) may be obtained from the received samples as shown in equation (13). An R×R outer product χp(s)χpH(s) may be computed and averaged over a sufficient number of pilot symbols. An R×M outer product χp(s)bpH(s) may also be computed and averaged. Wp may be computed based on the two averaged outer products. Wp may also be derived based on recursive least squares (RLS), block least squares, or some other techniques known in the art.


For chip level training, a filter may be derived based on received samples using the least squares criterion, as follows:












W
_

p

=


min


W
_

h







k
=


s
0


C





(


s
0

+
P

)


C

-
1










W
_

h
H




x
_



(
k
)



-




b
_

p



(
s
)


·


v
p



(

k





mod











C

)


·

p


(
k
)






2




,




Eq






(
27
)









where bp(s)·νp(k)·p(k) is an M×1 vector of pilot chips obtained by spreading and scrambling the pilot symbols.


In the limit, with P→∞ in equation (27), Wp may be expressed as:

Wp=[E{x(k)xH(k)}]−1 E{x(k)bpH(s)·νp(kp(k)}  Eq (28)


For chip level training, Wp may be derived as follows. An R×R outer product x(k)xH(k) may be computed based on the received samples and averaged over a sufficient number of pilot symbols. An R×M outer product x(k)bpH(s)·νp(k)·p(k) may also be computed and averaged. Wp may then be computed based on the two averaged outer products.


From equation (22), Wp may be expressed as:














W
_

p

=






R
~

_


-
1





H
_

~










G
_

p



(


I
_

+



G
_

p





H
~

_

H





R
_

~


-
1









H
~

_








G
_

p



)



-
1









=




F
_










G
_

p



(


I
_

+


P
_

p


)



-
1










Eq






(
29
)








where







P
_

p


=



G
_

p





H
~

_

H





R
~

_


-
1





H
~

_









G
_

p

.






Eq






(
30
)








The M×M matrix Pp may be estimated as follows:











P
_

p

=


1
P

·




s
=

s
0




s
0

+
P
-
1






F
_

p
H





χ
_

p



(
s
)







b
_

p
H



(
s
)


.








Eq






(
31
)









The estimate of Pp becomes more accurate in the limit, with P→∞. Similar to Wp, Pp may also be estimated based on pilot chips instead of pilot symbols.


Front-end filter F may be derived based on equation (29), as follows:

F=Wp(I+Pp)Gp−1.  Eq (32)


Combiner matrix Δc may be derived based on equations (24) and (30), as follows:

Δc=GcBc(I+BcHGcGp−1PpGp−1GcBc)−1.  Eq (33)


Filter Wc may be expressed based on Wp and Pp, as follows:














W
_

c

=




F
_








G
_

c






B
_

c



(


I
_

+



B
_

c
H




G
_

c





H
~

_

H





R
~

_


-
1





H
~

_








G
_

c




B
_

c



)



-
1









=






W
_

p



(


I
_

+


P
_

p


)





G
_

p

-
1





G
_

c







B
_

c



(


I
_

+



B
_

c
H




G
_

c




G
_

p

-
1





P
_

p




G
_

p

-
1





G
_

c




B
_

c



)



-
1


.









Eq






(
34
)








As shown in equation (32), front-end filter F may be derived based on Wp and Pp, which may in turn be estimated based on pilot symbols or chips. As shown in equation (33), combiner matrix Δc for each channelization code c may be derived based on Pp, gain matrices Gp and Gc for pilot and data, and transmit matrix Bc for channelization code c. GcGp−1 is also referred to as a traffic-to-pilot ratio and may be known (e.g., via signaling) or estimated by the receiver. It is normally sufficient to estimate the traffic-to-pilot ratio GcGp−1, and Gp and Gc do not need to be estimated separately.


Receiver 150 may recover the data symbols in bc(s) as follows:













b
^

_

c



(
s
)


=




Δ
_

c
H



(


1

C


·




k
=
sC




(

s
+
1

)


C

-
1






F
_

H





x
_



(
k
)


·


[



v
c

(

k





mod











C

)

·

p
(
k
)


]

*





)


.





Eq






(
35
)








Receiver 150 may perform the processing for equation (35) in two stages. In the first part of the first stage, receiver 150 may perform front-end filtering in each chip period k, as follows:

v(k)=FHx(k),  Eq (36)

where v(k) is an M×1 vector of filtered samples.


In the second part of the first stage, receiver 150 may despread and descramble the filtered samples for each channelization code c, as follows:














d
^

_

c



(
s
)


=


1

C


·




k
=
sC




(

s
+
1

)


C

-
1






v
_



(
k
)


·


[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*





,




Eq






(
37
)









where {circumflex over (d)}c(s) an M×1 vector of filtered symbols, which is an estimate of dc(s).


In the second stage, receiver 150 may perform combining for each channelization code c, as follows:

{circumflex over (b)}c(s)=ΔcH{circumflex over (d)}c(s)  Eq (38)


Receiver 150 may also recover the data symbols in bc(s) as follows:













b
^

_

c



(
s
)


=



Δ
_

c
H




F
_

H




1

C


·




k
=
sC




(

s
+
1

)


C

-
1






x
_



(
k
)


·



[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*

.









Eq






(
39
)








Equation (39) may also be performed in two stages. In the first part of the first stage, receiver 150 may despread and descramble the received samples for each channelization code c to obtain despread symbols for that channelization code. In the second part of the first stage, receiver 150 may perform filtering on the despread symbols for each channelization code c with the same front-end filter F to obtain filtered symbols for that channelization code. In the second stage, receiver 150 may combine the filtered symbols for each channelization code c with the combiner matrix Δc for that channelization code.



W
p is obtained based on pilot symbols or chips and may not have converged to the optimal settings, e.g., because a finite number of pilot symbols (P) is used for training. In such instances, using F and Δc derived based on Wp may result in performance degradation.


In another receiver design, Wp is used as the front-end filter for the first stage. A combiner matrix Dc is computed for each channelization code c and used for the second stage.


The filtered symbols obtained with Wp may be expressed as:














z
_

c

=





W
_

p
H





χ
_

c



(
s
)









=






W
_

p
H




H
~

_








G
_

c




B
_

c





b
_

c



(
s
)



+



n
_

c



(
s
)









=






A
_

c





b
_

c



(
s
)



+



n
_

c



(
s
)










Eq






(
40
)









where







A
_

c


=



W
_

p
H




H
~

_








G
_

c




B
_

c



,
and




Eq






(
41
)









z
c(s) is an M×1 vector of filtered symbols for channelization code c.


The data symbols in bc(s) may be obtained as:

bc(s)=DcHzc(s)  Eq (42)

where Dc is an M×L combiner matrix for channelization code c.


Combiner matrix Dc may be derived based on minimum mean square error (MMSE) criterion, as follows:

Dc=(AcAcH+Rnn,c)−1Ac.  Eq (43)


The noise covariance matrix Rnn,c may be estimated as follows:













R

nn
,
c


=




1
P

·




s
=


s
0


C




s
0

+
P
-
1






[




z
_

p



(
s
)


-




A
_

p



(
s
)






b
_

p



(
s
)




]



[




z
_

p



(
s
)


-




A
_

p



(
s
)






b
_

p



(
s
)




]


H










=





1
P

·




s
=

s
0




s
0

+
P
-
1







z
_

p



(
s
)






z
_

p
H



(
s
)





-



P
_

p




P
_

p
H




,







Eq






(
44
)









where Ap=WpH{tilde over (H)}Gp. The second equality in equation (44) results from the fact that an unbiased estimate of Ap is simply Ap=Pp.


The M×L matrix Ac may be expressed as:

Ac=ApGp1GcBc.  Eq (45)


As shown in equation (45), matrix Ac may be computed for each channelization code c based on (a) matrix Pp estimated from pilot symbols or chips and applicable for all channelization codes and (b) traffic-to-pilot ratio Gp−1Gc and transmit matrix Bc that are specific for channelization code c. As shown in equation (43), combiner matrix Dc may be computed for each channelization code c based on (a) noise covariance matrix Rnn,c that is applicable for all channelization codes and (b) matrix Ac computed for channelization code c.


Combiner matrix Dc may also be estimated for each channelization code c as follows:












R
_

zz

=

E


{


1
C

·




c
=
1

C






z
_

c



(
s
)






z
_

c
H



(
s
)





}



,
and




Eq






(
46
)










D
_

c

=



R
_

zz

-
1





A
_

c



,




Eq






(
47
)









where Rzz is an M×M covariance matrix for zc(s).


In equation (46), an outer product zc(s)zcH(s) may be computed for each channelization code, then averaged over all channelization codes with the same transmit matrix Bc, and further averaged over a sufficient number of symbol periods to obtain covariance matrix Rzz. Dc may then be computed based on Ac and the inverse of Rzz.


Receiver 150 may recover the data symbols in bc(s) as follows:













b
_

^

c



(
s
)


=




D
_

c
H



(


1

C


·




k
=
sC




(

s
+
1

)


C

-
1






W
_

p
H





x
_



(
k
)


·


[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*





)


.





Eq






(
48
)








In equation (48), receiver 150 may filter the received samples with front-end filter Wp, then despread and descramble the filtered samples for each channelization code c, and then combine the filtered symbols for each channelization code with combiner matrix Dc.


Receiver 150 may also recover the data symbols in bc(s) as follows:













b
_

^

c



(
s
)


=



D
_

c
H




W
_

p
H




1

C


·




k
=
sC




(

s
+
1

)


C

-
1






x
_



(
k
)


·



[



v
c



(

k





mod





C

)


·

p


(
k
)



]

*

.









Eq






(
49
)








In equation (49), receiver 150 may despread and descramble the received samples for each channelization code c, then filter the despread symbols for each channelization code with front-end filter Wp, and then combine the filtered symbols for each channelization code with combiner matrix Dc.


The receiver processing may also be performed in multiple stages in other manners. A specific receiver design is described below.



FIG. 4 shows a block diagram of a design of various blocks within receiver 150 in FIG. 1. In this design, front-end filtering is performed prior to CDMA demodulation. Block 160 includes a front-end filter/equalizer 410 and a CDMA demodulator 420. Demodulator 420 includes C descramblers/despreaders 422a through 422C for up to C channelization codes used for traffic data. Block 170 includes C combiners 432a through 432C for up to C channelization codes used for traffic data.


Within channel processor 156, a timing estimator 442 determines the timing of the received signals. Unit 442 may estimate channel impulse responses and/or power delay profiles for different antennas and may determine the center of gravity of the channel impulse responses and/or power delay profiles. Unit 442 may then determine the timing of the received signals based on the center of gravity.


A coefficient computation unit 444 derives coefficients for filter Wp based on the received samples, e.g., as shown in equation (28). Unit 444 may also derive Wp based on RLS, block least squares, or some other technique. The timing information from unit 442 may be used for training, e.g., to align the locally generated pilot chips with the received samples. Unit 444 provides Wp to front-end filter 410.


Filter 410 performs front-end filtering/equalization on the received samples x(k) with Wp and provides filtered samples. Within demodulator 420, each unit 422 despreads and descrambles the filtered samples for a different channelization code and provides filtered symbols zc(s) for that channelization code.


A unit 446 despreads and descrambles the filtered samples for pilot channelization code p. Units 422 and 446 perform despreading and descrambling based on the timing provided by unit 442. A channel estimator 448 estimates an M×M matrix WpH{tilde over (H)} based on the filtered pilot symbols from unit 446. A unit 450 computes the outer product zc(s)zcH(s) for each channelization code, averages the outer product across channelization codes and symbol periods, and provides correlation matrix Rzz, e.g., as shown in equation (46). A unit 452 derives the coefficients for combiner matrix Dc for each channelization code c based on matrix WpH{tilde over (H)} from unit 448, the correlation matrix Rzz from unit 450, and code-specific matrices, as follows:

Dc=Rzz−1WpH{tilde over (H)}GcBc.  Eq (50)


Within RX MIMO processor 170, each combiner 452 combines the filtered symbols for a different channelization code c based on the combiner matrix Dc and provides detected symbols for that channelization code.


Receiver 150 may estimate the received signal quality, which may be quantified by a signal-to-interference-and-noise ratio (SINR), etc. The detected symbols from equation (42) may be expressed as:
















b
_

^

c



(
s
)


=






D
_

c
H




A
_

c





b
_

c



(
s
)



+



D
_

c
H





n
_

c



(
s
)










=






L
_

c
H





b
_

c



(
s
)



+



w
_

c



(
s
)










Eq






(
51
)









where LcH=DcHAc and wc(s)=DcHnc(s). The covariance of nc(s) may be given as Rnn,c=E{nc(s)ncH(s)}. The covariance of wc(s) may be given Rww,c=DcHRnn,cDc.


The SINR of the l-th element of {circumflex over (b)}c(s), bl,c(s), may be expressed as:











SINR






{


b


,
c




(
s
)


}


=






L
c



(


,


)




2




R

ww
,
c




(


,


)


+





i
=
1

,

i




L







L
c



(


,
i

)




2





,




Eq






(
52
)









where Lc(l,l) is the (l,l)-th element of Lc, and



R
ww,c(l,l) is the (l,l)-th element of Rww,c.


SINR {bl,c(s)} is the SINR of the l-th data stream sent with channelization code c and may be used to select a data rate for that data stream. The SINR for each channelization code c is dependent on transmit matrix Bc used for that channelization code. Receiver 150 may determine the SINR for different possible transmit matrices and select the transmit matrix with the highest SINR. Receiver 150 may send feedback information to transmitter 110. This feedback information may comprise the transmit matrix selected for each channelization code, the SINR or data rate for each channelization code, an average SINR or data rate for all channelization codes, etc.


In general, front-end filtering may be performed in the first stage to process non on-time signal components in the M received signals. The front-end filter is, in general, not dependent on how the signals are processed at the transmitter prior to transmission. For a CDM transmission, the front-end filter may be applicable for all channelization codes. The second stage may combine the on-time signal components to recover the L transmitted signals. The combiner matrices used in the second stage may be dependent on how the signals are processed prior to transmission (e.g., the transmit matrix Bc and gain matrix Gc used by the transmitter) and other factors (e.g., the channel response {tilde over (H)} and signal statistics Rzz).



FIG. 5 shows a design of a process 500 for recovering a MIMO transmission at a receiver. A front-end filter for processing (e.g., compensating for, suppressing, or mitigating) non on-time signal components in multiple received signals is derived (block 512). The front-end filter does not isolate the non on-time signal components. Instead, the front-end filter processes the non on-time signal components in a desirable/beneficial manner and may also (incidentally) process on-time signal components. At least one combiner matrix for combining on-time signal components for multiple transmitted signals is also derived (block 514). The front-end filter may be F derived as shown in equation (32), and the combiner matrices may be Δc derived as shown in equation (33). The front-end filter may also be Wp derived as shown in equation (26) or (28), and the combiner matrices may be Dc derived, e.g., as shown in equation (43), (47) or (50). The front-end filter and combiner matrices may also be derived in other manners. The front-end filter may be derived based on received data for pilot and in accordance with, e.g., least squares criterion. The combiner matrices may be derived based on the transmit matrices used to send data, the gains used for data, a channel response estimate, the front-end filter, signal and/or noise statistics, etc. The combiner matrices may also be derived in accordance with MMSE or some other criterion.


Received data is filtered to process the non on-time signal components in the multiple received signals (block 516). Filtered data is processed to combine the on-time signal components for the multiple transmitted signals (block 518). Received data for more than one symbol period may be filtered to process the non on-time signal components. Filtered data for one symbol period may be processed to combine the on-time signal components. The received data and filtered data may be given in samples, symbols, etc.


For a CDM transmission sent with multiple channelization codes, a single front-end filter may be derived and used to process the non on-time signal components, and multiple combiner matrices may be derived and used to combine the on-time signal components for the multiple channelization codes. In one scheme, the received data is first filtered with the front-end filter to obtain intermediate data. The intermediate data is then despread for each channelization code to obtain filtered data for the channelization code. The filtered data for each channelization code is further processed with a combiner matrix for that channelization code to obtain output data for the channelization code. In another scheme, the received data is first despread for each channelization code to obtain despread data for the channelization code. The despread data for each channelization code is then filtered with the same front-end filter to obtain filtered data for the channelization code. The filtered data for each channelization code is further processed with a combiner matrix for the channelization code to obtain output data for the channelization code.


For CDM, the front-end filter may be derived based on the received data and known pilot, e.g., based on (a) samples for the received data and known pilot chips for chip level training or (b) despread pilot symbols obtained from the received data and known pilot symbols for symbol level training. The combiner matrices may be derived based on the transmit matrices used for the multiple channelization codes, the gains for the multiple channelization codes, a channel response estimate, the front-end filter, signal and/or noise statistics, etc., or a combination thereof. The front-end filter and channel response estimate may be estimated jointly, e.g., as WpH{tilde over (H)}.


The multi-stage receiver may also be used for other communication systems. For example, in a time division multiplexed (TDM) system, a front-end filter may be derived based on pilot received in a first time interval, and a combiner matrix for a second time interval may be derived based on a transmit matrix used in the second time interval. Data received in the second time interval may be filtered with the front-end filter, and the filtered data may be further processed with the combiner matrix.


In general, a filter may be derived based on pilot, which may be sent on a particular channelization code and/or time interval and using a particular transmit matrix and gain. The filter derived from the pilot may be used to derive a filter for data, which may be sent on other channelization codes and/or time intervals and possibly using different transmit matrices and gains.


For CDMA, the on-time and non on-time signal components may be distinguished by the time at which they are transmitted. The receiver may process a window of samples in order to recover a desired symbol transmitted by the transmitter. The timing of the equalizer determines the time instant at which the desired symbol is transmitted relative to the window. The samples obtained by the receiver contain different additive signal components including on-time and non on-time signal components. The on-time signal components are signal components for the desired symbol as well as other symbols transmitted at the same time as the desired symbol. All other signal components are non on-time signal components, which include signal components tracing back to symbols transmitted before and after the desired symbol.


A symbol may be transmitted by a transmit function, which may be dependent on one or more parameters. For example, the transmit function may be dependent on symbol period s, channelization code c, frequency slot or subcarrier index n, etc., and may be denoted as ƒ(s, c, n, . . . ). For simplicity, the transmit function may be dependent on three parameters s, c and n, or a tuple (s, c, n). The transmit functions for different symbols may be orthogonal so that <ƒ(s1,c1,n1), ƒ(s2,c2,n2)>≠0 only if s1=s2, c1=c2 and n1=n2, which may be expressed as (s1,c1,n1)=(s2,c2,n2).


A received signal may include (a) desired signal components from a desired transmit function ƒ(s1,c1,n1) defined by tuple (s1,c1,n1) and (b) other signal components from other transmit functions ƒ(s,c,n), with (s,c,n)≠(s1,c1,n1). The front-end filtering in the first stage would process the other signal components. The combiner in the second stage would process the desired signal components.


For CDM, the transmit functions for symbol period s are determined by channelization codes of length C multiplied by scrambling sequence p(k). The transmit function for symbol period s and channelization code c may be denoted as ƒ(s,c). From the perspective of a symbol transmitted with transmit function ƒ(s1,c1), the received signal contains the following:

    • 1. non on-time signal components corresponding to ƒ(s,c) for s≠s1,
    • 2. on-time signal components corresponding to ƒ(s1,c) and composed of:
      • a. on-time signal components from the desired channelization code and corresponding to ƒ(s1,c1), and
      • b. on-time signal components from other channelization codes and corresponding to ƒ(s1,c2) for c1≠c2.


The front-end filter processes the non on-time signal components corresponding to ƒ(s,c). The descrambling and despreading by the front-end filter also cancels the on-time signal components from other channelization codes and corresponding to ƒ(s1,c2). The combiner processes the on-time signal components from the desired channelization code and corresponding to ƒ(s1,c1).


In a single carrier system that does not utilize CDM, the transmit functions may be simply digital deltas in time and may be given as ƒ(s)=δ(t−s). As time t advances, the position of the delta changes in time.


In an OFDM-based system, the transmit functions may be for different subcarriers and may be given as ƒ(s,n), where n is a subcarrier index. The subcarriers in OFDM may correspond to the channelization codes in CDM. A transmitter may send N data/pilot symbols on N subcarriers in an OFDM symbol period from a given transmit antenna by (a) converting the N data/pilot symbols to the time-domain with an inverse fast Fourier transform (IFFT) to obtain N time-domain samples and (b) appending a cyclic prefix to the time-domain samples to obtain an OFDM symbol. A receiver may obtain received data/pilot symbols for a given receive antenna by (a) removing the cyclic prefix in the received samples and (b) converting N received samples to the frequency-domain with a fast Fourier transform (FFT) to obtain N received symbols for the N subcarriers. The received symbols may correspond to zc(s) in equation (40), where subscript c is replaced with subcarrier index n. For OFDM, the on-time signal components may be signal components sent on a particular subcarrier from different transmit antennas. The non on-time signal components may be signal components sent on other subcarriers. The front-end filter may be implemented by the FFT and cyclic prefix removal at the receiver. A combiner matrix Dc may be computed for each subcarrier and used to combine received symbols from all received antennas for that subcarrier.


Those of skill in the art would understand that information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, symbols, and chips that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.


Those of skill would further appreciate that the various illustrative logical blocks, modules, circuits, and algorithm steps described in connection with the disclosure herein may be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.


The various illustrative logical blocks, modules, and circuits described in connection with the disclosure herein may be implemented or performed with a general-purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.


The steps of a method or algorithm described in connection with the disclosure herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module may reside in RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium known in the art. An exemplary storage medium is coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC. The ASIC may reside in a user terminal. In the alternative, the processor and the storage medium may reside as discrete components in a user terminal.


The previous description of the disclosure is provided to enable any person skilled in the art to make or use the disclosure. Various modifications to the disclosure will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other variations without departing from the spirit or scope of the disclosure. Thus, the disclosure is not intended to be limited to the examples described herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.

Claims
  • 1. An apparatus comprising: at least one processor including: a front-end filter to filter received data to obtain intermediate data;a demodulator to despread the intermediate data for each of a plurality of channelization codes to obtain filtered data for each channelization code;a set of combiners to process the filtered data with one combiner matrix for each channelization code to obtain output data for each channelization code; and
  • 2. The apparatus of claim 1, wherein the at least one processor filters the received data for more than one symbol period to process the non on-time signal components, and processes the filtered data for one symbol period to combine the on-time signal components.
  • 3. The apparatus of claim 1, wherein the at least one processor filters the received data in time domain.
  • 4. The apparatus of claim 1, wherein the at least one processor derives the coefficients of a plurality of combiner matrices for combining the on-time signal components for the plurality of channelization codes used for the multiple transmitted signals.
  • 5. The apparatus of claim 4, wherein the at least one processor processes the filtered data with the plurality of combiner matrices to obtain output data for the plurality of channelization codes.
  • 6. The apparatus of claim 4, wherein the at least one processor derives the coefficients of the front-end filter based on the received data and known pilot.
  • 7. The apparatus of claim 4, wherein the at least one processor derives the coefficients of the front-end filter based on samples of the received data and known pilot chips.
  • 8. The apparatus of claim 4, wherein the at least one processor despreads the received data with a pilot channelization code to obtain despread pilot symbols, and derives the coefficients of the front-end filter based on the despread pilot symbols and known pilot symbols.
  • 9. The apparatus of claim 4, wherein the at least one processor derives the coefficients of the front-end filter based on a least squares criterion.
  • 10. The apparatus of claim 4, wherein the at least one processor derives the coefficients of the plurality of combiner matrices based on a plurality of transmit matrices used for the plurality of channelization codes.
  • 11. The apparatus of claim 10, wherein the at least one processor derives the coefficients of the multiple plurality of combiner matrices further based on gains for the plurality of channelization codes.
  • 12. The apparatus of claim 10, wherein the at least one processor derives the coefficients of the plurality of combiner matrices further based on a channel response estimate and the front-end filter.
  • 13. The apparatus of claim 10, wherein the at least one processor derives the coefficients of the plurality of combiner matrices based on a minimum mean square error (MMSE) criterion.
  • 14. The apparatus of claim 4, wherein the at least one processor derives the coefficients of each of the plurality of combiner matrices for each channelization code based on a noise covariance matrix, the front-end filter, a channel response estimate, and a transmit matrix for the channelization code.
  • 15. The apparatus of claim 4, wherein the at least one processor derives the coefficients of each of the plurality of correlation matrices based on the filtered data and derives the coefficients of a combiner matrix for each channelization code based on the correlation matrix, the front-end filter, a channel estimate, and a transmit matrix for the channelization code.
  • 16. The apparatus of claim 4, wherein the at least one processor updates the coefficient of the front-end filter at a first update rate and updates the coefficients of the plurality of combiner matrices at a second update rate different from the first update rate.
  • 17. The apparatus of claim 1, wherein the at least one processor estimates received signal quality for at least one data signal sent in the multiple transmitted signals.
  • 18. An apparatus comprising: at least one processor including: a front-end filter to filter received data to obtain intermediate data;a demodulator to despread the intermediate data for each of a plurality of channelization codes to obtain filtered data for each channelization code;a set of combiners to process the filtered data with one combiner matrix for each channelization code to obtain output data for each channelization code; anda memory coupled to the at least one processor to store the intermediate data and filtered data, wherein the at least one processor filters the received data to process non on-time signal components in multiple received signals and processes the filtered data to combine on-time signal components for multiple transmitted signals,wherein the at least one processor derives the coefficients of a front-end filter based on pilot received in a first time interval, derives the coefficients of a combiner matrix for a second time interval based on a transmit matrix used in the second time interval, filters received data for the second time interval with the front-end filter to obtain filtered data for the second time interval, and processes the filtered data with the combiner matrix.
  • 19. An apparatus comprising: at least one processor to derive the coefficients of a front-end filter for processing non on-time signal components in multiple received signals, to derive the coefficients of a plurality of combiner matrices for combining on-time signal components for multiple transmitted signals sent with a plurality of channelization codes, to filter received data with the front-end filter and obtain filtered symbols for the plurality of channelization codes, and to process filtered symbols for each of the plurality of channelization codes with a combiner matrix for the channelization code to obtain output symbols for the channelization code, wherein the at least one processor derives the coefficients of the combiner matrix for each channelization code based on a transmit matrix used for the channelization code; anda memory coupled to the at least one processor.
  • 20. The apparatus of claim 19, wherein the at least one processor derives the coefficients of the front-end filter based on the samples of the received data received samples and known pilot chips.
  • 21. A method comprising: filtering received data to process non on-time signal components in multiple received signals with a front-end filter to obtain intermediate filtered data;despreading the intermediate data for each of a plurality of channelization codes to obtain filtered data for each channelization code;processing the filtered data for each channelization code with at least one combiner matrix for each channelization code to combine on-time signal components for multiple transmitted signals,deriving the coefficients of the front-end filter for processing the non on-time signal components; andderiving the coefficients of the plurality of combiner matrices for combining the on-time signal components for the plurality of channelization codes used for the multiple transmitted signals,wherein the deriving of the coefficients of the multiple combiner matrices comprises deriving a combiner matrix for each of the plurality of channelization codes based on a transmit matrix used for the channelization code.
  • 22. The method of claim 21, wherein the deriving of the coefficients of the front-end filter is based on samples for the received data and known pilot chips.
  • 23. An apparatus comprising: means for filtering received data to process non on-time signal components in multiple received signals and obtain filtered data, wherein the means for filtering the received data comprises means for filtering the received data with a front-end filter to obtain intermediate data, and means for despreading the intermediate data for each of a plurality of channelization codes to obtain filtered data for each channelization code;means for processing the filtered data to combine on-time signal components for multiple transmitted signals, wherein the means for processing the filtered data comprises means for processing the filtered data for each channelization code with a combiner matrix for the channelization code to obtain output data for the channelization code;means for deriving the coefficients of the a front-end filter for processing the non on-time signal components; andmeans for deriving the coefficients of the plurality of combiner matrices for combining the on-time signal components for the plurality channelization codes used for the multiple transmitted signals,wherein the means for deriving
  • 24. A processor readable medium media for storing instructions operable to: filter received data to process non on-time signal components in multiple received signals with a front end filter to obtain intermediate data;despread the intermediate data for each of a plurality of channelization codes to obtain filtered data for each channelization code; andprocess the filtered data for each channelization code with at least one combiner matrix for each channelization code to combine on-time signal components for multiple transmitted signals;derive the coefficients of the front-end filter for processing the non on-time signal components; andderive the coefficients of the plurality of combiner matrices for combining the on-time signal components for the plurality of channelization codes used for the multiple transmitted signals,wherein the deriving of the coefficients of the multiple combiner matrices comprises deriving a combiner matrix for each of the plurality of channelization codes based on a transmit matrix used for the channelization code.
CLAIM OF PRIORITY UNDER 35 U.S.C. §119

The present Application for Patent claims priority to Provisional Application Ser. No. 60/741,159, entitled “Bipartite Receiver Structure for MIMO CDMA Downlinks,” filed Nov. 30, 2005, assigned to the assignee hereof, and expressly incorporated herein by reference.

US Referenced Citations (11)
Number Name Date Kind
6301293 Huang et al. Oct 2001 B1
6801565 Bottomley et al. Oct 2004 B1
6990137 Smee et al. Jan 2006 B2
7039134 Avital et al. May 2006 B1
7099299 Liang et al. Aug 2006 B2
7170924 Corbaton et al. Jan 2007 B2
7197282 Dent et al. Mar 2007 B2
7782987 Jonsson Aug 2010 B2
20030165131 Liang et al. Sep 2003 A1
20050047515 Walton et al. Mar 2005 A1
20050201499 Jonsson Sep 2005 A1
Foreign Referenced Citations (19)
Number Date Country
1358355 Jul 2002 CN
1353452 Oct 2003 EP
2003503879 Jan 2003 JP
2004222241 Aug 2004 JP
2005065197 Mar 2005 JP
2005260977 Sep 2005 JP
2005531219 Oct 2005 JP
1020050061536 Jun 2005 KR
2264036 Nov 2005 RU
576029 Feb 2004 TW
WO0101594 Jan 2001 WO
WO0101595 Jan 2001 WO
WO02052743 Jul 2002 WO
WO02080379 Oct 2002 WO
WO2004075499 Sep 2004 WO
WO2004075499 Sep 2004 WO
WO2005086402 Sep 2005 WO
WO2005093961 Oct 2005 WO
WO2005099117 Oct 2005 WO
Related Publications (1)
Number Date Country
20070195865 A1 Aug 2007 US
Provisional Applications (1)
Number Date Country
60741159 Nov 2005 US