Optical proximity sensor

Abstract
A sensor including lenses, light emitters, each emitter projecting light out of a lens in a particular emission direction along a detection plane, light detectors, each detector detecting maximum light intensity when light enters a lens at a particular detection angle, a table of hotspots, each hotspot corresponding to an emitter-detector pair, the hotspot being a two-dimensional location in the detection plane along the emission direction of the emitter of the pair where projected light reflected by an object placed at that location, enters the lens for the detector of the pair at the detection angle of the detector, and a processor receiving outputs from the detectors corresponding to detected amounts of projected light reflected by an object in the detection plane, and calculating a two-dimensional location of the object in the detection plane based on the received outputs and based on hotspots for synchronously activated emitter-detector pairs.
Description
FIELD OF THE INVENTION

The field of the present invention is light-based touch screens and proximity sensors and eye-tracking devices.


BACKGROUND OF THE INVENTION

In the prior art, a one-dimensional array of proximity sensors is not accurate enough to determine a two-dimensional location of a pointer within a two-dimensional plane extending from the array.


Laptop computers are typically available in touch screen and non-touch screen versions. It would be advantageous to enable consumers of non-touch screen laptops to enable touch screen functionality when desired. For example, it would be advantageous to enable swipe, pinch and rotate gestures when browsing images or checking a newsfeed. Another example is to enable touch screen functionality in specific situations, e.g., when using a laptop on a drop-down tray table that is so close to the user, it is more comfortable to use one's fingers to touch the screen than to use the laptop's built-in trackpad. It would also be advantageous to provide more intuitive user interfaces that track the user's focus of attention.


SUMMARY

There is provided in accordance with an embodiment of the present invention a user interface system, including a display surface displaying thereon a plurality of controls representing different applications, a multi-faceted housing situated along a single edge of the display surface, including an eye tracker mounted in a first facet of the housing, the first facet being distal from the display surface, the eye tracker identifying a control on the display surface at which a user's eyes are directed, and a proximity sensor mounted in a second facet of the housing, the second facet being between the first facet and the display, the proximity sensor detecting a gesture performed by an object opposite the second facet, and a processor running the different applications, connected to the proximity sensor and to the eye tracker, causing the application represented by the control identified by the eye tracker to receive as input the gesture detected by the proximity sensor.


There is additionally provided in accordance with an embodiment of the present invention a single straight bar, including an eye tracker identifying a location on the display at which a user's eyes are directed, when the user is gazing at the display, a proximity sensor detecting a gesture performed by an object in a detection plane that forms an acute angle with the direction of the user's gaze, means for repeatedly attaching the bar to and detaching the bar from an exterior housing of a computer display, and a communication port through which the identified location and the detected gesture are transmitted to a processor running different applications, each application having an associated control displayed on the computer display, wherein the processor in turn provides an input based on the gesture detected by the proximity sensor, to the application associated with the control that is displayed at the location identified by the eye tracker.


In certain embodiments, the eye tracker includes a plurality of first vertical-cavity surface-emitting lasers (VCSELs) mounted in the housing such that each first VCSEL illuminates a different section of the airspace opposite the housing, at least two camera sensors mounted in the housing receiving light emitted by the VCSELs reflected by the user, and outputting images thereof, an image processor receiving the output images from the camera sensors, identifying a location on the display surface at which the user's eyes are directed, and identifying the VCSELs that illuminated the user's eyes, and an activation unit receiving the image processor outputs, selectively activating the VCSELs identified by the image processor, wherein the image processor and the activating unit iteratively repeat the identifying a location, the identifying the VCSELs, and the selectively activating.


In certain embodiments, the proximity sensor includes a linear array of interlaced second VCSELs and photodiode detectors mounted on a printed circuit board such that each of the second VCSELs illuminates a different section of the airspace opposite the second facet of the housing, wherein the object reflects light, projected by the second VCSELs, back towards the photodiode detectors, and wherein the eye tracker activation unit synchronously activates the second VCSELs with the photodiode detectors only when the eye tracker VCSELs are not activated.


There is further provided in accordance with an embodiment of the present invention a proximity sensor for identifying a proximal object, including a housing, at least one light emitter mounted in the housing, each emitter operable when activated to project a light beam out of the housing, a plurality of light detectors mounted in the housing, each detector operable when activated to output a measure of an amount of light arriving at that detector, a plurality of lenses mounted in the housing, each lens, denoted L, being positioned in relation to a respective one of the detectors, denoted D, such that light entering lens L is maximally detected at detector D when the light enters lens L at an angle of incidence θ, and a processor connected to the emitters and to the detectors, operable to activate all of the detectors synchronously with activation of each emitter, the processor configured to calculate a location of a reflective object along a path of a light beam projected by an activated emitter, by (i) calculating an axis of symmetry with respect to which the outputs of the synchronously activated detectors are approximately symmetric, (ii) orienting the calculated axis of symmetry by the angle θ, and (iii) locating a point of intersection of the path of the emitted light beam with the oriented axis of symmetry.


In certain embodiments, the processor calculates the estimated axis of symmetry based on detector outputs surrounding a maximal detector output.





BRIEF DESCRIPTION OF THE DRAWINGS

The present invention will be more fully understood and appreciated from the following detailed description, taken in conjunction with the drawings in which:



FIG. 1 is a simplified illustration of a combined eye tracker and gesture sensor, featuring a multi-faceted housing that includes an eye tracker mounted in a first facet of the housing and a proximity sensor mounted in a second facet of the housing adjacent the first facet, wherein the proximity sensor is oriented to detect gestures on a display, in accordance with an embodiment of the present invention;



FIG. 2 is a simplified flow chart of a method for operating the combined proximity sensor and eye tracker of FIG. 1, in accordance with an embodiment of the present invention;



FIG. 3 is a simplified illustration of components in the combined proximity sensor and eye tracker of FIG. 1, in accordance with an embodiment of the present invention;



FIG. 4 is a simplified waveform illustrating how the eye tracker and proximity sensor are activated by a shared controller, in accordance with an embodiment of the present invention;



FIG. 5 is a simplified illustration of a combined eye tracker and gesture sensor, featuring a multi-faceted housing that includes an eye tracker mounted in a first facet of the housing and a proximity sensor mounted in a second facet of the housing adjacent the first facet, wherein the proximity sensor is oriented to detect gestures on a keyboard or surface in front of a display, in accordance with an embodiment of the present invention;



FIGS. 6-9 are simplified illustrations of a proximity sensor, in accordance with an embodiment of the present invention;



FIG. 10 is an illustration of maximum detected forward reflections for a single emitter beam in a proximity sensor, in accordance with an embodiment of the present invention;



FIG. 11 is a simplified illustration of a first scenario in which there is a single maximum detection signal corresponding to a reflection beam, in accordance with an embodiment of the present invention;



FIG. 12 is a simplified illustration of a second scenario in which there are two maximum detection signals corresponding to reflection beams, indicating that the maximum reflection is probably between these two reflection beams, in accordance with an embodiment of the present invention;



FIG. 13 is a simplified illustration of a method for calculating a degree to which a current distribution of detection signals is similar to a pattern of detected reflection signals generated when an object is inserted into the path of a projected light beam, in accordance with an embodiment of the present invention;



FIG. 14 is a simplified illustration of a plurality of hotspots in a detection area adjacent a calibrated proximity sensor, in accordance with an embodiment of the present invention;



FIG. 15 is a simplified illustration of raw data signals from a proximity sensor, in accordance with an embodiment of the present invention;



FIG. 16 is a simplified illustration of signals from a proximity sensor, before and after normalization, in accordance with an embodiment of the present invention;



FIG. 17 is a simplified illustration of filtered signals from a proximity sensor detecting an object in the sensor's detection area, in accordance with an embodiment of the present invention; and



FIG. 18 is a simplified illustration of a calibration tool for a proximity sensor, in accordance with an embodiment of the present invention.





The following table catalogs the numbered elements and lists the figures in which each numbered element appears. Similarly numbered elements represent elements of the same type, but they need not be identical elements.












Numbered Elements











Element
Description
Figures







100
emitters
3



101-110
emitter
6-10, 18



120
emitter array
1, 3, 5



200
detectors
3



201-211, 217
detector
6- 10, 18



221, 222
camera sensor
1, 3, 5



302, 304-307, 316
lens
6-10, 18



400
light beams
1, 5



404, 409
emitted light beam
6-13, 18



404.01-404.23
forward reflected light
6, 8, 10-13, 18



(odd numbers after
beam




decimal point)





404.04, 409.04
backward reflected light
7, 8




beam




501
proximity sensor
1, 3, 5-9, 14, 18



502
eye tracker
1



601
housing
1, 3, 5



602
keyboard
5



603
laptop computer
5



701
controller
3, 6-9, 18



801
display
1, 5



802-804
user interface control
1, 5



901, 902
shaft
18



903
motor
18



904, 904.01-904.12,
hotspot location
6-13



905, 909





905
reflective calibration
18




object




906
arrow
18



911
reflective object
6-9



912
calculated location of
11-13




object




921-923
axis of symmetry
11-13



930-932
time period
4



940
detection area
14



1001-1009
flowchart operation
2










DETAILED DESCRIPTION

Reference is made to FIG. 1, which is a simplified illustration of a combined eye tracker and gesture sensor, featuring a multi-faceted housing 601 that includes an eye tracker 502 mounted in a first facet of the housing and a proximity sensor 501 mounted in a second facet of the housing adjacent the first facet, wherein the proximity sensor is oriented to detect gestures on a display, in accordance with an embodiment of the present invention. Housing 601 is used with a PC or smart TV display 801 that presents controls 802-804 for activating tasks or applications, in accordance with an embodiment of the present invention. Proximity sensor 501 is operable to detect gestures performed by a reflective object on or near display 801. Eye tracker 502 is operable to identify a direction of a user's gaze and output that information to the PC or smart TV that maps that directional gaze to one of controls 802-804 on display 801. In certain embodiments of the invention, the task or application represented by that control receives as input the gesture detected by proximity sensor 501.


