SOFT VALUE GENERATION USING SERIAL LOCALIZATION WITH INDECISION

Abstract
Soft bit values are generated for received symbols transmitted based on a modulation constellation by demodulating the received symbols via a sequence of demodulation stages, each demodulation stage producing a symbol decision based on an effective constellation. Each effective constellation used by a non-final one of the demodulation stages includes subsets of centroids approximating a region of the modulation constellation. Adjacent ones of the subsets have one or more common points so that at least two adjacent subsets overlap. The soft bit values for the symbol decisions are determined based on detection metrics computed during demodulation for the points included in the effective constellation constructed incrementally over the sequence of demodulation stages, the effective constellation produced by the final demodulation stage being devoid of one or more points included in the modulation constellation.
Description
TECHNICAL FIELD

The present invention generally relates to bit soft value generation, and more particularly relates to bit soft value generation based on serial localization with indecision.


BACKGROUND

Demodulation involves extracting an original information-bearing signal from a signal which is modulated in accordance with a particular constellation and transmitted over a channel. The complexity of the demodulation process increases significantly for very large signal constellations. Relatively large signal constellations such as 16-, 32- and 64-QAM (Quadrature Amplitude Modulation) have been adopted in EDGE (Enhanced Data Rates for GSM Evolution), HSPA (High Speed Packet Access), LTE (Long Term Evolution) and WiMax (Worldwide Interoperability for Microwave Access). In HSPA, multi-code transmission creates even larger effective constellations. Also, MIMO (Multiple-Input, Multiple-Output) schemes with two or more streams have been adopted in HSPA, LTE and WiMax. MIMO implementations also yield relatively large effective constellations. Demodulation complexity further increases when any of these techniques occur in combination, e.g. multi-code and MIMO.


The ideal demodulation scheme is MLD (Maximum Likelihood Detection). However, the complexity of MLD increases substantially due to the size of the modulation constellation and/or because of the exponential effects of MIMO or multi-codes to the point where MLD becomes impractical. Less complex solutions are available such as sphere decoding (SD), where the demodulator tries to approximate the performance of MLD, but limits its search for the best solution to a subset of all possible transmitted signals, and where the subset is described by a sphere. A key step in SD is the triangular factorization of the channel matrix. This step simplifies the identification of candidate solutions in the sphere.


Another conventional demodulation technique is ITS (Iterative Tree Search) detection for MIMO QAM. ITS can be viewed as an alternative to SD. Like SD, ITS exploits the triangular factorization of the channel. Unlike SD, ITS uses the M-algorithm for reducing the search for the best candidate. ITS breaks down the search further, by dividing the QAM constellation in its four quadrants, and representing each quadrant by its centroid in intermediate computations. The selected quadrant itself is subdivided again into its 4 quadrants, and so on. This results in a quaternary tree search. Other conventional approaches give particular attention to the additional error introduced by the use of the centroids instead of true symbols. The error is modeled as Gaussian noise whose variance is determined and incorporated in likelihood computations. However, a tight connection is typically made between the centroid representation and the bit mapping from bits to symbols. That is, if a so-called multi-level bit mapping is employed, then identifying a quadrant is equivalent to making a decision on a certain pair of bits. Such constraints place a restriction on bit mappings, restricting the design of subsets.


Soft bit information is generated based on the demodulation results. Joint detection (JD) is the MLD form in the MIMO scenario, and is often used in generation of soft bit information. JD searches over all qM effective constellation points for an M×1 vector c of transmitted symbols corresponding to M transmitted streams for the candidate that minimizes the metric m(c)=(r−Hc)HR−1(r−Hc). There are several ways to produce soft values for JD. One conventional approach is based on the concept of nearest neighbors.


A nearest neighbor (NN) is a symbol at the smallest distance from a given symbol. From the perspective of JD, the NNs in principle should be in the “receive domain”. That is, the metric m(c) given above is used, to include the effect of the channel. The distance between two symbol vectors c and d is then given by (Hc−Hd)HR−1(Hc−Hd) where H is an N×M channel coefficient matrix where the columns correspond to the M transmitted streams and R is a noise covariance matrix. Finding NNs in the receive domain is a highly complex operation because the channel effectively distorts the signal constellation, making it difficult to search. Also, since H and R change with time, the operation must be repeated.


Another approach involves finding the NNs in the “transmit domain”, where the constellation is un-distorted by the channel and easily searchable, allowing many factors to be pre-computed. The standard Euclidean distance is also used. Specifically, the effect of the channel is ignored and the neighbors in the original constellation are considered. Furthermore, the NNs of the M individual symbols of a symbol vector can be examined. Altogether, this simplifies the search for NNs. However, some valuable information is lost by ignoring the effect of channel. Also, an NN in the transmit domain is not necessarily an NN in the receive domain.


From the concept of NN arises the concept of bit nearest neighbor (BNN). Without much loss of generality, a constellation with 2J symbols is considered. Let bJ−1Λb0 denote the J bits mapping into symbol ĉ at position k in the symbol vector ĉ. For bit bj, the BNN cj is defined as the closest symbol in the constellation with bj flipped. If multiple symbols satisfy the BNN requirement, one is selected so that the BNN is unique. No conditions are imposed on the remaining J−1 bits, which may or may not change. The BNNs can be computed off-line, from the constellation and the bit map.


