

# DAC1000/DAC1001/DAC1002/DAC1006/DAC1007/ DAC1008 μP Compatible, Double-Buffered D to A Converters

# **General Description**

The DAC1000/1/2 and DAC1006/7/8 are advanced CMOS/Si-Cr 10-, 9- and 8-bit accurate multiplying DACs which are designed to interface directly with the 8080, 8048, 8085, Z-80 and other popular microprocessors. These DACs appear as a memory location or an I/O port to the  $\mu P$  and no interfacing logic is needed.

These devices, combined with an external amplifier and voltage reference, can be used as standard D/A converters; and they are very attractive for multiplying applications (such as digitally controlled gain blocks) since their linearity error is essentially independent of the voltage reference. They become equally attractive in audio signal processing equipment as audio gain controls or as programmable attenuators which marry high quality audio signal processing to digitally based systems under microprocessor control.

All of these DACs are double buffered. They can load all 10 bits or two 8-bit bytes and the data format can be either right justified or left justified. The analog section of these DACs is essentially the same as that of the DAC1020.

The DAC1000 series are the 10-bit members of a family of microprocessor-compatible DAC's (MICRO-DACTM's). For applications requiring other resolutions, the DAC0830 series (8 bits) and the DAC1208 and DAC1230 (12 bits) are available alternatives.

| Part #  | Accuracy<br>(bits) | Pin | Description |
|---------|--------------------|-----|-------------|
| DAC1000 | 10                 |     | Has all     |
| DAC1001 | 9                  | 24  | logic       |
| DAC1002 | 8                  |     | features    |
| DAC1006 | 10                 |     | For left-   |
| DAC1007 | 9                  | 20  | justified   |
| DAC1008 | 8                  |     | data        |

## **Features**

- Uses easy to adjust END POINT specs, NOT BEST STRAIGHT LINE FIT
- Low power consumption
- Direct interface to all popular microprocessors.
- Integrated thin film on CMOS structure
- Double-buffered, single-buffered or flow through digital data inputs.
- Loads two 8-bit bytes or a single 10-bit word.
- Logic inputs which meet TTL voltage level specs (1.4V logic threshold).
- Works with ±10V reference—full 4-quadrant multiplica-
- Operates STAND ALONE (without µP) if desired.
- Available in 0.3" standard 20-pin and 0.6" 24-pin package.
- Differential non-linearity selection available as special order.

# **Key Specifications**

■ Output Current Settling Time

500 ns

Resolution

10 bits

■ Linearity

10, 9, and 8 bits (quaranteed over temp.)

■ Gain Tempco

-0.0003% of FS/°C

 Low Power Dissipation (including ladder) 20 mW

Single Power Supply

5 to 15 V<sub>DC</sub>

# **Typical Application**

#### DAC1006/1007/1008



# Absolute Maximum Ratings (Notes 1 & 2)

If Military/Aerospace specified devices are required, please contact the National Semiconductor Sales Office/Distributors for availability and specifications.

DC Voltage Applied to I<sub>OUT1</sub> or I<sub>OUT2</sub>

(Note 4) —100 mV to V<sub>CC</sub>

ESD Susceptibility (Note 11)

Lead Temp. (Soldering, 10 seconds)

Dual-In-Line Package (plastic)
Dual-In-Line Package (ceramic)

800V 260°C 300°C

Operating Ratings (Note 1)

Temperature Range
Part numbers with 'LCN' suffix
Part numbers with 'LCJ' suffix
Part numbers with 'LJ' suffix

 $T_{MIN} \le T_{A} \le T_{MAX}$ 0°C to 70°C
-40°C to +85°C
-55°C to +125°C

Voltage at Any Digital Input

V<sub>CC</sub> to GND

# **Electrical Characteristics**

Tested at  $V_{CC} = 4.75 \ V_{DC}$  and 15.75  $V_{DC}$ ,  $T_A = 25^{\circ}C$ ,  $V_{REF} = 10.000 \ V_{DC}$  unless otherwise noted

| Parameter                                                                                                    | Conditions                                                                                                                                                    | See           | V <sub>CC</sub> = 12V <sub>DC</sub> ± 5%<br>to 15V <sub>DC</sub> ± 5% |                        |                    | V <sub>CC</sub> = 5V <sub>DC</sub> ± 5% |                        |                    | Units                                  |
|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------------------------------------------|------------------------|--------------------|-----------------------------------------|------------------------|--------------------|----------------------------------------|
|                                                                                                              |                                                                                                                                                               | HOLE          | Min.                                                                  | Тур.                   | Max.               | Min.                                    | Тур.                   | Max.               |                                        |
| Resolution                                                                                                   |                                                                                                                                                               |               |                                                                       |                        | 10                 |                                         |                        | 10                 | bits                                   |
| Linearity Error                                                                                              | Endpoint adjust only T <sub>MIN</sub> < T <sub>A</sub> < T <sub>MAX</sub> − 10V ≤ V <sub>REF</sub> ≤ ± 10V DAC1000 and 1006 DAC1001 and 1007 DAC1002 and 1008 | 4,7<br>6<br>5 |                                                                       |                        | 0.05<br>0.1<br>0.2 |                                         |                        | 0.05<br>0.1<br>0.2 | % of FSR<br>% of FSR<br>% of FSR       |
| Differential<br>Nonlinearity                                                                                 | Endpoint adjust only T <sub>MIN</sub> < T <sub>A</sub> < T <sub>MAX</sub> − 10V ≤ V <sub>REF</sub> ≤ + 10V DAC1000 and 1006 DAC1001 and 1007 DAC1002 and 1008 | 4,7<br>6<br>5 |                                                                       |                        | 0.1<br>0.2<br>0.4  |                                         |                        | 0.1<br>0.2<br>0.4  | % of FSR<br>% of FSR<br>% of FSR       |
| Monotonicity                                                                                                 | T <sub>MIN</sub> < T <sub>A</sub> < T <sub>MAX</sub><br>− 10V ≤ V <sub>REF</sub> ≤ + 10V<br>DAC1000 and 1006<br>DAC1001 and 1007<br>DAC1002 and 1008          | 4,6<br>5      | 10<br>9<br>8                                                          |                        |                    | 10<br>9<br>8                            |                        |                    | bits<br>bits<br>bits                   |
| Gain Error                                                                                                   | Using internal R <sub>fb</sub><br>-10V≤V <sub>REF</sub> ≤+10V                                                                                                 | 5             | -1.0                                                                  | ± 0.3                  | 1.0                | -1.0                                    | ±0.3                   | 1.0                | % of FS                                |
| Gain Error Tempco                                                                                            | T <sub>MIN</sub> <t<sub>A<t<sub>MAX<br/>Using internal R<sub>fb</sub></t<sub></t<sub>                                                                         | 6<br>9        |                                                                       | -0.0003                | -0.001             |                                         | -0.0006                | -0.002             | % of FS/°C                             |
| Power Supply<br>Rejection                                                                                    | All digital inputs<br>latched high<br>V <sub>CC</sub> = 14.5V to 15.5V<br>11.5V to 12.5V<br>4.75V to 5.25V                                                    |               |                                                                       | 0.003<br>0.004         | 0.008<br>0.010     |                                         | 0.033                  | 0.10               | % FSR/V<br>% FSR/V<br>% FSR/V          |
| Reference Input<br>Resistance                                                                                |                                                                                                                                                               |               | 10                                                                    | 15                     | 20                 | 10                                      | 15                     | 20                 | kΩ                                     |
| Output Feedthrough<br>Error                                                                                  | V <sub>REF</sub> = 20V <sub>p-p</sub> , f=100 kHz<br>All data inputs<br>latched low<br>D Package<br>N Package                                                 |               |                                                                       | 130<br>90              |                    |                                         | 130<br>90              |                    | mV <sub>p-p</sub><br>mV <sub>p-p</sub> |
| Output I <sub>OUT1</sub> Capacitance I <sub>OUT2</sub> I <sub>OUT1</sub> I <sub>OUT2</sub> I <sub>OUT2</sub> | All data inputs<br>latched low<br>All data inputs<br>latched high                                                                                             |               |                                                                       | 60<br>250<br>250<br>60 |                    |                                         | 60<br>250<br>250<br>60 |                    | pF<br>pF<br>pF<br>pF                   |
| Supply Current Drain                                                                                         | T <sub>MIN</sub> ST <sub>A</sub> ST <sub>MAX</sub>                                                                                                            | 6             |                                                                       | 0.5                    | 3.5                |                                         | 0.5                    | 3.5                | mA                                     |

