



# Application Note: I/O Voltage Level Shifting

15 April 2013; updated 21 May 2013

## Q:

The RHD2000 USB interface board includes general-purpose digital I/O, but these lines operate with 3.3V logic levels. How can these signals be scaled to and from 5.0V logic levels?

The interface board also includes analog-to-digital converters, but the range of these ADCs is restricted to positive voltages in the range of 0 - 3.3V. Is there a circuit that can adapt these ADCs to sense voltages in the range of  $\pm 3.3V$  or  $\pm 5.0V$ ?

## A:

This application note presents relatively simple circuits that can be used to interface the 3.3V signals on the RHD2000 USB interface board to a wider range of voltage levels. All the circuits shown in this document can be built using breadboard, wirewrap, or hand soldering techniques. None of these circuits operate at high speeds (the maximum sampling rate of the RHD2000 USB interface board is 30 kS/s), so users need not worry about parasitic capacitances, ground planes, or other high-performance circuit building techniques. We have purposely selected parts that are available in DIP packages so that surface-mount assembly can be avoided to ease assembly.

### Converting 3.3V Digital Output Signals to 5.0V

The RHD2000 USB interface board allocates 16 output lines from the Spartan-6 FPGA as general-purpose digital outputs. These signals are controlled using the **setTtlOut** function in the Rhythm C++ API (see the **RHD2000 USB/FPGA Interface** document for more information). Since the FPGA operates with 3.3V I/O, these signals operate between ground and 3.3V.

A circuit for scaling these 3.3V signals to 5.0V signals is shown in Figure 1 on the following page. The circuit uses an MC14504B level shifter integrated circuit (IC) that contains six digital voltage translator circuits. The input pins ( $\mathbf{Ain} - \mathbf{Fin}$ ) receive digital signals operating on a voltage scale defined by the **VCC** power pin. These signals are shifted to the voltage scale defined by the **VDD** power pin and appear on the output pins ( $\mathbf{Aout} - \mathbf{Fout}$ ). It is recommended that 0.1  $\mu$ F capacitors to ground be placed close to the power pins to supply rapid currents when switching occurs.

The 50  $\Omega$  resistors are optional, but will reduce signal reflections if the output pins are connected to a long coaxial cable. If long twisted pairs or ribbon cables are used, a resistor value of 100  $\Omega$  or 200  $\Omega$  may work better to dampen reflections.



# **RHD2000-EVAL Application Note**



signals to 5.0V logic signals.

Figure 1. Digital level shifter circuit to convert 3.3V logic Figure 2. Simple level shifter circuit to convert 5.0V logic signals to 3.3V logic signals.

The MC14504B chip is widely available in both 16-pin DIP and SOIC (surface mount) packages. Digi-Key part numbers are MC14504BCPGOS-ND (for the DIP package) and MC14504BDR2GOSCT-ND (for the SOIC package). More information on this part can be found by searching for the MC14504B datasheet. The MC14504B chip introduces a delay of approximately 200 ns to digital signals in this configuration; faster level-shifter chips are available from many companies. If the MC14504B is not available, the Texas Instruments CD4504B (Digi-Key part number 296-3527-5-ND for the DIP version) may be used in its place.

An alternate level-shifting IC containing eight level shifters in one 24-pin package is the SN74LVC4245A, but this part is only available in surface-mount packages.

#### Converting 5.0V Digital Input Signals to 3.3V

The RHD2000 USB interface board also includes 16 general-purpose digital input lines. These inputs are sampled in synchrony with all amplifier channels when using the RHD2000 interface software, and they may also be accessed using the getTtlln function in the Rhythm C++ API (see the RHD2000 USB/FPGA Interface document for more information). Since the FPGA operates with 3.3V I/O, these signals should not exceed 3.3V.

A simple circuit for scaling 5.0V logic signals to 3.3V signals is shown in Figure 2 above. This is a simple voltage divider, and its speed is limited by the parallel resistance of the two resistors in combination with the capacitance at the FPGA input pin (approximately 35 pF). Since the digital inputs are never sampled faster than 30 kS/s, this simple circuit will suffice for most applications. Using larger resistors is not recommended due to the "pull-down" current of roughly 300 µA associated with each digital input.

The input resistance of this circuit is approximately 10 kΩ, so it will draw 0.5 mA when driven with a "high" 5.0V logic signal. If this current draw cannot be tolerated, a downward level shifter can be built using the MC14504B chip shown in Figure 1, but reversing the voltages on the VCC and VDD pins. The MC14504B chip introduces a delay of approximately 350 ns to digital signals in this configuration; faster level-shifter chips are available from many companies.

## Converting ±3.3V Analog Input Signals to 0 – 3.3V Signals