Given a soft value solution ĉ out of JD, a symbol vector c is constructed for bit bj where the k-th symbol ĉ is replaced by its BNN cj. The other symbols are left unchanged. The soft value for bit bj in symbol ci is given by βj=m(ĉ)−m( c) where c is commonly referred to as the BNN vector. There is a need to adapt the concept of NNs and BNNs to receiver architectures that employ serial localization with indecision which represents transmitted symbols as a series of approximations.


SUMMARY

Demodulation is performed in a series of stages. Each stage attempts to further localize the search for a solution for the benefit of the next stage, based on input from the previous stage. The demodulator structure is referred to herein as serial localization with indecision (SLIC). SLIC is a lower complexity alternative to MLD, where MLD coincides with joint demodulation (JD) for MIMO environments. Viewed in isolation, a given SLIC demodulation stage can be quite indecisive, but makes progress and avoids an irreversible wrong decision. A given demodulation stage localizes the solution by inputting a subset representative of the constellation and outputting a further reduced subset. Each stage makes a choice among candidate reduced subsets. Indecision arises from representing the modulation constellation with overlapping subsets. Indecision is beneficial in a multi-stage structure, because indecision discourages an irreversible bad decision in an early stage.


The bit nearest neighbor (BNN) concept is adapted to SLIC to account for the centroids used in SLIC. This leads the concept of an effective constellation, which approximates the true constellation with a variable granularity, guided by the stage decisions of SLIC. This enables effective BNNs (EBNN) to be defined, which are used in soft value computations.


According to an embodiment, soft bit values are generated for received symbols transmitted based on a modulation constellation by demodulating the received symbols via a sequence of demodulation stages. Each demodulation stage produces a symbol decision based on an effective constellation. Each effective constellation used by a non-final one of the demodulation stages includes subsets of centroids approximating a region of the modulation constellation. Adjacent ones of the subsets have one or more common points so that at least two adjacent subsets overlap. The soft bit values for the symbol decisions are determined based on detection metrics computed during demodulation for the points included in the effective constellation constructed incrementally over the sequence of demodulation stages, the effective constellation produced by the final demodulation stage being devoid of one or more points included in the modulation constellation.


Of course, the present invention is not limited to the above features and advantages. Those skilled in the art will recognize additional features and advantages upon reading the following detailed description, and upon viewing the accompanying drawings.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates a block diagram of an embodiment of a receiver including a multi-stage SLIC demodulator and a constellation processing module.



FIG. 2 illustrates a block diagram of an embodiment of a two-stage SLIC demodulator.



FIG. 3 illustrates a diagram of an embodiment of overlapping constellation subsets for use by a multi-stage SLIC demodulator.



FIG. 4 illustrates a diagram of an embodiment of overlapping ASK constellation subsets for use by a multi-stage SLIC demodulator.



FIG. 5 illustrates a block diagram of another embodiment of a two-stage SLIC demodulator.



FIG. 6 illustrates a block diagram of an embodiment of an i-th stage of a multi-stage SLIC demodulator.



FIG. 7 illustrates a block diagram of an embodiment of an N-stage SLIC demodulator.



FIG. 8 illustrates a diagram of an embodiment of overlapping QAM constellation subsets for use by a multi-stage SLIC demodulator.



FIG. 9 illustrates a diagram of another embodiment of overlapping QAM constellation subsets for use by a multi-stage SLIC demodulator.



FIG. 10 illustrates a flow diagram of an embodiment of a method for determining a final effective constellation of a SLIC demodulator for use in generating soft bit values.



FIG. 11 shows the bits mapping into each symbol of the modulation example shown in FIG. 10, and the corresponding bit nearest neighbors for each symbol.



FIG. 12 shows different possible effective constellations for various stages of a SLIC demodulator and the corresponding effective bit nearest neighbors.





DETAILED DESCRIPTION


FIG. 1 illustrates an embodiment of a wireless transmitter 100 in communication with a wireless receiver 110 over a channel 120. The receiver includes a baseband processor 130 with a constellation processing module 140, multi-stage SLIC demodulator 150, soft value generation unit 160 and a decoder 170 included in or associated with the baseband processor 130. The constellation processing module 140 groups points of a constellation associated with a transmitted signal into a plurality of subsets, e.g., subsets of ASK constellation points, QAM constellation points, etc. At least two adjacent subsets have one or more common constellation points to ensure that these adjacent subsets overlap. In some embodiments, all adjacent subsets have one or more common constellation points to ensure that all adjacent subsets overlap. In each case, the constellation processing module 140 also determines a centroid-based value for each of the subsets of constellation points and groups the centroid-based values into one or more sets. The values included in each set are centroid-based in that they may be actual centroids, approximations of centroids such as integer values or values quantized to a certain finite precision, the closest constellation point to a centroid, etc. More generally, each subset is assigned a centroid-based representative, which we call a centroid from here on.


The multi-stage SLIC demodulator 150 includes a plurality of stages 152, 154 for performing signal demodulation in stages. Each of the demodulation stages 152 except for the last stage 154 localizes the search for a final symbol decision using the set of centroid-based values input to or selected by the stage 152 as constellation points. The last demodulation stage 154 determines the final symbol decision using a subset of the initial constellation points. This way, each of the demodulation stages 152 except for the last stage 154 further localizes the search for a solution using a set of the centroid-based values as constellation points, reducing the overall complexity of the demodulator. The last stage 154 outputs the final solution based on a subset of the actual constellation. The constellation processing module 140 ensures that at least two adjacent subsets of constellation points overlap to reduce the likelihood of demodulation errors, particularly for the earlier demodulation stages as will be described in more detail later herein. The soft value generation unit 160 determines soft bit values for the symbol decisions generated by the demodulator based on detection metrics computed during demodulation for the points included in the effective constellation constructed incrementally over the sequence of demodulation stages as will be described in more detail later herein, with the final effective constellation being produced by the final stage of the demodulator. The decoder 170 processes the soft values produced by the soft value generation unit 160 for modem bits. The decoder 170 uses the soft values as an input to determine the information bits, and is the companion function at the receiver for the encoder at the transmitter.



