## : ©hipsmall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from,Europe,America and south Asia,supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts,Customers Priority,Honest Operation, and Considerate Service",our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip,ALPS,ROHM,Xilinx,Pulse,ON,Everlight and Freescale. Main products comprise IC,Modules,Potentiometer,IC Socket,Relay,Connector.Our parts cover such applications as commercial,industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!


## Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832
Email \& Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, \#122 Zhenhua RD., Futian, Shenzhen, China

## Data Sheet

## FEATURES

## 1024-position resolution

Nonvolatile memory maintains wiper setting
Power-on refresh with EEMEM setting
EEMEM restore time: $140 \boldsymbol{\mu s}$ typ
Full monotonic operation
$10 \mathrm{k} \Omega, 50 \mathrm{k} \Omega$, and $100 \mathrm{k} \Omega$ terminal resistance
Permanent memory write protection
Wiper setting readback
Predefined linear increment/decrement instructions
Predefined $\pm 6$ dB/step log taper increment/decrement instructions
SP ${ }^{\oplus}$-compatible serial interface
3 V to 5 V single-supply or $\pm 2.5 \mathrm{~V}$ dual-supply operation 28 bytes extra nonvolatile memory for user-defined data 100 -year typical data retention, $\mathrm{T}_{\mathrm{A}}=55^{\circ} \mathrm{C}$

## APPLICATIONS

Mechanical potentiometer replacement Instrumentation: gain, offset adjustment Programmable voltage to current conversion Programmable filters, delays, time constants Programmable power supply Low resolution DAC replacement
Sensor calibration


Figure 2. $R_{w A}(D)$ and $R_{w B}(D)$ vs. Decimal Code
resistance between Terminals W-A and Terminals W-B. This setting can be stored into the EEMEM and is transferred automatically to the RDAC register during system power-on.

The EEMEM content can be restored dynamically or through external $\overline{\mathrm{PR}}$ strobing, and a $\overline{\mathrm{WP}}$ function protects EEMEM contents. To simplify the programming, the linear-step increment or decrement commands can be used to move the RDAC wiper up or down, one step at a time. The $\pm 6 \mathrm{~dB}$ step commands can be used to double or half the RDAC wiper setting.

The AD5231 is available in a 16 -lead TSSOP. The part is guaranteed to operate over the extended industrial temperature range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

[^0]
## COMPARABLE PARTS

View a parametric search of comparable parts.

## DOCUMENTATION

## Application Notes

- AN-1291: Digital Potentiometers: Frequently Asked Questions
- AN-349: Keys to Longer Life for CMOS
- AN-579: Versatile Programmable Amplifiers Using Digital Potentiometers with Nonvolatile Memory
- AN-580: Programmable Oscillator Uses Digital Potentiometers
- AN-582: Resolution Enhancements of Digital Potentiometers with Multiple Devices
- AN-686: Implementing an $I^{2} C^{\oplus}$ Reset


## Data Sheet

- AD5231: Nonvolatile Memory, 1024-Position Digital Potentiometer Data Sheet


## SOFTWARE AND SYSTEMS REQUIREMENTS

- Digital Potentiometer Linux Driver


## DESIGN RESOURCES

- AD5231 Material Declaration
- PCN-PDN Information
- Quality And Reliability
- Symbols and Footprints


## DISCUSSIONS

View all AD5231 EngineerZone Discussions.

## SAMPLE AND BUY

Visit the product page to see pricing options.

## TECHNICAL SUPPORT $\square$

Submit a technical question or find your regional support number.

## DOCUMENT FEEDBACK

Submit feedback for this data sheet.

## TABLE OF CONTENTS

Features .....  1
Applications .....
Functional Block Diagram .....  1
General Description .....  1
Revision History ..... 2
Specifications ..... 3
Electrical Characteristics- $10 \mathrm{k} \Omega, 50 \mathrm{k} \Omega, 100 \mathrm{k} \Omega$ Versions .....  3
Timing Characteristics- $10 \mathrm{k} \Omega, 50 \mathrm{k} \Omega, 100 \mathrm{k} \Omega$ Versions ..... 5
Absolute Maximum Ratings ..... 7
ESD Caution ..... 7
Pin Configuration and Function Descriptions ..... 8
Typical Performance Characteristics ..... 9
Test Circuits. ..... 13
Theory of Operation ..... 14
Scratchpad and EEMEM Programming ..... 14
Basic Operation ..... 14
EEMEM Protection ..... 14
Digital Input/Output Configuration ..... 15
Serial Data Interface ..... 15
Daisy-Chain Operation ..... 15
Terminal Voltage Operation Range ..... 16
Power-Up Sequence ..... 16
REVISION HISTORY
3/13—Rev. C to Rev. D
Added $\mathrm{t}_{\mathrm{wp}}$; Table 2 ..... 5
Changes to Ordering Guide ..... 27
1/07—Rev. B to Rev. C
Updated Format ..... Universal
Changes to Dynamic Characteristics Specifications. .....  4
Changes to Table 2 Footnote .....  5
Changes to Table 3 .....  7
Changes to Ordering Guide ..... 27
9/04—Rev. A to Rev. B
Updated Format ..... Universal
Changes to Table 20 ..... 23
Changes to Resistance Scaling Section ..... 25
Changes to Ordering Guide ..... 27
Latched Digital Outputs ..... 16
Advanced Control Modes ..... 18
RDAC Structure ..... 19
Programming the Variable Resistor ..... 19
Programming the Potentiometer Divider ..... 20
Programming Examples ..... 21
Flash/EEMEM Reliability. ..... 22
Applications ..... 23
Bipolar Operation from Dual Supplies ..... 23
High Voltage Operation ..... 23
Bipolar Programmable Gain Amplifier ..... 23
10-Bit Bipolar DAC ..... 23
10-Bit Unipolar DAC ..... 24
Programmable Voltage Source with Boosted Output ..... 24
Programmable Current Source ..... 24
Programmable Bidirectional Current Source ..... 25
Resistance Scaling ..... 25
RDAC Circuit Simulation Model ..... 26
Outline Dimensions ..... 27
Ordering Guide ..... 27
5/04-Rev. 0 to Rev. A
Updated formatting. Universal
Edits to Features, General Description, and Block Diagram ..... 1
Changes to Specifications ..... 3
Replaced Timing Diagrams. ..... 6
Changes to Pin Function Descriptions ..... 8
Changes to Typical Performance Characteristics. ..... 9
Changes to Test Circuits ..... 13
Edits to Theory of Operation ..... 14
Edits to Applications ..... 23
Updated Outline Dimensions ..... 27
12/01—Revision 0: Initial Version

## SPECIFICATIONS

## ELECTRICAL CHARACTERISTICS— $\mathbf{1 0} \mathbf{~ k} \boldsymbol{\Omega}, \mathbf{5 0} \mathbf{k} \Omega, \mathbf{1 0 0} \mathbf{k} \Omega$ VERSIONS

$\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V} \pm 10 \%$ or $5 \mathrm{~V} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~V}_{\mathrm{A}}=\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{B}}=0 \mathrm{~V},-40^{\circ} \mathrm{C}<\mathrm{T}_{\mathrm{A}}<+85^{\circ} \mathrm{C}$, unless otherwise noted.
Table 1.

