Passive touch system and method of detecting user input

Information

  • Patent Grant
  • 8055022
  • Patent Number
    8,055,022
  • Date Filed
    Tuesday, February 24, 2009
    15 years ago
  • Date Issued
    Tuesday, November 8, 2011
    13 years ago
Abstract
A method of tracking an object of interest preferably includes (i) acquiring a first image and a second image representing different viewpoints of the object of interest; (ii) processing the first image into a first image data set and the second image into a second image data set; (iii) processing the first image data set and the second image data set to generate a background data set associated with a background; (iv) generating a first difference map by determining differences between the first image data set and the background data set and a second difference map by determining differences between the second image data set and the background data set; (v) detecting a first relative position of the object of interest in the first difference map and a second relative position of the object of interest in the second difference map; and (vi) producing an absolute position of the object of interest from the first and second relative positions of the object of interest.
Description
FIELD OF THE INVENTION

The present invention related generally to input devices and in particular to a passive touch system and method of detecting use input.


BACKGROUND OF THE INVENTION

Touch systems are well known in the art and typically include a touch screen having a touch surface on which contacts are made using a pointer in order to generate user input. Pointer contacts with the touch surface are detected and are used to generate corresponding output depending on areas of the contact surface where the contacts are made. There are basically two general types of touch systems available and they can be broadly classified as “active” touch systems and “passive” touch systems.


Active touch systems allow a user to generate user input by contacting the touch surface with a special pointer that usually requires some form of on-board power source, typically batteries. The special pointer emits signals such as infrared light, visible light, ultrasonic frequencies, electromagnetic frequencies, etc. that activate the touch surface.


Passive touch systems allow a user to generate user input by contacting the touch surface with a passive pointer and do not require the use of a special pointer in order to activate the touch surface. A passive pointer can be a finger, a cylinder of some material, or any suitable object that can be used to contact some predetermined area of interest on the touch surface.


Passive touch systems provide advantages over active touch systems in that any suitable pointing device, including a user's finger, can be used as a pointer to contact the touch surface. As a result, user input can easily be generated. Also, since special active pointers are not necessary in passive touch systems, battery power levels and/or pointer damage, theft, or misplacement are of no concern to users.


Passive touch systems have a number of applications relating to computer operation and video display. For example, in one interactive application, as is disclosed in U.S. Pat. No. 5,448,263 to Martin, assigned to the assignee of the present invention, the passive touch system is coupled to a computer and the computer display is projected onto the touch surface of the touch screen. The coordinates representing specific locations on the touch surface are mapped to the computer display. When a user contacts the touch surface, the coordinates of the contact are fed back to the computer and mapped to the computer display thereby allowing the user to operate the computer in a manner similar to using a computer mouse simply by contacting the touch surface. Furthermore, the coordinates fed back to the computer can be recorded in an application and redisplayed at a later time. Recording contact coordinates is typically done when it is desired to record information written or drawn on the touch surface by the user.


The resolution of a passive touch screen determines if the touch system is suitable for recording information written or drawn on the touch screen or only useful for selecting areas on the touch screen mapped to large regions on the computer or video display in order to manipulate the computer or video display. Resolution is typically measured in dots per inch (DPI). The DPI is related to the size of the touch screen and the sampling ability of the touch system hardware and software used to detect contacts on the touch surface.


Low-resolution passive touch screens only have enough DPI to detect contacts on the touch surface within a large group of pixels displayed by the computer or video system. Therefore, these low-resolution passive touch screens are useful only for manipulating the computer or video display.


On the other hand, high-resolution passive touch screens have sufficient DPI to detect contacts that are proportional to a small number of pixels or sub-pixels of the computer or video display. However, a requirement for high-resolution touch screens is the ability to detect when the pointer is in contact with the touch surface. This is necessary for writing, drawing, mouse-click operations, etc. Without the ability to detect pointer contact with the touch screen, writing and drawing would be one continues operation, and mouse clicks would not be possible thereby making computer display manipulation impossible. A secondary requirement is the ability to detect when the pointer is “hovering” above the touch surface. Although not required for writing or drawing, today's computer operating systems are increasingly using hover information to manipulate computer or video displays or pop-up information boxes.


Passive touch screens are typically either of the analog resistive type, Surface Acoustic Wave (SAW) type or capacitive type. Unfortunately, these touch screens suffer from a number of problems or shortcomings as will be described.


Analog resistive touch screens typically have a high-resolution.


Depending on the complexity of the touch system, the resolution of the touch screen can produce 4096×4096 DPI or higher. Analog resistive touch screens are constructed using two flexible sheets that are coated with a resistive material and arranged as a sandwich. The sheets do not come into contact with each other until a contact has been made. The sheets are typically kept separated by insulating microdots or by an insulating air space. The sheets are constructed from ITO, which is mostly transparent. Thus, the touch screen introduces some image distortion but very little parallax.


During operation of an analog resistive passive touch screen, a uniform voltage gradient is applied in one direction along a first of the sheets. The second sheet measures the voltage along the first sheet when the two sheets contact one another as a result of a contact made on the touch surface. Since the voltage gradient of the first sheet can be translated to the distance along the first sheet, the measured voltage is proportional to the position of the contact on the touch surface. When a contact coordinate on the first sheet is acquired, the uniform voltage gradient is then applied to the second sheet and the first sheet measures the voltage along the second sheet. The voltage gradient of the second sheet is proportional to the distance along the second sheet. These two contact coordinates represent the X-Y position of the contact on the touch surface in a Cartesian coordinate system.


Since mechanical pressure is required to bring both sheets into contact, analog resistive touch screens can only detect contact when there is sufficient pressure to bring the two sheets together. Analog resistive passive touch screens cannot sense when a pointer is hovering over the touch surface. Therefore, contact events and positions can only be detected when actual contacts are made with the touch surface.


Surface Acoustic Wave (SAW) touch screens typically provide for medium resolution and are not suitable for recording good quality writing. SAW touch screens employ transducers on the borders of a glass surface to vibrate the glass and produce acoustic waves that ripple over the glass surface. When a contact is made on the glass surface, the waves reflect back and the contact position is determined from the signature of the reflected waves.


Unfortunately, SAW touch screens exhibit noticeable parallax due to the thickness of the vibrating glass which is placed over the surface of the video or computer display. Also, contact events and positions can only be detected when actual contacts are made with the glass surface. Furthermore, SAW touch screens do not scale beyond a few feet diagonal.


Capacitive touch screens provide for low resolution because contacts can only be determined in large areas (approximately ½″×½″). As a result, capacitive touch screens cannot be used for recording writing or drawing and are suitable for selecting areas on the touch screen corresponding to computer generated buttons displayed on the video or computer display. These touch screens also suffer disadvantages in that they are sensitive to temperature and humidity. Similar to analog resistive touch screens and SAW touch screens, capacitive touch screens can also only detect contact events and positions when actual contacts are made with the touch surface.


Scalability of passive touch screens is important since the demand for larger electronic digitizers is increasing. Where digitizers were once small desktop appliances, today they have found there way onto electronic whiteboarding applications. The need to build a passive touch sensitive “wall” has become a requirement for new touch screen applications. Existing passive touch screens of the types discussed above are all limited in the maximum size where they are still functional.


As will be appreciated, improvements to passive touch systems are desired. It is therefore an object of the present invention to provide a novel passive touch system and method of detecting user input.


SUMMARY OF THE INVENTION

According to one aspect of the present invention there is provided a passive touch system comprising:


a passive touch surface;


at least two cameras associated with said touch surface, said at least two cameras acquiring images of said touch surface from different locations and having overlapping fields of view; and


a processor receiving and processing images acquired by said at least two cameras to detect the existence of a pointer therein and to determine the location of said pointer relative to said touch surface.


In a preferred embodiment, the at least two cameras are two-dimensional image sensor and lens assemblies having fields of view looking along the plane of the touch surface. The processor determines the location of the pointer relative to the touch screen using triangulation. The processor also determines when the pointer is in contact with the touch surface and when the pointer is hovering above the touch surface.


In one embodiment, the processor selects pixel subsets of images acquired by the image sensor and lens assemblies and processes the pixel subsets to determine the existence of the pointer. The processor includes a digital signal processor associated with each image sensor and lens assembly and a master digital signal processor in communication with the digital signal processors. The digital signal processors associated with each image sensor and lens assembly select the pixel subsets and process the pixel subsets to determine the existence of the pointer. The master digital signal processor receives pixel characteristic data from the digital signal processors and triangulates the pixel characteristic data to determine the location of the pointer relative to the touch surface.


According to another aspect of the present invention there is provided a method of detecting the position of a pointer relative to a passive touch surface comprising the steps of:


acquiring images of said touch surface from different locations using cameras having overlapping fields of view; and


processing said images to detect the existence of a pointer therein and to determine the location of said pointer relative to said touch surface.