FIG. 2 illustrates an embodiment of a 2-stage SLIC demodulation structure 200 included in the receiver 110 of FIG. 1 for demodulating a received signal rk. The received signal rk is carried over the channel 120 and originally modulated at the transmitter 100 using symbol constellation Q. For purely illustrative purposes only, signal rk in a single input single output (SISO) scenario of a signal transmission embodiment over a noisy channel with no ISI (Inter-Symbol Interference) is given by:






r
k
=H
0
s
k
+v
k   (1)


where vk represents white Gaussian noise, H0 represents the channel 120, sk represents the transmitted symbols and all quantities are scalar. One skilled in the art can readily expand the signal model represented by equation (1) to other scenarios such as MIMO and multi-coded transmission, where the quantities in equation (1) become vectors and matrices. The originally transmitted signal has symbol constellation Q of size q. The constellation processing module 140 of the receiver 110 groups the points of constellation Q into a plurality of subsets in a way that ensures at least two adjacent subsets overlap. The constellation processing module 140 also determines a centroid-based value for each of the subsets of constellation points and generates an alternative constellation Q′ including the centroid-based values, not necessarily belonging to Q, for input to a first stage 210 of the 2-stage SLIC demodulation structure 200.


The first stage 210 of the SLIC structure 200 performs demodulation using the alternative constellation Q′. That is, the first demodulation stage 210 uses the centroid-based values included in Q′ as constellation points. Each point in Q′ represents a subset of clustered points in Q. In one embodiment, each centroid-based value included in Q′ is the actual centroid for the points of a particular subset of Q. In another embodiment, the centroids are approximated as integer values. In yet another embodiment, each centroid-based value included in Q′ is the constellation point of Q located closest to the corresponding centroid value. Still other types of values may be used which are derived based on the centroids determined from the different subsets of Q.


The first demodulation stage 210 outputs a symbol decision s′k[1], which belongs to Q′. The second demodulation stage 220 accepts s′k[1] and uses s′k[1] to choose a localized subset Q″ of Q as its own constellation. The decision s′k[1] output by the first demodulation stage 210 can be interpreted to be the representative of Q″ in the first demodulation stage 210. The second demodulation stage 220 outputs the final symbol decision ŝk, which belongs to Q″. The final symbol decision ŝk output by the second stage 220 is determined based on the original received signal rk and subset Q″, which is selected based on the localized symbol decision s′k[1] output by the first stage 210. In one embodiment, both demodulation stages 210, 220 implement MLD over their respective alphabets. Alternatively, the demodulation stages 210, 220 implement other types of demodulation schemes such as joint detection, sphere decoding, tree searching, etc. The 2-stage SLIC demodulation structure 200 makes q′=|Q′| comparisons in the first stage 210 and q″=|Q″| comparisons in the second stage 220. Complexity of the SLIC structure 200 is reduced when q′+q″<q. Also, SLIC has constant complexity, unlike many suboptimal techniques whose complexity is a random variable.


SLIC can mimic the behavior of MLD. The performance of the 2-stage SLIC structure 200 of FIG. 2 is primarily limited by that of the first demodulation stage 210, which in turn is determined by the choice of subsets. Performance suffers when no adjacent subsets overlap. Consider the case of disjoint subsets. MLD implicitly defines a decision region (Voronoi region) around each constellation point, consisting of received values closest to that point than any other. The decision region boundaries are polyhedrons (made up of sections of hyperplanes). Two constellation points x and y are neighbors if their decision regions touch. The common part is a section of the hyperplane P(x,y) that bisects the space according to x and y. In degenerate cases, the common part can become a line or a point. Now consider two adjacent subsets X and Y of Q which are available to the first demodulator stage 210 of the two-stage SLIC structure 200. Subsets X and Y have centroids c(X) and c(Y), respectively. Consider neighbor pair (x,y), where x belongs to X and y belongs to Y. Suppose x is transmitted, and the first demodulation stage 210 makes an error and chooses subset Y instead of subset X. The effective decision boundary of the first demodulation stage 210 is the hyperplane P(c(X),c(Y)). In contrast, MLD would make the choice based on P(x,y). For the sake of comparison, MLD can be thought of as making an effective decision between X and Y. Then the effective decision boundary is made up of the sections P(x, y) of different nearest neighbor pairs (x,y).



FIG. 3 illustrates the effective decision boundary between adjacent subsets X and Y in two dimensions, where the hyperplane becomes a straight line and each constellation point is represented by a circle. In contrast, the decision boundary for MLD is a piecewise straight jagged line. The discrepancy between these hypothetical decision boundaries leads to a performance loss in SLIC.


Overlapping two or more adjacent subsets smoothes the decision boundary discrepancy. In particular, in the two stage SLIC, including nearest neighbor symbols pairs in the overlap of adjacent subsets of the first demodulation stage means that the first demodulation stage does not have to make a decision about those symbols. That decision will be made in the second stage.


