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.
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
Given a soft value solution ĉ out of JD, a symbol vector
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.
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.
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
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
Q={−7, −5, −3, −1, +1, +3, +5, +7} (2)
The three overlapping subsets shown in
Q′={−4, 0, +4} (3)
The overlap means that the second demodulation stage 220 of the SLIC structure 200 of
{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
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
ŝ
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
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
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.
The design of overlapping subsets need not be based on the component ASK constellation.
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
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.
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
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
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,
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.
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.
Number | Date | Country | |
---|---|---|---|
Parent | 12549132 | Aug 2009 | US |
Child | 12912927 | US |