# **Electrical Characteristics**

Tested at  $V_{CC} = 4.75 V_{DC}$  and 15.75  $V_{DC}$ ,  $T_A = 25$ °C,  $V_{REF} = 10.000 V_{DC}$  unless otherwise noted (Continued)

| Parameter                                   |                 | Conditions                                                                                                                | See<br>Note | V <sub>CC</sub> = 12V <sub>DC</sub> ± 5%<br>to 15V <sub>DC</sub> ± 5% |            |                                         | V <sub>CC</sub> = 5V <sub>DC</sub> ± 5% |            |                 | Units                                                 |
|---------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------------------------------|------------|-----------------------------------------|-----------------------------------------|------------|-----------------|-------------------------------------------------------|
|                                             |                 |                                                                                                                           | Note        | Min.                                                                  | Тур.       | Max.                                    | Min.                                    | Тур.       | Max.            |                                                       |
| Output Leakage<br>Current I <sub>OUT1</sub> | ï               | T <sub>MIN</sub> ≤T <sub>A</sub> ≤T <sub>MAX</sub><br>All data inputs<br>latched low<br>All data inputs<br>latched high   | 6<br>10     |                                                                       |            | 200<br>200                              |                                         |            | 200<br>200      | nA<br>nA                                              |
| Digital Input<br>Voltages                   |                 | T <sub>MIN</sub> ≤T <sub>A</sub> ≤T <sub>MAX</sub><br>Low level<br>LJ suffix<br>LCJ, LCN suffix<br>High level (all parts) | 6           | 2.0                                                                   |            | 0.8<br>0.8, 0.8                         | 2.0                                     |            | 0.6<br>0.7, 0.8 | V <sub>DC</sub><br>V <sub>DC</sub><br>V <sub>DC</sub> |
| Digital Input<br>Currents                   |                 | T <sub>MIN</sub> ≤T <sub>A</sub> ≤T <sub>MAX</sub><br>Digital inputs <0.8V<br>Digital inputs >2.0V                        | 6           |                                                                       | -40<br>1.0 | -150<br>+10                             |                                         | -40<br>1.0 | -150<br>+10     | μΑ <sub>DC</sub><br>μΑ <sub>DC</sub>                  |
| Current Settling<br>Time                    | t <sub>S</sub>  | $V_{IL} = 0V$ , $V_{IH} = 5V$                                                                                             |             |                                                                       | 500        |                                         |                                         | 500        |                 | ns                                                    |
| Write and XFER Pulse Width                  | tw              | $V_{IL} = 0V, V_{IH} = 5V,$ $T_A = 25^{\circ}C$ $T_{MIN} \le T_A \le T_{MAX}$                                             | 8<br>9      | 150<br>320                                                            | 60<br>100  |                                         | 320<br>500                              | 200<br>250 |                 | ns<br>ns                                              |
| Data Set Up Time                            | t <sub>DS</sub> | $V_{IL} = 0V, V_{IH} = 5V,$ $T_A = 25^{\circ}C$ $T_{MIN} \le T_A \le T_{MAX}$                                             | 9           | 150<br>320                                                            | 80<br>120  | , i i i i i i i i i i i i i i i i i i i | 320<br>500                              | 170<br>250 |                 | ns<br>ns                                              |
| Data Hold Time                              | t <sub>DH</sub> | $V_{IL} = OV, V_{IH} = 5V$ $T_A = 25^{\circ}C$ $T_{MIN} \le T_A \le T_{MAX}$                                              | 9           | 200<br>250                                                            | 100<br>120 |                                         | 320<br>500                              | 220<br>320 |                 | ns<br>ns                                              |
| Control Set Up<br>Time                      | tcs             | $V_{IL} = 0V, V_{IL} = 5V,$ $T_A = 25^{\circ}C$ $T_{MIN} \le T_A \le T_{MAX}$                                             | 9           | 150<br>320                                                            | 60<br>100  |                                         | 320<br>500                              | 180<br>260 |                 | ns<br>ns                                              |
| Control Hold Time                           | t <sub>CH</sub> | $V_{IL} = 0V, V_{IH} = 5V,$ $T_A = 25^{\circ}C$ $T_{MIN} \le T_A \le T_{MAX}$                                             | 9           | 10<br>10                                                              | 0          |                                         | 10<br>10                                | 0          |                 | ns<br>ns                                              |

Note 1: Absolute Maximum Ratings indicate limits beyond which damage to the device may occur. DC and AC electrical specifications do not apply when operating the device beyond its specified operating conditions.

Note 2: All voltages are measured with respect to GND, unless otherwise specified.

Note 3: This 500 mW specification applies for all packages. The low intrinsic power dissipation of this part (and the fact that there is no way to significantly modify the power dissipation) removes concern for heat sinking.

Note 4: For current switching applications, both I<sub>OUT1</sub> and I<sub>OUT2</sub> must go to ground or the "Virtual Ground" of an operational amplifier. The linearity error is degraded by approximately V<sub>OS</sub> ÷ V<sub>REF</sub>. For example, if V<sub>REF</sub> = 10V then a 1 mV offset, V<sub>OS</sub>, on I<sub>OUT1</sub> or I<sub>OUT2</sub> will introduce an additional 0.01% linearity error.

Note 5: Guaranteed at  $V_{REF} = \pm 10 \ V_{DC}$  and  $V_{REF} = \pm 1 \ V_{DC}$ .

