The present invention relates to trigger circuits for triggering, for example, test and measurement instruments to acquire data from an input signal, and relates more particularly to a noise rejection filter for a trigger circuit that provides improved noise rejection for more accurate triggering.
U.S. Pat. No. 7,072,804, issued Jul. 4, 2006 to Dennis J. Weller and entitled “Digital Trigger Filter for a Real Time Digital Oscilloscope”, describes a digital trigger circuit that includes a digital trigger filter which generates high frequency rejection, low frequency rejection, AC and DC trigger signals. The digital trigger filter uses two Infinite Impulse Response (IIR) filters with taps that provide the trigger signal outputs needed for high and low frequency rejection in response to a digitized input signal. The AC trigger signal is produced by subtracting the output of the second IIR filter from the digitized input signal, and the DC trigger signal is simply the digitized input signal. A multiplexer selects one of the trigger signals for input to a digital trigger comparator that uses two levels for comparison with the selected trigger signal, the difference (ΔV) between the two levels representing hysteresis. The comparison results are processed by a state machine that determines whether a trigger event has occurred. Unfortunately a digital comparator with hysteresis waits until the input trigger signal has passed above or below both levels (depending upon whether triggering is on the rising or falling edge of a signal) so that it doesn't mistakenly trigger on noise. When the state machine is set up for pulse width triggering, this may result in an error since the measured width from the above the high level to below the low level may not accurately reflect the pulse width at a desired trigger level. Also, when using a traditional comparator with hysteresis, rising edge triggers stop occurring when the trigger level is near the minimum peak value for the digitized input signal, and falling edge triggers stop occurring when the trigger level is near the maximum peak value for the digitized input signal.
An article by W. Van Driessche and C. Gullentops in the Review of Scientific Instruments, Vol. 46, No. 12, December 1975, pgs. 1659-1661 entitled “Digital Trigger Circuit with Excellent Noise Suppression” uses a pseudo filter to process a digitized input signal. The output from the pseudo filter is compared with each new sample of the digitized input signal. If the difference between the input and output of the pseudo filter is less than or equal to a hysteresis amount (ΔV), the output register of the pseudo filter is left unaltered. However if the difference is larger than ΔV, the output is set to a new value equal to the input signal minus ΔV for increasing signals or plus ΔV for decreasing signals. The output from the pseudo filter is compared with a selected trigger level by a digital comparator. The output of the digital comparator is passed through a slope control circuit before being applied to a trigger multivibrator to generate the trigger signal on the desired slope of the input signal. A disadvantage of the Driessche et al noise suppression system is that it knocks the peaks off of the digitized input signal, which causes triggering to stop when the trigger level is near either the minimum or maximum peak value for the digitized input signal.
Therefore what is desired is a trigger system with noise rejection that provides a more accurate representation of the input signal for triggering while providing a more accurate representation of pulse width at a desired trigger level.
Accordingly, the present invention provides a noise rejection filter for a digital trigger circuit, useful in a test and measurement instrument, that provides high and low frequency rejection while preserving signal pulse width at a desired trigger level and preserving triggering at signal peaks. Whether implemented by processing samples of an input sampled signal serially or in groups of samples for higher speed applications, the algorithm for the noise rejection filter compares each sample with the filter output to determine (i) whether there is a change in slope direction and (ii) whether the difference between the sample and the filter output is greater than a hysteresis value. If there is no change in slope, the sample value replaces the filter output value as the new filter output. If there is a change in slope, but the difference is less than or equal to the hysteresis value, the filter output remains unchanged. If there is a change in slope and the difference is greater than the hysteresis value, then the slope direction is changed while the filter output is updated by the sample value. In a trigger circuit the input sampled signal is selected from different filtered versions of a sampled signal. The selected signal is filtered by the noise rejection filter to produce a filtered trigger signal. The filtered trigger signal is then input to a comparator for comparison with a desired trigger level to generate a trigger output.
The objects, advantages and other novel features of the present invention are apparent from the following detailed description when read in conjunction with the appended claims and attached drawing.
Referring now to
The algorithm for the noise rejection filter 20, as shown by the state diagram of
Likewise for a falling signal if the input is less than or equal to the previous output, then the output is set to the new value. If the input is greater than the output but the difference is less than or equal to the hysteresis value, then the output of the filter 20 is left unaltered. If the input is greater than the output by greater than the hysteresis value, then the output of the filter 20 is set to the new value and the direction of the signal is considered to have changed to rising.
A simple hardware implementation of the state diagram of
Note that the above simple circuit for the noise rejection filter 20 requires two subtracts per new data point. The first subtract (21) determines the direction of the signal and the magnitude of the change, and the second subtract (23) determines whether the magnitude of the change exceeds the hysteresis value. However for high speed digital trigger circuits, multiple data points are acquired in parallel for each clock cycle. For example if there are eight sequential data points per clock cycle, then to perform the serial process described for
First, find all possible filter results for data7. If data7 is more than the hysteresis value away from data6, no further processing looking back is required. In fact if there is a large direction change (at least equal to the hysteresis value) anywhere within data0-data7, dataP does not need to be considered. However if all of the data points data0-data7 are within the hysteresis value of each other as shown, then the value and slope of dataP are required. If all the data points are within the hysteresis value of dataP, then the previous slope is maintained. For a rising slope the output of the filter 20 for the present clock cycle is max(dataP, data 0, . . . , data7). The max of data0 through data7 may be precomputed and is shown as the value H (in this example determined by data6). Therefore if all of the data points are within the hysteresis value apart, the result of the filter is max(dataP,H). Likewise for the falling slope the output of the filter is min(dataP, data0, . . . , data7) or min(dataP, L), where L in this example is determined by data3.
Although all of the data points within the clock cycle may be within the hysteresis value of each other, some of them may be more than the hysteresis value away from dataP. For example if the value of dataP is above the data points shown, has a rising slope and is more than the hysteresis value from data3, then data0, data1 and data2 will be held at the dataP level. However data3-data7 follow the falling slope line since data3 is a change in direction from dataP to a falling slope.
To implement this design, either in hardware or in software using a data processor, the problem is broken into two parts. The first part of the filter circuit 20 figures out, or pre-computes, all possible answers for each point within the group of eight samples to determine a maximum value, H, a minimum value L, and identifies all differences between samples within the group that are at least equal to the hysteresis value. Referring now to
The second part of the filter circuit 20 selects which output to use for all non-“locked” points, i.e., the earlier points in the group before the direction change. The outputs are determined from the value and slope of dataP. The waveform slope is determined for each point—equal to the previous slope unless one of the earlier points in this clock cycle is more than the hysteresis value away from dataP. Once the direction of the slope is determined, the output from the filter circuit 20 is the maximum of dataP and the local high (H) for rising slopes, or the minimum of dataP and the local low (L) for falling slopes. For illustration in
Thus, the present invention provides a noise rejection filter that may be used in a trigger circuit which preserves the peaks of the input sampled signal as well as the pulse width at a desired trigger level by monotonically changing the value of the filter output for each sample point so long as the value is changing in the same direction as the current signal slope, preserving the value for each sample point as long as any difference between the filter output and the new sample value in the opposite direction is less than or equal to the hysteresis value, and changing the slope when the difference between the filter output and the new sample value in the opposite direction is greater than the hysteresis value while updating the output from the filter with the new sample value.
The present non-provisional application claims the filing date of provisional U.S. Patent Application Ser. No. 60/835,276 filed Aug. 2, 2006, which provisional application is hereby explicitly abandoned.
Number | Name | Date | Kind |
---|---|---|---|
4823076 | Haines et al. | Apr 1989 | A |
4888588 | Castagnozzi | Dec 1989 | A |
5184062 | Ladwig | Feb 1993 | A |
5375067 | Berchin | Dec 1994 | A |
5414635 | Ohta | May 1995 | A |
5438531 | Shank | Aug 1995 | A |
5930745 | Swift | Jul 1999 | A |
5978742 | Pickerd | Nov 1999 | A |
6279130 | Moser | Aug 2001 | B1 |
6615148 | Pickerd | Sep 2003 | B2 |
6621913 | de Vries | Sep 2003 | B1 |
6753677 | Weller et al. | Jun 2004 | B1 |
6760673 | Genther et al. | Jul 2004 | B2 |
6892150 | Pickerd | May 2005 | B2 |
6915218 | Pickerd | Jul 2005 | B2 |
6970118 | Regier | Nov 2005 | B2 |
7034517 | Newcombe | Apr 2006 | B2 |
7072785 | De Lacy et al. | Jul 2006 | B2 |
7072804 | Weller | Jul 2006 | B2 |
7110898 | Montijo et al. | Sep 2006 | B2 |
7191079 | Smith et al. | Mar 2007 | B2 |
7219037 | Pupalaikis et al. | May 2007 | B2 |
20020171408 | Hansen | Nov 2002 | A1 |
20040119620 | Tran et al. | Jun 2004 | A1 |
20040236527 | Felps | Nov 2004 | A1 |
20050246113 | Montijo | Nov 2005 | A1 |
20060015862 | Odom et al. | Jan 2006 | A1 |
Number | Date | Country |
---|---|---|
2224869 | May 1990 | GB |
Number | Date | Country | |
---|---|---|---|
20080177508 A1 | Jul 2008 | US |
Number | Date | Country | |
---|---|---|---|
60835276 | Aug 2006 | US |