With SLIC, the search is further localized from one stage to the next, but the final decision is not made until the last stage. In particular, by making nearest neighbor symbols belong to multiple subsets, a later demodulation stage (e.g. the second stage 220 in FIG. 2) may recover from an error in an earlier stage (e.g. the first stage 210 in FIG. 2). In this context, indecision is beneficial. However, ensuring adjacent subsets overlap has a cost. In terms of complexity, q′ or q″, or both, will increase for the overlap case in comparison to the disjoint case.



FIG. 4 illustrates an exemplary embodiment of an 8-ASK constellation grouped into three subsets. The 8-ASK constellation is given by:






Q={−7, −5, −3, −1, +1, +3, +5, +7}  (2)


The three overlapping subsets shown in FIG. 4 have centroids given by:






Q′={−4, 0, +4}  (3)


The overlap means that the second demodulation stage 220 of the SLIC structure 200 of FIG. 2 can often recover from a bad decision by the first demodulation stage 210. The two outer subsets shown in FIG. 4 are offsets of one another, and the offset is equal to the centroid difference. SLIC complexity can be further reduced by accounting for the highly structured nature of these subsets. Of course, less structured subsets can also be used with SLIC.



FIG. 5 illustrates another embodiment of a 2-stage SLIC demodulation structure 500 for demodulating signal rk. The 2-stage SLIC structure 500 shown in FIG. 5 is similar to the one shown in FIG. 2, except it is tailored to the highly structured nature of the ASK constellation subsets shown in FIG. 4. The constellation input to or selected by the first demodulation stage 510 is the set of centroids denoted Q′[1]. The first modulation stage 510 outputs a decision ŝ′k[1] which is the centroid-based value included in Q′[1] that most closely corresponds to the signal rk. The first demodulation stage 510 also generates a re-modulated signal {circumflex over (r)}′k[1] as a function of ŝ′k[1] and the channel 120 over which the signal is carried as given by:





{circumflex over (r)}′k[1]=H0ŝ′k[1]  (4)


where H0 represents the channel 120.


The first demodulation stage 510 removes the re-modulated signal from {circumflex over (r)}′k[1] to generate a modified signal rk[1] for input to the second stage 520 as given by:






r
k
[1]
=r
k
−{circumflex over (r)}′
k
[1]  (5)


The modified signal rk[1] is then fed to the second demodulation stage 520 instead of the original signal rk. The second demodulation stage 520 determines the final symbol decision ŝk by demodulating rk[1] output by the first stage 510 using subset q′[2] of constellation points input to or selected by the last stage 520 to generate a localized symbol decision ŝ′k[2] associated with the second stage 520. A summer 530 included in or associated with the second demodulation stage 520 sums ŝ′k[1] and ŝ′k[2] to generate the final symbol decision ŝk as given by:






ŝ
k
=ŝ′
k
[1]
+ŝ′
k
[2]  (6)


To account for change to the input of the second demodulation stage 520, constellation Q′[2] is the subset of Q centered so its centroid is equal to 0. With regard to the subset embodiment shown in FIG. 4, Q′[2] is the middle subset. The decision s′k[2] output by the second demodulation stage 520 is an element of Q′[2]. Considering again an exemplary 8-ASK constellation embodiment, Q′[1]={−4, 0, +4} and Q′[2]={−3, −1, +1, +3}. The second subset Q′[2] corresponds to the 4-ASK constellation. This SLIC embodiment is referred to herein as SL34. The corresponding number of comparisons is 3 and 4, for a total of 7 compared to 8 for MLD. The computational efficiency SLIC has over MLD increases substantially for MIMO and multi-code transmission scenarios.


An L×L MIMO embodiment is described next, where a plurality of signal components are transmitted from multiple antennas and received from multiple antennas. The number of transmit and receive antennas are both assumed to be equal to L. Those skilled in the art will recognize that the number of receive antennas may in fact be smaller or larger than the number of transmit antennas. Now rk, sk and vk in equation (1) are L×1 vectors and H0 is an L×L matrix. For ease of explanation only and without much loss of generality, the same constellation is presumed to be used for all L transmitted signals. However, those skilled in the art will recognize that the embodiments described next can be readily expanded to cover the scenario where some or all of the L transmitted signals have different constellations. The effective constellation at the receiver has points given by H0ŝk and size q. Unlike the SISO case, where the channel 120 applied a trivial scaling and rotation to the constellation, here the effective constellation gets distorted by H0. In principle, overlapping subsets can be designed for the effective constellation. However, the effective constellation changes with the channel 120, and thus so would the design of the overlapping subsets. In another embodiment, the subsets can be designed on a signal component basis. According to this embodiment, the discrepancy between the MLD and SLIC decision boundaries can be big enough to affect performance of the SLIC when the effective constellation is distorted significantly. However, this embodiment still proves to be very resilient.