The present invention provides advantages in that the passive touch system is of high resolution and allows actual pointer contacts with the touch surface as well as pointer hovers above the touch surface to be detected and corresponding output generated. Also, the present passive touch system provides advantages in that it does not suffer from parallax, image distortion, pointer position restrictions, image projection and scalability problems that are associated with prior art passive touch systems.





BRIEF DESCRIPTION OF THE DRAWINGS

An embodiment of the present invention will now be described more fully with reference to the accompanying drawings in which:



FIG. 1 is a schematic diagram of a passive touch system in accordance with the present invention;



FIG. 2 is an isometric view of a touch screen forming part of the passive touch system of FIG. 1;



FIG. 3 is an isometric view of a corner portion of the touch screen of FIG. 2;



FIG. 4 is a schematic diagram of a camera assembly forming part of the touch screen of FIG. 2;



FIG. 5 is a front lavational view of the touch screen of FIG. 2 showing the fields of view of two camera assemblies;



FIG. 6 is a schematic diagram of a master controller forming part of the passive touch system of FIG. 1;



FIG. 7 is case diagram showing functions executed by the camera assemblies;



FIG. 8 is a flowchart showing the steps performed during execution of a findPointerMotion( ) function;



FIG. 9 is a flowchart showing the steps performed during execution of an autoSelectThres( ) function;



FIG. 10 is a flowchart showing the steps performed during execution of an extractPointer function;



FIG. 11 is a flowchart showing the steps performed during execution of a centerOfMass( ) function;



FIG. 12 is a flowchart showing the steps performed during execution of a processROI( ) function;



FIG. 13 is a flowchart showing the steps performed during execution of a getHighestRegion( ) function;



FIG. 14 shows an acquired image and a pixel subset of the image that is processed;



FIG. 15 shows a region of interest within the pixel subset;



FIG. 16 shows the triangulation geometry used to calculate a pointer contact position on the touch surface of the touch screen;



FIG. 17 shows an image acquired by an image sensor and lens assembly including the pointer and its median line; and



FIG. 18 shows pointer contact and pointer hover for different orientations of the pointer.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT

Turning now to FIG. 1, a passive touch system in accordance with the present invention is shown and is generally indicated to by reference numeral 50. As can be seen, passive touch system 50 includes a touch screen 52 coupled to a master controller 54. Master controller 54 is also coupled to a computer 56. Computer 56 executes one or more application programs and provides display output that is projected onto the touch screen 52 via a projector 58. The touch screen 52, master controller 54, computer 56 and projector 58 form a closed-loop so that user contacts with the touch screen 52 can be recorded as writing or drawing or used to control execution of application programs executed by the computer 56.



FIGS. 2 to 4 better illustrate the touch screen 52. Touch screen 52 includes a touch surface 60 bordered by a frame 62. Touch surface 60 is passive and is in the form of a rectangular planar sheet of material. Camera subsystems are associated with each corner of the touch screen 52. Each camera subsystem includes a camera assembly 63 mounted adjacent a different corner of the touch screen 52 by a frame assembly 64. Each frame assembly 64 includes an angled support plate 66 on which the camera assembly 63 is mounted. Supporting frame elements 70 and 72 are mounted on the plate 66 by posts 74 and secure the plate 66 to the frame 62.


Each camera assembly 63, in this embodiment, includes a camera in the form of a two-dimensional CMOS camera image sensor and associated lens assembly 80, a first-in-first-out (FIFO) buffer 82 coupled to the image sensor and lens assembly 80 by a data bus and a digital signal processor (DSP) 84 coupled to the FIFO 82 by a data bus and to the image sensor and lens assembly 80 by a control bus. A boot EPROM 86 and a power supply subsystem 88 are also included.


In the present embodiment, the CMOS camera image sensor is a Photobit PB300 image sensor configured for a 20×640 pixel subarray that can be operated to capture image frames at rates in excess of 200 frames per second. The FIFO buffer 82 is manufactured by Cypress under part number CY7C4211V and the DSP 84 is manufactured by Analog Devices under part number ADSP2185M.


The DSP 84 provides control information to the image sensor and lens assembly 80 via the control bus. The control information allows the DSP 84 to control parameters of the image sensor and lens assembly 80 such as exposure, gain, array configuration, reset and initialization. The DSP 84 also provides clock signals to the image sensor and lens assembly 80 to control the frame rate of the image sensor and lens assembly 80.


As shown in FIG. 5, each image sensor and lens assembly 80 has a 55° field of view. The angle of the plate 66 is selected so that the field of view of each image and lens assembly 80 includes at least the majority of a different peripheral edge of the touch surface 60. In this way, the entire touch surface 60 is within the fields of view of the image sensor and lens assemblies 80.


Master controller 54 is best illustrated in FIG. 6 and includes a DSP 90, a boot EPROM 92, a serial line driver 94 and a power supply subsystem 95. The DSP 90 communicates with the DSPs 84 of the camera assemblies 63 over a data bus through a serial port 96 and communicates with the computer 56 over a data bus through a serial port 98 and the serial line driver 94. In this embodiment, the DSP 90 is also manufactured by Analog Devices under part number ADSP2185M. The serial line driver 94 is manufactured by Analog Devices under part number ADM222.


The master controller 54 and each camera assembly 63 follow a communication protocol that enables bi-directional communications via a common serial cable similar to a universal serial bus (USB). The transmission bandwidth is divided into thirty-two (32) 16-bit channels. Of the thirty-two channels, five (5) channels are assigned to each of the DSPs 84 in the camera assemblies 63 and to the DSP 90 in the master controller 54 and the remaining seven (7) channels are unused. The master controller 54 monitors the twenty (20) channels assigned to the camera assembly DSPs 84 while the DSPs 84 in the camera subsystems 63 monitor the five (5) channels assigned to the master controller DSP 90. Communications between the master controller 54 and the camera assemblies 63 are performed as background processes in response to interrupts.


The general operation of the passive touch system 50 will now be described. Each camera assembly 63 acquires images of the touch surface 60 within the field of view of its image sensor and lens assembly 80 at the frame rate established by the DSP clock signals and processes the images to determine if a pointer is in the acquired images. If a pointer is in the acquired images, the images are further processed to determine characteristics of the pointer contacting or hovering above the touch surface 60. Pointer characteristics are then converted into pointer information packets (PIPs) and the PIPs are queued for transmission to the master controller 54.


The camera assemblies 63 also receive and respond to diagnostic PIPs generated by the master controller 54.


The master controller 54 polls the camera assemblies 63 at a set frequency (in this embodiment 70 times per second) for PIPs and triangulates pointer characteristics in the PIPs to determine pointer position data. The master controller 54 in turn transmits pointer position data and/or status information to the personal computer 56. In this manner, the pointer position data transmitted to the personal computer 56 can be recorded as writing or drawing or can be used to control execution of application programs executed by the computer 56. The computer 56 also updates the display output conveyed to the projector 58 so that information projected onto the touch surface 60 reflects the pointer activity.


The master controller 54 also receives commands from the personal computer 56 and responds accordingly as well as generates and conveys diagnostic PIPs to the camera assemblies 63.


Specifics concerning the processing of acquired images and the triangulation of pointer characteristics in PIPs will now be described with particular reference to FIGS. 7 to 13.


Initially, an alignment routine is performed to align the image sensor and lens assemblies 80. During the alignment routine, a pointer is held in the approximate center of the touch surface 60. Subsets of the pixels of the image sensor and lens assemblies 80 are then selected until a subset of pixels for each image sensor and lens assembly 80 is found that captures the pointer and the pointer tip on the touch surface 60. This alignment routine allows for a relaxation in mechanical mounting of the image sensor and lens assemblies on the frame assemblies 64. The identification of the pointer tip on the touch surface 60 also gives a calibration that determines the row of pixels of each image sensor and lens assembly 80 that detects actual contacts made with the touch surface. Knowing these pixel rows allows the difference between pointer hover and pointer contact to be determined.


In this embodiment, since a computer display is projected onto the touch surface 60, during the alignment routine several known coordinate locations are also displayed and the user is required to touch these coordinate locations in sequence using the pointer so that the subset of pixels for each of image sensor and lens assembly 80 includes all of the coordinate locations as well. Calibration data is then stored for reference so that pointer contacts on the touch surface 60 can be mapped to corresponding areas on the computer display.


As mentioned above, each camera assembly 63 acquires images of the touch surface 60 within its field of view. The images are acquired by the image and lens assembly 80 at intervals in response to the clock signals received from the DSP 84. Each image acquired by the image and lens assembly 80 is sent to the FIFO buffer 82.


The DSP 84 in turn reads each image from the FIFO buffer 82 and processes the image to determine if a pointer is located in the image and if so, to extract the pointer and related pointer statistical information. To avoid processing significant numbers of pixels containing no useful information, only the subset of the pixels in the image determined during the alignment routine are actually processed as is shown in FIG. 14.