In FIG. 1, housing 601 is placed along the bottom edge of display 801. Proximity sensor 501 projects light beams 400 substantially parallel to the surface of display 801, through a facet of housing 601 facing display 801. When an object touches the surface of display 801, that object reflects a portion of beams 400 back towards proximity sensor 501. These reflected beams are detected by light detectors mounted in housing 601. Based on these detected reflected beams, touch gestures on display 801 are identified, as explained below.


Gesture detection data from proximity sensor 501 is transferred to the PC or smart TV in different formats according to how proximity sensor 501 is configured, and this configuration can be changed during operation of proximity sensor 501. In one mode, gesture detection data from proximity sensor 501 is transferred in Human Interface Device (HID) format for touch screens whereby the gesture coordinates are mapped to absolute screen coordinates. In another mode, gesture detection data from proximity sensor 501 is transferred in HID format for trackpads, whereby the gesture coordinates are relative coordinates, e.g., a slide left gesture moves a screen cursor left, regardless of where the gesture is detected in the proximity sensor detection zone. In another mode, gesture detection data from proximity sensor 501 is transferred in HID format for keyboards, whereby the gesture is interpreted into key presses, e.g., the detection area is mapped to a virtual keyboard such that tap gestures at different locations are transmitted as key presses of corresponding keys in the virtual keyboard, or a slide left gesture at the outer right edge of the screen is transmitted as the key-press combination Windows key+C which is the keyboard shortcut for opening the Charms bar in the Windows® operating system. WINDOWS is a registered trademark of Microsoft Corporation. In yet another mode, the detection signals are transmitted in a custom HID format which is read and interpreted by an application running on the PC or smart TV.


Proximity sensor 501 will change its mode of transmitting gesture data in response to detecting specific gestures or in response to configuration commands received from an application running on the PC or smart TV. For example, even when proximity sensor 501 is configured to output data in touch screen format, a sweep left gesture at the right edge of the screen is transmitted as the key-press combination Windows key+C. In some embodiments, when proximity sensor 501 is facing upwards, it is internally configured to output data in touch screen mode and when proximity sensor 501 is facing the user, it is internally configured to output data in trackpad mode or keyboard mode. Furthermore, when proximity sensor 501 is facing the user and attached to a display it is internally configured to output data in keyboard mode, as it is assumed that the detection area is directly above a keyboard, and when proximity sensor 501 is facing the user but detached from any display, it is internally configured to output data in trackpad mode, as it is assumed that the detection area is directly above a tabletop with no keypad indicia. In some embodiments, an accelerometer or orientation sensor is mounted in housing 601 to detect the direction proximity sensor 501 is facing.


Eye tracker 502 includes an array 120 of VCSELs that project infra-red light or near infra-red light, through an outward-facing facet of housing 601, adjacent the proximity sensor facet, towards the user of display 801. This light is reflected by the eye and captured by camera sensors 221 and 222 mounted along the outward-facing facet of housing 601. The camera images are analyzed to extract eye rotation from changes in the captured reflections. In some embodiments of the invention the eye is identified by corneal reflection (the first Purkinje image) and the center of the pupil. In other embodiments, the eye is identified using reflections from the front of the cornea (first Purkinje image) and the back of the lens (fourth Purkinje image). In still other embodiments of the invention, features from inside the eye are tracked as the eye rotates, such as the retinal blood vessels.


By identifying the direction of the user's gaze toward display 801, the eye tracker enables the PC or smart TV to identify which of controls 802-804 the user is gazing at. Subsequent input actions such as taps, sweep gestures or spread gestures are then applied to the application or task corresponding to the thus identified control, regardless of where the input action is performed. For example, when the PC or smart TV identifies that the user is gazing at a scrollbar, subsequent slide gestures scroll the active document, and when the PC or smart TV identifies that the user is gazing at a volume slider control, subsequent slide gestures move the slider thumb to change the volume. This can be accomplished in several ways, inter alia, (1) by configuring proximity sensor 501 to output data in HID keyboard format and outputting an appropriate keyboard command to scroll the document or change the volume, (2) by configuring proximity sensor 501 to output data in HID trackpad format to move the slider thumb, or (3) by configuring proximity sensor 501 to output data in HID custom format and configuring the volume or document application to receive that data and interpret it. In some embodiments of the present invention, the control thus-identified by the PC or smart TV is enlarged, highlighted, or otherwise altered, to indicate to the user that subsequent input gestures will be applied to that control.


In some embodiments of the present invention, housing 601 includes a magnet for attaching and detaching housing 601 to a ferromagnetic exterior housing of a computer display or smart TV.


Reference is made to FIG. 2, which is a simplified flow chart of a method for operating the combined proximity sensor 501 and eye tracker 502 of FIG. 1, in accordance with an embodiment of the present invention. At operation 1001 the VCSELs in array 120 are activated and their reflections are captured by cameras 221 and 222. At operation 1002 the captured images are analyzed to extract the eye reflections as discussed hereinabove. In certain embodiments, the method further identifies, at operation 1003, which VCSELs in array 120 generated the retinal reflections and in a subsequent operation 1001, only those VCSELs identified at operation 1003 are activated. By tracking and activating only those VCSELs needed to generate retinal reflections, this system saves power.


In some embodiments of the invention, the VCSELs are activated individually, enabling the system to identify which VCSEL generated the retinal reflections. In other embodiments, multiple VCSELs are activated at once, but the area illuminated by each VCSEL within each captured image is known. Thus, the system is able to identify which VCSEL generated the retinal reflections by determining the location in the captured images at which the retinal reflections appear. Subsequently, only the identified VCSELs are activated. In some embodiments, VCSELs surrounding the thus-identified VCSEL are also activated at operations 1001. In some embodiments the VCSELs surrounding the thus-identified VCSEL are activated when retinal reflections are no longer captured by activating the identified VCSEL, as it is assumed that the retina has moved slightly from its previous location.


At operation 1004, emitters 100 and receivers 200 of proximity sensor 501 are activated, and at operation 1005 proximity sensor 501 processes the reflections detected by receivers 200 to identify the location of a touch object. By tracking the object's location over time, gestures are detected.


At operation 1006 a decision is taken by the PC or smart TV as to whether to combine the outputs of proximity sensor 501 and eye tracker 502. If the decision is affirmative, at operation 1007 the detected gesture is applied to the application or task corresponding to the control identified at operation 1002 by the PC or smart TV configuring proximity sensor 501 to output gesture data in an appropriate HID format. As discussed hereinabove, proximity sensor output can be configured as a specific command, e.g., as a key-press combination or in a custom format interpreted by the application. This is indicated by operation 1008. Conversely, if the decision is negative, at operation 1009 the proximity sensor data is output in a different format, e.g., in HID format for a touch screen device. In certain embodiments, proximity sensor 501 is only activated after eye tracker 502 identifies a control at which the user's gaze is directed and to which subsequent gestures will be applied. Furthermore, because the detected gesture is applied to the identified control, the gesture can be relative, rather than absolute; i.e., the gesture need not be performed on or near the identified control. This is similar to a computer mouse which can be placed anywhere to control a cursor on a screen. This provides freedom for user interface designers to provide controls that can be easily seen, but do not need to be easy to touch.


In embodiments of the present invention, gestures detected by proximity sensor 501 are transmitted to the host processor controlling the display in several different ways. A first case is where proximity sensor 501 detects touch gestures on the screen without reference to a control identified by eye tracker 502. In this case, proximity sensor 501 outputs x and y screen coordinates of the touch, e.g., output in HID format for a touch screen device. In a second case, proximity sensor 501 detects touch gestures on the screen with reference to a control identified by eye tracker 502. In this case, proximity sensor 501 outputs up-down motion or left-right motion of the touch object, but not the absolute x and y screen coordinates of the touch, e.g., output in HID format for a trackpad device. This is one difference between the present invention and prior art touch screen sensors, computer mice and computer trackpads, that always output touch data in the same format. Namely, prior art touch screen sensors always output absolute x and y screen coordinates of the touch in a first HID format, and computer mice and computer trackpads always output up-down motion or left-right motion of the touch object in a second HID format. In contrast, in embodiments of the present invention, the proximity sensor output format is dynamically configured in response to changing conditions.


Reference is made to FIG. 3, which is a simplified illustration of components in the combined proximity sensor 501 and eye tracker 502 of FIG. 1, in accordance with an embodiment of the present invention. An alternating array of emitters 100 and detectors 200 is provided for proximity sensor 501; and an array of light emitters 120 and camera sensors 221 and 222 are provided for eye tracker 502. Emitters 100 and 120, detectors 200 and camera sensors 221 and 222 are synchronously activated by a single, shared controller 701. In some embodiments, emitters 100 are VCSELs.


Reference is made to FIG. 4, which is a simplified waveform illustrating how the eye tracker 502 and proximity sensor 501 are activated by a shared controller 701, in accordance with an embodiment of the present invention. In particular, it is important that eye tracker VCSELs 120 are not activated while proximity sensor emitters 100 are activated, in order to avoid detections of the eye tracker light at proximity sensor receivers 200. For example, proximity sensor 501 takes a time interval 931 to complete a detection cycle, namely, to activate emitters 100 and detect reflections at receivers 200 and process the detections, and eye tracker 502 takes time interval 930 to capture images (illuminate VCSELs 120, capture images in cameras 220 and 221) and an additional time interval 932 to read out the image data and process the images. As illustrated in FIG. 4, time intervals 930 and 931 are kept separate, but time intervals 931 and 932 overlap.