Again turning to the exemplary 8-ASK constellation, the 8-ASK constellation is applied to 2×2 MIMO in an embodiment, where each signal component constellation is 8-ASK. For the 2-stage SLIC structure 500 shown in FIG. 5, the three overlapping subsets shown in FIG. 4 are used for each signal component constellation. According to the SL34 embodiment, the first demodulation stage 510 compares 3×3=9 candidates and the second demodulation stage 520 compares 4×4=16 candidates, for an SLIC total of 25. In contrast, MLD compares 8×8=64 candidates. In an alternate embodiment, the set of centroid-based values input to the first demodulation stage 510 includes four values and is given by Q′[1]={−5, −1, +1, +5}. The subset points input to the second demodulation stage 520 includes three ASK localized constellation points given by Q′[2]={−2, 0, +2}. This SLIC embodiment is referred to herein as SL43. In yet another embodiment referred to herein as SL25, Q′[1]=−3, +3} and Q′[2]={−4, −2, 0, +2, +4}. In each case, the subsets overlap to reduce the likelihood of errors caused by the 2-stage SLIC structures described herein. The 2-stage SLIC embodiments described herein can be readily extended to any number of desired stages.



FIG. 6 illustrates an embodiment of the i-th stage 600 of an SLIC demodulator structure where i<N. The input to the i-th demodulation stage 600 is the modified received signal rki−1] output by the immediately preceding stage (not shown in FIG. 6). The constellation Q′[i] input to the i-th stage 600 includes a set of centroid-based values determined as previously described herein. A MLD component 610 of the i-th stage 600 outputs symbols ŝ′k[i] based on Q′[i] and rk[i−1]. A re-modulator component 620 of the i-th stage 600 generates a re-modulated signal {circumflex over (r)}′k[i]=H0ŝ′k[i]. A signal subtractor component 630 of the i-th stage 600 subtracts from {circumflex over (r)}′k[1] from rk[i−1] to yield a modified received signal rk[i], which is fed to the next stage (not shown in FIG. 6).



FIG. 7 illustrates an embodiment of an N-stage SLIC demodulation structure 700. The input to the first stage 710 is the original received signal rk[0]=rk. For the last stage 730, the constellation Q′[N] is a subset of Q. There is no need for re-modulation block in the last stage 730. A summer component 740 included in or associated with the last stage 730 determines the overall final symbol decision by adding all intermediate symbol decisions as given by:






ŝ
k
=ŝ′
k
[1]
+Λ+ŝ′
k
[N]  (7)


In one embodiment, each intermediary stage 720 of the N-stage SLIC demodulator 700 has the same structure as the i-th demodulation stage 600 shown in FIG. 6. According to this embodiment, the i-th intermediary stage 720 localizes the search for the final symbol decision ŝk by demodulating a modified version of the received signal rk[i−1] output by the immediately preceding stage using the set of centroid-based values Q′[i] input to or selected by the i-th intermediary stage 720 and outputting a localized symbol decision ŝ′k[i] as described previously herein.


The i-th intermediary stage 720 also generates a re-modulated signal {circumflex over (r)}′k[i] as a function of the channel 120 and the localized symbol decision generated by the stage 720. The re-modulated signal {circumflex over (r)}′k[i] is removed from the modified version of the received signal rk[i−1] output by the immediately preceding stage, e.g. as shown in FIG. 6, to generate a newly modified version of the received signal rk[i] for input to the stage immediately following the i-th intermediary stage 720. Subtracting {circumflex over (r)}′k[i] removes part of the transmitted signal, which acts as self-interference. This enables later stages to operate with less self-interference. The constellation Q′[i] input to or selected by each of the i intermediary stages 720 includes centroid-based values, which may or may not belong to Q, whereas the constellation Q′[N] input to or selected by the last stage 730 is a subset of Q. As such, the last stage 730 of the N-stage SLIC demodulation structure 700 functions as an MLD on what is left from the original signal in rk[N−1].


Broadly, there is no restriction on how the overlapping subsets used for SLIC are defined. Subset size can vary, the number of available subsets can change from stage to stage, etc. For the case of ASK, overlapping subsets can be defined in a way that yields a nested structure and a three subset representation. Consider the general case of 2LASK, having the constellation given by:






Q={−2L+1, Λ, −1, +1, Λ, +2L−1}  (8)


Three overlapping subsets are defined, where the first subset contains the 2L−1 negative points. The second includes the 2L−1 middle points {−2L−1+1, Λ, +2L−1−1}, corresponding to 2L−1ASK. The third subset includes the 2L−1 positive points. The centroids for each of the three subsets are −2L−1, 0 and +2L−1, respectively. The same technique can be used to generate three overlapping subsets for 2L−1ASK, and so on. An N-stage SLIC demodulation structure can then be designed using these subsets with N≦L. Except for the last stage of the N-stage SLIC demodulator, the set of centroids input to or selected by the i-th stage is given by:






Q′
[1]={−2n−i, 0, +2N−i}  (9)


The last stage of the N-stage SLIC demodulator has the constellation of 2L−N+1ASK. In particular, for N=L−1, Q′[N]={−3, −1, +1, +3}. If the maximum number of stages N=L is used, then Q′[N]={−1, +1}. Again considering 8ASK, the SL34 structure satisfies the nested subset design. Alternatively, a 3-stage SLIC demodulator structure with the nested subset design can also be employed where the first and second demodulator stages each compares 9 candidates, and the third (last) demodulator stage compares 4 candidates, for a total of 21, which is slightly less than 25 for the SL34 structure.


The SLIC embodiments described herein can be readily adapted to other modulation schemes such as QAM. The extension of SLIC from ASK to QAM is straightforward. Again, in principle, there is no restriction on how the overlapping subsets are defined. In one embodiment, the nested subset design of 2L-ASK can be generalized to 22L-QAM. Just as QAM can be viewed as taking the product of two ASK constellations to produce the complex QAM constellation, the product of the ASK subsets can be taken to produce the subsets of QAM.



