# BINARY D/A CONVERTERS CAN PROVIDE BCD-CODED CONVERSION

Prepared by: Tim Henry Motorola Semiconductor

### Datasheet.Live

This note describes the application and use of integrated circuit D/A converters for use in providing a BCD-coded conversion. The technique is illustrated using a 2-1/2 digit digital voltmeter.

## Binary D/A converters can provide BCD-coded conversion

You can use IC D/A converters, even though they're binary coded, to do BCD-to-analog conversion. It just takes a few extra parts.

Monolithic digital-to-analog (D/A) converters have become very popular because of their versatility and low cost. They have one limitation, however, and that is that they are all binary coded. Thus, they cannot be used directly for the many applications where a binary-coded decimal (BCD) conversion is required. It is possible, though, by adding some external components to make a binary-coded D/A converter perform as a BCD code converter.

#### Two-digit converter

A 2-digit, BCD-coded voltage-output D/A converter is shown in Fig. 1. To understand its operation, note the 4-bit binary code and corresponding one digit of BCD code shown in Table 1. The BCD code and the 0-to-9 of the binary code are exactly the same. The 4-bit binary code sequences through all 16 steps before the next most-significant bit (fifth bit) increments one step. However, when counting in BCD the 4-bit code will only sequence through ten steps before the next most-significant bit increments once. This means that 10 least-significant bit steps in BCD equal 16 least-significant bit steps in binary, assuming the next most-significant bit of both codes is the same magnitude. Therefore, by making the four least-significant bits of the binary-weighed D/A converter appear larger, such that 10 least-significant bit steps equal the magnitude of the next significant bit, a BCDcoded D/A converter can be effectively produced.

To make the four least-significant bits of the D/A appear larger than normal (Fig. 1), current rom the node connecting the output of the D/A onverter and the virtual ground of the op amp is used. This virtual ground of the op amp provides a very good summing junction.

In implementing the technique it was found hat the hardware available made it much easier o switch currents into the node than out of it. his problem was circumvented by taking a onstant current out of the node and switching urrents into it.

The output of the binary D/A is a current sink,

with the amount of current depending on the reference current input,  $l_{\rm ref}$ , and the digital word on its input lines. This is empirically given by:

$$I_{\rm o} = I_{\rm ref} \left( \frac{X}{256} \right)$$

$$I_{ret} = \frac{V_{ret}}{R_{ret}}$$

where  $I_n$  is the output current,  $I_{ref}$  is the reference current and x is the digital word input.

The op-amp feedback resistor changes analog current In to an analog voltage, e.,, where:

$$e_{..} = I_{..}R$$

Thus,  $e_n$  is directly proportional to  $l_n$ , namely R times.

The outputs of the CMOS NOR gates appear as voltage sources, with 750 $\Omega$  output impedances. In



Fig. 1—Two-digit BCD D/A converter uses a binary-coded monlithic D/A converter as its basic conversion element.

| TABLE 1 |   |   | BIN | NARY | / V | S 1- | DIG<br>BC   |   | BCD |
|---------|---|---|-----|------|-----|------|-------------|---|-----|
| 0       | 0 | 0 | 0   | 0    |     | 0    | 0           | 0 | 0   |
| 1       | 0 | 0 | 0   | 1    |     | 0    | 0           | 0 | 1   |
| 2       | 0 | 0 | 1   | 0    |     | 0    | 0           | 1 | 0   |
| 3       | 0 | 0 | 1   | 1    |     | 0    | 0           | 1 | 1   |
| 4       | 0 | 1 | 0   | 0    |     | 0    | 1           | 0 | 0   |
| 5       | 0 | 1 | 0   | 1 .  |     | 0    | 1           | 0 | 1   |
| 6       | 0 | 1 | 1   | 0    |     | 0    | 1           | 1 | 0   |
| 7       | 0 | 1 | 1   | 1    |     | 0    | 1           | 1 | 1   |
| 8       | 1 | 0 | 0   | 0    |     | 1    | 0           | 0 | 0   |
| 9       | 1 | 0 | 0   | 1    |     | 1    | 0           | 0 | 1   |
| 10      | 1 | 0 | 1   | 0    |     |      |             |   | _   |
| 11      | 1 | 0 | 1   | 1    |     | _    | <del></del> |   | _   |
| 12      | 1 | 1 | 0   | 0    |     | _    |             |   |     |
| 13      | 1 | 1 | 0   | 1    |     | -    |             |   |     |
| 14      | 1 | 1 | 1   | 0    |     | _    |             |   |     |
| 15      | 1 | 1 | 1   | 1    |     | -    |             |   |     |

other words, when the output of a gate is LOW, it looks like a 7500 resistor to ground. When the output is HICH, a gate looks like a 750 $\Omega$  resistor to V<sub>ref</sub>.

