HEART RATE DETECTION USING AMBIENT LIGHT

Abstract
While experimenting with photoplethysmography, the applicant has observed that cardiac activity can be measured through human skin using ambient light in place of active lighting systems. Disclosed herein are techniques for exploiting this phenomenon to provide improved, low power physiological monitoring systems. In order to facilitate more continuous physiological monitoring over a range of lighting conditions, the intensity of ambient light can be monitored, and active lighting can be selectively deployed under conditions where ambient light does not provide sufficient optical energy for cardiac measurements.
Description
BACKGROUND

Reflectance photoplethysmography (RPPG) has emerged as a useful technique for monitoring cardiac activity. In general, RPPG entails illuminating skin with an LED or other light source, and then measuring changes in light absorption to draw inferences about cardiac activity. While these techniques are accurate, they require a variety of active components including light sources that pose challenges to deployment in wearable or portable devices for continuous physiological monitoring. There remains a need for heart rate detection techniques with decreased power requirements.


SUMMARY

While experimenting with photoplethysmography, the applicant has observed that cardiac activity can be measured through human skin using ambient light in place of active lighting systems. Disclosed herein are techniques for exploiting this phenomenon to provide improved, low power physiological monitoring systems. In order to facilitate more continuous physiological monitoring over a range of lighting conditions, the intensity of ambient light can be monitored, and active lighting can be selectively deployed under conditions where ambient light does not provide sufficient optical energy for cardiac measurements.


In one aspect, there is disclosed herein a wearable system for physiological measurement comprising: a wearable strap configured to be coupled to an appendage of a user, the wearable strap comprising: one or more light detectors positioned to receive ambient light from an ambient light source reflected from a skin of a user; and an electronic circuit board comprising a processing module configured to determine a heart rate of the user by: executing one or more computer-executable instructions associated with a peak detection algorithm to process the data corresponding to the ambient light reflected from the skin to detect a plurality of peaks associated with a plurality of beats of the user's heart, calculating a sequence of instantaneous heart rates of the user based on the plurality of peaks, and calculating a heart rate variability of the user based on the sequence of instantaneous heart rates.


The processing module may be further configured to select an algorithm for calculating the instantaneous heart rates by: determining an R-wave-to-R-wave interval (RR interval) based on the plurality of peaks detected by the peak detection algorithm; determining a confidence level associated with the RR interval; and based on the confidence level associated with the RR interval, selecting either the peak detection algorithm or a frequency analysis algorithm to process data corresponding to the reflected light to determine the sequence of instantaneous heart rates of the user.


The processing module may be further configured to perform the steps of determining whether the confidence level associated with the RR interval is above a predetermined threshold or is equal to or below the predetermined threshold, and determining an instantaneous heart rate of the user using the plurality of peaks when the confidence level is above the predetermined threshold, and determining an instantaneous heart rate of the user using the frequency analysis algorithm when the confidence level is equal to or below the predetermined threshold.


The wearable system may include a motion sensor, wherein the frequency analysis algorithm processes the data corresponding to the reflected light based on the motion of the user. The motion sensor may be an accelerometer. The wearable system may include a sensor for detecting a magnitude of ambient light incident on the skin. The wearable system may include one or more light sources positioned to illuminate the skin, wherein the processing module is configured to activate the one or more light sources when the magnitude of ambient light falls below a predetermined threshold. The wearable system may include a visual display device, wherein the processing module is further configured to display the heart rate variability of the user on the visual display device. The processing module may also or instead be configured to display the sequence of instantaneous heart rates of the user on the visual display device. The wearable system may include a storage device configured to store the sequence of instantaneous heart rates.


In another aspect a computer program product for operating a wearable system for physiological measurement, the computer program product comprising computer executable code embodied in a non-transitory computer readable medium that, when executing on one or more computing devices, performs the steps of: detecting ambient light from an ambient light source reflected from a skin of a user wearing the wearable system without active illumination of the skin by the wearable system; executing a peak detection algorithm to process the data corresponding to the ambient light reflected from the skin to detect a plurality of peaks associated with a plurality of beats of the user's heart; calculating a sequence of instantaneous heart rates of the user based on the plurality of peaks; and calculating a heart rate variability of the user based on the sequence of instantaneous heart rates. A method is also disclosed herein for performing these steps.


The computer program product may further include code that performs the steps of: determining an R-wave-to-R-wave interval (RR interval) based on the plurality of peaks detected by the peak detection algorithm; determining a confidence level associated with the RR interval; and based on the confidence level associated with the RR interval, selecting either the peak detection algorithm or a frequency analysis algorithm to process data corresponding to the reflected light to determine the sequence of instantaneous heart rates of the user.


The computer program product may include code that performs the step of determining a motion of the user based on data from a motion sensor in the wearable system, wherein the frequency analysis algorithm processes the data corresponding to the reflected light based on the motion of the user. The motion sensor may be an accelerometer. The computer program product may include code that performs the steps of determining whether the confidence level associated with the RR interval is above a predetermined threshold or is equal to or below the predetermined threshold, and determining an instantaneous heart rate of the user using the plurality of peaks when the confidence level is above the predetermined threshold, and determining an instantaneous heart rate of the user using the frequency analysis algorithm when the confidence level is equal to or below the predetermined threshold. The computer program product may include code that performs a step of receiving data from a sensor and determining a magnitude of ambient light incident on the skin. The computer program product may include code that performs the step of driving one or more light sources in the wearable system positioned to illuminate the skin when the magnitude of ambient light falls below a predetermined threshold. The computer program product may include code that performs the step of presenting a visual display of the heart rate variability in a user interface of the wearable system. The computer program product may include code that performs the step of presenting a visual display of the sequence of instantaneous heart rates in a user interface of the wearable system. The computer program product may include code that performs the step of storing the sequence of instantaneous heart rates in a storage device.





BRIEF DESCRIPTION OF THE DRAWINGS

The foregoing and other objects, features, and advantages of the devices, systems, and methods described herein will be apparent from the following description of particular embodiments thereof, as illustrated in the accompanying figures. The figures are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the devices, systems, and methods described herein.



FIG. 1 illustrates front and back perspective views of a wearable system configured as a bracelet including one or more straps.



FIGS. 2-4 illustrate various embodiments of a bracelet.



FIG. 5 illustrates placement of a wearable physiological measurement system on a user's wrist.



FIG. 6 shows a block diagram illustrating components of a wearable physiological measurement system configured to provide continuous collection and monitoring of physiological data.



FIG. 7A illustrates a side view of a physiological measurement system including a strap that is not coupled to a modular head portion.



FIG. 7B illustrates a side view of a physiological measurement system in which a modular head portion is removably coupled to the strap.



FIGS. 8A and 8B depict a schematic side view and top view, respectively, of a physiological measurement system including a head portion, a strap, and a multi-chip module.



FIG. 9 is a flowchart illustrating a signal processing algorithm for generating a sequence of heart rates for every detected heartbeat that may be embodied in computer-executable instructions stored on one or more non-transitory computer-readable media.



FIG. 10 is a flowchart illustrating a method of determining an intensity score.



FIG. 11 is a flowchart illustrating a method by which a user may use intensity and recovery scores.



FIG. 12 illustrates a display of an intensity score index indicated in a circular graphic component with an exemplary current score of 19.0 indicated.



FIG. 13 illustrates a display of a recovery score index indicated in a circular graphic component with a first threshold of 66% and a second threshold of 33% indicated.



FIGS. 14A-14C illustrate the recovery score graphic component with recovery scores and qualitative information corresponding to the recovery scores.



FIGS. 15A-18B illustrate a user interface for displaying physiological data specific to a user as rendered on visual display device.



FIGS. 19A-19B illustrate a user interface rendered on a visual display device for displaying physiological data on a plurality of users.



FIG. 20 illustrates a user interface that may be used to independently select time periods of data for multiple users so that the data from the selected periods may be displayed together.