Note 6:  $T_{MIN} = 0$ °C and  $T_{MAX} = 70$ °C for "LCN" suffix parts.

 $T_{MIN} = -40$ °C and  $T_{MAX} = 85$ °C for "LCJ" suffix parts.

T<sub>MIN</sub> = 55°C and T<sub>MAX</sub> = 125°C for "LJ" suffix parts.

Note 7: The unit "FSR" stands for "Full Scale Range." "Linearity Error" and "Power Supply Rejection" specs are based on this unit to eliminate dependence on a particular Y<sub>REF</sub> value and to indicate the true performance of the part. The "Linearity Error" specification of the DAC1000 is "0.05% of FSR (MAX)." This guarantees that after performing a zero and full scale adjustment (See Sections 2.5 and 2.6), the plot of the 1024 analog voltage outputs will each be within 0.05% × V<sub>REF</sub> of a straight line which passes through zero and full scale.

Note 8: This specification implies that all parts are guaranteed to operate with a write pulse or transfer pulse width (t<sub>W</sub>) of 320 ns. A typical part will operate with t<sub>W</sub> of only 100 ns. The entire write pulse must occur within the valid data interval for the specified t<sub>W</sub>, t<sub>DS</sub>, t<sub>DH</sub>, and t<sub>S</sub> to apply.

Note 9: Guaranteed by design but not tested.

Note 10: A 200 nA leakage current with  $R_{tb}$  = 20K and  $V_{RFF}$  = 10V corresponds to a zero error of  $(200 \times 10^{-9} \times 20 \times 10^{3}) \times 100 \div 10$  which is 0.04% of FS.

Note 11: Human body model, 100 pF discharged through a 1.5 k $\Omega$  resistor.

# **Switching Waveforms**



TL/H/5688~2

# **Typical Performance Characteristics**

















# **Block and Connection Diagrams**





DAC1000/1001/1002





# DAC1000/1001/1002—Simple Hookup for a "Quick Look"



#### Notes:

- 1. For  $V_{\mbox{\scriptsize REF}} = -10.240 \mbox{\ V}_{\mbox{\scriptsize DC}}$  the output voltage steps are approximately 10 mV each.
- 2. Operation is set up for flow through-no latching of digital input data.
- 3. Single point ground is strongly recommended.

# DAC1006/1007/1008—Simple Hookup for a "Quick Look"



#### Notes:

- 1. For  $V_{\mbox{\scriptsize REF}}$  =  $-10.240~V_{\mbox{\scriptsize DC}}$  the output voltage steps are approximately 10 mV each.
- SW1 is a normally closed switch. While SW1 is closed, the DAC register is latched and new data can be loaded into the input latch via the 10 SW2 switches.

When SW1 is momentarily opened the new data is transferred from the input latch to the DAC register and is latched when SW1 again closes.

#### 1.0 DEFINITION OF PACKAGE PINOUTS

**1.1 Control Signals** (All control signals are level actuated.)  $\overline{\text{CS}}$ : Chip Select — active low, it will enable  $\overline{\text{WR}}$  (DAC1003–1008) or WR<sub>1</sub> (DAC1000–1002).

 $\overline{WR}$  or  $\overline{WR_1}$ : Write — The active low  $\overline{WR}$  (or  $\overline{WR_1}$  — DAC1000-1002) is used to load the digital data bits (DI) into the input latch. The data in the input latch is latched when  $\overline{WR}$  (or  $\overline{WR_1}$ ) is high. The 10-bit input latch is split into two latches; one holds 8 bits and the other holds 2 bits. The Byte1/ $\overline{Byte2}$  control pin is used to select both input latches when  $\overline{Byte1/Byte2} = 1$  or to overwrite the 2-bit input latch when in the low state.

 $\overline{\text{WR}_2}$ : Extra Write (DAC1000–1002) — The active low  $\overline{\text{WR}_2}$  is used to load the data from the input latch to the DAC register while  $\overline{\text{XFER}}$  is low. The data in the DAC register is latched when  $\overline{\text{WR}_2}$  is high.

Byte1/Byte2: Byte Sequence Control — When this control is high, all ten locations of the input latch are enabled. When low, only two locations of the input latch are enabled and these two locations are overwritten on the second byte write. On the DAC1006, 1007, and 1008, the Byte1/Byte2 must be low to transfer the 10-bit data in the input latch to the DAC register.

XFER: Transfer Control Signal, active low — This signal, in combination with others, is used to transfer the 10-bit data which is available in the input latch to the DAC register — see timing diagrams.

**LJ/\overline{RJ}:** Left Justify/Right Justify (DAC1000–1002) — When LJ/ $\overline{RJ}$  is high the part is set up for left justified (fractional) data format. (DAC1006–1008 have this done internally.) When LJ/ $\overline{RJ}$  is low, the part is set up for right justified (integer) data.

#### 1.2 Other Pin Functions

 $DI_{I}$  (I=0 to 9): Digital Inputs —  $DI_{0}$  is the least significant bit (LSB) and  $DI_{0}$  is the most significant bit (MSB).

I<sub>OUT1</sub>: DAC Current Output 1 — I<sub>OUT1</sub> is a maximum for a digital input code of all 1s and is zero for a digital input code of all 0s.

 $I_{OUT2}$ : DAC Current Output 2 —  $I_{OUT2}$  is a constant minus  $I_{OUT1}$ , or

$$I_{OUT1} + I_{OUT2} = \frac{1023 \text{ V}_{REF}}{1024 \text{ R}}$$
  
where R  $\cong$  15 k $\Omega$ .



a. End Point Test After Zero and FS Adj.

**R<sub>FB</sub>**: Feedback Resistor — This is provided on the IC chip for use as the shunt feedback resistor when an external op amp is used to provide an output voltage for the DAC. This on-chip resistor should always be used (not an external resistor) because it matches the resistors used in the on-chip R-2R ladder and tracks these resistors over temperature.

VREF: Reference Voltage Input — This is the connection for the external precision voltage source which drives the R-2R ladder. VREF can range from — 10 to + 10 volts. This is also the analog voltage input for a 4-quadrant multiplying DAC application.

**V<sub>CC</sub>:** Digital Supply Voltage — This is the power supply pin for the part.  $V_{CC}$  can be from +5 to +15 V<sub>DC</sub>. Operation is optimum for +15V. The input threshold voltages are nearly independent of V<sub>CC</sub>. (See Typical Performance Characteristics and Description in Section 3.0, T<sup>2</sup>L compatible logic inputs.)

GND: Ground — the ground pin for the part.

#### 1.3 Definition of Terms

**Resolution:** Resolution is directly related to the number of switches or bits within the DAC. For example, the DAC1000 has 2<sup>10</sup> or 1024 steps and therefore has 10-bit resolution.

Linearity Error: Linearity error is the maximum deviation from a straight line passing through the endpoints of the DAC transfer characteristic. It is measured after adjusting for zero and full-scale. Linearity error is a parameter intrinsic to the device and cannot be externally adjusted.