| Parameter | Symbol | Conditions | Min | Typ ${ }^{1}$ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS— <br> RHEOSTAT MODE <br> Resistor Differential Nonlinearity ${ }^{2}$ <br> Resistor Integral Nonlinearity ${ }^{2}$ <br> Nominal Resistor Tolerance <br> Resistance Temperature Coefficient Wiper Resistance | R-DNL <br> R-INL <br> $\Delta R_{A B} / R_{A B}$ <br> $\left(\Delta R_{w z} / R_{w b}\right) / \Delta T \times 10^{6}$ <br> Rw | $\begin{aligned} & \mathrm{R}_{w B}, V_{A}=\mathrm{NC}, \text { monotonic } \\ & \mathrm{Rw}_{w,}, V_{A}=\mathrm{NC} \\ & \mathrm{D}=0 \times 3 \mathrm{FF} \\ & \\ & \mathrm{I}_{\mathrm{w}}=100 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{DD}}=5.5 \mathrm{~V}, \\ & \text { code }=\text { half scale } \\ & \mathrm{I}_{\mathrm{w}}=100 \mu \mathrm{~A}, \mathrm{~V}_{\mathrm{DD}}=3 \mathrm{~V}, \\ & \text { code }=\text { half scale } \end{aligned}$ | $\begin{aligned} & -1 \\ & -0.2 \\ & -40 \end{aligned}$ | $\begin{aligned} & \pm 1 / 2 \\ & 600 \\ & 15 \\ & 50 \end{aligned}$ | $\begin{aligned} & +1.8 \\ & +0.2 \\ & +20 \\ & 100 \end{aligned}$ | $\begin{aligned} & \text { LSB } \\ & \text { LSB } \\ & \% \\ & \mathrm{ppm} /{ }^{\circ} \mathrm{C} \\ & \Omega \\ & \Omega \end{aligned}$ |
| DC CHARACTERISTICS— <br> POTENTIOMETER DIVIDER MODE <br> Resolution <br> Differential Nonlinearity ${ }^{3}$ <br> Integral Nonlinearity ${ }^{3}$ <br> Voltage Divider Temperature <br> Coefficient <br> Full-Scale Error <br> Zero-Scale Error | $\begin{aligned} & \mathrm{N} \\ & \mathrm{DNL} \\ & \mathrm{INL} \\ & \left(\Delta \mathrm{~V}_{\mathrm{w}} / \mathrm{V}_{\mathrm{w}}\right) / \Delta \mathrm{T} \times 10^{6} \\ & \mathrm{~V}_{\text {WFSE }} \\ & \mathrm{V}_{\text {WZSE }} \\ & \hline \end{aligned}$ | Monotonic, $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> Monotonic, $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ or $+85^{\circ} \mathrm{C}$ <br> Code $=$ half scale <br> Code $=$ full scale <br> Code $=$ zero scale | $\begin{aligned} & -1 \\ & -1 \\ & -0.4 \\ & \\ & -3 \\ & 0 \end{aligned}$ | $\pm 1 / 2$ 15 | $\begin{aligned} & 10 \\ & +1 \\ & +1.25 \\ & +0.4 \\ & \\ & 0 \\ & 1.5 \end{aligned}$ | Bits <br> LSB <br> LSB <br> LSB <br> $\mathrm{ppm} /{ }^{\circ} \mathrm{C}$ <br> \% FS <br> \% FS |
| RESISTOR TERMINALS <br> Terminal Voltage Range ${ }^{4}$ <br> Capacitance A, $\mathrm{B}^{5}$ <br> Capacitance $\mathrm{W}^{5}$ <br> Common-Mode Leakage Current ${ }^{5,6}$ | $\mathrm{V}_{\mathrm{A}, \mathrm{B}, \mathrm{W}}$ <br> $\mathrm{C}_{\mathrm{A}, \mathrm{B}}$ <br> Cw <br> Ісм | $\mathrm{f}=1 \mathrm{MHz}$, measured to GND, code = half-scale $\mathrm{f}=1 \mathrm{MHz}$, measured to GND, code $=$ half-scale $\mathrm{V}_{\mathrm{W}}=\mathrm{V}_{\mathrm{DD}} / 2$ | $\mathrm{V}_{\text {ss }}$ | 50 <br> 50 <br> 0.01 | $V_{\text {DD }}$ | V <br> pF <br> pF <br> $\mu \mathrm{A}$ |
| DIGITAL INPUTS AND OUTPUTS <br> Input Logic High <br> Input Logic Low <br> Input Logic High <br> Input Logic Low <br> Input Logic High | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | With respect to GND, $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ <br> With respect to GND, $V_{D D}=5 \mathrm{~V}$ <br> With respect to GND, $\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$ <br> With respect to $G N D, V_{D D}=3 \mathrm{~V}$ <br> With respect to GND, $\mathrm{V}_{\mathrm{DD}}=+2.5 \mathrm{~V}$, <br> $\mathrm{V}_{\mathrm{ss}}=-2.5 \mathrm{~V}$ | 2.4 2.1 2.0 |  | 0.8 0.6 | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \\ & \mathrm{~V} \end{aligned}$ |
| Input Logic Low | VIL | With respect to GND, $\mathrm{V}_{\mathrm{DD}}=+2.5 \mathrm{~V}$, $V_{s s}=-2.5 \mathrm{~V}$ |  |  | 0.5 | V |
| Output Logic High (SDO, RDY) | Vor | Rpull-UP $=2.2 \mathrm{k} \Omega$ to 5 V (see Figure 26) | 4.9 |  |  | V |
| Output Logic Low | Voı | $\begin{aligned} & \mathrm{IoL}=1.6 \mathrm{~mA}, \mathrm{~V}_{\text {LoGic }}=5 \mathrm{~V} \\ & \text { (see Figure } 26 \text { ) } \end{aligned}$ |  |  | 0.4 | V |
| Input Current <br> Input Capacitance ${ }^{5}$ <br> Output Current ${ }^{5}$ | IL $\mathrm{C}_{\text {II }}$ $\mathrm{I}_{10}, \mathrm{l}_{02}$ | $V_{I N}=0 V \text { or } V_{D D}$ $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\ & \mathrm{~V}_{\mathrm{DD}}=2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |  | $\begin{aligned} & 4 \\ & 50 \\ & 7 \end{aligned}$ | $\pm 2.5$ | $\mu \mathrm{A}$ <br> pF <br> mA <br> mA |


| Parameter | Symbol | Conditions | Min | Typ ${ }^{1}$ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| POWER SUPPLIES |  |  |  |  |  |  |
| Single-Supply Power Range | $V_{\text {DD }}$ | $\mathrm{V}_{5 s}=0 \mathrm{~V}$ | 2.7 |  | 5.5 | V |
| Dual-Supply Power Range | $\mathrm{V}_{\mathrm{DD}} / \mathrm{V}_{\text {SS }}$ |  | $\pm 2.25$ |  | $\pm 2.75$ | V |
| Positive Supply Current | ldo | $\mathrm{V}_{\mathrm{H}}=\mathrm{V}_{\text {DD }}$ or $\mathrm{V}_{\mathrm{IL}}=\mathrm{GND}$ |  | 2.7 | 10 | $\mu \mathrm{A}$ |
| Negative Supply Current | Iss | $\begin{aligned} & \mathrm{V}_{\mathrm{H}}=\mathrm{V}_{\mathrm{DD}} \text { or } \mathrm{V}_{\mathrm{IL}}=\mathrm{GND}, \\ & \mathrm{~V}_{\mathrm{DD}}=+2.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=-2.5 \mathrm{~V} \end{aligned}$ |  | 0.5 | 10 | $\mu \mathrm{A}$ |
| EEMEM Store Mode Current | ldo (store) | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}}=\mathrm{V}_{\mathrm{DD}} \text { or } \mathrm{V}_{\mathrm{IL}}=\mathrm{GND}, \\ & \mathrm{~V}_{\mathrm{SS}}=\mathrm{GND}, \mathrm{I}_{\mathrm{IS}} \approx 0 \end{aligned}$ |  | 40 |  | mA |
|  | $\mathrm{I}_{\text {S }}$ (store) | $\mathrm{V}_{\mathrm{DD}}=+2.5 \mathrm{~V}, \mathrm{~V}_{S S}=-2.5 \mathrm{~V}$ |  | -40 |  | mA |
| EEMEM Restore Mode Current ${ }^{7}$ | ldD (restore) | $\begin{aligned} & \mathrm{V}_{\mathrm{HH}}=\mathrm{V}_{\mathrm{DD}} \text { or } \mathrm{V}_{\mathrm{IL}}=\mathrm{GND}, \\ & \mathrm{~V}_{\mathrm{SS}}=\mathrm{GND}, \mathrm{ISS} \approx 0 \end{aligned}$ | 0.3 | 3 | 9 | mA |
|  | Iss (restore) | $\mathrm{V}_{\mathrm{DD}}=+2.5 \mathrm{~V}, \mathrm{~V}_{S S}=-2.5 \mathrm{~V}$ | -0.3 | -3 | -9 | mA |
| Power Dissipation ${ }^{8}$ | PDISS | $\mathrm{V}_{\mathrm{H}}=\mathrm{V}_{\text {DD }}$ or $\mathrm{V}_{\text {IL }}=\mathrm{GND}$ |  | 0.018 | 0.05 | mW |
| Power Supply Sensitivity ${ }^{5}$ | Pss | $\Delta V_{D D}=5 \mathrm{~V} \pm 10 \%$ |  | 0.002 | 0.01 | \%/\% |
| DYNAMIC CHARACTERISTIC55,9 |  |  |  |  |  |  |
| Bandwidth | BW | $\begin{aligned} & -3 \mathrm{~dB}, \mathrm{R}_{A B}=10 \mathrm{k} \Omega / 50 \mathrm{k} \Omega / \\ & 100 \mathrm{k} \Omega \end{aligned}$ |  | 370/85/44 |  | kHz |
| Total Harmonic Distortion | THDw | $\begin{aligned} & \mathrm{V}_{\mathrm{A}}=1 \mathrm{Vrms}, \mathrm{~V}_{\mathrm{B}}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{kHz}, \\ & \mathrm{R}_{\mathrm{AB}}=10 \mathrm{k} \Omega \end{aligned}$ |  | 0.045 |  | \% |
|  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{A}}=1 \mathrm{Vrms}, \mathrm{~V}_{\mathrm{B}}=0 \mathrm{~V}, \mathrm{f}=1 \mathrm{kHz}, \\ & \mathrm{R}_{A B}=50 \mathrm{k} \Omega, 100 \mathrm{k} \Omega \end{aligned}$ |  | 0.022 |  | \% |
| Vw Settling Time | ts | $\begin{aligned} & V_{A}=V_{D D}, V_{B}=0 \mathrm{~V}, \\ & V_{W}=0.50 \% \text { error band, } \\ & \text { Code } 0 \times 000 \text { to } 0 \times 200 \\ & \text { for } R_{A B}=10 \mathrm{k} \Omega / 50 \mathrm{k} \Omega / 100 \mathrm{k} \Omega \end{aligned}$ |  | 1.2/3.7/7 |  | $\mu \mathrm{s}$ |
| Resistor Noise Voltage | en_wb | $\mathrm{R}_{\text {wB }}=5 \mathrm{k} \Omega, \mathrm{f}=1 \mathrm{kHz}$ |  | 9 |  | $\mathrm{nV} / \mathrm{V} \mathrm{Hz}$ |

${ }^{1}$ Typical values represent average readings at $25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$.
${ }^{2}$ Resistor position nonlinearity error ( $\mathrm{R}-\mathrm{INL}$ ) is the deviation from an ideal value measured between the maximum resistance and the minimum resistance wiper positions. R-DNL measures the relative step change from ideal between successive tap positions. $I_{W} \sim 50 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{DD}}=2.7 \mathrm{~V}$ and $\mathrm{I}_{\mathrm{w}} \sim 400 \mu \mathrm{~A} @ \mathrm{~V}_{\mathrm{DD}}=5 \mathrm{~V}$ for the $R_{A B}=10 \mathrm{k} \Omega$ version, $\mathrm{I}_{\mathrm{w}} \sim 50 \mu \mathrm{~A}$ for the $\mathrm{R}_{A B}=50 \mathrm{k} \Omega$, and $\mathrm{I} w \sim 25 \mu \mathrm{~A}$ for the $\mathrm{R}_{A B}=100 \mathrm{k} \Omega$ version (see Figure 26).
${ }^{3}$ INL and DNL are measured at $V_{W}$ with the RDAC configured as a potentiometer divider similar to a voltage output $D A C . V_{A}=V_{D D}$ and $V_{B}=V_{S S}$. DNL specification limits of
-1 LSB minimum are guaranteed monotonic operating condition (see Figure 27).
${ }^{4}$ Resistor Terminal A, Resistor Terminal B, and Resistor Terminal W have no limitations on polarity with respect to each other. Dual-supply operation enables groundreferenced bipolar signal adjustment.
${ }^{5}$ Guaranteed by design and not subject to production test.
${ }^{6}$ Common-mode leakage current is a measure of the dc leakage from any Terminal B-W to a common-mode bias level of $\mathrm{V}_{\mathrm{DD}} / 2$.
${ }^{7}$ EEMEM restore mode current is not continuous. Current consumed while EEMEM locations are read and transferred to the RDAC register (see Figure 23). To minimize power dissipation, a NOP Instruction $0(0 \times 0)$ should be issued immediately after Instruction 1 ( $0 \times 1$ ).
${ }^{8} \mathrm{P}_{\text {DISS }}$ is calculated from $\left(\mathrm{I}_{\mathrm{DD}} \times \mathrm{V}_{\mathrm{DD}}\right)+\left(\mathrm{l}_{\mathrm{SS}} \times \mathrm{V}_{\text {SS }}\right)$.
${ }^{9}$ All dynamic characteristics use $\mathrm{V}_{\mathrm{DD}}=+2.5 \mathrm{~V}$ and $\mathrm{V}_{S S}=-2.5 \mathrm{~V}$.

