WO1995000829A1 - Front end apparatus and method - Google Patents

Front end apparatus and method Download PDF

Info

Publication number
WO1995000829A1
WO1995000829A1 PCT/US1994/006940 US9406940W WO9500829A1 WO 1995000829 A1 WO1995000829 A1 WO 1995000829A1 US 9406940 W US9406940 W US 9406940W WO 9500829 A1 WO9500829 A1 WO 9500829A1
Authority
WO
WIPO (PCT)
Prior art keywords
tip
coupled
error
port
vessel
Prior art date
Application number
PCT/US1994/006940
Other languages
French (fr)
Inventor
Greg S. Clark
Russell A. Cooper
Scott R. Johnson
Dale A. Keiser
Original Assignee
Boehringer Mannheim Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Boehringer Mannheim Corporation filed Critical Boehringer Mannheim Corporation
Priority to EP94921977A priority Critical patent/EP0705424A4/en
Priority to JP7503013A priority patent/JPH08511871A/en
Publication of WO1995000829A1 publication Critical patent/WO1995000829A1/en

Links

Classifications

    • GPHYSICS
    • G01MEASURING; TESTING
    • G01NINVESTIGATING OR ANALYSING MATERIALS BY DETERMINING THEIR CHEMICAL OR PHYSICAL PROPERTIES
    • G01N35/00Automatic analysis not limited to methods or materials provided for in any single one of groups G01N1/00 - G01N33/00; Handling materials therefor
    • G01N35/10Devices for transferring samples or any liquids to, in, or from, the analysis apparatus, e.g. suction devices, injection devices
    • G01N35/1009Characterised by arrangements for controlling the aspiration or dispense of liquids
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B01PHYSICAL OR CHEMICAL PROCESSES OR APPARATUS IN GENERAL
    • B01LCHEMICAL OR PHYSICAL LABORATORY APPARATUS FOR GENERAL USE
    • B01L9/00Supporting devices; Holding devices
    • B01L9/06Test-tube stands; Test-tube holders
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01NINVESTIGATING OR ANALYSING MATERIALS BY DETERMINING THEIR CHEMICAL OR PHYSICAL PROPERTIES
    • G01N33/00Investigating or analysing materials by specific methods not covered by groups G01N1/00 - G01N31/00
    • G01N33/48Biological material, e.g. blood, urine; Haemocytometers
    • G01N33/483Physical analysis of biological material
    • G01N33/487Physical analysis of biological material of liquid biological material
    • G01N33/49Blood
    • G01N33/4905Determining clotting time of blood
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01NINVESTIGATING OR ANALYSING MATERIALS BY DETERMINING THEIR CHEMICAL OR PHYSICAL PROPERTIES
    • G01N35/00Automatic analysis not limited to methods or materials provided for in any single one of groups G01N1/00 - G01N33/00; Handling materials therefor
    • G01N35/02Automatic analysis not limited to methods or materials provided for in any single one of groups G01N1/00 - G01N33/00; Handling materials therefor using a plurality of sample containers moved by a conveyor system past one or more treatment or analysis stations
    • G01N35/026Automatic analysis not limited to methods or materials provided for in any single one of groups G01N1/00 - G01N33/00; Handling materials therefor using a plurality of sample containers moved by a conveyor system past one or more treatment or analysis stations having blocks or racks of reaction cells or cuvettes
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01NINVESTIGATING OR ANALYSING MATERIALS BY DETERMINING THEIR CHEMICAL OR PHYSICAL PROPERTIES
    • G01N11/00Investigating flow properties of materials, e.g. viscosity, plasticity; Analysing materials by determining flow properties
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01NINVESTIGATING OR ANALYSING MATERIALS BY DETERMINING THEIR CHEMICAL OR PHYSICAL PROPERTIES
    • G01N35/00Automatic analysis not limited to methods or materials provided for in any single one of groups G01N1/00 - G01N33/00; Handling materials therefor
    • G01N35/00584Control arrangements for automatic analysers
    • G01N35/00722Communications; Identification
    • G01N35/00732Identification of carriers, materials or components in automatic analysers
    • G01N2035/00742Type of codes
    • G01N2035/00752Type of codes bar codes
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01NINVESTIGATING OR ANALYSING MATERIALS BY DETERMINING THEIR CHEMICAL OR PHYSICAL PROPERTIES
    • G01N35/00Automatic analysis not limited to methods or materials provided for in any single one of groups G01N1/00 - G01N33/00; Handling materials therefor
    • G01N35/10Devices for transferring samples or any liquids to, in, or from, the analysis apparatus, e.g. suction devices, injection devices
    • G01N35/1009Characterised by arrangements for controlling the aspiration or dispense of liquids
    • G01N2035/1025Fluid level sensing
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01NINVESTIGATING OR ANALYSING MATERIALS BY DETERMINING THEIR CHEMICAL OR PHYSICAL PROPERTIES
    • G01N35/00Automatic analysis not limited to methods or materials provided for in any single one of groups G01N1/00 - G01N33/00; Handling materials therefor
    • G01N35/10Devices for transferring samples or any liquids to, in, or from, the analysis apparatus, e.g. suction devices, injection devices
    • G01N2035/1027General features of the devices
    • G01N2035/103General features of the devices using disposable tips