National's linearity test (a) and the "best straight line" test (b) used by other suppliers are illustrated below. The "best straight line" requires a special zero and FS adjustment for each part, which is almost impossible for user to determine. The "end point test" uses a standard zero and FS adjustment procedure and is a much more stringent test for DAC linearity.

**Power Supply Sensitivity:** Power supply sensitivity is a measure of the effect of power supply changes on the DAC full-scale output (which is the worst case).

### b. Best Straight Line



**Settling Time:** Settling time is the time required from a code transition until the DAC output reaches within  $\pm \frac{1}{2}$  LSB of the final output value. Full-scale settling time requires a zero to full-scale or full-scale to zero output change.

**Full-Scale Error:** Full scale error is a measure of the output error between an ideal DAC and the actual device output. Ideally, for the DAC1000 series, full-scale is  $V_{REF}-1$  LSB. For  $V_{REF}=-10V$  and unipolar operation,  $V_{FULL-SCA-LE}=10.0000V-9.8mV=9.9902V$ . Full-scale error is adjustable to zero.

Monotonicity: If the output of a DAC increases for increasing digital input code, then the DAC is monotonic. A 10-bit DAC with 10-bit monotonicity will produce an increasing analog output when all 10 digital inputs are exercised. A 10-bit DAC with 9-bit monotonicity will be monotonic when only the most significant 9 bits are exercised. Similarly, 8-bit monotonicity is guaranteed when only the most significant 8 bits are exercised.

#### 2.0 DOUBLE BUFFERING

These DACs are double-buffered, microprocessor compatible versions of the DAC1020 10-bit multiplying DAC. The addition of the buffers for the digital input data not only allows for storage of this data, but also provides a way to assemble the 10-bit input data word from two write cycles when using an 8-bit data bus. Thus, the next data update for the DAC output can be made with the complete new set of 10-bit data. Further, the double buffering allows many DACs in a system to store current data and also the next data. The updating of the new data for each DAC is also not time critical. When all DACs are updated, a common strobe signal can then be used to cause all DACs to switch to their new analog output levels.

### 3.0 TTL COMPATIBLE LOGIC INPUTS

To guarantee TTL voltage compatibility of the logic inputs, a novel bipolar (NPN) regulator circuit is used. This makes the input logic thresholds equal to the forward drop of two diodes (and also matches the temperature variation) as occurs naturally in TTL. The basic circuit is shown in Figure 1. A curve of digital input threshold as a function of power supply voltage is shown in the Typical Performance Characteristics section.

#### 4.0 APPLICATION HINTS

The DC stability of the V<sub>REF</sub> source is the most important factor to maintain accuracy of the DAC over time and temperature changes. A good single point ground for the analog signals is next in importance.

These MICRO-DAC converters are CMOS products and reasonable care should be exercised in handling them prior to final mounting on a PC board. The digital inputs are protected, but permanent damage may occur if the part is subjected to high electrostatic fields. Store unused parts in conductive foam or anti-static rails.

# 4.1 Power Supply Sequencing & Decoupling

Some IC amplifiers draw excessive current from the Analog inputs to V — when the supplies are first turned on. To prevent damage to the DAC — an external Schottky diode connected from I<sub>OUT1</sub> or I<sub>OUT2</sub> to ground may be required to prevent destructive currents in I<sub>OUT1</sub> or I<sub>OUT2</sub>. If an LM741 or LF356 is used — these diodes are not required.

The standard power supply decoupling capacitors which are used for the op amp are adequate for the DAC.

TI /H/5688-9



FIGURE 1. Basic Logic Threshold Loop

#### 4.2 Op Amp Bias Current & Input Leads

The op amp bias current (I<sub>B</sub>) CAN CAUSE DC ERRORS, BI-FETTM op amps have very low bias current, and therefore the error introduced is negligible. BI-FET op amps are strongly recommended for these DACs.

The distance from the  $I_{OUT1}$  pin of the DAC to the inverting input of the op amp should be kept as short as possible to prevent inadvertent noise pickup.

#### 5.0 ANALOG APPLICATIONS

The analog section of these DACs uses an R-2R ladder which can be operated both in the current switching mode and in the voltage switching mode.

The major product changes (compared with the DAC1020) have been made in the digital functioning of the DAC. The analog functioning is reviewed here for completeness. For additional analog applications, such as multipliers, attenuators, digitally controlled amplifiers and low frequency sine wave oscillators, refer to the DAC1020 data sheet. Some basic circuit ideas are presented in this section in addition to complete applications circuits.

# 5.1 Operation in Current Switching Mode

The analog circuitry, Figure 2, consists of a silicon-chromium (Si-Cr) thin film R-2R ladder which is deposited on the surface oxide of the monolithic chip. As a result, there is no parasitic diode connected to the  $V_{\rm REF}$  pin as would exist if diffused resistors were used. The reference voltage input ( $V_{\rm REF}$ ) can therefore range from  $-10{\rm V}$  to  $+10{\rm V}$ .

The digital input code to the DAC simply controls the position of the SPDT current switches, SW0 to SW9. A logical 1 digital input causes the current switch to steer the avail-

able ladder current to the I<sub>OUT1</sub> output pin. These MOS switches operate in the current mode with a small voltage drop across them and can therefore switch currents of either polarity. This is the basis for the 4-quadrant multiplying feature of this DAC.

# 5.1.1 Providing a Unipolar Output Voltage with the DAC in the Current Switching Mode

A voltage output is provided by making use of an external op amp as a current-to-voltage converter. The idea is to use the internal feedback resistor, RFB, from the output of the op amp to the inverting (—) input. Now, when current is entered at this inverting input, the feedback action of the op amp keeps that input at ground potential. This causes the applied input current to be diverted to the feedback resistor. The output voltage of the op amp is forced to a voltage given by:

$$V_{OUT} = -(I_{OUT1} \times R_{FB})$$

Notice that the sign of the output voltage depends on the direction of current flow through the feedback resistor.

In current switching mode applications, both current output pins ( $I_{OUT1}$  and  $I_{OUT2}$ ) should be operated at 0 V<sub>DC</sub>. This is accomplished as shown in *Figure 3*. The capacitor, C<sub>C</sub>, is used to compensate for the output capacitance of the DAC and the input capacitance of the op amp. The required feedback resistor, R<sub>FB</sub>, is available on the chip (one end is internally tied to  $I_{OUT1}$ ) and must be used since an external resistor will not provide the needed matching and temperature tracking. This circuit can therefore be simplified as

#### DIGITAL INPUT CODE



FIGURE 2. Current Mode Switching



shown in Figure 4, where the sign of the reference voltage has been changed to provide a positive output voltage. Note that the output current,  $I_{OUT1}$ , now flows through the  $R_{FB}$  pin.

# 5.1.2 Providing a Bipolar Output Voltage with the DAC in the Current Switching Mode

The addition of a second op amp to the circuit of *Figure 4* can be used to generate a bipolar output voltage from a fixed reference voltage *Figure 5*. This, in effect, gives sign significance to the MSB of the digital input word to allow two quadrant multiplication of the reference voltage. The polarity of the reference can also be reversed to realize the full four-quadrant multiplication.