FIG. 8 illustrates an embodiment of generalizing ASK to 16-QAM. Each QAM constellation point shown in FIG. 8 is represented by an ‘X’. The three subsets for ASK, e.g. as shown in FIG. 4, yield nine subsets for 16-QAM as illustrated by the boxes drawn around the different groups of constellation points in FIG. 8. At least two adjacent subsets have overlapping constellation points. The middle subset coincides with 4-QAM, or QPSK (Quadrature Phase-Shift Keying). The nine centroid values for 16-QAM, which are shown as circles in FIG. 8, are also determined from the respective three centroid values for ASK. ASK can be further generalized to 64-QAM. For the SL34 embodiment and 64-QAM, the first demodulation stage compares 9×9=81 candidates and the second demodulator stage compares 16×16=256 candidates, for a total of 337. In contrast, MLD compares 64×64=4096 candidates for 64-QAM. Thus, the reduced-complexity advantage of SLIC becomes more pronounced as the constellation grows.


The design of overlapping subsets need not be based on the component ASK constellation. FIG. 9 illustrates an embodiment of the 16-QAM constellation where each of the subsets is directly determined from the QAM constellation and not derived from ASK. Each QAM constellation point shown in FIG. 9 is represented by an ‘X’ and the subsets are shown as boxes drawn around different groups of constellation points. Again, at least two adjacent subsets have overlapping constellation points. Each of the SLIC embodiments described herein, including subset selection, yield a low complexity alternative to MLD with good performance. SLIC provides a distinct complexity advantage as the effective modulation constellation grows, such as in MIMO and multi-code scenarios.


The soft value generation unit 160 included in the receiver 110 can implement joint detection (JD) in the MIMO scenario to generate soft bit information. Conventional JD operates on the product constellation QM, and SLIC stage i operates on the product constellations (Q[i])M as previously described herein. The SLIC process produces an effective constellation (EC), denoted Qe, which can be viewed as an approximation of QM, with a variable granularity, guided by the SLIC stage decisions ŝ′k[1], ŝk[2] etc. e.g. as shown in FIG. 7. The finer granularity corresponds to the region where SLIC progressively focuses its search, as previously explained above.


The effective constellation Qe is constructed demodulation stage by demodulation stage. Prior to the first demodulation stage 152, Qe consists of (Q[1])M. A symbol vector ŝ′k[1] from (Q[1])M is the decision of the first demodulation stage 152. Before the second demodulation stage, ŝ′k[1] is removed from Qe, and replaced with the set:






ŝ′
k
[1]Γ(Q[2])M={ŝ′k[1]+a, a∈(Q[2])M}  (10)


Compared to ŝ′k[1], the elements of ŝ′k[1]Γ(Q[2])M can be viewed as better approximations to the elements of QM in the region of ŝ′k[1].


Similarly for the second demodulation stage, symbol ŝ′k[2] from (Q[2])M is the decision of the second demodulation stage. By construction, (ŝ′k[1]+ŝ′k[2]) is an element of Qe. Before the third demodulation stage, (ŝ′k[1]+ŝ′k[2]) is removed from Qe, and replaced with the set:





(ŝk[1]+ŝ′k[2])Γ(Q[3])M={ŝ′k[1]+ŝ′k[2]+a, a∈(Q[3])M}  (11)


Compared to (ŝ′k[1]+ŝ′k[2]), the elements of (ŝ′k[1]+ŝ′k[2])Γ(Q[3])M can be viewed as better approximations to the elements of QM in the region of (ŝ′k[1]+ŝ′k[2]).


This construction continues just before the last demodulation stage 154, producing the final Qe, which includes the SLIC solution ŝ=ŝ′k[1]+Λ+ŝk[L] where L corresponds to the last demodulation stage 154. As the constellation size q and number of transmitted symbols M become large, the size of Qe becomes much smaller than ·qM.


The soft value generation unit 160 determines soft bit values for the symbol decisions based on detection metrics computed during demodulation for the points included in the effective constellation constructed incrementally over the sequence of demodulation stages. The effective constellation produced by the final demodulation stage is devoid of one or more points included in the modulation constellation as previously described herein. As such, the soft value generation unit 160 uses the effective constellation constructed incrementally over the sequence of demodulation stages to find effective bit nearest neighbors (EBNNs) closest to the true BNNs, some of which may not be available.


In more detail, the soft value generation unit 160 associates a metric computed by the SLIC process with each element e in the effective constellation Qe. The metric may be a detection metric computed during demodulation for the symbol decisions and/or a detection metric computed during demodulation for symbols corresponding to the EBNNs. In each case, e is of the form e=(ŝ′k[1]+Λ+ŝ′k[i−1]+a) and a belongs to (Q[i])M. In SLIC stage i, a metric is computed for a. The soft generation unit associates that metric with e, which is denoted m(e). In one embodiment, the soft generation unit obtains the metric m(ŝ) for the SLIC solution ŝ from the last demodulation stage 154.



FIG. 10 illustrates an embodiment of determining the final effective constellation of a SLIC demodulator for use in generating soft bit values for a purely illustrative 4-ASK modulation example. For simplicity, let M=1. Suppose ŝ′k[1]=−2, then the final effective constellation is Qe={−3, −1, 0, +2}. The true constellation symbols +1 and +3 are missing as shown in FIG. 10. FIG. 11 shows the bits b1b0 mapping into each symbol ŝ and the corresponding bit nearest neighbors (BNNs) s1 and s2 for each symbol.


