This disclosure relates generally to data processing and, in particular, to forecasting blood glucose concentration and/or interpreting forecasted data.
Diabetes mellitus (DM) is a group of metabolic disorders in which there are high blood sugar levels over a prolonged period. Typical symptoms of such condition include frequent urination, increased thirst, increased hunger, etc. If left untreated, diabetes can cause many complications. There are three main types of diabetes: Type 1 diabetes results from pancreas's failure to produce enough insulin. In Type 2 diabetes, cells fail to respond to insulin properly. Gestational diabetes occurs when pregnant women without a previous history of diabetes develop high blood sugar levels.
Diabetes affects a significant percentage of world's population. Timely and proper diagnoses and treatment are essential to maintaining relatively healthy lifestyle for individuals with diabetes. Application of treatment typically relies on accurate determination of glucose concentration in the blood of an individual at a present time and/or in the future. Conventional systems are unable to provide accurate prediction or forecast of blood glucose concentration at a point in time in the future. Thus, there is a need for a system and a method that is capable of accurately forecasting blood glucose concentration for an individual that is based on the information/data about that individual and/or other similarly situated individuals.
In some implementations, the current subject matter relates to a computer implemented method for forecasting blood glucose concentration. The method can include determining one or more features for training a blood glucose concentration forecasting model, wherein the one or more features are determined based on one or more input data parameters associated with a user in a plurality of users, training, using the determined one or more features, the blood glucose concentration forecasting model, and generating, using the trained blood glucose concentration forecasting model, one or more expected blood glucose concentrations for the user.
In some implementations, the current subject matter can include one or more of the following optional features. The method can further include displaying the generated expected blood glucose concentrations for the user on one or more graphical user interfaces.
In some implementations, the training can include training the blood glucose concentration forecasting model using one or more parameters associated with one or more other users in the plurality of users. The parameters associated with other users can include one or more historical data parameters associated with one or more other users.
In some implementations, the input parameters can include at least one of the following: a data indicating a type of diabetes of the user, a data indicating a medical condition of the user, a data indicating medication being consumed by the user, a data indicating a meal consumed by the user, a data indicating a physical activity performed by the user, a data indicating a time of a blood glucose concentration measurement of the user, a data indicating at least one of a previous and a current value of a blood glucose concentration measurement of the user, a data indicating a time of a previous blood glucose concentration forecast, a data indicating a target blood glucose concentration (a1c) for the user, a data indicating at least one of a current date and a current time, a data indicating a weight of the user, a data indicating one or more changes in the blood glucose concentration of the user, a data indicating one or more carbohydrate values as consumed by the user, and any combination thereof.
In some implementations, the generating can include generating one or more target blood glucose concentration ranges for the user, generating one or more confidence intervals for the generated expected blood glucose concentrations, where the confidence intervals can indicate an accuracy of the generated one or more expected blood glucose concentrations, and comparing the generated target blood glucose concentration ranges, the confidence intervals for the generated expected blood glucose concentrations, and the generated expected blood glucose concentrations. The method can also include displaying, based on the comparison, an indication whether the generated expected blood glucose concentrations is within the target blood glucose concentration ranges. The method can further include generating an alert to the user when the generated expected blood glucose concentrations is not within the target blood glucose concentration ranges.
In some implementations, the generated expected blood glucose concentrations can be generated for a point in time subsequent to the determining.
In some implementations, the method can also include repeating the determination of the features, as well as the training of the forecasting model, and then, generating, based on the repeated determinations and training, one or more updated expected blood glucose concentrations for the user.
In some implementations, the current subject matter relates to a computer implemented method for forecasting and interpreting blood glucose concentration for a user. The method can include determining features (e.g., input data parameters) for training a forecasting data model, training the model, generating blood glucose concentration predictions, determining confidence intervals for the predictions, generating target ranges for the blood glucose concentration values, combining forecasting data, confidence intervals and target ranges for display to a user, and interpreting the forecasted data, e.g., to provide feedback to the user.
In some exemplary implementations, the current subject matter can provide a method for determining forecasts of a user's blood glucose concentration (BG) at a point in the future from 15-minutes to 24-hours, quantifying confidence intervals relating to the forecasted data, and producing an interpretation of whether the forecast is above, below or within the range consistent with any given target blood glucose health (a1c) goal. For forecasting purposes, the current subject matter can use past blood glucose concentration values, grams carbohydrates eaten at meals, workouts or minutes of activity, past values of weight, past values of a1c, year of diagnosis, etc., and/or any combination thereof. It can also use the above information that users have entered, which can widely vary from user to user, and from month to month for a given user.
In some exemplary implementations, the current subject matter can organize the above information to make it amenable to machine learning (e.g., “feature engineering”), whereby irregular and/or gappy historical information can be transformed into a standard form for each prediction being made. This can allow the model to make predictions for one user based on histories of other users in similar situations. In some exemplary, non-limiting implementations, the current subject matter can predict blood glucose in advance for pre-diabetes, gestational diabetes, Type 2 diabetes that are using no insulin and/or using basal insulin and/or using bolus insulin, with 75% of “test set” predictions within 34 mg/dL and 86% of predictions within 50 mg/dL. The accuracy of the above model is based on not only the user's particular information, but also from the information obtained from other users. The current subject matter can also provide confidence intervals, e.g., how close the forecasted data is close to real values. For example, for a particular user, two hours from now, the current subject matter can be
Non-transitory computer program products (i.e., physically embodied computer program products) are also described that store instructions, which when executed by one or more data processors of one or more computing systems, causes at least one data processor to perform operations herein. Similarly, computer systems are also described that may include one or more data processors and memory coupled to the one or more data processors. The memory may temporarily or permanently store instructions that cause at least one processor to perform one or more of the operations described herein. In addition, methods can be implemented by one or more data processors either within a single computing system or distributed among two or more computing systems. Such computing systems can be connected and can exchange data and/or commands or other instructions or the like via one or more connections, including but not limited to a connection over a network (e.g., the Internet, a wireless wide area network, a local area network, a wide area network, a wired network, or the like), via a direct connection between one or more of the multiple computing systems, etc.
The details of one or more variations of the subject matter described herein are set forth in the accompanying drawings and the description below. Other features and advantages of the subject matter described herein will be apparent from the description and drawings, and from the claims.
The accompanying drawings, which are incorporated in and constitute a part of this specification, show certain aspects of the subject matter disclosed herein and, together with the description, help explain some of the principles associated with the disclosed implementations. In the drawings,
To address these and potentially other deficiencies of currently available solutions, one or more implementations of the current subject matter relate to methods, systems, articles of manufacture, and the like that can, among other possible advantages, provide a way to forecast and interpret blood glucose data and other data related to the user.
In some implementations, the current subject matter can provide a computing system and/or framework for performing such determining, forecasting and/or interpretation of blood glucose data and other data related to the user. The data can include data, metadata, structured content data, unstructured content data, embedded data, nested data, hard disk data, memory card data, cellular telephone memory data, smartphone memory data, main memory images and/or data, forensic containers, zip files, files, memory images, and/or any other data/information. The input and/or the output data can be in various formats, such as text, numerical, alpha-numerical, hierarchically arranged data, table data, email messages, text files, video, audio, graphics, etc. The input data can include at least one of the following: current and/or previous blood glucose measurement data of the user, current and/or previous blood glucose measurement data of other users (e.g., the data can be appropriately anonymized), meal characteristics data (e.g., number of meals, time of meals, grams carbohydrates consumed during meal times (whether currently and/or in the past)), physical exercise data (e.g., workout times, activity type (e.g., walking, running, etc.), current and/or previous weight data of the user, current and/or previous a1c data values, medical history data related to the user (e.g., family history, user health history, diagnoses, blood pressure, etc.), as well as similar type of data related to other users.
The components 102-106 can include any combination of hardware and/or software. In some implementations, components 102-106 can be disposed on one or more computing devices, such as, server(s), database(s), personal computer(s), laptop(s), cellular telephone(s), smartphone(s), tablet computer(s), and/or any other computing devices and/or any combination thereof. In some implementations, the components 102-106 can be disposed on a single computing device and/or can be part of a single communications network. Alternatively, the components can be separately located from one another.
A user can access the system 100 via a user device 104. The user device 104 can be used to obtain blood glucose measurement data and/or any other data (e.g., health data, nutrition data, exercise data, etc.) relating to the user and/or any other users (appropriately anonymized). In some exemplary implementations, the user device 104 can include a component that is capable of obtaining blood samples from the user and determining glucose concentration levels in user's blood. Any means of obtaining blood samples from the user and/or determining blood glucose concentration levels can be used. The device can also include one or more data input components that can allow entry of various data (e.g., nutrition data (e.g., consumption times, number of calories, amount of fat, sugars, etc.), health data (e.g., weight, age, sleeping patterns, medical conditions, cholesterol levels, etc.), exercise data (e.g., walking, running, swimming, etc.), personal data (e.g., name, gender, social network information, etc.), and/or any other data, and/or any combination thereof), etc. In some implementations, the data can be queried by the user device 104 from one or more third party databases. The user device 104 can be used to generate a query and transmit it to the engine 102, which can determine which database may contain requisite information and then connect with that database to execute a query and retrieve appropriate information. In some implementations, the engine 102 can include various application programming interfaces (APIs) and/or communication interfaces that can allow interfacing between user devices 104, databases, and/or any other components.
As shown in
Any means can be used to obtain data for the purposes of the analysis performed by engine 102, where the means can include one or more of the following a microphone (either a separate microphone or a microphone imbedded in the user device), a speaker, a screen (e.g., using a touchscreen, a stylus pen, and/or in any other fashion), a keyboard, a mouse, a camera, a camcorder, a telephone, a smartphone, a tablet computer, a personal computer, a laptop computer, and/or using any other device. The engine 102 can also obtain data from various third party sources. In some implementations, engine 102 can be communicatively coupled to various public and/or private databases that can store various information, e.g., census information, health statistics (appropriately anonymized), demographic information, population information, and/or any other information. For example, the engine 102 can be used to obtain information about blood glucose measurements/concentration and/or forecasts of blood glucose concentrations of a plurality of users (without identifying the users) of the system 100, nutrition data relating to such users, exercise data, social network information, and/or any other information and/or any combination thereof.
The engine 102 can execute a query that may be and/or process data received from the user device 104 and access the database 106 to obtain relevant data that may be stored in the database 106. Exemplary relevant data is shown in
As shown in
The forecasted blood glucose values can be provided to the recommendation/message generation module 128 to generate one or more recommendations for the user and/or any other important messages (at 125 as shown in
In some implementations, the forecasted blood glucose values may be provided to the forecast-in-range percentage determination module 124 for the purposes of determining whether the generated forecast is in a percentage particular range of a specific target blood glucose concentration threshold value (at 123 as shown in
In some implementations, the current subject matter may also perform an assessment of accuracy of any of the above forecasted values using various techniques. For example, the forecasted values may be compared against an accuracy threshold, e.g., a standard error of prediction higher than 80 mg/dL (or any other value), or a 90% confidence interval (or any other confidence interval) of width greater than 100 mg/dL (or any other width), or a likelihood less than 75% (or any other value) of meeting any given clinical accuracy criterion such as the Clarke Error Grid zone “A” (or any other label from any error classification scheme), to determine whether the forecasted values have a high degree of uncertainty. If so, the current subject matter may determine that the forecasted values should not be delivered to the user device 104. Alternatively, the graphical user interface of the device 104 may generate an indication that the forecasted values may have a high degree of uncertainty and graphical prompt asking the user whether the user wishes to review the generated high uncertainty forecasted values, such as, for example, to ascertain where a possible error in input data values may have occurred. Once corrections, if any, are made, the forecast may be re-executed.
The process 130 can be illustrated by the following example. If the user logs a meal at 12:30 PM local time on December 23, the user device 104 can generate a request for a forecast. All of the user's logged information can be retrieved. Inputs can be computed for forecasts at 1 PM, 1:30 PM, 2 PM, 2:30 PM and so on. The trained model can then be used to predict the user's blood glucose concentration at those upcoming times.
In some implementations, referring back to
The engine 102 can perform analysis of the obtained data (e.g., a statistical analysis, machine learning analysis, etc.) and generate a forecast of an expected blood glucose concentration for the user as well as provide an interpretation of the obtained data and/or the forecasted data, as further discussed below. The engine 102 can perform such analysis/assessment once and/or on a continuous basis, e.g., when updated data is supplied to the engine 102, the engine 102 can perform analysis and re-assessment of the previous forecast and update its previous prediction. In performing its analysis, the engine 102 can also generate additional queries to obtain further information. In some exemplary implementations, additional queries can be generated when new, updated, etc. forecast is to be generated. A new forecast can be requested whenever there are new data, when the user accesses a forecast user interface on the user device 104, etc. When a new forecast is requested (e.g., a forecast request is triggered), all of the user's information, including, but not limited to, any information that has been entered and/or obtained since any previous forecasts, can be obtained from the database 106 and used by the engine 102. In some implementations, the user device 104 can automatically supply the engine 102 with such information. Receipt of updated/additional information can generate a trigger and cause the engine 102 to execute a process associated with performing analysis/forecast/re-forecast/interpretation/etc. The updated/additional information can include, but is not limited to, blood glucose values, medication data, food intake data, physical activity data, etc. that can be actively and/or passively logged by the user device 104 and/or is actively and/or passively collected by the system 100 shown in
The following provides further details of a process performed by the engine 102 to generate a forecast of a blood glucose concentration for a user as well as provide an interpretation of the data and/or forecast for the user.
In some implementations, as stated above, the engine 102 can initiate its process with the raw data provided by user and/or other users through one or more user interfaces of one or more user devices 104 (e.g., an “app” installed on the user device 104 (e.g., a smartphone, a tablet, etc.), and use them to produce automated decision support for users.
As shown in
In some implementations, in addition to the data stored in table 202 shown in
At 402, the engine 102 can be configured to determine features that will be used for training a forecasting data model. This can be also referred to as feature engineering. In some implementations, a large number of candidate features can be evaluated. The candidate features can be generated based on a multitude of factors and/or data. By way of non-limiting examples, the data can include data collected to date relating changes in blood glucose concentrations (e.g., whether in individuals with any type of diabetes, individuals without any type of diabetes, healthy with/out any other medical conditions, etc.) resulting from various activities (e.g., food intake, medication intake, physical activity, etc.), data specifically related to metabolic processes that cause different factors (e.g., food, medication, etc.) to affect blood glucose values. The candidate features can then be used in training and/or validation processes where a model can be trained with some of the candidate features using a first set of data (i.e., a training data), then the accuracy of that model can be evaluated by using it to predict values from a second set of data (i.e., validation data). This process can be repeated with different sets of candidate features until the features are identified that produce the best accuracy on the validation data. Because these processes can be repeated over time, specific features being used in the model can be changed and/or improved regularly.
As part of the feature determination process, information shown in tables in
As stated above,
In some implementations, the current subject matter system 100 can organize the data shown in table 500 to predict blood glucose concentration at an arbitrary time, based on different filters of all previous inputs (e.g., most recent, average(s), smooth(s), metabolic action(s) since the previous blood glucose measurements, etc., and/or any combination thereof), which can be defined regardless of the number or irregularity of past data entries from a particular user. Instead of having to predict a blood glucose concentration, for example, every hour on the hour and collect training data every hour on the hour, the current subject matter system 100 can generate a prediction at any time, such as, whenever there is a blood glucose measurement and/or can use information collected prior to that time. In some implementations, for training and/or testing the forecasting model, blood glucose concentrations can be predicted based on the time they are obtained, where predictions are scored to determine how close they are to the actual concentrations.
In some implementations, the scoring can be representative of an absolute difference between predicted and actual values. Thus, smaller differences between predicted and actual can be representative of a substantially accurate prediction, a zero difference can represent a perfect prediction, etc. By way of a non-limiting example (and in addition to the discussion below), if a user recorded a blood glucose concentration (BG) of 163 mg/dL at 4 PM on Tuesday, Dec. 23, 2018, and the last information provided before that time was a meal logged at 12:30 PM on the same day, then the system 100 (shown in
In some implementations, as the model is trained, similar examples from all users can be sorted together to provide a basis for new predictions. In some exemplary implementations, such information can be used for the purposes of making predictions for a particular user. For example, if blood glucose concentration is being predicted 12 PM on a Thursday (e.g., user local time) for a user whose previous blood glucose concentration was near 100 mg/dL, around 4 hours ago, and of a known weight, a1c, average activity, etc. then the model can predict that user's blood glucose concentration using previous examples having similar inputs from one or more other users. In some exemplary, non-limiting, implementations, as stated above, only those criteria that the model training exercise discovers to be predictively useful can actually be used to determine which other users are considered “relevant”.
At 404, the system 100 can perform forecasting model training, as shown in
At 406, the system 100 can generate one or more predictions of blood glucose concentration for the particular user. The trained model can be used to generate predictions in the following exemplary manner. At the time the prediction is made, input data shown in
At 408, the system 100 can determine confidence intervals of the forecasted data. The training models used by the system 100 (e.g., XGBoost model, etc.) can include a large number of “trees” (e.g., 150). As can be understood, any training models can be used by the system 100 and the current subject matter is not limited to the XGBoost or similar such models, e.g., Gradient Boosted Trees models, etc. For ease of illustration only, the following description will refer to the models identified above. In these models, each data item can correspond to one “leaf” of each tree, and each leaf can have a “weight” that can be determined when the model is trained. The predicted value for that data item can be the sum of the weights of the leaves that that data item ends up in for each tree. In some exemplary implementations, the confidence intervals can be determined based on prediction errors/error distribution set (as discussed below). As discussed above and shown in
The weights can be determined as follows: each tree's contribution can be considered to be a correction to the running sum. For example, to compute weights in a leaf of a 4th tree, the training routine looks at the predictions for the items in that leaf from summing their weights from the first three trees. All those 3-tree predictions can have some error, and the mean value of that 3-tree error for those items becomes the correction value, or the weight of the tree-4 leaf being computed. As such, the weight of that tree-4 leaf can be the mean value of the 3-tree errors of the items in that leaf multiplied by a value that depends on the model parameters being trained.
That weight does not consider the spread of the 3-tree errors. The errors of items in the tree-4 leaf could range from 10 to 12, with an average value of 11, or they could range from −89 to +111, with an average value of 11: the weight can be the same. However, the 4-tree prediction errors can be larger in the second case than in the first. In some implementations of the current subject matter, the system 100 can assume that if the prediction is the sum of each leafs errors' mean, then the variance of the prediction can be the sum of the each leaf's errors' variance. The system 100 can then examine the trained model (e.g., XGBoost model) and determine the variance of errors in each leaf of each tree, and turn that into a “variance model”. The inputs to the variance model can be the same as the inputs to the prediction model: for each prediction, the variance model adds up the variances of the leaf that prediction lands in for each tree to produce the variance of the prediction. The square root of the variance gives the standard error of the prediction.
The prediction errors might not be normally distributed, however, the error distributions can be very close between training and test sets. Next, the error distribution for training set predictions with the same variance as the prediction in question can be ascertained. The quantiles of that training set distribution can then be assumed to be the quantiles of the prediction in question.
Referring back to
This information can be used to help the user to interpret forecasted blood glucose concentration in terms of whether the forecast was in line with healthy a1c values, above, below, etc. Unlike constant values, blood glucose target ranges shift throughout the day, depending on when the user eats, performs various activities, etc. To develop a target range (e.g., as shown in
The values in table 700 (in column time 702 and column “target BG”) 704) can correspond to upper ends of ranges of blood glucose concentration readings from users who had a1c levels under 7%. To translate those to times of day, observed meal times data in the log for a particular user can be used. In some exemplary implementations, logged carbohydrate values can be tagged as “breakfast”, “lunch”, or “dinner.” Data from 30 minutes before meals can be treated as “pre-meal” data, 2 hours after meals as “post-meal” data, and late evening data as “bedtime” data. If a user has not logged a meal during a past period, or if target ranges are being determined for future hours when meals have not happened yet, user's most frequent meal time can be used for that meal. If the user has not logged at least 3 meals of that meal type, the system 100 can assume the most popular meal times using data obtained from other users. Once the meal times are determined for a particular day, target points at correct pre-meal and post-meal times can be plotted, as shown by the plot 800 in
Referring back to
At 414 of
In some exemplary implementations, support messages can be in one or more of the following categories (or any other categories):
In some implementations, based on the forecast interpretation, the user device 104 can display a message (e.g., as shown in
In some implementations, the user interfaces may be configured to allow user to customize or personalize display of various health related and/or any other data through use of various graphical user interface elements, which may include but are not limited to, buttons, screens, tiles, pointers, etc. (hereinafter, “tiles”). The tiles may allow users to customize/personalize the display of health data across multiple conditions. By way of a non-limiting example, the tiles may enable users to combine data from manual user input and/or automatic data ingestion from multiple information sources, view key health information at a glance across multiple conditions, perform deeper analysis of user's data along with various health metrics, customize user interface display to their preference, etc.
The following provides a discussion of an exemplary experimental implementation of system 100 (as available from Goldner, D. R., “A Machine-Learning Model Accurately Predicts Projected Blood Glucose,” Diabetes 2018 July; 67(Supplement 1)). In this experimentation, 1,923,416 BG measurements from 14,706 people with noninsulin treated Type 2 diabetes were collected. Additionally, various contextual information (CI) was collected. The CI included at least one of the following/various combinations of the following: demographic data, health data (e.g., weight, A1c), etc.
Input to the prediction model: prior blood glucose data and CI.
The model did not distinguish between users' BGs with similar CI. Forecast horizons were determined using time since prior blood glucose concentrations and varied from 10 minutes to several days. Machine learning algorithms to predict BG values were trained and tested on BGs entered prior to September 2017 (83% of all BGs). BGs (17%) entered from September-November 2017 were held out and predicted.
Results: Users were 59% male, with 80% from North America, 9% from Europe, and 11% from elsewhere. 50% of users were diagnosed with Type 2 diabetes in the past 3 years. The median and mean absolute error of holdout predictions were 14.2 and 21.3 mg/dL respectively, with 91% of predictions within +/−50 mg/dL.
In another exemplary experimental implementation, an initial sample of 23,876 forecasts were sent via in-app notifications to 4,679 users with Type 2 diabetes. Forecasts included of BG trend, duration, and level (“rising, but not too high, over the next 3 hours”) and, when appropriate, a support message relevant to forecast and user history. Forecast delivery was random, triggered with 50% probability when information was logged, no more than once/day/user.
Forecasts could be rated “Useful” or “Not Useful”. A machine learning model, trained on the initial sample, predicted the probability of each type of feedback. A second sample of 28,838 forecasts were sent to 5,506 users, with probability of usefulness determined by the model.
Results: in the first sample, 42.8% of forecasts received feedback from 69.6% of users; 87.1% was “Useful”. In the second sample, 63.7% of forecasts received feedback from 67.1% of users; 92.4% was “Useful”.
The experimental results demonstrated that a new machine learning model tailored forecast delivery, reducing the “Not Useful” rate by 41.1% (from 12.9% of feedback to 7.6%).
In some implementations, the current subject matter can be configured to be implemented in a system 1300, as shown in
In some implementations, the current subject matter can include one or more of the following optional features. The method can further include displaying the generated expected blood glucose concentrations for the user on one or more graphical user interfaces.
In some implementations, the training can include training the blood glucose concentration forecasting model using one or more parameters associated with one or more other users in the plurality of users. The parameters associated with other users can include one or more historical data parameters associated with one or more other users.
In some implementations, the input parameters can include at least one of the following: a data indicating a type of diabetes of the user, a data indicating a medical condition of the user, a data indicating medication being consumed by the user, a data indicating a meal consumed by the user, a data indicating a physical activity performed by the user, a data indicating a time of a blood glucose concentration measurement of the user, a data indicating at least one of a previous and a current value of a blood glucose concentration measurement of the user, a data indicating a time of a previous blood glucose concentration forecast, a data indicating a target blood glucose concentration (a1c) for the user, a data indicating at least one of a current date and a current time, a data indicating a weight of the user, a data indicating one or more changes in the blood glucose concentration of the user, a data indicating one or more carbohydrate values as consumed by the user, and any combination thereof.
In some implementations, the generating can include generating one or more target blood glucose concentration ranges for the user, generating one or more confidence intervals for the generated expected blood glucose concentrations, where the confidence intervals can indicate an accuracy of the generated one or more expected blood glucose concentrations, and comparing the generated target blood glucose concentration ranges, the confidence intervals for the generated expected blood glucose concentrations, and the generated expected blood glucose concentrations. The method can also include displaying, based on the comparison, an indication whether the generated expected blood glucose concentrations is within the target blood glucose concentration ranges. The method can further include generating an alert to the user when the generated expected blood glucose concentrations is not within the target blood glucose concentration ranges.
In some implementations, the generated expected blood glucose concentrations can be generated for a point in time subsequent to the determining.
In some implementations, the method can also include repeating the determination of the features, as well as the training of the forecasting model, and then, generating, based on the repeated determinations and training, one or more updated expected blood glucose concentrations for the user.
The systems and methods disclosed herein can be embodied in various forms including, for example, a data processor, such as a computer that also includes a database, digital electronic circuitry, firmware, software, or in combinations of them. Moreover, the above-noted features and other aspects and principles of the present disclosed implementations can be implemented in various environments. Such environments and related applications can be specially constructed for performing the various processes and operations according to the disclosed implementations or they can include a general-purpose computer or computing platform selectively activated or reconfigured by code to provide the necessary functionality. The processes disclosed herein are not inherently related to any particular computer, network, architecture, environment, or other apparatus, and can be implemented by a suitable combination of hardware, software, and/or firmware. For example, various general-purpose machines can be used with programs written in accordance with teachings of the disclosed implementations, or it can be more convenient to construct a specialized apparatus or system to perform the required methods and techniques.
The systems and methods disclosed herein can be implemented as a computer program product, i.e., a computer program tangibly embodied in an information carrier, e.g., in a machine readable storage device or in a propagated signal, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
As used herein, the term “user” can refer to any entity including a person or a computer.
Although ordinal numbers such as first, second, and the like can, in some situations, relate to an order; as used in this document ordinal numbers do not necessarily imply an order. For example, ordinal numbers can be merely used to distinguish one item from another. For example, to distinguish a first event from a second event, but need not imply any chronological ordering or a fixed reference system (such that a first event in one paragraph of the description can be different from a first event in another paragraph of the description).
The foregoing description is intended to illustrate but not to limit the scope of the invention, which is defined by the scope of the appended claims. Other implementations are within the scope of the following claims.
These computer programs, which can also be referred to programs, software, software applications, applications, components, or code, include machine instructions for a programmable processor, and can be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. As used herein, the term “machine-readable medium” refers to any computer program product, apparatus and/or device, such as for example magnetic discs, optical disks, memory, and Programmable Logic Devices (PLDs), used to provide machine instructions and/or data to a programmable processor, including a machine-readable medium that receives machine instructions as a machine-readable signal. The term “machine-readable signal” refers to any signal used to provide machine instructions and/or data to a programmable processor. The machine-readable medium can store such machine instructions non-transitorily, such as for example as would a non-transient solid state memory or a magnetic hard drive or any equivalent storage medium. The machine-readable medium can alternatively or additionally store such machine instructions in a transient manner, such as for example as would a processor cache or other random access memory associated with one or more physical processor cores.
To provide for interaction with a user, the subject matter described herein can be implemented on a computer having a display device, such as for example a cathode ray tube (CRT) or a liquid crystal display (LCD) monitor for displaying information to the user and a keyboard and a pointing device, such as for example a mouse or a trackball, by which the user can provide input to the computer. Other kinds of devices can be used to provide for interaction with a user as well. For example, feedback provided to the user can be any form of sensory feedback, such as for example visual feedback, auditory feedback, or tactile feedback; and input from the user can be received in any form, including, but not limited to, acoustic, speech, or tactile input.
The subject matter described herein can be implemented in a computing system that includes a back-end component, such as for example one or more data servers, or that includes a middleware component, such as for example one or more application servers, or that includes a front-end component, such as for example one or more client computers having a graphical user interface or a Web browser through which a user can interact with an implementation of the subject matter described herein, or any combination of such back-end, middleware, or front-end components. The components of the system can be interconnected by any form or medium of digital data communication, such as for example a communication network. Examples of communication networks include, but are not limited to, a local area network (“LAN”), a wide area network (“WAN”), and the Internet.
The computing system can include clients and servers. A client and server are generally, but not exclusively, remote from each other and typically interact through a communication 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.
The implementations set forth in the foregoing description do not represent all implementations consistent with the subject matter described herein. Instead, they are merely some examples consistent with aspects related to the described subject matter. Although a few variations have been described in detail above, other modifications or additions are possible. In particular, further features and/or variations can be provided in addition to those set forth herein. For example, the implementations described above can be directed to various combinations and sub-combinations of the disclosed features and/or combinations and sub-combinations of several further features disclosed above. In addition, the logic flows depicted in the accompanying figures and/or described herein do not necessarily require the particular order shown, or sequential order, to achieve desirable results. Other implementations can be within the scope of the following claims.
The present application claims priority to U.S. Provisional Patent Appl. No. 62/728,496 to Goldner et al., filed Sep. 7, 2018, and entitled “Forecasting Blood Glucose Concentration” and U.S. Provisional Patent Appl. No. 62/854,088 to Goldner et al., filed May 29, 2019, and entitled “Forecasting Blood Glucose Concentration,” and incorporates their disclosures herein by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
62728496 | Sep 2018 | US | |
62854088 | May 2019 | US |