1. Field of the Invention
This invention relates to MPSK symbol hypothesis testing, and, more specifically, to metrics for performing MPSK symbol hypothesis testing, and systems and methods for providing the metrics.
2. Related Art
An MPSK symbol constellation is a constellation of M possible symbols arranged around a unit circle on the quadrature (I-Q) plane. The value M is a power of two and can be expressed as M=2p. In a transmitter employing an MPSK symbol constellation, a bit to symbol mapper maps successive renderings of p bits into one of the symbols, a modulator modulates a carrier signal with the I and Q values associated with that symbol, and an antenna transmits the signal. In a receiver employing the MPSK symbol constellation, an antenna receives the signal, and a demodulator demodulates the carrier signal to baseband I and Q values. The demodulator or a downstream decoder may then perform hypothesis testing on the received symbols represented by the baseband I and Q values in order to estimate the MPSK symbols that were transmitted.
A conventional approach for performing MPSK symbol hypothesis testing is through a look up table containing entries for all possible hypotheses for all possible received symbols. For a given received symbol, a metric for a particular hypothesis is obtained by performing an access to the lookup table. Multiple accesses may be performed for each of the possible hypotheses. The metrics may then be analyzed to estimate the symbol corresponding to the most likely hypothesis.
A problem with the conventional approach is that, in certain applications, the amount of memory required may be prohibitive. Consider, for example, an application in which received symbols are represented through 8 bits of resolution, and the symbol constellation is an 8-PSK symbol constellation in which 8 hypotheses are possible for each received symbol. In this application, a lookup table with 211 entries would be required. However, space and cost constraints might not permit a lookup table of this size.
A system for MPSK symbol hypothesis testing is provided by the invention. A received symbol having in-phase (I) and quadrature (Q) components is input to the system. A demodulator may derotate the symbols to achieve proper orientation of the symbol constellation. Multipliers for each of the components are determined corresponding to the MPSK symbol hypothesis being tested. The multipliers are each derived from fractional values which approximate to a desired level of resolution the I and Q values of the symbol hypothesis being tested. The system multiplies the I and Q components by their respective multipliers, and adds the resulting products to form a number from which a metric for testing the hypothesis is derived. Preferably, the multipliers are such that the multiplications can be performed through a discrete series of shift, add, and twos complement operations.
In one embodiment, the symbol constellation is an 8-PSK symbol constellation oriented such that all the symbols are off an I or Q axis by 22.5°. In this embodiment, the multipliers are each equal to either ±{fraction (15/16)}or ±⅜. A multiplication by {fraction (15/16)} in this embodiment may be performed by shifting the multiplicand (either the I or Q component of the received symbol) four places to the right and adding the shifted value to the unshifted multiplicand. A multiplication by −{fraction (15/16)} in this embodiment may be performed by performing the foregoing two steps and then taking the twos complement of the result.
A multiplication by ⅜ in this embodiment may be performed by shifting the multiplicand (again, either the I or Q component of the received symbol) two places to the right, shifting the multiplicand one place to the right, and adding the two shifted multiplicands. A multiplication by −⅜ may be performed by performing the foregoing two steps and then taking the twos complement of the result.
Note that the multiplications in this embodiment may introduce rounding error as bits may be lost due to the shift right operations, and that this problem may be eliminated by padding each of the multiplicands by 4 bits on the right.
In a second embodiment, designed to avoid rounding error without the need to pad each of the multiplicands, the multipliers are each either ±15 or ±6. These values are derived from ±{fraction (15/16)}, ±⅜ by multiplying these values by the common factor 16. To account for this, the rightmost bit of each of the multiplicands is interpreted to be the 2−4 position rather than the 2° position. In effect, a multiplication of each of the multipliers by 16 is counterbalanced by dividing each of the multiplicands by 16.
A multiplication by 15 in this embodiment may be performed by shifting the multiplicand (either the I or Q component of the received symbol) four places to the left and adding the shifted value to the twos complement of the multiplicand. A multiplication by −15 may be performed by performing the foregoing two steps and then taking the twos complement of the result.
A multiplication by 6 in this embodiment may be performed by shifting the multiplicand (again, either the I or Q component of the received symbol) two places to the left, shifting the multiplicand one place to the left, and adding the two shifted multiplicands. A multiplication by −6 may be performed by performing the foregoing two steps and then taking the twos complement of the result.
Note that, in this embodiment, the multiplications do not introduce rounding error and right padding is unnecessary since all the shifting operations are left shift operations. Moreover, left padding is unnecessary by interpreting the rightmost bit of each multiplicand to be the 2−4 position rather than the 2° position.
Consequently, a system is provided for testing an 8-PSK symbol hypothesis in which multiplication is performed through a discrete number of addition, shifting, and twos complement operations.
Other systems, methods, features and advantages of the invention will be or will become apparent to one with skill in the art upon examination of the following figures and detailed description. It is intended that all such additional systems, methods, features and advantages be included within this description, be within the scope of the invention, and be protected by the accompanying claims.
The invention can be better understood with reference to the following figures. The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention. Moreover, in the figures, like reference numerals designate corresponding parts throughout the different views.
I. Example Application
In this section, for illustrative purposes only and without limiting effect, an example application of the invention will be described. However, it should be appreciated that many other applications of the invention are possible. In particular, although the example application here relates to computing a branch metric for use in a log-MAP decoder, it should be appreciated that the invention may be used with any trellis representation or any trellis decoder including, including without limitation, soft output decoders, Viterbi decoders, MAP decoders, log-MAP decoders, SOVA decoders, and MAX-log-MAP decoders. It should also be appreciated that the invention may be used in contexts other than computing metrics for use in decoders. One example is achieving synchronization between a transmitter and a receiver through detection of a known sync word comprising a plurality of MPSK symbols. In this application, the invention could be used to correlate the stream of incoming symbols with the sync word to thereby test for the presence of the sync word.
A trellis decoder utilizes a trellis representation in the decoding process. A trellis representation represents the states of a Markov process, which can be used to model the corresponding encoder, at discrete points in time. Branches between the states represent possible hypotheses about the code symbols that were transmitted or the underlying source bits. Examples of trellis decoders include maximum a posteriori (MAP) decoders, log-MAP decoders, Max-Log-Map decoders, Viterbi decoders, and Soft Output Viterbi (SOVA) decoders. For additional information, please see A, Viterbi, “An Intuitive Justification and a Simplified Implementation of the MAP Decoder for Convolutional Codes,” IEEE Journal On Selected Areas In Communications, Vol. 16, No. 2, February 1998, pp. 260-264; S. Benedetto et al., “A Soft-Input Soft-Output Maximum A Posteriori (MAP) Module to Decode Parallel and Serial Concatenated Codes,” TDA Progress Report 42-127, Nov. 15, 1996, pp. 1-20; D. Divsalar et al., “Turbo Trellis Coded Modulation with Iterative Decoding for Mobile Satellite Communications,” Proc. Int. Mobile Satellite Conf, June 1997; “A Comparison of Optimal and Sub-Optimal MAP Decoding Algorithms Operating in the Log Domain,” Proc. IC '95, Seattle, Wash. 1995, pp. 1009-1013; C. Berrou et al., “Near Shannon Limit Error-Correcting Coding And Decoding: Turbo-Codes,” Proc. IEEE Int. Conf. Commun., Geneva, Switzerland, 1993, pp. 1064-1070; L. R. Bahl et al., “Optimal Decoding of Linear Codes For Minimizing Symbol Error Rate,” IEEE Trans. Inform. Theory, vol. IT-20, pp. 284-287, 1974, each of which is incorporated by reference herein as through set forth in fill.
During the decoding process, state metrics may be computed for each of the states in the trellis, and branch metrics may be computed for each of the transitions in the trellis. These metrics are used by the decoder to evaluate various hypotheses about the symbols that were transmitted or about the underlying source bits. In the log MAP decoding process, the group of hypotheses which maximizes the a posteriori probabilities is selected as the decoder output.
A portion 100 of a trellis representation is illustrated in FIG. 1. The trellis representation illustrates the states of an encoder and transitions between the states over discrete points in time. In
During the decoding process, state metrics are computed for each of the states in the trellis representation, and branch metrics are computed for each of the transitions between the states in the trellis representation.
In a log MAP decoding process, state metrics are computed recursively. Both forward state metrics and backward state metrics are computed. The forward state metrics are metrics which, for states at time k, are computed recursively based on the state metrics for time k−1. The backward state metrics are metrics which, for states at time k, are computed recursively based on the state metrics for time k+1. In
In
In the particular example illustrated in
In a log-MAP decoder, the state and branch metrics are in the natural log domain. Therefore, with a log-MAP decoder, the joint probability of transitioning from a state m to a state m′ at time k, λkmm′, may be expressed αkm+γkmm′+βk+1m′.
Once these joint probabilities have been determined, a log-likelihood ratio function, LLRk may be determined in accordance with the following equation:
LLRk=MAX*∀edges that imply release of 1(λkmm′)−MAX*∀edges that imply release of 0(λkmm′) (1)
where the function MAX*(A,B) is defined to be:
MAX*(A,B)≡MAX(A,B)+ln(1+exp(−|A−B|)) (2)
This value may then be used to estimate the source bit at time k. If the value is greater than 0, the source bit is estimated to be a 1; if the value is less than 0, the source bit is estimated to be a 0.
II. Preferred Embodiments
A. Derivation of Metric
A metric sufficient for testing the hypothesis that a received symbol r resulted from transmitting a hypothesized MPSK symbol s over a communications channel may be represented by the following expression:
where * indicates the complex conjugate operation, σ2 is the variance of the noise introduced by transmission through the channel, and r and s are both quadrature symbols which may be represented by complex numbers.
To explain the derivation of this expression, we will start with the conditional probability of a real random variable and extend this to the case of a complex random variable.
Consider that the conditional probability of a real-valued received symbol r given a real-valued hypothesized symbol s can, assuming transmission occurs over an additive white Gaussian noise channel, be expressed as follows:
Since r and s are quadrature symbols, r can be expressed as the complex number rI+jrQ, where rI is the in-phase component of r, and rQ is the quadrature component of r, and s can be expressed as the complex number sI+jsQ, where sI is the in-phase component of s, and sQ is the quadrature component of s. Since r and s are complex numbers, expression (4) is inapplicable.
However, r can be considered to be formed of a pair two independent random variables, the first being the in-phase component, and the second being the quadrature component. Since the joint probability density function of two independent random variables is given by the product of their respective probability density functions, the probability density function of r given s can be expressed as:
Pr(r|s)=Pr(rI|sI)×Pr(rQ|sQ) (5)
Since the noise added to the in-phase and quadrature components of r is considered to be Gaussian distributed, both Pr(rI|sI) and Pr(rQ|sQ) will be of the form of expression (4). Therefore, expression (5) can be re-expressed as follows:
where σI2 is the variance of the noise added to the I component of transmitted symbol, and σQ2 is the variance of the noise added to the Q component of the transmitted symbol.
Since σI2 and σQ2 can reasonably assumed to be equal, and also given that σ2=σI2+σQ2=σ2σI2, expression (6) can be re-expressed as follows:
Since the natural logarithm is a monotonically increasing function of its argument, expression (7) can be put into the natural log domain with no loss of metric quality. In the natural log domain, this probability can be expressed as:
where K is the constant ln
From the standpoint of determining a metric that may be useful for comparing different symbol hypotheses, the constant K is irrelevant and can be ignored. Thus, expression (8) can be simplified to:
The numerator of expression (9) can be expanded to: −(rI2−2rIsI+sI2+rQ2−2rQsQ+sQ2). In this expanded expression, the terms rI2 and rQ2 can be ignored since they will be the same regardless of symbol hypothesis. In addition, the terms sI2 and sQ2 can be ignored since, for an MPSK symbol constellation, where all the hypothesized symbols lie on the unit circle, the sum sI2+sQ2 will always be 1.
Therefore, expression (9) can be even further simplified to:
The numerator of expression (10) can be re-stated as rs*+r*s. Substituting this for the numerator of expression (10), expression (3) set forth at the outset results.
In the case in which a MAX operation applies to select amongst the competing hypotheses, expression (10) can be further simplified to:
rIsI+rQsQ (11)
That is because MAX is a linear operation, and the constant 2/σ2 in expression (10) is irrelevant since MAX(2A/σ2, 2B/σ2)=2/σ2MAX(A, B). In a Viterbi decoder, the MAX operation is used to select amongst competing hypotheses. Therefore, for use in the Viterbi or MAX-log-MAP decoder, the metric of expression (11) is appropriate.
However, in the case in which a MAX* operation applies to select amongst the competing hypotheses, the 2/σ2 factor must be retained. That is because MAX* is a non-linear operation, and MAX*(2A/σ2, 2B/σ2)≠2/σ2MAX*(A, B). As discussed in the previous section, the MAX* operation is used to select amongst competing hypotheses in a log-MAP decoder. Therefore, for use in a log-MAP decoder, the metric of expressions (3) or (10) is appropriate.
B. An 8-PSK Symbol Constellation
A characteristic of this symbol constellation is that all the symbols are rotated relative to one of the I and Q axes by ±π/8 radians. Therefore, in terms of in-phase (I) and out-of-phase (Q) components, each of these symbols can be expressed either as (±cos(π/8), ±sin(π/8)) or as (±sin(π/8), ±cos(π/8)). For example, the I component of symbols s1 and s8 is cos(π/8), as indicated by numeral 202 in
An approximation which is accurate to 7 bits of resolution is that the factor cos(π/8) can be approximated by {fraction (15/16)}, and sin(π/8) by ⅜. Using these approximations, each of the symbols in
C. Embodiments of Systems According to the Invention
An embodiment of a system for forming a metric for testing an 8-PSK symbol hypothesis is illustrated in
Multiplier 308 multiplies rI by a multiplier, and multiplier 310 multiplies rQ by a multiplier, each of which are selected from the values ±{fraction (15/16)}, ±⅜ based on the particular symbol hypothesis, si, being tested. If ±{fraction (15/16)} is selected for rI, then ±⅜ is selected for rQ, and vice-versa. The value selected for rI is identified with numeral 306, and that for rQ is identified by numeral 312.
The resulting products from the multipliers are added by adder 314 to form a number 316 from which a metric for testing the hypothesis is derived. The metric may be the number 316 which results from adding the two products, or it may be derived from that number such as by multiplying the number by 2/σ2 for those applications that require it.
In one implementation, the number 316 is rounded or truncated to a desired or required level of precision before being input to a decoder.
A second embodiment of a system for forming a metric for testing an 8-PSK symbol hypothesis is illustrated in FIG. 3B. Again, a received symbol having in-phase (I) and quadrature (Q) components is input to the system. The component rI is identified with numeral 302, and the component rQ is identified with numeral 304. The component rI forms a multiplicand which is input to multiplier 308. The component rQ forms a multiplicand which is input to multiplier 310.
Multiplier 308 multiplies rI by a multiplier, and multiplier 310 multiplies rQ by a multiplier, each of which are selected from the values ±15, ±6 based on the particular symbol hypothesis, si, being tested. If ±15 is selected for rI, then ±6 is selected for rQ, and vice-versa. The value selected for rI is identified with numeral 318, and that for rQ is identified by numeral 320. Note that ±15 is derived from ±{fraction (15/16)} simply by multiplying the latter by 16, and that ±6 is derived from ±⅜ by again multiplying the latter by 16. To account for this, the rightmost bit in the multiplicands rI and rQ may be re-interpreted to be the 2−4 position rather than the 2° position, thus in effect, dividing the multiplicands by 16 to counterbalance the multiplication of the multipliers by 16.
The resulting products from the multipliers are added by adder 314 to form a number 316 from which a metric for testing the hypothesis is derived. Again, the metric may be the number 316 which results from adding the two products, or it may be derived from that number such as by multiplying the number by 2/σ2 for those applications that require it.
In one implementation, the number 316 is rounded or truncated to a desired or required level of precision before being input to a decoder.
A third embodiment of a system for forming a metric for testing an 8-PSK symbol hypothesis is illustrated in
Multiplier 308 multiplies multiplicand 324 by a multiplier which is ±⅜. Multiplier 310 multiplies multiplicand 326 by a multiplier which is ±{fraction (15/16)}. The multiplier selected for multiplicand 324 is identified with numeral 322, and that for multiplicand 326 is identified by numeral 328.
The resulting products from the multipliers are added by adder 314 to form a number 316 from which a metric for testing the hypothesis is derived. Again, the metric may be the number 316 which results from adding the two products, or it may be derived from that number such as by multiplying the number by 2/σ2 for those applications that require it.
In one implementation, the number 316 is rounded or truncated to a desired or required level of precision before being input to a decoder.
A fourth embodiment of a system for forming a metric for testing an 8-PSK symbol hypothesis is illustrated in
Multiplier 308 multiplies multiplicand 324 by a multiplier which is ±6. Multiplier 310 multiplies multiplicand 326 by a multiplier which is ±15. The multiplier selected for multiplicand 324 is identified with numeral 330, and that for multiplicand 326 is identified by numeral 332.
Note again that ±15 is derived from ±{fraction (15/16)} simply by multiplying the latter by 16, and that ±6 is derived from ±⅜ by again multiplying the latter by 16. To account for this, the rightmost bit in the multiplicands rI and rQ may be re-interpreted to be the 2−4 position rather than the 2° position, thus in effect, dividing the multiplicands by 16 to counterbalance the multiplication of the multipliers by 16.
The resulting products from the multipliers are added by adder 314 to form a number 316 from which a metric for testing the hypothesis is derived. Again, the metric may be the number 316 which results from adding the two products, or it may be derived from that number such as by multiplying the number by 2/σ2 for those applications that require it.
In one implementation, the number 316 may be truncated or rounded to a desired or required level of precision before being input to a decoder.
An implementation of the embodiment of
As illustrated, the I and Q components of the received symbol r are input to selector 430. The selector 430 outputs two multiplicands “a” and “b”. Responsive to control signal c1, selector 430 either selects rI or rQ as multiplicand “a”, and it selects either rQ or rI as multiplicand “b”. If rI is selected to be multiplicand “a”, then rQ is selected to be multiplicand “b”, and vice-versa.
Multiplicand “a” is input to shifter 404, which shifts “a” four places to the right. Inverter 406 inverts the shifted version of “a”, such as by forming the twos complement thereof. The output of inverter 406 is then added to multiplicand “a” by adder 408. The output of adder 408, a value representative of “a”×(1−{fraction (1/16)}), is then input to logic 410 which selectively takes the twos complement of this value responsive to the control signal c2.
The multiplicand “b” in
The outputs of logic 410 and 424 are then input to adder 414, which adds the two together to produce output “d”. A metric for testing whether the symbol r resulted from hypothesized symbol si may then be set equal to or derived from “d”. From
The control signals c1, c2, and c3 are determined based on the symbol hypothesis si being tested. The following table shows the relationship between these control signals and the symbol hypothesis being tested:
An implementation of the embodiment of
As illustrated, the I and Q components of the received symbol r are input to selector 530. The selector 530 outputs two multiplicands “a” and “b”. Responsive to control signal c1, selector 530 either selects rI or rQ as multiplicand “a”, and it selects either rQ or rI as multiplicand “b”. If rI is selected to be multiplicand “a”, then rQ is selected to be multiplicand “b”, and vice-versa.
Multiplicand “a” is input to shifter 506, which shifts “a” four places to the left. It is also input to inverter 504, which inverts “a” such as by forming the twos complement thereof. The outputs of shifter 506 and inverter 504 are then added by adder 508. The output of adder 508, a value representative of “a”×(16−1), is then input to logic 510 which selectively flips the sign of this value responsive to the control signal c2.
The multiplicand “b” in
The outputs of logic 510 and 524 are then input to adder 514, which adds the two together to produce output “d”. A metric for testing whether the symbol r resulted from hypothesized symbol si may then be set equal to or derived from “d”. From
The control signals c1, c2, and c3 are determined based on the symbol hypothesis si being tested. The table set forth previously shows the relationship between these control signals and the symbol hypothesis being tested.
Note that this implementation, unlike the previous implementation, is not subject to rounding error since no right shift operations are involved. Moreover, the multiplication of each of the multipliers by the factor 16 is counterbalanced by re-interpreting the rightmost bit in each of the multiplicands to be the 2−4 rather than the 2° position, thus in effect dividing each of the multiplicands by 16. Note also that it is unnecessary to add padding bits to either the right or the left of the multiplicands.
It should be appreciated that, for purposes of this disclosure, the terms “logic”, “selector”, “shifter”, “inverter” and “adder” encompass hardware, including but not limited to digital or analog circuitry, integrated circuits, chips, PLAs, ASICs, etc., software, such as code running on a general purpose DSP, or a combination of hardware and software, and the systems of any of
In one implementation example, the selectors, shifters, inverters, and adders of
D. Methods According to the Invention
A first embodiment of a method according to the invention is illustrated in FIG. 6A. As illustrated, the method begins with optional step 602 in which both the I and Q components of the received symbol r are pre-weighted by 2/σ2 in accordance with expressions (3) or (10) above. This step is optional, and need not be performed for those applications in which the metric represented by expression (11) is adequate for performing hypothesis testing. Even in those applications in which the metric of expressions (3) or (10) is required for hypothesis testing, this step need not be performed if the multiplication by 2/σ2 is performed in step 612. In those applications which require it, it is preferred that the factor 2/σ2 be accounted for either by pre-weighting the components of r with the factor, or post-weighting rs*+r*s with this factor, and not by pre-weighting the components of s with this factor. Pre-weighting of the components of s by this factor is not preferred because that would not allow use of the simplified implementations of
Optional step 602 is followed by step 604, in which a multiplier for rI is selected based on the symbol hypothesis si being tested. As discussed, the multiplier is preferably derived from either ±{fraction (15/16)} or ±⅜. Step 604 is followed by or performed in parallel with step 606, in which a multiplier for rQ is also selected based on the symbol hypothesis si being tested. Again, the multiplier is derived from either ±{fraction (15/16)} or ±⅜, provided, however, that this multiplier is derived from ±{fraction (15/16)} if that for rI is derived from ±⅜, and vice-versa. The multipliers in these steps may either be set equal to ±{fraction (15/16)} or ±⅜ or may be derived from one of these values such as through multiplication or division by a common factor applied to all the values One example discussed earlier is where the multipliers are set equal to either ±15 or ±6. Depending on the multipliers chosen, it may be necessary to re-interpret the rightmost bit of each of the multiplicands to be the 2−4 position rather than the 2° position.
Step 604 is followed by step 608, in which the components rI and rQ are multiplied by their respective multipliers. Step 608 is followed by step 610 in which the resulting products are added.
Step 610 is followed by step 612, in which a metric is derived from the sum from step 610. As discussed, depending on the application, the metric may be set equal to this sum or may be derived from it, such as through multiplication by the factor 2/σ2.
A second embodiment of a method according to the invention is illustrated in FIG. 6B. As illustrated, the method begins with optional step 620 in which both the I and Q components of the received symbol r are pre-weighted by 2/σ2 in accordance with expressions (3) or (10) above. This step is optional for the same reasons discussed previously in relation to the embodiment of FIG. 6A.
Optional step 620 is followed by step 622, in which a multiplicand is selected for a first multiplier based on the symbol hypothesis si being tested. The multiplicand may either be rI or rQ, and the first multiplier is preferably derived from either ±{fraction (15/16)} or ±⅜. Step 622 is followed by or performed in parallel with step 624, in which a multiplicand is selected for a second multiplier based on the symbol hypothesis si being tested. Again, the multiplicand may either be rI or rQ, provided, however, that the multiplicand for step 624 should be rQ if that for step 622 is selected to be rI, and vice-versa. Also, the second multiplier should be derived from ±{fraction (15/16)} if the first multiplier is derived from ±⅜, and vice-versa. Again, the multipliers in these steps may either be set equal to ±{fraction (15/16)} or ±⅜ or may be derived from one of these values such as through multiplication or division by a common factor applied to all the values. Again, depending on the multipliers chosen, it may be necessary to re-interpret the rightmost bit of the multiplicands to be the 2−4 position rather than the 2° position.
Step 624 is followed by step 626, in which the multiplicands rI and rQ are multiplied by their respective multipliers. Step 626 is followed by step 628 in which the resulting products are added.
Step 628 is followed by step 630, in which a metric is derived from the sum from step 628. As discussed, depending on the application, the metric may be set equal to this sum or may be derived from it, such as through multiplication by the factor 2/σ2.
It should be appreciated that any of the foregoing methods may be tangibly embodied as a series of instructions stored on a processor readable medium or memory including, without limitation, RAM, ROM, PROM, EPROM, EEPROM, hard disk, floppy disk, CD-ROM, DVD, tape, flash memory, etc. A system may also be formed comprising the processor readable medium coupled to a processor configured to access and execute the instructions stored on the processor readable medium.
In one configuration, software, comprising a series of instructions embodying any of the methods according to the invention, is stored in ROM 751. When the system is booted up, the software is loaded into RAM 760. A section of RAM 760 may also be allocated to the storage of data. CPU 762 accesses this software as stored in RAM 760, and executes it to compute a metric for testing a symbol hypothesis.
Any of the methods of the invention may be embodied as hardware, software, or a combination of hardware and software. The hardware may comprise dedicated analog or digital circuitry, integrated circuits, ASICs, PLAs, or the like. The software may comprise code running on a general purpose DSP.
E. Extensions to MPSK
It should be apparent to one of skill in the art from a reading of this disclosure that the principles of the foregoing embodiments can readily be extended to the MPSK case. Consider that an MPSK symbol constellation beyond 8-PSK can always be oriented so that 8 of the symbols thereof coincide with the 8 symbols on the constellation illustrated in
One of skill in the art will appreciate that the invention may also be readily extended to the other symbols in the constellation although with different multipliers. In particular, the I and Q components of these symbols may be approximated to a desired level of resolution with fractional values, and the multipliers may be set equal to or derived from these fractional values. Preferably, the multipliers are selected so that the multiplications can be performed through a discrete series of addition, shifting, and twos complement operations.
While various embodiments of the invention have been described, it will be apparent to those of ordinary skill in the art that many more embodiments and implementations are possible that are within the scope of this invention. Accordingly, the invention is not to be restricted except in light of the attached claims and their equivalents.
This application claims the benefit of U.S. Provisional Application Ser. No. 60/255,757, filed Dec. 15, 2000, which is hereby fully incorporated by reference herein as though set forth in full.
Number | Name | Date | Kind |
---|---|---|---|
4104729 | Gingell | Aug 1978 | A |
5349609 | Tsujimoto | Sep 1994 | A |
6421400 | Rhee et al. | Jul 2002 | B1 |
6570910 | Bottomley et al. | May 2003 | B1 |
6608874 | Beidas et al. | Aug 2003 | B1 |
Number | Date | Country | |
---|---|---|---|
60255757 | Dec 2000 | US |