In order to determine if a pointer is located in the image and extract pointer and related pointer statistical information, the DSP 84 executes a main findPointerMotion( ) function 120 that calls a number of other functions, namely an autoSelectThres( ) function 122, an extractPointer function 124, a centerOfMass( ) function 126, and a processROI( ) function 128 (see FIG. 7). The extractPointer( ) function 128 also calls a getHighestRegion( ) function 130.


The findPointerMotion( ) function 120 is used to extract the pointer from the image. Turning now to FIG. 8, the steps performed during execution of the findPointerMotion( ) function 120 is shown. When the findPointerMotion( ) function is called, a check is made to determine if a previous image iPrev including a pointer exists (step 150). If no previous image iPrev exists, center of mass parameters Cx and Cz are assigned zero values (step 152). The current image iCurr being processed is then designated as the previous image iPrev (step 154) to complete the findPointerMotion( ) function.


At step 150, if a previous image iPrev exists, the current image iCurr is subtracted from the previous image iPrev and the absolute value of the difference image iDiff is taken (step 156). By forming the difference image iDiff, background features and noise are removed. The autoSelectThres( ) function 122 is then called to select a threshold value tValue for the difference image iDiff (step 158) based on the histogram of the difference image iDiff. The threshold iThres of the difference image iDiff is then taken (step 160) to highlight further the pointer within the current image iCurr. During thresholding a grayscale image is mapped to the binary difference image iDiff. Pixels in the difference image with values equal to or less than the threshold value tValue are made black while all other pixels are made white. The result is a binary image containing the pointer and some noise both designated by white pixels.


Once the difference image has been thresholded, the extractPointer function 124 is called (step 162) to extract the pointer ptr from the difference image iDiff and ignore the noise. The size of the pointer ptr is then examined to determine if it is greater than a threshold value MIN_PTR_SIZE (step 164).


If the size of the pointer is greater than the threshold value MIN_PTR_SIZE, the centerOfMass( ) function 126 is called (step 166) to determine the center of the pointer. Following this, the processROI( ) function 128 is called (step 168) to select a region of interest ROI within the difference image iDiff and extract the pointer from the region of interest.


Once the pointer has been extracted from the region of interest ROI, the size of the extracted pointer is determined (step 170). If the pointer size is greater than zero, a medianLine function is called (step 172). During execution of the medianLine function, the median line of the pointer (i.e. the pointer location within the region of interest) is calculated using linear least squares. The current image iCurr is then designated as the previous image iPrev to complete the findPointerMotion( ) function.


At step 164, if the pointer size is equal to zero, the center of mass parameters Cx and Cz are examined (step 174). If both of the center of mass parameters Cx and Cz have values greater zero, the processROI( ) function 128 is called (step 168) to select a region of interest ROI within the difference image iDiff and extract the pointer from the region of interest. At step 174, if one or both of the center of mass parameters Cx and Cz have values equal to zero or at step 170, if the size of the pointer is less than zero, a no pointer found condition is determined (step 176). At this stage, the current image iCurr is designated as a calibration image glRef. The findPointerMotion( ) function then proceeds to step 152 where the center of mass parameters Cx and Cz are assigned zero values.


As mentioned above, at step 158, when the findPointerMotion( ) function 120 calls the autoSelectThres( ) function 122, a threshold value for the difference image iDiff is selected based on the histogram of the difference image so that when the difference image iDiff is thresholded, the pointer is further highlighted from background features and noise. Selection of the threshold value in this manner is more robust than hardcoding the threshold value.


Turning now to FIG. 9, the steps performed during execution of the autoSelectThres( ) function 122 are illustrated. As can be seen, in order to select the threshold level, a histogram of the difference image iDiff is taken and the number of pixels in each bin of the histogram are counted (step 200). The number of pixels in the bin having the highest count is used as a peak parameter and the threshold value is initially assigned a value of one (step 202). The number of bins having non-zero counts is then examined to determine if more than eight (8) bins have non-zero counts (step 204). If less than eight (8) bins have non-zero counts, the threshold value remains at its initially assigned value and the autoSelectThres( ) function is completed.


At step 204, if more than eight (8) bins have non-zero counts, the number of non-zero bins is checked again to determine if an entire difference image is being processed (i.e. the autoSelectThres( ) function was called by the findPointerMotion( ) function 120) or if a region of interest ROI within the difference image is being processed (i.e. the autoSelecThres( ) function was called by the processROI( ) function 128) (step 206). If the entire difference image iDiff is being processed, a threshold minimum parameter (tMin) is set to a value of twelve (12) and a Peak_Div parameter is set to a value of eight (8) (step 208). A minimum count parameter minCount is then calculated by dividing the peak parameter determined at step 202 by the Peak_Div parameter (step 210). If a region of interest is being processed, the threshold minimum parameter (tMin) is set to a value of forty (40) and the Peak_Div parameter is set to a value of thirty-two (32) (step 212) before proceeding to step 210.


Once minCount has been determined, the peak level is checked to determine if it is greater than the threshold minimum tmin (step 214). Peak level is the grayscale level that contains the most pixels. In the case of a tie, the grayscale level with the highest numerical value (i.e. the closest to 255) is chosen. If the peak level is greater than the threshold minimum tMin, a startLevel parameter is assigned a value equal to the peak level+1 (step 216). At step 214, if the peak level is less than the threshold minimum tMin, the startLevel parameter is assigned a value equal to the threshold minimum tMin (step 218).


Following step 216 or 218, a loop is entered. During the loop, the levCount for each bin having a bin number between the value of the startLevel parameter and two hundred and fifty-five (255) is examined to determine if it is greater than zero and if it is less than the minCount parameter determined at step 210 (step 220). If the condition is met during the loop, the loop is exited and the threshold value is assigned a value equal to the bin number having the levCount that resulted in the loop being exited+1 (step 222). If the condition is not met, the loop is exited after the levCount for bin number 255 has been checked.


Once the loop has been exited, the threshold value is checked to determine if it is less than the minimum threshold value tMin (step 224). If not, a check is again made to determine if an entire difference image is being processed or whether a region of interest ROI is being processed (step 226). If the threshold value is less than the minimum threshold value tMin, the threshold value is set equal to the minimum threshold value tMin (step 228) before the check is made to determine if an entire difference image is being processed or whether a region of interest is being processed (step 226).


At step 226, if a difference image iDiff is being processed, the autoSelectThres( ) function is completed. However, if a region of interest is being processed, a parameter p is assigned a value corresponding to the first grayscale level at which 90% or more of the pixels will go black (step 230). The parameter p is then compared to the threshold level (step 232). If the parameter p is less than the threshold level, the autoSelectThres( ) function is completed. If the parameter p is greater than the threshold level, the threshold value is set to the value of parameter p (step 234) and the autoSelectThres( ) function is completed.


As mentioned above, at step 162 the findPointerMotion( ) function 120 calls the extractPointer( ) function 124 to extract the pointer from the binary image and ignore the noise. This is done by selecting the “white region” in the binary image that is greater than or equal to a certain minimum size and is the highest region (i.e. the largest in the y-axis (20 pixel axis)). Specifically, when the extractPointer( ) function 124 is called, the extractPointer( ) function calls the getHighestRegion( ) function 130 (step 250). The getHighestRegion( ) function 130 uses the threshold value and tol parameters to select the appropriate white region szRegion in the thresholded difference image. The tol parameter is used to avoid situations where board surface noise is mistaken as a pointer. FIG. 13 shows the steps performed during this function.


Once the white region szRegion has been selected, the white region szRegion is checked to see if it is greater than zero (step 252). If not, a no pointer condition is determined (step 254). If the white region szRegion is greater than zero, morphological operator of erosion and dilation are used on the white region to reduce further noise (steps 256 to 264) and the extractPointer( ) function is completed.


As mentioned above, at step 166 the findPointerMotion( ) function 120 calls the centerOfMass( ) function 126 to determine the center of the pointer. During this function, the black pixels in the binary image are treated as having a mass of zero (0) and the white pixel are treated as having a mass of one (1). The physics formulae for center-of-mass are used. The equation below gives the center of mass in the x-direction:

Cx=sum((Xi)/M)

where:


Xi are the x-coordinates of the white pixels in the binary image; and


M is the number of white pixels in the binary image.


Initially, once the centerOfMass( ) function is executed, the center of mass parameters massX, massZ and a mass parameter are assigned zero values (see step 300 in FIG. 11). A loop is then entered to calculate the center of mass parameters massX and massZ using the above equation and to calculate the mass parameter (step 302).