If the output of a gate is LOW, the voltage across its resistor from the output to the virtual ground (R<sub>i</sub> through R<sub>i</sub>) is approximately zero. However, when the output of a gate is HIGH, the voltage across its resistor is  $V_{\rm rel}$ . Therefore, the current into the summing node is given by:

$$I_1 = \frac{V_{\rm rel}}{R_1}$$

$$I_2 = \frac{V_{\rm rel}}{R_2}$$

$$I_3 = \frac{V_{\rm rel}}{R_3}$$

$$I_4 = \frac{V_{\rm ret}}{R_4}$$

Since the NOR gates function as inverters for the digital word input, the outputs of the inverters are going to be normally HIGH for a ZERO on the input line. Now, if the currents are set so that

$$I_{B} = I_{1} + I_{2} + I_{3} + I_{4}$$

when the input word is all ZEROs, no net current will be taken from or added to the summing mode. If one of the four least-significant bits is turned ON, the output of that inverter goes LOW

and the current through the resistor to the summing junction is zero. This requires a net current, equal to the amount that was being injected into the summing junction by the resistor, to be drawn out of the summing junction, causing that bit of the D/A to appear larger than it really is. The other three bits work in exactly the same manner.

The only problem now is to determine the values of the resistors for proper operation.

Since the output of the D/A is a direct function of the reference current, it follows that the added currents must be also. The most-significant current of the D/A is  $t_{\rm m}/2$ . The second mostsignificant bit current is  $I_{\rm rel}/4$  and so on. Table 2 shows the value for the current of each bit of the D/A and also gives the values needed for BCD operation. The difference between the binary value and the BCD value must be taken from the node to make the binary-weighed D/A behave as though it were BCD coded.

It is interesting to note that making the D/A converter act as if it were BCD coded could also be achieved if the four most-significant bits of the D/A were made to look smaller than normal. The reason the system is set up as described is that the least-significant bit currents do not have to be as accurate as the most-significant bit currents. This means that the magnitude of the current subracted from the summing junction using the least-significant bits is not critical.

### Determining allowable current error

If the BCD-coded D/A converter is to be



Fig. 2-Addition of a current source and current switch expands the 2-digit BCD converter of Fig. 1 into a 2-1/2-digit converter.

accurate, the maximum amount that any of the bit currents can deviate from the ideal value is 50% of the least-significant bit current. Since the least-significant bit current is larger for BCD than for binary, a less accurate D/A is required to give 2-digit BCD accuracy (100 steps) than for 8-bit binary (256 steps).

**Table 2** shows that the value of the least-significant bit current for BCD is 0.125 mA. So to give the required accuracy, each bit current must not deviate from the ideal value by more than  $\pm 0.00625$  mA, or 6.25  $\mu$ A.

For an 8-bit binary D/A, assuming a 2 mA ladder current, the maximum error that any bit may have is 3.9 μA. Assuming the 8-bit D/A to have the worst allowable error on each of the least-significant bits, that leaves an error of 6.25 μA minus 3.9 μA, or 2.35 μA to be introduced by the injected currents. In other words, to insure that the 2-digit BCD-coded D/A is accurate, the injected currents must be kept within \* 2.35 μA of their ideal value.

It is easy now to determine the accuracy required for the injected currents. The percentage of accuracy is simply the amount of deviation allowed, 2.35 µA, divided by the amount of injected current. This is given by:

% allowable error 
$$-\frac{2.35 \ \mu\text{A}}{\text{amount current injected}} \times 100$$

Using this formula, the injected currents' allowable errors are:

LSB; 50% 2nd LSB; 25% 3rd LSB; 12.5% 4th LSB: 6.25%

This shows that 5% tolerance resistors are more than adequate. Fig. 1 gives the resistor values for a 5.0V reference voltage. These values are sufficient to neglect the output impedance of the NOR gates.

Calibration of the circuit of Fig. 1 is as follows: First,  $V_{\rm ref}$  or  $R_{\rm ref}$  is adjusted to give a half-scale

TABLE 2 - BIT CURRENTS
BIT NUMBER BINARY BCD

| BIT            | NUMBER | BINARY   | BCD      | DIFFERENCE |
|----------------|--------|----------|----------|------------|
| A <sub>o</sub> | MSB    | 1.000MA* | 1.000MA* | 0          |
| A,             | 2ND    | 0.5000   | 0.5000   | 0          |
| A <sub>2</sub> | 3RD    | 0.2500   | 0.2500   | 0          |
| A <sub>3</sub> | 4TH    | 0.1250   | 0.1250   | 0          |
| A <sub>4</sub> | 5TH    | 0.0625   | 0.1000   | 0.0375     |
| A <sub>5</sub> | 6TH    | 0.0312   | 0.0500   | 0.0188     |
| A <sub>6</sub> | 7TH    | 0.0158   | 0.0250   | 0.0094     |
| Α,             | LSB    | 0.0078   | 0.0125   | 0.0047     |