## TIMING CHARACTERISTICS—10 k $\Omega, \mathbf{5 0} \mathbf{k} \Omega, 100 \mathrm{k} \Omega$ VERSIONS

$\mathrm{V}_{\mathrm{DD}}=3 \mathrm{~V}$ to $5.5 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$, and $-40^{\circ} \mathrm{C}<\mathrm{T}_{\mathrm{A}}<+85^{\circ} \mathrm{C}$, unless otherwise noted.
Table 2.

\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter \& Symbol \& Conditions \& Min \& Typ \({ }^{1}\) \& Max \& Unit \\
\hline \begin{tabular}{l}
INTERFACE TIMING CHARACTERISTICS \({ }^{2,3}\) \\
Clock Cycle Time (tcrc) \\
\(\overline{\mathrm{CS}}\) Setup Time \\
CLK Shutdown Time to \(\overline{\mathrm{CS}}\) Rise \\
Input Clock Pulse Width \\
Data Setup Time \\
Data Hold Time \\
\(\overline{\mathrm{CS}}\) to SDO-SPI Line Acquire \\
\(\overline{\mathrm{CS}}\) to SDO-SPI Line Release \\
CLK to SDO Propagation Delay \({ }^{4}\) \\
CLK to SDO Data Hold Time \\
\(\overline{\mathrm{CS}}\) High Pulse Width \({ }^{5}\) \\
\(\overline{C S}\) High to \(\overline{C S}\) High \(^{5}\) \\
RDY Rise to \(\overline{C S}\) Fall \\
\(\overline{C S}\) Rise to RDY Fall Time \\
Store/Read EEMEM Time \({ }^{6}\) \\
Power-On EEMEM Restore Time \\
Dynamic EEMEM Restore Time \\
\(\overline{\mathrm{WP}}\) High or Low to \(\overline{\mathrm{CS}}\) Fall Time \\
\(\overline{\mathrm{CS}}\) Rise to Clock Rise/Fall Setup \\
Preset Pulse Width (Asynchronous) \\
Preset Response Time to Wiper Setting
\end{tabular} \& \begin{tabular}{l}
\(\mathrm{t}_{1}\) \\
\(\mathrm{t}_{2}\) \\
\(\mathrm{t}_{3}\) \\
\(\mathrm{t}_{4}, \mathrm{t}_{5}\) \\
\(\mathrm{t}_{6}\) \\
\(\mathrm{t}_{7}\) \\
\(\mathrm{t}_{8}\) \\
\(\mathrm{t}_{9}\) \\
\(\mathrm{t}_{10}\) \\
\(\mathrm{t}_{11}\) \\
\(\mathrm{t}_{12}\) \\
\(\mathrm{t}_{13}\) \\
\(\mathrm{t}_{14}\) \\
\(\mathrm{t}_{15}\) \\
\(\mathrm{t}_{16}\) \\
teemem1 \\
teemem2 \\
\(t_{\text {WP }}\) \\
\(\mathrm{t}_{17}\) \\
tpRW \\
tpresp
\end{tabular} \& \begin{tabular}{l}
Clock level high or low \\
From positive CLK transition \\
From positive CLK transition
\[
\begin{aligned}
\& \mathrm{R}_{\mathrm{P}}=2.2 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}<20 \mathrm{pF} \\
\& \mathrm{R}_{\mathrm{P}}=2.2 \mathrm{k} \Omega, \mathrm{C}_{\mathrm{L}}<20 \mathrm{pF}
\end{aligned}
\] \\
Applies to instructions \(0 \times 2,0 \times 3\), and \(0 \times 9\)
\[
\begin{aligned}
\& \mathrm{R}_{A B}=10 \mathrm{k} \Omega \\
\& \mathrm{R}_{A B}=10 \mathrm{k} \Omega
\end{aligned}
\] \\
Not shown in timing diagram \(\overline{\mathrm{PR}}\) pulsed low to refresh wiper positions
\end{tabular} \& \[
\begin{aligned}
\& 20 \\
\& 10 \\
\& 1 \\
\& 10 \\
\& 5 \\
\& 5 \\
\& \\
\& \\
\& 0 \\
\& 10 \\
\& 4 \\
\& 0 \\
\& \hline
\end{aligned}
\]
\[
50
\] \& \[
\begin{aligned}
\& 0.1 \\
\& 25 \\
\& 140 \\
\& 140 \\
\& 40 \\
\& \\
\& 70
\end{aligned}
\] \& 40
50
50

0.15 \& | ns |
| :--- |
| ns |
| tcyc |
| ns |
| ns |
| ns |
| ns |
| ns |
| ns |
| ns |
| ns |
| tcre |
| ns |
| ms |
| ms |
| $\mu \mathrm{s}$ |
| $\mu \mathrm{s}$ |
| ns |
| ns |
| ns |
| $\mu \mathrm{s}$ | <br>

\hline FLASH/EE MEMORY RELIABILITY Endurance ${ }^{7}$ Data Retention ${ }^{8}$ \& \& \& 100 \& \& \& | kCycles |
| :--- |
| Years | <br>

\hline
\end{tabular}

[^1]
## AD5231

## Timing Diagrams



Figure 3. $C P H A=1$ Timing Diagram


Figure 4. $C P H A=0$ Timing Diagram

## ABSOLUTE MAXIMUM RATINGS

$\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, unless otherwise noted.

Table 3.