Upon exiting the loop, the mass parameter is checked to determine if its value is greater than zero (step 304). If the value of the mass parameter is equal to zero, the center of mass parameters Cx and Cz are assigned values of zero (step 306) and the centerOfMass( ) function 126 is completed. At step 304, if the value of the mass parameter is greater than zero, the center of mass coordinates Cx and Cz are calculated (step 308) using the equations:

Cx=massX/mass; and
Cz=massZ/mass.


Once the center of mass coordinates have been calculated, the centerOfMass( ) function 126 is completed.


As mentioned above, at step 168 the findPointerMotion( ) function 120 calls the processROI( ) function 128 to process the region-of-interest in a manner similar to the findPointerMotion( ) function 120 except, here the image size is 100×20 pixels and a calibration image including only background (i.e. no pointer) is used in place of the previous image. Upon execution of the processROI( ) function 128, xLeft and xRight parameters are calculated by subtracting and adding fifty (50) to the center of mass parameter Cx (step 350). The value of parameter xLeft is then checked to determine if it is less than one (1) (step 352). If the parameter xLeft has a value less than one (1), the parameter xRight is recalculated and the parameter xLeft is assigned a value of one (1) (step 354) to define boundaries of the region of interest as shown in FIG. 15. A difference image iDiff of the region of interest is then calculated by subtracting the region of interest of the current image from the region of interest of the calibration image glRef determined at step 176 of the findPointerMotion( ) function 120 and taking the absolute value of the difference (step 356).


At step 352, if the parameter xLeft has a value greater than one (1), the parameter xRight is checked to determine if it has a value greater than 640 (step 358). If the parameter xRight has a value greater than 640, the parameter xLeft is recalculated and the parameter xRight is assigned a value of one (1) (step 360) to define boundaries of the region of interest. The processROI( ) function 128 then proceeds to step 356 to calculate the difference image iDiff of the region of interest. At step 358, if the parameter xRight has a value less than 640, the processROI( ) function 128 proceeds directly to step 356 to calculate the difference image iDiff of the region of interest.


Once the difference image iDiff of the region of interest has been calculated, the autoSelectThres( ) function 122 is called to select a threshold value for the difference image iDiff of the region of interest (step 362) in the manner described above with reference to FIG. 9. The difference image iDiff of the region of interest is then thresholded (step 364). Following this, the extractPointer( ) function 124 is called to extract the pointer from the difference image iDiff of the region of interest (step 366) in the manner described above with reference to FIG. 10.


Once the acquired image has been processed in the above manner, a PIP for the acquired image is created by the DSP 84. The PIP is a five (5) word packet and has a layout including camera identification, an LRC checksum to ensure data integrity and a valid tag to ensure zero packets are not valid. The valid tag indicates whether the PIP relates to a pointer characteristic packet (10), a diagnostic packet for a specific camera assembly 63 (01) or a diagnostic packet for all camera assemblies 63 (11). Table 1 below shows the PIP layout.

























TABLE 1





Word
15
14
13
12
11
10
9
8
7
6
5
4
3
2
1
0















Pointer Characteristics packet (generated by Camera)










0
Valid
Camera
X Intercept (at Y0)



tag
#









1
Frame rate
intensity/color









2
Packet #
pointer area


3
Unused
X intercept (at Y19)










4
Unused
Z position
LRC checksum







Diagnostic Packet (generated by Camera or Master)










0
Valid
Camera




tag
#


1









2
Packet #



3









4

LRC checksum









As mentioned above, each camera assembly 63 acquires and processes an image in the manner described above in response to each clock signal generated by its DSP 84. The PIPs created by the DSPs 84 are only sent to the master controller 54 when the camera assemblies 63 are polled by the master controller. The DSPs 84 create PIPs faster than the master controller 54 polls the camera assemblies 63. PIPs that are not sent to the master controller 54 are overwritten.


When the master controller 54 polls the camera assemblies 63, frame sync pulses are sent to the camera assemblies 63 to initiate transmission of the PIPs created by the DSPs 84. Upon receipt of a frame sync pulse, each DSP 84 transmits the PIP to the master controller 54 over the data bus. The PIPs transmitted to the master controller 54 are received via the serial port 96 and auto-buffered into the DSP 90.


After the DSP 90 has polled the camera assemblies 63 and has received PIPs from each of the camera assemblies, the DSP 90 processes the PIPs using triangulation to determine the location of the pointer relative to the touch surface 60 in (x,y) coordinates. Specifically, the PIPs from pairs of camera assemblies 63 are processed using triangulation.



FIG. 16 shows that two angles φ1 and φ2 are needed to triangulate the position (x0,y0) of the pointer relative to the touch screen 60. The PIPs generated by each camera assembly 63 include a number θε[0,sensorResolution−1] (see FIG. 17) identifying the median line of the pointer. The sensor Resolution, in the case of the Photobit PB300 image sensor, is 640. The equations below relate the angle φ to the position θ taking into account the field-of-view of the image sensor and lens assembly 80:









ϕ
=



θ
sensorResolution

×

F
ov


-
δ





(
1
)






ϕ
=




SensorResolution
-
θ

sensorResolution

×

F

ov







-
δ





(
2
)







The above equations subtract away an angle δ that allows the image sensor and lens assembly 80 to have some overlap with the frame 62. The overlap with the frame 62 is desired due to mechanical tolerance issues in the frame assemblies 64 (i.e. the angle of the plate 66 can have an error of 1° to 2°). The angle δ is allowed to be negative, meaning that there is no overlap with the frame 62, in fact part of the touch surface 60 along the frame 62 is missed. Equation 1 or 2 is used to determine. φ, depending on the mounting and/or optical properties of the image sensor and lens assembly 80. If the image acquired by the camera assembly 63 is rotated as a result of the mounting and/or optical properties of the image sensor and lens assembly 80, then equation 2 is used. Equation 1 is used otherwise. In the present embodiment, equation 1 is used with the camera assemblies 63 positioned at the top left and bottom right corners of the touch screen 52 and equation 2 is used with the camera assemblies 63 positioned at the bottom left and top right corners of the touch screen 52.


As discussed above, equations 1 and 2 allow the pointer median line data included in the PIPs to be converted by the DSP 90 into an angle φ with respect to the x-axis. When two such angles are available, the intersection of the median lines extending at these angles from their respective camera assemblies 63 yields the location of the pointer relative to the touch surface 60.


In this embodiment, since the touch screen 52 includes four camera assemblies 63, six pairs of camera assemblies can be used for triangulation. The following discussion describes how a pointer position is determined by triangulation for each pair of the camera assemblies 63.


In order to determine a pointer position using the PIPs received from the camera assemblies 63 along the left side of the touch screen 52, the following equations are used to determine the (x0,y0) coordinates of the pointer position given the angles φ0 and φ1 for the upper and lower camera assemblies:










x
0

=


h
w

×

1


tan


(

ϕ
0

)


+

tan


(

ϕ
1

)









(
3
)







y
0

=


tan


(

ϕ
0

)




tan


(

ϕ
0

)


+

tan


(

ϕ
1

)








(
4
)








where:


h is the height of the touch screen 52 i.e. the vertical distance from camera assembly focal point-to-focal point;


w is the width of the touch screen 52 i.e. the horizontal distance from camera assembly focal point-to-focal point; and


φi is the angle with respect to the horizontal, measured using camera assembly i and equation 1 or 2.


For the camera assemblies 63 along on the right side of the touch screen 52, the following equations are used to determine the (x0, y0) coordinates of the pointer position given the angles φ2 and φ3 for the upper and lower camera assemblies:










x
0

=

1
-


h
w

×

1


tan


(

ϕ
2

)


+

tan


(

ϕ
3

)










(
5
)







y
0

=

1
-


tan


(

ϕ
2

)




tan


(

ϕ
2

)


+

tan


(

ϕ
3

)









(
6
)







The similarity between equations 3 and 5, i.e. equation 5=1-equation 3 once φ2 and φ3 have been substituted into equation 3 for φ1 and φ2 respectively should be apparent. Equations 4 and 6 are related in a similar manner.


In order to determine a pointer position using the camera assemblies 63 along the bottom of the touch screen 52, the following equations are used to determine the (x0, y0) coordinates of the pointer position given the angles φ0 and φ3 for bottom left and bottom right camera assemblies:










x
0

=


tan


(

ϕ
3

)




tan


(

ϕ
0

)


+

tan


(

ϕ
3

)








(
7
)










y
0

=




w
h

×


tan


(

ϕ
3

)




tan


(

ϕ
0

)


+

tan


(

ϕ
3

)




×

tan


(

ϕ
0

)









=




w
h

×

x
0

×

tan


(

ϕ
0

)










(
8
)







In order to determine a pointer position using the camera assemblies 63 along the top of the touch screen 52, the following equations are used to determine the (x0, y0) coordinates of the pointer position given the angles φ1 and φ2 for the top left and top right camera assemblies:










x
0