<sup>\*1</sup>\_, = 2.0000mA

reading of e, with only the most-significant bit ON. Next, with all bits turned OFF, R, is adjusted so that e, is zero. The D/A is now calibrated.

#### 2-1/2-digit converter

In many applications, a 2-1/2-digit BCD-coded converter is desired. That is, a circuit that will count to 199 rather than to 99. Once the basic 2-digit circuit has been designed, it is relatively easy to add the half digit. Fig. 2 shows such a 2-1/2-digit circuit. It is identical to the 2-digit configuration, except for the addition of a current source and a current switch to produce the 1/2 digit.

In operation, the circuit should sequence through steps 0 to 99 while the 1/2 digit is LOW and through steps 100 to 199 while the 1/2 digit is HIGH. This means that the 1/2-digit current is equal to 100 least-significant bits of current. If the least-significant bit current in the 2-1/2-digit circuit is the same as the least-significant bit current in the 2-digit circuit previously described, the value for the 1/2 digit is 1.250 mA (100 × 0.0125 mA). Therefore, the circuit will act as a 2-1/2-digit BCD-coded D/A if the 1/2-digit switch sinks zero current for the first 100 counts (0 to 99) and sinks 1.250 mA for the second 100 counts (100 to 199).

The 1/2-digit current is added in the same manner as the least-significant bit currents were added in the 2-digit system. Namely, a constant current,  $I_{\rm B}$ , is sunk from the summing node, and the various currents,  $I_{\rm I}$  through  $I_{\rm S}$ , are switched into the node. For the 2-1/2-digit circuit,  $I_{\rm B}$  is obtained by:

$$I_{B} = I_{1} + I_{2} + I_{3} + I_{4} + I_{5}$$

where  $I_1$  through  $I_3$  are identical with their 2-digit system counterparts.

The tolerance of  $I_{\rm B}$  to assure that the D/A remains accurate is 2.35  $\mu$ A. This is the same value as that derived in the 2-digit section. Since  $I_{\rm B}$  is much larger for the 2-1/2-digit system, the percentage tolerance of  $I_{\rm B}$  is much more critical. If the values for  $I_{\rm T}$  through  $I_{\rm T}$  shown in **Table 2** are summed with the value of  $I_{\rm D}$ , we have;

 $l_{\rm B} = 4.7~\mu A + 9.4~\mu A + 18.8~\mu A + 37.5~\mu A + 1250~\mu A = 1320~\mu A.$ 

If  $I_B$  can only vary  $\pm 2.35~\mu A$ , its tolerance is  $\pm 0.18\%$ .

In the 2-digit system, current  $I_{\rm B}$  could be produced simply by a resistor from the summing node to the negative supply because the summing node is a virtual ground. Once the system is calibrated by adjusting  $R_{\rm b}$ , current  $I_{\rm B}$  is constant except for changes caused by variations in the negative supply voltage.

In the 2-1/2-digit system, a circuit is needed that will sink current from the summing node without being referenced to the negative supply voltage.



Fig. 3—2-1/2-digit DVM uses a binary D/A converter to accomplish conversion of a BCD digital input signal.

One circuit that fills the need is the operational-amplifier current source shown in Fig. 2.

There is one other difference between the basic 2-digit system and the 2-1/2-digit circuit. In the 2-1/2-digit implementation, a CMOS hex-inverter is used instead of a quad 2-input NOR gate package. This is because the 2-1/2-digit system requires five switches.

The 2-1/2-digit system is calibrated as follows:

- a) Attach an accurate DVM to the output, e,... With all inputs LOW, adjust ZERO CAL potentiometer for a zero reading of e,..
- b) Put a HIGH input only on the mostsignificant bit of the monolithic D/A (0 1000 0000), then read and record e<sub>o</sub>.
- c) Put a HIGH input only on the 1/2 digit and adjust the 1/2 SCALE CAL potentiometer to

- give exactly 1.25 times the reading of the previous step.
- d) With all inputs LOW, readjust the ZERO CAL potentiometer for an e<sub>o</sub> of exactly 0V.
- e) Finally, input the BCD word for 199, (1 1001 1001) and adjust the F.S. CAL for the desired full-scale reading.

### **DVM** shows application

Fig. 3 shows how the technique can be incorporated into a 2-1/2-digit digital voltmeter. The circuit uses the staircase type of conversion, with the staircase being produced by the 2-1/2-digit BCD-coded D/A and the BCD counters. The MLM301A is used as a comparator to compare the staircase to the input signal.