 
                 Patent Grant
 Patent Grant
                     12170136
 12170136
                    The present invention relates to insulin pumps, and more particularly, to insulin pumps having correction factors.
A large portion of the world's population suffers from diabetes. Many of these people need to take injections of insulin to normalize the level of sugar in their bodies to prevent complications. Such complications can include kidney failure, loss of circulation, and blindness. The need to manually take injections with a syringe and the process of determining the dose for various shots can be a great inconvenience and can limit a diabetic's activities and restrict their movements. Furthermore, it can be difficult to maintain a consistent level of blood glucose because there is a practical limit to the number of injections that most patients can receive.
One solution to reduce some of the problems associated with the manual injection of insulin is an ambulatory pump that delivers insulin to the diabetic user. Such insulin pumps can provide a more consistently normal level of blood glucose, which reduces the risk of complications from diabetes. However, current pumps still have practical limits to their programming that make them cumbersome to program and that limits the potential of the pump to provide even greater control over blood glucose levels.
According to a first aspect, a method of regulating blood glucose levels using an insulin pump is disclosed. The method includes receiving a current blood glucose level, and determining whether the current blood glucose level is above a threshold value. The method also includes calculating a correction bolus value based upon the current blood glucose.
According to a second aspect, an insulin pump is disclosed. The insulin pump includes a pump mechanism and a memory configured to store one or more blood glucose levels. The insulin pump also includes a programmable circuit arranged to control the pump mechanism and operatively connected to the memory. The programmable circuit is programmed to receive a current blood glucose level and determine whether the current blood glucose level is above a threshold value. The programmable circuit is also programmed to calculate a correction bolus value based upon the current blood glucose.
According to a third aspect, an insulin pump is disclosed. The insulin pump includes a pump mechanism and a memory configured to store one or more rules, each rule including a threshold and a percentage. The insulin pump includes a programmable circuit arranged to control the pump mechanism and operatively connected to the memory. The programmable circuit is programmed to prompt a user to input the threshold value and the percentage for at least one rule. The programmable circuit is further programmed to receive a current blood glucose level, and determine whether the current blood glucose level is above a threshold value. The programmable circuit is also programmed to, upon determining that the current blood glucose level is above the threshold value, alter a correction bolus calculation factor. The programmable circuit is programmed to calculate a correction bolus value based upon the correction factor and deliver the correction bolus to the user.
    
    
    
    
    
    
    
    
    
    
    
    
    
    
Various embodiments of the present invention will be described in detail with reference to the drawings, wherein like reference numerals represent like parts and assemblies throughout the several views. Reference to various embodiments does not limit the scope of the invention, which is limited only by the scope of the claims attached hereto. Additionally, any examples set forth in this specification are not intended to be limiting and merely set forth some of the many possible embodiments for the claimed invention.
The logical operations of the various embodiments of the invention described herein are implemented as: (1) a sequence of computer implemented steps, operations, or procedures running on a programmable circuit within a computer, (2) a sequence of computer implemented steps, operations, or procedures running on a programmable circuit within a pump for delivering insulin; and/or (3) interconnected machine modules or program engines within the programmable circuits.
The various embodiments execute or utilize operating parameters, which customize or personalize operation of the computer implemented steps, machine modules, and programs to meet the requirements of individual pump users. The operating parameters can be numerical values, text strings, flags, argument names, or any other aspect of the insulin pump programming that the user can set to control operation of the pump.
Additionally, the pump generates and presents information and fields in user interfaces, which are also referred to as displays. The user interfaces can include fields, alpha/numeric character strings, times, and dates. The fields, also referred to as cells, prompt users to enter and/or select information. Because there is not an alpha/numeric keyboard on the pump, each of the field is associated with a spin box that includes values the user can enter into the field. The user spins or scrolls through values until the desired value is visible within the field. When the user selects the visible value it is entered into the field. The user selects a value with a Next function, Edit function, or Select function as identified herein. When the pump displays a field and the field has focus, it is said to prompt the user to select a value. Additionally, selecting a value in a field causes the pump to index focus to the next field as defined by the programmed operations or to display the next user interface as defined by the programmed operations. In an alternative embodiment, the pump has an alpha/numeric keyboard from which operating parameters can be typed directly into the pump.
The description set forth herein discusses pumping insulin. One skilled in the art will realize that many of the features, structures, and methods disclosed herein can be used with medical infusion pumps for delivering agents other than insulin. The term “user” generally applies to the person who is receiving insulin from the pump. In many contexts, however, the user could also refer to any other person such as a caregiver that is operating the pump.
A. Pump Architecture
  