The soft value generation unit 160 generates the effective bit nearest neighbors (EBNNs) based on the SLIC solution ŝ. Consider the soft value for bit bj in the k-th symbol ŝ. The soft value generation unit 160 defines an EBNN vector in Qe, denoted {tilde over (s)}, to be used in the soft value computation. The soft value generation unit 160 uses the Euclidean distance in the transmit domain throughout to compute the EBNNs according to an embodiment. Focusing on the k-th symbol e of element e in Qe, the soft value generation unit 160 performs a two step procedure. In the first step, for each e, the soft value generation unit 160 compares e to the true BNN sj and identifies the values e closest to sj. If multiple values e are closest to sj, then the soft value generation unit 160 chooses as {tilde over (s)}j the one among them that is also closest to ŝ. If there is only a single value e closest to sj, then the soft value generation unit chooses e as the EBNN {tilde over (s)}j. Also if e= sj, then the soft value generation unit 160 chooses sj as the EBNN {tilde over (s)}j.


In the second step, the soft value generation unit 160 identifies the elements e in Qe with e={tilde over (s)}j. If multiple elements e have e={tilde over (s)}j, then the soft value generation unit 160 chooses as the EBNN {tilde over (s)} the one among them closest to ŝ. If there is a single element e with e={tilde over (s)}j, then the soft value generation unit 160 chooses it as {tilde over (s)}. In particular, if the vector equal to ŝ except for ŝ replaced with sj belongs to Qe, then the soft value generation unit 160 chooses this value as {tilde over (s)}, coinciding with the original BNN vector s for JD. Also, if {tilde over (s)}jsj, and the vector equal to ŝ except for ŝ replaced with {tilde over (s)}j belongs to Qe, then it will be chosen as {tilde over (s)}. As such, each EBNN corresponds to the point included in the effective constellation Qe produced by the final demodulation stage that is nearest one of the symbol decisions with one of the bits of the symbol decision flipped.


The soft value generation unit 160 then determines the soft value for bit bj in symbol si based on the EBNN vector {tilde over (s)} as given by:





βj=m(ŝ)−m({tilde over (s)})   (12)


By limiting the EBNN vectors to Qe and using their associated SLIC metrics, no new metric computations are required to compute the soft values.


Returning to the 4-ASK example explained above, FIG. 12 shows 3 different effective constellations Qe corresponding to 3 possible decisions for ŝ′[1](−2, 0 and +2) in the first demodulation stage and the corresponding EBNNs {tilde over (s)}1 and {tilde over (s)}2 determined by the soft value generation unit 160 based on the possible outcomes of ŝ as explained above in detail. The soft value generation unit 160 can pre-compute a table such as the one shown in FIG. 12 so that the EBNNs {tilde over (s)}1, Λ {tilde over (s)}L are predetermined and do not require calculation during operation of the receiver 110. Alternatively, the soft value generation unit 160 performs the two-step process described above to determine the EBNNs. The two-step process may be implemented in hardware, software or some combination of both. All of the computations associated with the two-step process may be performed by the soft value generation unit 160. In another embodiment, the true BNNs are predetermined in advance and known a priori to the soft value generation unit 160. This way, the soft value generation unit 160 need not compute the true BNNs in real time, instead working on-the-fly to determine just the EBNNs.


The soft value generation unit 160 can simplify the search for the EBNN vector {tilde over (s)} in the second step. For example, multiple elements e in Qe may have e={tilde over (s)}j. Instead of searching for all such elements and identifying the one closest to ŝ, the soft value generation unit 160 simplifies the search Qe by identifying the first e in Qe with e={tilde over (s)}j and assigning it to the EBNN vector {tilde over (s)}. The order of the search is not important. Moreover, since the search order is not important, the soft value generation unit 160 can go back to the first step, where {tilde over (s)}j is first found. The corresponding element e is then assigned to {tilde over (s)}. The search process ends and the second step is not required. The soft value generation unit 160 then determines the soft bit values based on the EBNN vector in accordance with equation (12) as described above. The soft value generation unit 160 does not attempt to control the symbols of {tilde over (s)} other than the k-th symbol according to this embodiment, and therefore search precision may be reduced with the advantage of faster performance.


With the above range of variations and applications in mind, it should be understood that the present invention is not limited by the foregoing description, nor is it limited by the accompanying drawings. Instead, the present invention is limited only by the following claims, and their legal equivalents.

