Not applicable.
Not applicable.
This invention is in the field of digital communications, and is more specifically directed to decoding digital signals received from wireless communications.
High-speed data communication services, for example in providing high-speed Internet access, have become a widespread utility for many businesses, schools, and homes. In its current stage of development, access to these services is available through an array of technologies. Recent advances in wireless communications technology have enabled localized wireless network connectivity according to the IEEE 802.11 standard to become popular for connecting computer workstations and portable computers to a local area network (LAN), and typically through the LAN to the Internet. Broadband wireless data communication technologies, for example those technologies referred to as “WiMAX” and “WiBro”, and those technologies according to the IEEE 802.16d/e standards, have also been developed to provide wireless DSL-like connectivity in the Metro Area Network (MAN) and Wide Area Network (WAN) context. In addition, the communications specifications resulting from the “LTE” (Long Term Evolution) project of the Third Generation Partnership Project (3GPP), which set out to improve the UMTS mobile phone standard, also promise to provide broadband data communication on a wide-area basis.
Multiple-input-multiple-output (MIMO) communication techniques have recently attracted attention, especially in the wireless network context. In a general sense, MIMO communications are realized by providing multiple signal paths between a transmitter and a receiver. In this manner, the transmitted information is either redundantly or independently transmitted as multiple spatial streams between a transmitter antennae and receiver antennae, with the multiple spatial streams combined at the receiver. The spatial diversity provided by the MIMO approach provides improved data rates for a given bit error rate in the signal. These improvements are attractive in any wireless communications context, including wireless LAN/MAN/WAN communications, and wireless telephony. An overview of MIMO technology is provided in Gesbert et al., “From Theory to Practice: An Overview of MIMO Space-Time Coded Wireless Systems”, Journal on Selected Areas in Communications, Vol. 21, No. 3 (IEEE, April 2003), pp. 281-302.
In the wireless network context, particularly in connection with the WiMAX and LTE standards, MIMO communication technology is being investigated for use in conjunction with orthogonal frequency-division multiplexing (OFDM) techniques. As known in the art, OFDM refers to a broadband communications approach in which modulated signals are transmitted over multiple narrow-bandwidth (e.g., 20 kHz) channels. The combination of MIMO and OFDM technologies is contemplated to provide excellent performance in the stringent environment of high data-rate wireless communications.
However, this combination complicates the decoding involved in order to correctly receive digital data over MIMO OFDM communications. In order to secure the MIMO wireless communications link, a MIMO decoder is necessary to resolve the incoming signal received at multiple antennae, at varying delay time. This MIMO decoder is typically realized as a maximum-likelihood (“ML”) decoder, operating at high speed and high throughput in order to provide the desired high data rate performance. Demodulation of the OFDM datastream from its multiple sub-channels requires a Fast Fourier Transform function. And because the communicated data is encoded for purposes of forward error correction, yet another decoder function is necessary at the output of the MIMO OFDM receiver. Indeed, multiple error correction decoders must be made available for the various components of the communicated datastream.
In the example of
In conventional MIMO OFDM receiver system 2, the frequency-domain demodulated signals from FFT functions 61, 62 are applied to MIMO decoder 7, which analyzes the multiple received datastreams y and recovers the transmitted signal x therefrom. As fundamental in the art, recovery of signals x1, x2 that are transmitted over two respective antennae, from signals y1, y2 received over two antennae involves the solution of a system such as:
where the hij matrix members refer to the transfer function from the jth transmit antenna to the ith receive antenna, as shown in
Following MIMO decoder 8, the datastream estimates {circumflex over (x)}1, {circumflex over (x)}2 are communicated to forward error correction function 10, which applies the appropriate error correction decoding to each datastream to recover the digital values of the information that was originally transmitted. As known in the art for WiMAX and LTE communications and as shown in
As is well known in the art, each of these various multiple decoding functions involves complex logic functions and circuitry. A substantial number of logic gates and functions, and thus substantial integrated circuit “chip area”, are necessary to realize these functions, especially as data rates increase. However, the power and chip area requirements of the end systems (e.g., mobile phone handsets, laptop computer wireless access cards) into which these functions are to be implemented are also becoming more stringent. In short, the operational requirements for modern high data rate communications are becoming more complicated, while the chip area and power consumption constraints of the circuitry carrying out those functions are becoming more stringent.
It is therefore an object of this invention to provide circuitry and a method for reducing the circuit cost and complexity for MIMO and Viterbi decoding in the receipt of wireless digital MIMO communications.
It is a further object of this invention to provide such circuitry and method in a manner that does not adversely affect the throughput or fidelity of the data being communicated.
It is a further object of this invention to provide such circuitry and method that is scalable with the sizes and numbers of states of the decoders to be implemented.
Other objects and advantages of this invention will be apparent to those of ordinary skill in the art having reference to the following specification together with its drawings.
This invention may be implemented into circuitry and methods of operating circuitry in a Multiple-Input, Multiple-Output (MIMO) receiver receiving coded communications signals that, at least in part, are to be decoded by way of a Viterbi decoder. Circuitry used in MIMO decoding of demodulated signals from multiple receive antennae is also used in the Viterbi decoding of those decoded signals.
a and 7b are tree and trellis diagrams, respectively, that illustrate the commonality of computational paths in ML estimation and Viterbi decoding according to the preferred embodiment of the invention.
This invention will be described in connection with its preferred embodiment, namely as implemented into the receive path of a transceiver system in a multiple-input, multiple-output (MIMO) communications environment, in which the communicated signals are modulated according to orthogonal frequency division multiplexing (OFDM). This particular embodiment is described in this specification because it is contemplated that this invention will be particularly beneficial when used in such an application. However, it is contemplated that this invention can provide substantial benefit in other applications beyond MIMO OFDM decoding, particularly in those applications in which decoding using both maximum-likelihood (ML) estimation or similar tree search minimization techniques, and also Viterbi decoding or other trellis-based decoding. Accordingly, it is to be understood that the following description is provided by way of example only, and is not intended to limit the true scope of this invention as claimed.
It is contemplated that receiver 20 will typically be implemented within a wireless network device that both receives and transmits OFDM-modulated communications over multiple antennae. For clarity of this description, only the receiver side of such a device is shown in
In the example of
According to the preferred embodiment of the invention, the demodulated signals from FFT functions 261, 262 are applied to MIMO decoder 27. MIMO decoder 27 generates estimates of the two signals x1, x2 that were originally transmitted from the two transmitting antennae ATX1, ATX2, from the signals received at the two receive antennae ARX1, ARX2, considering that each receive antenna will receive a signal component from both of the transmitting antennae. In general, as discussed above, the signals y1, y2 received at the two receive antennae ARX1, ARX2 are the result of a linear system:
where the hij matrix members refer to the transfer function from the jth transmit antenna to the ith receive antenna, and where noise received at the ith receive antenna is represented by ni. In this example as in conventional receivers, channel estimation function 27 drives an estimate of the transfer functions and of received noise from training signals received and demodulated by FFT functions 26. The transfer functions and noise estimates are communicated by channel estimation function 27 to MIMO decoder 28 as transfer matrix estimate ĥ and channel noise estimates {circumflex over (n)}1, {circumflex over (n)}2 MIMO decoder 28 in return produces datastream estimates {circumflex over (x)}1, {circumflex over (x)}2, which are estimates of the signals transmitted at antennae ATX1, ATX2, respectively, accounting for channel distortion and noise.
In receiver 20 of
According to the preferred embodiment of this invention, decoder logic circuitry 35 is shared between MIMO decoder function 28 and forward error correction function 30. This sharing results from the discovery, made in connection with this invention, that Viterbi decoding of the control channel within a received MIMO OFDM frame is performed during such time as MIMO decoder 28 is idle, and that MIMO decoder 28 operates during such time as Viterbi decoding of the control channel is not being performed. This temporal alternating of these two functions is due to the dependence of data channel MIMO decoding on the content of the control channel of that frame. As is apparent from the description above, MIMO decoding of received signals by MIMO decoder 28 is carried out for the control channel prior to the Viterbi decoding of that control channel. But MIMO decoding of the data channel is not performed until after Viterbi decoding of the control channel indicates that the data channel contains live data. This is because the contents of the control channel for a given MIMO OFDM frame may indicate that the data channel is empty. As such, receiver 20 according to this embodiment of the invention does not carry out MIMO decoding of a data channel in a given frame until the Viterbi decoding of the corresponding control channel is complete; the incoming data channel bits are simply buffered until the control channel information is interpreted. Conversely, Viterbi decoding is not applied to the data channel of MIMO OFDM frames according to the current operative technology; rather, turbo or LDPC decoding is applied to payload data. Because of this operation of conventional MIMO OFDM receivers, it has been discovered, according to this invention, that Viterbi decoding is not performed during such time as MIMO decoder 28 is operating.
According to another discovery made in connection with this invention, maximum-likelihood (ML) estimation decoding, as performed by MIMO decoder 28, and Viterbi decoding involve computations and operations that are very similar to one another.
As a result of these discoveries that ML decoding and Viterbi decoding involve similar computations and are not performed at the same time, the preferred embodiment of the invention incorporates shared logic circuitry 35 that is capable of performing operations involved in ML MIMO decoding and also Viterbi decoding. In effect, this shared circuitry 35 is included in both MIMO decoder function 28 and forward error correction function 30 in receiver 20. Because both of these decoding functions are quite complex, and involve substantial numbers of logic gates and interconnections, the sharing of logic circuitry between ML and Viterbi decoding according to this invention is contemplated to save substantial integrated circuit chip area, and also to substantially reduce power dissipation.
In
Transceiver 45 in this example includes modem processor 51, which is bidirectionally coupled to bus B on one side, and to radio frequency (RF) circuitry 53 on its other side. RF circuitry 53, which may be realized by conventional RF circuitry known in the art, performs the analog demodulation, amplification, and filtering of RF signals received over the wireless channel and the analog modulation, amplification, and filtering of RF signals to be transmitted by transceiver 45 over the wireless channel, both via multiple antennae A1 and A2 in this MIMO context. As such, RF circuitry 53 includes front end functions 241, 242 of
According to the preferred embodiment of the invention, shared ML/Viterbi decoder circuitry 35 is provided within modem processor 51. For example, ML/Viterbi decoder circuitry 35 may be configured as a co-processor function relative to baseband processor 59 or CPU 56. As discussed above relative to
In addition, as discussed above, additional decoder circuitry may also be provided in modem processor 51 according to this preferred embodiment of the invention. As shown in
As known in the art, maximum likelihood (ML) estimation is a useful technique in resolving the multiple datastreams xi transmitted from multiple antennae, from signals yj as received at multiple antennae, considering that each receiver antenna receives signals from each of the multiple transmitter antennae. As discussed above, a vector y of received signals relates to a vector x of transmitted signals by:
y=Hx+n
where H is the matrix of transfer functions among the transmitter and receiver antennae, and where n represents the vector of received noise. For a 2×2 MIMO system (i.e., two transmitter antennae and two receiver antennae), signals y1, y2 received at the two receiver antennae can be expressed in terms of the individual transmitted data streams x1, x2, transfer functions hij between the jth transmit antenna and the ith receive antenna, and received noise ni:
To recover the transmitted datastreams data streams x1, x2 from received signals y1, y2, using estimates of the transfer functions and noise, one must solve this system for components x1, x2 by linear algebra techniques.
According to the well-known approach to ML MIMO decoding, for example as described in commonly assigned U.S. Patent Application Publication No. US 2008/0095281 A1, published Apr. 24, 2008, and incorporated herein by reference, ML estimation of the transmitted vector x of dimension M (M being the number of transmitter antennae) from a received vector y of dimension N (N being the number of receiver antennae) is based on the minimization:
{circumflex over (x)}=argmin|y−Hx|2
where H is the transfer function matrix. The result {circumflex over (x)} is that vector x that produces the minimum of the squared difference. A known approach to the solution of this problem, given the dimensionality of the vectors, involves the decomposition of transfer function matrix H into a triangular form. A preferred approach is the QR decomposition of transfer function matrix H into right triangular form (matrix R discussed below). After this decomposition, the minimization problem can be re-formulated into a “tree” search, which facilitates the calculation of the minimization function for each vector combination, and the selection of the vector that renders the minimum error.
The tree diagram of
D=|{tilde under (y)}−Rx|
2
where vector {tilde over (y)} is the received signal vector
after QR decomposition, where vector x is the transmitted signal vector
being evaluated, and where matrix R is the right triangular matrix derived by QR decomposition of the transfer function matrix H as follows:
as determined in the manner well-known in the art.
Other approaches to ML estimation also involve this distance D calculation. For example, as described in the above-incorporated U.S. patent application Publication, a “zero-forcing” approach can be used to limit the number of branches (i.e., leaves) in the tree search structure for which this calculation is to be made.
As evident from the foregoing description, the complexity of ML estimation and decoding depends on the complexity of the modulation scheme, as well as the number of receiver antennae. The number of “levels” of the tree structure depends on the number of receiver antennae. For example, if signals are received at three receiver antennae, then an additional level of branches will be present; in this case, the top (null) level of the tree diagram would be Level 3, with three levels of states underlying that top level. The number of points in the modulation constellation determines the number of possible states in each level. For example, if 64-QAM modulation is used, sixty-four possible states (S0 through S63) would be available for each symbol. In a 2×2 MIMO receiving 64-QAM modulated signals, Level 1 of the two-level tree diagram would have sixty-four states, and Level 0 would have 4096 possible states (sixty-four possible states for each of the sixty-four Level 1 states).
As noted above, it has been discovered, in connection with this invention, that the Viterbi decoding process involves computations that are quite similar to that involved in ML estimation. As is fundamental in the art, for example as described by Viterbi, “Error Bounds for Convolutional Codes and an Asymptotically Optimum Decoding Algorithm,” Transactions on Information Theory, Volume IT-13, pp. 260-69 (IEEE, 1967), Viterbi decoding effectively calculates the “Hamming distance”, or error distance, between the received symbol value at a given time in a sequence, and each of the possible symbol values that could have been received at that time. Each Hamming distance value for a transition to a state of the decoder is accumulated for that state, along with a “history” of the predecessor state from which that possible symbol value caused a transition. The process is repeated for the next state transition(s), until the code word has been processed (including any tail, or memory flushing, bits). A traceback process is then performed, beginning from the terminal state and following the path of smallest accumulated error metrics and associated predecessor states. The most likely transmitted bits can be identified from this traceback path, despite occasional errors caused by channel and noise effects.
As is well known, and as summarized above, the Viterbi decoder problem is to identify, for a given encoder state at a given point in time, which of the possible state transitions to that state is most likely. From a computational standpoint, this determination is made by identifying the state transition with the minimum Hamming distance between the received symbol value r and the encoder output symbol value y corresponding to that state transition. Of course, the received symbol value r corresponds to the transmitted symbol value x plus noise n injected over the channel (i.e., r=x+n). In other words, over a set of possible state transition output symbol values y, the Viterbi decoding problem amounts to:
argmin|y−r|2
In the trellis diagram of
As evident from the foregoing discussion, similar calculations are involved in ML estimation and Viterbi decoding.
D=|{tilde over (y)}−Rx|
2
which, in expanded form involves the calculations of:
D(x2=S3,x1=S3)=({tilde over (y)}1−r11S3−c12S3)2+({tilde over (y)}2−r22S3)2
D(x2=S3,x1=S2)=({tilde over (y)}1−r11S2−c12S3)2+({tilde over (y)}2−r22S3)2
D(x2=S3,x1=S3)=({tilde over (y)}1−r11S2−c12S3)2+({tilde over (y)}2−r22S2)2
D(x2=S3,x1=S2)=({tilde over (y)}1−r11S3−c12S2)2+({tilde over (y)}2−r22S3)2
b highlights the branch metrics necessary to evaluate the accumulated path metrics (PM) of the four possible paths to state P0 at time (n+2). These four paths also involve four calculations of branch metrics (BM), as follows:
PM(P0,n→P0,n+2)=PM(P0,n)+BM(P0,n→P0,n+2)
BM(P0,n→P0,n+2)=)(rn+1−d(P0,n→P0,n+1))2+(rn+2−d(P0,n+1→P0,n+2))2
PM(P1,n→P0,n+2)=PM(P1,n)+BM(P1,n→P0,n+2)
BM(P1,n→P0,n+2)=(rn,1−d(P1,n→P2,n+1))2+(P2,n+1→P0,n+2))2
PM(P2,n→P0,n+2)=PM(P2,n)+BM(P2,n→P0,n+2)
BM(P2,n→P0,n+2)=(n+1−d(P2,n→P0,n+1))2+(rn+2−d(P0,n+1→P0,n+2))2
PM(P3,n→P0,n+2)=PM(P3,n)+BM(P3,n→P0,n+2)
BM(P3,n→P0,n+2)=(rn+1−d(P3,n→P2,n+1))2+(rn,n+1−d(P2,n+1→P2,n+2))2
where the path metric PM(P0,n) is the accumulated path metric at state P0 at time n, where the branch metric BM(P0,n→P0,n+2) is the branch metric for the branch between state P0 at time n and state P0 at time n+2, where the function d(P0,n→P0,n+1) refers to the encoder output for the state transition between state P0 at time n and state P0 at time n+1, and where rn+1 is the received symbol value for the time interval between time n and time n+1. As evident from a comparison of
Adders 60a, 60b in the example of
The instance of the circuitry illustrated in
Considering the commonality of calculations involved in ML estimation and Viterbi decoding, as discovered in connection with this invention, the parameters defining the ML estimation tree (
N1=2K
The number N1 of nodes in Level 1 of the ML tree depends on the number of points in the modulation constellation of the first symbol value considered (e.g., X2). For the example of QPSK, in which four points are present in the modulation constellation in the complex plane, N1=4. This renders Kmax=3. And, as well known in the Viterbi decoder art, a constraint value K=3 results in 2K−1=4 states at each point in time in the Viterbi trellis. Also according to this preferred embodiment of the invention, the number N2 of nodes in the second level of the ML tree from the top level (i.e., Level 0 of the ML tree of
N2=2R
where R is the maximum radix supportable. This number N2 of nodes in Level 0 corresponds to the total number of combinations of symbol values, and thus on the modulation for the second symbol value considered (e.g., x1). In this embodiment of the invention, both of the symbol values are QPSK modulated (four point constellations). As such, the number of nodes in Level 0 of the ML tree of
Of course, if the particular MIMO decoding to be carried out by an instance of receiver 20 in a particular environment is substantially more or substantially less complex than the corresponding Viterbi decoding, shared decoder circuitry 35 will not be used to full efficiency in one or both of those decoding operations. For example, if the MIMO decoding is substantially more complex than the Viterbi decoder, either the MIMO decoding will require additional iterations through shared decoder logic circuitry 35, or the Viterbi decoding will not fully utilize the shared decoder logic circuitry 35 to decode the control channel of the received frame. It is therefore preferable, depending on the environment of course, to match the MIMO detection function with Viterbi decoding in complexity, according to the relationship discussed above.
The integrated circuit chip area savings attained by sharing logic circuitry between ML search and Viterbi decoding according to this preferred embodiment of the invention is contemplated to be substantial. By way of calculation and simulation in connection with an example of 2×2 64-QAM modulated MIMO OFDM signals, it has been determined that Viterbi decoding with a constraint K=7 (determined from the 64-QAM constellation as discussed above), and a ⅓ mother code rate, can be supported by the shared ML/Viterbi decoder logic circuitry 35, at a integrated circuit chip area saving of 35% relative to the chip area required if these functions were implemented separately.
Referring now to
The control channel 15 of the received and demodulated data frame is then decoded by shared ML/Viterbi decoder logic circuitry 35, in process 74. To the extent that the data channel 17 of the current frame has been received, that data may be buffered within receiver 20, either before or after filtering and demodulation. As described above, shared decoder logic circuitry 35 preferably applies ML estimation to the contents of control channel 15 to recover an estimate of the datastream as transmitted. Following MIMO decoding process 74, and such other post-MIMO detection processing, the contents of control channel 15 are then decoded according to the Viterbi algorithm in process 76, using shared ML/Viterbi decoder logic circuitry 35, in the manner described above. Shared ML/Viterbi decoder logic circuitry 35 is available for Viterbi decoding in process 76, as discussed above, because further MIMO decoding (i.e., of data channel 17) is not performed until after interpretation of control channel 15.
Following Viterbi decoding process 76, the recovered contents of control channel 15 are then interpreted, for example by MAC processor 57. If the interpreted contents of control channel 15 indicate that payload data is contained within data channel 17 of the current MIMO OFDM frame (decision 77 is YES), MIMO decoding of data channel 17 can then commence in process 78, again using shared ML/Viterbi decoder logic circuitry 35. In process 80, the datastreams recovered from MIMO decoding process 78 can then be decoded for purposes of forward error correction, for example by way of turbo decoding as discussed above. Receiver 20 is then ready to receive the next MIMO OFDM frame.
According to the preferred embodiment of the invention, shared ML/Viterbi decoder logic circuitry 35 is available for use during turbo decoding process 80, considering that turbo decoder logic 32 (
According to the preferred embodiments of this invention, therefore, substantial integrated circuit chip area can be saved by utilizing shared logic circuitry for the two computationally-intensive operations of ML estimation for MIMO decoding, and the calculations involved in Viterbi decoding. This sharing of logic circuitry is enabled, according to this embodiment of the invention, without any deleterious effect on system performance in the MIMO OFDM environment, because of the realization that MIMO decoding is not being carried out during the Viterbi decoding of the control channel portion of the MIMO OFDM frame. Accordingly, the reduced cost and lower power consumption provided by the preferred embodiments of the invention is attained at little or no performance cost.
While this invention has been described according to its preferred embodiments, it is of course contemplated that modifications of, and alternatives to, these embodiments, such modifications and alternatives obtaining the advantages and benefits of this invention, will be apparent to those of ordinary skill in the art having reference to this specification and its drawings. It is contemplated that such modifications and alternatives are within the scope of this invention as subsequently claimed herein.