1. Field of the Invention
The present invention relates generally to a system for capturing and managing data in a health care environment. More particularly, the present invention relates to a medical processing system that includes a handheld scanner that receives data from a patient and medication and transmits that data to a data storage mechanism for analysis. In one particular embodiment, the system determines patterns of medicine interactions between patient populations.
2. Description of the Related Art
Some computing tasks or environments require a high degree of mobility, ease of operation, and low cost implementation due to a large number of users. One example of such tasks is the administration and documentation of care provided to patients in a medical or hospital environment. Computer resources in these environments are limited due to inadequate availability of access points such as input/output (I/O) stations or terminals. Although stationary terminals have a large screen, familiar full-featured keyboard, and mouse input devices, such terminals are inconvenient to use in certain environments due to lack of portability, or availability due to cost and space constraints. Notebook computers with wireless communication capabilities can increase the power of computer terminals while maintaining relatively fast and available computing power. However, they are still somewhat large in size, bulky to transport, have limited battery life, require two hands to operate, and are expensive.
A plurality of small sized wireless computing devices have been developed, such as wireless personal digital assistants (PDA's), for use by caregivers in administration and documentation of medical care. For example, U.S. Pat. No. 4,916,441 to Gombrich describes a handheld terminal that includes a wireless transmitter and a bar code scanner for entering medical data into a computer system. Unfortunately, a nurse needs to manually type much of the information onto a small keyboard on the device. This is inconvenient and time-consuming in a hospital environment.
In addition, similar devices are fragile, bulky or expensive, and require two-handed or tedious tasks for operation. Thus, improved devices and methods are needed in the technology.
In one embodiment of the present invention a method of capturing drug administration data at a point of care comprises providing a hand held device comprising a scanner configured to scan identification codes or symbols, a processor and a data storage device connected to the processor, storing patient data and a drug identifier to the data storage device, transmitting the patient data and the drug identifier to a server and correlating the patient data and the drug identifier to determine correlations between patient populations and drugs.
In some embodiments the method further comprises receiving a time of administration of the drug into the handheld device. In some embodiments the time of administration comprises a date of administration, an address for the facility administering care or a name of an attendant administering care. In some embodiments storing the patient data comprises scanning at least one of a one dimensional code, a two dimensional code and a radio frequency identification tag. In some embodiments the patient data comprises biological information. In some embodiments the biological information is at least one of a fingerprint and a retinal scan. In some embodiments the patient data is selected from the list consisting of a patient name, a doctor name, a doctor identifier, a list of medications taken by the patient, a patient gender, a patient date of birth, a method of payment for service, a dosage administered, a route of administration, an apical pulse prior to drug administration, a blood sugar level prior to drug administration, a pain level prior to drug administration, a patient statement prior to drug administration, a diagnosis or condition recorded by an attendant prior to drug administration, an apical pulse after drug administration, a blood sugar level after drug administration, a pain level after drug administration, a patient statement after drug administration and a diagnosis or condition recorded by an attendant after drug administration. In some embodiments storing the drug identifier comprises scanning at least one of a one dimensional code, a two dimensional code and a radio frequency identification tag. In some embodiments the drug identifier is selected from the list consisting of a dosage form, a list of drug active ingredients, a National Drug Code, a dosage strength, a package size, a drug class, a drug manufacturer, a manufacturer lot number, a brand name, a drug formulation and a drug SIG code. In some embodiments the correlations comprise at least one correlation selected from the list consisting of method of payment correlations, regional and/or geographic correlations, drug manufacturer correlations, gender correlations, demographic correlations, age correlations, diagnosis/ailment correlations, physician correlations, hospital correlations and drug combination correlations.
In another embodiment a medical electronic data capture system in a medical workflow environment comprises a hand held scanner for reading patient data and drug identifiers, wherein the scanner comprises a processor, a wireless transceiver connected to the processor, wherein the wireless transceiver is configured to communicate with a data storage device and to transmit the patient data and the drug identifiers to the data storage device and a module communicating with the data storage device and configured to correlate the patient data with the drug identifiers to determine correlations between patient populations and drugs.
In some embodiments the patient data is selected from the list consisting of patient age, patient diagnosis, patient gender, patient medical history, patient blood sugar levels before drug administration, patient blood sugar levels after drug administration, patient blood pressure before drug administration, patient blood pressure after drug administration, drug manufacturing data, drug dosage level, route of administration, hospital employee identification, attending doctor identification, hospital identification, time of administration or food ingested before drug administration. In some embodiments the drug identifier is selected from the list consisting of a dosage form, a list of drug active ingredients, a National Drug Code, a dosage strength, a package size, a drug class, a drug manufacturer, a manufacturer lot number, a brand name, a drug formulation or a drug SIG code. In some embodiments the wireless terminal is configured to be in periodic communication with the data storage device. In some embodiments the wireless terminal is configured to be in constant communication with the data storage device. In some embodiments the data storage device is a server computer. In some embodiments the medical electronic data capture system further comprises a peripheral device. In some embodiments the peripheral device is an intravenous drug delivery device for administering drugs intravenously to a patient.
In another embodiment a medical electronic data capture system in a medical workflow environment comprises means for reading patient data and drug identifiers, means for communicating patient data and drug identifiers, means for associating patient data with patient populations and means for determining correlations between patient populations and drugs.
In some embodiments the means for reading patient data and drug identifiers is a terminal electrically connected to a processor. In some embodiments the means for reading patient data and drug identifiers is a handheld scanner, and wherein the wireless handheld scanner is wirelessly connected to a server. In some embodiments the means for associating patient data with patient populations is a handheld scanner comprising a processor. In some embodiments the means for associating patient data with patient populations is a module comprising instructions for the associating. In some embodiments the means for communicating patient data and drug identifiers is a wireless handheld scanner. In some embodiments the means for communicating patient data and drug identifiers is a wired terminal. In some embodiments the means for determining correlations between patient populations and drugs is a module comprising instructions for the determining. In some embodiments the means for determining correlations between patient populations and drugs is a handheld scanner
The present invention is described with reference to the accompanying drawings. In the drawings, like reference numbers indicate like elements.
Embodiments of the invention relate to a system for analyzing data patterns in a medical environment. As is known, within a hospital, patients are given a wide variety of treatments and medicines. However, it has become challenging to correlate the variety of treatments and medicines in order to discern correlations between patient outcomes and treatments/medicines. Thus, in one embodiment of the invention, the system determines correlations between patient care and the treatments or medicines provided to the patient.
In one example, a series of patients may be given an aspirin at the same time as a new antibiotic. As the nurse gives the aspirin and the new antibiotic to a patient, a wireless handheld terminal, as described in detail below, is used to enter an identifier of the patient, and identifiers corresponding to the medication order for aspirin and the new antibiotic. The wireless terminal sends that information to a central server that compiles the information regarding the patient and the medicines and treatments that the patient has received.
Once a database of such medical information is provided, it can be “mined” to determine correlations between the patient data and the treatment or medicine data. For example, it may be discovered that patients who took aspirin and the new antibiotic reported stomach pains within three hours of treatment. It may be discovered that patients who took the antibiotic and aspirin, but were over 50 years old, had adverse reactions. Any number of data correlations can be determined once the patient data and the medicine/treatment data is provided from the wireless terminal to a database.
In one embodiment, a pharmaceutical company may use such a database for tracking the effect of a new medicine on a large population of patients. As is known, pharmaceutical companies run clinical trials in order to determine the safety and efficacy of their medicines. However, once the medicine is approved for treatment, it can be difficult for the pharmaceutical company to continue to track the medicine's effect on the wider population of patients, and to correlate that medicine's effect with a variety of medically relevant variables.
Using the systems and methods described herein, a pharmaceutical company can compile a database of patient data from patients that were given a particular medicine. They can then mine that data for any correlations with adverse effects on the patient. Because the data is entered into the system as part of the normal course of patient care, using the wireless terminal as described below, the data is provided in a way that is transparent to the hospital or treating personnel.
Embodiments of the invention relate to a system and method employing a wireless handheld terminal for management of medical care in an environment such as a hospital. The wireless terminal preferably has at least one code reader, or scanner, used to read codes or symbols corresponding to, for example, patient identification, item identification, documentation characters and phrases, commands, and instructions. The codes or symbols are preferably machine readable codes or symbols, including one and two dimensional optically readable codes or symbols such as bar codes, but can include radio frequency identification (RF ID) devices or tags. The codes or symbols can be applied to objects, cards, or placards throughout a hospital environment. In one embodiment, each user can have a card, or codesheet, comprising that user's most commonly used codes or symbols. Thereby, the user only needs to scan the codes or symbols on their codesheet to enter particular data, or carry out specific instructions.
As described below, in addition to scanning in codes or symbols as data, the system also scans in codes or symbols that provide an instruction to the system. The system may scan in codes or symbols that provide data or an instruction to the system, either via a connected server or via a direct wired or wireless link to a peripheral device, such as an intravenous delivery device (e.g., an IV pump). By scanning in a plurality of codes or symbols, a user, such as a nurse, can send messages, page, print, process commands either at a server or directly at a peripheral device (thus bypassing the need to communicate via a server), and order medical tests. For example, in one embodiment, a nurse may need to page a doctor to the patient's location. In this embodiment, the nurse would scan the patient ID bracelet, which includes a scan code sequence identifying the patient. The nurse would then scan an instruction code, printed either on a placard or in the room, which provides the instruction “page the doctor”. The scanned codes or symbols would be transmitted wirelessly to the server, and the instruction would be executed at the server.
The server would query a database or lookup table of codes or symbols and instructions for the scanned codes or symbols and determine that one of the scanned codes or symbols corresponded to a “paging” instruction. This database can reside either on a server, on a peripheral device such as an intravenous delivery device or pump or on the wireless handheld terminal itself. The system would then execute instructions to identify the doctor to be paged based on the scan code corresponding to the identification of the patient, and then page the appropriate doctor to the patient's location. In one embodiment, the system is linked to a hospital administration system which stores the name of each patient, and the doctor for the patient that is currently on-call. Thus, the wireless terminal not only provides the function of reading data with the code scanner, but also advantageously performs functions using the same code scanner.
The terminal preferably establishes communication with a server that maintains a database of codes or symbols and corresponding information or commands which it uses to process the codes or symbols received from the terminal via a wireless communication link. The server is preferably in communication with additional devices via a network, such as a local area network (LAN), where the additional devices perform a variety of functions, such as messaging, printing, or record keeping. The server is also configured to communicate with the wireless terminal to provide requested information or information in response to scanning of particular codes or symbols, such as codes or symbols corresponding to particular medications. The terminal can also bypass a server and communicate directly with a peripheral device, such as an intravenous delivery pump, either via wired or wireless means.
In one aspect of the invention, the wireless terminal has processing capabilities such that it can process codes or symbols locally without communicating with the server, and thereby interacting with the user autonomously in certain capacities. The terminal communicates with the user via indicators and a display screen, such as an LCD screen. The terminal can also be adapted with audio indicators such as a beep to indicate a warning condition or a message awaiting acknowledgement. The user can acknowledge or respond to messages displayed on the screen with an acknowledgement or “OK” button on the terminal. As one example, a nurse might scan in a code from a packet of Digoxin, which is a medicine to treat heart problems that should be administered only after an apical pulse measurement has been taken by the nurse. Once the nurse scans the code from the Digoxin packet, a processor in the terminal reads the code and compares it with an internal list of codes or symbols. In this case, the terminal would recognize the code as requiring an apical pulse measurement, and would display a warning and request input from the nurse of the apical pulse. The nurse could then scan in the apical pulse measurement by scanning codes or symbols corresponding to the appropriate numbers in order to enter the pulse measurement into the terminal. Once the pulse measurement was entered, the terminal could transmit the entered data to the server.
The codes or symbols used and maintained in the system are preferably in a “closed” symbology, such that only one code corresponds to a particular instruction or piece of information. This ensures that the system does not receive duplicate codes or symbols which correspond to different instructions or information. In certain embodiments, the codes or symbols are implemented as a 2-D matrix, or DOT as described in International Publication No. WO 02/07065, hereby incorporated by reference in its entirety. In one embodiment, the physical DOT is 7 mm in diameter, and comprises 321 white or dark hexagons. In another embodiment, the physical DOT is approximately 5 mm in diameter, but less than 7 mm in diameter. In one embodiment, a computer server can be configured to generate a 64 bit number, encrypt it, and algorithmically produce a 2-D DOT which uniquely represents the encoded data. Where the system is implemented using the DOT symbology, the system can have additional capabilities such as the methods and systems described in International Publication No. 02/21794 A2. As used herein, a “dot scanner” is configured to read the DOT symbology. The system can also function using other one-dimensional or two-dimensional symbols such as AZTEC® codes and two-dimensional barcodes along with the DOT as described in International Publication No. WO 02/07065.
The 2-D DOT or other one-dimensional or two-dimensional symbols advantageously permit high density placement of DOTs or other one-dimensional or two-dimensional symbols as explained in Publication No. 02/21794 A2. The DOTs or other one-dimensional or two-dimensional symbols can be placed adjacent to one another in the same horizontal row or vertical column without the data from one DOT or other one-dimensional or two-dimensional symbols interfering with the ability of a terminal to read an adjacent DOT. Thus, the DOTs or other one-dimensional or two-dimensional symbols can be arranged as an array of DOTs or other one-dimensional or two-dimensional symbols. In one embodiment, a center to center distance between adjacent DOTs or other one-dimensional or two-dimensional symbols is approximately 20 mm and is less than 25 mm. In other embodiments, the center to center distance between adjacent DOTs or other one-dimensional or two-dimensional symbols is less than about 10 mm, 15 mm, 20 mm, 30 mm, 35 mm, 40 mm, 45 mm, 50 mm, 55 mm, 60 mm, 65 mm, 70 mm, 75 mm, 80 mm, 90 mm, or 100 mm.
Due to the vast number of data combinations made possible by the DOT or other one-dimensional or two-dimensional symbols, an entire medical management system can be implemented using DOTs or other one-dimensional or two-dimensional symbols to represent all of the information and commands desired in the system. Thereby, the possibility of confusion with commonly used bar codes is eliminated. The system may, however, be implemented with both DOTs or other one-dimensional or two-dimensional symbols and bar code technology, where the terminal would include both a bar code scanner and a DOT or other one-dimensional or two-dimensional symbol scanner. Such an embodiment is described below.
As used herein, “instructions” refer to computer-implemented steps for processing information in the system. Instructions can be implemented in software, firmware or hardware and include any type of programmed step undertaken by components of the system. As used herein, the term “manual instructions” are those steps that may be implemented by humans interacting with the system.
As used herein, a “code which corresponds to instructions” or a “code corresponding to an instruction” means a code that refers to, or is converted into, one or more instructions to be carried out in the system. For example, a code “ABC123” might point to an instruction that results in a doctor being paged to a particular room. As another example, a code might trigger an intravenous delivery system to access specific medication information and settings for a specific patient and specific medication order corresponding to that patient. The specific settings can be accessed from remote storage, such as a networked server, from information resident in the handheld terminal or from information resident in the device, such as within the intravenous delivery system. Codes or symbols and their corresponding instructions can be stored in a database or lookup table so that scanning in a code causes the terminal to lookup the code in the database and retrieve its corresponding instruction, or set of instructions. As described, codes or symbols are preferably converted into 1D or 2D symbols so that they can be conveniently scanned into the system.
One example of a Local Area Network may be a corporate computing network, including access to the Internet, to which computers and computing devices comprising the system are connected. In one embodiment, the LAN conforms to the Transmission Control Protocol/Internet Protocol (TCP/IP) industry standard. In alternative embodiments, the LAN may conform to other network standards, including, but not limited to, the International Standards Organization's Open Systems Interconnection, IBM's SNA, Novell's Netware, and Banyan VINES.
As used herein, a “microprocessor” may be any conventional general purpose single- or multi-chip microprocessor such as a Pentium® processor, a 8051 processor, a MIPS® processor, a Power PC® processor, an ALPHA® processor, an ARM processor, a RISC processor or any one of a number of microcontrollers or other devices that process instructions that may be measured in number of instructions per second, e.g., millions of instructions per second (MIPS). In addition, the microprocessor may be any conventional special purpose microprocessor such as a digital signal processor or a graphics processor. The microprocessor typically has conventional address lines, conventional data lines, and one or more conventional control lines.
As used herein, the term “module” refers to the various modules in the system as discussed in detail below. As can be appreciated by one of ordinary skill in the art, each of the modules comprises various sub-routines, procedures, definitional statements and macros. Each of the modules are typically separately compiled and linked into a single executable program. Therefore, the following description of each of the modules is used for convenience to describe the functionality of the preferred system. Thus, the processes that are undergone by each of the modules may be arbitrarily redistributed to one of the other modules, combined together in a single module, or made available in, for example, a shareable dynamic link library.
The system may include any type of two or more electronically connected computers including, for instance, the following networks: Internet, Intranet, Local Area Networks (LAN), Wide Area Networks (WAN) or direct connections such as peer-to-peer connections. In addition, the connectivity to the network may be, for example, remote modem, Ethernet (IEEE 802.3), Token Ring (IEEE 802.5), Fiber Distributed Datalink Interface (FDDI) or Asynchronous Transfer Mode (ATM). Note that computing devices may be desktop, server, portable, hand-held, set-top, or any other desired type of configuration. As used herein, an Internet includes network variations such as public internet, a private internet, a secure internet, a private network, a public network, a value-added network, an intranet, and the like.
As used herein, the term “programming language” refers to any programming language including, but not limited to, C, C++, C#, BASIC, Pascal, Java, FORTRAN, and Assembly Language and ran under a computer operating system. C, C++, C#, BASIC, Pascal, Java, and FORTRAN are industry standard programming languages for which many commercial compilers can be used to create executable code.
The wireless terminals 14 and server 12 are configured to communicate both constantly or periodically, although the preference is for periodic communication sessions rather than constant communication. Thereby, battery power at the wireless terminals 14 can be conserved and situations where the terminal 14 is out of communication range with the server 12 do not create power consuming loop processes wherein the terminal 14 continually attempts communication with the server 12. The server 12 and wireless terminals 14, however, can communicate at any instant if desired, and are not limited to communication during the designated communication sessions. The wireless terminals 14 are preferably small in size for ease of portability and one-handed use.
The server 12 is also coupled to a plurality of peripheral devices and systems, such as a printer 20, a messaging system 22, a pharmacy system 24, a laboratory system 26, a hospital server 28, a financial system 29 and a patient record system 30, via a network connection. Commands or instructions received from the wireless terminals 14 are communicated by the server 12 to the various devices and systems for performance of requested tasks, and information from the various peripheral devices and systems are communicated to the wireless terminals 14 by the server 12. For example, the pharmacy system 24 can send updated medication information for patients or send notification to the server 12 when a patient's medication is ready. A terminal 14 can also query the pharmacy system 24 for information via the server 12. Similarly, a terminal 14 can send laboratory test requests to the laboratory system 26, or receive test results from the laboratory system 26 via the server 12. Additionally, the system 10 can send billing and charge data to the financial system 29 based upon the information gathered by the system 10 during its use.
Where the hospital server 28 maintains, for example, patient registration information, the hospital server 28 can send updated information to the server 12, and the wireless terminals 14 can update the hospital server 28, for example, when a patient has been discharged.
In one embodiment, the patient record system 30 is an Electronic Medical Record (EMR) system, and is updated with information from the wireless terminals 14 so as to maintain an electronic record of each patient's medication administration and any additional comments input to the terminal 14 by a user.
Thus, the wireless terminals 14 have capabilities similar to computer terminals which are connected to the peripheral devices and systems through a conventional network. Peripheral devices may include, for example, an intravenous delivery pump. The interaction of the wireless terminals 14, server 12, and peripheral devices and systems will be described in further detail hereinafter.
The server 12 comprises a database 32 for storing a plurality of scan codes or symbols and each codes or symbols' corresponding data or instruction in order to perform a plurality of electronic tasks. Scan codes or symbols can also be stored on the handheld terminal and/or on a device such as an intravenous pump. The data includes, for example, information corresponding to a patient, medication, objects, and note taking entries, and the instructions can include tasks such as “print a patient report”, “order laboratory tests”, and “request assistance”. The database 32 can be modified and maintained using the terminal 16 or additional computer terminals in communication with the server 12. In certain embodiments, the system comprises both a local server and a remote server, including local and remote databases. In such embodiments, the local databases may provide pointers to locate the appropriate remote server, or the local and remote servers may operate or interface together in a different manner. In addition, where a plurality of servers and databases are used in a single hospital, for example, a master computer or server can be used to maintain and update the databases.
The server 12 comprises a transceiver module 50 configured to receive and facilitate transmission of data via the transceiver circuitry 46. The server 12 further comprises an activation module 54 configured to initiate each terminal 14 at the beginning of each use. In one embodiment, a user may request activation of a terminal 14 by scanning a code (or codes or symbols) corresponding to user information, such as a username and password. In one embodiment, the user scans an identification code on their name badge, and thereafter enters a password into the code scanner. In response to an activation request, the activation module 54 first verifies whether the user is authorized to use the terminal 14 by attempting to correlate the user information with information stored at the database 32. Secondly, where a nurse at a nurse's station in a hospital is requesting activation of the terminal 14, the activation module 54 sends a list of tasks to be performed and information to be used by the nurse during their working shift. More specifically, where Nurse A requests activation of a terminal 14, the activation module 54 sends information corresponding to Patients A, B, C, and D, who are assigned to Nurse A, to the terminal 14 along with any additional tasks to be performed by Nurse A for those patients or in general. These exemplary features of the system 10 are discussed in more detail hereinafter below in reference to
As shown in
The server 12 further comprises an instruction processing module 58 for processing an instruction, and a data processing module 60 for processing data, wherein analysis by the analyze module 56 determines whether a communication from a networked terminal 14 comprises data or an instruction, and sends the communication contents to the appropriate module for processing. The server 12 also includes a processor 62 and a memory 64, used by instruction processing and data processing modules 58, 60 during operation. The memory 64 can also be configured to store the database 32 of scan codes or symbols and corresponding instructions or data. It should be realized that additional memory types, such as a flash memory, can also be used to store data within the server 12.
The memory 64 is also configured to store information received from peripheral systems for use by the wireless terminals 14 and their users. For example, where a server 12 is assigned to each nursing station in a hospital, the memory 64 stores information corresponding both to the patients assigned to the nursing station and to the tasks to be performed by the caregivers assigned to the patients. More specifically, the medications, time of administration, and any additional information regarding the care of patient A is stored in memory 64 for use by the caregiver assigned to patient A.
The additional processing and task performance modules at the server 12 comprise an information update module 66, configured to update information stored in memory 64 with information from the plurality of peripheral devices and systems. For example, the information update module 66 receives medication orders from the pharmacy system, updates the memory 64 with the pharmacy orders, and sends updated medication orders to the appropriate wireless terminal 14.
As shown in
In one embodiment, the server 12 also includes a messaging module 70 configured to receive, generate, and send messages to the wireless terminals 14 and peripheral systems. The module 70 receives messages from the messaging system 22 (
In one embodiment, the report generation module 68 is configured to generate a message to notify the user of the terminal 14 which requested generation of a report that the report has been printed. The generated message is communicated to the messaging module 70, which formats the message and adds information for communication to the appropriate terminal 14.
In another embodiment, the patient record system 30 maintains an electronic record for each patient with respect to medication administration, including, but not limited to, type of medication, quantity of medication administered, how administered, time of administration, observations and other data that may be of value to caregivers and/or the insurers of patients. This information may then be stored at the server 12 and terminal 14, such that the server 12 may generate an alert or notification message if a terminal fails to timely send data indicating administration of medication. Alternately, the terminal may generate an alert or notification message if expected medication administration is not received by the stored time of administration, or within a predefined time period prior to the specified time of administration.
For example, a patient may be scheduled for administration of a particular medication at a predetermined time. The terminal 14 tracks an elapsed time after a predetermined medication administration time and may generate an alert or notification message if no indication of medication administration has been received within a predetermined alert time. The predetermined alert time may be, for example, 30 minutes or one hour after a scheduled administration time. Thus, the terminal 14 may be configured to monitor for an event where the time elapsed since the scheduled time exceeds some predetermined latency time. The terminal 14 may transmit the message to the server 12 for entry into the patient's care record. The terminal 14 will continue to periodically alert the user of the terminal 14 until the user acknowledges the alerts or the expected information is entered at the terminal 14. The user of the terminal 14 may acknowledge the alert or notification by, for example, selecting the “OK” button on the terminal 14.
Alternatively, the server 12 may send a message to a terminal 14 in response to some predetermined patient event. For example, a patient may have had one or more lab tests ordered to evaluate a condition. The server 12 may send a message to a terminal 14 in response to events such as availability of lab results for a particular patient, changes in patient medication, changes in patient health which may be monitored manually or through the use of telemetry, or some other predetermined event, such as a critical abnormal lab result.
In one embodiment, the server 12 maintains statistics on usage related to each individual terminal 14, the user, time information, and the type of code (barcode or DOT, for example) read by the user during each code read or scan event. In addition, information regarding, for example, mistakes in medication administration or user operation of the terminal, misreads of the code scanners, or other operational activity outside of an ideal work flow is tracked by the server. Such tracking or compilation of statistics provides for future performance improvement and optimization of the system.
The terminal 14 may also include indicators, such as a multiple or tricolor LED “Good Read” and message indicator 74 which, for example, illuminates briefly in green to notify the user when a code has been properly scanned, illuminates in red to notify the user when a code has been improperly scanned, and illuminates in yellow to notify the user when a message has been displayed on the display 72. The terminal 14 may also include additional indicators, such as a power source indicator and a wireless connectivity indicator (not shown). Such indicators can be incorporated as part of the display 72, or can be separate LED indicators which illuminate only when the available power is low or the terminal 14 is out of range for wireless connection with the server 12. In other embodiments, the one or more indicators may be one or more LEDs. The indicators are not limited to the colors and functions described above. For example, an indicator LED may display red, yellow, or green, or combinations of these, depending on a status of the terminal 14.
Also located on the upper surface 71A is a DOT and/or one-dimensional or two-dimensional image scan button 76 and a barcode scan button 77 to activate the code scanners, where the illustrated embodiment comprises both a DOT scanner and a barcode scanner. In the illustrated embodiment, the DOT scan button 76 is positioned on the upper surface 71A opposite the location of the DOT and/or other one-dimensional or two-dimensional symbol scanner on a lower surface of the terminal 14, and the barcode scan button 77 is positioned on the upper surface 71A opposite the location of the barcode scanner on the lower surface of the terminal 14 to indicate the location of the scanners to the user for scanning codes or symbols. It will be appreciated that in a first embodiment a terminal 14 comprises only a barcode scanner and barcode scan button. In a second embodiment a terminal 14 comprises only a DOT scanner and DOT and/or other one-dimensional or two-dimensional symbol scan button. In a third embodiment a terminal 14 comprises any one of a number of combinations of the first embodiment and the second embodiment discussed above. The terminal may additionally or alternatively include means for reading an RF ID tag.
As shown, the terminal 14 also includes an “OK” or acknowledge button 78 for user input in response to questions, or to acknowledge messages appearing on the display 72. Engaging the OK button 78 allows the terminal 14 to interact with the user in a predefined manner so that input from the user can be stored within the terminal 14, or transmitted to the server 12 for processing. It should be realized that other mechanisms for entering data into the terminal 14 are also contemplated. For example, a pair of “YES” and “NO” buttons could be implemented in place of the single OK button 78. In addition, fewer or more buttons could be placed on the rear surface or other surfaces of the terminal 14 without departing from the spirit of the invention. For example, the OK button 78 could be placed on a side surface and still be within the scope of the invention. In one embodiment, the terminal 14 includes a jog dial on a side surface of the terminal, for example, that can be used to scroll through messages that appear on the display 72, or to activate one of the scanners 80, 81.
The microcontroller 82 further comprises memory, which may be a combination of a static random access memory (SRAM) 86 and flash memory 88. The SRAM 86 is configured to store program and application data, and preferably has a size capable of supporting a real-time operating system and application data, as well as memory space for image processing using data from the DOT scanner. In one embodiment, the SRAM 86 is supplemented by a pseudo SRAM device 87, which combines a dynamic random access memory (DRAM) cell structure with an SRAM interface, so as to provide for low power consumption and low device cost. As will be appreciated by those skilled in the art, the single communication lines connecting elements of the terminal 14 are exemplary in nature, and a plurality of communication or control lines are contemplated.
The flash memory 88 is configured for permanent storage of boot firmware, operating system, driver, protocol stack, and application programming, and is also preferably configured for low power operation. In one embodiment, the flash memory 88 provides a relatively small storage amount, such as 2 Mbytes, and additional flash memory 90 is provided external to the microcontroller 82. For example, an additional 4 or 8 Mbytes of flash memory 90 is mapped into the memory area of the microcontroller 82 using external interface or glue logic 92 for address decoding into the same bank as the flash memory 88. In one embodiment, the terminal operating system and/or application software at the flash memory 88, 90 can be upgraded in whole or in part via a wireless communication link.
The microcontroller 82 also comprises a plurality of interfaces for communication with a plurality of peripheral devices. In one embodiment, the microcontroller 82 further comprises an external bus interface 94 configured to interface with the external memory components 87, 90 and glue logic 92, for example. The microcontroller 82 may also comprise a plurality of universal asynchronous receiver-transmitters (UART's) 96, 97 configured for asynchronous communications with peripheral devices, a plurality of programmed input/output lines, and a programmed input/output controller 98, configured to control the signals on the parallel input/output lines according to information from the processor 84.
The terminal 14 may additionally comprise a supervisory chip 99 coupled to the processor 84 and including a reset function and a watchdog timer. The reset function facilitates a system reset, for example, when the voltage supply rail exceeds a predefined threshold and maintains the reset condition for a predefined period of time while the terminal 14 components are allowed to stabilize. The watchdog timer is coupled to a watchdog timer signal output from the processor 84, wherein the timer will trip in the event of a software deadlock at the processor 84, and subsequently initiate a system reset. In one embodiment, the terminal 14 includes a clock 100 which provides the CPU clock, and the processor 84 can be configured to reduce the clock rate to conserve power when in a standby or sleep mode. The clock 100 may include a clock synthesizer. The microprocessor 82 may also use the clock as a real-time clock in order to communicate reminder messages or tones to the user for scheduled medication administrations or tasks. The clock can also provide for time stamping of each code scanning event or other events at the terminal 14. The terminal 14 may also include a real time clock, such as the Real Time Clock chip DS2415 from Maxim Semiconductor (Dallas), to provide the microcontroller 82 with real time information.
The glue logic 92 in this embodiment is provided by a low power complex programmable logic device (CPLD), and is configured to interface with the DOT scanner 81, a wireless communication transceiver 102, a display controller 104, and a user input and indicator controller 106. The terminal 14 may further include one or more antennas 108, coupled to the wireless communication transceiver 102. The DOT scanner 81 comprises an image sensor 120, such as an Omnivision OV6130 CMOS black and white imager incorporated into a digital camera including lens optics, and a bright LED 122 for illumination of the DOT image for scanning. In one embodiment, the DOT scanner 81 is a complete, individual unit and is configured to interface with the microcontroller 82 via the glue logic 92.
The wireless communication transceiver 102 is configured to communicate with the server 12 using wireless communication specifications such as RF, Bluetooth, IrDA or a WLAN specification, and the one or more antennas 108. In one embodiment, the wireless communication transceiver 102 is a wireless LAN (WLAN) module comprising a media access controller (MAC), such as the Agere WaveLAN WL 60010 MAC, and physical layer solution, such as the Agere WaveLAN WL 1141 802.11b Physical Layer Solution, the Philips solution, or the Marvell and Wi2Wi solutions. The MAC controller interfaces with the glue logic 92 via a compact flash interface 124, and implements the 802.11 protocol specified by IEEE standards. The WLAN module may also be configured to implement an advanced encryption standard (AES). In one embodiment, the terminal 14 further comprises an EEPROM 126, which is coupled to the transceiver 102 and configured to store device information, such as production attributes (serial number, board version, manufacturing date, MAC address, production number, etc.) and radio calibration data.
The display controller 104 is configured to interface with the display 72, which can be implemented with a black and white back-lit LCD. For example, the display 72 can be a 128×64 dot LCD module with chip-on-glass (COG) technology, or a 122×32 dot LCD module with tape carrier package (TCP) technology. The graphic controller 104 can be implemented, for example, with the Samsung Graphic Driver (KS0713/S6B1713). In one embodiment, the display controller 104 is not configured with built-in character fonts and a character font table is stored in memory in the terminal 14. The display controller 104 may be configured to display predefined symbols, such as a battery power indicator, battery charge status indicator, wireless communication status, and wireless communication signal strength.
In one embodiment, the user input and indicator controller 106 is configured to interface with one or more visual indicators, such as a plurality of single color LED's, bicolor LED's, the tricolor LED indicator 74, or a color display so as to facilitate activation or illumination of such indicators according to control signals from the microcontroller 82. The user input and indicator controller 106 is further configured to monitor and receive input from one or more input switches or buttons, such as the DOT scan button 76, the barcode scan button 77, and the acknowledge or “OK” button 78. In one embodiment, the terminal 14 includes a jog dial switch to select and initiate the reading of a barcode, DOT image and/or other one-dimensional or two-dimensional symbol. The user input and indicator controller 106 preferably interfaces with the microcontroller 82 via the glue logic 92, wherein the glue logic 92 extends general purpose input/output (GPIO) capabilities from the microcontroller 82. In addition, a de-bounce function may be provided for the input buttons and the jog dial switch.
In one embodiment, the terminal 14 comprises one or more audio indicators, such as a piezo speaker 130 and driver 132, coupled either directly to the microcontroller 82 or through the glue logic 92. The audio indicator preferably provides acknowledgement to a user of a successful code reading and/or decoding of a barcode or DOT image, and may also notify a user of a waiting message, alarm, or warning. The audio indicator may also produce different audio signals to indicate different conditions to the user, such as a first audio signal to indicate a successful code reading and decoding, and a second, different audio signal to indicate an unsuccessful code reading and/or decoding. An enhanced speaker may also provide feedback in the form of speech or other audio signals, some of which are described above.
The microcontroller 82 may include testing circuitry or one or more interfaces for testing circuitry at the terminal 14. In one embodiment, the microcontroller 82 comprises an embedded in-circuit emulator 134, and the terminal includes a joint test action group (JTAG) interface 136 to support ARM standard embedded in-circuit emulation. The terminal 14 may further comprise a debug port 138 for the microcontroller 82, comprising an RS232 transistor-transistor logic (TTL) interface to communicate with a peripheral test and debug monitor or circuit. The debug port 138 may also provide for initial programming of flash memory in the terminal 14 through a built-in flash programming routine at the microcontroller 82.
The terminal 14 further comprises the barcode reader 80, which may be implemented with a modular barcode scan engine such as a miniaturized, high performance 650 nm laser-based, single-line decoded scan engine from Symbol Technologies (model no. SE-923). The scan engine is preferably modular and self-contained, and includes a microcontroller configured to decode a barcode into a format compatible with and readable by the microcontroller 82. In one embodiment, the barcode reader 80 communicates with the microcontroller 82 through an RS232 TTL interface via a slave microcontroller 140. The slave microcontroller 140 is preferably configured for low-power operation, and acts as a pass-through device when the barcode reader 80 is configured to decode barcode data independently. In certain embodiments, the barcode reader 80 is implemented with a scan engine which is not configured to decode a barcode, and the terminal 14 further comprises additional decoding or conversion circuitry configured to convert barcode data into an acceptable format for processing at the slave microcontroller 140.
In one embodiment, the terminal 14 comprises a battery monitor and safety circuit 144 coupled to a battery power interface 146. The battery power interface 146 is preferably configured to draw power from a re-chargeable battery, such as a Li-Ion Polymer single cell battery, which provides approximately 3.7 volts. In one embodiment, the battery and the battery monitor and safety circuit 144 are a single unit, and may include the Texas Instruments chip BQ2050, for example. Where a re-chargeable battery is used, the terminal 14 further comprises a battery charger interface 148 configured to interface the battery monitor and safety circuit 144 with an external battery charger through metallic charger contacts, for example. The battery charger interface may be implemented, for example, with the Texas Instruments lithium ion charger, part no. BQ24002PWP.
The battery monitor and safety circuit 144 is configured to monitor the power level in the battery and conditions during charging, and the slave microcontroller 140 provides an interface, preferably a one wire interface, between the microcontroller 82 and the battery monitor and safety circuit 144. The battery preferably provides 3.3 volts for input/output and 1.65 volts for the processor core power rails through an on/off switch 149 for operation of the terminal 14. In one embodiment, the terminal 14 includes one or more voltage converters 150, such as the Micropower Synchronous Buck-Boost DC/DC converter by Linear Technology (LT3440EMS), to provide the desired power rails.
As the terminal 14 preferably remains operational for an extended period of time, such as up to 12 hours, the terminal 14 is configured for low power operation. In one embodiment, peripheral components of the reader are not all operated simultaneously. For example, the terminal 14 is preferably configured to refrain from transmitting and receiving data at the wireless communication transceiver 102 at the same time a code reading event occurs at the DOT reader 81 or the barcode reader 80. In certain embodiments, the wireless communication transceiver 102 may consume a large amount of power, and the specific transceiver implemented, such as the Agere WaveLAN, provides a variety of power savings modes that can be implemented to optimize the operational time of the terminal 14 between battery re-charging events.
The data or instructions corresponding to the scan codes or symbols may be used or performed locally at the terminal 14, or transmitted to the server 12 via the communication transceiver 102. The microcontroller 82 may include a transceiver module 168, which is configured to format data or an instruction for communication to the server according to the communication specifications of the communication transceiver 102. As discussed above, the terminal preferably communicates with the server 12 during designated communication sessions. During a communication session, the terminal 14 preferably transmits more than a single scan code from the terminal 14, however, the terminal 14 can transmit a scan code outside a designated communication session according to whether the data or instruction is to be sent to the server immediately. Determination of whether data or instructions are to be transmitted immediately may be based on user input or the type of data or instruction.
The microcontroller 82 also comprises an activation module 170 configured to operate in conjunction with the activation module 54 at the server 12 when a user requests activation of a terminal 14. Following user authorization by the server 12, the activation module 170 is configured to process information sent by the activation module 54 at the server 12 and store the information in memory. In association with the modules illustrated in
Referring to the example previously discussed, Nurse A requests activation of the terminal 14 by scanning a code on her identification badge. Upon authorization of Nurse A to use the terminal 14, which may also include input of a password at the hardwired terminal 16 or the terminal 14, the activation module 170 coordinates receipt of information corresponding to Patients A, B, C, and D, who are assigned to Nurse A, along with any additional tasks to be performed by Nurse A for those patients or in general. The activation module 170, or another data storage mechanism then stores the received information in memory. The activation module 170 also stores the authorized user's identification code in memory, such that data and instructions sent to the server 12 can be tagged with the user's identification for future use, for example, in record keeping. In one embodiment, the terminal 14 communicates with the server 12 using a hardwired connection during an activation procedure.
The microcontroller 82 further comprises a display module 172 configured to facilitate display of messages, text, and indicators on the display 72 via the display controller 104. The microcontroller 82 also comprises a user input module 174, configured to monitor and process user input received at the OK button 78 and a keypad if included on the terminal 14. The user input module 174 responds to the received input accordingly, for example, depending on the message being displayed on the display 72.
The microcontroller 82 may further comprise an indicator module 176 configured to control illumination of the Good Read and message indicator 74, via the user input and indicator controller 106. As discussed above, the indicators may include an LED configured for illumination, for example, to notify a user that the terminal 14 is awaiting acknowledgment of a message or has displayed a warning at the display 72. The indicator module 176 may also be configured to facilitate illumination of the Good Read indicator 74 when either of the scanners 80, 81 have scanned a new code. Where the terminal 14 includes an auditory indicator, the indicator module 176 is further configured to facilitate activation of the auditory indicator, such as a beep or buzz, as a warning or to indicate that a code has been properly or improperly read by one of the scanners 80, 81. The terminal 14 can include a plurality of auditory indicators, which can be downloaded, for example, from the server 12 via a hardwired or wireless connection.
The microcontroller 82 also includes a power management module 178 configured to monitor remaining battery power via the battery monitor and safety circuit 14, and to schedule low power or no power operation of terminal components to conserve power. The power management module 178 may also be configured to facilitate display of the amount of available power or status of the battery via an indicator as discussed above. The power management module 78 may be further configured to facilitate communication of this information to the server 12. In one embodiment, the microcontroller 82 further comprises an alarm and warning module 180, configured to detect alarm and warning conditions and generate alarm or warning messages for display at the display 72, or activation of the indicators.
In the terminal 14 based embodiment of the alert system described above, the terminal 14 can further be configured maintain an electronic record for each patient with respect to medication administration, including, but not limited to, type of medication, quantity of medication administered, how administered, and time of administration. The microcontroller 82 may generate an alert or notification message if a user of the terminal 14 fails to timely indicate administration of medication. A user of the terminal 14 may timely indicate administration of medication by, for example, reading the DOTs associated with the patient and the medication. The microcontroller 82 may include a scheduling module 182 configured to manage scheduled tasks such as medication administration times, to monitor user input indicating completion of scheduled tasks or rescheduling thereof, and user notification of scheduled tasks.
For example, a patient may be scheduled for administration of a particular medication at a predetermined time. The terminal 14, uses a schedule monitoring function at the scheduling module 182 to track an elapsed time after a predetermined medication administration time and may generate an alert or notification message if no indication of medication administration has occurred within a predetermined alert time. As with the server based system, the predetermined alert time may be, for example, 30 minutes or one hour after a scheduled administration time. Thus, the scheduling module 182 may monitor data entry for receipt of scan codes or symbols indicating administration of a medication or completion of a task, for example, which correspond to scheduled medication administrations or tasks. In the event the scheduling module 182 determines that the elapsed time following a scheduled medication administration exceeds some predetermined latency time, and no scan codes or symbols have been received to indicate completion of the scheduled medication administration, the scheduling module 182 facilitates activation of an indicator or display of an appropriate message at the display 72. The terminal 14 may continue to periodically display or sound the notification or alert until acknowledgement by the user of the terminal 14. The user of the terminal 14 may acknowledge the alert or notification by, for example, selecting the “OK” button 78 on the terminal 14 or by performing the process associated with the alert. The terminal 14 may present the alert on a display, using one or more indicators, audibly, or using some other way or some other combination of ways.
In one embodiment, the terminal 14 is configured to schedule notification for a follow-up task in response to an event such as administration of a medication or treatment. For example, in response to receipt of user input indicating administration of a medication, the scheduling module 182 schedules a follow-up visit notification or reminder for the user to visit the patient and perform an additional task. In one particular example, a nurse may administer a pain medication and input corresponding information into the terminal 14. In response to receipt of information regarding the administration of the pain medication, the scheduling module 182 schedules a notification for a predetermined time following administration of the medication, such as one hour. In addition, the notification may include instructions to perform an additional task or enter additional information, such as patient heart rate or a pain score provided by the patient. Subsequently, the terminal 14 notifies the user, upon lapse of the predetermined time, with instructions to visit the patient and perform a predetermined task or obtain and input predetermined information or data, such as a pain level either pre- or post administration of an analgesic medication.
One embodiment of a method 198 of operating the terminal 14 is illustrated in the flowchart of
If the scan code is determined to correspond to an expected type of data as determined in state 204, the terminal 14 determines whether to wait for additional data in a decision state 208. If the terminal 14 determines that it should wait for additional data in state 208, the wireless terminal waits to receive another scan code in state 201. For example, where a scan code corresponding to patient identification data was received in state 200, the terminal 14 would await additional data for the patient, such as the medication administered, dosage of medication, and note taking entries.
In the event the terminal 14 determines in decision state 208 that it should not wait for additional data, it proceeds to a state 210 to determine whether the scan code data corresponds to data stored in memory. For example, where the authorized medications for Patient A are stored in memory, the terminal 14 determines whether the scan code data corresponds to an approved medication for a designated patient as stored in memory. If the scan code data does not correspond to the data in memory, the terminal 14 generates a warning to the user in a state 212, indicating that a code corresponding to an incorrect medication has been scanned. The terminal 14 waits to receive another scan code in state 201. The process 198 then moves to decision state 215 to determine whether or not to display the warning to the user. If a warning is to be displayed, the process 198 moves to state 216 and displays the message at the display 72. If a determination is made at decision state 215 that no warning is to be displayed to the user, the process skips state 216 and terminates at an end state 217.
However, if the scan code data does correspond to an authorized medication in state 208, the wireless terminal transmits the scan code data to the server at the next communication session in state 214. Preferably, a plurality of scan codes or symbols are grouped together for transmission to the server, wherein a group comprises a patient identification code, a medication code, and a dosage. Depending on the type of medication administered, the group may also comprise a patient's vital sign such as temperature, method of administration such as oral or injection, and location of injection. Of course, embodiments of the invention are not limited to particular groupings of data for transmission to the server.
If the scan code is determined to correspond to an unexpected type of data as determined in state 204, the method 198 then moves to decision state 215 to determine if a message should be displayed to the user. There are several instances where the user should be provided with messages. For example, where the terminal 14 is being used to document and ensure accurate medication administration, the user first uses the wireless terminal to scan a code corresponding to a patient, such as a code on the patient's wristband. In response to such a code, the terminal 14 waits for additional data, and the user would proceed to scan a code on medication packaging. The wireless terminal 14 then uses the patient identification code to determine whether the code from the medication packaging is an authorized code for the patient according to the information stored in memory. In the event the scanned medication code corresponds to the authorized medication as stored in memory, the terminal 14 may display a message to indicate that the administration of the medication is authorized, dosage information, and administration information. The terminal 14 can also display a prompt to the user for entry of additional information, such as patient pulse and/or temperature. The user can enter such additional information, for example, by scanning codes or symbols corresponding to numerical digits with the terminal 14.
Following administration of a medication, a caregiver can use the terminal 14 for documentation or note taking. In particular, the user can document a reaction to a medication by scanning the appropriate code. For example, in the event a patient vomits after receiving medication, the user of the wireless terminal scans a code corresponding to the text “PATIENT VOMITED”. The terminal 14 recognizes that the code corresponds to documentation data and transmits it to the server 12 with the patient identification code during the next communication session.
Referring now back to decision state 202, if the terminal 14 determined that the received scan code corresponds to an instruction, the terminal 14 proceeds to a decision state 218. In decision state 218, the terminal 14 determines whether the instruction is to be performed by the terminal 14 or to be sent to the server 12. If the instruction is to be performed by the terminal 14, the wireless terminal executes the instruction in a state 220. The process 198 then moves to the decision state 215 to determine if a message should be displayed to the user.
If the instruction is to be sent to the server 12, the terminal 14 proceeds to a decision state 222 to determine whether the instruction is an immediate instruction, i.e. the instruction needs to be sent immediately and the terminal 14 should not wait for the next communication session. If the terminal 14 determines that the instruction is an immediate instruction in state 222, the terminal 14 transmits the instruction to the server 12 immediately in a state 224 and does not wait for the next communication session. If the wireless terminal determines that the instruction is not an immediate instruction in state 222, the terminal proceeds to a state 226 to transmit the instruction to the server 12 during the next scheduled communication session.
Thus, in one embodiment, the user of the terminal 14 scans a code corresponding to an instruction to print a report or order a laboratory test for a patient, sends a message or page, or requests information from a peripheral system connected to the server 12 by scanning the appropriate code(s) with the code scanners 80, 81. The terminal 14 then proceeds to transmit the instruction and any additional information, such as patient identification information, to the server 12 to initiate a procedure according to the instruction.
The terminal 14 can also initiate performance of an instruction, such as immediate request for assistance. For example, a user can scan a code on the wall in a patient room to request immediate assistance, wherein the code includes information regarding the location of the code as scanned. Such an instruction would be determined to be an immediate instruction in state 222 and would therefore be transmitted to the server 12 without waiting for the next communication session. In addition, the terminal 14 is configured to execute instructions or commands such as display medication data for a patient, or recall and display the last N scan code entries.
The terminal 14 or a server 12 can also communicate directly with a peripheral device, such as an intravenous pump, either via a wired or wireless connection. In the situation where the terminal 14 communicates directly with the peripheral device and bypasses the server 12, the logic existing on the server 12 for processing the communications can exist either on the terminal 14, the peripheral device or on any combination of the terminal 14 and the peripheral device.
Data input on the terminal 14 can be either by self-contained buttons and keys, by a wired input device such as a small keyboard, by a wireless input device such as a small wireless keyboard or by speech commands from the user.
One embodiment of a method of operation of the server 12 during a communication session with a wireless terminal is illustrated by the flowchart of
In one embodiment the terminal 14 communicates directly with a peripheral device, either via wireless or wireless means. In this situation, the data transmitting logic or similar logic existing on the server 12 will exist on the terminal, the peripheral device or a combination of both. Generally, after communicating directly with the peripheral device, the terminal 14 will pass the pertinent data to the server 12 for storage and retrieval. The passing of data to a server 14 can be accomplished either via wired or wireless connection and may occur in real-time, in near real-time or some time after the data is collected.
One embodiment of a method 290 of operation of the server 12 in response to receiving a scan code from a terminal 14 is illustrated in more detail in the flowchart of
If the scan code is determined to correspond to an instruction in state 302, the server proceeds to a state 306 to determine whether the instruction is to be performed by the server 12 or another device or system. If the instruction is to be performed by the server 12, the method proceeds to a state 308 wherein the server 12 executes the instruction. If the instruction is to be performed by a device or system other than the server 12, the server 12 proceeds to a state 310 to determine whether the instruction is to be performed by a peripheral device, such as the printer 20, or a system, such as the messaging system 22.
If the instruction is to be performed by a device, the server 12 proceeds to a state 312 where the process is initiated in the designated device according to the instruction by either sending the instruction directly to the device, or modifying and formatting the instruction and sending a formatted instruction to the designated device. Following initiation of the process in the designated device, the server 12 may query whether the instruction has been performed or completed in a state 314. If the instruction has not been performed, the server 12 can initiate the process in the designated device again by returning to state 312. If the instruction has been performed, the server 12 proceeds to an end state 316. In addition, the server 12 can send a message to the terminal 14 notifying the user that the process initiated in response to the received instruction has been completed. If the peripheral device designated to perform the instruction is not connected to the server 12, the instruction processing logic or similar logic existing on the server 12 will exist on the terminal 14, the peripheral device or a combination of both. Generally, after completing the instructions, the peripheral device or the terminal 14 will pass the pertinent data to the server 12 for storage and retrieval.
If the server 12 determines in state 310 that the instruction is to be performed by a system, the server 12 initiates the appropriate process in the designated system or sends the instruction to the system designated as part of the instruction. In a state 320, the server 12 queries the system as to whether the instruction has been performed. If the instruction has been performed, the server proceeds to an end state 322, and if the instruction has not been performed the server returns to state 318 and sends the instruction to the designated system again to be performed. Alternately, if the instruction is in the process of being performed, or is waiting to be performed, the server 12 will continue to query the system until the instruction has been performed. In addition, the server 12 can notify the user of the terminal 14 that sent the instruction that the instruction has been performed by sending a message to the terminal 14 for display.
One embodiment of a method of operation of the messaging module 70 in the server 12 is illustrated in the flowchart of
The system 10 is also capable of additional processes, such as billing or inventory control. For example, every item given or used by a patient in a hospital has a scan code applied to it or that corresponds to it in the system. When that item is used by or for the patient, the caregiver providing the item scans the patient ID code and the item code. Such information is then transmitted to a billing or record keeping system for future reference.
An additional capability of the system 10 may include entry of physician orders for patients, where a physician uses a terminal 14 to enter medication or medical care orders for a patient by scanning codes or symbols corresponding to the patient identification information, the medication to be administered, the dosage, and additional information regarding administration of the medication.
The Medication Worksheet 1200 comprises a number of fields supplying a variety of information. For example, the Medication Worksheet 1200 can include an assignment field 1210 that identifies the responsible user or nurse, applicable date, and applicable shift in terms of time. The Medication Worksheet 1200 can also include a patient field 1220 that identifies one or more patients, their corresponding medications, and scheduled administration times for the medications.
The Medication Worksheet 1200 can also include fields comprising scan codes or symbols that a user such as a nurse or authorized personnel are likely to use during their working shift, such as medication administration sites. In one embodiment, the fields include a “sites” field 1230, an “override” field 1240, a “keypad” field 1250, and an “other” field 1260.
The “sites” field 1230 can include one or more scan codes or symbols associated with one or more medication administration sites or methods. For example, a user can administer medication to a first patient in accordance with the schedule shown in the patient field 1220, wherein the user scans a first patient scan code 1222 associated with the first patient. The user can then indicate, by scanning the appropriate scan code, the site at which a first listed medication was administered. For example, the user may scan the “1. thigh” scan code 1232 to indicate that the first medication was administered via an injection to the left thigh. The terminal 14 would then transmit the information corresponding to the scan codes or symbols, such as patient information, medication, and location of medication administration, to the server 12. In response to receipt of the information from the terminal 14, the server 12 can then communicate the information to one or more modules or servers in the system, such as the patient record system 30.
The user can similarly scan a scan code in the “override” field 1240 to indicate a reason for overriding a scheduled administration of medication, such as “increased nausea”. The “keypad” field 1250 can be used to compose messages or enter data for transmission to a server 12, such as patient statistics including temperature. In
The “other” field 1260 can include other instructions or data entries not included in the previously described fields. For example, the “other” field 1260 may include a page scan code 1262 corresponding to an instruction to “page S. Felner RN”, or other designated personnel that may be currently on duty. In response to a user scanning the page scan code 1260, the terminal 14 sends an instruction to the server 12, and the server facilitates a page to the listed party. In addition, the user can compose a message that is used in the page using the scan codes or symbols in the “keypad” field 1250, or additional scan codes or symbols in the “other field 1260 corresponding to predefined messages, such as “patient requested consultation”.
It may be advantageous to implement the scan codes or symbols on the Medication Worksheet with DOTs to identify various inputs. Unlike a bar code, the DOTs and/or other one-dimensional or two-dimensional symbols consume a small area on a standard printed page and can be positioned adjacent one another, both horizontally as well as vertically. The two-dimensional nature of the dots allows the terminal 14 to isolate and selectively read dots that are positioned very close to one another.
The system 10 can similarly use DOTs and/or other one-dimensional or two-dimensional symbols to initially configure a terminal 14.
In one embodiment, the system administrator inputs a server address 1310 and network address 1320 to the server 12. The server address can be, for example, an IP address. The system administrator can, for example, identify one of a plurality of server addresses using a pull down menu, manual entry, automated process or some other method of identifying a server. Similarly, the system administrator can identify a network from one or more available networks using a pull down menu, manual entry, automated process or some other method of identifying a server 12.
The server 12 can then process the information entered by the system administrator and generate one or more configuration scan codes or symbols 1330 that can be used to configure the terminal 14. The one or more scan codes or symbols 1330 can include, for example, one or more DOTs and/or other one-dimensional or two-dimensional symbols that identify or dictate a configuration operation recognized by the terminal 14. One or more additional scan codes or symbols may also be used to identify the server address and network, as well as other communication protocol. In one embodiment, the one or more scan codes or symbols in the configuration report 1300 identify a Wired Equivalent Privacy (WEP) algorithm key that is used by the terminal 14 to provide security over a wireless communication channel.
In order to configure a terminal 14 using the configuration report 1300, a user can simply sequentially read each scan code or DOT and/or other one-dimensional or two-dimensional symbols in the configuration report with the terminal 14. The terminal 14 is configured once all of the dots in the configuration report 1300 have been read by the terminal 14.
The assembled scanner 1400 is illustrated in more detail in
Medications administered to patients are typically annotated on paper charts. These charts, called Medication Administration Records, or “MAR,” depict the treatments given by the nurse for each patient. However, it is difficult to correlate medicine administration data between different patients, or look for patterns of reactions between differing medicines when the MARs are stored on paper.
Embodiments, of this invention relate to a system and method for electronically collecting medication administration data at the point of care. This electronic data can be stored and used to determine exactly how drugs are being used at the point of care. In addition, that data can be matched with a variety of other factors, such as the a patient's sex, age, medical history, etc. in order to provide a more robust set of data to be later analyzed.
It should also be realized that pharmaceutical companies typically track their medicine shipments to distribution centers, but rarely have any access to how and where there medicine was actually used. Moreover, they typically have no access to the patient data regarding the health of the person both before and after administration of the medicine. The pharmaceutical company may know that a certain hospital purchased particular medicines, however, they do not know how the drugs were used once they were in possession of the hospital.
Accordingly, embodiments of the present invention provide a system and method that allows a pharmaceutical company to track and correlate the usage of their medicine with patient data. By using the handheld wireless scanner described above, the care provider automatically captures all medically relevant data into the system. Thus the handheld scanner provides a means for scanning identification codes or symbols. In some embodiments the handheld scanner also includes a processor and a data storage device connected to the processor. That data, regarding medicines administered, patient health, timing of administration, foods given to the patient, etc. can all be stored to a central database. For example, in some embodiments the handheld scanner can provide a means for storing the patient data and a drug identifier to a data storage device and a means for transmitting the patient data and the drug identifier to a server. The server provides a means for correlating the patient data (herein also known as “patient identifier” or “patient information”) and the drug identifier to determine correlations between patients and drugs. The server may serve as the central database or the server may transmit the patient data and the drug identifier and/or any correlations between the patient data and the drug identifier to the central database. The central database can then be mined with will known data analysis tools to determine if there are any correlations developing between a particular medicine, and the health of the patient. In some embodiments a handheld scanner also provides a means for receiving a time of administration of a drug into the handheld scanner.
Of course, it should be realized that this system can be in place at several hospitals or treatment centers, each of which are automatically feeding patient care data to the central database. In this manner, a pharmaceutical company can look for correlations between administrations of its medicines from a variety of locations. The ability to capture and correlate medication administration data at the time the drug or medication is administered to the patient offers a new level of refinement to the feedback process for improving health care.
Embodiments of the invention use a computer terminal at a point of care that records the drugs or medications administered to a patient or drug recipient. The terminal can be static at the point of care (a fixed computer in a patient's or drug recipient's room, for example). Alternatively, the terminal can be mobile at the point of care (a laptop or notebook computer either carried or moved about on a mobile platform). The terminal can also be a handheld device, as described above, that reads the medication administration data and then transfers that data to a data storage mechanism. The terminal can be a handheld device that first stores and then: transfers the medication administration data in real-time to a data storage mechanism. The terminal can also transfer drug administration data to a data storage mechanism via a wired network. The terminal can transfer drug administration data to a data storage mechanism via a wireless network. The terminal can transfer drug administration data to a data storage mechanism via removable media, i.e., CD, USB Storage Device, DVD, etc.
In one embodiment, the patient data and the drug administration data are captured at the point of care, in the patient's room, and then may be transferred to a data storage device either from the point of care or from another location. Drug administration data for each administered drug may include a National Drug Code (NDC), the dosage form, the active ingredients, the strength of the drug, the package size and type of the drug, the major drug class of the drug, an FDA approved application number of the drug, a drug manufacturer, a drug manufacturer lot number or other data unique to the drug manufacturer of the given drug. Further drug administration data might include the drug brand name, a drug formulary or an SIG code.
The patient data (data associated with a patient) may include the name, height, weight, sex, allergies, age, family medical history, eating history, smoking history, address, current medicine history, patient diagnosis, patient medical history, patient blood sugar levels before drug administration, patient blood sugar levels after drug administration, patient blood pressure before drug administration, patient blood pressure after drug administration, drug manufacturing data, drug dosage level, route of administration, hospital employee identification, attending doctor identification, hospital identification, time of administration or food ingested before drug administration or other factors from the patient.
Once a patient is identified in the system, a care giver can scan a bar code or other symbology on a medicine to be administered to the patient. That bar code or other symbology contains a unique medicine identifier in either a one dimensional and/or two dimensional code. The system may also identify the drug via a radio frequency device (i.e. an RFID tag). A care giver might also enter the drug label or input the physical properties of the drug into the system so that the system might recognize and identify the drug.
Patient information for a specific drug administration might include a patient name, a patient gender, patient birth date, patient age, patient diagnosis/ailment information, patient weight, patient medical history, a doctor name, a caregiver name (for example, a nurse, a phlebotomist, a technician, a hospital employee, etc.), a caregiver identification number, a doctor identification number, a date of drug administration, a time of drug administration, a dosage administered, a route of drug administration, a reason drug was given early with respect to a prescribed administration time, a reason drug was given late with respect to the prescribed administration time, a reason a specific drug administration was omitted with respect to the prescribed administration time, a patient apical pulse prior to administering a drug, a patient blood sugar level prior to administering a drug, a patient pain level prior to administering a drug, patient comments or statements prior to administering a drug, a patient condition as noted by the caregiver prior to administering the drug, a patient apical pulse after administering the drug, a patient blood sugar level after administering the drug, a patient pain level after administering the drug, patient comments or statements after administering the drug, a patient condition as noted by the caregiver after administering the drug.
Further illustrated in
The block diagram of
The hospital server 1706 is also connected electronically to a database 1718 within a pharmaceutical company 1720. The database 1718 can store the data from the data storage device 1708, or other databases, within the server 1706. This outside pharmaceutical company 1720 also contains a correlation module 1722 connected to the database 1718. As explained above, the correlation module 1722 is configured to determine correlations between patient populations and drugs using the patient identifiers 1710 in combination with the drug identifiers 1712. The correlations thus determined by the correlation module are presented through an output module 1724 to a user. The output module may include a terminal, printer or other output source.
As described above, the database 1718 may be include a correlation module configured to correlate the patient identifiers and medicine identifiers in order to determine correlations in that data. Among the data that can be provided to the database 1718 is an address of the facility providing the care/administering the drug to the patient or medicine recipient. The database 1718 that stores and correlates the drug administration data may also have the ability to create electronic reports, printed reports, and digital files for further analysis.
The system has the ability to store and use all of the data collected in a hospital from a patient or drug recipient's admission time to the patient or drug recipient's discharge time from the hospital. This allows the system to contain drug administration data relating to regional, or geographic, correlations in the prescription and administration of medicine to patients.
Various types of correlations may be found among the patient identifiers and the drug identifiers. These correlations might include, but are not limited to: identifying method of payment correlations (i.e., health insurance, Medicare, etc.) correlations in the prescription and administration of drugs; identifying drug cost correlations in the prescription and administration of drugs; identifying drug manufacturer correlations in the prescription and administration of drugs; identifying gender correlations in the prescription and administration of drugs; identifying age correlations in the prescription and administration of drugs; identifying diagnosis/ailment correlations in the prescription and administration of drugs; identifying individual physician correlations in the prescription and administration of drugs; identifying drug combination correlations in the prescription and administration of drugs; identifying drug reaction correlations in the prescription and administration of drugs; and identifying length-of-stay correlations based upon the prescription and administration of drugs.
The system, including the handheld terminal 14, may interface with systems supporting peripheral devices or directly with the peripheral devices either via the network or via direct wired or wireless connection from the handheld terminal. For example, the handheld terminal 14 may be used to accept and to store intravenous pump data or transfer data or instructions to the pump either via the network or via direct wired or wireless connection. The handheld terminal 14 may be used to display data that should be manually entered and verified on the intravenous pump. The handheld terminal 14 may also be used to identify the pump via electronic reading of a one-dimensional or two-dimensional symbol or via RFID or other means of identification. In a workflow involving a peripheral device such as an intravenous pump, the caregiver can use the handheld terminal 14 to identify the patient, the pump and to set the pump's medication administration settings, to prompt the caregiver to manually set the required medication data, and/or to verify the pump settings set.
In another embodiment, the system obtains specimen collection orders via wireless or wired connections to the network or directly to the laboratory information system. The caregiver uses a handheld terminal 14 to identify a patient. The handheld terminal 14 prompts the caregiver to collect a specimen in a preordained process, identifying individual containers by size, color, shape, etc. and by leading the caregiver through the collection process one step at a time. The handheld terminal 14 connects with a peripheral device such as a label printer either via the network or via a direct wired or wireless connection. The label printer uses this connection to print labels specific to the patient, the ordered test and the specific container containing the specimen while at the patient's side. The scanning of DOTs or other one-dimensional or two-dimensional symbols is used to enter observation or charting data. The system may also check to verify and validate the specimens prior to their evaluation.
It will be appreciated that the above-described system can be implemented in additional environments, such as nursing homes, etc. and is not limited to the health care industry. For example, implementation of the above system can also be advantageous in industries or environments where precise inventory tracking and workflow management.
The foregoing description details certain embodiments of the invention. It will be appreciated, however, that no matter how detailed the foregoing appears in text, the invention can be practiced in many ways. As is also stated above, it should be noted that the use of particular terminology when describing certain features or aspects of the invention should not be taken to imply that the terminology is being re-defined herein to be restricted to including any specific characteristics of the features or aspects of the invention with which that terminology is associated. The scope of the invention should therefore be construed in accordance with the appended claims and any equivalents thereof.
This application claims priority to U.S. Provisional Patent Application No. 60/743,758 entitled “ELECTRONIC DATA CAPTURE IN A MEDICAL WORKFLOW SYSTEM” filed on Mar. 24, 2006, which is hereby incorporated by referenced in its entirety.
Number | Date | Country | |
---|---|---|---|
60743758 | Mar 2006 | US |