Reference is made to FIG. 5, which is a simplified illustration of a combined eye tracker and gesture sensor, including a multi-faceted housing that includes an eye tracker 502 mounted in a first facet of the housing and a proximity sensor 501 mounted in a second facet of the housing adjacent the first facet, wherein the proximity sensor is oriented to detect gestures on a keyboard or surface in front of a display, in accordance with an embodiment of the present invention. In contrast to the combined eye tracker and gesture sensor of FIG. 1, in which proximity sensor 501 is oriented to detect gestures on screen 801, in the combined eye tracker and gesture sensor of FIG. 5, proximity sensor 501 is oriented to detect gestures on a surface in front of the screen. FIG. 5 illustrates laptop computer 603 that includes display 801 connected by a hinge to a lower panel in which keyboard 602 is mounted. Proximity sensor light beams 400 are projected along a plane parallel to keyboard 602, and proximity sensor 501 detects gestures performed above the keys of keypad 602. Like the combined eye tracker and gesture sensor of FIG. 1, the combined eye tracker and gesture sensor of FIG. 5 combines gestures detected by proximity sensor 501 with outputs from eye tracker 502. When not combining gestures detected by proximity sensor 501 with outputs from eye tracker 502, the combined device outputs gestures detected by proximity sensor 501 to the host computer as up-down motion or left-right motion of the touch object, e.g., output in HID format for a trackpad device.


In other embodiments of the present invention, eye tracker 502 and proximity sensor 501 are located in separate housings, but their activations are coordinated and their outputs are combined by a shared PC or smart TV to which they are both connected.


Reference is made to FIGS. 6-9, which are simplified illustrations of proximity sensor 501, in accordance with an embodiment of the present invention. Proximity sensor 501 includes light emitters 101-110 and light detectors 201-211, each light emitter being situated between two of the detectors. Proximity sensor 501 also includes a plurality of lenses, such as lenses 302, 306 and 307, each lens being positioned in relation to two respective neighboring ones of the detectors such that light entering that lens is maximally detected at a first of the two detectors when the light enters that lens at an acute angle of incidence θ1, and light entering that lens is maximally detected at the other of the two detectors when the light enters that lens at an obtuse angle of incidence θ2. The lens is positioned in relation to the light emitter situated between these two detectors such that the light from the emitter is collimated as it exits proximity sensor 501.



FIG. 6 shows a forward reflection path of maximum detection 404.03 for hotspot 904 generated by emitter/detector pair 104/207, whereby light beam 404, from emitter 104, reflected off object 911 is maximally detected by sensor 207, as it reaches lens 306 at an angle of incidence θ2. The term “hotspot” refers to a location within a sub-area of the two-dimensional detection plane opposite proximity sensor 501 at which an object will generate reflections that are maximally detected at one or more detectors, in comparison to other locations within that sub-area or neighborhood.



FIG. 7 shows a backward reflection path of maximum detection 409.04 for hotspot 909 generated by emitter/detector pair 109/207, whereby light beam 409, from emitter 109, reflected off object 911 is maximally detected by detector 207, as it reaches lens 307 at an angle of incidence θ1. FIGS. 6 and 7 show how detector 207 is situated with respect to neighboring lenses 306 and 307 such that detector 207 receives maximum forward reflection values at an angle of incidence θ1 via lens 306, and maximum backward reflection values at an angle of incidence θ2 via lens 307.


The intersections outside proximity sensor 501 between the projected light beams and the corridors of maximum detection provide a map of hotspots. Four hotspots are illustrated in FIGS. 8 and 9, two of which are numbed 904 and 905. Reflective object 911 is shown near hotspot 904 in FIG. 8. Thus, the maximum detection of object 911 is generated by emitter/detector pairs 104/202 and 104/207. Emitter/detector pair 104/202 provides backward detection 404.04, and emitter/detector pair 104/207 provides forward detection 404.03, as discussed above. Additional detections are generated by other emitter/detector pairs, e.g., forward detection emitter/detector pair 104/208, because light beams from emitter 104 are scattered by object 911, and a portion of the scattered light arrives at detector 208, but the amount of light detected at detector 208 is significantly less than that detected at detector 207, because the scattered light arriving at detector 208 does not travel along the corridor of maximum detection, i.e., it does not reach lens 307 at an angle of incidence θ2.


In FIG. 9 object 911 is moved a distance d to the right, as compared to FIG. 8. In this case, similar detections are generated by forward emitter/detector pairs 104/207 and 105/208. Each of these detections is less than the detection generated by emitter/detector pair 104/207 in FIG. 8 and greater than the detection generated by emitter/detector pair 104/208 in FIG. 8. The location of object 911 between hotspots 904 and 905 is calculated by interpolating the coordinates of hotspots 904 and 905 according to the amounts of light detected by emitter/detector pairs 104/207 and 105/208, respectively.


Reference is made to FIG. 10, which is an illustration of maximum detected forward reflections 404.01-404.23 for a single emitter beam 404 in a proximity sensor 501, in accordance with an embodiment of the present invention. In this specification, reflections of an emitter beam n are numbered n.xy where the number xy after the decimal point is odd for forward reflections and even for backward reflections. Each maximal detected reflection is detected at a respective detector 206-217, through a corresponding lens 305-316. A reflective object placed somewhere along the path of emitter beam 404 will generate detection signals at several of the receivers, forming a pattern. The object's position along beam 404 is calculated by calculating an estimated axis of symmetry within the detector output pattern, orienting the axis of symmetry by θ, and finding its intersection with the path of emitted light beam 404. FIG. 10 shows 12 hotspot locations 904.01-904.12 along beam 404.


Because the detectors receive light from many angles, it is important to remove those signals that are largely unrelated to the path of maximum detection from the calculation. It has been found that four or five signals around the maximum signal are useful for calculating the object location. However, this number of neighbors is to be taken as an example, and other numbers of neighbors may be used.


Reference is made to FIG. 11, which is a simplified illustration of a first scenario in which there is a single maximum detection signal corresponding to reflection beam 404.13, in accordance with an embodiment of the present invention. The top half of the figure shows the detection signals at each of the detectors, each detector corresponding to a respective one of the forward reflections 404.01-404.23. In this case, five detection signals are used: two neighbors on either side of the maximum, namely, the detections corresponding to forward reflections 404.09-404.17. These signals are surrounded by a rectangle with rounded corners in FIG. 11. One method for calculating the axis of symmetry is to assign a respective coordinate, along the length of proximity sensor 501, to each detection signal. An axis of symmetry is found by calculating a weighted average of the coordinates, each coordinate's weight corresponding to its detection signal. Dashed line 921 indicates the resulting calculated axis of symmetry. Orienting the axis of symmetry by θ, and finding its intersection with the path of emitted light beam 404 provides the estimated location 912 of object 911 at hotspot 904.07, as illustrated in the bottom half of FIG. 11. Processor 701 calculates the object's location. Alternatively, the detection signals are output to an external processor, e.g., a host PC, and the object's location is calculated by the external processor.


Reference is made to FIG. 12, which is a simplified illustration of a second scenario in which there are two maximum detection signals corresponding to reflection beams 404.11 and 404.13, indicating that the maximum reflection is probably between these two reflection beams, in accordance with an embodiment of the present invention. The upper half of the figure shows the detection signals at each of the detectors, each detector corresponding to a respective one of the forward reflections 404.01-404.23. In this case, four detection signals are used; namely, the two maxima and their neighbors, corresponding to forward reflections 404.09-404.15. These signals are surrounded by a curved rectangle in FIG. 12. Dashed line 922 indicates the axis of symmetry calculated by the same method discussed hereinabove with respect to FIG. 11, but using only four detection signals. Orienting the axis of symmetry by θ, and finding its intersection with the path of emitted light beam 404 provides the estimated location 912 of object 911 midway between hotspots 904.06 and 904.07, as illustrated in the bottom half of FIG. 12.


If every case in which there is a single maximum detection signal would be processed like the case shown in FIG. 11, namely, using five detection signals in the neighborhood of the maximum to calculate the axis of symmetry, then when an object moves between neighboring hotspots along beam 404, and it transitions from the state shown in FIG. 11, to that shown in FIG. 12, there will be a sudden jerk in the object's calculated location when different signals are used to calculate the axis of symmetry, namely, when four signals are used instead of five. In order to avoid these jerky movements, the transition between the states shown in FIGS. 11 and 12 is gradual, in accordance with an embodiment of the present invention. This gradual change is done by calculating a degree to which the current distribution of detection signals is similar to that of FIG. 11 and including the fifth, outermost detection signal in proportion to that degree of similarity.


This process uses two values: SingleMax and DoubleMax. SingleMax represents the degree to which the distribution is evenly distributed around a single maximum, and DoubleMax represents the degree to which the distribution is evenly distributed around two, adjacent maximum signals. Specifically, SingleMax is the magnitude of difference between (a) the sum of all signals left of the maximum, and (b) the sum of all signals right of the maximum. The central maximum itself is not included in the SingleMax calculation. For the DoubleMax calculation, the signals are divided into two groups whose dividing line lies between the two largest signals. DoubleMax is the magnitude of difference between (c) the sum of all signals in the left group, and (d) the sum of all signals in the right group.


As mentioned hereinabove, in cases of a single maximum value, an uneven number (2n+1) of signals is used to determine the axis of symmetry (n neighbors on either side of the maximum, and the maximum), whereas in cases of two adjacent maximum values, a smaller, even number (2n) of signals is used to determine the axis of symmetry (left n neighbors and right n neighbors, which include the maximum signals). In this process, the extra signal is used in proportion to the degree that the distribution is similar to the single maximum case. One score for this similarity is:






similarity
=

DoubleMax

(

SingleMax
+
DoubleMax

)







Note that in the case of an even distribution around two neighboring maxima, the sum of all signals on the left equals the sum of an equal number of signals on the right, and thus,

    • DoubleMax=0, and
    • similarity=0.


Conversely, in the case of an even distribution around a single maximum, the sum of all signals left of the maximum equals the sum of an equal number of signals right of the maximum, and thus,

    • SingleMax=0, and






similarity
=


DoubleMax

