Embodiments relate generally to machine user interfaces, and more specifically to the use of virtual objects as user input to machines.
Conventional machine interfaces are in common daily use. Every day, millions of users type their commands, click their computer mouse and hope for the best.
Unfortunately, however, these types of interfaces are very limited.
Therefore, what is needed is a remedy to this and other shortcomings of the traditional machine interface approaches.
Aspects of the systems and methods described herein provide for improved control of machines or other computing resources based at least in part upon enhancing a virtual reality primitive or construct based upon sensed information indicating commands and/or other inputs. Embodiments can enable modeling of physical objects, created objects and interactions with various combinations thereof for machine control or other purposes.
The technology disclosed relates to simplified manipulation of virtual objects by detected hand motions. In one embodiment, a detected hand includes calculation points of potential interaction with a manipulation point of a virtual object. In particular, the technology disclosed relates to detecting hand motion and positions of the calculation points relative to the virtual object to be manipulated, dynamically selecting at least one manipulation point proximate to the virtual object based on the detected hand motion and positions of one or more of the calculation points, and manipulating the virtual object by interaction between the detected hand motion and positions of one or more of the calculation points and the dynamically selected manipulation point. In another embodiment, opposable motion and positions of the calculation points of the hand are detected.
In some embodiments, the technology disclosed relates to detecting opposable motion and positions of the calculation points of the hand, detecting the manipulation point proximate to a point of convergence of the opposable calculation points, and assigning a strength attribute to the manipulation point based on a degree of convergence of the opposable calculation points. In one embodiment, the dynamically selected manipulation point is selected from a predetermined list of available manipulation points for a particular form of the virtual object. In another embodiment, the dynamically selected manipulation point is created proximate to the virtual object based on the detected hand motion and positions of the calculation points.
In some embodiments, the hand and the virtual object both have anchor points and force applied by the calculation points through the manipulation point is calculated between a hand anchor point and a virtual object anchor point. In other embodiments, the technology disclosed relates to generating data for augmented display representing a position of the virtual object relative to a direct view of the detected hand. In yet other embodiments, the technology disclosed relates to generating data for display representing positions in a rendered virtual space of the virtual object and the detected hand. In yet another embodiment, the technology disclosed relates to manipulating the virtual object responsive to a proximity between a virtual representation of the detected hand generated using the data for display and the manipulation point of the virtual object. In a further embodiment, the calculation points include finger tips and a base of the hand.
The technology disclosed also relates to detecting motion of two hands, dynamically selecting two manipulation points proximate to opposed sides of the virtual object, defining a selection plane through the virtual object linking the two manipulation points, and manipulating the virtual object responsive to manipulation of the selection plane. It further relates to dynamically selecting an anchor point for the hand proximate to a grasp point of two or more of the calculation points of the hand, assigning a strength attribute to the anchor point based on a degree of convergence to the dynamically selected anchor points, and manipulating the virtual object responsive to the anchor point strength attribute when the anchor point and the manipulation point are within a predetermined range of each other. In some embodiments, the grasp point of a pinch gesture includes convergence of at least two opposable finger or thumb contact points. In other embodiments, the grasp point of a grab gesture includes convergence of a palm contact point with at least one opposable finger contact points.
The technology disclosed also relates to simplifying manipulation of a virtual object using detected hand motions that operate a virtual tool. In another embodiment, a detected hand includes calculation points of potential interaction with a manipulation point of the virtual tool. In particular, detecting finger motion of the hand and positions of calculation points of fingers of the hand relative to the virtual tool used to manipulate the virtual object, manipulating the virtual tool by interaction between the detected finger motion and virtual manipulation points on an input side of the virtual tool, dynamically selecting at least one manipulation point proximate to the virtual object based on convergence of calculation points of the virtual tool, and manipulating the virtual object by interaction between contact points on an output side of the virtual tool and a virtual manipulation point on the virtual object.
In one embodiment, the virtual tool is a scissor and manipulating the virtual object further includes cutting the virtual object. In another embodiment, the virtual tool is a scalpel and manipulating the virtual object further includes slicing the virtual object.
The technology disclosed also relates to detecting opposable motion and positions of the calculation points of the fingers of the hand. The technology disclosed further relates to detecting opposable motion and positions of the calculation points of the fingers of the hand, detecting the manipulation point proximate to a point of convergence of the opposable calculation points, and assigning a strength attribute to the manipulation point based on a degree of convergence of the opposable calculation points.
In one embodiment, the dynamically selected manipulation point is selected from a predetermined list of available manipulation points for a particular form of the virtual object. In another embodiment, the dynamically selected manipulation point is created proximate to the virtual object based on the detected finger motion and positions of the calculation points. In yet another embodiment, the fingers and the virtual object both have anchor points and force applied by the calculation points through the manipulation point is calculated between a finger anchor point and a virtual object anchor point.
In some embodiments, the technology disclosed also includes generating data for augmented display representing a position of the virtual object relative to a direct view of the detected hand. In other embodiments, the technology disclosed further includes generating data for display representing positions in a rendered virtual space of the virtual object and the detected hand. In yet another embodiment, the technology disclosed relates to manipulating the virtual object responsive to a proximity between a virtual representation of the detected hand generated using the data for display and the manipulation point of the virtual object.
One embodiment includes detecting hand motion and positions of the calculation points relative to two or more virtual objects to be manipulated, dynamically selecting one or more manipulation points proximate to at least one of the virtual objects based on the detected hand motion and positions of one or more of the calculation points, and manipulating at least one of the virtual objects by interaction between the detected hand motion and positions of one or more of the calculation points and the dynamically selected manipulation points.
One embodiment includes detecting hand motion and positions of calculation points relative to two or more virtual objects to be manipulated, manipulating a first virtual object by interaction between the detected hand motion and at least one virtual manipulation point of the first virtual object, dynamically selecting at least one manipulation point of a second virtual object responsive to convergence of calculation points of the first virtual object, and manipulating the second virtual object when the virtual manipulation point of the first virtual object and the virtual manipulation point of the second virtual object are within a predetermined range of each other.
In one embodiment, a method for finding a virtual object primitive is provided. The method can include receiving at least one primitive indicating a virtual concept. Determining from the primitive and sensory information about an environment a variation in a property of the at least one primitive indicating a result of a virtualized simulation based at least in part on the primitive and the sensory information can be included in the method. The method further includes providing the object primitive property.
In an embodiment, determining can comprise simulating the effect of a force.
In an embodiment, determining can comprise minimizing a cost function.
In an embodiment, determining can comprise: detecting a collision.
In an embodiment, determining can comprise recognizing an object property dependence (e.g., understanding how scale and orientation of primitive affects interaction.
In an embodiment, determining can comprise determining a meaning in context.
In one embodiment, determining a meaning in context can comprise performing eye tracking. Determining a meaning in context can comprise recognizing at least one parameter of the human voice in some embodiments. Determining a meaning in context can comprise vector or tensor mechanics.
In an embodiment, one or more manipulation points can be determined using a weighted average of distance from each calculation point to an anchor point.
In an embodiment, an anchor point can be determined based upon a type of interaction. In an embodiment, an anchor point can be determined based upon a locus of activity of an interaction.
Among other aspects, embodiments can enable improved control of machines or other computing resources based at least in part upon enhancing a virtual reality primitive or construct based upon sensed information indicating commands and/or other inputs. Embodiments can enable modeling of physical objects, created objects and interactions with combinations thereof for interfacing with a variety of machines (e.g., a computing systems, including desktop, laptop, tablet computing devices, special purpose computing machinery, including graphics processors, embedded microcontrollers, gaming consoles, audio mixers, or the like; wired or wirelessly coupled networks of one or more of the foregoing, and/or combinations thereof).
A more complete understanding of the subject matter can be derived by referring to the detailed description and claims when considered in conjunction with the following figures, wherein like reference numbers refer to similar elements throughout the figures.
Techniques described herein can be implemented as one or a combination of methods, systems or processor executed code to form embodiments capable of improved control of machines or other computing resources based at least in part upon enhancing a virtual reality primitive or construct based upon sensed information indicating commands and/or other inputs. Embodiments can enable modeling of physical objects, created objects and interactions with combinations thereof for machine control or other purposes.
In an embodiment, a simulation mechanism comprises simulating the effect of a force (114). In an embodiment, a simulation mechanism comprises minimizing a cost function (112).
In an embodiment, a simulation mechanism comprises detecting a collision (110).
In an embodiment, a simulation mechanism comprises determining a meaning in context (116). Sometimes, determining a meaning in context further comprises eye tracking. In some applications determining a meaning in context further comprises recognizing at least one parameter of the human voice.
In an embodiment, a simulation mechanism comprises recognizing an object property dependence (e.g., understanding how scale and orientation of primitive affects interaction.
In an embodiment, a simulation mechanism comprises vector or tensor mechanics (120).
Manipulation point 201A comprises a location in virtual space; in embodiments this virtual space may be associated with a physical space for example as described in commonly owned U.S. patent application Ser. No. 14/516,493, entitled, “VELOCITY FIELD INTERACTION FOR FREE SPACE GESTURE INTERFACE AND CONTROL”, filed on Oct. 16, 2014. A manipulation point can comprise one or more quantities representing various attributes, such as for example a manipulation point “strength” attribute, which is indicated in
A manipulation point can be used to describe an interaction in virtual space, properties and/or attributes thereof, as well as combinations thereof. In example 201, a manipulation point 201A represents a location of a “pinch” gesture in virtual space; the shading of the point as depicted by
Now with reference to a manipulation point example 202, a manipulation point 202A comprises a strength and a location of a “grab” gesture 202A-1. Gestures can “occur” in physical space, virtual space and/or combinations thereof.
In embodiments, manipulation points, or attributes thereof, can be used to describe interactions with objects in virtual space. In single handed manipulation example 203 a virtual hand 203A-1 starts with a weak “pinch” manipulation point between the thumb and the index finger. The virtual hand 203A-1 approaches a virtual object 203A-2, and the thumb and index finger are brought closer together; this proximity may increase the strength of the manipulation point 203A. In embodiments, if the strength of the manipulation point exceeds a threshold and/or the manipulation point is in sufficient proximity to a virtual object, the virtual object can be “selected”. Selection can comprise a virtual action (e.g., virtual grab, virtual pinch, virtual swat and so forth) relative to the virtual object that represents a physical action that can be made relative to a physical object; however it is not necessary for the physical action nor the physical object to actually exist. Virtual actions can result in virtual results (e.g., a virtual pinch can result in a virtual deformation or a virtual swat can result in a virtual translation). Thresholding (or other quantitative techniques) can be used to describe the extent of a virtual action yielding a virtual result depending on an object type and other properties of the scene. For example, a virtual rubber object can be virtually pinched according to a different threshold indicating virtual deformation of a surface of the virtual rubber object than a threshold indicating deformation of a virtual steel object.
As illustrated in single handed interaction example 203 once a manipulation point selects a virtual object, the virtual object can be rotated, translated, scaled, and otherwise manipulated. If the thumb and index finger of the virtual hand become separated, the strength of the manipulation point may decrease, and the object may be disengaged from the prediction model.
A two handed interaction example 204 illustrates a two-handed manipulation of a virtual object 204A-2 facilitated by a plurality of manipulation points 204A. The manipulation point 204A need not intersect the virtual object 204A-2 to select it. In an embodiment, a plurality of manipulation points may engage with one another and “lock” on as if one or more of the plurality was itself a virtual object. In an embodiment, two or more manipulation points may lock if they both exceed a threshold strength; this may define a “selection plane” 204X (or vector, or other mathematical construct defining a relationship) as illustrated in 204.
Now with reference to example 303A, an “anchor point” 303-2 can be defined as a calculation point and can serve as an input into the manipulation point determination method. For example, an anchor point can be selected according to a type of interaction and/or a location of where the interaction is to occur (i.e., a center of activity) (e.g., a pinch gesture indicates an anchor point between the thumb and index finger, a thrumming of fingertips on a desk indicates an anchor point located at the desk where the wrist is in contact). As shown with reference to example 303B in comparison to example 303A, a manipulation point 303-3 can be determined based at least in part upon the one or more calculation points 303-1 and the anchor point 303-2. For example, the location is determined in one embodiment using a weighted average of the locations of the calculation points with respect to the location of the anchor point. The strength of the manipulation point 303-3 can be determined in a variety of ways, such as for example according to a location of the calculation point determined to be “farthest” away from manipulation point 303-3. Alternatively, the strength could be determined according to a weighting of different distances of calculation points from the manipulation point 303-3. Other techniques can be used in various other embodiments.
In embodiments, the manipulation point(s) can be used to facilitate interactions in virtual space as described above with reference to
An anchor point 307-3 in example 307A can itself serve as a calculation point, thereby enabling determining a further refined manipulation point 307-4 as shown by example 307B. In an embodiment, a weighted average of the location and strength of a plurality of manipulation points 307-3, 307-3-2 in example 307 can be used to define a “general manipulation point” 307-4 in example 307B.
In embodiments, anchor or calculation points can be placed on objects external to the prediction model as illustrated with reference to example 309. As shown by example 309, an object 309-5, separate from predictive model 301 includes an anchor point 309-2. Object(s) 309-5 can be purely virtual constructs, or virtual constructs based at least on part on prediction models of physical objects as described above. In an embodiment illustrated with reference to example 311, such object is a “virtual surface” 311-5. Complex interactions can be enabled by determining the manipulation point of a prediction model 301 with respect to at least one anchor point 311-2 defined on virtual surface 311-5. In embodiments, such virtual surface can correspond to a desk, kitchen countertop, lab table or other work surface(s) in physical space. Association of anchor point 311-2 with virtual surface 311-5 can enable modeling of a user interaction “anchored” to a physical surface, e.g., a user's hand resting on a flat surface while typing while interacting meaningfully with the virtual space.
A prediction model can be based upon an observed object in physical space, e.g., a real hand using a real pair of scissors). Any component of the prediction model could be, however entirely or partially created without reference to any particular object in physical space.
For example, a hand holding a tool may be interpreted by a system as a prediction model of a hand whose manipulation point 403-2 is engaging a prediction model of a scissors; the scissors model may itself have one or more manipulation points 403-1 which can be distinct from the one or more manipulation points 403-2 of the hand as illustrated by example 403.
In embodiments, various configurations of modeled physical objects and created objects can be represented as predictive models. For example, to enable users to use modeled tools to manipulate created objects as illustrated by example 404. In example 404, the harder the user “squeezes” the modeled tool, the higher the strength of the tool's manipulation point 404-1 (e.g., the strength indicates more or less vigorous cutting of the created object by the action of the user). In example 405, a created tool is used in conjunction with a created object. In yet further example 406, a created tool manipulates a modeled object. For example a physical CPR dummy modeled can be “operated upon” virtually by a surgeon using created tools in a mixed physical-virtual environment. More than one hand using one or more tools is illustrated by examples 407. In example 407A two hands are gripping two tools that are brought in proximity to a created object. In 407B, further interactions are illustrated, including for example the user is enabled to simultaneously stretch and rotate the created object.
As illustrated by example 501, a user may reach in space and come into proximity with one or more virtual objects as illustrated by example 502. Using manipulation points or another technique a user can select a virtual object as illustrated by example 503. A user can drag the virtual object as illustrated by example 504 and manipulate it in preparation for use as illustrated by example 505. When the user is done with the virtual object, they may use one of a variety of techniques to return the virtual object to its initial position or to a different position. Example 506 illustrates an embodiment in which the user is able to throw the virtual object, and the virtual object's trajectory and placement are determined at least in part by a system simulating the physics behind a hypothetical trajectory as illustrated by example 507 (object in transit) and example 508 (object at a final resting point).
Embodiments permit the use of two-handed manipulations of virtual objects. As illustrated by example 509, a user may hold a virtual object in place with one hand while manipulating the object with the other hand. Users can stretch, shrink, contort and otherwise transform virtual objects in the same ways as the virtual object manipulations described above as illustrated by example 510. In embodiments, a virtual construct (i.e., plane) can be defined in proximity to the virtual object to enable engagements with the object as illustrated by example 511. One use of such virtual constructs is further described in commonly owned U.S. patent application Ser. Nos. 14/154,730, 14/280,018, and 14/155,722. In an embodiment, real and/or virtual objects can be used in conjunction with a manipulated object. For example a real or virtual keyboard can be used with a virtual screen as illustrated by example 512.
In one embodiment, a motion sensing and controller system provides for detecting that some variation(s) in one or more portions of interest of a user has occurred, for determining that an interaction with one or more machines corresponds to the variation(s), for determining if the interaction should occur, and, if so, for affecting the interaction. The Machine Sensory and Control System (MSCS) typically includes a portion detection system, a variation determination system, an interaction system and an application control system.
As
In one embodiment, the detection module 92 includes one or more capture device(s) 190A, 190B (e.g., light (or other electromagnetic radiation sensitive devices) that are controllable via the controller 96. The capture device(s) 190A, 190B can comprise individual or multiple arrays of image capture elements 190A (e.g., pixel arrays, CMOS or CCD photo sensor arrays, or other imaging arrays) or individual or arrays of photosensitive elements 190B (e.g., photodiodes, photo sensors, single detector arrays, multi-detector arrays, or other configurations of photo sensitive elements) or combinations thereof. Arrays of image capture device(s) 190C (of
While illustrated with reference to a particular embodiment in which control of emission module 91 and detection module 92 are co-located within a common controller 96, it should be understood that these functions will be separate in some embodiments, and/or incorporated into one or a plurality of elements comprising emission module 91 and/or detection module 92 in some embodiments. Controller 96 comprises control logic (hardware, software or combinations thereof) to conduct selective activation/de-activation of emitter(s) 180A, 180B (and/or control of active directing devices) in on-off, or other activation states or combinations thereof to produce emissions of varying intensities in accordance with a scan pattern which can be directed to scan an area of interest 5. Controller 96 can comprise control logic (hardware, software or combinations thereof) to conduct selection, activation and control of capture device(s) 190A, 190B (and/or control of active directing devices) to capture images or otherwise sense differences in reflectance or other illumination. Signal processing module 94 determines whether captured images and/or sensed differences in reflectance and/or other sensor—perceptible phenomena indicate a possible presence of one or more objects of interest 98, including control objects 99, the presence and/or variations thereof can be used to control machines and/or other applications 95.
In various embodiments, the variation of one or more portions of interest of a user can correspond to a variation of one or more attributes (position, motion, appearance, surface patterns) of a user hand 99, finger(s), points of interest on the hand 99, facial portion 98 other control objects (e.g., styli, tools) and so on (or some combination thereof) that is detectable by, or directed at, but otherwise occurs independently of the operation of the machine sensory and control system. Thus, for example, the system is configurable to ‘observe’ ordinary user locomotion (e.g., motion, translation, expression, flexing, deformation, and so on), locomotion directed at controlling one or more machines (e.g., gesturing, intentionally system-directed facial contortion, etc.), attributes thereof (e.g., rigidity, deformation, fingerprints, veins, pulse rates and/or other biometric parameters). In one embodiment, the system provides for detecting that some variation(s) in one or more portions of interest (e.g., fingers, fingertips, or other control surface portions) of a user has occurred, for determining that an interaction with one or more machines corresponds to the variation(s), for determining if the interaction should occur, and, if so, for at least one of initiating, conducting, continuing, discontinuing and/or modifying the interaction and/or a corresponding interaction.
For example and with reference to
A model management module 197 embodiment comprises a model refiner 197F to update one or more models 197B (or portions thereof) from sensory information (e.g., images, scans, other sensory-perceptible phenomenon) and environmental information (i.e., context, noise, etc.); enabling a model analyzer 197I to recognize object, position, motion and attribute information that might be useful in controlling a machine. Model refiner 197F employs an object library 197A to manage objects including one or more models 197B (i.e., of user portions (e.g., hand, face), other control objects (e.g., styli, tools)) or the like (see e.g., model 197B-1, 197B-2 of
In an embodiment and with reference to
For example and according to one embodiment illustrated by
The ellipse equation (1) is solved for θ, subject to the constraints that: (1) (xC, yC) must lie on the centerline determined from the four tangents 195A, 195B, 195C, and 195D (i.e., centerline 189A of
A1x+B1y+D1=0
A2x+B2y+D2=0
A3x+B3y+D3=0
A4x+B4y+D4=0 (2)
Four column vectors r12, r23, r14 and r24 are obtained from the coefficients Ai, Bi and Di of equations (2) according to equations (3), in which the “\” operator denotes matrix left division, which is defined for a square matrix M and a column vector v such that M\v=r, where r is the column vector that satisfies Mr=v:
Four component vectors G and H are defined in equations (4) from the vectors of tangent coefficients A, B and D and scalar quantities p and q, which are defined using the column vectors r12, r23, r14 and r24 from equations (3).
c1=(r13+r24)/2
c2=(r14+r23)/2
δ1=c21−c11
δ2=c22−c12
p=δ1/δ2
q=c11,c12*p
G=Ap+B
H=Aq+D (4)
Six scalar quantities vA2, vAB, vB2, wA2, wAB, and wB2 are defined by equation (5) in terms of the components of vectors G and H of equation (4).
Using the parameters defined in equations (1)-(5), solving for θ is accomplished by solving the eighth-degree polynomial equation (6) for t, where the coefficients Qi (for i=0 to 8) are defined as shown in equations (7)-(15).
0=Q8t8+Q7t7+Q6t6+Q5t5+Q4t4+Q3t3+Q2t2+Q1t+Q0 (6)
The parameters A1, B1, G1, H1, vA2, vAB, vB2, wA2, wAB, and wB2 used in equations (7)-(15) are defined as shown in equations (1)-(4). The parameter n is the assumed semi-major axis (in other words, a0). Once the real roots t are known, the possible values of θ are defined as θ=atan(t).
In this exemplary embodiment, equations (6)-(15) have at most three real roots; thus, for any four tangent lines, there are at most three possible ellipses that are tangent to all four lines and that satisfy the a=a0 constraint. (In some instances, there may be fewer than three real roots.) For each real root θ, the corresponding values of (xC, yC) and b can be readily determined. Depending on the particular inputs, zero or more solutions will be obtained; for example, in some instances, three solutions can be obtained for a typical configuration of tangents. Each solution is completely characterized by the parameters {θ, a=a0, b, (xC, yC)}. Alternatively, or additionally, a model builder 197C and model updater 197D provide functionality to define, build and/or customize model(s) 197B using one or more components in object library 197A. Once built, model refiner 197F updates and refines the model, bringing the predictive information of the model in line with observed information from the detection system 90A.
The model subcomponents 197-1, 197-2, 197-3, and 197-4 can be scaled, sized, selected, rotated, translated, moved, or otherwise re-ordered to enable portions of the model corresponding to the virtual surface(s) to conform within the points 193 in space. Model refiner 197F employs a variation detector 197G to substantially continuously determine differences between sensed information and predictive information and provide to model refiner 197F a variance useful to adjust the model 197B accordingly. Variation detector 197G and model refiner 197F are further enabled to correlate among model portions to preserve continuity with characteristic information of a corresponding object being modeled, continuity in motion, and/or continuity in deformation, conformation and/or torsional rotations.
An environmental filter 197H reduces extraneous noise in sensed information received from the detection system 90A using environmental information to eliminate extraneous elements from the sensory information. Environmental filter 197H employs contrast enhancement, subtraction of a difference image from an image, software filtering, and background subtraction (using background information provided by objects of interest determiner 198H (see below) to enable model refiner 197F to build, refine, manage and maintain model(s) 197B of objects of interest from which control inputs can be determined.
A model analyzer 197I determines that a reconstructed shape of a sensed object portion matches an object model in an object library; and interprets the reconstructed shape (and/or variations thereon) as user input. Model analyzer 197I provides output in the form of object, position, motion and attribute information to an interaction system 90C.
Again with reference to
A context determiner 198G and object of interest determiner 198H provide functionality to determine from the object, position, motion and attribute information objects of interest (e.g., control objects, or other objects to be modeled and analyzed), objects not of interest (e.g., background) based upon a detected context. For example, when the context is determined to be an identification context, a human face will be determined to be an object of interest to the system and will be determined to be a control object. On the other hand, when the context is determined to be a fingertip control context, the finger tips will be determined to be object(s) of interest and will be determined to be a control objects whereas the user's face will be determined not to be an object of interest (i.e., background). Further, when the context is determined to be a styli (or other tool) held in the fingers of the user, the tool tip will be determined to be object of interest and a control object whereas the user's fingertips might be determined not to be objects of interest (i.e., background). Background objects can be included in the environmental information provided to environmental filter 197H of model management module 197.
A virtual environment manager 198E provides creation, selection, modification and de-selection of one or more virtual constructs 198B (see
Further with reference to
A control module 199 embodiment comprises a command engine 199F to determine whether to issue command(s) and what command(s) to issue based upon the command information, related information and other information discernable from the object, position, motion and attribute information, as received from an interaction interpretation module 198. Command engine 199F employs command/control repository 199A (e.g., application commands, OS commands, commands to MSCS, misc. commands) and related information indicating context received from the interaction interpretation module 198 to determine one or more commands corresponding to the gestures, context, etc. indicated by the command information. For example, engagement gestures can be mapped to one or more controls, or a control-less screen location, of a presentation device associated with a machine under control. Controls can include imbedded controls (e.g., sliders, buttons, and other control objects in an application), or environmental level controls (e.g., windowing controls, scrolls within a window, and other controls affecting the control environment). In embodiments, controls may be displayed using 2D presentations (e.g., a cursor, cross-hairs, icon, graphical representation of the control object, or other displayable object) on display screens and/or presented in 3D forms using holography, projectors or other mechanisms for creating 3D presentations, or audible (e.g., mapped to sounds, or other mechanisms for conveying audible information) and/or touchable via haptic techniques.
Further, an authorization engine 199G employs biometric profiles 199B (e.g., users, identification information, privileges, etc.) and biometric information received from the interaction interpretation module 198 to determine whether commands and/or controls determined by the command engine 199F are authorized. A command builder 199C and biometric profile builder 199D provide functionality to define, build and/or customize command/control repository 199A and biometric profiles 199B.
Selected authorized commands are provided to machine(s) under control (i.e., “client”) via interface layer 196. Commands/controls to the virtual environment (i.e., interaction control) are provided to virtual environment manager 198E. Commands/controls to the emission/detection systems (i.e., sensory control) are provided to emission module 91 and/or detection module 92 as appropriate.
In various embodiments and with reference to
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
At action 902, hand motion and positions of the calculation points are detected relative to the virtual object to be manipulated. The method further includes detecting opposable motion and positions of the calculation points of the hand. In some embodiments, the calculation points include finger tips and a base of the hand.
At action 912, at least one manipulation point proximate to the virtual object is dynamically selected based on the detected hand motion and positions of one or more of the calculation points. Also, the dynamically selected manipulation point is selected from a predetermined list of available manipulation points for a particular form of the virtual object. In addition, the dynamically selected manipulation point is created proximate to the virtual object based on the detected hand motion and positions of the calculation points.
In one embodiment, the method includes detecting opposable motion and positions of the calculation points of the hand, detecting the manipulation point proximate to a point of convergence of the opposable calculation points, and assigning a strength attribute to the manipulation point based on a degree of convergence of the opposable calculation points.
In one another embodiment, the method includes detecting motion of two hands, dynamically selecting two manipulation points proximate to opposed sides of the virtual object, defining a selection plane through the virtual object linking the two manipulation points, and manipulating the virtual object responsive to manipulation of the selection plane.
In yet another embodiment, the method includes dynamically selecting an anchor point for the hand proximate to a grasp point of two or more of the calculation points of the hand, assigning a strength attribute to the anchor point based on a degree of convergence to the dynamically selected anchor points, and manipulating the virtual object responsive to the anchor point strength attribute when the anchor point and the manipulation point are within a predetermined range of each other. In some embodiments, the grasp point of a pinch gesture includes convergence of at least two opposable finger or thumb contact points. In other embodiments, the grasp point of a grab gesture includes convergence of a palm contact point with at least one opposable finger contact points.
At action 922, the virtual object is manipulated by interaction between the detected hand motion and positions of one or more of the calculation points and the dynamically selected manipulation point. In some embodiments, the hand and the virtual object both have anchor points and force applied by the calculation points through the manipulation point is calculated between a hand anchor point and a virtual object anchor point.
In one embodiment, the method includes generating data for augmented display representing a position of the virtual object relative to a direct view of the detected hand. In another embodiment, the method includes generating data for display representing positions in a rendered virtual space of the virtual object and the detected hand. In one another embodiment, the virtual object is manipulated responsive to a proximity between a virtual representation of the detected hand generated using the data for display and the manipulation point of the virtual object.
One embodiment includes detecting hand motion and positions of the calculation points relative to two or more virtual objects to be manipulated, dynamically selecting one or more manipulation points proximate to at least one of the virtual objects based on the detected hand motion and positions of one or more of the calculation points, and manipulating at least one of the virtual objects by interaction between the detected hand motion and positions of one or more of the calculation points and the dynamically selected manipulation points.
One embodiment includes detecting hand motion and positions of calculation points relative to two or more virtual objects to be manipulated, manipulating a first virtual object by interaction between the detected hand motion and at least one virtual manipulation point of the first virtual object, dynamically selecting at least one manipulation point of a second virtual object responsive to convergence of calculation points of the first virtual object, and manipulating the second virtual object when the virtual manipulation point of the first virtual object and the virtual manipulation point of the second virtual object are within a predetermined range of each other.
At action 1002, finger motion of the hand and positions of calculation points of fingers of the hand are detected relative to the virtual tool used to manipulate the virtual object. In one embodiment, the virtual tool is a scissor and manipulating the virtual object further includes cutting the virtual object. In another embodiment, the virtual tool is a scalpel and manipulating the virtual object further includes slicing the virtual object.
The method further includes detecting opposable motion and positions of the calculation points of the fingers of the hand.
At action 1012, the virtual tool is manipulated by interaction between the detected finger motion and virtual manipulation points on an input side of the virtual tool. The method further includes detecting opposable motion and positions of the calculation points of the fingers of the hand, detecting the manipulation point proximate to a point of convergence of the opposable calculation points, and assigning a strength attribute to the manipulation point based on a degree of convergence of the opposable calculation points.
At action 1022, at least one manipulation point proximate to the virtual object is dynamically selected based on convergence of calculation points of the virtual tool. In some embodiments, the dynamically selected manipulation point is selected from a predetermined list of available manipulation points for a particular form of the virtual object. In other embodiments, the dynamically selected manipulation point is created proximate to the virtual object based on the detected finger motion and positions of the calculation points.
At action 1032, the virtual object is manipulated by interaction between contact points on an output side of the virtual tool and a virtual manipulation point on the virtual object.
In some embodiments, the fingers and the virtual object both have anchor points and force applied by the calculation points through the manipulation point is calculated between a finger anchor point and a virtual object anchor point.
In one embodiment, the method includes generating data for augmented display representing a position of the virtual object relative to a direct view of the detected hand. In another embodiment, the method includes generating data for display representing positions in a rendered virtual space of the virtual object and the detected hand. In one another embodiment, the virtual object is manipulated responsive to a proximity between a virtual representation of the detected hand generated using the data for display and the manipulation point of the virtual object.
Refer first to
In various implementations, the system and method for capturing 3D motion of an object as described herein can be integrated with other applications, such as a head-mounted device or a mobile device. Referring again to
System 1100 includes any number of cameras 1102, 1104 coupled to sensory processing system 1106. Cameras 1102, 1104 can be any type of camera, including cameras sensitive across the visible spectrum or with enhanced sensitivity to a confined wavelength band (e.g., the infrared (IR) or ultraviolet bands); more generally, the term “camera” herein refers to any device (or combination of devices) capable of capturing an image of an object and representing that image in the form of digital data. For example, line sensors or line cameras rather than conventional devices that capture a two-dimensional (2D) image can be employed. The term “light” is used generally to connote any electromagnetic radiation, which may or may not be within the visible spectrum, and may be broadband (e.g., white light) or narrowband (e.g., a single wavelength or narrow band of wavelengths).
Cameras 1102, 1104 are preferably capable of capturing video images (i.e., successive image frames at a constant rate of at least 15 frames per second); although no particular frame rate is required. The capabilities of cameras 1102, 1104 are not critical to the technology disclosed, and the cameras can vary as to frame rate, image resolution (e.g., pixels per image), color or intensity resolution (e.g., number of bits of intensity data per pixel), focal length of lenses, depth of field, etc. In general, for a particular application, any cameras capable of focusing on objects within a spatial volume of interest can be used. For instance, to capture motion of the hand of an otherwise stationary person, the volume of interest might be defined as a cube approximately one meter on a side.
As shown, cameras 1102, 1104 can be oriented toward portions of a region of interest 1112 by motion of the device 1101, in order to view a virtually rendered or virtually augmented view of the region of interest 1112 that can include a variety of virtual objects 1116 as well as contain an object of interest 1114 (in this example, one or more hands) moves within the region of interest 1112. One or more sensors 1108, 1110 capture motions of the device 1101. In some implementations, one or more light sources 1115, 1117 are arranged to illuminate the region of interest 1112. In some implementations, one or more of the cameras 1102, 1104 are disposed opposite the motion to be detected, e.g., where the hand 1114 is expected to move. This is an optimal location because the amount of information recorded about the hand is proportional to the number of pixels it occupies in the camera images, and the hand will occupy more pixels when the camera's angle with respect to the hand's “pointing direction” is as close to perpendicular as possible. Sensory processing system 1106, which can be, e.g., a computer system, can control the operation of cameras 1102, 1104 to capture images of the region of interest 1112 and sensors 1108, 1110 to capture motions of the device 1101. Information from sensors 1108, 1110 can be applied to models of images taken by cameras 1102, 1104 to cancel out the effects of motions of the device 1101, providing greater accuracy to the virtual experience rendered by device 1101. Based on the captured images and motions of the device 1101, sensory processing system 1106 determines the position and/or motion of object 1114.
For example, as an action in determining the motion of object 1114, sensory processing system 1106 can determine which pixels of various images captured by cameras 1102, 1104 contain portions of object 1114. In some implementations, any pixel in an image can be classified as an “object” pixel or a “background” pixel depending on whether that pixel contains a portion of object 1114 or not. Object pixels can thus be readily distinguished from background pixels based on brightness. Further, edges of the object can also be readily detected based on differences in brightness between adjacent pixels, allowing the position of the object within each image to be determined. In some implementations, the silhouettes of an object are extracted from one or more images of the object that reveal information about the object as seen from different vantage points. While silhouettes can be obtained using a number of different techniques, in some implementations, the silhouettes are obtained by using cameras to capture images of the object and analyzing the images to detect object edges. Correlating object positions between images from cameras 1102, 1104 and cancelling out captured motions of the device 1101 from sensors 1108, 1110 allows sensory processing system 1106 to determine the location in 3D space of object 1114, and analyzing sequences of images allows sensory processing system 1106 to reconstruct 3D motion of object 1114 using conventional motion algorithms or other techniques. See, e.g., U.S. patent application Ser. No. 13/414,485 (filed on Mar. 7, 2012) and U.S. Provisional Patent Application Nos. 61/724,091 (filed on Nov. 8, 2012) and 61/587,554 (filed on Jan. 7, 2012), the entire disclosures of which are hereby incorporated by reference.
Presentation interface 1120 employs projection techniques in conjunction with the sensory based tracking in order to present virtual (or virtualized real) objects (visual, audio, haptic, and so forth) created by applications loadable to, or in cooperative implementation with, the device 1101 to provide a user of the device with a personal virtual experience. Projection can include an image or other visual representation of an object.
One implementation uses motion sensors and/or other types of sensors coupled to a motion-capture system to monitor motions within a real environment. A virtual object integrated into an augmented rendering of a real environment can be projected to a user of a portable device 101. Motion information of a user body portion can be determined based at least in part upon sensory information received from imaging 1102, 1104 or acoustic or other sensory devices. Control information is communicated to a system based in part on a combination of the motion of the portable device 1101 and the detected motion of the user determined from the sensory information received from imaging 1102, 1104 or acoustic or other sensory devices. The virtual device experience can be augmented in some implementations by the addition of haptic, audio and/or other sensory information projectors. For example, an optional video projector 1120 can project an image of a page (e.g., virtual device) from a virtual book object superimposed upon a real world object, e.g., desk 1116 being displayed to a user via live video feed; thereby creating a virtual device experience of reading an actual book, or an electronic book on a physical e-reader, even though no book nor e-reader is present. Optional haptic projector can project the feeling of the texture of the “virtual paper” of the book to the reader's finger. Optional audio projector can project the sound of a page turning in response to detecting the reader making a swipe to turn the page. Because it is a virtual reality world, the back side of hand 1114 is projected to the user, so that the scene looks to the user as if the user is looking at the user's own hand(s).
A plurality of sensors 1108, 1110 coupled to the sensory processing system 1106 to capture motions of the device 1101. Sensors 1108, 1110 can be any type of sensor useful for obtaining signals from various parameters of motion (acceleration, velocity, angular acceleration, angular velocity, position/locations); more generally, the term “motion detector” herein refers to any device (or combination of devices) capable of converting mechanical motion into an electrical signal. Such devices can include, alone or in various combinations, accelerometers, gyroscopes, and magnetometers, and are designed to sense motions through changes in orientation, magnetism or gravity. Many types of motion sensors exist and implementation alternatives vary widely.
The illustrated system 1100 can include any of various other sensors not shown in
It will be appreciated that the Figures shown in
While the invention has been described by way of example and in terms of the specific embodiments, it is to be understood that the invention is not limited to the disclosed embodiments. To the contrary, it is intended to cover various modifications and similar arrangements as would be apparent to those skilled in the art. Therefore, the scope of the appended claims should be accorded the broadest interpretation so as to encompass all such modifications and similar arrangements.
This application is a continuation of U.S. patent application Ser. No. 16/228,521, entitled, “VIRTUAL INTERACTIONS FOR MACHINE CONTROL,” filed on Dec. 20, 2018, which is a continuation U.S. patent application Ser. No. 14/527,742 entitled, “VIRTUAL INTERACTIONS FOR MACHINE CONTROL,” filed on Oct. 29, 2014, which claims the benefit of US Provisional Patent Application No. 61/897,186, entitled, “VIRTUAL INTERACTIONS FOR MACHINE CONTROL,” filed on Oct. 29, 2013. The provisional and non-provisional applications are hereby incorporated by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
2665041 | Maffucci | Jan 1954 | A |
4175862 | DiMatteo et al. | Nov 1979 | A |
4879659 | Bowlin et al. | Nov 1989 | A |
5134661 | Reinsch | Jul 1992 | A |
5282067 | Liu | Jan 1994 | A |
5454043 | Freeman | Sep 1995 | A |
5554980 | Hashimoto et al. | Sep 1996 | A |
5574511 | Yang et al. | Nov 1996 | A |
5581276 | Cipolla et al. | Dec 1996 | A |
5594469 | Freeman et al. | Jan 1997 | A |
5616078 | Oh | Apr 1997 | A |
5659475 | Brown | Aug 1997 | A |
5742263 | Wang et al. | Apr 1998 | A |
5900863 | Numazaki | May 1999 | A |
5901170 | Peysakhovich et al. | May 1999 | A |
6002808 | Freeman | Dec 1999 | A |
6031161 | Baltenberger | Feb 2000 | A |
6031661 | Tanaami | Feb 2000 | A |
6061064 | Reichlen | May 2000 | A |
6072494 | Nguyen | Jun 2000 | A |
6075892 | Fan et al. | Jun 2000 | A |
6075895 | Qiao et al. | Jun 2000 | A |
6084979 | Kanade et al. | Jul 2000 | A |
6090443 | Eastep | Jul 2000 | A |
6111580 | Kazama et al. | Aug 2000 | A |
6147678 | Kumar et al. | Nov 2000 | A |
6154558 | Hsieh | Nov 2000 | A |
6160899 | Lee et al. | Dec 2000 | A |
6181343 | Lyons | Jan 2001 | B1 |
6184326 | Razavi et al. | Feb 2001 | B1 |
6184926 | Khosravi et al. | Feb 2001 | B1 |
6191773 | Maruno et al. | Feb 2001 | B1 |
6195104 | Lyons | Feb 2001 | B1 |
6204852 | Kumar et al. | Mar 2001 | B1 |
6222465 | Kumar et al. | Apr 2001 | B1 |
6252598 | Segen | Jun 2001 | B1 |
6256033 | Nguyen | Jul 2001 | B1 |
6263091 | Jain et al. | Jul 2001 | B1 |
6417866 | Man et al. | Jul 2002 | B1 |
6493041 | Hanko et al. | Dec 2002 | B1 |
6498628 | Iwamura | Dec 2002 | B2 |
6603867 | Sugino et al. | Aug 2003 | B1 |
6661918 | Gordon et al. | Dec 2003 | B1 |
6702494 | Dumler et al. | Mar 2004 | B2 |
6771294 | Pulli et al. | Aug 2004 | B1 |
6786877 | Foxlin | Sep 2004 | B2 |
6788809 | Grzeszczuk et al. | Sep 2004 | B1 |
6798628 | Macbeth | Sep 2004 | B1 |
6804654 | Kobylevsky et al. | Oct 2004 | B2 |
6804656 | Rosenfeld et al. | Oct 2004 | B1 |
6814656 | Rodriguez | Nov 2004 | B2 |
6819796 | Hong et al. | Nov 2004 | B2 |
6842175 | Schmalstieg et al. | Jan 2005 | B1 |
6901170 | Terada et al. | May 2005 | B1 |
6919880 | Morrison et al. | Jul 2005 | B2 |
6943774 | Horiki | Sep 2005 | B2 |
6950534 | Cohen et al. | Sep 2005 | B2 |
6993157 | Oue et al. | Jan 2006 | B1 |
7030861 | Westerman et al. | Apr 2006 | B1 |
7071914 | Marks | Jul 2006 | B1 |
7095401 | Liu et al. | Aug 2006 | B2 |
7170492 | Bell | Jan 2007 | B2 |
7213707 | Hubbs et al. | May 2007 | B2 |
7215828 | Luo | May 2007 | B2 |
7244233 | Krantz et al. | Jul 2007 | B2 |
7257237 | Luck et al. | Aug 2007 | B1 |
7259873 | Sikora et al. | Aug 2007 | B2 |
7308112 | Fujimura et al. | Dec 2007 | B2 |
7340077 | Gokturk et al. | Mar 2008 | B2 |
7379563 | Shamaie | May 2008 | B2 |
7519223 | Dehlin et al. | Apr 2009 | B2 |
7532206 | Morrison et al. | May 2009 | B2 |
7536032 | Bell | May 2009 | B2 |
7542586 | Johnson | Jun 2009 | B2 |
7598942 | Underkoffler et al. | Oct 2009 | B2 |
7606417 | Steinberg et al. | Oct 2009 | B2 |
7646372 | Marks et al. | Jan 2010 | B2 |
7652679 | Aratani et al. | Jan 2010 | B2 |
7656372 | Sato et al. | Feb 2010 | B2 |
7665041 | Wilson et al. | Feb 2010 | B2 |
7692625 | Morrison et al. | Apr 2010 | B2 |
7831932 | Josephsoon et al. | Nov 2010 | B2 |
7840031 | Albertson et al. | Nov 2010 | B2 |
7849421 | Yoo et al. | Dec 2010 | B2 |
7861188 | Josephsoon et al. | Dec 2010 | B2 |
7874917 | Marks et al. | Jan 2011 | B2 |
7886229 | Pachet | Feb 2011 | B2 |
7886236 | Kolmykov-Zotov et al. | Feb 2011 | B2 |
7940885 | Stanton et al. | May 2011 | B2 |
7948493 | Klefenz et al. | May 2011 | B2 |
7971156 | Albertson et al. | Jun 2011 | B2 |
7980885 | Gattwinkel et al. | Jul 2011 | B2 |
8064704 | Kim et al. | Nov 2011 | B2 |
8085339 | Marks | Dec 2011 | B2 |
8086971 | Radivojevic et al. | Dec 2011 | B2 |
8111239 | Pryor et al. | Feb 2012 | B2 |
8112719 | Hsu et al. | Feb 2012 | B2 |
8144121 | Kitaura | Mar 2012 | B2 |
8144148 | El Dokor et al. | Mar 2012 | B2 |
8144233 | Fukuyama | Mar 2012 | B2 |
8150102 | Zheng et al. | Apr 2012 | B2 |
8166421 | Magal et al. | Apr 2012 | B2 |
8185176 | Mangat et al. | May 2012 | B2 |
8213707 | Li et al. | Jul 2012 | B2 |
8230852 | Zhang et al. | Jul 2012 | B2 |
8235529 | Raffle et al. | Aug 2012 | B1 |
8244233 | Chang et al. | Aug 2012 | B2 |
8289162 | Mooring et al. | Oct 2012 | B2 |
8290208 | Kurtz et al. | Oct 2012 | B2 |
8311370 | Ha et al. | Nov 2012 | B2 |
8325214 | Hildreth | Dec 2012 | B2 |
8373654 | Wang et al. | Feb 2013 | B2 |
8379101 | Mathe et al. | Feb 2013 | B2 |
8405680 | Cardoso Lopes et al. | Mar 2013 | B1 |
8457353 | Reville et al. | Jun 2013 | B2 |
8487871 | Langridge et al. | Jul 2013 | B2 |
8488246 | Border et al. | Jul 2013 | B2 |
8502789 | Tse et al. | Aug 2013 | B2 |
8514221 | King et al. | Aug 2013 | B2 |
8576222 | Handley et al. | Nov 2013 | B2 |
8593402 | Stinson, III | Nov 2013 | B2 |
8631355 | Murillo et al. | Jan 2014 | B2 |
8638989 | Holz | Jan 2014 | B2 |
8659594 | Kim et al. | Feb 2014 | B2 |
8659658 | Vassigh et al. | Feb 2014 | B2 |
8693731 | Holz et al. | Apr 2014 | B2 |
8817087 | Weng et al. | Aug 2014 | B2 |
8836768 | Rafii et al. | Sep 2014 | B1 |
8842084 | Andersson et al. | Sep 2014 | B2 |
8843857 | Berkes et al. | Sep 2014 | B2 |
8854433 | Rafii | Oct 2014 | B1 |
8856687 | Robertson et al. | Oct 2014 | B2 |
8872914 | Gobush | Oct 2014 | B2 |
8881051 | Frey et al. | Nov 2014 | B2 |
8922590 | Luckett, Jr. et al. | Dec 2014 | B1 |
8930852 | Chen et al. | Jan 2015 | B2 |
8933876 | Galor et al. | Jan 2015 | B2 |
8942881 | Hobbs et al. | Jan 2015 | B2 |
8963867 | Narita | Feb 2015 | B2 |
9056396 | Linnell | Jun 2015 | B1 |
9058057 | Matsuda | Jun 2015 | B2 |
9128552 | Case et al. | Sep 2015 | B2 |
9134800 | Maeda | Sep 2015 | B2 |
9213890 | Huang et al. | Dec 2015 | B2 |
9250707 | Choi et al. | Feb 2016 | B2 |
9256282 | Latta et al. | Feb 2016 | B2 |
9256288 | Lee et al. | Feb 2016 | B2 |
9299013 | Curlander et al. | Mar 2016 | B1 |
9383895 | Vinayak | Jul 2016 | B1 |
9398243 | Ryu et al. | Jul 2016 | B2 |
9436288 | Holz | Sep 2016 | B2 |
9448634 | Wakeford et al. | Sep 2016 | B1 |
9552673 | Hilliges et al. | Jan 2017 | B2 |
9600078 | Rafii | Mar 2017 | B2 |
9983697 | Gribetz | May 2018 | B1 |
10042512 | Robertson et al. | Aug 2018 | B2 |
10126823 | Nahman et al. | Nov 2018 | B2 |
10275039 | Cohen et al. | Apr 2019 | B2 |
10281987 | Yang et al. | May 2019 | B1 |
10353532 | Holz et al. | Jul 2019 | B1 |
10901518 | Cohen et al. | Jan 2021 | B2 |
10921949 | Holz et al. | Feb 2021 | B2 |
11500473 | Cohen et al. | Nov 2022 | B2 |
11520477 | Bailey et al. | Dec 2022 | B2 |
11567583 | Cohen et al. | Jan 2023 | B2 |
11875012 | Benson | Jan 2024 | B2 |
20020008211 | Kask | Jan 2002 | A1 |
20020041327 | Hildreth et al. | Apr 2002 | A1 |
20020064382 | Hildreth et al. | May 2002 | A1 |
20020105484 | Navab et al. | Aug 2002 | A1 |
20020140633 | Rafii et al. | Oct 2002 | A1 |
20030053658 | Pavlidis | Mar 2003 | A1 |
20030053659 | Pavlidis et al. | Mar 2003 | A1 |
20030081141 | Mazzapica | May 2003 | A1 |
20030085866 | Bimber et al. | May 2003 | A1 |
20030123703 | Pavlidis et al. | Jul 2003 | A1 |
20030138130 | Cohen et al. | Jul 2003 | A1 |
20030152289 | Luo | Aug 2003 | A1 |
20030202697 | Simard et al. | Oct 2003 | A1 |
20040046736 | Pryor et al. | Mar 2004 | A1 |
20040068409 | Tanaka et al. | Apr 2004 | A1 |
20040125228 | Dougherty | Jul 2004 | A1 |
20040145809 | Brenner | Jul 2004 | A1 |
20040193413 | Wilson et al. | Sep 2004 | A1 |
20040207597 | Marks | Oct 2004 | A1 |
20040212725 | Raskar | Oct 2004 | A1 |
20050068518 | Baney et al. | Mar 2005 | A1 |
20050071864 | Denoue et al. | Mar 2005 | A1 |
20050131607 | Breed | Jun 2005 | A1 |
20050168578 | Gobush | Aug 2005 | A1 |
20050236558 | Nabeshima et al. | Oct 2005 | A1 |
20050285845 | Dehlin | Dec 2005 | A1 |
20060017807 | Lee et al. | Jan 2006 | A1 |
20060035710 | Festejo et al. | Feb 2006 | A1 |
20060072105 | Wagner | Apr 2006 | A1 |
20060210112 | Cohen et al. | Sep 2006 | A1 |
20060239471 | Mao et al. | Oct 2006 | A1 |
20060252477 | Zalewski et al. | Nov 2006 | A1 |
20060290950 | Platt et al. | Dec 2006 | A1 |
20070042346 | Weller | Feb 2007 | A1 |
20070067798 | Wroblewski | Mar 2007 | A1 |
20070092118 | Tachibana | Apr 2007 | A1 |
20070120834 | Boillot | May 2007 | A1 |
20070126696 | Boillot | Jun 2007 | A1 |
20070130547 | Boillot | Jun 2007 | A1 |
20070206719 | Suryanarayanan et al. | Sep 2007 | A1 |
20070216894 | Garcia et al. | Sep 2007 | A1 |
20070220444 | Sunday et al. | Sep 2007 | A1 |
20070236475 | Wherry | Oct 2007 | A1 |
20070238956 | Haras et al. | Oct 2007 | A1 |
20080005703 | Radivojevic et al. | Jan 2008 | A1 |
20080013826 | Hillis et al. | Jan 2008 | A1 |
20080056561 | Sawachi | Mar 2008 | A1 |
20080056752 | Denton et al. | Mar 2008 | A1 |
20080064954 | Adams et al. | Mar 2008 | A1 |
20080106746 | Shpunt et al. | May 2008 | A1 |
20080113756 | Williams et al. | May 2008 | A1 |
20080141181 | Ishigaki et al. | Jun 2008 | A1 |
20080174547 | Kanevsky et al. | Jul 2008 | A1 |
20080244465 | Kongqiao et al. | Oct 2008 | A1 |
20080273764 | Scholl | Nov 2008 | A1 |
20080278589 | Thorn | Nov 2008 | A1 |
20080304740 | Sun et al. | Dec 2008 | A1 |
20080319356 | Cain et al. | Dec 2008 | A1 |
20090031240 | Hildreth | Jan 2009 | A1 |
20090040215 | Afzulpurkar et al. | Feb 2009 | A1 |
20090070093 | Nakanishi et al. | Mar 2009 | A1 |
20090085881 | Keam | Apr 2009 | A1 |
20090102840 | Li | Apr 2009 | A1 |
20090103780 | Nishihara et al. | Apr 2009 | A1 |
20090122146 | Zalewski et al. | May 2009 | A1 |
20090128564 | Okuno | May 2009 | A1 |
20090184920 | Francis | Jul 2009 | A1 |
20090203993 | Mangat et al. | Aug 2009 | A1 |
20090203994 | Mangat et al. | Aug 2009 | A1 |
20090217211 | Hildreth et al. | Aug 2009 | A1 |
20090228841 | Hildreth | Sep 2009 | A1 |
20090257623 | Tang et al. | Oct 2009 | A1 |
20090265671 | Sachs et al. | Oct 2009 | A1 |
20090274339 | Cohen et al. | Nov 2009 | A9 |
20090278917 | Dobbins et al. | Nov 2009 | A1 |
20090309710 | Kakinami | Dec 2009 | A1 |
20090319892 | Wright et al. | Dec 2009 | A1 |
20090323121 | Valkenburg et al. | Dec 2009 | A1 |
20100013662 | Stude | Jan 2010 | A1 |
20100020078 | Shpunt | Jan 2010 | A1 |
20100023015 | Park | Jan 2010 | A1 |
20100026963 | Faulstich | Feb 2010 | A1 |
20100027845 | Kim et al. | Feb 2010 | A1 |
20100046842 | Conwell | Feb 2010 | A1 |
20100050134 | Clarkson | Feb 2010 | A1 |
20100053164 | Imai et al. | Mar 2010 | A1 |
20100058252 | Ko | Mar 2010 | A1 |
20100066667 | MacDougall et al. | Mar 2010 | A1 |
20100083109 | Tse et al. | Apr 2010 | A1 |
20100092267 | Najdovski et al. | Apr 2010 | A1 |
20100095206 | Kim | Apr 2010 | A1 |
20100118123 | Freedman et al. | May 2010 | A1 |
20100125815 | Wang et al. | May 2010 | A1 |
20100156676 | Mooring et al. | Jun 2010 | A1 |
20100158372 | Kim et al. | Jun 2010 | A1 |
20100177035 | Schowengerdt et al. | Jul 2010 | A1 |
20100177049 | Levy et al. | Jul 2010 | A1 |
20100177929 | Kurtz et al. | Jul 2010 | A1 |
20100199221 | Yeung et al. | Aug 2010 | A1 |
20100199232 | Mistry et al. | Aug 2010 | A1 |
20100201880 | Iwamura | Aug 2010 | A1 |
20100219934 | Matsumoto | Sep 2010 | A1 |
20100222102 | Rodriguez | Sep 2010 | A1 |
20100230494 | Okui | Sep 2010 | A1 |
20100231512 | Perez et al. | Sep 2010 | A1 |
20100234094 | Gagner et al. | Sep 2010 | A1 |
20100235786 | Maizels et al. | Sep 2010 | A1 |
20100261526 | Anderson et al. | Oct 2010 | A1 |
20100275159 | Matsubara et al. | Oct 2010 | A1 |
20100277411 | Yee et al. | Nov 2010 | A1 |
20100278393 | Snook et al. | Nov 2010 | A1 |
20100283739 | Zhang et al. | Nov 2010 | A1 |
20100296698 | Lien et al. | Nov 2010 | A1 |
20100302015 | Kipman et al. | Dec 2010 | A1 |
20100302357 | Hsu et al. | Dec 2010 | A1 |
20100303291 | Margolis | Dec 2010 | A1 |
20100306712 | Snook et al. | Dec 2010 | A1 |
20100306713 | Geisner et al. | Dec 2010 | A1 |
20100309097 | Raviv et al. | Dec 2010 | A1 |
20100315336 | Butler et al. | Dec 2010 | A1 |
20100321377 | Gay et al. | Dec 2010 | A1 |
20110007072 | Khan et al. | Jan 2011 | A1 |
20110018795 | Jang | Jan 2011 | A1 |
20110026765 | Ivanich et al. | Feb 2011 | A1 |
20110035666 | Geisner et al. | Feb 2011 | A1 |
20110043806 | Guetta et al. | Feb 2011 | A1 |
20110057875 | Shigeta et al. | Mar 2011 | A1 |
20110066984 | Li | Mar 2011 | A1 |
20110080470 | Kuno et al. | Apr 2011 | A1 |
20110090252 | Yoon et al. | Apr 2011 | A1 |
20110093820 | Zhang et al. | Apr 2011 | A1 |
20110107216 | Bi | May 2011 | A1 |
20110107270 | Wang et al. | May 2011 | A1 |
20110115486 | Frohlich et al. | May 2011 | A1 |
20110119640 | Berkes et al. | May 2011 | A1 |
20110134112 | Koh et al. | Jun 2011 | A1 |
20110148875 | Kim et al. | Jun 2011 | A1 |
20110164029 | King | Jul 2011 | A1 |
20110169726 | Holmdahl et al. | Jul 2011 | A1 |
20110173204 | Murillo et al. | Jul 2011 | A1 |
20110173235 | Aman et al. | Jul 2011 | A1 |
20110173574 | Clavin et al. | Jul 2011 | A1 |
20110181509 | Rautiainen et al. | Jul 2011 | A1 |
20110193939 | Vassigh et al. | Aug 2011 | A1 |
20110205151 | Newton et al. | Aug 2011 | A1 |
20110213664 | Osterhout et al. | Sep 2011 | A1 |
20110228978 | Chen et al. | Sep 2011 | A1 |
20110234840 | Klefenz et al. | Sep 2011 | A1 |
20110251896 | Impollonia et al. | Oct 2011 | A1 |
20110254765 | Brand | Oct 2011 | A1 |
20110267259 | Tidemand et al. | Nov 2011 | A1 |
20110286676 | El Dokor | Nov 2011 | A1 |
20110289455 | Reville et al. | Nov 2011 | A1 |
20110289456 | Reville et al. | Nov 2011 | A1 |
20110291925 | Israel et al. | Dec 2011 | A1 |
20110291988 | Bamji et al. | Dec 2011 | A1 |
20110296353 | Ahmed et al. | Dec 2011 | A1 |
20110299737 | Wang et al. | Dec 2011 | A1 |
20110304650 | Campillo et al. | Dec 2011 | A1 |
20110310007 | Margolis et al. | Dec 2011 | A1 |
20110314427 | Sundararajan | Dec 2011 | A1 |
20120001938 | Sandberg | Jan 2012 | A1 |
20120013613 | Vesely | Jan 2012 | A1 |
20120038549 | Mandella et al. | Feb 2012 | A1 |
20120038637 | Marks | Feb 2012 | A1 |
20120050157 | Latta et al. | Mar 2012 | A1 |
20120053015 | Esaki et al. | Mar 2012 | A1 |
20120062489 | Andersson et al. | Mar 2012 | A1 |
20120062558 | Lee et al. | Mar 2012 | A1 |
20120065499 | Chono | Mar 2012 | A1 |
20120068914 | Jacobsen et al. | Mar 2012 | A1 |
20120069168 | Huang et al. | Mar 2012 | A1 |
20120079420 | Arriola | Mar 2012 | A1 |
20120079421 | Arriola | Mar 2012 | A1 |
20120086729 | Baseley et al. | Apr 2012 | A1 |
20120087543 | Choi et al. | Apr 2012 | A1 |
20120105613 | Weng et al. | May 2012 | A1 |
20120110447 | Chen | May 2012 | A1 |
20120113223 | Hilliges et al. | May 2012 | A1 |
20120117514 | Kim | May 2012 | A1 |
20120121185 | Zavesky | May 2012 | A1 |
20120127070 | Ryoo et al. | May 2012 | A1 |
20120150650 | Zahand | Jun 2012 | A1 |
20120151421 | Clarkson | Jun 2012 | A1 |
20120157203 | Latta et al. | Jun 2012 | A1 |
20120162117 | Wilson et al. | Jun 2012 | A1 |
20120162214 | Chavez et al. | Jun 2012 | A1 |
20120167134 | Hendricks et al. | Jun 2012 | A1 |
20120170800 | da Silva Frazao et al. | Jul 2012 | A1 |
20120179970 | Hayes | Jul 2012 | A1 |
20120194517 | Izadi et al. | Aug 2012 | A1 |
20120204133 | Guendelman et al. | Aug 2012 | A1 |
20120206339 | Dahl | Aug 2012 | A1 |
20120218263 | Meier et al. | Aug 2012 | A1 |
20120223882 | Galor et al. | Sep 2012 | A1 |
20120223959 | Lengeling | Sep 2012 | A1 |
20120250936 | Holmgren | Oct 2012 | A1 |
20120257035 | Larsen | Oct 2012 | A1 |
20120268410 | King et al. | Oct 2012 | A1 |
20120309516 | Langridge et al. | Dec 2012 | A1 |
20120313848 | Galor et al. | Dec 2012 | A1 |
20120317510 | Noda et al. | Dec 2012 | A1 |
20120320080 | Giese et al. | Dec 2012 | A1 |
20120322527 | Aoki et al. | Dec 2012 | A1 |
20120324332 | Zaragoza et al. | Dec 2012 | A1 |
20130007616 | Bell et al. | Jan 2013 | A1 |
20130016896 | Seida | Jan 2013 | A1 |
20130019204 | Kotler et al. | Jan 2013 | A1 |
20130033483 | Im et al. | Feb 2013 | A1 |
20130055120 | Galor et al. | Feb 2013 | A1 |
20130127980 | Haddick et al. | May 2013 | A1 |
20130135218 | Jain et al. | May 2013 | A1 |
20130167092 | Yu et al. | Jun 2013 | A1 |
20130169594 | Yi | Jul 2013 | A1 |
20130182897 | Holz | Jul 2013 | A1 |
20130182902 | Holz | Jul 2013 | A1 |
20130191911 | Dellinger et al. | Jul 2013 | A1 |
20130194238 | Sakai | Aug 2013 | A1 |
20130207963 | Stirbu et al. | Aug 2013 | A1 |
20130222640 | Baek et al. | Aug 2013 | A1 |
20130239059 | Chen et al. | Sep 2013 | A1 |
20130246967 | Wheeler et al. | Sep 2013 | A1 |
20130278499 | Anderson | Oct 2013 | A1 |
20130293454 | Jeon et al. | Nov 2013 | A1 |
20130293683 | Zhou et al. | Nov 2013 | A1 |
20130300788 | Konno | Nov 2013 | A1 |
20130307935 | Rappel et al. | Nov 2013 | A1 |
20130321265 | Bychkov et al. | Dec 2013 | A1 |
20130321401 | Piemonte et al. | Dec 2013 | A1 |
20130335318 | Nagel et al. | Dec 2013 | A1 |
20130342459 | Karakotsios et al. | Dec 2013 | A1 |
20130342572 | Poulos et al. | Dec 2013 | A1 |
20140015831 | Kim et al. | Jan 2014 | A1 |
20140028716 | Yeh | Jan 2014 | A1 |
20140063055 | Osterhout et al. | Mar 2014 | A1 |
20140089849 | Choi et al. | Mar 2014 | A1 |
20140095119 | Lee et al. | Apr 2014 | A1 |
20140098018 | Kim et al. | Apr 2014 | A1 |
20140104206 | Anderson | Apr 2014 | A1 |
20140104274 | Hilliges et al. | Apr 2014 | A1 |
20140113507 | Vanzetto | Apr 2014 | A1 |
20140118255 | Billerbeck | May 2014 | A1 |
20140125813 | Holz | May 2014 | A1 |
20140134733 | Wu et al. | May 2014 | A1 |
20140137039 | Kroeger et al. | May 2014 | A1 |
20140139641 | Holz | May 2014 | A1 |
20140157135 | Lee et al. | Jun 2014 | A1 |
20140157209 | Dalal et al. | Jun 2014 | A1 |
20140177913 | Holz | Jun 2014 | A1 |
20140192206 | Holz | Jul 2014 | A1 |
20140201666 | Bedikian et al. | Jul 2014 | A1 |
20140201674 | Holz | Jul 2014 | A1 |
20140201683 | Holz | Jul 2014 | A1 |
20140201684 | Holz | Jul 2014 | A1 |
20140201690 | Holz | Jul 2014 | A1 |
20140222385 | Muenster et al. | Aug 2014 | A1 |
20140223385 | Ton et al. | Aug 2014 | A1 |
20140225918 | Mittal et al. | Aug 2014 | A1 |
20140240215 | Tremblay et al. | Aug 2014 | A1 |
20140240225 | Eilat | Aug 2014 | A1 |
20140247695 | Vangeel et al. | Sep 2014 | A1 |
20140248950 | Tosas Bautista | Sep 2014 | A1 |
20140249961 | Zagel et al. | Sep 2014 | A1 |
20140258880 | Holm et al. | Sep 2014 | A1 |
20140267019 | Kuzmin | Sep 2014 | A1 |
20140282282 | Holz | Sep 2014 | A1 |
20140304665 | Holz | Oct 2014 | A1 |
20140306903 | Huang et al. | Oct 2014 | A1 |
20140307920 | Holz | Oct 2014 | A1 |
20140317576 | Song et al. | Oct 2014 | A1 |
20140327782 | Mangla et al. | Nov 2014 | A1 |
20140333560 | Kramer | Nov 2014 | A1 |
20140340311 | Holz | Nov 2014 | A1 |
20140344731 | Holz | Nov 2014 | A1 |
20140344762 | Grasset et al. | Nov 2014 | A1 |
20140364209 | Perry | Dec 2014 | A1 |
20140375947 | Park et al. | Dec 2014 | A1 |
20150003673 | Fletcher | Jan 2015 | A1 |
20150016777 | Abovitz et al. | Jan 2015 | A1 |
20150026646 | Ahn et al. | Jan 2015 | A1 |
20150029218 | Williams et al. | Jan 2015 | A1 |
20150054729 | Minnen et al. | Feb 2015 | A1 |
20150084864 | Geiss et al. | Mar 2015 | A1 |
20150084989 | Laughlin et al. | Mar 2015 | A1 |
20150097772 | Starner | Apr 2015 | A1 |
20150103004 | Cohen et al. | Apr 2015 | A1 |
20150106767 | Abercrombie | Apr 2015 | A1 |
20150116214 | Grunnet-Jepsen et al. | Apr 2015 | A1 |
20150135132 | Josephson | May 2015 | A1 |
20150153832 | Krepec | Jun 2015 | A1 |
20150153833 | Pinault et al. | Jun 2015 | A1 |
20150160348 | Zweigle et al. | Jun 2015 | A1 |
20150169076 | Cohen et al. | Jun 2015 | A1 |
20150169175 | Cohen et al. | Jun 2015 | A1 |
20150169176 | Cohen et al. | Jun 2015 | A1 |
20150205358 | Lyren | Jul 2015 | A1 |
20150205400 | Hwang et al. | Jul 2015 | A1 |
20150206321 | Scavezze et al. | Jul 2015 | A1 |
20150220150 | Plagemann et al. | Aug 2015 | A1 |
20150220776 | Cronholm | Aug 2015 | A1 |
20150227795 | Starner et al. | Aug 2015 | A1 |
20150234569 | Hess | Aug 2015 | A1 |
20150243078 | Watson et al. | Aug 2015 | A1 |
20150253574 | Thurber | Sep 2015 | A1 |
20150258432 | Stafford et al. | Sep 2015 | A1 |
20150260990 | Ueno et al. | Sep 2015 | A1 |
20150277583 | Kasahara et al. | Oct 2015 | A1 |
20150309629 | Amariutei et al. | Oct 2015 | A1 |
20150338998 | Chathoth et al. | Nov 2015 | A1 |
20150346820 | Poupyrev et al. | Dec 2015 | A1 |
20150355827 | Van Der Westhuizen et al. | Dec 2015 | A1 |
20150379770 | Haley, Jr. et al. | Dec 2015 | A1 |
20150381970 | Sugimoto | Dec 2015 | A1 |
20160026253 | Bradski et al. | Jan 2016 | A1 |
20160034039 | Maeda et al. | Feb 2016 | A1 |
20160093105 | Rimon et al. | Mar 2016 | A1 |
20160154241 | Alhashim | Jun 2016 | A1 |
20160210781 | Thomas et al. | Jul 2016 | A1 |
20160239080 | Marcolina et al. | Aug 2016 | A1 |
20160328022 | Holz | Nov 2016 | A1 |
20170018119 | Kim et al. | Jan 2017 | A1 |
20170094184 | Gao | Mar 2017 | A1 |
20170287214 | Anderson et al. | Oct 2017 | A1 |
20170324841 | Clement et al. | Nov 2017 | A1 |
20170357407 | Palmaro | Dec 2017 | A1 |
20180239137 | Boger et al. | Aug 2018 | A1 |
20180239515 | Cooper et al. | Aug 2018 | A1 |
20180259406 | Waldman | Sep 2018 | A1 |
20180285636 | Fei et al. | Oct 2018 | A1 |
20190155384 | Fajt et al. | May 2019 | A1 |
20190286252 | Beach et al. | Sep 2019 | A1 |
Number | Date | Country |
---|---|---|
101930286 | Dec 2010 | CN |
102117117 | Jul 2011 | CN |
102135796 | Jul 2011 | CN |
102184020 | Sep 2011 | CN |
102216883 | Oct 2011 | CN |
102262438 | Nov 2011 | CN |
102402290 | Apr 2012 | CN |
102439538 | May 2012 | CN |
102902355 | Jan 2013 | CN |
103493106 | Jan 2014 | CN |
105308536 | Feb 2016 | CN |
11 2014 000 441 | Oct 2015 | DE |
1477924 | Nov 2004 | EP |
2369443 | Sep 2011 | EP |
2378488 | Oct 2011 | EP |
2419433 | Apr 2006 | GB |
2002512069 | Apr 2002 | JP |
20090006825 | Jan 2009 | KR |
2010148155 | Dec 2010 | WO |
2013169842 | Nov 2013 | WO |
2014113507 | Jul 2014 | WO |
Entry |
---|
Hurst et al. “Gesture-Based Interaction via Finger Tracking For Mobile Augmented Reality”, Multimedia Tools and Applications 62:233-258, Jan. 18, 2012. |
Schlattmann et al., “3D Interaction Techniques for 6 DOF Markerless Hand-Tracking”, 2009, 10 pages. |
Pachmann, Gabriel, “Virtual Reality in Assembly Simulation-Collision Detection, Simulation Algorithms, and Interaction Techniques”, May 29, 2000, 20 pages. |
Melax, S., et al., “Dynamics Based 3D Skeletal Hand Tracking”, Proceedings of Graphics Interface 2013. Canadian Information Processing Society, 2013. 8 pages. |
Wang, R., et al. “6D Hands: Markerless Hand-Tracking For Computer Aided Design” Proceedings of the 24th Annual ACM Symposium on User Interface Software and Technology. ACM, 2011, 8 pages. |
Montgomery, K., et al. “Spring: A General Framework for Collaborative, Real-Time Surgical Simulation.” Studies in health technology and informatics(2002), 8 pages. |
Wang, X., et al. “Tracking of Deformable Human Hand in Real Time as Continuous Input for Gesture-Based Interaction”, Proceedings of the 12th International Conference on Intelligent User Interfaces. ACM, 2007, 8 pages. |
Zadi, Shahram, et al. “KinectFusion: Real-Time 3D Reconstruction and Interaction Using a Moving Depth Camera” Proceedings of the 24th annual ACM symposium on User interface software and technology, Oct. 16-19, 2011, 10 pages. |
U.S. Appl. No. 14/527,742—Office Action dated Apr. 12, 2017, 20 pages. |
U.S. Appl. No. 14/527,742—Response to Office Action dated Apr. 12, 2017, filed Jul. 12, 2017, 20 pages. |
U.S. Appl. No. 14/527,742—Supplemental Response to Office Action dated Apr. 12, 2017, filed Aug. 17, 2017, 20 pages. |
U.S. Appl. No. 14/527,742—Office Action dated Nov. 2, 2017, 16 pages. |
U.S. Appl. No. 14/527,742—Response to Office Action dated Nov. 2, 2017 filed Dec. 20, 2017, 13 pages. |
U.S. Appl. No. 14/527,742—Office Action dated Jan. 18, 2018, 20 pages. |
U.S. Appl. No. 14/527,742—Response Office Action dated Jan. 18, 2018, filed Aug. 8, 2018, 9 pages. |
U.S. Appl. No. 14/527,742—Notice of Allowance dated Aug. 8, 2018, 8 pages. |
U.S. Appl. No. 14/541,078—Office Action dated Oct. 21, 2016, 22 pages. |
U.S. Appl. No. 14/541,078—Response to Office Action dated Oct. 21, 2016 filed Jan. 23, 2017, 15 pages. |
U.S. Appl. No. 14/541,078—Final Office Action dated May 19, 2017, 21 pages. |
U.S. Appl. No. 14/541,078—Response to Final Office Action dated May 19, 2017, filed Aug. 7, 2017, 16 pages. |
U.S. Appl. No. 14/541,078—Supplemental Response to Final Office Action dated May 19, 2017, filed Sep. 6, 2017, 15 pages. |
U.S. Appl. No. 14/530,364—Office Action dated Mar. 13, 2017, 35 pages. |
U.S. Appl. No. 14/530,364—Response to Office Action dated Mar. 13, 2017, filed May 31, 2017, 12 pages. |
U.S. Appl. No. 14/530,364—Office Action dated Sep. 8, 2017, 19 pages. |
U.S. Appl. No. 14/530,364—Response to Office Action dated Sep. 8, 2017 filed Nov. 8, 2017, 10 pages. |
U.S. Appl. No. 14/541,078—2nd Response to Final Office Action dated May 19, 2017, filed Sep. 6, 2017, 15 pages. |
U.S. Appl. No. 16/228,521—Office Action dated Nov. 22, 2019, 13 pages. |
U.S. Appl. No. 16/228,521—Response to Office Action dated Nov. 22, 2019, filed Feb. 24, 2020, 12 pages. |
U.S. Appl. No. 16/228,521—Notice of Allowance dated Apr. 7, 2020, 16 pages. |
U.S. Appl. No. 14/530,364—Notice of Allowance dated Jan. 18, 2018, 6 pages. |
U.S. Appl. No. 14/530,364—Corrected Notice of Allowance dated Feb. 9, 2018, 5 pages. |
U.S. Appl. No. 16/000,768—Office Action dated Apr. 8, 2021, 37 pages. |
Liang Hui, Junsong Yuan, and Daniel Thalmann. “3D fingertip and palm tracking in depth image sequences.” Proceedings of the 20th ACM international conference on Multimedia. 2012. (Year: 2012). |
U.S. Appl. No. 14/541,078—Office Action dated Nov. 7, 2018, 40 pages. |
U.S. Appl. No. 14/541,078—Response to Nonfinal Office Action dated Nov. 7, 2018, filed Mar. 6, 2019, 13 pages. |
U.S. Appl. No. 14/541,078—Notice of Allowance dated May 6, 2019, 13 pages. |
U.S. Appl. No. 16/568,022—Office Action dated Feb. 10, 2021, 52 pages. |
U.S. Appl. No. 16/568,022—Response to Non-Final Office Action dated Feb. 10, 2021 filed May 7, 2021, 35 pages. |
U.S. Appl. No. 16/568,022—Final Office Action dated Jun. 14, 2021, 29 pages. |
U.S. Appl. No. 16/568,022—Response to Final Office Action dated Jun. 14, 2021 filed Aug. 16, 2021, 16 pages. |
U.S. Appl. No. 16/568,022—Advisory Action dated Sep. 17, 2021, 3 pages. |
U.S. Appl. No. 16/000,768 Notice of Allowance, dated Jul. 22, 2021, 10 pages. |
Melax, S., et al., “Dynamics Based 3D Skeletal Hand Tracking”, Proceedings of Graphics Interface Conference 2013, May 29-31, Regina, Saskatchewan, Canada. Canadian Information Processing Society, 2013. 8 pages. |
Anonymous, Multilateration, Wikipedia, retrieved on Aug. 19, 2022, 5 pages. Retrieved from the internet [URL: https://en.wikipedia.org/w/index.php?title=Multilateration&oldid=523281858]. |
Anonymous, Kabsch Algorithm, Wikipedia, retrieved on Aug. 21, 2022, 4 pages. Retrieved from the internet [URL: https://en.wikipedia.org/wiki/Kabsch_algorithm]. |
Anonymous, Euclidean Group, Wikipedia, retrieved on Aug. 21, 2022, 7 pages. Retrieved from the internet [URL: http://en.wikipedia.org/wiki/Euclidean_group]. |
Anonymous, Affine Transformation, Wikipedia, retrieved on Aug. 21, 2022, 8 pages. Retrieved from the internet [URL—https://en.wikipedia.org/wiki/Affine_transformation]. |
Anonymous, Rotation Matrix, Wikipedia, retrieved on Aug. 21, 2022, 26 pages. retrieved from the internet [URL—https://en.wikipedia.org/wiki/Rotation_matrix]. |
Anonymous, 3D Rotation, Wikipedia, retrieved on Aug. 21, 2022, 10 pages. Retrieved from the internet [URL: https://en.wikipedia.org/wiki/3D_rotation_group]. |
Anonymous, Transformation Matrix, Wikipedia, retrieved on Aug. 21, 2022, 10 pages. Retrieved from the internet [URL: https://en.wikipedia.org/wiki/Transformation_matrix]. |
Anonymous, Axis-angle representation, Wikipedia, retrieved on Aug. 21, 2022, 6 pages. Retrieved from the internet [URL: https://en.wikipedia.org/wiki/Axis%E2%80%93angle_representation]. |
Anonymous, Visual odometry, Wikipedia, retrieved on Aug. 21, 2022, 6 pages. Retrieved from the internet [URL: https://en.wikipedia.org/wiki/Visual_odometry]. |
Anonymous, Optical flow, Wikipedia, retrieved on Aug. 21, 2022, 7 pages. Retrieved from the internet [URL—https://en.wikipedia.org/wiki/Optical_flow]. |
PCT/US2016/017632—International Search Report and Written Opinion dated Jul. 27, 2016, 13 pages. |
PCT/US2016/017632—International Preliminary Report on Patentability dated Aug. 24, 2017, 12 pages. |
CN 201680018136.2—Response to Second Office Action dated 10 Sep., 2020, as filed Nov. 25, 2020, 13 pages Including English translation. |
CN 201680018136.2—Notice of Allowance dated Dec. 11, 2020, 2 pages. |
CN 201680018136.2—Second Office Action dated Sep. 10, 2020, 6 pages. |
CN 201680018136.2—Response to First Office Action dated Dec. 23, 2019, as filed May 7, 2020, 22 pages including English translation. |
CN 201680018136.2—First Office Action dated Dec. 23, 2019, 12 pages including English translation. |
Korida, et al., “An Interactive 3D Interface for a Virtual Ceramic Art Work Environment”, published on Virtual Systems and MultiMedia, 1997. VSMM '97. Proceedings., International Conference (Sep. 10, 1997), 8 pages. |
Wikipedia, “Transformation matrix”, published Sep. 6, 2014, [online] https://web.archive.org/web/20140906170238/http:I/en.wikipedia.org/wiki/Transformation_matrix (Year: 2014), 8 pages. |
Hummel, Johannes et al., “An evaluation of two simple methods for representing heaviness in immersive virtual environments.”, 2013, 8 pages. |
Bergamasco, Massimo et al., “A realistic approach for grasping and moving virtual objects.” Proceedings of IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS'94). vol. 1. IEEE, 1994, 8 pages. |
U.S. Appl. No. 14/527,742, filed Oct. 29, 2014, U.S. Pat. No. 10,168,873, Jan. 1, 2019, Granted. |
U.S. Appl. No. 16/228,521, filed Dec. 20, 2018, U.S. Pat. No. 10,739,965, Aug. 11, 2020, Granted. |
U.S. Appl. No. 16/941,448, filed Jul. 28, 2020, US-20200356238-A1, Nov. 12, 2020, Under Exam. |
U.S. Appl. No. 17/532,976, filed Nov. 22, 2021, US-20220083880-A1, Mar. 17, 2022, Allowed. |
U.S. Appl. No. 16/568,022, filed Sep. 11, 2019, US-20200004403-A1, Jan. 2, 2020, Under Exam. |
U.S. Appl. No. 16/510,535, filed Jul. 12, 2019, U.S. Pat. No. 10,921,949, Feb. 16, 2021, Granted. |
U.S. Appl. No. 18/114,156, filed Feb. 24, 2023, Pending. |
U.S. Appl. No. 17/867,648, filed Jul. 18, 2022, US-20220357800-A1, Nov. 10, 2022, Published. |
U.S. Appl. No. 14/530,364, filed Oct. 31, 2014, U.S. Pat. No. 9,996,797, Jun. 12, 2018, Granted. |
U.S. Appl. No. 16/000,768, filed Jun. 5, 2018, U.S. Pat. No. 11,182,685, Nov. 23, 2021, Granted. |
U.S. Appl. No. 17/532,976, filed Nov. 22, 2021, 20220083880, Mar. 17, 2022, Allowed. |
U.S. Appl. No. 14/541,078, filed Nov. 13, 2014, U.S. Pat. No. 10,416,834, Sep. 17, 2019, Granted. |
U.S. Appl. No. 16/568,022, filed Sep. 11, 2019, 20200004403, Jan. 2, 2020, Pending. |
U.S. Appl. No. 14/626,820, filed Feb. 19, 2015, U.S. Pat. No. 10,353,532, Jul. 16, 2019, Granted. |
U.S. Appl. No. 16/510,535, filed Jul. 19, 2019, U.S. Pat. No. 10,921,949, Feb. 16, 2021, Granted. |
U.S. Appl. No. 17/175,439, filed Feb. 12, 2021, U.S. Pat. No. 11,599,237, Mar. 7, 2023, Granted. |
U.S. Appl. No. 18/114,156, filed Feb. 24, 2023, 20240094860, Mar. 21, 2024, Published. |
U.S. Appl. No. 14/626,683, filed Feb. 19, 2015, U.S. Pat. No. 9,767,613, Sep. 19, 2017, Granted. |
U.S. Appl. No. 15/678,896, filed Aug. 16, 2017, U.S. Pat. No. 9,911,240, Mar. 6, 2018, Granted. |
U.S. Appl. No. 14/626,898, filed Feb. 19, 2015, U.S. Pat. No. 9,696,795, Jul. 4, 2017, Granted. |
U.S. Appl. No. 15/587,173, filed May 4, 2017, U.S. Pat. No. 10,261,594, Apr. 16, 2019, Granted. |
U.S. Appl. No. 16/383,553, filed Apr. 12, 2019, U.S. Pat. No. 10,936,080, Mar. 2, 2021, Granted. |
U.S. Appl. No. 17/187,676, filed Feb. 26, 2021, U.S. Pat. No. 11,392,212, Jul. 19, 2022, Granted. |
U.S. Appl. No. 17/867,648, filed Jul. 18, 2022, 20220357800, Nov. 10, 2022, Allowed. |
U.S. Appl. No. 14/626,904, filed Feb. 19, 2015, Abandoned. |
Bowman, “Design and Evaluation of Menu Systems for Immersive Virtual Environments”, Proceedings of the Virtual Reality 2001 Conference (VR'01) 0-7695-0948—Jul. 2001 $17.00 © 2001 IEEE, pp. 7-8. (Year: 2001). |
Sato, “Implementation and Evaluations of Vision-based Finger Flicking Gesture Recognition for Tabletops”, 978-1-4244-2898—Apr. 2008/ $25.00 2008 IEEE, pp. 2-3. (Year: 2008). |
Steinicke, “Grab-and-Throw Metaphor: Adapting Desktop-based Interaction Paradigms to Virtual Reality”, IEEE Symposium on 3D User Interfaces Mar. 25-26, 2006 Alexandria, Virginia, USA, pp. 1-4. (Year: 2006). |
PCT/US2014/011737—International Search Report and Written Opinion dated May 30, 2014, 20 pages. |
CN 201480014375.1—First Office Action dated Jul. 3, 2017, 7 pages. |
CN 201480014375.1—Response to First Office Action dated Jul. 3, 2017 filed Nov. 17, 2017, 9 pages. |
Bullock, Jamie, Tychonas Michailidis, and Matthieu Poyade. “Towards a live interface for direct manipulation of spatial audio.” Proceedings of the international conference on live interfaces. Sussex: Reframe Books, 2016 (Year: 2016). |
CN 201480014375.1—Second Office Action dated Jan. 17, 2018, 15 pages. |
CN 201480014375.1—Response to Second Office Action dated Jan. 17, 2018 filed Jun. 1, 2018, 17 pages. |
CN 201480014375.1—Third Office Action dated Aug. 20, 2018, 15 pages. |
CN 201480014375.1—Response to Third Office Action dated Aug. 20, 2018 filed Nov. 5, 2018, 5 pages. |
CN 201480014375.1—Fourth Office Action (Rejection Decision) dated Jan. 25, 2019, 6 pages. |
CN 201480014375.1—Request for re-examination filed May 9, 2019, 11 pages including English translation. |
CN 201480014375.1—First Board Opinion mailed Oct. 10, 2020, 7 pages. |
CN 201480014375.1—Response to First Board Opinion filed Nov. 20, 2020, 10 pages. |
Wu et al., Vision-Based Gesture Recognition: A Review, in Gesture-Based Communication in Human-Computer Interaction, Springer, dated 1999, 13 pages, pp. 103-115. |
Pavlovic, V.I., et al., “Visual Interpretation of Hand Gestures for Human-Computer Interaction: A Review,” IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 19, No. 7, Jul. 1997, pp. 677-695. |
CN 201480014375.1—Second Board Opinion mailed Apr. 12, 2021, 14 pages. |
Bowman, Doug A., et al., “3D User Interfaces: New Directions and Perspectives”, Nov./Dec. 2008, IEEE Computer Society 17pages. |
PCT/US2014/011737—International Preliminary Report on Patentability dated Jul. 30, 2015, 15 pages. |
Number | Date | Country | |
---|---|---|---|
20200356238 A1 | Nov 2020 | US |
Number | Date | Country | |
---|---|---|---|
61897186 | Oct 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16228521 | Dec 2018 | US |
Child | 16941448 | US | |
Parent | 14527742 | Oct 2014 | US |
Child | 16228521 | US |