1. Field of the Invention
The present invention relates to a circuit and method for determining a time of arrival of a signal event. More particularly, the present invention involves a circuit for estimating an arrival time of a signal pulse edge by calculating a plurality of intermediate amplitude values between a first signal sample and a second signal sample and interpolating the arrival time by comparing each of the plurality of intermediate values to a threshold value.
2. Description of Prior Art
Radio frequency (RF) signal receivers and other receivers use analog-to-digital converters (ADCs) to capture signal samples for processing. Such ADCs are typically driven by a receiver system clock, and thus capture samples at a rate equal to the frequency of the system clock. A circuit that determines a time of arrival (TOA) of a signal event, such as a rising edge of the signal, relies on the samples generated by the ADC and is thus limited in operation to the system clock rate.
By way of example, and referring to
One method of increasing the resolution of the TOA involves the use of an additional analog-to-digital converter (ADC) sampling the RF signal at a higher frequency than the system clock to generate one or more amplitude samples during the time T between samples N and N+1. With this method, the slower ADC running at the system clock speed captures samples used to detect when the signal has exceeded a threshold value to trigger a circuit to compare the most recent values generated by the fast ADC to the threshold value, thus more accurately determining the arrival time of the signal event.
This method suffers from various problems and limitations. First, the faster ADC requires dedicated analog-to-digital conversion circuitry, an additional clock, and storage elements (for storing recent values) among other things, all of which contribute to the size and power consumption of the overall circuit. Second, the additional clock must run the faster ADC at a higher frequency than the system clock and be synchronized with the system clock, adding to the complexity of the overall circuit.
Accordingly, there is a need for an improved TOA detection method that does not suffer from the problems and limitations of the prior art.
The present invention provides an improved circuit for determining the time of a arrival of a signal event. Particularly, the present invention provides a circuit for estimating an arrival time of a signal pulse edge by calculating a plurality of intermediate amplitude values between a first signal sample and a second signal sample and interpolating the arrival time by comparing each of the plurality of intermediate values to a threshold value.
According to a first embodiment of the invention, a system for determining the arrival time of a signal event comprises an intermediate value calculator, a comparator, and a decoder. The intermediate value calculator receives two samples of the signal, wherein a first sample includes a first amplitude value and a first time of arrival and a second sample includes a second amplitude value and a second time of arrival, and defines a plurality of intermediate values between the first amplitude value and the second amplitude value.
The comparator receives a threshold value and the plurality of intermediate values, compares each intermediate value to the threshold value, and generates a comparison result. The decoder generates a time of arrival adjustment value based on the comparison result, the first time of arrival, and the second time of arrival.
According to a second embodiment of the invention, an electronic circuit for determining the arrival time of a signal event comprises a first stage, a second stage, and a third stage. The first circuit stage receives a first signal sample with a first amplitude value and a first time of arrival, receives a second signal sample with a second amplitude value and a second time of arrival, and determines a one-half amplitude value by adding the first and second amplitude values and dividing the result by two.
The second circuit stage determines a one-fourth amplitude value by adding the first amplitude value to the one-half amplitude value and dividing the result by two, and determines a three-fourths amplitude value by adding the second amplitude value to the one-half amplitude value and dividing the result by two. The third circuit stage compares the one-fourth, one-half, and three-fourths amplitude values to a threshold amplitude value and generates a time of arrival adjustment value based on the comparisons.
According to a third embodiment of the invention, the electronic circuit includes a system clock as well as first, second, and third circuit stages, wherein the system clock generates a clock signal characterized by clock events. The first stage includes a signal input, a first memory element for receiving a value from the signal input and storing the value upon the occurrence of a first clock event, and a first adder for receiving the stored value from the first memory element and a value from the signal input and adding the two values to generate a first added value.
The second stage includes second and third memory elements as well as second and third adders. The second memory element receives the first added value and stores the first added value upon the occurrence of a second clock event, and the third memory element receives the stored value from the first memory element and stores the value upon the occurrence of the second clock event. The second adder receives the stored values from the second and third memory elements and adds the two values to generate a second added value, and the third adder receives the stored values from the first memory element and the second memory element and adds the two values to generate a third added value.
The third stage includes fourth, fifth, sixth and seventh memory elements as well as fourth, fifth, sixth, and seventh adders. The fourth memory element receives the stored value from the third memory element and stores the value upon the occurrence of a third clock event, and the fifth memory element receives and stores a portion of the second added value upon the occurrence of the third clock event.
The fourth adder receives the stored values from the fourth and fifth memory elements and adds the values to generate a fourth added value. The sixth memory element receives the stored value from the second memory element and stores the value upon the occurrence of the third clock event. The fifth adder receives the stored values from the fifth an sixth memory elements and adds the values to generate a fifth added value.
The seventh memory element receives and stores a portion of the third added value upon the occurrence of the third clock event, and the sixth adder receives the stored values from the sixth and seventh memory elements and adds the values to generate a sixth added value. The seventh adder receives the stored values of the third and seventh memory elements and generates a seventh added value.
These and other important aspects of the present invention are described more fully in the detailed description below.
An embodiment of the present invention is described in detail below with reference to the attached drawing figures, wherein:
A preferred embodiment of a high-resolution time of arrival interpolation circuit incorporating principles of the present teachings is illustrated in
Referring also to
The detection circuit 26 performs various operations on the signal received from the antenna 24 before communicating it to the signal processing circuitry 28 and the interpolation circuit 10. For example, the detection circuit 26 converts the signal to a digital format, creates a threshold value 32 for use in identifying a signal event, and generates one or more synchronization signals to synchronize the signal processing circuitry 28 and the interpolation circuit 10 with the signal event.
The detection circuit 26 includes an analog-to-digital converter (ADC) 34 for converting the signal received from the antenna 24 from an analog form to a digital form for digital processing. The ADC 34 samples the signal received from the antenna 24 to generate a series of digital values representing an amplitude of the signal at different points in time. The detection circuit 26 then filters the digital values generated by the ADC 34 by averaging consecutive signal values which can, for example, remove noise spikes from the signal to avoid false indications of a signal event. The detection circuit 26 may use two, four, or eight samples of the digital signal to generate two-point, four-point, or eight-point averaged data, respectively, where an averaged data value is the average of the sampled values.
More particularly, the detection circuit 26 may generate two-point averaged data by summing two consecutive sample values and dividing by two; four-point averaged data by summing four consecutive sample values and dividing by four, and eight-point averaged data by summing eight consecutive sample values and dividing by eight. The series of digital values generated by the ADC 34 thus are replaced by a series of averaged (filtered) values that will hereinafter be referred to collectively as the “digital signal,” wherein a “sample” of the digital signal has reference to one of the averaged values.
The detection circuit 26 is operable to selectively communicate the digital signal to the interpolation circuit 10 and the signal processing circuitry 28 in one of a plurality of formats, and preferably as two-point, four-point, or eight-point averaged data. For example, the detection circuit 26 may provide a two-point averaged data output as “DATA_A,” a four-point averaged data output as “DATA_B,” and an eight-point averaged data output as “DATA_C,” wherein all three outputs are communicated to the interpolation circuit 10 (see
The detection circuit 26 calculates the threshold value 32, which is used to determine when a rising edge, falling edge, or other signal event has occurred. The threshold value typically corresponds to one-half of the average measured voltage of the signal or one-half of the average measured power of the signal, and can be calculated using the two-point, four-point, or eight-point averaged data values. By way of example, the threshold value may be the average amplitude of the previous one-hundred samples of the digital signal, or may be the average amplitude of all samples over a period spanning a specific number of signal events, such as the two most recent leading edges of signal pulses. The detection circuit 26 communicates the threshold value to the interpolation circuit 10 for use in generating a high resolution time of arrival value, as explained below in greater detail.
The detection circuit 26 also generates one or more synchronization signals to synchronize operation of the signal processing circuitry 28, interpolation circuit 10, or both, with a detected signal event. The detection circuit 26 may detect, for example, a leading or trailing edge (or both) of a signal pulse by monitoring samples of the digital signal. For example, the detection circuit 26 may detect a rising edge on the digital signal by comparing an amplitude value corresponding to the sample N+1 with the threshold value 32 and determining that the amplitude value is greater than the threshold value 32. When the detection circuit 26 has detected a rising edge, it asserts the first synchronization signal after a pre-determined delay to notify the interpolation circuit 10 that a leading pulse edge has been detected and, therefore, the data being communicated to the interpolation circuit 10 may be used to determine a time of arrival of the rising edge. The detector circuit 26 asserts the second synchronization signal when it subsequently detects a falling edge on the digital signal to notify the interpolation circuit 10 and the signal processing circuitry 28 that a trailing pulse edge has been detected. The first synchronization signal is communicated to the interpolation circuit 10 as “SYNC_1” and the second synchronization signal is communicated to the interpolation circuit 10 as “SYNC_2,” illustrated in
The receiver system 22 is preferably implemented at least partially in an integrated circuit and is adapted to receive an RF signal in a conventional manner. The interpolation circuit 10 is preferably implemented at least partially in a field programmable gate array (FPGA), or other programmable logic device. It will be appreciated, however, that the present invention is not limited to a particular circuit construction methodology or use with a particular type of signal or a particular signal frequency. The interpolation circuit 10, for example, may be implemented in an application specific integrated circuit (ASIC), and may be used to detect signals in any of a variety of environments, including wired or wireless communications operating at substantially any frequency. Furthermore, the receiver system 22, or a portion thereof, may be implemented with one or more discrete circuit components.
As explained above, the detection circuit 26 detects a time of arrival of a leading edge or a trailing edge of a signal when the signal crosses the threshold value 32. Because the ADC 34 samples the signal at the system clock 30 rate, prior art systems would record the time of arrival of the signal illustrated in
To increase the resolution of the time of arrival determined by the signal processing circuitry 28, the circuit 10 interpolates a plurality of amplitude values between the measured amplitude values from samples N and N+1 (see
The time corresponding to the intermediate value 42 is an estimate based on the difference between the time of arrival associated with N and the time of arrival associated with N+1. Because N and N+1 correspond to consecutive events of the system clock 30 (such as consecutive rising edges), the time difference between samples N and N+1 is equal to one clock period T, which is 12.5 ns with an 80 MHz system clock. There are eight total intervals between samples N and N+1, and five of the intervals are between sample N+1 and the threshold value. Therefore, the high resolution time of arrival is estimated as the time of arrival of N+1 less (⅝×T).
The interpolation circuit 10 includes a system of adders and memory elements. It will be appreciated that the circuit 10 as illustrated and described is exemplary, and not limiting, in nature, and that the illustrated circuit elements may be substituted with similar elements without departing from the scope of the claimed invention.
Referring now to
Each stage 64,66,68 includes one or more memory elements and one or more adders. Each memory element is a D-type flip-flop with a fourteen-bit input, a fourteen-bit output, and a clock signal input. A flip-flop stores the input value upon the occurrence of a clock event, such as a rising edge of a clock signal. The stored value is presented on the output, and does not change until a new input is stored upon the occurrence of another clock event. The flip-flops may include other features not shown including, for example, an inverted output and an enable input.
Each adder includes two fourteen-bit inputs and a fifteen-bit output, wherein the output represents a sum of the inputs and includes a carry bit as the most significant bit. The adders are combinatorial circuits that are conventional in nature and may be constructed according to any of various methodologies without departing from the scope of the claimed invention. It should be noted that the interpolation circuit 10 is not limited to memory elements and adders of the size described above, buy may one or more circuit elements that accommodate more or fewer bits according to particular implementations of the invention.
The first stage 64 of the intermediate value calculator 10 includes a signal input 70, a first memory element 72, and a first adder 74. The sample input 70 receives a digital signal sample and communicates the sample to the first memory element 72 and to the first adder 74. An output A of the first memory element 72 is also communicated to the adder 74, such that the adder 74 receives a current signal value from the signal input 70 as well as a previous signal value stored in the first memory element 72. Thus, the adder 74 adds the amplitude values of samples N and N+1 illustrated in
From the foregoing it can be seen that two values are associated with each sample N and N+1: an amplitude value and a time of arrival. The amplitude value is the value communicated to the intermediate value calculator 10 via the sample input 70 as the signal sample. The time of arrival of a sample corresponds to the particular clock cycle in which the sample was captured. The time of arrival of N+1 is one clock cycle greater than the time of arrival of N.
The second stage 66 includes second 76 and third 78 memory elements as well as second 80 and third 82 adders. The second memory element 76 receives all but the least significant bit of the output B of the first adder 74 and presents the stored value on output C. Because the memory element 76 receives all but the least-significant bit of output B, it is receiving one-half of the value on output B, or the sum of the amplitude of sample N and the amplitude of sample N+1 divided by two. This value represents an estimate of the amplitude of the signal at a time half-way between the time of sample N and the time of sample N+1, hereinafter referred to as the one-half amplitude value.
The third memory element 78 receives the output A of the first memory element and presents the stored value on output D. Outputs C and D are communicated to the second adder 80, which sums the values and presents a fifteen-bit value on output E that is the sum of the two inputs. As explained above, the input to the second memory element 76 represents the one-half amplitude value. In the second stage, the output D of the third memory element 78 is the amplitude value of sample N, therefore, the second adder 80 receives as inputs the one-half amplitude value and the amplitude value of sample N and sums the two values, presenting the result on output E.
The third adder 82 receives as inputs the output C of the second memory element 76 and the output A of the first memory element 72. Output C is the one-half amplitude value, and output A is the amplitude value of sample N+1. Thus, the third adder 82 adds the one-half amplitude value to the amplitude value of sample N+1 and presents the sum on output F.
The third stage 68 includes fourth 84, fifth 86, sixth 88, and seventh 90 memory elements as well as fourth 92, fifth 94, sixth 96, and seventh 98 adders. The fourth memory element 84 receives all bits except for the least significant bit of the output E of the second adder 80, which represents a one-fourth amplitude value, therefore the output of the fourth memory element 84 is the one-fourth amplitude value. The fifth memory element 86 receives the output D of the third memory element 78 and generates an output G that is the amplitude value of sample N. The fourth adder 92 also receives the one-fourth amplitude value from the fourth memory element 84. The fourth adder 92 therefore sums the one-fourth amplitude value and the amplitude value of sample N and presents the result on output H, wherein the result is a fifteen-bit value representing a one-eighth amplitude value multiplied by two.
The sixth memory element 88 receives the output C of the second memory element 76, which is the one-half amplitude value, therefore the output of the sixth memory element 88 is the one-half amplitude value. The fifth adder 94 receives the one-fourth amplitude value from the fourth memory element 84 and the one-half amplitude value from the sixth memory element 88. The fifth adder 94 therefore sums the one-fourth amplitude value and the one-half amplitude value and presents the result on output I, wherein the result is a fifteen-bit value representing a three-eighths amplitude value multiplied by two.
The seventh memory element 90 receives all bits except for the least significant bit of the output F of the third adder 82, which represents the three-fourths amplitude value. The sixth adder 96 receives the one-half amplitude value from the sixth memory element 88 and the three-fourths amplitude value from the seventh memory element 90. The sixth adder 96 therefore sums the one-half amplitude value and the three-fourths amplitude value and presents the result on output J, wherein the result is a fifteen-bit value representing a five-eighths amplitude value multiplied by two.
The seventh adder 98 receives the output D of the third memory element 78 which is the amplitude value of the sample N+1. The seventh adder 98 also receives the three-fourths amplitude value from the seventh memory element 90. The seventh adder 98 therefore sums the three-fourths amplitude value and the amplitude value of the sample N+1 and presents the result on output K, wherein the result is a fifteen-bit value representing a seven-eighths amplitude value multiplied by two.
The seven outputs of the interpolation circuit 10 are illustrated on the right of
Referring again to
An exemplary comparator circuit 116 implementing the function of the comparator 14 is illustrated in
The decoder 16 receives the output of the comparator 14 and generates a time of arrival adjustment value that represents a difference between the low-resolution time of arrival and the high-resolution time of arrival. Appendix A includes a block of hardware description language code that performs this function. A skilled artisan will recognize that the code segment identified as a table assigns one of eight values to a decoder output 124. If, for example, all of the input values are equal to a logical “1,” the decoder 16 asserts the hexadecimal value “7” on the output 124, and if all of the inputs are equal to a logical “0,” the decoder 16 asserts the hexadecimal value “0” on the output 124. If a portion of the input values are equal to a logical “1” and a portion are equal to a logical “0,” the decoder 16 asserts a hexadecimal value between “1” and “6,” inclusive, on the output 124.
The capture memory element 18 receives the time of arrival adjustment value from the decoder 16 and stores the value upon assertion of the SYNC_1 input 126. The SYNC_1 input 126 receives the first synchronization signal from the detection circuit 26 that is asserted a pre-determined time after the detection circuit 26 detects a rising edge to enable the capture memory element 18 to store the time of arrival adjustment value generated by the decoder 16. In the illustrated embodiment, the time of arrival adjustment value is present on the output 124 of the decoder 16 four clock cycles after a rising edge is detected by the detection circuit 26 because it takes that long for the N and N+1 sample values to move through the intermediate value calculator 12, comparator 14, and decoder 16.
The hold memory element 20 receives and stores the time of arrival adjustment value from the capture memory element 18 upon assertion of the SYNC_2 input 128. The SYNC_2 input 128 receives the second synchronization signal from the detection circuit 26 and is asserted when the detection circuit 26 detects a falling edge of the signal to enable the hold memory element 20 to capture the time of arrival adjustment value. The capture memory element 18 thus holds the time of arrival adjustment value corresponding to a rising edge from a first falling edge after the rising edge to a subsequent falling edge of the signal, i.e., from a trailing edge of a first signal pulse to a trailing edge of a second signal pulse.
This value is communicated to the signal processing circuitry 28, which includes a time of arrival adjuster 130. The time of arrival adjuster 130 is operable to determine the high-resolution time of arrival by adjusting the low-resolution time of arrival according to the time of arrival adjustment value generated by the interpolation circuit.
While the interpolation circuit 10 has been described herein as generating a time of arrival adjustment value corresponding to a rising edge of the signal, the circuit 10 may also be used to determine other signal events as well. The circuit 10 may be used, for example, to generate a time of arrival adjustment value corresponding to a falling edge of the signal without modifying the circuit 10 as illustrated and described. If the circuit 10 is used to generate a time of arrival adjustment value corresponding to a falling edge, however, the outputs 100 through 112 of the third stage 68 of the intermediate value calculator 12 would be reversed such that the one-eighth point output 100 would actually hold the seven-eighths point value, the one-fourth point output 102 would actually hold the three-fourths point value, and so forth. Thus, the decoder circuit 16 would need to be programmed accordingly. Furthermore, the interpolation circuit 10 is not limited to use with RF signals, but may be used with signals of a virtually any frequency communicated through virtually any medium.
Number | Name | Date | Kind |
---|---|---|---|
3754236 | Dotson, Jr. | Aug 1973 | A |
4586005 | Crawford | Apr 1986 | A |
5075880 | Moses et al. | Dec 1991 | A |
5815419 | Fujitomi et al. | Sep 1998 | A |
5987392 | Tucker et al. | Nov 1999 | A |
6687315 | Keevill et al. | Feb 2004 | B2 |
6763072 | Matsui et al. | Jul 2004 | B1 |