FIGS. 21A-21B illustrate a user interface viewable by an administrative user, including a selectable and editable listing of users (e.g., a trainer's clients) whose health information is available for display.



FIG. 22 is a block diagram of a computing device that may be used herein.



FIG. 23 is a block diagram of a distributed computer system in which various aspects and functions in accord with the present disclosure may be practiced.



FIG. 24 is a diagram of a network environment suitable for a distributed implementation of embodiments described herein.



FIG. 25 is a flow chart illustrating a method according to an implementation.



FIG. 26 is a flow chart illustrating a method according to an implementation.



FIG. 27 is a flow chart of a process for detecting heart rate variability using ambient light.





DETAILED DESCRIPTION

The embodiments will now be described more fully hereinafter with reference to the accompanying figures, in which preferred embodiments are shown. The foregoing may, however, be embodied in many different forms and should not be construed as limited to the illustrated embodiments set forth herein. Rather, these illustrated embodiments are provided so that this disclosure will convey the scope to those skilled in the art.


All documents mentioned herein are hereby incorporated by reference in their entirety. References to items in the singular should be understood to include items in the plural, and vice versa, unless explicitly stated otherwise or clear from the text. Grammatical conjunctions are intended to express any and all disjunctive and conjunctive combinations of conjoined clauses, sentences, words, and the like, unless otherwise stated or clear from the context. Thus, the term “or” should generally be understood to mean “and/or” and so forth.


Recitations of ranges of values herein are not intended to be limiting, referring instead individually to any and all values falling within the range, unless otherwise indicated herein, and each separate value within such a range is incorporated into the specification as if it were individually recited herein. The words “about,” “approximately,” or the like, when accompanying a numerical value, are to be construed as indicating a deviation as would be appreciated by one of ordinary skill in the art to operate satisfactorily for an intended purpose. Ranges of values and/or numeric values are provided herein as examples only, and do not constitute a limitation on the scope of the described embodiments. The use of any and all examples, or exemplary language (“e.g.,” “such as,” or the like) provided herein, is intended merely to better illuminate the embodiments and does not pose a limitation on the scope of the embodiments. No language in the specification should be construed as indicating any unclaimed element as essential to the practice of the embodiments.


In the following description, it is understood that terms such as “first,” “second,” “above,” “below,” and the like, are words of convenience and are not to be construed as limiting terms.


Exemplary embodiments provide physiological measurement systems, devices and methods for continuous health and fitness monitoring, and provide improvements to overcome the drawbacks of conventional heart rate monitors. One aspect of the present disclosure is directed to providing a lightweight wearable system with a strap that collects various physiological data or signals from a wearer. The strap may be used to position the system on an appendage or extremity of a user, for example, wrist, ankle, and the like. Exemplary systems are wearable and enable real-time and continuous monitoring of heart rate without the need for a chest strap or other bulky equipment which could otherwise cause discomfort and prevent continuous wearing and use. The system may determine the user's heart rate without the use of electrocardiography and without the need for a chest strap. Exemplary systems can thereby be used in not only assessing general well-being but also in continuous monitoring of fitness. Exemplary systems also enable monitoring of one or more physiological parameters in addition to heart rate including, but not limited to, body temperature, heart rate variability, motion, sleep, stress, fitness level, recovery level, effect of a workout routine on health and fitness, caloric expenditure, and the like.


A health or fitness monitor that includes bulky components may hinder continuous wear. Existing fitness monitors often include the functionality of a watch, thereby making the health or fitness monitor quite bulky and inconvenient for continuous wear. Accordingly, one aspect is directed to providing a wearable health or fitness system that does not include bulky components, thereby making the bracelet slimmer, unobtrusive and appropriate for continuous wear. The ability to continuously wear the bracelet further allows continuous collection of physiological data, as well as continuous and more reliable health or fitness monitoring. For example, embodiments of the bracelet disclosed herein allow users to monitor data at all times, not just during a fitness session. In some embodiments, the wearable system may or may not include a display screen for displaying heart rate and other information. In other embodiments, the wearable system may include one or more light emitting diodes (LEDs) to provide feedback to a user and display heart rate selectively. In some embodiments, the wearable system may include a removable or releasable modular head that may provide additional features and may display additional information. Such a modular head can be releasably installed on the wearable system when additional information display is desired, and removed to improve the comfort and appearance of the wearable system. In other embodiments, the head may be integrally formed in the wearable system.


Exemplary embodiments also include computer-executable instructions that, when executed, enable automatic interpretation of one or more physiological parameters to assess the cardiovascular intensity experienced by a user (embodied in an intensity score or indicator) and the user's recovery after physical exertion or daily stress given sleep and other forms of rest (embodied in a recovery score). These indicators or scores may be stored and displayed in a meaningful format to assist a user in managing his health and exercise regimen. Exemplary computer-executable instructions may be provided in a cloud implementation.


Exemplary embodiments also provide a vibrant and interactive online community, in the form of a website, for displaying and sharing physiological data among users. A user of the website may include an individual whose health or fitness is being monitored, such as an individual wearing a wearable system disclosed herein, an athlete, a sports team member, a personal trainer or a coach. In some embodiments, a user may pick his/her own trainer from a list to comment on their performance. Exemplary systems have the ability to stream all physiological information wirelessly, directly or through a mobile communication device application, to an online website using data transfer to a cell phone/computer. This information, as well as any data described herein, may be encrypted (e.g., the data may include encrypted biometric data). Thus, the encrypted data may be streamed to a secure server for processing. In this manner, only authorized users will be able to view the data and any associated scores. In addition, or in the alternative, the website may allow users to monitor their own fitness results, share information with their teammates and coaches, compete with other users, and win status. Both the wearable system and the website allow a user to provide feedback regarding his/her day, exercise and/or sleep, which enables recovery and performance ratings.


In an exemplary technique of data transmission, data collected by a wearable system may be transmitted directly to a cloud-based data storage, from which data may be downloaded for display and analysis on a website. In another exemplary technique of data transmission, data collected by a wearable system may be transmitted via a mobile communication device application to a cloud-based data storage, from which data may be downloaded for display and analysis on a website.


In some embodiments, the website may be a social networking site. In some embodiments, the website may be displayed using a mobile website or a mobile application. In some embodiments, the website may be configured to communicate data to other websites or applications. In some embodiments, the website may be configured to provide an interactive user interface. The website may be configured to display results based on analysis on physiological data received from one or more devices. The website may be configured to provide competitive ways to compare one user to another, and ultimately a more interactive experience for the user. For example, in some embodiments, instead of merely comparing a user's physiological data and performance relative to that user's past performances, the user may be allowed to compete with other users and the user's performance may be compared to that of other users.


I. DEFINITIONS OF TERMS

Certain terms are defined below to facilitate understanding of exemplary embodiments.


The term “user” as used herein, refers to any type of animal, human or non-human, whose physiological information may be monitored using an exemplary wearable physiological monitoring system.


The term “body,” as used herein, refers to the body of a user.


The term “continuous,” as used herein in connection with heart rate data collection, refers to collection of heart rate data at a sufficient frequency to enable detection of every heart beat and also refers to collection of heart rate data continuously throughout the day and night.


The term “pointing device,” as used herein, refers to any suitable input interface, specifically, a human interface device, that allows a user to input spatial data to a computing system or device. In an exemplary embodiment, the pointing device may allow a user to provide input to the computer using physical gestures, for example, pointing, clicking, dragging, and dropping. Exemplary pointing devices may include, but are not limited to, a mouse, a touchpad, a touchscreen, and the like.


The term “multi-chip module,” as used herein, refers to an electronic package in which multiple integrated circuits (IC) are packaged with a unifying substrate, facilitating their use as a single component, i.e., as a higher processing capacity IC packaged in a much smaller volume.


The term “computer-readable medium,” as used herein, refers to a non-transitory storage hardware, non-transitory storage device or non-transitory computer system memory that may be accessed by a controller, a microcontroller, a computational system or a module of a computational system to encode thereon computer-executable instructions or software programs. The “computer-readable medium” may be accessed by a computational system or a module of a computational system to retrieve and/or execute the computer-executable instructions or software programs encoded on the medium. The non-transitory computer-readable media may include, but are not limited to, one or more types of hardware memory, non-transitory tangible media (for example, one or more magnetic storage disks, one or more optical disks, one or more USB flash drives), computer system memory or random access memory (such as, DRAM, SRAM, EDO RAM) and the like.


The term “distal,” as used herein, refers to a portion, end or component of a physiological measurement system that is farthest from a user's body when worn by the user.


The term “proximal,” as used herein, refers to a portion, end or component of a physiological measurement system that is closest to a user's body when worn by the user.


The term “equal,” as used herein, refers, in a broad lay sense, to exact equality or approximate equality within some tolerance.


II. EXEMPLARY WEARABLE PHYSIOLOGICAL MEASUREMENT SYSTEMS

Exemplary embodiments provide wearable physiological measurements systems that are configured to provide continuous measurement of heart rate. Exemplary systems are configured to be continuously wearable on an appendage, for example, wrist or ankle, and do not rely on electrocardiography or chest straps in detection of heart rate. The exemplary system includes one or more light emitters for emitting light at one or more desired frequencies toward the user's skin, and one or more light detectors for received light reflected from the user's skin. The light detectors may include a photo-resistor, a photo-transistor, a photo-diode, and the like. As light from the light emitters (for example, green light) pierces through the skin of the user, the blood's natural absorbance or transmittance for the light provides fluctuations in the photo-resistor readouts. These waves have the same frequency as the user's pulse since increased absorbance or transmittance occurs only when the blood flow has increased after a heartbeat. The system includes a processing module implemented in software, hardware or a combination thereof for processing the optical data received at the light detectors and continuously determining the heart rate based on the optical data. The optical data may be combined with data from one or more motion sensors, e.g., accelerometers and/or gyroscopes, to minimize or eliminate noise in the heart rate signal caused by motion or other artifacts (or with other optical data of another wavelength).



FIG. 1 illustrates front and back perspective views of one embodiment of a wearable system configured as a bracelet 100 including one or more straps 102. FIGS. 2 and 3 show various exemplary embodiments of a bracelet according to aspects disclosed herein. FIG. 4 illustrates an exemplary user interface of a bracelet. The bracelet is sleek and lightweight, thereby making it appropriate for continuous wear. The bracelet may or may not include a display screen, e.g., a screen 106 such as a light emitting diode (LED) display for displaying any desired data (e.g., instantaneous heart rate), as shown and described below with reference to the exemplary embodiments in FIGS. 2-4.


As shown in the non-limiting embodiment in FIG. 1, the strap 102 of the bracelet may have a wider side and a narrower side. In one embodiment, a user may simply insert the narrower side into the thicker side and squeeze the two together until the strap is tight around the wrist, as shown in FIG. 5. To remove the strap, a user may push the strap further inwards, which unlocks the strap and allows it to be released from the wrist. In other embodiments, various other fastening means may be provided. For example, the fastening mechanism may include, without limitation, a clasp, clamp, clip, dock, friction fit, hook and loop, latch, lock, pin, screw, slider, snap, button, spring, yoke, and so on.


In some embodiments, the strap of the bracelet may be a slim elastic band formed of any suitable elastic material, for example, rubber. Certain embodiments of the wearable system may be configured to have one size that fits all. Other embodiments may provide the ability to adjust for different wrist sizes. In one aspect, a combination of constant module strap material, a spring-loaded, floating optical system and a silicon-rubber finish may be used in order to achieve coupling while maintaining the strap's comfort for continuous use. Use of medical-grade materials to avoid skin irritations may be utilized.


As shown in FIG. 1, the wearable system may include components configured to provide various functions such as data collection and streaming functions of the bracelet. In some embodiments, the wearable system may include a button underneath the wearable system. In some embodiments, the button may be configured such that, when the wearable system is properly tightened to one's wrist as shown in FIG. 3A, the button may press down and activate the bracelet to begin storing information. In other embodiments, the button may be disposed and configured such that it may be pressed manually at the discretion of a user to begin storing information or otherwise to mark the start or end of an activity period. In some embodiments, the button may be held to initiate a time stamp and held again to end a time stamp, which may be transmitted, directly or through a mobile communication device application, to a website as a time stamp.


Time stamp information may be used, for example, as a privacy setting to indicate periods of activity during which physiological data may not be shared with other users. In one aspect, the button may be tapped, double-tapped (or triple-tapped or more), or held down in order to perform different functions or display different information (e.g., display battery information, generate time stamps, etc.). Other implementations may include more or less buttons or other forms of interfaces. More general, a privacy switch such as any of the user inputs or controls described herein may be operated to control restrictions on sharing, distribution, or use of heart rate or other continuously monitored physiological data. For example, the privacy switch may include a toggle switch to switch between a private setting where data is either not gathered at all or where data is stored locally for a user, and between a public, shared, or other non-private setting where data is communicated over a network and/or to a shared data repository. The privacy switch may also support numerous levels of privacy, e.g., using a hierarchical, role-based, and/or identity-based arrangement of permitted users and/or uses. As another example, various levels of privacy may be available for the type and amount of data that is shared versus private. In general, the privacy switch may be a physical switch on the wearable system, or a logical switch or the like maintained on a computer or other local or mobile computing device of the user, or on a website or other network-accessible resource where the user can select and otherwise control privacy settings for monitored physiological data.


In some embodiments, the wearable system may be waterproof so that users never need to remove it, thereby allowing for continuous wear.


The wearable system may include a heart rate monitor. In one example, the heart rate may be detected from the radial artery, in the exemplary positioning shown in FIG. 5. See, Certified Nursing Association, “Regular monitoring of your patient's radial pulse can help you detect changes in their condition and assist in providing potentially life-saving care.” See, http://cnatraininghelp.com/cna-skills/counting-and-recording-a-radial-pulse, the entire contents of which are incorporated herein by reference. Thus, the wearable system may include a pulse sensor. In one embodiment, the wearable system may be configured such that, when a user wears it around their wrist and tightens it, the sensor portion of the wearable system is secured over the user's radial artery or other blood vessel. Secure connection and placement of the pulse sensor over the radial artery or other blood vessel may allow measurement of heart rate and pulse. It will be understood that this configuration is provided by way of example only, and that other sensors, sensor positions, and monitoring techniques may also or instead be employed without departing from the scope of this disclosure.


In some embodiments, the pulse or heart rate may be taken using an optical sensor coupled with one or more light emitting diodes (LEDs), all directly in contact with the user's wrist. The LEDs are provided in a suitable position from which light can be emitted into the user's skin. In one example, the LEDs mounted on a side or top surface of a circuit board in the system to prevent heat buildup on the LEDs and to prevent burns on the skin. The circuit board may be designed with the intent of dissipating heat, e.g., by including thick conductive layers, exposed copper, heatsink, or similar. In one aspect, the pulse repetition frequency is such that the amount of power thermally dissipated by the LED is negligible. Cleverly designed elastic wrist straps can ensure that the sensors are always in contact with the skin and that there is a minimal amount of outside light seeping into the sensors. In addition to the elastic wrist strap, the design of the strap may allow for continuous micro adjustments (no preset sizes) in order to achieve an optimal fit, and a floating sensor module. The sensor module may be free to move with the natural movements caused by flexion and extension of the wrist.


In some embodiments, the wearable system may be configured to record other physiological parameters including, but not limited to, skin temperature (using a thermometer), galvanic skin response (using a galvanic skin response sensor), motion (using one or more multi-axes accelerometers and/or gyroscope), and the like, and environmental or contextual parameters, e.g., ambient temperature, humidity, time of day, and the like. In an implementation, sensors are used to provide at least one of continuous motion detection, environmental temperature sensing, electrodermal activity (EDA) sensing, galvanic skin response (GSR) sensing, and the like. In this manner, an implementation can identify the cause of a detected physiological event. Reflectance PhotoPlethysmoGraphy (RPPG) may be used for the detection of cardiac activity, which may provide for non-intrusive data collection, usability in wet, dusty and otherwise harsh environments, and low power requirements. For example, as explained herein, using the physiological readouts of the device and the analytics described herein, an “Intensity Score” (e.g., 0-21) (e.g., that measures a user's recent exertion), a “Recovery Score” (e.g., 0-100%), and “Sleep Score” (e.g., 0-100) may together measure readiness for physical and psychological exertion.


In some embodiments, the wearable system may further be configured such that a button underneath the system may be pressed against the user's wrist, thus triggering the system to begin one or more of collecting data, calculating metrics and communicating the information to a network. In some embodiments, the sensor used for, e.g., measuring heart rate or GSR or any combination of these, may be used to indicate whether the user is wearing the wearable system or not. In some embodiments, power to the one or more LEDs may be cut off as soon as this situation is detected, and reset once the user has put the wearable system back on their wrist.


The wearable system may include one, two or more sources of battery life, e.g., two or more batteries. In some embodiments, it may have a battery that can slip in and out of the head of the wearable system and can be recharged using an included accessory. Additionally, the wearable system may have a built-in battery that is less powerful. When the more powerful battery is being charged, the user does not need to remove the wearable system and can still record data (during sleep, for example).


In some embodiments, an application associated with data from an exemplary wearable system (e.g., a mobile communication device application) may include a user input component for enabling additional contextual data, e.g., emotional (e.g., the user's feelings), perceived intensity, and the like. When the data is uploaded from the wearable system directly or indirectly to a website, the website may record a user's “Vibes” alongside their duration of exercise and sleep.


In exemplary embodiments, the wearable system is enabled to automatically detect when the user is asleep, awake but at rest and exercising based on physiological data collected by the system.


As shown in the exemplary embodiment of FIG. 4, a rotatable wheel 108 may be provided at the center of the wearable system to control whether the system is displaying the heart rate. For example, when the wheel is turned to the right however, the system continuously shows heart rate, and turns off the heart rate display when the wheel is turned to the right again. In one example, turning the wheel to the right and holding it there creates a time stamp to indicate the duration of exercise. Turning the wheel to the left and holding it there forces data transmission to a cell phone, external computer or the Internet. In other embodiments, the wheel 108 may be absent in the wearable system. In some embodiments, the functionality of a rotatable wheel described herein may be provided in an application of a mobile communication device that is associated with physiological data collected from a wearable system.



FIG. 6 shows a block diagram illustrating exemplary components of a wearable physiological measurement system 600 configured to provide continuous collection and monitoring of physiological data. The wearable system 600 includes one or more sensors 602. As discussed above, the sensors 602 may include a heart rate monitor. In some embodiments, the wearable system 600 may further include one or more of sensors for detecting calorie burn, distance and activity. Calorie burn may be based on a user's heart rate, and a calorie burn measurement may be improved if a user chooses to provide his or her weight and/or other physical parameters. In some embodiments, manual entering of data is not required in order to derive calorie burn; however, data entry may be used to improve the accuracy of the results. In some embodiments, if a user has forgotten to enter a new weight, he/she can enter it for past weeks and the calorie burn may be updated accordingly.


The sensors 602 may include one or more sensors for activity measurement. In some embodiments, the system may include one or more multi-axes accelerometers and/or gyroscope to provide a measurement of activity. In some embodiments, the accelerometer may further be used to filter a signal from the optical sensor for measuring heart rate and to provide a more accurate measurement of the heart rate. In some embodiments, the wearable system may include a multi-axis accelerometer to measure motion and calculate distance, whether it be in real terms as steps or miles or as a converted number. Activity sensors may be used, for example, to classify or categorize activity, such as walking, running, performing another sport, standing, sitting or lying down. In some embodiments, one or more of collected physiological data may be aggregated to generate an aggregate activity level. For example, heart rate, calorie burn, and distance may be used to derive an aggregate activity level. The aggregate level may be compared with or evaluated relative to previous recordings of the user's aggregate activity level, as well as the aggregate activity levels of other users.


The sensors 602 may include a thermometer for monitoring the user's body or skin temperature. In one embodiment, the sensors may be used to recognize sleep based on a temperature drop, GSR data, lack of activity according to data collected by the accelerometer, and reduced heart rate as measured by the heart rate monitor. The body temperature, in conjunction with heart rate monitoring and motion, may be used to interpret whether a user is sleeping or just resting, as body temperature drops significantly when an individual is about to fall asleep), and how well an individual is sleeping as motion indicates a lower quality of sleep. The body temperature may also be used to determine whether the user is exercising and to categorize and/or analyze activities.


For ambient light detection as contemplated herein, the sensors 602 may include one or more light detectors positioned to receive ambient light from an ambient light source reflected from a skin of a user such as any of the optical sensors contemplated herein for photoplethysmography or the like. The sensors 602 may include a sensor for independently detecting a magnitude of ambient light incident on the skin, or ambient light may be measured from sensors used for heart rate detection.


The system 600 includes one or more batteries 604. According to one embodiment, the one or more batteries may be configured to allow continuous wear and usage of the wearable system. In one embodiment, the wearable system may include two or more batteries. The system may include a removable battery that may be recharged using a charger. In one example, the removable battery may be configured to slip in and out of a head portion of the system, attach onto the bracelet, or the like. In one example, the removable battery may be able to power the system for around a week. Additionally, the system may include a built-in battery. The built-in battery may be recharged by the removable battery. The built-in battery may be configured to power the bracelet for around a day on its own. When the more removable battery is being charged, the user does not need to remove the system and may continue collecting data using the built-in battery. In other embodiments, the two batteries may both be removable and rechargeable.


In some embodiments, the system 600 may include a battery that is a wireless rechargeable battery. For example, the battery may be recharged by placing the system or the battery on a rechargeable mat. In other example, the battery may be a long range wireless rechargeable battery. In other embodiments, the battery may be a rechargeable via motion. In yet other embodiments, the battery may be rechargeable using a solar energy source.


The wearable system 600 includes one or more non-transitory computer-readable media 606 for storing raw data detected by the sensors of the system and processed data calculated by a processing module of the system.


The system 600 includes a processor 608, a memory 610, a bus 612, a network interface 614 and an interface 616. The network interface 614 is configured to wirelessly communicate data to an external network. Some embodiments of the wearable system may be configured to stream information wirelessly to a social network. In some embodiments, data streamed from a user's wearable system to an external network may be accessed by the user via a website. The network interface may be configured such that data collected by the system may be streamed wirelessly. In some embodiments, data may be transmitted automatically, without the need to manually press any buttons. In some embodiments, the system may include a cellular chip built into the system. In one example, the network interface may be configured to stream data using Bluetooth technology. In another example, the network interface may be configured to stream data using a cellular data service, such as via a 3G or 4G cellular network.


In one aspect, the system 600 may be configured to obtain cardiac data using ambient light as described for example with reference to FIG. 27 below. Thus, an electronic circuit board of the system 600 may include a processing module such as the processor 608 configured to determine a heart rate of the user by: executing one or more computer-executable instructions associated with a peak detection algorithm to process the data corresponding to the ambient light reflected from the skin to detect a plurality of peaks associated with a plurality of beats of the user's heart, calculating a sequence of instantaneous heart rates of the user based on the plurality of peaks, and calculating a heart rate variability of the user based on the sequence of instantaneous heart rates.


As generally described with reference to FIG. 27, the processing module may be configured to select an algorithm for calculating the instantaneous heart rates by: determining an R-wave-to-R-wave interval (RR interval) based on the plurality of peaks detected by the peak detection algorithm; determining a confidence level associated with the RR interval; and based on the confidence level associated with the RR interval, selecting either the peak detection algorithm or a frequency analysis algorithm to process data corresponding to the reflected light to determine the sequence of instantaneous heart rates of the user.


The sensors 602 may include a motion sensor such as an accelerometer, and where the frequency analysis algorithm is used, the frequency analysis algorithm processes the data corresponding to the reflected light (from ambient light) based on the motion of the user.


The sensors 602 may also or instead include output transducers such as illumination sources positioned to illuminate the skin, e.g., for a conventional photoplethysmography process. The processing module may be configured to selectively activate these light sources when the magnitude of ambient light falls below a predetermined threshold.


In some embodiments, a physiological measurement system may be configured in a modular design to enable continuous operation of the system in monitoring physiological information of a user wearing the system. The module design may include a strap and a separate modular head portion or housing that is removably couplable to the strap. FIG. 7A illustrates a side view of an exemplary physiological measurement system 100 including a strap 102 that is not coupled to a modular head portion or housing 104. FIG. 7B illustrates a side view of the system 100 in which the modular head portion 104 is removably coupled to the strap 102.


In the non-limiting illustrative module design, the strap 102 of a physiological measurement system may be provided with a set of components that enables continuous monitoring of at least a heart rate of the user so that it is independent and fully self-sufficient in continuously monitoring the heart rate without requiring the modular head portion 104. In one embodiment, the strap includes a plurality of light emitters for emitting light toward the user's skin, a plurality of light detectors for receiving light reflected from the user's skin, an electronic circuit board comprising a plurality of electronic components configured for analyzing data corresponding to the reflected light to automatically and continually determine a heart rate of the user, and a first set of one or more batteries for supplying electrical power to the light emitters, the light detectors and the electronic circuit board. In some embodiments, the strap may also detect one or more other physiological characteristics of the user including, but not limited to, temperature, galvanic skin response, and the like. The strap may include one or more slots for permanently or removably coupling batteries 702 to the strap 102.


The strap 102 may include an attachment mechanism 706, e.g., a press-fit mechanism, for coupling the modular head portion 104 to the strap 102. The modular head portion 104 may be coupled to the strap 102 at any desired time by the user to impart additional functionality to the system 100. In one embodiment, the modular head portion 104 includes a second set of one or more batteries 704 chargeable by an external power source so that the second set of batteries can be used to charge or recharge the first set of batteries 702 in the strap 102. The combination of the first and second sets of batteries enables the user to continuously monitor his/her physiological information without having to remove the strap for recharging. In some embodiments, the module head portion may include one or more additional components including, but not limited to, an interface 616 including visual display device configured to render a user interface for displaying physiological information of the user, a GPS sensor, an electronic circuit board (e.g., to process GPS signals), and the like.


Certain exemplary systems may be configured to be coupled to any desired part of a user's body so that the system may be moved from one portion of the body (e.g., wrist) to another portion of the body (e.g., ankle) without affecting its function and operation. An exemplary system may include an electronic circuit board comprising a plurality of electronic components configured for analyzing data corresponding to the reflected light to automatically and continually determine a heart rate of the user. The electronic circuit board implements a processing module configured to detect an identity of a portion of the user's body, for example, an appendage like wrist, ankle, to which the strap is coupled based on one or more signals associated with the heart rate of the user, and, based on the identity of the appendage, adjust data analysis of the reflected light to determine the heart rate of the user.


In one embodiment, the identity of the portion of the user's body to which the wearable system is attached may be determined based on one or more parameters including, but not limited to, absorbance level of light as returned from the user's skin, reflectance level of light as returned from the user's skin, motion sensor data (e.g., accelerometer and/or gyroscope), altitude of the wearable system, and the like.


In some embodiments, the processing module is configured to determine that the wearable system is taken off from the user's body. In one example, the processing module may determine that the wearable system has been taken off if data from the galvanic skin response sensor indicates data atypical of a user's skin. If the wearable system is determined to be taken off from the user's body, the processing module is configured to deactivate the light emitters and the light detectors and cease monitoring of the heart rate of the user to conserve power.


In some exemplary embodiments, the electronic components of the physiological measurement system may be provided in the form of a multi-chip module in which a plurality of electrically-coupled electronic circuit boards are provided separately within the system. In one non-limiting example, the processor and random-access memory (RAM) may be provided on a first circuit board, wireless communication components may be provided on a second circuit board, and sensors may be provided on a third circuit board. The separate electronic circuit boards may be provided in a modular head of the system and/or along a strap of the system. The term “multi-chip module,” as used herein, refers to an electronic package in which multiple integrated circuits (IC) are packaged with a unifying substrate, facilitating their use as a single component, i.e., as a higher processing capacity IC packaged in a much smaller volume. Each IC can comprise a circuit fabricated in a thinned semiconductor wafer. Any suitable set of one or more electronic components may be provided in the circuit boards of a multi-chip module. Exemplary embodiments also provide methods for fabricating and assembling multi-chip modules as taught herein.


Exemplary numbers of chips integrated in a multi-chip module may include, but are not limited to, two, three, four, five, six, seven, eight, and the like. In one embodiment of a physiological measurement system, a single multi-chip module is provided on a circuit board that performs operations to generate physiological information associated with a user of the system. In other embodiments, a plurality of multi-chip modules are provided on a circuit board of the physiological measurement system. The plurality of multi-chip modules may be stacked vertically on top of one another on the circuit board to further minimize the packaging size and the footprint of the circuit board.


In one multi-chip embodiment, two or more electrically-coupled circuit boards of a multi-chip module may be provided in a physiological measurement system in a vertically stacked manner to minimize the packaging size and the footprint of the circuit board. Vertically stacking the components on a circuit board minimizes the packaging size (e.g., the length and width) and the footprint occupied by the chips on the circuit board. In certain non-limiting embodiments, a circuit board including one or more physiological sensors may be placed closest to, proximal to or in contact with the user's skin, while one or more circuit boards including one or more processors, storage devices, communication components and non-physiological sensors may be provided in vertical layers that are distal to the user's skin.



FIGS. 8A and 8B depict a schematic side view and top view, respectively, of an exemplary physiological measurement system 100 including a head portion 104, a strap 102 and a multi-chip module. The head portion and/or the strap may include a circuit board 802 including a multi-chip module assembled in a vertically stacked configuration. Two or more layers of active electronic integrated circuit (IC) components are integrated vertically into a single circuit in the circuit board. The IC layers are oriented in spaced planes that extend substantially parallel to one another in a vertically stacked configuration. As illustrated in FIG. 8A, the circuit board 802 includes a substrate 804 for supporting the multi-chip module. A first integrated circuit chip 806 is coupled to the substrate 804 using any suitable coupling mechanism, for example, epoxy application and curing. A first spacer layer 808 is coupled to the surface of the first integrated circuit chip 806 opposite to the substrate 804 using, for example, epoxy application and curing. A second integrated circuit chip 810 is coupled to the surface of the first spacer layer 808 opposite to the first integrated circuit chip 806 using, for example, epoxy application and curing. The first and second integrated circuit chips 806 and 810 are electrically coupled using wiring 812.


In some embodiments, a metal frame may be provided for mechanical and/or electrical connection among the integrated circuit chips. An exemplary metal frame may take the form of a lead frame. The first and second integrated circuit chips may be coupled to the metal frame using wiring. A packaging may be provided to encapsulate the multi-chip module assembly and to maintain the multiple integrated circuit chips in substantially parallel arrangement with respect to one another.


As illustrated in FIG. 8A, the vertical three-dimensional stacking of the first integrated circuit chip 806 and the second integrated circuit chip 810 provides high-density functionality on the circuit board while minimizing overall packaging size and footprint (as compared to a circuit board that does not employ a vertically stacked multi-chip module). One of ordinary skill in the art will recognize that an exemplary multi-chip module is not limited to two stacked integrated circuit chips. Exemplary numbers of chips vertically integrated in a multi-chip module may include, but are not limited to, two, three, four, five, six, seven, eight, and the like.


In one embodiment, a single multi-chip module is provided. In other embodiments, a plurality of multi-chip modules as illustrated in FIG. 8A is provided. In an exemplary embodiment, a plurality of multi-chip modules (for example, two multi-chip modules) may be stacked vertically on top of one another on a circuit board of a physiological measurement system to further minimize the packaging size and footprint of the circuit board.


In addition to the need for reducing the footprint, there is also a need for decreasing the overall package height in multi-chip modules. Exemplary embodiments may employ wafer thinning to sub-hundreds micron to reduce the package height in multi-chip modules. Any suitable technique can be used to assemble a multi-chip module on a substrate. Exemplary assembly techniques include, but are not limited to, laminated MCM (MCM-L) in which the substrate is a multi-layer laminated printed circuit board, deposited MCM (MCM-D) in which the multi-chip modules are deposited on the base substrate using thin film technology, and ceramic substrate MCM (MCM-C) in which several conductive layers are deposited on a ceramic substrate and embedded in glass layers that layers are co-fired at high temperatures (HTCC) or low temperatures (LTCC).


In another multi-chip embodiment illustrated in FIG. 8B, two or more electrically-coupled circuit boards of a multi-chip module may be provided in a physiological measurement system in a horizontally spaced manner to minimize the height of the circuit board. Providing the components on a circuit board in a horizontally spaced manner minimizes the packaging height occupied by the chips on the circuit board. In certain non-limiting embodiments, a circuit board including one or more physiological sensors may be placed close to or in contact with the user's skin so that physiological signals are detected reliably, while one or more circuit boards including one or more processors, storage devices, communication components and non-physiological sensors may be provided may be distributed throughout the wearable system to provide improved flexibility, wearability, comfort and durability of the system.



FIG. 8B depicts a schematic top view of an exemplary physiological measurement system 100 including a head portion 104 and a strap 102. The head portion 104 and/or the strap 102 may include a circuit board including a plurality of integrated circuit boards or chips 820, 822, 824 forming a multi-chip module assembled in a horizontally spaced configuration. The integrated circuit chips are electrically coupled to one another using wiring 826. The circuit chips may be distributed through the head portion and/or the strap of the system. In the non-limiting illustrative embodiment, for example, one chip is provided in the head portion and two chips are provided in the strap.


Exemplary systems include a processing module configured to filter the raw photoplethysmography data received from the light detectors to minimize contributions due to motion, and subsequently process the filtered data to detect peaks in the data that correspond with heart beats of a user. The overall algorithm for detecting heart beats takes as input the analog signals from optical sensors (mV) and accelerometer, and outputs an implied beats per minute (heart rate) of the signal accurate within a few beats per minute as that determined by an electrocardiography machine even during motion.


In one aspect, using multiple LEDs with different wavelengths reacting to movement in different ways can allow for signal recovery with standard signal processing techniques. The availability of accelerometer information can also be used to compensate for coarse movement signal corruption. In order to increase the range of movements that the algorithm can successfully filter out, an aspect utilizes techniques that augment the algorithm already in place. For example, filtering violent movements of the arm during very short periods of time, such as boxing as exercising, may be utilized by the system. By selective sampling and interpolating over these impulses, an aspect can account for more extreme cases of motion. Additionally, an investigation into different LED wavelengths, intensities, and configurations can allow the systems described herein to extract a signal across a wide spectrum of skin types and wrist sizes. In other words, motion filtering algorithms and signal processing techniques may assist in mitigating the risk caused by movement.



FIG. 9 is a flowchart illustrating an exemplary signal processing algorithm for generating a sequence of heart rates for every detected heartbeat that is embodied in computer-executable instructions stored on one or more non-transitory computer-readable media. In step 902, light emitters of a wearable physiological measurement system emit light toward a user's skin. In step 904, light reflected from the user's skin is detected at the light detectors in the system. In step 906, signals or data associated with the reflected light are pre-processed using any suitable technique to facilitate detection of heart beats. In step 908, a processing module of the system executes one or more computer-executable instructions associated with a peak detection algorithm to process data corresponding to the reflected light to detect a plurality of peaks associated with a plurality of beats of the user's heart. In step 910, the processing module determines an RR interval based on the plurality of peaks detected by the peak detection algorithm. In step 912, the processing module determines a confidence level associated with the RR interval.


Based on the confidence level associated with the RR interval estimate, the processing module selects either the peak detection algorithm or a frequency analysis algorithm to process data corresponding to the reflected light to determine the sequence of instantaneous heart rates of the user. The frequency analysis algorithm may process the data corresponding to the reflected light based on the motion of the user detected using, for example, an accelerometer. The processing module may select the peak detection algorithm or the frequency analysis algorithm regardless of a motion status of the user. It is advantageous to use the confidence in the estimate in deciding whether to switch to frequency-based methods as certain frequency-based approaches are unable to obtain accurate RR intervals for heart rate variability analysis. Therefore, an implementation maintains the ability to obtain the RR intervals for as long as possible, even in the case of motion, thereby maximizing the information that can be extracted.


For example, in step 914, it is determined whether the confidence level associated with the RR interval is above (or equal to or above) a threshold. In certain embodiments, the threshold may be predefined, for example, about 50%-90% in some embodiments and about 80% in one non-limiting embodiment. In other embodiments, the threshold may be adaptive, i.e., the threshold may be dynamically and automatically determined based on previous confidence levels. For example, if one or more previous confidence levels were high (i.e., above a certain level), the system may determine that a present confidence level that is relatively low compared to the previous levels is indicative of a less reliable signal. In this case, the threshold may be dynamically adjusted to be higher so that a frequency-based analysis method may be selected to process the less reliable signal.


If the confidence level is above (or equal to or above) the threshold, in step 916, the processing module may use the plurality of peaks to determine an instantaneous heart rate of the user. On the other hand, in step 920, based on a determination that the confidence level associated with the RR interval is equal to or below the predetermined threshold, the processing module may execute one or more computer-executable instructions associated with the frequency analysis algorithm to determine an instantaneous heart rate of the user. The confidence threshold may be dynamically set based on previous confidence levels.


In some embodiments, in steps 918 or 922, the processing module determines a heart rate variability of the user based on the sequence of the instantaneous heart rates/beats.


The system may include a display device configured to render a user interface for displaying the sequence of the instantaneous heart rates of the user, the RR intervals and/or the heart rate variability determined by the processing module. The system may include a storage device configured to store the sequence of the instantaneous heart rates, the RR intervals and/or the heart rate variability determined by the processing module.


In one aspect, the system may switch between different analytical techniques for determining a heart rate such as a statistical technique for detecting a heart rate and a frequency domain technique for detecting a heart rate. These two different modes have different advantages in terms of accuracy, processing efficiency, and information content, and as such may be useful at different times and under different conditions. Rather than selecting one such mode or technique as an attempted optimization, the system may usefully switch back and forth between these differing techniques, or other analytical techniques, using a predetermined criterion. For example, where statistical techniques are used, a confidence level may be determined and used as a threshold for switching to an alternative technique such as a frequency domain technique. The threshold may also or instead depend on historical, subjective, and/or adapted data for a particular user. For example, selection of a threshold may depend on data for a particular user including without limitation subjective information about how a heart rate for a particular user responds to stress, exercise, and so forth. Similarly, the threshold may adapt to changes in fitness of a user, context provided from other sensors of the wearable system, signal noise, and so forth.


An exemplary statistical technique employs probabilistic peak detection. In this technique, a discrete probabilistic step may be set, and a likelihood function may be established as a mixture of a Gaussian random variable and a uniform. The heart of the likelihood function encodes the assumption that with a first probability (p) the peak detection algorithm has produced a reasonable initial estimate, but with a second probability (1−p) it has not. In a subsequent step, Bayes' rule is applied to determine the posterior density on the parameter space, of which the maximum is taken (that is, the argument (parameter) that maximizes the posterior distribution). This value is the estimate for the heart rate. In a subsequent step, the previous two steps are reapplied for the rest of the sample. There is some variance in the signal due to process noise, which is dependent on the length of the interval. This process noise becomes the variance in the Gaussians used for the likelihood function. Then, the estimate is obtained as the maximum a posteriori on the new posterior distribution. A confidence value is recorded for the estimate which, for some precision measurement, the posterior value is summed at points in the parameter space centered at our estimate+/−the precision.


The beats per minute (BPM) parameter space, θ, may range between about 20 and about 240, corresponding to the empirical bounds on human heart rates. In an exemplary method, a probability distribution is calculated over this parameter space, at each step declaring the mode of the distribution to be the heart rate estimate. A discrete uniform prior may be set:





π1˜DiscUnif(θ)


The un-normalized, univariate likelihood is defined by a mixture of a Gaussian function and a uniform:






l
1
˜IG+(1˜I)U,G˜N1τ2),I˜Ber(p)





where






U˜DiscUnif(θ)


and where σ and p are predetermined constants.


Bayes' rule is applied to determine the posterior density on θ, for example, by component-wise multiplying the prior density vector (π1(θ))θεθ with the likelihood vector (l1(θ))θεθ to obtain the posterior distribution η1. Then, the following is set:





β1=argmaxθεθη1(θ)


For k≧2, the variance in signal S(t) due to process noise is determined. Then, the following variable is set to imbue temporally long RR intervals with more process/interpeak noise and set the post-normalization convolution:





πkk-1*fN(o,λk2


where f is a density function of the following:






Z˜N(o,λk2)


Then, the following expressions are calculated:






l
k
˜pG
k+(1−p)U,Gk˜Nk,σ2)


The expression is then normalized and recorded:





βk=argmaxθεθηk(θ)


Finally, the confidence level of the above expression for a particular precision threshold is determined:







C
k

=




θ






ε


[



β
k

-

e
1


,


β
k

+
e


]



θ





η
k

.






An exemplary frequency analysis algorithm used in an implementation isolates the highest frequency components of the optical data, checks for harmonics common in both the accelerometer data and the optical data, and performs filtering of the optical data. The algorithm takes as input raw analog signals from the accelerometer (3-axis) and pulse sensors, and outputs heart rate values or beats per minute (BPM) for a given period of time related to the window of the spectrogram.


The isolation of the highest frequency components is performed in a plurality of stages, gradually winnowing the window-sizes of consideration, thereby narrowing the range of errors. In one implementation, a spectrogram of 2̂15 samples with overlap 2̂13 samples of the optical data is generated. The spectrogram is restricted to frequencies in which heart rate can lie. These restriction boundaries may be updated when smaller window sizes are considered. The frequency estimate is extracted from the spectrogram by identifying the most prominent frequency component of the spectrogram for the optical data. The frequency may be extracted using the following exemplary steps. The most prominent frequency of the spectrogram is identified in the signal. It is determined if the frequency estimate is a harmonic of the true frequency. The frequency estimate is replaced with the true frequency if the estimate is a harmonic of the true frequency. It is determined if the current frequency estimate is a harmonic of the motion sensor data. The frequency estimate is replaced with a previous temporal estimate if it is a harmonic of the motion sensor data. The upper and lower bounds on the frequency obtained are saved. A constant value may be added or subtracted in some cases. In subsequent steps, the constant added or subtracted may be reduced to provide narrower searches. A number of the previous steps are repeated one or more times, e.g., three times, except taking 2̂{15−i} samples for the window size and 2̂{13−i} for the overlap in the spectrogram where i is the current number of iteration. The final output is the average of the final symmetric endpoints of the frequency estimation.


The table below demonstrates the performance of the algorithm disclosed herein. To arrive at the results below, experiments were conducted in which a subject wore an exemplary wearable physiological measurement system and a 3-lead ECG which were both wired to the same microcontroller (e.g., Arduino) in order to provide time-synced data. Approximately 50 data sets were analyzed which included the subject standing still, walking, and running on a treadmill.









TABLE 1







Performance of signal processing algorithm disclosed herein










Clean data error
Noisy data error



(mean, std) in BPM
(mean, std) in BPM















4-level spectrogram
0.2, 2.3
0.8, 5.1



(80 second blocks)










The algorithm's performance comes from a combination of a probabilistic and frequency based approach. The three difficulties in creating algorithms for heart rate calculations from the PPG data are 1) false detections of beats, 2) missed detections of real beats, and 3) errors in the precise timing of the beat detection. The algorithms disclosed herein provide improvements in these three sources of error and, in some cases, the error is bound to within 2 BPM of ECG values at all times even during the most motion intense activities.


The exemplary wearable system computes heart rate variability (HRV) to obtain an understanding of the recovery status of the body. These values are captured right before a user awakes or when the user is not moving, in both cases photoplethysmography (PPG) variability yielding equivalence to the ECG HRV. HRV is traditionally measured using an ECG machine and obtaining a time series of R-R intervals. Because an exemplary wearable system utilizes photoplethysmography (PPG), it does not obtain the electric signature from the heart beats; instead, the peaks in the obtained signal correspond to arterial blood volume. At rest, these peaks are directly correlated with cardiac cycles, which enables the calculation of HRV via analyzing peak-to-peak intervals (the PPG analog of RR intervals). It has been demonstrated in the medical literature that these peak-to-peak intervals, the “PPG variability,” is identical to ECG HRV while at rest. See, Charlot K, et al. “Interchangeability between heart rate and photoplethysmography variabilities during sympathetic stimulations.” Physiological Measurement. 2009 December; 30(12): 1357-69. doi: 10.1088/0967-3334/30/12/005. URL: http://www.ncbi.nlm.nih.gov/pubmed/19864707; and Lu, S, et. al. “Can photoplethysmography variability serve as an alternative approach to obtain heart rate variability information?” Journal of Clinical Monitoring and Computing. 2008 February; 22(1):23-9. URL: http://www.ncbi.nlm.nih.gov/pubmed/17987395, the entire contents of which are incorporated herein by reference.


Exemplary physiological measurement systems are configured to minimize power consumption so that the systems may be worn continuously without requiring power recharging at frequent intervals. The majority of current draw in an exemplary system is allocated to power the light emitters, e.g., LEDs, the wireless transceiver, the microcontroller and peripherals. In one embodiment, the circuit board of the system may include a boost converter that runs a current of about 10 mA through each of the light emitters with an efficiency of about 80% and may draw power directly from the batteries at substantially constant power. With exemplary batteries at about 3.7 V, the current draw from the battery may be about 40 mW. In some embodiments, the wireless transceiver may draw about 10-20 mA of current when it is actively transferring data. In some embodiments, the microcontroller and peripherals may draw about 5 mA of current.


An exemplary system may include a processing module that is configured to automatically adjust one or more operational characteristics of the light emitters and/or the light detectors to minimize power consumption while ensuring that all heart beats of the user are reliably and continuously detected. The operational characteristics may include, but are not limited to, a frequency of light emitted by the light emitters, the number of light emitters activated, a duty cycle of the light emitters, a brightness of the light emitters, a sampling rate of the light detectors, and the like.


The processing module may adjust the operational characteristics based on one or more signals or indicators obtained or derived from one or more sensors in the system including, but not limited to, a motion status of the user, a sleep status of the user, historical information on the user's physiological and/or habits, an environmental or contextual condition (e.g., ambient light conditions), a physical characteristic of the user (e.g., the optical characteristics of the user's skin), and the like.


In one embodiment, the processing module may receive data on the motion of the user using, for example, an accelerometer. The processing module may process the motion data to determine a motion status of the user which indicates the level of motion of the user, for example, exercise, light motion (e.g., walking), no motion or rest, sleep, and the like. The processing module may adjust the duty cycle of one or more light emitters and the corresponding sampling rate of the one or more light detectors based on the motion status. For example, upon determining that the motion status indicates that the user is at a first higher level of motion, the processing module may activate the light emitters at a first higher duty cycle and sample the reflected light using light detectors sampling at a first higher sampling rate. Upon determining that the motion status indicates that the user is at a second lower level of motion, the processing module may activate the light emitters at a second lower duty cycle and sample the reflected light using light detectors sampling at a second lower sampling rate. That is, the duty cycle of the light emitters and the corresponding sampling rate of the light detectors may be adjusted in a graduated or continuous manner based on the motion status or level of motion of the user. This adjustment ensures that heart rate data is detected at a sufficiently high frequency during motion to reliably detect all of the heart beats of the user.


In non-limiting examples, the light emitters may be activated at a duty cycle ranging from about 1% to about 100%. In another example, the light emitters may be activated at a duty cycle ranging from about 20% to about 50% to minimize power consumption. Certain exemplary sampling rates of the light detectors may range from about 50 Hz to about 1000 Hz, but are not limited to these exemplary rates. Certain non-limiting sampling rates are, for example, about 100 Hz, 200 Hz, 500 Hz, and the like.


In one non-limiting example, the light detectors may sample continuously when the user is performing an exercise routine so that the error standard deviation is kept within 5 beats per minute (BPM). When the user is at rest, the light detectors may be activated for about a 1% duty cycle—10 milliseconds each second (i.e., 1% of the time) so that the error standard deviation is kept within 5 BPM (including an error standard deviation in the heart rate measurement of 2 BPM and an error standard deviation in the heart rate changes between measurement of 3 BPM). When the user is in light motion (e.g., walking), the light detectors may be activated for about a 10% duty cycle—100 milliseconds each second (i.e., 10% of the time) so that the error standard deviation is kept within 6 BPM (including an error standard deviation in the heart rate measurement of 2 BPM and an error standard deviation in the heart rate changes between measurement of 4 BPM).


The processing module may adjust the brightness of one or more light emitters by adjusting the current supplied to the light emitters. For example, a first level of brightness may be set by current ranging between about 1 mA to about 10 mA, but is not limited to this exemplary range. A second higher level of brightness may be set by current ranging from about 11 mA to about 30 mA, but is not limited to this exemplary range. A third higher level of brightness may be set by current ranging from about 80 mA to about 120 mA, but is not limited to this exemplary range. In one non-limiting example, first, second and third levels of brightness may be set by current of about 5 mA, about 20 mA and about 100 mA, respectively.


In some embodiments, the processing module may detect an environmental or contextual condition (e.g., level of ambient light) and adjust the brightness of the light emitters accordingly to ensure that the light detectors reliably detect light reflected from the user's skin while minimizing power consumption. For example, if it is determined that the ambient light is at a first higher level, the brightness of the light emitters may be set at a first higher level. If it is determined that the ambient light is at a second lower level, the brightness of the light emitters may be set at a second lower level. In some cases, the brightness may be adjusted in a continuous manner based on the detected environment condition.


In some embodiments, the processing module may detect a physiological condition of the user (e.g., an optical characteristic of the user's skin) and adjust the brightness of the light emitters accordingly to ensure that the light detectors reliably detect light reflected from the user's skin while minimizing power consumption. For example, if it is determined that the user's skin is highly reflective, the brightness of the light emitters may be set at a first lower level. If it is determined that the user's skin is not very reflective, the brightness of the light emitters may be set at a second higher level.


Shorter-wavelength LEDs may require more power than is required by longer-wavelength LEDs. Therefore, an exemplary wearable system may provide and use light emitted at two or more different frequencies based on the level of motion detected in order to save battery life. For example, upon determining that the motion status indicates that the user is at a first higher level of motion (e.g., exercising), one or more light emitters may be activated to emit light at a first wavelength. Upon determining that the motion status indicates that the user is at a second lower level of motion (e.g., at rest), one or more light emitters may be activated to emit light at a second wavelength that is longer than the first wavelength. Upon determining that the motion status indicates that the user is at a third lower level of motion (e.g., sleeping), one or more light emitters may be activated to emit light at a third wavelength that is longer than the first and second wavelengths. Other levels of motion may be predetermined and corresponding wavelengths of emitted light may be selected. The threshold levels of motion that trigger adjustment of the light wavelength may be based on one or more factors including, but are not limited to, skin properties, ambient light conditions, and the like. Any suitable combination of light wavelengths may be selected, for example, green (for a higher level of motion)/red (for a lower level of motion); red (for a higher level of motion)/infrared (for a lower level of motion); blue (for a higher level of motion)/green (for a lower level of motion); and the like.


Shorter-wavelength LEDs may require more power than is required by other types of heart rate sensors, such as, a piezo-sensor or an infrared sensor. Therefore, an exemplary wearable system may provide and use a unique combination of sensors—one or more light detectors for periods where motion is expected and one or more piezo and/or infrared sensors for low motion periods (e.g., sleep)—to save battery life. Certain other embodiments of a wearable system may exclude piezo-sensors and/or infrared sensors.


For example, upon determining that the motion status indicates that the user is at a first higher level of motion (e.g., exercising), one or more light emitters may be activated to emit light at a first wavelength. Upon determining that the motion status indicates that the user is at a second lower level of motion (e.g., at rest), non-light based sensors may be activated. The threshold levels of motion that trigger adjustment of the type of sensor may be based on one or more factors including, but are not limited to, skin properties, ambient light conditions, and the like.


The system may determine the type of sensor to use at a given time based on the level of motion (e.g., via an accelerometer) and whether the user is asleep (e.g., based on movement input, skin temperature and heart rate). Based on a combination of these factors the system selectively chooses which type of sensor to use in monitoring the heart rate of the user. Common symptoms of being asleep are periods of no movement or small bursts of movement (such as shifting in bed), lower skin temperature (although it is not a dramatic drop from normal), drastic GSR changes, and heart rate that is below the typical resting heart rate when the user is awake. These variables depend on the physiology of a person and thus a machine learning algorithm is trained with user-specific input to determine when he/she is awake/asleep and determine from that the exact parameters that cause the algorithm to deem someone asleep.


In an exemplary configuration, the light detectors may be positioned on the underside of the wearable system and all of the heart rate sensors may be positioned adjacent to each other. For example, the low power sensor(s) may be adjacent to the high power sensor(s) as the sensors may be chosen and placed where the strongest signal occurs. In one example configuration, a 3-axis accelerometer may be used that is located on the top part of the wearable system.


In some embodiments, the processing module may be configured to automatically adjust a rate at which data is transmitted by the wireless transmitter to minimize power consumption while ensuring that raw and processed data generated by the system is reliably transmitted to external computing devices. In one embodiment, the processing module determines an amount of data to be transmitted (e.g., based on the amount of data generated since the time of the last data transmission), and may select the next data transmission time based on the amount of data to be transmitted. For example, if it is determined that the amount of data exceeds (or is equal to or greater than) a threshold level, the processing module may transmit the data or may schedule a time for transmitting the data. On the other hand, if it is determined that the amount of data does not exceed (or is equal to or lower than) the threshold level, the processing module may postpone data transmission to minimize power consumption by the transmitter. In one non-limiting example, the threshold may be set to the amount of data that may be sent in two seconds under current conditions. Exemplary data transmission rates may range from about 50 kbytes per second to about 1 MByte per second, but are not limiting to this exemplary range.


In some embodiments, an operational characteristic of the microprocessor may be automatically adjusted to minimize power consumption. This adjustment may be based on a level of motion of the user's body.


More generally, the above description contemplates a variety of techniques for sensing conditions relating to heart rate monitoring or related physiological activity either directly (e.g., confidence levels or accuracy of calculated heart rate) or indirectly (e.g., motion detection, temperature). However measured, these sensed conditions can be used to intelligently select from among a number of different modes, including hardware modes, software modes, and combinations of the foregoing, for monitoring heart rate based on, e.g., accuracy, power usage, detected activity states, and so forth. Thus there is disclosed herein techniques for selecting from among two or more different heart rate monitoring modes according to a sensed condition.


III. EXEMPLARY PHYSIOLOGICAL ANALYTICS SYSTEM

Exemplary embodiments provide an analytics system for providing qualitative and quantitative monitoring of a user's body, health and physical training. The analytics system is implemented in computer-executable instructions encoded on one or more non-transitory computer-readable media. The analytics system relies on and uses continuous data on one or more physiological parameters including, but not limited to, heart rate. The continuous data used by the analytics system may be obtained or derived from an exemplary physiological measurement system disclosed herein, or may be obtained or derived from a derived source or system, for example, a database of physiological data. In some embodiments, the analytics system computes, stores and displays one or more indicators or scores relating to the user's body, health and physical training including, but not limited to, an intensity score and a recovery score. The scores may be updated in real-time and continuously or at specific time periods, for example, the recovery score may be determined every morning upon waking up, the intensity score may be determined in real-time or after a workout routine or for an entire day.


In certain exemplary embodiments, a fitness score may be automatically determined based on the physiological data of two or more users of exemplary wearable systems.


An intensity score or indicator provides an accurate indication of the cardiovascular intensities experienced by the user during a portion of a day, during the entire day or during any desired period of time (e.g., during a week or month). The intensity score is customized and adapted for the unique physiological properties of the user and takes into account, for example, the user's age, gender, anaerobic threshold, resting heart rate, maximum heart rate, and the like. If determined for an exercise routine, the intensity score provides an indication of the cardiovascular intensities experienced by the user continuously throughout the routine. If determined for a period of including and beyond an exercise routine, the intensity score provides an indication of the cardiovascular intensities experienced by the user during the routine and also the activities the user performed after the routine (e.g., resting on the couch, active day of shopping) that may affect their recovery or exercise readiness.


In exemplary embodiments, the intensity score is calculated based on the user's heart rate reserve (HRR) as detected continuously throughout the desired time period, for example, throughout the entire day. In one embodiment, the intensity score is an integral sum of the weighted HRR detected continuously throughout the desired time period. FIG. 10 is a flowchart illustrating an exemplary method of determining an intensity score.


In step 1002, continuous heart rate readings are converted to HRR values. A time series of heart rate data used in step 1002 may be denoted as:






HεT




    • A time series of HRR measurements, v(t), may be defined in the following expression in which MHR is the maximum heart rate and RHR is the resting heart rate of the user:










v


(
t
)


=



H


(
t
)


-
RHR


MHR
-
RHR






In step 1004, the HRR values are weighted according to a suitable weighting scheme. Cardiovascular intensity, indicated by an intensity score, is defined in the following expression in which w is a weighting function of the HRR measurements:






I(to,t1)=∫t0t1w(v(t))dt


In step 1006, the weighted time series of HRR values is summed and normalized.






I
t=∫Tw(v(t))dt≦w(1)|T|


Thus, the weighted sum is normalized to the unit interval, i.e., [0, 1]:







N
T

=


I
T




w


(
1
)


·
24






hr






In step 1008, the summed and normalized values are scaled to generate user-friendly intensity score values. That is, the unit interval is transformed to have any desired distribution in a scale (e.g., a scale including 21 points from 0 to 21), for example, arctangent, sigmoid, sinusoidal, and the like. In certain distributions, the intensity values increase at a linear rate along the scale, and in others, at the highest ranges the intensity values increase at more than a linear rate to indicate that it is more difficult to climb in the scale toward the extreme end of the scale. In some embodiments, the raw intensity scores are scaled by fitting a curve to a selected group of “canonical” exercise routines that are predefined to have particular intensity scores.


In one embodiment, monotonic transformations of the unit interval are achieved to transform the raw HRR values to user-friendly intensity scores. An exemplary scaling scheme, expressed as f: [0, 1]→4 [0, 1], is performed using the following function:







(

x
,
N
,
p

)

=

0.5


(



arc






tan


(

N


(

x
-
p

)


)




π
/
2


+
1

)






To generate an intensity score, the resulting value may be multiplied by a number based on the desired scale of the intensity score. For example, if the intensity score is graduated from zero to 21, then the value may be multiplied by 21.


In step 1010, the intensity score values are stored on a non-transitory storage medium for retrieval, display and usage. In step 1012, the intensity score values are, in some embodiments, displayed on a user interface rendered on a visual display device. The intensity score values may be displayed as numbers and/or with the aid of graphical tools, e.g., a graphical display of the scale of intensity scores with current score, and the like. In some embodiments, the intensity score may be indicated by audio. In step 1012, the intensity score values are, in some embodiments, displayed along with one or more quantitative or qualitative pieces of information on the user including, but not limited to, whether the user has exceeded his/her anaerobic threshold, the heart rate zones experienced by the user during an exercise routine, how difficult an exercise routine was in the context of the user's training, the user's perceived exertion during an exercise routine, whether the exercise regimen of the user should be automatically adjusted (e.g., made easier if the intensity scores are consistently high), whether the user is likely to experience soreness the next day and the level of expected soreness, characteristics of the exercise routine (e.g., how difficult it was for the user, whether the exercise was in bursts or activity, whether the exercise was tapering, etc.), and the like. In one embodiment, the analytics system may automatically generate, store and display an exercise regimen customized based on the intensity scores of the user.


Step 1006 may use any of a number of exemplary static or dynamic weighting schemes that enable the intensity score to be customized and adapted for the unique physiological properties of the user. In one exemplary static weighting scheme, the weights applied to the HRR values are based on static models of a physiological process. The human body employs different sources of energy with varying efficiencies and advantages at different HRR levels. For example, at the anaerobic threshold (AT), the body shifts to anaerobic respiration in which the cells produce two adenosine triphosphate (ATP) molecules per glucose molecule, as opposed to 36 at lower HRR levels. At even higher HRR levels, there is a further subsequent threshold (CPT) at which creatine triphosphate (CTP) is employed for respiration with even less efficiency.


In order to account for the differing levels of cardiovascular exertion and efficiency at the different HRR levels, in one embodiment, the possible values of HRR are divided into a plurality of categories, sections or levels (e.g., three) dependent on the efficiency of cellular respiration at the respective categories. The HRR parameter range may be divided in any suitable manner, such as, piecewise, including piecewise-linear, piecewise-exponential, and the like. An exemplary piecewise-linear division of the HRR parameter range enables weighting each category with strictly increasing values. This scheme captures an accurate indication of the cardiovascular intensity experienced by the user because it is more difficult to spend time at higher HRR values, which suggests that the weighting function should increase at the increasing weight categories.


In one non-limiting example, the HRR parameter range may be considered a range from zero (0) to one (1) and divided into categories with strictly increasing weights. In one example, the HRR parameter range may be divided into a first category of a zero HRR value and may assign this category a weight of zero; a second category of HRR values falling between zero (0) and the user's anaerobic threshold (AT) and may assign this category a weight of one (1); a third category of HRR values falling between the user's anaerobic threshold (AT) and a threshold at which the user's body employs creatine triphosphate for respiration (CPT) and may assign this category a weight of 18; and a fourth category of HRR values falling between the creatine triphosphate threshold (CPT) and one (1) and may assign this category a weight of 42, although other numbers of HRR categories and different weight values are possible. That is, in this example, the weights are defined as:







w


(
v
)


=

{



0




:
v

=
0





1



:

v






ε
(

0
,
AT

]







18



:

v






ε
(

AT
,
CPT

]







42



;

v






ε
(

CPT
,
1

]











In another exemplary embodiment of the weighting scheme, the HRR time series is weighted iteratively based on the intensity scores determined thus far (e.g., the intensity score accrued thus far) and the path taken by the HRR values to get to the present intensity score. The path may be detected automatically based on the historical HRR values and may indicate, for example, whether the user is performing high intensity interval training (during which the intensity scores are rapidly rising and falling), whether the user is taking long breaks between bursts of exercise (during which the intensity scores are rising after longer periods), and the like. The path may be used to dynamically determine and adjust the weights applied to the HRR values. For example, in the case of high intensity interval training, the weights applied may be higher than in the case of a more traditional exercise routine.


In another exemplary embodiment of the weighting scheme, a predictive approach is used by modeling the weights or coefficients to be the coefficient estimates of a logistic regression model. In this scheme, a training data set is obtained by continuously detecting the heart rate time series and other personal parameters of a group of individuals. The training data set is used to train a machine learning system to predict the cardiovascular intensities experienced by the individuals based on the heart rate and other personal data. The trained system models a regression in which the coefficient estimates correspond to the weights or coefficients of the weighting scheme. In the training phase, user input on perceived exertion and the intensity scores are compared. The learning algorithm also alters the weighs based on the improving or declining health of a user as well as their qualitative feedback. This yields a unique algorithm that incorporates physiology, qualitative feedback, and quantitative data. In determining a weighting scheme for a specific user, the trained machine learning system is run by executing computer-executable instructions encoded on one or more non-transitory computer-readable media, and generates the coefficient estimates which are then used to weight the user's HRR time series.


One of ordinary skill in the art will recognize that two or more aspects of any of the disclosed weighting schemes may be applied separately or in combination in an exemplary method for determining an intensity score.


In one aspect, heart rate zones quantify the intensity of workouts by weighing and comparing different levels of heart activity as percentages of maximum heart rate. Analysis of the amount of time an individual spends training at a certain percentage of his/her MHR may reveal his/her state of physical exertion during a workout. This intensity, developed from the heart rate zone analysis, motion, and activity, may then indicate his/her need for rest and recovery after the workout, e.g., to minimize delayed onset muscle soreness (DOMS) and prepare him/her for further activity. As discussed above, MHR, heart rate zones, time spent above the anaerobic threshold, and HRV in RSA (Respiratory Sinus Arrhythmia) regions—as well as personal information (gender, age, height, weight, etc.) may be utilized in data processing.


A recovery score or indicator provides an accurate indication of the level of recovery of a user's body and health after a period of physical exertion. The human autonomic nervous system controls the involuntary aspects of the body's physiology and is typically subdivided into two branches: parasympathetic (deactivating) and sympathetic (activating). Heart rate variability (HRV), i.e., the fluctuation in inter-heartbeat interval time, is a commonly studied result of the interplay between these two competing branches. Parasympathetic activation reflects inputs from internal organs, causing a decrease in heart rate. Sympathetic activation increases in response to stress, exercise and disease, causing an increase in heart rate. For example, when high intensity exercise takes place, the sympathetic response to the exercise persists long after the completion of the exercise. When high intensity exercise is followed by insufficient recovery, this imbalance lasts typically until the next morning, resulting in a low morning HRV. This result should be taken as a warning sign as it indicates that the parasympathetic system was suppressed throughout the night. While suppressed, normal repair and maintenance processes that ordinarily would occur during sleep were suppressed as well. Suppression of the normal repair and maintenance processes results in an unprepared state for the next day, making subsequent exercise attempts more challenging.


The recovery score is customized and adapted for the unique physiological properties of the user and takes into account, for example, the user's heart rate variability (HRV), resting heart rate, sleep quality and recent physiological strain (indicated, in one example, by the intensity score of the user). In one exemplary embodiment, the recovery score is a weighted combination of the user's heart rate variability (HRV), resting heart rate, sleep quality indicated by a sleep score, and recent strain (indicated, in one example, by the intensity score of the user). In an exemplar, the sleep score combined with performance readiness measures (such as, morning heart rate and morning heart rate variability) provides a complete overview of recovery to the user. By considering sleep and HRV alone or in combination, the user can understand how exercise-ready he/she is each day and to understand how he/she arrived at the exercise-readiness score each day, for example, whether a low exercise-readiness score is a predictor of poor recovery habits or an inappropriate training schedule. This insight aids the user in adjusting his/her daily activities, exercise regimen and sleeping schedule therefore obtain the most out of his/her training.


In some cases, the recovery score may take into account perceived psychological strain experienced by the user. In some cases, perceived psychological strain may be detected from user input via, for example, a questionnaire on a mobile device or web application. In other cases, psychological strain may be determined automatically by detecting changes in sympathetic activation based on one or more parameters including, but not limited to, heart rate variability, heart rate, galvanic skin response, and the like.


With regard to the user's HRV used in determining the recovery score, suitable techniques for analyzing HRV include, but are not limited to, time-domain methods, frequency-domain methods, geometric methods and non-linear methods. In one embodiment, the HRV metric of the root-mean-square of successive differences (RMSSD) of RR intervals is used. The analytics system may consider the magnitude of the differences between 7-day moving averages and 3-day moving averages of these readings for a given day. Other embodiments may use Poincaré Plot analysis or other suitable metrics of HRV.


The recovery score algorithm may take into account RHR along with history of past intensity and recovery scores.


With regard to the user's resting heart rate, moving averages of the resting heart rate are analyzed to determine significant deviations. Consideration of the moving averages is important since day-to-day physiological variation is quite large even in healthy individuals. Therefore, the analytics system may perform a smoothing operation to distinguish changes from normal fluctuations.


Although an inactive condition, sleep is a highly active recovery state during which a major portion of the physiological recovery process takes place. Nonetheless, a small, yet significant, amount of recovery can occur throughout the day by rehydration, macronutrient replacement, lactic acid removal, glycogen re-synthesis, growth hormone production and a limited amount of musculoskeletal repair. In assessing the user's sleep quality, the analytics system generates a sleep score using continuous data collected by an exemplary physiological measurement system regarding the user's heart rate, skin conductivity, ambient temperature and accelerometer/gyroscope data throughout the user's sleep. Collection and use of these four streams of data enable an understanding of sleep previously only accessible through invasive and disruptive over-night laboratory testing. For example, an increase in skin conductivity when ambient temperature is not increasing, the wearer's heart rate is low, and the accelerometer/gyroscope shows little motion, may indicate that the wearer has fallen asleep. The sleep score indicates and is a measure of sleep efficiency (how good the user's sleep was) and sleep duration (if the user had sufficient sleep). Each of these measures is determined by a combination of physiological parameters, personal habits and daily stress/strain (intensity) inputs. The actual data measuring the time spent in various stages of sleep may be combined with the wearer's recent daily history and a longer-term data set describing the wearer's personal habits to assess the level of sleep sufficiency achieved by the user. The sleep score is designed to model sleep quality in the context of sleep duration and history. It thus takes advantage of the continuous monitoring nature of the exemplary physiological measurement systems disclosed herein by considering each sleep period in the context of biologically-determined sleep needs, pattern-determined sleep needs and historically-determined sleep debt.


The recovery and sleep score values are stored on a non-transitory storage medium for retrieval, display and usage. The recovery and/or sleep score values are, in some embodiments, displayed on a user interface rendered on a visual display device. The recovery and/or sleep score values may be displayed as numbers and/or with the aid of graphical tools, e.g., a graphical display of the scale of recovery scores with current score, and the like. In some embodiments, the recovery and/or sleep score may be indicated by audio. The recovery score values are, in some embodiments, displayed along with one or more quantitative or qualitative pieces of information on the user including, but not limited to, whether the user has recovered sufficiently, what level of activity the user is prepared to perform, whether the user is prepared to perform an exercise routine a particular desired intensity, whether the user should rest and the duration of recommended rest, whether the exercise regimen of the user should be automatically adjusted (e.g., made easier if the recovery score is low), and the like. In one embodiment, the analytics system may automatically generate, store and display an exercise regimen customized based on the recovery scores of the user alone or in combination with the intensity scores.


As discussed above, the sleep performance metric may be based on parameters like the number of hours of sleep, sleep onset latency, and the number of sleep disturbances. In this manner, the score may compare a tactical athlete's duration and quality of sleep in relation to the tactical athlete's evolving sleep need (e.g., a number of hours based on recent strain, habitual sleep need, signs of sickness, and sleep debt). By way of example, a soldier may have a dynamically changing need for sleep, and it may be important to consider the total hours of sleep in relation to the amount of sleep that may have been required. By providing an accurate sensor for sleep and sleep performance, an aspect may evaluate sleep in the context of the overall day and lifestyle of a specific user.



FIG. 11 is a flowchart illustrating an exemplary method by which a user may use intensity and recovery scores. In step 1102, the wearable physiological measurement system begins determining heart rate variability (HRV) measurements based on continuous heart rate data collected by an exemplary physiological measurement system. In some cases, it may take the collection of several days of heart rate data to obtain an accurate baseline for the HRV. In step 1104, the analytics system may generate and display intensity score for an entire day or an exercise routine. In some cases, the analytics system may display quantitative and/or qualitative information corresponding to the intensity score. FIG. 12 illustrates an exemplary display of an intensity score index indicated in a circular graphic component with an exemplary current score of 19.0 indicated. The graphic component may indicate a degree of difficulty of the exercise corresponding to the current score selected from, for example, maximum all out, near maximal, very hard, hard, moderate, light, active, light active, no activity, asleep, and the like. The display may indicate, for example, that the intensity score corresponds to a good and tapering exercise routine, that the user did not overcome his anaerobic threshold and that the user will have little to no soreness the next day.


In step 1106, in an exemplary embodiment, the analytics system may automatically generate or adjust an exercise routine or regimen based on the user's actual intensity scores or desired intensity scores. For example, based on inputs of the user's actual intensity scores, a desired intensity score (that is higher than the actual intensity scores) and a first exercise routine currently performed by the user (e.g., walking), the analytics system may recommend a second different exercise routine that is typically associated with higher intensity scores than the first exercise routine (e.g., running).


In step 1108, at any given time during the day (e.g., every morning), the analytics system may generate and display a recovery score. In some cases, the analytics system may display quantitative and/or qualitative information corresponding to the intensity score. For example, in step 1110, in an exemplary embodiment, the analytics system may determine if the recovery is greater than (or equal to or greater than) a first predetermined threshold (e.g., about 60% to about 80% in some examples) that indicates that the user is recovered and is ready for exercise. If this is the case, in step 1112, the analytics system may indicate that the user is ready to perform an exercise routine at a desired intensity or that the user is ready to perform an exercise routine more challenging than the past day's routine. Otherwise, in step 1114, the analytics system may determine if the recovery is lower than (or equal to or lower than) a second predetermined threshold (e.g., about 10% to about 40% in some examples) that indicates that the user has not recovered. If this is the case, in step 1116, the analytics system may indicate that the user should not exercise and should rest for an extended period. The analytics system may, in some cases, the duration of recommended rest. Otherwise, in step 1118, the analytics system may indicate that the user may exercise according to his/her exercise regimen while being careful not to overexert him/herself. The thresholds may, in some cases, be adjusted based on a desired intensity at which the user desires to exercise. For example, the thresholds may be increased for higher planned intensity scores.



FIG. 13 illustrates an exemplary display of a recovery score index indicated in a circular graphic component with a first threshold of 66% and a second threshold of 33% indicated. FIGS. 14A-14C illustrate the recovery score graphic component with exemplary recovery scores and qualitative information corresponding to the recovery scores.


Optionally, in an exemplary embodiment, the analytics system may automatically generate or adjust an exercise routine or regimen based on the user's actual recovery scores (e.g., to recommend lighter exercise for days during which the user has not recovered sufficiently). This process may also use a combination of the intensity and recovery scores.


The analytics system may, in some embodiments, determine and display the intensity and/or recovery scores of a plurality of users in a comparative manner. This enables users to match exercise routines with others based on comparisons among their intensity scores.


IV. EXEMPLARY DISPLAYS AND USER INTERFACES

Exemplary embodiments also provide a vibrant and interactive online community for displaying and sharing physiological data among users. Exemplary systems have the ability to stream the physiological information wirelessly, directly or through a mobile device application, to an online website. The website allows users to monitor their own fitness results, share information with their teammates and coaches, compete with other users, and win status. Both the wearable system and the website allow a user to provide feedback regarding his day, which enables recovery and performance ratings. One aspect is directed to providing an online website for health and fitness monitoring. In some embodiments, the website may be a social networking site. The website may allow users, such as young athletes, to monitor their own fitness results, share information with their teammates and coaches, compete with other users, and win prizes. A user may include an individual whose health or fitness is being monitored, such as an individual wearing a bracelet disclosed herein, an athlete, a sports team member, a personal trainer or a coach. In some embodiments, a user may pick their own trainer from a list to comment on their performance.


In some embodiments, the website may be configured to provide an interactive user interface. The website may be configured to display results based on analysis on physiological data received from one or more devices. The website may be configured to provide competitive ways to compare one user to another, and ultimately a more interactive experience for the user. For example, in some embodiments, instead of merely comparing a user's physiological data and performance relative to that user's past performances, the user may be allowed to compete with other users and the user's performance may be compared to that of other users.


In some embodiments, the website may be a mobile website or a mobile application. In some embodiments, the website may be configured to communicate data to other websites or applications.


The exemplary website may include a brief and free sign-up process during which a user may create an account with his/her name, account name, email, home address, height, weight, age, and a unique code provided in his/her wearable physiological measurement system. The unique code may be provided, for example, on the wearable system itself or in the packaged kit. Once subscribed, continuous physiological data received from the user's system may be retrieved in a real-time continuous basis and presented automatically on a webpage associated with the user. Additionally, the user can add information to his profile, such as, a picture, favorite activities, sports team(s), and the user may search for teammates/friends on the website for sharing information.



FIGS. 15A-18B illustrate an exemplary user interface 1500 for displaying physiological data specific to a user as rendered on visual display device. The user interface 1500 may take the form of a webpage in some embodiments. One of ordinary skill in the art will recognize that the information in FIGS. 15-18 represent non-limiting illustrative examples. The user interface 1500 may include a summary panel 1502 including an identification 1504 of the user (e.g., a real or account name) with, optionally, a picture or photo corresponding to the user. The summary panel 1502 may also display the current intensity score 1506 and the current recovery score 1508 of the user. In some embodiments, the summary panel 1502 may display the number of calories burned by the user 1510 that day and the number of hours of sleep 1512 obtained by the user the previous night.


The user interface 1500 may also include panels for presenting information on the user's workouts—a workout panel 1514 accessible using tab 1516, day—a day panel 1518 accessible using tab 1520, and sleep—a sleep panel 1522 accessible using tab 1524. The same or different feedback panels may be associated with the workout, day and sleep panels. The panels may enable the user to select and customize one or more informative panels that appear in his/her user interface display.


The workout panel 1514 may present quantitative information on the user's health and exercise routines, for example, a graph 1530 of the user's continuous heart rate during the exercise, statistics 1532 on the maximum heart rate, average heart rate, duration of exercise, number of steps taken and calories expended, zones 1534 in which the maximum heart rate fell during the exercise, and a graph 1536 of the intensity scores over a period of time (e.g., seven days).


A feedback panel 1538 associated with the workout panel 1514 may present information on the intensity score and the exercise routines performed by the user during a selected period of time including, but not limited to, quantitative information, qualitative information, feedback, recommendations on future exercise routines, and the like. The feedback panel 1538 may present the intensity score along with a qualitative summary 1540 of the score indicating, for example, whether the user pushed past his anaerobic threshold for a considerable period of the exercise, whether the exercise is likely to cause muscle pain and soreness, and the like. Based on analysis of the quantitative health parameters monitored during the exercise routine, the feedback panel 1538 may present one or more tips 1542 on adjusting the exercise routine, for example, that the exercise routine started too rapidly and that the user should warm up for longer. In some cases, upon selection of the tips sub-panel 1542, a corresponding indicator 1544 may be provided in the heart rate graph 1530.


Based on analysis of the quantitative health parameters monitored during the exercise routine, the feedback panel 1538 may also present qualitative information 1545 on the user's exercise routine, for example, comparison of the present day's exercise routine to the user's historical exercise data. Such information may indicate, for example, that the user's maximum heart rate for the day's exercise was the highest ever recorded, that the steps taken by the user that day was the fewest ever recorded, that the user burned a lot of calories and that more calories may be burned by lowering the intensity of the exercise, and the like. The feedback panel 1538 may also present cautionary indicators 1546 to warn the user of future anticipated health events, for example, the likelihood of soreness (e.g., if the intensity score is higher than a predefined threshold), and the like.


An exemplary analytics system may analyze the information presented in the workout panel 1514 and determine whether the user performed a specific exercise routine or activity. As one example, given a small number of steps taken and a high calorie burn and heart rate, the system may determine that it is possible the user rode a bicycle that day. In some cases, the feedback panel 1538 may prompt the user to confirm whether he/she indeed performed that activity in a user field 1548. This user input may be displayed and/or used to improve an understanding of the user's health and exercise routines.


The day panel 1518 may include information on health parameters of the user during the current day including, but not limited to, the number of calories burned and the number of calories taken in 1500 (which may be based on user input on the foods eaten), a graph 1554 of the day's continuous heart rate, statistics 1556 on the resting heart rate and steps taken by the user that day, a graph 1558 of the calories burned that and other days, and the like.


In some cases, an analytics system may analyze the physiological data (e.g., heart rate data) and estimate the durations of sleep, activity and workout during the day. A feedback panel 1562 associated with the day panel 1518 may present these durations 1564. In some cases, the feedback panel 1562 may display a net number of calories consumed by the user that day 1566. Based on analysis of the quantitative health parameters monitored during the exercise routine, the feedback panel 1562 may also present qualitative information 1568 on the user's exercise routine. Such information may indicate, for example, that the user was stressed at a certain point in the day (e.g., if there was a high level of sweat with little activity), that the user's maximum heart rate for the day's exercise was the highest ever recorded, that the steps taken by the user that day was the fewest ever recorded, that the user burned a lot of calories and that more calories may be burned by lowering the intensity of the exercise, and the like. The feedback panel 1562 may also present cautionary indicators 1570 to warn the user of future anticipated health events, for example, tachycardia, susceptibility to illness or overtraining (e.g., if the resting heart rate is elevated for a few days), and the like.


An exemplary analytics system may analyze the information presented in the day panel 1518 and determine whether the user performed a specific exercise routine or activity. As one example, given an elevated heart rate with little activity, the system may determine that it is possible the user drank coffee at that point. In some cases, the feedback panel 1562 may prompt the user to confirm whether he/she indeed performed that activity in a user field 1572. This user input may be displayed and/or used to improve an understanding of the user's health and exercise routines.


The sleep panel 1522 may include information on health parameters of the user during sleep including, but not limited to, an overlaid graph 1573 of heart rate and movement during sleep, statistics 1574 on the maximum heart rate, minimum heart rate, number of times the user awoke during sleep, average movement during sleep, a sleep cycle indicator 1576 showing durations spent awake, in light sleep, in deep sleep and in REM sleep, and a sleep duration graph 1578 showing the number of hours slept over a period of time.


A feedback panel 1580 associated with the sleep panel 1522 may present information on the user's sleep including, but not limited to, quantitative information, qualitative information, feedback, recommendations on future exercise routines, and the like. The feedback panel 1580 may present a sleep score and/or a number of hours of sleep along with a qualitative summary of the score 1582 indicating, for example, whether the user slept enough, whether the sleep was efficient or inefficient, whether the user moved around and how much during sleep, and the like. Based on analysis of the quantitative health parameters monitored during sleep, the feedback panel 1580 may present one or more tips 1584 on adjusting sleep, for example, that the woke up a number of times during sleep and that user can try to sleep on his side rather than on his back.


Based on analysis of the quantitative health parameters monitored during the exercise routine, the feedback panel 1580 may also present qualitative information 1586 on the user's sleep. Such information may indicate, for example, that the user's maximum heart rate for the day's exercise was the highest ever recorded during sleep. The feedback panel 1580 may also present cautionary indicators 1588 to warn the user of future anticipated health events, for example, a sign of overtraining and a recommendation to get more sleep (e.g., if the user awoke many times during sleep and/or if the user moved around during sleep.


The user interface 1500 may provide a user input field 1590 for enabling the user to indicate his/her feelings, e.g., activities performed perceived exertion, energy level, performance. The user interface 1500 may also provide a user input field 1592 for enabling the user to indicate other facts about his exercise routine, e.g., comments on what the user was doing at a specific point in the exercise routine with a link 1594 to a corresponding point in the heart rate graph 1530. In some embodiments, the user may specify a route and/or location on a map at which the exercise routine was performed.


Exemplary embodiments also enable a user to compare his/her quantitative and/or qualitative physiological data with those of one or more additional users. A user may be presented with user selection components representing other users who data is available for display. When a pointer is hovered over a user selection component (e.g., an icon representing a user), a snapshot of the user's information is presented in a popup component, and clicking on the user selection component opens up the full user interface displaying the user's information. In some cases, the user selection components include certain user-specific data surrounding an image representing the user, for example, a graphic element indicating the user's intensity score. The user selection components may be provided in a grid as shown or in a linear listing for easier sorting. The users appearing in the user selection components may be sorted and/or ranked based on any desired criteria, e.g., intensity scores, who is experiencing soreness, and the like. A user may leave comments on other users' pages.


Similarly, a user may select privacy settings to indicate which aspects of his/her own data may be viewed by other users. Because the wearable systems described herein support truly continuous monitoring, a user may wish to carefully control whether and when data is transmitted wirelessly, stored in a remote data repository, and shared with others. A privacy switch as described herein may be usefully employed to toggle between various privacy settings or to explicitly select private or restricted times when no monitoring should occur.



FIGS. 19A-19B illustrate an exemplary user interface 1900 rendered on a visual display device for displaying physiological data on a plurality of users. In some cases, a user may freely compare the data of any users whose data is available and accessible, i.e., set to an appropriate privacy level. In some cases, comparative data may correspond to a plurality of users who may be grouped together based on any suitable criteria, e.g., members of a gym, military team, and the like. In some cases, the user may be able to discover other users or comparable data by searching or performing queries on any desired parameters, for example, workouts, activities, age groups, locations, intensities, recoveries and the like. For example, a user may perform a query for “Workouts above a 17 Intensity in Boston for runners my age.” The exemplary user interface may also identify or suggest users with whom to exchange data based on similar parameters. Data on any number of users may be presented and compared including, but not limited to, 2, 3, 4, 5, 6, 7, 8, 9, 10, and the like.


In a default option, data from the same time period(s) may be presented for all of the users. In some embodiments, time periods for each user may be selected independently and data from the selected time periods may be displayed in a comparative manner on the same user interface, e.g., in one or more overlaid graphs. FIG. 20 illustrates a user interface 2000 that may be used to independently select time periods of data for each of five users so that the data from the selected periods may be displayed together. The user interface 2000 includes a representation of each user 2002a-2002e, optionally an indication of each user's intensity score, a calendar component 2004 for selecting the time periods, and a component 2006a-2006e indicating the time periods selected for each user. In some cases, data from different time periods (but, for example, for the same time duration) for the same user may be presented on the same user interface for comparative purpose, for example, to determine training progress.


In FIGS. 19A-19B, the user interface 1900 may include a summary panel 1902 including an identification 1904a-1904b of the users (e.g., a real or account name) with, optionally, a picture or photo corresponding to the user. In some cases, the summary panel 1902 may also display certain information associated with the users, for example, their intensity scores.


A workout panel 1908 may present quantitative information on the users' health and exercise routines, for example, an overlaid graph 1910 of the users' continuous heart rate during the exercise, statistics 1912 on the users' maximum heart rate, average heart rate, duration of exercise, number of steps taken and calories expended, zones 1914 in which the users' maximum heart rate fell during the exercise, and an overlaid graph 1916 of the intensity scores over a period of time (e.g., seven days). A feedback panel 1918 associated with the workout panel 1908 may present comparative qualitative information on the users' exercise routines including, but not limited to, whether the users were working out at the same time, which user had a more difficult workout, the comparative efficiencies of the users, and the like. Similarly, a day panel and a sleep panel may present comparative information for the selected users.


The analytics system may analyze comparative data among a plurality of users and provide rankings of individuals, teams and groups of individuals (e.g., employees of a company, members of a gym) based on, for example, average intensity scores. For each user, the analytics system may calculate and display percentile rankings of the user with respect to all of the users in a community in terms of, for example, intensity scores, quality of sleep, and the like.


Exemplary embodiments also provide user interfaces to enable intuitive and efficient monitoring of a plurality of users by an individual with administrative powers to view the users' health data. Such an administrative user may be a physical instructor, trainer or coach who may use the interface to manage his/her clients' workout regimen.



FIGS. 21A-21B illustrate an exemplary user interface 2100 viewable by an administrative user, including a selectable and editable representation or listing 2102 of the users (e.g., a trainer's clients) whose health information is available for display. When a mouse is hovered over a user selection component (e.g., an icon representing a user), a snapshot of the user's information is presented in a popup component, and clicking on the user selection component opens up the full user interface displaying the user's information. In some cases, the user selection components include certain user-specific data surrounding an image representing the user, for example, a graphic element indicating the user's intensity score. The user selection components in the listing 2102 may be provided in a grid as shown or in a linear listing for easier sorting. The users appearing in the listing 2102 may be sorted and/or ranked based on any desired criteria, e.g., intensity scores, who is experiencing soreness, and the like. Selection of any one user causes the user interface specific to that user to be opened, for example, as shown in FIGS. 15A-18B. The administrative user may leave messages on the user interfaces of the different users. Selection of more than one user causes a user interface comparing the selected users to be opened, for example, as shown in FIGS. 19A-19B.


The administrative user interface 2100 may include a listing of users 2104 who recently performed exercise routines including the time of their last workout and their intensity scores, a listing of users 2106 who are off-schedule in their exercise regimen and how many days they have not been exercising, a listing of users 2108 who are experiencing soreness (that may be determined automatically based on intensity scores), a listing of users who are sleep-deprived (that may be determined automatically based on sleep data), and the like. The user interface 2100 may also display a calendar or portion of a calendar 2110 indicating training times for different users. The calendar feature enables the administrative user to review exercise schedules over time and understand how well individuals or teams are meeting goals. For example, the administrative user may determine that an individual is undertraining if his intensity for the day was 18 whereas the team average was 14.


In any of the exemplary user interfaces disclosed herein, color coding may be used to indicate categories of any parameter. For example, in a day panel of a user interface, color coding may be used to indicate whether a user's day was difficult (e.g., with the color red), tapering (e.g., with the color yellow), or a day off from training (e.g., with the color blue).


Exemplary embodiments enable selected qualitative and/or quantitative data from any of the user interfaces disclosed herein to be selected, packaged and exported to an external application, computational device or webpage (e.g., a blog) for display, storage and analysis. The data may be selected based on any desired characteristic including, but not limited to, gender, age, location, activity, intensity level, and any combinations thereof. An online blog may be presented to display the data and allow users to comment on the data.


V. EXEMPLARY COMPUTING DEVICES

Various aspects and functions described herein may be implemented as hardware, software or a combination of hardware and software on one or more computer systems. Exemplary computer systems that may be used include, but are not limited to, personal computers, embedded computing systems, network appliances, workstations, mainframes, networked clients, servers, media servers, application servers, database servers, web servers, virtual servers, and the like. Other examples of computer systems that may be used include, but are not limited to, mobile computing devices, such as wearable devices, cellular phones and personal digital assistants, and network equipment, such as load balancers, routers and switches.



FIG. 22 is a block diagram of an exemplary computing device 2200 that may be used in to perform any of the methods provided by exemplary embodiments. The computing device may be configured as an embedded system in the integrated circuit board(s) of a wearable physiological measurements system and/or as an external computing device that may receive data from a wearable physiological measurement system.


The computing device 2200 includes one or more non-transitory computer-readable media for storing one or more computer-executable instructions or software for implementing exemplary embodiments. The non-transitory computer-readable media may include, but are not limited to, one or more types of hardware memory, non-transitory tangible media (for example, one or more magnetic storage disks, one or more optical disks, one or more USB flash drives), and the like. For example, memory 2206 included in the computing device 2200 may store computer-readable and computer-executable instructions or software for implementing exemplary embodiments. The computing device 2200 also includes processor 2202 and associated core 2204, and optionally, one or more additional processor(s) 2202′ and associated core(s) 2204′ (for example, in the case of computer systems having multiple processors/cores), for executing computer-readable and computer-executable instructions or software stored in the memory 2206 and other programs for controlling system hardware. Processor 2202 and processor(s) 2202′ may each be a single core processor or multiple core (2204 and 2204′) processor.


Virtualization may be employed in the computing device 2200 so that infrastructure and resources in the computing device may be shared dynamically. A virtual machine 2214 may be provided to handle a process running on multiple processors so that the process appears to be using only one computing resource rather than multiple computing resources. Multiple virtual machines may also be used with one processor.


Memory 2206 may include a computer system memory or random access memory, such as DRAM, SRAM, EDO RAM, and the like. Memory 2206 may include other types of memory as well, or combinations thereof.


A user may interact with the computing device 2200 through a visual display device 2218, such as a computer monitor, which may display one or more user interfaces 2220 that may be provided in accordance with exemplary embodiments. The visual display device 2218 may also display other aspects, elements and/or information or data associated with exemplary embodiments, for example, views of databases, photos, and the like. The computing device 2200 may include other I/O devices for receiving input from a user, for example, a keyboard or any suitable multi-point touch interface 2208, a pointing device 2210 (e.g., a mouse). The keyboard 2208 and the pointing device 2210 may be coupled to the visual display device 2218. The computing device 2200 may include other suitable conventional I/O peripherals.


The computing device 2200 may also include one or more storage devices 2224, such as a hard-drive, CD-ROM, or other computer readable media, for storing data and computer-readable instructions and/or software that implement exemplary methods as taught herein. Exemplary storage device 2224 may also store one or more databases 2026 for storing any suitable information required to implement exemplary embodiments. The databases may be updated by a user or automatically at any suitable time to add, delete or update one or more items in the databases.


The computing device 2200 may include a network interface 2212 configured to interface via one or more network devices 2222 with one or more networks, for example, Local Area Network (LAN), Wide Area Network (WAN) or the Internet through a variety of connections including, but not limited to, standard telephone lines, LAN or WAN links (for example, 802.11, T1, T3, 56 kb, X.25), broadband connections (for example, ISDN, Frame Relay, ATM), wireless connections, controller area network (CAN), or some combination of any or all of the above. The network interface 2212 may include a built-in network adapter, network interface card, PCMCIA network card, card bus network adapter, wireless network adapter, USB network adapter, modem or any other device suitable for interfacing the computing device 2200 to any type of network capable of communication and performing the operations described herein. Moreover, the computing device 2200 may be any computer system, such as a workstation, desktop computer, server, laptop, handheld computer, tablet computer (e.g., the iPad® tablet computer), mobile computing or communication device (e.g., the iPhone® communication device), or other form of computing or telecommunications device that is capable of communication and that has sufficient processor power and memory capacity to perform the operations described herein.


The wearable physiological measurement system may record and transmit at least the following types of data to an external computing system, mobile communication system or the Internet: raw continuously-detected data (e.g., heart rate data, movement data, galvanic skin response data) and processed data based on the raw data (e.g., RR intervals determined from the heart rate data). Transmission modes may be wired (e.g., using USB stick inserted into a USB port on the system) or wireless (e.g., using a wireless transmitter). The raw and processed data may be transmitted together or separately using different transmission modes. Since a raw data file is typically substantially larger than a processed data file, the raw data file may be transmitted using WiFi or a USB stick, while the processed data file may be transmitted using Bluetooth.


An exemplary wearable system may include a 2G, 3G or 4G chip that wirelessly uploads all data to the website disclosed herein without requiring any other external device. A 3G or 4G chip may be used preferably as a 2G connection on a Nokia 5800 was found to transfer data at a rate of 520 kbps using 1.69 W, while a 3G connection transferred at 960 kbps using 1.73 W. Therefore, the 3G chip would use negligibly more power for almost twice the transfer speed, thereby halving half the transfer time and using much less energy from the battery.


In some cases, the wearable system may opportunistically transfer data when in close proximity to a streaming outlet. For example, the system may avoid data transmission when it is not within close proximity of a streaming outlet, and, when nearby a streaming outlet (e.g., a linked phone), may send the data to the external device via Bluetooth and to the Internet via the external device. This is both convenient and “free” in the sense that it utilizes existing cellular data plans.


Limiting the frequency with which data is streamed increases the wearable system's battery life. In one non-limiting example, the system may be set to stream automatically in the morning and following a time stamp. Regardless of the data transmission scheme, the system stores all the data it collects. Data may also be streamed on demand by a user, for example, by turning a physical component on the system and holding it or by initiating a process on the mobile application or receiving device. In some embodiments, the data transmission frequency may be automatically adjusted based on one or more physiological parameters, e.g., heart rate. For example, higher heart rates may prompt more frequent and real-time streaming transmission of data.


The computing device 2200 may run any operating system 2216, such as any of the versions of the Microsoft® Windows® operating systems, the different releases of the Unix and Linux operating systems, any version of the MacOS® for Macintosh computers, any embedded operating system, any real-time operating system, any open source operating system, any proprietary operating system, any operating systems for mobile computing devices, or any other operating system capable of running on the computing device and performing the operations described herein. In exemplary embodiments, the operating system 2216 may be run in native mode or emulated mode. In an exemplary embodiment, the operating system 2216 may be run on one or more cloud machine instances.


VI. EXEMPLARY NETWORK ENVIRONMENTS

Various aspects and functions of the implementations may be distributed among one or more computer systems configured to provide a service to one or more client computers, or to perform an overall task as part of a distributed system. Additionally, aspects may be performed on a client-server or multi-tier system that includes components distributed among one or more server systems that perform various functions. Thus, the implementations are not limited to executing on any particular system or group of systems. Further, aspects may be implemented in software, hardware or firmware, or any combination thereof. Thus, aspects may be implemented within methods, acts, systems, system placements and components using a variety of hardware and software configurations, and they are not limited to any particular distributed architecture, network or communication protocol. Furthermore, aspects may be implemented as specially-programmed hardware and/or software.



FIG. 23 is a block diagram of an exemplary distributed computer system 2300 in which various aspects and functions may be practiced. The distributed computer system 2300 may include one or more computer systems. For example, as illustrated, the distributed computer system 2300 includes three computer systems 2302, 2304 and 2306. As shown, the computer systems 2302, 2304, 2306 are interconnected by, and may exchange data through, a communication network 2308. The network 2308 may include any communication network through which computer systems may exchange data. To exchange data via the network 2308, the computer systems and the network may use various methods, protocols and standards including, but not limited to, token ring, Ethernet, wireless Ethernet, Bluetooth, TCP/IP, UDP, HTTP, FTP, SNMP, SMS, MMS, SS7, JSON, XML, REST, SOAP, CORBA, HOP, RMI, DCOM and Web Services. To ensure data transfer is secure, the computer systems may transmit data via the network using a variety of security measures including, but not limited to, TSL, SSL and VPN. While the distributed computer system 2300 illustrates three networked computer systems, the distributed computer system may include any number of computer systems, networked using any medium and communication protocol.


Various aspects and functions may be implemented as specialized hardware or software executing in one or more computer systems. As depicted, the computer system 2300 includes a processor 2310, a memory 2312, a bus 2314, an interface 2316 and a storage system 2318. The processor 2310, which may include one or more microprocessors or other types of controllers, can perform a series of instructions that manipulate data. The processor 2310 may be a well-known commercially-available processor such as an Intel Pentium, Intel Atom, ARM Processor, Motorola PowerPC, SGI MIPS, Sun UltraSPARC or Hewlett-Packard PA-RISC processor, or may be any other type of processor or controller as many other processors and controllers are available. The processor 2310 may be a mobile device or smart phone processor, such as an ARM Cortex processor, a Qualcomm Snapdragon processor or an Apple processor. As shown, the processor 2310 is connected to other system placements, including a memory 2312, by the bus 2314.


The memory 2312 may be used for storing programs and data during operation of the computer system 2300. Thus, the memory 2312 may be a relatively high performance, volatile, random access memory such as a dynamic random access memory (DRAM) or static memory (SRAM). However, the memory 2312 may include any device for storing data, such a disk drive or other non-volatile storage device, such as flash memory or phase-change memory (PCM). Various embodiments can organize the memory 2312 into particularized and, in some cases, unique structures to perform the aspects and functions disclosed herein.


Components of the computer system 2300 may be coupled by an interconnection element such as the bus 2314. The bus 2314 may include one or more physical busses (for example, buses between components that are integrated within the same machine) and may include any communication coupling between system placements including specialized or standard computing bus technologies such as IDE, SCSI, PCI and InfiniBand. Thus, the bus 2314 enables communications (for example, data and instructions) to be exchanged between system components of the computer system 2300.


Computer system 2300 also includes one or more interface devices 2316, such as input devices, output devices and combination input/output devices. The interface devices 2316 may receive input, provide output, or both. For example, output devices may render information for external presentation. Input devices may accept information from external sources. Examples of interface devices include, but are not limited to, keyboards, mouse devices, trackballs, microphones, touch screens, printing devices, display screens, speakers, network interface cards, and the like. The interface devices 2316 allow the computer system 2300 to exchange information and communicate with external entities, such as users and other systems.


Storage system 2318 may include one or more computer-readable and computer-writeable non-volatile and non-transitory storage media on which computer-executable instructions are encoded that define a program to be executed by the processor. The storage system 2318 also may include information that is recorded on or in the media, and this information may be processed by the program. More specifically, the information may be stored in one or more data structures specifically configured to conserve storage space or increase data exchange performance. The instructions may be persistently stored as encoded signals, and the instructions may cause a processor to perform any of the functions described herein. A medium that can be used with various embodiments may include, for example, optical disk, magnetic disk or flash memory, among others. In operation, the processor 2310 or some other controller may cause data to be read from the non-transitory recording media into another memory, such as the memory 2312, that allows for faster access to the information by the processor than does the storage medium included in the storage system 2318. The memory may be located in the storage system 2318 and/or in the memory 2312. The processor 2310 may manipulate the data within the memory 2312, and then copy the data to the medium associated with the storage system 2318 after processing is completed. A variety of components may manage data movement between the media and the memory 2312, and the present disclosure is not limited thereto.


Further, the implementations are not limited to a particular memory system or storage system. Although the computer system 2300 is shown by way of example as one type of computer system upon which various aspects and functions may be practiced, aspects are not limited to being implemented on the computer system. Various aspects and functions may be practiced on one or more computers having different architectures or components than that shown in the illustrative figures. For instance, the computer system 2300 may include specially-programmed, special-purpose hardware, such as for example, an application-specific integrated circuit (ASIC) tailored to perform a particular operation disclosed herein. Another embodiment may perform the same function using several general-purpose computing devices running MAC OS® System X with Motorola PowerPC® processors and several specialized computing devices running proprietary hardware and operating systems.


The computer system 2300 may include an operating system that manages at least a portion of the hardware placements included in computer system 2300. A processor or controller, such as processor 2310, may execute an operating system which may be, among others, a Windows-based operating system (for example, Windows NT, Windows 2000/ME, Windows XP, Windows 7, or Windows Vista) available from the Microsoft Corporation, a MAC OS® System X operating system available from Apple Computer, one of many Linux-based operating system distributions (for example, the Enterprise Linux operating system available from Red Hat Inc.), a Solaris operating system available from Sun Microsystems, or a UNIX operating systems available from various sources. The operating system may be a mobile device or smart phone operating system, such as Windows Mobile, Android or iOS. Many other operating systems may be used, and embodiments are not limited to any particular operating system.


The processor and operating system together define a computing platform for which application programs in high-level programming languages may be written. These component applications may be executable, intermediate (for example, C# or JAVA bytecode) or interpreted code which communicate over a communication network (for example, the Internet) using a communication protocol (for example, TCP/IP). Similarly, functions may be implemented using an object-oriented programming language, such as SmallTalk, JAVA, C++, Ada, or C# (C-Sharp). Other object-oriented programming languages may also be used. Alternatively, procedural, scripting, or logical programming languages may be used.


Additionally, various functions may be implemented in a non-programmed environment (for example, documents created in HTML, XML or other format that, when viewed in a window of a browser program, render aspects of a graphical-user interface or perform other functions). Further, various embodiments may be implemented as programmed or non-programmed placements, or any combination thereof. For example, a web page may be implemented using HTML while a data object called from within the web page may be written in C++. Thus, the implementations are not limited to a specific programming language and any suitable programming language could also be used.


A computer system included within an embodiment may perform functions outside the scope of the embodiment. For instance, aspects of the system may be implemented using an existing product. Aspects of the system may be implemented on database management systems such as SQL Server available from Microsoft of Seattle, Wash.; Oracle Database from Oracle of Redwood Shores, Calif.; and MySQL from Sun Microsystems of Santa Clara, Calif.; or integration software such as WebSphere middleware from IBM of Armonk, N.Y. However, a computer system running, for example, SQL Server may be able to support both aspects in accord with the implementations and databases for sundry applications not within the scope of the disclosure.



FIG. 24 is a diagram of an exemplary network environment 2400 suitable for a distributed implementation of exemplary embodiments. The network environment 2400 may include one or more servers 2402 and 2404 coupled to one or more clients 2406 and 2408 via a communication network 2410. The network interface 2212 and the network device 2222 of the computing device 2200 enable the servers 2402 and 2404 to communicate with the clients 2406 and 2408 via the communication network 2410. The communication network 2410 may include, but is not limited to, the Internet, an intranet, a LAN (Local Area Network), a WAN (Wide Area Network), a MAN (Metropolitan Area Network), a wireless network, an optical network, and the like. The communication facilities provided by the communication network 2410 are capable of supporting distributed implementations of exemplary embodiments.


In an exemplary embodiment, the servers 2402 and 2404 may provide the clients 2406 and 2408 with computer-readable and/or computer-executable components or products under a particular condition, such as a license agreement. For example, the computer-readable and/or computer-executable components or products may include those for providing and rendering any of the user interfaces disclosed herein. The clients 2406 and 2408 may provide and render an exemplary graphical user interface using the computer-readable and/or computer-executable components and products provided by the servers 2402 and 2404.


Alternatively, in another exemplary embodiment, the clients 2406 and 2408 may provide the servers 2402 and 2404 with computer-readable and computer-executable components or products under a particular condition, such as a license agreement. For example, in an exemplary embodiment, the servers 2402 and 2404 may provide and render an exemplary graphical user interface using the computer-readable and/or computer-executable components and products provided by the clients 2406 and 2408.



FIG. 25 is a flow chart of a method 2500 according to an implementation.


As shown in step 2502, the method 2500 may include providing a strap with a sensor and a heart rate monitoring system. The strap may be shaped and sized to fit about an appendage. For example, the strap may be any of the straps described herein, including, without limitation, a bracelet. The heart rate monitoring system may be configured to provide two or more different modes for detecting a heart rate of a wearer of the strap. The modes may include the use of optical detectors (e.g., light detectors), light emitters, motion sensors, a processing module, algorithms, other sensors, a peak detection technique, a frequency domain technique, variable optical characteristics, non-optical techniques, and so on.


As shown in step 2504, the method 2500 may include detecting a signal from the sensor. The signal may be detected by one or more sensors, which may include any of the sensors described herein. The signal may include, without limitation, one or more signals associated with the heart rate of the user, other physiological signals, an optical signal, signals based on movement, signals based on environmental factors, status signals (e.g., battery life), historical information, and so on.


As shown in step 2506, the method 2500 may include determining a condition of the heart rate monitoring system, which may be based upon the signal. The condition may include, without limitation, an accuracy of heart rate detection determined using a statistical analysis to provide a confidence level in the accuracy, a power consumption, a battery charge level, a user activity, a location of the sensor or motion of the sensor, an environmental or contextual condition (e.g., ambient light conditions), a physiological condition, an active condition, an inactive condition, and so on. This may include detecting a change in the condition, responsively selecting a different one of the two or more different modes, and storing additional continuous heart rate data obtained using at least one of the two or more different modes.


As shown in step 2508, the method 2500 may include selecting one of the two or more different modes for detecting the heart rate based on the condition. For example, based on the motion status of the user, the method may automatically and selectively activate one or more light emitters to determine a heart rate of the user. The system may also or instead determine the type of sensor to use at a given time based on the level of motion, skin temperature, heart rate, and the like. Based on a combination of these factors the system may selectively choose which type of sensor to use in monitoring the heart rate of the user. A processor or the like may be configured to select one of the modes. For example, if the condition is the accuracy of heart rate detection determined using a statistical analysis to provide a confidence level in the accuracy, the processor may be configured to select a different one of the modes when the confidence level is below a predetermined threshold.


As shown in step 2510, the method 2500 may include storing continuous heart rate data using one of the two or more different modes. This may include communicating the continuous heart rate data from the strap to a remote data repository. This may also or instead including storing the data locally, e.g., on a memory included on the strap. The memory may be removable, e.g., via a data card or the like, or the memory may be permanently attached/integral with the strap or a component thereof. The stored data (e.g., heart rate data) may be for the user's private use, for example, when in a private setting, or the data may be shared when in a shared setting (e.g., on a social networking site or the like). The method 2500 may further include the use of a privacy switch operable by the user to controllably restrict communication of a portion of the data, e.g., to the remote data repository.



FIG. 26 is a flow chart of a method 2600 according to an implementation.


As shown in step 2602, the method 2600 may include monitoring data from a wearable system. The wearable system may be a continuous-monitoring, physiological measurement system worn by a user. The data may include heart rate data, other physiological data, summary data, motion data, fitness data, activity data, or any other data described herein or otherwise contemplated by a skilled artisan.


As shown in step 2604, the method 2600 may include detecting exercise activity. This may include automatically detecting exercise activity of the user. The exercise activity may be detected through the use of one or more sensors as described herein. The exercise activity may be sent to a server that, e.g., performs step 2606 described below.


As shown in step 2606, the method 2600 may include generating an assessment of the exercise activity. This may include generating a quantitative assessment of the exercise activity. Generating a quantitative assessment of the exercise activity may include analyzing the exercise activity on a remote server. Generating a quantitative assessment may include the use of the algorithms discussed herein. The method 2600 may also include generating periodic updates to the user concerning the exercise activity. The method 2600 may also include determining a qualitative assessment of the exercise activity and communicating the qualitative assessment to the user.


As shown in step 2608, the method 2600 may include detecting a recovery state. This may include automatically detecting a physical recovery state of the user. The recovery state may be detected through the use of one or more sensors as described herein. The recovery state may be sent to a server that, e.g., performs step 2610 described below.


As shown in step 2610, the method 2600 may include generating an assessment of the recovery state. This may include generating a quantitative assessment of the physical recovery state. Generating a quantitative assessment may include the use of the algorithms discussed herein. Generating a quantitative assessment of the physical recovery state may include analyzing the physical recovery state on a remote server. The method 2600 may also include generating periodic updates to the user concerning the physical recover state. The method 2600 may also include determining a qualitative assessment of the recovery state and communicating the qualitative assessment to the user.


As shown in step 2612, the method 2600 may include analyzing the assessments, i.e., analyzing the quantitative assessment of the exercise activity and the quantitative assessment of the physical recovery. The analysis may include the use of one or more of the algorithms described herein, a statistical analysis, and so on. The analysis may include the use of a remote server.


As shown in step 2614, the method 2600 may include generating a recommendation. This may include automatically generating a recommendation on a change to an exercise routine of the user based on the analysis performed in step 2612. This may also or instead include determining a qualitative assessment of the exercise activity and/or recovery state, and communicating the qualitative assessment(s) to the user. The recommendation may be generated on a remote server. The recommendation may be communicated to the user in an electronic mail, it may be presented to the user in a web page, other communications interface, or the like. Generating the recommendation may be based upon a number of cycles of exercise and rest.


The method 2600 described above, or any of the methods discussed herein, may also or instead be implemented on a computer program product including non-transitory computer executable code embodied in a non-transitory computer-readable medium that executes on one or more computing devices to perform the method steps. For example, code may be provided that performs the various steps of the methods described herein.



FIG. 27 shows a method for heart rate detection using ambient light. The applicant has observed that conventional photoplethysmography hardware such as the various systems described herein may be sufficiently sensitive to detect cardiac activity under certain ambient light conditions even without active illumination. For example, under daylight, or indoors under normal lighting conditions, light intensity varies at the sensor of a photoplethysmography device in a manner that permits capture of a cardiac signal and extraction of heart rate intervals over time. Truly continuous physiological monitoring also contemplates the acquisition of cardiac data in low light conditions or darkness (e.g., when sleeping), and a device may thus be usefully configured to detect ambient light and determine when active illumination is needed for data acquisition.


A method 2700 as contemplated herein may be implemented as a computer program product for operating a wearable system for physiological measurement comprising computer executable code stored in a non-transitory computer readable medium that, when executing on one or more computing devices (such as a physiological monitoring system) performs the method steps described below.


As shown in step 2702, the method 2700 may begin with detecting ambient light. This may generally include detecting ambient light from an ambient light source such as daylight or indoor illumination that is reflected from a skin of a user who is wearing the wearable system. The ambient light may usefully be provided and detected without any need for active illumination of the skin by the wearable system so that a battery or other power supply of the wearable system does not have to provide power to an illumination subsystem.


As shown in step 2704, the method 2700 may include determining whether the ambient light is above a predetermined threshold. This may, for example, include receiving data from a sensor such as an optical detector and determining a magnitude of ambient light incident on the skin, which may be performed as an independent measurement from the underlying peak detection process, i.e., with a separate sensor or at a different time. This may also or instead include measuring ambient light concurrently with the peak detection process, such as by analyzing an intensity of light that is detected during peak detection and determining whether there is sufficient light to rely on ambient light for accurate data acquisition. In another aspect, this step may be performed indirectly, such as by analyzing the quality of peak detection data obtained from light intensity measurements.


As shown in step 2706, the method may include executing a peak detection algorithm to process the data corresponding to the ambient light reflected from the skin to detect a plurality of peaks associated with a plurality of beats of the user's heart. This may for example, include peak detection using any of the techniques described herein.


As shown in step 2707, if the ambient light is above the predetermined threshold, then the process may include performing peak detection with ambient light. In general, the light measurements and data processing for this step may be the same as for a process using active light, except that it is not necessary to drive a supplemental light source when taking measurements from a light sensor.


As shown in step 2708, if the ambient light is below the predetermined threshold, the method 2700 may include performing peak detection with active light when the ambient light is below a predetermined threshold, such as using the techniques more generally described herein. For example, this may include driving one or more light sources in the wearable system positioned to illuminate the skin, e.g., using any of the techniques and light sources described herein. It will be understood that the predetermined threshold may be any suitable quantitative threshold, and will generally depend on the sensitivity and output of sensors being used rather than an absolute intensity or focus of ambient light.


As shown in step 2710, regardless of how individual peaks are detected, the method may optionally include selecting a suitable algorithm for detecting a user's instantaneous heart rate. For example, the system may have multiple techniques for calculating an R-wave-to-R-wave interval (RR interval) such as a peak detection algorithm or a frequency analysis algorithm. While peak detection may be preferred for a variety of reasons such as accuracy or processing efficiency, this may not always yield useful results. Thus the method may include determining an RR interval based on the plurality of peaks detected by the peak detection algorithm, and then determining a confidence level associated with the RR interval. Based on this confidence level, the method 2700 may include selecting the peak detection algorithm or, when confidence is low (e.g., below some predetermined quantitative threshold), selecting an alternative technique such as a frequency analysis algorithm to process data corresponding to the reflected light and to determine the sequence of instantaneous heart rates of the user.


More generally, the method may include determining whether the confidence level associated with the RR interval is above a predetermined threshold or is equal to or below the predetermined threshold, and determining an instantaneous heart rate of the user using the plurality of peaks when the confidence level is above the predetermined threshold, and determining an instantaneous heart rate of the user using the frequency analysis algorithm when the confidence level is equal to or below the predetermined threshold.


Similarly, a motion sensor may be employed, and may be optionally incorporated into the selection or implementation of a particular heart rate detection algorithm.


For example, the method 2700 may include determining a motion of the user based on data from a motion sensor in the wearable system, wherein the frequency analysis algorithm processes the data corresponding to the reflected light based on the motion of the user. The motion sensor may be an accelerometer or any other suitable sensor or sensor system for detection motion of a user.


As shown in step 2712, the method 2700 may include calculating a sequence of instantaneous heart rates of the user based on the plurality of peaks. As noted above, a variety of techniques are available for performing this calculation, and the selection of a particular technique may depend in part on the quality and quantity of available data.


As shown in step 2714, the method may include calculating a heart rate variability of the user based on the sequence of instantaneous heart rates determined in step 2712.


As shown in step 2716, the method 2700 may include storing or displaying results. For example, the method may include presenting a visual display of the heart rate variability in a user interface of the wearable system, or presenting a visual display of the sequence of instantaneous heart rates or any other useful data in a user interface of the wearable system. In addition, the sequence of instantaneous heart rates may be stored in a storage device such as memory of the wearable system or volatile or nonvolatile memory coupled in a communicating relationship with the wearable system.


VII. EQUIVALENTS

It is to be appreciated that embodiments of the systems, apparatuses and methods discussed herein are not limited in application to the details of construction and the arrangement of components set forth in the following description or illustrated in the accompanying drawings. Exemplary systems, apparatuses and methods are capable of implementation in other embodiments and of being practiced or of being carried out in various ways. Examples of specific implementations are provided herein for illustrative purposes only and are not intended to be limiting. In particular, acts, elements and features discussed in connection with any one or more embodiments are not intended to be excluded from a similar role in any other embodiments. One or more aspects and embodiments disclosed herein may be implemented on one or more computer systems coupled by a network (e.g., the Internet).


The phraseology and terminology used herein are for the purpose of description and should not be regarded as limiting. Any references to embodiments or elements or acts of the systems and methods herein referred to in the singular may also embrace embodiments including a plurality of these elements, and any references in plural to any embodiment or element or act herein may also embrace embodiments including only a single element. The use herein of terms like “including,” “comprising,” “having,” “containing,” “involving,” and variations thereof, is meant to encompass the items listed thereafter and equivalents thereof as well as additional items. Any references front and back, left and right, top and bottom, upper and lower, and vertical and horizontal, are intended for convenience of description, not to limit the present systems and methods or their components to any one positional or spatial orientation.


In describing exemplary embodiments, specific terminology is used for the sake of clarity. For purposes of description, each specific term is intended to, at least, include all technical and functional equivalents that operate in a similar manner to accomplish a similar purpose. Additionally, in some instances where a particular exemplary embodiment includes a plurality of system elements or method steps, those elements or steps may be replaced with a single element or step. Likewise, a single element or step may be replaced with a plurality of elements or steps that serve the same purpose. Further, where parameters for various properties are specified herein for exemplary embodiments, those parameters may be adjusted up or down by 1/20th, 1/10th, ⅕th, ⅓rd, ½nd, and the like, or by rounded-off approximations thereof, unless otherwise specified. Moreover, while exemplary embodiments have been shown and described with references to particular embodiments thereof, those of ordinary skill in the art will understand that various substitutions and alterations in form and details may be made therein without departing from the scope of the disclosure. Further still, other aspects, functions and advantages are also within the scope of the disclosure.


Embodiments disclosed herein may be combined with other embodiments disclosed herein in any manner consistent with at least one of the principles disclosed herein, and references to “an embodiment,” “one embodiment,” “an exemplary embodiment,” “some embodiments,” “some exemplary embodiments,” “an alternate embodiment,” “various embodiments,” “exemplary embodiments,” and the like, are not necessarily mutually exclusive and are intended to indicate that a particular feature, structure, characteristic or functionality described may be included in at least one embodiment. The appearances of such terms herein are not necessarily all referring to the same embodiment.


Exemplary flowcharts are provided herein for illustrative purposes and are non-limiting examples of methods. One of ordinary skill in the art will recognize that exemplary methods may include more or fewer steps than those illustrated in the exemplary flowcharts, and that the steps in the exemplary flowcharts may be performed in a different order than the order shown in the illustrative flowcharts.


The above systems, devices, methods, processes, and the like may be realized in hardware, software, or any combination of these suitable for the control, data acquisition, and data processing described herein. This includes realization in one or more microprocessors, microcontrollers, embedded microcontrollers, programmable digital signal processors or other programmable devices or processing circuitry, along with internal and/or external memory. This may also, or instead, include one or more application specific integrated circuits, programmable gate arrays, programmable array logic components, or any other device or devices that may be configured to process electronic signals. It will further be appreciated that a realization of the processes or devices described above may include computer-executable code created using a structured programming language such as C, an object oriented programming language such as C++, or any other high-level or low-level programming language (including assembly languages, hardware description languages, and database programming languages and technologies) that may be stored, compiled or interpreted to run on one of the above devices, as well as heterogeneous combinations of processors, processor architectures, or combinations of different hardware and software.


Thus, in one aspect, each method described above and combinations thereof may be embodied in computer executable code that, when executing on one or more computing devices, performs the steps thereof. In another aspect, the methods may be embodied in systems that perform the steps thereof, and may be distributed across devices in a number of ways, or all of the functionality may be integrated into a dedicated, standalone device or other hardware. The code may be stored in a non-transitory fashion in a computer memory, which may be a memory from which the program executes (such as random access memory associated with a processor), or a storage device such as a disk drive, flash memory or any other optical, electromagnetic, magnetic, infrared or other device or combination of devices. In another aspect, any of the systems and methods described above may be embodied in any suitable transmission or propagation medium carrying computer-executable code and/or any inputs or outputs from same. In another aspect, means for performing the steps associated with the processes described above may include any of the hardware and/or software described above. All such permutations and combinations are intended to fall within the scope of the present disclosure.


It should further be appreciated that the methods above are provided by way of example. Absent an explicit indication to the contrary, the disclosed steps may be modified, supplemented, omitted, and/or re-ordered without departing from the scope of this disclosure.


The method steps of the invention(s) described herein are intended to include any suitable method of causing such method steps to be performed, consistent with the patentability of the following claims, unless a different meaning is expressly provided or otherwise clear from the context. So for example performing the step of X includes any suitable method for causing another party such as a remote user, a remote processing resource (e.g., a server or cloud computer) or a machine to perform the step of X. Similarly, performing steps X, Y and Z may include any method of directing or controlling any combination of such other individuals or resources to perform steps X, Y and Z to obtain the benefit of such steps. Thus method steps of the implementations described herein are intended to include any suitable method of causing one or more other parties or entities to perform the steps, consistent with the patentability of the following claims, unless a different meaning is expressly provided or otherwise clear from the context. Such parties or entities need not be under the direction or control of any other party or entity, and need not be located within a particular jurisdiction.


It will be appreciated that the methods and systems described above are set forth by way of example and not of limitation. Numerous variations, additions, omissions, and other modifications will be apparent to one of ordinary skill in the art. In addition, the order or presentation of method steps in the description and drawings above is not intended to require this order of performing the recited steps unless a particular order is expressly required or otherwise clear from the context. Thus, while particular embodiments have been shown and described, it will be apparent to those skilled in the art that various changes and modifications in form and details may be made therein without departing from the spirit and scope of this disclosure and are intended to form a part of the invention as defined by the following claims, which are to be interpreted in the broadest sense allowable by law.

Claims
  • 1. A wearable system for physiological measurement comprising: a wearable strap configured to be coupled to an appendage of a user, the wearable strap comprising:one or more light detectors positioned to receive ambient light from an ambient light source reflected from a skin of a user; andan electronic circuit board comprising a processing module configured to determine a heart rate of the user by: executing one or more computer-executable instructions associated with a peak detection algorithm to process the data corresponding to the ambient light reflected from the skin to detect a plurality of peaks associated with a plurality of beats of the user's heart, calculating a sequence of instantaneous heart rates of the user based on the plurality of peaks, and calculating a heart rate variability of the user based on the sequence of instantaneous heart rates.
  • 2. The wearable system of claim 1 wherein the processing module is further configured to select an algorithm for calculating the instantaneous heart rates by: determining an R-wave-to-R-wave interval (RR interval) based on the plurality of peaks detected by the peak detection algorithm; determining a confidence level associated with the RR interval; andbased on the confidence level associated with the RR interval, selecting either the peak detection algorithm or a frequency analysis algorithm to process data corresponding to the reflected light to determine the sequence of instantaneous heart rates of the user.
  • 3. The wearable system of claim 2 further comprising a motion sensor, wherein the frequency analysis algorithm processes the data corresponding to the reflected light based on the motion of the user.
  • 4. The wearable system of claim 3 wherein the motion sensor is an accelerometer.
  • 5. The computer wearable system of claim 2 wherein the processing module is further configured to perform the steps of determining whether the confidence level associated with the RR interval is above a predetermined threshold or is equal to or below the predetermined threshold, and determining an instantaneous heart rate of the user using the plurality of peaks when the confidence level is above the predetermined threshold, and determining an instantaneous heart rate of the user using the frequency analysis algorithm when the confidence level is equal to or below the predetermined threshold.
  • 6. The wearable system of claim 1 further comprising a sensor for detecting a magnitude of ambient light incident on the skin.
  • 7. The wearable system of claim 6 further comprising one or more light sources positioned to illuminate the skin, wherein the processing module is configured to activate the one or more light sources when the magnitude of ambient light falls below a predetermined threshold.
  • 8. The wearable system of claim 1 further comprising a visual display device, wherein the processing module is further configured to display the heart rate variability of the user on the visual display device.
  • 9. The wearable system of claim 1 further comprising a visual display device, wherein the processing module is further configured to display the sequence of instantaneous heart rates of the user on the visual display device.
  • 10. The wearable system of claim 1, further comprising a storage device configured to store the sequence of instantaneous heart rates.
  • 11. A computer program product for operating a wearable system for physiological measurement, the computer program product comprising computer executable code embodied in a non-transitory computer readable medium that, when executing on one or more computing devices, performs the steps of: detecting ambient light from an ambient light source reflected from a skin of a user wearing the wearable system without active illumination of the skin by the wearable system;executing a peak detection algorithm to process the data corresponding to the ambient light reflected from the skin to detect a plurality of peaks associated with a plurality of beats of the user's heart;calculating a sequence of instantaneous heart rates of the user based on the plurality of peaks; andcalculating a heart rate variability of the user based on the sequence of instantaneous heart rates.
  • 12. The computer program product of claim 11 further comprising code that performs the steps of: determining an R-wave-to-R-wave interval (RR interval) based on the plurality of peaks detected by the peak detection algorithm;determining a confidence level associated with the RR interval; andbased on the confidence level associated with the RR interval, selecting either the peak detection algorithm or a frequency analysis algorithm to process data corresponding to the reflected light to determine the sequence of instantaneous heart rates of the user.
  • 13. The computer program product of claim 12 further comprising code that performs the step of determining a motion of the user based on data from a motion sensor in the wearable system, wherein the frequency analysis algorithm processes the data corresponding to the reflected light based on the motion of the user.
  • 14. The computer program product of claim 13 wherein the motion sensor is an accelerometer.
  • 15. The computer program product of claim 12 further comprising code that performs the steps of determining whether the confidence level associated with the RR interval is above a predetermined threshold or is equal to or below the predetermined threshold, and determining an instantaneous heart rate of the user using the plurality of peaks when the confidence level is above the predetermined threshold, and determining an instantaneous heart rate of the user using the frequency analysis algorithm when the confidence level is equal to or below the predetermined threshold.
  • 16. The computer program product of claim 11 further comprising code that performs a step of receiving data from a sensor and determining a magnitude of ambient light incident on the skin.
  • 17. The computer program product of claim 16 further comprising code that performs the step of driving one or more light sources in the wearable system positioned to illuminate the skin when the magnitude of ambient light falls below a predetermined threshold.
  • 18. The computer program product of claim 11 further comprising code that performs the step of presenting a visual display of the heart rate variability in a user interface of the wearable system.
  • 19. The computer program product of claim 11 further comprising code that performs the step of presenting a visual display of the sequence of instantaneous heart rates in a user interface of the wearable system.
  • 20. The computer program product of claim 11, further comprising code that performs the step of storing the sequence of instantaneous heart rates in a storage device.