The present invention relates generally to a signal conditioning topology which is consistent with a methodology for converting multiple types of inputs including AC sensor signals to equivalent engineering units.
Although this invention is not limited to LVDTs or resolvers, these sensors will be used as examples to describe the operation and some of the benefits of the present invention. LVDTs and resolvers each generate a pair of AC sensor signals that together indicate position and/or angle. These AC sensor signals must be converted to their equivalent engineering units. Signal conditioning methods include separate anti-aliasing filter and demodulators for each of the AC sensor signals. This increases the cost, size and power consumption of the circuit. Additionally, signal condition methods include multiple signals that are not sampled simultaneously due to being fed through a common multiplexer, introducing a time skew error into the signal processing. For applications where AC sensors require multiple signals to compute position such as LVDTs and resolvers and the position may change rapidly, it is advantageous to have an efficient, cost effective means to sample the sensor's signal outputs within the same time-frame such that position slewing errors are eliminated.
A signal convertor includes a first sensor configured to generate a first signal and a second signal and first and second multiplexers configured receive the first and second signals, respectively, and generate samples. The signal convertor also includes an analog-to-digital (A/D) convertor configured to convert the samples and a processor configured to multiply the samples by a sine vector and by a cosine vector and determine a magnitude of the first and second signals based upon the product of the samples and the sine vector and the product of the samples and the cosine vector.
A method for converting a signal includes the steps of a) providing first and second signals from a sensor to first and second multiplexers, respectively, b) multiplying samples from the first and second multiplexers by a sine vector, c) multiplying samples from the first and second multiplexers by a cosine vector, d) determining the magnitude of the first and second signals based upon steps b) and c), and e) determining a mechanical angle of the first and second signals based upon steps b) and c).
Other advantages of the present invention will be readily appreciated as the same becomes better understood by reference to the following detailed description when considered in connection with the accompanying drawings wherein:
A signal conditioner 10 for a plurality of input signals from a plurality of sensors 12, 14, 16 is shown in
A plurality of first tier multiplexers 20a-e each group a plurality of input signals into a shared antialiasing filter 22a-e. The plurality of input signals for any given first tier multiplexer 20a-e is preferably sufficiently similar such that a single antialiasing filter 22a-e can be used. For multiple AC input signals from a single sensor, for example five-wire LVDTs 12 (E1 and E2) and resolvers 14 (A sine β and A cosine β windings), signals from the same sensor are fed through separate first tier multiplexers 20a, 20b and antialiasing filters 22a, 22b, respectively. This is done so that the signals E1 and E2 or A sine β (“sin”) and A cosine β (“cos”) can be sampled nearly simultaneously to eliminate any error introduced by a time skew when the LDVTs 12 or resolvers 14 positions' are changing. Sampling E1 and E2 (or resolver signals) nearly simultaneously promotes concurrent settling of multiplexers 20a and 20b and antialiasing filters 22a and 22b and a digital filter (if used) since the LVDT 12 (or resolver 14 signals) E1 and E2 signals are nearly in phase. The concurrent settling of the two E1 and E2 (or resolver 14 signals) paths optimizes the overall settling time and improves conversion throughput. The effect of sampling E1 and E2 (or resolver 14 signals) within the same timeframe is also beneficial for periodic amplitude variation or noise that is present on both E1 and E2 especially if introduced as a result of the LVDT 12 (or resolver 14) AC excitation source.
To correct for any error introduced by the use of separate multiplexers 20a, 20b and filters 22a, 22b, a common AC gain signal (AC_GAIN 1 and AC_GAIN 2) is used to “gain compensate” each signal path. The AC gain signals are driven from LVDT 12 or resolver 14 AC excitation.
The number of sensors that can share a single first tier multiplexer 20a-e depends on the throughput requirement for the sensors and their respective conversion times. For LVDTs 12, for example, if the desired update rate was 10 msec and conversion takes 1 msec for E1 or E2, then five LVDTs 12 could be grouped into a common antialiasing filter 22a-e. However, if gain and test inputs are used as shown, then four LVDTs 12 could be grouped.
The second tier multiplexer 26 selects its inputs from the outputs of the first tier multiplexers 20a-e. The output of the second tier multiplexer 26 feeds a sample and hold circuit 28. The output of the sample and hold circuit 28 is digitized by a high speed A/D converter 30. For example, the A/D converter 30 could provide a fourteen bit digitized output in two microseconds (500 kHz). The number of first tier multiplexers 20a-e (and/or optionally direct inputs from a single sensor and antialiasing filter) that can be handled by the second tier multiplexer 26 during the dwell time of the first tier multiplexers 20a-e, is dependant on the second tier multiplexer 26 settling time and the A/D converter 30 update rate. For example, if the first tier multiplexer 20 dwell time is 1 msec, the second tier multiplexer 26 settling time is 2 microseconds, and the conversion rate is 500 kHz, 250 conversions could be done. However, this does not necessarily mean that 250 signals can be converted each millisecond, since subsequent digital filtering of the A/D converter 30 output typically requires from 8 to 36 samples of input data. This reduces the signals converted per msec to be between 6 to 32 signals.
The A/D converter 30 output is provided to the controller, which in the example shown is a DSP 32. The controller could also be a gate array, general-purpose processor, etc. Software in the DSP 32 provides the digital filtering as well as the EUC conversion. Some of the details of this digital processing will be discussed in more detail below.
The AC sensors (LVDTs 12, resolvers 14 and other sensors 16) and the sample and hold circuit 28 are preferably all synchronously operated by the same sine wave generator 40 (or other clock). More specifically, the sampling frequency is preferably an integer multiple of the frequency of the AC sensors. As will be described later, opting to sample each of the AC input signals at a frequency that is twelve times the frequency of the AC input signals simplifies some calculations, and is therefore advantageous, although not required.
Assuming the A/D converter 30 is capable of converting at a 500 kHz rate, and the second tier multiplexer settling time is 2 microseconds, six input signals could be concurrently sampled in the 27.7 microseconds. The dwell time on the first tier multiplexer 20a-e is dependent on the signal type antialiasing filter 22a-e settling time, and the digital filtering required. For example, for AC signals the filter settling time is approximately 0.165 msec, and a minimum of 12 samples of the signal are required for one complete cycle of the input wave. This makes the minimum dwell time 0.5 msec. Addition of recommended digital low pass filters increases this number of samples to typically 30, making the dwell time 1 millisecond. Using the above numbers six simultaneous waves could be converted every 0.5 milliseconds or every 1 millisecond, without and with digital filtering respectively. Assuming the average update rate required for the AC signals was 10 msec, 120 or 60 (without and with digital filtering respectively) AC signals could be converted at this average rate by one A/D converter 30. In the example illustrated in
As mentioned above the settling time for each first tier multiplexer 20a-e and its associated antialiasing filter 22a-e must be accommodated before usable samples are obtained. This delay is to allow steady state conditions to be achieved before samples that will be used are taken. The delay is determined by the multiplexer delay and the antialiasing filter 22a-e settling time constant. The amount of filtering required is dependent on the expected magnitude of any potential input frequency which might alias a signal frequency within the signal conditioner pass band. The usable samples (in this example, twelve to thirty) of the AC input signal are then processed to determine the magnitude (and phase for four quadrant resolvers 14) of the AC input signal.
It will become clear in future discussions that the signal processing algorithm for the AC signals, implemented by the DSP 32 produces a bandpass filter centered around the frequency of the AC input signals. Depending upon the frequency of the input signal and the sample rate, an alias signal could be produced that is within the pass band of the bandpass filter. The antialiasing filters 22a-e are chosen to eliminate (or substantially reduce) the magnitude of input signals that could produce this aliased signal. The signal at 11X the excitation frequency is typically the worst case since it will produce an aliased signal precisely at 3 kHz. Higher frequency signal (e.g. 13x) can also produce beat notes. However, since an antialiasing filter is characteristically implemented by using a multiple pole low pass filter; if it is designed to adequately attenuate the lowest frequency that could produce an aliased signal, the filter will also take care of other higher frequency signals that could produce an undesired aliased signal. The specific antialiasing filter requirements would be based upon the magnitude of the potential aliased signal in a particular application, and the errors permitted for the signal conditioner.
The antialiasing filters 22a-e provide a settling time that reduces the throughput of the signal conditioner 10, as has been described above, since the A/D converter 30 will not produce valid data until steady state has been reached. This effect can be mitigated if the throughput loss becomes significant by adjusting the timing of the first tier multiplexer 20 so that the second tier multiplexer 26 is sampling a different antialiasing filter 22a-e which has already settled while the antialiasing filter 22a-e in question is settling.
After the stabilized samples are collected, digital processing is performed. Two cases will be considered. The first case is where there is no requirement for digital low pass filtering. In this case the digitized AC input signal (e.g. the twelve post-settling samples) is sine wave synchronously demodulated by the DSP 32. This is done by multiplying the sampled input vector by the value of the sine and cosine vectors (at 30-degree increments) for one complete cycle. The sine and cosine synchronous demodulation allows even as well as odd harmonics to be eliminated in the processed digital signal. The output of the sine (and cosine) synchronous demodulator is summed to produce an output which is six times the peak sine wave input. (This is because the synchronous demodulation process produces an output that is ½ the input peak magnitude, and twelve samples are taken). Note both a sine and a cosine synchronous demodulation process is provided so that phase shift errors due to timing skew of the sampler and the sampled signal will not cause conversion errors. The resultant sine and cosine components are vector summed by the DSP 32 to produce the magnitude of the input wave. The update rate of this calculation is only 1/12 the input A/D rates however, so the DSP 32 burden is thereby reduced.
An example calculation is illustrated in
Choosing twelve samples per cycle simplifies the sine and cosine multiplication. All of the multiplication can be accomplished by binary shifts or are zero, except the sin 60 (120, 240, 300) or the cos of 30 (150, 210, 330) which equal SQRT3/2. This can be accurately approximated with shift and add operations, thereby eliminating the need for an ALU to provide the desired mathematical operations. Alternatively, the mathematical operations could be provided in an ALU or otherwise in the controller.
To better understand the mathematics behind this algorithm, the following general equations are provided:
A sin(f(t))sin(ωt)=A(½ cos(f(t)−ωt)−½ cos(f(t)+ωt)) (1)
A sin(f(t))cos(ωt)=A(½ sin(f(t)−ωt)+½ sin(f(t)+ω)) (2)
Where f(t)=LVDT or Resolver input voltage
As can be seen, the multiplication yields sum and difference frequency outputs.
Evaluating the simplistic case where 2π*f(t) and cot are identical, except for a phase shift (α) between the two, the above equations yield time invariant resolved outputs of the input magnitude A plus a sum frequency component.
A sin(f(t)+α)sin(ωt)=A(½ cos(α)−½ cos(f(t)+ωt)+α) (1)
A sin(f(t)+α)cos(ωt)=A(½ sin(α)+½ sin(f(t)+ωt)+α) (2)
The sine and cosine products are a function of the electrical phase relationship α between the LVDT 12 excitation and the E1 or E2 outputs. The sum frequency is removed by averaging the sampled outputs over precisely one period of the input signal for the non digitally filtered case as illustrated in
The characteristic Equation of the EUC conversion for a five wire LVDT is as follows:
Position=(LVDT Gain)*{(E1−E2)/(E1+E2)}+LVDT Bias
As can be seen by the above equations, interface gain errors and LVDT excitation magnitude variations would cancel. (This fact allows small errors in antialiasing filter gain due to non-perfect settling to cancel as well, as has been mentioned previously).
The same analysis described above with respect to
A four-quadrant resolver 14 can also be converted. A single quadrant conversion is a subset of this logic, and is not covered in any detail. The algorithm for determining the magnitude of the A sin β or A cosine β, (where β is the resolver angle) windings is virtually identical to that logic used for calculating E1 and E2 for the LVDTs 12, with one exception. The A sin β or A cos β outputs must be properly signed, since the arctan function that is used to convert the ratio A sin β/A cos β to the angle β angle repeats itself over 360 degrees of travel This sign determining logic is as follows:
Sin component*A sin β=Sum(sin product 1 to 12)/6
Cos component*A sin β=Sum(cos product 1 to 12)/6
If Sin component*sin β>0,sign of A sin β=+,else sign of A sin β=−Magnitude Sin β=SQRT((Sin component A sin β)2+(Cos component A sin β)2)Cos ω conversion is done in a similar manner.
This logic requires some rough time synchronization to be done in the starting point of the sine cosine table, and the excitation zero crossing. As phase shift occurs with imperfect time synchronization, the sensitivity of the sine component starts to diminish; however the zero crossing point is still maintained.
When LVDT 12 E1 and E2 are computed as discussed above with respect to
Compensated E2=E2*(AC_GAIN1/AC_GAIN2)
Where AC_GAIN1 and AC_GAIN2 are vector magnitudes calculated as was described above
The vector magnitude of E1 can remain uncompensated since E2 is effectively normalized to the E1 gain path. The same gain compensation can be applied to an A cos β signal from a resolver 14. Again, the A sin β does not need to be compensated since the A cos β signal path is effectively normalized to the A sin β path.
The final LVDT 12 or resolver 14 position calculation described above is performed using the gain-compensated values. For example, the LVDT 12 position is calculated as:
Position=(LVDT Gain)*{(E1−Compensated E2)/(E1+Compensated E2)}+LVDT Bias
Where LVDT Gain and LVDT Bias terms are LVDT characteristics provided by the manufacturer, and E1 and E2 are determined as was described above. Similarly, the final resolver EUC position calculation is performed using the A sin β signal and the compensated A cos β signal.
In one example, the AC gain signs are range-checked against their expected ranges in consideration of all component variables as an additional built-in test.
The EUC calculations as well as the octant logic are detailed in
The case of the AC conversion of E1 or E2 (or A sin 13 and A cos (3 for the resolver case) using digital filtering will next be considered. The flow chart and time domain responses will first be presented for comparison with the AC conversion without digital filtering. A comparison of the two cases will then be made in the frequency domain to illustrate the improvement in noise immunity afforded by the addition of the digital filter.
The low pass filter 22 (
The frequency response comparison for the AC conditioner, both with and without a digital filter, is illustrated in
A test signal is required, however, to verify the proper performance of the antialiasing filter for the AC conditioner. Assume the antialiasing filter is a 3-pole LP filter at 7 kHz. To properly test the attenuation characteristics of this filter, assume the test signal for the filter is set at 4 times the LVDT excitation frequency, or 12 kHz. The antialiasing filter defined should attenuate this test signal by approximately a factor of 5. However, if the digital processing of the AC conditioner were to remain unchanged, the interface would attenuate the test signal in this frequency range (see
Other filtering techniques such as a slew rate filter on the output can be effective in bounding the excursions of wild points. Basically the output is constrained to move only as much as the maximum slew rate of the devise would allow it to move. This type of filter is most effective when the sampling rate is high compared to the maximum slew rate, so that the maximum travel is constrained to a small value each dt.
Signal processing of DC (baseband) signals such as illustrated by 16 in
In accordance with the provisions of the patent statutes and jurisprudence, exemplary configurations described above are considered to represent a preferred embodiment of the invention. However, it should be noted that the invention can be practiced otherwise than as specifically illustrated and described without departing from its spirit or scope.
Number | Name | Date | Kind |
---|---|---|---|
3516084 | Sacks et al. | Jun 1970 | A |
3829854 | Brand et al. | Aug 1974 | A |
3976869 | Stella et al. | Aug 1976 | A |
4062005 | Freed et al. | Dec 1977 | A |
4099245 | Maysonett | Jul 1978 | A |
4542336 | Powell | Sep 1985 | A |
4594540 | Currie et al. | Jun 1986 | A |
4651130 | Pennell | Mar 1987 | A |
4652821 | Kreft | Mar 1987 | A |
4656585 | Stephenson | Apr 1987 | A |
5134397 | Eyerly et al. | Jul 1992 | A |
5134404 | Peterson | Jul 1992 | A |
5168222 | Volsin et al. | Dec 1992 | A |
5180932 | Bengel | Jan 1993 | A |
5241268 | Lee | Aug 1993 | A |
5260650 | Schwesig et al. | Nov 1993 | A |
5463393 | Havlicsek | Oct 1995 | A |
5600576 | Broadwater et al. | Feb 1997 | A |
6014022 | Demma et al. | Jan 2000 | A |
6084376 | Piedl et al. | Jul 2000 | A |
6331759 | Atmur | Dec 2001 | B1 |
6697006 | McCartney et al. | Feb 2004 | B1 |
7149654 | Ramsdale et al. | Dec 2006 | B2 |
7400283 | Zhu | Jul 2008 | B1 |
7403580 | Ishii et al. | Jul 2008 | B2 |
7432836 | Games | Oct 2008 | B2 |
7663520 | Sugihara et al. | Feb 2010 | B2 |
7667631 | Zhu | Feb 2010 | B1 |
7817070 | Games | Oct 2010 | B2 |
20030233954 | Frank et al. | Dec 2003 | A1 |
20040027118 | Lenz et al. | Feb 2004 | A1 |
20040027263 | Pailleur et al. | Feb 2004 | A1 |
20080316079 | Games | Dec 2008 | A1 |
Number | Date | Country |
---|---|---|
6338798 | Dec 1994 | JP |
2000037031 | Feb 2000 | JP |
200660721 | Mar 2006 | JP |
8503586 | Aug 1985 | WO |
Entry |
---|
European Search Report for European Application No. 15171660.2 completed Nov. 9, 2015. |
Number | Date | Country | |
---|---|---|---|
20150365099 A1 | Dec 2015 | US |