| Parameters | Ratings |
| :---: | :---: |
| $V_{\text {DD }}$ to GND | -0.3 V, +7 V |
| $V_{\text {ss }}$ to GND | $+0.3 \mathrm{~V},-7 \mathrm{~V}$ |
| $V_{\text {dD }}$ to $V_{\text {SS }}$ | 7 V |
| $\mathrm{V}_{\mathrm{A}}, \mathrm{V}_{\mathrm{B}}, \mathrm{V}_{\mathrm{w}}$ to GND | $\mathrm{V}_{S S}-0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}+0.3 \mathrm{~V}$ |
| A-B, A-W, B-W |  |
| Intermittent ${ }^{1}$ | $\pm 20 \mathrm{~mA}$ |
| Continuous | $\pm 2 \mathrm{~mA}$ |
| Digital Input and Output Voltage to GND | $-0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}+0.3 \mathrm{~V}$ |
| Operating Temperature Range ${ }^{2}$ | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| Maximum Junction Temperature ( $\mathrm{T}, \mathrm{max}$ ) | $150^{\circ} \mathrm{C}$ |
| Storage Temperature | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |
| Reflow Soldering |  |
| Peak Temperature | $260^{\circ} \mathrm{C}$ |
| Time at Peak Temperature | 20 sec to 40 sec |
| Thermal Resistance Junction-to-Ambient $\left(\theta_{\text {JA }}\right)$,TSSOP-16 | $150^{\circ} \mathrm{C} / \mathrm{W}$ |
| Junction-to-Case ( $\theta_{\text {ıc }}$, , TSSOP-16 | $28^{\circ} \mathrm{C} / \mathrm{W}$ |
| Package Power Dissipation | $\left(\mathrm{T}_{J} \mathrm{max}-\mathrm{T}_{\mathrm{A}}\right) / \theta_{\mathrm{JA}}$ |

${ }^{1}$ Maximum terminal current is bounded by the maximum current handling of the switches, maximum power dissipation of the package, and maximum applied voltage across any two of the A, B, and W terminals at a given resistance.
${ }^{2}$ Includes programming of nonvolatile memory.

Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; functional operation of the device at these or any other conditions above those indicated in the operational section of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## ESD CAUTION

|  | ESD (electrostatic discharge) sensitive device. <br> Charged devices and circuit boards can discharge <br> without detection. Although this product features <br> patented or proprietary protection circuitry, damage <br> may occur on devices subjected to high energy ESD. <br> Therefore, proper ESD precautions should be taken to <br> avoid performance degradation or loss of functionality. |
| :--- | :--- |

## PIN CONFIGURATION AND FUNCTION DESCRIPTIONS



Figure 5. Pin Configuration

Table 4. Pin Function Descriptions

| Pin No. | Mnemonic | Description |
| :---: | :---: | :---: |
| 1 | O1 | Nonvolatile Digital Output 1. ADDR $=0 \times 1$, data bit position D0. For example, to store O 1 high, the data bit format is $0 \times 310001$. |
| 2 | CLK | Serial Input Register Clock Pin. Shifts in one bit at a time on positive clock edges. |
| 3 | SDI | Serial Data Input Pin. Shifts in one bit at a time on positive clock CLK edges. MSB loaded first. |
| 4 | SDO | Serial Data Output Pin. Serves readback and daisy-chain functions. <br> Command 9 and Command 10 activate the SDO output for the readback function, delayed by 24 or 25 clock pulses, depending on the clock polarity before and after the data-word (see Figure 3, Figure 4, and Table 7). In other commands, the SDO shifts out the previously loaded SDI bit pattern, delayed by 24 or 25 clock pulses depending on the clock polarity (see Figure 3 and Figure 4). This previously shifted-out SDI can be used for daisy-chaining multiple devices. <br> Whenever SDO is used, a pull-up resistor in the range of $1 \mathrm{k} \Omega$ to $10 \mathrm{k} \Omega$ is needed. |
| 5 | GND | Ground Pin. Logic ground reference. |
| 6 | $V_{\text {SS }}$ | Negative Supply. Connect to 0 V for single-supply applications. If $\mathrm{V}_{\text {ss }}$ is used in dual-supply applications, it must be able to sink 40 mA for 25 ms when storing data to EEMEM. |
| 7 | T | Reserved for factory testing. Connect to $\mathrm{V}_{\text {DD }}$ or $\mathrm{V}_{S S}$. |
| 8 | B | Terminal B of RDAC. |
| 9 | W | Wiper Terminal of RDAC. ADDR (RDAC) $=0 \times 0$. |
| 10 | A | Terminal A of RDAC. |
| 11 | $\mathrm{V}_{\text {DD }}$ | Positive Power Supply Pin. |
| 12 | $\overline{W P}$ | Optional Write Protect Pin. When active low, $\overline{\mathrm{WP}}$ prevents any changes to the present contents, except $\overline{\mathrm{PR}}$ and Instruction 1 and Instruction 8 and refreshes the RDAC register from EEMEM. Execute a NOP instruction before returning to $\overline{\mathrm{WP}}$ high. Tie $\overline{\mathrm{WP}}$ to $\mathrm{V}_{\mathrm{DD}}$, if not used. |
| 13 | $\overline{\mathrm{PR}}$ | Optional Hardware Override Preset Pin. Refreshes the scratchpad register with current contents of the EEMEM register. Factory default loads midscale $512_{10}$ until EEMEM is loaded with a new value by the user. $\overline{\mathrm{PR}}$ is activated at the logic high transition. $\mathrm{Tie} \overline{\mathrm{PR}}$ to $\mathrm{V}_{\mathrm{DD}}$, if not used. |
| 14 | $\overline{C S}$ | Serial Register Chip Select Active Low. Serial register operation takes place when $\overline{\mathrm{CS}}$ returns to logic high. |
| 15 | RDY | Ready. Active-high open-drain output. Identifies completion of Instructions 2, 3, 8, 9, 10, and $\overline{\mathrm{PR}}$. |
| 16 | O2 | Nonvolatile Digital Output 2. ADDR $=0 \times 1$, data bit position D1. For example, to store O 2 high, the data bit format is $0 \times 310002$. |

## TYPICAL PERFORMANCE CHARACTERISTICS



Figure 6. INL vs. Code, $T_{A}=-40^{\circ} \mathrm{C},+25^{\circ} \mathrm{C},+85^{\circ} \mathrm{C}$ Overlay, $R_{A B}=10 \mathrm{k} \Omega$


Figure 7. $D N L$ vs. Code, $T_{A}=-40^{\circ} \mathrm{C},+25^{\circ} \mathrm{C},+85^{\circ} \mathrm{C}$ Overlay, $R_{A B}=10 \mathrm{k} \Omega$


Figure 8. $R$-INL vs. Code, $T_{A}=-40^{\circ} \mathrm{C},+25^{\circ} \mathrm{C},+85^{\circ} \mathrm{C}$ Overlay, $R_{A B}=10 \mathrm{k} \Omega$


Figure 9. $R$-DNL vs. Code, $T_{A}=-40^{\circ} \mathrm{C},+25^{\circ} \mathrm{C},+85^{\circ} \mathrm{C}$ Overlay, $R_{A B}=10 \mathrm{k} \Omega$


Figure 10. $\left(\Delta R_{w B} / R_{w B}\right) / \Delta T \times 10^{6}$


Figure 11. $\left(\Delta V_{w} / V_{w}\right) / \Delta T \times 10^{6}$


Figure 12. Wiper On Resistance vs. Code


Figure 13. $I_{D D}$ vs. Temperature, $R_{A B}=10 \mathrm{k} \Omega$


Figure 14. $I_{D D}$ vs. Clock Frequency, $R_{A B}=10 \mathrm{k} \Omega$


Figure 15. -3dB Bandwidth vs. Resistance (Figure 32)


Figure 16. Total Harmonic Distortion vs. Frequency


Figure 17. Gain vs. Frequency vs. Code, $R_{A B}=10 \mathrm{k} \Omega$ (Figure 32)


Figure 18. Gain vs. Frequency vs. Code, $R_{A B}=50 \mathrm{k} \Omega$ (Figure 32)


Figure 19. Gain vs. Frequency vs. Code, $R_{A B}=100 \mathrm{k} \Omega$ (Figure 32)


Figure 20. PSRR vs. Frequency


Figure 21. Power-On Reset, $V_{A}=2.25 V, V_{B}=0$ V, Code $=1010101010_{B}$


Figure 22. Midscale Glitch Energy, Code 0x200 to 0x1FF


Figure 23. IDD vs. Time when Storing Data to EEMEM


SUPPLY CURRENT RETURNS TO MINIMUM POWER CONSUMPTION IF INSTRUCTION 0 (NOP) IS EXECUTED IMMEDIATELY AFTER INSTRUCTION 1 (READ EEMEM).
Figure 24. IDD vs. Time when Restoring Data from EEMEM


Figure 25. Iwb_max vs. Code

## TEST CIRCUITS

Figure 26 to Figure 35 define the test conditions used in the specifications.


Figure 26. Resistor Position Nonlinearity Error (Rheostat Operation; R-INL, R-DNL)


Figure 27. Potentiometer Divider Nonlinearity Error (INL, DNL)


Figure 28. Wiper Resistance


Figure 29. Power Supply Sensitivity (PSS, PSRR)


Figure 30. Inverting Gain


Figure 31. Noninverting Gain


Figure 32. Gain vs. Frequency


Figure 33. Incremental On Resistance


Figure 34. Common-Mode Leakage Current


Figure 35. Load Circuit for Measuring $V^{\text {Он }}$ and $V_{O L}$ (The diode bridge test circuit is equivalent to the application circuit with Rpull-up of $2.2 \mathrm{k} \Omega$ )

## THEORY OF OPERATION

The AD5231 digital potentiometer is designed to operate as a true variable resistor replacement device for analog signals that remain within the terminal voltage range of $\mathrm{V}_{\text {SS }}<\mathrm{V}_{\text {TERM }}<\mathrm{V}_{\text {DD }}$. The basic voltage range is limited to $\mathrm{V}_{\mathrm{DD}}-\mathrm{V}_{\mathrm{SS}}<5.5 \mathrm{~V}$. The digital potentiometer wiper position is determined by the RDAC register contents.

The RDAC register acts as a scratchpad register, allowing as many value changes as necessary to place the potentiometer wiper in the correct position. The scratchpad register can be programmed with any position value using the standard SPI serial interface mode by loading the complete representative data-word. Once a desirable position is found, this value can be stored in an EEMEM register. Thereafter, the wiper position is always restored to that position for subsequent power-up.
The storing of EEMEM data takes approximately 25 ms ; during this time, the shift register is locked, preventing any changes from taking place. The RDY pin pulses low to indicate the completion of this EEMEM storage.
The following instructions facilitate the user's programming needs (see Table 7 for details):
0 . Do nothing.

1. Restore EEMEM content to RDAC.
2. Store RDAC setting to EEMEM.
3. Store RDAC setting or user data to EEMEM.
4. Decrement 6 dB .
5. Decrement 6 dB .
6. Decrement one step.
7. Decrement one step.
8. Reset EEMEM content to RDAC.
9. Read EEMEM content from SDO.
10. Read RDAC wiper setting from SDO.
11. Write data to RDAC.
12. Increment 6 dB .
13. Increment 6 dB .
14. Increment one step.
15. Increment one step.

## SCRATCHPAD AND EEMEM PROGRAMMING

The scratchpad RDAC register directly controls the position of the digital potentiometer wiper. For example, when the scratchpad register is loaded with all zeros, the wiper is connected to Terminal B of the variable resistor. The scratchpad register is a standard logic register with no restriction on the number of changes allowed, but the EEMEM registers have a program erase/write cycle limitation (see the Flash/EEMEM Reliability section).

## BASIC OPERATION

The basic mode of setting the variable resistor wiper position (programming the scratchpad register) is accomplished by loading the serial data input register with Instruction $11(0 \mathrm{xB})$, Address 0 , and the desired wiper position data. When the proper wiper position is determined, the user can load the serial data input register with Instruction 2 ( $0 \times 2$ 2), which stores the wiper position data in the EEMEM register. After 25 ms , the wiper position is permanently stored in the nonvolatile memory. Table 5 provides a programming example listing the sequence of serial data input (SDI) words with the serial data output appearing at the SDO pin in hexadecimal format.

Table 5. Set and Store RDAC Data to EEMEM Register

| SDI | SDO | Action |
| :--- | :--- | :--- |
| $0 \times B 00100$ | $0 \times X X X X X X$ | Writes data 0x100 to the RDAC <br> register, Wiper W moves to 1/4 <br> full-scale position. |
| $0 \times 20 X X X X$ | $0 \times B 00100$ | Stores RDAC register content into <br> the EEMEM register. |

At system power-on, the scratchpad register is automatically refreshed with the value previously stored in the EEMEM register. The factory-preset EEMEM value is midscale, but it can be changed by the user thereafter.
During operation, the scratchpad (RDAC) register can be refreshed with the EEMEM register data with Instruction 1 ( $0 \times 1$ ) or Instruction 8 ( $0 \times 8$ ). The RDAC register can also be refreshed with the EEMEM register data under hardware control by pulsing the $\overline{\mathrm{PR}}$ pin. The $\overline{\mathrm{PR}}$ pulse first sets the wiper at midscale when brought to logic zero, and then, on the positive transition to logic high, it reloads the RDAC wiper register with the contents of EEMEM.
Many additional advanced programming commands are available to simplify the variable resistor adjustment process (see Table 7). For example, the wiper position can be changed one step at a time using the increment/decrement instruction or by 6 dB with the shift left/right instruction. Once an increment, decrement, or shift instruction has been loaded into the shift register, subsequent $\overline{\mathrm{CS}}$ strobes can repeat this command.
A serial data output SDO pin is available for daisy-chaining and for readout of the internal register contents.

## EEMEM PROTECTION

The write protect $(\overline{\mathrm{WP}})$ pin disables any changes to the scratchpad register contents, except for the EEMEM setting, which can still be restored using Instruction 1, Instruction 8, and the $\overline{\mathrm{PR}}$ pulse. Therefore, $\overline{\mathrm{WP}}$ can be used to provide a hardware EEMEM protection feature. To disable $\overline{\mathrm{WP}}$, it is recommended to execute a NOP instruction before returning $\overline{\mathrm{WP}}$ to logic high.

## DIGITAL INPUT/OUTPUT CONFIGURATION

All digital inputs are ESD-protected, high input impedance that can be driven directly from most digital sources. Active at logic low, $\overline{\mathrm{PR}}$ and $\overline{\mathrm{WP}}$ must be tied to $\mathrm{V}_{\mathrm{DD}}$ if they are not used. No internal pull-up resistors are present on any digital input pins. The SDO and RDY pins are open-drain digital outputs that need pull-up resistors only if these functions are used. A resistor value in the range of $1 \mathrm{k} \Omega$ to $10 \mathrm{k} \Omega$ is a proper choice that balances the dissipation and switching speed.

The equivalent serial data input and output logic is shown in Figure 36. The open-drain output SDO is disabled whenever chip-select $\overline{\mathrm{CS}}$ is in logic high. ESD protection of the digital inputs is shown in Figure 37 and Figure 38.


Figure 36. Equivalent Digital Input-Output Logic


Figure 37. Equivalent ESD Digital Input Protection


Figure 38. Equivalent $\overline{W P}$ Input Protection

## SERIAL DATA INTERFACE

The AD5231 contains a 4 -wire SPI-compatible digital interface (SDI, SDO, $\overline{C S}$, and CLK). It uses a 24 -bit serial data-word loaded MSB first. The format of the SPI-compatible word is shown in Table 6 . The chip-select $\overline{\mathrm{CS}}$ pin must be held low until the complete data-word is loaded into the SDI pin. When $\overline{\mathrm{CS}}$
returns high, the serial data-word is decoded according to the instructions in Table 7. The command bits (Cx) control the operation of the digital potentiometer. The address bits (Ax) determine which register is activated. The data bits ( Dx ) are the values that are loaded into the decoded register.

The AD5231 has an internal counter that counts a multiple of 24 bits (a frame) for proper operation. For example, AD5231 works with a 48-bit word, but it cannot work properly with a 23 -bit or 25 -bit word. In addition, AD5231 has a subtle feature that, if $\overline{\mathrm{CS}}$ is pulsed without CLK and SDI, the part repeats the previous command (except during power-up). As a result, care must be taken to ensure that no excessive noise exists in the CLK or $\overline{\mathrm{CS}}$ line that might alter the effective number of bits (ENOB) pattern. Also, to prevent data from mislocking (due to noise, for example), the counter resets if the count is not a multiple of four when $\overline{\mathrm{CS}}$ goes high.
The SPI interface can be used in two slave modes: CPHA = 1 , $\mathrm{CPOL}=1$ and $\mathrm{CPHA}=0, \mathrm{CPOL}=0 . \mathrm{CPHA}$ and CPOL refer to the control bits that dictate SPI timing in the following MicroConverters ${ }^{\ominus}$ and microprocessors: ADuC812/ADuC824, M68HC11, and MC68HC16R1/916R1.

## DAISY-CHAIN OPERATION

The serial data output pin (SDO) serves two purposes. It can be used to read the contents of the wiper setting and EEMEM values using Instruction 10 and Instruction 9, respectively. The remaining instructions ( 0 to 8,11 to 15 ) are valid for daisychaining multiple devices in simultaneous operations. Daisychaining minimizes the number of port pins required from the controlling IC (see Figure 39). The SDO pin contains an open-drain N -Ch FET that requires a pull-up resistor if this function is used. As shown in Figure 39, users need to tie the SDO pin of one package to the SDI pin of the next package.
Users might need to increase the clock period, because the pull-up resistor and the capacitive loading at the SDO to SDI interface might require additional time delay between subsequent packages. When two AD5231s are daisy-chained, 48 bits of data are required. The first 24 bits go to U 2 and the second 24 bits go to U1. The $\overline{\mathrm{CS}}$ should be kept low until all 48 bits are clocked into their respective serial registers. The $\overline{\mathrm{CS}}$ is then pulled high to complete the operation.


Figure 39. Daisy-Chain Configuration Using SDO

## TERMINAL VOLTAGE OPERATION RANGE

The AD5231's positive VDD and negative $V_{\text {ss }}$ power supplies define the boundary conditions for proper 3-terminal digital potentiometer operation. Supply signals present on the A, B, and W terminals that exceed $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\text {SS }}$ are clamped by the internal forward-biased diodes (see Figure 40).

The ground pin of the AD5231 device is primarily used as a digital ground reference, which needs to be tied to the common ground of the PCB. The digital input control signals to the AD5231 must be referenced to the device ground pin (GND) and satisfy the logic level defined in the Specifications section. An internal level-shift circuit ensures that the common-mode voltage range of the three terminals extends from $\mathrm{V}_{\mathrm{SS}}$ to $\mathrm{V}_{\mathrm{DD}}$, regardless of the digital input level.


Figure 40. Maximum Terminal Voltages Set by $V_{D D}$ and $V_{S S}$

## POWER-UP SEQUENCE

Because there are diodes to limit the voltage compliance at the A, B, and W terminals (Figure 40), it is important to power $\mathrm{V}_{\mathrm{DD}} / \mathrm{V}_{\text {SS }}$ first before applying any voltage to Terminal A , Terminal B, and Terminal W. Otherwise, the diode is forwardbiased such that $V_{D D} / V_{S S}$ are powered unintentionally and might affect the rest of the user's circuit. The ideal power-up sequence is $G N D, V_{D D}, V_{S S}$, digital inputs, and $V_{A} / V_{B} / V_{W}$. The order of powering $V_{A}, V_{B}, V_{W}$, and digital inputs is not important as long as they are powered after $\mathrm{V}_{\mathrm{DD}} / \mathrm{V}_{\mathrm{ss}}$.
Regardless of the power-up sequence and the ramp rates of the power supplies, once $\mathrm{V}_{\mathrm{DD}} / \mathrm{V}_{\text {SS }}$ are powered, the power-on preset remains effective, which restores the EEMEM value to the RDAC register.

## LATCHED DIGITAL OUTPUTS

A pair of digital outputs, O 1 and O 2 , is available on the AD5231. These outputs provide a nonvolatile Logic 0 or Logic 1 setting. O 1 and O 2 are standard CMOS logic outputs, shown in Figure 41. These outputs are ideal to replace the functions often provided by DIP switches. In addition, they can be used to drive other standard CMOS logic-controlled parts that need an occasional setting change. Pin O1 and Pin O2 default to Logic 1, and they can drive up to 50 mA of load at $5 \mathrm{~V} / 25^{\circ} \mathrm{C}$.


Figure 41. Logic Outputs O1 and O2

In Table 6, command bits are C 0 to C 3 , address bits are A 3 to A 0 , Data Bit D 0 to Data Bit D 9 are applicable to RDAC, and D0 to D15 are applicable to EEMEM.

Table 6. AD5231 24-Bit Serial Data-Word

|  | MSB Command Byte 0 |  |  |  |  |  |  |  | Data Byte 1 |  |  |  |  |  |  |  | Data Byte 0 |  |  |  |  |  |  | LSB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDAC | C3 | C2 | C1 | C0 | 0 | 0 | 0 | 0 | X | X | X | X | X | X | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| EEMEM | C3 | C2 | C1 | C0 | A3 | A2 | A1 | A0 | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |

Command instruction codes are defined in Table 7.
Table 7. Command/Operation Truth Table ${ }^{1,2,3}$

| Instruction Number | Command Byte 0 |  |  |  |  |  |  |  | Data Byte 1 |  |  |  | Data Byte 0 |  |  | Operation |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{array}{\|l\|} \hline \text { B23 } \\ \hline \text { C3 } \\ \hline \end{array}$ | C2 | C1 | C0 | A3 | A2 | A1 | $\begin{aligned} & \hline \text { B16 } \\ & \hline \text { A0 } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { B15 } \\ \hline \mathrm{X} \\ \hline \end{array}$ | ... | D9 | $\begin{aligned} & \hline \text { B8 } \\ & \hline \text { D8 } \end{aligned}$ | $\begin{aligned} & \hline \text { B7 } \\ & \hline \text { D7 } \end{aligned}$ | $\ldots$ | $\begin{aligned} & \hline \text { B0 } \\ & \hline \text { D0 } \end{aligned}$ |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 0 | 0 | 0 | 0 | X | X | X | X | X | $\ldots$ | X | X | X | $\ldots$ | X | NOP: Do nothing. See Table 15. |
| 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | X | $\ldots$ | X | X | X | $\cdots$ | X | Restore EEMEM(0) contents to RDAC register. This command leaves the device in the read program power state. To return the part to the idle state, perform NOP instruction 0 . See Table 15. |
| 2 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | X | $\ldots$ | X | X | X | $\cdots$ | X | Store Wiper Setting: Store RDAC setting to EEMEM(0). See Table 14. |
| $3^{4}$ | 0 | 0 | 1 | 1 | A3 | A2 | A1 | A0 | D15 | $\ldots$ |  | D8 | D7 | $\cdots$ | D0 | Store contents of Data Bytes 0 and 1 (total 16 bits) to EEMEM (ADDR 1to ADDR 15). See Table 17. |
| $4^{5}$ | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | X | $\cdots$ | X | X | $x$ | .. | X | Decrement RDAC by 6 dB . |
| $5^{5}$ | 0 | 1 | 0 | 1 | X | X | X | X | X | $\cdots$ | X | X | X | $\cdots$ | X | Same as Instruction 4. |
| $6^{5}$ | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | X | $\cdots$ | X | X | $x$ | $\cdots$ | X | Decrement RDAC by 1 position. |
| $7^{5}$ | 0 | 1 | 1 | 1 | X | X | X | X | X | $\cdots$ | X | X | X | $\cdots$ | X | Same as Instruction 6. |
| 8 | 1 | 0 | 0 | 0 | X | X | X | X | X | $\cdots$ | X | X | X | $\ldots$ | X | Reset: Restore RDAC with EEMEM (0) value. |
| 9 | 1 | 0 | 0 | 1 | A3 | A2 | A1 | A0 | X | $\cdots$ | X | X | X | $\ldots$ | X | Read EEMEM (ADDR 0 to ADDR 15) from SDO output in the next frame. See Table 18. |
| 10 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | X | $\cdots$ | X | X | X | $\ldots$ | X | Read RDAC wiper setting from SDO output in the next frame. See Table 19. |
| 11 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | X | $\cdots$ | D9 | D8 | D7 | $\cdots$ | D0 | Write contents of Data Bytes 0 and 1 (total 10 bits) to RDAC. See Table 13. |
| $12^{5}$ | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | X | $\cdots$ | X | X | X | $\cdots$ | X | Increment RDAC by 6 dB. See Table 16. |
| $13^{5}$ | 1 | 1 | 0 | 1 | X | X | X | X | X | $\cdots$ | X | X | X | $\ldots$ | X | Same as Instruction 12. |
| $14^{5}$ | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | X | $\ldots$ | X | X | X | $\cdots$ | X | Increment RDAC by 1 position. See Table 14. |
| $15^{5}$ | 1 | 1 | 1 | 1 | X | X | X | X | X | $\ldots$ | X | X | X | $\ldots$ | X | Same as Instruction 14. |

[^2]
## ADVANCED CONTROL MODES

The AD5231 digital potentiometer includes a set of user programming features to address the wide number of applications for these universal adjustment devices.

Key programming features include:

- Scratchpad programming to any desirable values
- Nonvolatile memory storage of the scratchpad RDAC register value in the EEMEM register
- Increment and decrement instructions for the RDAC wiper register
- Left and right bit shift of the RDAC wiper register to achieve $\pm 6 \mathrm{~dB}$ level changes
- 28 extra bytes of user-addressable nonvolatile memory


## Linear Increment and Decrement Instructions

The increment and decrement instructions ( $14,15,6$, and 7 ) are useful for linear step-adjustment applications. These commands simplify microcontroller software coding by allowing the controller to send just an increment or decrement command to the device.
For an increment command, executing Instruction 14 with the proper address automatically moves the wiper to the next resistance segment position. Instruction 15 performs the same function, except that the address does not need to be specified.

## Logarithmic Taper Mode Adjustment

Four programming instructions produce logarithmic taper increment and decrement of the wiper. These settings are activated by the 6 dB increment and 6 dB decrement instructions ( $12,13,4$, and 5 ). For example, starting at zero scale, executing the increment Instruction 12 eleven times moves the wiper in 6 dB per step from $0 \%$ to full scale, $\mathrm{R}_{\text {AB. }}$. The 6 dB increment instruction doubles the value of the RDAC register contents each time the command is executed. When the wiper position is near the maximum setting, the last 6 dB increment instruction causes the wiper to go to the full-scale 1023 code position. Further 6 dB per increment instructions do not change the wiper position beyond its full scale.
The 6 dB step increments and 6 dB step decrements are achieved by shifting the bit internally to the left or right, respectively. The following information explains the nonideal $\pm 6 \mathrm{~dB}$ step adjustment under certain conditions. Table 8 illustrates the operation of the shifting function on the RDAC register data bits. Each table row represents a successive shift operation. Note that the left-shift 12 and 13 instructions were modified such that, if the data in the RDAC register is equal to zero and the data is shifted left, the RDAC register is then set to Code 1 . Similarly, if the data in the RDAC register is greater than or equal to midscale and the data is shifted left, then the data in the RDAC register is automatically set to full scale. This
makes the left-shift function as ideal a logarithmic adjustment as possible.
The right-shift 4 and 5 instructions are ideal only if the LSB is 0 (ideal logarithmic $=$ no error). If the LSB is 1 , the right-shift function generates a linear half-LSB error, which translates to a number-of-bits dependent logarithmic error, as shown in Figure 42. The plot shows the error of the odd numbers of bits for the AD5231.

Table 8. Detail Left-Shift and Right-Shift Functions for 6 dB Step Increment and Decrement

|  | Left-Shift | Right-Shift |
| :--- | :--- | :--- |
|  | 0000000000 | 1111111111 |
|  | 0000000001 | 0111111111 |
|  | 0000000010 | 0011111111 |
|  | 0000000100 | 0001111111 |
|  | 0000001000 | 0000111111 |
| Left-Shift | 0000010000 | 0000011111 |$\quad$ Right-Shift $\quad$ (+6 dB/step) $0000100000 ~ 10000001111 \quad$ (-6 dB/step)

Actual conformance to a logarithmic curve between the data contents in the RDAC register and the wiper position for each right-shift 4 and 5 command execution contains an error only for odd numbers of bits. Even numbers of bits are ideal. The graph in Figure 42 shows plots of Log_Error $\left[20 \times \log _{10}\right.$ (error/code)] for the AD5231. For example, Code 3 Log_Error $=20 \times \log _{10}(0.5 / 3)=-15.56 \mathrm{~dB}$, which is the worst case. The plot of Log_Error is more significant at the lower codes.


Figure 42. Plot of Log_Error Conformance for Odd Numbers of Bits Only (Even Numbers of Bits Are Ideal)

## Using Additional Internal Nonvolatile EEMEM

The AD5231 contains additional user EEMEM registers for storing any 16 -bit data such as memory data for other components, look-up tables, or system identification information. Table 9 provides an address map of the internal storage registers shown in the functional block diagram as EEMEM1, EEMEM2, and 28 bytes ( 14 addresses $\times 2$ bytes each) of user EEMEM.

Table 9. EEMEM Address Map

| Address | EEMEM for... |
| :--- | :--- |
| 0000 | RDAC $^{1,2}$ |
| 0001 | O1 and O2 ${ }^{3}$ |
| 0010 | USER1 $^{4}$ |
| 0011 | USER2 |
| $\ldots$ | $\ldots$ |
| 1110 | USER13 |
| 1111 | USER14 |

${ }^{1}$ RDAC data stored in EEMEM location is transferred to the RDAC register at power-on, or when Instruction 1, Instruction 8 , or $\overline{P R}$ are executed.
${ }^{2}$ Execution of Instruction 1 leaves the device in the read mode power consumption state. After the last Instruction 1 is executed, the user should perform a NOP, Instruction 0 to return the device to the low power idling state.
${ }^{3} \mathrm{O} 1$ and O 2 data stored in EEMEM locations is transferred to the corresponding digital register at power-on, or when Instruction 1 and Instruction 8 are executed.
${ }^{4}$ USERx are internal nonvolatile EEMEM registers available to store 16-bit information using Instruction 3 and restore the contents using Instruction 9.

## RDAC STRUCTURE

The patent-pending RDAC contains multiple strings of equal resistor segments with an array of analog switches that act as the wiper connection. The number of positions is the resolution of the device. The AD5231 has 1024 connection points, allowing it to provide better than $0.1 \%$ settability resolution. Figure 43 shows an equivalent structure of the connections among the three terminals of the RDAC. The $\mathrm{SW}_{\mathrm{A}}$ and $\mathrm{SW}_{\mathrm{B}}$ are always on, while the switches $\operatorname{SW}(0)$ to $\operatorname{SW}\left(2^{\mathrm{N}}-1\right)$ are on one at a time, depending on the resistance position decoded from the data bits. Because the switch is not ideal, there is a $15 \Omega$ wiper resistance, Rw. Wiper resistance is a function of supply voltage and temperature. The lower the supply voltage or the higher the temperature, the higher the resulting wiper resistance. Users should be aware of the wiper resistance dynamics if accurate prediction of the output resistance is needed.


Figure 43. Equivalent RDAC Structure (Patent Pending)

Table 10. Nominal Individual Segment Resistor ( $\mathrm{R}_{\mathrm{s}}$ )

| Device <br> Resolution | $\mathbf{1 0} \mathbf{k} \boldsymbol{\Omega}$ <br> Version | $\mathbf{5 0} \mathbf{k} \boldsymbol{\Omega}$ <br> Version | $\mathbf{1 0 0} \mathbf{k} \boldsymbol{\Omega}$ <br> Version |
| :--- | :--- | :--- | :--- |
| $10-$ Bit | $9.8 \Omega$ | $48.8 \Omega$ | $97.6 \Omega$ |

## PROGRAMMING THE VARIABLE RESISTOR Rheostat Operation

The nominal resistance of the RDAC between Terminal A and Terminal $\mathrm{B}, \mathrm{R}_{\mathrm{AB}}$, is available with $10 \mathrm{k} \Omega, 50 \mathrm{k} \Omega$, and $100 \mathrm{k} \Omega$ with 1024 positions (10-bit resolution). The final digit(s) of the part number determine the nominal resistance value, for example, $10 \mathrm{k} \Omega=10 ; 50 \mathrm{k} \Omega=50 ; 100 \mathrm{k} \Omega=\mathrm{C}$.
The 10-bit data-word in the RDAC latch is decoded to select one of the 1024 possible settings. The following discussion describes the calculation of resistance $\mathrm{R}_{\mathrm{wB}}$ at different codes of a $10 \mathrm{k} \Omega$ part. For $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$, the wiper's first connection starts at Terminal B for data $0 \mathrm{x} 000 . \mathrm{R}_{\mathrm{wB}}(0)$ is $15 \Omega$ because of the wiper resistance, and because it is independent of the nominal resistance. The second connection is the first tap point where $R_{\text {wb }}$ (1) becomes $9.7 \Omega+15 \Omega=24.7 \Omega$ for data $0 \times 001$. The third connection is the next tap point representing $\mathrm{R}_{\mathrm{wB}}(2)=$ $19.4 \Omega+15 \Omega=34.4 \Omega$ for data $0 x 002$ and so on. Each LSB data value increase moves the wiper up the resistor ladder until the last tap point is reached at $\mathrm{R}_{\text {wb }}(1023)=10,005 \Omega$. See Figure 43 for a simplified diagram of the equivalent RDAC circuit. When $\mathrm{R}_{\mathrm{wb}}$ is used, Terminal A can be left floating or tied to the wiper.


Figure 44. $R_{w A}(D)$ and $R_{w B}(D)$ vs. Decimal Code
The general equation that determines the programmed output resistance between W and B is

$$
\begin{equation*}
R_{W B}(D)=\frac{D}{1024} \times R_{A B}+R_{W} \tag{1}
\end{equation*}
$$

where:
$D$ is the decimal equivalent of the data contained in the RDAC register.
$R_{A B}$ is the nominal resistance between Terminal A and
Terminal B.
$R_{W}$ is the wiper resistance.
For example, the output resistance values in Table 11 are set for the given RDAC latch codes with $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ (applies to $\mathrm{R}_{\mathrm{AB}}=10 \mathrm{k} \Omega$ digital potentiometers).

Table 11. $\mathrm{R}_{\mathrm{WB}}(\mathrm{D})$ at Selected Codes for $\mathrm{R}_{\mathrm{AB}}=10 \mathrm{k} \Omega$

| $\mathbf{D}(\mathbf{D E C})$ | RwB $\left.^{\mathbf{D}} \mathbf{D}\right)(\boldsymbol{\Omega})$ | Output State |
| :--- | :--- | :--- |
| 1023 | 10,005 | Full scale |
| 512 | 50,015 | Midscale |
| 1 | 24.7 | 1 LSB |
| 0 | 15 | Zero scale (wiper contact resistor) |

