

NOT RECOMMENDED FOR NEW DESIGNS

# ICL7112

### 12-Bit, High-Speed, CMOS μP-Compatible A/D Converter

January 1998

### Features

- 12-Bit Resolution and Accuracy
- No Missing Codes
- Microprocessor Compatible Byte-Organized Buffered
  Outputs
- Auto-Zeroed Comparator for Low Offset Voltage
- Low Linearity and Gain Errors
- Low Power Consumption (60mW)
- No Gain or Offset Adjustment Necessary
- Provides 3% Usable Overrange
- Fast Conversion (40μs)

### Description

The ICL7112 is a monolithic 12-bit resolution, fast successive approximation A/D converter. It uses thin film resistors and CMOS circuitry combined with an on-chip PROM calibration table to achieve 12-bit linearity without laser trimming. Special design techniques used in the DAC and comparator result in high speed operation, while the fully static silicon-gate CMOS circuitry keeps the power dissipation very low.

Microprocessor bus interfacing is eased by the use of standard memory  $\overline{WRite}$  and  $\overline{ReaD}$  cycle timing and control signals, combined with  $\overline{Chip}$  Select and Address pins. The digital output pins are byte-organized and three-state gated for bus interface to 8-bit and 16-bit systems.

The ICL7112 provides separate Analog and Digital grounds for increased system accuracy. Operating with  $\pm$ 5V supplies, the ICL7112 accepts 0V to +10V input with a -10V reference or 0V to -10V input with a +10V reference.

| PART NO.    | TEMP. RANGE ( <sup>O</sup> C) | PACKAGE      | RESOLUTION WITH NO MISSION<br>CODES |
|-------------|-------------------------------|--------------|-------------------------------------|
| ICL7112JCDL | 0 to 70                       | 40 Ld CERDIP | 11-Bit                              |
| ICL7112KCDL | 0 to 70                       | 40 Ld CERDIP | 12-Bit                              |
| ICL7112LCDL | 0 to 70                       | 40 Ld CERDIP | 12-Bit (Note)±                      |
| ICL7112JIDL | -25 to 85                     | 40 Ld CERDIP | 11-Bit                              |
| ICL7112KIDL | -25 to 85                     | 40 Ld CERDIP | 12-Bit                              |
| ICL7112LIDL | -25 to 85                     | 40 Ld CERDIP | 12-Bit (Note)±                      |
| ICL7112JMDL | -55 to 125                    | 40 Ld CERDIP | 11-Bit                              |
| ICL7112KMDL | -55 to 125                    | 40 Ld CERDIP | 12-Bit                              |
| ICL7112LMDL | -55 to 125                    | 40 Ld CERDIP | 12-Bit (Note)±                      |

### **Ordering Information**

NOTE: Over operating temperature range.



### Absolute Maximum Ratings $T_A = 25^{\circ}C$

| Supply Voltage (V <sup>+</sup> to DGND)0.3V to +6.5V   |
|--------------------------------------------------------|
| Supply Voltage (V <sup>-</sup> to DGND) +0.3V to -6.5V |
| V <sub>REF</sub> , V <sub>IN</sub> to DGND             |
| AGND to DGND                                           |
| V <sub>REF</sub> , V <sub>IN</sub> , AGND Current      |
| Digital I/O Pin Voltages                               |
| PROG to DGND Voltage V <sup>-</sup> to (V+ +0.3V)      |

### **Thermal Information**