The pump motor 104 drives a drive mechanism 112 that pushes a plunger mechanism 114. The plunger mechanism 114 ejects insulin from an insulin cartridge (not shown). The insulin cartridge contains a supply of insulin for delivery to a patient. These mechanical components are illustrated and discussed in commonly assigned U.S. patent application Ser. No. 10/086,646, entitled Cartridge and Pump With Axial Loading, the disclosure of which is hereby incorporated by reference.
The screen 106 can have many different configurations such as an LCD screen. As explained in more detail herein, the screen 106 displays a user interface that presents various items of information useful to a patient or caregiver. The audible alarm 108 is a beeper, and an alarm provides actual alarms, warnings, and reminders. Similar to other portable electronic devices such as a cellular telephone, the vibratory alarm 110 provides an alarm to either supplement the audio alarms or replace the audio alarm when an audible beep would be disruptive or not heard. A user can selectively enable or disable the audible 108 and vibratory 110 alarms. In one possible embodiment, however, both the audible 108 and vibratory 110 alarms cannot be disabled at the same time.
The microprocessor 102 is in electrical communication with both a random access memory (RAM) 116 and a read only memory (ROM) 118, which are onboard the pump 100 but external to the microprocessor 102 itself. The microprocessor 102 can be any programmable circuit configured to execute instructions stored in the memory devices. In one possible embodiment, the microprocessor 102 includes internal memory as well. The RAM 116 is a static RAM stores that data that can change over time such as pump settings and a historical log of events experienced by the insulin pump 100. The ROM 118 stores code for the operating system and the application programs. The ROM 118 can be any type of programmable ROM such as an EPROM. In one possible embodiment, the RAM 116 has 500 kilobytes of memory capacity and the ROM 118 has 2 megabytes of memory capacity.
An infrared (IR) port 120 is in electrical communication with the microprocessor. As explained in more detail below, the IR port 120 provides data communication with an external device such as a computer for programming an application program, programming pump settings, and downloading historical data logs. The insulin pump 100 can include other types of communication ports in place of or in addition to the IR port 120. Examples of other possible communication ports include a radio frequency (RF) port or a port that provides a hard-wired data communication link such as an RS-232 port, a USB port, or the like.
A real-time clock 122 provides a clock signal to the microprocessor 102. An advantage of having a real-time clock 122 is that it provides the program with the actual time in real-time, including day of the week, so that the programs executed by the insulin pump can track and control the actual time of day that insulin delivery and other events occur. Various durations described here are used for alerts, alarms, reminders, and other functions. In one possible embodiment, the timers are formed by the real-time clock 122 and software executed by the microprocessor 102.
A battery 123 electrically connects to the real time clock 122 and the RAM 116. The battery 123 provides an alternate electricity source for the real time clock and the RAM 116 to preserve data stored in the RAM in the case of a power interruption, such as during removal of a primary battery.
A keypad 124 also provides input to the microprocessor 102. Although other possible types of keypads are possible, one type of keypad has four buttons and is a membrane-type of keypad, which provides resistance to water and other environmental conditions. The keypad 124 contains soft keys for which the function of the keys can change as a user executes different menu selections and commands.
An audio bolus button 125 provides a further input to the microprocessor 102. The audio bolus button 125 enables a bolus, such as a correction bolus or meal bolus as described herein, corresponding to a specific audible sound. In a possible embodiment, various potential audio bolus amounts correspond to unique audible sounds configured to allow a user to program the audio bolus without requiring the user to visually reference the pump screen 106.
Other inputs into the microprocessor 102 include a pressure sensor 126, which is sensitive to the pressure within a reservoir of insulin; a cartridge sensor 128, which is sensitive to the presence of an insulin cartridge; and a motion detector 130, which detects motion of a gear (not shown) in the drive mechanism 112. The pressure sensor 126, cartridge sensor 128, and motion detector 130 are described in more detail in U.S. patent application Ser. No. 10/086,646, which is entitled Cartridge and Pump With Axial Loading, the disclosure of which was incorporated by reference above.
Referring to 
The template portion 136 provides a template that indicates the function assigned to each of the keys on the keypad. In the embodiment illustrated in the drawings, the keypad 124 has a first function key 138 and a second function key 140, and an up key 142 and a down key 144. The up and down keys 142 and 144 are for scrolling or spinning through operating parameters that are presented in a spin box associated with a field or between pages present within a user interface such as the home pages as described below. Additionally, a first portion 146 in the template identifies the function assigned to the first function key 138, and a second portion 148 identifies the function assigned to the second function key 140. If a variable or menu selection can be scrolled up or down, a corresponding center portion 150 of the template presents one or both of an up arrow corresponding to the scroll direction of the up key 142, and a down arrow corresponding to the scroll direction of the down key 144.
B. Home Page
In one possible embodiment, the insulin pump 100 is controlled by a menu-driven application program that is stored in the ROM 118 and executed by the processor 102. The application program also is parameter-driven in that the outcome or steps executed by the various application programs depend on the operating parameters set by the user. Examples of outcomes and steps that depend on the operating parameters include delivery rates, delivery schedules, delivery amounts, the generation and presentation of menus, and the like.
Referring still to 
In one possible embodiment, the home page 152 presents the current status 162 of the insulin pump's 100 operation. In the example set forth in the illustration, the insulin pump 100 is delivering insulin at a rate of 1.15 units per hour according to a first basal schedule. The home page 152 also presents the name 166 of the active delivery program it is executing and personal information 168 as programmed by the user. In the illustrated example, the personal information it displays is a banner “Mary's Pump,” which identifies the owner of the insulin pump 100. Other examples of information that might be included in the personal field includes medical information about the pump user similar to that information included on a medical alert bracelet such as allergies and the fact that the patient is diabetic, more detailed information about the patient including the patient's full name, telephone number, and address, detailed information about the user's caregiver such as the name and telephone number of the user's physician, and a warning that the pump 100 is an insulin pump and should not be removed from the user.
Furthermore, the pump 100 can be configured to present more than one home page. In this embodiment, the user scrolls through the home pages using the up and down keys 142 and 144. For example, other home pages might include the date, time, and amount of the last bolus delivered by the insulin pump; contact information about the patient's caregiver; medical information about the patient such as a list of the user's allergies, a warning that the user is a diabetic, and a warning that the pump is an insulin pump and should not be removed.
The pump 100 displays an icon 170 in the home page 152 to identify the displayed page as the home page. Additionally, the icon 170 can include a page number to indicate which home page is currently being displayed. One possible shape for the home page icon is an icon having the shape of a house.
C. Main Menu
Referring to 
The New Cartridge menu item is selected to access the cartridge or syringe of insulin loaded in the pump 100. In one possible embodiment, selecting the New Cartridge menu item automatically sequences the user through the steps of loading the new cartridge, priming the tubing for the infusion set, priming the cannula, and setting the site reminder, if the display site reminder is enabled. The site reminder is discussed below in more detail. In yet another embodiment the user will affirmatively acknowledge each of these steps by pressing a predetermined key, either the first or second function keys 138 or 140 on the keypad 124, at the conclusion of each step, which causes the pump to index to the next step. After sequencing through each of these steps, the pump 100 prompts the user to enter an instruction whether to resume delivery of insulin.
Accessing the cartridge is discussed in more detail in U.S. patent application Ser. No. 10/086,646, entitled Cartridge and Pump With Axial Loading, the disclosure of which was incorporated by reference above.
The user selects the desired menu item by using the up and down keys 142 and 144 until the desired menu item is highlighted or otherwise marked. The user then activates the highlighted menu item by activating a select function 194 assigned to the second function key 140.
By selecting the Pump Settings menu item, the pump brings up a Pump Settings submenu 196 of several submenu items, including Time and Date, Beep/Vibrate, Program Lock, and Personalize. The Time and Date menu option is selected to set the time and date of the clock. This time and date is set in real time. When the Time and Date menu option is selected, the screen displays the time and date, and focus is placed on the hour field 198. The user scrolls through values for the hour until the desired value is set. The user then activates a next function 200 assigned to the second function key 140 to index through the remaining fields for the time and date (e.g., the minute field 202, the am/pm field 204, the month field 206, the day field 208, and the year field 210) and set the desired values for each of these fields. The user exits the Time and Date function at any time by activating the Done function 212 assigned to the first function key 138. Activating the Done function 212 saves the current time and date settings and returns the pump to the Pump Settings submenu 196.
D. Beep/Vibrate
Referring to 
E. Navigation Sounds
Audible sounds generated by the pump 100 provide assistance to the user in navigating through the pump menus. The audible sounds provide a method by which a user need not rely on visually observing the pump screen while programming the pump. Such a feature can be used by visually impaired users, or users who do not wish to otherwise visually confirm the pump settings. In various embodiments of the pump 100, the sounds indicate the current screen displayed by the pump, and also signify buttons depressed on the pump or other pump events.
The pump 100 uses the home screen 152 as a basis for navigating through the pump menus by providing a unique audible sound, such as a beep of a unique pitch as compared with other sounds made by the pump. Additional home screens and menu screens programmed into the pump are associated with beeps of varying pitches. For example, the home screen 152 is associated with a first sound, which is emitted when the pump first displays the home screen, as well as each time a user navigates back to the home screen. The main menu 190 is associated with a second sound different from the first sound, and that second sound is emitted each time a user navigates to the main menu 190. Additional sounds, different from the first and second sounds and also different from each other, are associated with other home pages and menu screens as described herein. In one embodiment, the pump emits a sound of a specific pitch upon display of one or more optional setup screens. Associating a sound with an optional screen notifies the user that they are outside the typical pump programming screens. For example, the pump 100 can emit the sound upon display of a correction bolus screen, a basal rate confirmation screen, or some other unannounced screen displayed by the pump.
Some screens programmed into the pump revert back to a home screen after a predetermined period of time elapses. A user relying on sounds to navigate through the screens will want to know when this occurs. For such screens, the pump 100 can emit a second sound which is either the same as or different from the first sound associated with the screen so as to signify that such a reversion will take place. In one embodiment, the pump 100 emits three sounds thirty seconds before the reversion takes place. In such an embodiment, the pump can also optimally emit a single sound fifteen seconds before the reversion takes place. Additional sounds of varying pitch, length, or occurrence can be used as well. For example, the same sound can be used for multiple screens, but be repeated a different number of times to indicate the occurrence of one screen or the other.
Sounds are also associated with the up and down keys 142, 144 on the pump 100 to assist in setting pump delivery rates, times, and other settings. A first sound, different from the home screen and menu screen sounds described above, is associated with the up key 142. A second sound, different from this first sound and also different from the home screen and menu screen sounds, can be associated with the down key 144. The pump emits the first or second sounds when the up key 142 or down key 144 is depressed, respectively. In one embodiment, the sound associated with the up key is of a higher pitch than the sound associated with the down key. In another possible embodiment, the up key 142 or down key 144 repeats operation when held in a depressed position by a user. In this embodiment, the sound associated with the selected key 142, 144 repeats for each instance in which operation of the key repeats. In a further embodiment, sounds of increasing pitch are associated with numerical values scrolled through using the up and down keys, such that lower values are associated with sounds of a lower pitch, and higher values are associated with sounds of a higher pitch.
When scrolling through a range of values to select a setting in a pump, at least two implementations are possible with respect to the boundaries of each range. In one implementation, pressing the up key 142 at the top of the range will cause the pump value to wrap around, to the lowest value in the range. Likewise, pressing the down key 144 at the bottom of the range will cause the pump value to wrap around to the highest value in the range. In a second implementation, pressing the up key 142 at the top of the range or the down key 144 at the bottom of the range will have no effect, causing the pump setting to remain at that maximum or minimum value. In an embodiment in which the wrap around implementation is used, a sound is emitted by the pump 100 when either one of the up or down keys 142, 144 is depressed and the wrap around condition occurs, which is different from the sound emitted when either of the up or down keys 142, 144 are depressed and the condition does not exist. This sound notifies a user that the wrap around condition has occurred without the need for visual confirmation. In an embodiment in which the “wrap around” implementation is not used, a sound is emitted by the pump 100 when a user presses the up or down key 142, 144 which is different from the normal sound emitted when one of the keys is depressed. This second sound notifies a user that depressing that key had no effect, again, without the need for visual confirmation. In various additional embodiments in which either the wrap around implementation is or is not used, the unique sound which occurs at the boundary of the range can be different if at the top of the range or at the bottom of the range. In other embodiments, additional unique sounds can be used to denote a position within the range scrolled through. For example, the pump 100 can emit a unique sound each time a value is reached that is a multiple of 10. Unique sounds for each multiple of 10, or other notable positions within the range can be used as well.
Sounds are further associated with one or more alerts and/or alarms occurring in the pump 100. These sounds can be customized so that the user hears a familiar sound upon occurrence of a specific event or alarm. For example, a missed meal alarm can be associated with a dinner bell or some other sound. In a possible embodiment, the pump emits sounds, such as numerical values or messages, in Morse code or some other audibly encoded format.
The combination of all of the sounds for the screens, menus, and keys allows a user to program the pump 100 without relying on either visual confirmation using the pump screen or otherwise having to accurately count the number of times which a key is depressed. In a possible embodiment, one or more of these sound features can be disabled. For example, some or all sounds can be disabled if a user selects the vibrate option in the choose-alert field 214 described above.
F. Pump History
Referring to 
The pump 100 can be programmed to track many different types of historical information, to present the historical information in many different ways, and to provide different ways to access historical information. In one possible embodiment, the historical information that the pump 100 tracks includes:
In one possible embodiment, as used herein total daily dose, also referred to as Total Daily Dose or TDD, refers to the total amount of insulin delivered during a single day including the amount of insulin delivered as a correction bolus. Other embodiments might include the amount of insulin delivered as a correction bolus in the total daily dose of insulin.
To customize how the historical information is displayed on the pump 100, the user selects the History menu item from the Personalize submenu 222. The pump 100 indexes to a delivery-summary field 264, which is placed in focus. The user scrolls to and selects the desired yes or no value. The yes value enables the Delivery Summary menu item in the History submenu 290 (
Upon selecting the yes or no value in the delivery-summary field 264, focus indexes to an average-delivery-summary field 266, in which the user scrolls to and selects either a yes value or a no value. The yes value enables the Average Delivery Summary menu item in the History submenu 290, and the no value disables the Average Delivery Summary menu item in the History submenu 290. In one possible embodiment, the Average Delivery Summary displayed under this menu item includes the average daily total for a predetermined number of days for the aggregate insulin delivered by the pump as well as the amount of insulin broken down by insulin delivered as a meal bolus, insulin delivered to counteract estimated carbohydrates consumed by the user (if the carbohydrate estimator is used), delivered as a correction bolus, and delivered according to basal delivery protocols.
Upon selecting the yes or no value in the average-delivery-summary field 266, focus indexes to a basal-as-percent-of-TDD field 268. In one possible embodiment, basal as a percent of TDD is the amount of insulin delivered by the pump 100 according to a basal protocol as a daily percent of the total insulin delivered by the pump 100. The user selects whether to display the Basal as a Percent of TDD menu item in the History submenu 290 using a procedure similar to that described for the Delivery Summary. Under this menu item, the pump 100 lists the total daily amount of insulin delivered as a basal as a percent of the total daily dose of insulin delivered. In an alternative embodiment, the pump 100 lists the total daily amount of insulin delivered as a bolus as a percent of the total daily dose of insulin delivered. In various embodiments, the bolus as a percent can be listed as the meal bolus as a percent of the total daily dose of insulin delivered, correction bolus as a percent of the total daily dose of insulin delivered, or total bolus as a percent of the total daily dose of insulin delivered. The pump 100 then indexes focus to an average-basal-as-percent-of-TDD field 270. In one possible embodiment, average basal as a percent of total daily delivery (TDD) is the amount of insulin delivered by the pump 100 according to a basal protocol as an average daily percent over a predetermined number of days of the total insulin delivered by the pump 100. The user selects whether to display the Avg Basal as a Percent of TDD menu item in the History submenu 290 using a procedure similar to that described for the Delivery Summary. The pump 100 lists the average basal as a percent of the total daily delivery under this menu item.
The pump 100 then indexes focus to a bolus-history field 272. In one possible embodiment, the Bolus History is the date, time, and amount of each bolus delivered. The user selects whether to display a Bolus History menu item in the History submenu 290 using a procedure similar to that described for the Delivery Summary. The pump 100 lists the pump's 100 Bolus History under the Bolus History menu item.
The pump 100 then indexes focus to an edit-display-of-more-history field 274. The user scrolls to a yes value or a no value as desired and then activates the next function. If the user selects the no value, the pump returns to the Personalize submenu 222. If the user selects the yes value, the focus indexes to a carbohydrate-ratio field 276 in which the user scrolls to a yes value or a no value as desired and activates the Next function. Selecting the yes value causes the pump 100 to display a Calc 500 Rule menu item in the history submenu 290 and to display the calculated carbohydrate ratio. The pump indexes focus to a 500-rule-factor field 278 when the user selects yes in the 500-rule-factor field 276. The user then scrolls to the desired 500-Rule factor to use in various calculations and activates the Next function. In one possible embodiment, the potential factors are in the range from 400 to 600 in increments of 15. The pump 100 then indexes focus from the 500-rule-factor field to an average-carb-ratio field 280. Selecting the no value in the 500-Rule-factor field 276 disables display of the Calc 500 Rule menu item in the History submenu 290 and causes the pump 100 to index directly from the 500-rule-factor field 276 to the average-carb-ratio field 280.
Within the average-carb-ratio field 280, the user scrolls to and selects either a yes value or a no value. If the user selects the yes value, the pump 100 will enable an Avg Calc 500 Rule menu item in the History submenu 290. Under the Avg Calc 500 Rule menu item, the pump displays the average carbohydrate ratio for a predetermined number of days. In one possible embodiment, the pump 100 calculates the average carbohydrate ratio for a 7-day period. Upon selecting the yes or no value, the pump indexes focus to a correction-factor field 282.
In other embodiments, the pump calculates the average carbohydrate ratio for periods other than 7 days. For example, the range could be in the range from 2 to 90 days. In another possible embodiment, the pump 100 calculates the average carbohydrate ratio for however number of days it stores historical data. In yet another embodiment, the user can select a predetermined number of days over which to calculate and average the carbohydrate ratio.
If the user selects the yes value in the correction-factor field 282, the focus indexes to an 1800-rule-factor field 284. The user then scrolls to and selects the desired 1800-Rule factor to use in various calculations. In one possible embodiment, the potential 1800-Rule factors are in the range from 1500 to 2200 in increments of 100. The pump then indexes focus to an average-correction-factor field 286. Selecting the no value in the correction-factor field 282 disables display of the Calc 1800-Rule menu item in the History submenu 290 and causes the pump to index directly from the correction-factor field 282 to the average-correction-factor field 286. Within the average-correction-factor field 286, the user scrolls to and selects a yes value or a no value. If the user selects the yes value, the pump 100 will enable the Avg. Calc 1800 Rule menu item in the History submenu 290. Under the Avg; Calc 1800 Rule menu item, the pump 100 displays the average correction factor for a predetermined number of days. In one possible embodiment, the pump 100 calculates the average correction factor for a 7-day period. Upon selecting the yes or no value, in the average-correction-factor field 286, the pump indexes focus to a complete-history field 288.
In other embodiments, the pump calculates the average correction factor for periods other than 7 days. For example, the range could be in the range from 2 to 90 days. In another possible embodiment, the pump 100 calculates the average correction factor for however number of days it stores historical data. In yet another embodiment, the user can select a predetermined number of days over which to calculate and average the correction factor.
Within the complete-history field 288, the user scrolls between either a yes value or a no value. The user selects yes to enable a Complete History menu item in the History submenu 290 and selects the no value to disable the Complete History menu item. Upon selecting either the yes or no value, the pump returns to the Personalize submenu. Under the Complete History menu item, the pump displays the complete body of historical information stored in RAM 116.
Referring now to 
If the user selects Delivery Summary, the pump indexes to a Delivery Summary 292 that has a date field 294 in which the current date is listed and a Total field in which the total number of insulin units delivered is listed, a Meal Bolus field in which the number of insulin units delivered as a meal bolus is listed, a Carbs field in which the total number of carbohydrates that the user entered as an estimate of carbohydrate consumption is listed, Corr. Bolus field in which the total number of insulin units delivered as a correction bolus are listed, and a Basal field in which the total number of insulin units delivered according to the basal protocols employed by the pump are listed.
The user can scroll through dates in the date field 294 and see this historical information for dates other than the current date. In one possible embodiment, the user can scroll through the seven different dates, including the current date and the six previous dates. When the user scrolls to a different date, the pump automatically updates the historical delivery information relating to delivery that occurred on the date now listed in the date field. In an alternative embodiment, the user can scroll through the previous 90 days of data. In yet another possible embodiment, the user can scroll through however many days of data are stored on the pump 100.
If the user selects the Avg Delivery Summary menu item in the History submenu 290, the pump 100 indexes to a display 296 entitled “7 Day Average,” 293 and displays the same fields (Total field, Meal Bolus field, Carbs field, Corr. Bolus field, Basal field) as the Delivery Summary display 292. However, rather than daily totals, the fields present that average number of insulin units delivered over a predetermined number of days. Additionally, in place of the date field 294, the screen for the Avg Delivery Summary presents an avg-over field 298, which contains the number of days for which the historical data is being averaged. The user can change the number of days by scrolling up or down using the up or down keys, respectively. In one possible embodiment, the number of days that can be averaged are in the range from 2-30. In another possible embodiment, the number of days that can be averaged are in the range from 2-90 days. In yet another possible embodiment, the number of days that can be averaged are in the range from 2 days to however many days of historical data are stored on the pump 100. After scrolling to a new number of days to average, the user activates an Update Function 300 and the pump 100 recalculates the averages.
If the user changes the number of days over which the average data is calculated, the title “7 Day Average” 293 changes to “X Day Average,” where X is the selected number of days over which the data is averaged.
If the user selects the Basal as % of TDD item menu from the History submenu 290, the pump 100 will display a “Basal as % of TDD” display (not shown) and present the percent of total insulin delivered by the pump according to the basal delivery protocols on any given day. The Basal as % of TDD display will present a date field in which the user can change the day for which the historical information is presented in a manner similar to the Delivery Summary display 292 as described above.
If the user selects the Avg Basal as % of TDD item menu from the History submenu 290, the pump 100 will display an “Avg Basal as % of TDD” display (not shown) and present the average percent of total insulin delivered by the pump 100 according to the basal delivery protocols for a predefined number of days. The Basal as % of TDD screen will display an avg-over field 298 in which the user can change the number of days for which the historical information averaged in a manner similar to the 7 Day Summary display 296 as described above.
If the user selects Calc 500 Rule, the pump will index to a “Carb Ratio—500 Rule” display and present a table of information. In each row of the table, the pump will list a date and the calculated carbohydrate ratio for that date. The carbohydrate ratio is calculated by dividing the 500-Rule factor by the total number of insulin units delivered for that day. In one possible embodiment, the pump 100 will calculate and list the carbohydrate ratio for 30 days and the user can scroll through those values using the up and down keys. However, other embodiments will calculate and list the carbohydrate ratio for any other number of days.
If the user selects Avg Calc 500 Rule, the pump 100 indexes to an “Avg Carb Ratio—500 Rule” display. The pump 100 calculates and presents the average carbohydrate ratio for a predetermined number of days. The “Avg Carb Ratio—500 Rule” display includes an avg-over field 298 in which the user can change the number of days for which the average carbohydrate ratio is averaged in a manner similar to the “Avg Delivery Summary” display as described above.
If the user selects Calc 1800 Rule, the pump 100 will index to a “Correction Factor—1800 Rule” display and present a table of information. In each row of the table, the pump 100 will list a date and the calculated correction factor for that date. The correction factor is calculated by dividing the 1800-Rule factor by the total daily dose of insulin required to maintain the user blood sugar level in an acceptable range. In one possible embodiment, the pump 100 will calculate and list the correction factor for 30 days and the user can scroll through those values using the up and down keys 142 and 144. However, other embodiments will calculate and list the correction factor for other numbers of days.
If the user selects Avg Calc 1800 Rule, the pump 100 indexes to an “Avg Correction Factor—1800 Rule” display. The pump 100 calculates and presents the average correction factor for a predetermined number of days. The Avg Correction Factor—1800 Rule screen includes an avg-over field 298 in which the user can change the number of days for which the average correction factor is averaged in a manner similar to the “Avg Delivery Summary” display as described above.
G. Basal Rate Test
In an exemplary embodiment, the insulin pump 100 performs basal testing to determine a proper basal rate for a user of the pump. The basal rate for a pump is the rate at which the pump delivers insulin to a user, and in the exemplary embodiment correlates to the rate at which, independent of meals, the user requires insulin for normal metabolism, based on the user's particular metabolic need for insulin. The user's metabolic need for insulin is determined by testing under a controlled set of circumstances. Basal rate testing aborts under a number of circumstances, for example due to delivery of a correction bolus or a meal bolus as described herein. Also, unusual insulin levels, such as levels falling very far outside of a safe range, can cause interruption of a basal rate test or invalidation of test results for user safety reasons. A blood glucose level that is too high or too low is unsafe to the tested user and will cause the pump 100 to abort the basal rate test. Likewise, an initially high or low blood glucose level or high level of insulin on board can prevent the start of a basal rate test. Prior to and during the basal rate tests, the pump 100 notifies a user of proper behaviors for a basal rate test, as well as behaviors which can cause test failure, such as eating or delivering a correction bolus.
As described in more detail herein, the basal rate test is performed by measuring the user's blood glucose level at least at the beginning and end of a defined time period. The data representing the measured blood glucose levels and the time at which they were measured can be presented in different formats such as a table or graph.
If the difference between the beginning and ending blood glucose levels falls outside a predetermined range, the user's body is not using insulin at the same rate at which the pump is delivering it and the user can adjust the basal rate accordingly. Since a user's basal insulin needs can vary from hour to hour, the blood glucose level also can be measured at different points throughout the test and compared to the beginning blood glucose level. A difference between any of these intermediate blood glucose levels and the beginning blood glucose level also can indicate that the basal rate needs adjustment. In possible embodiments, this process can be performed iteratively until the difference between the beginning and ending blood glucose levels are within a desired range.
Since a user's basal insulin needs can change over time (weight gain or loss, change in fitness level, etc), basal rate testing may be performed periodically by users of the pump to ensure that the proper basal rate is programmed into the pump for basal delivery, discussed below. The basal testing, in general, enables four sets of scheduled alarms to define a basal test. Each set of alarms corresponds to a time segment during the day in which a user may want to check their basal delivery. For example, the set of alarms can represent times before or after meals, or at other times during a day, week, or other time period.
Referring now to 
Upon selection of the Start Test option, the pump 100 displays a start basal test screen 285. The start basal test screen 285 allows the user to confirm that a basal test is intended, and may display one or more messages to the user. The messages can include information about the basal test, about activities to avoid during the basal test, or other related information. The user confirms that a basal test is intended by selecting a continue option 287. If the basal test is not intended, a back option returns to the basal test submenu 281.
When the user confirms that a basal test is in fact intended, the pump 100 displays a basal test timing screen 289. The basal test timing screen 289 displays options for various predefined basal tests, such as an overnight basal test, a daytime basal test, or an evening basal test. The daytime basal test can be, for example, a morning basal test or an afternoon basal test. In the example shown, the overnight basal test is selected using the up and down keys 142, 144 and the continue option 287.
Upon selection of the desired basal test, the pump displays a listing 291 of reminder alerts which will be activated to guide the user through the basal testing process associated with that basal test. The reminder alerts represent times during the basal test process at which the user is prompted to enter their current blood glucose level. The reminder alerts can be, for example, times of the day. The listing 291 of reminder alerts can be editable by the user, so as to change the times of the day at which the reminders occur, or to change the number of reminders, as shown below in 
A start option 295 initiates the basal test. In the embodiment shown, a user can start a basal test at any time. However, the pump 100 only enters the basal testing state upon the occurrence of the first programmed reminder alert. Upon initiation of the test, the pump can optionally present one or more prompts or informational screens to the user to assist the user in running the basal rate test. The pump can advise the user as to optimal methods for performing the basal rate test, such as not eating for two hours prior to the test. In one possible embodiment, the one or more prompts includes a series of questions presented to the user prior to initiation of the test. The questions can be related to the user's health or sickness, activity or exercise level, stress levels, and variations of these factors from their normal levels. Other questions can be asked as well. In response to the answers provided by a user, the pump 100 may optionally display guidelines for taking a basal rate test or suggest postponement of the basal rate test. The questions and responsive answers can be included in a report, such as the one discussed below in conjunction with 
When the reminder alert occurs, the pump 100 prompts the user to test their blood glucose and input the blood glucose reading into the pump. Optionally, the user can select a snooze option to delay the blood glucose test by 15 minutes. The user can repeat selection of the snooze option indefinitely.
Referring to 
A basal test submenu 281′ corresponds to the basal test submenu 281 of 
If the user selects the current test status option, the pump 100 indexes focus to a test status screen 297. The test status screen 297 displays information related to the currently scheduled test. The information can include the time remaining in the test, the time of the next reminder alarm, and other information. A back option returns focus to the basal test submenu 281′.
If the user selects the end the current test option from the basal test screen 281′, the pump 100 indexes focus to an end test screen 299. The end test screen 299 asks the user to confirm that ending the test before its completion is intended. An end option 301 on the end test screen 297 confirms that the test should be aborted. A back option returns focus to the basal test submenu 281′.
If the user selects the set up testing option, the pump 100 indexes focus to a test setup screen 303. The test setup screen 303 includes navigation options to allow the user to set up a basal test and also to allow the user to set threshold blood glucose levels at which the basal test will be aborted. The user selects one of the listed tests, shown in screen 303 as “Overnight test”, “Daytime test” and “Evening test”. Upon selecting one of the tests, a blood glucose limit screen 305 provides the user with an interface for defining high and low threshold values, 307, 309. The user selects and edits the high and/or low threshold value 307, 309 using the up and down arrow keys 142, 144. A next option confirms the settings of the threshold values 307, 309, and causes the pump 100 to index focus to a basal test timing screen 287′.
The basal test timing screen 287′ corresponds to the basal test timing screen 287 of 
Default tests reside within the pump 100 and are customizable by a user. In one embodiment, the overnight test includes reminder alerts at 8:00 p.m., 11:00 p.m., 3:00 a.m., and 7:00 a.m. The daytime basal test schedule includes reminder alerts at 9:00 a.m., 12:00 p.m., 2:00 p.m., and 4:00 p.m. The evening basal test schedule includes reminder alerts at 3:00 p.m., 6:00 p.m., 9:00 p.m., and 12:00 a.m. Other times are possible as either default or customized tests as well. In one embodiment, the pump 100 does not allow editing of a basal test while the test is in progress.
The basal test terminates upon detection of any of a number of conditions. These conditions include determination that the user's current blood glucose value is outside of the range defined by the high and low threshold values, initiation of a meal bolus, initiation of a correction bolus, changing the insulin cartridge associated with the pump, changing the basal pattern, or initiation of a temporary basal rate.
If the user selects the test history option, the pump 100 indexes focus to a test selection screen 319. The test selection screen 319 prompts the user to select the type of test for which to review the test history. A test listing 323 within the test selection screen 319 displays the programmed tests and corresponding radio buttons, allowing the user to select one of the tests by using the up and down keys 142, 144. The test types include the types of tests executable by the pump, such as an overnight test, daytime test (such as a morning or afternoon test), or evening test. Each test differs by the timing of the set of reminder alerts associated with the test. Upon user selection of one of the types of tests, the pump 100 indexes focus to a test data screen 325 which displays one or more of the tests of that type which have been performed by the pump. In one embodiment, the pump 100 displays data related to the last three instances in which the test was run. In a possible embodiment, the data includes the date, the time, and the user's blood glucose level at the time of the last blood glucose test.
Referring to 
Referring back to 
In one possible embodiment of pump 100, the basal rate testing is performed by prompting a user to input blood glucose values at scheduled times during the test. In an alternate embodiment, the pump 100 communicatively links to a blood glucose sensor. In such an embodiment, the pump 100 optionally requests blood glucose level information from the blood glucose sensor at various times during the test. The various times during the test can include the scheduled times during which manual or automated blood glucose test result entry would be expected, and can also include a periodic request to a blood glucose sensor. For example, the periodic request can occur every ten minutes or some other period, and may be a user-selectable period. The pump 100 would receive the most recent test result obtained by the blood glucose sensor. In embodiments including a communicative link to a blood glucose sensor, the user need only be interrupted when an abnormal blood glucose level is detected so that appropriate corrective action is taken
H. Basal Rate Delivery
Referring to 
Selecting the Delivery menu item in the Personalize submenu 222 causes the pump to index to a Personalize Delivery submenu 302 in which the user can select the type of bolus or basal delivery protocol to edit. Selecting the Basal Program menu item causes the pump 100 to index a maximum-basal-rate field 304, which is placed in focus. Within the maximum-basal-rate field 304, the user scrolls to and selects the desired maximum basal rate. In one possible embodiment, the maximum basal rate values are in the units of u/hr and the user can scroll through values in the range from 0.5 u/hr to 36 u/hr in increments of 0.5 u/hr. When the desired maximum basal rate is selected, focus indexes to a review/edit-basal-programs field 306 in which the user selects either a yes or a no value. If the user selects the no value, the insulin pump 100 returns to the Personalize Delivery submenu 302.
If the user selects the yes value, the pump 100 indexes to a display 308 entitled “Select Program” and lists the name 310 for each of the basal programs, Basal 1, Basal 2, Basal 3, and Basal 4. A check box 312 is also displayed next to each name 310 for the basal delivery programs. If a Basal program is enabled, the check box 312 next to its name is set. If a Basal program is not enabled, the check box 312 next to its name is cleared. The name 310 of each enabled basal-delivery program is displayed as a menu item in the Basal Programs submenu 318 (
To enable or disable a basal program, the user scrolls to the desired basal program and activates the Edit function 254. The pump 100 indexes to a display 313 entitled “Basal 1,” where “Basal 1” is the name of the basal program being edited. The display has two fields, an enable field 314 and a name field 316. Within the enable field 314, the user selects either a yes value or a no value. If the user selects the no value, the pump 100 disables the basal program associated with the screen 313 (Basal Program 1 in the illustrated example) and returns to the Select Program display 308. The check box 312 for the disabled program is cleared. In one possible embodiment, if the pump 100 is actually executing the basal program that the user attempts to disable, the pump 100 will not disable the program and will present an error message stating, “You may not disable the active program.”
If the user selects the yes value in the enable field 314, the pump 100 indexes focus to the name field 316. Within the name field 316, the user can assign a custom name to the basal delivery program. In one possible embodiment, the user can scroll through names that are preloaded into the pump 100. Examples of names might include Weekday, Weekend, Sick Day, Travel, Monthly, and the generic names such as Basal 1, Basal 2, etc. When the user has scrolled to the desired name, the user activates the Next function and the pump 100 returns to the Select Program display 308. The check box 312 for the program that was just edited is set to indicate that the basal program is enabled. Additionally, the name selected in the name field 316 is displayed in the Select Program display 308 in place of the previously assigned name. The name selected in the name field 316 is also displayed as a menu item in the Basal Programs sub menu 318.
The user repeats this procedure from the Select Program display 308 for each basal program 310 for which he or she desires to change the enabled state and/or name. When the user is done changing the enabled states and program names for the various basal programs 310, the user activates the Done function 212. The pump 100 then returns to the Personalize Delivery submenu 302. As described below, the names of the enabled basal delivery programs will then appear the Basal Programs submenu 318.
In an alternative embodiment, within the display entitled “My Program X,” the user can access a spin box in which they scroll through a list of optional names and select a custom name for the enabled basal delivery programs. The selected name would then replace the generic name (e.g., Basal 1, Basal 2, Basal 3, and Basal 4 in the illustrated example) for the program associated with the display. Examples of optional names that might be loaded in the pump 100 include weekday, weekend, sick, and monthly (which is to designate a basal delivery program set for a woman's menstrual cycle).
Referring now to 
To edit a basal program, the user scrolls to and selects the desired basal program. The pump 100 indexes to a submenu 322 for which the title is the same name as the selected basal program. The menu has two menu items, an Edit menu item and a Start Using menu item. The user selects the edit menu item and the pump 100 indexes to a Summary user interface 324 that presents a table in which each row identifies a start time 326 and a scheduled delivery rate 328 for each time interval in the basal program. In the illustrated embodiment, there is a first time interval 330 having a start time and a delivery rate, a second time interval 332 having a start time and a delivery rate, and a third time interval having 334 a start time and a delivery rate. The start times are listed in a start-time field, and the delivery rates, are listed in a delivery-rate field.
To edit the start times and the delivery rates, the user activates the edit function 254 in the Summary user interface 324 and the pump 100 indexes to an Edit user interface 336 and assigns the Done function 212 to the first function key 138. Additionally, the pump 100 places focus on the delivery-rate field 340 for the first interval 330. The user scrolls to and selects the desired delivery rate. The user selects the desired delivery by scrolling to the desired value and activating the Next function 200. In one possible embodiment, the pump 100 scrolls through delivery rates in the range from 0 u/hr to 2 u/hr in increments of 0.05 units per hour. The delivery rate does not exceed the maximum delivery rate (
When the desired delivery rate is selected, the pump 100 indexes focus to the start-time field 342 for the second time interval 332. The user scrolls to and selects the desired start time. In one possible embodiment, the pump 100 scrolls through start times in increments of 30 minutes. In one possible embodiment, the start time cannot be earlier than or equal to the start time of the previous time interval and cannot be later than or equal to the start time of the next subsequent time interval. Other embodiments will implement different scrolling increments and limitations on the start time that can be selected. In another embodiment, if a selected start time is not in sequence, the pump 100 will automatically reposition the delivery intervals so they are in chronological order.
When the desired start time is selected, pump 100 then indexes focus to the delivery-rate field 340 for the second time interval 332, which the user sets using the procedures described above with respect to the first time interval 330. The user continues this procedure indexing through the start times for each of the time intervals and their associated delivery rates until the start time for each of the delivery intervals and their associated delivery rates are set. When the user is finished setting and/or editing the start times and delivery rates for the various intervals, he or she activates the Done function 212 and the pump 100 returns to the Summary Display 324.
In one possible embodiment, the first time interval 330 always starts at 12:00 midnight. In this embodiment, the last time interval will terminate at 12:00 midnight. If, within the Summary Display 324, the user highlights and selects the first time interval 330 for editing, the pump 100 indexes to the Edit display 336 and initially highlights the delivery rate 328 for the first time interval 330 rather than the start time 326. In another embodiment, however, the user can change the start time 320 for the first time interval 330. The last time interval would then extend until the start time for the first time interval 330. Additionally, within the Summary Display 324, the user can scroll to a delivery interval other than the first interval 330 and activate the Edit function 254. In this situation, the start-time field 342 for the selected interval is initially placed into focus rather than the delivery-rate field 340.
To add a time interval to the basal program, the user continues to index through all of the time intervals and associated fields until the pump generates a new delivery interval and displays the characters “--:--” 344 in the start-time field 342 of the new interval, which occurs after indexing through the delivery-rate field 340 for the last time interval. The user then scrolls through desired start times for the new time interval. After the desired start time is selected, the user activates the Next function 200 and the pump 100 indexes to the delivery-rate field 340 for the new time interval, which the user sets by scrolling through available delivery rate values. The user can then activate the Next function 200 to add yet another new time interval or can activate the Done function 212 to return to the Summary display 324. In one embodiment, the pump 100 can include up to 48 time segments, although other embodiment will include more or fewer time segments.
To delete a time interval from the basal program, the user places the start-time field 342 for the desired interval into focus and scrolls down until the time reads “--:--” 344. The user then activates the Next function and the time interval is deleted and the user either activates the Next function 200 to index to another time interval for editing or activates the Done function 212 to return to the Summary display 324.
Additionally, both the Summary user interface 324 and the Edit user interface 336 include a total field 346 in which the total insulin scheduled to be delivered over a 24-hour period for that basal program is listed. The total insulin scheduled to be delivered is calculated by multiplying the delivery rate by the length of each time interval to calculate the total insulin to be delivered for each time interval by the basal program being edited. The total insulin to be delivered for each time interval is then summed to calculate the total insulin scheduled to be delivered over a 24-hour period.
Referring to 
I. Correction Bolus
In addition to delivering a basal rate the pump 100 may administer a bolus to lower the user's blood glucose level. One possible embodiment of the pump 100 can deliver two types of boluses, a correction bolus and a meal bolus. The correction bolus delivers a dose of insulin over and above the basal rate to lower or correct the user's blood glucose level if it becomes too high. A meal bolus is a dose of insulin delivered in anticipation of consuming a meal to counteract the effects that the meal may have on the user's blood glucose.
Referring to 
Selecting the Correction Bolus menu item causes the pump 100 to display a main-menu field 388, and places it in focus. The user scrolls to and selects either a yes value or a no value. The yes value enables a Correction Bolus menu item in the main menu 190, and a no value disables the Correction Bolus menu item in the main menu 190. Upon selecting the yes or no value, focus indexes to a meal-bolus field 390 in which the user scrolls to and selects either a yes value or a no value. A yes value enables the user to set a correction bolus through the meal bolus delivery program as described below. A no value disables the ability to set a correction bolus through the meal bolus delivery program.
Upon selecting a yes or no value in the meal-bolus field 390, focus indexes to a units field 392 in which the user scrolls to and selects units for measuring blood glucose levels in either mg/dL and mmol/L. Upon selecting the units, focus indexes to a correction-bolus-factor field 394 in which the user scrolls to and selects a desired correction factor. The correction factor is the amount that the user's blood glucose drops for each unit of delivered insulin. In one possible embodiment, the user scrolls through values ranging from 5 mg/dL to 200 mg/dL (or 0.2 mmol/L to 12 mmol/L). When the desired correction factor is set, focus indexes to a target blood glucose field 393.
Additionally, the pump 100 calculates the average correction value for a predetermined number of days beginning with the previous day and extending backwards in time, and then displays 396 the average correction factor together with the correction-bolus-factor field 394. In the illustrated example, the pump 100 displays the average correction factor for the previous seven days. As discussed above, other embodiments average the correction factor over other periods of time. In yet other embodiments the user can select the period of time over which to average the correction factor.
The target blood glucose field 393 allows a user to edit or review the correction bolus blood glucose targets. An edit option 395 allows the user to optionally edit the blood glucose target values. If the user chooses to edit the blood glucose target values, they can optionally choose to set a constant target blood glucose value, or a variable target blood glucose value which changes throughout the day based on expected meal consumption, activity levels, or other factors. When the desired blood glucose targets are set or if the user chooses not to edit the blood glucose target values, focus indexes to a correction bolus adder field 397.
The correction bolus adder field 397 sets one or more correction bolus changes within the pump 100. In the field 397 shown, the correction bolus adder field prompts a user to indicate whether to increase the correction bolus delivered by the pump 100 based on the user's current blood glucose level. An edit option 399 allows the user to optionally customize the increase amount for the correction bolus based on blood glucose. The addition of insulin to the correction bolus can be a constant amount over a given threshold, can be a graduated increase based on current blood glucose, or a set of stepped increases in insulin based on blood glucose. Once one or more of the desired correction bolus adders are set, focus indexes to a duration-of-activity field 398. Within the duration-of-activity field 398, the user scrolls to and selects the duration of time over which insulin remains in the user's body. This amount will vary from user to user depending on a variety of factors including physical traits of the user and the type of insulin that is used. In one possible embodiment, the user scrolls through durations in the range from 2 hours to 6 hours. When the duration is set, the pump 100 returns to the Personalize Delivery submenu 302.
In a possible embodiment, a user selects an insulin absorption model from among multiple insulin absorption models for application by the pump 100. Insulin absorption models are used in the pump to determine the remaining insulin in a user's body a period of time after the insulin is delivered to the user, whether by a basal rate, a correction bolus, a meal bolus, or another insulin delivery method described herein. To calculate the user's insulin level, the insulin absorption model uses the programmed duration in the duration-of-activity field 398. The user optionally selects a linear or non-linear absorption model. A linear absorption model assumes a constant absorption rate of insulin into the body. A nonlinear absorption model assumes a faster absorption rate with higher insulin levels, and a lower absorption rate with lower insulin levels. The user optionally also programs a start time and tail time into the pump 100.
  
  
  
    
  
For example, if a 3 Unit bolus is delivered using this selected model, at a time one and a half hours later the model estimates that the user has 1.5 Unit remaining unabsorbed within their body.
  
  
    
  
  
Note: During Start up Time, current IOB limited to Initial Bolus Amount until the Current IOB reaches 5% of the Initial Bolus Amount. At that point, the equation used becomes:
  
    
  
  
More generally, the tail can be affected by changing the percentage of insulin on board at which the tail time occurs. In such an instance, the above equation becomes:
  
    
  
  
  
    
  
  
  
Additional methods for varying the absorption model can be incorporated into the pump 100 as well. A general method for varying insulin absorption would include incorporation of factors which can affect the rate at which the user would actually absorb insulin, such as due to boluses, activity, or other factors. In one example embodiment, the pump 100 varies the insulin absorption model based on a bolus amount. In a further embodiment, the pump 100 varies the insulin absorption model based on both a bolus amount and the user's body weight. In a further embodiment, the pump 100 varies the insulin absorption model based on the user's anticipated near-future activity level. Other factors can include the user's age, fitness level, body mass index or other user entered health information. In yet a further embodiment, the pump varies the insulin absorption model based on the ambient temperature experienced by the user. In further embodiments, the pump 100 varies the insulin absorption model based on other patient-specific parameters.
Referring now to 
  
    
  
  
and displays the recommended correction bolus in the recommend-bolus field 402. The user can adjust the recommended correction bolus by incrementing the recommend amount up or down using the up and down keys 142 and 144, respectively.
When the desired correction bolus is displayed in the recommend-bolus field 402, the user activates the Deliver function 384 and the pump 100 displays a banner 408 in the screen stating the bolus is delivering and the amount of the bolus. The pump 100 then returns to the home page 152 after delivery of the bolus is complete.
Additionally, the pump 100 has a duration of activity program that determines whether any bolus that was previously delivered is still active. If a previous bolus is still active, the pump 100 calculates the estimated amount of insulin that is still active in the patient's body. In a linear system the pump uses an equation analogous to the Insulin on Board equations above:
  
    
  
  
where Residual Insulin is the amount of insulin from a previous bolus still active within the user's body, Last Bolus Amount is the amount of the last bolus, Duration is the duration of insulin, which is set as described in conjunction with 
The pump 100 then calculates an adjusted correction bolus according to the equation:
  
    
  
  
The pump 100 then displays the reduced recommended corrected bolus in the correction-bolus field 402 rather than the recommended correction bolus. The display also presents a banner (not shown) with the recommended-bolus field that indicates that the recommended bolus is reduced to accommodate residual bolus insulin that is still working in the user's body. An example of such a banner is “*reduced for insulin on-board”.
In an alternative embodiment, when the user selects the Correction Bolus menu item from the main menu 190, the pump 100 indexes to a display that presents the correction factor, displays the user's target blood glucose level, and displays a current-blood-glucose field that prompts the user to enter the user's current blood glucose level. The user scrolls to and selects their current blood glucose level. The pump 100 then calculates the appropriate amount of the bolus to lower the user's blood glucose level to the target value and then presents the verification display. In this embodiment, the pump 100 calculates the desired drop in the glucose level, and the pump 100 calculates the correction bolus according to the equation:
  
    
  
In one possible embodiment, the pump 100 varies the correction bolus amount based not only upon the time of day, but also the current blood glucose of the user. The user can set one or more rules in the pump 100 to change the correction factor applied. These rules can be based on a rules framework programmed into the pump 100. For example, the pump can include an additive rule framework of the form “If blood glucose is above X, add Y %”. The user could create a number of personalized rules of the same form, by entering a blood glucose setting and a percentage value. For example, by entering 250 and 20%, respectively, the user tells the pump 100 to add 20% to the bolus if the user's blood glucose level is over 250. In a possible embodiment, the effect of these defined rules can be added to the correction bolus after it is initially calculated using equation (4), above. In a second possible embodiment, the correction factor is altered to take into account whether or not a rule applies at the time the correction bolus is calculated.
A plurality of rules can be created in the pump 100 with differing glucose values and percentages. In one possible embodiment, up to four rules can be programmed into the pump 100. Additionally, the added insulin delivered by the pump 100 can be displayed on the pump screen, such as upon selection of the Correction Bolus menu item in the main menu 190. These equations can change based on the insulin absorption model selected.
J. Negative Meal Bolus
Similar to the correction bolus, the pump 100 can suggest a negative meal bolus, which is a suggested amount of carbohydrates for the user to consume. A negative meal bolus is suggested by the pump when the user's blood glucose level is too low or potentially will become too low due to the current level of insulin on board. The negative meal bolus is complementary to the correction bolus, and the two operate to maintain the user's blood glucose level within a safe range.
In a possible embodiment, when the user selects the Correction Bolus menu item from the main menu 190 and the pump 100 determines that the user's blood glucose is below the target level, the pump indexes to a display that includes a notification message indicating to a user that their blood glucose level is below their target blood glucose level. In a further embodiment, the pump 100 includes a negative meal bolus target analogous to the correction bolus target, which is a target level to which the negative meal bolus is configured to aim. The negative meal bolus target can be a different value from the correction bolus target. For example, the correction bolus target can represent a higher level within a range of safe blood glucose levels, such as 130 mg/dl, and the negative meal bolus target can represent a lower level within the range, such as 90 mg/dl. In a possible embodiment, the correction bolus target and negative meal bolus target are user-selectable.
In a possible embodiment, the pump 100 deactivates the negative bolus feature based on the occurrence of other events within the pump. For example, the negative bolus feature can be disabled during an extended bolus, or for a predetermined or customizable period of time after delivery of a meal bolus, as described below.
The negative meal bolus feature allows the pump 100 to optionally display the amount of carbohydrates necessary to bring the user's low blood glucose back to the target level, consistent with the equations described above. In an embodiment of the pump 100 incorporating a food database as described below, the pump optionally displays one or more foods appropriate for treating low blood glucose which contain at least the required number of carbohydrates. In such an embodiment, the pump also optionally displays a minimum serving size to be consumed to reach the required number of carbohydrates.
The pump 100 also optionally displays the user's current blood glucose level or the user's target blood glucose level. The pump 100 optionally executes a meal bolus program which, in one aspect, can calculate and display the number of carbohydrates to bring the user's blood glucose from its current level to the user's target level. The calculated number of carbohydrates is editable by the user, although the number entered by the user may be replaced by the number calculated by the pump 100 if the user-entered value is lower.
Once the number of carbohydrates is accepted, raised, or lowered by the user, one of three things may happen. If the user accepts the calculated bolus, the pump 100 applies a “zero” bolus. If the user lowers the number of carbohydrates, the pump 100 displays a message indicating that the user's blood glucose would still be below target. If the user raises the number of carbohydrates, a meal bolus program, such as those discussed below, calculates the amount of insulin necessary to counteract the extra carbohydrates. This insulin can be delivered to the user at the time the user selects the number of carbohydrates to consume, or can optionally delay the insulin bolus for an amount of time sufficient to ensure that the user's blood glucose level increases quickly back to a normal level. In a possible embodiment, the pump 100 delays 15 minutes before delivering additional insulin to allow the user a chance to consume some carbohydrates and raise their blood glucose level. In a further possible embodiment, the software prompts the user to perform a blood glucose test to confirm that the bolus is needed. In such an embodiment, the software allows the user to confirm or cancel the bolus as appropriate.
In an embodiment of the pump 100 including a food database, as described below, the pump 100 can display one or more foods that are good to eat when blood glucose is abnormal, i.e. too high or too low. Additionally, foods which are well-suited for consumption in anticipation of exercise or on sick days can be displayed as well. The pump 100 can present to a user a list of foods which are appropriate under other circumstances as well.
K. Meal Bolus Programs
A meal bolus is a bolus that the pump delivers in anticipation of a meal that the user plans to consume. In one possible embodiment, the amount of the meal bolus is based on how much insulin is required to work against the carbohydrates that the user plans to consume. There are several types of meal bolus programs that the pump 100 may include. One type is a standard bolus in which the pump 100 delivers the meal bolus a predetermined time prior to when the user consumes the meal or snack. The standard program delivers the bolus at the maximum rate that the pump 100 is able to deliver it. As explained below, the standard program can be set for programming in either units of insulin or number of carbohydrates. Another type of meal bolus that the pump 100 can be programmed to deliver is an extended bolus in which the pump 100 delivers the meal bolus over an extended period. Yet another type of meal bolus that the pump 100 can be programmed to deliver is a combination bolus in which the pump 100 immediately delivers a portion of the meal bolus and the balance of the meal bolus over an extended period of time.
Referring to 
The pump 100 then prompts 416 the user to select whether to enable an extended bolus program and to display an Extended Bolus menu item within a Meal Bolus submenu 434 (
If the pump 100 is preprogrammed with one or more custom meal boluses, the pump prompts 422 the user to select whether to review or edit a custom bolus. If the user does not want to review or edit a custom bolus, the user selects no and the pump 100 returns to the Personalize Delivery submenu 302. If the user selects yes, the pump 100 presents a display 424 entitled “Custom Bolus,” which lists the names 426 of the available custom meal bolus programs. The display 424 also presents a check box 428 for each of the custom meal bolus programs 426. If a custom meal bolus program 426 is enabled, the check box 428 is set. If a custom meal bolus program 426 is not enabled, the check box 428 is cleared. When a custom meal bolus is enabled, it is displayed in the Meal Bolus submenu 434 as a separate menu item. If the custom meal bolus program is not enabled, it is not displayed in the Meal Bolus submenu 434 and the user cannot execute the program.
To enable or disable a meal bolus program, the user scrolls to the desired custom meal bolus program and activates the Edit function 254. The pump 100 presents a display 430 entitled “Custom Bolus: X,” where X is the name of the selected custom meal bolus program. In the illustrated example, the title of the display is Custom Meal Bolus: Pizza”. Upon activating the Edit function 254, the pump 100 prompts 432 the user to select either a yes value or no value. If the user selects the yes value, the pump 100 enables the custom meal bolus program 426 and displays the name of the program as a menu item in the Meal Bolus submenu 434. If the user selects the no value, the pump 100 disables the custom meal bolus program 426 and does not display the name of the program as menu item in the Meal Bolus submenu 434. After the yes or no value is selected, the pump 100 returns to the “Custom Bolus” display 424.
The user repeats this procedure from the “Custom Bolus” display 424 for each custom meal bolus program 426 for which they desire to change the enabled state. When the user is done changing the enabled states for the available custom meal bolus programs 426, the user activates the Done function 212 in the “Custom Bolus” display 424. The pump 100 then returns to the Personalize Delivery submenu 302.
Additionally, in one possible embodiment, if there are no custom meal bolus programs available for the user to enable, the pump 100 automatically returns to the Personalize Delivery submenu 302 after the user instructs 420 the pump 100 whether to enable an Audio Bolus.
In one possible embodiment, a user can program the pump 100 to include a database of foods for which to configure delivery of a custom bolus. A user of the pump 100 selects one or more foods from the database of foods to form a meal from which the user's carbohydrate intake is calculated. The database of foods can include a number of records associated with food entries. The food entries each represent a food or a combination of foods. The record includes fields for a name of the food entry, the amount of carbohydrates contained in the food or foods represented by the food entry, and a default serving size for the food entry.
Each entry in the food database is a food entry. The food entry has a number of fields within it. One field can be a name field, and will be the information displayed to the user representing the name or names of the food displayed. The food entries can represent specific foods tracked by a user of the pump. The food entries can also represent meals including a variety of foods typically eaten by the user, and would include combinations of types of foods. Examples of foods displayed could be “pizza” or “apple”, or could also be “Chicken, Potato, and Green Beans” or some other combination commonly consumed by the user, who may wish to store the combination so that they do not have to select each food and serving size each time they consume the common meal.
Additional fields include a carbohydrate field and a serving size field related to the foods displayed. The carbohydrate field contains information related to the number of carbohydrates are contained in the foods, given a default serving size stored in the serving size field. The carbohydrate field and the serving size field are customizable by a user, and can be set independently of each other as well.
In a possible embodiment of the food database, nutritional information is stored in the food database and associated with the one or more food items. The additional nutritional information can be stored in additional fields associated with the food entry, or can be stored separately and referenced by the food entry. The nutritional information includes, for example, additional carbohydrate information, fat information, or protein information. Other nutritional information can be stored as well.
In a further possible embodiment of the food database, the pump 100 stores metadata related to one or more user conditions in conjunction with one or more of the foods in the food database. The pump can be configured to display specific foods upon occurrence of the conditions. These conditions include, for example, such as activity levels, sickness, high or low blood glucose levels, or other conditions. For example, in the case of a low blood glucose level, a metadata tag may be associated with a food entry in the food database “orange juice” which will be displayed to the user upon detection of a low blood glucose level. Optionally, the pump 100 displays a specific amount of orange juice to consume, as calculated using the negative meal bolus feature, described herein.
In one embodiment, the food database includes 500 or more foods, categories of foods, and/or meals. In a possible embodiment, the food database is a subset of a larger food database that is stored on a computing system that can be interfaced with the pump 100, such as the system shown below in 
Referring now to 
Upon activation of the next option 413, the pump 100 indexes focus to a servings screen 409. The user selects the number of servings, or “serving size” of the selected food entry that will be consumed, using a servings field 417 and the up and down keys 142, 144. The user optionally also defines the default amount of food referred to as the “serving size”, such that a single serving of the food represents the amount of the food that user eats in a single meal. In one particular implementation, the selectable number of servings of the food can be between 0.5 and 3 servings, based on the default food amount. Upon selection of a serving size using a select option 419, the pump calculates the number of carbohydrates to be consumed for the selected food entry, and indexes focus to a confirmation screen 421. The confirmation screen 421 displays the food or foods selected, as well as a number of informational items related to nutritional aspects of the food, including the serving size of the food, the number of carbohydrates, and the amount of fiber, protein, and fat included in the food. The informational items correspond to the information stored in the food database and associated with the food entry. Other information can be displayed as well, such as by incorporating additional fields into each food entry in the food database. The user can select an add option 423 to add additional food entries to the current meal using the food database, or confirm that the food entries selected represent the meal desired using a set option 425. Upon user confirmation using the set option 425, the pump 100 indexes focus to a delivery screen 427. The delivery screen 427 displays overall meal information, including a total number of carbohydrates consumed, a listing of the foods to be consumed, and other optional nutritional or serving size information. Upon selection of a home option 429 the pump indexes focus to a carbohydrate delivery screen 200, such as are shown below in 
If a food is not selected from the food database, the user can directly enter a number of carbohydrates, as illustrated in 
In the embodiment shown in 
  
If the pump 100 is programmed to enable administration of a correction bolus through the Meal Bolus program, the pump 100 prompts 436 the user to enter the number of units to deliver as a meal bolus. The user then activates the Deliver function 384 and the pump 100 prompts 438 the user to enter the amount by which they want to lower their blood glucose level. In one possible embodiment, the user enters the amount by scrolling through values in units of either mg/dL or mmol/L. When the desired drop in blood glucose is entered, the user activates the Next function 200, which causes the pump 100 to calculate a recommended bolus amount and to display a user interface with the banner 439 stating “Bolus to Lower BG X plus Y meal bolus.” X is the amount the user entered to lower the blood glucose level, and Y is the amount of the meal bolus entered by the user.
The user interface also displays the recommended bolus amount 440 to deliver. The recommended bolus amount 440 is the recommended correction bolus as calculated above, plus the amount of the meal bolus. This feature allows the user to correct a high blood glucose level and deliver additional insulin to work against carbohydrates that they plan to consume. The user can adjust the recommended bolus amount by increasing or decreasing the recommended bolus amount by scrolling up or down. In one possible embodiment, the user scrolls in increments of 0.5 units. Once the desired bolus amount is set, the user activates the Deliver function 384.
Activating the Deliver function 384 causes the pump 100 to deliver the correction bolus. The pump 100 will begin to deliver the bolus and display a banner 408 stating that the bolus is being delivered. An example of such a banner is “Bolus X is Delivering”, where X is the bolus amount. When delivery of the bolus is complete, the pump 100 returns to the home page 152.
In an alternative embodiment, when the pump 100 is programmed to enable administration of a correction bolus through a Meal Bolus, the pump 100 displays a user interface entitled “Current Blood Glucose.” The pump 100 calculates the current correction factor and displays the correction factor in the user interface. The pump 100 also displays the target blood glucose level. The user then enters his or her current blood glucose level in units of either mg/dL or mmol/L, by scrolling through a range of values until the current blood glucose level is displayed. In this embodiment, the target blood glucose level and the appropriate units are programmed into the pump 100 when personalizing the correction bolus program as described herein. After the user enters the current blood glucose level, the user activates the Next function 200 and the pump 100 calculates a recommended bolus amount, using the equations set forth above, and adds it to the meal bolus. The pump 100 displays the user interface with the banner “Bolus to Lower BG X plus Y Meal Bolus” 439. The user can then change the amount 440 and activate the Deliver function 384 to begin delivery of the bolus as described above.
Additionally, in one possible embodiment, the pump 100 adjusts the recommended bolus based on the meal bolus or the meal bolus plus the correction bolus to accommodate insulin on board or residual insulin that is still working within the user's body. In this embodiment, the amount of the adjusted correction bolus is adjusted using the equations described above in conjunction with the duration-of-activity function. The methods of adjusting the bolus amount for insulin on board are described above.
Referring to 
The user enters the carbohydrate ratio by scrolling through values in a predetermined range such as from 0 gm/u to 50 gm/u in increments of 1. When the desired number of carbohydrates is set, the user activates the Next function 200 and the pump 100 prompts 446 the user to set the increment by which the user would like to be able to scroll through the number of carbohydrates when programming the pump 100 to deliver a meal bolus. In one possible embodiment, the user can set the desired increment between 1 and 15 grams.
The pump 100 prompts 448 the user to enter the maximum bolus that can be delivered. In one possible embodiment, the user scrolls through values in the range between 0 units and 40 units of insulin in increments of 1 until the desired value is highlighted. The pump 100 then prompts 450 the user to enter the increments in which the user can select the actual bolus to be delivered. In one possible embodiment, the user scrolls between 0.05 units, 0.10 units, 0.50 units, and 1.00 units and activates the Next function 200.
The pump prompts 452 the user to select whether to enable an extended bolus program and to display an Extended Bolus menu item within the Meal Bolus submenu 434. The extended bolus program is enabled by highlighting and activating a yes value and not enabled by highlighting and selecting a no value. The pump 100 also prompts 454 the user to select whether to enable a combination bolus program and to display a Combo Bolus menu item within a Meal Bolus submenu 434. The combination bolus program is enabled by highlighting and activating a yes value and not enabled by highlighting and selecting a no value. The user activates the Next function 200 to index through these prompts 452 and 454. The pump 100 then prompts 456 the user to choose whether to enable an audio bolus program. The user selects a yes value to enable the audio bolus program and selects a no value to not enable the audio bolus program and then activates the next function 200.
If the pump 100 is preprogrammed with one or more custom meal boluses, the pump 100 then prompts 458 the user to select whether to review or edit a custom bolus. If the user does not want to review or edit a custom bolus, the user selects no and the pump 100 returns to the Personalize Delivery submenu 302. If the user selects yes, the pump indexes to a display 460 entitled “Custom Bolus,” which lists the names 462 of the available custom programs. In the illustrated example, there are four custom boluses available on the pump, Breakfast, Lunch, Dinner, and Snack.
The screen also presents a check box 464 for each of the custom meal bolus programs 462. If a custom meal bolus program is enabled, the pump 100 sets the check box 464. If a custom meal bolus program is not enabled, the pump 100 clears the check box 464. When a custom meal bolus program is enabled, it is displayed in the Meal Bolus submenu 434 as a separate menu item. If the custom meal bolus program is not enabled, it is not displayed in the Meal Bolus submenu 434 and the user cannot execute the custom meal bolus program.
To enable or disable a custom meal bolus program, the user selects the desired custom meal bolus program and activates the Edit function 254. The pump 100 indexes to a display 466 entitled “Custom Bolus: X,” where X is the name 462 of the selected custom meal bolus program. In the illustrated example, the title of the display 466 is “Custom Meal Bolus: Breakfast”. The user interface 466 displays 468 a default number of carbohydrates for the custom bolus. For example, the user can create a custom breakfast meal bolus that would have a default value of 90 carbohydrates, equal to the number of carbohydrates in a bowl of cereal and milk normally consumed by the user at breakfast. The pump also prompts 470 the user to select either a fixed carbohydrate ratio or the previously entered carbohydrate ratio schedule. If the user selects a fixed carbohydrate ratio, the fixed carbohydrate ratio is used with the custom meal bolus program. The value of the carbohydrate ratio 468 may or may not be the same value as the carbohydrate ratio 444. The user enters the carbohydrate ratio by scrolling through values in a predetermined range such as from 0 gm/u to 50 gm/u in increments of 1. When the desired number of carbohydrate ratio is set, the user activates the Next function 200 and the pump 100 returns to the “Custom Bolus” submenu 434.
The user repeats this procedure from the “Custom Bolus” display 460 for each custom bolus program for which they desire to change the enabled state. When the user is done changing the enabled states for the available custom meal bolus programs, the user activates the Done function 212. The pump 100 then returns to the Personalize Delivery submenu 302.
Additionally, in one possible embodiment, if there are no custom meal bolus programs available for the user to enable, the pump 100 automatically returns to the Personalize Delivery submenu 302 after the user instructs 456 the pump 100 whether to enable an Audio Bolus.
  
The user selects the Standard Menu item and the pump 100 prompts 472 the user to enter the number of carbohydrates that the user plans to consume. The user interface also displays the current carbohydrate ratio 473. The user sets the desired number of carbohydrates. In one possible embodiment, the user scrolls through carbohydrates in the range from 0 grams to 225 grams.
The user then activates the Next function 200 and the pump 100 calculates a recommended size for the meal bolus using the equation:
  
    
  
  
The pump 100 displays 474 the recommended meal bolus. The user can then adjust the size of the meal bolus by scrolling up or down. In one possible embodiment, the pump 100 scrolls in increments of 1. Once the desired bolus amount is set the user activates the Deliver function 384.
In a further possible embodiment, the recommended meal bolus is altered based on other nutritional information associated with the selected food entries from the food database. For example, the meal bolus can be increased for foods with a large number of proteins and/or fats in addition to the carbohydrates in the food.
In yet another embodiment, the meal bolus is altered based on other nutritional information associated with the selected food entries from the food database. For example, a combination or extended bolus is optionally recommended for foods having a large number of fats in addition to the carbohydrates in the food.
When the pump 100 is programmed to enable administration of a correction bolus through a Meal Bolus, the pump 100 prompts 472 the user to enter the number of carbohydrates to be consumed. The user then activates the Next function 200, and the pump 100 prompts 478 the user to enter the amount by which they want to lower their blood glucose level. The user then activates the Next function 200, which causes the pump 100 to calculate a recommended bolus amount and to display a user interface with a banner 482 stating “Bolus to Lower BG X plus Y grams of carbohydrates.” X is the amount by which the user entered to lower the blood glucose level, and Y is the number of carbohydrates that the user entered.
The pump 100 also displays the recommended bolus amount 480 to deliver. The recommended bolus amount 480 is the recommended correction bolus plus the amount of the meal bolus. This feature allows the user to correct a high blood glucose level and deliver additional insulin to work against carbohydrates that they plan to consume. The user can adjust the recommended bolus amount by increasing or decreasing the recommended bolus amount by scrolling up or down. In one possible embodiment, the user scrolls in increments of 0.5 units. Once the desired bolus amount is set, the user activates the Deliver function 384.
Activating the Deliver function 384 causes the pump 100 to start the countdown timer and display the banner 404 that states a bolus will be delivered in predetermined time. In one possible embodiment, that time is 5 seconds and the banner 404 also states the bolus amount. An example of a possible banner 404 states “Bolus X Delivery Starts in 5 Seconds,” where X is the bolus amount. The pump 100 also assigns a Stop function 406 to the first function key 138.
If the user activates the Stop function 406 before the countdown timer times out, the pump 100 will terminate delivery of the bolus and return to the home page 152. If the user does not activate the Stop function 406, when the timer times out, the pump 100 will begin to deliver the bolus and display the banner 408 stating that the bolus is being delivered. An example of such a banner is “Bolus X is Delivering”, where X is the bolus amount. When delivery of the bolus is complete, the pump returns to the home page 152.
In an alternative embodiment, when the pump 100 is programmed to enable administration of a correction bolus through a Meal Bolus, the pump 100 prompts the user to enter their current blood glucose measurement. The pump 100 calculates the current correction factor and also displays the correction factor and the target blood glucose level with the prompt. The user then enters his or her current blood glucose level in units of either mg/dL or mmol/L, by scrolling through a range of values until the current blood glucose level is displayed. In this embodiment, the target blood glucose level and the appropriate units are programmed into the pump when personalizing or customizing the correction bolus program. Once the user enters the current blood glucose level, the user activates the Next function 200 and the pump 100 calculates a recommended bolus amount and adds it to the meal bolus. The pump 100 displays the user interface with the banner 482 “Bolus to Lower BG X plus Y grams of carbohydrates.” The user can then change the amount and activate the Deliver function 384 to begin delivery of the bolus as described above.
Additionally, in one possible embodiment, the pump 100 adjusts the recommended bolus based on the meal bolus or the meal bolus plus the correction bolus to accommodate insulin on board or residual insulin that is still working within the user's body. In this embodiment, the amount of the adjusted correction bolus is adjusted using the equations described above in conjunction with the duration-of-activity function. The methods of adjusting the bolus amount for insulin on board is described herein.
In a further possible embodiment, the pump 100 logs the meals selected by the user and for which meal boluses are delivered. The pump optionally logs nutritional information related to the meals, such as information related to carbohydrates, fats, or proteins. Other nutritional information can be logged as well.
In yet another embodiment the pump 100 generates and presents reports to the user. The reports can include historical food intake, as well as cumulative nutritional information of the foods consumed.
  
The user selects the Extended Bolus menu item and, when the pump 100 is set to program in units of insulin, the pump prompts 484 the user to enter the number of units to deliver. In one possible embodiment, the user can scroll through values in the range from 0 units to 17 units in increments of 0.5 units. When the number of units for delivery are entered, the user activates the Next function 200 and the pump 100 prompts 486 the user to enter the duration of length of time over which the extended bolus is to be delivered. In one possible embodiment, the user enters a duration in the range of 0 minutes to 6 hours in increments of 30 minutes.
When the duration is set, the pump 100 displays a user interface 488 that presents the programmed amount 490 of the extended bolus and the duration 492 over which it is to be delivered. To begin delivery of the extended bolus, the user activates the Deliver function 384. The pump 100 then begins delivering the extended bolus and will complete delivery upon expiration of the duration.
Alternatively, when the pump 100 is set to program in grams of carbohydrates, the pump 100 prompts 484′ the user to enter the grams of carbohydrates that the user plans to consume rather than the units of insulin to deliver as an extended bolus. The pump 100 also prompts 486 the user to enter the duration for the extended bolus. The pump 100 displays 485 the carbohydrate ratio while prompting the user to enter the grams of carbohydrates 484′ and the duration 486. The pump 100 then calculates a recommended bolus amount 490′ using the carbohydrate ratio as described above and displays the recommended bolus amount 490′, together with the duration 492 in a user interface that confirms the parameters for delivery of the extended bolus. The user can adjust the recommended amount 490′ for the extended bolus by scrolling with the up and down keys 142 and 144. The user activates the Deliver function 384 to begin delivery of the extended bolus using the parameters displayed in the user interface.
After delivery of the extended bolus begins, if the pump 100 is programmed to enable administration of a correction bolus through the Meal Bolus program, the pump 100 prompts 494 the user to enter the amount by which they want to lower their blood glucose level. The user then activates the Next function 200 and the pump 100 prompts 496 the user to enter the number of units to deliver as a meal bolus. In one possible embodiment, the user enters the amount by scrolling through values in units of either mg/dL or mmol/L. When the desired drop in blood glucose is entered, the user activates the Next function 200, which causes the pump 100 to calculate a recommended bolus amount and to display the banner 497 “Bolus to Lower BG X.” X is the amount by which the user entered to lower the blood glucose level.
The prompt 496 initially displays the recommended bolus amount to deliver. The recommended bolus amount is the recommended correction bolus 490 or 490′, which the pump 100 calculates using the correction factor as discussed above. This feature allows the user to correct a high blood glucose level and deliver additional insulin to work against carbohydrates that they plan to consume. The user can adjust the recommended bolus amount 496 by increasing or decreasing the recommended bolus amount 496 by using the up and down keys 142 and 144. In one possible embodiment, the user scrolls in increments of 0.5 units. Once the desired bolus amount is set, the user activates the Deliver function 384.
Activating the Deliver function 384 causes the pump 100 to display the banner 404 that states a bolus will be delivered in predetermined time. In one possible embodiment, that time is 5 seconds and the pump 100 displays the bolus amount 496 in the banner. An example of a possible user interface states “Bolus X Delivery Starts in 5 Seconds,” where X is the amount of the correction bolus. The pump 100 also assigns the Stop function 406 to the first function key 138.
If the user activates the Stop function 406 before the countdown timer times out, the pump 100 will terminate delivery of the correction bolus and return to the home page 152. In one possible embodiment, activating the Stop function 406 will terminate delivery of the correction bolus, but not the extended bolus. If the user does not activate the Stop function 406, when the timer times out, the pump 100 will begin to deliver the bolus and display the banner 408 stating that the bolus is being delivered. An example of such a banner is “Bolus X is Delivering”, where X is the bolus amount. When delivery of the bolus is complete, the pump 100 returns to the home page 152. In an alternative embodiment, no timer is included in the pump and the pump 100 begins delivering the correction bolus immediately.
In an alternative embodiment, when the pump 100 is programmed to enable administration of a correction bolus through a Meal Bolus, the pump 100 prompts the user to enter their current blood glucose measurement. The pump 100 calculates the current correction factor and displays the correction factor in the user interface. The pump 100 also displays the target blood glucose level. The user then enters his or her current blood glucose level in units of either mg/dL or mmol/L, by scrolling through a range of values until the current blood glucose level is displayed. In this embodiment, the target blood glucose level and the appropriate units are programmed into the pump 100 when personalizing the correction bolus program. Once the user enters the current blood glucose level, the user activates the Next function 200 and the pump 100 calculates a recommended bolus amount and adds it to the meal bolus. The pump 100 displays the user interface with the banner “Bolus to Lower BG X plus Y Meal Bolus.” The user can then change the amount and activate the Deliver function 384 to begin delivery of the bolus as described above.
Additionally, in one possible embodiment, the pump 100 adjusts the recommended correction bolus based on the meal bolus or the meal bolus plus the correction bolus to accommodate insulin on board or residual insulin that is still working within the user's body. In this embodiment, the amount of the adjusted correction bolus is adjusted using the equations described above in conjunction with the duration-of-activity function. The methods of adjusting the bolus amount for insulin on board is described herein.
Referring to 
Referring to 
Referring to 
L. Weekly Schedule
A weekly schedule can be created and preprogrammed into the pump 100. The weekly schedule allows the user to schedule a pattern of basal rates for individual days of the week, and also allows the user to schedule a set of missed meal bolus alerts for individual days of the week. The weekly schedule allows a user to preprogram one or more basal rates as described above in conjunction with 
Referring to 
The user selects one of the menu items to edit the corresponding aspect of the weekly schedule. If the user selects the Temp Basal Pattern option in the edit schedule submenu 500, the pump 100 indexes focus to a start temporary basal pattern screen 502 which allows the user to indicate when to start the temporary basal pattern. A temporary basal pattern is a basal pattern that overrides, for a day, the basal pattern scheduled in the weekly schedule. For example, if a pump user has to occasionally work on Saturday, they can schedule their “Weekday” pattern to temporarily override their “Weekend” pattern for the Saturday they must work. Selecting the Temp Basal Pattern option allows the user to have a temporary basal pattern applied by the pump 100 for the remainder of the current day and a second temporary basal pattern programmed to take effect the following day as well. A temp basal pattern start box 503 displays the time at which the temporary basal pattern will begin. In the start temporary basal pattern screen 502 shown, the temp basal pattern start box 503 indicates that the basal pattern will start immediately. To select a different time at which the temporary basal pattern will begin, the user can change the setting in the temp basal pattern start box 503 using the up and down keys. Other start times, such as delayed by an hour, a day, or other time period are possible. A back option returns focus to the edit schedule submenu 500.
Upon confirmation of the temp basal pattern start time by selecting a next option, the pump 100 indexes focus to a select temp pattern screen 504. The select temp pattern screen 504 prompts the user to select the temporary basal pattern that is to be applied. The user selects from the list of basal patterns 505 programmed or loaded into and enabled in the pump. In the example shown, “Weekday”, “Weekend”, “Sick Day”, and “Basal Pattern 4” are listed as selectable options. Other lists or combinations of basal patterns can be displayed as well, depending upon the patterns created or loaded into the pump 100. The user selects one of the basal patterns using up and down keys 142, 144. Upon selection of a basal pattern and confirmation of the selection with a select option, focus returns to a main menu 190. A back option in the select temp pattern screen 504 returns focus to the start temporary basal pattern screen 502.
If the user selects the Edit Weekly Schedule option in the edit schedule submenu 500, the pump 100 indexes focus to a day program screen 506, which displays the basal pattern and missed meal pattern associated with that day. In the day program screen 506 shown, the day displayed is Monday, and the basal pattern is Pattern 1. The missed meal bolus alarm set is shown as Set 1. The up and down keys 142, 144 navigate through the days of the week, and an edit option 507 indexes focus to a day edit screen 508. The day edit screen 508 displays the basal pattern assigned to the day in a basal pattern field 509, and allows the user to edit the basal pattern for the day selected in the day program screen 506. The user changes the basal pattern using the up and down keys 142, 144, among the basal patterns edited using the Edit Basal Patterns option in the edit schedule submenu 500. The user also optionally selects a missed meal bolus alert set to associate with the selected day, from a listing of missed meal bolus alert sets programmed using the Edit Missed Meal Alert option in the edit schedule submenu. A back option and a next option both cause the pump 100 to index focus back to the day program screen 506.
If the user selects the Edit Basal Patterns option in the edit schedule submenu 500, the pump 100 displays a basal pattern listing 510 including basal patterns programmed into the pump. The basal pattern listing 510 displays one or more editable basal patterns which are available to be scheduled in the day edit screen 509 or used as temporary basal patterns in the select rate screen 504. The basal pattern listing 510 displays the defined basal patterns, and allows a user to select one of the predefined basal patterns using the up and down keys 142, 144. The user selects a back option to return to the edit schedule submenu 500, or selects a select option 511 to cause the pump 100 to index focus to a pattern view screen 512 related to the selected basal pattern. The pump 100 displays a listing of times and associated delivery rates in the pattern view screen 512 for the basal pattern selected in the basal pattern listing 510. If the user does not wish to edit the times displayed, the user selects a back option to return to the basal pattern listing 510. To edit one or more of the times and/or basal patterns, the user selects an edit option 513 to cause the pump 100 to index focus to a pattern edit screen 514. The pattern edit screen 514 displays on the pump 100 and allows the user to change the times and basal rates, or add additional times with associated basal rates. The user employs the up and down keys 142, 144 to select and edit the times of the day, as well as to select and edit the basal rates associated with the times of the day. A done option 515 indicates that the user has completed editing the basal pattern, and causes the pump 100 to index focus back to the pattern view screen 512. A next option 517 indexes focus within the pattern edit screen 514.
If the user selects the Missed Meal Alert option in the edit schedule submenu 500, the pump indexes focus to a missed meal alert listing 516. The missed meal alert listing 516 includes one or more sets of alerts configured to match the planned meal times of the user. The sets of alerts correspond to the alerts selected using the day edit screen 508. If the pump 100 does not deliver a meal bolus between the start and end time of a missed meal alert, the user may have forgotten to deliver the meal bolus and is prompted to deliver the meal bolus. The meal bolus can be programmed according to the meal bolus and food database description above. The user can select one or more missed meal alert sets using selection boxes associated with each of the missed meal alert sets. A select option 519 causes the pump to index focus to an alert enable screen 518.
The alert enable screen 518 displays the enabled or disable status of the missed meal alert set selected in the missed meal alert listing 516, and also displays the name of the alert set. A next option indexes focus to an alert listing 520 associated with the alert set displayed in the alert enable screen 518. A back option returns focus to the missed meal alert listing 516.
Upon user selection of the next option, the pump 100 indexes focus to the alert listing 520, which displays all of the defined missed meal alerts associated with a missed meal alert set. The user can select one or more of the alerts in the alert listing which the user wishes to edit. Upon selection of a select option 519, the pump 100 indexes focus to an alert edit screen 522. A back option returns focus to the alert listing screen 520.
The alert edit screen 522 allows the user to set a start time and an end time for the selected alert in the missed meal alert set. Upon selection of a next option 523 in the alert edit screen 522, the pump 100 returns focus to the missed meal alert listing 516. A back option in the alert edit screen 522 returns focus to the alert listing 520.
In a possible embodiment of the weekly schedule, the home screen 152 can be modified to display information related to the weekly schedule as programmed, such as the current day of the week, the type of day or basal rate currently applied, the name of the basal rate pattern, the missed meal alert set applied, or other information related to the weekly schedule.
Although specific examples are illustrated herein, the weekly schedule can be used to schedule basal rates, delivery patterns, and boluses for various events such as different daily meal schedules, upcoming athletic events, travel schedules, work schedules, sick days, parties, and any other type of schedule or event. Additionally, sets of scheduled target blood glucose levels, such as are related to a correction bolus or negative meal bolus, can be created. In an alternative embodiment, a weekly schedule could also be used to remind the user of other events such as testing blood glucose levels.
The weekly schedule disclosed herein is modifiable to provide to a user a monthly or yearly schedule as well. The monthly or yearly schedule can be programmed with monthly or yearly meal boluses, and can track holidays, vacations, or other events which occur outside the user's typical daily or weekly schedule.
M. Disconnect/Suspend Bolus
Referring back to 
When the user wishes to disconnect from the pump 100, the user is first prompted by the pump 100 to enter the duration they will be disconnected from the pump. The pump 100 calculates and displays the amount of insulin delivery which will be missed in that time. This includes any basal rate and temporary rate scheduled during that time. The pump 100 prompts the user to enter a percentage of the missed insulin that the user wishes to receive as a bolus prior to disconnecting from the pump, and accepts any percentage value up to 100% of the total insulin delivery that will be missed, although other embodiments might include a limit other than 100%. This percentage bolus delivered prior to disconnection can be referred to as a disconnect bolus.
The pump 100 prompts the user to optionally check their blood glucose level prior to disconnecting from the pump. If the user chooses to check their blood glucose level and requires a correction bolus, the correction bolus is delivered prior to disconnection. If the user chooses to check their blood glucose level and the negative meal bolus feature would normally activate, the pump 100 reduces the disconnect bolus to compensate for the user's low blood glucose level.
Upon confirmation by the user, the pump stops all basal rate delivery, logs the disconnection time, the percentage of immediately delivered insulin as selected, and delivers the disconnection bolus, which is the bolus amount calculated by the pump and multiplied by the percentage input by the user. Once the bolus delivery is complete, the pump 100 triggers an alarm, such as a visible alarm displayed on the pump or an audible alarm emitted by the pump, indicating to a user that they should disconnect from the pump. In the exemplary embodiment, the pump requests confirmation by the user that they are disconnected from the pump. Once confirmation is received from the user, the pump adds a “reconnect” option into the main menu 190. The pump stores its disconnected state and the elapsed disconnection time, such that the pump status is retained during the disconnect/suspend bolus operation even if the pump power is interrupted during the disconnect period, or if the user changes the time or date in the pump 100.
When the pump 100 remains in the disconnected state, the user can physically reconnect their infusion set and configure the pump to deliver a meal bolus or a correction bolus. The pump 100 maintains the interrupted basal rate during the time that the pump is in the disconnected state.
When the user begins the reconnect process by selecting the reconnect option on the main menu, the pump 100 calculates the originally scheduled insulin dose, which is the amount of insulin originally scheduled to be delivered during the elapsed time between the time the pump was disconnected and the time the reconnect option is selected on the main menu. The pump then subtracts the originally scheduled insulin dose from the dose delivered by disconnection bolus the dose. If the difference is a negative number, the user has reconnected before the time they had indicated, and the pump should not deliver additional insulin to the patient upon reconnection. The pump 100 starts a temporary rate of zero units per hour for the time required for the basal rate and boluses to make up for that negative amount. If the amount of insulin owed is a positive number, the pump 100 prompts the user to enter the percentage of that “missed” amount that they wish to have delivered, up to 100%. This percentage of missed insulin is referred to as the reconnect bolus.
The pump 100 prompts the user to optionally check their blood glucose level before reconnecting. If the user chooses to check their blood glucose level, any correction bolus deemed necessary will be added to the reconnect bolus. Likewise, if the user chooses to check their blood glucose level, any negative meal bolus will be subtracted from the reconnect bolus.
N. Additional Pump Features
Additional features can be included in the pump consistent with the present disclosure. For example, the pump can include programming for temporary basal rates, an option to include an audio bolus, customized alerts, and lock levels. A temporary rate allows the user to temporarily raise or lower the delivery rate being administered by the active bolus program. The user can personalize or customize the temporary rate programs and how they are present in the user interface. An audio bolus provides for delivery of a standard meal bolus using a single button. A series of sounds, such as beeps, are used to provide an indication of the setting to the user. In a possible embodiment, the beeps are configured analogously to the sounds used to program the pump 100 without the need for visual confirmation, such as by a visually impaired user. Customizable alerts allow a user to select specific alerts for various types of events occurring in the pump. Lock levels provide various levels of user rights in the pump based on access codes. Lock levels prevent unauthorized users from entering and changing settings in the pump. These and additional pump features are described in greater detail in U.S. Pat. No. 6,744,350, filed Feb. 28, 2002 and entitled Insulin Pump Having Missed Meal Bolus Alarm, the disclosure of which was incorporated by reference in its entirety above.
O. Computer-Pump Communication and Programming
In one possible embodiment, the pump 100 can communicate with a computer. The computer can upload information from the pump 100, including the historical information generated by and stored on the pump 100. The computer can archive the historical information and maintain a complete historical record about the pump 100. Additionally, the computer can generate various reports regarding use of the pump 100, including information about delivery rates, bolus amounts, and alarms. Additionally, the computer can operate a program that allows the user to enter operating parameters for the various delivery programs that are loaded on the pump 100 and to download those operating parameters to the pump 100. In yet another possible embodiment, the computer can be used to download delivery programs and software updates to the pump 100.
Referring to 
Communication between a medical pump and a computer is also discussed in U.S. Pat. No. 5,935,099, entitled Drug Pump Systems and Methods, the disclosure of which is hereby incorporated by reference.
Referring to 
A primary window 544 can include a variety of different data entry features for entering the operating parameters including text, numbers, flags, or the like. Examples of the data entry features include buttons, check boxes, spin boxes, text fields, numeric fields, and tables. The buttons and check boxes are alternatively set and cleared by clicking on them with a pointing device such as a mouse. Each spin box is associated with up and down buttons and contains a list of values. The user sets the desired value by spinning though the list of values with the up and down keys until the desired value is visible in the spin box. The tables have rows of cells and a scroll bar. The user can manipulate the scroll bar with a pointing device to scroll through the available rows within the table. Additionally, each primary window has a download button, an upload button, and a save button.
The primary window on the top of the stack is active, and the user can enter, edit, and view operating parameters in the active primary window. The user can bring any one of the primary windows to the top of the stack by clicking on the primary window's tab.
Still referring to 
The second panel 552 of the screen has one secondary window 554a-554d for each of the basal delivery programs. The secondary windows are stacked and are marked with tabs 556a-556d. Each tab 556 is marked with the name of the basal program associated with the tab's secondary window 554. The secondary window 554 on the top of the stack is active, and the user can enter, edit, and view operating parameters in the active secondary window. The user clicks on the tab 556 for any given secondary window to bring it to the top of the stack. In the illustrated example, there are four basal delivery programs and hence four secondary windows named Basal 1 554a, Basal 2 554b, Basal 3 554c, and Basal 4 554d.
Each secondary window 554 has a button 558, a check box 560, and a text field 562 organized into a second group box 564 for setting program preferences. A table 566 and a graph 568 are organized into a third group box 570 and are for naming, setting, and viewing the basal delivery rates. To activate a basal delivery program, the user sets the button 558 by clicking on it. Any other basal program that was active becomes inactive and the button for the previously active basal delivery program is cleared. Additionally, an asterisk is placed in the tab 556 for the active basal delivery program so that the user can easily identify the active basal delivery program if the secondary window 554 for that basal delivery program is not on top of the stack. When the operating parameters for the basal delivery programs are downloaded to the pump 100, the basal delivery program in which the button 558 is set will become the active basal delivery program on the pump 100.
To display the basal delivery program as a menu item in the Basal Program submenu 318 (
To customize the name of the basal delivery program, the user types the custom name into the text field 562. The custom name is assigned to the basal delivery program and appears in the tab 556 for that program. Additionally, the custom name is the name downloaded into the pump 100 and appears in the Basal Program submenu 318, if the checkbox 560 is set. In an alternative embodiment, a spin box is associated with the text field 562. The spin box presents preprogrammed, optional names for the basal delivery programs that the user can select. The selected name would then replace the generic name (e.g., Basal 1, Basal 2, Basal 3, and Basal 4 in the illustrated example) for the program associated with the display. Examples of optional names that might be loaded in the pump 100 include weekday, weekend, sick, and monthly (which is to designate a basal delivery program set for a woman's menstrual cycle).
The basal rate table 566 or grid has a plurality of rows 572 and each row has two cells 574 and 576. When a cell within the table 566 has focus and the user presses the enter key or the tab key, the focus shifts to the next cell to the right. If the current cell is the last cell in the row, focus shifts to the first cell in the next row. If the user presses the enter key while the last cell in the last row is in focus, a new row is created. In this manner, the user can expand the length of the table 572. If the user presses the enter key while the last cell of a row is in focus and there is no data in any cell within that row, the computer will delete the row. The one exception is the first row in the table, which cannot be deleted.
The first cell within a row is a start-time cell 574, and the second cell within a row is a delivery-rate cell 576. Each row corresponds to a different interval in the delivery protocol for the basal delivery program. To set the delivery protocol for a basal program, the user enters the start time for each delivery interval in the start-time cell 574 and the delivery rate in the delivery-rate cell 576. The pump 100 will then deliver at the set delivery rate beginning at the set start time and until the start time for the next delivery interval. In one possible embodiment, the start time for the first interval is 12:00 midnight and cannot be changed.
Accordingly, to set the delivery protocol for the basal delivery program, the user types the start time in the start-time cell 574, hits the enter key and changes the focus to the delivery-rate cell 576 to the right. The user then types in the delivery rate for that interval, hits the cell key, and changes the focus to the start-time cell in the next row (creating the row if the next row does not already exist). A new row will appear in which the user can enter the operating parameters for another delivery interval. The user continues this process until the operating parameters for all of the desired intervals are entered into the table.
In an alternative embodiment, when a cell has focus, a spin box having up and down buttons is presented in that cell. The user can either type a value into the spin box or spin through values until a desired value is visible in the spin box. When the cell and hence the spin box loses focus, the visible value from the spin box is entered into the corresponding cell and the spin box becomes invisible.
The graph 568 provides a graphical illustration of the delivery rate for the basal delivery program over a 24-hour period. In one possible embodiment, the graph 568 is a bar chart illustrating the delivery rate in a resolution of 30 minutes. In the illustrated example, Basal 1 is set to deliver 2 units/hour from 12:00 midnight to 2:00 am, 2.5 units/hour from 2:00 am to 3:00 am, etc.
In one possible embodiment, the graph 568 is automatically updated as the user completes entering the start time and delivery rate for each delivery interval. Additionally, the total daily basal rate is displayed 578, and is automatically calculated and updated as the user completes entering the start time and delivery rate for each delivery interval. Entry of data for an interval is complete when the user enters the start time and delivery rate for the interval and exits both the start-time cell 574 and the delivery-rate cell 576.
The third panel 580 presents instructions to the user. In one possible embodiment, the user interface presents a help label 582 (e.g., the question mark in the illustrated example) in each of the group boxes 549, 564, and 570. When the user clicks on a help label 582, instructions specific to the group box or other aspects of the user interface associated with the help label are presented in the third panel. Alternatively, the user can point to a particular aspect of the user interface and right click on the mouse to present field-specific instructions in the third panel.
An additional panel (not shown) can include control options for performing a basal test. The additional panel will include options to set up and review the results of the basal test. The additional panel will have analogous functionality to that described above in conjunction with 
  
The pair of buttons 586, spin boxes 588, 590 and table 591 are present in a first group box 604. The check boxes 596, 598, 600, and 601 are presented in a second group box 606, and the table 602 is present in a third group box 608. Spin boxes 592 and 594 are present in a fourth group box 610. The pair of buttons 586 is for setting the meal bolus delivery program to use either units of insulin or grams of carbohydrates. The pair of buttons 586 toggle between set and cleared states so that when one is set the other cleared. The user set the first button to program the meal bolus programs in units of insulin and sets the second button to program the meal bolus programs in grams of carbohydrates
The first spin box 588 is for setting the maximum bolus that the pump 100 can deliver when executing the meal bolus program. The second spin box 590 is for setting the duration of the bolus. The table 591 is for setting the user's fixed carbohydrate ratio. The table 591 optionally also works in conjunction with functionality to set a schedule of carbohydrate ratios configured to change based on the time of day.
In the fourth group box 610, the spin box 592 is for programming in units of insulin and is for setting the increments at which a user can spin through bolus amounts. The spin box 594 is for programming in grams of carbohydrates and is for setting the increments at which a user can spin through grams of carbohydrates to be consumed in a meal.
When the user sets the first button for programming in units of insulin, the third spin box 592 is enabled and the fourth 594 spin box is disabled. When the user sets the second button for programming in grams of carbohydrates, the fourth 594 spin boxes is enabled, and the third spin box 592 is disabled.
To enable the extended bolus program, the user sets the first check box 596. To enable the combination bolus program, the user sets the second check box 598. To enable the audio bolus function, the user sets the third check box 600.
To enable to food database, the user sets the fourth check box 602. Selection of the fourth check box 602 can optionally trigger creation of another window (not shown) used for browsing a food database stored on the computer.
The custom meal bolus table 608 has a plurality of rows, and each row has a plurality of cells. The user navigates through the meal bolus table 608 using procedures substantially similar to that of the basal rate table. Also similar to the basal rate table, the custom meal bolus table 608 can have various spin boxes that become visible when a cell has focus. The spin boxes are for entering values and pre-typed text into the cell with which it is associated.
Within the meal bolus table 608, each row has seven cells. The first cell 612 has a check box 613. To enable the custom meal bolus defined by that row, the user sets the check box 613. The second cell 614 has a text field in which the user types a name to identify the custom meal bolus defined by that row. An example includes pizza, when the operating parameters for the custom meal bolus are customized to deliver insulin for working against a meal of pizza. Other examples, might include breakfast, lunch, dinner, snack, or any other specific type of food, drink, or meal.
The third cell 616 contains a text field for entering the type of custom meal bolus, whether it is a standard bolus, an extend bolus, or a combination bolus. In one possible embodiment, a spin box is presented in the third cell 616 when focus is placed on the cell. The user can then spin through the types of bolus (e.g., standard, extended, or combination) and set the desired type. The fourth cell 618 is a numeric field for entering the default number of carbohydrates to be delivered by the bolus program defined by that row. The fifth cell 620 is a duration field in which the user enters the duration of the bolus delivery if the bolus program defined by that row is an extended bolus or a combination bolus. The sixth cell 622 is a numeric field in which the user enters the percent of the bolus to be delivered immediately if the bolus program defined by that row is a combination bolus.
The seventh cell 626 contains a text field for entering the type of carbohydrate ratio entered into the pump 100. In the embodiment shown, the carbohydrate ratio is either a Fixed or Scheduled ratio. When a Scheduled carbohydrate ratio is selected, the custom bolus uses the carbohydrate ratio that is currently in use by the pump 100. If a Fixed carbohydrate ratio is selected, the custom bolus uses the carbohydrate ratio entered in the eighth cell 624. In one possible embodiment, a spin box is presented in the seventh cell 626 when focus is placed on the cell. The user can then spin through the types of carbohydrate ratios (e.g., Fixed or Scheduled) to set the desired type. The eighth cell 624 is a numeric field in which the user enters the carbohydrate ratio the pump 100 is to use when the seventh cell is set to Fixed. The carbohydrate ratio is used when calculating the bolus amount to deliver. The eighth cell 624 allows the user to enter a customized carbohydrate ratio independent of the carbohydrate ratio schedule. For example, a user might use one carbohydrate for a custom meal bolus to be delivered before an early morning breakfast and a different carbohydrate ratio for a custom meal bolus to be delivered prior to an exercise session.
If the type of meal bolus set in the third cell (Type of Meal Bolus) 616 is standard, the fifth cell (Duration) 620 and sixth cell (% as Immediate) 622 are disabled and cleared. If the type of meal bolus set in the third cell 616 is an extended bolus, the fifth cell 620 is enabled and the sixth cell 622 is disabled and cleared. If the type of meal bolus set in the third cell 616 is set as a combination bolus, the fifth 620 and sixth 622 cells are enabled.
Also, the fourth cell 618 allows a default number carbohydrates for the custom bolus to be entered. For example, if a user eats a 40 gram carbohydrate snack before bed each night, a custom meal bolus called “Bedtime Snack” could be created with a default carbohydrate value of 40 grams. The default value can be adjusted before the bolus is delivered.
An optional second panel (not shown) in the primary window 544b for the meal bolus delivery program presents instructions. It operates in a manner substantially similar to the third, instruction panel 580 in the first primary window 544a for the basal rate delivery programs as described above.
  
A table control 638 resides within a second group box 640, and sets a schedule of correction factors. The correction factors define operating parameters used by the correction bolus program. The table control allows the user to define a start time and a Factor, which refers to the amount of correction which could occur at that time of day. Alternately, a pair of buttons set the units for the operating parameters used by the correction bolus program. The pair of buttons toggle between set and cleared states so that when one is set the other is cleared. The first button is set to use mg/dL and the second button is set to use mmol/l. A first spin box is for setting the correction bolus factor. When the first spin box is in focus, the user spins through value until the desired correction factor is set. The pair of buttons and the first spin box are optionally organized into the second group box 640.
A third group box 635 has buttons and a table control. The buttons 636 set the method by which blood glucose is measured. In the embodiment shown, the buttons 636 allow a user to select between units of mg/dl and mmol/L. The table control 637 defines one or more target blood glucose levels and associates the target blood glucose levels with times of the day. In an optional embodiment, the table control 637 allows a user to define a schedule or target blood glucose levels for one or more days.
A fourth group box 644 in the first panel 628 has buttons and spin boxes. A second spin box 642 is for setting the duration of activity or action for the insulin. As discussed above, the duration of activity is the length of time that each bolus remains working in the user's body. To enter the duration of activity, the user spins through values in the second spin box 642 until the desired value is set. Optional spin boxes (not shown) set the start time and tail time of an insulin absorption model. To enter the start and tail times, the user spins through the values in the respective spin boxes until the desired values are set. Buttons may set the insulin absorption model to be used in the pump by toggling between set and cleared states so that when one is set the other two buttons are cleared. Each button can correspond to a linear absorption model such as is shown in 
A fifth group box 631 enables and sets the change in the correction factor based on the user's blood glucose level. A check box 633 enables changes in the correction factor based on the user's current blood glucose level, of the form “If blood glucose is at least X, add Y %.” A series of spin boxes 635 set the threshold blood glucose reading at which the rule takes effect for one or more rules, and represents the “X” value in the above statement for each selected rule. A second series of spin boxes 637 sets the percentage increase in insulin delivery upon reaching the threshold blood glucose level, and represents the “Y” value in the above statement for each corresponding selected rule. In the implementation shown, four separate sets of spin boxes are used to set four blood glucose dependent rules for insulin delivery. However, more or fewer sets of spin boxes are included according to specific implementations of the group box 631 and correction factors.
An optional second panel (not shown) in the primary window 544c for the correction bolus delivery program presents instructions. It operates in a manner substantially similar to the third, instruction panel 580 in the first primary window 544a for the basal rate delivery programs as described above.
  
The pair of buttons 656 sets the temporary rate either as a percentage of the running basal rate or as a new temporary basal rate. The pair of buttons 656 toggle between set and cleared states so that when one button is set the other button is cleared. The user sets the first button to set the temporary rate as a percent of the basal rate. The user sets the second button to set the temporary rate as a new, temporary basal rate.
To set a reminder so that the pump 100 intermittently generates a reminder (audible and/or vibratory) while the temporary rate program is running, the user sets the second check box 652. When the second check box 652 is set, the spin box 658 is enabled. The spin box 658 is for setting the interval between reminders. The spin box 658 is disabled when the second check box 652 is cleared. To set the pump 100 to generate a final reminder upon completion of the temporary rate, the user sets the third check box 654.
The temporary rate table 660 has a plurality of rows 668, and each row 668 contains a plurality of cells. The user navigates through the temporary rate table 660 using procedures substantially similar to that of the basal rate table. Also similar to the basal rate table 602, the temporary rate table 660 can have various spin boxes that become visible when a cell has focus. The spin boxes are for entering values and pre-typed text into the cell with which it is associated.
Within the temporary rate table 660, each row has six cells. The first cell 670 has a check box 672. To enable the temporary rate defined by that row, the user sets the check box 672. The second cell 674 has a text field in which the user types a name to identify the temporary rate defined by that row. Examples might include exercise, 5-mile run, sick, evening, and the like. The third cell 676 is a text field to set the temporary rate to be programmed as a percent of current basal rate or as a new rate. In one possible embodiment a spin is present in the third cell 676 when focus is place on the cell. The user then spins through the types of temporary rates (e.g., % of Basal or New Rate) and sets the desired type.
The fourth cell 678 is for assigning the percentage of the running basal rate to set as the temporary rate. The fifth cell 680 is for setting a new rate for the temporary rate. When the user enters % of basal in the third cell 676, the fourth cell 678 is enabled and the fifth cell 680 is disabled. When the user enters New Rate in the third cell 676, the fourth cell 678 is disabled, and the fifth cell 680 is enabled. The sixth cell 682 is for setting the duration of the temporary rate.
Additionally, in one possible embodiment, when the user sets the first button to adjust the delivery rate as a percent of the basal rate, the check box 672 is set in the first cell 670 for each row 668 in which there is a percentage in the fourth cell 678. The check box 672 in the first cell 670 is cleared for each row 668 in which there is a delivery rate value in the fifth cell 680. Similarly, when the user sets the second button to use a new delivery rate, the check box 672 is set in the first cell 670 for each row 668 in which there is a delivery rate value in the fifth cell 680. The check box 672 in the first cell 670 is cleared for each row 668 in which there is a percentage value in the fourth cell 678.
The second panel 684 in the primary window 544d for the temporary rate delivery programs presents instructions. It operates in a manner substantially similar to the third, instruction panel 580 in the first primary window 544a for the basal rate delivery programs as described above.
In addition to operating parameters, one possible embodiment of the user interface 542 also enables a user to view, edit, and enter other data, character strings, and settings that are loaded on the insulin pump 100.
For example, 
The second panel 696 in the primary window 544e presents instructions. It operates in a manner substantially similar to the third, instruction panel 580 in the first primary window 544a for the basal rate delivery programs as described above.
  
The first panel 700 also has a third spin box 706 and a fourth spin box 708 configured to set the basal pattern and missed meal bolus alerts for weekend operation. To select a weekend basal pattern, the user can spin through the listed basal patterns programmed in the basal patterns tab 544a and set the desired type. Likewise, to select a weekend missed meal alert set, the user can spin through the listed alert sets configured in the meal boluses tab 544b and set the desired type. The first and second spin boxes 706, 708 correspond to a graphical representation 712 of the weekend schedule, which displays the basal rates and meal bolus alerts analogously to the weekday graphical representation 706. In an alternative embodiment, the first panel 700 can include seven spin box controls, corresponding to each day of the week. In a further alternative embodiment, the first panel 700 can include a graphical calendar display configured to allow monthly programming of the basal pattern and/or missed meal bolus alerts.
A first check box 714 enables the weekly schedule option in the software and on the pump 100. The first check box 714 is by default in a checked, or enabled, state.
One or more indicators 718 correspond to alarms scheduled to occur during the day displayed. The indicators and corresponding alarms can represent appointments, times of the day at which blood glucose values should be checked, or other user reminders.
The second panel 716 in the primary window 544f presents instructions. It operates in a manner substantially similar to the instruction panel 580 in the first primary window 544a for the basal rate delivery programs as described above.
Yet other embodiments of the user interface 542 include various windows, buttons, checkboxes, spin boxes, and fields for setting other parameters used to operate the pump 100. Examples of such other parameters that can be set through the user interface 542 include various format settings, alarms, reminders, operating limits, report formats, security settings, character strings, and indeed any other operating parameters, data, settings, and character strings that can be programmed into the pump 100.
Referring to 
To upload operating parameters from the pump 100 into the active primary window 544, the user clicks the upload button 688. The profile settings in RAM 116 that correspond to the active primary window 544 are then retrieved from RAM 116 on the pump 100 and are sent to the computer 534. The uploaded operating parameters are then populated into the fields of the active primary window 544, including all secondary windows 554. To save the profile settings, the user clicks the save button 690. The profile settings that populate the active primary window 544 then are saved in the storage device 538. In one possible embodiment, the name of the file that includes the saved data is the name of the pump user.
Furthermore, the user interface 542 can be used on the computer 534 to program and manage pumps 100 for several different pump users. In one such embodiment, the computer 534 is programmed with an initial interface that includes a text field in which the name of the pump user is entered either through the computer keyboard or through a spin box. Upon entering the name of the pump user, the computer 534 populates the data saved for that pump user's pump 100 into the user interface 542. In an alternative embodiment, the computer 534 is loaded with a menu in which the name of each pump user having stored data is included as a menu item. Selecting the name/menu item causes the computer 534 to populate the user interface 542 with data.
The various embodiments described above are provided by way of illustration only and should not be construed to limit the invention. Those skilled in the art will readily recognize various modifications and changes that may be made to the present invention without following the example embodiments and applications illustrated and described herein, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.
This application is a continuation of U.S. application Ser. No. 15/954,173 filed Apr. 16, 2018, which in turn is a continuation of U.S. application Ser. No. 14/455,460 filed Aug. 8, 2014, now abandoned, which in turn is a continuation of U.S. application Ser. No. 13/477,641, filed May 22, 2012, now U.S. Pat. No. 8,821,433, issued Sep. 2, 2014, which in turn is a continuation of U.S. application Ser. No. 13/281,168, filed Oct. 25, 2011, now U.S. Pat. No. 8,657,807, issued Feb. 25, 2014, which in turn is a continuation of U.S. application Ser. No. 11/582,519 filed Oct. 17, 2006, now abandoned, which are hereby fully incorporated herein by reference.
| Number | Name | Date | Kind | 
|---|---|---|---|
| 4529401 | Leslie et al. | Jul 1985 | A | 
| 4779762 | Klein et al. | Oct 1988 | A | 
| 4826482 | Kamen | May 1989 | A | 
| 5131816 | Brown et al. | Jul 1992 | A | 
| 5148154 | Mackay et al. | Sep 1992 | A | 
| 5172474 | Kurkowski | Dec 1992 | A | 
| 5247434 | Peterson et al. | Sep 1993 | A | 
| 5327777 | Kaye et al. | Jul 1994 | A | 
| 5339393 | Duffy et al. | Aug 1994 | A | 
| 5438510 | Bryant et al. | Aug 1995 | A | 
| 5455496 | Williams et al. | Oct 1995 | A | 
| 5505777 | Ciardella et al. | Apr 1996 | A | 
| 5556421 | Prutchi et al. | Sep 1996 | A | 
| 5634896 | Bryant et al. | Jun 1997 | A | 
| 5665065 | Colman et al. | Sep 1997 | A | 
| 5685844 | Marttila | Nov 1997 | A | 
| 5711989 | Ciardella et al. | Jan 1998 | A | 
| 5713856 | Eggers et al. | Feb 1998 | A | 
| 5754355 | Nakamura et al. | May 1998 | A | 
| 5788669 | Peterson | Aug 1998 | A | 
| 5800420 | Gross et al. | Sep 1998 | A | 
| 5807375 | Gross et al. | Sep 1998 | A | 
| 5814015 | Gargano et al. | Sep 1998 | A | 
| 5820622 | Gross et al. | Oct 1998 | A | 
| 5822715 | Worthington et al. | Oct 1998 | A | 
| 5848593 | Mcgrady et al. | Dec 1998 | A | 
| 5876370 | Blomquist | Mar 1999 | A | 
| 5935099 | Peterson et al. | Aug 1999 | A | 
| 5959418 | Gotou | Sep 1999 | A | 
| 5997475 | Bortz | Dec 1999 | A | 
| 6024699 | Surwit et al. | Feb 2000 | A | 
| 6070761 | Bloom et al. | Jun 2000 | A | 
| 6144866 | Miesel et al. | Nov 2000 | A | 
| 6188192 | Chen | Feb 2001 | B1 | 
| 6243222 | Boutaghou et al. | Jun 2001 | B1 | 
| 6285521 | Hussein | Sep 2001 | B1 | 
| 6368272 | Porumbescu | Apr 2002 | B1 | 
| 6379301 | Worthington et al. | Apr 2002 | B1 | 
| 6396652 | Kawachi et al. | May 2002 | B1 | 
| 6427088 | Bowman, IV et al. | Jul 2002 | B1 | 
| 6471855 | Odak et al. | Oct 2002 | B1 | 
| 6505059 | Kollias et al. | Jan 2003 | B1 | 
| 6535714 | Melker et al. | Mar 2003 | B2 | 
| 6544212 | Galley et al. | Apr 2003 | B2 | 
| 6551276 | Mann et al. | Apr 2003 | B1 | 
| 6554798 | Mann et al. | Apr 2003 | B1 | 
| 6558351 | Steil et al. | May 2003 | B1 | 
| 6562001 | Lebel et al. | May 2003 | B2 | 
| 6571128 | Lebel et al. | May 2003 | B2 | 
| 6577899 | Lebel et al. | Jun 2003 | B2 | 
| 6582366 | Porumbescu | Jun 2003 | B1 | 
| 6585644 | Lebel et al. | Jul 2003 | B2 | 
| 6589229 | Connelly et al. | Jul 2003 | B1 | 
| 6594634 | Hampton et al. | Jul 2003 | B1 | 
| 6599281 | Struys et al. | Jul 2003 | B1 | 
| 6605072 | Struys et al. | Aug 2003 | B2 | 
| 6629934 | Mault et al. | Oct 2003 | B2 | 
| 6641533 | Causey, III et al. | Nov 2003 | B2 | 
| 6648821 | Lebel et al. | Nov 2003 | B2 | 
| 6649403 | Mcdevitt et al. | Nov 2003 | B1 | 
| 6656148 | Das et al. | Dec 2003 | B2 | 
| 6659948 | Lebel et al. | Dec 2003 | B2 | 
| 6668196 | Villegas et al. | Dec 2003 | B1 | 
| 6733446 | Lebel et al. | May 2004 | B2 | 
| 6740059 | Flaherty | May 2004 | B2 | 
| 6740072 | Starkweather et al. | May 2004 | B2 | 
| 6740075 | Lebel et al. | May 2004 | B2 | 
| 6744350 | Blomquist | Jun 2004 | B2 | 
| 6752787 | Causey, II et al. | Jun 2004 | B1 | 
| 6790198 | White et al. | Sep 2004 | B1 | 
| 6810290 | Lebel et al. | Oct 2004 | B2 | 
| 6811534 | Bowman, IV et al. | Nov 2004 | B2 | 
| 6819072 | White et al. | Nov 2004 | B2 | 
| 6827702 | Lebel et al. | Dec 2004 | B2 | 
| 6835175 | Porumbescu | Dec 2004 | B1 | 
| 6852104 | Blomquist | Feb 2005 | B2 | 
| 6872200 | Mann et al. | Mar 2005 | B2 | 
| 6873268 | Lebel et al. | Mar 2005 | B2 | 
| 6934220 | Cruitt et al. | Aug 2005 | B1 | 
| 6936029 | Mann et al. | Aug 2005 | B2 | 
| 6950708 | Bowman IV et al. | Sep 2005 | B2 | 
| 6958705 | Lebel et al. | Oct 2005 | B2 | 
| 6974437 | Lebel et al. | Dec 2005 | B2 | 
| 6979326 | Mann et al. | Dec 2005 | B2 | 
| 6997920 | Mann et al. | Feb 2006 | B2 | 
| 7022072 | Fox et al. | Apr 2006 | B2 | 
| 7024236 | Ford | Apr 2006 | B2 | 
| 7025743 | Mann et al. | Apr 2006 | B2 | 
| 7033338 | Vilks et al. | Apr 2006 | B2 | 
| 7041082 | Blomquist et al. | May 2006 | B2 | 
| 7109878 | Mann et al. | Sep 2006 | B2 | 
| 7137951 | Pilarski | Nov 2006 | B2 | 
| 7141425 | Dzekunov et al. | Nov 2006 | B2 | 
| 7154102 | Poteet et al. | Dec 2006 | B2 | 
| 7156808 | Quy | Jan 2007 | B2 | 
| 7179226 | Crothall et al. | Feb 2007 | B2 | 
| 7204823 | Estes et al. | Apr 2007 | B2 | 
| 7264730 | Connell et al. | Sep 2007 | B2 | 
| 7267665 | Kamen et al. | Sep 2007 | B2 | 
| 7278983 | Ireland et al. | Oct 2007 | B2 | 
| 7282029 | Poulsen et al. | Oct 2007 | B1 | 
| 7289142 | Silverbrook | Oct 2007 | B2 | 
| 7291107 | Hellwig et al. | Nov 2007 | B2 | 
| 7303680 | Connell et al. | Dec 2007 | B2 | 
| 7306555 | Dolecek et al. | Dec 2007 | B2 | 
| 7316899 | Mcdevitt et al. | Jan 2008 | B2 | 
| 7318892 | Connell et al. | Jan 2008 | B2 | 
| 7324949 | Bristol | Jan 2008 | B2 | 
| 7341577 | Gill | Mar 2008 | B2 | 
| 7347836 | Peterson et al. | Mar 2008 | B2 | 
| 7350190 | Torres et al. | Mar 2008 | B2 | 
| 7351340 | Connell et al. | Apr 2008 | B2 | 
| 7354420 | Steil et al. | Apr 2008 | B2 | 
| 7399277 | Saidara et al. | Jul 2008 | B2 | 
| 7402153 | Steil et al. | Jul 2008 | B2 | 
| 7404796 | Gensberg | Jul 2008 | B2 | 
| 7442186 | Blomquist | Oct 2008 | B2 | 
| 7464010 | Yang et al. | Dec 2008 | B2 | 
| 7465285 | Hutchinson et al. | Dec 2008 | B2 | 
| 7476209 | Gara et al. | Jan 2009 | B2 | 
| 7479123 | Briggs | Jan 2009 | B2 | 
| 7510544 | Vilks et al. | Mar 2009 | B2 | 
| 7515060 | Blomquist | Apr 2009 | B2 | 
| 7517335 | Gravesen et al. | Apr 2009 | B2 | 
| 7547281 | Hayes et al. | Jun 2009 | B2 | 
| 7553281 | Hellwig et al. | Jun 2009 | B2 | 
| 7559926 | Blischak | Jul 2009 | B1 | 
| 7569030 | Lebel et al. | Aug 2009 | B2 | 
| 7606274 | Mirov et al. | Oct 2009 | B2 | 
| 7630773 | Seeberger et al. | Dec 2009 | B2 | 
| 7647237 | Malave et al. | Jan 2010 | B2 | 
| 7651489 | Estes et al. | Jan 2010 | B2 | 
| 7651845 | Doyle et al. | Jan 2010 | B2 | 
| 7653639 | Peterson et al. | Jan 2010 | B2 | 
| 7654976 | Peterson et al. | Feb 2010 | B2 | 
| 7662638 | Dadala et al. | Feb 2010 | B2 | 
| 7678071 | Lebel et al. | Mar 2010 | B2 | 
| 7678833 | Ott | Mar 2010 | B2 | 
| 7704226 | Mueller, Jr. et al. | Apr 2010 | B2 | 
| 7717903 | Estes et al. | May 2010 | B2 | 
| 7734323 | Blomquist et al. | Jun 2010 | B2 | 
| 7737581 | Spurlin et al. | Jun 2010 | B2 | 
| 7749528 | De Carvalho et al. | Jul 2010 | B2 | 
| 7751907 | Blomquist | Jul 2010 | B2 | 
| 7753879 | Mernoe | Jul 2010 | B2 | 
| 7756722 | Levine et al. | Jul 2010 | B2 | 
| 7766830 | Fox et al. | Aug 2010 | B2 | 
| 7768408 | Reggiardo et al. | Aug 2010 | B2 | 
| 7779183 | Koehler et al. | Aug 2010 | B2 | 
| 7785288 | Mernoe et al. | Aug 2010 | B2 | 
| 7785313 | Mastrototaro | Aug 2010 | B2 | 
| 7801596 | Fischell et al. | Sep 2010 | B2 | 
| 7806886 | Kanderian et al. | Oct 2010 | B2 | 
| 7811279 | John | Oct 2010 | B2 | 
| 7815602 | Mann et al. | Oct 2010 | B2 | 
| 7831310 | Lebel et al. | Nov 2010 | B2 | 
| 7837647 | Estes et al. | Nov 2010 | B2 | 
| 7850641 | Lebel et al. | Dec 2010 | B2 | 
| 7860583 | Condurso et al. | Dec 2010 | B2 | 
| 7875022 | Wenger et al. | Jan 2011 | B2 | 
| 7884729 | Reggiardo et al. | Feb 2011 | B2 | 
| 7887511 | Mernoe et al. | Feb 2011 | B2 | 
| 7901394 | Ireland et al. | Mar 2011 | B2 | 
| 7905859 | Bynum et al. | Mar 2011 | B2 | 
| 7912674 | Killoren Clark et al. | Mar 2011 | B2 | 
| 7922462 | Preuthun et al. | Apr 2011 | B2 | 
| 7933780 | De La Huerga | Apr 2011 | B2 | 
| 7935076 | Estes et al. | May 2011 | B2 | 
| 7942844 | Moberg et al. | May 2011 | B2 | 
| 7946985 | Mastrototaro et al. | May 2011 | B2 | 
| 7959598 | Estes | Jun 2011 | B2 | 
| 7972296 | Braig et al. | Jul 2011 | B2 | 
| 7976778 | Drucker et al. | Jul 2011 | B2 | 
| 7979136 | Young et al. | Jul 2011 | B2 | 
| 7981034 | Jennewine et al. | Jul 2011 | B2 | 
| 7988850 | Roncadi et al. | Aug 2011 | B2 | 
| 7999674 | Kamen | Aug 2011 | B2 | 
| 8007724 | Guzman | Aug 2011 | B2 | 
| 8012119 | Estes et al. | Sep 2011 | B2 | 
| 8020564 | Batch | Sep 2011 | B2 | 
| 8029459 | Rush et al. | Oct 2011 | B2 | 
| 8029460 | Rush et al. | Oct 2011 | B2 | 
| 8030058 | Benedict et al. | Oct 2011 | B1 | 
| 8034026 | Grant et al. | Oct 2011 | B2 | 
| 8070742 | Woo | Dec 2011 | B2 | 
| 8092428 | Ramey et al. | Jan 2012 | B2 | 
| 8105268 | Lebel et al. | Jan 2012 | B2 | 
| 8106534 | Spurlin et al. | Jan 2012 | B2 | 
| 8109921 | Estes et al. | Feb 2012 | B2 | 
| 8114350 | Silver et al. | Feb 2012 | B1 | 
| 8118770 | Galley et al. | Feb 2012 | B2 | 
| 8119593 | Richardson et al. | Feb 2012 | B2 | 
| 8121857 | Galasso et al. | Feb 2012 | B2 | 
| 8129429 | Sporn et al. | Mar 2012 | B2 | 
| 8133197 | Blomquist et al. | Mar 2012 | B2 | 
| 8140275 | Campbell et al. | Mar 2012 | B2 | 
| 8149131 | Blomquist | Apr 2012 | B2 | 
| 8152789 | Starkweather et al. | Apr 2012 | B2 | 
| 8170721 | Nickerson | May 2012 | B2 | 
| 8192394 | Estes et al. | Jun 2012 | B2 | 
| 8192395 | Estes et al. | Jun 2012 | B2 | 
| 8202267 | Field et al. | Jun 2012 | B2 | 
| 8204729 | Sher | Jun 2012 | B2 | 
| 8206296 | Jennewine | Jun 2012 | B2 | 
| 8206350 | Mann et al. | Jun 2012 | B2 | 
| 8208984 | Blomquist et al. | Jun 2012 | B2 | 
| 8211364 | Drucker et al. | Jul 2012 | B2 | 
| 8219222 | Blomquist | Jul 2012 | B2 | 
| 8221345 | Blomquist | Jul 2012 | B2 | 
| 8221385 | Estes | Jul 2012 | B2 | 
| 8226891 | Sloan et al. | Jul 2012 | B2 | 
| 8231562 | Buck et al. | Jul 2012 | B2 | 
| 8236242 | Drucker et al. | Aug 2012 | B2 | 
| 8246540 | Ginsberg | Aug 2012 | B2 | 
| 8250483 | Blomquist | Aug 2012 | B2 | 
| 8257300 | Budiman et al. | Sep 2012 | B2 | 
| 8257652 | Drucker et al. | Sep 2012 | B2 | 
| 8257653 | Drucker et al. | Sep 2012 | B2 | 
| 8287495 | Michaud et al. | Oct 2012 | B2 | 
| 8294581 | Kamen | Oct 2012 | B2 | 
| 8298184 | Diperna et al. | Oct 2012 | B2 | 
| 8326650 | Horiguchi et al. | Dec 2012 | B2 | 
| 8328754 | Estes et al. | Dec 2012 | B2 | 
| 8340792 | Condurso et al. | Dec 2012 | B2 | 
| 8343092 | Rush et al. | Jan 2013 | B2 | 
| 8346399 | Blomquist | Jan 2013 | B2 | 
| 8348885 | Moberg et al. | Jan 2013 | B2 | 
| 8348886 | Kanderian, Jr. et al. | Jan 2013 | B2 | 
| 8348923 | Kanderian, Jr. et al. | Jan 2013 | B2 | 
| 8376943 | Kovach et al. | Feb 2013 | B2 | 
| 8414523 | Blomquist et al. | Apr 2013 | B2 | 
| 8414563 | Kamen et al. | Apr 2013 | B2 | 
| 8435206 | Evans et al. | May 2013 | B2 | 
| 8444595 | Brukalo et al. | May 2013 | B2 | 
| 8449523 | Brukalo et al. | May 2013 | B2 | 
| 8452953 | Buck et al. | May 2013 | B2 | 
| 8454510 | Yodfat et al. | Jun 2013 | B2 | 
| 8454576 | Mastrototaro et al. | Jun 2013 | B2 | 
| 8457901 | Beshan et al. | Jun 2013 | B2 | 
| 8465460 | Yodfat et al. | Jun 2013 | B2 | 
| 8467980 | Campbell et al. | Jun 2013 | B2 | 
| 8475409 | Tsoukalis | Jul 2013 | B2 | 
| 8502662 | Pohlman et al. | Aug 2013 | B2 | 
| 8504179 | Blomquist | Aug 2013 | B2 | 
| 8579853 | Reggiardo et al. | Nov 2013 | B2 | 
| 8585638 | Blomquist | Nov 2013 | B2 | 
| 8657807 | Blomquist | Feb 2014 | B2 | 
| 8734428 | Blomquist | May 2014 | B2 | 
| 8753316 | Blomquist | Jun 2014 | B2 | 
| 8768717 | Blomquist | Jul 2014 | B2 | 
| 8821433 | Blomquist | Sep 2014 | B2 | 
| 8858526 | Blomquist | Oct 2014 | B2 | 
| 9474856 | Blomquist | Oct 2016 | B2 | 
| 9492608 | Saint | Nov 2016 | B2 | 
| 9603995 | Rosinko et al. | Mar 2017 | B2 | 
| 9737656 | Rosinko | Aug 2017 | B2 | 
| 9940441 | Walsh | Apr 2018 | B2 | 
| 10016561 | Saint et al. | Jul 2018 | B2 | 
| 10049768 | Blomquist | Aug 2018 | B2 | 
| 20010041869 | Causey et al. | Nov 2001 | A1 | 
| 20020029776 | Blomquist | Mar 2002 | A1 | 
| 20020065454 | Lebel et al. | May 2002 | A1 | 
| 20020072733 | Flaherty | Jun 2002 | A1 | 
| 20020096543 | Juselius | Jul 2002 | A1 | 
| 20020107476 | Mann et al. | Aug 2002 | A1 | 
| 20020193679 | Malave et al. | Dec 2002 | A1 | 
| 20030028089 | Galley et al. | Feb 2003 | A1 | 
| 20030032867 | Crothall et al. | Feb 2003 | A1 | 
| 20030040821 | Case | Feb 2003 | A1 | 
| 20030055570 | Ribeiro, Jr. | Mar 2003 | A1 | 
| 20030060765 | Campbell et al. | Mar 2003 | A1 | 
| 20030065308 | Lebel et al. | Apr 2003 | A1 | 
| 20030130616 | Steil et al. | Jul 2003 | A1 | 
| 20030163088 | Blomquist | Aug 2003 | A1 | 
| 20030163789 | Blomquist | Aug 2003 | A1 | 
| 20030208113 | Mault et al. | Nov 2003 | A1 | 
| 20030211617 | Jones | Nov 2003 | A1 | 
| 20030212364 | Mann et al. | Nov 2003 | A1 | 
| 20040015132 | Brown | Jan 2004 | A1 | 
| 20040073095 | Causey et al. | Apr 2004 | A1 | 
| 20040193090 | Lebel et al. | Oct 2004 | A1 | 
| 20050021006 | Tonnies | Jan 2005 | A1 | 
| 20050021376 | Zaleski et al. | Jan 2005 | A1 | 
| 20050022274 | Campbell | Jan 2005 | A1 | 
| 20050027182 | Siddiqui et al. | Feb 2005 | A1 | 
| 20050137530 | Campbell et al. | Jun 2005 | A1 | 
| 20050143864 | Blomquist | Jun 2005 | A1 | 
| 20050159656 | Hockersmith et al. | Jul 2005 | A1 | 
| 20050171513 | Mann et al. | Aug 2005 | A1 | 
| 20050177135 | Hildebrand | Aug 2005 | A1 | 
| 20050177395 | Blomquist | Aug 2005 | A1 | 
| 20050197621 | Poulsen et al. | Sep 2005 | A1 | 
| 20050240092 | Shah et al. | Oct 2005 | A1 | 
| 20050246416 | Blomquist | Nov 2005 | A1 | 
| 20060031094 | Cohen et al. | Feb 2006 | A1 | 
| 20060047192 | Hellwig et al. | Mar 2006 | A1 | 
| 20060137695 | Hellwig et al. | Jun 2006 | A1 | 
| 20060149220 | Ullestad et al. | Jul 2006 | A1 | 
| 20060173406 | Hayes et al. | Aug 2006 | A1 | 
| 20060173444 | Choy et al. | Aug 2006 | A1 | 
| 20060253296 | Liisberg et al. | Nov 2006 | A1 | 
| 20060264835 | Nielsen et al. | Nov 2006 | A1 | 
| 20060276771 | Galley et al. | Dec 2006 | A1 | 
| 20070010950 | Abensour et al. | Jan 2007 | A1 | 
| 20070033074 | Nitzan et al. | Feb 2007 | A1 | 
| 20070060869 | Tolle et al. | Mar 2007 | A1 | 
| 20070060870 | Tolle et al. | Mar 2007 | A1 | 
| 20070066956 | Finkel | Mar 2007 | A1 | 
| 20070093786 | Goldsmith et al. | Apr 2007 | A1 | 
| 20070100222 | Mastrototaro et al. | May 2007 | A1 | 
| 20070112301 | Preuthun et al. | May 2007 | A1 | 
| 20070118405 | Campbell et al. | May 2007 | A1 | 
| 20070123819 | Mernoe et al. | May 2007 | A1 | 
| 20070124002 | Estes et al. | May 2007 | A1 | 
| 20070156033 | Causey, III et al. | Jul 2007 | A1 | 
| 20070161955 | Bynum et al. | Jul 2007 | A1 | 
| 20070179355 | Rosen | Aug 2007 | A1 | 
| 20070219480 | Kamen et al. | Sep 2007 | A1 | 
| 20070219496 | Kamen et al. | Sep 2007 | A1 | 
| 20070219597 | Kamen et al. | Sep 2007 | A1 | 
| 20070228071 | Kamen et al. | Oct 2007 | A1 | 
| 20070250007 | Shekalim | Oct 2007 | A1 | 
| 20070251835 | Mehta et al. | Nov 2007 | A1 | 
| 20070253021 | Mehta et al. | Nov 2007 | A1 | 
| 20070253380 | Jollota et al. | Nov 2007 | A1 | 
| 20070254593 | Jollata et al. | Nov 2007 | A1 | 
| 20070255116 | Mehta et al. | Nov 2007 | A1 | 
| 20070255125 | Moberg et al. | Nov 2007 | A1 | 
| 20070255126 | Moberg et al. | Nov 2007 | A1 | 
| 20070255348 | Holtzclaw | Nov 2007 | A1 | 
| 20070258395 | Jollata et al. | Nov 2007 | A1 | 
| 20070287985 | Estes et al. | Dec 2007 | A1 | 
| 20080004601 | Jennewine et al. | Jan 2008 | A1 | 
| 20080033357 | Mann et al. | Feb 2008 | A1 | 
| 20080033360 | Evans et al. | Feb 2008 | A1 | 
| 20080033361 | Evans et al. | Feb 2008 | A1 | 
| 20080033402 | Blomquist | Feb 2008 | A1 | 
| 20080033749 | Blomquist | Feb 2008 | A1 | 
| 20080034323 | Blomquist | Mar 2008 | A1 | 
| 20080065007 | Peterson et al. | Mar 2008 | A1 | 
| 20080065016 | Peterson et al. | Mar 2008 | A1 | 
| 20080071251 | Moubayed et al. | Mar 2008 | A1 | 
| 20080071580 | Marcus et al. | Mar 2008 | A1 | 
| 20080076969 | Kraft et al. | Mar 2008 | A1 | 
| 20080097289 | Steil et al. | Apr 2008 | A1 | 
| 20080103447 | Reggiardo et al. | May 2008 | A1 | 
| 20080106431 | Blomquist | May 2008 | A1 | 
| 20080119705 | Patel et al. | May 2008 | A1 | 
| 20080126969 | Blomquist | May 2008 | A1 | 
| 20080139910 | Mastrototaro et al. | Jun 2008 | A1 | 
| 20080147004 | Mann et al. | Jun 2008 | A1 | 
| 20080147050 | Mann et al. | Jun 2008 | A1 | 
| 20080148235 | Foresti et al. | Jun 2008 | A1 | 
| 20080171967 | Blomquist et al. | Jul 2008 | A1 | 
| 20080172026 | Blomquist | Jul 2008 | A1 | 
| 20080172027 | Blomquist | Jul 2008 | A1 | 
| 20080172028 | Blomquist | Jul 2008 | A1 | 
| 20080172029 | Blomquist | Jul 2008 | A1 | 
| 20080172030 | Blomquist | Jul 2008 | A1 | 
| 20080172031 | Blomquist | Jul 2008 | A1 | 
| 20080183060 | Steil et al. | Jul 2008 | A1 | 
| 20080200868 | Alberti et al. | Aug 2008 | A1 | 
| 20080200869 | Bedingfield | Aug 2008 | A1 | 
| 20080206799 | Blomquist | Aug 2008 | A1 | 
| 20080228056 | Blomquist et al. | Sep 2008 | A1 | 
| 20080249470 | Malave et al. | Oct 2008 | A1 | 
| 20080269714 | Mastrototaro et al. | Oct 2008 | A1 | 
| 20080269723 | Mastrototaro et al. | Oct 2008 | A1 | 
| 20080287922 | Panduro | Nov 2008 | A1 | 
| 20080300534 | Blomquist | Dec 2008 | A1 | 
| 20080300572 | Rankers et al. | Dec 2008 | A1 | 
| 20080306434 | Dobbles et al. | Dec 2008 | A1 | 
| 20080306444 | Brister et al. | Dec 2008 | A1 | 
| 20090005726 | Jones et al. | Jan 2009 | A1 | 
| 20090030382 | Brandt et al. | Jan 2009 | A1 | 
| 20090030398 | Yodfat et al. | Jan 2009 | A1 | 
| 20090036753 | King | Feb 2009 | A1 | 
| 20090037020 | Brown | Feb 2009 | A1 | 
| 20090043290 | Villegas et al. | Mar 2009 | A1 | 
| 20090069745 | Estes et al. | Mar 2009 | A1 | 
| 20090069787 | Estes et al. | Mar 2009 | A1 | 
| 20090088731 | Campbel et al. | Apr 2009 | A1 | 
| 20090099866 | Newman | Apr 2009 | A1 | 
| 20090099867 | Newman | Apr 2009 | A1 | 
| 20090131861 | Braig et al. | May 2009 | A1 | 
| 20090150484 | Roberts | Jun 2009 | A1 | 
| 20090156990 | Wenger et al. | Jun 2009 | A1 | 
| 20090156991 | Roberts | Jun 2009 | A1 | 
| 20090157202 | Roberts et al. | Jun 2009 | A1 | 
| 20090157622 | Roberts et al. | Jun 2009 | A1 | 
| 20090157695 | Roberts | Jun 2009 | A1 | 
| 20090158274 | Roberts | Jun 2009 | A1 | 
| 20090163855 | Shin et al. | Jun 2009 | A1 | 
| 20090171269 | Jennewine et al. | Jul 2009 | A1 | 
| 20090177142 | Blomquist et al. | Jul 2009 | A1 | 
| 20090177147 | Blomquist et al. | Jul 2009 | A1 | 
| 20090177248 | Roberts | Jul 2009 | A1 | 
| 20090177249 | Roberts et al. | Jul 2009 | A1 | 
| 20090177769 | Roberts | Jul 2009 | A1 | 
| 20090212966 | Panduro | Aug 2009 | A1 | 
| 20090227855 | Hill et al. | Sep 2009 | A1 | 
| 20090254037 | Bryant, Jr. et al. | Oct 2009 | A1 | 
| 20090270810 | DeBelser et al. | Oct 2009 | A1 | 
| 20090270833 | DeBelser et al. | Oct 2009 | A1 | 
| 20090275886 | Blomquist et al. | Nov 2009 | A1 | 
| 20090281393 | Smith | Nov 2009 | A1 | 
| 20090292245 | Basso et al. | Nov 2009 | A1 | 
| 20100010330 | Rankers et al. | Jan 2010 | A1 | 
| 20100030092 | Kristensen et al. | Feb 2010 | A1 | 
| 20100049164 | Estes | Feb 2010 | A1 | 
| 20100056993 | Chase | Mar 2010 | A1 | 
| 20100064257 | Buck et al. | Mar 2010 | A1 | 
| 20100069890 | Graskov et al. | Mar 2010 | A1 | 
| 20100094251 | Estes | Apr 2010 | A1 | 
| 20100114015 | Kanderian, Jr. et al. | May 2010 | A1 | 
| 20100138197 | Sher | Jun 2010 | A1 | 
| 20100156633 | Buck et al. | Jun 2010 | A1 | 
| 20100160740 | Cohen et al. | Jun 2010 | A1 | 
| 20100161236 | Cohen et al. | Jun 2010 | A1 | 
| 20100161346 | Getschmann et al. | Jun 2010 | A1 | 
| 20100164727 | Bazargan et al. | Jul 2010 | A1 | 
| 20100168538 | Keenan et al. | Jul 2010 | A1 | 
| 20100168711 | Bazargan et al. | Jul 2010 | A1 | 
| 20100174266 | Estes | Jul 2010 | A1 | 
| 20100174553 | Kaufman et al. | Jul 2010 | A1 | 
| 20100185142 | Kamen et al. | Jul 2010 | A1 | 
| 20100185175 | Kamen et al. | Jul 2010 | A1 | 
| 20100192686 | Kamen et al. | Aug 2010 | A1 | 
| 20100198142 | Sloan et al. | Aug 2010 | A1 | 
| 20100198183 | Lanigan et al. | Aug 2010 | A1 | 
| 20100198520 | Breton et al. | Aug 2010 | A1 | 
| 20100205001 | Knudsen et al. | Aug 2010 | A1 | 
| 20100218132 | Soni et al. | Aug 2010 | A1 | 
| 20100222765 | Blomquist et al. | Sep 2010 | A1 | 
| 20100228186 | Estes et al. | Sep 2010 | A1 | 
| 20100249530 | Rankers et al. | Sep 2010 | A1 | 
| 20100251114 | Wehba et al. | Sep 2010 | A1 | 
| 20100256565 | Mernoe et al. | Oct 2010 | A1 | 
| 20100256598 | Mernoe et al. | Oct 2010 | A1 | 
| 20100262117 | Magni et al. | Oct 2010 | A1 | 
| 20100262434 | Shaya | Oct 2010 | A1 | 
| 20100274592 | Nitzan et al. | Oct 2010 | A1 | 
| 20100292556 | Kubel et al. | Nov 2010 | A1 | 
| 20100292634 | Kircher, Jr. et al. | Nov 2010 | A1 | 
| 20100295686 | Sloan et al. | Nov 2010 | A1 | 
| 20100298662 | Yu et al. | Nov 2010 | A1 | 
| 20100305545 | Kanderian, Jr. et al. | Dec 2010 | A1 | 
| 20100305965 | Benjamin et al. | Dec 2010 | A1 | 
| 20100317950 | Galley et al. | Dec 2010 | A1 | 
| 20100324382 | Cantwell et al. | Dec 2010 | A1 | 
| 20100324932 | Galley et al. | Dec 2010 | A1 | 
| 20100331652 | Groll et al. | Dec 2010 | A1 | 
| 20110021898 | Wei et al. | Jan 2011 | A1 | 
| 20110033833 | Blomquist et al. | Feb 2011 | A1 | 
| 20110040247 | Mandro et al. | Feb 2011 | A1 | 
| 20110040251 | Blomquist et al. | Feb 2011 | A1 | 
| 20110047499 | Mandro et al. | Feb 2011 | A1 | 
| 20110053121 | Heaton | Mar 2011 | A1 | 
| 20110071464 | Palerm | Mar 2011 | A1 | 
| 20110071465 | Wang et al. | Mar 2011 | A1 | 
| 20110071765 | Yodfat et al. | Mar 2011 | A1 | 
| 20110077493 | Shadforth et al. | Mar 2011 | A1 | 
| 20110077663 | Knudsen et al. | Mar 2011 | A1 | 
| 20110082439 | Wenger et al. | Apr 2011 | A1 | 
| 20110092788 | Long et al. | Apr 2011 | A1 | 
| 20110092894 | Mcgill et al. | Apr 2011 | A1 | 
| 20110098637 | Hill | Apr 2011 | A1 | 
| 20110098638 | Chawla et al. | Apr 2011 | A1 | 
| 20110098674 | Vincente et al. | May 2011 | A1 | 
| 20110106050 | Yodfat et al. | May 2011 | A1 | 
| 20110112505 | Starkweather et al. | May 2011 | A1 | 
| 20110112506 | Starkweather et al. | May 2011 | A1 | 
| 20110118699 | Yodfat et al. | May 2011 | A1 | 
| 20110118700 | Remde | May 2011 | A1 | 
| 20110119087 | Drucker et al. | May 2011 | A1 | 
| 20110124996 | Reinke et al. | May 2011 | A1 | 
| 20110124999 | Reggiardo et al. | May 2011 | A1 | 
| 20110125085 | Mcgill et al. | May 2011 | A1 | 
| 20110125095 | Lebel et al. | May 2011 | A1 | 
| 20110125530 | Drucker et al. | May 2011 | A1 | 
| 20110137239 | DeBelser et al. | Jun 2011 | A1 | 
| 20110144586 | Michaud et al. | Jun 2011 | A1 | 
| 20110144616 | Michaud et al. | Jun 2011 | A1 | 
| 20110151571 | Wollridge et al. | Jun 2011 | A1 | 
| 20110152769 | Ramey et al. | Jun 2011 | A1 | 
| 20110152770 | Diperna et al. | Jun 2011 | A1 | 
| 20110152824 | Diperna et al. | Jun 2011 | A1 | 
| 20110154237 | Bush et al. | Jun 2011 | A1 | 
| 20110160695 | Sigrist et al. | Jun 2011 | A1 | 
| 20110166544 | Verhoef et al. | Jul 2011 | A1 | 
| 20110166875 | Hayter et al. | Jul 2011 | A1 | 
| 20110178462 | Moberg et al. | Jul 2011 | A1 | 
| 20110184264 | Galasso et al. | Jul 2011 | A1 | 
| 20110190694 | Lanier, Jr. et al. | Aug 2011 | A1 | 
| 20110190701 | Remde et al. | Aug 2011 | A1 | 
| 20110196213 | Thukral et al. | Aug 2011 | A1 | 
| 20110196248 | Grunwald | Aug 2011 | A1 | 
| 20110208123 | Gray et al. | Aug 2011 | A1 | 
| 20110208155 | Palerm et al. | Aug 2011 | A1 | 
| 20110256024 | Cole et al. | Oct 2011 | A1 | 
| 20110319862 | Friedman et al. | Dec 2011 | A1 | 
| 20120013625 | Blomquist et al. | Jan 2012 | A1 | 
| 20120013802 | Blomquist et al. | Jan 2012 | A1 | 
| 20120029433 | Michaud et al. | Feb 2012 | A1 | 
| 20120029941 | Malave et al. | Feb 2012 | A1 | 
| 20120030610 | Diperna et al. | Feb 2012 | A1 | 
| 20120041415 | Estes et al. | Feb 2012 | A1 | 
| 20120059353 | Kovatchev et al. | Mar 2012 | A1 | 
| 20120095315 | Tenbarge et al. | Apr 2012 | A1 | 
| 20120096451 | Tenbarge | Apr 2012 | A1 | 
| 20120172802 | Blomquist | Jul 2012 | A1 | 
| 20120185267 | Kamen | Jul 2012 | A1 | 
| 20120191052 | Rao | Jul 2012 | A1 | 
| 20120191061 | Yodfat et al. | Jul 2012 | A1 | 
| 20120191062 | Blomquist | Jul 2012 | A1 | 
| 20120191063 | Brauker et al. | Jul 2012 | A1 | 
| 20120226124 | Blomquist | Sep 2012 | A1 | 
| 20120232484 | Blomquist | Sep 2012 | A1 | 
| 20120232485 | Blomquist | Sep 2012 | A1 | 
| 20120232486 | Blomquist | Sep 2012 | A1 | 
| 20120232520 | Sloan et al. | Sep 2012 | A1 | 
| 20120232521 | Blomquist | Sep 2012 | A1 | 
| 20120238854 | Blomquist | Sep 2012 | A1 | 
| 20120239362 | Blomquist | Sep 2012 | A1 | 
| 20120265722 | Blomquist | Oct 2012 | A1 | 
| 20120296269 | Blomquist | Nov 2012 | A1 | 
| 20120296310 | Blomquist | Nov 2012 | A1 | 
| 20120293328 | Blomquist | Dec 2012 | A1 | 
| 20120330227 | Budiman et al. | Dec 2012 | A1 | 
| 20130012878 | Blomquist | Jan 2013 | A1 | 
| 20130012879 | DeBelser et al. | Jan 2013 | A1 | 
| 20130012880 | Blomquist | Jan 2013 | A1 | 
| 20130015980 | Evans et al. | Jan 2013 | A1 | 
| 20130018315 | Blomquist | Jan 2013 | A1 | 
| 20130131630 | Blomquist | May 2013 | A1 | 
| 20130159456 | Daoud et al. | Jun 2013 | A1 | 
| 20130231711 | Kaib | Sep 2013 | A1 | 
| 20140005633 | Finan | Jan 2014 | A1 | 
| 20140012511 | Mensinger et al. | Jan 2014 | A1 | 
| 20140094744 | Blomquist | Apr 2014 | A1 | 
| 20140094764 | Blomquist | Apr 2014 | A1 | 
| 20140095485 | Blomquist | Apr 2014 | A1 | 
| 20140095499 | Blomquist | Apr 2014 | A1 | 
| 20140276420 | Rosinko | Sep 2014 | A1 | 
| 20140351712 | Blomquist | Nov 2014 | A1 | 
| 20150081894 | Blomquist | Mar 2015 | A1 | 
| 20150182693 | Rosinko | Jul 2015 | A1 | 
| 20150314062 | Blomquist et al. | Nov 2015 | A1 | 
| 20150317437 | Daoud et al. | Nov 2015 | A1 | 
| 20160082188 | Blomquist et al. | Mar 2016 | A1 | 
| 20160129185 | Ludolph | May 2016 | A1 | 
| 20170165416 | Saint | Jun 2017 | A1 | 
| 20170246380 | Rosinko et al. | Aug 2017 | A1 | 
| 20170312423 | Rosinko | Nov 2017 | A1 | 
| 20180021514 | Rosinko | Jan 2018 | A1 | 
| 20180133398 | Blomquist | May 2018 | A1 | 
| 20180137252 | Mairs | May 2018 | A1 | 
| 20180137938 | Vaddiraju | May 2018 | A1 | 
| 20180226145 | Walsh | Aug 2018 | A1 | 
| Number | Date | Country | 
|---|---|---|
| 1102194 | May 2001 | EP | 
| 9958973 | Nov 1999 | WO | 
| 03081052 | Oct 2003 | WO | 
| 2004093648 | Nov 2004 | WO | 
| 2007056504 | May 2007 | WO | 
| 2007065944 | Jun 2007 | WO | 
| 2009032400 | Mar 2009 | WO | 
| 2009035759 | Mar 2009 | WO | 
| Entry | 
|---|
| US 8,333,733 B2, 12/2012, Lanigan et al. (withdrawn) | 
| Application for U.S. Appl. No. 60/734,498, filed May 31, 2007, 10 pages. | 
| International Search Report and Written Opinion mailed Mar. 10, 2008 for International Application No. PCT/US-2007/022052. | 
| International Search Report and Written Opinion for Internation Application No. PCT/US-2007/022004 mailed Oct. 9, 2008. | 
| International Search Report for PCT/US-2007/022048 dated Mar. 7, 2008. | 
| International Search Report for PCT/US-2007/022049 dated Mar. 7, 2008. | 
| Plougmann et al., “DiasNet-a diabetes advisory system for communication and education via the internet,” Internation Journal of Medical Informatics vol. 64, pp. 319-330 (Dec. 2001) Abstract. | 
| Lehmann et al., “Combining rule based reasoning and mathematical modeling in diabetes care,” Artificial Intelligence in Medicine. pp. 137-160. (1994). | 
| Wach et al., “Numerical Approximation of Mathematical Model for Absorption of SubcutaneoUS-ly Injected Insulin,” Department of Internal Medicine. vol. 33, pp. 18-23. (1995). | 
| Puckett et al., “A Model for multiple subcutaneoUS-insulin injections developed from individual diabetic patient data,” Chemical Engineering Department. University of Wisconsin-Madison, Wisconsin (1995). | 
| Bott et al., “Impact of Smoking on the Metabolic Action of SubcutaneoUS—Regular Insulin in Type 2 Diabetic patients,” Horm. Metab. res., vol. 37, pp. 445-449 (2005). | 
| Deltec Cozmo Personalized Insulin Pump Starting Guide, Smiths Medical MD, pp. 1-79 (2004). | 
| Hildebrandt, “Subcutaneous absorption of Insulin in insulin-dependent diabetic patients,” Danish Medical Bulletin., vol. 38, No. 4. pp. 337-346. (Aug. 1991). | 
| Trajanoski et al., “Pharmacokinetic Model for Absorption of Subcutaneously Injected Soluble Insulin and Monomeric Insulin Analogues,” Biomed Technik. vol. 38, pp. 224-231 (1993). | 
| Wilinska et al., “Insulin Kinetics in Type-1 Diabetes: Continuous and Bolis Delivery of Rapid Acting Insulin,” IEEE Transactions on Biomedical Engineering, vol. 52, No. 1, pp. 3-12. Jan. 2005. | 
| Application and File History for U.S. Appl. No. 13/477,666, filed May 22, 2012, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 11/018,706, filed Dec. 20, 2004, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 11/582,852, filed Oct. 17, 2006, inventor Blomquist et al. | 
| Application and File History for U.S. Appl. No. 11/582,841, filed Oct. 17, 2006, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 11/582,877, filed Oct. 17, 2006, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 13/477,684, filed May 22, 2012, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 13/477,679, filed May 22, 2012, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 13/477,641, filed May 22, 2012, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 11/582,823, filed Oct. 17, 2006, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 11/582,831, filed Oct. 17, 2006, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 13/477,657, filed May 22, 2012, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 10/087,449, filed Feb. 28, 2002, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 11/582,519, filed Oct. 17, 2006, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 13/281,168, filed Oct. 15, 2011, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 13/481,228, filed May 25, 2012, inventor Blomquist. | 
| Application and File History for U.S. Appl. No. 14/455,460, filed Aug. 8, 2014, inventor Blomquist. | 
| Number | Date | Country | |
|---|---|---|---|
| 20220101978 A1 | Mar 2022 | US | 
| Number | Date | Country | |
|---|---|---|---|
| Parent | 15954173 | Apr 2018 | US | 
| Child | 17549404 | US | |
| Parent | 14455460 | Aug 2014 | US | 
| Child | 15954173 | US | |
| Parent | 13477641 | May 2012 | US | 
| Child | 14455460 | US | |
| Parent | 13281168 | Oct 2011 | US | 
| Child | 13477641 | US | |
| Parent | 11582519 | Oct 2006 | US | 
| Child | 13281168 | US |