(

0
+
DoubleMax

)


=
1.





Reference is made to FIG. 13, which is a simplified illustration of a method for calculating a degree to which a current distribution of detection signals is similar to a pattern of detected reflection signals generated when an object is inserted into the path of a projected light beam, in accordance with an embodiment of the present invention. The upper half of FIG. 13 illustrates a scenario in which there is a single maximum detection signal surrounded by an uneven distribution of the surrounding detection signals: detection signal 404.13 is greater than detection signal 404.09 and detection signal 404.15 is greater than detection signal 404.07. In this case the four highest detection signals 404.09-404.15 are used together with a partial contribution of detection signal 404.07. As discussed hereinabove, the partial contribution (404.07′) for detection signal 404.07 in the weighted average is:








404.07


=


404.07
*
DoubleMax


(

SingleMax
+
DoubleMax

)



,





where

SingleMax=Abs((404.07+404.09)−(404.013+404.15)), and
DoubleMax=Abs((404.09+404.11)−(404.13+404.15)).


Dashed line 923 in FIG. 13 indicates the resulting calculated axis of symmetry. Orienting the axis of symmetry by θ, and finding its intersection with the path of emitted light beam 404 provides the estimated location 912 of object 911 between hotspots 904.06 and 904.07, but nearer to hotspot 904.06, as illustrated in the bottom half of FIG. 13.


Because the similarity score calculation handles the extreme cases of perfect single maximum (similarity=1) and perfect double maximum (similarity=0), in all cases the axis of symmetry is calculated by calculating a weighted average based on an even number of signals (e.g., four signals) in the neighborhood of the maximum and adding an additional signal, further from the maximum, in proportion to the detection pattern similarity score.


According to an alternative method, a first axis of symmetry is calculated using an odd number of signals, as in the case of a single maximum, and a second axis of symmetry is calculated using an even number of signals, as in the case of a double maximum. A weighted sum of the two axes is calculated using the same similarity score discussed hereinabove.


When detecting a highly reflective object with the proximity sensor of the present invention, e.g., a shiny metal object, there can be a very large difference between the maximum detection signal and its neighbors. This can cause inaccuracies when calculating the axis of symmetry in the manner discussed hereinabove. Therefore, in some embodiments, the maximum detection signal is capped at a multiple of its neighboring signals, e.g., 2× of its immediate right or left neighbor. This capping of the maximum may be implemented differently for cases of a single maximum and double maximum. For example, in the double maximum case, the two, central maximum values are capped at a multiple of their outer neighbors. This difference between the single maximum and double maximum cases in how exceptional values are capped will affect the method that involves calculating two axes of symmetry. Thus, when calculating the axis of symmetry for the single maximum type of distribution, only the central signal is capped, based on its immediate neighbors; whereas, when calculating the axis of symmetry for the double maximum type of distribution, the two central signals are capped, based on their outer neighbors.


As discussed hereinabove, a touch location is calculated based on reflection signals that correspond to several hotspots. The following configuration parameters are used to calculate a touch position: (i) signal intensity, (ii) hotspot x- and y-coordinate positions, (iii) intensity relationship between hotspots, and (iv) electrical noise of the system. An explanation of these parameters is presented below together with methods for determining values for each parameter.


In order to be able to combine signals from different hotspots, the signal received from all hotspots should be proportional to the object size. This creates a need to normalize the signals. The signal intensity parameter is thus a normalization factor, also referred to as “gain”, indicating how much the raw photodiode detection signal is amplified. Hotspot x- and y-coordinate positions need to be precisely known in order to calculate the touch location as described hereinabove. The intensity relationship between hotspots parameter enables the position calculation to take into account systematic intensity differences between neighboring hotspot locations in both x and y directions and their relationship. The electrical noise parameter is used for making minor adjustments in filter characteristics in the calculations, based on noise in the sensor.


Reference is made to FIG. 14, which is a simplified illustration of a plurality of hotspots in a detection area adjacent to a calibrated proximity sensor, in accordance with an embodiment of the present invention. FIG. 14 shows hotspot maximum detection locations for a calibrated system as a heat map where maximum detection locations in each neighborhood are marked with a black spot and their relative strengths are normalized. Note the variations in position between neighboring hotspots in both x and y directions.


The four configuration parameters are calculated by placing each sensor module into an apparatus that moves a reflective object throughout the detection plane in front of the sensor module and enables correlating detections on the sensor with objects at known locations within the detection plane. In some embodiments, the reflective object is a stylus shaped like a finger and painted gray or skin color in order to have a reflection that is similar to a finger. In other embodiments a flat spatula, spanning the width of the sensor module is used. When using a stylus the calibration test bed needs to move the stylus in both x and y directions, whereas, when using a long spatula the calibration test bed needs to move the spatula only in the y direction. In some embodiments the spatula is moved a fixed distance at each iteration, and the reflection signals are measured at each location. In other embodiments the spatula moves continuously and the reflection signals are measured throughout the movement.


A signal intensity parameter is calculated for each hotspot during calibration on the test bed and written to flash memory on the sensor module for use during calculation. One formula for calculating this parameter is







gain

signal





i


=

gainRef
*


gainFactor


[
rowIndex
]





Signal
i






max

-


Signal
i






min









where gainRef is the normalization peak target, gainFactor is an adjustment factor for the reflectance of the flat calibration spatula used in the test bed compared to the reflectance of a cylindrical finger. This factor is different from row to row. Signali max and Signali min are the maximum and minimum values in the neighborhood surrounding a specific hotspot, defined by the row it is in (rowlndex) and that hotspot's position (i) within that row. Signali min values are collected by taking the median value of a series of samples taken for each hotspot in a row when the calibration spatula enters a row of hotspots. Typically, for hotspots near the sensor, the minimum signal is at that portion of the hotspot neighborhood closest to the sensor, whereas for hotspots farther from the sensor, the minimum signal is at that portion of the hotspot neighborhood farthest from the sensor.


The gain factor needs to be calibrated since the strength of the emitters and the sensitivity of photodiode (PD) detectors may vary widely among similar components. Light guide quality, emitter/PD placement, and semiconductor placement within the emitter and PD components are other factors that affect signal intensity.


Reference is made to FIG. 15, which is a simplified illustration of raw data signals from a proximity sensor, in accordance with an embodiment of the present invention. FIG. 15 shows a collection of raw data signals from objects at hotspot rows 3 and 4 before normalization. The x axis represents the distance from the sensor light guide edge in millimeters, and the y axis represents detection signal amplitude. FIG. 15 illustrates that detection signals generated by an object at a location nearer to the light guide are larger than those generated by that object at a location further from the light guide.


Reference is made to FIG. 16, which is a simplified illustration of signals from a proximity sensor, before and after normalization, in accordance with an embodiment of the present invention. FIG. 16 shows signals from objects at hotspot rows 3 and 4 before and after normalization. The x axis represents the distance from the sensor light guide edge in millimeters, and the y axis represents detection signal amplitude. FIG. 16 shows that the normalized signals accentuate the maximal reflections and normalize the signals from objects at different distances from the sensor light guide to be in the same range of values.


Every hotspot is mapped to x and y coordinates in the sensor detection plane during calibration and this table of coordinates is stored to flash memory on the sensor for use when calculating object locations. The hotspot detection works by first collecting data when the calibration spatula or stylus moves over the active area. All samples that belong to a certain hotspot are stored in the calibration software along with the position, in millimeters, of the calibration spatula or stylus from the sensor. The data is filtered to remove noise disturbances. The filter used depends on the collection method of the samples. If a continuous movement of the robot arm is used, the filter is a moving average filter with a small sample window, e.g., a 3-5 sample window, depending on robot arm speed. If the raw data is collected using a step-based collection method where the calibration spatula or stylus stops at each position and collects several samples, a median filter is applied for all samples at the same location.


The largest value of the filtered data is found in the list of samples. When the peak has been found a number of samples in the neighborhood around the peak are used as input to a curve adapting function. The maximum of the curve is then set as the y position of the hotspot.


Reference is made to FIG. 17, which is a simplified illustration of filtered signals from a proximity sensor detecting an object in the sensor's detection area, in accordance with an embodiment of the present invention. FIG. 17 shows filtered samples for one hotspot after calibration. The x axis represents the distance from the sensor light guide edge in millimeters, and the y axis represents detection signal amplitude. A signal maximum is detected around 19 mm from the light guide.


The thus calculated x and y positions for each hotspot are adjusted by a scaling factor that adjusts the peak position slightly to adjust for a slight difference between the locations that generate maximum reflection for the flat, calibration spatula and the cylindrical, stylus reference object. This scaling factor is dependent on the distance from the light guide, resulting in a different factor for each row of hotspots.


The y values are then used to calculate the x positions based on geometrical properties of component placement like LED/PD placement and pitch between components. The adjustments in x positions are generally much smaller than the adjustments in y positions.


No assumptions are made as to where the peak y positions are located. The calibration process records data that is outside the expected range and then calculates each peak individually. The validation of the detected peak location is done at a later stage.


The hotspot positions need to be calibrated since they vary from device to device depending on light guide quality, emitter/PD placement, semiconductor placement inside the emitter and PD components and other factors.


The average noise for each hotspot row is written to the MCU flash memory. The noise for each hotspot row is used by the controller or processor firmware calculating object locations to tune an Infinite Impulse Response (IIR) filter used for noise reduction, in order to set the filtering at a level that is not too high on devices having a low noise level.


Noise samples are collected, for each hotspot row, when the calibration spatula is at the position, associated with that row, furthest from the light guide. The noise is estimated by taking the median of the absolute deviation from the median of the data for each hotspot signal that belongs to one row (MAD value). Different emitter and PD components, and different controllers, have different values of electrical noise.