| Thermal Resistance (Typical, Note 1)<br>CERDIP Package                                                                  | θ <sub>JA</sub> ( <sup>o</sup> C/W) | θ <sub>JC</sub> ( <sup>o</sup> C/W)  |
|-------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------|
| Maximum Power Dissipation (Note 2)<br>Derate above 70°C at 10mW/°C                                                      |                                     | 500mW                                |
| Maximum Junction Temperature (Ceramic I<br>Maximum Storage Temperature Range .<br>Maximum Lead Temperature (Soldering 1 | 65 <sup>0</sup>                     | <sup>o</sup> C to 150 <sup>o</sup> C |

### **Operating Conditions**

| ICL7112XCXX0 to 70 |
|--------------------|
| ICL7112XIXX        |
| ICL7112XMXX        |

CAUTION: Stresses above those listed in "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress only rating and operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied.

### NOTES:

1.  $\theta_{JA}$  is measured with the component mounted on an evaluation PC board in free air.

2. All voltages with respect to DGND, unless otherwise noted.

3. Assumes all leads soldered or welded to printed circuit board.

### J Κ L TEST CONDITIONS SYMBOL TYP ТҮР TYP MAX PARAMETER MIN MAX MIN MAX MIN UNITS ACCURACY Resolution RES 12 Bits Resolution with No RES Notes 4, 5, 6 11 12 $R_M$ 12 Bits (NMC) Missing Codes T<sub>MIN</sub> -T<sub>MAX</sub> 10 11 12 Notes 4, 5 ±0.012 %FSR Integral Linearity $R_M$ --±0.024 \_ -±0.012 -ILE \_ ±0.030 ±0.020 ±0.020 Error T<sub>MIN</sub> -T<sub>MAX</sub> Unadjusted Full FSE С Adjust-R<sub>M</sub> ±0.10 -±0.08 \_ ±0.08 $T_{MIN} T_{MAX}$ Scale Error able to ±0.12 ±0.10 ±0.10 Zero R<sub>M</sub> ±0.10 ±0.08 ±0.08 ---T<sub>MIN</sub> -T<sub>MAX</sub> ±0.13 $\pm 0.11$ ±0.11 %FSR ±0.10 ±0.08 ±0.08 Μ R<sub>M</sub> ----T<sub>MIN</sub> -T<sub>MAX</sub> ±0.14 ±0.12 ±0.12 Zero Error ZE Notes 4, 5 R<sub>M</sub> ±1 -\_ +1 -+1 \_ -T<sub>MIN</sub> -T<sub>MAX</sub> ±1.5 ±1.5 ±1.5 ANALOG INPUT v Analog Input V<sub>IN</sub> 0 \_ 10.3 0 \_ 10.3 0 \_ 10.3 Range Input Resistance Notes 5, 8 4 9 4 9 4 9 R<sub>IN</sub> kΩ --ppm/<sup>o</sup>C Temperature -300 -300 -300 T<sub>C</sub> (R<sub>IN</sub>) T<sub>MIN</sub> -T<sub>MAX</sub> --\_ -Coefficient of RIN **REFERENCE INPUT** Analog Reference -10.0 -10.0 -10.0 ٧ VREF ------Reference R<sub>REF</sub> 5 5 5 kΩ Resistance POWER SUPPLY SENSITIVITY $V^+, V^- = 4.5 - 5.5V$ Power Supply PSRR RM -±0.5 ±1 -±0.5 ±1 ±0.5 ±1 LSB **Rejection Ration** T<sub>MIN</sub> -T<sub>MAX</sub> +2±2 ±2 LOGIC INPUT Low State $V_{IL}$ T<sub>MIN</sub> -T<sub>MAX</sub> 0.8 0.8 0.8 V \_ \_ \_ \_ Input Voltage

### **Electrical Specifications** Test Conditions: V + = +5V, V - = -5V, $V_{REF} = -10V$ , $T_A = 25^{\circ}C$ , $f_{CLK} = 500$ kHz, Unless Otherwise Noted

### ICL7112

|                               |                     | TEST                                                            |      | J   |        | К    |     | L      |      |     |        |       |
|-------------------------------|---------------------|-----------------------------------------------------------------|------|-----|--------|------|-----|--------|------|-----|--------|-------|
| PARAMETER                     | SYMBOL              | CONDITIONS                                                      | MIN  | TYP | MAX    | MIN  | ТҮР | MAX    | MIN  | ТҮР | MAX    | UNITS |
| High State<br>Input Voltage   | V <sub>IH</sub>     | T <sub>MIN</sub> -T <sub>MAX</sub>                              | 2.4  | -   | -      | 2.4  | -   | -      | 2.4  | -   | -      | V     |
| Logic Input<br>Current        | I <sub>LIH</sub>    | 0 < V <sub>IN</sub> < V <sup>+</sup>                            | -    | 1   | 10     | -    | 1   | 10     | -    | 1   | 10     | μΑ    |
| Logic Input<br>Capacitance    | C <sub>IN</sub>     |                                                                 | -    | 15  | -      | -    | 15  | -      | -    | 15  | -      | pF    |
| LOGIC OUTPUT                  |                     |                                                                 |      |     |        |      |     |        |      |     |        |       |
| Low State Output<br>Voltage   | V <sub>OL</sub>     | I <sub>OUT</sub> = 1.6mA<br>T <sub>MIN</sub> -T <sub>MAX</sub>  | -    | -   | 0.4    | -    | -   | 0.4    | -    | -   | 0.4    | V     |
| High State Output<br>Voltage  | V <sub>OH</sub>     | I <sub>OUT</sub> = -200μA<br>T <sub>MIN</sub> -T <sub>MAX</sub> | 2.8  | -   | -      | 2.8  | -   | -      | 2.8  | -   | -      | V     |
| Three-State Output<br>Current | I <sub>OX</sub>     | 0 < V <sub>OUT</sub> < V <sup>+</sup>                           | -    | 1   | -      | -    | 1   | -      | -    | 1   | -      | μΑ    |
| Logic Output<br>Capacitance   | C <sub>OUT</sub>    | Three-State                                                     | -    | 15  | -      | -    | 15  | -      | -    | 15  | -      | pF    |
| POWER REQUIRE                 | MENTS               |                                                                 |      |     |        |      |     |        |      |     |        |       |
| Supply Voltage<br>Range       | V <sub>SUPPLY</sub> | Functional Operation Only                                       | ±4.5 | -   | ±6.0   | ±4.5 | -   | ±6.0   | ±4.5 | -   | ±6.0   | V     |
| Supply Current,<br>I+, I-     | ISUPPLY             | R <sub>M</sub><br>T <sub>MIN</sub> -T <sub>MAX</sub>            | -    | 2   | 4<br>6 | -    | 2   | 4<br>6 | -    | 2   | 4<br>6 | mA    |

NOTES:

4. Full scale range (FSR) is 10V (reference adjusted).

5. Assume all leads are soldered or welded to printed circuit board.

6. "J" and "K" versions not production tested. Guaranteed by Integral Linearity Test.

7. Typical values are not tested, for reference only.

8. Not production tested. Guaranteed by design.

## AC Electrical Specifications Test Conditions V + = +5V, V - = -5V, $T_A = 25^{\circ}C$ , $f_{CLK} = 500$ kHz, unless otherwise noted. Data derived from extensive characterization testing. Parameters are not production tested

| PARAMETER                                 | SYMBOL            | TEST<br>CONDITIONS           | MIN | ТҮР | МАХ | UNITS              |
|-------------------------------------------|-------------------|------------------------------|-----|-----|-----|--------------------|
| READ CYCLE TIMING                         | •                 |                              |     |     | •   | •                  |
| Propagation Delay $\overline{CS}$ to Date | t <sub>cd</sub>   | RD Low, A <sub>0</sub> Valid | -   | -   | 200 |                    |
| Propagation Delay A <sub>0</sub> to Data  | t <sub>ad</sub>   | CS Low, RD Low               | -   | -   | 200 | 1                  |
| Propagation Delay RD to Data              | t <sub>rd</sub>   | CS Low, A <sub>0</sub> Valid | -   | -   | 200 | ns                 |
| Propagation Delay Data to Three-State     | t <sub>rx</sub>   |                              | -   | -   | 150 | 1                  |
| Propagation Delay EOC High to Data        | t <sub>ed</sub>   |                              | -   | -   | 200 | 1                  |
| WRITE CYCLE TIMING                        | •                 |                              |     |     |     |                    |
| WR Low Time                               | t <sub>wr</sub>   |                              | 150 | -   | -   | ns                 |
| Propagation Delay WR Low to EOC Low       | t <sub>we</sub>   | Wait Mode                    | 1   | -   | 2   |                    |
| EOC High Time                             | t <sub>eo</sub>   | Free Run Mode                | 0.5 | -   | 1.5 | 1/f <sub>CLK</sub> |
| Conversion Time                           | t <sub>conv</sub> |                              | -   | -   | 20  | 1                  |
| Clock Frequency Range                     | fCLK              | Functional Operation Only    | -   | 500 | -   | kHz                |

NOTE:

9. All typical values have been characterized, but are not tested.

### Pin Descriptions

| PIN NO. | NAME              | DESCRIF                                                                                | PTION                 |                |
|---------|-------------------|----------------------------------------------------------------------------------------|-----------------------|----------------|
| 1       |                   | No connection.                                                                         |                       |                |
| 2       | AGND <sub>f</sub> | FORCE input for analog ground.                                                         |                       |                |
| 3       | CS                | Chip Select enables reading and writing (a                                             | ctive low).           |                |
| 4       | RD                | ReaD (active low).                                                                     |                       |                |
| 5       | A <sub>0</sub>    | Byte select (low = $D_0 - D_7$ , high = $D_8 - D_{11}$ ,                               | OVR).                 |                |
| 6       | BUS               | Bus select (low = outputs enabled by $A_0$ , h                                         | igh = all outputs ena | bled togethe   |
| 7       | DGND              | Digital GrouND return.                                                                 |                       |                |
| 8       | D <sub>11</sub>   | Bit 11 (most significant bit).                                                         |                       |                |
| 9       | D <sub>10</sub>   | Bit 10                                                                                 |                       |                |
| 10      | D <sub>9</sub>    | Bit 9                                                                                  |                       | Link Dute      |
| 11      | D <sub>8</sub>    | Bit 8                                                                                  |                       | High Byte      |
| 12      | D <sub>7</sub>    | Bit 7                                                                                  | Dutput                |                |
| 13      | D <sub>6</sub>    | Bit 6                                                                                  | Data                  |                |
| 14      | D <sub>5</sub>    | Bit 5                                                                                  | Bits                  |                |
| 15      | D <sub>4</sub>    | Bit 4 (Hig                                                                             | Jh =True)             |                |
| 16      | D <sub>3</sub>    | Bit 3                                                                                  | ,                     |                |
| 17      | D <sub>2</sub>    | Bit 2                                                                                  |                       | Low Byte       |
| 18      | D <sub>1</sub>    | Bit 1                                                                                  |                       |                |
| 19      | D0                | Bit 0 (least significant bit).                                                         |                       |                |
| 20      |                   | No connection.                                                                         |                       |                |
| 21      |                   | No connection.                                                                         |                       |                |
| 22      |                   | No connection.                                                                         |                       |                |
| 23      |                   | No connection.                                                                         |                       |                |
| 24      |                   | No connection.                                                                         |                       |                |
| 25      | EOC               | End of conversion flag (low = busy, high =                                             | conversion complete   | ).             |
| 26      | OVR               | OVerRange flag (valid at end of conversior three-state output enabled with high byte). |                       | exceeds full-s |
| 27      | V+                | Positive power supply input.                                                           |                       |                |
| 28      | PROG              | Used for programming only. Must tie to V <sup>+</sup>                                  | for normal operation  |                |
| 29      | TEST              | Used for programming only. Must tie to V <sup>+</sup>                                  | for normal operation  |                |
| 30      | OSC1              | Oscillator inverter input.                                                             |                       |                |
| 31      | OSC2              | Oscillator inverter output.                                                            |                       |                |
| 32      | TEST              | Must tie to V <sup>+</sup> for normal operation.                                       |                       |                |
| 33      | WR                | WRite pulse input (low starts new conversi                                             | on).                  |                |
| 34      | C <sub>AZ</sub>   | Auto-zero capacitor connection (Note).                                                 |                       |                |
| 35      | V-                | Negative power supply input.                                                           |                       |                |
| 36      | COMP              | Used in test, tie to $V^-$ .                                                           |                       |                |
| 37      | V <sub>IN</sub>   | SENSE line for input voltage.                                                          |                       |                |
| 38      | V <sub>REF</sub>  | SENSE line for reference input.                                                        |                       |                |
| 39      | AGNDs             | SENSE line for analog ground.                                                          |                       |                |
| 40      | - 3               | No connection                                                                          |                       |                |

### Timing Diagrams CS A۵ VALID t∆n RD 🖛 t<sub>RD</sub> t<sub>RX</sub> VALID D<sub>0</sub> - D<sub>13</sub> t<sub>ED</sub> EOC = DON'T CARE FIGURE 1. READ CYCLE TIMING CS twR WR twe EOC t<sub>EO</sub> = DON'T CARE

FIGURE 2. WRITE CYCLE TIMING

### TABLE 2: I/O CONTROL

| CS | WR | RD | $A_0$ | BUS | FUNCTION                             |
|----|----|----|-------|-----|--------------------------------------|
| 0  | 0  | х  | х     | х   | Initiates a conversion.              |
| 1  | х  | х  | х     | х   | Disables all chip commands.          |
| 0  | х  | 0  | 0     | 0   | Low byte is enabled.                 |
| 0  | х  | 0  | 1     | 0   | High byte is enabled.                |
| 0  | х  | 0  | х     | 1   | Low and High bytes enabled together. |
| х  | х  | 1  | х     | х   | Disables outputs (high-impedance).   |

| TABLE 3  | TRANSFER | FUNCTION |
|----------|----------|----------|
| IADEE 0. |          |          |

| INPUT VOLTAGE                                  | EXPECTED OUTPUT CODE |                  |                                                   |                  |  |  |
|------------------------------------------------|----------------------|------------------|---------------------------------------------------|------------------|--|--|
| V <sub>REF</sub> = -10.0V                      | OVR                  | MSB              |                                                   | LSB              |  |  |
| 0<br>+0.00244                                  | 0<br>0               | 0<br>0           | 000000000<br>0000000000                           | 0<br>1           |  |  |
| +0.30029                                       | 0                    | 0                | 0000111101                                        | 1                |  |  |
| +4.99756<br>+5.00000                           | 0<br>0               | 0<br>1           | 1111111111<br>0000000000                          | 1<br>0           |  |  |
| +9.99512<br>+9.99756<br>+10.00000<br>+10.00244 | 0<br>0<br>1<br>1     | 1<br>1<br>0<br>0 | 1111111111<br>1111111111<br>0000000000<br>0000000 | 0<br>1<br>0<br>1 |  |  |
| +10.29000                                      | 1                    | 0                | 0000111101                                        | 1                |  |  |

### **Detailed Description**

The ICL7112 is basically a successive approximation A/D converter with an internal structure much more complex than

a standard SAR-type converter. The Functional Block Diagram shows the functional diagram of the ICL7112 12-bit A/D converter. The additional circuitry incorporated into the ICL7112 is used to perform error correction and to maintain the operating speed in the  $40\mu$ s range.

The internal DAC of the ICL7112 is designed around a radix of 1.85, rather than the traditional 2.00. This radix gives each bit of the DAC a weight of approximately 54% of the previous bit. The result is a usable range that extends to 3% beyond the full-scale input of the A/D. The actual value of each bit is measured and stored in the on-chip PROM. The absolute value of each bit weight then becomes relatively unimportant because of the error correction action of the ICL7112.

The output of the high-speed auto-zeroed comparator is fed to the data input of a successive approximation register (SAR). This register is uniquely designed for the ICL7112 in that it tests bit pairs instead of individual bits in the manner of a standard SAR. At the beginning of the conversion cycle, the SAR turns on the MSB (D<sub>11</sub>) and the MSB 4-bit (D<sub>7</sub>). The sequence continues for each bit pair, B<sub>X</sub> and B<sub>x-4</sub>, until only the four LSBs remain. The sequence concludes by testing the four LSBs individually.

The SAR output is fed to the DAC register and to the preprogrammed PROM where it acts as PROM address. PROM data is fed to a full-adder/accumulator where the decoded results from each successive phase of the conversion are summed with the previous results. After 20 clock cycles, the accumulator contains the final binary data which is latched and sent to the three-state output buffers. The accuracy of the A/D converter depends primarily upon the accuracy of the data that has been programmed into the PROM during the final test portion of the manufacturing process.

The error correcting algorithm built into the ICL7112 reduces the initial accuracy requirements of the DAC. The overlap in the testing of bit pairs reduces the accuracy requirements on the comparator which has been optimized for speed. Since the comparator is auto-zeroed, no external adjustment is required to get ZERO code for ZERO input voltage.

Twenty clock cycles are required for the complete 12-bit conversion. The auto-zero circuitry associated with the comparator is employed during the last three clock cycles of the conversion to cancel the effect of offset voltage. Also during this time, the SAR and accumulator are reset in preparation for the start of the next conversion.

The overflow output of the full-adder is also the OVer Range (OVR) output of the ICL7112. Unlike standard SAR type A/D converters, the ICL7112 has the capability of providing valid usable data for inputs that exceed the fullscale range by as much as 3%.

### **Optimizing System Performance**

When using A/D converters with 12 or more bits of resolution, special attention must be paid to grounding and the elimination of potential ground loops. A ground loop can be formed by allowing the return current from the ICL7112's DAC to flow through traces that are common to other analog circuitry. If care is not taken, this current can generate small unwanted voltages that add to or detract from the reference or input voltages of the A/D converter.

Figure 3 and Figure 4 show two different grounding techniques. Although the difference between the two circuits may not be readily apparent, the circuit of Figure 3 is very likely to have significant ground loop errors which the circuit of Figure 4 avoids. In Figure 3, the supply currents for analog ground, digital ground, and the reference voltage all flow through a lead, common to the input. This will generate a DC offset voltage due to the currents flowing in the resistance of the common lead. This offset voltage will vary with the input voltage and with the digital output. Even the auto-zero loop of the ICL7112 cannot remove this error.

Figure 4 shows a much better arrangement. The ground and reference currents do not flow through the input common lead, eliminating any error voltages. Note that the supply currents and any other analog system currents must also be returned carefully to analog ground. The clamp diodes will protect the ICL7112 against signals which could result from separate analog and digital grounds. The absolute maximum voltage rating between AGND and DGND is  $\pm 1.0V$ . The two inverse-parallel diodes clamp this voltage to less than  $\pm 0.7V$ .

### Input Warning

As with any CMOS integrated circuit, no input voltages should be applied to the ICL7112 until the  $\pm 5V$  power supplies have stabilized.

### Interfacing To Digital Systems

The\_ICL7112 provides three-state data output buffers,  $\overline{CS}$ ,  $\overline{RD}$ ,  $\overline{WR}$ , and bus select inputs (A<sub>0</sub> and BUS) for interfacing to a wide variety of microcomputers and digital systems. The I/O Control Truth Table shows the functions of the digital control lines. The BUS select and A<sub>0</sub> lines are provided to enable the output data onto either 8-bit or 16-bit data buses. A conversion is initiated by a  $\overline{WR}$  pulse (pin 33) when  $\overline{CS}$  (pin 3) is low. Data is enabled on the bus when the chip is selected and  $\overline{RD}$  (pin 4) is low.

Figure 5 illustrates a typical interface to an 8-bit microcomputer. The "Start and Wait" operation requires the fewest external components and is initiated by a low level on the  $\overline{WR}$  input to the ICL7112 after the I/O or memory mapped address decoder has brought the  $\overline{CS}$  input low. After executing a delay or utility routine for a period of time greater than the conversion time of the ICL7112, the processor issues two consecutive bus addresses to read output data into two bytes of memory. A low level on A<sub>0</sub> enables the LSBs, and a high level enables the MSBs.



FIGURE 3. IMPROPER GROUNDING TECHNIQUE WILL CAUSE GROUND LOOP ERRORS





By adding a three-state buffer and two control gates, the End-of-Conversion (EOC) output can be used to control a "Start and Poll" interface (Figure 6). In this mode, the  $A_0$  and CS lines connect the EOC output to the data bus along with the most significant byte of data. After pulsing the  $\overline{WR}$  line to initiate a conversion, the microprocessor continually reads the most significant byte until it detects a high level on the EOC bit. The "Start and Poll" interface increases data throughput compared with the "Start and Wait" method by eliminating delays between the conversion termination and the microprocessor read operation.

Other interface configurations can be used to increase data throughput without monopolizing the microprocessor during waiting or polling operations by using the EOC line as an interrupt generator as shown in Figure 7. After the conversion cycle is initiated, the microprocessor can continue to execute routines that are independent of the A/D converter until the converter's output register actually holds valid data. For fastest data throughput, the ICL7112 can be connected directly to the data bus but controlled by way of a Direct

Memory Access (DMA) controller as shown in Figure 8.

### **Applications**

Figure 9 shows a typical application of the ICL7112 12- bit A/D converter. A bipolar input voltage range of +10V to -10V is the result of using the current through R<sub>2</sub> to force a 1/2 scale offset on the input amplifier (A<sub>1</sub>). The output of A<sub>1</sub> swings from 0V to -1 0V. The overall gain of the A/D is varied by adjusting the 100 $\Omega$  trim resistor, R<sub>5</sub>. Since the ICL7112 is automatically zeroed every conversion, the system gain and offset stability will be superb as long as a reference with a tempco of 1ppm/<sup>o</sup>C and stable external resistors are used.

If is important to note that since the 7112's DAC current flows in  $A_1$ , the amplifier should be a wideband (GBW > 20MHz) type to minimize errors.

The clock for the ICL7112 is taken from whatever system clock is available and divided down to the level for a conversion time of 40 $\mu$ s. Output data is controlled by the BUS and A<sub>0</sub> inputs. Here they are set for 8-bit bus operation with BUS grounded and A<sub>0</sub> under the control of the address decode section of the external system.

Because the ICL7112's internal accumulator generates accurate output data for input signals as much as 3% greater than full-scale, and because the converter's OVR output flags overrange inputs, a simple microprocessor routine can be employed to precisely measure and correct for system gain and offset errors. Figure 10 shows a typical data acquisition system that uses a 10V reference, input signal multiplexer, and input signal Track/Hold amplifier. Two of the multiplexer's input channels are dedicated to sampling the system analog ground and reference voltage. Here, as in Figure 9, bipolar operation is accommodated by an offset resistor between the reference voltage and the summing junction of  $A_1$ . A flip-flop in IC<sub>3</sub> sets  $1_{C2}$ 's Track/Hold input after the microprocessor has initiated a WR command, and resets when EOC goes high at the end of the conversion.

The first step in the system calibration routine is to select the multiplexer channel that is connected to system analog ground and initiate a conversion cycle for the ICL7112. The results represent the system offset error which comes from the sum of the offsets from IC<sub>1</sub>, IC<sub>2</sub>, and A<sub>1</sub>. Next the channel connected to the reference voltage is selected and measured. These results, minus the system offset error, represent the system full-scale range. A gain error correction factor can be derived from this data. Since the ICL7112 provides valid data for inputs that exceed full-scale by as much as 3%, the OVR output can be thought of as a valid 13th data bit. Whenever the OVR bit is high, however, the total 12-bit result should be checked to ensure that it falls within 100% and 103% of full-scale. Data beyond 103% of full-scale should be discarded.

### **Clock Considerations**

The ICL7112 provides an internal inverter which is brought out to pins OSC1 and OSC2, for crystal or ceramic resonator oscillator operation. The clock frequency is calculated from:

$$f_{CLK} = \frac{20}{t_{CONV}}$$



FIGURE 6. START AND POLL" OPERATION







FIGURE 8. DATA TO MEMORY VIA DMA CONTROLLER



FIGURE 9. TYPICAL APPLICATION WITH BIPOLAR INPUT RANGE, FORCED GROUND, AND 10V ULTRA STABLE REFERENCE