The applied digital word is offset binary which includes a code to output zero volts without the need of a large valued resistor common to existing bipolar multiplying DAC circuits. Offset binary code can be derived from 2's complement data (most common for signed processor arithmetic) by inverting the state of the MSB in either software or hardware. After doing this the output then responds in accordance to the following expression:

$$V_O = V_{REF} \times \frac{D}{512}$$

where  $V_{REF}$  can be positive or negative and D is the signed decimal equivalent of the 2's complement processor data.  $(-512 \le D \le +511 \text{ or } 1000000000 \le D \le 01111111111)$ . If the applied digital input is interpreted as the decimal equivalent of a true binary word,  $V_{OLIT}$  can be found by:

$$V_O = V_{REF} \left( \frac{D - 512}{512} \right)$$
  $0 \le D \le 1023$ 

With this configuration, only the offset voltage of amplifier 1 need be nulled to preserve linearity of the DAC. The offset voltage error of the second op amp has no effect on linearity. It presents a constant output voltage error and should be nulled only if absolute accuracy is needed. Another advantage of this configuration is that the values of the external resistors required do not have to match the value of the internal DAC resistors; they need only to match and temperature track each other.

A thin film 4 resistor network available from Beckman Instruments, Inc. (part no. 694-3-R10K-D) is ideally suited for this application. Two of the four available 10 k $\Omega$  resistor can be paralleled to form R in *Figure 5* and the other two can be used separately as the resistors labeled 2R.

TL/H/5688-11

Operation is summarized in the table below:

| 2's Comp. | 2's Comp.  | Applied       | Applied<br>True Binary | ,                       | /ou <del>t</del>           |
|-----------|------------|---------------|------------------------|-------------------------|----------------------------|
| (Decimal) | (Binary)   | Digital Input | (Decimal)              | + V <sub>REF</sub>      | V <sub>REF</sub>           |
| +511      | 0111111111 | 1111111111    | 1023                   | V <sub>REF</sub> -1 LSB | - V <sub>REF</sub>  +1 LSB |
| + 256     | 0100000000 | 1100000000    | 768                    | V <sub>REF</sub> /2     | - V <sub>REF</sub>  /2     |
| 0         | 000000000  | 100000000     | 512                    | 0                       | 0                          |
| -1        | 1111111111 | 0111111111    | 511                    | -1 LSB                  | + 1 LSB                    |
| -256      | 1100000000 | 0100000000    | 256                    | V <sub>REF</sub> /2     | + V <sub>REF</sub> /2      |
| -512      | 1000000000 | 0000000000    | 0                      | -V <sub>REF</sub>       | +  V <sub>REF</sub>        |

with: 1 LSB = 
$$\frac{|V_{REF}|}{512}$$



FIGURE 4. Providing a Unipolar Output Voltage



FIGURE 5. Providing a Bipolar Output Voltage with the DAC in the Current Switching Mode

#### 5.2 Analog Operation in the Voltage Switching Mode

Some useful application circuits result if the R-2R ladder is operated in the voltage switching mode. There are two very important things to remember when using the DAC in the voltage mode. The reference voltage (+V) must always be positive since there are parasitic diodes to ground on the  $l_{OUT1}$  pin which would turn on if the reference voltage went negative. To maintain a degradation of linearity less than  $\pm\,0.005\,\%$ , keep +V  $\leq\,3\,$  V $_{DC}$  and V $_{CC}$  at least 10V more positive than +V. Figures 6 and 7 show these errors for the voltage switching mode. This operation appears unusual, since a reference voltage (+V) is applied to the  $l_{OUT1}$  pin and the voltage output is the V $_{REF}$  pin. This basic idea is shown in Figure 8.

This  $V_{OUT}$  range can be scaled by use of a non-inverting gain stage as shown in *Figure 9*.

Notice that this is unipolar operation since all voltages are positive. A bipolar output voltage can be obtained by using a single op amp as shown in Figure 10. For a digital input code of all zeros, the output voltage from the  $V_{\rm REF}$  pin is zero volts. The external op amp now has a single input of + V and is operating with a gain of -1 to this input. The output of the op amp therefore will be at -V for a digital input of all zeros. As the digital code increases, the output voltage at the  $V_{\rm REF}$  pin increases.

Notice that the gain of the op amp to voltages which are applied to the (+) input is +2 and the gain to voltages which are applied to the input resistor, R, is -1. The output voltage of the op amp depends on both of these inputs and is given by:

$$V_{OUT} = (+V)(-1) + V_{REF}(+2)$$









FIGURE 9. Amplifying the Voltage Mode Output (Single Supply Operation)



FIGURE 10. Providing a Bipolar Output Voltage with a Single Op Amp



FIGURE 11. Increasing the Output Voltage Swing

The output voltage swing can be expanded by adding 2 resistors to Figure 10 as shown in Figure 11. These added resistors are used to attenuate the +V voltage. The overall gain,  $A_V(-)$ , from the +V terminal to the output of the op amp determines the most negative output voltage,  $-4(+\mbox{V})$  (when the  $\mbox{V}_{REF}$  voltage at the + input of the op amp is zero) with the component values shown. The complete dynamic range of  $\mbox{V}_{OUT}$  is provided by the gain from the (+) input of the op amp. As the voltage at the  $\mbox{V}_{REF}$  pin ranges from 0V to +V(1023/1024) the output of the op amp will range from -10  $\mbox{V}_{DC}$  to +10V (1023/1024) when using a +V voltage of +2.500  $\mbox{V}_{DC}$ . The 2.5  $\mbox{V}_{DC}$  reference voltage can be easily developed by using the LM336 zener which can be biased through the  $\mbox{R}_{FB}$  internal resistor, connected to  $\mbox{V}_{CC}$ .

#### 5.3 Op Amp V<sub>OS</sub> Adjust (Zero Adjust) for Current Switching Mode

Proper operation of the ladder requires that all of the 2R legs always go to exactly 0  $V_{DC}$  (ground). Therefore offset voltage,  $V_{OS}$ , of the external op amp cannot be tolerated as every millivolt of  $V_{OS}$  will introduce 0.01% of added linearity error. At first this seems unusually sensitive, until it becomes clear the 1 mV is 0.01% of the 10V reference! High resolution converters of high accuracy require attention to every detail in an application to achieve the available performance which is inherent in the part. To prevent this source of error, the  $V_{OS}$  of the op amp has to be initially zeroed. This is the "zero adjust" of the DAC calibration sequence and should be done first.

If the  $V_{OS}$  is to be adjusted there are a few points to consider. Note that no "dc balancing" resistance should be used in the grounded positive input lead of the op amp. This resistance and the input current of the op amp can also create errors. The low input biasing current of the BI-FET op amps makes them ideal for use in DAC current to voltage applications. The  $V_{OS}$  of the op amp should be adjusted with a digital input of all zeros to force  $I_{OUT} = 0$  mA. A 1 k $\Omega$  resistor can be temporarily connected from the inverting input to ground to provide a dc gain of approximately 15 to the  $V_{OS}$  of the op amp and make the zeroing easier to sense.

