The present invention relates to systems and methods for operating drug delivery devices, such as drug pumps.
Various ambulatory medical devices are known for treating and/or monitoring patients at a remote site away from the caregiver's or clinician's office. One example of an ambulatory medical device is a drug delivery device, such as a drug pump, for providing periodic or continuous drug delivery to the patient when the patient is away from the caregiver's office.
Certain drugs rarely achieve their maximum therapeutic action through conventional injection techniques. Many drugs reach their full potential only through precise delivery over an extended period of time. With controlled drug infusion through a drug pump, the drug can be given at a precise rate that will keep the drug concentration within the therapeutic margin and out of the toxic range. Ambulatory drug pumps can provide appropriate drug delivery to the patient at a controllable rate which does not require frequent medical attention and which allows the patient to leave the hospital or caregiver's office.
A failure to adequately monitor the drug pump and the patient's usage of the drug pump can reduce or eliminate any benefits the patient may have received from a proper drug delivery therapy. In some cases, the drug therapies can have serious health consequences to the patient if the drugs are not administered properly.
Various concerns arise in connection with operation of the drug pumps. One concern arises in that the drug pump must be adequately monitored when the patient utilizes the drug pump at a remote site. Another concern relates to controlling the sophisticated therapies desired by the caregivers and the patients for the ambulatory drug pumps. Additional concerns relate to accurate pumping of an appropriate drug therapy. Still further concerns relate to the costs to manufacture and maintain the drug pump.
There is a need for drug pump operating systems and methods which address the above concerns and other concerns.
The present invention concerns a drug pump including a control module interconnectable to a cassette, the cassette being linked to a remote fluid reservoir or an enclosed fluid reservoir disposed within the cassette. The control module includes a pump mechanism for pumping fluid from the fluid reservoir to the patient. The control module includes a control system including a pump application program for providing a desired therapy, and patient specific settings accessed by the pump application program to deliver the particular therapy desired to the patient. The control system further includes a display and a keyboard. Preferably, a communications port is provided to transfer information to and from the drug pump. The drug pump is programmable to allow for different pump application programs for pumping different therapies to a patient, such as an antibiotic therapy, a chemotherapy, a pain control therapy, and a nutritional therapy.
Systems and methods are provided for communication between two drug pumps or between a drug pump and a computer. Further systems and methods are provided for simulating a pump, such as for training purposes. Systems and methods are further provided for reprogramming the pump application program including a flash memory resident within the control module. Systems and methods are also provided for identifying a cassette mounted to the control module. Systems and methods are further provided for automated testing of the pump systems, such as operation of the pumping mechanism.
Referring now to
In
Control module 102 includes an outer housing 120 containing within the control system and pump mechanism 140. Control module 102 includes a keyboard 122 with a plurality of keys 124 including up and down arrow keys 124a, 124b for scrolling. Tactile structures can be provided to assist a user in distinguishing the keys 124 by feel. Keyboard 122 permits entry of information to pump 100. Control module 120 further includes a display 126 for displaying information concerning operation of pump 100. Visual indicators 128, 130, such as amber and green LED indicators are provided with control module 120 to indicate various conditions of pump 100 to the patient or caregiver.
Referring now to
Pump 100 is an expulsor or peristaltic infusion pump which includes pump mechanism 140 as shown in
Preferably, cam shaft 154 is constructed and arranged with double lobes (1800 activation cycle) for each cam 162, 164, 166 for optimized energy consumption, such as described in U.S. Pat. No. 5,364,242, issued Nov. 15, 1994, the disclosure of which is incorporated herein by reference. Preferably, pump mechanism 140 is made in accordance with the methods described in U.S. Pat. No. 5,364,242. Other pump mechanisms are anticipated including finger style pump mechanisms, roller pump mechanisms, and other fluid pumping arrangements. Examples of further expulsor style infusion pumps are shown in U.S. Pat. Nos. 4,559,038; 4,565,542; 4,650,469; and 5,181,910, the disclosures of which are incorporated herein by reference.
Referring now to
Both adaptor 170 and cassette 104 include an upper surface 175 with two extending hooks 177 and a loop 176 which permit releasable mounting to control module 102. See for example U.S. Pat. No. 4,565,542 previously incorporated by reference. Adapter 170 and cassette 104 may be both referred to as “cassettes.” Hooks 177 engage a suspended pin assembly on control module 102 and loop 176 is engaged by latch 116 to mount the cassette to control module 102. Latch 116 in the latched state holds loop 176 so that the cassette cannot be pivoted away from control module 102 about an axis defined by hooks 177 and the suspended pin assembly.
Referring now to
Specifically, memory 184 stores various programs and data related to the operation of pump 100. Memory 184 is coupled to microprocessor 182, which in turn runs the desired operating programs which control operation of pump mechanism 140. Stored in memory 184 is the program to permit communication with devices external to pump 100.
Access to microprocessor 182 is provided through communications port 132. Communications port 132 is preferably a standard RS232 communications port, although other communication links are possible (e.g., infrared telemetry). Information programmed into memory 184 instructs information to be transmitted or received via communications port 132. This feature allows information being received via communications port 132 from an external device to control pump 100. This feature also allows for the downloading of any or all information from memory 184 to an external device. An example of one type of device with which the pump 100 might communicate is described in U.S. patent application Ser. No. 08/561,809, which is entitled Pump Tracking System and was filed on Nov. 22, 1995, the disclosure of which is hereby incorporated by reference.
Control system 180 also includes keyboard 122 or other operator input structure for providing information to microprocessor 182. When a key 124 is pressed on keyboard 122, the key sends a signal to microprocessor 182 indicative of the key being pressed. Microprocessor 182 responds to the signal received in the desired manner. Other such input structures may include knobs, buttons, or other like structures for performing pump functions, such as starting, stopping, and priming pump 100.
Display 126 of control system 180 includes structure for displaying information to the patient or caregiver. A liquid crystal display (“LCD”) may be provided. A 4-line×21 character alpha/numeric display capable of creating 5×7 pixel characters may be used. Display signals sent from microprocessor 182 permit display of information related to the operation of pump 100.
Pump 100 may also be provided with a variety of sensors, switches, or other devices (hereinafter “sensors”). The type of sensors provided depends on the type of pump and its intended usage. An example of such sensors include occlusion detectors 186a, 186b for detecting occlusions in tubing 110. Preferably, at least a downstream occlusion sensor 186b, such as a pressure or force sensitive sensor for sensing pressure in tubing 110 is provided, along with an associated CPU or hardwired circuitry. A silicon piezo resistive sensor is an example of occlusion detector 186b. Further examples of desirable sensors for pump 100 include a cassette latch sensor 188 for indicating whether the control module's latch is open or closed, a cassette lock sensor 190 for indicating whether the latch is locked, an air sensor 192 for detecting air in tubing 110, a cassette identification sensor 196, and an external communications cable sensor 198. The sensors typically send a suitable electrical signal to microprocessor 182 indicative of the condition sensed. Microprocessor 182 and memory 184 is appropriately programmed to receive and process such signals. In addition, pump 100 may also be equipped with alarm 194, such as a visual alarm (e.g., lights 128, 130 of
Referring now to
Referring now to
Referring now to
An information transfer link is provided by communications link 208 between pump 100 and computer system 204. An information transfer link between pump tester 210 and computer system 204 is provided via communications link 212. A fluid line 214 between pump 100 and pump tester 210 provides a closed loop system 215 for automated testing of a functioning patient pump 100.
Referring now to
A motor position sensor 220 is provided for monitoring the position of the motor of the pumping mechanism. An appropriate signal is generated by sensor 220 and communicated to microprocessor 182.
Beeper 222 provides an audible signal at the desired time to the user of pump 100. An appropriate signal from microprocessor 182 activates beeper 222 at the appropriate time.
External communication sensor 198 senses when a communications cable connection or powered external serial device connection is made with respect to pump 100 at communications port 132. An appropriate signal is generated by external communication sensor 198 and sent to processor 182 indicative of the connection and/or the lack of connection with the communications cable or other connection device. Such connection can automatically trigger events in pump 100, such as initiation of pump to pump communications operation. Optionally, external communication sensor 198 can sense when a remote dose cord is attached, or when a remote data gathering device (e.g., temperature sensor, blood pressure monitor, EKG monitor, or respiratory monitor) is attached. The remote dose cord can also be used by the patient as an event marker for storage in pump memory 184. For example, the patient can note with the remote dose cord a nauseous condition.
Motor control switch 224 turns on and off the motor of pump mechanism 140 at the desired time based upon signals sent from microprocessor 182. Pump 100 can be intermittently operated a predetermined number of times at predetermined intervals according to the pump operations program provided to control system 180. These intervals can range from once every couple of seconds or less to as long as a couple of times an hour or more.
Air detector port 226 allows the plug in of an appropriate external sensor to sense air in the fluid conduit between the reservoir and the patient. A sensor may be provided to sense when the air sensor is attached, or when the door to the port is removed.
AC adapter sensor 228 senses when an AC adapter has been plugged into pump 100 such that the pump is then powered by the alternating current power supply or a battery pack.
Temperature sensor 229 senses the temperature to provide an input to the pump operating program to increase the accuracy of the pressure sensor. Tube compression properties can be affected by the ambient air temperature.
Battery sensor 230 senses the presence of a battery supply, such as a nine volt battery. Battery sensor 230 also senses when the battery supply is low.
Auxiliary battery output port 232 is provided for supplying a source of power to an external accessory of pump 100 from the power supply of pump 100.
Remote dose cord port 234 permits interconnection of a remote dose cord arrangement to pump 100. The remote dose cord arrangement permits the patient to remotely press or simulate pressing a key on keyboard 122, such as the key which manually operates the pumping mechanism, via a signal from a remote switch sent through remote dose cord port 234 to processor 182. A signal generated by an appropriate sensor at port 234 is sent to microprocessor 182 to indicate to microprocessor 182 that the remote dose cord is connected to pump 100.
A serial communication device 236 is provided for controlling communications access with auxiliary battery output port 232, remote dose cord port 234, communications port 132, and sensor 198 in a serial manner.
Pump mechanism 140 is illustrated as being controlled by motor control switch 224 and monitored by motor position sensor 220. Pump mechanism 140 is responsible for pumping fluid from the reservoir to the patient. As noted above, one possible pumping mechanism includes a rotatable cam shaft with tube engaging followers reciprocally mounted to move as the cam shaft rotates.
The various sensors, switches, and devices in control system 180 generate and/or receive an appropriate signal or signals during communication with microprocessor 182 during operation of pump 100. Microprocessor 182 is electrically interconnected through an appropriate interface bus 238 with all of the various sensors, switches, and other devices of pump 100. Microprocessor 182 responds to input signals by generating appropriate control output signals in accordance with the program control logic stored in memory. One preferred microprocessor 182 that may be used in connection with pump 100 is an MC68HC11E9 high-density complimentary metal-oxide semiconductor (HCMOS) high performance microcontroller unit (MCU) by Motorola. Such processor includes 512 bytes of electrically erasable programmable read only memory (EEPROM), and 512 bytes of random access memory (RAM).
Microprocessor 182 is further electrically interconnected to a flash memory 240, an electrically erasable programmable read only memory (EEPROM) 242 and a static random access memory (RAM) 244. A real time clock 246 is also provided. Battery 248, such as a lithium cell, provides a power supply to the real time clock 246 and the static RAM 244.
Microprocessor 182, flash memory 240, EEPROM 242, static RAM 244, gate array 257, real-time clock 246, and parallel input/output means 258 comprise at least a part of the processor control circuitry of control system 180.
As shown in
The pump system software includes software designed to reside inside the pump as well as software designed to run on a personal computer (PC). The pump is a hardware platform designed to support a variety of software which implements different infusion modes, as well as other utility features. In addition, the pump can communicate with accessory PC programs, either via a direct serial connection, over phone lines using a modem, or other communication methods. The system software includes executable programs such as pump software programs which implement an infusion mode (also called “applications”); pump software programs which implement something other than an infusion mode (also called “utilities”); and pump software which handles power-up control (also called “the boot system”).
The pump applications also can provide different infusion modes including, but not limited to:
The pump applications/utilities and boot system also can provide features in addition to infusion modes including, but not limited to:
The PC software programs can interface to a pump via a serial connection or other connection, and provide features including, but not limited to:
Desirable software of one preferred pump operating system and method includes software: for controlling pump power up; for implementing the pump application necessary to pump fluid to the patient; for implementing a master mode communication sequence between two pumps; for implementing a communication sequence between a PC and a patient pump; for testing the pump hardware; for controlling the pump hardware testing; and for changing resident pump applications and utilities using a PC.
The pump software controls the pump after a power-up or power-on reset. Various inputs, processing features, and outputs are provided:
Inputs
Processing Features
Outputs
The pump software implements different infusion modes or applications. Various inputs, processing features, and outputs are provided:
Inputs
Processing Features
Outputs
Pump software is provided to implement a master mode of operation, during which one pump controls a pump application in another pump via a remote serial connection by sending keypress messages and receiving display update messages. Various inputs, processing features, and outputs are provided:
Inputs
Processing Features
Outputs
PC software is provided which controls a pump application via a remote serial connection. Various inputs, processing features and outputs are provided:
Inputs
Processing Features
Outputs
Pump software is provided which allows the pump hardware to be tested via a direct serial connection. Various inputs, processing features and outputs are provided:
Inputs
Processing Features
Outputs
PC software is provided which controls pump hardware testing via a direct serial connection. Various inputs, processing features, and outputs are provided:
Inputs
Processing Features
Outputs
PC software is provided which changes resident pump applications and utilities via a direct serial connection. Various inputs, processing features, and outputs are provided:
Inputs
Processing Features
Outputs
Referring now to
In system 203, remote pump 100 is functioning as an ambulatory patient pump for pumping drugs to the patient and is located with the patient at a site remote from caregiver pump 200, such as at the patient's home 302. Also, site 302 may be the patient's workplace.
Pumps 100, 200 each include a pumping mechanism which is capable of pumping fluid from a fluid reservoir to a patient. Specific components of patient pump 100 are shown in greater detail in
Both caregiver pump 200 and patient pump 100 can be utilized for pumping or delivering a drug to a patient when the respective pump is interconnected to the patient. Pumps 100, 200 are preferably identical with respect to the electrical and the mechanical fluid pumping functions. One advantage of this is that caregiver pump 200 can be an unused spare patient pump 100. As will be discussed below, the respective control systems of pumps 100, 200 may be programmed differently to operate in the appropriate desired manner during pump to pump communications. As will also be discussed, this programming can be done locally or remotely. Preferably, pumps 100, 200 include appropriate programs to operate either as a master pump or as a slave pump during pump to pump communications. In some cases, the programs in each pump that control operation of the pumping mechanism will be different. This will also be discussed in more detail below.
Pumps 100, 200 each include operator input structure for permitting an operator of the respective pump to communicate with the control system of the pump, specifically the internal processor of the pump and the information in the internal memory. In the preferred embodiment, a plurality of operator keys 304 on caregiver pump 200 are provided for pressing by the caregiver. Preferably, each key has at least one function. Keys 304 send a signal to the control system of caregiver pump 200 indicative of the key pressed by the caregiver. The control system of pump 200 responds in the desired manner if an acceptable key press is made by the caregiver.
Patient pump 100 has keys 124 preferably identical to keys 304. Keys 124 send a signal to the control system of patient pump 100 indicative of the key pressed. The control system of patient pump 100 responds in the desired manner if an acceptable key press is made by the patient.
Caregiver pump 200 includes a display 306 for displaying selected information stored in the control system. In one preferred embodiment, display 306 includes an LCD dot matrix display. LCD dot matrix display 306 is interconnected to the control system of caregiver pump 200. Display signals sent from the control system of caregiver pump 200 permit display of information related to operation of pump 200 on display 306.
Patient pump 100 has a display 126 preferably identical to display 306 of caregiver pump 200. Display signals sent from the control system of patient pump 100 display information related to operation of pump 100 on display 126.
Communication port 308 of caregiver pump 200 permits interconnection of the control system of caregiver pump 200 to a modem 310 located locally with respect to caregiver pump 200. Caregiver pump 200 is interconnected to modem 310 through connection structure 312, such as an RS232 serial cable. Caregiver pump 200 and modem 310 may be located at the caregiver's office 300, at the caregiver's home during on-call periods, or even at a mobile site, such as the caregiver's automobile.
Communication port 132 permits interconnection of the control system of patient pump 100 to modem 320 with connection structure 322, such as an RS232 serial cable. Patient pump 100 and modem 320 are both located remotely to caregiver pump 200 and modem 310, such as at the patient's home or workplace 302, or other location remote from caregiver pump 200.
Communication between pump 200 and pump 100 through modems 310, 320 is over communications medium 324 such as conventional telephone lines, cellular phones, fiber optics links, satellite links, microwave links, or other links. Modems 310, 320 preferably communicate at 9600 bps and include error correction and data compression features over conventional telephone lines.
One advantage of the present invention is that the caregiver can communicate with the patient pump 100 using a similar pump, the caregiver's pump 200. The caregiver presumably has knowledge of operation of patient pump 100. This knowledge is useful in utilizing caregiver pump 200 to communicate with patient pump 100 to access the processor of patient pump 100 from a remote location.
Communication between the control system of the remote patient pump 100 and the control system of the local caregiver pump 200 permits remote data gathering from the remote patient pump by the local caregiver pump. Such data gathering may be useful for periodic monitoring of the patient pump 100 during use of the patient pump at the remote site. Data gathering may also be useful at the end of the patient use.
Communication between the remote patient pump 100 and the local caregiver pump 200 permits troubleshooting with respect to the remote patient pump, without the caregiver being located at the same location as the patient's pump. Remote troubleshooting is useful in the case where patients are unfamiliar with the some of the more sophisticated operations of their pump. Also, remote troubleshooting using the pump to pump communication system is useful for patients who have difficulty orally communicating with the caregiver over the telephone.
Communication with the remote patient pump 40 is also useful for accessing the pump operations programs for changing or adjusting the operation of the remote patient pump from the local site, thereby saving the caregiver and the patient time from not having to make an in-person visit.
Information programmed into the control system of the caregiver pump 200 permits the caregiver pump 200 to be put into a master mode from the normal pumping mode at the appropriate time. In the master mode, caregiver pump 200 sends a keyboard input signal indicative of a key 304 pressed by the caregiver over port 308 to patient pump 100. In the master mode, caregiver pump 200 receives its display signals primarily from patient pump 100 via communication port 308. In the master mode, the key presses on keys 124 of caregiver pump 200 do not access the memory of caregiver pump 200 for the purposes of programming the memory of caregiver pump 200 or selecting information for display relating to caregiver pump 200. The master mode is primarily for permitting caregiver pump 200 to communicate with the controller of patient pump 100 for the purposes of programming the memory of patient pump 100 or selecting information for display relating to patient pump 100 from the memory of patient pump 100. The master mode is carried out by a terminal application program in pump 200.
With respect to patient pump 100, information programmed into its control system permits patient pump 100 be put into a slave mode from the normal pumping mode at the appropriate time. In the slave mode, patient pump 100 receives keyboard input signals primarily from caregiver pump 200 via communication port 132. Patient pump 100 sends its display signals from communication port 132 to caregiver pump 200.
To communicate between caregiver pump 200 and patient pump 100 over modems 310, 320, caregiver pump 200 is out of the normal pumping mode and in the master mode. Similarly, patient pump 100 is out of the normal pumping mode and in the slave mode. In some cases, control systems with sufficient capacity may be provided where the pumps 200, 100 operate simultaneously in the normal pumping mode and in the master or slave modes.
In system 203, patient pump 100 is at least programmed to be operable in two modes, the normal pumping mode and the slave mode. There typically is not a need for patient pump 100 to operate in the master mode when the patient possesses the patient pump. Further, in system 203, caregiver pump 20 is at least operable in the master mode. However, situations are anticipated where it is desirable to have one or both pumps 100, 200 include programs for operation in the normal pumping mode, the slave mode, and the master mode. In some cases, caregiver pump 200 may be an unused patient spare. At a later date, the unused patient spare may be needed as a patient pump. This would require the slave mode operating program, and a particular normal operation mode program suitable for the patient. It may be more efficient for the caregiver if the controller of each pump 100, 200 is preprogrammed to include both the master mode program and the slave mode program. The selection of master or slave mode may be made by the caregiver by preconfiguring the patient's pump 100 to enter the slave mode during pump to pump communication, and not enter the master mode. The caregiver would have the capability to preconfigure the caregiver pump 200 to only enter the master mode during pump to pump communication, and not the slave mode if the caregiver desired. At some point later in time, the caregiver could reconfigure the caregiver pump 200 to only enter the slave mode during pump to pump communications if the caregiver pump 200 was needed as a patient pump.
In system 203 of
In one embodiment, disabling structure is provided with respect to caregiver pump 200 for disabling the pumping mechanism of caregiver pump 200 such that during pump to pump communications, the pumping mechanism and pumping protocol is suspended. Similarly, for patient pump 100, disabling structure is provided to suspend the pumping mechanism and the pumping protocol of patient pump 100 during pump to pump communications. This may be necessary due to processor capability limitations. This may also be a safety feature to prevent a caregiver from starting operation of the patient's pump from the remote site. However, in some situations it may be desirable for caregiver pump 200 to begin operation of the pumping mechanism of patient pump 100 at a site remote from the location of the caregiver during pump to pump communications. If a suitable controller is provided, it may be possible to operate the pumping mechanism of patient pump 100 while patient pump 100 is communicating with caregiver pump 200. Suspension of operation allows the caregiver to see how the pump is configured. The pump is restarted after the pump is disconnected from pump to pump communications set up.
Referring now to
The terminal application program shall be written such that it can stand alone in caregiver pump 200 which does not contain any patient pumping application program. The caregiver has the option of running a printing program 115 on the terminal application program which prints the terminal application communications record consisting of the history of at least one pump to pump communication session with patient pump 100. This data can be saved immediately after logging on to patient pump 100. Such data may include: the time and date of log on and the serial number of the pump running the terminal application program; information concerning patient pump 100 including the model number, the serial number, and the identifier of the pump application program running in patient pump 100; information concerning the specific application program running in patient pump 100 including the type of cassette attached to the pump, the status of the latch, the status of the lock, the status of the external power source, the status of the air detector, and the run/stop status of the application program. A terminal application communications record can be generated at the time of logging off including the same type of data noted above. The terminal application communications record can also include the last error code of patient pump 100. Also, the terminal application communications record may include the pump's current time, the pump's current date, the pump's event log, the pump's error history, the pump's hardware I.D., and the pump's 9-volt battery state. In the case of a patient controlled analgesic therapy, additional reports can be generated including any demand dose or clinician lock level.
When the software of caregiver pump 200 detects the communication cable has been connected, the caregiver shall be presented with two connection choices, a communications mode, and a printer mode. The communications mode allows communication with a pump. The printing option allows the caregiver to print an event log including a descriptive name of the report, the name, model and serial number of the pump, the time and date the report was printed, the active application program, a label placed to write the patient's name, the patient's identification number, and the name of the drug being infused.
Automatic selection of the slave mode and stoppage of the normal pumping mode in patient pump 100 is provided using suitable logic circuitry and sensor structure, such as sensor 198 in
Sensor 198 may include two spaced apart pins which engage the communication cable 322 to activate sensor 198 when the cable 322 is operatively positioned in communications port 132. Closure of the loop sends a suitable signal to microprocessor 182 that the cable 322 is present and pump to pump communications is desired, i.e. the slave mode operations program.
The operating system of caregiver pump 200 shall allow the pump to be placed in the caregiver mode of remote programming from the normal pumping mode of operation. Automatic selection of the master mode and automatic suspension of the normal pumping mode in caregiver pump 200 is provided using suitable logic circuitry and sensor structure to sense the presence of cable 320, such as with a similar sensor to sensor 198 of patient pump 100. Alternatively, the caregiver may have to hit a predetermined key 304 or flip a suitable switch to exit the normal pumping mode and enter the master mode if no automatic selection linked to insertion of cable 30 is provided.
Patient pump 100 sends its current display to caregiver pump 200 once the pumps are first linked together. In pump to pump communications, the control systems are preferably menu driven and the current display lets the caregiver see the current status of the patient pump 100 before the caregiver begins to send key input signals to patient pump 100 to obtain the desired information from the patient pump. Following the display on display 306 of the current information on display 126, caregiver pump 200 receives its displays sent to caregiver pump 200 in response to the key inputs to caregiver pump 200 which are sent to patient pump 100.
Instead of an automatic initiation of the modem link to patient pump 100 operating in the slave mode, the caregiver and the patient could both hang up their respective phones after the modem cables were connected. Patient pump 100 is programmed to instruct modem 320 installed at the patient's home to answer the phone the next time it rings. The patient would then wait for the caregiver to call back. Caregiver pump 200 is programmed to instruct modem 310 to call the patient back. Once modem 310 is connected with modem 320, communication between the respective controllers is provided with respect to key input signals and display signals.
In one embodiment, display 126 of patient pump 100 displays everything that is sent to display 306 of caregiver pump 200. In another embodiment, the control system of patient pump 100 is programmed to include a blocking program to block some or all of the information that is sent to the control system of caregiver pump 200 from the controller of patient pump 100 from being displayed on display 126 of patient pump 100 during pump to pump communication. This may be advantageous in keeping some information from the patient, such as controller access codes used to access the processor of patient pump 100 via the keys 124, or keys 304 during pump to pump communications.
If the communication session were interrupted by a bad phone line, patient pump 100 might remain unchanged or partially programmed. During programming of patient pump 100, caregiver pump 200 could get a continuously updated status report from patient pump 100 through appropriate programming in caregiver pump 200 and patient pump 100. The caregiver could review the status report after disconnecting the pump from the modem to verify that patient pump 100 had been programmed as desired by the caregiver.
The control system of each pump 100, 200 controls operation of the respective modem 310, 320 attached as a peripheral device. The control system of each pump 100, 200 instructs its respective modem to go off-hook and disconnect the phone at the initiation of pump to pump communications.
The control system of each pump 100, 200 may be provided with masking programs to mask the keys 124, 304 which are inactive during pump to pump communication.
Attempting to start the caregiver pump 200 is one method of signalling to the control system to terminate the pump to pump communication. The control system of caregiver pump 200 begins the disconnection sequence with respect to modem 310. The control system of caregiver pump 200 further requests that patient pump 100 begin the disconnection sequence with respect to modem 320. Alternatively, pressing another key such as a HELP key can begin a disconnection sequence.
In some applications, the control system of patient pump 100 is locked, at least partially, via an access code program to prevent the patient from altering the pump operations program or from accessing other information in the memory. In one preferred embodiment, the caregiver can unlock the pump lock of patient pump 100 from a remote location via the pump to pump communication system. Preferably, the caregiver can then relock the pump lock of patient pump 100 after the caregiver has adjusted or changed the pump operations program. Automatic relock program means may be provided to automatically relock the control system at the conclusion of the caregiver's access of the control system to change the operating programs.
In one possible embodiment, locking the pump 100 is accomplished through various lock levels that are used to limit patient access to certain programming and operating functions. Each lock level provides a different level at which the user can interact with the pump 100. Each programming and operating function is executed by predetermined key strokes. If a function is not available at the lock level that is set, the microprocessor will ignore the predetermined key strokes if pressed.
One embodiment of the pump 100 has three lock levels—LL0, LL1, and LL2. When the pump 100 is in LL0, the user can access all programming and operating functions of the pump 100. LL1 permits limited control of the programming and operating functions. LL2 permits only minimal access of programming and operating functions. When the pump 100 is running, it is usually in a predetermined lock level that offers some security against an unauthorized person from reprogramming the pump 100, either LL1 or LL2.
The user can then reprogram the pump 100. Programming in this sense is not changing the actual programming code loaded in the pump 100, but is rather launching a new application program from the flash memory or changing operating parameters such as dosages and delivery rates. After programming is complete, the user can press the START/STOP key, one of the keys of the pump 100, which will restart the pump 100. When the START/STOP key is pressed, the pump 100 will automatically return to the predetermined lock level.
In the past, the user had to manually reset the lock level to its predetermined level. Otherwise, the lock level would stay at LL0 when the pump 100 was restarted and given to the patient. In this situation, an unauthorized person could access programming and operating functions in the pump 100 and change parameters such as delivery dosage and delivery rates. Thus, the present invention is advantageous because it eliminates this risk by automatically returning the pump 100 to the predetermined lock level when it is restarted.
In an alternative embodiment of the present invention, the pump 100 will not automatically enter the predetermined lock level if the caregiver manually sets the lock level prior to pressing the start button to restart the pump 100. Rather, the pump 100 will remain at the manually set lock level. This feature is advantageous because it allows flexibility in resetting the lock level after the pump 100 is reprogrammed. Another alternative embodiment of the present invention permits the caregiver to turn the automatic lock level feature on and off.
Referring now to
An example of computer 204 includes an 80386 INTEL microprocessor, with 2 megabytes of RAM and operated by commercially available operations software such as DOS, UNIX, and others and further programmed with application specific program functions to communicate with pumps 100, 404 and carry out the specified tasks desired by the caregiver. A suitable keyboard may be provided with computer 204 to make operator inputs to the microprocessor.
As shown in
Pump 404 is preferably identical mechanically and electrically to pumps 100, 200 described previously. In some situations, the control system of pump 404 may be programmed differently, depending on how the pump is to be used. Pump 100 is typically used as a patient pump. As a patient pump, pump 100 requires the normal pumping mode operating program and the slave mode operating program at minimum.
In system 402, pump 404 may be a patient pump or a caregiver pump. As a patient pump, pump 404 requires the normal pumping mode operating program and the slave mode operating program at a minimum. Pump 404 as a patient pump is present at the same site as computer 204 such as when pump 404 is brought in by the patient. In some situations, pump 404 may be a patient pump that is in the caregiver's office 406 for data gathering, trouble shooting, and/or program changes or modifications. Also, before the patient leaves the caregiver's office 406, pump 404 is present in caregiver's office 406 for use as a patient pump in the caregiver's office. As a caregiver pump, pump 404 requires the master mode operating program at a minimum. Pump 404 operating as a caregiver pump may also include the normal pumping mode operating program and the slave mode operating program.
To permit communication between pump 404, computer 204, and pump 100, a modem 420 is provided. Preferably modem 420 is a conventional modem for remote communication over telephone lines.
In another preferred embodiment, modems 310, 320, and 420 can be replaced with a digital simultaneous voice and data modem 421 that has the capability of simultaneously transmitting voice information between the patient and caregiver, and data information between the master pump and the slave pump. As shown in
Data from the pump 100 is simultaneously communicated through an RS232 interface 439 and then to a second serial FIFO buffer 441 at which point the microprocessor 431 will process the data for communication. The information is then passed through a second modulator 443 and communicated to the multiplexer 437. The multiplexer 437 then transmits packets of information from the pump 100 and the telephone 425 to a line interface 445, which communicates it over the telephone line.
One skilled in the art will realize that the digital simultaneous voice and data modem 421 at the receiving end will essentially operate in the opposite manner. One skilled in the art will further realize that
One advantage of using a digital simultaneous voice data modem 421 during pump to pump communications is that oral communication between the patient and caregiver is not interrupted. As a result, the caregiver can answer questions and give instructions during pump to pump communications.
Communication between computer 204 and a pump, whether remotely (with pump 100) or locally (with pump 404) is useful for several reasons. First, computer 204 may be provided with greater memory and data processing capabilities than exist with the individual pumps 100, 404. Printing capabilities may be greater with a printer 438 electrically interconnected to computer 204. Display capabilities may be greater with a monitor 440 electrically interconnected to computer 204. Also, computer 204 may be useful in the recertifying operations of the pumps periodically, as required to verify operability and accuracy of the pumps.
Computer 204 also may be useful for making program adjustments or application changes in the pumps 100, 404, such as described in application Ser. No. 08/561,809, previously incorporated by reference. For example, drug delivery devices may be used in a variety of normal pumping modes, or applications, such as 1) pain control; 2) nutrition; 3) chemotherapy; and 4) antibiotic therapy. Other applications are possible.
Each of the applications may involve different operations of the pumping mechanism. Each application may have one or more patient specific variations on operation of the pumping mechanism and other pump control functions. Also, some of the applications may involve some patient input, such as is sometimes the case in pain control applications. For example, if the patient is experiencing pain at a particular time, the caregiver may provide for increased dosages as needed by the patient, within specified parameters such as time and amount. In this application, the pumping mechanism needs to be operable automatically, and at the discretion of the patient, within the specified parameters. The operating program contains the appropriate pump control commands for controlling the pumping mechanism and the functions of the keys which permit patient control of the pumping mechanism. The other applications may include different pump control commands and different functions of the keys. within each of the four applications listed above, various different pump operations programs may exist. The control system of the patient pump 100 may be appropriately programmed by the caregiver for the specific patient usage.
It is to be appreciated that the caregiver pump 200 and the patient pump 100 do not need to include the same application program for operating the pumping mechanism. A significant advantage of the present invention is that the caregiver can communicate successively with different patients, with each patient involving a different pump application, or each patient involving. the same pump application with different patient specific functions. At a minimum, it is preferred that caregiver pump 200 includes the master mode operations program, and that patient pump 100 includes the slave mode operations program and one application or normal pumping mode operations program for operating the pumping mechanism to pump fluid to the patient. Preferably, it is more convenient for the caregiver if caregiver pump 200 and patient pump 100 include both the slave mode operations program and the master mode operations program, and also at least one normal pumping mode operations program.
It is anticipated that the caregiver can locally or remotely program the control systems of pumps 100, 200, 404 such that the pump operates either in 1) the normal pumping mode or slave mode, or 2) the normal pumping mode or the master mode at the initiation of the pump to pump communications sequences.
Various pump related data may be stored in the control systems of pumps 100, 200. Information which may be gathered during use of patient pump 100 includes date and time of:
Various functions are anticipated for each of the keys on each pump 100, 200. Each key has at least one function. Examples of potential functions of the different keys include:
Referring now to
Computer screen 450 and computer 204 are utilized to communicate with a pump located at a remote site, like pump 100 of FIG. 10. If the pump is located locally, like pump 404 of
The arrangement involving the computer screen of
The computer system with the pump image program may also be used as a simulator for training the caregiver and/or the patient how to use the pump. The simulator includes various programs for simulating operation of a patient's pump to pump fluid. The simulator also includes various programs for simulating various communication situations with a patient's pump.
As shown in
The simulator system also includes simulation programs in simulator information 462 for simulating operation of the pump on the screen 458 as a patient pump to pump fluid to a patient. This would be useful for training a patient and a caregiver how to operate the pump in the normal pumping mode.
The present invention relates specifically to a pump communication simulator for training a pump operator comprising: a computer system including processor means, and display means electrically interconnected to the processor means of the computer system; first program means for displaying an image of the pump on the display means, the image having an input region and a display region; second program means for permitting manipulation of the input region of the image of the pump on the display means by the pump operator such that access to the processor means of the computer system is achieved; and third program means for sending a predetermined message to the display region of the image of the pump in response to manipulations of the input region of the image by the pump operator.
Flash Memory Systems and Methods
Flash memory 240 is electrically interconnected to the processor 182 for storing pump operation information (See FIGS. 8A and 8B). The flash memory 240 is electrically interconnected to the communications port 132 to permit transfer of pump operation information to the flash memory 240 from external of the pump.
Referring now to
Communication means 472 links computer system 470 and pump 100. Included in communication means 472 is a cable 474 or other communication structure interconnecting communications port 132 of pump 100 to a device 478. Cable 476 or other communications structure interconnects device 478 to computer system 470. Pump 100 is preferably not linked directly to computer system 470, since pump 100 may be provided with one or more power supplies other than conventional 110 volt power supplies used to power computer system 470. Device 478 performs an isolation function in FIG. 17. It is desirable to electrically protect pump 100 from computer system 470 to protect pump 100 and the patient from any hazards, such as electrical shock, associated with the electrical source power for computer system 470. In
The operations system 480 of
Referring now to
The second operations system 482 in
Device 478 of
Flash memory 240 is utilized to store pump operation information which is accessed by the processor 182 for operating pumping mechanism 140 and the other sensors, switches, and devices of pump 100. Flash memory 240 permits pump operation information to be initially electrically written to flash memory 240 and subsequently stored in flash memory 240. Storage of the pump operation information in flash memory 240 is nonvolatile in that is does not require a continuous power supply to flash memory 150 to maintain the information stored in the memory. At a later time, flash memory 240 can be electrically erased, and rewritten with different pump operation information.
In one preferred embodiment, the program or programs needed to run pump 100 is stored in the flash memory 240. Patient specific settings for pump 100 can be input via keyboard 122 or communications port 132 and stored in flash memory 240, memory associated with microprocessor 182 or EEPROM 242. Examples of patient specific settings include rate of infusion, length of infusion, bolus information, security codes, and patient weight and sex. It is preferred to store such patient specific pump operation information in EEPROM 242 or other memory location other than flash memory 240 due to limitations of flash memory 240 with respect to the number of times the memory can be erased and rewritten. Since the patient specific information is typically frequently changed in many of the anticipated uses of pump 100, it is not desirable to store this type of information in flash memory 240. Port sensor 198 can be used to appropriately direct incoming data to the proper location by sensing when a cable is present. If not present, pump 100 will look to its internal memory 184 for the information needed to run the pump and keyboard 122 for patient settings if not already entered.
Static RAM 244 can be utilized to store some information relating to operation of the pump. Typically, intermediate information concerning pump operations is stored in the static RAM 244. Intermediate information may include calculation results from the pump operations program performed by microprocessor 182. Pump usage information regarding pump operation events may be stored in static RAM 244, such as the number of start and stop events, the number of cassettes attached, and the total dosage pumped. An additional location for storage of pump operation information is the memory associated with the real time clock 246.
Flash memory 240 preferably includes a boot program which is preferably non-erasable. The boot program permits initialization and loading of pump operation information to the pump 100 via communications port 132. Further, gate array 257 and/or flash memory 240 includes appropriate programming to handle incoming data from communications port 132 or keyboard 122 wherein the information is directed to the proper storage location if the information is not to be stored in flash memory 240. For example, remote programming may be utilized to enter the patient specific information into control system 180. The patient specific information may be entered initially or when changes occur over time due to changes in the specific therapy needed. For example, if the patient's condition improves or worsens, changes may need to be made in the specific patient settings. The flash memory 240 may include the appropriate program or programs to direct storage of the patient specific settings to the appropriate memory device in control system 180.
Flash. memory 240 is an embedded memory associated with control module 102. Once installed in control module 102, flash memory 240 is not removed from pump 100. Flash memory 240 is electrically erasable and reprogrammable and does not require power to maintain the contents of its memory. A variety of flash memories may be used for flash memory 240. An example of one preferred flash memory which is usable in pump 100 is by Intel Corporation, and identified as 28F008SA 8 MBIT (1 MBIT×8) Flashfile™ memory. Such memory is useful in pump 100 for handling pump operations information associated with the various features provided on pump 100. The Intel product is useful in that it includes separately erasable and reprogrammable blocks of memory, at least one of which can be blocked from erasure once programmed with the desired information.
Pump 100 may be utilized for a variety of different therapy types or applications. For example, pump 100 may be used as a pump in: 1) a pain control therapy, or patient controlled analgesia; 2) a nutrition therapy, or total parenteral nutrition therapy; 3) a chemotherapy program or therapy; or 4) an antibiotic therapy. Other applications are possible. All of these can be resident on pump 100, or they can be uploaded to pump 100 on an as needed basis. The different applications may involve different operations of pump mechanism 140 and the other switches, sensors, and other devices in pump 100. For example, the volume of fluid per unit time pumped by the pumping mechanism 140 may be continuous or it may be changed over time. A bolus amount (increased dosage) pumped by the pumping mechanism 140 may be provided once or at periodic intervals. The bolus amounts and/or the bolus intervals may be varied over time. The patient may be given limited ability to increase the dosage when the patient desires by causing extra activations of the pumping mechanism 140 through a dose key.
As another example, there may be lock out access to the patient wherein various keys of keyboard 122 are inoperative such that the patient cannot change the therapy prescribed by the caregiver unless the caregiver removes the lock out feature. Each application may have different lock out features.
Calculations by the processor may be needed to achieve a certain total dosage over a certain time even though the patient may be able to increase the dosages at one or more times during the therapy. Inputs to pump 100 may include reservoir size, activation amount, and/or drug concentration. In some cases, it is desirable for pump 100 to calculate the desired number of activations and intervals to achieve a certain drug level in a patient having a certain sex and weight. Each application may involve different calculations performed by pump 100.
Other sensors, switches, and devices of pump 100 may be operated differently in different therapies. The pump control program stored in the memory of pump 100 including flash memory 240 includes information relating to the various aspects of pump 100 needed to deliver the appropriate therapy. In one preferred pump 100, flash memory 240 contains the general application or operating program (such as pain, nutrition, antibiotic, or chemotherapy) which is accessed by processor 182 during usage of pump 100. Only one application be stored in flash memory 240 as a safety precaution against the caregiver or the patient inadvertently running the wrong program. Alternatively, a plurality of different applications can be stored in flash memory 240 to allow selection of the desired application for the patient's needed therapy. Also, the other pump function programs can be stored in flash memory 240, such as the programs necessary for pump to pump communication or other administrative functions. Also, variations in the display language can be stored in flash memory 240 so as to display messages in a desired foreign language.
The patient specific information needed to operate pump 100 for the specific application is stored in the memory associated with microprocessor 182 and is utilized by the processor 182 when needed with respect to the pump applications program. Any intermediate calculation information or other pump information, including specific pump usage information, may be stored in any of the various memories. Static RAM 244 provides a useful memory location for storage of the intermediate information.
Pump 100 can be programmed from computer system 470 in a variety of different ways. In one method, computer system 204 can include a single pump application program stored in its memory. The caregiver or pump supplier would load the pump application program from computer system 204 to flash memory 240 of pump 100. Alternatively, computer system 204 can include a plurality of different pump application programs. The caregiver or pump supplier can select the desired program to be loaded to flash memory 240 of pump 100. Alternatively, computer system 204 can include one or more pump application programs that each include options for selection by the caregiver or pump supplier for each pump application program. Once the options are selected, the caregiver can load the pump application program generated by the caregiver to flash memory 240 of pump 100. In the above methods, it is anticipated that the caregiver would not generate the code for the pump application program. The code would be supplied by the pump supplier or other programming specialist. This is a safety feature as well as convenience to the caregiver. The caregiver need only be familiar enough with computer system 204 to set up the link to pump 100 and then select and download the appropriate pump application program. It is to be appreciated that, in some cases, the caregiver will have sufficient expertise to generate the code for the pump application program. Similar safety and convenience features are present with respect to any programming of the patient specific parameters downloaded from computer system 204. User prompts are preferably provided for requesting the caregiver to enter the particular settings when entered via computer system 204.
Flash memory 240 is used to advantage in pump 100. Unlike removable memory devices, there is no large opening in the pump housing associated with the memory which needs to be protected from tampering, contaminants or moisture. No fragile parts are accessible via communications port 132 from a mechanical protrusion as they would in the case of card readers having relatively large openings to receive the card. The communications port 132 is relatively easy to protect from contaminants and moisture. There is also no loose cartridge or card that could be dislodged, tampered with, damaged or lost. The patient or the caregiver does not need to be concerned that the removable memory device, such as the card or cartridge, is properly positioned in the opening in the pump as in the case of pumps utilizing the separate memory cards or cartridges. This is especially important when the patient is using the pump in an unsupervised location. Should a card or cartridge become dislodged from the pump, there is a concern that the pump would cease operation and the patient would be unable to restart the pump. The use of flash memory 240 eliminates these problems.
Another advantage of flash memory 240 is that neither the caregiver nor the patient needs to maintain any separate memory cartridges or cards for different therapies. There is no need for the caregiver to keep track of any cards, cartridges or other pieces separate from the pump. Disposal or destruction of outdated cards is no longer a problem. Since no card or cartridge reader needs to be provided, there is a reduction in the size of pump 100.
Another advantage of providing flash memory 240 is that there is no need to open up the housing and remove a chip or other wired-in-memory device in order to reprogram the pump. Changes to the applications stored on flash memory 240 are done electronically via the input/output communications port 132. virtually any programmed function of pump 100 can be electrically changed if desired. As yet undeveloped improvements can be added as they are completed. Caregivers do not need to worry about their pumps becoming obsolete as long as new operating programs are developed. There are no mechanical changes needed for the memory connections to the rest of the pump control system when the flash memory is reprogrammed. Handling of the new chips prior to and during installation is no longer a concern. Disposal or destruction of the old chips is no longer a problem. Applications updates needed by the caregiver can be handled via a floppy disk mailed to the caregiver whereby the caregiver can download the updated program to the pump or the inventory of pumps maintained by the caregiver. Alternatively, the applications updates can be transmitted over the telephone lines via modems to the caregiver. No special expertise is needed to reprogram as is the case of pumps where chips must be removed and replaced to change the memory.
Pump 100 provides system of pumping fluid to a patient where pump 100 is very flexible in how the control system 180 operates. Unlike pumps using EPROM memory for storing the pump operating program, pump 100 with control system 180 is easily changeable as needs and circumstances change. No chips need to be removed or specially handled to reprogram. At the same time, pump 100 is tamper resistant, contamination resistant, and reliable during operation, unlike pumps with replaceable cards.
A further advantage of flash memory 240 is the ability to remotely program flash memory 240. Such remote programming is not possible with cards or cartridges which need to be changed, or replaceable EPROMs which need to be physically handled and reprogrammed. Remote programming can be done initially prior to the first use of the pump or 6i at a later date after initial operation of the pump. The applications can be easily reprogrammed if a bug is identified or if improvements are made in the application program. Applications updates needed by the caregiver can be handled via the telephone lines. Also, changes can be made to the operating program midway through the therapy to address changes in the patient's condition.
Another advantage of the present invention is that custom programs for caregivers who desire particular operating programs for their inventory of pumps are possible through the use of flash memory 240. Individual patients may require a custom program. Flash memory 240 permits the custom program to be quickly downloaded to the patient either locally or remotely via communications port 132. Once the patient no longer needs the custom program, the pump is easily electrically reprogrammed via communications port 132.
Flash memory 240 has sufficiently large memory capability to store the operating program needed to run pump 100, including all of the sensors, switches, and devices.
Since a caregiver can reprogram the pump 100 when the pump is needed for a different application, less inventory of pumps is required by the caregiver. Flash memory 240 permits each pump to be utilized in more than one application over time depending on the immediate needs of the patients. Also, pump 100 may be simpler to operate if only one application is stored in the memory of pump 100. With only one application program stored in the memory, it is not possible for the wrong application program to be selected, once pump 100 is properly programmed. This is a safety feature for protecting the patient from inadvertently receiving the wrong therapy even though a correct drug cartridge is attached. Blocks of flash memory 240 can be used to store different applications for selection by the caregiver or patient.
In some illnesses or treatments, a patient may desire successive different uses of pump 100. For example, some chemotherapy programs are preceded by a nutrition therapy to build up the patient's reserves of fluids or other nutrients. In that case, the memory of pump 100 does not need to simultaneously store both a nutrition therapy application and a chemotherapy application. In that case, the patient would utilize pump 100 with a nutrition therapy application programmed into flash memory 240. At the appropriate time, flash memory 240 could be reprogrammed with the chemotherapy application. Alternatively, flash memory 240 can include all the necessary programs, and the caregiver or patient can select the desired program at the appropriate time.
Keyboard 122 can intentionally be provided with a limited number of keys to keep operation of pump 100 through keyboard 122 simple. However, some applications and even some patient specific settings may involve numerous inputs such that the use of a standard keyboard, through computer system 204 may be advantageous. Downloading of this information from a computer system 204 is useful since all of the inputs of information can be made through a standard keyboard of computer system 204. The present invention provides the caregiver with the ability to download just applications to flash memory 240, or applications to flash memory 240 and patient specific settings to the other memory locations without entering information through keyboard 122.
Since reprogramming of flash memory 240 can only take place with a computer system 204, electronically monitoring the status of the pumps is easier. An updated status check, using appropriate status check program means stored in computer system 204 and/or in pump 100 (for example stored in flash memory 240), can be made of the pump each time there is an application download to the flash memory 240 or each time the pumps 100 are returned to the caregiver after use. The status program means for tracking pump status can help monitor the pumps which are configured for specific types of therapies. The status program means can also include patient name, address and telephone number, and pump location. There are advantages for caregivers and/or pump suppliers to have quick access to status reports on the configuration of the inventory of pumps maintained by the caregiver or supplier. The caregiver or supplier may need to quickly identify particular pumps in case a problem develops where the pumps must be recalled or reprogrammed. Use of computer system 204 to reprogram pump 100 provides a useful way to tie in status tracking software for automatic tracking of each pump 100. The status program means can include recertification tracking program means which automatically flags pumps needed for recertification of the operating systems.
The status program means can be general to only track pump configuration and/or time since recertification. The status program means can also download specific detailed pump operation information from pump 100 to computer system 204 pertaining to the therapy given. Examples of pump operation information that may be sent to computer system 204 from pump 100 include: drug type used, amount of drug used, type of pump operating program used, any changes to pump operating program, dates of pump usage, and a record of all pump start and stop events, number of cassettes used, occurrence of alarms, and other pump usage events. Such information is useful to the caregiver and to the pump supplier/manufacturer. Some of the relevant status information can be entered via the keyboard of computer system 204, instead of from pump 100, at the time of programming before the therapy or at the time of reprogramming after the therapy, such as date information.
Another advantage due to the presence of flash memory 240 having to be reprogrammed with a computer system 204 is that appropriate diagnostic program means for checking pump control system 180 and other features can be downloaded to flash memory 240 each time a programming operation occurs. The diagnostic program means need only be temporarily downloaded to flash memory 240. The diagnostic program means runs through various checks of control system 180 to verify that pump 100 and the associated switches, sensors, and devices are functioning properly. The diagnostic program means is then removed or erased from flash memory 240 and the new application program is downloaded onto flash memory 240. In this manner, any errors in pump 100 can be identified each time a pump 100 is programmed. Such diagnostic program can be downloaded to pump 100 initially before pump 100 is ever programmed to operate as a pump, or at a later date when pump 100 is reprogrammed.
Flash memory 240 allows for convenient reprogramming of pump 100 such that message on display 126 will be in an appropriate language that can be comprehended by the caregiver or patient. For example, messages in Spanish, Japanese or Korean may be displayed to facilitate easy use by the caregiver or patient. Reprogramming of generic pumps in this regard saves on inventory or excessively large pump memory while allowing versatility in use of pump 100. Flash memory 240 also allows for convenient manufacture of pump 100 by permitting a manufacturing program to be stored in flash memory 240. The manufacturing program can be erased once it is no longer needed. The program allows for the various components of pump 100 to be tested during installation.
Physically, the flash memory 240 is divided into sixteen banks. Each application program occupies three banks, each utility slot occupies one bank and the boot system occupies one bank. Additionally, the flash memory 240 includes a core bank 247. Although the programs stored in the flash memory are separate entities, they all share the core bank 247. The core bank 247 is used to store pump drivers, a serial communication protocol, and a portion of the pump kernel. The code stored in the core bank is shared by all of the programs.
The boot system is formed from the boot code, the pump kernel, the pump drivers, and the serial communication protocol. The boot system controls the pump 100 at power up. In one possible embodiment, tasks orchestrated by the boot system include self tests or diagnostics. The boot system also generates several screens of information while performing the diagnostics and determines if the pump 100 is in a launch mode or a command mode. The basic tasks performed by the boot software include:
Additionally, if no peripheral device is connected to the communications port 132, the pump 100 will enter the launch mode and the boot system will pass control to the designated or launch application program. A user can change the launch application program, which will cause the pump 100 to go through a warm boot. Once the launch application program is changed, the pump 100 will automatically launch the new application program upon subsequent power ups. If a peripheral device is connected to the communications port 132, the pump 100 will enter command mode and the boot system will send and receive signals via the communication port 132.
Each application program, such as the PCA application, includes an application template, application-specific code, a pump kernel, a serial communication protocol, and pump drivers. The application program controls the pump 100 after being launched by the boot system and performs additional self tests. The pump application program then begins a review sequence during which various screens are generated and displayed showing the current values of selected application parameters.
Upon launching an application program, the pump 100 will automatically stop the pump 100 so that it is not in the normal pumping mode. The caregiver can then program delivery parameters that control how the pump 100 delivers fluid after it is restarted by pressing the START/STOP key. While the pump 100 is running, it is in the normal pumping mode. The pump 100 will deliver fluid and keep track of delivery with status parameters while in the normal pumping mode. It is preferred that none of the application parameters be changeable while the pump 100 is in the normal pumping mode.
The pump application template is a portion of the application program that provides consistency among the various pump application programs. It defines all standard application items, and the user interface structure that each application must follow to create custom application items. Standard application items define the characteristics of each application, which are added to or supplanted by the specific application. The basic tasks performed by the pump application template include:
The application-specific code is a portion of application program that provides custom application items that are particular to the specific application. The application-specific code is used to customize the pump's 100 behavior and can be programmed only while the pump 100 is stopped. Custom application items may either replace or supplement the standard items provided by the pump application template. Basic tasks performed by a specific pump application include:
Additionally, each application program is an event driven system. The pump drivers provide all hardware interface, and the pump kernel provides support services that include an event scheduling and a dispatching system. The serial communication protocol provides serial communication services with peripherals that are connected to the communications port 132.
Each application program also includes code for communication with a remote pump during pump to pump communications. The pump to pump communication code included in the application program interfaces with the serial communication protocol and is used when the pump 100 is in the slave mode as described above.
The terminal utility is formed from the terminal code, the drivers, the kernel, and the serial communication protocol. The terminal controls the external modem and one of the applications running in the pump 100 via the remote serial connection during pump to pump communication. The pump 100 is in the master mode when the terminal utility is providing serial communication with a remote pump that is in the slave mode.
The testing utility is formed from the testing code, the drivers, the kernel, and the serial communication protocol. The testing utility is a stand alone program that performs various tests on the pump hardware during closed-loop testing.
The scratch memory serves as a second layer of buffer that provides protection if there is a power failure while data is being written to the RAM 244. During the write process, destination addresses will be designated to receive the data. However, data is first saved in the scratch memory. After the data is saved in the scratch memory, it will be saved to the destination addresses. In one embodiment, data is written to and read from the scratch memory in blocks using an error checking scheme or algorithm such as cyclic redundancy code (“CRC”).
A first flag will be set while data is being written to the scratch memory. A second flag is set after the write process is complete at which time it is written from the scratch memory to the destination addresses. Because the RAM 244 is a static RAM, either the first or second flag will be saved of the pump 100 has a power failure.
When power is returned to the pump 100, the flag will be read. If the first flag is set, the pump 100 either can disregard the data in the scratch memory or can complete the process of saving data to the scratch memory. If the second flag is set when power is returned to the pump 100, the pump 100 either can rewrite all of the data from the scratch memory to the destination address or can merely complete the write process from the scratch memory to the destination addresses.
An advantage of using the scratch memory in this manner is that the integrity of the data is maintained while being written to the RAM, which will help minimize the risk of a pump failure or faulty information stored in the history log.
The scratch memory is also used for system diagnostics during power up. The boot program will initially test the scratch memory, which is Bank 0249a. Data from Bank 1249b is then transferred to the scratch memory so that the pump 100 can run diagnostics on that bank. A similar procedure is followed with banks 2 and 3249c and 249d.
The four sets of addresses in Bank 1249b for application configuration parameters are used to store persistent data, i.e., parameters that typically remain constant when a particular application program is being used. An example of such data might include the maximum and minimum flow rates or the maximum or minimum concentration settings.
A set of addresses for the application template configuration includes the data that is common between application programs. An application might include the lock level setting or a flag that activates the automatic lock level feature. Addresses for the delivery status and parameter of the launch program are used to store data that is not persistent, including various settings for the launch program. Examples of such data include the delivery rate and dosage. The history log is used to track various historical events such as a change in the delivery rate or when a pump 100 is powered up with time and date stamps.
Cassette Identification Systems and Methods
This aspect of the present invention relates to systems and methods for automatically identifying a cassette 104 mounted to control module 102 of pump 100. The identification system can identify indicia on the cassette relating to the type of drug, the concentration of the drug, the volume of the fluid reservoir, or the amount of drug pumped per activation of the pump, i.e., tube size. Such information is important to safe and effective drug therapy. When the information is entered automatically to the control module, such as with the indicia identifying system, a safer and more effective system results. There is less chance for human error, as would be the case if such information were entered manually. Also, the indicia identifying system can be used to prevent operation of the pump if an unauthorized cassette is attached.
Various cassettes are provided to be identified by the control module. The control module identifies the cassettes in one of a variety of manners, including engagement with a projection on the cassette or sensing optical signals or the absence of optical signals due to the presence of the cassette. Other structures and methods are provided to identify the cassettes such as described in U.S. Pat. No. 5,531,697 issued Jul. 2, 1996, the disclosure of which is incorporated by reference.
While the preferred system for identifying cassettes is by identifying a single indicia on each cassette, it is to be understood that the identification system could look for two indicia, such as two projections, for each cassette. A redundant system could still be provided in that case since the control module would request that two signals be received. Less than two or more than two would indicate an error condition. Moreover, the invention is not to be limited to three sensors. More than three, or less than three, are possible whether the systems sense the presence of one indicia, the absence of one indicia, or variations in the number of indicia sensed, such as zero, one, two, three, etc. corresponding to the number of sensors provided and the possible combinations thereof.
Referring now to
As shown in
Control module 102 includes a chassis 540 and an outer housing 560. A seal 562 seals between chassis 540 and housing 560. A component board 564 is mounted to chassis 540 via screws 566, spacers 568, and alignment pins 570. A first plunger 530 is reciprocally mounted to chassis 540. Second plunger 532 and third plunger 534 are also reciprocally mounted to chassis 540. Plungers 530, 532, 534 are similarly configured and operated.
First plunger 530 and third plunger 534 are provided for sensing additional projections. In particular, first plunger 530 engages projection 592 extending from the main surface 594 of base plate 542 of first cassette 104. Second plunger 532 engages second projection 596 extending from main surface 636 of base plate 552 of second cassette 550. Third plunger 534 engages projection 598 extending from base plate 552 of third cassette 554. In this manner, control module 102 can identify at least three different cassettes 102, 550, 554.
Referring in particular to
Referring now to
As shown by a comparison of
Also, cassette 550 includes clip features for releasably gripping tube 649 to provide a mechanical hold down during adhesive attachment of tube 649 to cassette 550. In particular, first clip 650 and second clip 652 provide hold down of tube 649 to cassette 550. First clip 650 and second clip 652 hold the tube in place during assembly, allowing the adhesive to set up without the need for special clamps or external fixtures.
Referring now to
The cassette identification system of
Reciprocally mounted plungers and slotted optical sensors are useful to solve some of the above possible problems and other problems with cassette identification systems. However, it is to appreciated that in some instances the use of microswitches, FSR's, inductive switches, magnetic switches, reflective elements, moving contacts, or other systems noted above may be desirable.
Automated Testing Systems and Methods
This aspect of the present invention concerns a system for automated testing of a pump, which includes a computer electrically connected to both a testing device and a pump. The pump is connected to the testing device by the pump's fluid tube so that a closed loop configuration is obtained. The medical device is programmed to conduct a variety of tests upon receiving commands from the computer. The testing device provides for measurement of various parameters during the performance of these tests, such as flow rate and pressure. The medical device and/or computer may be programmed to store the test results. By providing a central place for storing such information, not only can each pump be tracked as it moves from location to location, information relating to that pump can be automatically updated. With such a configuration, the testing of the pump is substantially automated.
Referring now to
As shown in
Major components of testing device 814 are illustrated in FIG. 29. Testing device 814 is connected to tube 816 of pump 100 via fluid inlet 818. Testing device 814 includes a flow rate tester 820 and a pressure tester 822. Flow rate tester 820 tests the accuracy of the flow rate of a drug being delivered by pump 100. Pressure tester 822 tests the accuracy of medical device's occlusion detector 186 and/or alarms 194 in response to an occlusion in tube 816. Pressure tester 822 measures the pressure generated over time until pump 100 stops, alarm 194 sounds, or pump 100 reaches a certain predetermined test pressure set by computer 812. Computer 812 then compares the pressure measured by testing device 814 to the pressure of pump 100 once alarm 194 sounds or the predetermined test pressure has been reached to determine pressure accuracy. In a preferred embodiment, pressure tester 822 can test at multiple test pressures, such as a range from a low pressure to a high pressure. Testing device 814 is equipped with a fluid outlet 830 for releasing the fluid which runs through testing device 814 during or after the flow rate and pressure tests.
Access to testing device 814 is provided through communications port 826. Preferably, communications port 826 is a standard RS232 communications port. This feature allows information being received via communications port 826 from computer 812 to control testing device 814.
A control system 828 is provided for controlling operation of flow rate tester 820 and pressure tester 822, as well as for controlling communication between testing device 814 and computer 812. Control system 828 includes a microprocessor and associated memory for controlling operation of testing device 814. Testing device 814 may also include an optional display, for displaying information, such as that related to the tests conducted by flow rate tester 820 and pressure tester 822.
One preferred testing device which may be used in system 810 is an Infusion Device Analyzer (IDA) made by Ultramedic, Ltd. of Liverpool, England, and distributed by Bio-Tek Instrument, Inc. of Winooski, Vt. The IDA tests a variety of drug delivery devices, such as infusion pumps.
As is further shown in
Computer 812 further includes a monitor 840 for displaying information related to the operation of system 10, such as test instructions, test results, etc. Such information may also be delivered via hard copy printout to printer 836 attached to computer 812. Computer 812 may also include a keyboard 838 for inputting information into computer 812. Data may also be input into computer 812 via disk, tape, or card reader.
Computer 812 preferably includes a control system for controlling operation of the computer. The control system includes at least a microprocessor and an associated memory with selected functions for controlling operation of the computer. In particular, the memory stores various programs and data needed to run the tests performed on pump 100, such as those performed by flow rate tester 820 and pressure tester 822. Such programs and data may also be stored via disks which may be inserted into computer 112.
Information programmed into computer 112 permits an operator to communicate over communications links 832 and 824 with both pump 100 and testing device 814, respectively. Via communications link 824, computer 812 instructs testing device 814 to measure the flow rate and/or pressure and requests the results of such measurements. With the addition of communications link 832, however, many of the steps performed on pump 100 by flow rate tester 820 and pressure tester 822, which would otherwise have to be performed manually, are now automated.
Communications link 832 also allows for the automation of tests other than the flow rate and pressure tests previously mentioned herein. In particular, via communications link 832, computer 812 can instruct pump 100 to pump fluid for a flow rate test or a pressure test, or to perform internal tests, such as a self-test 898 (see
Referring now to
Specifically, at 850, the system is initialized. At 852, a check is made whether pump 100 successfully completed system initialization 850. If not, at 862, a message is displayed on monitor 840 of computer 812 detailing the error and requesting service, and at 878, the testing procedures are ended. If system initialization 850 is successful, system 810 then conducts a series of tests, such as those performed by flow rate tester 820 and pressure tester 822, as well as maintenance test 864. The list of tests mentioned above, however, is not exclusive. Depending on the medical device being tested, cost constraints, and/or the testing history of the device, more or fewer tests may be performed. Moreover, as those skilled in the art can appreciate, the order in which the tests are performed is not critical.
At 854, a check is made to determine whether the flow rate of pump 100 should be tested. If so, at 856, flow rate tester 820 performs a flow rate test. If not, at 858, a check is made to determine whether the pressure of pump 100 should be tested. If so, at 860, pressure tester 822 performs a pressure test. If not, at 822, a check is made to determine whether a maintenance test should be performed. If so, at 866, a maintenance test is performed. If not, at 868, after all desired tests have been performed, a check is made whether test results should be printed. If so, at 870, a signal is sent to printer 836 to start printing the test results. If not, at 872, a check is made whether the test results should be recorded. If so, at 874, computer 112 records the results. If not, at 700, the testing process is ended.
The flow charts of
Referring now to
At 884, a check is made to determine whether computer 812 received the information from the pump. If not, at 140, a further check is made to determine whether pump 100 and computer 812 are in fact connected. If so, at 890, a message is displayed on monitor 840 detailing the error and requesting service, and at 878, the testing process is ended. If not, at 888, computer 812 instructs the operator to connect pump 100 to computer 812, and then repeats steps 880 through 884.
If the information is received by computer 812, at 892, the operator has the option of including additional information, such as the operator's name, and the date and location of the test. If the operator chooses to add information, at 180, he or she may input the information into computer 812 via keyboard 838. If no additional information is added, at 898, computer 812 sends a signal to pump 100 to begin self-test 898. At 900, pump 100 sends a signal back to computer 812 representative of the results of self-test 898. At 902, system initialization 850 is complete.
At 912, computer 812 instructs the operator to input a test flow rate. Computer 812 may be programmed to provide the operator with a menu listing a variety of commonly tested flow rates from which to choose. In a preferred embodiment, computer 812 may automatically command pump 100 to test the flow rate at a single test flow rate or at several test flow rates, such as in a range from a low flow rate to a high flow rate. At 914, computer 812 sends a signal to pump 100 setting the pump at the flow rate chosen by the operator. At 916, computer 812 sends a signal to pump 100 to start pumping. At 918, computer 812 sends a signal to flow rate tester 820 of testing device 814 to begin the flow rate test. After a predetermined period of time, at 920, testing device 814 sends a signal via computer 112 to pump 100 to stop pumping. If the flow rate is automatically selected, steps 912, 914, and 916 are not necessary.
At 922, testing device 814 sends a signal to computer 112 representative of the flow rate measurements taken by the testing device. Such measurements may include the duration of the test, instantaneous and average flow rate, and cumulative volume. It should be appreciated that signals representing real time test data can be sent to computer 812 anytime throughout the duration of the test, provided the infusion is continuous.
At 924, computer 812 compares the measured flow rate with the test flow rate to determine flow rate accuracy. At 926, computer 812 records the test results. At 928, a check is made whether to print the test results. If so, at 930 the results are printed to printer 836. If not, at 932, a check is made whether other flow rates should be tested. If so, computer 812 repeats steps 912 through 930 until all desired testing is complete. Alternatively, the flow rate test results can be printed at the conclusion of all the test procedures (see FIG. 44). Once all flow rate testing is complete, at 934, the flow rate test is ended.
At 944, computer 812 sends a signal to pump 100 to start pumping. At 946, computer 812 sends a signal to pressure tester 822 of testing device 814 to begin the pressure test. Pump 100 is set to stop pumping due to an occlusion in tube when the pressure of pump 100 reaches a predetermined level due to the activation of occlusion detector 186 at a predetermined pressure sensed by occlusion detector 186. As previously mentioned, pump 100 may also be set to pump to test one or more pre-selected test pressure settings below the predetermined level where pumping will cease.
At 948, once pump 100 has stopped pumping or has reached the predetermined pressure or pre-selected test pressure, pump 100 sends a signal to computer 812 representative of the pressure sensed by occlusion detector 186. At 950, computer 812 sends a signal to testing device 814 requesting the pressure measured by the testing device. At 952, testing device 814 sends a signal to computer 812 representative of the pressure measured. It should be appreciated, however, that signals representing real time test data can be sent to computer 812 anytime throughout the duration of pressure tester 822.
At 954, computer 112 compares the pressure measured by testing device 814 with the pressure received from pump 100 to determine the accuracy of the response of pump 100 to the occlusion in tube and the accuracy of occlusion detector 186. In an alternate but less desirable mode of operation, the operator himself or herself can read the measured pressure and compare it to the pressure of pump 100 to determine pressure accuracy.
At 956, computer 812 records the tests results. At 958, a check is made whether to print the test results. Alternatively, the pressure test results can be printed at the conclusion of all test procedures (see FIG. 44). If so, at 960, the results are printed to printer 836. If not, at 962, pressure test 822 is ended.
If no more keys are to be tested, at 978, a check is made to determine whether to test any of the sensors of pump 100. If so, at 980, computer 812 instructs the operator to select the sensor to be tested. At 982, computer 112 sends a signal to pump 100 requesting the status of that sensor. At 984, pump 100 sends a signal back to computer 812 indicating the status of the sensor. At 986, computer 812 instructs the operator to input the status of the sensor being tested. At 988, computer 812 determines whether the status of the sensor is consistent with the condition inputted by the operator.
Computer 812 could instruct the operator to change the status of the sensor. For example, if the latch on the cassette door was closed, the operator could be instructed to unlatch the cassette door. Computer 812 could then determine whether the status of the sensor changed accordingly.
At 990, computer 812 records the results. At 992, a check is made to determine whether the operator wishes to test another sensor. If so, steps 980 through 990 are repeated until all the desired sensors have been tested.
If no more sensors are to be tested, at 994, a check is made to determine whether to test the structural integrity of pump 100. If so, at 996, computer 812 instructs the operator to input the name of the component to be tested. Alternatively, computer 812 could be programmed to provide the operator with a menu from which to chose which components to test. At 998, computer 812 instructs the operator to inspect the component selected. This inspection may be visual and/or physical. At 1000, computer 112 instructs the operator to input the condition of the component. Alternatively, computer 812 could be programmed to provide the user with a rating system from which to rate the component's condition. Such ratings, for example, could include: broken, damaged but operable, fair, etc. At 1002, computer 812 records the result. At 1004, a check is made to determine whether another component should be tested. If so, steps 996 through 1002 are repeated until all desired components are tested. At 1006, a check is made to determine whether to print the test results. Alternatively, the maintenance test results can be printed at the conclusion of all test procedures. If so, at 1008, the results are printed to printer 836. If not, at 1010 maintenance test 866 is ended.
In a preferred embodiment, computer 812 is also preferably programmed to provide the operator with other instructions relating to the particular component being tested, such as how to clean it, how to repair it, if possible, and other related instructions.
While the present invention has been described in connection with the preferred embodiments thereof, it will be understood many modifications will be readily apparent to those skilled in the art, and this application is intended to cover any adaptations or variations thereof. It is manifestly intended this invention be limited only by the claims and equivalents thereof.
The present application is a continuation of application Ser. No. 09/795,266, filed on Feb. 27, 2001, which is a continuation of application Ser. No. 09/324,305, filed on Jun. 2, 1999, now Pat. No. 6,241,704, which is a continuation of application Ser. No. 08/782,486, filed on Jan. 10, 1997, now Pat. No. 5,935,099, which is a continuation-in-part of: (1) application Ser. No. 08/555,304, filed on Nov. 8, 1995, now Pat. No. 5,658,250, which is a continuation of application Ser. No. 08/090,738, filed on Jul. 13, 1993, now abandoned;(2) application Ser. No. 08/206,737, filed on Mar. 7, 1994, now Pat. No. 5,669,877;(3) application Ser. No. 08/586,952, filed on Jan. 16, 1996, now abandoned, which is a continuation of application Ser. No. 08/276,025, filed on Jul. 15, 1994, now Pat. No. 5,485,408, which is a continuation of application Ser. No. 07/942,288, filed on Sep. 9, 1992, now Pat. No. 5,338,157;(4) application Ser. No. 08/540,960, filed on Oct. 11, 1995, now abandoned;(5) application Ser. No. 08/561,809, filed on Nov. 22, 1995, now Pat. No. 5,788,669. Priority is also claimed to Provisional application No. 60/010,090, filed on Jan. 12, 1996, which application(s) are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
2968804 | Buffington | Jan 1961 | A |
3555286 | Cote | Jan 1971 | A |
3603152 | Alibert et al. | Sep 1971 | A |
3777165 | Bryant et al. | Dec 1973 | A |
3809871 | Howard et al. | May 1974 | A |
3923060 | Ellinwood, Jr. | Dec 1975 | A |
3942526 | Wilder et al. | Mar 1976 | A |
3985133 | Jenkins et al. | Oct 1976 | A |
4027536 | Heggie | Jun 1977 | A |
T961004 | Horton | Aug 1977 | I4 |
4080967 | O'Leary | Mar 1978 | A |
4091550 | Schrenk et al. | May 1978 | A |
4098267 | Stein et al. | Jul 1978 | A |
4137913 | Georgi | Feb 1979 | A |
4141252 | Lodge | Feb 1979 | A |
4146029 | Ellinwood, Jr. | Mar 1979 | A |
4174637 | Mulzet et al. | Nov 1979 | A |
4184815 | Casson et al. | Jan 1980 | A |
4191184 | Carlisle | Mar 1980 | A |
4210138 | Jess et al. | Jul 1980 | A |
4213454 | Shim | Jul 1980 | A |
4217993 | Jess et al. | Aug 1980 | A |
4236880 | Archibald | Dec 1980 | A |
4270532 | Franetzki et al. | Jun 1981 | A |
4279188 | Scott | Jul 1981 | A |
4280136 | Kashima et al. | Jul 1981 | A |
4282872 | Franetzki et al. | Aug 1981 | A |
4299218 | Knigge et al. | Nov 1981 | A |
4299541 | Ohara et al. | Nov 1981 | A |
4308866 | Jelliffe et al. | Jan 1982 | A |
4309993 | Brown | Jan 1982 | A |
4311377 | Matteson | Jan 1982 | A |
4314227 | Eventoff | Feb 1982 | A |
4314228 | Eventoff | Feb 1982 | A |
4315238 | Eventoff | Feb 1982 | A |
4320757 | Whitney et al. | Mar 1982 | A |
4368645 | Glenn et al. | Jan 1983 | A |
4369780 | Sakai | Jan 1983 | A |
4370983 | Lichtenstein | Feb 1983 | A |
4373525 | Kobayashi | Feb 1983 | A |
4373527 | Fischell | Feb 1983 | A |
4373527 | Fischell | Feb 1983 | A |
4385630 | Gilcher et al. | May 1983 | A |
4385958 | Long | May 1983 | A |
RE31315 | Jenkins et al. | Jul 1983 | E |
4392849 | Petre et al. | Jul 1983 | A |
4394862 | Shim | Jul 1983 | A |
4395259 | Prestele et al. | Jul 1983 | A |
4398542 | Cunningham et al. | Aug 1983 | A |
4410322 | Archibald | Oct 1983 | A |
4425661 | Moses et al. | Jan 1984 | A |
4431425 | Thompson et al. | Feb 1984 | A |
4443218 | DeCant, Jr. et al. | Apr 1984 | A |
4446344 | Fiedler | May 1984 | A |
4460355 | Layman | Jul 1984 | A |
4484479 | Eckhardt | Nov 1984 | A |
4489302 | Eventoff | Dec 1984 | A |
4490798 | Franks et al. | Dec 1984 | A |
4493704 | Beard et al. | Jan 1985 | A |
4494950 | Fischell | Jan 1985 | A |
4498843 | Schneider et al. | Feb 1985 | A |
4512013 | Nash et al. | Apr 1985 | A |
4520706 | Deforeit | Jun 1985 | A |
4526574 | Pekkarinen | Jul 1985 | A |
4529401 | Leslie et al. | Jul 1985 | A |
4530696 | Bisera et al. | Jul 1985 | A |
4534756 | Nelson | Aug 1985 | A |
4542532 | McQuilkin | Sep 1985 | A |
4550731 | Batina et al. | Nov 1985 | A |
4550748 | Nunez | Nov 1985 | A |
4557725 | Heyne et al. | Dec 1985 | A |
4559037 | Franetzki et al. | Dec 1985 | A |
4559038 | Berg et al. | Dec 1985 | A |
4559044 | Robinson et al. | Dec 1985 | A |
4561443 | Hogrefe et al. | Dec 1985 | A |
4562751 | Nason et al. | Jan 1986 | A |
4563179 | Sakai | Jan 1986 | A |
4565542 | Berg | Jan 1986 | A |
4578573 | Flies et al. | Mar 1986 | A |
4596575 | Rosenberg et al. | Jun 1986 | A |
4597754 | Thill et al. | Jul 1986 | A |
4601702 | Hudson | Jul 1986 | A |
4606353 | Timm | Aug 1986 | A |
4617014 | Cannon et al. | Oct 1986 | A |
4623331 | Cewers et al. | Nov 1986 | A |
4624661 | Arimond | Nov 1986 | A |
4627835 | Fenton, Jr. | Dec 1986 | A |
4627839 | Young | Dec 1986 | A |
4649499 | Sutton et al. | Mar 1987 | A |
4650469 | Berg et al. | Mar 1987 | A |
4652260 | Fenton, Jr. et al. | Mar 1987 | A |
4658371 | Walsh et al. | Apr 1987 | A |
4671792 | Borsanyi | Jun 1987 | A |
4676776 | Howson | Jun 1987 | A |
4678408 | Nason et al. | Jul 1987 | A |
4681563 | Deckert et al. | Jul 1987 | A |
4685903 | Cable et al. | Aug 1987 | A |
4690673 | Bloomquist | Sep 1987 | A |
4692147 | Duggan | Sep 1987 | A |
4696671 | Epstein et al. | Sep 1987 | A |
4710163 | Butterfield | Dec 1987 | A |
4714462 | DiDomenico | Dec 1987 | A |
4722734 | Kolln | Feb 1988 | A |
D294733 | Peterson et al. | Mar 1988 | S |
4731051 | Fischell | Mar 1988 | A |
4731058 | Doan | Mar 1988 | A |
4731726 | Allen, III | Mar 1988 | A |
4739229 | Heiler, Jr. | Apr 1988 | A |
4741732 | Crankshaw et al. | May 1988 | A |
4745301 | Michalchik | May 1988 | A |
4747828 | Tseo | May 1988 | A |
4754401 | Kaczynski et al. | Jun 1988 | A |
4756706 | Kerns et al. | Jul 1988 | A |
4774029 | Poulin | Sep 1988 | A |
4775368 | Iwatschenko | Oct 1988 | A |
4778449 | Weber et al. | Oct 1988 | A |
4785799 | Schoon et al. | Nov 1988 | A |
4790816 | Sundblom et al. | Dec 1988 | A |
4799381 | Tromp | Jan 1989 | A |
4808161 | Kamen | Feb 1989 | A |
4808167 | Mann et al. | Feb 1989 | A |
4809697 | Causey, III et al. | Mar 1989 | A |
4810243 | Howson | Mar 1989 | A |
4810992 | Eventoff | Mar 1989 | A |
4816019 | Kamen | Mar 1989 | A |
4818186 | Pastrone et al. | Apr 1989 | A |
4826810 | Aoki | May 1989 | A |
4832033 | Maher et al. | May 1989 | A |
4836752 | Burkett | Jun 1989 | A |
4838856 | Mulreany et al. | Jun 1989 | A |
4838857 | Strowe et al. | Jun 1989 | A |
4842584 | Pastrone | Jun 1989 | A |
4846792 | Bobo, Jr. et al. | Jul 1989 | A |
4847990 | Patrick | Jul 1989 | A |
4850807 | Frantz | Jul 1989 | A |
4850972 | Schulman et al. | Jul 1989 | A |
4852581 | Frank | Aug 1989 | A |
4856339 | Williams | Aug 1989 | A |
4863425 | Slate et al. | Sep 1989 | A |
4869722 | Heyman | Sep 1989 | A |
4871351 | Feingold | Oct 1989 | A |
4878896 | Garrison et al. | Nov 1989 | A |
4882575 | Kawahara et al. | Nov 1989 | A |
4889132 | Hutcheson et al. | Dec 1989 | A |
4898578 | Rubalcaba, Jr. | Feb 1990 | A |
4901221 | Kodosky et al. | Feb 1990 | A |
4908017 | Howson et al. | Mar 1990 | A |
4919650 | Feingold et al. | Apr 1990 | A |
4925444 | Orkin et al. | May 1990 | A |
4927411 | Pastrone et al. | May 1990 | A |
4933873 | Kaufman et al. | Jun 1990 | A |
4943279 | Samiotes et al. | Jul 1990 | A |
4950235 | Slate et al. | Aug 1990 | A |
4950244 | Fellingham et al. | Aug 1990 | A |
4961533 | Teller et al. | Oct 1990 | A |
4976151 | Morishita | Dec 1990 | A |
4978335 | Arthur, III | Dec 1990 | A |
4979940 | Bobo, Jr. et al. | Dec 1990 | A |
4994035 | Mokros | Feb 1991 | A |
4996511 | Ohkawa et al. | Feb 1991 | A |
5000739 | Kulisz et al. | Mar 1991 | A |
5006997 | Reich | Apr 1991 | A |
5009641 | Gorton | Apr 1991 | A |
5010473 | Jacobs | Apr 1991 | A |
5017059 | Davis | May 1991 | A |
5034004 | Crankshaw | Jul 1991 | A |
5038800 | Oba | Aug 1991 | A |
5041086 | Koenig et al. | Aug 1991 | A |
5047014 | Mosebach et al. | Sep 1991 | A |
5050612 | Matsumura | Sep 1991 | A |
5053585 | Yaniger | Oct 1991 | A |
5053990 | Kreifels | Oct 1991 | A |
5062774 | Kramer et al. | Nov 1991 | A |
5069668 | Boydman | Dec 1991 | A |
5074756 | Davis | Dec 1991 | A |
5078682 | Miki et al. | Jan 1992 | A |
5078683 | Sancoff et al. | Jan 1992 | A |
5082014 | Olichney | Jan 1992 | A |
5084828 | Kaufman et al. | Jan 1992 | A |
5087245 | Doan | Feb 1992 | A |
5088983 | Burke | Feb 1992 | A |
5096385 | Georgi et al. | Mar 1992 | A |
5098262 | Wecker et al. | Mar 1992 | A |
5098409 | Stock | Mar 1992 | A |
5100380 | Epstein et al. | Mar 1992 | A |
5103211 | Daoud et al. | Apr 1992 | A |
5104374 | Bishko et al. | Apr 1992 | A |
5111234 | Taniguchi et al. | May 1992 | A |
5115223 | Moody | May 1992 | A |
5122820 | Pagano et al. | Jun 1992 | A |
5124744 | Ogura et al. | Jun 1992 | A |
5124802 | Ito et al. | Jun 1992 | A |
5131816 | Brown et al. | Jul 1992 | A |
5140862 | Pappalardo | Aug 1992 | A |
5153827 | Coutre et al. | Oct 1992 | A |
5154700 | Danby | Oct 1992 | A |
5172698 | Stanko | Dec 1992 | A |
5174472 | Raque et al. | Dec 1992 | A |
5176004 | Gaudet | Jan 1993 | A |
5181910 | Scanlon | Jan 1993 | A |
5190522 | Wojcicki et al. | Mar 1993 | A |
5207642 | Orkin et al. | May 1993 | A |
5211626 | Frank et al. | May 1993 | A |
5213573 | Hyman et al. | May 1993 | A |
5219327 | Okada | Jun 1993 | A |
5221268 | Barton et al. | Jun 1993 | A |
5224051 | Johnson | Jun 1993 | A |
5238001 | Gallant et al. | Aug 1993 | A |
5244461 | Derlien | Sep 1993 | A |
5244463 | Cordner, Jr. et al. | Sep 1993 | A |
5247434 | Peterson et al. | Sep 1993 | A |
5256157 | Samiotes et al. | Oct 1993 | A |
5265431 | Gaudet et al. | Nov 1993 | A |
5307263 | Brown | Apr 1994 | A |
5317506 | Coutré et al. | May 1994 | A |
5338157 | Blomquist | Aug 1994 | A |
5339821 | Fujimoto | Aug 1994 | A |
5350411 | Ryan et al. | Sep 1994 | A |
5354273 | Hagen | Oct 1994 | A |
5356378 | Doan | Oct 1994 | A |
5357427 | Langen et al. | Oct 1994 | A |
5364346 | Schrezenmeir | Nov 1994 | A |
5368562 | Blomquist et al. | Nov 1994 | A |
5376070 | Purvis et al. | Dec 1994 | A |
5383855 | Nicholson et al. | Jan 1995 | A |
5389071 | Kawahara et al. | Feb 1995 | A |
5389078 | Zelesky et al. | Feb 1995 | A |
5395321 | Kawahara et al. | Mar 1995 | A |
5429602 | Hauser | Jul 1995 | A |
5431627 | Pastrone et al. | Jul 1995 | A |
5440585 | Partridge, III | Aug 1995 | A |
5456691 | Snell | Oct 1995 | A |
5478211 | Dominiak et al. | Dec 1995 | A |
5482446 | Williamson et al. | Jan 1996 | A |
5485408 | Blomquist | Jan 1996 | A |
5531697 | Olsen et al. | Jul 1996 | A |
5531698 | Olsen | Jul 1996 | A |
5537436 | Bottoms et al. | Jul 1996 | A |
5558640 | Pfeiler et al. | Sep 1996 | A |
5569187 | Kaiser | Oct 1996 | A |
5573506 | Vasko | Nov 1996 | A |
5582593 | Hultman | Dec 1996 | A |
5594786 | Chaco et al. | Jan 1997 | A |
5616121 | McKay | Apr 1997 | A |
5626144 | Tacklind et al. | May 1997 | A |
5630710 | Tune et al. | May 1997 | A |
5643212 | Coutré et al. | Jul 1997 | A |
5647854 | Olsen et al. | Jul 1997 | A |
5658250 | Blomquist et al. | Aug 1997 | A |
5660176 | Iliff | Aug 1997 | A |
5665065 | Colman et al. | Sep 1997 | A |
5669877 | Blomquist | Sep 1997 | A |
5687734 | Dempsey et al. | Nov 1997 | A |
5695473 | Olsen | Dec 1997 | A |
5704366 | Tacklind et al. | Jan 1998 | A |
5717603 | McClendon et al. | Feb 1998 | A |
5764159 | Neftel | Jun 1998 | A |
5772635 | Dastur et al. | Jun 1998 | A |
5788669 | Peterson | Aug 1998 | A |
5807336 | Russo et al. | Sep 1998 | A |
5822715 | Worthington et al. | Oct 1998 | A |
5861018 | Feierbach | Jan 1999 | A |
5868669 | Iliff | Feb 1999 | A |
5871465 | Vasko | Feb 1999 | A |
5876370 | Blomquist | Mar 1999 | A |
5879163 | Brown et al. | Mar 1999 | A |
5885245 | Lynch et al. | Mar 1999 | A |
5897493 | Brown | Apr 1999 | A |
5899855 | Brown | May 1999 | A |
5913310 | Brown | Jun 1999 | A |
5918603 | Brown | Jul 1999 | A |
5925021 | Castellano et al. | Jul 1999 | A |
5933136 | Brown | Aug 1999 | A |
5935099 | Peterson et al. | Aug 1999 | A |
5935106 | Olsen | Aug 1999 | A |
5940801 | Brown | Aug 1999 | A |
5956501 | Brown | Sep 1999 | A |
5960403 | Brown | Sep 1999 | A |
5997476 | Brown | Dec 1999 | A |
6024539 | Blomquist | Feb 2000 | A |
6032119 | Brown et al. | Feb 2000 | A |
6101478 | Brown | Aug 2000 | A |
RE36871 | Epstein et al. | Sep 2000 | E |
6246992 | Brown | Jun 2001 | B1 |
6269340 | Ford et al. | Jul 2001 | B1 |
Number | Date | Country |
---|---|---|
2060151 | Aug 1992 | CA |
665 955 | Jun 1988 | CH |
0069350 | Jan 1983 | EP |
0078645 | May 1983 | EP |
0183351 | Sep 1985 | EP |
0188288 | Jul 1986 | EP |
0221005 | May 1987 | EP |
0233115 | Sep 1987 | EP |
0 319 272 | Jul 1989 | EP |
0384155 | Aug 1990 | EP |
408483 | Jan 1991 | EP |
0497041 | Aug 1992 | EP |
503670 | Sep 1992 | EP |
0371507 | Mar 1993 | EP |
551088 | Jul 1993 | EP |
0328162 | Dec 1993 | EP |
0 806 738 | Dec 1997 | EP |
2603488 | Mar 1988 | FR |
2675288 | Oct 1992 | FR |
2262452 | Jun 1993 | GB |
409192218 | Jul 1997 | JP |
WO 8403218 | Aug 1984 | WO |
WO8703814 | Jun 1987 | WO |
WO8707161 | Dec 1987 | WO |
WO9116609 | Oct 1991 | WO |
9208647 | Sep 1992 | WO |
9215439 | Sep 1992 | WO |
9408647 | Sep 1992 | WO |
WO9405355 | Mar 1994 | WO |
WO9408647 | Apr 1994 | WO |
WO9502426 | Jan 1995 | WO |
WO9525893 | Sep 1995 | WO |
WO9528190 | Oct 1995 | WO |
WO9603168 | Feb 1996 | WO |
WO 9636389 | Nov 1996 | WO |
WO 9725083 | Jul 1997 | WO |
WO9715227 | Apr 1998 | WO |
WO 9820439 | May 1998 | WO |
WO 9824358 | Jun 1998 | WO |
WO 9842407 | Oct 1998 | WO |
WO 9859487 | Dec 1998 | WO |
WO 9908183 | Feb 1999 | WO |
WO 9910801 | Mar 1999 | WO |
WO 9918532 | Apr 1999 | WO |
WO 9922236 | May 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20020183693 A1 | Dec 2002 | US |
Number | Date | Country | |
---|---|---|---|
60010090 | Jan 1996 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09795266 | Feb 2001 | US |
Child | 10068291 | US | |
Parent | 09324305 | Jun 1999 | US |
Child | 09795266 | US | |
Parent | 08782486 | Jan 1997 | US |
Child | 09324305 | US | |
Parent | 08090738 | Jul 1993 | US |
Child | 08555304 | US | |
Parent | 08276025 | Jul 1994 | US |
Child | 08586952 | US | |
Parent | 07942288 | Sep 1992 | US |
Child | 08276025 | US | |
Parent | 08540960 | Oct 1995 | US |
Child | 07942288 | US | |
Parent | 08561809 | Nov 1995 | US |
Child | 08540960 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 08555304 | Nov 1995 | US |
Child | 08782486 | US | |
Parent | 08206737 | Mar 1994 | US |
Child | 08090738 | US | |
Parent | 08586952 | Jan 1996 | US |
Child | 08206737 | US |