Claims
  • 1. A method of generating soft bit values for received symbols transmitted based on a modulation constellation, comprising: demodulating the received symbols via a sequence of demodulation stages, each demodulation stage producing a symbol decision based on an effective constellation, each effective constellation used by a non-final one of the demodulation stages including subsets of centroids approximating a region of the modulation constellation, adjacent ones of the subsets having one or more common points so that at least two adjacent subsets overlap; anddetermining soft bit values for the symbol decisions based on detection metrics computed during demodulation for the points included in the effective constellation constructed incrementally over the sequence of demodulation stages, the effective constellation produced by the final demodulation stage being devoid of one or more points included in the modulation constellation.
  • 2. The method of claim 1, comprising: determining an effective bit nearest neighbor for each bit of each symbol decision, each effective bit nearest neighbor corresponding to the point included in the effective constellation produced by the final demodulation stage that is nearest one of the symbol decisions with one of the bits of the symbol decision flipped; anddetermining the soft bit values based on the effective bit nearest neighbors.
  • 3. The method of claim 2, comprising identifying one or more points of the effective constellation used by the final demodulation stage that are closest to a true bit nearest neighbor associated with the modulation constellation, each true bit nearest neighbor corresponding to the point included in the modulation constellation that is nearest one of the points in the modulation constellation with a bit flipped.
  • 4. The method of claim 3, comprising determining which point or points included in the effective constellation used by the final demodulation stage are closest to the true bit nearest neighbors and to the symbol decisions to determine the effective bit nearest neighbors.
  • 5. The method of claim 3, comprising: identifying the first point in the effective constellation used by the final demodulation stage that corresponds to one of the effective bit nearest neighbors for each symbol decision;including the identified constellation point in a vector of effective bit nearest neighbors; anddetermining the soft bit values based on the vector of effective bit nearest neighbors.
  • 6. The method of claim 3, comprising: identifying the point in the effective constellation used by the final demodulation stage that most closely corresponds to one of the effective bit nearest neighbors for each symbol decision;including the identified constellation point in a vector of effective bit nearest neighbors; anddetermining the soft bit values based on the vector of effective bit nearest neighbors.
  • 7. The method of claim 3, comprising determining the soft bit values for the symbol decisions based on detection metrics computed during demodulation for the symbol decisions and detection metrics computed during demodulation for symbols corresponding to the effective bit nearest neighbors.
  • 8. The method of claim 3, comprising: computing the true bit nearest neighbors based on the points included in the modulation constellation; andcomputing the effective bit nearest neighbors based on the points included in the effective constellation.
  • 9. The method of claim 3, wherein the true bit nearest neighbors are predetermined and the effective bit nearest neighbors are computed based on the points included in the effective constellation.
  • 10. The method of claim 3, wherein the true bit nearest neighbors and the effective bit nearest neighbors are predetermined.
  • 11. A wireless communication device, comprising a baseband processor including: a multi-stage demodulator operable to demodulate received symbols transmitted based on a modulation constellation, each demodulation stage of the multi-stage demodulator being operable to produce a symbol decision based on an effective constellation, each effective constellation used by a non-final one of the demodulation stages including subsets of centroids approximating a region of the modulation constellation, adjacent ones of the subsets having one or more common points so that at least two adjacent subsets overlap; anda soft value generation unit operable to determine soft bit values for the symbol decisions based on detection metrics computed during demodulation for the points included in the effective constellation constructed incrementally over the sequence of demodulation stages, the effective constellation produced by the final demodulation stage being devoid of one or more points included in the modulation constellation.
  • 12. The wireless communication device of claim 11, wherein the soft value generation unit is operable to determine the soft bit values based on effective bit nearest neighbors determined for the bits of each symbol decision, each effective bit nearest neighbor corresponding to the point included in the effective constellation used by the final demodulation stage that is nearest one of the symbol decisions with one of the bits of the symbol decision flipped.
  • 13. The wireless communication device of claim 12, wherein the baseband processor is operable to identify one or more points of the effective constellation used by the final demodulation stage that are closest to a true bit nearest neighbor associated with the modulation constellation, each true bit nearest neighbor corresponding to the point included in the modulation constellation that is nearest one of the points in the modulation constellation with a bit flipped.
  • 14. The wireless communication device of claim 13, wherein the baseband processor is operable to determine which point or points included in the effective constellation used by the final demodulation stage are closest to the true bit nearest neighbors and to the symbol decisions to determine the effective bit nearest neighbors.
  • 15. The wireless communication device of claim 13, wherein the baseband processor is operable to identify the first point in the effective constellation used by the final demodulation stage that corresponds to one of the effective bit nearest neighbors for each symbol decision and include the identified constellation point in a vector of effective bit nearest neighbors, and wherein the soft value generation unit is operable to determine the soft bit values based on the vector of effective bit nearest neighbors.
  • 16. The wireless communication device of claim 13, wherein the baseband processor is operable to identify the point in the effective constellation used by the final demodulation stage that most closely corresponds to one of the effective bit nearest neighbors for each symbol decision and include the identified constellation point in a vector of effective bit nearest neighbors, and wherein the soft value generation unit is operable to determine the soft bit values based on the vector of effective bit nearest neighbors.
  • 17. The wireless communication device of claim 13, wherein the soft value generation unit is operable to determine the soft bit values for the symbol decisions based on detection metrics computed during demodulation for the symbol decisions and detection metrics computed during demodulation for symbols corresponding to the effective bit nearest neighbors.
  • 18. The wireless communication device of claim 13, wherein the baseband processor is operable to compute the true bit nearest neighbors based on the points included in the modulation constellation and compute the effective bit nearest neighbors based on the points included in the effective constellation.
  • 19. The wireless communication device of claim 13, wherein the true bit nearest neighbors are predetermined and the baseband processor is operable to compute the effective bit nearest neighbors based on the points included in the effective constellation.
  • 20. The wireless communication device of claim 13, wherein the true bit nearest neighbors and the effective bit nearest neighbors are predetermined.
CROSS-REFERENCE TO RELATED APPLICATION

This application is a continuation-in-part of co-pending U.S. patent application Ser. No. 12/549,132 filed 27 Aug. 2009, the content of which is incorporated herein by reference in its entirety.

Continuation in Parts (1)
Number Date Country
Parent 12549132 Aug 2009 US
Child 12912927 US