The present disclosure is directed at a method and apparatus for use in one or more of lock detection, signal-to-noise ratio (SNR) estimation, and modulation classification.
Digital communications systems often include one or more of a lock detector, a modulation classifier, and an SNR estimator. A lock detector is used, for example, when a receiver is coherently demodulating a carrier that it has received to determine whether a local carrier used for demodulation is in phase with the received carrier. A modulation classifier is used, for example, to determine which modulation scheme has been used to modulate the received carrier. Exemplary modulation schemes include various types of phase shift keying such as binary phase shift keying, quaternary phase shift keying, and more generally M-ary phase shift keying where M is theoretically any positive integer. An SNR estimator is used, for example, to estimate the SNR of the symbols transmitted using the received carrier.
In digital communications, and particularly in mobile digital communications, it is beneficial to employ circuitry that is fast, inexpensive, relatively simple, and power efficient. Accordingly, research and development continue into improving the designs of lock detectors, SNR estimators, and modulation classifiers.
According to one aspect, there is provided a method for generating a metric for one or both of lock detection and signal-to-noise ratio (SNR) estimation. The method includes obtaining a baseband symbol from a received carrier that is modulated using the symbol according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier; determining a received phase of the symbol; and generating the metric from the received phase, wherein possible metrics depend on possible received phases according to a base function that comprises a triangle wave having its maxima or minima located at ideal symbol phases and the other of its maxima or minima located at phases midway between adjacent ideal symbol phases.
The maxima and minima may have identical absolute values.
The received carrier may be modulated according to M-ary phase shift keying, and M may be a positive integer power of 2.
Determining the received phase may involve expressing the received phase as being between [−π,π) radians prior to generating the metric, and the base function may be implemented such that it spans only [−π,π) radians.
The received phase may be encoded using an encoding scheme that linearly encompasses substantially all of the possible received phases.
The ideal symbol phases may be uniformly distributed within any continuous angular interval spanning 2π radians.
The metric may be generated as a function of a principal angle that is directly proportional to the received phase modulo (π/2M). The principal angle may be normalized such that its supremum equals the absolute value of the maxima of the triangle wave. Additionally or alternatively, the principal angle may include one or more of the least significant bits of the received phase.
Generating the metric may involve inverting the principal angle as a function of one or more bits of the received phase; and adding one of A, −A or 0 to the principal angle or its inverse as a function of two or more bits of the received phase, wherein A is the absolute value of the maxima of the triangle wave.
The encoding scheme may be one's complement, two's complement, or sign-magnitude encoding, the received phase may have b bits, and M may be a positive integer power of 2. The principal angle may include a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase. Alternatively or additionally, the principal angle may be proportional to a binary number that comprises a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase.
Generating the metric may involve inverting the principal angle as a function of bit [b-1-log2 M] of the received phase; and adding either A, −A or 0 to the principal angle or its inverse as a function of bits [b-log2 M-1:b-log2 M-2] of the received phase, wherein A is the absolute value of the maxima of the triangle wave.
The method may also include determining whether a local carrier used to demodulate the received carrier is locked to the received carrier by averaging a plurality of the metrics to determine an average metric; comparing the average metric to a lock indicator detection threshold; and when the average metric surpasses the lock indicator detection threshold, determining that the local carrier is locked to the received carrier.
The method may also include estimating the SNR of the received carrier by averaging a plurality of the metrics to determine an average metric; comparing the average metric to an SNR sufficiency threshold; and when the average metric surpasses the SNR sufficiency threshold, utilizing the average metric as a proxy for the SNR.
The method may also involve estimating the SNR of the received carrier by averaging a plurality of the metrics to determine an average metric; comparing the average metric to an SNR sufficiency threshold; and when the average metric surpasses the SNR sufficiency threshold, estimating the SNR to be the SNR at which the expected value of the base function equals the average metric.
According to another aspect, there is provided a method for generating a metric for one or both of signal-to-noise ratio (SNR) estimation and modulation classification. The method includes obtaining a pair of baseband symbols from a received carrier that is modulated using the symbols according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier; determining a received phase difference between the pair of symbols; and generating the metric from the received phase difference, wherein possible metrics depend on possible received phase differences according to a base function that comprises a triangle wave having its maxima or minima located at ideal phase differences and the other of its maxima or minima located at phase differences midway between adjacent ideal phase differences.
The maxima and minima may have identical absolute values.
The received carrier may be modulated according to M-ary phase shift keying. M may be a positive integer power of 2.
The ideal phase differences may be located at (2π·mn)/M radians where mnε{0, 1, . . . , M−1}.
Determining the received phase difference may involve expressing the received phase difference as being between [−π,π) radians prior to generating the metric, and the base function may be implemented such that it spans only [−π,π) radians.
Determining the received phase difference may involve expressing the received phase difference as modulo 2π of: the received phase of one of the symbols of the pair subtracted from the received phase of the other of the symbols of the pair. One of the symbols of the pair may immediately follow the other of the symbols of the pair.
The received phase difference may be encoded using an encoding scheme that linearly encompasses substantially all of the possible received phase differences.
The ideal phase differences may be uniformly distributed within any continuous angular interval spanning 2π radians.
The metric may be generated as a function of a principal angle that is directly proportional to the received phase difference modulo (π/2M). The principal angle may be normalized such that its supremum equals the absolute value of the maxima of the triangle wave. The principal angle may also include one or more of the least significant bits of the received phase difference.
Generating the metric may involve inverting the principal angle as a function of one or more bits of the received phase difference; and adding either A, −A or 0 to the principal angle or its inverse as a function of two or more bits of the received phase difference, wherein A is the absolute value of the maxima of the triangle wave.
The encoding scheme may be one's complement, two's complement, or sign-magnitude encoding, the received phase difference may have b bits, and M may be a positive integer power of 2.
The principal angle may include a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase difference. Alternatively or additionally, the principal angle may be directly proportional to a binary number that comprises a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase difference.
Generating the metric may involve inverting the principal angle as a function of bit [b-1-log2 M] of the received phase difference; and adding either A, −A or 0 to the principal angle or its inverse as a function of bits [b-log2 M-1:b-log2 M-2] of the received phase difference, wherein A is the absolute value of the maxima of the triangle wave.
The method may also include estimating the SNR of the received carrier by averaging a plurality of the metrics to determine an average metric; comparing the average metric to an SNR sufficiency threshold; and when the average metric surpasses the SNR sufficiency threshold, utilizing the average metric as a proxy for the SNR.
The method may also include estimating the SNR of the received carrier by averaging a plurality of the metrics to determine an average metric; comparing the average metric to an SNR sufficiency threshold; and when the average metric surpasses the SNR sufficiency threshold, estimating the SNR to be the SNR at which the expected value of the base function equals the average metric.
The method may also involve generating the metric multiple times in accordance with a different base function each time, wherein the ideal phase differences for each of the base functions are uniformly distributed within any continuous angular interval spanning 2π radians and wherein each of the different base functions has a different value of M each evenly divisible by the lowest value of M for the different base functions; averaging the metrics to determine an average metric for each of the different base functions; comparing the average metric for each of the potential base functions to an associated validity threshold for each of the potential base functions; and when at least one of the average metrics surpasses its associated validity threshold, determining that M of the received carrier is less than or equal to the lowest value of M for which the average metric surpasses its validity threshold.
When at least one of the average metrics surpasses its associated validity threshold, the method may involve determining that M of the received carrier is higher than the highest value of M for which the average metric does not surpass its validity threshold.
The ideal phase differences for each of the different base functions corresponding to a value of M less than the highest value of M may be a subset of the ideal phase differences for the base function corresponding to the highest value of M.
The ideal phase differences for each of the different base functions corresponding to a value of M less than the highest value of M may be a subset of the ideal phase differences for the base functions corresponding to each higher value of M.
M for all of the different base functions and M of the received carrier may be positive integer powers of 2.
The lowest M for which the average metric surpasses the associated validity threshold and the highest M for which the average metric does not surpass the associated validity threshold may be adjacent powers of two.
The method may also involve generating the metric multiple times in accordance with a different base function each time, wherein ideal phase differences are uniformly distributed within any continuous angular interval spanning 2π radians and wherein none of the different base functions have identical values of M; averaging the metrics to determine an average metric for each of the different base functions; determining which of the average metrics is largest if the ideal phase differences correspond to the maxima of the base functions, or which of the average metrics is the smallest if the ideal phase differences correspond to the minima of the base functions; and determining that M of the received carrier is equal to the value for M that corresponds to (i) the largest average metric if the ideal phase differences correspond to the maxima of the base functions; and (ii) the smallest average metric if ideal phase differences correspond to the minima of the base functions.
According to another aspect, there is provided an apparatus for generating a metric for one or both of lock detection and signal-to-noise ratio (SNR) estimation. The apparatus includes a front end configured to obtain a baseband symbol from a received carrier that is modulated using the symbol according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier; a phase determiner communicatively coupled to the front end and configured to determine a received phase of the baseband symbol; and a metric generator communicatively coupled to the phase determiner and configured to generate the metric from the received phase, wherein possible metrics depend on possible received phases according to a base function that comprises a triangle wave having its maxima or minima located at ideal symbol phases and the other of its maxima or minima located at phases midway between adjacent ideal symbol phases.
The maxima and minima may have identical absolute values.
The received carrier may be modulated according to M-ary phase shift keying. M may be a positive integer power of 2.
The phase determiner may be configured to express the received phase as being between [−π,π) radians, and the base function may be implemented such that it spans only [−π,π) radians.
The phase determiner may be configured to encode the received phase using an encoding scheme that linearly encompasses substantially all of the possible received phases.
The ideal symbol phases may be uniformly distributed within any continuous angular interval spanning 2π radians, and the metric generator may be configured to determine for the received phase a principal angle that is directly proportional to the received phase modulo (π/2M) and to generate the metric as a function of the principal angle.
The metric generator may be configured to normalize the principal angle such that its supremum equals the absolute value of the maxima of the triangle wave.
The phase determiner may encode the received phase such that the principal angle comprises one or more of the least significant bits of the received phase.
The phase determiner may encode the received phase such that one or more bits (inversion control bits) of the received phase indicate whether to invert the principal angle and such that two or more bits (selection bits) of the received phase indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may also include (a) inverting hardware having (i) a data input to which the principal angle is input; (ii) an inversion control input to which the inversion control bits are input; and (iii) a data output that outputs the inverse of the principal angle when the inversion control bits indicate the principal angle is to be inverted and otherwise outputs the principal angle; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that outputs either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware is selected by the selection bits; and (c) adding hardware having (i) data inputs communicatively coupled to the data outputs of the inverting hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
A may be 1.
The phase determiner may encode the received phase such that a principal angle precursor includes one or more of the least significant bits of the received phase, and the principal angle may be directly proportional to the principal angle precursor.
The phase determiner may encode the received phase such that one or more bits (inversion control bits) of the received phase indicate whether to invert the principal angle precursor and such that two or more bits (selection bits) of the received phase indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may also include: (a) inverting hardware having: (i) a data input to which the principal angle precursor is input; (ii) an inversion control input to which the inversion control bits are input; and (iii) a data output that outputs the inverse of the principal angle precursor when the inversion control bits indicate the principal angle precursor is to be inverted and otherwise outputs the principal angle precursor; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that outputs either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware is selected by the selection bits; (c) amplification hardware having (i) a data input communicatively coupled to the data output of the inverting hardware; and (ii) a data output that outputs the amplification of the data input; and (d) adding hardware having (i) data inputs communicatively coupled to the data outputs of the amplification hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
The phase determiner may encode the received phase in one's complement, two's complement, or sign-magnitude encoding, the received phase may have b bits, M may be a positive integer power of 2, and the principal angle may include a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase.
The phase determiner may encode the received phase such that bit [b-1-log2 M] (inversion control bit) of the received phase indicates whether to invert the principal angle and such that bits [b-log2 M-1:b-log2 M-2] (selection bits) of the received phase indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may include (a) inverting hardware having (i) a data input to which the principal angle is input; (ii) an inversion control input to which the inversion control bit is input; (iii) a data output that outputs the inverse of the principal angle when the inversion control bit indicate the principal angle is to be inverted and otherwise outputs the principal angle; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that outputs either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware is selected by the selection bits; and (c) adding hardware having (i) data inputs communicatively coupled to the data outputs of the inverting hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
A may be 1.
The phase determiner may encode the received phase in one's complement, two's complement, or sign-magnitude encoding, the received phase may have b bits, M may be a positive integer power of 2, and the principal angle may be directly proportional to a principal angle precursor that comprises a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase.
The phase determiner may encode the received phase such that bit [b-1-log2 M] (inversion control bit) of the received phase indicates whether to invert the principal angle precursor and such that bits [b-log2 M-1:b-log2 M-2] (selection bits) of the received phase indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may include (a) inverting hardware having (i) a data input to which the principal angle precursor is input; (ii) an inversion control input to which the inversion control bits are input; and (iii) a data output that outputs the inverse of the principal angle precursor when the inversion control bits indicate the principal angle precursor is to be inverted and otherwise outputs the principal angle precursor; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that output either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware is selected by the selection bits; (c) amplification hardware having (i) a data input communicatively coupled to the data output of the inverting hardware; and (ii) a data output that outputs the amplification of the data input; and (d) adding hardware having (i) data inputs communicatively coupled to the data outputs of the amplification hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
An averager may be communicatively coupled to the metric generator and be configured to average a plurality of the metrics to determine an average metric.
A comparator may be communicatively coupled to the averager and be configured to compare the average metric to a lock indicator detection threshold and to indicate when the average metric surpasses the lock indicator detection threshold, thereby indicating when the local carrier is locked to the received carrier.
A comparator may be communicatively coupled to the averager and be configured to compare the average metric to an SNR sufficiency threshold and to indicate when the average metric surpasses the SNR sufficiency threshold, thereby indicating when the average metric may be used as a proxy for the SNR.
The apparatus may include a lookup table, relating values for the expected value of the base function to values for the SNR, communicatively coupled to the averager and configured to output an estimate for the SNR that is the SNR at which the expected value of the base function equals the average metric when the average metric surpasses the SNR sufficiency threshold.
According to another aspect, there is provided an apparatus for generating a metric for one or both of signal-to-noise ratio (SNR) estimation and modulation classification. The apparatus includes a front end configured to obtain a pair of baseband symbols from a received carrier that is modulated using the symbols according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier; a phase determiner communicatively coupled to the front end and configured to determine a received phase for each of the symbols; a phase difference determiner communicatively coupled to the phase determiner and configured to determine a received phase difference between the pair of symbols; and a metric generator communicatively coupled to the phase difference determiner and configured to generate the metric from the received phase difference, wherein possible metrics depend on possible received phase differences according to a base function that comprises a triangle wave having its maxima or minima located at ideal phase differences and the other of its maxima or minima located at phase differences midway between adjacent ideal phase differences.
The maxima and minima may have identical absolute values.
The received carrier may be modulated according to M-ary phase shift keying. M may be a positive integer power of 2.
The ideal phase differences may be located at (2πmn)/M radians where mnε{0, 1, . . . , M−1}.
The phase difference determiner may express the received phase difference as being between [−π,π) radians, and the base function may be implemented such that it spans only [−π,π) radians.
The phase difference determiner may express the received phase difference as modulo 2π of: the received phase of one of the symbols of the pair subtracted from the received phase of the other of the symbols of the pair. One of symbols may immediately follow the other of the symbols of the pair.
The phase difference determiner may be configured to encode the received phase difference using an encoding scheme that linearly encompasses substantially all of the possible received phase differences.
The ideal phase differences may be uniformly distributed within any continuous angular interval spanning 2π radians, and the metric generator may be configured to determine for the received phase difference a principal angle that is directly proportional to the received phase difference modulo (π/2M) and to generate the metric as a function of the principal angle.
The metric generator may be configured to normalize the principal angle such that its supremum equals the absolute value of the maxima of the triangle wave.
The phase difference determiner may encode the received phase difference such that the principal angle comprises one or more of the least significant bits of the received phase difference.
The phase difference determiner may encode the received phase difference such that one or more bits (inversion control bits) of the received phase difference indicate whether to invert the principal angle and such that two or more bits (selection bits) of the received phase difference indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may include (a) inverting hardware having (i) a data input to which the principal angle is input; (ii) an inversion control input to which the inversion control bits are input; and (iii) a data output that outputs the inverse of the principal angle when the inversion control bits indicate the principal angle is to be inverted and otherwise outputs the principal angle; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that outputs either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware are selected by the selection bits; and (c) adding hardware having (i) data inputs communicatively coupled to the data outputs of the inverting hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
A may be 1.
The phase difference determiner may encode the received phase difference such that a principal angle precursor comprises one or more of the least significant bits of the received phase difference, and the principal angle may be directly proportional to the principal angle precursor.
The phase difference determiner may encode the received phase difference such that one or more bits (inversion control bits) of the received phase difference indicate whether to invert the principal angle precursor and such that two or more bits (selection bits) of the received phase difference indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may include (a) inverting hardware having (i) a data input to which the principal angle precursor is input; (ii) an inversion control input to which the inversion control bits are input; and (iii) a data output that outputs the inverse of the principal angle precursor when the inversion control bits indicate the principal angle precursor is to be inverted and otherwise outputs the principal angle precursor; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that outputs either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware is selected by the selection bits; (c) amplification hardware having (i) a data input communicatively coupled to the data output of the inverting hardware; and (ii) a data output that outputs the amplification of the data input; and (d) adding hardware having (i) data inputs communicatively coupled to the data outputs of the amplification hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
The phase difference determiner may encode the received phase difference in one's complement, two's complement, or sign-magnitude encoding, the received phase difference may have b bits, M may be a positive integer power of 2, and the principal angle may include a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase difference.
The phase difference determiner may encode the received phase difference such that bit [b-1-log2 M] (inversion control bit) of the received phase difference indicates whether to invert the principal angle and such that bits [b-log2 M-1:b-log2 M-2] (selection bits) of the received phase difference indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may include (a) inverting hardware having (i) a data input to which the principal angle is input; (ii) an inversion control input to which the inversion control bit is input; and (iii) a data output that outputs the inverse of the principal angle when the inversion control bit indicate the principal angle is to be inverted and otherwise outputs the principal angle; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that outputs either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware is selected by the selection bits; and (c) adding hardware having (i) data inputs communicatively coupled to the data outputs of the inverting hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
A may be 1.
The phase difference determiner may encode the received phase difference in one's complement, two's complement, or sign-magnitude encoding, the received phase difference may have b bits, M may be a positive integer power of 2, and the principal angle may be directly proportional to a principal angle precursor that includes a plurality of the most significant bits of bits [b-3-log2 M:0] of the received phase difference.
The phase difference determiner may encode the received phase difference such that bit [b-1-log2 M] (inversion control bit) of the received phase difference indicates whether to invert the principal angle precursor and such that bits [b-log2 M-1:b-log2 M-2] (selection bits) of the received phase difference indicate whether to add A, −A or 0 to the principal angle or its inverse, wherein A is the absolute value of the maxima of the triangle wave, and the metric generator may include (a) inverting hardware having (i) a data input to which the principal angle precursor is input; (ii) an inversion control input to which the inversion control bit is input; and (iii) a data output that outputs the inverse of the principal angle precursor when the inversion control bit indicates the principal angle precursor is to be inverted and otherwise outputs the principal angle precursor; (b) data selection hardware having (i) a data input to which A, −A and 0 are input; (ii) a data selection input to which the selection bits are input; and (iii) a data output that outputs either A, −A or 0 in accordance with which one of the data inputs of the data selection hardware is selected by the selection bits; (c) amplification hardware having (i) a data input communicatively coupled to the data output of the inverting hardware; and (ii) a data output that outputs the amplification of the data input; and (d) adding hardware having (i) data inputs communicatively coupled to the data outputs of the amplification hardware and the data selection hardware; and (ii) a data output that outputs the sum of signals at the data inputs of the adding hardware.
The apparatus may include an averager communicatively coupled to the metric generator and configured to average a plurality of the metrics to determine an average metric. The apparatus may also include a comparator communicatively coupled to the averager and configured to compare the average metric to an SNR sufficiency threshold and to indicate when the average metric surpasses the SNR sufficiency threshold, thereby indicating when the average metric may be used as a proxy for the SNR. The apparatus may also include a lookup table, relating values for the expected value of the base function to values for the SNR, communicatively coupled to the averager and configured to output an estimate for the SNR that is the SNR at which the expected value of the base function equals the average metric when the average metric surpasses the SNR sufficiency threshold.
The apparatus may also include a plurality of the metric generators each configured to generate the metric in accordance with a different base function, wherein ideal phase differences for each of the base functions are uniformly distributed within any continuous angular interval spanning 2π radians and wherein none of the different base functions have identical values of M; a plurality of averagers, each communicatively coupled to a different one of the metric generators and configured to determine an average metric for each of the metric generators; a plurality of comparators, each of which is communicatively coupled to a different one of the averagers and is configured to compare the average metric to a validity threshold for that base function, and to output a signal indicating that the average metric surpasses the validity threshold only when the average metric surpasses the validity threshold; and a plurality of data selectors each comprising data inputs, a selection input, and a data output, wherein the output of each of the comparators except the comparator communicatively coupled to the metric generator for the base function having the highest M is coupled to the selection input on a different one of the data selectors, and wherein the data inputs and outputs of the data selectors are communicatively coupled together in a series such that the data output of the last of the data selectors in the series outputs a particular one of the data inputs of one of the data selectors selected by the metric generators.
The apparatus may also include ORing logic having inputs communicatively coupled to the outputs of the comparators.
The apparatus may also include a plurality of the metric generators each configured to generate the metric in accordance with a different base function, wherein ideal phase differences for each of the base functions are uniformly distributed within any continuous angular interval spanning 2π radians and wherein none of the different base functions have identical values of M; a plurality of averagers, each of which is communicatively coupled to a different one of the metric generators and configured to determine an average metric; and a peak detector communicatively coupled to each of the averagers, and configured to indicate: (i) if the ideal phase differences correspond to the maxima of the base functions, which of the average metrics is largest; and (ii) if the ideal phase differences correspond to the minima of the base functions, which of the average metrics is the smallest.
The apparatus may also include a plurality of comparators, each of which is communicatively coupled to a different one of the averagers and configured to compare the average metric to a validity threshold for that value of M, and to output a signal indicating that the average metric surpasses the validity threshold only when the average metric surpasses the validity threshold. M for each of the base functions may be a positive integer power of 2.
According to another aspect, there is provided a lock detector. The lock detector includes a front end configured to sample a received carrier that is modulated using a symbol according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier, wherein the front end comprises a symbol synchronizer configured to attempt to synchronize sampling instances to the symbols used to modulate the received carrier; a phase determiner communicatively coupled to the front end and configured to determine a received phase of the baseband symbol from one or more samples taken at the sampling instances; a metric generator communicatively coupled to the phase determiner and configured to generate a metric from the received phase, wherein possible metrics depend on possible received phases according to a base function that comprises a triangle wave having its maxima or minima located at ideal symbol phases and the other of its maxima or minima located at phases midway between adjacent ideal symbol phases; an averager communicatively coupled to the metric generator and configured to average a plurality of the metrics to determine an average metric; and a comparator communicatively coupled to the averager and configured to compare the average metric to a lock indicator detection threshold and to indicate when the average metric surpasses the lock indicator detection threshold, thereby indicating when the local carrier is locked to the received carrier. The symbol synchronizer does not have to synchronize the sampling instances to the symbols.
According to another aspect, there is provided a modulation classifier, having a front end configured to obtain a pair of baseband symbols from a received carrier that is modulated using the symbols according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier; a phase determiner communicatively coupled to the front end and configured to determine a received phase of each of the symbols; a phase difference determiner communicatively coupled to the phase determiner and configured to determine a received phase difference between the pair of symbols; a plurality of metric generators, each communicatively coupled to the phase difference determiner and configured to generate a metric from the received phase difference, wherein possible metrics depend on possible received phase differences according to a base function that comprises a triangle wave having its maxima located at ideal phase differences and its minima located at phase differences midway between adjacent ideal phase differences, and wherein each of the metric generators is configured to determine the metric in accordance with a different base function corresponding to a different digital modulation scheme; a plurality of averagers, each of which is communicatively coupled to a different one of the metric generators and configured to determine an average metric; and a peak detector communicatively coupled to each of the averagers, and configured to indicate which of the average metrics is largest.
The apparatus may also include a plurality of comparators, each of which is communicatively coupled to a different one of the averagers and configured to compare the average metric to a validity threshold for that metric, and to output a signal indicating that the average metric surpasses the validity threshold only when the average metric surpasses the validity threshold.
According to another aspect, there is provided an apparatus for generating a metric for one or both of lock detection and signal-to-noise ratio (SNR) estimation. The apparatus includes a data input configured to receive the phase of a baseband symbol obtained from a received carrier that is modulated using the symbol according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier; a data output configured to output the metric; and circuitry communicatively coupled between the data input and output and configured to generate the metric from the phase, wherein possible metrics depend on possible phases according to a base function that comprises a triangle wave having its maxima or minima located at ideal symbol phases and the other of its maxima or minima located at phases midway between adjacent ideal symbol phases.
According to another aspect, there is provided an apparatus for generating a metric for one or both of signal-to-noise ratio (SNR) estimation and modulation classification. The apparatus includes a data input configured to receive a phase difference between a pair of baseband symbols from a received carrier that is modulated using the symbols according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier; a data output configured to output the metric; and circuitry communicatively coupled between the data input and output and configured to generate the metric from the phase difference, wherein possible metrics depend on possible phase differences according to a base function that comprises a triangle wave having its maxima or minima located at ideal phase differences and the other of its maxima or minima located at phase differences midway between adjacent ideal phase differences.
According to another aspect, there is provided an apparatus for generating a metric for one or both of lock detection, signal-to-noise ratio (SNR) estimation, and modulation classification. The apparatus includes selecting means for selecting one of A, −A or 0 in response to selection bits; inverting means for inverting a principal angle in response to inversion control bits; and adding means, communicatively coupled to outputs of the selecting means and the inverting means, for adding one of A, −A or 0 to the principal angle or its inverse to generate the metric, wherein the received carrier is modulated using a symbol according to a modulation order (M) equaling the number of distinct ideal symbol phases used to modulate the received carrier, wherein the distinct ideal symbol phases are uniformly distributed within any continuous angular interval spanning 2π radians and wherein the principal angle is modulo (π/2M) of the phase of the symbol, normalized to have a supremum of A.
In the accompanying drawings, which illustrate one or more exemplary embodiments:
Many modern communications systems in recent years support several modulations, which are switched in one or more of an adaptive, user, and algorithm controlled manner. In some cases, the modulations are toggled in response to changing channel conditions, communications protocol requirements, or user choice. Switching between the various modulations often has as its core objective the efficient utilization of the available spectrum, in order to achieve high data throughput, while also efficiently utilizing the available transmission and signal processing power at the transmitter and receiver.
In recent years, significant developments and a large body of research has been done on Software Defined Radio (SDR) and Cognitive Radio (CR). In the former, the receiver's innards can be reconfigured in real-time in order to support different modulations; this is usually achieved through the use of one or both of reconfigurable hardware (such as field programmable gate arrays, hereinafter referred to as FPGAs) and a real-time software component. In CR, the receiver in theory autonomously decides what modulation it sees at its input and applies the appropriate receiver algorithms appropriately. Usually, CR and SDR go hand in hand; that is a CR will usually have a software defined architecture.
Modulation classifiers are typically used in CR. The CR makes intelligent choices as to the modulation that it sees at its receiver entrance. This is done using the modulation classifier. The following embodiments include a new structure for a modulation classifier.
Moreover, after the modulation has been classified, if the receiver demodulates the incoming signal coherently, a lock detector is often subsequently used. The following embodiments also include a new structure for a lock detector.
Frequently, an SNR estimator is used by the receiver to increase performance of the receiver, as well as to provide a signal quality indication to the receiver operator or for other receivers or entities. The following embodiments also include new structures for SNR estimators.
System Model
A simplified diagram of the front-end of the receiver under discussion is shown in
M is in general a positive integer. In many systems, M is a positive integer power of 2, i.e. M=2k where “k” is some positive integer. For example, M=2, M=4, M=8, M=16, M=32, and M=64 are examples of Ms which are positive integer powers of 2.
The modulated signal 100 that is present at the output of the receiver's intermediate frequency (IF) downconversion stage is Re[m(t)exp(jωit+jθi)]+n(t), where n(t) is the noise process, with ωi being the received IF carrier frequency in radians/sec, and θi (in radians) being the phase of the received IF carrier. In other embodiments, the receiver may not have an intermediate frequency, or may have several intermediate frequencies, in which case appropriate modifications are accordingly made to the exemplary embodiments. Hence, the description of the exemplary embodiments should not be construed as limiting. For the purposes of this disclosure, it is simpler to treat the receiver as a D-MPSK receiver, whether the actual receiver is M-PSK or D-MPSK. This is because a D-MPSK signal is identical to an M-PSK signal in terms of the transmitted signal waveform, with the exception that the D-MPSK waveform may be differentially coded whereas sometimes M-PSK signals are not so coded. In terms of demodulation, the only difference between M-PSK and D-MPSK is in how these are demodulated (the former, coherently, and the latter, differentially). However, for the embodiments of the modulation classifier presented herein carrier synchronization is not assumed and the proposed classifiers are non-data aided (NDA); hence, the issues of carrier synchronization and differential coding/decoding are irrelevant for the purpose of describing the exemplary embodiments. Therefore, the receiver may be treated as a D-MPSK receiver regardless of whether the actual system is M-PSK or D-MPSK.
Additionally, although several of the following embodiments use M-PSK as a modulation scheme, in alternative embodiments alternative modulations that are related to M-PSK, such as O-MPSK (Offset MPSK), D-O-MPSK (Differential Offset MPSK), MSK (Minimum Shift Keying), GMSK (Gaussian Minimum Shift Keying), π/M-MPSK, D-π/M-MPSK (Differential π/M-MPSK), FQPSK (Feher's QPSK) and its derivatives, SOQPSK (Shaped-Offset Quadrature Phase-Shift Keying) and its derivatives, 3π/M-8PSK, D-3π/M-8PSK (Differential 3π/M-8PSK), QAM (Quadrature Amplitude Modulation), OQAM (Offset QAM), PAM-PSK (Pulse Amplitude Modulation Phase Shift Keying), OFDM (Orthogonal Frequency Division Multiplexing), Offset-PAM-PSK, CPM (Continuous Phase Modulation) and its variants, and Trellis Coded Modulation (TCM) and its variants may be used.
The modulated signal 100 passes through matched filters 120, 135, whose response is p*(−t) (where “*” denotes complex conjugation), ωo=ωi+Δω (radians/sec) is the local carrier frequency (Δω is the frequency error between the received carrier and the local carrier 165) and θ0 (radians) is the phase of the local carrier 165. A quadrature receiver front end is assumed for the demodulator of the exemplary embodiment, i.e. multiplication using multipliers 105, 110 by the local carrier 165 and its quadrature which is generated by passing the local carrier 165 through a 90 degree phase shifter 115. Alternative embodiments may use other types of receiver front ends and the exemplary embodiment accordingly should not be construed as limiting. The local oscillator 165 may be controlled or may be free running, depending on the receiver architecture, and, moreover, the receiver structure may be implemented in analog, digital, or mixed signal circuits, or in another suitable manner. For the purposes of describing this embodiment, symbol timing synchronization is assumed, and the Nyquist criterion for zero ISI is assumed obeyed at the outputs of the matched filters 120, 135. Optionally, the amplifiers 125, 140 can be included after the matched filters 120, 135. The quantity K for the amplifiers 125, 140 may be a true amplification or it may be a mathematical equivalent (preferably AGC-controlled) I-Q arm gain. In many receivers, K is a slow function of time, and is controlled by the AGC in order to attain the desired signal level at the inputs of the I and Q samplers so as to utilize their full dynamic range without saturating. Following amplification, the I(t) and Q(t) signals are sampled by samplers 130, 145, which operate at a rate of at least 1/T Hertz, from which the relevant samples spaced 1/T seconds apart (corresponding to optimal sampling instances for each symbol) are extracted for the embodiments of the lock detector, SNR estimator, and modulation classifier that are discussed below. In alternative embodiments the sampling rate could be higher than 1/T Hertz. In such cases, the samples that correspond to the baseband symbols are extracted, via one or both of sample selection and interpolation; ideally those samples that correspond to the ideal sampling instances for the received symbols are obtained. These ideal sampling instances are usually determined via a symbol sampling synchronization and/or determination circuit that is contained within the receiver. In yet other embodiments, the sampling rate may be less than 1/T. In such a case, the structures presented herein would operate upon a subset of the received symbols, which is also possible.
The notations nI(t) and nQ(t) are used to refer to the noise present before the amplifiers 125, 140 in the I and Q arms, respectively. In many systems, this noise signal's source is an Additive White Gaussian Noise (AWGN) that is present in the channel, an assumption that is made for the purposes of describing the embodiments described in this disclosure.
Thus, I(n) 150 and Q(n) 155 are respectively I(n)=K(2ES·cos(−Δω·nT+θe+φn)+nI(nT)) and Q(n)=K(2ES·sin (−Δω·nT+θe+φn)+nQ(nT)), with θe≡θi−θo and nI(nT),nQ(nT)˜N(0,2N0ES), where
is the symbol energy and N0/2 is the AWGN noise power spectral density. The phase of the received (complex) baseband symbol rn≡I(n)+j·Q(n) is φn≡tan−1 (Q(n)/I(n)), which as discussed in more detail below is the instantaneous phase of the received baseband symbol 415 (“received phase”). In polar coordinates, rn=|rn|exp(jφn).
Here it is assumed that |Δω|<<2π/(M·T), which is a standard assumption that is made in D-MPSK receivers. In essence, it is assumed that a rough estimate of the carrier frequency has been made and that it has been corrected in such a manner so that |Δω|<<2π/(M·T) is met, i.e. that the local carrier frequency is relatively close to the carrier frequency of the input signal. This can be achieved using, for example, open loop frequency estimation and correction circuits. For example, in many cases |Δω|<<2π/(M·T) is already a given for a CR system since the frequency band of the input signal is known, though the modulation index is not.
The notation χ is used to refer to the Symbol SNR (Signal to Noise Ratio), that is, ES/N0=χ.
Without loss of generality, it can be assumed for mathematical convenience that ∀n, φn=0, whereupon:
The received phase φn 415 is independent of the value of K of the amplifiers 125, 140, as can be seen by the fact that K does not appear in (1). Since, as discussed below, the exemplary embodiment relies on operations upon φn, this means that the embodiment does not depend upon K nor upon the AGC's control of K. This is advantageous, since the AGC is usually non-ideal and the value of K usually does experience fluctuations. The only dependence of the embodiment on the AGC is indirect and weak, and will manifest itself if the AGC is so bad that one or both of I(t) 128 and Q(t) 142 are either overdriven or underdriven, which may cause substantial degradations due to one or more of saturation, compression, and quantization noise which are due to the finite dynamic range and quantization accuracy of the samplers 130, 145. However, usually the AGC can easily be made to be sufficiently robust in order to prevent frequent occurrences one or both of overdriving and underdriving, so that the independence of the embodiment from K is a real and substantial advantage in practice.
It can be defined that:
Δφn≡φn−(−ΔωnT+θe) (2)
Since it is assumed that ∀n, φn=0, the physical meaning of Δφn is clear: it is the phase error in the received phase of any one of the received baseband symbols, φn 415, relative to the symbol's ideal phase φn, that can be attributed to noise, i.e. to nI(nT) and nQ(nT) (to see this, substitute nI(nT)=nQ(nT)=0 in the expressions for I(n) and Q(n), and then φn=tan−1(Q(n)/I(n))=−ΔωnT+θeΔφn=φn−(−ΔωonT+θe)=0). From this, it can be shown that:
where −π≦Δφ≦π.
Lock Detector and SNR Estimator
As shown in
Yet other embodiments may be defined where the minima of hM(θ) (e.g. with value −A) correspond to the ideal symbol phases, and maxima (e.g. with value +A) correspond to the phases midway between the ideal symbol phases. In such embodiments, the thresholds and expected values are the negative of those discussed in the exemplary embodiments discussed herein, and other modifications to the embodiments are made as appropriate.
In
The hardware implementation of the lock detector and SNR estimator is shown in
This averaging can be done such as via an Integrate and Dump (IAD) component 425 as is done in the exemplary embodiment, and the output is denoted qM,N 430 in this exemplary embodiment, and is the average metric.
qM,N 430 is an estimate of the expected value E[hM(φn)], where E[·] is the expectation operator. Another way to phrase this is that
and when the carrier loop is in lock,
and in an ergodic system (as is commonly assumed for physical systems)
It should be noted that in other embodiments other averaging definitions can be used than that of (4), for example the number of samples averaged does not need to be even, nor do the samples need to be defined as between −N+1 and N, nor do the set of symbol intervals upon which the average is calculated need to be adjacently successive in time.
In the exemplary embodiment shown in
It should be noted that when qM,N is equal to or less than 0, then this implies any one or more of that the estimate is inaccurate, there is too much noise accompanying the signal (i.e. the SNR is very low), no signal is present, and the carrier is unlocked. In such cases, 10 log10(
Whilst an SNR estimate in dB is very useful and is perhaps the standard manner in which SNR is expressed, many other possible SNR indications are possible, for example a logarithmic value in a different base (e.g. ln(
A lock detection indicator 445 that signifies that a determination has been made that the local carrier 165 is locked to the received carrier, is obtained by comparing qM,N 430 to a lock indicator detection threshold 432 by use of a comparison device 435 such as a comparator. The value that should be chosen as the threshold 432 is dependent upon the value of
Calculation of the Scale Conversion Function 440
Determining values of 10 log10(
An example of the values of a lookup table for implementing the scale conversion function 440 in decibels can be found in
Implementation of the Phase Determiner 410
As for the phase determiner 410, it can be the same one used for determining the symbol phase for subsequently making decisions upon the received symbols (a common task in demodulators). Moreover, the output of this function, the received phase of the baseband symbol φn 415, is the same one required regardless of the value of M. Therefore, if structures are implemented for various Ms in the same receiver, such as in a receiver that has support for several modulations, then only one implementation of the phase determiner 410 may be used. This reduces the resources needed and is another advantage of the exemplary embodiment. The inverse tangent in the exemplary embodiment is one whose range is [−π,π), that is, it takes into account the quadrant in which rn is present. For example, it behaves similarly to the function a tan 2 in the program Matlab™. Although in the depicted embodiments the inverse tangent function is used to implement the phase determiner 410, in alternative embodiments (not depicted) the phase determiner 410 may be implemented in a different manner, and not necessarily using the inverse tangent function.
Relatively Efficient Implementation of the Metric Generator 420
A useful attribute of the lock detector and SNR estimator described above is that in some embodiments an implementation that takes advantage of the linear characteristic of the curves of kM(·) can be used. As discussed below, this implementation can be made to consume relatively few resources. Therefore some embodiments of the lock detectors, SNR estimators, and modulation classifiers in which the ideal symbol phases are uniformly distributed can be implemented using relatively efficient hardware, especially when multiple modulations are needed, since the phase determiner 410, which in many embodiments is a part that consumes substantial resources, can be reused from the symbol decision circuitry or other circuitry in the receiver that requires such functionality.
As a preliminary step, for the exemplary embodiment, the phase θ is encoded using a suitable encoding such as two's complement encoding which is b bits wide, in the exemplary embodiment from bits b−1 (the MSB (Most Significant Bit)) to 0 the LSB (Least Significant Bit). In the exemplary embodiment the MSB is the sign bit. The notation θ[x] refers to significant bit number “x” in the binary representation of θ. “x” is not necessarily the bit with index “x” counting from the right (as is the case in two's complement, starting with bit 0 as the LSB); in general, θ[0] would refer to the LSB, θ[1] would refer to the bit which is with the least significance except for the LSB, θ[2] would refer to the bit that is of the least significance except for θ[1] and θ[0], etc. For example, for the exemplary embodiment, θ[b−1] is the sign bit and MSB, and θ[0] is the LSB. The notation θ[x:y] is used to denote the binary number formed by the sequence of bits θ[x], θ[x−1], θ[x−2], . . . , θ[y]. For example, θ[3:0] signifies the binary number composed of the bits θ[3], θ[2], θ[1], θ[0] (e.g., if the code representing θ is 11110011 then θ[3:0]=0011 in this case). Additionally, the codes are assigned to linearly encompass the entire angular range, i.e. [−π,π) radians. That is, the lowest possible code (=the most negative code) represents the angle −π radians, and the highest possible encoding (=the most positive code) represents π−ε radians, where ε=π/(2b-1). To give a few examples, if there are b=8 bits in the code, the code “10000000” represents the angle −π, the code “10000001” represents the number −π+π/128, “10000010” represents the angle −π+2π/128 and so on; the code “00000000” represents the angle 0, the code “00000001” represents the angle π/128, the code “00000010” represents the angle 2π/128, and so on, and the highest code 01111111 represents the angle 127π/128=π−π/128=π−π/(2b-1). The purpose of this encoding is twofold. First, it maximizes the dynamic range utilization of the binary representation; since the angle's range is [−π,π) radians, the binary encoding encompasses this range and no codes are wasted. Hence quantization noise is reduced and the dynamic range of the binary representation is fully utilized. Secondly, as shall now be seen this allows for relatively efficient implementation of hM(·). Other encodings, such as one's-complement and sign-magnitude encoding can also similarly be used in other embodiments to attain similar efficiencies; such alternative encodings may or may not linearly encompass substantially all of the possible phases. It is also noted that the position of the LSB (which is the least significant) and MSB (which is the most significant) within the code word, as well as the position of the intermediate bits may depend on the encoding scheme used. Additionally, for convenience the concatenation operation is defined as <x,y> which signifies the concatenation of the binary numbers x and y. For example, <0101,1111> is the binary number 01011111.
To see how it is possible to relatively efficiently implement hM(·) using the encodings of the exemplary embodiment, note the linear characteristic of hM(·) at each interval of length π/(2M), e.g. for BPSK the intervals which h2(·) has the same sign and the same slope are [−π, −3π/4), [−3π/4,−π/2), [−π/2,−π/4), [−π/4,0), [0,π/4), [π/4,π/2), [π/2,3,π/4), [3π/4,π), as can be seen in
First, the “principal angle” is defined, which is directly proportional to the phase modulo (π/2M):
For the exemplary embodiment, the proportionality constant is π/(2M) in the denominator of (5) and the range of the “mod” (modulo) function is [0,π/(2M)), and these are chosen such that the value of θP is non-negative and is between 0 and 1, i.e. θPε[0,1). That is, the infimum of θP is 0 and the supremum of θP is 1. For example, for BPSK, the graph of θP is shown in
To illustrate this method, it is discussed below how h2(θ) and h4(θ) can be efficiently implemented for BPSK and QPSK, respectively. Tables 1 and 2 are respectively of h2(θ) as a function of θP and h4(θ) as a function of θP, according to the present exemplary embodiment.
Similar tables can be constructed for other values of M and other modulations.
Reviewing Tables 1 and 2, it can be determined how to relatively efficiently implement the base functions in hardware. For a relatively compact implementation for the exemplary embodiment, note that in two's complement notation of b bits, up to an inaccuracy of the LSB (Least Significant Bit), in order to compute hM(θ) (again, assuming the MSB (Most Significant Bit) is the bit with of index b-1 and the LSB is the bit of index 0):
In this way, multiplications and any other complicated operations can be avoided, and lookup tables do not need to be used. The only operations are performed using elementary gates, multiplexers, and additions. Moreover, the overhead for generating hM(θ) for multiple modulations is quite minimal, since no new computation of φn 415 is necessary for each additional modulation.
A relatively efficient implementation for computation of hM(θ) for an exemplary embodiment is shown in
Strictly speaking, obtaining the negative of a number in two's complement notation, i.e. obtaining −x for a number x, is performed via (˜x)+1, where “˜” represents bitwise inversion. The procedure described above may be modified to take this into account in alternative embodiments. Due to the asymmetric nature of two's complement encoding (i.e. that there is one more negative value than there are positive values) in many systems (especially signal-processing structures that are based on averaging, as is done here) −x is calculated simply as (˜x) in order to avoid potential overflow problems and in order to simplify logic. This is the procedure adopted for the various exemplary embodiments for two's complement representation.
As mentioned above, this implementation of hM(·) is the one that is used in order to compute hM(φn)), where φn 415 is the input to that function block as used in the exemplary embodiment, as shown in
A SystemVerilog implementation of hM(·) for BPSK, QPSK, 8-PSK and 16-PSK which requires no multiplications or other complicated operations, nor any significantly sized lookup table, is shown in
Although in the exemplary embodiment a two's complement notation is used, other numerical representations can be used, including but not limited to one or more of floating point and other fixed point or variable point notations, and non-binary encodings.
Implementation of hM(·) for Alternative Embodiments
In general, for alternative embodiments, the proportionality constant and modulo function range are chosen so that θP is between 0 and A (i.e. θPε[0,A)), where A is the absolute value of the maximum of the base function hM(·) and the base function has no DC offset. That is, the infimum of θP is 0 and the supremum of θP is A. The normalization in such cases is
For example, for BPSK:
Similar tables can be constructed for other values of M and other modulations. These tables allow us to reach a relatively very compact implementation, as follows.
For a relatively compact implementation for the exemplary embodiment, note that, in two's complement notation of b bits, up to an inaccuracy of the LSB (Least Significant Bit), in order to compute the lock detector (again, assuming the MSB (Most Significant Bit) is the bit with of index b-1 and the LSB is the bit of index 0):
Also, for convenience, the “principal angle precursor” is defined as <0,θ[b-3-log2 M:0]> for two's complement notation. In this case, it is clear from the above definitions that θP is B multiplied by the Principal Angle Precursor. In embodiments in which B equals one and the principal angle precursor is accordingly not amplified, the principal angle precursor and the principle angle are equal, as is the case for the embodiment described in relation to Tables 1 and 2, above. “Amplification” in the context of this disclosure does not necessarily mean that the amplitude increases; “amplification” by B in the context of this disclosure could also mean a reduction in amplitude (if B is less than 1) or no change in amplitude (if B equals 1).
A relatively efficient implementation for computation of hM(θ) for such embodiments is shown in
In alternative embodiments, everywhere that in the various exemplary embodiments the bits θ[b-3-log2 M:0] are used, it is possible to use a plurality of the most significant bits of those bits, for example θ[b-3-log2 M:0] (all the most significant bits of θ[b-3-log2 M:0], as is done in the exemplary embodiments), or θ[b-3-log2 M:1] (all the most significant bits of θ[b-3-log2 M:0] except the LSB), or θ[b-3-log2 M:2] (all the most significant bits of θ[b-3-log2 M:0] except the two least significant bits), etc. In an embodiment that differs from the exemplary embodiment wherein not all the most significant bits of θ[b-3-log2 M:0] are used, appropriate modifications are made to other parts of the receiver to accommodate the number of bits used. Such embodiments may be useful when a further reduction in resources is desired; however, such embodiments may be more susceptible to quantization noise.
Implementation of the Averager
The output 422 of the metric generator 420 is averaged by an averager 425 in order to compute qM,N 430 to obtain an estimate of the expectation E[hM(φn)], as noted earlier. In the exemplary embodiment, this is done using the IAD (Integrate and Dump) method. A possible implementation for the averager 425 is shown in
The IAD implementation for fixed-point logic, such as two's complement binary notation in the exemplary embodiment, is relatively efficient. In a hardware implementation as shown in
Many variations of this structure are possible, implemented in hardware, software, a combination of these, or via other means, and may be used in other embodiments. For example, averagers that are not IAD in nature can also be used in alternative embodiments. The structure presented here is an example used in a exemplary embodiment and should not be construed as limiting.
Calculation of
M(φn) can be determined from the S-curve function LM(χ,θe)≡E[hM(φn)|χ,θe,Δω=0]. To do this, the function hM(θ) is first written as its equivalent Fourier series representation:
Substituting this into the expression for the S-curve results in (7) (note the implicit dependence upon χ via the dependence of φn upon χ):
which is:
where In(·) is the n-th order modified Bessel function of the first kind. The expected value of the base function when perfectly locked is:
As an approximation, also note that:
and
(11) is useful for calculations at high SNR, since in some numerical program such as Matlab™ the calculation of Bessel functions is sometimes not sufficiently accurate at high SNRs.
A graph of the expected value of the base function
Determination of Threshold and of N for Lock Detection
The following describes one exemplary method for determining the lock indicator detection threshold 432 and N. Alternative embodiments are possible.
For notational convenience, the lock indicator detection threshold 432 is denoted as Γ, and the standard deviation of qM,N is denoted as σ=√{square root over (1/(2N))} (which is actually an upper bound on the standard deviation of the estimator qM,N). In general, using the fact that
and the fact that that due to the Central Limit Theorem qM,N is Gaussian for large N, the detection probability, that is the probability that the estimator qM,N passes the lock indicator detection threshold Γ when indeed the receiver is perfectly locked, is:
and the “≧” sign is due to the fact that an upper bound is being used on the standard deviation σ.
Conversely, when the receiver is not locked and only noise is present at the inputs, the probability of false alarm, that is, the probability that the lock detector will indicate lock when none is present, is calculated as:
Equations (12) and (13) are nonlinear inequalities. In order to find suitable values for Γ and N, (12) and (13) are treated as equalities. This will result in conservative (i.e. somewhat larger than necessary) values of N, which will consequently result in the system's performance in terms of the probability of a false alarm (PFA) and the probability of detection (PD) as being more than acceptable. Assuming for the exemplary embodiment that N is a constant, and that χ=χM,min is the minimum SNR which interests us for the particular modulation (for example, χM,min could be the minimum SNR in which the receiver is expected to achieve lock for a given M), then the values of N for acceptable PFA and PD for χ<χM,min are in general lower than the value computed for χ=χM,min (since the SNR is larger, and hence there is less variance of the estimator qM,N), and hence the value of N computed for χ=χM,min would be a conservative (and, hence, appropriate) value for N for χ>χM,min. Hence, treating (12) and (13) as equalities, and substituting σ=√{square root over (1/(2N))} and χ=χM,min, there is from (12):
√{square root over (N)}(Γ−
and from (13):
Substitution of (15) into (14) results in:
from which it follows that:
and substitution of (17) into (15) results in:
That is, calculation of Γ and N can be achieved via (17) and (18), given the false alarm and detection probabilities that the system is desired to attain.
In practical systems, PD>0.5 and PFA<0.5. Hence, erfc−1(2PD)<0 and erfr−1(2PFA)>0. From inspection of (18), this implies Γε(0,
Yet another exemplary method to determine Γ and N, which does not use a priori values of PFA and PD, is shown in
Extension to Handle Constellations with Phases Other than φn=2π·mn/M with mnε{0,1, . . . ,M−1}
As noted earlier, alternative embodiments can be made to handle a wide variety of modulations which are not limited to M-PSK or M-PSK-derived modulations. In such cases, M is defined as the total number of distinct phases in the constellation for the modulation. The guiding principle in such an adaptation is that the base function hM(θ) has a curve that is triangular in nature, with the maxima of the triangles corresponding to the ideal symbol phases and minima of equal amplitude (assuming no DC offset) but opposite polarity midway between the ideal symbol phases. Retained for convenience is the convention that phases upon which hM(θ) operates are defined such that they span the interval [−π,π). In alternative embodiments, the phases can be defined as residing in any interval of at least length 2π, in which case this entails a corresponding adaptation of the definition of hM(θ). In the present embodiment, hM(θ) has a maximum of 1 and a minimum of −1. In other embodiments, hM(θ) may have a maximum and minimum with different values, such as A for the maximum and −A for the minimum, where “A” is some non-zero value. Additionally, in some embodiments hM(θ) may have a DC offset, either inevitable (e.g. due to quantization) or intentional, that is for example the maximum will be A+DC and the minimum will be −A+DC, where “DC” represents the DC offset. However, that excessive DC offsets may cause performance degradations. Alternatively, the output of hM(θ) may span any suitable interval, such as any suitable subset of (−∞,∞), when implemented for example using software.
To exemplify the general process of determining hM(θ), in
Thus, since there are 12 distinct phases, the M for this case is 12. The graph of the function h12(θ) for Rectangular QAM-16 is shown in
The rest of the structures described for lock detection and SNR estimation that involve hM(θ) will also work for such a case. However, when evaluating hM(θ), the expectations that govern the various calculations, e.g. the definition hM(χ)≡E[hM(φn)|χ, carrier loop is locked], are made by taking into account the corresponding modulation type (in order that the symbol statistics and received phase statistics are correct) and by using the correct M for the given modulation (for example, for the case of Rectangular QAM-16 in
In the foregoing embodiments, references to the average metric qM,N 430 “surpassing” a “threshold” refers to qM,N 430 being greater than the threshold in embodiments in which the base function used to generate qM,N 430 is such that the ideal symbol phases correspond to the maxima of the base function (as in the exemplary embodiments), and refers to qM,N 430 being less than the threshold in embodiments in which the base function used to generate qM,N 430 is such that the ideal symbol phases correspond to the minima of the base function. As already noted, in alternative embodiments wherein the ideal symbol phases correspond to the minima of the base function, the thresholds will in general be the negative of the thresholds of the corresponding exemplary embodiments, and the expectation of the base function will be in general the negative of the expectation of the base function of the corresponding exemplary embodiments. Appropriate changes are then accordingly made to various components of such embodiments. For example, in an embodiment in which the ideal symbol phases of a modulation correspond to the minima of the base function, qM,N 430 “surpassing” the lock indicator detection threshold 432 may refer to qM,N 430 being −0.5 when the lock indicator detection threshold 432 is −0.1.
Extension to SNR Estimation for D-MPSK and MPSK without Carrier Lock and to Modulation Classifier
SNR Estimation
For a different type of SNR estimator, it is possible to use the base function hM(·) or a similarly defined base function, as described below, upon the normalized pseudo-coherently demodulated DMPSK constellation, allowing thus for SNR estimation and modulation classification without prior carrier synchronization.
Defined in this section is another embodiment of the triangle wave base function hMD(θ)≡hM(θ) for the definitions used in exemplary embodiments above for uniformly distributed phases, and hence the base function hMD(θ) can utilize the same relatively efficient implementations that are possible for hM(θ) for uniformly distributed phases, as described above. While the input to hM(θ) is the phase of the received baseband symbol itself, the input to hMD(θ) is the phase difference between two of the received baseband symbols. This is true for example for the exemplary embodiment where φn=2π·mn/M are the ideal symbol phases, with mnε{0,1, . . . , M−1}. When the symbol phases are not uniformly distributed, such as in other embodiments, as noted earlier hM(θ) will be such that with the maxima of the triangles correspond to the ideal symbol phases, whatever they may be. Analogously, when the ideal symbol phases are not uniformly distributed, hMD(θ) will be the triangle wave function with maxima corresponding to the ideal phase differences, which are defined as the set of all possible phase differences between ideal constellation symbols. As was the case for hM(θ), hMD(θ) is defined for all θε(−∞,∞), but, since any angle (in radians) is angularly equivalent to itself plus any integer multiple of 2π (radians), it suffices to implement hMD(θ) for any interval of length of at least 2π. In the exemplary embodiment, the domain of angles upon which hMD(θ) is implemented span the interval [−π,π) radians. For example, for QPSK in which the ideal phases are selected to be φ0=π/4, φ1=3π/4, φ2=5π/4, and φ3=7π/4, hM(θ) as implemented in the exemplary embodiment for this case will have maxima at the phases φ0=π/4, φ1=3π/4, φ2=5π/4, and φ3=7π/4 (or, rather, their equivalent phases in the range [−π,π), which are {−3π/4, −π/4,π/4,3π/4}) which are the ideal symbol phases, but hMD(θ) will have its maxima located at the ideal phase differences or their equivalent angles as expressed in the range [−π,π), which are for this example at angles {−π,−π/2,0,π/2}. In the foregoing example, the adjacent ideal phase differences are −π and −π/2, −π/2 and 0, and 0 and π/2.
In the exemplary embodiment, the phase differences upon which hMD(θ) operates are defined such that they span the interval [−π,π). In alternative embodiments the phase differences can be defined as residing in any appropriate interval of length of at least 2π, in which case this entails a corresponding adaptation of the implementation of hMD(θ). In the present embodiment, hMD(θ) has a maximum of 1 and a minimum of −1. In other embodiments, hMD(θ) may have a maximum and minimum with different values, such as A for the maximum and −A for the minimum, where “A” is some non-zero value. Additionally, in some embodiments hMD(θ) may have a DC offset, either inevitable (e.g. due to quantization) or intentional, that is for example the maximum will be A+DC and the minimum will be −A+DC, where “DC” represents the DC offset. However, excessive DC offsets may cause performance degradations.
Yet other embodiments may be defined where the minima of hMD(θ) (e.g. with value −A) correspond to the ideal phase differences, and maxima (e.g. with value +A) correspond to the phases midway between the ideal phase differences. In such embodiments, the thresholds and expected values are the negative of those discussed in the exemplary embodiments discussed herein, and other modifications to the embodiments are made as appropriate.
A possible implementation of the appropriate hardware structure is shown in
is defined as the normalized pseudo-coherently demodulated M-PSK signal. Defined now is φnD≡(φn−φn-1)mod2π, where the range of the modulo operation is [−π,π) such that φnDε[−π,π).
Substitutions show that
And accordingly:
Let ΔφnD≡Δφn−Δφn-1; note that since Δφn,Δφn-1ε[−π,π) then ΔφnDε[−2π,2π). Also let
Referring now to
As noted, for SNR estimation and modulation detection purposes the expectation E[hMD(φnD)] is approximated by a time averaging operation over a finite number of samples, as follows:
This averaging is done by an averager 930 that can be implemented for example using an Integrate and Dump (IAD) module, as shown in
As seen in
An example of the values of a lookup table for determining the SNR estimate 945 in decibels can be found in
While an SNR estimate in dB is very useful and is perhaps the standard manner in which SNR is expressed, many other possible SNR indications are possible, for example decibels in a different base (e.g. ln(
For a large enough N, qM,ND 935 will be a very good approximation of
(i.e. the value or qM,ND when N is very large). Another way to phrase this is that
and so for a given χ,
Then, as noted previously, using qM,ND as an estimate of
M
D(χ) can be calculated, and such a calculation is now presented for the exemplary embodiment. In the exemplary embodiment for M-PSK and D-MPSK, in order to calculate (
Note the lack of dependence on θe, which results from carrier synchronization not being needed. Also note the implicit dependency on χ through the variables φnD and ΔφnD. Furthermore, it can be determined that:
Therefore:
And:
And, using the fact that:
Then, approximately:
The expression of (27) is useful for calculations at high SNR, since in some numerical programs such as Matlab™ the calculation of Bessel functions is sometimes not sufficiently accurate at high SNRs.
Note that the assumption Δω→0 is satisfied by the condition |Δω|<<2π/(M·T) that was assumed previously, and which can be attained via a variety of methods such as open-loop frequency tuning
A graph of the expected value of the base function
Some structure re-use is possible in order to generate and use qM,ND 935 and qM,N 430 (as well as, for example, the SNR estimates 450, 945 derived from qM,N 430 and qM,ND 935). This is shown in
Extension to Non-MPSK Constellations
As noted above alternative embodiments can be made to handle a wide variety of modulations which are not limited to M-PSK modulations. In such cases, M is defined as the total number of distinct phases in the constellation. The guiding principle in such an adaptation is that hMD(θ) has a curve that is triangular in nature, with maxima of the triangles corresponding to the ideal phase differences of the symbols, which are in turn defined as the set of possible differences between ideal symbol phases. In embodiments without a DC offset, the function hMD(θ) will have minima of equal amplitude but opposite polarity located midway between its maxima. Retained for convenience is the convention that angles upon which hMD(θ) operates are defined such that they span the interval [−π,π). In alternative embodiments the angles can be defined as residing in any appropriate interval of length of at least 2π, in which case this entails a corresponding adaptation of the definition of hMD(θ). In the present embodiment, hMD(θ) has a maximum of 1 and a minimum of −1. In other embodiments, hMD(θ) may have a maximum and minimum with different values, such as A for the maximum and −A for the minimum, where “A” is some non-zero value. Additionally, in some embodiments hMD(θ) may have a DC offset, either inevitable (e.g. due to quantization) or intentional, that is for example the maximum will be A+DC and the minimum will be −A+DC, where “DC” represents the DC offset. However, excessive DC offsets may cause performance degradations. Alternatively, the output of hM(θ) may span any suitable interval, such as any suitable subset of (−∞,∞), when implemented for example using software.
To exemplify this process, in
Thus, since there are 12 distinct phases, the M for this case is 12. The graph of the function h12D(θ) for Rectangular QAM-16 is shown in
The structures described for SNR estimation and modulation classification that rely upon hMD(θ) will also work for cases other than those discussed in the exemplary embodiments. The expectations which govern the various calculations, e.g. the definition of the expected value of the base function
The number of maxima peaks in hMD(θ) is not necessarily M. This depends on the modulation used. For example, in the example above of Rectangular QAM-16, as can be seen in
The remainder of this disclosure again focuses on the M-PSK case, but extension to other modulations types is possible using the procedure outlined above.
In the foregoing embodiments, references to the average metric qM,ND 935 “surpassing” a “threshold” refers to qM,ND being greater than the threshold in embodiments in which the base function used to generate qM,ND is such that the ideal phase differences correspond to the maxima of the base function (as is the case in the exemplary embodiments), and refers to qM,ND being less than the threshold in embodiments in which the base function used to generate qM,ND is such that the ideal phase differences correspond to the minima of the base function. As already noted, in alternative embodiments wherein the ideal symbol phases correspond to the minima of the base function, the thresholds will in general be the negative of the thresholds of the corresponding exemplary embodiments, and the expectation of the base function will be in general the negative of the expectation of the base function of the corresponding exemplary embodiments. Appropriate changes are then accordingly made to various parts of such embodiments. For example, in an embodiment in which ideal phase differences of a modulation correspond to the minima of the base function, qM,ND “surpassing” the SNR sufficiency threshold 955 may refer to qM,ND being −0.5 when the SNR sufficiency threshold 955 is −0.1.
Modulation Classification
The values of qM,ND 935 can be used for modulation classification, as shown in
Theory of Modulation Classifier Operation
In the following, for the exemplary embodiment, the case of M-PSK or D-MPSK modulations where all the Ms are positive integer powers of 2 is considered. In other embodiments, other modulations or modulation orders may be present, and hence the description of the exemplary embodiment should not be construed as limiting. To gain insight into the surprising operation of the modulation classifier, the operation of the metric generator 920 is considered when the input signal has the “wrong” M; i.e., a value for M that does not correspond to the value of M for which the metric generator 920 is designed. Formally, suppose that the input signal modulation index is MT (with “T” standing for “True”). How would the metric generator 920 for computation of qM
This analysis is considered as two cases: Case (A): MW>MT, and Case (B): MW<MT.
For case (A), the constellation consisting of the MT possible constellation points is a symmetric subset of the MW constellation points for which the estimator qM
is the pseudo coherently demodulated normalized constellation of the input signal. The value of q4,ND is an average of the application of hM
Now, q4,ND for the symbols shown in
For case (B) (MW<MT) the situation is slightly more complicated. It can nonetheless be seen that for any MW<MT, E[qM
To exemplify this, refer to
In the more general case of MT=2kMW, where k is a positive integer, the constellation of νn can be decomposed into 2k separate constellations of MW symbols whose combined contribution to the value of qM
These statistics of qM
Since (see
where {circumflex over (M)}C is used to denote the decided upon modulation index, which nominally equals MC.
As an alternative to the peak detector decision rule or algorithm in (29), a simple decision method is also possible which is not as susceptible to quantization effects. Note that, given (28), the correct modulation classification is the modulation that corresponds to the lowest index j for which qM
if qM
else if qM
else if qM
else out=3; (30)
The decision rule of (30) is given for an exemplary case where there are 4 possible modulations to detect, with indices M1, M2, M3, and M4. Other embodiments may handle more than four modulations, or less than four modulations. The modulation decision method of (30) is implemented as shown in
In this example, the four possible modulation orders include adjacent powers of two; by “adjacent powers of two”, it is meant any two powers of 2 equaling 2k, where for one of the powers of two k=n and for the other k=n+1, and where n is a positive integer. In this example, M1 and M2 are adjacent powers of two; M2 and M3 are adjacent powers of two; and M3 and M4 are adjacent powers of two. In this example, each of the possible modulation orders is also evenly divisible by the lowest value of M; i.e., the lowest value of M is M=2, and M=2, 4, 8 and 16 are each divisible by M=2 without leaving a remainder. Such a set of values of M is beneficial because the fact that such a relationship between the values of M is present is part of the reason that the metric generators behave as they do when applied to “wrong” modulations.
There is the distinct possibility that none of the values of qM
It should be noted that although the structures in
Another possible embodiment of the modulation decision logic is given in
Regarding the validity thresholds, since the expected value of qM
Detection and False Alarm Probabilities
To implement a particular instantiation of the modulation classifier, the validity thresholds and the values of Ni are defined and the probability that each of the average metrics qM
For notational convenience, let the validity threshold for modulation index i be Γi, and the standard deviation of qM
and the “≧” sign is due to the fact that an upper bound is used on the standard deviation.
Conversely, using (28) for all i<C and to a good approximation:
In order find suitable values for Γi and Ni, (31) and (32) are treated as equalities. This will result in conservative (i.e. somewhat larger than necessary) values of Ni, which is not a problem, as the system's performance in terms of PD,i and PFA,i will exceed the required performance if Ni is larger than needed. Also, to find Ni as a constant, the equations are solved for χ=χM
√{square root over (Ni)}(Γi−
and from (32):
Substitution of (34) into (33) results in:
from which it follows that:
and substitution of (36) into (34) results in:
In practical systems, PD,i>0.5 and PFA,i<0.5. Hence, erfc−1(2PD,i)<0 and erfc−1(2PFA,i)>0. Combined with (37), this implies Γiε(0,
Yet another method to determine Γi and Ni, which does not require a priori specification of PD,i and PFA,i, is shown in
In the foregoing embodiments, references to the average metric qM
Reduction to Practice and Approximate Resource Usage Comparisons to Prior Art
All the structures presented in this disclosure have been implemented in practice and proven to work by the inventor using a Terasic DE2-115 board with an Altera Cyclone IV FPGA. In alternative embodiments, hardware other than an FPGA may be used for implementation. For example, the exemplary structures may be implemented using an ASIC.
The FPGA was also used to implement, as a point of comparison, the structures described in LINN, Y. & PELEG, N. 2004. A family of self-normalizing carrier lock detectors and Es/N0 estimators for M-PSK and other phase modulation schemes. IEEE Trans. Wireless Commun., 3, 1659-1668 and in LINN, Y. 2009. A Carrier-Independent Non-Data-Aided Real-Time SNR Estimator for M-PSK and D-MPSK Suitable for FPGAs and ASICs. IEEE Trans. Circuits and Systems I, 56, 1525-1538. In order to attain the comparison, several documents that calculate the equivalent gate count for FPGA structures were used as sources. These are documents Altera Inc. Application Note 110: Gate Counting Methodology for APEX 20K Devices, September 1999, Xilinx Inc. Application XAPP 059: Gate Count Capacity Metrics for FPGAs, February 1997 and M. H. Rais, “Efficient Hardware Realization of Truncated Multipliers using FPGA,” International Journal of Engineering and Applied Sciences, vol. 4, no. 2, 2009. From those sources, the following approximate gate equivalences are obtained:
Estimating the number of gates from FPGA structures is an imprecise science, and those gate counts will differ from ASIC gate counts. Nonetheless, the values in Table 4 are useful for the purposes of making comparisons.
First, the resource usage of the lock detectors and SNR estimators based on hM(·) is compared to prior art LINN, Y. & PELEG, N. 2004. A family of self-normalizing carrier lock detectors and Es/N0 estimators for M-PSK and other phase modulation schemes. IEEE Trans. Wireless Commun., 3, 1659-1668. In the Altera Cyclone IV FPGA in the DE2-115 board used for tests, the following resource usage data was measured:
Comparing the results, the total number of required gates has decreased substantially, by about 66.06%, i.e. only about a third of the logic resources are required as compared to the prior art (201908 equivalent gates as opposed to 594964 for the prior art). This also allows for a similar and corresponding reduction in power consumption and circuit area for the embodiment as compared to the prior art.
Now, the resource usage of the SNR estimators based on hMD(·) is compared to the prior art, Linn, 2009, A Carrier-Independent Non-Data-Aided Real-Time SNR Estimator for M-PSK and D-MPSK Suitable for FPGAs and ASICs. In the Altera Cyclone IV FPGA in the DE2-115 board used for tests, the following resource usage data was measured:
Comparing the results, the total number of required gates has decreased substantially, by about 95.79% (202058 equivalent gates vs. 4802568 equivalent gates for prior art), i.e. only about 4% of the logic resources are required as compared to prior art. This represents about a 25-fold reduction in logic, or an increased efficiency of 2500%. This also allows for a similar and corresponding reduction in power consumption and circuit area for the embodiment as compared to the prior art.
As can be seen, the advantage of the present structures increases as the number of supported modulations increases, i.e. the advantage would be even greater if 5 or 6 modulations (e.g. also 32-PSK and 64-PSK) were implemented as well.
The above comparison were done fairly; that is, the chosen quantization for the present structures and those of the prior art were chosen so that both would have roughly the same performance.
The above comparisons do not include the modulation classification embodiments discussed above. The implementation of the structure in
As discussed above, the foregoing embodiments enjoy several benefits. First, those embodiments that utilize the principal angle to evaluate the base function may be implemented using a relatively simple arrangement of logic gates, multiplexers, and adders, and that can make them quite useful in one or both of CR and SDR. Many modulation classification algorithms, while mathematically viable, are too cumbersome and resource hungry for practical use. In contrast, the modulation classifiers discussed above do not require divisions, multiplications, Fourier transforms, or other complicated transforms.
Second, for several of the presented exemplary embodiments no carrier synchronization of the input signal is needed to perform SNR estimation or modulation classification. This can be beneficial, since avoiding the need to recover the carrier phase avoids the inherent delay, risk of failure, and complexity of this synchronization operation (which is usually implemented as a phase locked loop (PLL) or other synchronization circuitry).
Third, the foregoing embodiments are Non-Data Aided (NDA), which is to say they are independent of the data being transmitted. As such, they are beneficial over Data Aided (DA) methods. DA methods require prior knowledge of some or all of the transmitted data sequence upon which the modulation classification estimation is done. This is problematic on several levels: for example, often some of the data throughput is sacrificed in DA methods in order to send known symbols, such as pilot symbols, and the receiver must known when those known data symbols are present, implying some sort of required prior frame synchronization. NDA methods, such as those presented above, avoid these pitfalls.
Fourth, the foregoing embodiments operate using only 1 sample/symbol. Thus, the computational complexity and power usage of the foregoing embodiments are accordingly reduced as compared to structures that require a higher sampling rate.
Fifth, the performance of the foregoing embodiments are largely independent of the AGC (Automatic Gain Control). In particular, the various thresholds and functions used in the embodiments of the modulation classifier or lock detector are largely independent of the AGC's performance or operating point, and their overall performance is also resilient to AGC imperfections. This is in sharp contrast to many typical modulation classifiers, SNR estimators, and lock detectors, which depend in some way on the AGC's operating point and performance, particularly with respect to calibration of the classification and lock thresholds. For example, the AGC loops generally converge very slowly compared to the symbol rate, and this implies that a modulation classification scheme that requires a priori knowledge of the AGC operating point must wait for the AGC loop to converge, hence prolonging the time until an accurate classification can be made. This problem is not present in the foregoing embodiments that are largely independent of the AGC.
Sixth, some parts of the modulation classifiers' hardware structure can be used concurrently, as parts of the carrier lock detector and SNR estimator, hence simplifying the overall structure of the receiver.
In addition to the hardware implementations discussed above, the foregoing embodiments may be encoded on to a computer readable medium that is readable by a processor so as to configure the receiver to have the functionality described above. The computer readable medium may be flash memory, RAM, any other suitable disc or semiconductor based memory, or any other suitable computer readable medium. Using software to implement the foregoing embodiments may be suitable when an embodiment of the base function is used that does not lend itself to a relatively efficient hardware implementation, or when the power consumption advantages of hardware are immaterial, for example.
For the sake of convenience, the example embodiments above are described as various interconnected functional blocks, which may be implemented using one or both of distinct hardware and software modules. This is not necessary, however, and there may be cases where these functional blocks or modules are equivalently aggregated into a single logic device, program or operation with unclear boundaries. In any event, the functional blocks, software, and hardware modules can be implemented by themselves, or in combination with other operations in one or both of hardware and software, or via any other suitable implementation method.
While particular example embodiments have been described in the foregoing, it is to be understood that other embodiments are possible and are intended to be included herein. It will be clear to any person skilled in the art that modifications of and adjustments to the foregoing example embodiments, not shown, are possible.
This application is entitled to the benefit of and incorporates by reference essential subject matter disclosed in International Patent Application No. PCT/CA2011/001220 filed on Nov. 1, 2011 and U.S. Patent Application No. 61/409,544 filed Nov. 3, 2010.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CA2011/001220 | 11/1/2011 | WO | 00 | 5/1/2013 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2012/058759 | 5/10/2012 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
3555194 | Goto | Jan 1971 | A |
3878475 | Okano et al. | Apr 1975 | A |
3927260 | Amundson et al. | Dec 1975 | A |
6804309 | Morelos-Zaragoza | Oct 2004 | B1 |
6993440 | Anderson et al. | Jan 2006 | B2 |
7035593 | Miller et al. | Apr 2006 | B2 |
7116943 | Sugar et al. | Oct 2006 | B2 |
7190741 | Manning | Mar 2007 | B1 |
7366137 | Abrishamkar et al. | Apr 2008 | B2 |
7376178 | Li et al. | May 2008 | B2 |
7379507 | Chen et al. | May 2008 | B2 |
7697639 | Kim et al. | Apr 2010 | B2 |
20020067778 | Ahn | Jun 2002 | A1 |
20030072392 | Beadle et al. | Apr 2003 | A1 |
20030112899 | Linsky et al. | Jun 2003 | A1 |
20050063487 | Sayegh | Mar 2005 | A1 |
20060072656 | Wiss et al. | Apr 2006 | A1 |
20060115013 | Kim et al. | Jun 2006 | A1 |
20060239338 | Kolanek et al. | Oct 2006 | A1 |
20070168407 | Prasad et al. | Jul 2007 | A1 |
20100061487 | Kumar et al. | Mar 2010 | A1 |
Entry |
---|
“A Self-Normalizing Symbol Synchronization Lock Detector for QPSK and BPSK”, Yair Linn, IEEE Transactions on Wireless Communications, vol. 5, No. 2, Feb. 2006; pp. 347-353. |
“A Real-Time SNR Estimator for D-MPSK over Frequency-Flat Slow Fading AWGN Channels”, Yair Linn, 2006 IEEE Sarnoff Symposium, Princeton, NJ, Mar. 27-28, 2006, pp. 1-8. |
“Synchronization and SNR Esimation in M-PSK Wireless Receivers” Yair Linn, in Proc. International Seminar: 15 Years of Electronic Engineering, Universidad Pontificia Bolivariana, Bucaramanga, Colunbia, Aug. 15-19, 2006, pp. 1-15. |
“A new family of NDA carrier phase detectors for coherent M-PSK receivers”, IEEE 2002 International Conference on Communications, Circuits and Systems and West Sino Expositions, Jun. 29-Ju. 1, 2002, vol. 1, pp. 134-141. |
“Survery of automatic modulation classification techniques: classical approaches and new trends”, O.A. Dobre, et al., IET Commun. 2007, 1 (2) pp. 137-156. |
“SNR Mismatch and Online Estimation in Turbo Decoding”, Todd A. Summers et al.; 0090-6778/98$10.00; 1998 IEEE; pp. 421-423. |
“A Unified Approach to the Performance Analysis of Digital Communication over Generalized Fading Channels”, Marvin K. Simon, et al.; Proceedings of the IEEE, vol. 86 No. 9 Sep. 1998; 0018-9219/98$10.00 1998 IEEE; pp. 1860-1877. |
“Channel Quality Estimation and Rate Adaptiion for Cellular Mobile Radio” Krishna Balachandran, et al.; IEEE Journal on Selected Areas in Communications, vol. 17, No. 7, Jul. 1999; 0733-8716/99$10.00 1998 IEEE; pp. 1244-1256. |
“Altera Inc. Application Note 110: Gate Counting Methodology for APEX 20K Devices, Sep. 1999,” at www.altera.com, accessed Sep. 2011; pp. 1-8. |
“Xilinx Inc. Application XAPP 059P: Gate Count Capacity Metrics for FPGAs. Feb 1997” at www.xilinx.com, accessed Sep. 2011; pp. 1-6. |
“Efficient Hardware Realization of Truncated Multipliers using FPGA” M. H. Rais, International Journal of Engineering and Applied Sciences, vol. 4, No. 2, 2009; pp. 124-128. |
“A Symbol Synchronization Lock Detector and SNR Estimator for QPSK, with Application to BPSK”, Yair Linn, Proceedings of the 3rd IASTED International Conference; Jul. 14-16, 2003, Banff, Alberta Canada; 9 pages. |
A Family of Self-Normalizing Carrier Lock Detectors and Es/No Estimators for M-PSK and Other Phase Modulation Schemes, Yair Linn, et al.; IEEE Transations on Wireless Communications, vol. 3, No. 5, Sep. 2004; pp. 1659-1668. |
“Quantitative Analysis of a New Method for Real-Time Generation of SNR Estimates for Digital Phase Modulation Signals”, Yair Linn, IEEE Transations on Wireless Communications, vol. 3, No. 6, Sep. 2004; pp. 1984-1988. |
“A Hardware Method for Real-Time SNR Estimation for M-PSK Using a Symbol Synchronization Lock Metric”, Yair Linn, Proceedings of the 9th Canadian Workshop on Information Theory, Montreal, Quebec, Jun. 5-8, 2005; pp. 247-251. |
“A Methodical Approach to Hybrid PLL Design for High-Speed Wireless Communications”, Yair Linn,; WAMICON 2006; 2-4244-0849-0/06$20.00 2006 IEEE; 9 pages. |
“Efficient Loop Filter Design in FPGAs for Phase Lock Loops in High-Datarate Wireless Receivers—Theory and Case Study” Yair Linn, 1-4244-0697-08/07.00 2007 IEEE; 8 pages. |
“Simple and Exact Closed-Form Expressions for the Expectation of the Linn-Peleg M-PSK Lock Detector”, Yair Linn, 1-4244-1190-4/071$25.00 2007 IEEE; pp. 102-104. |
“A Carrier-Independent Non-Data-Aided Real-Time SNR Estimator for M-PSK and D-MPSK Suitable for FPGAs and ASICs” Yair Linn, IEEE Transactions on Circuits and Systems—I: Regular Papers, vol. 56, No. 7 Jul. 2009; pp. 1525-1538. |
“A New Architecture for Coherent M-PSK Receivers”, Yair Linn; in Proc. IEEE COMCAS'09, Tel-Aviv, Israel, Nov. 9-11, 2009; 14 pages. |
“Efficient Structures for PLL's Loop Filter Designed in FPGAs in High-Datarate Wireless Receivers—Theory and Case Study”; Yair Linn; Wireless Technology, Lecture Notes in Electrical Engineering 44, DOI 10.1007/978-0-387-71787-6—6, Copyright Springer Science+Business Media, LLC 2009; pp. 115-132. |
International Search Report for PCT Serial No. PCT/CA2011/001220 dated Jan. 30, 2012. |
Number | Date | Country | |
---|---|---|---|
20130230085 A1 | Sep 2013 | US |
Number | Date | Country | |
---|---|---|---|
61409544 | Nov 2010 | US |