TL/H/5688-13

## 5.4 Full-Scale Adjust

The full-scale adjust procedure depends on the application circuit and whether the DAC is operated in the current switching mode or in the voltage switching mode. Techniques are given below for all of the possible application circuits.

#### 5.4.1 Current Switching with Unipolar Output Voltage

After doing a "zero adjust," set all of the digital input levels HIGH and adjust the magnitude of V<sub>REF</sub> for

$$V_{OUT} = -(ideal \, V_{REF}) \, \frac{1023}{1024}$$

This completes the DAC calibration.

#### 5.4.2 Current Switching with Bipolar Output Voltage

The circuit of *Figure 12* shows the 3 adjustments needed. The first step is to set all of the digital inputs LOW (to force  $I_{OUT1}$  to 0) and then trim "zero adj." for zero volts at the inverting input (pin 2) of 0A1. Next, with a code of all zeros still applied, adjust "-FS adj.", the reference voltage, for  $V_{OUT} = \pm |(\text{ideal }V_{REF})|$ . The sign of the output voltage will be opposite that of the applied reference.

Finally, set all of the digital inputs HIGH and adjust "+FS adj." for  $V_{OUT} = V_{REF}$  (511/512). The sign of the output at this time will be the same as that of the reference voltage. The addition of the  $200\Omega$  resistor in series with the  $V_{REF}$  pin of the DAC is to force the circuit gain error from the DAC to be negative. This insures that adding resistance to  $R_{fb}$ , with the  $500\Omega$  pot, will always compensate the gain error of the DAC.

#### 5.4.3 Voltage Switching with a Unipolar Output Voltage

Refer to the circuit of *Figure 13* and set all digital inputs LOW. Trim the "zero adj." for  $V_{OUT}$ =0  $V_{DC}\pm1$  mV. Then set all digital inputs HIGH and trim the "FS Adj." for:

$$V_{OUT} \!=\! (+V) \bigg(1 \!+\! \frac{R_1}{R_2}\bigg) \! \frac{1023}{1024}$$

### 5.4.4 Voltage Switching with a Bipolar Output Voltage

Refer to Figure 14 and set all digital inputs LOW. Trim the "-FS Adj." for  $V_{OUT} = -2.5 \, V_{DC}$ . Then set all digital inputs HIGH and trim the "+FS Adj." for  $V_{OUT} = +2.5 \, (511/512) \, V_{DC}$ . Test the zero by setting the MS digital input HIGH and all the rest LOW. Adjust  $V_{OS}$  of amp #3, if necessary, and recheck the full-scale values.



FIGURE 12. Full Scale Adjust — Current Switching with Bipolar Output Voltage



FIGURE 13. Full Scale Adjust — Voltage Switching with a Unipolar Output Voltage



FIGURE 14. Voltage Switching with a Bipolar Output Voltage

TL/H/5688-15

#### 6.0 DIGITAL CONTROL DESCRIPTION

The DAC1000 series of products can be used in a wide variety of operating modes. Most of the options are shown in Table 1. Also shown in this table are the section numbers of this data sheet where each of the operating modes is discussed. For example, if your main interest in interfacing to a  $\mu P$  with an 8-bit data bus you will be directed to Section 6.1.0.

The first consideration is "will the DAC be interfaced to a  $\mu P$  with an 8-bit or a 16-bit data bus or used in the stand-alone mode?" For the 8-bit data bus, a second selection is made on how the 2nd digital data buffer (the DAC Latch) is updated by a transfer from the 1st digital data buffer (the Input Latch). Three options are provided: 1) an automatic transfer when the 2nd data byte is written to the DAC, 2) a transfer which is under the control of the  $\mu P$  and can include more than one DAC in a simultaneous transfer, or 3) a transfer which is under the control of external logic. Further, the data format can be either left justified or right justified.

When interfacing to a  $\mu P$  with a 16-bit data bus only two selections are available: 1) operating the DAC with a single digital data buffer (the transfer of one DAC does not have to be synchronized with any other DACs in the system), or 2) operating with a double digital data buffer for simultaneous

transfer, or updating, of more than one DAC.

For operating without a  $\mu P$  in the stand alone mode, three options are provided: 1) using only a single digital data buffer, 2) using both digital data buffers — "double buffered," or 3) allowing the input digital data to "flow through" to provide the analog output without the use of any data latches.

To reduce the required reading, only the applicable sections of 6.1 through 6.4 need be considered.

#### 6.1 Interfacing to an 8-Bit Data Bus

Transferring 10 bits of data over an 8-bit bus requires two write cycles and provides four possible combinations which depend upon two basic data format and protocol decisions:

- 1. Is the data to be left justified (considered as fractional binary data with the binary point to the left) or right justified (considered as binary weighted data with the binary point to the right)?
- 2. Which byte will be transferred first, the most significant byte (MS byte) or the least significant byte (LS byte)?

Table 1

| Operating Mode          | Auto    | omatic Tran       | nsfer              | μP Control Transfer |                   |                   | External Transfer |                   |                   |  |
|-------------------------|---------|-------------------|--------------------|---------------------|-------------------|-------------------|-------------------|-------------------|-------------------|--|
| Data Bus                | Section | Figur<br>(24-Pin) | re No.<br>(20-Pin) | Section             | Figur<br>(24-Pin) | e No.<br>(20-Pin) | Section           | Figui<br>(24-Pin) | e No.<br>(20-Pin) |  |
| 8-Bit Data Bus (6.1.0)  |         |                   |                    |                     |                   |                   |                   |                   |                   |  |
| Right Justified (6.1.1) | 6.2.1   | 16                |                    | 6.2.2               | 16                |                   | 6.2.3             | 16                |                   |  |
| Left Justified (6.1.2)  | 6.2.1   | 17                | 18                 | 6.2.2               | 17                | 18                | 6.2.3             | 17                | 18                |  |
| 16-Bit Data Bus (6.3.0) | s       | ingle Buffere     | əd                 | D                   | ouble Buffer      | ed                | ı                 | low Throug        | h                 |  |
| To-Bit Data Bus (0.3.0) | 6.3.1   | 19                | 20                 | 6.3.2               | 19                | 20                | ١                 | lot Applicab      | le                |  |
| Stand Alone (6.4.0)     | s       | ingle Buffere     | əd                 | D                   | ouble Buffer      | ed                | ı                 | Flow Throug       | h                 |  |
| Gtario Alorio (0.4.0)   | 6.4.1   | 19                | 20                 | 6.4.2               | 19                | 20                | 6.4.3             | 19                | NA                |  |

TL/H/5688-16

These data possibilities are shown in Figure 15. Note that the justification of data depends on how the 10-bit data word is located within the 16-bit data source (CPU) register. In either case, there is a surplus of 6 bits and these are shown as "don't care" terms ("×") in this figure.