The RHD2000 USB interface board includes eight analog input lines that use analog-to-digital converters (ADCs) to sample voltages in the range of 0 - 3.3V. These voltages are sampled in synchrony with the amplifier channels when using the RHD2000 interface software, and are also accessible using the Rhythm C++ API (see the RHD2000 USB/FPGA Interface document for more information).

In many practical applications, both negative and positive voltages may need to be observed (e.g., an AC-coupled sensor with a zero-volt baseline signal). A circuit that scales voltage in the range of ±3.3V to the 0 - 3.3V range required by the interface board ADCs is shown in Figure 3 on the following page.



# **RHD2000-EVAL Application Note**



**Figure 3.** Circuit to scale analog voltages in the range of  $\pm 3.3$ V to the range of 0 - 3.3V for sensing by the RHD2000 interface board. The label "1%" indicates that resistors with 1% (or better) precision should be used for particular resistors.

This circuit uses the LMC6482 operational amplifier IC which contains two independent op amps. Importantly, these op amps operate "rail to rail" over the entire ±3.3V power supply range. They also have very small input bias currents and small voltage offsets. The LMC6482 is available in both DIP and SOIC (surface mount) packages. The Digi-Key part number for the 8-pin DIP package is LMC6482AIN/NOPB-ND; the part number for the 8-pin SOIC is LMC6482IMX/NOPBCT-ND.

The op amp on the left of Figure 3 is a unity-gain buffer that drives R1 and R2; these resistors scale the voltage by half and shift its range to 0-3.3V. The capacitor C1, in combination with the parallel combination of R1 and R2 (i.e.,  $10 \text{ k}\Omega$ ), set a low-pass filter frequency close to 15 kHz, which is appropriate for anti-alias filtering at a sample rate of 30 kS/s. The value of C1 may be increased to lower this filter frequency for lower sample rates.

The op amp on the right of Figure 3, along with R3, R4, and C2, form a unity-gain buffer capable of rapidly driving the capacitive input of an ADC. Capacitors C3 and C4 filter the ±3.3V power supply (which may be obtained from the RHD2000 USB interface board) and should be placed in close proximity to the LMC6482 chip. For best accuracy, the +3.3V supply should be taken from the connector next to the analog inputs on the RHD2000 USB interface board, since it is this supply that powers the ADCs. (The -3.3V supply can be taken from the connector between the digital inputs and analog outputs.)

Resistor R6 is used to protect the input op amp against over-voltage conditions, and R5 is used to ensure that the two inputs to the op amp see the same resistance to minimize voltage offsets. The input resistance of this circuit is greater than  $10^{12} \Omega$  owing to the CMOS inputs of the LMC6482 op amps. (See the LMC6482 datasheet for more information on this device.)



Figure 4. Circuit to scale analog voltages in the range of  $\pm 5.0$ V to the range of 0 - 3.3V for sensing by the RHD2000 interface board. The circuit is similar to the one in Figure 3, but the value of R5 has changed, R6 has been removed, and R7 and R8 have been added.



## **RHD2000-EVAL Application Note**

#### Converting ±5.0V Analog Input Signals to 0 – 3.3V Signals

In some applications, a wider range of analog voltages must be observed. The circuit shown in Figure 4 on the previous page scales voltages in the range of  $\pm 5.0$ V to the 0 – 3.3V range of the RHD2000 USB interface board ADCs.

This circuit is very similar to the one shown in Figure 3. A voltage divider consisting of resistor R7 and R8 have been added, R6 has been removed (though it could be kept), and the value of R5 has been changed to match the resistance seen by the positive input of the op amp (i.e., the parallel combination of R7 and R8).

The resistor divider formed by R7 and R8 scales the voltage down by a factor of 0.66, which maps  $\pm 5.0$ V to  $\pm 3.3$ V. The rest of the circuit works identically to the circuit from Figure 3. This circuit has a lower input resistance than the previous circuit: approximately 1.0 M $\Omega$ . If an extremely high input resistance is needed, then another unity-gain op amp must be added to the input as a buffer, but this op amp would have to be powered from a  $\pm 5.0$ V power supply to follow signals over this range. The LMC6482 can be operated from a  $\pm 5.0$ V supply, but the RHD2000 USB interface board provides only a  $\pm 5.0$ V voltage supply and not a  $\pm 5.0$ V supply.

Alternate values of R7 and R8 may be selected to scale a wider range of voltages to the 0-3.3V ADC level. For example, using R7 = 330 k $\Omega$  and R8 = 665 k $\Omega$  (both standard 1% precision resistance values) allows voltages over the range of  $\pm 10V$  to be accepted.