Note that, in the zero-scale condition, a finite wiper resistance of $15 \Omega$ is present. Care should be taken to limit the current flow between W and B in this state to no more than 20 mA to avoid degradation or possible destruction of the internal switches.
Like the mechanical potentiometer that the RDAC replaces, the AD5231 part is totally symmetrical. The resistance between Wiper W and Terminal A also produces a digitally controlled complementary resistance, $\mathrm{R}_{\mathrm{wA}}$. Figure 44 shows the symmetrical programmability of the various terminal connections. When $\mathrm{R}_{\mathrm{w} A}$ is used, Terminal B can be left floating or tied to the wiper. Setting the resistance value for $\mathrm{Rwa}_{\mathrm{wa}}$ starts at a maximum value of resistance and decreases as the data loaded in the latch is increased in value.

The general transfer equation for this operation is

$$
\begin{equation*}
R_{W B}(D)=\frac{1024-D}{1024} \times R_{A B}+R_{W} \tag{2}
\end{equation*}
$$

For example, the output resistance values in Table 12 are set for the RDAC latch codes with $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$ (applies to $\mathrm{R}_{\mathrm{AB}}=10 \mathrm{k} \Omega$ digital potentiometers).

Table 12. $\mathrm{R}_{\mathrm{WA}}(\mathrm{D})$ at Selected Codes for $\mathrm{R}_{\mathrm{AB}}=10 \mathrm{k} \Omega$