All of these DACs load 10 bits on the 1st write cycle. A particular set of 2 bits is then overwritten on the 2nd write cycle, depending on the justification of the data. This requires the 1st write cycle to contain the LS or L0 Byte data group for all right justified data options. For all left justified data options, the 1st write cycle must contain the MS or Hi Byte data group.

#### 6.1.1 Providing for Optional Data Format

The DAC1000/1/2 (24-pin parts) can be used for either data formatting by tying the LJ/RJ pin either high or low, respectively. A simplified logic diagram which shows the external connections to the data bus and the internal functions of both of the data buffer registers (Input Latch and DAC Register) is shown in *Figure 16* for the right justified data operation. *Figure 17* is for left justified data.

#### 6.1.2 For Left Justified Data

For applications which require left justified data, DAC1006–1008 (20-pin parts) can be used. A simplified logic diagram which shows the external connections to the data bus and the internal functions of both of the data buffer registers (Input Latch and DAC Register) is shown in *Figure 18*. These parts require the MS or Hi Byte data group to be transferred on the 1st write cycle.

#### 6.2 Controlling Data Transfer for an 8-Bit Data Bus

Three operating modes are possible for controlling the transfer of data from the Input Latch to the DAC Register, where it will update the analog output voltage. The simplest is the automatic transfer mode, which causes the data transfer to occur at the time of the 2nd write cycle. This is recommended when the exact timing of the changes of the DAC analog output are not critical. This typically happens where each DAC is operating individually in a system and the analog updating of one DAC is not required to be synchronized to any other DAC. For synchronized DAC updating, two options are provided:  $\mu$ P control via a common XFER strobe or external update timing control via an external strobe. The details of these options are now shown.



FIGURE 15. Fitting a 10-Bit Data Word into 16 Available Bit Locations

DAC1000/1001/1002 (24-Pin Parts)

# 

FIGURE 16. Input Connections and Controls for DAC1000-1002 Right Justified Data Option

3-77

(CSZ) XFER O

۷+0 نا/آنا

(INTERNAL LOGIC IS SHOWN FOR LF/RJ = 1-LEFT JUSTIFIED)

# B-BIT INPUT LATCH 8-BIT Data bus 10-BIT DAC LATCH TO CURRENT SWITCHES 2-BIT INPUT LATCH LATCH ENABLE LATCH ENABLE WHEN: Byte 1/Byte 2 C EATCH ENABLE = 1.0 OUTPUTS FOLLOW D INPUTS. LATCH ENABLE = 0, DATA AT D IS LATCHED.

DAC1000/1001/1002 (24-Pin Parts)

FIGURE 17. Input Connections and Controls for DAC1000-1002 Left Justified Data Option

# DAC1006/1007/1008 (20-Pin Parts for Left Justified Data) 8-BIT INPUT LATCH 8-BIT DATA BUS TO CURRENT SWITCHES 2-BIT INPUT LATCH AYCH ENABLE CATCH LATCH ENABLE = 1,Q OUTPUTS FOLLOW D INPUTS. LATCH ENABLE = 0, DATA AT D IS LATCHED. (CS2) XFER O

FIGURE 18. Input Connections and Controls for DAC1006/1007/1008 Left Justified Data

TL/H/5688-17

3-78

#### 6.2.1 Automatic Transfer

This makes use of a double byte (double precision) write. The first byte (8 bits) is strobed into the input latch and the second byte causes a simultaneous strobe of the two remaining bits into the input latch and also the transfer of the complete 10-bit word from the input latch to the DAC register. This is shown in the following timing diagrams; the point in time where the analog output is updated is also indicated on these diagrams.





### DAC1006/1007/1008 (20-Pin Parts)



TL/H/5688-18

\*SIGNIFIES CONTROL INPUTS WHICH ARE DRIVEN IN PARALLEL

### 6.2.2 Transfer Using $\mu P$ Write Stroke

The input latch is loaded with the first two write strobes. The XFER signal is provided by external logic, as shown below, to cause the transfer to be accomplished on a third write strobe. This is shown in the following diagrams:

# DAC1000/1001/1002 (24-Pin Parts)



### DAC1006/1007/1008 (20-Pin Parts)



WHERE THE XFER CONTROL CAN BE GENERATED BY USING A SECOND CHIP SELECT AS:



TL/H/5688-19

### 6.2.3 Transfer Using an External Strobe

This is similar to the previous operation except the  $\overline{XFER}$  signal is not provided by the  $\mu P$ . The timing diagram for this is:

# DAC1000/1001/1002 (24-Pin Parts)



### DAC1006/1007/1008 (20-Pin Parts)



#### 6.3 Interfacing to a 16-Bit Data Bus

The interface to a 16-bit data bus is easily handled by connecting to 10 of the available bus lines. This allows a wiring selected right justified or left justified data format. This is shown in the connection diagrams of *Figures 19* and *20*, where the use of DB6 to DB15 gives left justified data operation. Note that any part number can be used and the Byte1/Byte2 control should be wired Hi.



FIGURE 19. Input Connections and Logic for DAC1000-1002 with 16-Bit Data Bus



FIGURE 20. Input Connections and Logic for DAC1006/1007/1008 with 16-Bit Data Bus

Three operating modes are possible: flow through, single buffered, or double buffered. The timing diagrams for these are shown below:

# 6.3.1 Single Buffered





### 6.3.2 Double Buffered







XFER

TL/H/5688-22

#### 6.4 Stand Alone Operation

For applications for a DAC which are not under  $\mu P$  control (stand alone) there are two basic operating modes, single buffered and double buffered. The timing diagrams for these are shown below:

#### 6.4.1 Single Buffered





#### 6.4.2 Double Buffered

## DAC1000/1001/1002 (24-Pin Parts)



### DAC1006/1007/1008 (20-Pin Parts)\*



<sup>\*</sup>For a connection diagram of this operating mode use Figure 18 for the Logic and Figure 20 for the Data Input connections.

#### 6.4.3 Flow Through

This operating mode causes the 10-bit input word to directly create the DAC output without any latching involved.

#### DAC1000/1001/1002 (24-Pin Parts)

WR1 = WR2 = CS = XFER = 0 Byte 1/Byte 2 = 1

#### 7.0 MICROPROCESSOR INTERFACE

The logic functions of the DAC1000 family have been oriented towards an ease of interface with all popular  $\mu$ Ps. The following sections discuss in detail a few useful interface schemes.

#### 7.1 DAC1001/1/2 to INS8080A Interface

Figure 21 illustrates the simplicity of interfacing the DAC1000 to an INS8080A based microprocessor system.

The circuit will perform an automatic transfer of the 10 bits of output data from the CPU to the DAC register as outlined in Section 6.2.1, "Controlling Data Transfer for an 8-Bit Data Bus."

Since a double byte write is necessary to control the DAC with the INS8080A, a possible instruction to achieve this is a PUSH of a register pair onto a "stack" in memory. The 16-bit register pair word will contain the 10 bits of the eventual DAC input data in the proper sequence to conform to both



TL/H/5688-24