Landscapes

  • Health & Medical Sciences (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Chemical & Material Sciences (AREA)
  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Immunology (AREA)
  • Analytical Chemistry (AREA)
  • Biochemistry (AREA)
  • General Health & Medical Sciences (AREA)
  • General Physics & Mathematics (AREA)
  • Pathology (AREA)
  • Biomedical Technology (AREA)
  • Chemical Kinetics & Catalysis (AREA)
  • Hematology (AREA)
  • Clinical Laboratory Science (AREA)
  • Ecology (AREA)
  • Biophysics (AREA)
  • Molecular Biology (AREA)
  • Urology & Nephrology (AREA)
  • Food Science & Technology (AREA)
  • Medicinal Chemistry (AREA)
  • Automatic Analysis And Handling Materials Therefor (AREA)

Abstract

Air is supplied from an air supply through a disposable pipette tip (11). With no obstructions in the path from the supply through the tip, air will flow freely and little back pressure will be measured by a pressure transducer (12) located upstream from the tip in an air supply circuit. The tip is lowered toward the surface (16) of the liquid by a robotic arm (20). As the tip contacts the surface, the liquid blocks airflow and the pressure sensed by the transducer increases. This increase signals that the pipette tip has located the liquid level. The tip is lowered beneath the liquid level and a vacuum source is then coupled to the air supply circuit. The liquid is drawn onto the tip. The transducer measures a negative pressure. The measured pressure depends on air flow rate, liquid viscosity and a number of other secondary factors. If flow rate and these other factors are known, viscosity and change in viscosity can be measured. A clot or gel in the liquid at the tip produces a larger increase in the partial vacuum and hence the clot or gel is detected.

Description

FRONT END APPARATUS AND METHOD
Technical Field-Industrial Applicability
This invention relates to automated "front end" apparatus, that is, apparatus for pipette manipulation, sample collection and dispensing and the like in clinical laboratory systems.
Background Art Several types of automated front end apparatus are known. There are those illustrated and described in, for example, U.S. Patents: 4,794,085; 4,478,094; and, 4,780,833; European patent publications: 0,169,071; 0,273,128; and, 0,341,438; and, Patent Cooperation Treaty publication WO 91/16675. No representation is intended hereby, nor should any such representation be inferred, that this listing is a complete listing of the relevant prior art or identifies the most pertinent prior art.
Disclosure of Invention
According to an aspect of the invention, air is supplied from an air supply through a disposable pipette tip. With no obstructions in the path from the supply through the pipette tip, air will flow freely and little back pressure will be measured by a pressure transducer located upstream from the pipette tip in an air supply circuit. The tip is lowered toward the surface of a liquid by a robotic arm. As the pipette tip contacts the surface of the liquid, the liquid blocks airflow and the pressure sensed by the transducer increases. This increase signals that the pipette tip has located the liquid level. The pipette tip is lowered beneath the liquid level and a vacuum source is then coupled to the air supply circuit. The liquid is drawn into the pipette tip. The transducer measures a negative pressure (a partial vacuum) . The measured pressure depends on air flow rate, liquid viscosity and a number of other secondary factors. If flow rate and these other factors are known, viscosity and change in viscosity can be measured. A clot or gel in the liquid at the pipette tip produces a relatively larger increase in the partial vacuum and hence the clot or gel is detected. There are a number of factors such as pipette tip orifice diameter, liquid flow characteristics, wetting action, flow rates, robotic arm speed, and the like, which affect the processes and can be used to describe the processes more accurately.
Brief Description of Drawings
The invention may best be understood by referring to the following description and accompanying drawings which illustrate the invention. In the drawings:
Fig. 1 illustrates a fragmentary perspective view of a system constructed according to the present invention; Fig. 2 illustrates a block diagram of certain details of the system illustrated in Fig. 1;
Fig. 3 illustrates a sectional side elevational view of a detail of the system illustrated in Fig. 1;
Figs. 4a-4j illustrate in more detail and in block and schematic form certain details of the block diagram illustrated in Fig. 2;
Fig. 5 illustrates a fragmentary perspective view of the detail illustrated in Fig. 3, along with certain other related details of the system illustrated in Fig. 1; Fig. 6 illustrates the architecture and interaction of several software tasks for controlling a system constructed according to the present invention;
Figs. 7-11, 12a-b, 13, 14, 15a-b, 16a-b, 17-23, 24a-b, 25-41, 42a-b, 43-58, 59a-b, 60a-b, 61-70, 71a-b, 72a-b, 73a-b, 74a-b, 75, 76a-b, 77a-b, 78-80, 81a-b, 82-90, 91a-b, 92, 93, 94a-c, 95, 96a-b, 97a-b, 98a-b, 99a-b, 100, 101, 102a-b, 103a-b, 104, 105, 106a-c, 107, 108a-b, 109a-b, 110, 111, 112a-b, 113, 114, 115a-b, 116, 117, 118a-b, 119a-c, 120a-c, 121a-c, 122a-c, and 123-137 illustrate flowcharts and related diagrams useful in understanding the software tasks illustrated in Fig. 6;
Fig. 138 illustrates a top plan view of the system illustrated in Fig. 1;
Fig. 139 illustrates a top plan view of the detail illustrated in Fig. 3, along with certain other related details of the system illustrated in Fig. 1;
Fig. 140 illustrates a bottom plan view of a detail of the system illustrated in Fig. 1;
Fig. 141 illustrates a sectional side elevational view of a detail of the system illustrated in Fig. 1; Fig. 142 illustrates a top plan view of a detail of the system illustrated in Fig. 1; and.
Fig. 143 illustrates a sectional side elevational view of a detail of the system illustrated in Fig. 1.
Modes for Carrying Out the Invention
Referring now to Fig. 1, air is supplied from a syringe pump 10 through a disposable pipette tip 11. With no obstructions in the path from pump 10 through the pipette tip 11, air flows freely and little back pressure will be measured by a pressure transducer 12 (Fig. 2) located upstream from the pipette tip 11 in the syringe pump 10 circuit 14. Syringe pump 10 illustratively is a 39450 syringe pump available from Hamilton Company, P.O. Box 10030, Reno, NV 89520-0012. The tip 11 is lowered toward the surface 16 (Fig. 3) of a liquid 18 by an arm 20. As the pipette tip 11 contacts the surface 16 of the liquid 18, the liquid 18 blocks airflow and the pressure sensed by the transducer 12 increases. This increase signals that the pipette tip 11 has located the surface 16. The pipette tip 11 is then lowered beneath the surface 16 and the syringe pump 10 draws a partial vacuum in circuit 14. Liquid 18 is drawn into the pipette tip 11. The transducer 12 measures the partial vacuum. The measured partial vacuum depends on air flow rate through circuit 14, liquid 18 viscosity and a number of other secondary factors. If these factors are known, viscosity and change in viscosity can be measured. A clot or gel, illustrated in broken lines at 24, in the liquid 18 at the pipette tip 11 produces a relatively larger increase in the partial vacuum than the liquid 18 flow in the absence of the clot or gel 24 produces, and hence the clot or gel 24 is detected.
An electrical system useful for performing the method of the invention is illustrated in Figs. 2 and 4a-j. The following schematic and block circuit diagram descriptions identify specific integrated circuits and other components and in many cases specific sources for these. Specific terminal and pin names and numbers are generally given in connection with these for completeness. It is to be understood that these terminal and pin identifiers are provided for these specifically identified components. It is to be understood that this does not constitute a representation, nor should any such representation be inferred, that the specific components or sources are the only components available from the same or any other sources capable of performing the necessary functions. It is further to be understood that other suitable components available from the same or different sources may not use the same terminal/pin identifiers as those provided in this description. The system block diagram is illustrated in Fig.
2. The system comprises a master microcontroller (μC) 120 which interfaces through an RS232C interface 150 with a bar code reader 151, and with a personal computer 153 which controls a laboratory analytical instrument 155 such as the Boehringer Mannheim ES300 analyzer. A system analog-to- digital converter 70 provides input values from a force switch 71 through a resistance-to-voltage (R/V) converter 73, and from a vacuum/pressure transducer 12 to μC 120. Based upon these values, μC 120 controls a vent valve driver 132. μC 120 also controls an arm 20 R (angle) stepper motor 183 through R motor drivers 168, 172, 176, and an arm 20 Z (elevation) stepper motor 185 through Z motor drivers 170, 174 and 178, both through a first slave μC 160. Motion of the R and Z motors 183, 185, respectively, is confirmed through R and Z motor motion encoders whose motion signals are returned to the system through components 184-11, -13, -14 and 184-3, -15, -16, respectively. μC 120 also controls a specimen tube rack 300 (Fig. 5) shuttle 302 stepper motor 195 through shuttle motor drivers 198, 200 and 202, and a Y (radius) DC servomotor 197 through Y motor drivers 220 and 222, both through a second slave μC 190. Motion of the shuttle motor 195 is confirmed through a shuttle optical sensor 224. Motion of the Y motor 217 is confirmed through a Y motor motion encoder whose motion signals are returned to the system through components 234, 236. The second slave μC 190 also controls the syringe pump 10 through RS232 interface 150.
Referring now to Fig. 4a, the pressure transducer 12 of the system illustrated in Figs. 1-2 comprises a
Honeywell Microswitch Division type 176PC07 differential pressure transducer 12, pin 1 of which is coupled to the V, voltage supply, pin 3 of which is coupled to the system ground and pins 4.and 2 of which are coupled to the non- inverting (+) input terminals of two difference amplifiers 34, 36, respectively, of a National Semiconductor type LM324 quad difference amplifier. The inverting (-) input terminals of amplifiers 34, 36 are joined by a 10 KΩ resistor. The output terminals of amplifiers 34, 36 are coupled through respective 100 KΩ resistors to their - input terminals. The output terminals of amplifiers 34, 36 are also coupled through respective 100 KΩ resistors to the - and + input terminals, respectively, of an LM 324 difference amplifier 38. The output terminal of amplifier 38 is coupled through a parallel RC circuit including a 47 KΩ resistor and a .lμF capacitor to its - input terminal. Supply voltage is provided to the V5 terminal of transducer 12 from a +12VDC supply coupled to terminal 40-1 of a connector 40, a National Semiconductor type LM78L05 five volt regulator integrated circuit 42 and a type LM 324 difference amplifier 24. The +12VDC supply at terminal 40- 1 of connector 40 is coupled through a .lμF capacitor to ground and terminal 40-4 of connector 40. Terminal 40-1 is also coupled to the V, terminal of IC regulator 42. A .lμF capacitor is coupled across the V0 terminal of regulator 42 and ground. A 2.4 KΩ resistor is coupled between the V0 terminal of regulator 42 and the + input terminal of amplifier 44. The cathode of a National Semiconductor type LM 385-2.5V zener diode 46 is coupled to the + input terminal of amplifier 44, and its anode is coupled to ground. The output terminal of amplifier 44, in addition to being coupled to the Vs terminal of transducer 12, is coupled to ground through series 100 KΩ resistors 48, 50. The junction of resistors 48, 50 is coupled to the - input terminal of amplifier 44.
The circuit illustrated in Fig. 4a provides both low gain and high gain output signals. The high gain output signal, appearing at terminal 40-3 of connector 40, is provided from the output terminal of a type LM 324 difference amplifier 52 through a 10 KΩ resistor. The + input terminal of amplifier 52 is coupled through a 10 KΩ resistor to the anode of zener diode 46. The - input terminal of amplifier 52 is coupled through a 10 KΩ resistor to the output terminal of amplifier 38. The output terminal of amplifier 52 is coupled to its - input terminal through a parallel RC circuit including a 100 KΩ resistor and a .lμF capacitor. A circuit including the series string of a 100 KΩ resistor, a 10 KΩ potentiometer 54 and a 100 KΩ resistor is coupled between the output terminal of amplifier 44 and ground. The wiper of potentiometer 54 is coupled to the + input terminal of a type LM 324 difference amplifier 56 connected in unity gain buffer configuration. The output terminal of amplifier 56 is coupled through a 100 KΩ resistor to the + input terminal of amplifier 38. The output terminal of amplifier 38 is coupled through a 10 KΩ resistor to the low gain output terminal, terminal 40-2, of connector 40. The +5VDC level at the output terminal of amplifier 44 is coupled to the + input terminal of an LM 324 difference amplifier 58. +12VDC is coupled through a 10 KΩ resistor to the - input terminal of amplifier 58. The - input terminal of amplifier 58, the low gain terminal 40-2 of connector 40, and the high gain terminal 40-3 of connector 40 are coupled through respective 1N4148 diodes 60, 62, 64 to the output terminal of amplifier 58.
The low gain and high gain pressure signals from connector 40 are applied to an INput terminal 5 and an INput terminal 6, respectively, of a Microlinear type ML2258 analog-to-digital converter (A/D) 70 with multiplex capability (Fig. 4b) . Although both high gain (for liquid level sensing) and low gain (for liquid aspiration and dispensing) capabilities are provided, only the high gain input is used in the illustrated embodiment. Although some aspirate and dispense signals will saturate the high gain pressure transducer 12 output in this embodiment, the output will ultimately come out of saturation and return to a meaningful level. +35 VDC is coupled through series 69.8KΩ, 1% and 10KΩ resistors to ground. The junction of these two resistors is coupled to INput terminal 1 of A/D 70. +12VDC is coupled through series 30KΩ, 1% and 10KΩ resistors to ground. The junction of these two resistors is coupled to INput terminal 2 of A/D 70. System Vcc and +5VAccessory voltage supplies are coupled through respective series 10KΩ voltage dividers to ground and the junctions of the 10KΩ resistors in these voltage dividers are coupled respectively to INput terminals 3 and 4 of A/D 70.
+2.5VDC is coupled to the + input terminals of two LM324 difference amplifiers 76, 78. +2.5VDC is regulated by an LM385 2.5V zener diode 80 coupled across the + input terminals of amplifiers 76, 78 and ground. A .lμF capacitor is coupled in parallel with zener diode 80. A 2.4KΩ resistor is coupled from the + input terminals of amplifiers 76, 78 to Vcc. The output terminal of amplifier 76 is coupled to the base of a type 2N3944 NPN transistor 82. The collector of transistor 82 is coupled to +12VDC and its emitter is coupled to the Vcc and REF + terminals of A/D 70. Feedback is provided to the - input terminal of amplifier 76 from its output terminal through a .OOlμF capacitor, and from the emitter of transistor 82 through a 10KΩ resistor. A 10KΩ resistor is coupled between the - input terminal of amplifier 76 and ground.
The output terminal of amplifier 78 is coupled through a 10KΩ resistor to the base of a type 2N3904 NPN transistor 84. The collector of transistor 84 is coupled through a 10KΩ load resistor to +12VDC and its emitter is coupled through a 10KΩ feedback resistor to ground. The emitter of transistor 84 is coupled to the - input terminal of amplifier 78. The collector of transistor 84 is coupled to the + input terminal of an LM324 difference amplifier
86. The output terminal of amplifier 86 is coupled through a 10KΩ resistor to the base of a type 2N3906 PNP transistor 88. The emitter of transistor 88 is coupled directly to the - input terminal of amplifier 86 and to +12VDC through a 127K, 1% resistor. The collector of transistor 88 is coupled to the + input terminal of an LM324 difference amplifier 90 configured as a unity gain buffer.
A microεwitch (not shown) on the pipette chuck for signalling contact of the pipette tip 11 with, for example, the bottom of a tube or test cup, is coupled through a 10KΩ resistor across the input terminals of amplifier 90. A .OlμF capacitor is coupled across the + input terminal of amplifier 90 and ground. The output terminal of amplifier 90 is coupled through a 10KΩ resistor to INput terminal 7 of A/D 70. A 5.1 volt zener diode 92 protects INput terminal 7, and a 2.2μF, 16V tantalum capacitor is coupled across INput terminal 7 and ground. The Address 0 - Address 2 and Data Bus 0 - Data Bus 7 output terminals of A/D 70 are coupled to the A0-A2 and D0- D7 lines, respectively, of the system bus.
System reset is achieved through a reset circuit 93 including a manual reset button 94, one terminal of which is coupled to ground and the other terminal of which is coupled to the CLear input terminal of a type 74HC74 flip-flop 96. The Q input terminal of flip-flop 96 forms the HC74/Q line of the system bus. The Q output terminal of flip-flop 96 forms the X74Q line of the system bus. The MASTER/T1 line of the system bus is coupled to the CLocK input terminal of flip-flop 96. Reset can also be achieved by default. 10Hz clock signals are applied to the A input terminal of a type 74HC393 eight bit binary counter 100. The QC output terminal of counter 100 is coupled to the A input terminal of a 74HC393 counter 102 to configure the pair as a divide- by-32 counter, so that every 3.2 seconds a reset signal appears on the QD output terminal of counter 102. The 10Hz clock signals are provided at the output terminal of a type LM339 difference amplifier 105. The + input terminal of amplifier 105 is coupled to the junction of two 10KΩ resistors, the other terminal of one of which is coupled to Vcc and the other terminal of the other of which is coupled to ground. The - terminal of amplifier 105 is coupled through a 4.7μF tantalum capacitor to ground. Respective 10KΩ feedback resistors are coupled between the output terminal of amplifier 105 and its + and - input terminals. 5K resistance couples the output terminal of amplifier 105 to Vcc.
The QD output terminal of counter 102 is coupled through a 1N4148 diode to the - input terminal of an LM339 difference amplifier 104. A parallel RC circuit including a 1MΩ resistor and a .lμF capacitor is coupled across the - input terminal of amplifier 104 and ground. The + input terminal of amplifier 104 is coupled to +2.5VDC. Its output terminal is coupled through a 1MΩ pull-up resistor to Vcc and through a 2.2μF, 16V tantalum capacitor to ground. The output terminal of amplifier 104 is also coupled through a 1N4148 diode 106 to the normally ungrounded terminal of reset button 94. The anode of diode 106 is also coupled to the - input terminal of an LM339 difference amplifier 108. The cathode of diode 106 is also coupled to the output terminal of an LM339 difference amplifier 110. The + input terminal of amplifier 108 is coupled through a 100KΩ resistor to +2.5VDC. Its output terminal is coupled through a 1MΩ feedback resistor to its + input terminal. The - input terminal of amplifier 110 ir coupled to +2.5VDC. The + input terminal of amplifier 110 is coupled through a 10KΩ, 1% resistor to +12VDC and through a 3.74KΩ, 1% resistor to ground.
The output terminal of amplifier 108 is coupled through a 10KΩ pull-up resistor to Vcc and forms the Master RESET signal source for the system. It is also coupled through a series 1MΩ resistor 114 and .lμF capacitor 116 to the MASTER/T1 line of the system bus. The MASTER/T1 line is pulled up to Vcc through a 10KΩ resistor. The junction of resistor 114 and capacitor 116 is coupled to the CLeaR input terminals of counters 100, 102.
An Intel 8032 8 bit master microcontroller (μC) 120 (Fig. 4c) handles, via interface 150, all communication with the personal computer 153 which operates the laboratory instrument 155. μC 120 also utilizes an RS232 bidirectional interface to control the system's bar code reader 151. The two additional slave μCs 160, 190 are controlled by μC 120 via bidirectional communication. The force sensor 71, 73, pressure transducer 12 and vent valve driver 132 are also monitored by μC 120. Liquid levels and clots are detected by μC 120 through A/D converter 70 from pressure transducer 12. More specifically, liquid level is detected by execution by μC 120 of the following steps. The vent valve driver 132 opens the vent valve and syringe pump 10 aspirates air. Vent valve driver 132 then closes the vent valve and syringe pump 10 expels air as the pipette tip 11 is lowered toward the sample surface 16. The pressure increases slightly when tip 11 reaches the sample surface 16. The arm 20 stops moving in response to this slight increase in pressure. Vent valve driver 132 opens the vent valve and the air remaining in the syringe pump is expelled. Vent valve driver 132 then closes the vent valve, the arm 20 is lowered below the surface 16, lowering the tip 11 an amount determined by the volume of the sample to be aspirated, and the sample is aspirated. Clots are detected by the presence of abnormally low negative pressure (abnormally high vacuum) during sample aspiration. μC 120 has its PO.O - P0.7 terminals coupled respectively to the D0-D7 lines of the system bus. Its P1.0-P1.7 terminals are coupled to the Master Input/Output REQuest 1, Master BUSY 1, MI0REQ2, and MBUSY2 lines of the system bus, the input terminal of a Sprague type UDN2508 high line driver inverter 122, the input terminal of a Sprague type ULN2003 low line driver inverter 124, the MP1.6 line of the system bus, and a terminal 126-1 of a debugging connector 126, respectively. Series 10KΩ resistors 128, 130 couple the input terminals of inverters 122, 124 and the junction of resistors 128, 130 is maintained at Vcc. The output terminal of inverter 122 is coupled to the input terminal of a type ULN2003 inverter 132, the output terminal of which sinks current through a vent valve operating solenoid (not shown) coupled to a terminal 134-2 of a connector 134. Terminal 134-1 of connector 134 is coupled to +12VDC and a 1N4148 flyback diode is coupled across terminals 1, 2 of connector 134. The output terminal of inverter 124 sinks current from +12VDC through a 1KΩ resistor and a red status indicator LED (not shown) coupled across terminals 136-3, 136-4 of a connector 136. The output terminal of a type ULN2003 inverter 138 sinks current from +12VDC through a 1KΩ resistor and a green status indicator LED (not shown) coupled across terminals 136-1, 136-2 of connector 136. An Atmel EEPROM 140 has its A0-A12 and D0-D7 terminals coupled to the system bus A0-A12 and D0-D7 lines, respectively. The CE and OE terminals of EEPROM 140 are coupled to the MCS0 and ReaD lines, respectively, of the system bus. The WriteEnable terminal of EEPROM 140 is coupled to one terminal of an EEPROM enable slide switch 141, the other terminal of which is coupled to the WR terminal of μC 120. The WE terminal of EEPROM 140 is also coupled to Vcc through a 10KΩ pull-up resistor. A Waferscale, Inc, type PSD311 microcontroller interface 142 has its PA0-PA7 and AD8/A8-AD15/A15 terminals coupled to the system bus A0-A15 lines, respectively, and its AD0/A0- AD7/A7 terminals coupled to the system bus D0-D7 lines, respectively. The ReaD, WritE, Program Store ENable, and Address Latch Enable/P" terminals of μC 120 are coupled to the ReaD, WRite VPP, PSEN, and Address Latch Enable terminals, respectively of μC interface 142. The PB0-PB7, A16/CS8-A18/CS10, and A19/CSI terminals of μC interface 142 are coupled to the MCS0-MCS10 lines, respectively, of the system bus. The TXD, RXD INTerrupt 1, TO and TI terminals of μC 120 are coupled to the Master Transmit, Master
ReCeiVe, BARCODE, BUSY and MASTER/T1 lines, respectively, of the system bus. The RESET terminals of μC120 and μC interface 142 are coupled to the system RESET line. The INTerrupt 0 terminal of μC 120 is coupled to the IWT terminal of a Standard Microsystems 81C17 universal asynchronous receiver-transmitter (UART) 144.
The XI Terminal of μC 120 is coupled to the OUTput terminal of an ECS, Inc., type OECS-110.5-1-AlOlA 11.0592 MHz five volt clock oscillator 146. This terminal forms the CLOCK terminal of the system bus. The OUTput terminal of an ECS, Inc., type OECS-51-1-A101A 5.0688 MHz five volt clock oscillator 148 (Fig. 4d) forms the CLocK terminal of the system bus. The D0-D7 lines of the system bus are coupled to the D0-D7 lines, respectively, of UART
144. The WRite, ReaD, RS, ChipSelect and CLocK terminals of
UART 144 are coupled to the WR, RD, AO, MasterChipSelectl and CLK lines of the system bus. The 10 terminal of UART 144 is coupled to the HC74/Q line of the system bus. The TX and RX terminals of UART 144 are coupled to the TUN and R10UT terminals, respectively, of a Maxim type MAX238 RS232 driver 150 with on-board +5VDC-to-+and-l2VDC supplies. The T2IN, R20UT, T3IN and R30UT terminals of driver 150 are coupled to the MTX, MRCV, Slave 2 Transmit and Slave 2 ReCeiVe lines, respectively, of the system bus. Respective 4.7μF, 25V capacitors are coupled across the C1+ and Cl- terminals, the C2+ and C2- terminals, the V+ and Vcc terminals, and ground and the V- terminal of driver 150. Signals to and from a bar code reader 151 coupled across terminals 152-1 and 152-2 of a connector 152 are transmitted on Bar Code Transmit 1 and received on Bar Code Receive 1 at terminals T10UT and RUN, respectively, of driver 150. Bar code reader 151 illustratively is an LS- 20-I0024A bar code reader available from Symbol
Technologies, Inc., 116.T Wilbur Place, Bohemia, NY 11716- 3300. Bar code reader 151 is controlled by μC 120 through the RS232 bidirectional interface 150.
All communication with the PC 153 which controls the operation of the Boehringer Mannheim ES 300 analyzer 155 to which the illustrated system is attached passes through the T20UT-R2IN serial data port and connector terminals 154-1 and 154-2, respectively, of which T20UT and R2IN of driver 150 are coupled. The syringe pump 10 of the system is driven through connector terminals 156-1 and 156- 2 which are coupled respectively to terminals T30UT and R3IN of driver 150.
Control of the angle R through which the pipette tip-carrying arm 20 is swept from its 0° home position and the elevation Z of the tip 11 carried by arm 20 above the work surface is effected through a first Intel 8032 slave μC 160 and Waferscale, Inc., PSD311 μC interface 162. See Fig. 4e. μC 160 monitors and controls the R-drive utilizing a half-step driver 168, 172, 176 and motor 183 for movement and an encoder coupled to connectors 184-11, - 13 and -14 for position feedback. μC 160 also controls the Z-drive utilizing a half-step driver 170, 174, 178 and motor 185 for movement and an encoder coupled to connectors 184-3, -15 and -16 for position feedback. The home, or reference, position for the arm 20 is set by R and Z limit switches coupled to connectors 182-11 and 182-3, respectively.
The PB0-PB7 and A16/CS8-A18/CS10 terminals of μC interface 162 are coupled to the S1CS0-S1CS10 lines, respectively, of the system bus. The AD0/A0—AD7/A7 terminals of μC interface 162 are coupled to the S1D0-S1D7 lines respectively, of the system bus. The AD8/A8— AD15/A15 terminals of μC interface 162 are coupled to the S1A8-S1A15 lines, respectively, of the system bus. The P0.0-P0.7 terminals of μC 160 are coupled to the S1D0-S1D7 lines, respectively, of the system bus. The P2.0-P2.7 terminals of μC 160 are coupled to the S1A8-S1A15 lines, respectively, of the system bus. The RD terminals of μC 160 and μC interface 162 are coupled together. The WR terminal of μC 160 is coupled to the WR VPP terminal of μC interface 162. The PSEN terminal of μC 160 is coupled to the PSEN terminal of μC interface 162. The Address Latch
Enable/P" terminal of μC 160 is coupled to the ALE terminal of μC interface 162. The TXD terminal of μC 160 is coupled to a terminal 164-1 of a connector 164 which is used in debugging the system. Terminal 164-2 of connector 164 is coupled to ground. Terminal XI of μC 160 is coupled to the system CLOCK line. The INTerrupt 0, INTerrupt 1, TO and TI terminals of μC 160 are coupled to the system MIOREQ1, XRZ/INTerrupt, XDZ2 and XDZ1 lines, respectively. The P1.0-P1.7 terminals of μC 160 are coupled to the system
MBUSY1, RLIMIT, ZLIMIT, RSTEP0, ZSTEP0, RZENable, XDR1 and XDR2 lines, respectively. The RXD terminal of μC 160 is coupled to the system RZDIRection line. The RESET terminals of μC 160 and μC interface 162 are coupled to the system RESET line.
Referring to Fig. 4f, the system RSTEP0, ZSTEP0, RZEN and RZDIR lines control the R and Z stepper drive motors through type UDN2508 inverters 168, 170, 172, 174, 176 and 178. The RSTEP0 line is coupled to the input terminal of inverter 168. The ZSTEP0 line is coupled to the input terminal of inverter 170. The RZEN line is coupled to the input terminals of inverters 172, 174. The RZDIR line is coupled to the input terminals of inverters 176, 178. The RSTEP, ZSTEP, RENable, ZENable, RDIRection and ZDIRection control signals to the R and Z stepper motors appear at the output terminals of inverters 168, 170, 172, 174, 176 and 178, respectively. These signals are conveyed through terminals 180-7, 180-3, 180-5, 180-1, 180-8 and 180-4, respectively, of a connector 180 to the R and Z stepper motors.
Signals indicating R and Z stepper motor activity are returned through a connector 182 to the system. The force sensor signal applied to amplifier 90 appears across terminals 182-1 and 182-2. The RLIMIT signal appears across terminal 182-11 and ground, which is provided at terminals 182-19 and 20. The ZLIMIT signal appears across terminal 182-3 and ground. The RI, R2, Zl and Z2 signals appear across terminals 13-16, respectively, and ground. +12VDC is supplied to the R and Z stepper motor sensor circuits from terminals 182-17 and 18. Respective 100KΩ pull-up resistors are coupled between terminals 182-11 and 182-3 and Vcc. Respective 100KΩ pull-down resistors are coupled between terminals 182-13—16 and ground.
Respective 100KΩ resistors are coupled between terminals 182-11, 3, and 13—16 and the input terminals of respective 74HC14 inverters 184-11, 3 and 13—16. Respective .OOlμF capacitors are coupled between the input terminals of inverters 184-11, 3 and 13—16 and ground. The output terminals of inverters 184-11, 3 and 13—16 are coupled to the system RLIMIT, ZLIMIT, XRl, XR2, XZ1 and XZ2 lines, respectively.
A second Intel type 8032FA slave μC 190 and associated Waferscale, Inc. , type PSD 311 μC interface 192 (Fig. 4g) control the Y-axis movement of the pipette 11 radially inwardly and radially outwardly along the arm 20. μC 190 and its associated interface 192 also control the movement of the shuttle 302 which sequentially transports the tube racks 300 into position for removal of specimens from the respective test tubes 304-1—304-10 carried by them for analysis by the ES300 analyzer 155 to which the illustrative system is attached. μC 190 monitors and controls shuttle motor drivers 198, 200, 202 and Y motor drivers 220, 222. The P0.0-P0.7 terminals of μC 190 and the AD0/A0-AD7/A7 terminals of μC interface 192 are coupled to the system bus S2D0-S2D7 lines, respectively. The P2.0- P2.7 terminals of μC 190 and the AD8/A8-AD15/A15 terminals of μC interface 192 are coupled to the system S2A8-S2A15 lines, respectively. The RD and RD terminals, the WR and
WR VPP terminals, the PSEN and PSEN terminals, and the Address Latch Enable/P~ and ALE terminals, of μC 190 and μC interface 192, respectively, are coupled respectively to each other. The PA0-PA5 terminals of μC interface 192 are coupled, respectively, to the system XPoWeRDoWn 1,
XPoWeRDoWn 2, XDONE 1, XDONE 2, XRESET 1 and XRESET 2 lines. XDONE 1 and XDONE 2 and terminal PA6 of μC interface 192 are coupled through respective 10KΩ pull-up resistors to Vcc. Terminal PA6 is also coupled to the input terminal of a 74HC14 inverter 194, the output terminal of which is coupled to the input terminal of a 74HC14 inverter 196. The output terminal of inverter 196 provides the system RESET signal. The PB0-PB7 and A16/CS8-A18/CS10 terminals of μC interface 192 are coupled to the system S2CS0-S2CS10 lines, respectively. The RESET terminals of μC 190 and μC interface 192 are coupled to the system M RESET line.
The TXD and RXD terminals of μC 190 are coupled to the system S2TX and S2RCV lines, respectively. The XI terminal of μC 190 is coupled to the system CLOCK line. The INTerrupt 0, INT1, TO and TI terminals of μC 190 are coupled to the system MIOREQ2, XYIT, XDY1 and XDY2 lines, respectively. The P1.0-P1.4 terminals of μC 190 are coupled to the system MBUSY2, BARCODE, YENable, YCounterClockwise and YClockWise lines, respectively. The P1.2-P1.7 terminals of μC 190 are coupled through respective 10KΩ pull-up resistors to Vcc. Terminals P1.5-P1.7 are also coupled to the input terminals of respective type ULN2003 inverters 198, 200, 202. Terminal PI.7 is also coupled to a terminal 206-1 of a connector 206. Terminal 206-2 of connector 206 is coupled to ground. Connector 206 is used in system debugging. The output terminals of inverters 198, 200, and 202 supply the system SHuttle STEP, SHuttle ReSeT and SHuttle DIRection signals, respectively.
The firmware imbedded in the EPROMS of μC interfaces 142, 162 and 192 is described in detail in Appendix A hereto.
The YEN terminal of μC 190 is coupled to the - input terminal of a type LM339 difference amplifier 208. See Fig. 4h. The series combination of a 10KΩ resistor 210, a 6.8KΩ resistor 212 and a 2.4KΩ resistor 214 is coupled between V and ground. The approximately +2.4VDC level at the junction of resistors 210, 212 is coupled to the + input terminal of amplifier 208. The approximately + .625VDC level at the junction of resistors 212, 214 provides TTL thresholds to the + input terminals of two type LM 339 difference amplifiers 216, 218. The output terminal of amplifier 208 is coupled directly to an input terminal, pin 1, of an SGS type L293E bridge driver amplifier 220 and through a 10KΩ pull-up resistor to Vcc. An input terminal, pin 2, of amplifier 220 is coupled to the system XYCW line. An output terminal, pin 3, of amplifier 220 provides the signal to the system YDRIVECW line. An output terminal, pin 4, of amplifier 220 is coupled through a 10KΩ resistor to the - input terminal of amplifier 216 and through a 3.3Ω resistor to ground. A .lμF capacitor is coupled across the - input terminal of amplifier 216 and ground. The system XYCCW line is coupled to an input terminal, pin 9, of a type L239E amplifier 222. An output terminal, pin 8, of amplifier 222 provides the signal to the system YDRIVECCW line. Respective 1N4148 diodes are coupled between ground and the output terminals, pins 3 and 8 respectively, of amplifiers 220, 222 and between these terminals and +7VDC to clamp the voltages on these terminals between - .6V and +7.6V.
An output terminal, pin 7, of amplifier 222 is coupled through a 10KΩ resistor to the - input terminal of amplifier 218 and through a 3.3Ω resistor to ground. A .lμF capacitor is coupled across the - input terminal of amplifier 218 and ground. The output terminals of amplifiers 216, 218 are coupled through respective 10KΩ pull-up resistors to Vcc. These terminals provide the
XYLIMIN signal and XYLIMOUT signal, respectively, to the system.
The tube racks 300 each support up to ten test tubes 304-1—304-10 carrying specimens to be analyzed by the ES300 analyzer 155 to the front end of which the system of the present invention is coupled. The locations of tube racks are initially established during set-up of a particular system and are thereafter detected by optical detector 223-R, such as a Motorola type H22B1 slotted opto switch. The outputs of optical detector 223-R as well as optical detectors 223-1—223-10 which predict the positions of tubes 304-1—304-10 in a respective tube rack 300, enter the system of the present invention through a connector 224 (Fig. 4i) , terminals 224-1 and 224-2 of which supply +12VDC to the tube rack and tube position indicating apparatus 225 coupled to connector 224. Terminals 224-13—224-3 return from optical detectors 223-R and 223-1—223-10 signals indicating the locations of the tube racks and tubes in the tube racks. These signals are coupled to the junctions of respective 100KΩ resistors 226-13—226-3 and 228-12—228-3. The remaining terminals of resistors 226-13—226-3 are coupled to ground. The remaining terminals of resistors 228-13—228-3 are coupled to the input terminals of respective 74HC14 inverting amplifiers 230-13—230-3. The input terminals of inverters 230-13—230-3 are also coupled through respective .OOlμF capacitors to ground. The output terminals of inverters 230-13—230-3 are coupled to the system XRACK and XTUBE 1—XTUBE 10 lines, respectively. The Y drive motor includes a position encoder having two output terminals which provide signals identified in the system as YENCODERA and YENCODERB. See Fig. 4h. The YENCODERA signal line is coupled to ground through a 100KΩ resistor and to the input terminal of a type 74HC14 inverter 234 through a 100KΩ resistor. A lOOpF capacitor is coupled across the input terminal of inverter 234 and ground. The YENCODERB signal line is coupled to ground through a 100KΩ resistor and to the input terminal of a type 74HC14 inverter 236 through 1 100KΩ resistor. A lOOpF capacitor is coupled across the input terminal of inverter 236 and ground.
Two Xylinx, Inc., type XC2018-50PC84C programmable gate arrays 241, 242 are coupled as illustrated in Fig. 4j to the system lines. Pin numbers for gate arrays 241, 242 and system line names are as illustrated. μC 160 is controlled by μC 120 through the system bus and programmable gate array 241. μC 190 is controlled by μC 120 through the system bus and programmable gate array 242. μC 190 programs the gate arrays 241, 242 when the system is initialized.
System power is provided through a connector 244 across terminals 244-1 and 244-2 of which 13VAC is maintained. See Fig. 4h. A full wave bridge rectifier 246 comprising four type 1N5400 diodes 246-1—246-4 is coupled across terminals 244-1 and 2. 3300μF of capacitance 248 with a working voltage of 25V is coupled across bridge 246. +12VDC is supplied across capacitance 248. The +5VDC and Vcc supplies are provided by National Semiconductor type LM7805 five volt regulators 250, 252, the V, and ground terminals of which are coupled across capacitance 248. lμF tantalum capacitors are coupled across the V0 and ground terminals of regulators 250, 252. +5ENCoder voltage is provided by a Motorola 78L05 voltage regulator 254, the V, and ground terminals of which are coupled across capacitance 248 and the V0 terminal of which is coupled to the system YENCODER +5V line. A lμF tantalum capacitor is coupled across the V0 and ground terminals of regulator 254. +7VDC is provided by a Motorola type LM317 programmable voltage regulator 256, the Vm terminal of which is coupled to +12VDC. A 2KΩ resistor is coupled between the ADJust terminal of regulator 256 and ground. A 332Ω resistor is coupled across the ADJ and Vouτ terminals of regulator 256. lμF tantalum capacitors are coupled across the V^ terminal of regulator 256 and ground and across the Vouτ terminal of regulator 256 and ground.
A Lytron 1430 seven segment display 270 is provided for system diagnostic purposes. See Fig. 4f. Each of the seven segment terminals is coupled through a respective 1KΩ resistor to the output terminal of a respective type ULN2003 inverter 272-1—272-7. The DisPlay reset terminal of display 270 is coupled through a 1KΩ resistor to the output terminal of a type ULN2003 inverter 272-8. The input terminals of inverters 272-1—272-7 are coupled, respectively, to the system XLD0-XLD6 lines. The input terminal of inverter 272-8 is coupled to the output terminal of a type 74HC14 inverter, the input terminal of which is coupled to the system M RESET line. In the following descriptions of the flow charts of the software that runs the system, ALCO is the acronym for the software task responsible for sending command to the system, and returning any responses. ALER is the acronym for the system software error correction task. ALPR is the acronym for the system's main software control task. CAAL is the acronym for the software task responsible for the internal calibration of the system. INAL is the acronym for the software task responsible for initialization and end-of-load sequence. TIPS is the acronym for the software task responsible for finding a pipette tip 11 in a tip rack and installing the thus- located tip 11 on the pipette chuck. These software tasks are all in the PC 153 and control the system, sometimes referred to in the flow diagrams as an Autoloader system. The language of this software is C. TWIN is the acronym for the software in the PC 153 that controls the ES300 analyzer 155. TWIN is written in a combination of C and ZIM languages.
During a pipette sequence, all of the samples which are on the shuttle, and have been marked for use in the current analytical run, will be moved from the primary tubes in the various racks to respective sample cups on the ES300 analyzer's sample rotor. During a scanning sequence, the shuttle is moved through one complete cycle, so that the entire contents of the shuttle can be read by the barcode reader 151, and stored in the PC 153's database. The shuttle transports up to fifteen tube racks at a time for scanning and pipetting operations. The system uses the syringe pump 10 to aspirate samples from the primary tubes carried in the tube racks, and to dispense those samples into the sample cups. A tip rack holds disposable pipette tips 11 that are installed on a pipette chuck supported on the robotic arm 20. Two racks of ninety-six tips 11 each can be placed on the system at once. A tube racks holds ten primary tubes, and can be placed on the shuttle for loading of sample cups from the tubes carried by the tube rack.
Fig. 6 illustrates the relationships among the six specialized tasks that are responsible for controlling the system hardware. Each task is a separate program written in C and communications among different tasks use the QNX message passing facility. The main control task is ALPR. This task is responsible for managing the scanning and pipetting operations. The commands required to perform an operation are passed to ALCO which is almost a direct copy of the existing TWIN task RUCO, and is responsible for direct communication with the system hardware. If an error occurs during command processing, ALER, another task, is given control so that the error can be repaired or reported back to ALPR. One task, TIPS, is specialized only for the installation of pipette tips 11 onto the chuck on the system arm. INAL is responsible for initialization of the system and for moving the system into a rest position when it is not in use. CAAL is invoked for performing calibration operation for service. CAAL is not used in normal operation, and can only be accessed by service personnel. CAAL is started by ZIM code, performs its operations, and is then removed from memory. The ZIM code communicates with ALPR through the task ALSC which provides a convenient interface between the C and ZIM codes. The following discussion details the various modules which make up each task.
ALPR is the central administrative task for system operations. ZIM code can send QNX messages to ALPR to begin major operations, such as scanning the entire shuttle, or pipetting from all of the primary tubes. Once started, ALPR is assumed to be fully capable of completing the desired operation without assistance from ZIM code. ALPR does use ZIM PLI functions to gain access to entity sets. ALPR is the task that initiates communication between the tasks INAL and ALER. ALPR does not communicate with TIPS or CALL. Like all other system tasks, ALPR communicates with ALCO.
The main functions of ALPR are scanning and pipetting. ALPR also has other important functions, such as permitting service commands to be sent directly to the system. Figs. 7a-b illustrate a flowchart of the overall operation of ALPR. Each individual ALPR message option has its own flowchart and description of operation. Figs. 8a-b illustrate the messages supported by ALPR and processed by main() .
When the SCAN_ALL_TUBES message is received, ALPR changes from WAIT_STAT mode to SCAN mode. Figs. 9a-b illustrate how this is done. Before a shuttle scan can be performed, the system must be initialized. A check is made to see if initialization is required. If there are errors, the mode will revert back to WAIT_STAT. Otherwise, ALSW will indicate that a shuttle scan is in progress. During the scan, messages that would stop the scan before it is completed can still be received by ALPR.
Once scan mode is entered, ALPR main() loop, scan mode will administer the functions that read shuttle rack and tube barcodes. Figs. lOa-b and lla-b illustrate the scan flowcharts. If an unrepairable SYSTEM or FATAL system error occurs, the mode will be changed from SCAN to WAIT_STAT. This will terminate the scan. If an irreparable NON_FATAL error occurs, the sample will be skipped, but the scan will not be terminated. During the scan, the tube rack number, tube position, and tube barcode (patient sample I.D.) are added to ALPO. ZIM code monitors ALPO and removes the data as it is needed. Once the entire shuttle has been scanned, the mode is set to WAIT_STAT, and the scan terminates.
If an ALPR main () loop, PIPETTE message is received by ALPR, the flowchart illustrated in Figs. 12a-c will be executed. If needed, the system will be initialized first, and then the ES300 analyzer 155. If initialization is successful, pipetting operations will begin, starting with the pipette tip 11 in the number 1 location in tip rack 1. This will ensure that if the user has replenished the tip 11 supply, the run will begin with the first tip 11, instead of continuing from where the last run concluded.
After initialization, the main loop in ALPR will execute the flowcharts in Figs. 13a-b and 14a-b repeatedly with every pass through the main loop. During pipetting, ALPR can still receive messages. Until the end of the shuttle is reached, barcode data from the system, and sample data from SAMP, is passed to get_action() to determine if a sample can be pipetted. When the entire shuttle has been checked, ALPR_stat is set to WAIT_STAT, which terminates pipetting. If there is a serious enough error, pipetting will be stopped and the error will be recorded in ALSW. Minor errors will cause an individual sample to be skipped, but will not interfere with pipetting of the rest of the samples.
If get_action() determines that a sample can be pipetted, transfer_manager() is used to administer the fluid transfer from the primary tube to the sample rotor on the ES300 analyzer 155. Inside transfer_manager() ,
Pip_status in SAMP is set to *E' in case a power failure interrupts pipetting. When power is restored, the ΛE" marks the sample. If pipetting proceeds normally, Pip__status will be set to λY' as illustrated in Fig. 14b. Referring to Figs. 15a-b, the main function of
ALPR transfer_manager() is to orchestrate proper aspiration and dispense volumes for samples larger than lOOOμL. An array is filled with volumes for ASP and DSl commands based on the aspiration volume in SAMP. Unless the volume is over lOOOμL, the array will always have 0 volumes for DSl stored.
For volumes over lOOOμL, the volume is divided by two and subtracted from the original volume to obtain one of the volumes to aspirate. The difference left over becomes the second volume. This technique produces only whole μL volumes to aspirate, fractional volumes are not possible. The first aspirate volume becomes the second DSl volume, the "previously dispensed" volume.
Because the PC 153's TWIN software does not support volumes over 2000μL, any larger volume is set equal to 2000μL. Once the array is filled, transfer_sample() performs the fluid transfer.
With reference now to Figs. I6a-c, ALPR transfer_sample() is responsible for calling the functions that transfer a single sample volume from a tube in the tube rack to the sample cup on the ES300 analyzer. In addition, if errors are reported during the transfer, this function detects them and returns. If the start of a new run is detected, transfer_sample() tries to install tip number one from rack number 1, instead of the next tip in line from the preceding run. In case of some errors, ALER causes a tip to be removed and a fresh tip to be installed. Transfer_sample() detects this and updates ALSW as required. The function install_tip() is used for tip installation. See Fig. 17. Because it is necessary to try to install tip number one out of sequence, there are two functions called by install_tip() , alpr_next() for typical tip installations (see Fig. 18), and alpr_tipl() for installing tip one from rack one at the start of the run (see Fig. 19) . Since a tip installation can fail at any time if a tip is missing from the rack location being searched, ALER assumes responsibility and uses TIPS to try to find and install a tip. If the search is successful, the next tip to be installed must be recorded in ALSW. This is done by both TIPS and ALPR. By using different functions for typical installations and for tip number one, it is possible to keep track of which tip was installed in all cases. For the special tip number one case, alpr_tipl() saves what was in ALSW before trying to install tip one. If TIPS installs a tip because there was no tip one available, alpr_tipl() can compare the original ALSW to the new value to see if they are different. If they are different, then ALSW has already been updated by TIPS. If they are the same, then there was no TIPS activity and alpr_tipl() saves tip number two in ALSW as the next tip to use. alpr_next() does not have to detect TIPS activity and store an out-of-sequence number. It does have to detect when the last possible tip will be installed and to wrap the tip count around to tip one in ALSW.
Referring to Fig. 20, ALPR try_tip() is used by alpr_next() and alpr_tipl() to install a tip. It uses the specified tip number to put the arm 20 over the tip, and then uses IPT to try to install. A failure to install a tip will be handled by ALER.
ALPR set_rotor() uses the supplied sample rotor position to translate a new position for system use. See Fig. 21. In order for the arm to be able to dispense into the correct sample cup, a different ES300 analyzer rotor position must be specified so that the sample cup needed will be accessible by the arm. This is done by using rotor_array[] to find the corresponding coordinate needed. Once the new position is available, the ES300 analyzer command is constructed and transmitted using AL_Dispatch() . Errors from the ES300 analyzer cannot be corrected by ALER, so if any are detected by set_rotor() , the pipetting operation is canceled by setting ALPR_stat to WAIT_STAT.
ALPR asp_setup() (see Fig. 22) , • perf_asp() (see Fig. 23), and perf_dsl() (see Figs. 24a-c) issue system commands and check for errors. During perf_dsl() the arm must move over the sample cup for dispense. The array rotor_array[] is used to translate a supplied rotor position into an arm horizontal position. Other than this special operation, the functions primarily issue a fixed sequence of commands while checking for errors and early returns.
ALPR conv_al_ret() is used to minimize the need to call AL_Dispatch() and convert the return to integer form for error checking. See Fig. 25. conv_al_ret() performs both of these functions for the caller. However, it is still necessary for the caller to specify the index for the command control parameters.
The decision to pipette a sample depends on system information and SAMP information. ALPR get_action() sorts the combinations and either returns an error code, a skip code, or the code to pipette. There are two major decision groups: the system was able to supply a barcode from the current tube; and, no barcode was found for a particular rack and tube position. Compare Fig. 26, Fig. 27a-b.
If the system has supplied a barcode, then SAMP can be searched to find the same barcode. If pip_status and Ld_status in SAMP show that the same sample can be pipetted, then get_action() will return PIPETTE. If no barcode is available, SAMP cannot be searched by barcode number. Instead it is searched based on the rack and tube position. If a matching rack and tube position is found in SAMP, and the SAMP flags permit it, then get_action() will return PIPETTE.
In addition to the two sections in get_action() for SAMP searches, there are functions used by get_action() to do the actual work. For barcode number searches, the functions primary_id() and secondary_id() are used. See Figs. 28-29. For rack searches, primary_rack() and secondary_rack() are used.
The first time a search is made for a barcode number, the function primary_id() is used. If SAMP shows that the sample cannot be pipetted, another search is performed to find another SAMP record with the same barcode number. This is done using secondary_id() . secondary_id() uses the ZIM NEXT search method and must be preceded by a FIRST search method. This is done by primary_id() . NEXT searches stop when the barcode number criteria fail to match another SAMP record. primary_rack() and secondary_rack() searches are somewhat more complicated because, unlike an id number search, there is no unique key to use for the search. primary_rack() uses the FIRST search method to find the first instance of the rack number in SAMP. See Figs. 30 and 31. Since there is only a one-in-ten chance that this is the correct tube location (recall that there may be as many as ten tubes in a rack) , it is usually necessary to NEXT search until matches for both the rack and tube numbers are found. Even though primary_rack() finds a match, that may not be the only instance of that rack and tube location. If the sample from the first successful search cannot be pipetted, secondary_rack() is used to find, if available, another occurrence of the same rack and tube. See Fig. 32. If such other occurrence is found, this sample can also be pipetted.
ALPR get_next_barcode() is used for both scanning and pipetting operations. See Figs. 33, 34 and 35. However, because of the differences between these operations, not all of the code can be shared. The biggest difference is in moving the shuttle after a barcode is read. For scanning, the fastest possible shuttle movement is desired. As soon as the barcode is acquired, the shuttle begins to move to the next position. This permits database activity to be performed while the shuttle is moving. For pipetting, the shuttle must not move after reading a tube barcode because the tube must be stationary for fluid removal. Thus, get_next_barcode() uses flags to control movement after a barcode is read. The type of shuttle command used is also important. For scanning, MS3 and MSI can be used to move to the first or next tube as required. When the last tube in a rack is read, and MSI issues, the next tube one position will be moved into place. If no rack is available, an MS3 can be issued to move the next tube one position into place. This is efficient for scanning because movement can begin as soon as the barcode is acquired. For pipetting, it is not efficient to stop at tube one unless a rack is present. For pipetting, it is better to stop at the rack barcode and determine if a rack is present, and then either use MSI commands to move from tube to tube, or MS5 to move to the next rack. Thus, scanning uses MS3/MS1 commands for movement and pipetting uses MS5/MS1 commands. get_next_barcode() keeps track of the "end" of the shuttle. Since there is no physical "start" or "end" of the shuttle, get_next_barcode() is passed a flag when a scan or pipette operation starts. This causes the global count to be set to zero and the flag cleared. Thereafter, every tube or rack move will increment the count appropriately. When the count adds up to the capacity of the shuttle (150=up to fifteen racks times up to ten tubes per rack) the "end" of shuttle is said to have been reached. This means that every tube position has passed the barcode position once and, unless something has been changed by the operator, there is no new information to be acquired. Figs. 33-35 illustrate how scanning and pipetting modes are interleaved, as well as how the tube count is managed to determine the end-of-shuttle.
APLR SERVICE transmits operator commands directly to the system, and views the results in the reply. See Fig. 36. For each SERVICE message to ALPR there are four system exchanges. The service facility automatically requests the system to supply information, such as barcode data, for display on the ZIM screen. The ACIN entity set is initialized by ZIM and read by ALPR to do this. ALPR also uses ACOT to reply to the ZIM code. Transmissions to the system utilize AL_Serv_Disp() , not AL_Dispatch() . This is so because AL_Dispatch() detects errors and sends ALER a message to correct the error. This is not desired during service operations. Fig. 36 illustrates how a loop is used to read system commands from ACIN and send the commands using AL_Serv_Disp() .
ALPR SENSOR displays a continuous update of the system sensors on a ZIM screen. Once in SENSOR mode, a sequence of commands is repeated until a message is received that changes the mode from SENSOR to something else. Figs. 37-38 illustrate how SENSOR mode is established and how the sensors are read and the readings displayed. ALPR AL_Dispatch() is in every system task that communicates with ALCO. However, only ALPR AL_Dispatch() detects system errors and passes control to ALER. At entry to AL_Dispatch() there is a test for ZIM index use. To speed up ALPR as much as possible, the use of the ACMD entity set has been replaced by an index to an array that reflects the content of ACMD. However, for testing ALPR and ALER during verification tests, it is necessary to use the ZIM method because the index is not known as it would be in the rest of ALPR. When using ALPR to issue a system command, create an error, and pass the status to ALER, a technician issues the command to ALPR in the DIRECT mode. Under these conditions AL_Dispatch() must look up the command control parameters in ACMD. If necessary, AL_Dispatch() will re-initialize the Autoloader. This would normally not be needed except in cases of power failure. To transmit a command, AL_Dispatch() permits retries beyond what is performed by ALCO. The overall AL_Dispatch() entry, command transmission, and loop retry method is illustrated in Figs. 39a-b. The details for transmission are illustrated in Figs. 40, 41, 42a-b, and 43-45.
Fig. 40 illustrates the major command types, C (Command) , S (Status) , R (Read) , M (Macro) , and E (ES300 Analyzer) . Each type of command requires different handling. The types are determined by the index passed to AL_Dispatch() . Some commands must be detected prior to transmission in case there is a subsequent error. This is done using test_cmd_str() as illustrated in Fig. 40. The system does not have a facility for maintaining the last shuttle command sent. If there is an error due to a shuttle command, such as MSI, ALER does not have a way to obtain the shuttle command from the system. It must be supplied by ALPR. In order for ALPR to do this, it must trap the command before the message is sent to ALER, test_cmd_str() is used. For ALER to issue the ASP and DSl commands, the volume must be known by ALER. ALPR uses test_cmd_str() to trap the volume for later use if needed, see Fig. 46. Once the special command requirements are met, AL_Dispatch() executes the section of code appropriate for transmitting the command. In AL_Dispatch() , the error handling is specified as O for purposes of marking the trace. Normal processing is type O. If ALER is executing, it uses a different error handling code and this causes the trace to look different. This way ALER activity can be discriminated easily.
ALPR AL_Dispatch() type C command does not return a reply. Fig. 41 illustrates what is required to support a type C command. ALPR AL_Dispatch() , type S command causes the system to return a reply reflecting the status of some part of the system. All of the S type replies can include a busy status. AL_Dispatch() resends the command until the busy status is gone. Once the system is not busy, the system reply is converted to a long for testing. A zero result indicates no errors. All other results cause the status message to be sent to ALER for error correction. Along with the status goes a shuttle command, if appropriate, and a volume (which is meaningless unless the error was an ASQ or DSQ error) . After ALER replies, the return code is converted to an ASCII string to return to the caller of AL_Dispatch() . The return code reflects the success of ALER to correct the problem. One other housekeeping task is accomplished after the ALER reply is received. Because AL_Dispatch() keeps track of shuttle commands for use with ALER, it also has to keep track of the success of shuttle commands so that old information is removed. When a system shuttle command reply is received, and it is observed to be without error, the stored knowledge of the command is cleared. If there is an error and ALER is able to correct it so that the shuttle can move, this must also be detected. The routine test_smsg_str() is used with BEFORE and AFTER modes to accommodate checking system replies "before" being sent to ALER and "after." See Figs. 42a-b and 47.
ALPR AL_Dispatch() , type R commands are used to obtain information from the system. An example of such information is rack 300 and tube 304 barcodes. The replies from the system are pointers to the system string returned. Fig. 43 illustrates the type R flow chart.
ALPR AL_Dispatch, type M commands return system status information to AL_Dispatch() . However, unlike S commands, there is no busy status to contend with. When the system status is received, it is checked for errors. If an error is present, the status message is sent to ALER for correction. Fig. 44 illustrates the type M flowchart. ALPR AL_Dispatch() , type E commands are for the ES300 analyzer. The structure ES_Command is initialized with the values needed by SENDPROC() for proper ES300 analyzer communication. No ES300 analyzer error correction is possible from within the system task environment. Errors are only reported. Fig. 45 illustrates the type E flowchart.
ALPR test_scmd_str() and test_smsg_str() are used by AL_Dispatch() to detect certain commands so that information can be supplied to ALER. Test_smsg_str() also detects the results of ALER to clear knowledge about previously trapped shuttle commands. See the discussion of AL_Dispatch() and Figs. 46-47.
ALPR main(). Miscellaneous QNX messages include:
SHUTDOWN, which causes ALPR to terminate. See Fig. 48; CONNECT, which causes an ENQ to be sent to the system. See Fig. 49; DISCONNECT, which causes an EOT to be sent to the system. See Fig. 50; INTERRUPT and CONTINUE, which are used to start and stop an ALPR operation without canceling it altogether. See Figs. 51-52; END_LOAD, which erases any intermediate state as a result of a previous INTERRUPT, and signals INAL to send the end_load sequence. See Fig. 53; DIRECT—when testing ALER, by sending messages to ALPR, it is necessary to inform AL_Dispatch() that it has to look up the command control data using ZIM PLI. DIRECT mode is only used in the laboratory for software testing. See Fig. 54; and, SCAN_NEXT_TUBE, which permits only one tube to be scanned instead of the whole shuttle. See Fig. 55.
ALER is used to correct system errors during scanning and pipetting operations. Only ALPR communicates with ALER, so the only errors that can be corrected must come from operations in ALPR. In addition, ALER is only invoked by the routine AL_Dispatch() in ALPR. System commands must go through AL_Dispatch() in ALPR in order to trigger ALER if an error occurs. Fig. 56 illustrates the QNX message relationship between ALPR and ALER. Messages to ALER, triggered by system errors detected in ALPR, contain a status string representing the errors detected. The message may also contain information about a shuttle command or a fluid volume. However, unless the error was caused by a shuttle command, the shuttle information is not relevant. The same is true for fluid volume information. Except for ASQ and DSQ errors, the volume is not required. ALER may, or may not, be able to correct an error. The flag value in the QNX reply from ALER reveals how successful error correction was. Some errors are so serious, such as SYSTEM errors, that ALER cannot correct them. If ALER needs to install a pipette tip, it sends a QNX message to TIPS for this purpose. Fig. 57 illustrates the message relationship between ALER and TIPS. If a tip is installed by ALER/TIPS, that event is reported to ALPR. This is necessary to insure that the entity set ALSW is always properly updated to reflect the next tip to use. Each of the functions that makes up ALER is discussed hereinafter.
Fig. 58 illustrates the major decision blocks in ALER. To correct an error, ALER uses the status message from ALPR as the starting point. The status message contains information that can be used to select a correction strategy from a database. Except for tip installation, all error handling is list-based, using ZIM databases. The basic sequence for correction is typically error-bit detection, database key construction, database search, list execution, and re-sending the original system command to see if the error was corrected. There is an added complexity to status messages due to the presence of a "next-query." Some status messages report an error, but another command must be used to get the details. To accommodate more than one status message in ALER, there is a status stack. The stack is first-in, last-out. When a next-query is detected, the new status needed is requested from the system and placed on the stack. Error correction then proceeds using the new status until the error is fixed or it is determined that correction is not possible. Assuming that a next-query can be cleared from the stack, the previous status is then used to continue error correction. Presumably the error associated with the next- query can then be resolved. However, there could be other errors that still need to be corrected. These errors will generate database searches for lists, which will cause more commands to be sent to the system. Eventually, either an error-free response will be received from the system, or it will be clear that the error cannot be corrected. In either case, al_error() will return, causing a reply to ALPR reporting the success of ALER error correction activity. A discussion of the operation of the functions that make up ALER follows. The function test_bits() is used to determine the error bit number in the status message under investigation. The al_error() inner loop operates when a bit number is returned that is non-zero. The first step in processing an error is to find the error in the AERR database. This is done using find_aerr(). In the aerr structure is a member called error_type. Error correction is guided by the nature of error_type. For instance, if a particular error is an XS' (System) type error, no attempt is made to try to correct that error. On the other hand, a ΛF' or N' error is likely to be corrected. Figs. 59a-d illustrate the steps and functions used to handle all of the error types.
When test_bits() reports that the last bit in the status number has been processed, the outer loop section of al_error() will operate. This section is illustrated in Figs. 60a-b. The first decision point in the outer loop determines if the preceding inner loop error correction activity has had any effect. A check is made to determine if the latest status information indicates that there is an error. If there is still an error, it is possible that some improvement has been made. In this case, a check is made to see if the new error status is different than the original status when correction started. If the status is different, it may be worthwhile to begin error correction again from the beginning. A jump is made to the START point in al_error() to accomplish this. The reason for trying error correction again is related to bit position dependent error correction. Suppose that there are two errors that need to be corrected. test_bits() will identify the first error, but conceivably this error cannot be fixed because it is dependent on the second error. Eventually, the second error is detected and corrected. When the status is checked, it reveals that some error was corrected, but there is still a problem. When error recovery starts over at the beginning, the problem blocking the first error correction has been fixed. Now the error can be corrected, so the second pass produces complete error correction. This form of error correction was selected to eliminate the need to second-guess error correction order when selecting error correction methods. Once the decision point for no error/different error has been passed, the next test involves the depth of the status stack. When the status stack index reaches zero, it is necessary to determine the return code for ALPR. If the stack is not at zero, the current stack entry can be deleted and error correction resumed at the next higher stack level. When the stack reaches zero, the function get_return_status() determines the code to report to ALPR. If the stack is not zero, solve_problem() is called to position the system such that when the status that caused the next-query error handling to take place is reissued, no additional errors will be caused by the error handler. At this point, the status query from the stack is re-sent to the system, with the option to suppress an IPT if a tip was already installed by ALER, to determine the current status using send_current_query() . If the status shows that the error has been fixed, then the good status is placed on the stack, and error correction continues. When al_error() begins operation, the system- stored memory of what desired positions have been requested needs to be preserved. For instance, suppose that the system was commanded to move the arm 20 to horizontal position one, but failed because the arm 20 power was turned off. The desired destination, horizontal position one, is preserved by the system. Before al_error() can send any commands that would overwrite the stored destination positions, it must use get_current_pos() to retrieve and save the information for later use. Fig. 61 illustrates the operation of get_cur_pos() . The information stored is used by restore_position() . In order to accomplish error correction, it is necessary to place the system in the same state that it was in, or desired to be in, at the start of al_error() , the information retrieved from the system and saved by get_cur_pos() . Figs. 62-65 illustrate how the system position is restored. The position of the shuttle is special, and is actually the command used to produce an error that is used by restore_position() . This information is provided by ALPR and is not available from the system. The entity set AERR contains keys constructed by adding a bit position to the end of a system command. The lowest bit number possible is one, and the highest is sixteen. Suppose ALER received the status QSSS4096. The search key constructed by find_aerr() would be QSS13. If the status received has been ASQsl, the search key would be ASQ1, with a space after the one. This is for compatibility with ZIM. Fig. 66 illustrates how this is done. After the search is completed, the AERR structure is filled with a record from the ZIM AERR database on disk. The status stack is a continuous char buffer. Stack entries are determined by the index count and the maximum length of a status message. To add a status to the stack, it is necessary to compute the starting location, using the next index, and copy the message to the stack buffer. This process is illustrated in Fig. 67. ALER add_msg() will report an error if the stack is full.
However, the stack is defined big enough for ten status messages. It is theoretically impossible for the stack to grow beyond level 3, due to the limited number of next_query bits that can be detected. Thus, if a stac - full error is ever detected, something very wrong has happened to the software.
When a next_query status is added to the stack, the working state of the logic masks must also be saved. Eventually, the next_query will be cleared from the stack and error correction will resume on the previous status. To be able to do this, the masks used by test_bits() must be in the same state. ALER nxtquery_man() transfers the working masks to the mask stack using the status stack index. This is illustrated in Fig. 68. So that test_bits() is ready to process a new status, the working masks are initialized. Then send_next_query() is used to get the status specified by AERR that contains the additional error information needed for error correction,and add it to the stack. The message sent from ALPR to ALER contains a status string representing the system error condition. After error correction has been performed, it is necessary to request the same status to determine the results. If the status was generated by a "high-level" command, it is necessary to find the command that produced the error. This is done with ALER status_to_query() . The status characters are compared with an array of high-level status strings. If a match is found, the corresponding command is copied into the buffer padded at entry. Then the caller can proceed transmitting the status with the command that originally generated the error. Figs. 69a-b illustrate the methods employed to translate one character string into another. ALER status_to_query() uses a 3 character query to find a corresponding command. The input to status_to_query() includes a pointer to a status string such as IPQ, a pointer to a command string for return, and an array stat_quer(), with the sets illustrated in the following Table 1:
status command
IPQ IPT
EPQ EPT
PLQ PLD
LVQ LEV
RFQ RFC
DSQ DSl
ZZZ end of table ZZZ end of table
Table 1
ALER st_diff() is a utility to compare a long, supplied at entry, with an ASCII number in a status. The status is in the status stack. In the outer loop of al_error() , st_diff() is used to determine if a recent status is different from one stored on the stack. Fig. 70 illustrates the steps involved in the comparison.
After error correction has been performed, the query command that produced the system status must be re¬ sent. The status returned by the system can be used to determine if error correction has had any effect. For low- level commands, the first three letters of the status can be re-sent for the query. However, for high-level commands it is necessary to re-send the command that preceded the query, such as IPT before IPQ. Two high-level commands, ASP and DSl, must also include the volume. Thus, it is necessary to process the status characters and determine if a high-level command is required. This is illustrated in Fig. 71. If an ASP or DSl command is needed, then no additional search for a high-level command is performed. Otherwise, status_to_query() is used to build the needed command. Once the command is built, it is necessary to check whether it is safe to transmit. If an IPT command was previously used, and was successful, then it cannot be sent again, as it would cause an error after one was just corrected. To prevent IPT transmission, ALER send_cur_query() is supplied an option flag maintained by the caller. If suppressing IPT is needed, the caller includes the flag and the sent_cur_query() logic checks to see if the command is IPT, and, if the flag shows, to block transmission. Irrespective of whether a special high-level command is set or not, the first three characters of the status message are always sent. A pointer to the system reply is made available to the caller before returning.
To evaluate an error in a system status, it is necessary to identify the position of an error bit. The position of an error bit is used as part of a database search. ALER test_bits() is used to find error bit positions. Figs. 72a-b illustrate how test_bits() operates. test_bits() is designed to prevent retesting a part of a status that has already been tested. This is done by modifying a bit mask based on the results of a previous test. By using the bit mask, it is possible to generate a "new" status with the previously-checked bits eliminated. Thus, only new bit positions will be reported until the end of the status work is reached. Table 2 illustrates test_bits() operation for the value 4384, base ten (1120 hex) . The intermediate values generated on the way to producing the bit positions six, nine, thirteen, and finally zero, are illustrated in Table 2.
entry inv stat¬ statmask statmask exit position mask mask mask & inv & s = new mask of error
(hex) (hex) (hex) mask = status (hex) bit statmask (hex) (base (hex) 10)
0 ffff ffff ffff 1120 20 6
20 ffdf ffff ffdf 1100 100 9
100 feff ffdf fedf 1000 1000 13
1000 efff fedf eedf 0 10000 0
Table 2 test_bits() example for s=4384 (1120 hex)
Table 3 illustrates how the exit mask value corresponds to bit positioning, so that bit positions are not a mystery.
mask (hex) position (base 10)
1 1
2 2
4 3
8 4
10 5
20 6
40 7
80 8
100 9
200 10
400 11
800 12
1000 13
2000 14
4000 15
8000 16
10000 —
Table 3 test_bits() exit mask values with error bit positioning
After error correction is completed, the last available status from the system is used to determine the reply code to ALPR. If there are no errors, then the reply will be OK. In case of errors, it is important to report the worst error if there is more than one. Figs. 73a-b illustrate how get_return status() uses test_bits() to analyze the last system status. The process is complicated by next-query errors. ALER get_return_status() recovers previous status information from the stack in order to resolve comparisons between status values. The idea is to find the worst error among the status values that reflect system errors. This is done by transmitting the next-query specified by AERR, obtaining the return value based on the observed error, then recovering a previous status for further analysis. Overall, the worst error will still be reported.
Error correction is governed by defined strategies stored in AERR. The names of the strategies are: init_proc; flag_proc; run_proc; and, error_proc. The function solve_problem() does not use the error_proc method (see the discussion of clean_up() that follows) . Two of the methods in solve_problem() , init_proc and run_proc, are nearly identical in operation. The flag_proc method is for resolving problems that cannot be solved with a list-based approach. Currently, only tip installation requires a flag_proc. Figs. 74a-b, 75 and 76a-b illustrate how the three methods are detected and used in solve problem() for error correction. In init_proc and run_proc sections, the base string for the ALMA search is copied from AERR to a local buffer for key construction. Inside a loop, the base key has a sequence number added to form the search key. The search key is then used to find a command to send in ALMA. Once no more commands can be found, the init_proc or run_proc method is exhausted. Note that not all AERR entries have all three methods defined. If init_proc or run_proc have "ZZZ" in AERR, there is no defined strategy available in ALMA. A flag_proc is defined by a number. The number is used in a switch statement to select the flag_proc function that does the error correction. For flag_proc #1, the only flag_proc, the arm is moved over tip number one prior to beginning TIPS. This is to assist TIPS by getting the arm in the neighborhood of the position TIPS will need to request. This will prevent an arm error by TIPS if the arm is not positioned over a tip rack when TIPS is called. If the TIPS operations are successful, solve_proble () sets the ipt mode variable to SUPPRESS_IPT. This is done to prevent future attempts at tip installation after a tip was successfully installed.
The clean_up() function uses the error_proc member of AERR. ALER clean_up() operates in the same manner as init_proc and run_proc described immediately above in solve_problem() . Figs. 77a-b illustrate the operation of clean_up() .
If a next-query bit is set in a status message, the AERR structure will contain a command string after the search is made. The AERR command is sent to the system and the reply is placed on the status stack. This is illustrated in Fig. 78.
The function ipq_test() is used to detect that a tip was successfully installed. If the system status message is IPQsO, then a tip is present. This information is used by ALER to suppress future attempts to install a tip, and cause an error because a tip is already installed. Fig. 79 illustrates the method used to detect and report IPQsO in ipq_test() .
TIPS is a specialized task for installing pipette tips during error handling. ALER is the only task that communicates with TIPS. Figs. 80a-b illustrate the main() function in TIPS. Only two operations are supported: INSTALL TIPS; and, SHUTDOWN. In the case of INSTALLJTIPS, the reply back to ALER will contain the number of the tip installed, and a success code.
To install a tip, tip_manager() begins with the tip number in ALSW. In addition, this number is incremented and saved back into ALSW. If the installation is successful, then this will become the next tip to install. The incrementing and saving of the tip number is done by computer_tip() . Using the first number from ALSW and install_tip() , tip_manager() tries to install a tip. If the installation fails, tip manager() tries to find a tip using what is called a "column search." The first tip in each row of the first column of tip rack one and two is tried. If a tip is found, ALSW is updated with the new tip number plus one. The number of the tip actually installed is saved for return to ALER. Figs. 81a-b illustrate how the two methods are employed to find and install a tip.
Before a tip number can be saved in ALSW, it must be incremented and checked for range. The maximum tip number in rack two is 144. compute_tip() checks to see if the maximum will be exceeded, and, if it will be, wraps the next tip in ALSW around to one. See Fig. 82.
To record a tip number in ALSW, the caller passes a tip number to save_tip() . change_alsw() is used to record the change on disk. See Fig. 83. Referring to Figs. 84, 85, 86a-b, 87 and 88, TIPS
AL_Dispatch() is a subset of the version described in ALPR. Because TIPS is controlled by ALER, there is no trapping of errors as is done in ALPR. TIPS does not use indexes as a substitute for ACMD. Also, because AL_Dispatch() commands in TIPS are considered an extension of ALER, the error handling for SENDC0MM() is specified as 100. This tags TIPS' trace lines to show them as error handling like ALER.
INAL is used to initialize the system, and to place it in a known state after a run is completed. Both functions are performed in the same manner, the only difference being the address of the array that is the source of the search strings. Figs. 89a-b illustrate how the two main jobs, INIT and END_LOAD, are selected.
INAL send_cmd() is called by initialize() and end load() . Those two functions initialize arrays as required for the operation and pass the array address to send_cmd(). send_cmd() searches ALMA for all numbered sequences built around the contents of each array string provided. If an ALMA search is successful, the string from ALMA is sent to the system. Errors from the system will cause an early exit from INAL and an error reply to ALPR (only ALPR uses INAL) . INAL does not send error messages to ALER for correction. Table 4 and Figs. 90 and 91a-b illustrate the content of the arrays used for the ALMA searches and the method used to build ALMA keys and transmit commands that are found. The input to send_cmd() includes end_load() and initialize() . This stores the base of each search key in an array and passes a pointer to the array to send_cmd() . The contents of each array are as follows:
Initialize end_loa ()
"RES" "VAX"
"ARM" "HME"
"IPE" "ZZZ" end of table
"HME"
"STL"
"PIN"
"ZZZ" end of table marker
Table 4
The following INAL commands are sent to the system for initialization and end-load cleanup. If any errors occur during an INAL sequence, the sequence will be aborted, an error message will be displayed on the screen, and the error will be recorded in the error-log. re¬ initialization sequence
Reset Firmware
RES - Checks Power Supply, EEPROM,
Microprocessors, and RAM. Returns same status as QGS.
Test Arm
AP+ - Turn on power to arm motors.
LZ- - Move arm to Z-axis limit.
QAS - Poll busy-bit until arm move is complete.
LY+ - Move arm to Y-axis inner limit. QAS - Poll busy-bit until arm move is complete.
LR- - Move arm to R-axiε limit.
QAS - Poll busy-bit until arm move is complete.
LY_ - Move arm to Y-axis minimum limit.
QAS - Poll busy-bit until arm move is complete. LZ- - Move arm to Z-axis limit.
QAS - Poll busy-bit until arm move is complete.
MPVvl - Move arm down to full-up position.
QAS - Poll busy-bit until arm move is complete.
MPHhl91 - Move arm to "at rest" position. QAS - Poll bus-bit until arm move is complete.
Eject Tip
MPVvl - Move arm to full-up position. QAS - Poll busy-bit until arm move is complete.
MPHhl86 - Move arm to eject hole position.
QAS - Poll busy-bit until arm move is complete.
MPVv9 - Lower arm to tip eject elevation.
QAS - Poll busy-bit until arm move is complete. EPT - Eject pipette tip. EPQ - Check eject status.
MPHhl91 - Move arm to "at rest" position.
QAS - Poll busy-bit until arm move is complete.
Test Shuttle
SP+ - Turn on power to the shuttle.
MS5 - Move the rack barcode position of the next tray to the aspirate location. QSS - Poll busy-bit until shuttle move is complete.
Test Pump
PP+ - Turn on power to pump. ISP - Initialize pump. QPS - Poll busy-bit until pump move is complete.
End-load sequence
AP+ - Turn on power to arm motors. MPVvl - Move arm to full-up position. QAS - Poll busy-bit until arm move is complete. MPHhl91 - Move arm to "at rest" position. QAS - Poll busy-bit until arm move is complete.
The calibration task, CAAL, is the only task not controlled by ALPR. CAAL requires the services of ALCO. Otherwise, it is self-sufficient. CAAL is not resident in memory like the other system tasks. ZIM starts CAAL with a command line parameter for a specific operation. CAAL executes the command and then terminates. For calibration operations that require results from previous CAAL operations, the results are saved and recovered using disk files. There are no intermediate results preserved in memory between CAAL runs. Besides not consuming RAM when not in use, execution by the command line technique allows easier access to a display screen associated with PC 153. This makes it easier for CAAL to overwrite ZIM screens. There are basically two types of CAAL operations: file and display operations; and, calibration operations. CAAL requires a number of file copy options to permit new calibrations to be performed while preserving old information. Therefore, some command line parameters do nothing more than read a file and copy it to a new name. Some options are used only during development to make a copy of a file with default values for the first time. Once the file is made as a placeholder, it can be read by CAAL and eventually overwritten when a calibration is performed. For display purposes, some options read a file and use display coordinates to write to the screen.
The calibration options are much more complicated than the file and display type options. For calibration, the user is expected to toggle keys to align the system as needed. After alignment, the new coordinates are written to a file so they can be displayed. If the user decides that the new parameters are correct, they can be transferred from the file to the system EEPROM 140. Figs. 92 and 93a-c illustrate how main() uses command line parameters to route control to calibration or file and display operations.
The function that administers the calibration program is calman(). It calls the functions needed to perform the requested command line operations. Before any calibration can be performed, the RAM tables that hold constants and descriptions must be filled using disk files and rd_ table() . In addition, new_table[] must be filled with the most recent information from disk so that, if only one calibration is performed, the table can be written back with complete information. After the initial file activity, caiman() uses set_variables() to initialize the flags that control which axis(es) is (are) calibrated, how many positions on each axis, and how to find strings of commands to position the system before calibration begins. set_variables() does this based on the command line parameter at entry. Once the calibration control variables are set, caiman() begins loop execution. Inside the loop, a two letter code is used by send_cmd() to build keys for finding commands to send to the system. These commands will place the arm and shuttle where they need to be for operator alignment. If the operation to be performed is the calibration of the dispense positions, the ES300 analyzer is initialized. If a flag indicates that an axis needs to be adjusted by an operator, calibrate() is used to permit axis movement through keyboard control. The loop control is incremented with every pass. When the initialized loop value is exceeded, the loop exits, caiman() checks to see if the ES300 analyzer was needed, and if so, disconnects communication. If there were no system errors, caiman() uses wrt_table() to save the new calibration information in the al_new file and return. Other command line parameters actually must be used to load the calibrated coordinates into the system EEPROM 140. Figs. 94a-c illustrate how caiman() operates. Note that store() is used to transfer system coordinates to new_table[] in the loop.
Figs. 95a-b illustrate how CAAL set_variables() converts a command line parameter into codes for controlling calibration. For instance, if the command line parameter were 3, then the loop count would be set to two, the axis flags would be set to one for R, Y, and Z and the search code would be set to T2. This means that there will be two defined positions set during this calibration, all three arm axes will be set, but the shuttle will not, and the commands for setting up the arm can be found using T2 as the base code for searching ALMA. The input to set_variables() includes a pointer to the structure for holding sequence variables and CAAL entry command live parameter, clp. This function assigns codes and axis loop counts, for later use in sending sequences of commands to the system and positioning the arm.
Figs. 96a-b illustrate how axis variables govern allowed key strokes in CAAL calibrate() . Once in the calibrate() loop, the user is permitted to move the arm and the shuttle using key strokes. However, the R, Y, Z and S variables, initialized by set_variables() , must be ones for an axis to be controlled.
As part of the caiman() calibration process, send_cmd() is used to search for, and transmit, system commands. set_variables() stores the base code for a search of ALMA. set_variables() also sets the loop count used by calman() . The base code, such as "TI" or "BC," plus the loop count make up the first three characters of the search key. In send_cmd() there is another loop. This loop is set up to find every instance in ALMA where the first three characters match the base code and the loop count. To do this, an inner loop count is concatenated onto the first three characters of the search string to create the final key. Since there can be more than nine commands for each sequence, this inner loop count can be up to two digits long. Therefore, the full length of the key can be four or five characters. For ZIM compatibility, each key is padded with spaces to five characters if needed. Figs. 97a-b illustrate how send_cmd() operates. Once the operator has completed a calibration,
CAAL store() specifies how to save the information in new_table[]. The specifications are passed to get_pos(). This function reads the system's current position and then uses the index specifications from store() to save the position. Figs. 98a-b and 99a-b illustrate how store() and get_pos() operate. The input to store() includes a pointer to the structure for holding sequence variables. clp holds the CAAL entry command line parameter. The loop is managed by caiman() . The input to get_pos() includes a pointer to the structure holding sequence variables, specifically ridx, yidx, zidx and sidx, initialized by store() .
When the command line parameter number eleven is received, the process of calculating the complete set of calibration points from the set of points directly calibrated by the user begins. The most involved part of the process is the calibration of rackl and rack2 tip coordinates. From only two tip rack positions, the R and Y axis coordinates for every other tip in that rack can be calculated. calc_rackl() begins the process, and the function row_col() administers the calculations. Because row_col() is general purpose, calc_rackl() and calc_rack2() set up structures used by row_col(). Besides preparation for row_col(), the calc_rackX() functions compute the Z- axis tip installation and tip search elevations. These calculations are simple additions of different offsets, read from the file al_caal_parm, to the calibrated elevation of the tip rack. Figs. 100 and 101 illustrate how calc_rackl() and calc_rack2() operate.
CAAL row_col() administers the calculations for one tip rack at a time. At entry, it has access to the R and Y-axis coordinates of tips one and twelve in the first row of tips for the given rack. However, a Y-axis coordinate is not the distance from the center of the arm to the center of the tip, but is actually the distance from the y-axis position furthest away from the center of the arm to the center of the tip. To be able to use trigonometry to find the polar coordinates of all tip locations, it is necessary to compute the missing distance from the center of the arm to the Y-axis initialization position. This is performed using calc_r4(). Once r4 is known, the coordinates to all of the tips in the first row can be computed. This is done using init_rowl(). Once the coordinates of all of the tips in rowl are known, they can serve as the base coordinates for computing coordinates in the other rows. Using the rowl coordinates for computing all of the other tip locations comprises the main body of calculations performed by row_col() . Figs. 102a-b illustrate the overall operation of row_col(). Figs. 103a- b illustrate how row_col() computes an unknown location from a known rowl coordinate.
The following description describes each of the functions used by row_col(), and ends with a discussion of how row_col() computes the unknown locations from known coordinates. The input to row_col() includes a pointer to a working floating point array, and a pointer to a structure holding limits for rows, columns and tips.
Fig. 104 illustrates the relevant locations and distances for beginning the tip coordinate calculation process. During calibration, a step performed prior to beginning calculations, the positions of two tips in a rack are obtained. For the purposes of this discussion rack one is referenced, however, the same process could be explained with reference to rack 2. Tip 1 and tip 12 in rack 1 have known, measured, positions. These positions are available in polar coordinates, and the units are in motor steps.
Fig. 104 illustrates the magnitudes of these coordinates, and Fig. 105 illustrates the rotational coordinates. The first calculation problem to overcome relates to the unknown distance r4, which is measured from the center of the arm post to the inner limit of the Y-axis. This distance is not known due to possible differences in the assembly of the arm, and the characteristics of the Y-axis DC motor. In order to perform trigonometric calculations, the length of the side of the triangle which includes distance rl must be known. Because the triangle side is made up of r4 and rl, they must both be known. calc_r4() is used to compute r4. There are some other complicating factors to overcome before calc_r4() can be used. The first has to do with the origin of the Y-axis. When the "zero" point of the Y-axis is reached, the arm is not at the arm post. It is at the outer limit of the arm. In other words, the origin for the Y-axis polar coordinates is not where the origin needs to be. To overcome this, the origin is shifted by using a distance called ymax, so that the y-axis measurement is now zero at a point near the center of the arm, and greatest at a point farthest from the center of the arm. The function unload() uses this method to convert the given y-axis positions to the reference origin. As an example, assume that ymax was 10000 step counts, and that the y-axis step count given was 5500 counts. The distance from the end of R4 to tip 1 is 10000 - 5500 = 4500 steps. This becomes the R, value. To compute R4, it will be necessary to know the value of θl t as illustrated in Fig. 105. The angle 02 is read directly from the system. The corresponding rotation for tip 12 is also given. By subtracting these two values, 0, can be determined.
The input to unload() includes a pointer to a floating working array, arr[], a pointer to new_table[], a pointer to con_table[], and a rack number, either 1 or 2. Besides converting the y-axis positions into R, and R2, and computing 0,, unload() is responsible for building a working floating-point array specific to the rack of interest. In the array are the values needed to support future calculations. The values are gathered from various locations and calculations and are stored in one spot for ease of passing to other functions. Figs. I06a-c illustrate the operations performed in unload().
To compute the R4 distance, equation 1 is used. The R,, R2, and 0, values in equation 1 have already been discussed. R3 is a constant which was measured from the rack itself. See Fig. 104. Note that there is a ± sign in equation 1. By selecting Rj equal to the longer of the two sides R. and R2, the ± sign becomes a - in all cases. calc_r4() is responsible for performing this computation. Fig. 107 illustrates this calculation. The remaining steps to compute R4 are simple mathematical calculations. This procedure is illustrated in Figs. 108a-b. calc_r4() computes the distance r4 illustrated in Fig. 104. Equation 1 is used to compute r4. Note that 0. is illustrated in Fig. 105.
Equation 1
By determining the longer side in software between r2 and r,, the ± operator can be reduced to - for Rack 1 and Rack 2 calculations. r2 must always be the long side of the triangle, compared with r,. For RACK 1 and RACK 2, the distances Rl and R2 can be matched to equation values r- and r2 by using Fig. 107. The input to calc_r4() includes a pointer to a working floating point array, with variables stored for RACK 1 or RACK 2, and a pointer to a structure holding rack limits for rows, columns, and tips. Figs. 109a-b illustrate the operation of init_row(). This function calls calc_r4() and uses the results to compute the angle 06 illustrated in Fig. 110. The angle 06 is needed by calc_rowl(). Note that 06 is computed using equation 2 and illustrated in Fig. 110. θ6 =i 80 -arcsin (R2 +r4 ) /R3 'sinθj^
Equation 2
In the formula, R2 and R3 are known. r4 is computed using calc_r4(). The angle 0. is computed before entry to init_rowl(). The 06 result is used by calc_rowl() as the basis for computing coordinates for each tip location in row 1. The input to init_rowl() includes a pointer to a working floating point array. The last preliminary step in tip coordinate calculation is performed by calc_rowl(). To minimize the propagation of errors though repeated calculations, the coordinates of each tip in rowl are computed and used by row_col() to compute locations in other rows. calc_rowl() computes tip coordinates for tips 2-12 using equations 3-6. Fig. Ill illustrates rackl with the angles defined for computing tip2. calc_rowl() uses the known angles and triangle sides from previous calculations to compute new sides and angles for the triangles made from tips in rowl and tipl. Fig. Ill illustrates the small triangle made from the centers of tips 1 and 2, and the center of the arm. Equations 3-7 are used to compute the coordinates of tip2. All of the tips in row 1 are computed in the same way. The main results is that the 06 angle computed by init_rowl() can be computed and stored for every tip. These angles serve as the basis for computing other coordinates at rows above rowl. Figs. H2a-b and 113a-b illustrate the steps required to compute and store the 06 angles. The input to calc_rowl() includes a pointer to a working floating point array, and a pointer to a structure holding row, column, and tip limits. Fig. Ill illustrates an example to follow the steps to compute a tip position. To compute the r and y coordinates for every tip in a rack, a base coordinate position is computed for the 12 columns using the tip location in rowl. These coordinates are subsequently used by row_col() for every location. calc_row() is responsible for computing an angle, 06, and a distance, r6, for each tip in row 12. Refer to Fig. Ill for an illustration of the distance and angle location for one tip. To compute an r6 distance (also termed org_cc in the software) , Equation 3 is used.
r6=v /(R1+r4)2+r5 2-2(R1+r4)r5cosθ6
Equation 3
RI is known and r4 and 06 have been computed before entry. r5 is R3 divided by the total number of tip locations per row, times the tip number less 1.
To compute 06 for any rowl tip (called £6_cc in the software) it is necessary to compute £7 (also called angle_b) so that the r coordinate of the system horizontal position can be computed and angle_c can be computed. angle_c can be computed based on the fact that the sum of all 3 angles in a triangle is 160°. Once angle_c is known, 06 for the tip location can be computed by subtraction from 180°.
Θ7=arcsin((r5/r6)sinθ6)
Equation 4 θ42~θ7
Equation 5 angle.c =180° -THETA6 -θ7
Equation 6
Θ,tip2=180°-(angle_c)
Equation 7
The final step in tip coordinate calculation is to use the results from calc_rowl() to calculate all other tip locations. row_col() does this in a loop, looking up resources needed for calculations as it progresses from row2, tipl to row8, tipl2. Fig. 114 illustrates an example, computing the coordinates of tip23. Using the stored 06 value for tipll, it is possible to compute angle_a. Because the distance from the origin to tip 11 is known, and R5 is known, when used along with angle_a, the distance from the origin to tip23 can be computed. When Ε^ is subtracted, the remaining distance is the normalized y- axis coordinate. The angle_ccl for tipll is known for init_rowl(). Because all of the sides of a triangle are now known, and one angle, the angle designated angle_b can be computed. This process is performed for every tip to complete the calculations. As part of row_col(), save_pos() is called to store a computed Y and R tip coordinate in an image table. A global count of the tips stored is used as an index into the image tables. Before a tip can be stored, the position must be checked against the tip positions permitted. Not every tip in rack 2 is supported. The array pos_ok[] is used for this purpose. For tips in rack 2, there must be a matching position in pos_ok[], or the tip is not stored. Figs. 115a-b illustrate how save_pos() operates.
CAAL uses one basic technique for moving information between memory and disk. There is a common structure type that permits a description and the actual data. The description permits the disk file contents to be viewed and edited without reference to other documentation. Both the data and description are stored in ASCII. By specifying a RAM table address, a filename, and the number of records to process, most of the CAAL data can be moved using rd_table() and wrt_table() . See Figs. H6a-b and 117. The input to rd_table() includes a pointer to a destination ram table, a pointer to the name of a source disk file, and a number of records to read. Record length must be less than 60 characters. The input to wrt_table() includes a pointer to a ram table for source, a pointer to a disk file name to write, and a number of records to write.
CAAL ee_to_oldfile() is used to support command line parameter 10. See Figs. 93 and 118a-b. The purpose is to transfer the current system EEPROM 140 contents into the file al_old. Only the parameters needed for calibration are transferred. These are controlled by the ctrl_table[] array which holds commands used to get the data from the system.
CAAL images_to_ee and newfile_to_ee() are part of the support for command line parameter 11. See Fig. 93. After the calculations that compute all the system R, Y, and Z coordinates are completed, images_to_ee() is used to transmit the file data to the system. The calibration points that are not calculated are in table al_new[]. The function newfile_to_ee() is used to transmit the contents of this file to the system. See Figs. H9a-c, 120a-b, 121a-b and 122a-c. CAAL dfile_to_new() is used to transfer the nominal default parameters into the al_new file. The default values are close to where the exact values will be after calibration is completed. This provides a way to get close to the final calibrated locations before any actual calibration information is available for a particular system/ES300 analyzer combination. See Figs. 93 and 123.
CAAL ofile_to_new() provides support for command line parameter 13. When calibration begins, the "old" and "new" information are made identical by use of this function. As calibration proceeds, the new information will change. However, if a section of data is not modified by calibration it will need to be preserved. By starting out with the old data, only part of the system may be calibrated while still preserving the original, unchanged, calibrations. See Figs. 93 and 124.
CAAL old_to_disp() , new_to_disp() are used to support command line parameters 14 and 15. The calibration data stored in each table can be displayed on the screen by using the screen coordinates from ctrl_table[] and the function video_out_line() . These functions are coordinated with ZIM screens so that the old and new data actually fall onto a ZIM template. See Figs. 93, 125 and 126.
The system uses some constants that need to be loaded into the EEPROM 140. CAAL constants_to_eepro () performs this function. This is support for command line parameter 16. See Figs. 93 and 127. The file al_constants contains the data description, system command for transmission, and the data all in one record. This technique permits easier table updating to support new parameters without having to change more than one file.
CAAL make_default() , make_constants() , and make_images() provide support for command line parameters 50, 51, and 52. They are programmer's utilities and are only used for convenience in making the first copy of the files read by CAAL. Once the file is available, it can be read and modified as needed. This first copy is produced to avoid a missing file error. Should the CAAL data structures change, the old versions of CAAL text files should be discarded, and new ones built through the use of these functions. See Figs. 93, 128, 129 and 130. CAAL: make_default() is a programmer's utility used for making a copy of the first al_default file. CAAL: make-constants() is a programmer's utility used for making a copy of the first al_caal_parm file. CAAL: make_images() is a programmer's utility used for making the first copies of the r, y, and z image files.
CAAL save_old() supports command line parameter 10. CAAL save_old() will write the information contained in old_table[] into old_file. See Figs. 93, 116 and 131. CAAL AL-Dispatch() transmits commands to the system. Because the CAAL implementation of AL_Dispatch() is identical in structure to the implementation in ALER, the discussion of ALER can be consulted for an explanation of the operation of AL-Dispatch() . For CAAL, the handling type is set to O so that the trace will appear without the asterisk as in normal operations. This is the only difference between the CAAL and ALER implementations of AL_Dispatch() . See Figs. 132, 133, 134a-b and 135-137. CAAL: AL_Dispatch() , type E section is used for ES300 analyzer communications.
The task ALSC is a temporary task which is used to pass messages from ZIM to ALPR. ALSC is started from ZIM, and is passed one command line parameter. ALSC uses this parameter to decide which message to pass to ALPR.
Table 5 lists all messages passed from ZIM to ALPR through ALSC. ALSC terminates immediately after receiving a reply from ALPR. Passed Parameter Message to ALPR
1 Service Command Ready to be Sent
2 Begin Scan All Tubes Sequence
3 Begin Pipette Sequence
4 Interrupt Current Sequence
5 Continue Current Sequence
6 End Current Sequence
7 Connect to Autoloader
8 Disconnect from Autoloader
9 Start Sensor Test
Table 5
Racks 1 and 2 and their relationship to the rest of the system can further be appreciated by referring to Figs, l and 138. As best illustrated in Figs. 3, 5, 139 and 140, tube racks 300, each carrying from one to ten tubes 304 are placed on the shuttle 302. The shuttle motor 195 is activated during the scan operation and the racks 300 with their tubes 304 are sequentially carried into positions in front of the barcode reader 151 slot opening 310 in the shuttle 302 sidewall. The motion of racks 300 is achieved by the engagement of pins 312 on fifteen drag links 314 uniformly spaced along a drive chain 316. The racks 300 are provided with downwardly facing openings 31β for engagement by the pins 312. During initial set-up of the system, the rack and tube position encoder 225 which is driven from the shuttle 302 through a transmission is adjusted so that its flag 320 breaks the light path through optical switches 223-R and 223-1—223-10 as the barcodes 322-R and 322-1—322-10 of the racks 300 and any tubes 304- 1—304-10, respectively, that they carry reach positions directly in front of opening 310. The barcode reader 151 is thus able to transmit through connector 152 and connector 154 to PC 153 all of the rack 300 and patient identities codified on the barcodes on rack 300 and tubes 304.
Once all of this information has been entered into PC 153, pipetting can begin. Arm 20 and the pipette chuck carriage 324 movably supported by bearings 325 on arm 20 are manipulated by the R, Z and Y motors 183, 185 and 197 over the location of a pipette tip 11 in one of rack 1 or rack 2. The Z motor 165 is actuated to lower arm 20 until the pipette chuck 326 engages the pipette tip 11. A microswitch (not shown) with which pipette chuck 326 is equipped senses, through amplifier 90, force applied by arm 20 to the pipette tip 11. An O-ring 328 with which chuck 326 is provided, helps seal the air circuit 14, while at the same time facilitating fitting and ejection of pipette tips 11. The Z motor 185 is actuated to raise arm 20 above the level of tube racks 300 and the work surfaces of the analyzer 155. The syringe pump 10 is filled with air. The R and Y motors 183, 197 run to position the pipette chuck 326 with its tip 11 over a tube 304 from which a sample is to be taken for testing. The Z motor 185 is then actuated to lower the chuck 326 and tip 11. At the same time, syringe pump 10 pumps air from circuit 14 through tip 11. When transducer 12 detects a slight increase in the pressure in circuit 14 by virtue of the proximity of the surface 16 of the specimen 18 in tube 304, the Z motor 185 is stopped. The remaining air is pumped from syringe pump 10. The Z motor 185 is then actuated to immerse the pipette 11 below the surface 16 of specimen 18 a distance equal to 200μL divided by the cross-sectional area of tube 304 transverse to its cylindrical axis. Syringe pump 10 then aspirates into tip 11 200μL of the specimen 18. If a test to be run on this specimen requires a larger volume, the Z axis motor is then actuated to advance tip 11 a like distance into tube 304 and the syringe pump 10 aspirates another 200μL of the specimen, and so on. The volume is limited to lOOOμL, the capacity of tips 11 in the illustrated embodiment. This procedure minimizes the wetting of the pipette tip with the specimen 18. After an appropriate sample volume has been aspirated into the pipette 11, the Z axis motor 185 is actuated to raise the pipette 11 clear of all work surfaces and tubes 304. Then the R and Y axis motors 183, 197 are actuated to position the sample-containing pipette over a test cup 336 on the ES300 analyzer rotor 340. The Z axis motor 185 is actuated. The Z axis motor runs until the pipette 11 reaches the elevation where it should find the bottom of the test cup 338 and open the microswitch on the input terminals of amplifier 90. If the microswitch does not open, the system interprets this as the absence of a test cup and does not dispense the sample. Contamination of the rotor 340 is avoided. If the microswitch does open, the system interprets that opening as the presence of a test cup 33β. The sample contained in tip 11 is dispensed into the test cup 33B. The Z axis motor 185 is then actuated to raise the pipette tip 11 clear of any work surfaces. The R and Y axis motors 183, 197 are actuated to move the pipette tip 11 over the tip removal station 342. The R and Z axis motors 183, 185 are then manipulated to pull the spent tip 11 from the chuck 326 in order that the spent tip 11 can be dispensed of, and the system returns to get another tip 11.
If a test to be run in a test cup 338 requires more than lOOOμL of sample, up to 2000μL, the R and Y axis motors 183, 197 are actuated to move the pipette tip 11 back over the tube 304 from which the previous sample was withdrawn and the Z axis motor 185 is actuated to lower the pipette tip into the sample. Again, as before, the syringe pump 10 is actuated to expel air from the circuit 14 during this process so that the level 16 of the specimen 18 remaining in tube 304 can be sought. Once level 16 is found, the Z axis motor 185 is again actuated to lower the pipette tip 11 in 200μL increments into specimen 18 and aspirate the sample in 200μL increments until sufficient sample to complete the volume requirement of the test cup 338 is aspirated. Then the Z axis motor 185 is actuated so the pipette 11 will clear the work surfaces and tubes 304, and the R and Y motors 183, 197 are actuated as before the put the pipette tip 11 over the test cup 33B. The Z axis motor is actuated to return the tip 11 to the level of the sample in the test cup, which level has been saved in software. The sample is then dispensed into the test cup 338. The Z axis motor 165 is then actuated so that the pipette 11 will clear the work surfaces, and the R and Y axis motors 183, 197 are actuated to move the pipette tip 11 over the tip removal station 342. The R and Z axis motors 183, 185 are then actuated to pull the spent tip 11 from the chuck 326, and the system returns to get another tip 11.
The manner in which R, Z and Y axis motor 183, 185, 197 is transmitted to the chuck 326 can best be understood by referring to highly diagrammatic Figs. 142 and 143. The R axis motor 183 is coupled 340 to the column 342 in such a manner as to rotate the column 342 about its axis 344. A column rotation encoder wheel 346 is coupled to the bottom end of the column, so that the signals transmitted to inverters 164-11, -13 and -14 are representative of column 342 rotation. Column 342 also is slidably mounted to move axially. A lead screw 352 coupled 354 at its lower end to Z-axis motor 1B5 engages threads provided within column 342, for example, by an acme nut (not shown) in column 342. Rotation of lead screw 352 is detected by an encoder wheel 356 coupled to lead screw 352, so that the signals transmitted to inverters 184-3, -15 and -16 are representative of column 342 projection along the Z axis.
The Y axis motor 197 illustratively is a Portescap US, Inc., type MD162R16M18-210-D16-54-XX motor which has a built-in encoder. Motor 197 drives carriage 324 through a toothed flexible belt 364 trained about a toothed drive wheel 366 on the motor 197 output shaft and a toothed idler wheel 366 rotatably mounted at the remote end of arm 20. Belt 364 is cut and the resulting free ends trained about toothed belt 364 tensioners 370 mounted on carriage 324.

Claims

-66- Claims :
1. A method for transporting a fluid from a first vessel to a second vessel, the method comprising actuating a pump capable of selectively evacuating and pressurizing a gas circuit, the gas circuit having a port for ingress and egress of gas and fluid to be transported to pump gas from the circuit through the port, moving the port toward the surface of the fluid to be transported in the first vessel, monitoring the output signal of a transducer capable of producing an output signal indicative of pressure in the circuit, stopping the movement of the port toward the surface of the fluid in the first vessel when the transducer output signal reaches a first threshold indicating that the fluid surface in the first vessel is in close proximity to the port, immersing the port below the level of the fluid in the first vessel a distance corresponding to a first volume of fluid to be transported, controllably evacuating the gas circuit to aspirate into the port the first volume of fluid while monitoring the transducer output signal, moving the port into proximity to the second vessel, and controllably pressurizing the gas circuit to dispense the first volume of fluid into the second vessel.
2. The method of claim 1 further comprising the step of stopping the evacuation of the gas circuit to stop the aspiration into the port of the first volume if the transducer output signal reaches a second threshold indicating that the port is obstructed.
3. The method of claim 1 further comprising after pressurizing the gas circuit to dispense the first volume of fluid into the second vessel, moving the port back into proximity to the first vessel, monitoring the output signal of the transducer while moving the port toward the surface of the fluid in the first vessel, stopping the movement of the port toward the surface of the fluid in the first vessel when the transducer output signal reaches the first threshold, immersing the port below the level of the fluid in the first vessel a distance corresponding to a second volume of fluid to be transported, controllably evacuating the gas circuit to aspirate into the port the second volume of fluid while monitoring the transducer output signal, moving the port back into proximity to the second vessel, and controllably pressurizing the gas circuit to dispense the second volume of fluid into the second vessel.
4. The method of claim 3 and further comprising before the step of moving the port back into proximity to the first vessel, the step of storing in a memory an index of the location of the port proximate the second vessel, wherein the step of moving the port back into proximity to the second vessel comprises moving the port to a location determined by the index.
PCT/US1994/006940 1993-06-21 1994-06-20 Front end apparatus and method WO1995000829A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP94921977A EP0705424A4 (en) 1993-06-21 1994-06-20 Front end apparatus and method
JP7503013A JPH08511871A (en) 1993-06-21 1994-06-20 Front-end device and method

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US8061393A 1993-06-21 1993-06-21
US08/080,613 1993-06-21

Publications (1)

Publication Number Publication Date
WO1995000829A1 true WO1995000829A1 (en) 1995-01-05

Family

ID=22158489

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1994/006940 WO1995000829A1 (en) 1993-06-21 1994-06-20 Front end apparatus and method

Country Status (4)

Country Link
EP (1) EP0705424A4 (en)
JP (1) JPH08511871A (en)
CA (1) CA2153415A1 (en)
WO (1) WO1995000829A1 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0753750A2 (en) * 1995-07-13 1997-01-15 Ciba Corning Diagnostics Corp. Method and apparatus for aspirating and dispensing sample fluids
EP0785435A1 (en) * 1996-01-22 1997-07-23 JOHNSON & JOHNSON CLINICAL DIAGNOSTICS, INC. Avoiding bubble formation while sensing air-liquid interface using pressurized air flow
WO1999014601A1 (en) * 1997-09-16 1999-03-25 Coulter International Corp. Apparatus and method for detecting vent line failure in an automated blood analyzer
EP0990908A1 (en) * 1998-09-30 2000-04-05 F. Hoffmann-La Roche Ag Automated analyser with means for monitoring pipetting procedures
EP0990909A1 (en) * 1998-09-30 2000-04-05 F. Hoffmann-La Roche Ag Automated analyser with means for monitoring pipetting procedures
US6158269A (en) * 1995-07-13 2000-12-12 Bayer Corporation Method and apparatus for aspirating and dispensing sample fluids
WO2011107472A1 (en) * 2010-03-01 2011-09-09 Novozymes A/S Viscosity pressure assay

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5171352B2 (en) * 2008-03-31 2013-03-27 シスメックス株式会社 Immunoassay apparatus and immunoassay method

Citations (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3650306A (en) * 1970-09-18 1972-03-21 Cooke Eng Co Laboratory dispensing apparatus
US3759667A (en) * 1971-10-22 1973-09-18 Damon Corp Apparatus for aspirating precise volumes of fluid sample
US4077395A (en) * 1975-10-15 1978-03-07 St. Thomas's Hospital Medical School Apparatus for taking blood samples from a living patient
US4231989A (en) * 1977-04-29 1980-11-04 Chandon Investment Planning Ltd. Multichannel system for the handling of immobilized biologically active substances
US4461328A (en) * 1982-06-04 1984-07-24 Drummond Scientific Company Pipette device
US4478094A (en) * 1983-01-21 1984-10-23 Cetus Corporation Liquid sample handling system
US4794085A (en) * 1984-07-19 1988-12-27 Eastman Kodak Company Apparatus and method for detecting liquid penetration by a container used for aspirating and dispensing the liquid
EP0341438A2 (en) * 1988-05-13 1989-11-15 Abbott Laboratories Pneumatic sensing system
US5065800A (en) * 1989-07-24 1991-11-19 Japan Tobacco Inc. Liquid charging method and a liquid charging apparatus
US5132088A (en) * 1988-11-17 1992-07-21 Kabushiki Kaisha Nittec Automatic medical sampling device
US5226462A (en) * 1991-07-26 1993-07-13 Carl Richard A Introducing measured amounts of liquid into receptacles
US5309959A (en) * 1992-08-19 1994-05-10 British Nuclear Fuels Plc Dispensing apparatus

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
NO862717L (en) * 1985-07-05 1987-01-06 Cetus Corp PROCEDURE AND APPARATUS FOR AUTOMATIC BODY TREATMENT.
CA1321940C (en) * 1987-05-02 1993-09-07 Teruaki Itoh Apparatus for distributing sample liquid
EP0311440B1 (en) * 1987-10-09 1992-06-24 Seiko Instruments Inc. Apparatus for carrying out a liquid reaction

Patent Citations (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3650306A (en) * 1970-09-18 1972-03-21 Cooke Eng Co Laboratory dispensing apparatus
US3759667A (en) * 1971-10-22 1973-09-18 Damon Corp Apparatus for aspirating precise volumes of fluid sample
US4077395A (en) * 1975-10-15 1978-03-07 St. Thomas's Hospital Medical School Apparatus for taking blood samples from a living patient
US4231989A (en) * 1977-04-29 1980-11-04 Chandon Investment Planning Ltd. Multichannel system for the handling of immobilized biologically active substances
US4461328A (en) * 1982-06-04 1984-07-24 Drummond Scientific Company Pipette device
US4478094B1 (en) * 1983-01-21 1988-04-19
US4478094A (en) * 1983-01-21 1984-10-23 Cetus Corporation Liquid sample handling system
US4794085A (en) * 1984-07-19 1988-12-27 Eastman Kodak Company Apparatus and method for detecting liquid penetration by a container used for aspirating and dispensing the liquid
EP0341438A2 (en) * 1988-05-13 1989-11-15 Abbott Laboratories Pneumatic sensing system
US5132088A (en) * 1988-11-17 1992-07-21 Kabushiki Kaisha Nittec Automatic medical sampling device
US5065800A (en) * 1989-07-24 1991-11-19 Japan Tobacco Inc. Liquid charging method and a liquid charging apparatus
US5226462A (en) * 1991-07-26 1993-07-13 Carl Richard A Introducing measured amounts of liquid into receptacles
US5309959A (en) * 1992-08-19 1994-05-10 British Nuclear Fuels Plc Dispensing apparatus

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP0705424A4 *

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0753750A2 (en) * 1995-07-13 1997-01-15 Ciba Corning Diagnostics Corp. Method and apparatus for aspirating and dispensing sample fluids
EP0753750A3 (en) * 1995-07-13 1997-09-24 Ciba Corning Diagnostics Corp Method and apparatus for aspirating and dispensing sample fluids
US5750881A (en) * 1995-07-13 1998-05-12 Chiron Diagnostics Corporation Method and apparatus for aspirating and dispensing sample fluids
US6158269A (en) * 1995-07-13 2000-12-12 Bayer Corporation Method and apparatus for aspirating and dispensing sample fluids
EP1329725A2 (en) * 1995-07-13 2003-07-23 Bayer Corporation Method for detecting leaks in an aspirating and dispensing system
EP1329725A3 (en) * 1995-07-13 2003-08-27 Bayer Corporation Method for detecting leaks in an aspirating and dispensing system
EP0785435A1 (en) * 1996-01-22 1997-07-23 JOHNSON & JOHNSON CLINICAL DIAGNOSTICS, INC. Avoiding bubble formation while sensing air-liquid interface using pressurized air flow
WO1999014601A1 (en) * 1997-09-16 1999-03-25 Coulter International Corp. Apparatus and method for detecting vent line failure in an automated blood analyzer
EP0990908A1 (en) * 1998-09-30 2000-04-05 F. Hoffmann-La Roche Ag Automated analyser with means for monitoring pipetting procedures
EP0990909A1 (en) * 1998-09-30 2000-04-05 F. Hoffmann-La Roche Ag Automated analyser with means for monitoring pipetting procedures
US6456944B1 (en) 1998-09-30 2002-09-24 Roche Diagnostics Corporation Automatic analyzer for monitoring pipetting operations
WO2011107472A1 (en) * 2010-03-01 2011-09-09 Novozymes A/S Viscosity pressure assay

Also Published As

Publication number Publication date
EP0705424A1 (en) 1996-04-10
JPH08511871A (en) 1996-12-10
EP0705424A4 (en) 1996-12-04
CA2153415A1 (en) 1995-01-05

Similar Documents

Publication Publication Date Title
US5141871A (en) Fluid dispensing system with optical locator
US5061639A (en) Liquid dispenser accuracy verification method
EP0524307B1 (en) Calibration method for automated assay instrument
US6267927B1 (en) Apparatus for performing laboratory tests automatically
US5646046A (en) Method and instrument for automatically performing analysis relating to thrombosis and hemostasis
EP0355849B1 (en) Method and apparatus for automatic measurement of fluorescence
US4873633A (en) User controlled off-center light absorbance reading adjuster in a liquid handling and reaction system
US5730938A (en) Chemistry analyzer
KR100920652B1 (en) Method for automatic alignment of metering system for a clinical analyzer
EP1186893B1 (en) Analyzer with sample quality measurement, and method
AU688365B2 (en) Method and instrument for automatically performing analysis relating to thrombosis and hemostasis
JP2010101851A (en) Sample analysis device
US5314663A (en) Automatic analysis apparatus for clinical examination
WO1995000829A1 (en) Front end apparatus and method
EP1889662B1 (en) Method of normalizing surface tension of a sample fluid
US20220390936A1 (en) Systems, apparatus, and methods of analyzing specimens
JPH047956B2 (en)
JPH01212361A (en) Automatic chemical analyzer
US20190204347A1 (en) Automated analyzer and retesting instruction system
JPS6361959A (en) Automatic analysis instrument
JPS6324164A (en) Automatic biochemical anlayzing instrument
JPH07311076A (en) Specimen weight detector

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): CA JP

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
WWE Wipo information: entry into national phase

Ref document number: 2153415

Country of ref document: CA

WWE Wipo information: entry into national phase

Ref document number: 1994921977

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 1994921977

Country of ref document: EP

WWW Wipo information: withdrawn in national office

Ref document number: 1994921977

Country of ref document: EP