The present invention relates generally to angle sensors, and in particular to fast and accurate non-contacting bi-axial angle sensors.
Many applications require fast and accurate measurement of a relative angular orientation between two points. For these and other applications, angle sensors have been developed. Certain sensors require mechanical or other physical contact between the two bodies whose relative orientation is being studied. However, these types of sensors are undesirable in applications where complete freedom of movement between the two bodies is required.
Accordingly, it would be desirable if a non-contacting angle sensor could be developed that is both accurate and fast.
The present invention provides a fast and accurate non-contacting angle sensor. According to one aspect of the invention, the angular orientation of an inner payload relative to an outer structure is monitored with a 2 axis optical angle sensor for azimuth and elevation angles. The sensor operates on the same principle as an autocollimator, thus it measures both azimuth and elevation angles simultaneously. An object pattern affixed to the outer structure comprising an aharmonic variation of intensities, and which does not repeat over the full measurement range, is illuminated, reflected off the inner payload and analyzed to determine the angular orientation. The angle sensor measurements are extremely accurate for the angles (e.g. azimuth and elevation) of interest, while highly immune to translation in three axes, as well as roll angle between the inner payload and the outer structure.
These and other aspects and features of the present invention will become apparent to those ordinarily skilled in the art upon review of the following description of specific embodiments of the invention in conjunction with the accompanying figures, wherein:
The present invention will now be described in detail with reference to the drawings, which are provided as illustrative examples of the invention so as to enable those skilled in the art to practice the invention. Notably, the figures and examples below are not meant to limit the scope of the present invention to a single embodiment, but other embodiments are possible by way of interchange of some or all of the described or illustrated elements. Moreover, where certain elements of the present invention can be partially or fully implemented using known components, only those portions of such known components that are necessary for an understanding of the present invention will be described, and detailed descriptions of other portions of such known components will be omitted so as not to obscure the invention. In the present specification, an embodiment showing a singular component should not necessarily be limited to that embodiment but should encompass other embodiments including a plurality of the same component, and vice-versa, unless explicitly stated otherwise herein. Moreover, applicants do not intend for any term in the specification or claims to be ascribed an uncommon or special meaning unless explicitly set forth as such. Further, the present invention encompasses present and future known equivalents to the known components referred to herein by way of illustration.
As shown in
As further illustrated in the side view of
As shown in
It should be noted that outer portion 114 preferably includes computing means, such as a microprocessor and associated program and data memory (not shown), that performs angle calculations on data collected by detection camera 210 in a manner that will be described in more detail below. It should be further noted that angle sensor 110 may further include focusing and alignment means so as to focus and align the light beam throughout the optical path. The provision and arrangement of such focusing and alignment means will become apparent to those skilled in the art after being taught by the present disclosure.
Light source 202 is disposed to back-illuminate spatial filter 204, and is a diffuse source formed by a pulsed LED array 212 and a diffuser 214. In one example of the invention, LED array 212 is driven with a 1 μs pulse for a fast exposure time and is synchronized to the sampling of various outer structure sensors to allow calculation of the instantaneous angle of the inner payload relative to the outer structure mounting points. As a further preferred example, the LED array 212 is pulsed at a 60 Hz rate allowing angle updates at 60 Hz.
Although various arrangements of array 212 may be possible, such as a uniform distribution of light across the length and width of diffuser 214, accuracy, linearity, and noise may be improved by adjusting the intensity distribution of the light source and/or the spatial filter pattern to compensate for intensity variation due to light vignetted by the optics which is a function of the angle measured. Thus the periphery of the object filter 204 could be illuminated with greater intensity than the center. Alternately, this intensity variation could be incorporated in the spatial filter pattern design.
Spatial filter 204 is comprised of a 11 mm by 11 mm glass substrate and a chrome pattern forming an object on the surface of the substrate. As will be explained in more detail below, a preferred example of the spatial filter object pattern is comprised of 0.4 μm feature sizes having a sinusoidal variation in density along two orthogonal axes. The spatial filter object pattern provided on the surface of spatial filter 204 is positioned at the focal plane of collimator 206. Light filtered by the object is passed through beam-splitter 208. The deflected portion is not desired and is discarded by an absorber, while the desired, un-deflected, portion is collimated by collimator 206, which is in one example a 25 mm aperture converging lens.
The collimated light is directed toward mirror 220 mounted to the inner payload 102 which reflects the collimated light, returning it to the converging lens 206. The collimating lens 206 and mirror 220 are proximally located within a distance D so as to preferably allow a detectable level, such as 10%, of light to still be captured at the extremes of the useful angular range.
More particularly, as further shown in
Referring back to
A particular sub-set of the two-dimensional object produced by spatial filter 204 appears as a light pattern having approximately the same size and corresponding variations of light intensity as the spatial filter pattern at camera 210. Any angular displacement of inner payload 102 with respect to the outer structure 104 will cause mirror 220 to be identically displaced, and the image reflected back on camera 210 will be correspondingly displaced.
More particularly, as shown in
The present invention can be implemented with a variety of spatial filter patterns that selectively attenuate the illuminating light to form a high resolution object. Many possible patterns can be used to create an intensity variation spatial waveform along one or more axes of interest. In addition to orthogonal Cartesian coordinates, the spatial filter may be described in other coordinates such as polar coordinates, or more complex mapping approaches. In some applications, more than two axes might be used, such as three axes separated by 60 degree offsets, to match the axes of movement being measured, or to provide redundant information which increases robustness. The patterns on individual axes may be combined by multiplication to create the final spatial filter pattern.
An example spatial filter pattern for use with spatial filter 204 is further described below in connection with
As shown in
I(x,y)=[Ax SIN(2π·f1x)+Bx SIN(2π·f2x)]·[Ay SIN(2π·f1y)+By SIN(2π·f2y)]
where I(x,y) is the transmissibility of the spatial filter at coordinates x and y.
The amplitude parameters Ax, Bx, Ay, and By are chosen to optimize the systematic error (interference between components) and the random error (signal to noise ratio) of each spectral component. Simulations suggest that equal amplitudes are preferred.
The frequency f1 and the frequency f2 are chosen to trade off measurement resolution verses immunity to noise variations, which might cause large measurement errors. This tradeoff can be determined through numerical simulation. In accordance with an aspect of the present invention, the waveform chosen in the preferred embodiment uses f1 and f2 with significant separation (i.e. varying from each other by several factors), and also are not harmonics of each other, resulting in an “aharmonic” overall variation of intensities. The individual components of the pattern are illustrated in
In the preferred embodiment the spatial filter intensity variation is described in the x-axis by:
I(x)=0.25 SIN(2π·5.7x)+0.25 SIN(2π·23x)+0.5
And in the y-axis by:
I(y)=0.25 SIN(2π·5.7y)+0.25 SIN(2π·23y)+0.5
The spatial filter intensity variation at any coordinate (x,y) is thus described by:
I(x,y)=I(x)·I(y)=[0.25 SIN(2π·5.7x)+0.25 SIN(2π·23x)+0.5]·[0.25 SIN(2π·5.7y)+0.25 SIN(2π·23y)+0.5]
Where the parameters x and y are in units of one field of view at the detector or image.
More particularly, in one example, the length and width of spatial filter 204 are chosen such that the pattern includes 138 cycles of the high frequency sinusoid (i.e. x & y range from 0 to 6). Accordingly, in this embodiment, the full spatial filter size is dimensioned to cover 6 views of the pattern, whereas the measurement range only covers 5 views. For example, when the camera sees the negative extreme, it is viewing the spatial filter from −3 to −2 views and indicates the center of this, −2.5 views, as the extreme negative angle (−3 degrees). At the positive extreme, it is viewing the spatial filter from +2 to +3 views and indicates the center of this, +2.5 views, as the extreme positive angle (+3 degrees). Thus the spatial filter needs to be 6 views wide to achieve a measurement range that is 5 views, or 115 cycles of the high frequency component, wide. In general, therefore, the spatial filter size is preferably one view larger than the measurement range, unless one is willing to sacrifice accuracy near the extremes.
Continuing with this example, the 115 cycles of the high frequency component occur across the measurement range of 5 views wide. This is less than the least common multiple of the high and low frequencies (i.e. 131.1 cycles of the high frequency component), thus ensuring that the pattern does not repeat itself and further preventing measurement ambiguities, which is an aspect of the invention, and will be discussed in more detail below. In one example of the invention using a 0.4 μm process, this yields an image pattern that is 8960 μm by 8960 μm across the measurement range, and thus more than 10752 μm by 10752 μm for the size of spatial filter 204. Further, in this example, the linear patterns of dots 404 in
A large variety of fabrication processes could be used to fabricate the spatial filter. Photographic methods could be used to produce a filter on an ordinary photographic slide, glass plate, or print. In a preferred embodiment, the type of photolithography process that is conventionally used for fabricating integrated circuit masks is used to produce a spatial filter comprised of chrome deposited on a glass substrate. This provides an accurate, stable substrate capable of operation over wide temperature ranges.
Feature size requirements at the spatial filter are preferably related to the pixel size of the detector, the magnification of the optics, and the number of bits of intensity resolution desired. For a detector pixel size of 7 μm, a magnification of 1, and 8 bits of intensity resolution, a feature size of 7 μm/16=0.44 μm allows an array of 16×16 features to adjust the intensity of the spatial filter pattern as detected by a single pixel. Using this method we approximate that features either pass light or block light in proportion to the area of the features, ignoring diffraction effects. Thus, a 16×16 array allows 256 intensities, or 8 bits of intensity resolution.
When illuminating the spatial filter with light at 500 nm wavelength, using a collimator focal length of 42 mm, and an aperture size of 25 mm, the Rayleigh criteria for the minimum resolvable feature size, d, is given by:
d=2.44λf/D=2.44(500 nm)(42 mm)/(25 mm)=2 μm
In this preferred example, accordingly, the 0.44 μm features in the spatial filter will not be resolved by the 2 μm spot size produced at the detector, and so variation in spatial filter features primarily affect the intensity detected without any significant pattern related effects.
Since the intensity is determined by the number of features present or omitted on the spatial filter, there are many possibilities for choosing the placement of which features in a 16×16 array are present or omitted to achieve a particular intensity. A preferred embodiment distributes the features as evenly as possible over the 16×16 array, maintaining symmetry about the center of the array.
Referring back to
Because FPA 216 has one-sixth the dimensions of spatial filter 204, in the above example of the spatial filter pattern, 23 cycles of the high frequency pattern will be captured across 256 pixels in both directions. This yields over 11 samples per cycle which is significantly over-sampled relative to the Nyquist rate of 2 samples per cycle. This over sampling improves immunity to smear, or loss of contrast, due to motion during the exposure time.
A method of determining an angular orientation that can be performed using the above described sensor apparatus will now be described in more detail below in connection with
As shown in
As shown in
Next, in step S604, a Fourier transform is applied to the waveform data to determine the phase offset of the waveform. The method of mapping the waveform data, such as I(Xi, YP), to an absolute angle position is similar for both the azimuth and elevation waveforms, so the process is described for a waveform, I(i), without distinguishing its orientation.
Preferably, a Discrete Fourier Transform method is used to find the phase Ø1 of the low frequency component f1 from a composite waveform I(i) consisting of m samples. In this example of FPA 216, m is 256 (it should be noted that non-integral samples may be discarded, as will be discussed in more detail below). An arctangent function is used, which might normally return a value between −π and π; however, since the sign of both the numerator and denominator are known, this knowledge is used to map the result over the range 0 to 2π. For f1 and f2 in units of cycles/m, the following processing is performed:
Next, in step S606, the phase Ø2 of high frequency component f2, is calculated in the same fashion from composite waveform I(i):
Next, S608, calculations are performed to determine the unambiguous values of the phase offset from the calculated values Ø1 and Ø2. In particular, the high frequency result is ambiguous relative to the absolute angle desired as it repeats for every cycle of the high frequency pattern that is crossed due to changes in the measured angle. Moreover, the low frequency result is also ambiguous relative to the absolute phase angle. However, provided that f1 and f2 are chosen with a least common multiple beyond the range used to map absolute measurement angles, it should be possible to uniquely map the absolute angle from the measured values of Ø1 and Ø2. This mapping is greatly simplified by the appropriate choice of f1 relative to f2.
For example, frequency f2 is chosen to provide an integral number of cycles across the sampled waveform, such as 23 cycles across 256 sample points. This provides the best accuracy when processing the Fourier Transform math. Alternatively, samples may be discarded to leave an integral number of cycles of f2 when calculating the Fourier Transform.
A ‘measurement range’, is chosen as some multiple of f2, such as a·f2, where factor ‘a’ is a positive real number. For example, if factor ‘a’ is chosen to be 5, there will be 5·23==115 cycles across the measurement range. The absolute angle range is mapped to this measurement range by the choice of collimator focal length and detector pixel size. For example, if f2 has 23 cycles across 256 sample points, it has a·256=5·256=1280 samples across the measurement range. For an example where pixel size is 7 μm and a collimator focal length is 42 mm, each pixel represents an angular change of the received light beam of:
IFOV=A TAN(7 μm/42 mm)=167 μrad
For the case where the object source is designed to compensate for optical distortions and sine angle projection at the FPA plane, the field of view of the received light beam is:
FOV=(1280 samples)·IFOV=0.213 rad=12.2°
The absolute angle range, which describes the angular variation of the flat mirror mounted to the inner payload, has half the sensitivity of the FOV due to the reflection off the flat mirror, thus:
Absolute Angle Range=FOV/2=6.1°
If a hypothetical frequency, f3, is chosen such that:
a·f3=a·f2+δ
then δ represents the difference in total cycles across the measurement range between f2 and f3. While many choices of δ could be utilized, the range between −1 and +1 eliminates ambiguity in calculating absolute measurement position. Furthermore, the choice of −1 provides the best noise immunity, so δ=−1 will be used for the balance of this explanation. Thus:
f3=f2−1/a
Note that a·f3 is one cycle different than a·f2 across the measurement range, such as 114 cycles, relative to 115 cycles. The absolute measurement position is easily determined from the difference in phase between a·f3 and a·f2 because this phase varies across a single cycle over the measurement range, providing no ambiguity. However, f2 and f3 are so close in frequency that a large number of samples are required to distinguish their phase using the Fourier Transform method without significant interaction.
Instead, f1 is chosen as f3 divided by an integer, N:
f1=f3/N
Substituting for f3=f2−1/a:
f1=f2/N−1/(a·N)
For example, for f2=23, a=5, N=4, f1=23/4−1/(5·4)=5.7 cycles/view.
When calculating the phase of the low frequency component f1, i.e. Ø1, using the Fourier Transform method described above, 31 samples are discarded (e.g. from any combination of the two ends) leaving 5 cycles across the remaining 225 samples. Since we have chosen to make f3=N·fi, we can similarly calculate the phase of the f3, Ø3 using:
Ø3=N·Ø1
An absolute phase, ØABS is calculated by:
ØABS=MOD [Ø2−Ø3,2π]
where ØABS is maintained in the range 0 to 2π by the modulo operator, MOD. Since the phase difference between Ø2 and Ø3 has been arranged to vary from 0 to 2π across the measurement range, it is simple to map this to an absolute angle measurement: Absolute angle=ØABS·(Absolute Angle Range/2π)=ØABS·(6.1°/2π) thus accomplishing the intended measurement of this invention.
Constraining N to an integer is a key contribution of this invention to simplify the calculation of the absolute phase, ØABS. This is better understood when the equation for absolute phase is written in terms of the measured phases.
ØABS=MOD [Ø2−N·Ø1,2π]
Since there are 115 cycles of f2 across the measurement range, there are 114 points in the measurement range where Ø2 wraps, or transitions from 2π to 0. It might appear that such a dramatic change in Ø2 would cause a significant discontinuity in ØABS, however note that a change in ØABS of exactly 2π has no effect on ØABS due to the modulo function. A similar effect occurs when Ø1 wraps, except that ØABS then changes by N·2π, which also has no effect on ØABS due to the modulo function. If N were not an integer, ØABS would contain a complicated pattern of discontinuities which would be challenging to map to the absolute angle measurement.
At this point, there is a coarse estimation of the absolute angle being measured, for example either azimuth or elevation. According to an aspect of the invention, this coarse estimate is refined even further with an iterative process, as represented by steps S610 and S612. It should be noted that any number of the iterations described below could be performed in any given implementation.
According to one aspect of the invention, measurement resolution and accuracy can be significantly enhanced by compensating for systematic errors which mostly arise due to the interaction of f1 and f2 in the Fourier Transform calculation. In one example implementation, the correction approach uses ØABS, as a coarse estimate; Ø1X to refine that estimate to medium accuracy, ØABS2; known Ø1X errors are corrected to obtain ØABS3; the corrected Ø1X, Ø1C, is used to refine this estimate to medium-fine accuracy, ØABS4; Ø2X is used to refine this estimate to fine accuracy, ØABS5; known Ø2X errors are corrected; the corrected Ø2X, Ø2C, is used to refine this estimate to final, most accurate ØABS6 and final Azimuth angle, θX6.
As set forth in connection with step S610 above, the coarse estimate is calculated based on the Fourier Transform results from steps S606 and S608, Ø1X and Ø2X using,
ØABS1=MOD [Ø2X−N·Ø1X,2π]
The medium accuracy estimate, ØABS2, is found by adjusting ØABS1 by up to ±π of Ø1X so ØABS2 agrees with Ø1X. First the LINEAR implied by ØABS1 is calculated from:
Ø1NEAR=ØABS1·a·f1−INT[ØABS1·a·f1/2π]·2π
Then the error in ØABS1 is found for a shift by up to ±π from Ø1NEAR to agree with Ø1X:
ØERR1=(MOD [Ø1NEAR−Ø1X+π,2π]−π)/(a·f1)
Finally, the identified error in ØABS1 is removed:
ØABS2=ØABS1−ØERR1
Next, ØABS2 is used to find the known error in Ø1X, Ø1XERR, by interpolation from a table of known Ø1X errors verses ØABS2. This table is generated in an offline process by computer simulation at a resolution of one pixel and includes the expected errors which mostly arise due to the interaction of f1 and f2 in the Fourier Transform calculation, which should be apparent to those skilled in the art. The length of the look-up table in ØABS2 should extend beyond the 0 to 2π range by 1.5 cycles of Ø1X at each end. It is possible for the ØABS2 calculation to cause a wrap error of ±2π of Ø1X; however this has little effect on the goal of finding Ø1XERR in the look-up table because the error function is nearly periodic in Ø1X. To generate the look-up table, wrap anomalies are resolved by simply sorting the table by the independent variable, ØABS2.
The interpolated lookup value Ø1XERR, is then used to correct the previously calculated Ø1x value:
Ø1C=Ø1X−Ø1XERR
Then ØABS3 is found using the corrected Ø1C:
ØABS3=MOD [Ø2X−N·Ø1C,2π]
The medium-fine accuracy estimate, ØABS4, is found by adjusting ØABS3 by up to ±π of Ø1C so ØABS4 agrees with Ø1C. First the Ø1NEARC implied by ØABS3 is calculated from:
Ø1NEARC=ØABS3·a·f1−INT[ØABS3·a·f1/2π]·2π
Then the error in ØABS3 is found for a shift by up to ±π from Ø1NEARC to agree with Ø1C:
ØERR3=(MOD [Ø1NEARC−Ø1C+π,2π]−π)/(a·f1)
Finally, the identified error in ØABS3 is removed:
ØABS4=ØABS3−ØERR3
If there were no measurement noise, ØABS4 would provide a sufficient measurement, however for typical measurement noise due to a detector with 8 bit resolution and 2 bits of noise, for an effective 6 bit intensity resolution the measurement noise due to ØABS4 may be on the order of 5 ppm. Measurement noise may be significantly reduced with the additional corrections described below.
The fine accuracy estimate, ØABS5, is found by adjusting ØABS4 by up to ±π of Ø2X so ØABS5 agrees with Ø2X. First the Ø2NEAR implied by ØABS4 is calculated from:
Ø2NEAR=ØABS4·a·f2−INT[ØABS4·a·f2/2π]·2π
Then the error in ØABS4 is found for a shift by up to ±π from Ø2NEAR to agree with Ø2X:
ØERR4=(MOD [Ø2NEAR−Ø2X+π,2π]−π)/(a·f2)
Finally, the identified error in ØABS4 is removed:
ØABS5=ØABS4−ØERR4
ØABS5 is used to find the known error in Ø2X, Ø2XERR, by interpolation from a table of known Ø2X errors versus ØABS5. This table is generated by simulation at a resolution of one pixel and includes the errors which mostly arise due to the interaction of f1 and f2 in the Fourier Transform calculation. The length of the look-up table in ØABS5 should extend beyond the 0 to 2π range by ½ cycle of Ø2X at each end. It is possible for the ØABS5 calculation to cause a wrap error of ±2π of Ø2X in the presence of extreme noise levels. This determines the limit of acceptable noise.
The interpolated lookup value Ø2XERR, is then used to correct the previously calculated Ø2X value:
Ø2C=Ø2X−Ø2XERR
The most accurate result, ØABS6, is found by adjusting ØABS4 by up to ±π of Ø2C so ØABS6 agrees with Ø2C. The Ø2NEAR calculated previously may be used:
Ø2NEAR=ØABS4·a·f2−INT[ØABS4·a·f2/2π]·2π
Then the error in ØABS4 is found for a shift by up to ±π from Ø2NEAR to agree with Ø2C:
ØERR5=(MOD [Ø2NEAR−Ø2C+π,2π]−π)/(a·f2)
Finally, the revised error in ØABS4 is removed:
ØABS6=ØABS4−ØERR5
Similarly as discussed above, for a detector with 8-bit resolution and 2 bits of noise, and thus an effective 6-bit intensity resolution, the typical measurement noise due to ØABS5 is on the order of about 2.4 ppm.
The final absolute angle (e.g. azimuth or elevation) is found from:
Azimuth angle=θX6=ØABS6·(Absolute Angle Range/2π)=ØABS6·(6.1°/2π)
A similar procedure is used to find the corresponding orthogonal or alternative angle.
Since the above process only utilizes one row and one column of the array to find the final absolute angles, (e.g. azimuth and elevation) there is considerable additional data available which represents independent measurements of the same event. This additional data has best contrast at offsets of integral cycles of f1.
As shown in step S614 of
In step S618, the accuracy of the measurement might be further improved by calibrating to a standard with higher accuracy to obtain an error table versus position. This error table can then be used to correct the final averaged values of angle resulting in the final, most accurate measurements. These systematic errors might arise due to optical distortions, non-uniform illumination, inaccuracies in the fabrication of the spatial filter, or other effects.
It should be noted that the example methods of this invention may be utilized for repetitive measurements such as might be needed to provide feedback for a control system.
Although the invention has been described in connection with the presently preferred embodiments, the invention is not limited to the specific examples provided above, and those skilled in the art will be able to practice the invention with many variations and modifications to the above-described examples.
For example, a single, point light source and a collimating lens may be used to produce a light beam which illuminates the spatial filter. Further, the spatial filter could be illuminated from the opposite side and the reflected light could be utilized as the source object instead of the transmitted light through the filter. Still further, the beam splitter could be omitted, and the flat mirror could be replaced with a roof prism to offset the beam, with a separate collimating lens added for forming the image at the camera. As another example, the source beam aperture can be smaller than the receiving aperture and the system could have magnification other than one. As yet another example, a polychromatic or polarized light source, a polychromatic (color) or polarized spatial filter, and a polychromatic or polarized camera could be used to separate multiple waveform patterns by light wavelength (color) or polarization. As a further alternative, the angular orientation variations of any digital imaging system (camera) could be measured by viewing an object with a pattern as described above for the spatial filter and processing the digital image of the camera as described above. Still further, the system could be implemented at long range where angular changes dominate translation. As another possible variation, 2 axes of translation could be measured, instead of angles, of any digital imaging system (camera) by viewing an object with a pattern as described above for the spatial filter and processing the digital image of the camera as described above. And finally, the system could be implemented at close range where translation dominates angular changes. It is intended that the appended claims encompass these and other changes and modifications.
Number | Name | Date | Kind |
---|---|---|---|
3799675 | Johnson et al. | Mar 1974 | A |
4659219 | de Fleurieu et al. | Apr 1987 | A |
5044751 | Singer et al. | Sep 1991 | A |
5513000 | Smith et al. | Apr 1996 | A |
6384908 | Schmidt et al. | May 2002 | B1 |
6504605 | Pedersen et al. | Jan 2003 | B1 |