Discussion now turns to the calibration process. During calibration, the minimum and maximum signal values for each hotspot are output to a calibration log for gain calculation. These minimum and maximum signal values are also used to set a baseline for how a functioning system should behave, whereby, a minimum or maximum value outside the expected performance spread, indicates the need for further examination. If any signal is large enough to saturate the ADC, this information is output to the log since it will affect the normalization and impair detection accuracy.


During calibration, the detected x and y positions for each hotspot are output into the calibration log. These positions use the position of first emitter as the x origin and the light guide outer edge as the y origin. This data is used to set a baseline for how a functioning system should behave. A range for each hotspot position is also provided, namely, the difference between the detected and expected x and y positions for each hotspot.


During calibration, a PD noise value is estimated for each PD by taking the median of the absolute deviation from the median of the data for all signals output by one PD. This PD noise value identifies PD components that exhibit a higher noise than the population does on average, indicating that the PD, or the PD receiver port on the controller, may be defective.


During calibration, a component functional test is performed to determine that the maximum signal associated with a particular emitter or PD component is at least a threshold magnitude greater than the minimum signal associated with that component:







signal





increase





%

=




signal
i






max



signal
i






min




component





test





threshold







If signal increase values associated with a given component are below the threshold, that component is marked as having failed the component functional test. The log file contains a list of all components that failed the component functional test.


During calibration, the deviation in gain factor for all components with respect to all hotspots on a single row is output to the calibration log. The deviation in a perfect system should be 1 since all components would be equally strong on each row. A large deviation indicates that the device is faulty.


The calibration log file stores a component displacement error (xPos and yPos) for each emitter and PD component, that represents an estimated displacement of that component within the sensor module, based on the results of hotspot x and y positions identified during calibration.


This section describes the pass/fail calibration values and which settings are possible to change from the configuration file to modify the calibration pass/fail testing. A failed calibration is not written to flash and the reason of the fail is written to the calibration log file.


It is possible to set the maximum allowed gain scaling factor for each row. If the gain factor is greater than the maximum allowed gain, indicating a weak signal, the firmware will not be able to normalize the signal amplitude correctly. Thus, if the gain is larger than the maximum allowed gain, calibration fails. Gain for each hotspot row inside the detection area, namely, hotspot rows 1 thru outermost_row-1, should not reach the maximum value to make sure that there is sufficient signal for proper normalization. However, a high gain value at the outermost row of hotspots, which is used for interpolation with other hotspots, but is outside the active touch area, does not cause the device to fail.


All hotspot y-positions are validated against a range of possible values. If the hotspot y-position is outside the range, calibration fails. The default range is a simulated hotspot maximum shift from its expected position based on an optical simulation of component tolerances. The expected position is determined based on measurements taken from a large set of devices.


If the PD noise is outside a set range, calibration fails. Emitter noise is not as critical and is much less sensitive. If the component gain deviation value is greater than its threshold, the calibration fails. If the xPos and yPos are outside their thresholds, the calibration fails.


Reference is made to FIG. 18, which is a simplified illustration of a calibration tool for a proximity sensor, in accordance with an embodiment of the present invention. FIG. 18 shows a motor 903 and shafts 901 and 902 that move reflective calibration object 905, a flat reflective spatula, vertically in relation to proximity sensor bar 501, as indicated by arrows 906. At each location at which object 905 is placed, a plurality of source/sensor pairs that correspond to hotspots in the vicinity of that location are activated and the amounts of light detected are used to determine the sensitivity in the vicinity of those hotspots. Multiple such source/sensor pairs that share a common light source are activated simultaneously.


There are two different methods to operate the calibration tool of FIG. 18. According to one method, calibration object 905 is moved continuously by motor 903 according to arrows 906 and samples are continuously collected throughout this movement. According to another method, motor 903 stops movement of object 905 at predefined locations along the path indicated by arrows 906, and a series of samples is collected at each step.


When starting the calibration, a configuration file with all the settings used is loaded into the calibration program. This file is human readable and can be edited using a text editor. Most, if not all, of the parameters that control the calibration can be edited there. Some settings are more important than others. This section goes through all the possible settings and what they do. All data in the configuration file that is a range of values means that there are separate values for each row of hotspots. The table below lists the parameters in this configuration file.














Parameter
Setting
Description







iterationCount

Sets the number of samples collected at




each position the calibration bar stops at.




Increasing this value increases the




calibration time but more samples are




collected for filtering noise.




Not used for continousSweep calibration.


version

Version number is printed to calibration




log.


calibrationSteps
relativeOffset
Sets the midpoint of the interval used when




collecting samples for calibration.




Calibration flow uses two intervals. One is




the calibration interval and the second is




the location where minimum values are




collected at the position closest to the light




guide.




Change relativeOffset if the midpoint for




calibration should be changed.




Value is in mm based on the calibration




tool origin position.



range
Defines the range from the relativeOffset




that samples are collected in. The




midpoint + − range/2 defines the total range.




Value is in mm length.



sampleCount
Number of samples collected in the




interval. 1-2 mm steps are recommended.




Not used for continousSweep calibration.



direction
Direction calibration bar 905 should move




when calibrating compared to calibration




tool coordinate system.



minRelativeOffset
Calculated movement limits depending on



maxRelativeOffset
relativeOffset and range.



continousSweep
If true, the calibration is done in a




continousSweep instead of using step-




based calibration.


ValidationConfig
name
Name of calibration settings.


uration
noiseLimit
Limit used for Pass/Fail criteria of noise.



ledXLimit
Limit used for Pass/Fail criteria of emitter




component displacement test (x direction).



pdXLimit
Limit used for Pass/Fail criteria of PD




component displacement test (x direction).



pdYLimit
Limit used for Pass/Fail criteria of PD




component displacement test (y direction).



pdDeviation
Limit used for Pass/Fail criteria of PD gain




deviation.



ledDeviation
Limit used for Pass/Fail criteria of emitter




gain deviation.



gainFactor
Limit used for gainFactor adjustment for




each hotspot row in firmware. gainFactor




translates the reflection of calibration bar




905 compared to that of a cylindrical




reference object similar to a finger.



hotspotYMin
Limit used for Pass/Fail testing of hotspot




y-position. Value is in mm with sensor light




guide as origin. Detected hotspot position




outside range will cause calibration to fail.



hotspotYMax
Limit used for Pass/Fail testing of hotspot




y-position. Value is in mm with sensor light




guide as origin. Detected hotspot position




outside range will cause calibration to fail.



positionFormatFactor
Scaling factor for translating coordinates



componentLocationRef
Default PD position used for calculating x




positions.



pdyDefaultPosition
Default PD position used for calculating y




positions.



pitchSize
Distance between components.



maxGain
Expected max gain adjustment per hotspot




row.



maxGainLimit
Limit used for Pass/Fail criteria of gain




calculation.



forwardYAdaptOffset
This parameter adjusts the detected



backwardYAdaptOffset
hotspot y-position in mm. This is needed




since the peak signal generated by the




calibration tool bar and the peak signal




generated by an elliptical object such as a




finger will have different locations due to




the different surface shapes of the objects.




For example, −13 means that if the




calibration bar maximum is found at mm




50.0 then the position will be adjusted to




mm 48.7.



robotSpeedLimit
When doing a continuous sweep calibration




this is the maximum speed allowed for the




robot movement.



firstUsedRow
Instructs the calibration DLL which hotspot




row the calibration starts to calibrate on.



lastUsedRow
Instructs the calibration DLL which hotspot




row the calibration finishes calibration on.









In the foregoing specification, the invention has been described with reference to specific exemplary embodiments thereof. It will, however, be evident that various modifications and changes may be made to the specific exemplary embodiments without departing from the broader spirit and scope of the invention. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.

Claims
  • 1. A proximity sensor comprising: a housing;a plurality of lenses mounted in said housing;a plurality of light emitters mounted in said housing, each light emitter being positioned in relation to a respective one of said lenses so as to project light out of the lens in a particular emission direction along a detection plane;a plurality of light detectors mounted in said housing, each light detector being positioned in relation to a respective one of said lenses so as to detect maximum light intensity when light enters the lens at a particular detection angle;an activating unit mounted in said housing, synchronously activating emitter-detector pairs;a non-volatile computer-readable storage medium storing a table of hotspots, each hotspot in the table corresponding to an emitter-detector pair, the hotspot being a two-dimensional location in the detection plane along the emission direction of the emitter of the pair where projected light reflected by an object that is placed at that location, enters the lens for the detector of the pair at the detection angle of the detector; anda processor receiving outputs from said detectors corresponding to detected amounts of projected light reflected by an object in the detection plane, and calculating a two-dimensional location of the object in the detection plane based on the received outputs and based on corresponding hotspots for the emitter-detector pairs synchronously activated by said activating unit.
  • 2. The proximity sensor of claim 1, wherein different light detectors are positioned in relation to their respective lenses such that their detection angles are different.
  • 3. The proximity sensor of claim 1, wherein different light emitters are positioned in relation to their respective lenses such that their emission directions are different.
  • 4. The proximity sensor of claim 1, wherein said processor interpolates the hotspots corresponding to those of the emitter-detector pairs synchronously activated by said activating unit for which the processor's received outputs are maximum or nearly maximum vis-à-vis all of the received outputs.
  • 5. The proximity sensor of claim 4 wherein said processor interpolates the hotspots using linear weights proportional to the outputs received by said processor from the corresponding emitter-detector pairs.
  • 6. A method for calculating a location of a proximal object, comprising: providing a housing in which a plurality of lenses is mounted;providing a plurality of light emitters in said housing, each light emitter E being positioned in relation to a respective lens L such that light emitter E projects a light beam in a particular emission direction φE along a detection plane P;providing a plurality of light detectors in said housing, each light detector D being positioned in relation to a respective lens L such that light entering lens L is significantly detected at light detector D when the light enters lens L at a detection angle θD;providing a non-volatile computer-readable storage medium storing a table of hotspots, each hotspot H(E, D| O) being a two-dimensional location in detection plane P corresponding to an emitter-detector pair (E, D) and to the shape of an object O, the hotspot H(E, D| O) being a location along the light projected from emitter E of the pair along direction φE, where projected light reflected by the object O, when placed at that location, enters the lens L for detector D of the pair at detection angle θD;synchronously activating emitter-detector pairs (E, D);measuring detection by light detector D of each synchronously activated pair (E, D) of the light projected by light emitter E of the pair that is reflected by object O into the lens of light detector D; andcalculating a two-dimensional location of object O in detection plane P based on the measured detections, and based on the corresponding hotspots H(E, D| O) for the emitter-detector pairs (E, D) activated by said synchronously activating.
  • 7. The method of claim 6, wherein different light emitters E are positioned in relation to their respective lenses such that their emission directions φE are different.
  • 8. The method of claim 6, wherein different light detectors D are positioned in relation to their respective lenses such that their detection angles θD are different.
  • 9. The method of claim 6, further comprising interpolating the hotspots H(E, D| O) corresponding to those of the emitter-detector pairs (E, D) synchronously activated by said synchronously activating for which the measured detections are maximum or nearly maximum vis-à-vis all of the measured detections.
  • 10. The method of claim 9 further comprising interpolating the hotspots H(E, D| O) using linear weights proportional to the measured detections from the corresponding emitter-detector pairs (E, D).