| D (DEC) | Rwa $\mathbf{( D )}(\boldsymbol{\Omega})$ | Output State |
| :--- | :--- | :--- |
| 1023 | 24.7 | Full scale |
| 512 | 5015 | Midscale |
| 1 | 10005 | 1 LSB |
| 0 | 10,015 | Zero scale |

The typical distribution of $\mathrm{R}_{A B}$ from device to device matches tightly when they are processed in the same batch. When devices are processed at a different time, device-to-device matching becomes process-lot dependent and exhibits a $-40 \%$ to $+20 \%$ variation. The change in $\mathrm{R}_{A B}$ with temperature has a $600 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$ temperature coefficient.

## PROGRAMMING THE POTENTIOMETER DIVIDER

## Voltage Output Operation

The digital potentiometer can be configured to generate an output voltage at the wiper terminal that is proportional to the input voltages applied to Terminal A and Terminal B. For example, connecting Terminal A to 5 V and Terminal B to ground produces an output voltage at the wiper that can be any value from 0 V to 5 V . Each LSB of voltage is equal to the voltage applied across Terminals A-B divided by the $2^{\mathrm{N}}$ position resolution of the potentiometer divider.

Because AD5231 can also be supplied by dual supplies, the general equation defining the output voltage at $\mathrm{V}_{\mathrm{w}}$ with respect to ground for any given input voltages applied to Terminal A and Terminal B is