=


tan


(

ϕ
2

)




tan


(

ϕ
1

)


+

tan


(

ϕ
2

)








(
9
)










y
0

=



1
-


w
h

×


tan


(

ϕ
2

)




tan


(

ϕ
1

)


+

tan


(

ϕ
2

)




×

tan


(

ϕ
1

)










=



1
-


w
h

×

x
0

×

tan


(

ϕ
1

)











(
10
)







The similarity between equations 7 and 9, i.e. equation 9=equation 7 once φ1 and φ2 have been substituted into equation 7 for φ0 and φ3 should be apparent. Equations 8 and 10 have the following relationship: equation 10=1-equation 8 once φ1 and φ2 have been substituted into equation 8 for φ0 and φ3 respectively.


In order to determine a pointer position using the camera assemblies 63 across the bottom left to top right corner diagonal, the following equations are used to determine the (x0,y0) coordinates of the pointer position given the angles φ0 and φ2 for bottom left and top right camera assemblies:










x
0

=



h
w

-

tan


(

ϕ
2

)





tan


(

ϕ
0

)


-

tan


(

ϕ
2

)








(
11
)







y
0

=



1
-

w
h

-

tan


(

ϕ
2

)





tan


(

ϕ
0

)


-

tan


(

ϕ
2

)




×

tan


(

ϕ
0

)







(
12
)







In order to determine a pointer position using the camera assemblies 63 across the bottom right to top left diagonal, the following equations are used to determine the (x0,y0) coordinates of the pointer position given the angles φ1 and φ3 for the bottom right and top left camera assemblies:










x
0

=



h
w

-

tan


(

ϕ
3

)





tan


(

ϕ
1

)


-

tan


(

ϕ
3

)








(
13
)







y
0

=

1
-



1
-

w
h

-

tan


(

ϕ
3

)





tan


(

ϕ
1

)


-

tan


(

ϕ
3

)




×

tan


(

ϕ
1

)








(
14
)







The similarity between equations 11 and 13, i.e. equation 13=equation 11 once °1 and °3 have been substituted into equation 11 for φ0 and φ2 should be apparent. Equations 12 and 14 have the following relationship: equation 14=1-equation 12 once φ1 and φ3 have been substituted into equation 12 for φ0 and φ2 respectively.


As will be appreciated, the above equations generate the coordinates x0 and y0 on a scale of [0, 1]. Therefore, any appropriate coordinate scale can be reported by multiplying x0 and y0 by the maximum X and maximum Y values respectively.


In the present embodiment, the DSP 90 calculates the pointer position using triangulation for each camera pair excluding the diagonal pairs. The resulting pointer positions are then averaged and the resulting pointer position coordinates are queued for transmission to the personal computer 56 via the serial port 98 and the serial line driver 94. Since the rows of pixels of the image sensor and lens assemblies 80 that correspond to actual contacts with the touch surface 60 are known, any Z-position in a PIP that does not correspond with one of these rows is by definition a pointer hover event.


If desired, pointer velocity and angle can be calculated by the DSP 90 as shown in FIG. 18. The velocity of the pointer is calculated by examining the changes in the Z-position (or X-intercept) of the pointer in successive PIPs and knowing the camera frame rate. For example, if the camera frame rate is 200 frames per second and the Z-position changes by 1 pixel per frame, the pointer velocity is 200 pixels per second.


The angle of the pointer can be determined due to the fact that the PIP includes the X-intercept at pixel rows 0 and 19 of the median line. Since the X distance (the difference between X-intercepts) and the Y distance (the number of pixel rows) are known, all of the information necessary to calculate the pointer angle is available.


The present invention provides advantages in that the passive touch system 50 does not suffer parallax and/or image distortion problems due to the fact that a glass or other transparent overlay over a computer or video display is not required. In addition, the present passive touch system 50 allows both pointer contact and pointer hover over the touch surface 60 to be detected by using two-dimensional image sensor and lens assemblies 80 in the plane of the touch surface 60. Pointer contact with the touch surface 60 is defined only when the pointer is in very close proximity of the touch surface. The present invention also provides advantages in that the pointer position with respect to the touch surface is not restricted since the image sensor and lens assemblies 80 look along the plane of the touch surface 60.


With respect to resolution, the resolution of the passive touch system is a function of the distances of the pointer with respect to the image sensor and lens assemblies 80, the number of pixel elements in the image sensor and lens assemblies and the fields of view of the image sensor and lens assemblies. Since image sensor and lens assemblies are available with pixel elements that range in number from tens of thousand to many millions and since the number of pixel elements in image sensors and lens assemblies of this nature is only expected to increase, the resolution of the present passive touch system 50 is high.


The passive touch system 50 also provides advantages in that alignment is automatically corrected since only pixel subsets of images that include the touch surface and the pointer are processed. In addition, the present passive touch system allows for very fast acquisition of image data since the image sensor and lens assemblies can be triggered to capture images at rates exceeding two hundred frames per second.


The present passive touch system 50 is scalable and can include a touch surface 60 of arbitrary size. When used in conjunction with a projected computer image, the number of pixels of the image sensor and lens assemblies should be proportional to the number of pixels being displayed on the touch surface 60. For example, if a projected computer image is 1024×768 pixels, the size of the projected image is not be of concern provided the image sensor and lens assemblies 80 are able to resolve the (x,y) coordinates with sufficient accuracy with respect to the displayed pixels.


Although the passive touch system 50 is shown including camera assemblies 63 associated with each corner of the touch screen 52, those of skill in the art will appreciate that only two camera assemblies are required. In this case, the fields of view of the image sensor and lens assemblies are preferably selected so that the entire touch surface 60 is encompassed since the locations of pointer contacts are determined only when they occur within the overlapping fields of view of the camera assemblies 63.


Also, although the passive touch system 50 is described as including a projector to display the computer display output onto the touch surface 60, this is not required. No information need be displayed on the touch surface.


Although a preferred embodiment of the present invention has been described, those of skill in the art will appreciate that variations and modifications may be made without departing from the spirit and scope thereof as defined by the appended claims.

Claims
  • 1. A method of determining the absolute position of an object relative to a rectangular frame surrounding a region of interest in the front of a display surface from images captured by at least two digital camera devices, each digital camera device being mounted adjacent a different corner of the frame, said method comprising: capturing images with the digital camera devices, each digital camera device having a field of view that (i) images at least a portion of the display surface, (ii) images at least a portion of the frame, and (iii) extends at least beyond an adjacent peripheral edge of said frame, said digital camera devices being oriented to capture overlapping images of said region of interest, at least one of the digital camera devices having a sensor comprising a plurality of pixels extending in at least one direction; andprocessing pixel data of images received from each digital camera device using at least one processor to compensate for an angle between the field of view of each digital camera device and at least a portion of the peripheral edge of the frame and to determine the absolute position of the object relative to the frame.
  • 2. The method of claim 1, wherein said image capturing comprises capturing images with digital camera devices that each comprise a CMOS image sensor.
  • 3. The method of claim 1, wherein each digital camera device comprises a selectable pixel array, and wherein during said processing, pixel data from a subset of pixels of the selectable pixel array of each digital camera device is processed.
  • 4. The method of claim 3, wherein during said processing, pixel data from a subset of contiguous rows of pixels of the selectable pixel array of each digital camera device is processed.
  • 5. The method of claim 3, wherein during said processing, pixel data from a subset of contiguous rows of pixels, that is aligned so that the subset of pixels looks generally along a plane substantially coplanar to said display surface, of the selectable pixel array of each digital camera device is processed.
  • 6. The method of claim 5, wherein during said processing, the row of pixels in the subset of pixels of the selectable pixel array of each digital camera device, that acquires pixel data corresponding to a tip of said pointer within said region of interest, is determined to detect pointer contact and pointer hover over said display surface.
  • 7. A method of determining the absolute position of an object relative to a rectangular frame surrounding a region of interest in the front of a display surface from images captured by at least two imaging assemblies, each imaging assembly being mounted adjacent a different corner of the frame, said method comprising: capturing images with the imaging assemblies, each imaging assembly being oriented so that the fields of view of the imaging assemblies overlap across the front of the display surface and so that the field of view of each imaging assembly extends at least beyond an adjacent peripheral edge of said frame, at least one of the imaging assemblies having a sensor comprising a plurality of pixels extending in at least one direction; andprocessing pixel data of images received from each imaging assembly using at least one processor to compensate for an angle between the field of view of each imaging assembly and at least a portion of the peripheral edge of the frame and to determine the absolute position of the object relative to the frame.
  • 8. The method of claim 7, wherein said image capturing comprises capturing images with imaging assemblies that each comprise a CMOS image sensor.
  • 9. The method of claim 7, wherein during said processing, a subset of pixel data of images captured by each imaging assembly is processed.
  • 10. The method of claim 7, wherein during said processing, a subset of contiguous rows of pixel data of images captured by each imaging assembly is processed.
  • 11. The method of claim 7, wherein during said processing, a subset of contiguous rows of pixel data that is aligned so that the subset looks generally along a plane substantially coplanar to said display surface, of images captured by each imaging assembly is processed.
  • 12. The method of claim 11, wherein during said processing, the row that acquires pixel data corresponding to a tip of said pointer within said region of interest, is determined to detect pointer contact and pointer hover over said display surface.