CROSS REFERENCES TO RELATED APPLICATIONS

This application claims priority benefit from U.S. Provisional Application No. 62/348,179 entitled OPTICAL PROXIMITY SENSOR AND EYE TRACKER and filed on Jun. 10, 2016 by inventors Thomas Eriksson, Robert Pettersson, Stefan Holmgren, Xiatao Wang, Rozita Teymourzadeh, Per Erik Lindström, Emil Anders Braide, Jonas Daniel Justus Hjelm and Erik Rosengren. This application is also a continuation-in-part of U.S. patent application Ser. No. 15/588,646 now U.S. Pat. No. 10,282,034, entitled TOUCH SENSITIVE CURVED AND FLEXIBLE DISPLAYS and filed on May 7, 2017 by inventors Thomas Eriksson, Alexander Jubner, Rozita Teymourzadeh, Stefan Holmgren, Lars Sparf, Bengt Henry Hjalmar Edlund and Richard Berglind. U.S. patent application Ser. No. 15/588,646 claims priority benefit from: U.S. Provisional Patent Application No. 62/425,087 entitled OPTICAL PROXIMITY SENSOR AND ASSOCIATED USER INTERFACE and filed on Nov. 22, 2016 by inventors Thomas Eriksson, Alexander Jubner, Rozita Teymourzadeh, Stefan Holmgren, Lars Sparf and Bengt Henry Hjalmar Edlund; andU.S. Provisional Patent Application No. 62/462,034, entitled 3D IMAGING WITH OPTICAL PROXIMITY SENSOR and filed on Feb. 22, 2017 by inventors Thomas Eriksson, Alexander Jubner, Rozita Teymourzadeh, Stefan Holmgren, Lars Sparf, Bengt Henry Hjalmar Edlund. U.S. patent application Ser. No. 15/588,646 is also a continuation-in-part of U.S. patent application Ser. No. 14/960,369, now U.S. Pat. No. 9,645,679, entitled INTEGRATED LIGHT GUIDE AND TOUCH SCREEN FRAME AND MULTI-TOUCH DETERMINATION METHOD and filed on Dec. 5, 2015 by inventors Thomas Eriksson, Alexander Jubner, John Karlsson, Lars Sparf, Saska Lindfors and Robert Pettersson. U.S. patent application Ser. No. 14/960,369 is a continuation of U.S. patent application Ser. No. 14/588,462, now U.S. Pat. No. 9,207,800, entitled INTEGRATED LIGHT GUIDE AND TOUCH SCREEN FRAME AND MULTI-TOUCH DETERMINATION METHOD and filed on Jan. 2, 2015 by inventors Thomas Eriksson, Alexander Jubner, John Karlsson, Lars Sparf, Saska Lindfors and Robert Pettersson. U.S. patent application Ser. No. 14/588,462 claims priority benefit from U.S. Provisional Patent Application No. 62/054,353 entitled INTEGRATED LIGHT GUIDE AND TOUCH SCREEN FRAME AND MULTI-TOUCH DETERMINATION METHOD and filed on Sep. 23, 2014 by inventors Saska Lindfors, Robert Pettersson, John Karlsson and Thomas Eriksson. U.S. patent application Ser. No. 15/588,646 is also a continuation-in-part of U.S. patent application Ser. No. 15/000,815, now U.S. Pat. No. 9,921,661 entitled OPTICAL PROXIMITY SENSOR AND ASSOCIATED USER INTERFACE and filed on Jan. 19, 2016 by inventors Thomas Eriksson, Alexander Jubner, Rozita Teymourzadeh, Håkan Sven Erik Andersson, Per Rosengren, Xiatao Wang, Stefan Holmgren, Gunnar Martin Fröjdh, Simon Fellin, Jan Tomas Hartman, Oscar Sverud, Sangtaek Kim, Rasmus Dahl-Örn, Richard Berglind, Karl Erik Patrik Nordström, Lars Sparf, Erik Rosengren, John Karlsson, Remo Behdasht, Robin Kjell Åman, Joseph Shain, Oskar Hagberg and Joel Rozada. U.S. patent application Ser. No. 15/000,815 claims priority benefit from: U.S. Provisional Application No. 62/107,536 entitled OPTICAL PROXIMITY SENSORS and filed on Jan. 26, 2015 by inventors Stefan Holmgren, Oscar Sverud, Sairam Iyer, Richard Berglind, Karl Erik Patrik Nordström, Lars Sparf, Per Rosengren, Erik Rosengren, John Karlsson, Thomas Eriksson, Alexander Jubner, Remo Behdasht, Simon Fellin, Robin Kjell Åman and Joseph Shain;U.S. Provisional Application No. 62/197,813 entitled OPTICAL PROXIMITY SENSOR and filed on Jul. 28, 2015 by inventors Rozita Teymourzadeh, Håkan Sven Erik Andersson, Per Rosengren, Xiatao Wang, Stefan Holmgren, Gunnar Martin Fröjdh and Simon Fellin; andU.S. Provisional Application No. 62/266,011 entitled OPTICAL PROXIMITY SENSOR and filed on Dec. 11, 2015 by inventors Thomas Eriksson, Alexander Jubner, Rozita Teymourzadeh, Håkan Sven Erik Andersson, Per Rosengren, Xiatao Wang, Stefan Holmgren, Gunnar Martin Fröjdh, Simon Fellin and Jan Tomas Hartman. U.S. patent application Ser. No. 15/000,815 is also a continuation-in-part of U.S. patent application Ser. No. 14/630,737 entitled LIGHT-BASED PROXIMITY DETECTION SYSTEM AND USER INTERFACE and filed on Feb. 25, 2015 by inventors Thomas Eriksson and Stefan Holmgren. U.S. patent application Ser. No. 14/630,737 is a continuation of U.S. patent application Ser. No. 14/140,635, now U.S. Pat. No. 9,001,087, entitled LIGHT-BASED PROXIMITY DETECTION SYSTEM AND USER INTERFACE and filed on Dec. 26, 2013 by inventors Thomas Eriksson and Stefan Holmgren. U.S. patent application Ser. No. 14/140,635 is a continuation of U.S. patent application Ser. No. 13/732,456, now U.S. Pat. No. 8,643,628, entitled LIGHT-BASED PROXIMITY DETECTION SYSTEM AND USER INTERFACE and filed on Jan. 2, 2013 by inventors Thomas Eriksson and Stefan Holmgren. U.S. patent application Ser. No. 13/732,456 claims priority benefit from U.S. Provisional Patent Application Ser. No. 61/713,546 entitled LIGHT-BASED PROXIMITY DETECTION SYSTEM AND USER INTERFACE and filed on Oct. 14, 2012 by inventor Stefan Holmgren. U.S. patent application Ser. No. 15/000,815 is a continuation-in-part of U.S. patent application Ser. No. 14/726,533, now U.S. Pat. No. 9,678,601, entitled OPTICAL TOUCH SCREENS and filed on May 31, 2015 by inventors Robert Pettersson, Per Rosengren, Erik Rosengren, Stefan Holmgren, Lars Sparf, Richard Berglind, Thomas Eriksson, Karl Erik Patrik Nordstrom, Gunnar Martin Fröjdh, Xiatao Wang and Remo Behdasht. U.S. patent application Ser. No. 14/726,533 is a continuation of U.S. patent application Ser. No. 14/311,366, now U.S. Pat. No. 9,063,614, entitled OPTICAL TOUCH SCREENS and filed on Jun. 23, 2014 by inventors Robert Pettersson, Per Rosengren, Erik Rosengren, Stefan Holmgren, Lars Sparf, Richard Berglind, Thomas Eriksson, Karl Erik Patrik Nordström, Gunnar Martin Fröjdh, Xiatao Wang and Remo Behdasht. U.S. patent application Ser. No. 14/311,366 is a continuation of PCT Patent Application No. PCT/US14/40579, entitled OPTICAL TOUCH SCREENS and filed on Jun. 3, 2014 by inventors Robert Pettersson, Per Rosengren, Erik Rosengren, Stefan Holmgren, Lars Sparf, Richard Berglind, Thomas Eriksson, Karl Erik Patrik Nordstrom, Gunnar Martin Fröjdh, Xiatao Wang and Remo Behdasht. U.S. patent application Ser. No. 15/000,815 is also a continuation-in-part of U.S. patent application Ser. No. 14/555,731, now U.S. Pat. No. 9,741,184, entitled DOOR HANDLE WITH OPTICAL PROXIMITY SENSORS and filed on Nov. 28, 2014 by inventors Sairam Iyer, Stefan Holmgren and Per Rosengren. U.S. patent application Ser. No. 15/000,815 is also a continuation-in-part of U.S. patent application Ser. No. 14/791,414, now U.S. Pat. No. 10,324,565, entitled OPTICAL PROXIMITY SENSOR FOR TOUCH SCREEN AND ASSOCIATED CALIBRATION TOOL and filed on Jul. 4, 2015 by inventors Per Rosengren, Xiatao Wang and Stefan Holmgren. U.S. patent application Ser. No. 15/588,646 is also a continuation-in-part of U.S. patent application Ser. No. 14/880,231, now U.S. Pat. No. 10,004,985 entitled GAMING DEVICE and filed on Oct. 11, 2015 by inventors Stefan Holmgren, Sairam Iyer, Richard Berglind, Karl Erik Patrik Nordström, Lars Sparf, Per Rosengren, Erik Rosengren, John Karlsson, Thomas Eriksson, Alexander Jubner, Remo Behdasht, Simon Fellin, Robin Åman and Joseph Shain. U.S. patent application Ser. No. 14/880,231 is a divisional of U.S. patent application Ser. No. 14/312,787, now U.S. Pat. No. 9,164,625, entitled OPTICAL PROXIMITY SENSORS and filed on Jun. 24, 2014 by inventors Stefan Holmgren, Sairam Iyer, Richard Berglind, Karl Erik Patrik Nordström, Lars Sparf, Per Rosengren, Erik Rosengren, John Karlsson, Thomas Eriksson, Alexander Jubner, Remo Behdasht, Simon Fellin, Robin Åman and Joseph Shain. U.S. patent application Ser. No. 14/312,787 is a continuation-in-part of U.S. patent application Ser. No. 13/775,269, now U.S. Pat. No. 8,917,239, entitled REMOVABLE PROTECTIVE COVER WITH EMBEDDED PROXIMITY SENSORS and filed on Feb. 25, 2013 by inventors Thomas Eriksson, Stefan Holmgren, John Karlsson, Remo Behdasht, Erik Rosengren and Lars Sparf. U.S. patent application Ser. No. 14/312,787 is also a continuation of PCT Application No. PCT/US14/40112, entitled OPTICAL PROXIMITY SENSORS and filed on May 30, 2014 by inventors Stefan Holmgren, Sairam Iyer, Richard Berglind, Karl Erik Patrik Nordstrom, Lars Sparf, Per Rosengren, Erik Rosengren, John Karlsson, Thomas Eriksson, Alexander Jubner, Remo Behdasht, Simon Fellin, Robin Åman and Joseph Shain. PCT Application No. PCT/US14/40112 claims priority benefit from: U.S. Provisional Patent Application No. 61/986,341, entitled OPTICAL TOUCH SCREEN SYSTEMS and filed on Apr. 30, 2014 by inventors Sairam Iyer, Karl Erik Patrik Nordström, Lars Sparf, Per Rosengren, Erik Rosengren, Thomas Eriksson, Alexander Jubner and Joseph Shain;U.S. Provisional Patent Application No. 61/972,435, entitled OPTICAL TOUCH SCREEN SYSTEMS and filed on Mar. 31, 2014 by inventors Sairam Iyer, Karl Erik Patrik Nordstrom, Lars Sparf, Per Rosengren, Erik Rosengren, Thomas Eriksson, Alexander Jubner and Joseph Shain;U.S. Provisional Patent Application No. 61/929,992, entitled CLOUD GAMING USER INTERFACE and filed on Jan. 22, 2014 by inventors Thomas Eriksson, Stefan Holmgren, John Karlsson, Remo Behdasht, Erik Rosengren, Lars Sparf and Alexander Jubner;U.S. Provisional Patent Application No. 61/846,089 entitled PROXIMITY SENSOR FOR LAPTOP COMPUTER AND ASSOCIATED USER INTERFACE and filed on Jul. 15, 2013 by inventors Richard Berglind, Thomas Eriksson, Simon Fellin, Per Rosengren, Lars Sparf, Erik Rosengren, Joseph Shain, Stefan Holmgren, John Karlsson and Remo Behdasht;U.S. Provisional Patent Application No. 61/838,296 entitled OPTICAL GAME ACCESSORIES USING REFLECTED LIGHT and filed on Jun. 23, 2013 by inventors Per Rosengren, Lars Sparf, Erik Rosengren, Thomas Eriksson, Joseph Shain, Stefan Holmgren, John Karlsson and Remo Behdasht; andU.S. Provisional Patent Application No. 61/828,713 entitled OPTICAL TOUCH SCREEN SYSTEMS USING REFLECTED LIGHT and filed on May 30, 2013 by inventors Per Rosengren, Lars Sparf, Erik Rosengren and Thomas Eriksson. The contents of these applications are hereby incorporated by reference in their entireties.