$$
\begin{equation*}
V_{W}(D)=\frac{D}{1024} \times V_{A B}+V_{B} \tag{3}
\end{equation*}
$$

Equation 3 assumes that $V_{w}$ is buffered so that the effect of wiper resistance is minimized. Operation of the digital potentiometer in divider mode results in more accurate operation over temperature. Here, the output voltage is dependent on the ratio of the internal resistors and not the absolute value; therefore, the drift improves to $15 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$. There is no voltage polarity restriction between Terminal A, Terminal B, and Terminal W as long as the terminal voltage ( $\mathrm{V}_{\text {TERM }}$ ) stays within $\mathrm{V}_{\text {SS }}<\mathrm{V}_{\text {TERM }}<\mathrm{V}_{\mathrm{DD}}$.

## PROGRAMMING EXAMPLES

The following programming examples illustrate a typical sequence of events for various features of the AD5231. See Table 7 for the instructions and data-word format. The instruction numbers, addresses, and data appearing at SDI and SDO pins are in hexadecimal format.

Table 13. Scratchpad Programming

| SDI | SDO | Action |
| :--- | :--- | :--- |
| 0xB00100 | 0xXXXXXX | Writes data 0x100 into RDAC register, <br> Wiper W moves to 1/4 full-scale position. |

Table 14. Incrementing RDAC Followed by Storing the Wiper Setting to EEMEM

| SDI | SDO | Action |
| :--- | :--- | :--- |
| $0 \times B 00100$ | $0 \times X X X X X X$ | Writes data 0x100 into RDAC register, <br> Wiper W moves to 1/4 full-scale <br> position. |
| $0 \times E 0 X X X X$ | $0 \times B 00100$ | Increments RDAC register by one to <br> 0x101. <br> Increments RDAC register by one to |
| $0 \times E 0 X X X X$ | $0 x E 0 X X X X$ | Ox102. Continue until desired wiper <br> position is reached. <br> Stores RDAC register data into <br> EEMEM(0). Optionally tie WP to GND <br> to protect EEMEM values. |

The EEMEM value for the RDAC can be restored by power-on, by strobing the $\overline{\mathrm{PR}}$ pin, or by programming, as shown in Table 15.

Table 15. Restoring the EEMEM Value to the RDAC Register

| SDI | SDO | Action |
| :--- | :--- | :--- |
| $0 \times 10 X X X X$ | $0 \times X X X X X X$ | Restores the EEMEM(0) value to the <br> RDAC register. |
| $0 \times 00 X X X X$ | $0 x 10 X X X X$ | NOP. Recommended step to minimize <br> power consumption. |

Table 16. Using Left-Shift by One to Increment 6 dB Step

| SDI | SDO | Action |
| :--- | :--- | :--- |
| $0 \times C O X X X X$ | $0 \times X X X X X X$ | Moves the wiper to double the <br> present data contained in the RDAC <br> register. |

Table 17. Storing Additional User Data in EEMEM

| SDI | SDO | Action |
| :--- | :--- | :--- |
| 0x32AAAAA | 0xXXXXXX | Stores data 0xAAAA in the extra <br> EEMEM location USER1. (Allowable to <br> address in 14 locations with a <br> maximum of 16 bits of data.) <br> 0x335555 0x32AAAA |
| Stores data 0x5555 in the extra |  |  |
| EEMEM location USER2. (Allowable to |  |  |
| address in 14 locations with a |  |  |
| maximum of 16 bits of data.) |  |  |

Table 18. Reading Back Data from Memory Locations

| SDI | SDO | Action |
| :--- | :--- | :--- |
| $0 \times 92 \mathrm{XXXX}$ | 0xXXXXXX | Prepares data read from EEMEM(2) <br> location. |
| $0 \times 00 \mathrm{XXXX}$ | 0x92AAAA | NOP Instruction 0 sends a 24-bit word <br> out of SDO, where the last 16 bits <br> contain the contents in the EEMEM(2) <br> location. The NOP command ensures <br> that the device returns to the idle <br> power dissipation state. |

Table 19. Reading Back Wiper Settings

| SDI | SDO | Action |
| :--- | :--- | :--- |
| $0 \times B 00200$ | $0 \times X X X X X X$ | Writes RDAC to midscale. |
| $0 \times C 0 X X X X$ | $0 \times B 00200$ | Doubles RDAC from midscale to full <br> scale (left-shift instruction). |
| 0xA0XXXX | 0xC0XXXX | Prepares reading wiper setting from <br> RDAC register. |
| 0xXXXXXX | 0xA003FF | Reads back full-scale value from SDO. |

## FLASH/EEMEM RELIABILITY

The Flash/EE memory array on the AD5231 is fully qualified for two key Flash/EE memory characteristics, namely Flash/EE memory cycling endurance and Flash/EE memory data retention.
Endurance quantifies the ability of the Flash/EE memory to be cycled through many program, read, and erase cycles. In real terms, a single endurance cycle is composed of four independent, sequential events. These events are defined as

- Initial page erase sequence
- Read/verify sequence
- Byte program sequence
- Second read/verify sequence

During reliability qualification, Flash/EE memory is cycled from $0 \times 000$ to $0 \times 3 F F$ until a first fail is recorded signifying the endurance limit of the on-chip Flash/EE memory.
As indicated in the Specifications section, the AD5231 Flash/EE memory endurance qualification has been carried out in accordance with JEDEC Specification A117 over the industrial temperature range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$. The results allow the specification of a minimum endurance figure over supply and temperature of 100,000 cycles, with an endurance figure of 700,000 cycles being typical of operation at $25^{\circ} \mathrm{C}$.
Retention quantifies the ability of the Flash/EE memory to retain its programmed data over time. Again, the AD5231 has been qualified in accordance with the formal JEDEC Retention

Lifetime Specification (A117) at a specific junction temperature ( $\mathrm{T}_{\mathrm{J}}=55^{\circ} \mathrm{C}$ ). As part of this qualification procedure, the Flash/EE memory is cycled to its specified endurance limit, described previously, before data retention is characterized. This means that the Flash/EE memory is guaranteed to retain its data for its full specified retention lifetime every time the Flash/EE memory is reprogrammed. It should also be noted that retention lifetime, based on an activation energy of 0.6 eV , derates with $\mathrm{T}_{\mathrm{J}}$, as shown in Figure 45. For example, the data is retained for 100 years at $55^{\circ} \mathrm{C}$ operation, but reduces to 15 years at $85^{\circ} \mathrm{C}$ operation. Beyond these limits, the part must be reprogrammed so that the data can be restored.


