This disclosure relates, generally, to a device that can count a number of hand to mouth (HTM) movements.
Personal electronic devices may be used for scientific as well as non-scientific applications. For example, individuals seeking to monitor physical activity may use a personal electronic device to monitor physical activity, to track/document progress, and to provide motivation for increased physical activity. The capability to monitor and track food and beverage intake using a personal electronic device, in an effective and affordable manner, may be advantageous in achieving weight control goals.
In one aspect, a hand to mouth bite counting device, in accordance with embodiments broadly described herein, may include a sensing device included in a housing, the sensing device continuously collecting data corresponding to sensed movements of at least some portion of an arm of a user, a processor operably coupled to the sensing device to determine whether data collected by the sensing device throughout the sensed movement corresponds to a bite of food taken by the user, and an interface device operably coupled to the processor, the interface device providing for communication between the user and the processor. A set of attributes may be derived from the data collected within the predetermined interval of time, the set of attributes defining the sensed movement from an initial point at which the movement is initially sensed to a terminal point at which the movement has terminated.
In another aspect, an operation method for a hand to mouth bite counting device, the hand to mouth bite counting device including a sensing device in communication with a processor, may include activating the sensing device and continuously collecting data in response to sensed movement of at least a portion of an arm of a user, from an initial point at which the movement is sensed to a terminal point at which the movement is terminated, and transmitting the collected data to the processor, and implementing an algorithm on the collected data. The algorithm may include processing the data collected during a plurality of intervals of time, deriving a set of attributes for a first interval of time, of the plurality of intervals of time, from the data collected during the first interval of time, the set of attributes defining the movement sensed during the first interval of time from the initial point to the terminal point of the sensed movement, and processing the set of attributes and determining whether the movement sensed during the first interval of time is a bite of food taken by the user.
The details of one or more implementations are set forth in the accompanying drawings and the description below. Other features will be apparent from the description and drawings, and from the claims.
A personal electronic device may be used by individuals to collect data related to, for example, diet/weight control, such as losing weight, gaining weight, or maintaining a desired weight or a desired intake level of nutrients. Data collected in this manner may be used to track progress, establish/revise goals, facilitate competitive challenges among peers, and the like to provide motivation in achieving weight management goals. A hand to mouth (HTM) counter, in accordance with embodiments as broadly described herein, may provide an affordable, effective tool to collect objective measures of diet through automatic, individualized monitoring of intake based on monitoring of hand to mouth movements of the individual.
An algorithm and methodology of the HTM counter could run on any device capable of incorporating the appropriate hardware and software elements. In one example implementation, the HTM counter may be incorporated into a device worn on a wrist of a user, in the form of, for example, a wrist watch or a bracelet. In this arrangement, such a watch or bracelet could be worn on the same wrist of the user, day and night, e.g., continuously, to provide for consistent data collection by silently and constantly counting a number of hand to mouth movements made by the user that correspond to actual bites taken by the user, without specialized user interaction and/or manipulation. Application of the HTM counter is not limited to such a wrist watch or bracelet, and other types of hardware implementations may also be appropriate.
As shown in
Regardless of the particular hardware implementation of the HTM counter, hereinafter the combination of the algorithm, bite detection software and appropriate hardware implementation will be collectively referred to as the “device,” or “HTM device,” simply for ease of discussion.
In some embodiments, the HTM device may be a stand alone device worn on some portion of the arm, wrist or hand of the user, such as, for example, the HTM device 200 including the HTM counter 100 shown in
Regardless of the specific implementation of the HTM device 200, the HTM device 200 may be capable of operation in multiple different modes. For example, the HTM device 200 may be pre-programmed with a recognition model that is operational out of the box. In this initial operation mode, the HTM device 200 may begin collecting bite data as soon as it is worn by the user and turned on. In some embodiments, the HTM device 200 may also operate in a learning mode, in which the HTM device 200 learns from the individual user's own bite motions and patterns to tailor the pre-programmed recognition model to each individual user. In the learning mode, the HTM device 200 may request confirmation from the user whether a detected movement/series of movements constitute an actual bite/series of bites, and continually update the recognition model accordingly. A period of operation in the learning mode can be sustained as long as necessary to achieve a desired level of accuracy when comparing bites detected by the HTM device 200 to actual bites confirmed by the user. This allows the HTM device 200 and recognition model to be completely personalized to individual users, and could allow for periodic updates as a user's bite motions may change in different circumstances or over time, as intermediate weight management goals are achieved and re-set. The HTM counter 100/HTM device 200 may also detect when its accuracy is falling below acceptable levels that may be, for example, preset during fabrication or set and changed by the user as appropriate, and may determine which motions to request the user to perform to update and improve the model, using active learning techniques.
This real time feedback allows accuracy of the recognition model to be continuously improved, taking into account the full bite motion of the hand and arm toward the mouth, including the roll, pitch and yaw of the full movement to classify a detected movement in one or more of the X, Y and/or Z directions as an actual bite, and to update the model to reflect numerous different combinations of roll, pitch and yaw through the entirety of the movement, when confirmed by the user, to reflect actual bites. This level of granularity, coupled with the operation period in the learning mode, allows the HTM device 200 to more clearly distinguish between a hand/arm motion that is an actual bite taken by the user, and a hand/arm motion that may be similar in duration and/or direction, but is not an actual bite. This, in turn, allows the HTM device 200 to be worn by the user throughout the day, e.g., even between meals, spanning several meals, throughout a full day or series of days, with components of the sensing device 120 (for example, an accelerometer 125 and a gyro 128) remaining operational and collecting data in response to sensed movement whenever the device is on, and the processor 130 running and processing data collected by the sensing device 120 whenever the device is on, with essentially no user interaction required (outside of operation of the HTM device in the learning mode).
For example, because of this level of accuracy, there is no need to turn the device on at the start of the meal, and off at the end of the meal, as the HTM device 200 can effectively discriminate between bites and non-bites. This also allows the HTM device 200 to track not just planned bites/eating, during a meal, but also to track opportunistic bites/eating, such as snacking throughout the day, without excessive events of mis-identification/false classification of bites versus non-bites.
The recognition model used by the HTM device 200 may also be tailored for a particular user, for example, during operation in a personalization mode that may be either separate from or a part of the learning mode, to reflect age, gender, nationality, right or left handedness, preferred meal times, preferred cuisine/meals, preferred eating utensils including for example chopsticks, and other such personalized features.
In some embodiments, the HTM device 200 may also request that the user perform a set of basic learning motions when initializing the device, either before or after the device has collected information regarding these types of personalized features, again, in operation in the personalization mode, to allow the device to positively capture, for example, frequently used, known motions. Inclusion of these types of personalized features may render the time spent in the learning mode more efficient or shorter, and may render an even more accurate result.
To accurately capture the entire bite motion as described above, and collect data associated with the user's hand/arm movement to be matched with the recognition model, in one embodiment, the sensing device 120 of the HTM counter 100 may include, for example, one or more accelerometers 125 to detect/measure to measure movement and velocity/acceleration through the detected movement, and one or more gyroscopes 128 to detect orientation/direction of the detected movement. As noted above, the components of the sensing device 120 may remain operational whenever the device is on, always ready to collect data in response to sensed motion whenever the device is on, which may then be processed by the processor 130 to determine whether the sensed motion constitutes an actual bite. As shown in
In
The data collected by the sensing device 120, including the accelerometer(s) 125 and gyroscopes(s) 128, during the movements shown in
In refining the initial base algorithm to recognize bites, discriminate between bites and non-bites, and monitor and count bites with little to no user intervention, the initial base algorithm, or base recognition model, was subjected to a series of sample training sessions. During these training sessions, greater than 20 subjects wore the device loaded with the initial base algorithm, with the device collecting data through greater than 40 trial meals including greater than 3700 bite instances. During each sample training session, each subject wore a wrist mounted device equipped with a triaxial accelerometer and gyroscope motion sensing device to capture and record eating motions. In the initial training sessions, including greater than 5 meals, subjects pushed a button on the wrist mounted device before a bite was taken to positively mark and record each bite taken. In subsequent training sessions, including greater than 40 meals, video was used to mark bites taken by these subjects, to capture a more natural hand/arm movement during bites. These series of sample training sessions constituted greater than 3700 individual bite instances for which accelerometer X-, Y- and Z-axis data and gyroscope roll-pitch-yaw data was collected at between 1 Hz and 60 Hz. For initialization purposes, data may be collected at, for example, 10 Hz, or other frequency that may be appropriate for a particular implementation/particular user. Under circumstances in which data recording is broken into ten second segments for bite recognition, the example bite motion shown in
In the example shown in
Based on these sample training sessions, the processor may process each hand to mouth motion detected by the device and characterize these detected motions by a relatively large number of statistical features. For example, when the sensing device 120 detects that a motion has been initiated, for example, in a direction consistent with movement of the hand toward the mouth of the user, the sensing device 120 collects data that characterizes the sensed movement based on these features. In some embodiments, the sensing device 120 continuously collects this data, which may be segmented into given intervals of time, such as for example, approximately 10 seconds, which may correspond to an approximate duration of a hand to mouth movement constituting a bite of food taken by a user. A sample of the features which may be used to characterize this movement are shown in Table 1 below.
The sample features shown in Table 1 describe the X, Y, Z, pitch, yaw and roll motions that may occur within each bite window, for example, a 10 second bite window, or other interval as appropriate, continuously collected from initiation of the movement to the end of the movement, or for the given window of time. These features may include, for example, mean, standard deviation, pairwise covariance, number of 0 crossings, number of peaks, signal energy and spectral entropy. These features may also include, for example, a manipulation ratio that describes the ratio of angular motion to linear motion, a measure of linear acceleration that characterizes the strength of acceleration in a given direction, a wrist roll motion that characterizes how much a rolling motion varies from its average, and kurtosis that describes the shape of the graph. The features may be calculated across the entire window, as well as for the middle 50%, or other relevant segment as appropriate, of the bite window. In Table 1, a “50” at the end of any of the feature names indicates that particular feature is calculated on the middle 50%. However, features may be calculated based on another relevant segment of the bite window if appropriate, based on a particular user's bite motions and patterns.
The sample features shown in Table 1 may be processed by a machine learning type module of the algorithm, and in particular, a machine learning model developed for the processing of this type of data, such as a model employing the principles of, for example, a Naive Bayes Machine Learning type model, or other type of model capable of predicting whether, in a given ten second window of data, an actual bite action has occurred. This type of modeling may form the basis for the recognition model and algorithm used by the HTM counter 100/HTM device 200. This individualized machine learning model allows for the recognition model to continue to be updated and refined, in essentially real time, based on the user's specific movements and habits, repetition of specific movement and habits, and the like, without disruption in the use of the device. In this context, this continuous updating and refinement of the model may be done automatically by the model itself at a set interval, or each time a set amount of updated data/information has been collected, or each time a single item of updated data/information is collected, or other arrangement as appropriate. Regardless of the arrangement for this continuous updating and refinement, this process is carried out on board, by the processor 130 itself. That is, operation of the HTM counter 100/HTM device 200 does not need to be disrupted and hooked up or otherwise connected to any type of external device for periodic recalibration to achieve this level of well refined, personalized recognition of bites and discrimination between bites and non-bites.
Without the need for constant, scheduled recalibration and updating through separate, deliberate user intervention which disrupts regular operation of the device, user convenience, utility, and functionality of the model, and the HTM counter 100/HTM device 200 may be enhanced, with the model able to update itself and refine its own processes as it continues to gather more and more information through continued use, thus “learning” from its own experience. This allows the model to continuously improve accuracy and also adapt as the user's motions change. This does not simply amount to an adjustment of threshold values, as would a regular re-calibration of this type of device. Rather, this approach automatically captures the many subtleties of the motions of an individual user, yielding a much more personalized and intuitive device, which is not calibrated, but instead learns from the individual's particular motions and improves itself.
In some embodiments, the model implemented by the HTM counter 100 may employ a smaller number of features, for example, a subset of the sample features shown in Table 1, in the interest of computational efficiency. For example, in one embodiment, the model may select five features, as shown in Table 2, which the model may determine to be most critical in characterizing arm/hand movement defining an actual, confirmed bite action. Again, data associated with the subset of features may be captured by the sensing device 120 and processed by the processor 130, which are continuously in operation, beginning at a point in time at which the sensing device 120 senses a motion, particularly, a motion in a direction corresponding in a hand to mouth movement, has been initiated, and continue capturing this data until the sensing device 120 senses that the motion has been completed. In some embodiments, the data collection period corresponding to a bite window may be characterized by a given interval of time representing the bite motion, from initiation to completion. In some embodiments, this interval may be, for example, 10 seconds. Other intervals may also be appropriate, depending on a particular user's habits and patterns, and other such factors.
A number of different mechanisms may be applied in selecting this subset of features from the large group of sample features, which may be collected by the sensing device 120 and processed by the processor 130 as described above. For example, in one embodiment, the worth of a particular attribute may be evaluated by applying a support vector machine (SVM) classifier, which may rank all of the attributes by the square of the weight assigned by the SVM. By carefully selecting an appropriate subset of features from the large group of sample features shown in Table 1, so that the resulting data is most representative of an actual bite action, computational efficiency may be greatly improved, while sacrificing relatively little to nothing in accuracy. Table 2 provides one example in which 5 features have been selected from the large group of sample features in this manner. Although Table 1 lists 207 sample features and Table 2 lists 5 features selected from Table 1, either by an SVM classifier as described above or other mechanism as appropriate, Table 1 may include more, or fewer, features, and Table 2 may include more, or fewer, features, depending on an implementation of the device, the mechanism employed for selection of the subset of features, computational requirements, and other such factors as appropriate.
The minimum value of the Z accelerometer, as well as the number of peaks for the Z accelerometer, may be taken in the middle 50% of the measurement window. Although the hand is almost constantly rotating during a bite motion, the majority of the Z accelerometer's data characterizes acceleration on the vertical axis (see
In deriving spectral entropy, first each series of data points, x[n], is converted from their domain to the frequency domain with a one dimensional Discrete Fourier Transform (Equation 1). The squared absolute value of the result gives the power spectrum (Equation 2), which is then normalized to become a probability density function (Equation 3). Finally, the entropy of this value is then calculated to produce the spectral entropy (Equation 4).
Spectral entropy may provide a measure of the disorder or unpredictability of the past data set. The roll (in the middle 50% section) and yaw angular accelerations were selected, as these features provided a revealing measure of the relative disorder of their measurements within the 10-second window.
The signal energy mean was also measured for the yaw angular velocity across the 10-second window. The signal energy mean may be calculated by taking the absolute value of the first value of the fast Fourier transform on the given data set (Equation 5).
SignalEnergyMean=|X(f)|[1] (5)
The Signal Energy Mean may measure the average energy in the given data set. Movement energy along the yaw axis was among the most revealing, or most predictive, calculated features.
The HTM counter 100, in accordance with embodiments as broadly described herein, may employ this carefully selected subset of features to detect hand to mouth bite motions and carefully discriminate between bite and non-bite motions, with great accuracy when the subset of features are properly selected through, for example, 10-fold cross validation of data collected by the HTM counter 100, using the base recognition model. This type of recognition may be performed on, for example, a new/not previously tested subject pool, including, for example, a mix of males and females of different ethnicities, for greater than 10 subjects over greater than 15 of meals including greater than 1400 bite instances. Results of the cross validation are shown in Table 3.
As shown in Table 3, the HTM counter 100 may implement this type of model, monitoring hand to mouth movement continuously throughout the day, regardless of activity, and collecting data accordingly, so that both bite and non-bite motions may be accurately recognized and counted throughout the day with relatively high accuracy, while relying on only a subset of features. Bite recognition provided by the HTM counter 100 when relying on only a subset of features is high relative to the results achieved when relying on the full complement of features, especially when balanced against the significant increase in computational efficiency due to the reduced number of features. When taking into consideration the substantial additional increase in efficiency due to the user's personalization of the HTM counter 100 when initially operating in the learning mode to train the device to the user's specific characteristics and style, accuracy may be enhanced even further.
The recognition model may thus recognize and classify bites in real time, with accuracy improved by personalization and training of the HTM device in the learning mode. The algorithm may, over time, learn to recognize periods of eating throughout the user's day, and constantly update the model to reflect these patterns. The algorithm may constantly window the data and calculate statistics to continuously refine its ability to positively and accurately detect bites. In some embodiments, the algorithm may make use of a subsets of the various sensors included in the sensing device, to save power in periods of time when it is not needed. For example, power consumption of the gyroscope may, in certain implementations, be significantly higher than that of the accelerometer, so the gyroscope could be turned off for known non-meal periods, based on the learned and/or entered user patterns of behavior. For example, in some embodiments, these algorithms may intelligently wait for several bites to be taken in relatively quick succession before allowing bites to be freely recognized by the machine learning model, to help prevent the device from counting false outlier bite motions and further improve overall device accuracy.
As noted above, in order to personalize the HTM device for a particular user and improve bite motion detection accuracy, the device may include a personalization mode, in which a set of personalized data may be collected from the user to develop a personal profile. The personalization mode may be enabled at various different times, including, for example, prior to initiating use of the device, before or during operation in the learning mode, and any time the user wishes to update the personal profile to reflect changes in lifestyle, eating habits and the like which may affect how bites are discriminated from non-bites, and how and when bites are counted. Data collected during the personalization mode in developing the personal profile may include, for example, age, sex, left/right handedness, nationality, preferred meal times, preferred dishes, preferred eating utensils, and other such questions which may have an effect on arm/hand motion while eating. Based on the user's personal profile, the model may, for example, reverse the axis, about which the accelerometer measures movement/velocity and the gyroscope measures direction, in the case of left-handedness, and may cause the model to be more likely to accept bite motions closer to the times specified as normal meal times, in particular in cases where parameters of a detected movement border the characteristics of a bite action and a non-bite action. During operation in the learning mode, the user may perform several examples of bite motions and similar non-bite motions for storage in the model, and some confirmation of bites/non-bites in areas that require additional data and/or are outside of established or already collected data. This initialization data may be used to adjust the model, in conjunction with training data while operating in the learning mode, to further personalize the HTM device for the user and improve overall accuracy of the device. These refinements may make the device more effective in accurately distinguishing between a bite and non-bite action, allowing the HTM device to be worn all day and detect both planned and opportunistic eating without user interaction, and without the user activating the device at the beginning of an eating period and deactivating the device at the end of the eating period. Data collected in the learning/personalization mode may also be taken into consideration when further refining which of the sample features shown in Table 1 may be included in the subset of features to best characterize a particular user's bite motion.
As noted above, the HTM device may communicate with an external computing device, such as, for example, a smart phone, a tablet device, a laptop computer, a desktop computer and the like. In some embodiments, the algorithms and models described above may be embedded in an application on the paired computing device, and data may be presented to/viewed by/manipulated by the user through a GUI rendered by the computing device to facilitate use, learning, and feedback. The computing device may log and process data over long periods of time to develop historical trends, generate predictive trends, set and alter goals, and save the data in a quickly accessible form. Use of a machine learning model, such as the Naive Bayes model, which is not processing intensive, and reliance on a reduced number (five) of calculated features of the detected movement, battery power, processing capability and speed, and memory management may present little to no issue in the implementation of the HTM device.
An example operation method 600 for operation of a hand to mouth bite counting device, in accordance with embodiments as broadly described herein, is shown in
During the analysis of the collected data conducted by the processor at block 650, the processor 130 may also analyze the data to determine if the data collected during a particular time interval t reflects a new pattern or motion, and if the possible new pattern or motion may correspond to an actual bite taken by the user, so that the algorithm, and the HTM counter 100/HTM device 200 may be updated as appropriate. For example, as shown in
An example operation method 700 for operation of a hand to mouth bite counting device in a learning mode, in accordance with embodiments as broadly described herein, is shown in
As noted above, this initial user baseline may be used to improve the base recognition model, which is operational out of the box, by positively capturing, for example, frequently used, known motions, together with personalized features. The recognition model is further, and continuously improved, and made more accurate, as the device continues to be used in the operational mode, additional data is collected, and the algorithm is automatically updated. This process is very organic, and can naturally capture the wide variety of human movement. It does not rely on threshold values but captures entire motions for learning and recognition purposes.
During operation in both the learning and/or personalization mode, and during regular operation, movements captured by the HTM counter 110/HTM device 200, both for training and classification, are continuous and natural, with no pre-established thresholds that need to be maintained for continued proper operation of the device. For example, if the user notices that the HTM counter 100/HTM device 200 has mis-detected a particular movement as a bite or a non-bite, the user may simply repeat the mis-detected motion in learning mode and the model will intelligently update itself so that that particular motion and all motions closely related to that particular motion will be more often grouped to whichever category (bite or non-bite) the user positively assigned. This process may be extremely intuitive for the user, as the user moves naturally to capture and train the model, a mis-detection or mis-labeling being easily recognizable and correctable. The model may recognize a full range of motion of a user's arm and employs its current understanding of the arm's motion to classify movements. The organic nature of the machine learning model may allow the model to drastically improve accuracy and personalize itself to each individual user.
As noted above, the user may use the HTM counter 100/HTM device 200 to set, monitor and change specific goals, on, for example, a daily, weekly, monthly and/or yearly basis, or other interval as appropriate for a particular user's circumstances. In some situations, these goals may be relative type goals, such as, for example, increasing or decreasing a number of bites taken during a particular interval, or maintaining a particular number of bites within a given interval. These goals may be set so as to represent hard daily calorie count goals. After settings goals appropriate to the particular user's situation in the initial learning mode and/or personalization mode, the device may generate various different types of alerts as the user approaches one of these goals. These types of alerts may include, for example, an audio type alert, a visual type alert displayed on the display of the device, a movement type alert such as a vibration of the device, and other such alerts. Regardless of the type of alert, in setting and updating goals, the user may also select intervals related to these alerts. For example, the user may set the device so that an alert is generated as the user approaches 75% of the allotted bites for a given day, with additional reminders at intermediate intervals prior to reaching 100% of the allotted bites for the day. Although the device may remain relatively silent and unobtrusive throughout the day. these types of alerts may be selected to improve the user's consciousness of bites, and corresponding eating habits throughout the day, further facilitating the user's achievement of short and long term weight management goals. In some embodiments, the device may be initialized by the manufacturer in a relative counting and decreasing mode, so that the device is operable out of the box. However, specific user input and customization of goals and the like may provide significantly more flexibility and effectiveness.
Implementations of the various techniques described herein may be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations thereof. Implementations may implemented as a computer program product, i.e., a computer program tangibly embodied in an information carrier, e.g., in a machine-readable storage device (computer-readable medium), for processing by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computing device, or multiple computing devices. Thus, a computer-readable storage medium may be configured to store instructions that when executed cause a processor (e.g., a processor at a host device, a processor at a client device) to perform a process. A computer program, or algorithm, as described above, may be written in any form of programming language, including compiled or interpreted languages, and may be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program may be deployed to be processed on one computing device or on multiple computing devices at one site or distributed across multiple sites and interconnected by a communication network.
Method steps may be performed by one or more programmable processors executing a computer program to perform functions by operating on input data and generating output. Method steps also may be performed by, and an apparatus may be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application-specific integrated circuit).
Processors suitable for the processing of a computer program or algorithm may include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computing device. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. Elements of a computing device may include at least one processor for executing instructions and one or more memory devices for storing instructions and data. Generally, a computing device also may include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks. Data also could be transmitted to a companion device for processing/computation. The computation could happen on the device itself, on the companion device, on using a combination of the two. Information carriers suitable for embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory may be supplemented by, or incorporated in special purpose logic circuitry.
To provide for interaction with a user, implementations may be implemented on a computing device having a display device, e.g., a cathode ray tube (CRT), a light emitting diode (LED), or liquid crystal display (LCD) monitor, for displaying information to the user and an interface and/or input device by which the user can provide input to the computing device. Other kinds of devices can be used to provide for interaction with a user as well; for example, feedback provided to the user can be any form of sensory feedback, e.g., visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including acoustic, speech, or tactile input.
Reference throughout this 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. Thus, the appearances of the phrase “in one embodiment” or “in an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. In addition, the term “or” is intended to mean an inclusive “or” rather than an exclusive “or.”
While certain features of the described implementations have been illustrated as described herein, many modifications, substitutions, changes and equivalents will now occur to those skilled in the art. It is, therefore, to be understood that the appended claims are intended to cover all such modifications and changes as fall within the scope of the implementations. It should be understood that they have been presented by way of example only, not limitation, and various changes in form and details may be made. Any portion of the apparatus and/or methods described herein may be combined in any combination, except mutually exclusive combinations. The implementations described herein can include various combinations and/or sub-combinations of the functions, components and/or features of the different implementations described.
This application claims priority to Provisional Application Ser. No. 61/962,946 filed on Nov. 19, 2013, the entirety of which is incorporated by reference as if fully set forth herein.
Number | Date | Country | |
---|---|---|---|
61962946 | Nov 2013 | US |