The present invention generally relates to wearable technology, and more specifically to the use of location and environmental inputs to calculate health parameters.
Wearable technology is a new class of electronic systems that can provide data acquisition through a variety of unobtrusive sensors that may be worn by a user. The sensors gather information, for example, about the environment, the user's activity, or the user's health status. However, there are significant challenges related to the coordination, computation, communication, privacy, security, and presentation of the collected data. Additionally, there are challenges related to power management given the current state of battery technology. Furthermore, analysis of the data is needed to make the data gathered by the sensors useful and relevant to end-users. In some cases, additional sources of information may be used to supplement the data gathered by the sensors. The many challenges that wearable technology presents require new designs in hardware and software.
Typical wearable devices calculate various health parameters, such as calorie expenditure, hydration, and distance traveled. Further, these devices also in various occasions calculate health parameters based on the activity performed, e.g., walking, cycling, and swimming. Though these devices have many of these possibilities for the user, there is still room for improvement.
A first aspect of the present invention includes a method for health calculations. Such methods may include receiving a health input from a wearable device worn by a user where such health input includes one or more measurements from one or more health sensors, calculating a health parameter based on the health input, obtaining location-based information associated with the wearable device, and modifying the calculated health parameter based on the location-based information.
Revising a calculated health parameter utilizing location-based information offers several advantages, including but not limited to, the calculation of a more accurate health parameter, the elimination of environmental-induced inaccuracies from the calculation, and improved decisions utilizing the revised parameters. For instance, if the person is running uphill, which essentially means that he has to put more effort to complete the run, overall energy expenditure must be accordingly adjusted.
In further embodiment, the method includes transmitting a location of the wearable device to a network server.
In further embodiment, the method includes receiving location-based information associated with a location of the wearable device from the network server.
In further embodiment, the method includes storing the modified health parameter in a memory of the wearable device.
In further embodiment, the method includes classifying the health input into an activity based on the location-based information and modifying the calculated health parameter based on the classification of the health input. This is in particular advantageous as calculation of health parameters depend on the type of detected activity. For instance, cycling, running, walking, each has a different calculation of calorie expenditure. In the current embodiment of the present invention, it offers several advantages concerning health calculations, including the interpretation of movement data to more accurately categorize activities and utilize that categorization to more accurately determine health related parameters of a user. These embodiments may utilize physiological, environmental, and geolocational data to improve categorizations and eliminate false positives.
In further embodiment, the location-based information may include environmental information. The environmental information may include at least one of location, outdoor humidity, outdoor temperature, outdoor ultraviolet radiation, outdoor pollen density, outdoor wind direction, outdoor wind velocity, outdoor terrain roughness, outdoor road condition, outdoor trail condition, current season, indoor temperature, indoor humidity, gym equipment resistance, gym equipment difficulty level, and environmental stress level.
In further embodiment, the method includes receiving an environmental input from the wearable device and modifying the calculated health parameter based on the environmental input. The environmental input may include one or more measurements from one or more environmental sensors concerning an ambient environmental value.
In further embodiment, the method includes generating an alert to notify the user of the wearable device about a recommendation. The alert may be at least one of displaying a text notification, displaying a graphical notification, displaying a video notification, playing an audio notification, and initiating a vibration notification. In a further embodiment of the invention, the recommendation is based on the modified health parameter. For instance, if the person is running uphill in a sunny day, then the recommendation can be based on the calculated health parameter.
In further embodiment, the method includes generating an alert based on the modified health parameter.
In further embodiment, the location-based information corresponding to the location of the wearable device is an average of a plurality of location-based data points stored at the network server corresponding to a predetermined radius of the location of the wearable device.
In further embodiment, the method includes transmitting an algorithm used to modify the calculated health parameter based on the location-based information from the network server memory to a second wearable device.
In further embodiment, modifying the calculated health parameter includes modifying the calculated health parameter using rules that are specific to the type of health parameter.
In further embodiment, the one or more health sensors may measure at least one of a blood oxygen level, a hydration level, a blood pressure, a blood sugar level, a blood glucose level, an insulin level, a body temperature, a heart rate, a weight, a sleep quality, a number of steps, a velocity of movement, an acceleration of movement, a vitamin level, a respiratory rate, a heart sound, a breathing sound, a skin moisture, a sweat level, a sweat composition, and a nerve firing.
A second aspect of the present invention includes a system for personalized health calculations with location-improved accuracy. Such systems may include a wearable device and a network server. The wearable device may include one or more health sensors that provides one or more measurements regarding a health input, a communication interface that communicates over a wireless communication network to transmit a location of the wearable device to the network server and to receive location-based information from the network server where the location-based information corresponding to the location of the wearable device, a processor that executes instructions to modify the health input based on the location-based information, and memory that stores the modified health input.
According to a third aspect of the invention, a computer program product including the computer implemented method as described above is provided. There are provided a computer program which comprises program code means for causing a computer to perform the steps of the method disclosed herein when said computer program is carried out on a computer as well as a non-transitory computer-readable recording medium that stores therein a computer program product, which, when executed by a processor, causes the method disclosed herein to be performed.
Preferred embodiments of the disclosure are defined in the dependent claims. It should be understood that the claimed system and the claimed non-transitory computer readable storage medium can have similar preferred embodiments and the corresponding advantages as the claimed method and as defined in the dependent method claims.
The foregoing and other features and advantages of the present invention will be made more apparent from the descriptions, drawings, and claims that follow. One of ordinary skill in the art, based on this disclosure, would understand that other aspects and advantages of the present invention exist.
Examples of currently available wearable devices include the Apple Watch, FitBit, Jawbone Up, and the Garmin Forerunner. Within the exemplary wearable device 120, a number of elements are included which are all connected to a central bus 146. The elements include: a clock 134, one or more body sensors (1-N) 130, an optional graphical user interface (GUI) 138, a wired and/or wireless communication port 126 (e.g., a USB port module, a FireWire port module, a Lightning port module, a Thunderbolt port module, a Wi-Fi connection module, a 3G/4G/LTE cellular connection module, a Bluetooth connection module, a Bluetooth low energy connection module, a Bluetooth Smart connection module, a near field communication module, and a radio wave communications module), a processor 122, a power supply 124 (e.g., a rechargeable or non-rechargeable battery), a base software 136, a location accuracy software 142, a history database 140, a memory 128, a conversion database 144, and a global positioning system (GPS) module 132.
The clock 134 can be a system clock which is used to record both time and also time elapsed (e.g., stopwatch). A communication device (e.g., communication port 126) may be used together with or in place of the clock 134 to obtain accurate time from an outside source (e.g., cellular phone tower, NTP server, etc.).
The one or more body sensors 130 can be used to provide any number of health inputs associated with the user (e.g., blood oxygen level, hydration, blood pressure, blood sugar, blood glucose, insulin, body temperature (e.g., thermometer), heart rate, weight, sleep, number of steps (e.g., pedometer), velocity or acceleration (e.g., accelerometer), vitamin levels, respiratory rate, heart sound (e.g., microphone), breathing sound (e.g., microphone), movement speed, skin moisture, sweat detection, sweat composition, nerve firings (e.g., electromagnetic sensor), or similar health measurements). The body sensors 130 could also be used for other measurements (e.g., steps taken) which in turn could be used to calculate related health parameters (e.g., distance traveled, calories burned).
The GUI 138 can facilitate the user in creating settings and viewing data (e.g., amount of calories burned) on a display of the wearable device 120 (e.g., viewer 220 illustrated in
The communication module 126 may be used by the wearable device 120 to communicate with other devices and networks over a network. The communication module may be wireless, cellular, near field communication (NFC), Bluetooth, etc.
The base software 136, which can be seen in
The location accuracy software 142, as provided for the wearable device 120 in
The history database 140 is a storage for sensor data. The location accuracy software 142 may retrieve sensor data from the history database 140 to produce a modified or “converted” health parameter that takes into account geolocation data (e.g., weather data).
The conversion database 144 may contain pre-determined algorithmic conversion data that can be used to calculate the modified or “converted” health parameter that takes into account both data from body sensors 130 and geolocation data (e.g., weather, terrain) (see e.g., step 800 of
The GPS module 132 is used to determine a user's exact geolocation (e.g., the location of the wearable device) for the wearable device 120 to use and/or to provide to sources of external data (e.g., from data networks 160, 170, 180, 190 from
It should be noted that the wearable device 120 can, in some embodiments, communicate over a network 100 (e.g., connection 102) as well as directly with a user device 150 (e.g., connection 104) (e.g., via a wire, a Bluetooth connection, or a Wi-Fi direct connection). The user device 150 can be a smart phone, a tablet, a desktop computer, a laptop computer, a gaming console, a smart television, a home entertainment system, a second wearable device, or any other device the user may use to interact with the wearable device 120. The user device 150 itself includes a communication port 152 (e.g., a USB port module, a FireWire port module, a Lightning port module, a Thunderbolt port module, a Wi-Fi connection module, a 3G/4G/LTE cellular connection module, a Bluetooth connection module, a Bluetooth low energy connection module, a Bluetooth Smart connection module, a near field communication module, a radio wave communications module, etc.).
The user device 150 can also include a GUI 156, especially in situations where the wearable device 120 does not have its own GUI 138. The user device 150 also executes a location accuracy software 154. The software facilitates the user device 150 to run corresponding location accuracy algorithms on the user device 150 instead of on the wearable device 120 and can be seen as being similar to the location accuracy software 142 included in the wearable device 120.
Similarly to the wearable device 120, the user device 150 may also be connected to the network 100 (e.g., connection 106), and through this connection, is connected to the plurality of data networks (e.g., data networks 160, 170, 180, and 190 from
Because data networks (e.g., data networks 160, 170, 180, and 190) might not contain location-specific data for every possible location that a wearable device 120 might go, in such situations, a data network (e.g., data networks 160, 170, 180, and 190) may provide the data corresponding to the nearest geolocation, or an average of the nearest geolocations within a predetermined radius around the requesting location.
As an example embodiment, this system can be used to provide a more accurate calculation of the amount of calories burned during a run. Generally, the user wears or has on his body the wearable device 120. The one or more body sensors 130 obtain health input data about the user (e.g. pulse, breathing rate). Each sensor measurement of the health input data has an associated clock time stamp. The base software 136 calculates an initial amount of calories burned for that run using the health input data, the time stamp, the distance run, etc. Using the GPS module 132, the wearable device 120 can identify where the user is during the run. By using the communication system, the wearable device can access one or more networks (e.g., data networks 160, 170, 180, and 190 from
In some embodiments, the wearable device 120 may itself contain location-specific data which may be used to adjust the calculated health parameter as disclosed herein. For example, the wearable device 120 may contain downloaded maps, terrain information, weather forecasts, etc.
The embodiment of the wearable device 120 that is pictured in
The optional user device 150 may include the components and software elements of the user device 150 embodiment of
The health network 270 server may include a health database 272, a health software 274, and an application program interface (API) 276. The API 276 in the health network 270 may communicate with a set of third parties 280. Third parties may be doctors 282, online medical/health references like WebMD 284, users 286, and other third parties 288 such as caregivers or advertisers.
Regarding the data networks of
A GPS location from GPS module 132 may be used to identify the location of a user of a wearable device 120 (e.g., the location of the wearable device), where the location may be used by the health network 270 when preparing health recommendations to transmit to the wearable device 120. The optional user device 150 may be used as a proxy for the wearable device 120. When this occurs, the user device 150 may receive information from the wearable device 120, and the user device 150 may communicate over a network 100 with the health network 270, with the interior data network 160, with the geolocation data network 170, with the geolocation terrain data network 180, or with other networks 190. The user device 150 may also display recommendations received from the health network 270 or calculations from the networks of
One advantage of a user device 150 acting as a proxy for the wearable device 120 is that communications may be generally faster and/or more efficient, since a user device 150 may often have greater processing and communication capabilities than a typical wearable device 120. For example, wearable device 120 may not be capable of communicating over a cellular network (e.g., the wearable devices 120 may be limited to wired and/or Bluetooth communications), while a user device 150 can typically communicate over both a cellular network (e.g., an Edge, 3G, 4G, or “LTE” Long-Term-Evolution network) and Wi-Fi/Bluetooth networks. Another advantage of the user device 150 acting as a proxy for the wearable device 120 may be an improvement to the overall battery life of the wearable device 120.
In some embodiments, the wearable device 120 may itself contain location-specific data which may be used to adjust the calculated health parameter as disclosed herein. For example, the wearable device 120 may contain downloaded maps, terrain information, weather forecasts, etc.
Crosses identified in the table are identified by circles where horizontal and vertical lines intersect in the table. A first cross indicates that blood pressure 305 may be affected by temperature and barometric pressure 345. A second cross indicates that the seasons 350 may affect the mood 310 of a person, and a third cross indicates that asthma risk levels 355 may be exacerbated by a high body temperature 315. Other crosses indicate that dryness 320 and high pollen levels 360 may increase allergy symptoms, that temperature and barometric pressure 345 may affect blood sugar level 325, and that outdoor temperature 365 may affect the number of calories burned over time 330 (e.g., running in heat may cause faster calorie burn).
Crosses identified in this exemplary table may be used in some embodiments to provide recommendations to the user (e.g., “avoid running today—dangerously high pollen counts!”) and can be used to modify health parameter calculations. For example, the location accuracy software 142 of the wearable device 120 (or the location accuracy software 154 of the user device 150) may increase a calculated calorie count based on the user exercising in high temperature (see, e.g., calories 330 affected by temperature 365).
With the inputted health sensor data (see step 400), the base software 136 then calculates a value for a health parameter (e.g., distance run, calories burned) (step 410). These health parameter values are stored in a history file or history database 140 and 256 with the corresponding GPS location obtained in step 405 (step 415).
The base software 136, in combination with the location accuracy software 142, then communicates with one or more of the data networks pictured in
Determination if a link to a data network is available is performed (step 435). If a link to a data network is not possible at this time, the wearable device 120 displays the initial health parameter calculated by the base algorithm of the base software 136 (step 440). However, if a link to an external network is possible, then location-specific data (e.g., weather data, environmental inputs) is downloaded (step 445). Once downloaded, the location-specific data may be used by the location accuracy software 142 to modify (or “convert”) the initial parameter calculation of step 410 (e.g., provide a more accurate “calories burned” value based on weather conditions) (step 450). The location accuracy software 142 may also modify (or “convert”) initial calculations (see step 410) from historical sensor measurements from the body sensors 130 (e.g., stored in history database 140 of the wearable device 120 or history database 256 of the user device 150) (step 450). The location accuracy software 142 may then output the modified (or “converted”) parameter value in lieu of or in addition to the “raw” parameter value calculated in step 410 (step 455). In some embodiments, the output of step 455 is displayed at the wearable device 120 (e.g., at viewer 220) or at the user device 150 (e.g., using GUI 156). In some embodiments, the output of step 455 is stored in the history database 140/256 or to a data network (e.g., to health database 272 of health network 270). In some embodiments, the output of step 455 is also stored in the history database 140 or 256. Appropriate information from the conversion database is also used in order to facilitate the modifications by the location accuracy calculations. Afterwards, the new modified health parameter is provided to the user to view.
At this time, both sets of data (e.g., the location-specific data from the data networks from step 520 and the output from the health parameter calculation algorithm from step 510) are combined and the health parameter algorithm is modified based on the location-specific data (step 525). By using the modified health parameter algorithm, a health parameter is then calculated (step 530) and output to the wearable device 120 (e.g. to history database 140), to user device 150 (e.g., to history database 256), or to a data network (e.g., to health database 272 of health network 270) (step 535).
In some embodiments, the health network 270 may also serve to share geolocation-based adjustments, conversion algorithms of sensor measurements, and/or health parameter calculations among wearable devices 120. That is, portions of a conversion database 144 of one wearable device 120 may be shared with other (e.g., less capable) wearable devices 120. If geolocation-based adjustment or “conversion” algorithms vary between different devices, an algorithm producing an average result between those variances could be used and given to other (e.g., less capable) wearable devices.
Similarly, other data could be “crowdsourced.” For example, wearable devices could share data from their weather sensors 230 with data networks 160, 170, 180, and 190, which could then be averaged, thus producing or contributing to the data sets of data networks 160, 170, 180, and 190.
To more accurately categorize the movement data, the base software 136 includes a segmentation module 133 and a categorization module 135. The segmentation module 133 is configured to analyze and identify movement data within temporal ranges that have similar characteristics, for example, having similar amplitudes and/or frequencies. The categorization module 136 may categorize each segment as matching one or more active or passive activities such as walking, running, swimming, flying in an airplane, riding in a car, riding on a train, jogging, riding in an airplane, etc.
The categorization may be performed using a variety of techniques, including but not limited to matching segments against stored segments previously associated with a particular activity; comparing a segment against other recorded segments; comparing the parameters characterizing one or more segments against rules associating various parameters ranges with various activities; asking the user to manually identify the activity (and thereby creating a stored segment or a rule for future use), etc.
Exemplary embodiments of the base software 136 may use additional sensor data to further refine these categorizations, including but not limited to eliminating false positives or more accurately characterizing the nature of the movement detected in the captured movement data. These refinements can take a variety of forms, depending on the particular sensors available. Once categorized, the nature of the activity and its duration can be evaluated for its effect on the user's daily activity level and/or health.
One exemplary embodiment of the base software 136 utilizes location specific data to refine the categorization of the segmented movement data. For example, if the location specific data indicates that the movement occurred in a body of water and the speed of the user was approximately 5 miles per hour, then an initial categorization of walking may be refined as swimming. This characterization may be further confirmed by, for example, a temperature sensor indicating that the temperature of the mobile device is significantly cooler than that a networked-accessible source of weather data may indicate; a cardiometer indicating that the user's heart rate is higher than normal, etc.
In another example, an initial categorization of “walking” may be confirmed if the user's velocity is consistent with walking, for example, 4 mph or less. The categorization may be further refined by, for example, querying a source of terrain data for terrain information relevant to the user's positional location. A certain latitude/longitude combination may indicate that the user is in a gym, on a highway, in a river, etc. If the user is located on a highway, then the activity may be reclassified away from “walking” to “driving.” If the user's personal calendar indicates that the user is taking a train, and the accelerometer data is consistent with walking, the activity may be confirmed as “walking.”
This characterization may be further confirmed by, for example, a temperature sensor indicating that the temperature of the mobile device is significantly cooler than that a networked-accessible source of weather data may indicate; a cardiometer indicating that the user's heart rate is higher than normal, etc.
If the GPS unit instead indicates that the user is moving at, for example, 5+ mph in a consistent direction, while the user is in a body of water then the device may characterize the user's activity as sailing or boating. If the GPS unit instead indicates that the user is moving at, for example, 5+ mph in a varying direction, while the user is in a body of water then the device may characterize the user's activity as running (for example, on the deck of a cruise ship or around the edge of a powerboat). These characterizations could be further confirmed with the use of, for example, a temperature sensor indicating that the mobile device is at a temperature close to that of the ambient temperature indicated by a source of network-accessible weather data, a temperature sensor indicating that the ambient temperature is sub-freezing, access to the user's personal data indicating that the user is taking a cruise, etc. Swimming and running may be counted in the computation of health parameters, while sailing would not.
Similarly, if a source of network-accessible location data indicates, for example, that the user is in a gymnasium; a GPS sensor indicates that the user is stationary; but the device accelerometer indicates that the user is moving, then the mobile device may conclude that the user is utilizing a piece of exercise equipment and characterize the activity as walking or exercise depending on the characteristics of the movement measured by the accelerometer.
If a source of network indicates, for example, that the user is on a highway, the GPS unit indicates that the user is moving at 50 mph, and the accelerometer indicates the user is moving, then the mobile device may conclude that the user is driving a vehicle and may disregard the user's activity for, for example, determining whether the user has met a goal of a certain amount of physical exercise or the computation of a health parameter.
Some movements can have a similar frequency and/or speed as walking, but are more (or less) intense for the body, resulting in a higher (lower) heart rate and breathing rate, so other embodiments may utilize other health inputs (e.g., heart rate, breathing rate, and skin temperature) and environmental inputs (outdoor temperature, wind speed, etc.) in a similar fashion to characterize or assess the user's activity or improve the calculation of a health parameter (e.g. calories consumed).
The segmentation module 133 segments the movement data based on data characteristics, such as amplitude and frequency of the movement data (step 710). The movement data may be segmented into discrete blocks based on timing information received by the base software 136 and associated with the movement data. Once the data is segmented, each segment is then categorized as an activity (Step 720). Next, the base software 136, in operation with additional body sensors 130, the location accuracy software 142 and the GPS 132, refines the categorization based on location specific data received from the data networks 160, 170, 180, and 190 (Step 730).
In some cases movement may reflect a hybrid scenario, for example, a user jogging around the deck of a cruise ship, a user performing isometric exercises while in a private room on a train or plane, etc. In these cases, data from a variety of sensors, including but not limited to the GPS, a terrain sensor (e.g., GPS position data used in tandem with a terrain/maps database), a thermometer, etc., may be used to determine whether the captured movement relates to a hybrid scenario and the data may be used to further refine the categorization and for the determination of various health parameters related to the user's activities.
In yet other cases, the measured movement may reflect a false positive scenario, where the user is performing an activity with, for example, an amplitude or frequency profile that matches that of another activity. For example, the user tapping his foot out of boredom may generate an accelerometer signal that resembles the accelerometer signal generated when the user is walking. Something similar may occur if a user “drums” their fingers on a surface. Another false positive may occur when a user is a passenger is a vehicle traversing bumpy terrain. Accordingly, the refinement of the categorization using the location data may be used to eliminate certain segments from being considered for the determination of various health parameters related to the user's activity.
After the movement data has been refined it is then output for health related analysis including the calculation of health parameters related to the user's activities (step 740). The wearable device 120 may display parameters and information about the activities via screen or display (digital or analog). The refined movement data and/or health related parameters may be stored in a history database (e.g., history database 140), transmitted to a public database, or transmitted to a user's account “on the cloud” that can be accessed by the user using a computer, mobile device, or other device that can connect to the user's account.
Processors 904 as illustrated in
Other sensors could be coupled to peripherals interface 906, such as a temperature sensor, a biometric sensor, or other sensing device to facilitate corresponding functionalities. Location processor 915 (e.g., a global positioning transceiver) can be coupled to peripherals interface 906 to allow for generation of geo-location data thereby facilitating geo-positioning. An electronic magnetometer 916 such as an integrated circuit could be connected to peripherals interface 906 to provide data related to the direction of true magnetic North whereby the mobile device could enjoy compass or directional functionality. Camera subsystem 920 and an optical sensor 922 such as a charged coupled device (CCD) or a complementary metal-oxide semiconductor (CMOS) optical sensor can facilitate camera functions such as recording photographs and video clips.
Communication functionality can be facilitated through one or more communication subsystems 924, which may include one or more wireless communication subsystems. Wireless communication subsystems 924 can include 802.x or Bluetooth transceivers as well as optical transceivers such as infrared. Wired communication subsystems can include a port device such as a Universal Serial Bus (USB) port or some other wired port connection that can be used to establish a wired coupling to other computing devices such as network access devices, personal computers, printers, displays, or other processing devices capable of receiving or transmitting data. The specific design and implementation of communication subsystem 924 may depend on the communication network or medium over which the device is intended to operate. For example, a device may include wireless communication subsystem designed to operate over a global system for mobile communications (GSM) network, a GPRS network, an enhanced data GSM environment (EDGE) network, 802.x communication networks, code division multiple access (CDMA) networks, or Bluetooth networks. Communication subsystem 924 may include hosting protocols such that the device may be configured as a base station for other wireless devices. Communication subsystems can also allow the device to synchronize with a host device using one or more protocols such as TCP/IP, HTTP, or UDP.
Audio subsystem 926 can be coupled to a speaker 928 and one or more microphones 930 to facilitate voice-enabled functions. These functions might include voice recognition, voice replication, or digital recording. Audio subsystem 926 in conjunction may also encompass traditional telephony functions.
I/O subsystem 940 may include touch controller 942 and/or other input controller(s) 944. Touch controller 942 can be coupled to a touch surface 946. Touch surface 946 and touch controller 942 may detect contact and movement or break thereof using any of a number of touch sensitivity technologies, including but not limited to capacitive, resistive, infrared, or surface acoustic wave technologies. Other proximity sensor arrays or elements for determining one or more points of contact with touch surface 946 may likewise be utilized. In one implementation, touch surface 946 can display virtual or soft buttons and a virtual keyboard, which can be used as an input/output device by the user.
Other input controllers 944 can be coupled to other input/control devices 948 such as one or more buttons, rocker switches, thumb-wheels, infrared ports, USB ports, and/or a pointer device such as a stylus. The one or more buttons (not shown) can include an up/down button for volume control of speaker 928 and/or microphone 930. In some implementations, device 900 can include the functionality of an audio and/or video playback or recording device and may include a pin connector for tethering to other devices.
Memory interface 902 can be coupled to memory 950. Memory 950 can include high-speed random access memory or non-volatile memory such as magnetic disk storage devices, optical storage devices, or flash memory. Memory 950 can store operating system 952, such as Darwin, RTXC, LINUX, UNIX, OS X, ANDROID, WINDOWS, or an embedded operating system such as VxWorks. Operating system 952 may include instructions for handling basic system services and for performing hardware dependent tasks. In some implementations, operating system 952 can include a kernel.
Memory 950 may also store communication instructions 954 to facilitate communicating with other mobile computing devices or servers. Communication instructions 954 can also be used to select an operational mode or communication medium for use by the device based on a geographic location, which could be obtained by the GPS/Navigation instructions 968. Memory 950 may include graphical user interface instructions 956 to facilitate graphic user interface processing such as the generation of an interface; sensor processing instructions 958 to facilitate sensor-related processing and functions; phone instructions 960 to facilitate phone-related processes and functions; electronic messaging instructions 962 to facilitate electronic-messaging related processes and functions; web browsing instructions 964 to facilitate web browsing-related processes and functions; media processing instructions 966 to facilitate media processing-related processes and functions; GPS/Navigation instructions 968 to facilitate GPS and navigation-related processes, camera instructions 970 to facilitate camera-related processes and functions; and instructions 972 for any other application that may be operating on or in conjunction with the mobile computing device. Memory 950 may also store other software instructions for facilitating other processes, features and applications, such as applications related to navigation, social networking, location-based services or map displays.
Each of the above identified instructions and applications can correspond to a set of instructions for performing one or more functions described above. These instructions need not be implemented as separate software programs, procedures, or modules. Memory 950 can include additional or fewer instructions. Furthermore, various functions of the mobile device may be implemented in hardware and/or in software, including in one or more signal processing and/or application specific integrated circuits.
Certain features may be implemented in a computer system that includes a back-end component, such as a data server, that includes a middleware component, such as an application server or an Internet server, or that includes a front-end component, such as a client computer having a graphical user interface or an Internet browser, or any combination of the foregoing. The components of the system can be connected by any form or medium of digital data communication such as a communication network. Some examples of communication networks include LAN, WAN and the computers and networks forming the Internet. The computer system can include clients and servers. A client and server are generally remote from each other and typically interact through a network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
One or more features or steps of the disclosed embodiments may be implemented using an API that can define on or more parameters that are passed between a calling application and other software code such as an operating system, library routine, function that provides a service, that provides data, or that performs an operation or a computation. The API can be implemented as one or more calls in program code that send or receive one or more parameters through a parameter list or other structure based on a call convention defined in an API specification document. A parameter can be a constant, a key, a data structure, an object, an object class, a variable, a data type, a pointer, an array, a list, or another call. API calls and parameters can be implemented in any programming language. The programming language can define the vocabulary and calling convention that a programmer may employ to access functions supporting the API. In some implementations, an API call can report to an application the capabilities of a device running the application, such as input capability, output capability, processing capability, power capability, and communications capability.
In some embodiments, the recommendations 1030 may take into account the user's historical data (e.g., from historical database 140 and 256). For example, if the user has been running for a number of weeks, the recommendation 1030 could suggest a break in order to decrease susceptibility to knee injury. Similarly, if the weather sensors 230 indicate that the user has been in a high-pollen environment often in the past week, the recommendation 1030 could suggest that the user stay indoors in order to avoid becoming sick.
Multiple methods of alerting the user about the recommendation may be used in addition to the viewer 220. These may include displaying a text notification, displaying a graphical notification, displaying a video notification, playing an audio notification, or initiating a vibration notification.
Next, sensor measurement history (e.g., from history database 140 of the wearable device 120 or synchronized history database 256 of the user device 150) and geolocation data (e.g., weather/environment/terrain data from data networks 160, 170, and 180) is provided (step 1110). Here, information regarding a user's run, for example, can be provided. As seen in step 1110 of
Calculations based on the sensor measurement and geolocation data is performed in the next step (step 1120). In particular, pulling from the conversion database, information can be obtained to associate segments of a user's run with the amount of calories burned. An exemplary embodiment of the conversion database 144 is shown in
Next, converted parameters 1134 (e.g., incorporating geolocation data) and unconverted parameters 1132 (e.g., not incorporating geolocation data) are provided (step 1130). In particular the converted parameters (generated above in step 1120) are used to compare the calculations that the wearable device 120 may provide based solely on its sensor data. A corresponding difference 1136 and ratio 1138 between the two parameters may also be calculated and stored in the wearable device 120 (e.g., at history database 140), at the user device 150 (e.g., at history database 256), or at the health network 270 (e.g., at health database 272).
In particular, the method includes a base formula used to calculate the (non-converted) amount of calories burned (step 1200). Once that is ready, geolocation data (e.g., 5 mph headwind for a first leg of the bike path and 10 mph tailwind for a second leg of the bike path) may also be provided (step 1210). From this, a converted parameter can be calculated by applying the geolocation data's parameter adjustments (e.g., calorie adjustments) of step 1210 to the non-converted parameter calculated from the sensor measurements from step 1200 (step 1220).
As seen in
An alternative method for calculating the amount of calories burned is also provided in
It should be noted that the table 1300 shown in
In response to the GPS data, the data networks 160, 170, 180, and 190 send location-based data (e.g., geolocation, weather, terrain, and environment data) to the location accuracy software 142 at the wearable device 120 (step 1425). Next, the conversion database 144 provides ratios in view of the location-based geolocation data to the location accuracy software 142 (step 1430) so that the software can calculate the modified or “converted” health parameter (e.g., calories) and transmit it back to the base software 136 (step 1440). From there, it may be stored, for example, in a history database 140 at the wearable device 120, a history database 256 at user device 150, or a health database at health network 270.
It should be noted that some steps, for example providing the GPS location to the location accuracy software 142, and the base software 136 calculating step for an initial output, can be performed in different order.
In response to the GPS data, the data networks 160, 170, 180, and 190 sends, to the wearable device 120, location-based data (e.g., geolocation, weather, terrain, environment data) which is provided to the location accuracy software 142 (step 1530). Next, the conversion database 144 provides ratios in view of the location based data to the location accuracy software 142 (step 1535) so that the location accuracy software 142 can calculate the modified or “converted” health parameter (e.g. calories) and send them to the wearable device 120 where they can be displayed (e.g., on a viewer 220) (step 1540).
Dates in the table where the health thumbnail indicates that blood pressure (“BP”) is OK (see blood pressure in column 1610 and column 1625, and health summary in column 1630) include 6-1-10, 6-2-10, 7-3-10, and 12-2-10. In certain entries, the blood pressure sensed (see blood pressure in column 1610) and the adjusted blood pressure (see adjusted blood pressure in column 1625) may be identical when the sensed temperature is between 71° F. and 73° F. (see sensed temperature in column 1615 or temperature provided by geolocation data network 170 in column 1620), and that the blood pressure sensed and the adjusted blood pressure may not be identical when the sensed temperature is around 19° F. This is because an algorithm may adjust the blood pressure reading measured when temperatures are cold.
A date where the blood pressure is indicated as being high (off average) is 12-2-11. The table indicates that on 12-2-11, a blood pressure sensed by the body sensor is 111, that the weather temperature sensed is 19° F., that the a temperature reported by the weather network is 20° F., that an adjusted blood pressure is 101, and that the health summary indicates that the user BP is high. Further, blood vessels near the surface of the skin may narrow in cold weather to conserve heat, thus increasing blood pressure.
Determinations relating to a user BP being OK or being high may be determined using data in a rule database 222. Temperature measurements listed in the table may vary from about 20° F. to about 70° F., a difference of about 50° F. When the temperature is 19° F., a rule in the rule database 222 indicates that blood pressure measured should adjusted by one count for every ten degrees of temperature reduction. Since on the date of 12-2-10, the measured blood pressure was 101 and the measured weather temperature was 19° F., since 70 minus 19 is approximately 50, the measured blood pressure should be adjusted downward by 5 counts. Since 101−5=96, and since a blood pressure reading of 96 is considered normal by the rule database 222, the health summary may therefore identify the BP as being OK.
It should be understood that the history databases 140 and 256 may also include other data. Most notably, the history databases 140 and 256 may store data about parameter calculations before and after modification (e.g., the outputs of
In step 1755, it may be determined whether a health network 270 is available. If so, the method proceeds to step 1760 where geolocation data (e.g., temperature of 20° C.) may be sent to the health network 270 server, and in step 1765, a health recommendation 1030 may be received by the wearable device 120 from the health network 270 server. Then in step 1770, the health recommendation 1030 may be presented to a user of the wearable device 120 for the user to view on a viewer 220. After step 1770, the method may return to step 1720.
When it may be determined in step 1730 that data networks 160, 170, 180, and 190 are not available, or in step 1755 that the health network 270 is not available, the method may proceed directly to step 1775 where historic data is loaded from the history database 140 and 256.
A user device 150 may be tethered to the wearable device 120 by a wireless communication interface 152. In step 1910, the user device 150 may optionally be provided with matching base software 250, a geolocation data database 254, a history database 256, and a rule database.
One or more data networks 160, 170, 180, and 190 may then provide environment/weather/terrain data corresponding to a GPS location of the wearable device 120 in step 1920.
Next, a health network 270 may be provided with an API 276, health software 274, and a health database 272 in step 1930. Third parties 280 may be allowed to input health recommendations 1030 into the health database 272. The recommendations 1030 may correspond to temperatures measured at the data networks 160, 170, 180, and 190 and/or by the wearable device 120 in step 1940. In some embodiments, the health network 270 may detect the type of the wearable device 120 (e.g., what body sensors 130 and/or weather sensors 230 is contains) and customize its operations proactively based on this type, or transmit customized software to the wearable device 120 based on this type, or, later, transmit customized recommendations 1030 based on this type.
Base software 136 executing on a processor 122 at the wearable device 120 may body sensor data 130, weather sensor data 230 to routinely (e.g., every 10 minutes) to execute location accuracy software 142. Location accuracy software 142 may be used to collect data from the data networks 160, 170, 180, and 190 using the GPS data from the GPS module 132 of the wearable device 120, load data collected to a history database 140 and 256 daily, and run a rules/conversion algorithm that adjusts parameters and health summaries. The adjustments to the health summaries and the health parameters may be based on weather, environment, terrain, and other geolocation data. Actual measurements such as measured blood pressure or temperature and calculated health parameters such as calorie counts and health summaries may be sent to the health network 270. Furthermore, recommendations 1030 received from the health network 270 may be displayed on a viewer 220 for the user of the wearable device 120 to view in this step in step 1950.
Although each exemplary operations illustrated by
The software components described above, such as base software 136, location accuracy software 142, base wearable device software 250, heath software 274, weather software 228, etc. may be stored in the memory of the corresponding device, such as wearable device 120 executing the software or the memory of another network-connected device, such as user device 150. The processing unit of the device executing the software interacts with the stored softwares in the memory to execute the softwares. In some embodiments, the software components may be stored in the memory of the processing unit itself.
Various examples of the network 100 include but are not limited to the Internet, intranets, extranets, wired networks, wireless networks, wide area networks (WANs), local area networks (LANs), or other suitable networks, etc., or any combination of two or more such networks.
The foregoing detailed description of the technology herein has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the technology to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. The described embodiments were chosen in order to best explain the principles of the technology and its practical application to thereby enable others skilled in the art to best utilize the technology in various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope of the technology be defined by the claim.
The present patent application claims the priority and benefit of U.S. provisional patent application 62/087,741, filed Dec. 4, 2014 and titled “Location Improved Accuracy,” and U.S. provisional patent application 62/087,434, filed Dec. 4, 2014, and titled “Weather Adjustment to Wearable,” the disclosures of which are incorporated herein by reference.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/IB2015/059235 | 12/1/2015 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
62087741 | Dec 2014 | US | |
62087434 | Dec 2014 | US |