I. Field
The present disclosure relates generally to communication, and more specifically to techniques for performing detection and decoding at a receiver in a communication system.
II. Background
A multiple-input multiple-output (MIMO) communication system employs multiple (T) transmit antennas at a transmitter and multiple (R) receive antennas at a receiver for data transmission. A MIMO channel formed by the T transmit antennas and the R receive antennas may be decomposed into M spatial channels, where M≦min {T, R}. The M spatial channels may be used to transmit data in a manner to achieve higher overall throughput and/or greater reliability.
The transmitter may encode and transmit M data streams in parallel via the T transmit antennas. The receiver obtains R received symbol streams via the R receive antennas, performs MIMO detection to separate out the M data streams, and performs decoding on the detected symbol streams to recover the transmitted data streams. To achieve optimal performance, the receiver would need to evaluate many hypotheses for all possible sequences of data bits that might have been transmitted based on all of the information available at the receiver. Such an exhaustive search is computationally intensive and is prohibitive for many applications.
There is therefore a need in the art for techniques to perform detection and decoding with reduced complexity while achieving good performance.
Techniques for performing detection and decoding with reduced complexity while achieving good performance are described herein. These techniques are embodied in various reduced complexity detection schemes described below.
In one reduced complexity detection scheme, a receiver obtains R received symbol streams for M data streams transmitted by a transmitter, performs receiver spatial processing (or spatial matched filtering) on the received symbols to obtain detected symbols, performs log-likelihood ratio (LLR) computation independently for each of D “best” data streams, and performs LLR computation jointly for the M−D remaining data streams, where in general M>D≧1 and M>1. The D best data streams may be selected based on signal-to-noise-and-interference ratio (SNR) and/or other criteria. In another reduced complexity detection scheme, the receiver performs LLR computation independently for each of the D best data streams, performs LLR computation jointly for the M−D remaining data streams, and reduces the number of hypotheses to consider for the joint LLR computation by performing a search for candidate hypotheses using list sphere detection, Markov chain Monte Carlo, or some other search technique.
For both detection schemes, dimensionality is reduced from M to M−D by performing per-stream LLR computation for the D best data streams. The reduction in dimensionality may substantially reduce the number of hypotheses to consider for the joint LLR computation for the M−D remaining data streams. The number of hypotheses may be further reduced by performing a search for candidate hypotheses. These detection schemes may be used for (1) a single-pass receiver that performs detection and decoding once and (2) an iterative receiver that performs detection and decoding iteratively. These and other detection schemes are described in detail below.
Various aspects and embodiments of the invention are also described in further detail below.
The features and nature of the present invention will become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which like reference characters identify correspondingly throughout.
The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any embodiment or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments or designs.
The detection and decoding techniques described herein may be used for various communication systems in which multiple data streams are transmitted in parallel via a communication channel. For example, these techniques may be used for a MIMO system with a single frequency subband, a MIMO system with multiple subbands, a Code Division Multiple Access (CDMA) system, a Frequency Division Multiple Access (FDMA) system, a Time Division Multiple Access (TDMA) system, and so on. Multiple subbands may be obtained with orthogonal frequency division multiplexing (OFDM), single-carrier frequency division multiple access (SC-FDMA), or some other modulation technique. OFDM and SC-FDMA partition the overall system bandwidth into multiple (L) orthogonal subbands, which are also called subcarriers, tones, bins, and so on. Each subband is associated with a subcarrier that may be independently modulated with data. In general, modulation symbols are sent in the frequency domain with OFDM and in the time domain with SC-FDMA. For clarity, much of the description below is for a MIMO system that utilizes OFDM.
At transmitter 110, a TX data processor 120 receives traffic data from a data source 112 and processes (e.g., formats, encodes, interleaves, and symbol maps) the traffic data to generate data symbols, which are modulation symbols for traffic data. A TX spatial processor 130 multiplexes the data symbols with pilot symbols, which are modulation symbols for pilot. A pilot is a transmission that is known a priori by both the transmitter and receiver and may also be referred to as a training signal, a reference, a preamble, and so on. TX spatial processor 130 performs transmitter spatial processing and provides T streams of transmit symbols to T transmitter units (TMTR) 132a through 132t. Each transmitter unit 132 processes (e.g., OFDM modulates, converts to analog, filters, amplifies, and upconverts) its transmit symbol stream and generates a modulated signal. T modulated signals from transmitter units 132a through 132t are transmitted from antennas 134a through 134t, respectively.
At receiver 150, R antennas 152a through 152r receive the T modulated signals, and each antenna 152 provides a received signal to a respective receiver unit (RCVR) 154. Each receiver unit 154 processes its received signal in a manner complementary to the processing performed by transmitter units 132 to obtain received symbols, provides received symbols for traffic data to an RX spatial processor 160, and provides received symbols for pilot to a channel processor 194. Channel processor 194 estimates the response of the MIMO channel from transmitter 110 to receiver 150 based on the received symbols for pilot (and possibly the received symbols for traffic data) and provides channel estimates to RX spatial processor 160. RX spatial processor 160 performs detection on the received symbols for traffic data with the channel estimates and provides soft decisions, which may be represented by LLRs as described below. An RX data processor 170 further processes (e.g., deinterleaves and decodes) the soft decisions and provides decoded data to a data sink 172. The detection and decoding may be performed with a single pass through processors 160 and 170 or iteratively between processors 160 and 170.
Receiver 150 may send feedback information to assist transmitter 110 in controlling the data transmission to receiver 150. The feedback information may indicate a particular transmission mode to use for transmission, a particular rate or packet format to use for each data stream, acknowledgments (ACKs) and/or negative acknowledgments (NAKs) for packets decoded by receiver 150, channel state information, and so on, or any combination thereof. The feedback information is processed (e.g., encoded, interleaved, and symbol mapped) by a TX signaling processor 180, multiplexed with pilot symbols and spatially processed by a TX spatial processor 182, and further processed by transmitter units 154a through 154r to generate R modulated signals, which are transmitted via antennas 152a through 152r.
At transmitter 110, the R modulated signals are received by antennas 134a through 134t, processed by receiver units 132a through 132t, spatially processed by an RX spatial processor 136, and further processed (e.g., deinterleaved and decoded) by an RX signaling processor 138 to recover the feedback information. A controller/processor 140 controls the data transmission to receiver 150 based on the received feedback information. A channel processor 144 may estimate the response of the MIMO channel from receiver 150 to transmitter 110 and may derive spatial mapping matrices used by TX spatial processor 130.
Controllers/processors 140 and 190 control the operation at transmitter 110 and receiver 150, respectively. Memories 142 and 192 store data and program codes for transmitter 110 and receiver 150, respectively.
Within TX data processor 120, an encoder 220 encodes traffic data in accordance with a coding scheme and generates code bits. The coding scheme may include a convolutional code, a Turbo code, a low density parity check (LDPC) code, a cyclic redundancy check (CRC) code, a block code, and so on, or a combination thereof. A demultiplexer (Demux) 222 demultiplexes (or parses) the code bits into M streams and provides the M code bit streams to M sets of processing units. Each set includes a puncture unit 224, a channel interleaver 226, and a symbol mapper 228. Each puncture unit 224 punctures (or deletes) code bits, as necessary, to achieve a code rate selected for its stream and provides the retained code bits to an associated channel interleaver 226. Each channel interleaver 226 interleaves (or reorders) its code bits based on an interleaving scheme and provides interleaved bits to an associated symbol mapper 228. The interleaving may be performed separately for each data stream (as shown in
Each symbol mapper 228 maps its interleaved bits in accordance with a modulation scheme selected for its stream and provides a stream of data symbols {sm}. The symbol mapping for stream m may be achieved by (1) grouping sets of Qm bits to form Qm-bit values, where Qm≧1, and (2) mapping each Qm-bit value to one of 2Q
Within TX spatial processor 130, a multiplexer (Mux) 230 receives the M data symbol streams from symbol mappers 228a through 228m and maps the data symbols and pilot symbols to the proper subbands in each symbol period. A matrix multiplier 232 multiplies the data and/or pilot symbols for each subband l with a spatial mapping matrix P(l) and provides transmit symbols for that subband. Different spatial mapping matrices may be used for different transmission modes, and different spatial mapping matrices may be used for different subbands for some transmission modes, as described below.
Transmitter 110 typically encodes each packet separately. In an embodiment, the M data streams are jointly encoded so that a single packet may be sent on multiple (e.g., all M) spatial channels. In another embodiment, the M data streams are independently encoded so that each packet is sent on one spatial channel. In yet another embodiment, some data streams are jointly encoded while remaining data streams are independently encoded.
For clarity, the following description assumes that one data stream is sent on each spatial channel. The terms “data stream” and “spatial channel” are thus interchangeable for much of the description below. The number of data streams may be configurable and may be selected based on channel conditions and/or other factors. For clarity, the following description assumes that M data streams are sent on M spatial channels.
Within RX spatial processor 160a, a spatial filter matrix computation unit 308 receives the channel estimates from channel processor 194 and derives spatial filter matrices based on the channel estimates and the spatial mapping matrices used by transmitter 110, as described below. A MIMO detector 310 obtains the received symbols from R receiver units 154a through 154r, the channel estimates from channel processor 194, and the spatial filter matrices from unit 308. MIMO detector 310 performs detection as described below and provides K soft decisions for K code bits of M data symbols sent on each subband in each symbol period used for data transmission. A soft decision is a multi-bit value that is an estimate of a transmitted code bit. The soft decisions may be represented as LLRs and may be referred to as extrinsic LLRs. If M data symbols are sent on one subband in one symbol period, then K may be computed as
where Qm is the number of code bits used to form a data symbol for stream m. If the same modulation scheme is used for all M data streams, then K may be computed as K=M·Q, where Q is the number of code bits for each data symbol.
Within RX data processor 170a, channel deinterleavers 316a through 316m receive the extrinsic LLRs for the M data streams. Each channel deinterleaver 316 deinterleaves the extrinsic LLRs for its stream in a manner complementary to the interleaving performed by channel interleaver 226 for that stream. A multiplexer 318 multiplexes (or serializes) the deinterleaved LLRs from channel deinterleavers 316a through 316m. A decoder 320 decodes the deinterleaved LLRs and provides decoded data. The detection and decoding are described in detail below.
Within RX spatial processor 160b, a unit 408 derives spatial filter matrices based on the channel estimates and the spatial mapping matrices used by transmitter 110. A MIMO detector 410 obtains the received symbols from R receiver units 154a through 154r, the channel estimates from channel processor 194, the spatial filter matrices from unit 408, and a priori LLRs from a decoder 420. The a priori LLRs are denoted as La(bk) and represent a priori information from decoder 420. MIMO detector 410 performs detection as described below and provides K detector LLRs for K code bits of M data symbols sent on each subband in each symbol period used for data transmission. The detector LLRs are denoted as L(bk). K summers 412a through 412k subtract the a priori LLRs from the detector LLRs and provide extrinsic LLRs, which are denoted as Le(bk). The extrinsic LLRs represent extrinsic or new information from MIMO detector 410 to decoder 420.
Within RX data processor 170b, an M-stream channel deinterleaver 416 deinterleaves the extrinsic LLRs for each stream in a manner complementary to the interleaving performed by channel interleaver 226 for that stream. Channel deinterleaver 416 may include M channel deinterleavers 316a through 316m shown in
RX spatial processor 160b and RX data processor 170b may perform any number of iterations. In an embodiment, processors 160b and 170b perform a predetermined number of iterations (e.g., 4, 6, 8 or more iterations). In another embodiment, processors 160b and 170b perform one iteration, then check if a packet is decoded correctly and/or if a decoder reliability metric is sufficiently high, and perform another iteration if the packet is decoded in error or if the decoder reliability metric is low. The error detection may be achieved with a CRC and/or some other error detection code. Processors 160b and 170b may thus perform a fixed number of iterations or a variable number of iterations up to some maximum number of iterations. The iterative detection and decoding is described in detail below.
The received symbols at receiver 150 may be expressed as:
y(l)=Hch(l)·P(l)·s(l)+n(l)=H(l)·s(l)+n(l), for l=1, . . . , L, Eq (1)
where
In an embodiment, a MIMO detector (e.g., MIMO detector 310 or 410) performs detection separately for each subband based on the received symbols and the channel estimate for that subband and, if available, the a priori LLRs for the data symbols sent on that subband. In another embodiment, the MIMO detector performs detection jointly for multiple subbands. A decoder (e.g., decoder 320 or 420) performs decoding on a sequence of LLRs for a packet, which may be transmitted on one or multiple subbands. For clarity, subband index l is omitted in the following description.
A packet may be partitioned into multiple blocks, with each block containing K code bits. The K code bits for each block may be mapped to M data symbols, as follows:
s=map(b), Eq (2)
where
An optimal receiver for the transmission scheme shown in equation (1) is a maximum likelihood (ML) sequence receiver that performs detection and decoding jointly for an entire packet. This optimal receiver would make joint decisions on all data bits in the packet using knowledge of the correlation introduced by the coding scheme across the blocks, subbands, and OFDM symbols for the packet. The optimal receiver would perform an exhaustive search over all possible sequences of data bits that might have been transmitted for the packet to find the sequence that is most likely to have been transmitted. This optimal receiver would be prohibitively complex.
A receiver that performs detection and decoding iteratively, e.g., as shown in
In an embodiment, the MIMO detector is a maximum a posteriori probability (MAP) detector that minimizes the error probability for each code bit and provides a soft decision for each code bit. The MAP detector provides soft decisions in the form of a posteriori probabilities (APPs) that are often expressed as LLRs. The detector LLR for code bit bk, L(bk), may be expressed as:
where P{bk=+1|y} is the probability of code bit bk being +1 given received vector y; and
The detector LLR may be separated into two parts, as follows:
L(bk)=La(bk)+Le(bk) Eq (4)
where La(bk) is the a priori LLR for code bit bk provided by the decoder or possibly other sources to the MIMO detector and Le(bk) is the extrinsic LLR for code bit bk provided by the MIMO detector to the decoder. The a priori LLR for code bit bk may be expressed as:
where P{bk=+1} is the probability of code bit bk being +1; and
The MAP detector may be a log-MAP detector, a max-log-MAP detector, or some other type of MAP detector. The extrinsic LLR from a log-MAP detector, which is called a log-MAP LLR, may be computed as:
where
Equation (6) shows one expression for the extrinsic LLR from the log-MAP detector. The extrinsic LLR may also be expressed in other forms. The receiver typically derives Ĥ, which is an estimate of the effective MIMO channel response matrix H, and uses Ĥ in the LLR computation. For simplicity, the description herein assumes no channel estimation error, so that Ĥ=H.
Equation (6) is evaluated for each code bit in the transmitted bit vector b. For each code bit bk, 2K hypothesized bit vectors {tilde over (b)} for all possible sequences of code bits {b1 . . . bK} (or all possible combinations of code bit values) that might have been transmitted for vector b are considered. 2K−1 hypothesized bit vectors {tilde over (b)} have bk=+1, and the other 2K−1 hypothesized bit vectors {tilde over (b)} have bk=−1. Each hypothesized bit vector {tilde over (b)} has a corresponding hypothesized data vector {tilde over (s)}. The expression within the summation is computed for each hypothesized bit vector {tilde over (b)} to obtain a result for that bit vector. The results for the 2K−1 hypothesized bit vectors {tilde over (b)} with bk=+1 are summed to obtain a total result for the numerator. The results for the 2K−1 hypothesized bit vectors {tilde over (b)} with bk=−1 are summed to obtain a total result for the denominator. The log-MAP LLR for code bit bk is equal to the natural logarithm (ln) of the total result for the numerator divided by the total result for the denominator.
A max-log-MAP detector approximates the log-MAP LLR in equation (6) and provides a max-log-MAP LLR, as follows:
The max-log-MAP approximation in equation (7) replaces the summations in equation (6) with max { } operations. Only a small degradation in performance typically results from using the max-log-MAP approximation. Other approximations of the log-MAP LLR in equation (6) may also be used.
The log-MAP detector in equation (6) and the max-log-MAP detector in equation (7) make joint decisions on the received symbols in vector y and compute extrinsic LLRs for the code bits associated with these received symbols. In order to compute the extrinsic LLRs optimally, each MAP detector performs an exhaustive search over all possible combinations of data symbols that might have been transmitted for vector s. This exhaustive search is computationally intensive and may be prohibitive for many applications. The complexity of the LLR computation is exponential in the number of bits (K) in the transmitted bit vector b for both the log-MAP and max-log-MAP detectors. In particular, 2K hypotheses are considered by both MAP detectors for each code bit bk. Various detection schemes with reduced complexity are described below.
To reduce computational complexity, the receiver may perform receiver spatial processing (or spatial matched filtering) on the received symbols to obtain detected symbols and may then perform LLR computation independently for each detected symbol. The detected symbols are estimates of the data symbols transmitted by the transmitter. The receiver may perform receiver spatial processing based on a zero-forcing (ZF) technique, a minimum mean square error (MMSE) technique, a maximal ratio combining (MRC) technique, or some other technique. A spatial filter matrix may be derived based on the ZF, MMSE, or MRC technique, as follows:
Mzf=[HH·H]−1·HH, Eq (8)
Mmmse=Dmmse·[HH·H+σn2·I]−1·HH, Eq (9)
Mmrc=Dmrc·HH, Eq (10)
where
The receiver spatial processing may be expressed as:
ŝ=M·y, Eq (11)
where M may be equal to Mzf, Mmmse or Mmrc; and
LLR computation may be performed independently for each detected symbol. The extrinsic LLRs may be computed for the Qm code bits of each detected symbol ŝm with the max-log-MAP detector, as follows:
where
Equation (12) is evaluated for each code bit in each transmitted bit vector bm, for m=1, . . . , M. For each code bit bm,q in bit vector bm2Q
The complexity of the receiver spatial processing is linear in the number of data streams (M) and is not dependent on the signal constellation size. Computing the extrinsic LLRs on a per-stream basis reduces the number of hypotheses to evaluate from 2M·Q to M·2Q, assuming that the same modulation scheme is used for all M data streams. The per-stream LLR computation may substantially reduce computational complexity but may result in higher performance degradation than desired.
In an aspect, the receiver performs receiver spatial processing on the received symbols to obtain detected symbols, performs LLR computation independently for each of D best detected symbols, and performs LLR computation jointly for the M−D remaining detected symbols, where M>D≧1. The D best detected symbols may be for the D data streams with the highest SNRs, the D data streams with the smallest SNR variation, the D data streams with the most robust coding, and so on. This detection scheme is referred to as a reduced dimensionality detection scheme and may be used for the single-pass receiver shown in
The receiver may perform receiver spatial processing on the R received symbols to obtain the D best detected symbols (instead of all M detected symbols). A reduced spatial filter matrix MD of dimension D×R may be derived based on a reduced channel response matrix HD. Matrix HD has dimension of R×D and includes D columns of H corresponding to the D best detected symbols. The receiver spatial processing for the D best detected symbols is less computationally complex.
The receiver may perform LLR computation independently for each of the D best detected symbols, e.g., based on the max-log-MAP detector shown in equation (12) or some other type of detector. The receiver may perform joint LLR computation for the M−D remaining detected symbols in various manners.
In one embodiment, the receiver performs joint LLR computation for the remaining detected symbols by considering the D best detected symbols. For this embodiment, hard decisions are made on the D best detected symbols. A hard decision
assuming that the D best detected symbols have indices of m=M−D+1, . . . , M.
In another embodiment, the receiver performs joint LLR computation for the remaining detected symbols without considering the D best detected symbols. For this embodiment, the receiver forms reduced vectors for {tilde over (b)}, {tilde over (s)}, La,[k] and {tilde over (b)}[k] as well as a reduced matrix for H. The reduced vectors and matrix include only elements corresponding to the remaining detected symbols. The receiver then computes extrinsic LLRs for the code bits for the remaining detected symbols, e.g., based on the max-log-MAP detector shown in equation (7) or some other type of detector. The reduced vectors and matrix are used for the LLR computation. Hence, the number of hypotheses to evaluate and the computation for each hypothesis are both reduced.
In an embodiment, D is a fixed value that may be selected based on a tradeoff between complexity, performance, and/or other considerations. In another embodiment, D is a configurable value that may be selected based on the selected transmission mode, the channel conditions (e.g., the SNRs for the data streams) and/or other factors. D may be adaptive and may be selected per packet, per frame, per subband, or in some other manner.
The reduced dimensionality detection scheme may provide good performance with less complexity than the exhaustive detection scheme shown in equations (6) and (7). The reduced dimensionality detection scheme may be well suited for a data transmission in which some data streams observe high SNRs and/or low frequency selectivity and the remaining data streams observe lower SNRs and/or greater frequency selectivity. Frequency selectivity refers to variation in channel gains across frequency, which results in SNR variation across frequency. The reduced dimensionality detection scheme takes advantage of the high SNRs and/or low frequency selectivity for the D best data streams to reduce computational complexity. Near optimal detection is performed on the remaining data streams with lower SNRs and/or greater frequency selectivity to improve performance over a detection scheme that performs per-stream LLR computation for all M data streams.
A determination is then made whether to perform another iteration of detection and decoding (block 520). The answer for block 520 is ‘No’ after one iteration for a single-pass receiver and is also ‘No’ for an iterative receiver if a termination condition is encountered. If the answer is ‘Yes’ for block 520, then the a priori information is used for detection in the next iteration (block 522), and the process returns to block 514. Otherwise, the soft decisions from the detector are further processed to obtain decoded data (block 524). The soft decisions may also be decoded prior to block 520, and the result of the decoding may be used in block 520 to determine whether or not to perform another iteration.
A packet may be encoded and demultiplexed into multiple subpackets that may be sent on the multiple data streams. A CRC may be used for each subpacket or each data stream. In this case, the CRC for each detected data stream may be checked after block 514, and the subsequent processing may be terminated if the CRC fails for any of the data stream(s) detected in block 514.
The number of hypotheses to consider in the joint LLR computation may be reduced by performing a search for candidate hypotheses using list sphere detection (LSD), which is also referred to as sphere decoding, spherical decoding, and so on. List sphere detection may be used to reduce complexity for the log-MAP detector in equation (6), the max-log-MAP detector in equation (7), and other types of detector. List sphere detection seeks to reduce the search space of the detector by discarding less likely hypotheses based on a cost function. As an example, the log-MAP and max-log-MAP detectors may consider only hypotheses that satisfy the following condition:
∥y−H·{tilde over (s)}∥2≦r2, Eq (13)
where ∥y−H·{tilde over (s)}∥2 is the cost function and r2 is a sphere radius or threshold used to retain or discard hypotheses from consideration.
The cost function in equation (13) may be expanded, as follows:
where R is an upper-triangular matrix obtained from QR decomposition of H; and
QR decomposition may be performed on the effective MIMO channel response matrix H to obtain an orthonormal matrix Q and an upper triangular matrix R, or H=Q·R where QH·Q=I. The upper triangular matrix Rcontains zeros below the main diagonal. The fourth equality in equation (14) may be obtained based on the following: HH·H=[Q·R]H·Q·R=RH·QH·Q·R=RH·R.
For the cost function in equation (14), the detected symbols may be used as the center point for the search. The cost function may then be expressed as:
J({tilde over (s)})=∥R·(ŝ−{tilde over (s)})∥2, Eq (15)
where ŝ may be obtained from equation (11) based on any receiver spatial processing technique (e.g., zero-forcing or MMSE). The cost function in equation (15) may be computed for 2K hypothesized data vectors {tilde over (s)} that might have been transmitted for vector s to obtain 2K cost values for these 2K hypotheses. The hypothesized data vectors with cost values that are less than or equal to r2 may be considered for LLR computation, e.g., in equation (6) or (7).
The structure of the upper triangular matrix R may be exploited to reduce the number of hypotheses for which to compute the cost function. Equation (15) may be expanded as follows:
For M=4, equation (16) may be expressed as:
J=T1+T2+T3+T4, Eq (17)
where
Equation (17) may be generalized for any value of M, as follows:
As shown in equations (18) and (19), the cost function may be decomposed into a sum of M terms T1 through TM. Term TM is only dependent on detected symbol ŝm for stream M, term TM−1 is dependent on detected symbols ŝM−1, and ŝM for streams M−1 and M, and so on, and term T1 is dependent on detected symbols ŝ1 through ŝM for all M streams.
The cost function may be computed incrementally in M levels, one term Ti for each level, starting with the last term TM for the first level. This is indicated by the reverse summation for J in equation (18), which starts with i=M. For each level, Ti is computed for all hypotheses applicable for that level, and the cost function is updated.
The cost function may be computed by considering one additional symbol at a time, starting with ŝM and ending with ŝ1. To improve search performance, the streams may be sorted such that ŝM corresponds to the best stream (e.g., with the highest SNR) and ŝ1 corresponds to the worst stream (e.g., with the lowest SNR). The received vector y and the channel response matrix H may be reordered to achieve the desired ordering for the detected vector ŝ.
The LSD search may be performed in various manners. In a first embodiment, all hypotheses with cost values equal to or less than r2 are retained, and all other hypotheses are discarded. In a second embodiment, only B best hypotheses are retained at each level, and all other hypotheses are discarded. For both embodiments, the total number of hypotheses to consider is reduced by discarding hypotheses with high cost values.
The LSD search may be performed as follows. For the first level, a list PM is formed with 2Q
For the second level, a list PM−1 is formed with 2Q
Each of the remaining levels may be evaluated in similar manner. A list Pi is formed with 2Q
After all M levels have been evaluated, extrinsic LLRs may be computed for all hypotheses stored in candidate list C1, e.g., based on the max-log-MAP detector, as follows:
where Ck+ is a subset of candidate list C1 and contains hypotheses for which bk=+1; and
The extrinsic LLRs may also be computed based on the log-MAP detector or some other type of detector. The cost values already computed for the candidate hypotheses may be used to compute the extrinsic LLRs for these hypotheses. For clarity, the description above uses different candidate lists for different levels. A single candidate list C may be used for all M levels and may be updated at each level.
In an embodiment, the number of candidate hypotheses to store in list C is a fixed value that may be selected based on a tradeoff between detection performance, complexity, and/or other considerations. This fixed value (B) may be for each level, as described above. This fixed value may also be for each node of a given level, in which case BM−i·2Q
Two embodiments for computing cost for list sphere detection have been described above. The cost computation may also be performed in other manners.
List sphere detection is one search technique for reducing the number of hypotheses to consider for LLR computation. Other techniques may also be used to reduce the number of hypotheses for LLR computation. In another embodiment, a Markov chain Monte Carlo (MCMC) technique is used to generate a list of candidate hypotheses. The MCMC technique considers the M elements in data vector s in a sequential manner, evaluates one hypothesis for each element, and cycles through these M elements for multiple iterations. The list sphere detection and MCMC techniques are known in the art and described in various papers.
In another aspect, the receiver performs LLR computation independently for each of D best detected symbols, performs LLR computation jointly for the M−D remaining detected symbols, and reduces the number of hypotheses to consider for the joint LLR computation by performing a search using LSD, MCMC, or some other search technique. This detection scheme is referred to as a reduced order detection scheme and may be used for the single-pass receiver shown in
by performing a search. D may be adaptively selected based on channel conditions (e.g., SNRs) and/or some other factors. The SNR information may be readily obtained from the receiver spatial processing that provides the detected symbols used for the center point of an LSD search.
A determination is then made whether to perform another iteration of detection and decoding (block 822). If the answer is ‘Yes’, then a priori LLRs are computed to be used for LLR computation in the detector in the next iteration (block 824), and the process returns to block 814. Otherwise, the extrinsic LLRs from the detector are processed to obtain decoded data (block 826).
For the iterative receiver, the search for candidate hypotheses may be performed in various manners. In an embodiment, the search is performed for only the first iteration to obtain a list of candidate hypotheses, and this candidate list is used for all subsequent iterations. For this embodiment, the extrinsic LLRs for each subsequent iteration are computed with the a priori LLRs from the decoder and for the candidate hypotheses determined in the first iteration. In another embodiment, the search is performed for each iteration. In yet another embodiment, the search is performed for each iteration until a termination condition is encountered. This termination condition may be triggered, e.g., after a predetermined number of iterations has been completed, if the search provides the same list of candidate hypotheses for two consecutive iterations, and so on. For the embodiments in which the search is performed for multiple iterations, the threshold (e.g., the sphere radius) may be a fixed value for all iterations or may be a configurable value that may be set for each iteration based on, e.g., the a priori information from the decoder.
For the reduced order detection scheme, the reduction in complexity relative to the optimal log-MAP or max-log-MAP detector is dependent on the complexity of the search. For an LSD search, the complexity is determined by the number of nodes visited in the search tree, which in turn is dependent on various factors such as the number of hypotheses to store at each level (e.g., the value for B), the sphere radius r2, the specific channel response matrix H, the SNR, and so on.
In another reduced complexity detection scheme, the receiver performs (1) per-stream LLR computation for all M streams for the first iteration and (2) joint LLR computation for the M−D worst streams or all M streams for a subsequent iteration, if needed, e.g., if the packet is decoded in error.
For the iterative receiver, the channel estimates may be updated during the iterative detection and decoding process to obtain improved channel estimates. For example, if pilot symbols are received and monitored multiple times during the iterative process, then the effective SNR of the channel estimates may be improved over time by performing averaging and/or other processing. The improved channel estimates may be used for receiver spatial processing, e.g., as shown in equations (8) through (10), for LLR computation, e.g., as shown in equations (6), (7) and (12), for cost computation for a search of candidate hypotheses, e.g., as shown in equations (18) and (19).
Various reduced complexity detection schemes have been described above. These schemes reduce the number of hypotheses to consider for the LLR computation while achieving good error rate performance that is close to the performance of the optimal detector.
Decoder 320 in
The detection and decoding techniques described herein may be used for various MIMO transmission schemes, which may also be referred to as transmission modes, spatial modes, and so on. Table 1 lists some exemplary transmission modes and their short descriptions. The steered mode may also be called a beamforming mode, an eigensteering mode, a MIMO mode with beamforming, and so on. The unsteered mode may also be called a basic MIMO mode. The spatial spreading mode may also be called a pseudo-random transmit steering mode, a spatial expansion mode, and so on,
Each transmission mode has different capabilities and requirements. The steered mode typically provides better performance but requires spatial processing at transmitter 110 and receiver 150. The unsteered mode requires no spatial processing at transmitter 110. For example, transmitter 110 may transmit one data stream from each transmit antenna. The spatial spreading mode transmits M data streams with different spatial mapping matrices so that these data streams observe an ensemble of effective channels and achieve similar performance. A suitable transmission mode may be selected based on the availability of channel state information, the capabilities of the transmitter and receiver, and so on.
For the steered mode, data is transmitted on up to M eigenmodes of the MIMO channel, which may be obtained by diagonalizing the MIMO channel response matrix H via singular value decomposition of H or eigenvalue decomposition of a correlation matrix of H, which is A=HH·H. The eigenvalue decomposition of A may be expressed as:
A=HH·H=E·Λ·EH, Eq (21)
where E is a T×T unitary matrix of eigenvectors of A; and
Table 2 shows the transmitter spatial processing for the three transmission modes and the effective MIMO channel response matrix for each transmission mode. In Table 2, the subscript “es” denotes the steered mode (or eigensteering), “us” denotes the unsteered mode, and “ss” denotes the spatial spreading mode.
For a MIMO system with multiple subbands, the transmitter spatial processing shown in Table 2 may be performed for each subband l. In equation (1), P(l)=E(l) for the steered mode, P(l)=I for the unsteered mode, and P(l)=V(l) for the spatial spreading mode. V(l) is a T×T spatial mapping matrix used for spatial spreading and may be generated based on a Hadamard matrix, a Fourier matrix, and so on.
For a MIMO system with multiple subbands, the M eigenvalues for each subband l may be ordered from largest to smallest, so that the eigenmodes of H(l) are ranked from highest SNR to lowest SNR. Wideband eigenmode m may be formed with the m-th eigenmode for each of the L subbands. The principal wideband eigenmode (with m=1) is associated with the largest eigenvalues for all L subbands, the second wideband eigenmode (with m=2) is associated with the second largest eigenvalues for all L subbands, and so on. M data streams may be sent on the M wideband eigenmodes.
The principal wideband eigenmode has the highest average SNR and typically also has less SNR variability across time and frequency. Conversely, the weakest wideband eigenmode has the lowest average SNR and typically has more SNR variability. The techniques described herein may be used for data transmission on the M wideband eigenmodes. In an embodiment, the receiver may perform per-stream LLR computation for one or more of the strongest wideband eigenmodes and joint LLR computation for the remaining wideband eigenmodes. The number of hypotheses to consider for the joint LLR computation may be reduced by performing a search using LSD, MCMC, or some other search technique.
The detection and decoding techniques described herein may be implemented by various means. For example, these techniques may be implemented in hardware, firmware, software, or a combination thereof. For a hardware implementation, the processing units used to perform detection and decoding may be implemented within one or more application specific integrated circuits (ASICs), digital signal processors (DSPs), digital signal processing devices (DSPDs), programmable logic devices (PLDs), field programmable gate arrays (FPGAs), processors, controllers, micro-controllers, microprocessors, electronic devices, other electronic units designed to perform the functions described herein, or a combination thereof.
For a firmware and/or software implementation, the techniques may be implemented with modules (e.g., procedures, functions, and so on) that perform the functions described herein. The software codes may be stored in a memory (e.g., memory 192 in
The previous description of the disclosed embodiments is provided to enable any person skilled in the art to make or use the present invention. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without departing from the spirit or scope of the invention. Thus, the present invention is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
The present application claims priority to provisional U.S. Application Ser. No. 60/738,159, entitled “REDUCED COMPLEXITY INTERATIVE DETECTION AND DECODING FOR MIMO-OFDM SYSTEMS,” filed Nov. 18, 2005, assigned to the assignee hereof and incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5566209 | Forssen et al. | Oct 1996 | A |
6757337 | Zhuang et al. | Jun 2004 | B2 |
7154936 | Bjerke et al. | Dec 2006 | B2 |
7218683 | Ko et al. | May 2007 | B2 |
7317770 | Wang | Jan 2008 | B2 |
7433432 | Hoo | Oct 2008 | B2 |
20030214917 | Molisch et al. | Nov 2003 | A1 |
20040066866 | Tong et al. | Apr 2004 | A1 |
20050018789 | Jia et al. | Jan 2005 | A1 |
20050094713 | Yellin | May 2005 | A1 |
20050135498 | Yee | Jun 2005 | A1 |
20050201478 | Claussen et al. | Sep 2005 | A1 |
Number | Date | Country |
---|---|---|
1521414 | Apr 2005 | EP |
1545082 | Jun 2005 | EP |
2000269825 | Sep 2000 | JP |
2285335 | Oct 2006 | RU |
2297713 | Apr 2007 | RU |
WO03049397 | Jun 2003 | WO |
2004023663 | Mar 2004 | WO |
WO2005034455 | Apr 2005 | WO |
WO2005107125 | Nov 2005 | WO |
Entry |
---|
Bahl et al., “Optimal Decoding of Linear Codes for Minimizing Symbol Error Rate,” IEEE Transactions of Information Theory, pp. 284-287, Mar. 1974. |
Garrett et al., “Silicon Complexity for Maximum Liklihood MIMO Detection Using Spherical Decoding,” IEEE Journal of Solid-State Circuits, 39(9):1544-1552 (2004). |
Hagenauer et al., “A Viterbi Algorithm with Soft-Decision Outputs and its Applications,” IEEE, pp. 1680-1686 (1989). |
Hochwald et al., “Achieving Near-Capacity on a Multiple-Antenna Channel,” Bell Laboratories, Lucent Technologies, Dec. 2002. |
Zhu et al., “On Performance of Sphere Decoding and Markov Chain Monte Carlo Detection Methods,” IEEE Signal Processing Letters, 12(10):669-672 (2005). |
Partial International Search Report—PCT/US06/045031, International Search Authority—European Patent Office, May 14, 2007. |
International Search Report—PCT/US06/045031, International Search Authority—European Patent Office, Aug. 30, 2007. |
Written Opinion—PCT/US06/045031, International Search Authority—European Patent Office, Aug. 30, 2007. |
International Preliminary Report on Patentability—PCT/US06/045031, The International Bureau of WIPO—Geneva, Switzerland, May 20, 2008. |
Arslan et al., “Multi-access Interference Cancellation Receiver for Time-hopping Ultra-wideband Communication”, IEEE International Conference on Communications, XP010712346, Jun. 20, 2004, pp. 3394-3398, vol. 6, Piscataway, New Jersey, USA. |
Sun et al., “Large CDMA Random Access Systems with Exploitation of Retransmission Diversity”, IEEE Military Communications Conference, XP010901651, Oct. 17, 2005, pp. 1-6, Piscataway, New Jersey, USA. |
Forssen et al, “Adaptive Antenna Arrays for GSM900/DCS1800”, IEEE Vehicular Technology Conference, XP010123359, Jun. 8, 1994, pp. 605-609, New York, New York, USA. |
Ye et al., “A Two-Stage Decorrelating Detector for DS/CDMA Systems”, IEEE Vehicular Technology Conference, XP011064247, Mar. 2001, pp. 465-479, vol. 50, No. 2, Piscataway, New Jersey, USA. |
Karjalainen et al., “Antenna-by-Antenna and Joint-over-Antenna MIMO Signal Detection Techniques for Turbo-Coded SC/MMSE Frequency Domain Equalization”, IEEE Vehicular Technology Conference, XP010855547, May 30, 2005, pp. 934-938, Piscataway, New Jersey, USA. |
Xiangyang et al., “Coding-Assisted MIMO Joint Detection and Decoding in Turbo-Coded OFDM”, IEEE Vehicular Technology Conference, XP010608509, Sep. 24, 2002, pp. 23-27, vol. 1 of 4, Conf. 56, New York, New York, USA. |
Kind, “Iterative Decoding of Overloaded Multi-access Systems”, IEEE Communications Theory Workshop Proceedings, XP010912243, Feb. 2, 2005, pp. 255-259, Piscataway, New Jersey, USA. |
Ariyavisitakul et al, “A List Layered Space-Time Approach for MIMO Detection”, IEEE Conference on Communications, XP010825672, May 16, 2005, pp. 2679-2683, vol. 4, Piscataway, New Jersey, USA. |
European Search Report—EP10013237—Search Authority—The Hague—Jan. 5, 2011. |
European Search Report—EP10013238, Search Authority—The Hague Patent Office, Jan. 5, 2011. |
European Search Report—EP10013239, Search Authority—The Hague Patent Office, Jan. 5, 2011. |
Murakami Yutaka et al., “Likelihood Detection Utilizing Ordering and Decision of Partial Bits in Spatial Multiplexing MIMO systems”, IEICE Technical Report, Oct. 13, 2005, vol. 105, No. 356, pp. 31-36. |
Number | Date | Country | |
---|---|---|---|
20070116143 A1 | May 2007 | US |
Number | Date | Country | |
---|---|---|---|
60738159 | Nov 2005 | US |