Systems and methods for human hand gesture recognition through a training mode and a recognition mode are disclosed. In the training mode, a user can move a handheld device with a hand gesture intended to represent a command. Sensors within the handheld device can record raw data, which can be processed to obtain a set of values corresponding to a set of discrete features, which is stored in a database and associated with the intended command. The process is repeated for various hand gestures representing different commands. In the recognition mode, the user can move the handheld device with a hand gesture. A computer system can compare a set of values corresponding to a set of discrete features derived from the hand gesture with the sets of values stored in the database, select a command with the closest match and displays and/or executes the command.
|
45. A method, comprising:
detecting a first position of a mobile phone using a gyroscope;
consulting a look up table and matching the first position with a first command corresponding to a first column of the look up table representing a first trajectory of the mobile phone;
causing, based on the first command, a component of the mobile phone to enter into a sleep mode of operation;
detecting a second position of the mobile phone by using the gyroscope;
consulting the look up table and matching the second position with a second command corresponding to a second column of the look up table representing a second trajectory of the mobile phone;
causing, based on the second command, the component of the mobile phone to enter into an active mode of operation.
37. A method, comprising:
receiving, by a system comprising a processor, information from a gyroscope regarding a movement of the system;
consulting a look up table that associates discrete features representing trajectories of movements of the system with a plurality of commands;
wherein a discrete feature of the first plurality of discrete features or the second plurality of discrete features includes at least one of an angle of the trajectory, an inverse tangent of a change in a pitch associated with the movement divided by a change in a yaw associated with the movement, a location of a crossing point associated with the character, or a number of times in which the trajectory changes direction;
matching the movement to a command from the plurality of commands; and
switching, based on the command, a component of the system from a sleep mode of operation to an active mode of operation.
28. A handheld device, comprising:
a first processor;
a programmable module comprising a look up table that associates a plurality of discrete features representing trajectories of movements of the handheld device with a plurality of commands; wherein a discrete feature of the plurality of discrete features includes at least one of an angle of the trajectory, an inverse tangent of a change in a pitch associated with the movement divided by a change in a yaw associated with the movement, a location of a crossing point associated with the character, or a number of times in which the trajectory changes direction; and
a gyroscope, wherein the first processor receives at least a portion of first information related to a first movement of the handheld device from the gyroscope, determines the first movement based on the portion, consults the look up table and matches the first movement to a command from the plurality of commands, and wherein a first component coupled to the first processor enters a first active mode of operation from a sleep mode of operation based on the command.
14. A method for gesture recognition, comprising:
obtaining first training data related to a first trajectory of a first movement of a handheld device using a gyroscope and an accelerometer;
determining the first trajectory in response to integrating a portion of the first training data associated with the gyroscope with another portion of the first training data associated with the accelerometer representing a first tilt of the handheld device relative to earth's gravity;
converting the first training data into first values corresponding to a first set of a plurality of discrete features; wherein a discrete feature of the plurality of discrete features includes at least one of an angle of the trajectory, an inverse tangent of a change in a pitch associated with the movement divided by a change in a yaw associated with the movement, a location of a crossing point associated with the character, or a number of times in which the trajectory changes direction;
associating the first values with a first character;
storing the first values and information representing the first character in a data store; and
displaying the first character based on the first values.
25. A method, comprising:
obtaining first information from a gyroscope based on a first trajectory of a first movement of a handheld device;
storing the first information and authentication information representing an identity of a user in a training data store;
obtaining second information from the gyroscope based on a second trajectory of a second movement of the handheld device;
in response to determining an orientation of the handheld device utilizing a magnetometer, modifying the first information and the second information according to the orientation; wherein the first trajectory and the second trajectory are connected to a set of values corresponding to a set of selected discrete features wherein a discrete feature of the plurality of discrete features includes at least one of an angle of the trajectory, an inverse tangent of a change in a pitch associated with the movement divided by a change in a yaw associated with the movement, a location of a crossing point associated with the character, or a number of times in which the trajectory changes direction;
in response to the modifying, comparing the second information with the first information; and
authenticating the identity of the user in response to the comparing of the second information with the first information.
1. A handheld device, comprising:
inertial sensors comprising a gyroscope that generates gyroscope data representing a trajectory of a movement of the handheld device and an accelerometer that generates accelerometer data representing a tilt of the handheld device relative to earth's gravity; and
a processing component that:
determines the trajectory of the movement of the handheld device by combining the gyroscope data representing the trajectory of the movement of the handheld device and the accelerometer data representing the tilt of the handheld device relative to earth's gravity;
converts, via a training mode, a first portion of the data into a first set of values corresponding to a first plurality of discrete features,
associates the first set of values with a character, stores the first set of values and information representing the character in a training database,
converts, via a recognition mode, a second portion of the data into a second set of values corresponding to a second plurality of discrete features, wherein a discrete feature of the first plurality of discrete features or the second plurality of discrete features includes at least one of an angle of the trajectory, an inverse tangent of a change in a pitch associated with the movement divided by a change in a yaw associated with the movement, a location of a crossing point associated with the character, or a number of times in which the trajectory changes direction; and
in response to a determination that the second set of values matches the first set of values with respect to a defined condition, displays the character.
21. A handheld device, comprising:
a gyroscope;
an accelerometer;
a processing component that receives gyroscope data from the gyroscope representing a trajectory of a movement of the handheld device and receives accelerometer data from the accelerometer representing a tilt of the handheld device relative to earth's gravity;
a programmable module coupled to the processing component that includes a look up table that associates a plurality of discrete features comprising the trajectory of the movement of the handheld device and the tilt of the handheld device with a plurality of characters; and
a data store for storing a plurality of sets of values corresponding to the plurality of discrete features, wherein the processing component converts a first portion of the data into a first set of values corresponding to first features of the plurality of discrete features, associates, utilizing the look up table, the first set of values with a character of the plurality of characters based on the first features, stores the first set of values and information representing the character in the data store, converts a second portion of the data into a second set of values corresponding to second features of the plurality of discrete features, matches, using the data store, the second set of values to one of the plurality of sets of values, and displays the character using the information, wherein a discrete feature of the plurality of discrete features includes at least one of an angle of the trajectory, an inverse tangent of a change in a pitch associated with the movement divided by a change in a yaw associated with the movement, a location of a crossing point associated with the character, or a number of times in which the trajectory changes direction.
3. The handheld device of
4. The handheld device of
a display for displaying the trajectory of the movement.
5. The handheld device of
6. The handheld device of
8. The handheld device of
9. The handheld device of
10. The handheld device of
11. The handheld device of
12. The handheld device of
13. The handheld device of
15. The method of
obtaining the first training data using the gyroscope, the accelerometer, and a sensor comprising a compass.
16. The method of
17. The method of
18. The method of
learning a character with a plurality of strokes according to a plurality of vectors.
19. The method of
executing a first command associated with the first values.
20. The method of
obtaining second training data related to a second trajectory of a second movement of the handheld device using the gyroscope and the accelerometer;
determining the second trajectory in response to integrating a portion of the second training data associated with the gyroscope with another portion of the second training data associated with the accelerometer representing a second tilt of the handheld device relative to earth's gravity;
converting the second training data into second values corresponding to a second set of the plurality of discrete features;
associating the second values with a second character;
storing the second values and information representing the second character in the data store;
obtaining trajectory data related to a third trajectory of a third movement of the handheld device using the gyroscope and the accelerometer;
converting the trajectory data into third values corresponding to a third set of the plurality of discrete features;
matching the third values with the first values or the second values; and
displaying the first character or the second character in response to the matching.
22. The handheld device of
a display for displaying the trajectory in real time and displaying the character based on a third set of values corresponding to the trajectory.
23. The handheld device of
24. The handheld device of
26. The method of
27. The method of
generating a sound within a predetermined time period before or after the second movement;
detecting the sound using a microphone embedded in the handheld device; and
authenticating the user in response to the comparing and the detecting.
29. The handheld device of
a second processor coupled to the gyroscope for processing the first information.
30. The handheld device of
the first processor enters a second active mode of operation in response to receiving another portion of the first information from the second processor.
31. The handheld device of
an accelerometer for providing second information related to the first movement of the handheld device, wherein
the first component enters the first active mode of operation based on the second information.
33. The handheld device of
a camera; and
a display, wherein the camera switches from the sleep mode to the first active mode based on the first movement, wherein the camera uses more electrical power during the first active mode than during the sleep mode, and wherein the display is not switched from the sleep mode to the first active mode based on the first movement.
34. The handheld device of
35. The handheld device of
a second processor that facilitates switching the microprocessor from the sleep mode to the first active mode based on the first movement,
wherein the first processor comprises a microprocessor,
wherein the first component comprises a camera,
wherein the microprocessor facilitates switching the camera from the sleep mode to the first active mode based on the first movement,
wherein the microprocessor facilitates switching the display from the sleep mode to the first active mode based on a second movement of the handheld device and not based on the first movement, and
wherein the first active mode of operation is associated with a first consumption of electrical power that is greater than a second consumption of electrical power associated with the sleep mode of operation.
36. The handheld device of
38. The method of
43. The method of
preventing another component of the system from switching from the sleep mode to the active mode based on the movement.
44. The method of
46. The method of
|
This application claims the benefit of U.S. Provisional Patent Application 61/259,288, filed Nov. 9, 2009, and entitled “INTELLIGENT COMPUTER SYSTEM AND TECHNIQUES FOR CHARACTER AND COMMAND RECOGNITION RELATED TO HUMAN MOVEMENTS”, the entirety of which is incorporated by reference herein.
The present invention relates to a handheld computerized human hand gesture recognition system, and particularly to a handheld computer system that includes a handheld device having Micro Electro-Mechanical Systems (MEMS) based inertial sensors including a gyroscope and an accelerometer, and a miniature compass.
A hand gesture is a form of non-verbal communication in which visible hand actions allow an individual to communicate messages. Hand gesture recognition is being increasingly used in computer technology, with the goal of interpreting human gestures via mathematical algorithms. Hand gesture recognition technology enables humans to interface with a computer and interact naturally without any mechanical devices. For example, using the concept of gesture recognition, it is possible to point a finger at the computer screen so that the cursor will move accordingly.
The hand gesture recognition concept is also being increasingly used in the video game technology, in which a player's hand gestures are communicated to a computer system by way of a handheld device. For example, Wii, a home video game console made by Nintendo Co. Ltd. uses a wireless controller, the Wii Remote, which can be used as a handheld pointing device and can detect movement in three dimensions. The Wii remote can study changes in acceleration over time to represent gestures.
There are many challenges associated with the accuracy and usefulness of conventional gesture recognition computer systems and software. Conventional systems are not highly accurate because they generally rely on linear sensors, whereas human hand gestures largely include angular movements. Thus, conventional systems can only properly recognize large hand movements and are unable to properly differentiate between hand gestures that are only slightly different from each other. It would be desirable to have recognition systems that can differentiate between similar hand gestures.
The following presents a simplified summary of the subject disclosure in order to provide a basic understanding of some aspects thereof. This summary is not an extensive overview of the various embodiments of the subject disclosure. It is intended to neither identify key or critical elements nor delineate any scope. Its sole purpose is to present some concepts in a simplified form as a prelude to the more detailed description that is presented later.
The present invention relates to novel and efficient handheld computer system and methodology for human hand gesture recognition. The computer system includes a remote handheld device that includes inertial sensors, for example, a gyroscope, an accelerometer, and/or a compass. In the training mode, a user makes an intentional hand gesture while holding the handheld device to communicate a command or a character. Data related to the gesture movement is captured and provided by the inertial sensors. The data is pre-processed, filtered and converted into a set of values corresponding to a set of discrete features. The set of values are stored in a database and a command or a character is associated with the set. The database is populated for various hand gestures. During operation, the same data capture and conversion steps are performed for a user's hand gestures, and the set of values is compared with the database. The command associated with the match or the closest match is executed, or the character associated with the match or the closest match is displayed on the display of the handheld device.
To the accomplishment of the foregoing and related ends, the one or more aspects comprise the features hereinafter fully described and particularly pointed out in the claims. The following description and the annexed drawings set forth in detail certain illustrative features of the one or more aspects. These features are indicative, however, of but a few of the various ways in which the principles of various aspects may be employed, and this description is intended to include all such aspects and their equivalents.
The above and other objects and advantages of the present invention will be apparent upon consideration of the following detailed description, taken in conjunction with the accompanying drawings, in which like reference characters refer to like parts throughout, and in which:
This present invention discloses system(s) and techniques for recognizing, character(s) or commands intended by human movements, and displaying the characters or executing the commands. The claimed subject matter is now described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details and examples are set forth in order to provide a thorough understanding of the subject innovation. One of ordinary skill in the art will understand, however, that the subject innovation may be practiced without these specific details and is not limited by these specific details and examples. One of ordinary skill in the art will also appreciate that well-known structures and devices are shown in block diagram form in order to facilitate describing the claimed subject matter.
As used in this application, the terms “component,” “module,” “system,” or the like can, but need not, refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component might be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a controller and the controller can be a component. One or more components can reside within a process and/or thread of execution and a component can be localized on one computer and/or distributed between two or more computers.
Furthermore, the claimed subject matter may be implemented as a method, apparatus, or article of manufacture using standard programming and/or engineering techniques to produce software, firmware, hardware, or any combination thereof to control a computer to implement the disclosed subject matter. The term “article of manufacture” as used herein is intended to encompass a computer program accessible from any computer-readable device, carrier, or media. For example, computer readable media can include but are not limited to magnetic storage devices (e.g., hard disk, floppy disk, magnetic strips . . . ), optical disks (e.g., compact disk (CD), digital versatile disk (DVD) . . . ), smart cards, and flash memory devices (e.g., card, stick, key drive . . . ). Additionally it should be appreciated that a carrier wave can be employed to carry computer-readable electronic data such as those used in transmitting and receiving electronic mail or in accessing a network such as the Internet or a local area network (LAN). Of course, those skilled in the art will recognize many modifications may be made to this configuration without departing from the scope or spirit of the claimed subject matter.
Moreover, the word “exemplary” is used herein to mean serving as an example, instance, or illustration. Any aspect or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects or designs. Rather, use of the word exemplary is intended to present concepts in a concrete fashion. As used in this application, the term “or” is intended to mean an inclusive “or” rather than an exclusive “or.” Therefore, unless specified otherwise, or clear from context, “X employs A or B” is intended to mean any of the natural inclusive permutations. That is, if X employs A; X employs B; or X employs both A and B, then “X employs A or B” is satisfied under any of the foregoing instances. In addition, the articles “a” and “an” as used in this application and the appended claims should generally be construed to mean “one or more” unless specified otherwise or clear from context to be directed to a singular form.
As used herein, the terms “infer” and “inference” generally refer to the process of reasoning about or inferring states of the system, environment, and/or user from a set of observations as captured via events and/or data. Inference can be employed to identify a specific context or action, or can generate a probability distribution over states, for example. The inference can be probabilistic—that is, the computation of a probability distribution over states of interest based on a consideration of data and events. Inference can also refer to techniques employed for composing higher-level events from a set of events and/or data. Such inference results in the construction of new events or actions from a set of observed events and/or stored event data, whether or not the events are correlated in close temporal proximity, and whether the events and data come from one or several event and data sources.
MEMS-based motion sensors include an accelerometer and a gyroscope. An accelerometer can be used to measure linear acceleration. The physical mechanisms underlying MEMS-based accelerometers include capacitive, piezoresistive, electromagnetic, piezoelectric, ferroelectric, optical and tunneling. MEMS-based accelerometers can be simple devices consisting of a cantilever beam with a predetermined test mass (also known as proof mass seismic mass). Under the influence of external accelerations, the mass deflects from its neutral position. This deflection is measured in an analog or digital manner. Commonly, the capacitance between a set of fixed beams and a set of beams attached to the proof mass is measured.
Other types of MEMS-based accelerometers can contain a small heater at the bottom of a very small dome, which heats the air inside the dome to cause it to rise. A thermocouple on the dome determined where the heated air reaches the dome and the deflection off the center is a measure of the acceleration applied to the sensor. MEMS-based accelerometers generally operate in-plane, that is, they are designed to be sensitive only to a direction of the plane of the die. By integrating two devices perpendicularly on a single die a two-axis accelerometer can be made. By adding an additional out-of-plane device, three axes can be measured. Accelerometers with integral electronics offer readout electronics and self-test capability.
A compass is an instrument used for determining direction relative to the earth's magnetic pole. It consists of a magnetized pointer free to align itself with the earth's magnetic field. Miniature compasses are usually built out of two or three magnetic field sensors, for example Hall sensors, that provide data for a microprocessor. The correct heading relative to the compass is calculated using trigonometry. Often, a miniature compass is a discrete component which outputs either a digital or analog signal proportional to its orientation. This signal is interpreted by a controller or microprocessor. The compass can use highly calibrated internal electronics to measure the response of the compass to the earth's magnetic field. Examples of miniature compasses available in the marketplace include the HMC1051Z single-axis and the HMC1052 two-axis magneto-resistive sensors sold by Honeywell International Inc., the AK8973 3-axis electronic compass sold by Asahi Kasei Microdevices Corporation, and the AMI 201 (2-axis) and the AMI 302 (3-axis) electronic compass modules sold by Aichi Micro Intelligent Corporation of Japan.
A gyroscope is a device used for measuring or maintaining orientation, based on the principles of conservation of angular momentum. MEMS-based gyroscopes use vibrating proof masses. Those masses typically vibrate at a high frequency. As the sensor housing rotates in inertial space a Coriolis force is induced on the proof mass. The Coriolis force causes a vibration in an orthogonal plane and the amplitude of the orthogonal motion can be measured. This type of device is also known as a Coriolis vibratory gyro because as the plane of oscillation is rotated, the response detected by the transducer results from the Coriolis term in its equations of motion (“Coriolis force”). A vibrating structure gyroscope can be implemented as a tuning fork resonator, a vibrating wheel or a wine glass resonator using MEMS technology.
One of ordinary skill in the art will appreciate that the present invention is not limited to MEMS based devices, that the MEMS based embodiments disclosed herein are exemplary, and that the present invention can be implemented with any accelerometer, compass and gyroscope that can be incorporated in a handheld device. One of ordinary skill in the art will appreciate that other types of inertial sensors that can be included in a handheld device, for example, quartz sensors, can also be used in the present invention. Other types of inertial sensors that include mechanical components on the micron or millimeter scale and can be combined with electronic circuitry can also be used in the present invention.
At step 114, the data related to the trajectory of the gesture made in Step 112 is extracted by using the gyroscope, accelerometer and compass embedded in the handheld device. As human movement is largely angular, a trajectory drawn in the air with the hand can be expressed primarily with angular movement using a gyroscope. The raw gyroscope data is proportional to angular velocity, so this data can be preprocessed to remove any offset and integrated to provide an estimate of angular movement. The gyro bias offset, also known as the null voltage, is the measured voltage when the gyro is not rotating about its sensitive axis. Gyro output voltage measurements above the bias offset indicate rotation in one direction (e.g., clockwise), while voltage measurements below the bias offset indicate rotation in the opposite direction (e.g., counter-clockwise).
Additional filtering to clean up the signal may remove involuntary hand jitter and other unwanted high frequency components. A jitter is a small and rapid vibration that is inherently present in a human hand. A dead zone or similar mechanism can be used to remove slow, unintentional movement. A dead zone in a sensor is the point, period, area or zone where a sensor does not work. InvenSense Inc., the assignee of the present patent application, has developed proprietary methodologies, software and architectures for calibrating and correcting errors in handheld devices having MEMS-based gyroscopes and accelerometers and/or miniature compasses. These innovations allow gesture recognition systems to interpret and differentiate between the various commands and characters intended by the user, even when different commands and characters are represented by hand gestures that are only slightly different from each other.
Returning to Step 114, the accelerometer data can also be used to help stabilize gyroscope bias, and to facilitate determining the direction of gravity. The accelerometer data can also be correlated with the gyroscope data to distinguish between rotation with a strong linear component, or moment arm, signifying intentional movement through the air, and rotational component without such component, signifying unintentional rotation of the device within the user's hand. A compass can also be incorporated in the handheld device to stabilize the gyroscope bias in the yaw direction. The result of this preprocessing is a trajectory containing X and Y data points corresponding to yaw and pitch angular movement. Pitch, roll and yaw refer to movements of an object that are measured as angles. Pitch is up and down like a box lid. Yaw is left and right like a door on hinges, and roll is rotation.
To help isolate the trajectory, in one embodiment, a button on the handheld device can be used to distinguish between intentional gesture movement and unintentional movement or wind-up movement. The button can be held down during the course of gesture, or it can be pressed once at the beginning of the gesture and once at the end. In another embodiment, the speed of the trajectory can be used to determine start and end of a gesture. For example, when the user begins a large, fast movement, a gesture is assumed to have begun. When some time passes and the total amount or speed of movement is reduced to below some threshold value, the gesture is assumed to have ended. In yet another embodiment, any movement is assumed to be a potential gesture movement, and a moving window of data is used to capture gestures.
As users may not be familiar with the experience of using hand movement to draw predetermined trajectories in the air, feedback can be used to help the user learn to control the trajectory. In this case, an image corresponding to the X and Y path of the trajectory can be displayed, for example, on a computer display, to notify the user of the trajectory that will be used in the gesture recognition algorithm. One of ordinary skill in the art would appreciate that it would useful to normalize the trajectory in space and time, such that it is suitable for storage, querying and comparison in a database structure. To normalize it in space, the trajectory can be scaled down by an amount or ratio determined by the maximum of the total X and Y spans. To normalize in time, averaging can be used to reduce the dumber of data points. After normalization, all trajectories would have the same size and the same number of data points, thereby making it easier to compare them by shape.
At Step 116, the trajectory data can now be converted to a set values corresponding to a set of selected discrete features. One example of a set of features is the angle of the trajectory at any given point in time. This can be calculated using the inverse tangent of a change in pitch divided by a change in yaw. Another example of a set of features is the radial squared component, comprising X squared plus Y squared. Another example of a set of features is the pitch component, comprising only the pitch, or Y data points. Another example of a set of features is the yaw component, comprising only the yaw, or X data points. Another example of a set of features is the rate of change of the trajectory, useful for distinguishing, for example, the letter “U” from the letter “V.” Another example of a set of features is the location of a crossing point, useful for distinguishing, for example, the number “8” from the number “0.” Another example of a set of features is the number of times within a trajectory in which the trajectory changes direction, with the limitation that the angular change in direction is greater than a threshold value. One of ordinary skill in the art will appreciate that other sets of similar types of features can also be used within the premise and objectives of the system of the present invention.
At Step 118, after a set of values corresponding to a predetermined set of discrete features has been created, the set of values can be stored in a database along with a corresponding identifier, for example, an ID number, indicating the desired gesture. At Step 120, the database can be populated with numerous sets of values corresponding to the desired features and associated with various identifiers and desired gestures. The following is an exemplary database that can be created in Step 120. The table below includes a set of N features and M sets of values for the N features. A command or a character is associated with each set of values.
Feature
Command/
Feature 1
Feature 2
Feature 3
. . .
N
Character
Set 1
Set 2
Set 3
. . .
Set M
The database populated during the training mode 110 can then be used for gesture recognition mode during the recognition mode 130. In the recognition mode, at Step 132, the user makes a hand gesture either by moving the hand held device or just his/her hand in the air. At Step 134, the handheld device extracts data related to the trajectory of the gesture made in Step 132 by using the gyroscope, accelerometer and compass embedded in the handheld device.
At Step 136, the trajectory data extracted in Step 134 is converted into a set of values corresponding to some discrete features. Steps 134 and 136 can be implemented in the same or similar manner that Steps 114 and 116 in the training mode 110 are implemented respectively. At Step 138, the set of values that has been determined from the input trajectory in Step 136 can be compared to all sets of values stored in a gesture library or a subset of the sets of values stored in the gesture library. This library was generated by using training data in Step 120, or by using hard-coded data. At Step 140, upon identifying the set of values from the library that matches or most closely matches the set of values generated by the user's input trajectory, the character corresponding to that set of values is displayed or the command corresponding to that set of values is executed. The character can include a letter from an alphabet, which can be English or another language. One of ordinary skill in the art will appreciate that the term “character” as used can also include a word, a phrase or a signature. The character can also include a number, for example, a Roman numeral. The character can be displayed can be displayed in a word processing application document, for example, Microsoft Word.
At Step 140, to compare user input values set corresponding to a feature set with values sets corresponding to the feature set within the library, various techniques exist that can be used, including look-up tables, Hidden Markov Models (HMM), neural networks, and support vector machines. In the optimal embodiment, HMMs are used with some modification for optimization. An HMM includes a state transition matrix and an emission matrix. In the state transition matrix, a left-right model is used in which each state must be followed by the next state:
In the emission matrix, the features from the library can be used to generate a matrix in which the optimal point in the matrix is given by each library value for a feature, but with some allowed probability on either side of the library value for a feature. For example, if a given state has been recorded with feature #4 for a given library feature set, the corresponding row in the emission matrix might include: 0 A B C B A 0 0 etc
In which C corresponds to a high probability, and B and A correspond to respectively lower probabilities. This matrix may be generated using training methods such as the Baum-Welch method or may be entered directly from the feature library. After the state transition matrix and emission matrix have been generated, they may be used to evaluate the probability that input feature set values matches the library features set values using standard algorithms such as the forward algorithm or the Viterbi algorithm. The final probability may be generated as a log in order to prevent excessive scaling differences.
When several different feature sets are used to evaluate an input trajectory, a probability will be generated for each feature set. For example, probability A may reflect the probability for angular features, probability B may reflect the probability for radial features, and so on. A final probability can be given as a weighted linear combination of all the probabilities for all the types of features, in which the weights are determined experimentally. The highest probability determines best match for the trajectory; if the highest probability is below a threshold, then no match is returned.
In one embodiment, a set of short gestures may be pre-trained, such as a set of numbers, characters, or other trajectories of similar lengths. For each gesture, a set of different trajectories may be trained; for example, a 2 may be trained with or without a loop in the lower left corner. When a user inputs a trajectory that matches one of the predetermined feature sets, an event is triggered in the application or operating system of the device. In one embodiment, the gesture may trigger a mode change or event within an application or game. In another embodiment, the gesture may open or close an application, or otherwise control the set of applications running within an operating system. In another embodiment, a number or letter may indicate an element within a list within a program or operating system.
In one example, in a contact list within a phone, drawing a letter may indicate that the contact list should scroll to that letter within the alphabet. In another example, within a main menu, drawing a letter (such as ‘W’) may cause an application to start (such as a web browser). The list of predefined gestures may be preprogrammed by the vendor of the device, or trained by the user, or both.
In another embodiment, the trajectory to be matched may be an authentication signal used to unlock a device, unlock a program running on a device, or conclude a purchase or other financial transaction. Such an authentication signal is analogous to a signature, and may be longer than a simple character or number. Such an air signature may be an abstract set of shapes and curves, or may be a real signature drawn in the air. The trajectory drawn by the user may be stored in a database such that it can be viewed later if any conflict arises. It may also be matched to the user's predetermined air signature in real time, and the event intended to be triggered is successfully triggered only if the match probability is high enough.
To record an arbitrarily long trajectory as an air signature, it may not be sufficient to use a hard-coded number of features for all users' signatures, as some users may want to use a longer signature than others. In this case, the number of features to be used may be determined by the number of changes of direction within the signature.
In another embodiment, a hardcoded number of features can be used for all recognizable trajectories, with longer trajectories being made up of combinations of shorter trajectories. In this case, a long signature must be broken down into shorter units that are recorded and compared, with a long signature being recognized successfully only if it comprises a set of shorter trajectories that are successfully recognized in the correct order.
In one embodiment, the device moved by the user incorporates both the motion sensors and the display on which the feedback trajectory and result of the gesture recognition may be drawn. In this case, the device may be a handset, a portable gaming system, or other electronic system comprising a set of motion sensors and a display. In another embodiment, the device may contain motion sensors but not the display, and a display that is physically detached from the device may indicate the feedback and results. For example, the device may be similar to a remote control, air mouse, or game controller, and the display may be a computer, TV, or game console monitor.
In one embodiment, the trajectory drawn may be in the coordinate system of the handheld device. In this case, a vertically drawn 1 will be vertical relative to the earth if the user is standing up, but may be horizontal if the user is lying down. The trajectory will always be the same relative to the coordinate system of the handheld device.
In another embodiment, the trajectory drawn may be in the coordinate system of the earth or of a separate display not attached to the motion sensors. In this case, a vertically drawn 1 must always be vertical relative to the earth in order to be correctly recognized as a 1. In this case, because the gyroscope data is in the coordinate system of the device and not the earth, accelerometer data can be used to determine the direction of gravity and to process the gyroscope data. This can be done in real time using sensor fusion techniques or can be done in post-processing using look-up tables.
In cases in which the user cannot be expected to reliably draw the gesture in the correct coordinate system without some rotational error, the comparison algorithm may be run multiple times using slightly different angular offsets, with the best match chosen as the final probability. For example, a trajectory may be compared with a library features values sets with rotations of 0, 22.5 degrees, −22.5, 45, and −45.
The user or the device designer may also tune recognition thresholds in a variety of ways. Trajectories may only be valid if they are bigger in space than a certain threshold, or smaller than a certain threshold. They may only be valid if the execution time of the gesture is longer than a threshold or shorter than a threshold. They may only be valid if the speed of the gesture goes above a threshold or stays below a threshold. Each individual gesture may comprise independent thresholds, and may also comprise a final probabilistic scale factor that weights the gesture relative to other gestures, allowing an application designer to pick a gesture from two similar gestures that may be easier to trigger.
According to an aspect of the present invention, in order to recognize longer gestures, a technique can be used in which long trajectories are broken down into segments, and each segment is treated like an individual trajectory.
Determining the final probability threshold that a user must exceed in order for a gesture to be recognized is difficult because different trajectories may require different thresholds, and different users may have different degrees of precision in their movement. The probability threshold determination can be automated if a gesture is trained several times. For example, if the gesture ‘M’ is trained five times, the library contains in its memory five iterations of the gesture ‘M’, called M1, M2, M3, M4, and M5. Since the user considers all five of these iterations to be the same gesture, it should be possible for the trajectory M1 to be recognized as M2, M3, M3 and/or M5 within the library. By checking the match probability of M1 versus M2, M1 versus M3, M1 versus M4, and so on, a set of match probabilities can be determined. The recommended probability at which a new ‘M’ should be recognized can be determined by combining all the individual match probabilities in some way; for example, in an average, or by choosing the minimum probability.
According to an aspect of the present invention, a user may want to train a gesture that includes multiple strokes with spaces in between; for example, when training a Chinese, Korean, or Japanese character as a gesture. In this case, a mechanism must be in place for determining which movements correspond to “strokes.” For example, the handheld device can contain a button that, when held down, signifies that the user is “drawing” a stroke. When the button is not held down, this signifies that the user is traveling between strokes. A mechanism can also be in place that allows the user to see a cursor moving when the user's hand gesture is traveling between strokes, so that the required location of the start of the next stroke would be obvious. The user can therefore draw on a display a multi-stroke character using hand movement in the air.
During training, the each stroke can be stored as a gesture. The traveling movements can be stored as <x, y> vectors, signifying a straight line between the end of the previous gesture and the start of the new gesture. Each stroke can also have a vector signifying the straight line between the start of the stroke and the end of the stroke. During operation, all strokes and traveling vectors must match in order for the multi-stroke character to match. While the user is delivering strokes, an auto-complete feature can be active that attempts to match the first few strokes to a database of characters, and determines the most likely matches. When the number of auto-complete suggestions is sufficiently small, the user can simply select the correct character from the list. During operation, while a multi-stroke character can have a correct order and direction of strokes, the user may not necessarily draw the strokes in the right order or in the right direction relative to the manner in which the multi-stroke character was stored in the library during training. However, the gesture recognition engine of the present invention is able to determine that the resulting character still matches the desired character.
During operation, the same character including the strokes A, B and C can be drawn in a different, or wrong, order. If a character is drawn with the strokes in the wrong order 920, for example, B, A, C, this character can also be matched against a transformed version of the stored character in the library. By comparing the character with the strokes B, A, and C, and the vectors vB, vBA, vA, vAC, and vC, a match can be acquired. The new vectors can be calculated by using simple vector math: vAC=vAB+vB+vBC, and vBA=−vB−vAB−vA. In addition, if a character is drawn with one or more strokes drawn in the wrong direction, a match can be made by reversing the individual strokes and testing the result against the stored library. In this manner, a search may be done in which every combination of stroke order and direction can be tested until a match is found in the library or no match is found.
According to an aspect of the present invention; inertial sensors including gyroscopes are used to provide enhanced power management for a handheld device. Power management refers to turning off power or switching a system, a component, a function or an application to a low-power state when inactive. Power management for handheld devices is desired, to increase battery life, reduce cooling requirements, reduce noise, and reduce operating costs for energy and cooling. Lower power consumption also means lower heat dissipation, which increases system stability, decreases energy use, decreases costs and reduces the impact on the environment.
The main microprocessor 1008 is primarily responsible for managing the operations of the components of the handheld device 1000. The microprocessor 1008 is coupled to the applications (or components) including the network browser 1002 (e.g., an Internet browser), the display 1004, the camera 1006, the microphone 1010 and the keypad 1020. The main microprocessor 1008 is also coupled to the programmable module 1018. The programmable module 1008 is coupled to the keypad 1020 and the network 1022 by way of microprocessor 1008. The keypad 1020 can include the keypad for a smart phone from which the user can program the programming module 1018. The network 1022 can include a wired, wireless or optical network, the Internet, a local area network (LAN) or a computer from which the programming module 1018 can be programmed.
The display screen 1004 is an essential user interface component and is essential for operating smart phones. The display 1004 is also one of the components of the handheld device 1000 that consumes the most battery power. According to an aspect of the present invention, the motion processing unit 1012 is used to alleviate the handset's 1000 dependency on the display 1004. As illustrated in
The programmable module can include a look-up table including various hand motions and their corresponding commands. Examples of the motion commands can include a shake action or a special moving pattern (i.e. a signature) representing the command to answer the phone, a handwriting motion of the letter “C” representing the command to turn on the camera, a hand gesture to unlock the phone, a hand gesture to speed dial a phone number, and hand motions representing other user-specified shortcuts. For certain motion commands, for example, answering the phone and speed dialing a phone number, the display 1004 and the touch panel 1020 can remain turned off.
At Step 1104, the handheld device 1000 is in the stand-by (or sleep, low-power or turned-off mode). The device 1000 can enter into the sleep mode because, for example, the device 1000 has been idle for more than a pre-determined period of time. The sleep mode refers to a low power mode in which the handheld device 1000 significantly reduces its power consumption, but allows the device 1000 to immediately resume operation (i.e. switch back to active mode) without requiring the user to reset the programming codes or waiting for the handheld device 1000 to reboot. In the sleep mode, the network browser 1002, display 1004, the camera 1006 and the microphone 1010 are turned off and the main microprocessor 1008 is throttled down to its lowest-power state. However, according to an aspect of the present invention, the motion processing unit 1012 remains running (i.e. active) when the handheld device 1000 is in the sleep mode and continues to monitor for any motion commands.
At Step 1106, the user causes a movement of the handheld device 1000 representative of the user's desired command. The movement trajectory is detected by the gyro 1016. In one embodiment of the present invention, the gyro 1016 generates data representative of the motion trajectory and provides it to gyro processor 1014. The gyro processor 1014 communicates with the programmable module 1018 to identify the command or commands corresponding to the motion trajectory data. The gyro processor 1014 provides the main microprocessor 1008 with a wake up signal (Step 1108) and the identification of the user's motion command or commands. In response to the wake up signal, the main microprocessor 1008 switches from the sleep mode to the active (or high-power) mode of operation.
In another embodiment of the present invention, the gyro processor 1014 provides the main processor 1008 with the wake up signal and the data related to the user's motion's trajectory. The wake up signal causes the main microprocessor 1008 to switch from the sleep mode to the active mode (Step 1108). At Step 1110, the main microprocessor 1008 communicates with the programmable module 1018 to identify the command or commands corresponding to the gyro data. At Step 1112, the main microprocessor 1008 wakes up the application or applications (i.e. causes them to switch from the sleep mode to the active mode) that are required to execute the command or commands. At Step 1114, the main microprocessor 1008 and the now-active application or applications execute the command or commands. The present invention thus uses a motion trigger, instead of a push (or soft) button on the handheld device, to wake up the handheld device.
In one embodiment of the present invention, only the gyro 1016 is used to detect the user's motion. Gyros detect angular movements. Because human hand movement is mostly angular and because even linear hand movements are generally accompanied by angular movements, the gyro 1016 is well suited for detecting hand motions. As illustrated in
According to an aspect of the present invention, the motion processing unit 1012 is used as a user interface for detecting a user hand movement. In an exemplary embodiment of the present invention, the motion processing unit 1012 is a sub system of the main microprocessor 1008. In another embodiment of the present invention, the motion processing unit 1012 is directly controlled by the main microprocessor 1008. In both embodiments, the main microprocessor 1008 and the motion processing unit 1012 remain in the active mode even when the applications 1002, 1004, 1006, 1010, 1018 and 1020 enter into the sleep mode, for example, because the handheld device 1000 has been idle for longer than a predetermined amount of time.
Thus, unlike the embodiment disclosed in
In the conventional art, for a handheld device such as a mobile phone, to cause the handheld device to switch from sleep to active mode, a user must push a button on the keypad (or touch panel) of the handheld device. That causes the high power consuming display of handheld device to switch to active mode, even if the functionality the user desires to perform does not require the use of the display. For example, if the user is in a meeting and desires to audio tape a portion of the meeting using his/her smart mobile phone, in the conventional art, the user must first awaken the display and then select the audio taping application for example, by pressing soft or hard key(s) for selecting the audio taping application, even though the display is not needed for audio taping. Thus, conventional art causes wastage of power and time and requires multiple actions by the user.
According to the embodiments of the present invention, the user only needs to make a single predetermined gesture, for example, an air trajectory in the form of the letter “R” to convey his/her desire to make an audio recording of the meeting. In response to the “R” motion of the handheld device 1000, the main microprocessor 1008—MPU 1012 system would automatically communicate with the programmable module 1018 to determine that the user desires to activate the audio taping application, make a function call to the audio taping application to wake up the audio taping application components including, for example, the microphone, and begin the audio recording of the meeting. All of the above steps are performed automatically in response to the single “R” gesture by the user, and, are performed without awakening irrelevant applications such as the display 1004. The present invention provides advantages over conventional art in the form of reduced number of steps, less power consumption and reduced time to perform the desired function.
At Step 1306, the main microprocessor 1008 causes the camera application 1006 to switch from sleep to active mode. The main processor 1008 can also cause the display 1004 to switch from sleep to active mode, depending on the motion commands included in the programming module 1018. The network browser 1002 and the microphone 1010 remain in the sleep mode. If the display 1004 is not turned on, the user can view the object by using the view finder of the camera and use the click button to capture the photograph. If both the camera 1006 and the display 1004 are turned on, the user can then view the object on the display 1004 and take the photograph by using the click button. The present invention provides the capability to wake up devices and applications inside a handheld device without requiring push button(s), and specifically by using the movement of the handheld device as a trigger to wake up the devices and applications.
At Step 1410, the user causes a movement of the phone 1000, for example, by tapping anywhere on the phone twice to indicate that the user wants answer an incoming phone call. The small angular movement of the phone 1000 that would result from the tapping is detected by the gyro 1016. In response, at Step 1412, the gyro 1016, the gyro processor 1014, the main microprocessor 1008 and the programmable module 1018 cause the phone 1000 to return to the non-mute active mode and turn on the microphone 1010.
According to an aspect of the present invention, inertial sensors are used in combination with other sensors to perform user authentication.
In an embodiment of the present invention, inertial sensors including one or more gyroscopes, accelerometers and/or compasses, and memory and microprocessor for controlling the inertial sensors are located on a substrate. The substrate can also include an interrupt module to trigger the applications processor for the handheld device in response to motion detection by the inertial sensors.
According to the flow diagram 1620, the trajectory information can be obtained from the gyroscopes 1502 in the reference frame of the Earth (Step 1622). In this case, accelerometers 1504 can be used in addition to gyroscopes 1502 in order to determine the tilt of the handheld device 1500 relative to the Earth (Step 1624), and form a trajectory in which yaw is horizontal relative to the Earth and pitch is vertical relative to the Earth (Step 1626).
According to the flow diagram 1630, the trajectory information can be obtained from the gyroscopes 1502 in the reference frame of the handheld device 1500, without the use of accelerometers 1504 for tilt compensation (Step 1632). However, a third gyro axis can be used to detect rolling wrist motions (1634), and compensate the trajectory for any distortions due to this rolling motion during the trajectory (Step 1636). A magnetometer 1506 can also be used to measure the Earth's magnetic field, providing a fixed measurement of orientation (Step 1638) that can be used to compensate for any gyroscope 1502 drift (Step 1640).
At Step 1704, gyro(s) 1502 are used to obtain information related to the angular movement of the handheld device 1500. At Step 1706, accelerometer(s) 1504 are used to obtain information related to the linear movement of the handheld device 1500. After sensor fusion between accelerometers 1504 and gyroscopes 1502, linear acceleration can be extracted and double integrated to determine positional changes. However, due to inaccuracies in the sensors, the double integration can be unstable and may not lead to accurate information about linear movement. The angular movement, even if it is small, can be used to determine the movement direction and quality, due to the fact that angular movement does not require double integration. By correlating angular movement with linear movement, a final trajectory can be calculated that is usable even if the linear movement that occurs during the angular movement is much smaller (Step 1708).
Returning to
A sensor fusion algorithm can be used that uses accelerometer 1504 data over short linear distances and camera 1510 pixel tracking over long linear distances in order to provide a more accurate linear trajectory. The camera 1510 tracking can help stabilize the rotational movement by reducing drift. The gyroscopes 1502 and accelerometers 1504 provide more accurate movement information over short periods of time, and help reject disturbances from lighting changes or moving objects within the camera's 1510 field of view.
According to an aspect of the present invention, RF (radio frequency) sensors 1512 within the handheld device 1500 may also be used for motion tracking by tracking the magnitude of the RF signal and, in some cases, the direction of the RF signal, relative to some external reference 1516, such as a RF network, a stationary computer system, or another similar device. The RF signal can include a Bluetooth, Wi-Fi, GPS, infrared, or some other RF signal. The signal tracking can be used to compliment the other motion sensors by providing a fixed reference to some outside reference frame. The RF signal can be sent out by the handheld device 1500, or received by the handheld device 1500, or both.
In one embodiment, the same infrared RF signal can be used to compliment the motion sensors and also serve as a proximity sensor used to determine, for example, if a user's face is near the touch screen. In another embodiment, a separate infrared signal can be used for each purpose. The RF signal can also be used for other transmission purposes such as controlling a TV, computer, media center, or home automation system. The RF signal can be picked up by a dedicated antenna, or by a magnetometer that also serves to measure the Earth's magnetic field.
According to an aspect of the present invention, information from the motion tracking sensors is combined with information from other sensors that determine context. The context is used to determine if a command should be executed, the nature of the result of the command, or the set of commands that are available. Such context measuring sensors can include location sensors such as a global positioning system (GPS), RF sensors that determine the location of the device within an RF network, a touch screen, temperature sensors, a proximity sensor, or a microphone.
The sound can include a sound caused via contact with the device, for example, by either scratching or tapping the handheld device 1500. The scratching motion would be very difficult to see and imitate, making the authentication procedure more secure. The tapping or scratching can be used as a command or as a part of the authentication. The tapping or scratching can be detected by a combination of the information provided by the accelerometer(s) 1504, gyroscope(s) 1502, magnetometer(s) 1506 and the microphone (1514). A motion signal detected by a combination of accelerometers 1504, gyroscopes 1502, and magnetometers 1506, in response to the tapping or scratching, can be combined with an audio signal detected by the microphone 1514. This can help reject unconscious tapping, for example, unconscious tapping performed by switching hands. This can also make it possible to distinguish between tapping with the pad of the finger and tapping with the nail. At Step 1808, if the user's signature matches a signature in a library and the sound detected by the microphone matches a pre-determined or pre-programmed sound, the user is deemed to have been successfully authenticated. Thus, both motion sensors and the microphones are used for user authentication.
The motion trajectory that can be captured by the motion processing devices and sensors illustrated in
According to the flow diagram 1900, at Step 1902, the screen (e.g. 1004 in
Moreover, a smart phone is not the only platform that can realize motion-based identity authentication. The motion processing unit including inertial sensors and processor (e.g. 1012 in
According to an aspect of the present invention, a motion command does not always have to associate with a numerical or alphabetical symbol. The motion command can include any pre-defined motion pattern. For example, a video game console can define a special sword-waving sequence to activate a powerful attack, or determine if the conductor is waving the 3-beat or 4-beat pattern in an orchestra game. The motion command can be used for both entertainment and educational purposes. For example, A golf student can hold the motion processing device and practice swing to check if the hand grip is turned in the right way. Also, by using a television (TV) remote, a user can write a “C” in the air to change the channel to CNN, or an “E” to change it to ESPN.
Exemplary Networked and Distributed Environments
One of ordinary skill in the art can appreciate that the various embodiments of methods and devices for pointing based services and related embodiments described herein can be implemented in connection with any computer or other client or server device, which can be deployed as part of a computer network or in a distributed computing environment, and can be connected to any kind of data store. In this regard, the various embodiments described herein can be implemented in any computer system or environment having any number of memory or storage units, and any number of applications and processes occurring across any number of storage units. This includes, but is not limited to, an environment with server computers and client computers deployed in a network environment or a distributed computing environment, having remote or local storage.
Each object 210, 212, etc. and computing objects or devices 220, 222, 224, 226, 228, etc. can communicate with one or more other objects 210, 212, etc. and computing objects or devices 220, 222, 224, 226, 228, etc. by way of the communications network 240, either directly or indirectly. Even though illustrated as a single element in
There are a variety of systems, components, and network configurations that support distributed computing environments. For example, computing systems can be connected together by wired or wireless systems, by local networks or widely distributed networks. Currently, many networks are coupled to the Internet, which provides an infrastructure for widely distributed computing and encompasses many different networks, though any network infrastructure can be used for exemplary communications made incident to the techniques as described in various embodiments.
Thus, a host of network topologies and network infrastructures, such as client/server, peer-to-peer, or hybrid architectures, can be utilized. In a client/server architecture, particularly a networked system, a client is usually a computer that accesses shared network resources provided by another computer, e.g., a server. In the illustration of
A server is typically a remote computer system accessible over a remote or local network, such as the Internet or wireless network infrastructures. The client process may be active in a first computer system, and the server process may be active in a second computer system, communicating with one another over a communications medium, thus providing distributed functionality and allowing multiple clients to take advantage of the information-gathering capabilities of the server. Any software objects utilized pursuant to the direction based services can be provided standalone, or distributed across multiple computing devices or objects.
In a network environment in which the communications network/bus 240 is the Internet, for example, the servers 210, 212, etc. can be Web servers with which the clients 220, 222, 224, 226, 228, etc. communicate via any of a number of known protocols, such as the hypertext transfer protocol (HTTP). Servers 210, 212, etc. may also serve as clients 220, 222, 224, 226, 228, etc., as may be characteristic of a distributed computing environment.
Exemplary Computing Device
As mentioned, various embodiments described herein apply to any device wherein it may be desirable to perform pointing based services, and delay interactions with points of interest. It should be understood, therefore, that handheld, portable and other computing devices and computing objects of all kinds are contemplated for use in connection with the various embodiments described herein, i.e., anywhere that a device may request pointing based services. Accordingly, the general purpose remote computer described below in
Although not required, any of the embodiments can partly be implemented via an operating system, for use by a developer of services for a device or object, and/or included within application software that operates in connection with the operable component(s). Software may be described in the general context of computer executable instructions, such as program modules, being executed by one or more computers, such, as client workstations, servers or other devices. Those skilled in the art will appreciate that network interactions may be practiced with a variety of computer system configurations and protocols.
With reference to
Computer 310 typically includes a variety of computer readable media and can be any available media that can be accessed by computer 310. The system memory 330 may include computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) and/or random access memory (RAM). By way of example, and not limitation, memory 330 may also include an operating system, application programs, other program modules, and program data.
A user may enter commands and information into the computer 310 through input devices 340. A monitor or other type of display device is also connected to the system bus 321 via an interface, such as output interface 350. In addition to a monitor, computers may also include other peripheral output devices such as speakers and a printer, which may be connected through output interface 350.
The computer 310 may operate in a networked or distributed environment using logical connections to one or more other remote computers, such as remote computer 370. The remote computer 370 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, or any other remote media consumption or transmission device, and may include any or all of the elements described above relative to the computer 310. The logical connections depicted in
As mentioned above, while exemplary embodiments have been described in connection with various computing devices, networks and advertising architectures, the underlying concepts may be applied to any network system and any computing device or system in which it is desirable to derive information about surrounding points of interest.
There are multiple ways of implementing one or more of the embodiments described herein, e.g., an appropriate API, tool kit, driver code, operating system, control, standalone or downloadable software object, etc. which enables applications and services to use the pointing based services. Embodiments may be contemplated from the standpoint of an API (or other software object), as well as from a software or hardware object that provides pointing platform services in accordance with one or more of the described embodiments. Various implementations and embodiments described herein may have aspects that are wholly in hardware, partly in hardware and partly in software, as well as in software.
The word “exemplary” is used herein to mean serving as an example, instance, or illustration. For the avoidance of doubt, the subject matter disclosed herein is not limited by such examples. In addition, any aspect or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects or designs, nor is it meant to preclude equivalent exemplary structures and techniques known to those of ordinary skill in the art. Furthermore, to the extent that the terms “includes,” “has,” “contains,” and other similar words are used in either the detailed description or the claims, for the avoidance of doubt, such terms are intended to be inclusive in a manner similar to the term “comprising” as an open transition word without precluding any additional or other elements.
As mentioned, the various techniques described herein may be implemented in connection with hardware or software or, where appropriate, with a combination of both. As used herein, the terms “component,” “system” and the like are likewise intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on computer and the computer can be a component. One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers.
The aforementioned systems have been described with respect to interaction between several components. It can be appreciated that such systems and components can include those components or specified sub-components, some of the specified components or sub-components, and/or additional components, and according to various permutations and combinations of the foregoing. Sub-components can also be implemented as components communicatively coupled to other components rather than included within parent components (hierarchical). Additionally, it should be noted that one or more components may be combined into a single component providing aggregate functionality or divided into several separate sub-components, and any one or more middle layers, such as a management layer, may be provided to communicatively couple to such sub-components in order to provide integrated functionality. Any components described herein may also interact with one or more other components not specifically described herein but generally known by those of skill in the art.
In view of the exemplary systems described supra, methodologies that may be implemented in accordance with the disclosed subject matter will be better appreciated with reference to the flowcharts of the various figures. While for purposes of simplicity of explanation, the methodologies are shown and described as a series of blocks, it is to be understood and appreciated that the claimed subject matter is not limited by the order of the blocks, as some blocks may occur in different orders and/or concurrently with other blocks from what is depicted and described herein. Where non-sequential, or branched, flow is illustrated via flowchart, it can be appreciated that various other branches, flow paths, and orders of the blocks, may be implemented which achieve the same or a similar result. Moreover, not all illustrated blocks may be required to implement the methodologies described hereinafter.
While the various embodiments have been described in connection with the preferred embodiments of the various figures, it is to be understood that other similar embodiments may be used or modifications and additions may be made to the described embodiment for performing the same function without deviating therefrom. Still further, one or more aspects of the above described embodiments may be implemented in or across a plurality of processing chips or devices, and storage may similarly be effected across a plurality of devices. Therefore, the present invention should not be limited to any single embodiment, but rather should be construed in breadth and scope in accordance with the appended claims.
Li, Richard, Nakayama, Takashi, Lin, Shang-Hung, Sachs, David, Castro, Alex, Nasiri, Steve, Gu, Anjia
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
5252951, | Apr 28 1989 | INTERNATIONAL BUSINESS MACHINES CORPORATION A CORP OF NEW YORK | Graphical user interface with gesture recognition in a multiapplication environment |
6249792, | Dec 16 1998 | Microsoft Technology Licensing, LLC | On-line dynamic file shrink facility |
6842991, | Jul 31 2002 | Honeywell International Inc | Gyro aided magnetic compass |
7180500, | Mar 23 2004 | Fujitsu Limited | User definable gestures for motion controlled handheld devices |
7333087, | Jan 27 2004 | SAMSUNG ELECTRONICS CO , LTD | Method of adjusting pointing position during click operation and 3D input device using the same |
7358008, | Oct 12 2001 | Panasonic Corporation | Electrochemical device including electrolyte |
7496286, | Jun 05 2006 | MEMSIC SEMICONDUCTOR TIANJIN CO , LTD | Devices, systems, and methods for controlling a shutter |
7508384, | Jun 08 2005 | Daka Research Inc. | Writing system |
7548203, | Sep 15 2006 | Nokia Technologies Oy | Performance and power management in direction of arrival determination by utilizing sensor information |
7739061, | Feb 12 1999 | Method and system for controlling a user interface of a device using human breath | |
7777649, | Jan 20 2004 | Koninklijke Philips Electronics N V | Advanced control device for home entertainment utilizing three dimensional motion technology |
7940986, | Nov 20 2002 | KONINKLIJKE PHILIPS ELECTRONICS, N V | User interface system based on pointing device |
7961173, | Sep 05 2006 | NAVISENSE, LLC | Method and apparatus for touchless calibration |
8115731, | Jul 09 2001 | Malikie Innovations Limited | Method of operating a handheld device for directional input |
8250921, | Jul 06 2007 | Invensense, Inc.; InvenSense Inc | Integrated motion processing unit (MPU) with MEMS inertial sensing and embedded digital electronics |
8289162, | Dec 22 2008 | GOOGLE LLC | Gesture-based user interface for a wearable portable device |
20050110778, | |||
20050212911, | |||
20060033702, | |||
20060052109, | |||
20060061545, | |||
20060139327, | |||
20060164382, | |||
20070027367, | |||
20070032748, | |||
20070176898, | |||
20080134784, | |||
20080170776, | |||
20090088204, | |||
20090182955, | |||
20090195497, | |||
20090262074, | |||
20090265671, | |||
CN101365193, | |||
EP429391, | |||
WO2009026337, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jul 08 2010 | Invensense, Inc. | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Date | Maintenance Schedule |
Sep 29 2018 | 4 years fee payment window open |
Mar 29 2019 | 6 months grace period start (w surcharge) |
Sep 29 2019 | patent expiry (for year 4) |
Sep 29 2021 | 2 years to revive unintentionally abandoned end. (for year 4) |
Sep 29 2022 | 8 years fee payment window open |
Mar 29 2023 | 6 months grace period start (w surcharge) |
Sep 29 2023 | patent expiry (for year 8) |
Sep 29 2025 | 2 years to revive unintentionally abandoned end. (for year 8) |
Sep 29 2026 | 12 years fee payment window open |
Mar 29 2027 | 6 months grace period start (w surcharge) |
Sep 29 2027 | patent expiry (for year 12) |
Sep 29 2029 | 2 years to revive unintentionally abandoned end. (for year 12) |