NOTE: DOUBLE BYTE STORES CAN BE USED.
e.g. THE INSTRUCTION SHLD F001 STORES THE L
REG INTO B1 AND THE H REG INTO B2 AND
TRANSFERS THE RESULT TO THE DAC REGISTER.
THE OPERAND OF THE SHLD INSTRUCTION MUST
BE AN ODD ADDRESS FOR PROPER TRANSFER.

FIGURE 21. Interfacing the DAC1000 to the INS8080A CPU Group

the requirements of the DAC (with regard to right or left justified data) and the implementation of the PUSH instruction which will output the higher order byte of the register pair (i.e., register B of the BC pair) first. The DAC will actually appear as a two-byte "stack" in memory to the CPU. The auto-decrementing of the stack pointer during a PUSH allows using address bit 0 of the stack pointer as the Byte1/Byte2 and XFER strobes if bit 0 of the stack pointer address —1, (SP—1), is a "1" as presented to the DAC. Additional address decoding by the DM8131 will generate a unique DAC chip select (CS) and synchronize this CS to the two memory write strobes of the PUSH instruction.

To reset the stack pointer so new data may be output to the same DAC, a POP instruction followed by instructions to insure that proper data is in the DAC data register pair before it is "PUSHED" to the DAC should be executed, as the POP instruction will arbitrarily alter the contents of a register pair.

Another double byte write instruction is Store H and L Direct (SHLD), where the HL register pair would temporarily contain the DAC data and the two sequential addresses for the DAC are specified by the instruction op code. The auto incrementing of the DAC address by the SHLD instruction permits the same simple scheme of using address bit 0 to generate the byte number and transfer strobes.

#### 7.2 DAC1000 to MC6820/1 PIA Interface

In Figure 22 the DAC1000 is interfaced to an M6800 system through an MC6820/1 Peripheral Interface Adapter (PIA). In this case the CS pin of the DAC is grounded since the PIA is already mapped in the 6800 system memory space and no decoding is necessary. Furthermore, by using both Ports A and B of the PIA the 10-bit data transfer, assumed right justified again in two 8-bit bytes, is greatly simplified. The HIGH byte is loaded into Output Register A (ORA) of the

PIA, and the LOW byte is loaded into ORB. The 10-bit data transfer to the DAC and the corresponding analog output change occur simultaneously upon CB2 going LOW under program control. The 10-bit data word in the DAC register will be latched (and hence V<sub>OUT</sub> will be fixed) when CB2 is brought back HIGH.

If both output ports of the PIA are not available, it is possible to interface the DAC1000 through a single port without much effort. However, additional logic at the CB2(or CA2) lines or access to some of the 6800 system control lines will be required.

#### 7.3 Noise Considerations

A typical digital/microprocessor bus environment is a tremendous potential source of high frequency noise which can be coupled to sensitive analog circuitry. The fast edges of the data and address bus signals generate frequency components of 10's of megahertz and can cause noise spikes to appear at the DAC output. These noise spikes occur when the data bus changes state or when data is transferred between the latches of the device.

In low frequency or DC applications, low pass filtering can reduce these noise spikes. This is accomplished by overcompensating the DAC output amplifier by increasing the value of the feedback capacitor ( $C_C$  in *Figure 3*).

In applications requiring a fast transient response from the DAC and op amp, filtering may not be feasible. Adding a latch, DM74LS374, as shown in *Figure 23* isolates the device from the data bus, thus eliminating noise spikes that occur every time the data bus changes state. Another method for eliminating noise spikes is to add a sample and hold after the DAC op amp. This also has the advantage of eliminating noise spikes when changing digital codes.



FIGURE 22. DAC1000 to MC6820/1 PIA Interface

T1 /H/5688-25



FIGURE 23. Isolating Data Bus from DAC Circuitry to Eliminate Digital Noise Coupling



FIGURE 24. Digitally Controlled Amplifier/Attenuator

### 7.4 Digitally Controlled Amplifier/Attenuator

An unusual application of the DAC, Figure 24, applies the input voltage via the on-chip feedback resistor. The lower op amp automatically adjusts the  $V_{\rm REF\,IN}$  voltage such that  $I_{\rm OUT1}$  is equal to the input current ( $V_{\rm IN}/Rf_{\rm B}$ ). The magnitude of this  $V_{\rm REF\,IN}$  voltage depends on the digital word which is in the DAC register.  $I_{\rm OUT2}$  then depends upon both the magnitude of  $V_{\rm IN}$  and the digital word. The second op amp converts  $I_{\rm OUT2}$  to a voltage,  $V_{\rm OUT}$ , which is given by:

$$V_{OUT} = V_{IN} \left( \frac{1023 - N}{N} \right), \text{ where } 0 < N \le 1023.$$

Note that N=0 (or a digital code of all zeros) is not allowed or this will cause the output amplifier to saturate at either  $\pm V_{MAX}$ , depending on the sign of  $V_{IN}$ .

TI /H/5688-26

To provide a digitally controlled divider, the output op amp can be eliminated. Ground the  $I_{OUT2}$  pin of the DAC and  $V_{OUT}$  is now taken from the lower op amp (which also drives the  $V_{REF}$  input of the DAC). The expression for  $V_{OUT}$  is now given by

$$V_{OUT} = - rac{V_{IN}}{M}$$
 where M = Digital input (expressed as a fractional binary number).  $0 < M < 1$ .



FIGURE 25. Digital to Synchro Converter

# **Ordering Information**

1. All Logic Features - 24-pin package.

| Accuracy        | Temperature Range |                 |             |  |  |  |  |  |
|-----------------|-------------------|-----------------|-------------|--|--|--|--|--|
| Accuracy        | -40°C to +85°C    | -55°C to +125°C | 0° to +70°C |  |  |  |  |  |
| 0.05% (10-bit)  | DAC1000LCJ        | DAC1000LJ       | DAC 1000LCN |  |  |  |  |  |
| 0.10% (9-bit)   |                   |                 | DAC1001LCN  |  |  |  |  |  |
| 0.20% (8-bit)   | DAC1002LCJ        | DAC1002LJ       | DAC1002LCN  |  |  |  |  |  |
| Package Outline | J24A              | J24A            | N24A        |  |  |  |  |  |

# 2. For Left Justified Data — 20-pin package.

| Accuracy                       | Temperature Range |                 |                          |  |  |  |  |  |
|--------------------------------|-------------------|-----------------|--------------------------|--|--|--|--|--|
| Accuracy                       | -40°C to +85°C    | -55°C to +125°C | 0° to +70°C              |  |  |  |  |  |
| 0.05% (10-bit)                 | DAC1006LCJ        | DAC1006LJ       | DAC1006LCN               |  |  |  |  |  |
| 0.10% (9-bit)<br>0.20% (8-bit) | DAC1008LCJ        | DAC1008LJ       | DAC1007LCN<br>DAC1008LCN |  |  |  |  |  |
| Package Outline                | J20A              | J20A            | N20A                     |  |  |  |  |  |