Figure 45. Flash/EE Memory Data Retention

## APPLICATIONS

## BIPOLAR OPERATION FROM DUAL SUPPLIES

The AD5231 can be operated from dual supplies $\pm 2.5 \mathrm{~V}$, which enables control of ground referenced ac signals or bipolar operation. $A C$ signals as high as $V_{D D} / V_{\text {Ss }}$ can be applied directly across Terminal A to Terminal B with output taken from Terminal W. See Figure 46 for a typical circuit connection.


Figure 46. Bipolar Operation from Dual Supplies

## HIGH VOLTAGE OPERATION

The digital potentiometer can be placed directly in the feedback or input path of an op amp for gain control, provided that the voltage across Terminals A-B, Terminals W-A, or Terminals W - B does not exceed $|5 \mathrm{~V}|$. When high voltage gain is needed, users should set a fixed gain in an op amp operated at a higher voltage and let the digital potentiometer control the adjustable input. Figure 47 shows a simple implementation.


Figure 47. 15 V Voltage Span Control

## BIPOLAR PROGRAMMABLE GAIN AMPLIFIER

There are several ways to achieve bipolar gain. Figure 48 shows one versatile implementation. Digital potentiometer U1 sets the adjustment range; the wiper voltage $\mathrm{V}_{\mathrm{w}_{2}}$ can, therefore, be programmed between $V_{i}$ and $-\mathrm{KV}_{\mathrm{i}}$ at a given U 2 setting. For linear adjustment, configure A2 as a noninverting amplifier and the transfer function becomes

$$
\begin{equation*}
\frac{V_{O}}{V_{I}}=\left(1+\frac{R 2}{R 1}\right) \times\left(\frac{D_{2}}{1024} \times(1+K)-K\right) \tag{4}
\end{equation*}
$$

where:
$K$ is the ratio of $\mathrm{R}_{\mathrm{WB}} / \mathrm{R}_{\mathrm{WA}}$ that is set by U 1 .
$D$ is the decimal equivalent of the input code.


Figure 48. Bipolar Programmable Gain Amplifier
In the simpler (and much more usual) case where $\mathrm{K}=1$, a pair of matched resistors can replace U1. Equation 4 can be simplified to

$$
\begin{equation*}
\frac{V_{O}}{V_{I}}=\left(1+\frac{R 2}{R 1}\right) \times\left(\frac{2 D_{2}}{1024}-1\right) \tag{5}
\end{equation*}
$$

Table 20 shows the result of adjusting D with A2 configured as a unity gain, a gain of 2 , and a gain of 10 . The result is a bipolar amplifier with linearly programmable gain and 1024-step resolution.

Table 20. Result of Bipolar Gain Amplifier

| $\mathbf{D}$ | $\mathbf{R 1}=\boldsymbol{\infty}, \mathbf{R 2}=\mathbf{0}$ | $\mathbf{R} 1=\mathbf{R 2}$ | $\mathbf{R 2}=\mathbf{9} \times \mathbf{R 1}$ |
| :--- | :--- | :--- | :--- |
| 0 | -1 | -2 | -10 |
| 256 | -0.5 | -1 | -5 |
| 512 | 0 | 0 | 0 |
| 768 | 0.5 | 1 | 5 |
| 1023 | 0.992 | 1.984 | 9.92 |

## 10-BIT BIPOLAR DAC

If the circuit in Figure 48 is changed with the input taken from a voltage reference and A2 configured as a buffer, a 10-bit bipolar DAC can be realized. Compared to the conventional DAC, this circuit offers comparable resolution but not the precision because of the wiper resistance effects. Degradation of the nonlinearity and temperature coefficient is prominent near both ends of the adjustment range. On the other hand, this circuit offers a unique nonvolatile memory feature that in some cases outweighs any shortfall in precision.
The output of this circuit is

$$
\begin{equation*}
V_{O}=\left(\frac{2 D_{2}}{1024}-1\right) \times V_{R E F} \tag{6}
\end{equation*}
$$



Figure 49. 10-Bit Bipolar DAC

## 10-BIT UNIPOLAR DAC

Figure 50 shows a unipolar 10-bit DAC using AD5231. The buffer is needed to drive various leads.


Figure 50. 10-Bit Unipolar DAC

## PROGRAMMABLE VOLTAGE SOURCE WITH BOOSTED OUTPUT

For applications that require high current adjustment, such as a laser diode driver or tunable laser, a boosted voltage source can be considered (see Figure 51).


Figure 51. Programmable Booster Voltage Source
In this circuit, the inverting input of the op amp forces the $V_{\text {out }}$ to be equal to the wiper voltage set by the digital potentiometer. The load current is then delivered by the supply via the N -Ch FET $\mathrm{N}_{1}$. $\mathrm{N}_{1}$ power handling must be adequate to dissipate $\left(V_{i}-V_{O}\right) \times I_{L}$ power. This circuit can source a maximum of 100 mA with a 5 V supply.
For precision applications, a voltage reference such as ADR421, ADR03, or ADR370 can be applied at Terminal A of the digital potentiometer.

## PROGRAMMABLE CURRENT SOURCE

A programmable current source can be implemented with the circuit shown in Figure 52.


Figure 52. Programmable Current Source
REF191 is a unique low supply, headroom precision reference that can deliver the 20 mA needed at 2.048 V . The load current is simply the voltage across Terminals $\mathrm{B}-\mathrm{W}$ of the digital potentiometer divided by Rs:

$$
\begin{equation*}
I_{L}=\frac{V_{R E F} \times D}{R_{S} \times 1024} \tag{7}
\end{equation*}
$$

The circuit is simple, but be aware that there are two issues. First, dual-supply op amps are ideal because the ground potential of REF191 can swing from -2.048 V at zero scale to $\mathrm{V}_{\mathrm{L}}$ at full scale of the potentiometer setting. Although the circuit works under single-supply, the programmable resolution of the system is reduced. Second, the voltage compliance at $\mathrm{V}_{\mathrm{L}}$ is limited to 2.5 V or equivalently a $125 \Omega$ load. Should higher voltage compliance be needed, users can consider digital potentiometers AD5260, AD5280, and AD7376. Figure 53 shows an alternate circuit for high voltage compliance.
To achieve higher current, such as when driving a high power LED, the user can replace the UI with an LDO, reduce $\mathrm{R}_{\mathrm{s}}$, and add a resistor in series with the digital potentiometer's A terminal. This limits the potentiometer's current and increases the current adjustment resolution.


[^0]:    ${ }^{1}$ The terms nonvolatile memory and EEMEM are used interchangeably.
    ${ }^{2}$ The terms digital potentiometer and RDAC are used interchangeably.
    Rev. D
    Document Feedback
    Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties that may result from its use. Specifications subject to change without notice. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices. Trademarks and registered trademarks are the property of their respective owners.

[^1]:    ${ }^{1}$ Typical values represent average readings at $25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{DD}}=5 \mathrm{~V}$.
    ${ }^{2}$ Guaranteed by design and not subject to production test.
    ${ }^{3}$ See timing diagrams (Figure 3 and Figure 4) for location of measured values. All input control voltages are specified with $\mathrm{t}_{\mathrm{R}}=\mathrm{t}_{\mathrm{F}}=2.5 \mathrm{~ns}(10 \%$ to $90 \%$ of 3 V ) and timed from a voltage level of 1.5 V . Switching characteristics are measured using both $V_{D D}=3 \mathrm{~V}$ and $V_{D D}=35 \mathrm{~V}$.
    ${ }^{4}$ Propagation delay depends on the value of $\mathrm{V}_{\mathrm{DD}}, \mathrm{R}_{\text {PuLL-up, }}$ and $\mathrm{C}_{\mathrm{L}}$.
    ${ }^{5}$ Valid for commands that do not activate the RDY pin.
    ${ }^{6}$ RDY pin low only for Instructions $2,3,8,9,10$, and the $\overline{\text { PR }}$ hardware pulse: CMD_2, $3 \sim 20 \mathrm{~ms} ; \mathrm{CMD}_{2} 8 \sim 1 \mathrm{~ms} ; \mathrm{CMD}^{2} 9,10 \sim 0.12 \mathrm{~ms}$. Device operation at $\mathrm{T}_{\mathrm{A}}=-40^{\circ} \mathrm{C}$ and $V_{D D}<3 \mathrm{~V}$ extends the EEMEM store time to 35 ms .
    ${ }^{7}$ Endurance is qualified to 100,000 cycles per JEDEC Standard 22 , Method A117 and measured at $-40^{\circ} \mathrm{C},+25^{\circ} \mathrm{C}$, and $+85^{\circ} \mathrm{C}$; typical endurance at $+25^{\circ} \mathrm{C}$ is 700,000 cycles.
    ${ }^{8}$ Retention lifetime equivalent at junction temperature $\left(\mathrm{T}_{\mathrm{J}}\right)=55^{\circ} \mathrm{C}$ per JEDEC Standard 22, Method A117. Retention lifetime based on an activation energy of 0.6 eV derates with junction temperature, as shown in Figure 45 in the Flash/EEMEM Reliability section.

[^2]:    ${ }^{1}$ The SDO output shifts out the last 24 bits of data clocked into the serial register for daisy-chain operation. Exception: for any instruction following Instruction 9 or Instruction 10, the selected internal register data is present in Data Byte 0 and Data Byte 1. The instruction following 9 and 10 must also be a full 24-bit data-word to completely clock out the contents of the serial register.
    ${ }^{2}$ The RDAC register is a volatile scratchpad register that is refreshed at power-on from the corresponding nonvolatile EEMEM register.
    ${ }^{3}$ Execution of these operations takes place when the $\overline{C S}$ strobe returns to logic high.
    ${ }^{4}$ Instruction 3 writes two data bytes ( 16 bits of data) to EEMEM. In the case of 0 addresses, only the last 10 bits are valid for wiper position setting.
    ${ }^{5}$ The increment, decrement, and shift instructions ignore the contents of the shift register Data Byte 0 and Data Byte 1.