US Referenced Citations (145)
Number Name Date Kind
4267443 Carroll et al. May 1981 A
4593191 Alles Jun 1986 A
5070411 Suzuki Dec 1991 A
5103085 Zimmerman Apr 1992 A
5162783 Moreno Nov 1992 A
5414413 Tamaru et al. May 1995 A
5463725 Henckel et al. Oct 1995 A
5880462 Hsia Mar 1999 A
5889236 Gillespie et al. Mar 1999 A
5900863 Numazaki May 1999 A
5977888 Fujita et al. Nov 1999 A
6161005 Pinzon Dec 2000 A
6421042 Omura et al. Jul 2002 B1
6492978 Selig et al. Dec 2002 B1
6646633 Nicolas Nov 2003 B1
6690365 Hinckley et al. Feb 2004 B2
6874683 Keronen et al. Apr 2005 B2
6875977 Wolter et al. Apr 2005 B2
6985137 Kaikuranta Jan 2006 B2
7046232 Inagaki et al. May 2006 B2
7162124 Gunn, III et al. Jan 2007 B1
7221462 Cavallucci May 2007 B2
7225408 ORourke May 2007 B2
7232986 Worthington et al. Jun 2007 B2
7518738 Cavallucci et al. Apr 2009 B2
7659887 Larsen et al. Feb 2010 B2
7924264 Ohta Apr 2011 B2
8091280 Hanzel et al. Jan 2012 B2
8115745 Gray Feb 2012 B2
8120625 Hinckley Feb 2012 B2
8169404 Boillot May 2012 B1
8193498 Cavallucci et al. Jun 2012 B2
8289299 Newton Oct 2012 B2
8316324 Boillot Nov 2012 B2
8350831 Drumm Jan 2013 B2
8471814 LaFave et al. Jun 2013 B2
8581884 Fahraeus et al. Nov 2013 B2
8604436 Patel et al. Dec 2013 B1
8648677 Su et al. Feb 2014 B2
8922340 Salter et al. Dec 2014 B2
9050943 Muller Jun 2015 B2
9223431 Pemberton-Pigott Dec 2015 B2
20010043189 Brisebois et al. Nov 2001 A1
20020075243 Newton Jun 2002 A1
20020103024 Jeffway, Jr. et al. Aug 2002 A1
20020152010 Colmenarez et al. Oct 2002 A1
20030034439 Reime et al. Feb 2003 A1
20030174125 Torunoglu et al. Sep 2003 A1
20040031908 Neveux et al. Feb 2004 A1
20040056199 OConnor et al. Mar 2004 A1
20040090428 Crandall, Jr. et al. May 2004 A1
20040198490 Bansemer et al. Oct 2004 A1
20050024623 Xie et al. Feb 2005 A1
20050093846 Marcus et al. May 2005 A1
20050133702 Meyer Jun 2005 A1
20060028455 Hinckley et al. Feb 2006 A1
20060077186 Park et al. Apr 2006 A1
20060161870 Hotelling et al. Jul 2006 A1
20060161871 Hotelling et al. Jul 2006 A1
20060236262 Bathiche et al. Oct 2006 A1
20060238517 King et al. Oct 2006 A1
20060244733 Geaghan Nov 2006 A1
20070077541 Champagne et al. Apr 2007 A1
20070103436 Kong May 2007 A1
20080012835 Rimon et al. Jan 2008 A1
20080016511 Hyder et al. Jan 2008 A1
20080089587 Kim et al. Apr 2008 A1
20080096620 Lee et al. Apr 2008 A1
20080100572 Boillot May 2008 A1
20080100593 Skillman et al. May 2008 A1
20080134102 Movold et al. Jun 2008 A1
20080158172 Hotelling et al. Jul 2008 A1
20080211779 Pryor Sep 2008 A1
20080224836 Pickering Sep 2008 A1
20090122027 Newton May 2009 A1
20090135162 Van De Wijdeven et al. May 2009 A1
20090139778 Butler et al. Jun 2009 A1
20090166098 Sunder Jul 2009 A1
20090173730 Baier et al. Jul 2009 A1
20090195402 Izadi et al. Aug 2009 A1
20090198359 Chaudhri Aug 2009 A1
20090280905 Weisman et al. Nov 2009 A1
20090322673 Cherradi El Fadili Dec 2009 A1
20100013763 Futter et al. Jan 2010 A1
20100031203 Morris et al. Feb 2010 A1
20100066975 Rehnstrom Mar 2010 A1
20100134424 Brisebois et al. Jun 2010 A1
20100185341 Wilson et al. Jul 2010 A1
20100208234 Kaehler Aug 2010 A1
20100238138 Goertz et al. Sep 2010 A1
20100238139 Goertz et al. Sep 2010 A1
20100245289 Svajda Sep 2010 A1
20100299642 Merrell et al. Nov 2010 A1
20100321289 Kim et al. Dec 2010 A1
20110005367 Hwang et al. Jan 2011 A1
20110043325 Newman et al. Feb 2011 A1
20110050639 Challener et al. Mar 2011 A1
20110074734 Wassvik et al. Mar 2011 A1
20110087963 Brisebois et al. Apr 2011 A1
20110121182 Wong et al. May 2011 A1
20110122560 Andre et al. May 2011 A1
20110128234 Lipman et al. Jun 2011 A1
20110128729 Ng Jun 2011 A1
20110157097 Hamada et al. Jun 2011 A1
20110163996 Wassvik et al. Jul 2011 A1
20110169773 Luo Jul 2011 A1
20110169781 Goertz et al. Jul 2011 A1
20110175852 Goertz et al. Jul 2011 A1
20110179368 King et al. Jul 2011 A1
20110179381 King Jul 2011 A1
20110205186 Newton et al. Aug 2011 A1
20110227874 Fahraeus et al. Sep 2011 A1
20110242056 Lee et al. Oct 2011 A1
20110309912 Muller Dec 2011 A1
20110310005 Chen et al. Dec 2011 A1
20120068973 Christiansson et al. Mar 2012 A1
20120071994 Lengeling Mar 2012 A1
20120098746 Ogawa Apr 2012 A1
20120098753 Lu Apr 2012 A1
20120116548 Goree et al. May 2012 A1
20120127317 Yantek et al. May 2012 A1
20120131186 Klos et al. May 2012 A1
20120133956 Findlay et al. May 2012 A1
20120162078 Ferren et al. Jun 2012 A1
20120188205 Jansson et al. Jul 2012 A1
20120212457 Drumm Aug 2012 A1
20120212458 Drumm Aug 2012 A1
20120218229 Drumm Aug 2012 A1
20120223231 Nijaguna Sep 2012 A1
20120262408 Pasquero et al. Oct 2012 A1
20130127790 Wassvik May 2013 A1
20130234171 Heikkinen et al. Sep 2013 A1
20130263633 Minter et al. Oct 2013 A1
20140049516 Heikkinen et al. Feb 2014 A1
20140069015 Salter et al. Mar 2014 A1
20140104160 Eriksson et al. Apr 2014 A1
20140104240 Eriksson et al. Apr 2014 A1
20140213323 Holenarsipur et al. Jul 2014 A1
20140291703 Rudmann et al. Oct 2014 A1
20140292665 Lathrop et al. Oct 2014 A1
20140293226 Hainzl et al. Oct 2014 A1
20140320459 Pettersson et al. Oct 2014 A1
20150015481 Li Jan 2015 A1
20150227213 Cho Aug 2015 A1
20170160427 Costello et al. Jun 2017 A1
Foreign Referenced Citations (23)
Number Date Country
202014104143 Oct 2014 DE
1906632 Apr 2008 EP
10-148640 Jun 1998 JP
3240941 Dec 2001 JP
2003-029906 Jan 2003 JP
2013-149228 Aug 2013 JP
1020120120097 Nov 2012 KR
1012682090000 May 2013 KR
1020130053363 May 2013 KR
1020130053364 May 2013 KR
1020130053367 May 2013 KR
1020130053377 May 2013 KR
1020130054135 May 2013 KR
1020130054150 May 2013 KR
1020130133117 Dec 2013 KR
2010011929 Jan 2010 WO
2010134865 Nov 2010 WO
2012017183 Feb 2012 WO
2012089957 Jul 2012 WO
2012089958 Jul 2012 WO
2013102551 Jul 2013 WO
2014041245 Mar 2014 WO
2014194151 Dec 2014 WO
Non-Patent Literature Citations (30)
Entry
Hodges, S., Izadi, S., Butler, A., Rrustemi A., Buxton, B., “ThinSight: Versatile Multitouch Sensing for Thin Form-Factor Displays.” UIST'07, Oct. 7-10, 2007. <http://www.hci.iastate.edu/REU09/pub/main/telerobotics_team_papers/thinsight_versatile_multitouch_sensing_for_thin_formfactor_displays.pdf>.
Miyamoto, I., et al., Basic Study of Touchless Human Interface Using Net Structure Proximity Sensors, Journal of Robotics and Mechatronics vol. 25 No. 3, 2013, pp. 553-558.
Miyamoto, I., et al., Basic Study of Touchless Human Interface Using Net Structure Proximity Sensors, No. 12-3 Proceedings of the 2012 JSME Conference on Robotics and Mechanics, Hamamatsu, Japan, May 27-29, 2012, 2P1-P03(1) to 2P1-P03(3).
Moeller, J. et al., ZeroTouch: An Optical Multi-Touch and Free-Air Interaction Architecture, Proc. CHI 2012 Proceedings of the 2012 annual conference extended abstracts on Human factors in computing systems, May 5, 2012, pp. 2165-2174. ACM New York, NY, USA.
Moeller, J. et al., ZeroTouch: A Zero-Thickness Optical Multi-Touch Force Field, CHI EA '11 Proceedings of the 2011 annual conference extended abstracts on Human factors in computing systems, May 2011, pp. 1165-1170. ACM New York, NY, USA.
Moeller, J. et al., IntangibleCanvas: Free-Air Finger Painting on a Projected Canvas, CHI EA '11 Proceedings of the 2011 annual conference extended abstracts on Human factors in computing systems, May 2011, pp. 1615-1620. ACM New York, NY, USA.
Plaisant, C., Wallace, D. (1992): Touchscreen Toggle Design. In: Bauersfeld, Penny, Bennett, John, Lynch, Gene (eds.) Proceedings of the ACM CHI 92 Human Factors in Computing Systems Conference Jun. 3-7, 1992, Monterey, California. pp. 667-668.
Van Loenen, Evert, et al., Entertable: A Solution for Social Gaming Experiences, Tangible Play Workshop, Jan. 28, 2007, pp. 16-19, Tangible Play Research and Design for Tangible and Tabletop Games, Workshop at the 2007 Intelligent User Interfaces Conference, Workshop Proceedings.
Butler et al., “SideSight: Multi-touch Interaction Around Smart Devices.” UIST'08, Oct. 2008. http://131.107.65.14/en-us/um/people/shahrami/papers/sidesight.pdf.
Non-final Office action received for U.S. Appl. No. 14/312,787 dated Jan. 8, 2015, 15 pages.
Notice of Allowance for U.S. Appl. No. 14/312,787 dated Jun. 22, 2015, 9 pages.
International Preliminary Report on Patentability for PCT application No. PCT/US2014/040112 dated Dec. 1, 2015, 18 pages.
Search Report and Written Opinion for PCT application No. PCT/US2014/040112 dated Dec. 2, 2014, 21 pages.
Extended European Search Report for European patent application No. 14 804 520.6 dated May 24 2016, 11 pages.
First Office action for European patent application No. 14 804 520.6 dated May 5, 2017, 9 pages.
First Office Action received for Chinese patent application No. 201480030571.8 dated Aug. 16, 2016, 6 pages.
Second Office Action received for Chinese patent application No. 201480030571.8 dated May 4, 2017, 4 pages.
Non-final Office action received for U.S. Appl. No. 14/555,731 dated Dec. 2, 2016, 8 pages.
Search Report for PCT application No. PCT/US2015/057460 dated Jan. 21, 2016, 2 pages.
Written Opinion for PCT application No. PCT/US2015/057460 dated Jan. 21, 2016, 6 pages.
Non-final Office action received for U.S. Appl. No. 15/000,815 dated Jun. 3, 2016, 7 pages.
Final Office action received for U.S. Appl. No. 15/000,815 dated Jan. 23, 2017, 8 pages.
Search Report and Written Opinion for PCT application No. PCT/US2016/013927 dated May 26, 2016, 13 pages.
Extended European search report for European patent application No. 16743860.5, dated Jul. 18, 2018, 8 pages.
First Office action for Japanese patent application No. 2017-539236 dated Sep. 10, 2018, 3 pages.
Non-final Office action received for U.S. Appl. No. 15/616,106 dated Mar. 7, 2019, 10 pages.
Notice of Allowance for U.S. Appl. No. 15/616,106 dated Oct. 22, 2019, 8 pages.
Non-final Office action received for U.S. Appl. No. 15/898,585 dated Sep. 13, 2018, 9 pages.
Notice of Allowance for U.S. Appl. No. 15/990,587 dated Sep. 4, 2019, 8 pages.
Non-final Office action received for U.S. Appl. No. 16/127,238 dated Mar. 5, 2020, 18 pages.
Related Publications (1)
Number Date Country
20200167034 A1 May 2020 US
Provisional Applications (14)
Number Date Country
62348179 Jun 2016 US
62425087 Nov 2016 US
62462034 Feb 2017 US
62054353 Sep 2014 US
62107536 Jan 2015 US
62197813 Jul 2015 US
62266011 Dec 2015 US
61713546 Oct 2012 US
61846089 Jul 2013 US
61838296 Jun 2013 US
61828713 May 2013 US
61986341 Apr 2014 US
61972435 Mar 2014 US
61929992 Jan 2014 US
Divisions (1)
Number Date Country
Parent 14312787 Jun 2014 US
Child 14880231 US
Continuations (7)
Number Date Country
Parent 15616106 Jun 2017 US
Child 16775057 US
Parent 14588462 Jan 2015 US
Child 14960369 US
Parent 14140635 Dec 2013 US
Child 14630737 US
Parent 13732456 Jan 2013 US
Child 14140635 US
Parent 14311366 Jun 2014 US
Child 14726533 US
Parent PCT/US2014/040579 Jun 2014 US
Child 14311366 US
Parent PCT/US2014/040112 May 2014 US
Child 13775269 US
Continuation in Parts (9)
Number Date Country
Parent 15588646 May 2017 US
Child 15616106 US
Parent 14960369 Dec 2015 US
Child 15588646 US
Parent 15000815 Jan 2016 US
Child 15588646 US
Parent 14630737 Feb 2015 US
Child 15000815 US
Parent 14726533 May 2015 US
Child 15000815 US
Parent 14555731 Nov 2014 US
Child 15000815 US
Parent 14791414 Jul 2015 US
Child 14555731 US
Parent 14880231 Oct 2015 US
Child 15588646 US
Parent 13775269 Feb 2013 US
Child 14312787 US