Parent Case Info

This application is a continuation of U.S. patent application Ser. No. 12/118,407, filed May 9, 2008, which is a continuation of U.S. patent application Ser. No. 11/248,166, filed Oct. 13, 2005 (abandoned), which is a continuation of U.S. patent application Ser. No. 10/408,671, filed Apr. 8, 2003 (abandoned), which is a continuation of U.S. patent application Ser. No. 09/610,481, filed Jul. 5, 2000, now U.S. Pat. No. 6,803,906, which issued Oct. 12, 2004, all of which are incorporated herein by reference.

US Referenced Citations (397)
Number Name Date Kind
2769374 Sick Nov 1956 A
3025406 Stewart et al. Mar 1962 A
3128340 Harmon Apr 1964 A
3187185 Milnes Jun 1965 A
3360654 Muller Dec 1967 A
3478220 Milroy Nov 1969 A
3613066 Cooreman Oct 1971 A
3764813 Clement et al. Oct 1973 A
3775560 Ebeling et al. Nov 1973 A
3857022 Rebane et al. Dec 1974 A
3860754 Johnson et al. Jan 1975 A
4107522 Walter Aug 1978 A
4144449 Funk et al. Mar 1979 A
4243879 Carroll et al. Jan 1981 A
4247767 O'Brien et al. Jan 1981 A
4420261 Barlow et al. Dec 1983 A
4459476 Weissmueller et al. Jul 1984 A
4468694 Edgar Aug 1984 A
4507557 Tsikos Mar 1985 A
4550250 Mueller et al. Oct 1985 A
4553842 Griffin Nov 1985 A
4558313 Garwin et al. Dec 1985 A
4672364 Lucas Jun 1987 A
4673918 Adler et al. Jun 1987 A
4703316 Sherbeck Oct 1987 A
4710760 Kasday Dec 1987 A
4737631 Sasaki et al. Apr 1988 A
4742221 Sasaki et al. May 1988 A
4746770 McAvinney May 1988 A
4762990 Caswell et al. Aug 1988 A
4766424 Adler et al. Aug 1988 A
4782328 Denlinger Nov 1988 A
4811004 Person et al. Mar 1989 A
4818826 Kimura Apr 1989 A
4820050 Griffin Apr 1989 A
4822145 Staelin Apr 1989 A
4831455 Ishikawa May 1989 A
4851664 Rieger Jul 1989 A
4868551 Arditty et al. Sep 1989 A
4868912 Doering Sep 1989 A
4888479 Tamaru Dec 1989 A
4893120 Doering et al. Jan 1990 A
4916308 Meadows Apr 1990 A
4928094 Smith May 1990 A
4943806 Masters et al. Jul 1990 A
4980547 Griffin Dec 1990 A
4990901 Beiswenger Feb 1991 A
5025314 Tang et al. Jun 1991 A
5025411 Tallman et al. Jun 1991 A
5097516 Amir Mar 1992 A
5103085 Zimmerman Apr 1992 A
5105186 May Apr 1992 A
5109435 Lo et al. Apr 1992 A
5130794 Ritchey Jul 1992 A
5140647 Ise et al. Aug 1992 A
5148015 Dolan Sep 1992 A
5162618 Knowles Nov 1992 A
5162783 Moreno Nov 1992 A
5164714 Wehrer Nov 1992 A
5168531 Sigel Dec 1992 A
5179369 Person et al. Jan 1993 A
5196835 Blue et al. Mar 1993 A
5196836 Williams Mar 1993 A
5239152 Caldwell et al. Aug 1993 A
5239373 Tang et al. Aug 1993 A
5272470 Zetts Dec 1993 A
5317140 Dunthorn May 1994 A
5359155 Helser Oct 1994 A
5374971 Clapp et al. Dec 1994 A
5414413 Tamaru et al. May 1995 A
5422494 West et al. Jun 1995 A
5448263 Martin Sep 1995 A
5457289 Huang et al. Oct 1995 A
5483261 Yasutake Jan 1996 A
5483603 Luke et al. Jan 1996 A
5484966 Segen Jan 1996 A
5490655 Bates Feb 1996 A
5502568 Ogawa et al. Mar 1996 A
5525764 Junkins et al. Jun 1996 A
5528263 Platzker et al. Jun 1996 A
5528290 Saund Jun 1996 A
5537107 Funado Jul 1996 A
5554828 Primm Sep 1996 A
5581276 Cipolla et al. Dec 1996 A
5581637 Cass et al. Dec 1996 A
5591945 Kent Jan 1997 A
5594469 Freeman et al. Jan 1997 A
5594502 Bito et al. Jan 1997 A
5617312 Iura et al. Apr 1997 A
5638092 Eng et al. Jun 1997 A
5670755 Kwon Sep 1997 A
5686942 Ball Nov 1997 A
5698845 Kodama et al. Dec 1997 A
5729704 Stone et al. Mar 1998 A
5734375 Knox et al. Mar 1998 A
5736686 Perret, Jr. et al. Apr 1998 A
5737740 Henderson et al. Apr 1998 A
5739479 Davis-Cannon Apr 1998 A
5745116 Pisutha-Arnond Apr 1998 A
5764223 Chang et al. Jun 1998 A
5771039 Ditzik Jun 1998 A
5784054 Armstrong et al. Jul 1998 A
5785439 Bowen Jul 1998 A
5786810 Knox et al. Jul 1998 A
5790910 Haskin Aug 1998 A
5801704 Oohara et al. Sep 1998 A
5804773 Wilson et al. Sep 1998 A
5818421 Ogino et al. Oct 1998 A
5818424 Korth Oct 1998 A
5819201 DeGraaf Oct 1998 A
5825352 Bisset et al. Oct 1998 A
5831602 Sato et al. Nov 1998 A
5909210 Knox et al. Jun 1999 A
5911004 Ohuchi et al. Jun 1999 A
5914709 Graham et al. Jun 1999 A
5920342 Umeda et al. Jul 1999 A
5936615 Waters Aug 1999 A
5940065 Babb et al. Aug 1999 A
5943783 Jackson Aug 1999 A
5963199 Kato et al. Oct 1999 A
5982352 Pryor Nov 1999 A
5988645 Downing Nov 1999 A
5990874 Tsumura Nov 1999 A
6002808 Freeman Dec 1999 A
6008798 Mato, Jr. et al. Dec 1999 A
6031531 Kimble Feb 2000 A
6061177 Fujimoto May 2000 A
6075905 Herman et al. Jun 2000 A
6076041 Watanabe Jun 2000 A
6091406 Kambara et al. Jul 2000 A
6100538 Ogawa Aug 2000 A
6104387 Chery et al. Aug 2000 A
6118433 Jenkin et al. Sep 2000 A
6122865 Branc et al. Sep 2000 A
6128003 Smith et al. Oct 2000 A
6141000 Martin Oct 2000 A
6147678 Kumar et al. Nov 2000 A
6153836 Goszyk Nov 2000 A
6161066 Wright et al. Dec 2000 A
6179426 Rodriguez, Jr. et al. Jan 2001 B1
6188388 Arita et al. Feb 2001 B1
6191773 Maruno et al. Feb 2001 B1
6208329 Ballare Mar 2001 B1
6208330 Hasegawa et al. Mar 2001 B1
6209266 Branc et al. Apr 2001 B1
6215477 Morrison et al. Apr 2001 B1
6222175 Krymski Apr 2001 B1
6226035 Korein et al. May 2001 B1
6229529 Yano et al. May 2001 B1
6252989 Geisler et al. Jun 2001 B1
6256033 Nguyen Jul 2001 B1
6262718 Findlay et al. Jul 2001 B1
6310610 Beaton et al. Oct 2001 B1
6320597 Ieperen Nov 2001 B1
6323846 Westerman et al. Nov 2001 B1
6326954 Van Ieperen Dec 2001 B1
6328270 Elberbaum Dec 2001 B1
6335724 Takekawa et al. Jan 2002 B1
6337681 Martin Jan 2002 B1
6339748 Hiramatsu Jan 2002 B1
6346966 Toh Feb 2002 B1
6352351 Ogasahara et al. Mar 2002 B1
6353434 Akebi et al. Mar 2002 B1
6359612 Peter et al. Mar 2002 B1
6362468 Murakami et al. Mar 2002 B1
6377228 Jenkin et al. Apr 2002 B1
6384743 Vanderheiden May 2002 B1
6414671 Gillespie et al. Jul 2002 B1
6414673 Wood et al. Jul 2002 B1
6421042 Omura et al. Jul 2002 B1
6427389 Branc et al. Aug 2002 B1
6429856 Omura et al. Aug 2002 B1
6429857 Masters et al. Aug 2002 B1
6480187 Sano et al. Nov 2002 B1
6496122 Sampsell Dec 2002 B2
6497608 Ho et al. Dec 2002 B2
6498602 Ogawa Dec 2002 B1
6504532 Ogasahara et al. Jan 2003 B1
6507339 Tanaka Jan 2003 B1
6512838 Rafii et al. Jan 2003 B1
6517266 Saund Feb 2003 B2
6518600 Shaddock Feb 2003 B1
6522830 Yamagami Feb 2003 B2
6529189 Colgan et al. Mar 2003 B1
6530664 Vanderwerf et al. Mar 2003 B2
6531999 Trajkovic Mar 2003 B1
6532006 Takekawa et al. Mar 2003 B1
6540366 Keenan et al. Apr 2003 B2
6540679 Slayton et al. Apr 2003 B2
6545669 Kinawi et al. Apr 2003 B1
6559813 DeLuca et al. May 2003 B1
6563491 Omura May 2003 B1
6567078 Ogawa May 2003 B2
6567121 Kuno May 2003 B1
6570103 Saka et al. May 2003 B1
6570612 Saund et al. May 2003 B1
6577299 Schiller et al. Jun 2003 B1
6587099 Takekawa Jul 2003 B2
6590568 Astala et al. Jul 2003 B1
6594023 Omura et al. Jul 2003 B1
6597348 Yamazaki et al. Jul 2003 B1
6597508 Seino et al. Jul 2003 B2
6603867 Sugino et al. Aug 2003 B1
6608619 Omura et al. Aug 2003 B2
6614422 Rafii et al. Sep 2003 B1
6624833 Kumar et al. Sep 2003 B1
6626718 Hiroki Sep 2003 B2
6630922 Fishkin et al. Oct 2003 B2
6633328 Byrd et al. Oct 2003 B1
6650318 Arnon Nov 2003 B1
6650822 Zhou Nov 2003 B1
6674424 Fujioka Jan 2004 B1
6683584 Ronzani et al. Jan 2004 B2
6690357 Dunton et al. Feb 2004 B1
6690363 Newton Feb 2004 B2
6690397 Daignault, Jr. Feb 2004 B1
6710770 Tomasi et al. Mar 2004 B2
6714311 Hashimoto Mar 2004 B2
6720949 Pryor et al. Apr 2004 B1
6736321 Tsikos et al. May 2004 B2
6738051 Boyd et al. May 2004 B2
6741250 Furlan et al. May 2004 B1
6747636 Martin Jun 2004 B2
6756910 Ohba et al. Jun 2004 B2
6760009 Omura et al. Jul 2004 B2
6760999 Branc et al. Jul 2004 B2
6774889 Zhang et al. Aug 2004 B1
6803906 Morrison et al. Oct 2004 B1
6828959 Takekawa et al. Dec 2004 B2
6864882 Newton Mar 2005 B2
6911972 Brinjes Jun 2005 B2
6919880 Morrison et al. Jul 2005 B2
6927384 Reime et al. Aug 2005 B2
6933981 Kishida et al. Aug 2005 B1
6947032 Morrison et al. Sep 2005 B2
6954197 Morrison et al. Oct 2005 B2
6972401 Akitt et al. Dec 2005 B2
6972753 Kimura et al. Dec 2005 B1
7002555 Jacobsen et al. Feb 2006 B1
7007236 Dempski et al. Feb 2006 B2
7015418 Cahill et al. Mar 2006 B2
7030861 Westerman et al. Apr 2006 B1
7057647 Monroe Jun 2006 B1
7058204 Hildreth et al. Jun 2006 B2
7075054 Iwamoto et al. Jul 2006 B2
7084857 Lieberman et al. Aug 2006 B2
7084868 Farag et al. Aug 2006 B2
7098392 Sitrick et al. Aug 2006 B2
7121470 McCall et al. Oct 2006 B2
7151533 Van Iperen Dec 2006 B2
7176904 Satoh Feb 2007 B2
7184030 McCharles et al. Feb 2007 B2
7187489 Miles Mar 2007 B2
7190496 Klug et al. Mar 2007 B2
7202860 Ogawa Apr 2007 B2
7227526 Hildreth et al. Jun 2007 B2
7232986 Worthington et al. Jun 2007 B2
7236162 Morrison et al. Jun 2007 B2
7237937 Kawashima et al. Jul 2007 B2
7242388 Lieberman et al. Jul 2007 B2
7265748 Ryynanen Sep 2007 B2
7268692 Lieberman Sep 2007 B1
7274356 Ung et al. Sep 2007 B2
7283126 Leung Oct 2007 B2
7283128 Sato Oct 2007 B2
7289113 Martin Oct 2007 B2
7302156 Lieberman et al. Nov 2007 B1
7305368 Lieberman et al. Dec 2007 B2
7330184 Leung Feb 2008 B2
7333094 Lieberman et al. Feb 2008 B2
7333095 Lieberman et al. Feb 2008 B1
7355593 Hill et al. Apr 2008 B2
7372456 McLintock May 2008 B2
7375720 Tanaka May 2008 B2
RE40368 Arnon Jun 2008 E
7411575 Hill et al. Aug 2008 B2
7414617 Ogawa Aug 2008 B2
7479949 Jobs et al. Jan 2009 B2
7492357 Morrison et al. Feb 2009 B2
7499037 Lube Mar 2009 B2
7538759 Newton May 2009 B2
7559664 Walleman et al. Jul 2009 B1
7619617 Morrison et al. Nov 2009 B2
7692625 Morrison et al. Apr 2010 B2
20010019325 Takekawa Sep 2001 A1
20010022579 Hirabayashi Sep 2001 A1
20010026268 Ito Oct 2001 A1
20010033274 Ong Oct 2001 A1
20010050677 Tosaya Dec 2001 A1
20010055006 Sano et al. Dec 2001 A1
20020008692 Omura et al. Jan 2002 A1
20020015159 Hashimoto Feb 2002 A1
20020036617 Pryor Mar 2002 A1
20020041327 Hildreth et al. Apr 2002 A1
20020050979 Oberoi et al. May 2002 A1
20020064382 Hildrerth et al. May 2002 A1
20020067922 Harris Jun 2002 A1
20020075243 Newton Jun 2002 A1
20020080123 Kennedy et al. Jun 2002 A1
20020118177 Newton Aug 2002 A1
20020145595 Satoh Oct 2002 A1
20020163530 Takakura et al. Nov 2002 A1
20030001825 Omura et al. Jan 2003 A1
20030025951 Pollard et al. Feb 2003 A1
20030043116 Morrison et al. Mar 2003 A1
20030046401 Abbott et al. Mar 2003 A1
20030063073 Geaghan et al. Apr 2003 A1
20030071858 Morohoshi Apr 2003 A1
20030085871 Ogawa May 2003 A1
20030095112 Kawano et al. May 2003 A1
20030137494 Tulbert Jul 2003 A1
20030142880 Hyodo Jul 2003 A1
20030151532 Chen et al. Aug 2003 A1
20030151562 Kulas Aug 2003 A1
20030156118 Ayinde Aug 2003 A1
20030161524 King Aug 2003 A1
20030227492 Wilde et al. Dec 2003 A1
20040001144 McCharles et al. Jan 2004 A1
20040012573 Morrison et al. Jan 2004 A1
20040021633 Rajkowski Feb 2004 A1
20040031779 Cahill et al. Feb 2004 A1
20040032401 Nakazawa et al. Feb 2004 A1
20040046749 Ikeda Mar 2004 A1
20040051709 Ogawa et al. Mar 2004 A1
20040108990 Lieberman Jun 2004 A1
20040125086 Hagermoser et al. Jul 2004 A1
20040149892 Akitt et al. Aug 2004 A1
20040150630 Hinckley et al. Aug 2004 A1
20040169639 Pate et al. Sep 2004 A1
20040178993 Morrison et al. Sep 2004 A1
20040178997 Gillespie et al. Sep 2004 A1
20040179001 Morrison et al. Sep 2004 A1
20040189720 Wilson et al. Sep 2004 A1
20040201575 Morrison Oct 2004 A1
20040204129 Payne et al. Oct 2004 A1
20040218479 Iwamoto et al. Nov 2004 A1
20040221265 Leung et al. Nov 2004 A1
20040252091 Ma et al. Dec 2004 A1
20050052427 Wu et al. Mar 2005 A1
20050057524 Hill et al. Mar 2005 A1
20050077452 Morrison et al. Apr 2005 A1
20050083308 Homer et al. Apr 2005 A1
20050104860 McCreary et al. May 2005 A1
20050128190 Ryynanen Jun 2005 A1
20050151733 Sander et al. Jul 2005 A1
20050156900 Hill et al. Jul 2005 A1
20050190162 Newton Sep 2005 A1
20050241929 Auger et al. Nov 2005 A1
20050243070 Ung et al. Nov 2005 A1
20050248539 Morrison et al. Nov 2005 A1
20050248540 Newton Nov 2005 A1
20050270781 Marks Dec 2005 A1
20050276448 Pryor Dec 2005 A1
20060012579 Sato Jan 2006 A1
20060022962 Morrison et al. Feb 2006 A1
20060028456 Kang Feb 2006 A1
20060034486 Morrison et al. Feb 2006 A1
20060152500 Weng Jul 2006 A1
20060158437 Blythe et al. Jul 2006 A1
20060170658 Nakamura et al. Aug 2006 A1
20060197749 Popovich Sep 2006 A1
20060202953 Pryor et al. Sep 2006 A1
20060227120 Eikman Oct 2006 A1
20060244734 Hill et al. Nov 2006 A1
20060274067 Hikai Dec 2006 A1
20060279558 Van Delden et al. Dec 2006 A1
20070002028 Morrison et al. Jan 2007 A1
20070019103 Lieberman et al. Jan 2007 A1
20070075648 Blythe et al. Apr 2007 A1
20070075982 Morrison et al. Apr 2007 A1
20070089915 Ogawa et al. Apr 2007 A1
20070116333 Dempski et al. May 2007 A1
20070126755 Zhang et al. Jun 2007 A1
20070139932 Sun et al. Jun 2007 A1
20070152984 Ording et al. Jul 2007 A1
20070152986 Ogawa et al. Jul 2007 A1
20070165007 Morrison et al. Jul 2007 A1
20070167709 Slayton et al. Jul 2007 A1
20070205994 van Ieperen Sep 2007 A1
20070236454 Ung et al. Oct 2007 A1
20070273842 Morrison et al. Nov 2007 A1
20080029691 Han Feb 2008 A1
20080042999 Martin Feb 2008 A1
20080055262 Wu et al. Mar 2008 A1
20080055267 Wu et al. Mar 2008 A1
20080062140 Hotelling et al. Mar 2008 A1
20080062149 Baruk Mar 2008 A1
20080068352 Worthington et al. Mar 2008 A1
20080083602 Auger et al. Apr 2008 A1
20080106706 Holmgren et al. May 2008 A1
20080122803 Izadi et al. May 2008 A1
20080129707 Pryor Jun 2008 A1
20080259050 Lin et al. Oct 2008 A1
20080259052 Lin et al. Oct 2008 A1
20090058832 Newton Mar 2009 A1
20090058833 Newton Mar 2009 A1
20090146972 Morrison et al. Jun 2009 A1
Foreign Referenced Citations (151)
Number Date Country
2003233728 Dec 2003 AU
2006243730 Nov 2006 AU
2058219 Apr 1993 CA
2367864 Apr 1993 CA
2219886 Apr 1999 CA
2251221 Apr 1999 CA
2267733 Oct 1999 CA
2268208 Oct 1999 CA
2252302 Apr 2000 CA
2350152 Jun 2001 CA
2412878 Jan 2002 CA
2341918 Sep 2002 CA
2386094 Dec 2002 CA
2372868 Aug 2003 CA
2390503 Dec 2003 CA
2390506 Dec 2003 CA
2432770 Dec 2003 CA
2493236 Dec 2003 CA
2448603 May 2004 CA
2453873 Jul 2004 CA
2460449 Sep 2004 CA
2521418 Oct 2004 CA
2481396 Mar 2005 CA
2491582 Jul 2005 CA
2563566 Nov 2005 CA
2564262 Nov 2005 CA
2501214 Sep 2006 CA
2606863 Nov 2006 CA
2580046 Sep 2007 CA
1310126 Aug 2001 CN
1784649 Jun 2006 CN
101019096 Aug 2007 CN
101023582 Aug 2007 CN
1440539 Sep 2009 CN
3836429 May 1990 DE
198 10 452 Dec 1998 DE
60124549 Sep 2007 DE
0125068 Nov 1984 EP
0 279 652 Aug 1988 EP
0 347 725 Dec 1989 EP
0420335 Apr 1991 EP
0 657 841 Jun 1995 EP
0 762 319 Mar 1997 EP
0 829 798 Mar 1998 EP
0897161 Feb 1999 EP
0911721 Apr 1999 EP
1059605 Dec 2000 EP
1262909 Dec 2002 EP
1739528 Jan 2003 EP
1739529 Jan 2003 EP
1420335 May 2004 EP
1 450 243 Aug 2004 EP
1457870 Sep 2004 EP
1471459 Oct 2004 EP
1517228 Mar 2005 EP
1550940 Jun 2005 EP
1611503 Jan 2006 EP
1674977 Jun 2006 EP
1 297 488 Nov 2006 EP
1741186 Jan 2007 EP
1766501 Mar 2007 EP
1830248 Sep 2007 EP
1877893 Jan 2008 EP
2279823 Sep 2007 ES
1575420 Sep 1980 GB
2176282 May 1986 GB
2204126 Nov 1988 GB
2263765 Aug 1993 GB
57-211637 Dec 1982 JP
61-196317 Aug 1986 JP
61-260322 Nov 1986 JP
62-005428 Jan 1987 JP
63-223819 Sep 1988 JP
3-054618 Mar 1991 JP
03-244017 Oct 1991 JP
4-350715 Dec 1992 JP
4-355815 Dec 1992 JP
5-181605 Jul 1993 JP
5-189137 Jul 1993 JP
5-197810 Aug 1993 JP
06-110608 Apr 1994 JP
7-110733 Apr 1995 JP
7-230352 Aug 1995 JP
8-016931 Feb 1996 JP
8-108689 Apr 1996 JP
8-240407 Sep 1996 JP
8-315152 Nov 1996 JP
9-091094 Apr 1997 JP
9-224111 Aug 1997 JP
9-319501 Dec 1997 JP
10-105324 Apr 1998 JP
11-051644 Feb 1999 JP
11-064026 Mar 1999 JP
11-085376 Mar 1999 JP
11-110116 Apr 1999 JP
11-203042 Jul 1999 JP
11-212692 Aug 1999 JP
2000-105671 Apr 2000 JP
2000-132340 May 2000 JP
2001-075735 Mar 2001 JP
2001-142642 May 2001 JP
2001-282456 Oct 2001 JP
2001-282457 Oct 2001 JP
2002-055770 Feb 2002 JP
2002-236547 Aug 2002 JP
2003-65716 Mar 2003 JP
2003-158597 May 2003 JP
2003-167669 Jun 2003 JP
2003-173237 Jun 2003 JP
2005-108211 Apr 2005 JP
2005-182423 Jul 2005 JP
2005-202950 Jul 2005 JP
9807112 Feb 1998 WO
9908897 Feb 1999 WO
9921122 Apr 1999 WO
9928812 Jun 1999 WO
9940562 Aug 1999 WO
0124157 Apr 2001 WO
0131570 May 2001 WO
0163550 Aug 2001 WO
0191043 Nov 2001 WO
0203316 Jan 2002 WO
0207073 Jan 2002 WO
0227461 Apr 2002 WO
03104887 Dec 2003 WO
03105074 Dec 2003 WO
2004072843 Aug 2004 WO
2004090706 Oct 2004 WO
2004102523 Nov 2004 WO
2004104810 Dec 2004 WO
2005031554 Apr 2005 WO
2005034027 Apr 2005 WO
2005106775 Nov 2005 WO
2005107072 Nov 2005 WO
2006002544 Jan 2006 WO
2006092058 Sep 2006 WO
2006095320 Sep 2006 WO
2006096962 Sep 2006 WO
2006116869 Nov 2006 WO
2007003196 Jan 2007 WO
2007019600 Feb 2007 WO
2007037809 Apr 2007 WO
2007064804 Jun 2007 WO
2007079590 Jul 2007 WO
2007132033 Nov 2007 WO
2007134456 Nov 2007 WO
2008128096 Oct 2008 WO
2009029764 Mar 2009 WO
2009029767 Mar 2009 WO
2009146544 Dec 2009 WO
2010051633 May 2010 WO
Related Publications (1)
Number Date Country
20090153523 A1 Jun 2009 US
Continuations (4)
Number Date Country
Parent 12118407 May 2008 US
Child 12391759 US
Parent 11248166 Oct 2005 US
Child 12118407 US
Parent 10408671 Apr 2003 US
Child 11248166 US
Parent 09610481 Jul 2000 US
Child 10408671 US