The present invention relates generally to an Optical Positioning Device (OPD) and to methods of sensing movement using the same.
Pointing devices, such as computer mice or trackballs, are utilized for inputting data into and interfacing with personal computers and workstations. Such devices allow rapid relocation of a cursor on a monitor, and are useful in many text, database and graphical programs. A user controls the cursor, for example, by moving the mouse over a surface to move the cursor in a direction and over distance proportional to the movement of the mouse. Alternatively, movement of the hand over a stationary device may be used for the same purpose.
Computer mice come in both optical and mechanical versions. Mechanical mice typically use a rotating ball to detect motion, and a pair of shaft encoders in contact with the ball to produce a digital signal used by the computer to move the cursor. One problem with mechanical mice is that they are prone to inaccuracy and malfunction after sustained use due to dirt accumulation, and such. In addition, the movement and resultant wear of the mechanical elements, particularly the shaft encoders, necessarily limit the useful life of the device.
One solution to the above-discussed with mechanical mice problems has been the development of optical mice. Optical mice have become very popular because they are more robust and may provide a better pointing accuracy.
The dominant conventional technology used for optical mice relies on a light emitting diode (LED) illuminating a surface at or near grazing incidence, a two-dimensional CMOS (complementary metal-oxide-semiconductor) detector which captures the resultant images, and software that correlates successive images to determine the direction, distance and speed the mouse has been moved. This technology typically provides high accuracy but suffers from a complex design and relatively high image processing requirements. In addition, the optical efficiency is low due to the grazing incidence of the illumination.
Another approach uses one-dimensional arrays of photo-sensors or detectors, such as photodiodes. Successive images of the surface are captured by imaging optics, translated onto the photodiodes, and compared to detect movement of the mouse. The photodiodes may be directly wired in groups to facilitate motion detection. This reduces the photodiode requirements, and enables rapid analog processing. An example of one such a mouse is disclosed in U.S. Pat. No. 5,907,152 to Dandliker et al.
The mouse disclosed in Dandliker et al. differs from the standard technology also in that it uses a coherent light source, such as a laser. Light from a coherent source scattered off of a rough surface generates a random intensity distribution of light known as speckle. The use of a speckle-based pattern has several advantages, including efficient laser-based light generation and high contrast images even under illumination at normal incidence. This allows for a more efficient system and conserves current consumption, which is advantageous in wireless applications so as to extend battery life.
Although a significant improvement over the conventional LED-based optical mice, these speckle-based devices have not been wholly satisfactory for a number of reasons. In particular, mice using laser speckle have not demonstrated the accuracy typically demanded in state-of-the-art mice today, which generally are desired to have a path error of less than 0.5% or thereabout.
The present disclosure discusses and provides solutions to various problems with prior optical mice and other similar optical pointing devices.
One embodiment pertains to an optical displacement sensor for sensing relative movement between a data input device and a surface by determining displacement of optical features in a succession of images of the surface. The sensor includes a plurality of linear comb arrays (LCAs) arranged along an associated axis. Each LCA comprises a row of photosensistive elements parallel to the associated axis.
Another embodiment pertains to a method of sensing movement of a data input device across a surface. An intensity pattern of light reflected from an illuminated portion of the surface is detected using a first plurality of linear comb arrays (LCAs) arranged along a first axis and a second plurality of LCAs arranged along a second axis not parallel to the first axis. Each LCA in the first plurality comprises a plurality of photosensistive elements in a row parallel to the first axis, and each LCA in the second plurality comprises a plurality of photosensitive elements in a row parallel to the second axis.
Another embodiment pertains to an optical positioning apparatus. The apparatus includes at least a coherent light source, illumination optics, imaging optics, and a detector. The illumination optics is configured to illuminate a surface area with light from the coherent light source. The imaging optics is configured to project a speckle pattern of light from the illuminated surface area. The detector includes a first plurality of linear comb arrays oriented along a first axis and a second plurality of linear comb arrays oriented along a second axis which is not parallel to the first axis.
Other embodiments are also described.
These and various other features and advantages of the present disclosure are understood more fully from the detailed description that follows and from the accompanying drawings, which, however, should not be taken to limit the appended claims to the specific embodiments shown, but are for explanation and understanding only, where:
Problems with Prior Optical Positioning Devices
One problem with prior speckle-based OPDs stems from the pitch or distance between neighboring photodiodes, which typically ranges from ten (10) micrometers to five hundred (500) micrometers. Speckles in the imaging plane having a size smaller than this pitch are not properly detected, thereby limiting the sensitivity and accuracy of the OPD. Speckles significantly larger than this pitch produce a drastically smaller signal.
Another problem is the coherent light source must be correctly aligned with the detector in order to produce a speckled surface image. With prior designs, the illuminated portion of an image plane is typically much wider than the field of view of the detector to make sure the photodiode array(s) is (are) fully covered by the reflected illumination. However, having a large illuminated area reduces the power intensity of the reflected illumination that the photodiodes can detect. Thus, attempts to solve or avoid misalignment problems in prior speckle-based OPD have frequently resulted in a loss of reflected light available to the photodiode array, or have imposed higher requirements on the illumination power.
Yet another problem with conventional OPDs is the distortion of features on or emanating from the surface due to a viewing angle and/or varying distance between the imaging optics and features at different points within the field of view. This is particularly a problem for OPDs using illumination at grazing incidence.
An additional problem with prior speckle-based OPDs arising from image analysis of the speckle pattern is sensitivity of an estimation scheme to statistical fluctuations. Because speckles are generated through phase randomization of scattered coherent light, the speckles have a defined size and distribution on average, but the speckles may exhibit local patterns not consistent with the average. Therefore, the device can be subject to locally ambiguous or hard to interpret data, such as where the pattern of the speckle provides a smaller motion-dependent signal than usual.
Still another problem with speckle-based OPDs relates to the changing of the speckle pattern, or speckle “boiling”. In general, the speckle pattern from a surface moves as the surface is moved, and in the same direction with the same velocity. However, in many optical systems there will be additional changes in the phase front coming off of the surface. For example, if the optical system is not telecentric, so that the path length from the surface to the corresponding detector is not uniform across the surface, the speckle pattern may change in a somewhat random manner as the surface is moved. This distorts the signal used to detect surface motion, leading to decreases in the accuracy and sensitivity of the system.
Accordingly, there is a need for a highly accurate speckle-based optical pointing device and method of using the same that is capable of detecting movement with a path error of less than 0.5% or thereabout. It is desirable that the device have a straightforward and uncomplicated design with relatively low image processing requirements. It is further desirable that the device have a high optical efficiency in which the loss of reflected light available to the photodiode array is minimized. It is still further desirable to optimize the sensitivity and accuracy of the device for the speckle size used, and to maintain the speckle pattern accurately by the optical system.
OPD Embodiments Disclosed Herein
The present disclosure relates generally to a sensor for an Optical Positioning Device (OPD), and to methods for sensing relative movement between the sensor and a surface based on displacement of a random intensity distribution pattern of light, known as speckle, reflected from the surface. OPDs include, but are not limited to, optical mice or trackballs for inputting data to a personal computer.
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification do not necessarily all refer to the same embodiment.
Generally, the sensor for an OPD includes an illuminator having a light source and illumination optics to illuminate a portion of the surface, a detector having a number of photosensitive elements and imaging optics, and signal processing or mixed-signal electronics for combining signals from each of the photosensitive elements to produce an output signal from the detector.
In one embodiment, the detector and mixed-signal electronics are fabricated using standard CMOS processes and equipment. Preferably, the sensor and method of the present invention provide an optically-efficient detection architecture by use of structured illumination and telecentric speckle-imaging as well as a simplified signal processing configuration using a combination of analog and digital electronics. This architecture reduces the amount of electrical power dedicated to signal processing and displacement-estimation in the sensor. It has been found that a sensor using the speckle-detection technique, and appropriately configured in accordance with the present invention can meet or exceed all performance criteria typically expected of OPDs, including maximum displacement speed, accuracy, and % path error rates.
Introduction to Speckle-Based Displacement Sensors
This section discusses operating principles of speckle-based displacement sensors as understood and believed by the applicants. While these operating principles are useful for purposes of understanding, it is not intended that embodiments of the present disclosure be unnecessarily limited by these principles.
Referring to
In contrast, referring to
Speckle is expected to come in all sizes up to the spatial frequency set by the effective aperture of the optics, conventionally defined in term of its numerical aperture NA=sin θ as shown
It is interesting to note that the spatial frequency spectral density of the speckle intensity, which by Wiener-Khintchine theorem, is simply the Fourier transform of the intensity auto-correlation. The finest possible speckle, αmin=λ/2NA, is set by the unlikely case where the main contribution comes from the extreme rays 118 of
Note that the numerical aperture may be different for spatial frequencies in the image along one dimension (say “x”) than along the orthogonal dimension (“y”). This may be caused, for instance, by an optical aperture which is longer in one dimension than another (for example, an ellipse instead of a circle), or by anamorphic lenses. In these cases, the speckle pattern 116 will also be anisotropic, and the average speckle size will be different in the two dimensions.
One advantage of a laser speckle-based displacement sensor is that it can operate with illumination light that arrives at near-normal incidence angles. Sensors that employ imaging optics and incoherent light arriving at grazing incident angles to a rough surface also can be employed for transverse displacement sensing. However, since the grazing incidence angle of the illumination is used to create appropriately large bright-dark shadows of the surface terrain in the image, the system is inherently optically inefficient, as a significant fraction of the light is reflected off in a specular manner away from the detector and thus contributes nothing to the image formed. In contrast, a speckle-based displacement sensor can make efficient use of a larger fraction of the illumination light from the laser source, thereby allowing the development of an optically efficient displacement sensor.
Disclosed Architecture for Speckle-Based Displacement Sensor
The detailed description below describes an architecture for one such laser-speckle-based displacement sensor using CMOS photodiodes with analog signal combining circuitry, moderate amounts of digital signal processing circuitry, and a low-power light source, such as, for example, a 850 nm Vertical Cavity Surface Emitting Laser (VCSEL). While certain implementational details are discussed in the detailed description below, it will be appreciated by those skilled in the art that different light sources, detector or photosensitive elements, and/or different circuitry for combining signals may be utilized without departing from the spirit and scope of the present invention.
A speckle-based mouse according to an embodiment of the present invention will now be described with reference to
Speckle from the rough surface 304 is imaged to the detector plane with imaging optics 310. Preferably, the imaging optics 310 are telecentric for optimum performance.
In one embodiment, the comb array detection is performed in two independent, orthogonal arrays to obtain estimations of displacements in x and y. A small version of one such array 302 is depicted in
Each array in the detector consists of a number, N, of photodiode sets, each set having a number, M, of photodiodes (PD) arranged to form an MN linear array. In the embodiment shown in
One difficulty with comb detectors using 4N detection, as shown in
Multi-Row Detector Arrays
One solution to this fundamental noise source is to gang or arrange several rows of these detector or photosensitive elements together. A detector with two ganged rows 502-1 and 502-2 is depicted schematically in
Simulation methods
To demonstrate the efficacy of the configuration of
Error Rate Calculations
An example output from these simulations is shown in
The horizontal axis on these graphs show the frame count; 4000 individual measurements (frames) were used in this case. The lower two curves are the in-phase 602-1 and quadrature 602-2 signals (group 1 minus group 3, and 2 minus 4 respectively). From these two curves a signal length 604 and angle 606 can be determined, as shown in the upper two curves. Note that the in-phase 602-1 and quadrature 602-2 signals are very similar, as they rely on the same section of the speckle pattern.
This data can be used to calculate velocity. In this example, we use a simple zero-crossing algorithm for the velocity calculation. At each frame, the number of frames τ between the previous two positive-going zero crossings is calculated. A positive-going zero crossing is a zero crossing where the slope of the line is positive such that the signal is going from a negative value to a positive value. In this case, τ represents an estimate of the number of frames required to travel 20 microns (μm). Consider the frame rate (frames per unit time) to be f, and the detector pitch (distance from the start of one group of elements to a next group of elements) to be p. The estimated velocity (speed) v is then
v=f*p/τ (Equation 4)
The maximum velocity vmax is half of the Nyquist velocity. A histogram of the result is shown in
Referring to
The points of the first marker 702, containing all of the data, shows a strong peak at 5 frames and a distribution which decreases quickly to both sides. The vertical line 701 at 4.938 frames, which we call “truth”, is the actual velocity as estimated. There are two relatively strongest peaks in the data to each side of that line (i.e. at 4 frames and 5 frames).
For the purposes of this simulation we count as an error any point which falls outside of those two strongest peaks. In other words, an estimate which is more than one frame from “truth” is defined to be in “error.” This is a fairly strict definition of error, because often such an error will be made up in subsequent cycles. If the actual velocity lies close to an integral number of frames; there will be a significant fraction of errors which lie only a little more than one frame from “truth”. For example, the points at 6 frames in
Dependence on Vector Length
Errors are concentrated in those frames which have weak signals. The data in
The improvement in error rate by excluding smaller signal magnitudes is shown in
Thus, based on the improvement in error rate when smaller signal magnitudes are excluded, one scheme of row selection from amongst multiple rows of a detector is to select the row with the highest signal magnitude. For example, in the case of
Selecting the line signal from the row with the highest line signal quality is one scheme for utilizing signals from multiple rows to avoid or resist speckle fading. In addition, there are various other alternative schemes that accomplish the same or similar aim.
An alternative scheme would be to weight the line signals from different rows according to their magnitude (or other quality measure) and then average the weighted signals, for instance. In one embodiment, rather than simply averaging the weighted signals, the weighted set of signals may be more optimally processed by an algorithm employing recursive filtering techniques. One notable example of a linear recursive filtering technique uses a Kalman filter. [See R. E. Kalman, “A New Approach to Linear Filtering and Prediction Problems,” Trans. ASME, Journal of Basic Engineering, Volume 82 (Series D), pages 35-45 (1960).] An extended Kalman filter may be utilized for non-linear estimation algorithms (such as the case of sinusoidal signals from the comb detector arrangement). The nature of the signal and measurement models for a speckle-based optical mouse indicate that a recursive digital signal processing algorithm is well-suited to the weighted signals produced by the speckle-mouse front-end detector and electronics.
Simulation of Multi-Row Arrangements
Detectors of two and three rows were simulated using the same techniques. Each row was illuminated by an independent part of the speckle pattern. The results for error rate are shown in
The simulation shows, for example, that a single row of 32 elements has an error rate slightly more than 20%. Combining two of those rows (for a total element count of 64) reduces the error rate to about 13%. This is slightly lower than the result for a single row of 64 elements. Combining three of those rows (for a total element count of 96) gives an error rate of about 8%, a reduction to less than 12 of the single-row error rate.
The benefit of increasing the number of rows is greater for a higher number of elements. Combining three rows of 128 elements (for a total element count of 384) reduces the error rate from 10% (for a single row of 128 elements) to 1.5% (for the combination of three of those rows), a reduction to less than ⅙ of the single-row error rate.
Path error
We can calculate the path error from this error rate as follows. When traversing a path which is M counts long, the total number of errors is ME. Here, E is the error rate discussed and calculated above. As the surface is moved, the errors appear as extra counts and missed counts. For measurements over a longer distance, these errors tend to cancel out and the average net error increases only as the square root of the total number of errors. The measured number of counts differs from the expected counts by an amount which could be positive or negative, but on average it has an absolute value equal to the square root of the number of errors. We define the path error as
When traversing a path which is M counts long, the mouse will generate, on average, ME errors and end up off by {square root}{square root over (ME)} counts. So in the case where the measured counts are higher than the expected counts, Measured_counts=M+{square root}{square root over (ME)}, and the path error is
This is only a rough statement of the average path error, which in a more accurate calculation would have a distribution centered around zero having a standard deviation of {square root}{square root over (E/M)}.
To apply this formula to the results presented above, we assume a resolution of 847 dots-per-inch (dpi) (i.e. 847 frames or samples per inch) and a distance traveled of 2 centimeters (cm). This yields 667 frames per measurement (i.e. 667 frames in traveling 2 cm), and so M=667. For 3 rows of 128 detector or photosensitive elements, we have an error rate E of 1.5%, and so a path error of 0.5% in accordance with Equation 6. The path error would improve considerably at longer distances.
Detection Using Ganged Combinations of Detectors or Photosensitive Elements
Another solution to the noise problem of comb detectors using 4N detection is to provide a detector having an array including one or more rows with a number of sets of interlaced groups (N) of photosensitive elements, each set having a number of consecutive photosensitive elements (M), where M is not equal to four (4). In other words, M is a number from a set consisting of 3, 5, 6, 7, 8, 9, 10, and so on. In particular, every third, every fifth, every sixth, or every Mth detector or photosensitive element is combined to generate an independent signal for estimating motion.
The above example includes one-hundred-twenty (120) detector or photosensitive elements operating at about 72% of a maximum rated speed. The horizontal axis on the graphs of
As noted previously, this data can be used to calculate velocity. In this case we use a simple zero-crossing algorithm. At each frame the number of frames, τ, between the previous two positive going zero crossing is calculated. This represents an estimate of the number of frames required to travel 20 micrometers. Consider the frame rate (frames per unit time) to be f and the detector pitch (distance from the start of one group of elements to a next group of elements) to be p. The estimated velocity v is then:
v=f*p/τ (Equation 4)
This velocity is the component of the total velocity which lies along the long axis of the detector array.
In order to generate the velocity dependent signals, for configurations other than 4N, the groups of detector or photosensitive elements are weighted and combined. One embodiment of suitable weighting factors is given by the following equations:
where i spans all photosensitive elements in a set from 0 to M-1. Here phi is a phase shift which is common to all weighting factors.
The in-phase weighted summation of the output signals (i.e. the in-phase signal) is given by the following:
while the quadrature weighted summation of the output signals (i.e. the quadrature signal) is given by the following:
For 5-element groups, that is for a 5N configuration, those factors are shown in
Weighting factors for an array having photosensitive elements coupled in 6N configuration are shown in
Weighting factors for an array having photosensitive elements coupled in 4N configuration are shown in
In another aspect, the present disclosure is directed to a sensor having a detector with two or more different groupings of photosensitive elements. Such an embodiment with multiple groupings of elements allows the generation of multiple independent signals for motion estimation.
For example, if combs with different M values are combined in the same sensor (say 4N and 6N), and the width of the photosensitive element is kept constant, we can get good performance from an arrangement like that shown in
Alternatively, we can use the same arrays and the same sections of the speckle pattern. This is the case modeled in
One circuit implementation to wire individual photodiode elements with multiple values of M is shown in
In the particular example shown in
In an alternate circuit implementation, each detector or photosensitive element can feed multiple current mirrors with different gains to enable the same detector or photosensitive element to contribute to different, independent in-phase and quadrature sums for different detector periods (values of M).
In another alternate circuit implementation, the detector values may be sampled individually or multiplexed and sequentially sampled using analog-to-digital converter (ADC) circuitry, and the digitized values may then be processed to generate the independent sums. In yet another circuit implementation, analog sums of the detector outputs may be processed by a shared time-multiplexed or multiple simultaneous ADC circuitry. There are a number of circuit implementations that could accomplish the task, where the different implementations trade off factors, such as circuit complexity, power consumption, and/or noise figure.
The embodiments shown in
In
The detailed embodiments described above show the detector or photosensitive element oriented along a single axis—i.e. in a one-dimensional array, albeit possibly with several rows. In another embodiment, the detectors or photosensitive elements are arrayed in two dimensions, as shown, for example, in
In
The foregoing description of specific embodiments and examples of the invention have been presented for the purpose of illustration and description, and although the invention has been described and illustrated by certain of the preceding examples, it is not to be construed as being limited thereby. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed, and many modifications, improvements and variations within the scope of the invention are possible in light of the above teaching. It is intended that the scope of the invention encompass the generic area as herein disclosed, and by the claims appended hereto and their equivalents.
The present application claims the benefit of U.S. provisional application No. 60/573,076, entitled “Optical position sensing device having a multi-row detector array,” filed May 21, 2004, by inventors Charles B. Roxlo, David A. LeHoty, Jahja I. Trisnadi and Clinton B. Carlisle. The disclosure of the aforementioned U.S. provisional application is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
60573076 | May 2004 | US |