8/10/12-Bit Digital-to-Analog Converters, 1 LSb INL 
Single/Dual Voltage Outputs with I²C Interface

Features

• Memory Options:
  - Volatile Memory: MCP47CVBXX
  - Nonvolatile Memory: MCP47CMBXX

• Operating Voltage Range:
  - 2.7V to 5.5V – Full specifications
  - 1.8V to 2.7V – Reduced device specifications

• Output Voltage Resolutions:
  - 8-bit: MCP47CXB0X (256 steps)
  - 10-bit: MCP47CXB1X (1024 steps)
  - 12-bit: MCP47CXB2X (4096 steps)

• Nonvolatile Memory (MTP) Size: 32 Locations

• 1 LSb Integral Nonlinearity (INL) Specification

• DAC Voltage Reference Source Options:
  - Device V_DD
  - External V_REF pin (buffered or unbuffered)
  - Internal band gap (1.214V typical)

• Output Gain Options:
  - 1x (Unity)
  - 2x (available when not using internal V_DD as voltage source)

• Power-on/Brown-out Reset (POR/BOR) Protection

• Power-Down Modes:
  - Disconnects output buffer (high-impedance)
  - Selection of V_OUT pull-down resistors (100 kΩ or 1 kΩ)

• I²C Interface:
  - Slave address options: register-defined address with two physical address select pins (package dependent)
  - Standard (100 kbps), Fast (400 kbps) and High-Speed (up to 3.4 Mbps) modes

• Package Types:
  - Dual: 16-lead 3 x 3 QFN, 10-lead MSOP, 10-lead 3 x 3 DFN
  - Single: 16-lead 3 x 3 QFN, 10-lead MSOP, 10-lead 3 x 3 DFN

• Extended Temperature Range: -40°C to +125°C

Package Types

MCP47CXB1 (Single)
MSOP-10, DFN-10 (3x3)

MCP47CXB2 (Dual)
MSOP-10, DFN-10 (3x3)

Note 1: Exposed pad (substrate paddle).
2: This pin’s signal can be connected to DAC0 and/or DAC1.
General Description

The MCP47CXBXX devices are single and dual channel 8-bit, 10-bit and 12-bit buffered voltage output Digital-to-Analog Converters (DAC) with volatile or MTP memory, and an I²C serial interface.

The MTP memory can be written by the user up to 32 times for each specific register. It requires a high-voltage level on the HVC pin, typically 7.5V, in order to successfully program the desired memory location. The nonvolatile memory includes power-up output values, device Configuration registers and general purpose memory.

The VREF pin, the device VDD or the internal band gap voltage can be selected as the DAC’s reference voltage. When VDD is selected, VDD is internally connected to the DAC reference circuit.

Applications

• Set Point or Offset Trimming
• Sensor Calibration
• Low-Power Portable Instrumentation
• PC Peripherals
• Data Acquisition Systems

When the VREF pin is used with an external voltage reference, the user can select between a gain of 1 or 2 and can have the reference buffer enabled or disabled. When the gain is 2, the VREF pin voltage should be limited to a maximum of VDD/2.

These devices have a two-wire I²C compatible serial interface for Standard (100 kHz), Fast (400 kHz) or High-Speed (1.7 MHz and 3.4 MHz) modes.
MCP47CXBXX

MCP47CMBX2 Block Diagram (Dual Channel Output)

Note 1: On dual output devices, except those in a QFN16 package, the LAT0 pin is internally connected to LAT1 input of DAC1.

2: On dual output devices, except those in a QFN16 package, the VREF0 pin is internally connected to VREF1 input of DAC1.
## Family Device Features

<table>
<thead>
<tr>
<th>Device</th>
<th>Package Type</th>
<th># of Channels</th>
<th>Resolution (bits)</th>
<th>DAC Output POR/BOR Setting$^{(1)}$</th>
<th># of $V_{REF}$ Inputs</th>
<th># of LAT Inputs$^{(3)}$</th>
<th># of Address Pins</th>
<th>Memory$^{(2)}$</th>
<th>GP MTP Locations</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCP47CVB01</td>
<td>MSOP, QFN, DFN</td>
<td>1</td>
<td>8</td>
<td>7Fh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td>MCP47CVB11</td>
<td>MSOP, QFN, DFN</td>
<td>1</td>
<td>10</td>
<td>1FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td>MCP47CVB21</td>
<td>MSOP, QFN, DFN</td>
<td>1</td>
<td>12</td>
<td>7FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td>MCP47CVB02</td>
<td>QFN</td>
<td>2</td>
<td>8</td>
<td>7Fh</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td></td>
<td>MSOP, DFN</td>
<td>2</td>
<td>8</td>
<td>7Fh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td>MCP47CVB12</td>
<td>QFN</td>
<td>2</td>
<td>10</td>
<td>1FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td></td>
<td>MSOP, DFN</td>
<td>2</td>
<td>10</td>
<td>1FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td>MCP47CVB22</td>
<td>QFN</td>
<td>2</td>
<td>12</td>
<td>7FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td></td>
<td>MSOP, DFN</td>
<td>2</td>
<td>12</td>
<td>7FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>RAM</td>
<td>—</td>
</tr>
<tr>
<td>MCP47CMB01</td>
<td>MSOP, QFN, DFN</td>
<td>1</td>
<td>8</td>
<td>7Fh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td>MCP47CMB11</td>
<td>MSOP, QFN, DFN</td>
<td>1</td>
<td>10</td>
<td>1FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td>MCP47CMB21</td>
<td>MSOP, QFN, DFN</td>
<td>1</td>
<td>12</td>
<td>7FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td>MCP47CMB02</td>
<td>QFN</td>
<td>2</td>
<td>8</td>
<td>7Fh</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td></td>
<td>MSOP, DFN</td>
<td>2</td>
<td>8</td>
<td>7Fh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td>MCP47CMB12</td>
<td>QFN</td>
<td>2</td>
<td>10</td>
<td>1FFh</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td></td>
<td>MSOP, DFN</td>
<td>2</td>
<td>10</td>
<td>1FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td>MCP47CMB22</td>
<td>QFN</td>
<td>2</td>
<td>12</td>
<td>7FFh</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
<tr>
<td></td>
<td>MSOP, DFN</td>
<td>2</td>
<td>12</td>
<td>7FFh</td>
<td>1</td>
<td>1</td>
<td>2</td>
<td>MTP</td>
<td>8</td>
</tr>
</tbody>
</table>

Note 1: The factory default value.

Note 2: Each nonvolatile memory location can be written 32 times. For subsequent writes to the MTP, the device will ignore the commands and the memory will not be modified.

Note 3: If the product is a dual device and the package has only one LAT pin, it is associated with both DAC0 and DAC1.
1.0 ELECTRICAL CHARACTERISTICS

Absolute Maximum Ratings(†)

Voltage on \( V_{DD} \) with respect to \( V_{SS} \) ................................................................. -0.6V to +6.5V
Voltage on all pins with respect to \( V_{SS} \) ........................................................................ -0.6V to \( V_{DD} + 0.3V \)
Input clamp current, \( I_{IK} \) (\( V_I < 0 \), \( V_I > V_{DD} \), \( V_I > V_{PP} \) on HV pins) .................................................. ±20 mA
Output clamp current, \( I_{OK} \) (\( V_O < 0 \) or \( V_O > V_{DD} \))............................................................. ±20 mA
Maximum current out of \( V_{SS} \) pin (Single) ................................................................. 50 mA
Maximum current out of \( V_{SS} \) pin (Dual) ................................................................. 100 mA
Maximum current into \( V_{DD} \) pin (Single) ................................................................. 50 mA
Maximum current into \( V_{DD} \) pin (Dual) ................................................................. 100 mA
Maximum current sourced by the \( V_{OUT} \) pin ................................................................. 20 mA
Maximum current sunk by the \( V_{OUT} \) pin ................................................................. 20 mA
Maximum current source/sunk by the \( V_{REF(0)} \) pin (in Band Gap mode) ................................... 20 mA
Maximum current sunk by the \( V_{REFx} \) pin when \( V_{REF} \) is in Unbuffered mode ........................................... 175 µA
Maximum current sourced by the \( V_{REFx} \) pin ................................................................. 20 µA
Maximum current sunk by the \( V_{REF} \) pin ................................................................. 125 µA
Maximum input current source/sunk by \( SDA, SCL \) pins ......................................................... 2 mA
Maximum output current sunk by \( SDA \) output pin ............................................................. 25 mA
Total power dissipation(†) .............................................................................................. \( \geq \pm 6 \text{kV (HBM)} \)
ESD protection on all pins .......................................................................................... \( \geq \pm 400 \text{V (MM)} \)
Latch-up (per JEDEC JESD78A) at +125°C ................................................................. \( \geq \pm 100 \text{mA} \)
Storage temperature ...................................................................................... -65°C to +150°C
Ambient temperature with power applied .............................................................. -55°C to +125°C
Soldering temperature of leads (10 seconds) ......................................................... +300°C
Maximum Junction Temperature (\( T_J \)) ......................................................................................... +150°C

† Notice: Stresses above those listed under “Maximum Ratings” may cause permanent damage to the device. This is a stress rating only and functional operation of the device at those or any other conditions above those indicated in the operational listings of this specification is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

Note 1: Power dissipation is calculated as follows:

\[
P_{\text{DIS}} = V_{DD} \times (I_{DD} - \sum I_{OH}) + \sum (V_{DD} - V_{OH}) \times I_{OH} + \sum (V_{OL} \times I_{OL})
\]
## DC CHARACTERISTICS

**Standard Operating Conditions (unless otherwise specified):**

Operating Temperature: \(-40^\circ C \leq T_A \leq +125^\circ C\) (Extended)

All parameters apply across the specified operating ranges unless noted.

\(V_{DD} = +2.7\text{V to 5.5V}, V_{REF} = +1.000\text{V to } V_{DD}, V_{SS} = 0\text{V}, R_L = 2\text{k}\Omega \) from \(V_{OUT}\) to GND, \(C_L = 100\text{ pF}\).

Typical specifications represent values for \(V_{DD} = 5.5\text{V}, T_A = +25^\circ C\).

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Supply Voltage</td>
<td>(V_{DD})</td>
<td>2.7</td>
<td>—</td>
<td>5.5</td>
<td>V</td>
<td>DAC operation (reduced analog specifications) and serial interface</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1.8</td>
<td>—</td>
<td>2.7</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>(V_{DD}) Voltage (rising) to Ensure Device Power-on Reset</td>
<td>(V_{POR})</td>
<td>—</td>
<td>—</td>
<td>1.75</td>
<td>V</td>
<td>RAM retention voltage: ((V_{RAM}) &lt; V_{POR}). (V_{DD}) voltages greater than the (V_{POR}) limit ensure that the device is out of Reset</td>
</tr>
<tr>
<td>(V_{DD}) Voltage (falling) to Ensure Device Brown-out Reset</td>
<td>(V_{BOR})</td>
<td>(V_{RAM})</td>
<td>—</td>
<td>1.61</td>
<td>V</td>
<td>RAM retention voltage: ((V_{RAM}) &lt; V_{BOR})</td>
</tr>
<tr>
<td>(V_{DD}) Rise Rate to Ensure Power-on Reset</td>
<td>(V_{DDRR})</td>
<td></td>
<td></td>
<td></td>
<td>V/ms</td>
<td></td>
</tr>
<tr>
<td>Power-on Reset to Output-Driven Delay(2)</td>
<td>(T_{POR2OD})</td>
<td>—</td>
<td>—</td>
<td>130</td>
<td>(\mu s)</td>
<td>(V_{DD}) rising, (V_{DD} &gt; V_{POR}), single output</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>—</td>
<td>145</td>
<td>(\mu s)</td>
<td>(V_{DD}) rising, (V_{DD} &gt; V_{POR}), dual output</td>
</tr>
</tbody>
</table>

**Note 2** This parameter is ensured by characterization.

**Note 3** POR/BOR voltage trip point is not slope-dependent. Hysteresis implemented with time delay.
## DC CHARACTERISTICS (CONTINUED)

**Standard Operating Conditions (unless otherwise specified):**
Operating Temperature: -40°C ≤ TA ≤ +125°C (Extended)
All parameters apply across the specified operating ranges unless noted.

V<sub>DD</sub> = +2.7V to 5.5V, V<sub>REF</sub> = +1.000V to V<sub>DD</sub>, V<sub>SS</sub> = 0V, R<sub>L</sub> = 2 kΩ from V<sub>OUT</sub> to GND, C<sub>L</sub> = 100 pF.

Typical specifications represent values for V<sub>DD</sub> = 5.5V, TA = +25°C.

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Supply Current</td>
<td>I&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>—</td>
<td>—</td>
<td>230</td>
<td>µA</td>
<td>Single 100 kHz&lt;sup&gt;(2)&lt;/sup&gt; Serial interface active, VRxB:VRxA = 10&lt;sup&gt;(4)&lt;/sup&gt;, 400 kHz, 1.7 MHz&lt;sup&gt;(2)&lt;/sup&gt;, 3.4 MHz&lt;sup&gt;(2)&lt;/sup&gt;, Volatile DAC register = Mid-Scale</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>310</td>
<td></td>
<td></td>
<td>Dual 100 kHz&lt;sup&gt;(2)&lt;/sup&gt; Serial interface active, VRxB:VRxA = 10&lt;sup&gt;(4)&lt;/sup&gt;, 400 kHz, 1.7 MHz&lt;sup&gt;(2)&lt;/sup&gt;, 3.4 MHz&lt;sup&gt;(2)&lt;/sup&gt;, Volatile DAC register = Mid-Scale</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>460</td>
<td></td>
<td></td>
<td>Single 100 kHz&lt;sup&gt;(2)&lt;/sup&gt; Serial interface inactive, VRxB:VRxA = 10&lt;sup&gt;(4)&lt;/sup&gt;, 400 kHz, 1.7 MHz&lt;sup&gt;(2)&lt;/sup&gt;, 3.4 MHz&lt;sup&gt;(2)&lt;/sup&gt;, Volatile DAC register = Mid-Scale</td>
</tr>
<tr>
<td>LAT/HVC Pin Write Current&lt;sup&gt;(2)&lt;/sup&gt;</td>
<td>I&lt;sub&gt;DD(MTP_WR)&lt;/sub&gt;</td>
<td>—</td>
<td>—</td>
<td>6.40</td>
<td>mA</td>
<td>Single 100 kHz&lt;sup&gt;(2)&lt;/sup&gt; Serial interface active, VRxB:VRxA = 10&lt;sup&gt;(4)&lt;/sup&gt;, 400 kHz, 1.7 MHz&lt;sup&gt;(2)&lt;/sup&gt;, 3.4 MHz&lt;sup&gt;(2)&lt;/sup&gt;, Volatile DAC register = Mid-Scale</td>
</tr>
<tr>
<td>Power-Down Current</td>
<td>I&lt;sub&gt;DDP&lt;/sub&gt;</td>
<td>0.65</td>
<td>3.80</td>
<td></td>
<td>µA</td>
<td>Dual 100 kHz&lt;sup&gt;(2)&lt;/sup&gt; Serial interface inactive, VRxB:VRxA = 10&lt;sup&gt;(4)&lt;/sup&gt;, 400 kHz, 1.7 MHz&lt;sup&gt;(2)&lt;/sup&gt;, 3.4 MHz&lt;sup&gt;(2)&lt;/sup&gt;, Volatile DAC register = Mid-Scale</td>
</tr>
</tbody>
</table>

**Note 2** This parameter is ensured by characterization.

**Note 4** Supply current is independent of current through the resistor ladder in mode VRxB:VRxA = 10.

**Note 5** The PDxB:PDxA = 01, 10 and 11 configurations should have the same current.
### DC CHARACTERISTICS (CONTINUED)

**Standard Operating Conditions (unless otherwise specified):**
Operating Temperature: -40°C ≤ T<sub>A</sub> ≤ +125°C (Extended)
All parameters apply across the specified operating ranges unless noted.
V<sub>DD</sub> = +2.7V to 5.5V, V<sub>REF</sub> = +1.000V to V<sub>DD</sub>, V<sub>SS</sub> = 0V, R<sub>L</sub> = 2 kΩ from V<sub>OUT</sub> to GND, C<sub>L</sub> = 100 pF.

Typical specifications represent values for V<sub>DD</sub> = 5.5V, T<sub>A</sub> = +25°C.

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Resistor Ladder Resistance&lt;sup&gt;(6)&lt;/sup&gt;</td>
<td>R&lt;sub&gt;L&lt;/sub&gt;</td>
<td>63.9</td>
<td>71</td>
<td>78.1</td>
<td>kΩ</td>
<td>VRxB:VRxA = 10, V&lt;sub&gt;REF&lt;/sub&gt; = V&lt;sub&gt;DD&lt;/sub&gt;</td>
</tr>
<tr>
<td>Resolution (# of resistors and # of taps), (see C.1 “Resolution”)</td>
<td>N</td>
<td>256</td>
<td>Taps</td>
<td></td>
<td></td>
<td>8-bit No missing codes</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1024</td>
<td>Taps</td>
<td></td>
<td></td>
<td>10-bit No missing codes</td>
</tr>
<tr>
<td></td>
<td></td>
<td>4096</td>
<td>Taps</td>
<td></td>
<td></td>
<td>12-bit No missing codes</td>
</tr>
<tr>
<td>Nominal V&lt;sub&gt;OUT&lt;/sub&gt; Match&lt;sup&gt;(10)&lt;/sup&gt;</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V&lt;sub&gt;OUT&lt;/sub&gt; − V&lt;sub&gt;OUTMEAN&lt;/sub&gt; / V&lt;sub&gt;OUTMEAN&lt;/sub&gt;</td>
<td>—</td>
<td>0.016</td>
<td>0.300</td>
<td>%</td>
<td>1.8V ≤ V&lt;sub&gt;DD&lt;/sub&gt; ≤ 5.5V&lt;sup&gt;(2)&lt;/sup&gt;</td>
<td></td>
</tr>
<tr>
<td>V&lt;sub&gt;OUT&lt;/sub&gt; Tempco&lt;sup&gt;(2)&lt;/sup&gt; (see C.19 “V&lt;sub&gt;OUT&lt;/sub&gt; Temperature Coefficient”)</td>
<td>ΔV&lt;sub&gt;OUT&lt;/sub&gt;/ΔT</td>
<td>—</td>
<td>3</td>
<td>—</td>
<td>ppm/°C</td>
<td>Code = Mid-Scale, VRxB:VRxA = 00, 10 and 11</td>
</tr>
<tr>
<td>V&lt;sub&gt;REF&lt;/sub&gt; Pin Input Voltage Range&lt;sup&gt;(4)&lt;/sup&gt;</td>
<td>V&lt;sub&gt;REF&lt;/sub&gt;</td>
<td>V&lt;sub&gt;SS&lt;/sub&gt;</td>
<td>—</td>
<td>V&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>V</td>
<td>1.8V ≤ V&lt;sub&gt;DD&lt;/sub&gt; ≤ 5.5V</td>
</tr>
</tbody>
</table>

**Note 1**  This parameter is ensured by design.

**Note 2**  This parameter is ensured by characterization.

**Note 6**  Resistance is defined as the resistance between the V<sub>REF</sub> pin (mode VRxB:VRxA = 10) to the V<sub>SS</sub> pin. For dual channel devices (MCP47CXBX2), this is the effective resistance of each resistor ladder. The resistance measurement is one of the two resistor ladders measured in parallel.

**Note 10**  Variation of one output voltage to mean output voltage for dual devices only.
## DC CHARACTERISTICS (CONTINUED)

### Standard Operating Conditions (unless otherwise specified):
- Operating Temperature: 
  -40°C ≤ T_A ≤ +125°C (Extended)
- All parameters apply across the specified operating ranges unless noted.
- V_DD = +2.7V to 5.5V, V_REF = +1.000V to V_DD, V_SS = 0V, R_L = 2 kΩ from V_OUT to GND, C_L = 100 pF.
- Typical specifications represent values for V_DD = 5.5V, T_A = +25°C.

### DC Electrical Characteristics

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Zero-Scale Error (Code = 000h)</td>
<td>E_ZS</td>
<td>—</td>
<td>—</td>
<td>0.375</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 0, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>—</td>
<td>1.5</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 0, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>—</td>
<td>6</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 0, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>See Section 2.0 “Typical Performance Curves”(2)</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 1, VREF = 0.5 x V_DD, no load</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Offset Error (see C.7 “Offset Error (E_OS)”)</td>
<td>E_OS</td>
<td>-6</td>
<td>±0.4</td>
<td>+6</td>
<td>mV</td>
<td>VRxB:VRxA = 10, G = 0, no load, 8-bit: Code = 4; 10-bit: Code = 16; 12-bit: Code = 64</td>
</tr>
<tr>
<td>Offset Voltage Temperature Coefficient(2,9)</td>
<td>V_OSTC</td>
<td>—</td>
<td>±5</td>
<td>—</td>
<td>µV/°C</td>
<td></td>
</tr>
<tr>
<td>Full-Scale Error (see C.4 “Full-Scale Error (E_FS)”)</td>
<td>E_FS</td>
<td>—</td>
<td>—</td>
<td>2.5</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 0, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>—</td>
<td>9</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 0, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>—</td>
<td>35</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 0, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>See Section 2.0 “Typical Performance Curves”(2)</td>
<td>LSb</td>
<td>VRxB:VRxA = 10, G = 1, VREF = 0.5 x V_DD, no load</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Gain Error (see C.9 “Gain Error (E_G)”)(7)</td>
<td>E_G</td>
<td>-1</td>
<td>±0.1</td>
<td>+1</td>
<td>% of FSR</td>
<td>VRxB:VRxA = 10, G = 0, Code = 252, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td>-1</td>
<td>±0.1</td>
<td>+1</td>
<td>% of FSR</td>
<td>VRxB:VRxA = 10, G = 0, Code = 1008, VREF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td>-1</td>
<td>±0.1</td>
<td>+1</td>
<td>% of FSR</td>
<td>VRxB:VRxA = 10, G = 0, Code = 4032, VREF = V_DD, no load</td>
</tr>
<tr>
<td>Gain Error Drift(2,9) (see C.10 “Gain Error Drift (EGD)”)</td>
<td>ΔG/°C</td>
<td>—</td>
<td>-6</td>
<td>—</td>
<td>ppm/°C</td>
<td></td>
</tr>
</tbody>
</table>

**Note 2** This parameter is ensured by characterization.

**Note 7** This gain error does not include the offset error.

**Note 9** Code range dependent on resolution: 8-bit, codes 4 to 252; 10-bit, codes 16 to 1008; 12-bit, codes 64 to 4032.
DC CHARACTERISTICS (CONTINUED)

Standard Operating Conditions (unless otherwise specified):
Operating Temperature: -40°C ≤ T_A ≤ +125°C (Extended)
All parameters apply across the specified operating ranges unless noted.
V_DD = +2.7V to 5.5V, V_REF = +1.000V to V_DD, V_SS = 0V, R_L = 2 kΩ from V_OUT to GND, C_L = 100 pF.
Typical specifications represent values for V_DD = 5.5V, T_A = +25°C.

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Total Unadjusted Error (ET)</td>
<td>-2.5</td>
<td>—</td>
<td>0.75</td>
<td>LSb</td>
<td>8-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>-9</td>
<td>—</td>
<td>3</td>
<td>LSb</td>
<td>10-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>-35</td>
<td>—</td>
<td>12</td>
<td>LSb</td>
<td>12-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>See Section 2.0 “Typical Performance Curves”</td>
</tr>
<tr>
<td>Integral Nonlinearity (INL)</td>
<td>-0.1</td>
<td>—</td>
<td>+0.1</td>
<td>LSb</td>
<td>8-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>-0.25</td>
<td>—</td>
<td>+0.25</td>
<td>LSb</td>
<td>10-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>-1</td>
<td>—</td>
<td>+1</td>
<td>LSb</td>
<td>12-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>See Section 2.0 “Typical Performance Curves”</td>
</tr>
<tr>
<td>Different Nonlinearity</td>
<td>-0.1</td>
<td>—</td>
<td>+0.1</td>
<td>LSb</td>
<td>8-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>-0.25</td>
<td>—</td>
<td>+0.25</td>
<td>LSb</td>
<td>10-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td>-1.0</td>
<td>—</td>
<td>+1.0</td>
<td>LSb</td>
<td>12-bit</td>
<td>VRx:B:VRxA = 10, G = 0, V_REF = V_DD, no load</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>See Section 2.0 “Typical Performance Curves”</td>
</tr>
</tbody>
</table>

Note 2: This parameter is ensured by characterization.
Note 9: Code range dependent on resolution: 8-bit, codes 4 to 252; 10-bit, codes 16 to 1008; 12-bit, codes 64 to 4032.
## DC CHARACTERISTICS (CONTINUED)

**Standard Operating Conditions (unless otherwise specified):**
Operating Temperature: -40°C ≤ T_A ≤ 125°C (Extended)
All parameters apply across the specified operating ranges unless noted.
V_DD = +2.7V to 5.5V, V_REF = +1.000V to V_DD, V_SS = 0V, R_L = 2 kΩ from V_OUT to GND, C_L = 100 pF.
Typical specifications represent values for V_DD = 5.5V, T_A = +25°C.

### -3 dB Bandwidth
(see C.16 “-3 dB Bandwidth”)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>-3 dB Bandwidth</td>
<td>BW</td>
<td>—</td>
<td>60</td>
<td>—</td>
<td>kHz</td>
<td>V_REF = 3.00V ± 2V, VRxB:VRxA = 10, Gx = 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>35</td>
<td>—</td>
<td></td>
<td>V_REF = 3.50V ± 1.5V, VRxB:VRxA = 10, Gx = 1</td>
</tr>
</tbody>
</table>

### Output Amplifier (Op Amp)

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Phase Margin(1)</td>
<td>PM</td>
<td>—</td>
<td>58</td>
<td>—</td>
<td>°C</td>
<td>R_L = ∞</td>
</tr>
<tr>
<td>Slew Rate</td>
<td>SR</td>
<td>—</td>
<td>0.15</td>
<td>—</td>
<td>V/μs</td>
<td>R_L = 2 kΩ</td>
</tr>
<tr>
<td>Load Regulation</td>
<td></td>
<td>—</td>
<td>130</td>
<td>—</td>
<td>μV/mA</td>
<td>1 mA ≤ I ≤ 6 mA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>—</td>
<td>320</td>
<td>—</td>
<td>μV/mA</td>
<td>-6 mA ≤ I ≤ -1 mA</td>
</tr>
<tr>
<td>Short-Circuit Current</td>
<td>I_{SC_OA}</td>
<td>6</td>
<td>10</td>
<td>14</td>
<td>mA</td>
<td>Short to V_SS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>6</td>
<td>10</td>
<td>14</td>
<td>mA</td>
</tr>
<tr>
<td>Settling Time(8)</td>
<td>I_{SETTLING}</td>
<td>—</td>
<td>16</td>
<td>—</td>
<td>μs</td>
<td>R_L = 2 kΩ</td>
</tr>
</tbody>
</table>

### Internal Band Gap

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Band Gap Voltage</td>
<td>V_BG</td>
<td>1.180</td>
<td>1.214</td>
<td>1.260</td>
<td>V</td>
<td>1.8V ≤ V_DD ≤ 5.5V</td>
</tr>
<tr>
<td>Short-Circuit Current</td>
<td>I_{SC_BG}</td>
<td>6</td>
<td>10</td>
<td>14</td>
<td>mA</td>
<td>Short to V_SS</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>6</td>
<td>10</td>
<td>14</td>
<td>mA</td>
</tr>
<tr>
<td>Band Gap Voltage</td>
<td>V_{BGTC}</td>
<td>—</td>
<td>16</td>
<td>—</td>
<td>ppm/°C</td>
<td>1.8V ≤ V_DD ≤ 5.5V</td>
</tr>
<tr>
<td>Temperature Coefficient</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Band Gap mode, V_REF Pin Load</td>
<td>I_{BG}</td>
<td>—</td>
<td>30</td>
<td>—</td>
<td>μV/mA</td>
<td>1 mA ≤ I ≤ 6 mA</td>
</tr>
<tr>
<td>Regulation</td>
<td></td>
<td>—</td>
<td>390</td>
<td>—</td>
<td>μV/mA</td>
<td>-6 mA ≤ I ≤ -1 mA</td>
</tr>
</tbody>
</table>

**Note 1**  This parameter is ensured by design.

**Note 8**  Within 1/2 LSb of the final value, when code changes from 1/4 to 3/4 of FSR. (Example: 400h to C00h in 12-bit device.)
## DC CHARACTERISTICS (CONTINUED)

**Standard Operating Conditions (unless otherwise specified):**
- Operating Temperature: \(-40°C \leq T_A \leq +125°C\) (Extended)
- All parameters apply across the specified operating ranges unless noted.
- \(V_{DD} = +2.7V\) to 5.5V, \(V_{REF} = +1.000V\) to \(V_{DD}\), \(V_{SS} = 0V\), \(R_L = 2\, k\Omega\) from \(V_{OUT}\) to GND, \(C_L = 100\, pF\).
- Typical specifications represent values for \(V_{DD} = 5.5V\), \(T_A = +25°C\).

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>External Reference (V_{REF})</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Input Range (^{(1)})</td>
<td>(V_{REF})</td>
<td>(V_{SS})</td>
<td>(\ldots)</td>
<td>(V_{DD})</td>
<td>(V)</td>
<td>(V_{REF}:V_{xRef} = 10) (Unbuffered mode)</td>
</tr>
<tr>
<td>Input Capacitance</td>
<td>(C_{REF})</td>
<td>(\ldots)</td>
<td>29</td>
<td>(\ldots)</td>
<td>(pF)</td>
<td>(V_{REF}:V_{xRef} = 10) (Unbuffered mode)</td>
</tr>
<tr>
<td>Input Impedance</td>
<td>(R_L)</td>
<td>(\ldots)</td>
<td>(\ldots)</td>
<td>(\ldots)</td>
<td>(\Omega)</td>
<td>2.7V (\leq V_{DD} \leq 5.5V), (V_{REF} = V_{DD})</td>
</tr>
<tr>
<td>Current through V_{REF} (^{(1)})</td>
<td>(I_{REF})</td>
<td>(\ldots)</td>
<td>(\ldots)</td>
<td>172.15</td>
<td>(\mu A)</td>
<td>Mathematically from (R_{VREF(min)}) spec (at 5.5V)</td>
</tr>
<tr>
<td>Total Harmonic Distortion (^{(1)})</td>
<td>(THD)</td>
<td>(\ldots)</td>
<td>-76</td>
<td>(\ldots)</td>
<td>(dB)</td>
<td>(V_{REF} = 2.048V \pm 0.1V), (V_{REF}:V_{xRef} = 10), (Gx = 0), Frequency = 1 kHz</td>
</tr>
<tr>
<td><strong>Dynamic Performance</strong></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Major Code Transition Glitch (see C.14 “Major Code Transition Glitch”(^{(1)}))</td>
<td>(\ldots)</td>
<td>(\ldots)</td>
<td>10</td>
<td>(\ldots)</td>
<td>(nV\cdot s)</td>
<td>1 LSb change around major carry (7FFh to 800h)</td>
</tr>
<tr>
<td>Digital Feedthrough (see C.15 “Digital Feedthrough”(^{(1)}))</td>
<td>(\ldots)</td>
<td>(\ldots)</td>
<td>&lt;2</td>
<td>(\ldots)</td>
<td>(nV\cdot s)</td>
<td></td>
</tr>
</tbody>
</table>

**Note 1** This parameter is ensured by design.

**Note 6** Resistance is defined as the resistance between the \(V_{REF}\) pin (mode \(V_{REF}:V_{xRef} = 10\)) to the \(V_{SS}\) pin. For dual channel devices (MCP47CXBX2), this is the effective resistance of each resistor ladder. The resistance measurement is one of the two resistor ladders measured in parallel.
**DC CHARACTERISTICS (CONTINUED)**

Standard Operating Conditions (unless otherwise specified):
Operating Temperature: -40°C ≤ TA ≤ +125°C (Extended)
All parameters apply across the specified operating ranges unless noted.
V<sub>DD</sub> = +2.7V to 5.5V, V<sub>REF</sub> = +1.000V to V<sub>DD</sub>, V<sub>SS</sub> = 0V, R<sub>L</sub> = 2 kΩ from V<sub>OUT</sub> to GND, C<sub>L</sub> = 100 pF.
Typical specifications represent values for V<sub>DD</sub> = 5.5V, TA = +25°C.

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Schmitt Trigger High Input Threshold</td>
<td>V&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>0.45 V&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>—</td>
<td>—</td>
<td>V</td>
<td>1.8V ≤ V&lt;sub&gt;DD&lt;/sub&gt; ≤ 5.5V (allows 2.7V digital V&lt;sub&gt;DD&lt;/sub&gt; with 5.5V analog V&lt;sub&gt;DD&lt;/sub&gt; or 1.8V digital V&lt;sub&gt;DD&lt;/sub&gt; with 3.0V analog V&lt;sub&gt;DD&lt;/sub&gt;)</td>
</tr>
<tr>
<td>Schmitt Trigger Low Input Threshold</td>
<td>V&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>—</td>
<td>—</td>
<td>0.2 V&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Hysteresis of Schmitt Trigger Inputs</td>
<td>V&lt;sub&gt;HYS&lt;/sub&gt;</td>
<td>—</td>
<td>0.1 V&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>—</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>Input Leakage Current</td>
<td>I&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>-1</td>
<td>—</td>
<td>1</td>
<td>µA</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = V&lt;sub&gt;DD&lt;/sub&gt; and V&lt;sub&gt;IN&lt;/sub&gt; = V&lt;sub&gt;SS&lt;/sub&gt;</td>
</tr>
<tr>
<td>Pin Capacitance</td>
<td>C&lt;sub&gt;IN&lt;/sub&gt;, C&lt;sub&gt;OUT&lt;/sub&gt;</td>
<td>—</td>
<td>10</td>
<td>—</td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>Digital Interface (SDA, SCL)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Output Low Voltage</td>
<td>V&lt;sub&gt;OL&lt;/sub&gt;</td>
<td>—</td>
<td>—</td>
<td>0.4 V&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>V</td>
<td>V&lt;sub&gt;DD&lt;/sub&gt; ≥ 2.0V, I&lt;sub&gt;OL&lt;/sub&gt; = 3 mA</td>
</tr>
<tr>
<td>Input High Voltage (SDA and SCL pins)</td>
<td>V&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>0.7 V&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>—</td>
<td>—</td>
<td>V</td>
<td>1.8V ≤ V&lt;sub&gt;DD&lt;/sub&gt; ≤ 5.5V</td>
</tr>
<tr>
<td>Input Low Voltage (SDA and SCL pins)</td>
<td>V&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>—</td>
<td>—</td>
<td>0.3 V&lt;sub&gt;DD&lt;/sub&gt;</td>
<td>V</td>
<td>1.8V ≤ V&lt;sub&gt;DD&lt;/sub&gt; ≤ 5.5V</td>
</tr>
<tr>
<td>Input Leakage</td>
<td>I&lt;sub&gt;L&lt;/sub&gt;</td>
<td>-1</td>
<td>—</td>
<td>1</td>
<td>µA</td>
<td>SCL = SDA = V&lt;sub&gt;SS&lt;/sub&gt; or SCL = SDA = V&lt;sub&gt;DD&lt;/sub&gt;</td>
</tr>
<tr>
<td>Pin Capacitance</td>
<td>C&lt;sub&gt;PIN&lt;/sub&gt;</td>
<td>—</td>
<td>10</td>
<td>—</td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>RAM Value</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Value Range</td>
<td>N</td>
<td>0h</td>
<td>—</td>
<td>FFh</td>
<td>Hex</td>
<td>8-bit</td>
</tr>
<tr>
<td>DAC Register POR/BOR Value</td>
<td>N</td>
<td>See Table 4-2</td>
<td>Hex</td>
<td>8-bit</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PDCON Initial Factory Setting</td>
<td>—</td>
<td>See Table 4-2</td>
<td>Hex</td>
<td>8-bit</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Power Requirements</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Power Supply Sensitivity (C.17 “Power Supply Sensitivity (PSS)” )</td>
<td>PSS</td>
<td>—</td>
<td>0.0010</td>
<td>0.0035</td>
<td>%/%</td>
<td>8-bit</td>
</tr>
<tr>
<td>Power Requirements</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Power Supply Sensitivity (C.17 “Power Supply Sensitivity (PSS)” )</td>
<td>PSS</td>
<td>—</td>
<td>0.0010</td>
<td>0.0035</td>
<td>%/%</td>
<td>8-bit</td>
</tr>
<tr>
<td>Power Requirements</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Power Supply Sensitivity (C.17 “Power Supply Sensitivity (PSS)” )</td>
<td>PSS</td>
<td>—</td>
<td>0.0010</td>
<td>0.0035</td>
<td>%/%</td>
<td>8-bit</td>
</tr>
</tbody>
</table>
### DC CHARACTERISTICS (CONTINUED)

Standard Operating Conditions (unless otherwise specified):

Operating Temperature: 

-40°C ≤ TA ≤ +125°C (Extended)

All parameters apply across the specified operating ranges unless noted.

VDD = +2.7V to 5.5V, VREF = +1.000V to VDD, VSS = 0V, RL = 2 kΩ from VOUT to GND, CL = 100 pF.

Typical specifications represent values for VDD = 5.5V, TA = +25°C.

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Multi-Time Programming Memory (MTP)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>MTP Programming Voltage(1)</td>
<td>VPG_MTP</td>
<td>2.0</td>
<td>—</td>
<td>5.5</td>
<td>V</td>
<td>HVC = VIH, -20°C ≤ TA ≤ +125°C</td>
</tr>
<tr>
<td>LAT/HVC Pin Voltage for MTP Programming (high-voltage commands)</td>
<td>VIH</td>
<td>7.25</td>
<td>7.5</td>
<td>7.75V</td>
<td>V</td>
<td>The LAT/HVC pin will be at one of the three input levels (VIL, VIH or VHHH(1)(11)), the LAT/HVC pin must supply the required MTP programming current (up to 6.4 mA)</td>
</tr>
<tr>
<td>Writes Cycles</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>32(12) Cycles</td>
<td></td>
</tr>
<tr>
<td>Data Retention</td>
<td>DR_MTP</td>
<td>10</td>
<td>—</td>
<td>—</td>
<td>Years At +85°C(1)</td>
<td></td>
</tr>
<tr>
<td>MTP Range</td>
<td>N</td>
<td>0h</td>
<td>—</td>
<td>FFh</td>
<td>Hex  8-bit</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0h</td>
<td>—</td>
<td>3FFh</td>
<td>Hex  10-bit</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0h</td>
<td>—</td>
<td>FFFh</td>
<td>Hex  12-bit</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>0000h</td>
<td>—</td>
<td>7FFH</td>
<td>Hex  All general purpose memory</td>
<td></td>
</tr>
<tr>
<td>Initial Factory Setting</td>
<td>N</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>See Table 4-2</td>
<td></td>
</tr>
<tr>
<td>MTP Programming Write Cycle Time(1)</td>
<td>tWC(MTP)</td>
<td>—</td>
<td>—</td>
<td>250</td>
<td>µs   VDD = +2.0V to 5.5V, -20°C ≤ TA ≤ +125°C</td>
<td></td>
</tr>
</tbody>
</table>

**Note 1** This parameter is ensured by design.

**Note 11** High-voltage on the LAT/HVC pin must be limited to the command + programming time. After the programming cycle, the LAT/HVC pin voltage must be returned to 5.5V or lower.

**Note 12** After 32 MTP write cycles, writes are inhibited and the 32nd write value is retained (not corrupted).
DC Notes:

1. This parameter is ensured by design.
2. This parameter is ensured by characterization.
3. POR/BOR voltage trip point is not slope-dependent. Hysteresis implemented with time delay.
4. Supply current is independent of current through the resistor ladder in mode VRxB:VRxA = 10.
5. The PDxB:PDxA = 01,10 and 11 configurations should have the same current.
6. Resistance is defined as the resistance between the VREF pin (mode VRxB:VRxA = 10) to the VSS pin. For dual channel devices (MCP47CXBX2), this is the effective resistance of each resistor ladder. The resistance measurement is one of the two resistor ladders measured in parallel.
7. This gain error does not include the offset error.
8. Within 1/2 LSb of the final value, when code changes from 1/4 to 3/4 of FSR. (Example: 400h to C00h in 12-bit device.)
9. Code range dependent on resolution: 8-bit, codes 4 to 252; 10-bit, codes 16 to 1008; 12-bit, codes 64 to 4032.
10. Variation of one output voltage to mean output voltage for dual devices only.
11. High-voltage on the LAT/HVC pin must be limited to the command + programming time. After the programming cycle, the LAT/HVC pin voltage must be returned to 5.5V or lower.
12. After 32 MTP write cycles, writes are inhibited and the 32nd write value is retained (not corrupted).
1.1 Timing Waveforms and Requirements

1.1.1 WIPER SETTLING TIME

**FIGURE 1-1:** $V_{OUT}$ Settling Time Waveforms.

**TABLE 1-1: WIPER SETTLING TIMING**

<table>
<thead>
<tr>
<th>Timing Characteristics</th>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{OUT}$ Settling Time (see C.13 “Settling Time”)</td>
<td>$t_S$</td>
<td>—</td>
<td>16</td>
<td>—</td>
<td>µs</td>
<td>12-bit Code = 400h → C00h; C00h → 400h$^2$</td>
<td></td>
</tr>
</tbody>
</table>

*Note 2* Within 1/2 LSB of final value when code changes from 1/4 to 3/4 of FSR.

1.1.2 LATCH PIN (LAT) TIMING

**FIGURE 1-2:** LAT Pin Waveforms.

**TABLE 1-2: LAT PIN TIMING**

<table>
<thead>
<tr>
<th>Timing Characteristics</th>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>LATx pin pulse width</td>
<td>$t_{LAT}$</td>
<td>20</td>
<td>—</td>
<td>—</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
1.2  \(^2\text{C Mode Timing Waveforms and Requirements}

**FIGURE 1-3:**  Power-on and Brown-out Reset Waveforms.

**FIGURE 1-4:**  \(^2\text{C Power-Down Command Timing.}

**TABLE 1-3:**  \textbf{RESET TIMING}

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typ.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Power-on Reset Delay(^{(1)})</td>
<td>(t_{\text{POR2SIA}})</td>
<td>—</td>
<td>—</td>
<td>130</td>
<td>(\mu\text{s})</td>
<td>Single Monitor ACK bit response to ensure the device responds to command</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>145</td>
<td></td>
<td>Dual</td>
</tr>
<tr>
<td>Brown-out Reset Delay</td>
<td>(t_{\text{BORD}})</td>
<td>—</td>
<td>30</td>
<td>—</td>
<td>(\mu\text{s})</td>
<td>(V_{\text{DD}}) transitions from (V_{\text{DD(MIN)}}) (\rightarrow) (V_{\text{POR}}). (V_{\text{OUT}}) driven to (V_{\text{OUT}}) disabled</td>
</tr>
<tr>
<td>Power-Down Output Enable Time Delay</td>
<td>(T_{\text{PDE}})</td>
<td>—</td>
<td>1.5</td>
<td>—</td>
<td>(\mu\text{s})</td>
<td>(\text{PDxA:PDxA} = 11, 10, \text{ or } 01 \geq 00) started from the rising edge of the (\text{SCL}) at the end of the 8th clock cycle, Volatile DAC register = (\text{FFFFh}), (V_{\text{OUT}} = 10 \text{ mV}, V_{\text{OUT}}) not connected</td>
</tr>
<tr>
<td>Power-Down Output Disable Time Delay</td>
<td>(T_{\text{PDD}})</td>
<td>—</td>
<td>0.025</td>
<td>—</td>
<td>(\mu\text{s})</td>
<td>(\text{PDxA:PDxA} = 00 \rightarrow 11, 10 \text{ or } 01) started from the rising edge of the (\text{SCL}) at the end of the 8th clock cycle, (V_{\text{OUT}} = V_{\text{OUT}} - 10 \text{ mV}, V_{\text{OUT}}) not connected</td>
</tr>
</tbody>
</table>

\textbf{Note 1}  Not tested. This parameter is ensured by characterization.

---

\(^{(1)}\) \(t_{\text{POR2SIA}} = t_{\text{POR2OD}}\)
Note 1: The HVC pin must be at $V_{IH}$ until the MTP write cycle is complete.

**FIGURE 1-5:** $\text{i}^2\text{C}$ Bus Start/Stop Bits and HVC Timing Waveforms.
### TABLE 1-4:  \(^2\text{C} \) BUS START/STOP BITS AND LAT REQUIREMENTS

<table>
<thead>
<tr>
<th>Param. No.</th>
<th>Sym.</th>
<th>Characteristic Description</th>
<th>Min.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>( F_{\text{SCL}} )</td>
<td>SCL Pin Frequency</td>
<td>Standard mode</td>
<td>0</td>
<td>100</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Fast mode</td>
<td>0</td>
<td>400</td>
<td>kHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>High Speed 1.7</td>
<td>0</td>
<td>1.7</td>
<td>MHz</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>High Speed 3.4</td>
<td>0</td>
<td>3.4</td>
<td>MHz</td>
</tr>
<tr>
<td>90</td>
<td>( T_{\text{SU:STA}} )</td>
<td>Start Condition Setup Time (only relevant for Repeated Start condition)</td>
<td>100 kHz mode</td>
<td>4700</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>600</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td>91</td>
<td>( T_{\text{HD:STA}} )</td>
<td>Start Condition Hold Time (after this period, the first clock pulse is generated)</td>
<td>100 kHz mode</td>
<td>4000</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>600</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td>92</td>
<td>( T_{\text{SU:STO}} )</td>
<td>Stop Condition Setup Time</td>
<td>100 kHz mode</td>
<td>4000</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>600</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td>93</td>
<td>( T_{\text{HD:STO}} )</td>
<td>Stop Condition Hold Time</td>
<td>100 kHz mode</td>
<td>4000</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>600</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td>94</td>
<td>( T_{\text{HVCUS}} )</td>
<td>HVC High to Start Condition (setup time)</td>
<td>0</td>
<td>—</td>
<td>( \mu \text{s} )</td>
<td>Not tested, specification ensured by Master</td>
</tr>
</tbody>
</table>

**Note 1**: Not tested. This parameter is ensured by characterization.
### Table 1-5: \(\text{I}^2\text{C} \text{ BUS REQUIREMENTS (SLAVE MODE)}\)

<table>
<thead>
<tr>
<th>Param. No.</th>
<th>Sym.</th>
<th>Characteristic</th>
<th>Min.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>100</td>
<td>(T_{\text{HIGH}})</td>
<td>Clock High Time</td>
<td>100 kHz mode</td>
<td>4000</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>600</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>120</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>60</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td>101</td>
<td>(T_{\text{LOW}})</td>
<td>Clock Low Time</td>
<td>100 kHz mode</td>
<td>4700</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>1300</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>320</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>160</td>
<td>—</td>
<td>ns</td>
</tr>
<tr>
<td>102A(^{(10)})</td>
<td>(T_{\text{RSCl}})</td>
<td>SCL Rise Time</td>
<td>100 kHz mode</td>
<td>—</td>
<td>1000</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>(20 + 0.1C_b)(^{(4)})</td>
<td>300</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>20</td>
<td>80</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>20</td>
<td>160</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>10</td>
<td>40</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>10</td>
<td>80</td>
<td>ns</td>
</tr>
<tr>
<td>102B(^{(10)})</td>
<td>(T_{\text{RSDA}})</td>
<td>SDA Rise Time</td>
<td>100 kHz mode</td>
<td>—</td>
<td>1000</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>(20 + 0.1C_b)(^{(4)})</td>
<td>300</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>20</td>
<td>160</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>10</td>
<td>80</td>
<td>ns</td>
</tr>
<tr>
<td>103A(^{(10)})</td>
<td>(T_{\text{FSCl}})</td>
<td>SCL Fall Time</td>
<td>100 kHz mode</td>
<td>—</td>
<td>300</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>(20 + 0.1C_b)(^{(4)})</td>
<td>300</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>20</td>
<td>80</td>
<td>ns</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>10</td>
<td>40</td>
<td>ns</td>
</tr>
</tbody>
</table>

Note 1: Not tested. This parameter is ensured by characterization.

Note 4: Use \(C_b\) in pF for the calculations.

Note 10: Not tested. This parameter is ensured by design.
### TABLE 1-5: I2C BUS REQUIREMENTS (SLAVE MODE) (CONTINUED)

<table>
<thead>
<tr>
<th>Param. No.</th>
<th>Sym.</th>
<th>Characteristic</th>
<th>Min.</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>103B</td>
<td>T_FSDA</td>
<td>SDA Fall Time</td>
<td></td>
<td></td>
<td>ns</td>
<td>C_b is specified to be from 10 to 400 pF (100 pF maximum for 3.4 MHz mode)</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 kHz mode</td>
<td>100 kHz</td>
<td>300</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>400 kHz</td>
<td>300</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>1.7 MHz</td>
<td>160</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>3.4 MHz</td>
<td>80</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>106</td>
<td>T_HD:DAT</td>
<td>Data Input Hold Time</td>
<td></td>
<td></td>
<td>ns</td>
<td>1.8V-5.5V</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 kHz mode</td>
<td>100 kHz</td>
<td>0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>400 kHz</td>
<td>0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>1.7 MHz</td>
<td>0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>3.4 MHz</td>
<td>0</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>107</td>
<td>T_SU:DAT</td>
<td>Data Input Setup Time</td>
<td></td>
<td></td>
<td>ns</td>
<td>Notes 1, 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 kHz mode</td>
<td>100 kHz</td>
<td>250</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>400 kHz</td>
<td>100</td>
<td>ns</td>
<td>Note 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>1.7 MHz</td>
<td>10</td>
<td>ns</td>
<td>Notes 1, 6</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>3.4 MHz</td>
<td>10</td>
<td>ns</td>
<td>Notes 1, 6</td>
</tr>
<tr>
<td>109</td>
<td>T_AA</td>
<td>Output Valid from Clock</td>
<td></td>
<td></td>
<td>ns</td>
<td>Notes 1, 5, 7, 9</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 kHz mode</td>
<td>100 kHz</td>
<td>0</td>
<td>ns</td>
<td>Notes 1, 5, 7, 9</td>
</tr>
<tr>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>400 kHz</td>
<td>0</td>
<td>ns</td>
<td>Notes 5, 7, 9</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>1.7 MHz</td>
<td>0</td>
<td>ns</td>
<td>C_b = 400 pF</td>
</tr>
<tr>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>3.4 MHz</td>
<td>0</td>
<td>ns</td>
<td>C_b = 100 pF</td>
</tr>
<tr>
<td>110</td>
<td>T_BUF</td>
<td>Bus Free Time</td>
<td></td>
<td></td>
<td>ns</td>
<td>Time the bus must be free before a new transmission can start</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 kHz mode</td>
<td>100 kHz</td>
<td>4700</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>400 kHz</td>
<td>1300</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>1.7 MHz</td>
<td>1300</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>3.4 MHz</td>
<td>N.A.</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>111</td>
<td>T_SP</td>
<td>Input Filter Spike Suppression (SDA and SCL)</td>
<td></td>
<td></td>
<td>ns</td>
<td>NXP Spec states N.A.</td>
</tr>
<tr>
<td></td>
<td></td>
<td>100 kHz mode</td>
<td>100 kHz</td>
<td>50</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>400 kHz mode</td>
<td>400 kHz</td>
<td>50</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>1.7 MHz mode</td>
<td>1.7 MHz</td>
<td>10</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>3.4 MHz mode</td>
<td>3.4 MHz</td>
<td>10</td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

**Note 1** Not tested. This parameter is ensured by characterization.

**Note 4** Use C\_b in pF for the calculations.

**Note 5** A Master transmitter must provide a delay to ensure that the difference between SDA and SCL fall times does not unintentionally create a Start or Stop condition.

**Note 6** A Fast mode (400 kHz) I\(^2\)C bus device can be used in a Standard mode (100 kHz) I\(^2\)C bus system, but the requirement, T\_SU:DAT \geq 250 ns, must then be met. This will automatically be the case if the device does not stretch the Low period of the SCL signal. If such a device does stretch the Low period of the SCL signal, it must output the next data bit to the SDA line, T\_R max. + T\_SU:DAT = 1000 + 250 = 1250 ns (according to the Standard mode I\(^2\)C bus specification) before the SCL line is released.

**Note 7** As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (minimum 300 ns) of the falling edge of SCL to avoid unintended generation of Start or Stop conditions.

**Note 8** Ensured by the T\_AA 3.4 MHz specification test.

**Note 9** The specification is not part of the I\(^2\)C specification. T\_AA = T\_HD:DAT + T\_FSDA (or T\_RSDA).

**Note 10** Not tested. This parameter is ensured by design.
Timing Notes:

1. Not tested. This parameter is ensured by characterization.
2. Within 1/2 LSb of final value when code changes from 1/4 to 3/4 of FSR.
3. The transition of the LAT signal, between 10 ns before the rising edge (Spec 94) and 250 ns after the rising edge (Spec 95) of the SCL signal, is indeterminate whether the change in VOUT is delayed or not.
4. Use Cb in pF for the calculations.
5. A Master transmitter must provide a delay to ensure that the difference between SDA and SCL fall times does not unintentionally create a Start or Stop condition.
6. A Fast mode (400 kHz) I2C bus device can be used in a Standard mode (100 kHz) I2C bus system, but the requirement, tsu,dat ≥ 250 ns, must then be met. This will automatically be the case if the device does not stretch the Low period of the SCL signal. If such a device does stretch the Low period of the SCL signal, it must output the next data bit to the SDA line, Tr max. + tsu,dat = 1000 + 250 = 1250 ns (according to the Standard mode I2C bus specification) before the SCL line is released.
7. As a transmitter, the device must provide this internal minimum delay time to bridge the undefined region (minimum 300 ns) of the falling edge of SCL to avoid unintended generation of Start or Stop conditions.
8. Ensured by the TaA 3.4 MHz specification test.
9. The specification is not part of the I2C specification. TaA = Thd,dat + Tsda (or Trsda).
10. Not tested. This parameter is ensured by design.
### TEMPERATURE SPECIFICATIONS

**Electrical Specifications**: Unless otherwise indicated, $V_{DD} = +2.7\text{V}$ to $+5.5\text{V}$, $V_{SS} = \text{GND}$.

<table>
<thead>
<tr>
<th>Parameters</th>
<th>Sym.</th>
<th>Min.</th>
<th>Typical</th>
<th>Max.</th>
<th>Units</th>
<th>Conditions</th>
</tr>
</thead>
<tbody>
<tr>
<td>Specified Temperature Range</td>
<td>$T_A$</td>
<td>-40</td>
<td>—</td>
<td>+125</td>
<td>°C</td>
<td>—</td>
</tr>
<tr>
<td>Operating Temperature Range</td>
<td>$T_A$</td>
<td>-40</td>
<td>—</td>
<td>+125</td>
<td>°C</td>
<td>—</td>
</tr>
<tr>
<td>Storage Temperature Range</td>
<td>$T_A$</td>
<td>-65</td>
<td>—</td>
<td>+150</td>
<td>°C</td>
<td>—</td>
</tr>
</tbody>
</table>

**Thermal Package Resistances**

<table>
<thead>
<tr>
<th>Thermal Resistance, 10L-MSOP</th>
<th>$\theta_{JA}$</th>
<th>—</th>
<th>206</th>
<th>—</th>
<th>°C/W</th>
</tr>
</thead>
<tbody>
<tr>
<td>Thermal Resistance, 10L-DFN (3x3)</td>
<td>$\theta_{JA}$</td>
<td>—</td>
<td>91</td>
<td>—</td>
<td>°C/W</td>
</tr>
<tr>
<td>Thermal Resistance, 16L-QFN (3x3)</td>
<td>$\theta_{JA}$</td>
<td>—</td>
<td>58</td>
<td>—</td>
<td>°C/W</td>
</tr>
</tbody>
</table>
2.0 TYPICAL PERFORMANCE CURVES

Note: The graphs and tables provided following this note are a statistical summary based on a limited number of samples and are provided for informational purposes only. The performance characteristics listed herein are not tested or guaranteed. In some graphs or tables, the data presented may be outside the specified operating range (e.g., outside specified power supply range), and therefore, outside the warranted range.

2.1 Electrical Data

Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-1:** Average Device Supply Current vs. $F_{SCL}$ Frequency, Voltage and Temperature – Active Interface, $V_{RxB}:V_{RxA} = 00$, (VDD Mode).

**FIGURE 2-2:** Average Device Supply Current vs. $F_{SCL}$ Frequency, Voltage and Temperature – Active Interface, $V_{RxB}:V_{RxA} = 01$ (Band Gap Mode).

**FIGURE 2-3:** Average Device Supply Current vs. $F_{SCL}$ Frequency, Voltage and Temperature – Active Interface, $V_{RxB}:V_{RxA} = 11$ (VREF Buffered Mode).

**FIGURE 2-4:** Average Device Supply Current – Inactive Interface (SCL = VIH or VIL) vs. Voltage and Temperature, $V_{RxB}:V_{RxA} = 00$ (VDD Mode).

**FIGURE 2-5:** Average Device Supply Current – Inactive Interface (SCL = VIH or VIL) vs. Voltage and Temperature, $V_{RxB}:V_{RxA} = 01$ (Band Gap Mode).

**FIGURE 2-6:** Average Device Supply Current – Inactive Interface (SCL = VIH or VIL) vs. Voltage and Temperature, $V_{RxB}:V_{RxA} = 11$ (VREF Buffered Mode).
Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

FIGURE 2-7: Average Device Supply Current vs. $F_{SCL}$ Frequency, Voltage and Temperature – Active Interface, $V_{RXB}:V_{RXA} = 10$ ($V_{REF}$ Unbuffered Mode).

FIGURE 2-8: Average Device Supply Active Current ($I_{DDA}$) (at 5.5V and $F_{SCL} = 3.4$ MHz) vs. Temperature and DAC Reference Voltage Mode.

FIGURE 2-9: Average Device Supply Current – Inactive Interface ($SCL = V_{IH}$ or $V_{IL}$) vs. Voltage and Temperature, $V_{RXB}:V_{RXA} = 10$ ($V_{REF}$ Unbuffered Mode).
2.2 Linearity Data

2.2.1 TOTAL UNADJUSTED ERROR (TUE) – MCP47CXB2X (12-BIT), $V_{REF} = V_{DD}$
($VRXB:VRXA = 1:0$), GAIN = 1x, CODE 64-4032

Note: Unless otherwise indicated: $T_A = +25°C$, $V_{DD} = 5.5V$.

**FIGURE 2-10:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 5.5V$.

**FIGURE 2-11:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 2.7V$.

**FIGURE 2-12:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 1.8V$.

**FIGURE 2-13:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 5.5V$.

**FIGURE 2-14:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 2.7V$.

**FIGURE 2-15:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 1.8V$. 
2.2.2 INTEGRAL NONLINEARITY (INL) – MCP47CXB2X (12-BIT), $V_{REF} = V_{DD}$ ($VRXB:VRXA = 10$), GAIN = 1x, CODE 64-4032

Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-16:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 5.5V$.

**FIGURE 2-17:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 2.7V$.

**FIGURE 2-18:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 1.8V$.

**FIGURE 2-19:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 5.5V$.

**FIGURE 2-20:** INL Error vs. DAC Code and Temperature (Code 100-4000) (Dual Channel – MCP47CXB22), $V_{DD} = 2.7V$.

**FIGURE 2-21:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 1.8V$. 
2.2.3  DIFFERENTIAL NONLINEARITY (DNL) – MCP47CXB2X (12-BIT), $V_{REF} = V_{DD}$
(VRXB:VRXA = 10), GAIN = 1x, CODE 64-4032

Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.
2.2.4 TOTAL UNADJUSTED ERROR (TUE) – MCP47CXB2X (12-BIT), EXTERNAL $V_{REF} = 0.5 \times V_{DD}$ ($VRXB:VRXA = 10$), UNBUFFERED, CODE 64-4032

**Note:** Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-28:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{REF} = 0.5 \times V_{DD} = 2.75V$, Gain = 2x.

**FIGURE 2-29:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{REF} = 0.5 \times V_{DD} = 1.35V$, Gain = 2x.

**FIGURE 2-30:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code, and Temperature (Dual Channel – MCP47CXB22), $V_{REF} = 0.5 \times V_{DD} = 2.75V$, Gain = 2x.

**FIGURE 2-31:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{REF} = 0.5 \times V_{DD} = 1.35V$, Gain = 2x.
2.2.5 INTEGRAL NONLINEARITY (INL) – MCP47CXB2X (12-BIT), EXTERNAL $V_{REF} = 0.5 \times V_{DD}$ ($VRXB/VRXA = 10$), UNBUFFERED, CODE 64-4032

Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-32:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{REF} = 0.5 \times V_{DD} = 2.75V$, Gain = 2x.

**FIGURE 2-33:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{REF} = 0.5 \times V_{DD} = 1.35V$, Gain = 2x.

**FIGURE 2-34:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{REF} = 0.5 \times V_{DD} = 2.75V$, Gain = 2x.

**FIGURE 2-35:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{REF} = 0.5 \times V_{DD} = 1.35V$, Gain = 2x.
2.2.6 DIFFERENTIAL NONLINEARITY ERROR (DNL) – MCP47CXB2X (12-BIT),
EXTERNAL $V_{\text{REF}} = 0.5 \, V_{\text{DD}}$ ($V_{\text{RXB}}:V_{\text{RXA}} = 1:10$), UNBUFFERED, CODE 64-4032

Note: Unless otherwise indicated, $T_A = +25^\circ\text{C}$, $V_{\text{DD}} = 5.5\text{V}$.

**FIGURE 2-36:** DNL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21),
$V_{\text{DD}} = 5.5\text{V}$, $V_{\text{REF}} = 0.5 \times V_{\text{DD}} = 2.75\text{V}$.

**FIGURE 2-37:** DNL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21),
$V_{\text{DD}} = 5.5\text{V}$, $V_{\text{REF}} = 0.5 \times V_{\text{DD}} = 1.35\text{V}$.

**FIGURE 2-38:** DNL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22),
$V_{\text{DD}} = 5.5\text{V}$, $V_{\text{REF}} = 0.5 \times V_{\text{DD}} = 2.75\text{V}$.

**FIGURE 2-39:** DNL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22),
$V_{\text{DD}} = 5.5\text{V}$, $V_{\text{REF}} = 0.5 \times V_{\text{DD}} = 1.35\text{V}$.
2.2.7 TOTAL UNADJUSTED ERROR (TUE) – MCP47CXB2X (12-BIT), \( V_{\text{REF}} \) = INTERNAL BAND GAP (VRXB:VRXA = 01), CODE 64-4032

**Note:** Unless otherwise indicated, \( T_A = +25^\circ \text{C} \), \( V_{\text{DD}} = 5.5 \text{V} \).

**FIGURE 2-40:** Total Unadjusted Error \( (V_{\text{OUT}}) \) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), \( V_{\text{DD}} = 5.5 \text{V} \), Gain = 1x.

**FIGURE 2-41:** Total Unadjusted Error \( (V_{\text{OUT}}) \) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), \( V_{\text{DD}} = 5.5 \text{V} \), Gain = 2x.

**FIGURE 2-42:** Total Unadjusted Error \( (V_{\text{OUT}}) \) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), \( V_{\text{DD}} = 2.7 \text{V} \), Gain = 1x.

**FIGURE 2-43:** Total Unadjusted Error \( (V_{\text{OUT}}) \) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), \( V_{\text{DD}} = 5.5 \text{V} \), Gain = 1x.

**FIGURE 2-44:** Total Unadjusted Error \( (V_{\text{OUT}}) \) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), \( V_{\text{DD}} = 5.5 \text{V} \), Gain = 2x.

**FIGURE 2-45:** Total Unadjusted Error \( (V_{\text{OUT}}) \) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), \( V_{\text{DD}} = 2.7 \text{V} \), Gain = 1x.
Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-46:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 2.7V$, Gain = 2x.

**FIGURE 2-47:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 1.8V$, Gain = 1x.

**FIGURE 2-48:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code, 25°C, Gain = 1x.

**FIGURE 2-49:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 2.7V$, Gain = 2x.

**FIGURE 2-50:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 1.8V$, Gain = 1x.

**FIGURE 2-51:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code, 25°C, Gain = 2x.
Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-52:** Total Unadjusted Error ($V_{OUT}$) vs. DAC Code, $+25^\circ C$, Gain = 1x and 2x.
2.2.8 INTEGRAL NONLINEARITY ERROR (INL) – MCP47CXB2X (12-BIT), \( V_{\text{REF}} = \text{INTERNAL BAND GAP (VRXB:VRXA = 01)}, \text{CODE 64-4032} \)

**Note:** Unless otherwise indicated, \( T_A = +25^\circ\text{C}, V_{\text{DD}} = 5.5\text{V}. \)

**FIGURE 2-53:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), \( V_{\text{DD}} = 5.5\text{V}, \text{Gain} = 1x. \)

**FIGURE 2-54:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), \( V_{\text{DD}} = 5.5\text{V}, \text{Gain} = 2x. \)

**FIGURE 2-55:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), \( V_{\text{DD}} = 2.7\text{V}, \text{Gain} = 1x. \)

**FIGURE 2-56:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), \( V_{\text{DD}} = 5.5\text{V}, \text{Gain} = 1x. \)

**FIGURE 2-57:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), \( V_{\text{DD}} = 5.5\text{V}, \text{Gain} = 2x. \)

**FIGURE 2-58:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), \( V_{\text{DD}} = 2.7\text{V}, \text{Gain} = 1x. \)
Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$. 

**FIGURE 2-59:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 2.7V$, Gain = 2x.

**FIGURE 2-60:** INL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 1.8V$, Gain = 1x.

**FIGURE 2-61:** INL Error vs. DAC Code, $+25^\circ C$, Gain = 1x.

**FIGURE 2-62:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 2.7V$, Gain = 2x.

**FIGURE 2-63:** INL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 1.8V$, Gain = 1x.

**FIGURE 2-64:** INL Error vs. DAC Code, $+25^\circ C$, Gain = 2x.
Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-65:** INL Error vs. DAC Code, +25°C, Gain = 1x and 2x.
2.2.9 DIFFERENTIAL NONLINEARITY ERROR (DNL) – MCP47CXB2X (12-BIT), VREF = INTERNAL BAND GAP (VRXB/VRXA = 01), CODE 64-4032

**Note:** Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-66:** DNL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 5.5V$, Gain = 1x.

**FIGURE 2-67:** DNL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 5.5V$, Gain = 2x.

**FIGURE 2-68:** DNL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 2.7V$, Gain = 1x.

**FIGURE 2-69:** DNL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 5.5V$, Gain = 1x.

**FIGURE 2-70:** DNL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 5.5V$, Gain = 2x.

**FIGURE 2-71:** DNL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 2.7V$, Gain = 1x.
**MCP47CXBXX**

**Note:** Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-72:** DNL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 2.7V$, Gain = 2x.

**FIGURE 2-73:** DNL Error vs. DAC Code and Temperature (Single Channel – MCP47CXB21), $V_{DD} = 1.8V$, Gain = 1x.

**FIGURE 2-74:** DNL Error vs. DAC Code, $+25^\circ C$, Gain = 1x.

**FIGURE 2-75:** DNL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 2.7V$, Gain = 2x.

**FIGURE 2-76:** DNL Error vs. DAC Code and Temperature (Dual Channel – MCP47CXB22), $V_{DD} = 1.8V$, Gain = 1x.

**FIGURE 2-77:** DNL Error vs. DAC Code, $+25^\circ C$, Gain = 2x.
Note: Unless otherwise indicated, $T_A = +25^\circ C$, $V_{DD} = 5.5V$.

**FIGURE 2-78:** DNL Error vs. DAC Code, $+25^\circ C$, Gain = 1x and 2x.
3.0 PIN DESCRIPTIONS

Overviews of the pin functions are provided in Section 3.1 “Positive Power Supply Input (VDD)” through Section 3.9 “No Connect (NC)”. The descriptions of the pins for the single DAC output device are listed in Table 3-1 and descriptions for the dual DAC output device are listed in Table 3-2.

**TABLE 3-1: MCP47CXB1 (SINGLE DAC) PIN FUNCTION TABLE**

<table>
<thead>
<tr>
<th>Pin</th>
<th>Symbol</th>
<th>I/O</th>
<th>Buffer Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>MSOP 10L</td>
<td>DFN 10L</td>
<td>QFN 16L</td>
<td>Symbol</td>
<td>I/O</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>16</td>
<td>VDD</td>
<td>—</td>
</tr>
<tr>
<td>2</td>
<td>2</td>
<td>1</td>
<td>A0</td>
<td>I</td>
</tr>
<tr>
<td>3</td>
<td>3</td>
<td>2</td>
<td>VREF</td>
<td>A</td>
</tr>
<tr>
<td>4</td>
<td>4</td>
<td>3</td>
<td>VOUT</td>
<td>A</td>
</tr>
<tr>
<td>5</td>
<td>5</td>
<td>4,5,6,7, 8,14,15</td>
<td>NC</td>
<td>—</td>
</tr>
<tr>
<td>6</td>
<td>6</td>
<td>9</td>
<td>LAT/HVC</td>
<td>I</td>
</tr>
<tr>
<td>7</td>
<td>7</td>
<td>10</td>
<td>VSS</td>
<td>—</td>
</tr>
<tr>
<td>8</td>
<td>8</td>
<td>11</td>
<td>A1</td>
<td>I</td>
</tr>
<tr>
<td>9</td>
<td>9</td>
<td>12</td>
<td>SCL</td>
<td>I</td>
</tr>
<tr>
<td>10</td>
<td>10</td>
<td>13</td>
<td>SDA</td>
<td>I/O</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
<td>17</td>
<td>EP</td>
<td>—</td>
</tr>
</tbody>
</table>

**Note 1:** A = Analog, I = Input, ST = Schmitt Trigger, O = Output, I/O = Input/Output, P = Power
### TABLE 3-2: MCP47CXBX2 (DUAL DAC) PIN FUNCTION TABLE

<table>
<thead>
<tr>
<th>Pin</th>
<th>Symbol</th>
<th>I/O</th>
<th>Buffer Type</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>V_DD</td>
<td>—</td>
<td>P</td>
<td>Supply Voltage Pin</td>
</tr>
<tr>
<td>2</td>
<td>A0</td>
<td>I</td>
<td>ST</td>
<td>I^2C Slave Address Bit 0 Pin</td>
</tr>
<tr>
<td>3</td>
<td>V_REF</td>
<td>A</td>
<td>Analog</td>
<td>Voltage Reference Input/Output Pin</td>
</tr>
<tr>
<td>—</td>
<td>VREF0</td>
<td>A</td>
<td>Analog</td>
<td>Voltage Reference Input/Output Pin for DAC0</td>
</tr>
<tr>
<td>—</td>
<td>VREF1</td>
<td>A</td>
<td>Analog</td>
<td>Voltage Reference Input/Output Pin for DAC1</td>
</tr>
<tr>
<td>4</td>
<td>VOUT0</td>
<td>A</td>
<td>Analog</td>
<td>Buffered Analog Voltage Output 0 Pin</td>
</tr>
<tr>
<td>5</td>
<td>VOUT1</td>
<td>A</td>
<td>Analog</td>
<td>Buffered Analog Voltage Output 1 Pin</td>
</tr>
<tr>
<td>—</td>
<td>NC</td>
<td>—</td>
<td>—</td>
<td>Not Internally Connected</td>
</tr>
<tr>
<td>6</td>
<td>LAT/HVC</td>
<td>I</td>
<td>ST</td>
<td>DAC Wiper Register Latch/High-Voltage Command Pin. The Latch pin allows the value in the Volatile DAC registers (Wiper and Configuration bits) to be transferred to the DAC output (VOUT). High-voltage commands allow the user MTP Configuration bits to be written.</td>
</tr>
<tr>
<td>—</td>
<td>LAT0/HVC</td>
<td>I</td>
<td>ST</td>
<td>DAC0 Wiper Register Latch/High-Voltage Command Pin. The Latch pin allows the value in the Volatile DAC0 registers (Wiper and Configuration bits) to be transferred to the DAC0 output (VOUT0). High-voltage commands allow the user MTP Configuration bits to be written.</td>
</tr>
<tr>
<td>—</td>
<td>LAT1</td>
<td>I</td>
<td>ST</td>
<td>DAC1 Wiper Register Latch Pin. The Latch pin allows the value in the Volatile DAC1 registers (Wiper and Configuration bits) to be transferred to the DAC1 output (VOUT1).</td>
</tr>
<tr>
<td>7</td>
<td>V_SS</td>
<td>—</td>
<td>P</td>
<td>Ground Reference Pin for all circuitries on the device</td>
</tr>
<tr>
<td>8</td>
<td>A1</td>
<td>I</td>
<td>ST</td>
<td>I^2C Slave Address Bit 1 Pin</td>
</tr>
<tr>
<td>9</td>
<td>SCL</td>
<td>I</td>
<td>ST</td>
<td>I^2C Serial Clock Pin</td>
</tr>
<tr>
<td>10</td>
<td>SDA</td>
<td>I/O</td>
<td>ST</td>
<td>I^2C Serial Data Pin</td>
</tr>
</tbody>
</table>

**Note 1:** A = Analog, I = Input, ST = Schmitt Trigger, O = Output, I/O = Input/Output, P = Power
3.1 Positive Power Supply Input (VDD)

VDD is the positive supply voltage input pin. The input supply voltage is relative to VSS.

The power supply at the VDD pin should be as clean as possible for good DAC performance. It is recommended to use an appropriate bypass capacitor of about 0.1 µF (ceramic) to ground as close as possible to the pin. An additional 10 µF capacitor (tantalum) in parallel is also recommended to further attenuate noise present in application boards.

3.2 Ground (VSS)

The VSS pin is the device ground reference.

The user must connect the VSS pin to a ground plane through a low-impedance connection. If an analog ground path is available in the application PCB (Printed Circuit Board), it is highly recommended that the VSS pin be tied to the analog ground path or isolated within an analog ground plane of the circuit board.

3.3 Voltage Reference Pin (VREF)

The VREF pin is either an input or an output. When the DAC’s voltage reference is configured as the VREF pin, the pin is an input. When the DAC’s voltage reference is configured as the internal band gap, the pin is an output.

When the DAC’s voltage reference is configured as the VREF pin, there are two options for this voltage input: VREF pin voltage is buffered or unbuffered. The buffered option is offered in cases where the external reference voltage does not have sufficient current capability to not drop its voltage when connected to the internal resistor ladder circuit.

When the DAC’s voltage reference is configured as the device VDD, the VREF pin is disconnected from the internal circuit.

When the DAC’s voltage reference is configured as the internal band gap, the VREF pin’s drive capability is minimal, so the output signal should be buffered.

See Section 5.2 “Voltage Reference Selection” and Register 4-2 for more details on the Configuration bits.

3.4 Analog Output Voltage Pins (VOUT0, VOUT1)

VOUT0 and VOUT1 are the DAC analog voltage output pins. Each DAC output has an output amplifier. The DAC output range is dependent on the selection of the voltage reference source (and potential output gain selection). These are:

- Device VDD – The Full-Scale Range (FSR) of the DAC output is from VSS to approximately VDD.
- VREF pin – The Full-Scale Range of the DAC output is from VSS to G x VRL, where G is the gain selection option (1x or 2x).
- Internal Band Gap – The Full-Scale Range of the DAC output is from VSS to G x VBG, where G is the gain selection option (1x or 2x).

In Normal mode, the DC impedance of the output pin is about 1Ω. In Power-Down mode, the output pin is internally connected to a known pull-down resistor of 1 kΩ, 100 kΩ or open. The power-down selection bits settings are shown in Register 4-3 (Table 5-5).

3.5 Latch/High-Voltage Command Pin (LAT/HVC)

The DAC output value update event can be controlled and synchronized using the LAT pin, for one or both channels, on single or different devices.

The LAT pin controls the effect of the Volatile Wiper registers, VRxB:VRxA and PDxB:PDxA, and the Gx bits on the DAC output. If the LAT pin is held at VIH, the values sent to the Volatile Wiper registers and Configuration bits have no effect on the DAC outputs. After the Volatile Wiper registers and Configuration bits have been loaded with the desired data, once the voltage on the pin transitions to VIL, the values in the Volatile Wiper registers and Configuration bits are transferred to the DAC outputs. Pulsing LAT low during writes to the registers could lead to unpredictable DAC output voltage values until the next pulse is issued and should be avoided. The pin is level-sensitive, so writing to the Volatile Wiper registers and Configuration bits while it is being held at VIL will trigger an immediate change in the outputs.

For dual output devices in MSOP and DFN packages, the LAT pin controls both channels at the same time. The HVC pin allows the device’s MTP memory to be programmed for the MCP47CMBXX devices. The programming voltage supply should provide 7.5V and at least 6.4 mA.

Note: The HVC pin should have voltages greater than 5.5V present only during the MTP programming operation. Using voltages greater than 5.5V for an extended time on the pin may cause device reliability issues.
3.6 \textbf{I}^2\textbf{C} – 
\textbf{S}erial \textbf{C}lock \textbf{P}in (SCL)

The SCL pin is the serial clock pin of the I^2C interface. The MCP47CXBXX I^2C interface only acts as a Slave and the SCL pin accepts only external serial clocks. The input data from the Master device are shifted into the SDA pin on the rising edges of the SCL clock and output from the device occurs at the falling edges of the SCL clock. The SCL pin is an open-drain N-channel driver. Therefore, it needs an external pull-up resistor from the VDD line to the SCL pin. Refer to Section 6.0 “I^2C Serial Interface Module” for more details on the I^2C serial interface communication.

3.7 \textbf{I}^2\textbf{C} – 
\textbf{S}erial \textbf{D}ata \textbf{P}in (SDA)

The SDA pin is the serial data pin of the I^2C interface. The SDA pin is used to write or read the DAC registers and Configuration bits. The SDA pin is an open-drain N-channel driver. Therefore, it needs an external pull-up resistor from the VDD line to the SDA pin. Except for Start and Stop conditions, the data on the SDA pin must be stable during the high period of the clock. The high or low state of the SDA pin can only change when the clock signal on the SCL pin is low. See Section 6.0 “I^2C Serial Interface Module”.

3.8 \textbf{I}^2\textbf{C} Slave \textbf{A}ddress \textbf{P}ins (A0,A1)

The state of these pins will determine the device’s I^2C Slave Address bit 0 value (overriding the ADD0 bit and the ADD1 bit in Register 4-5).

3.9 No Connect (NC)

The NC pin is not internally connected to the device.
4.0 GENERAL DESCRIPTION

The MCP47CXBX1 (MCP47CXB01, MCP47CXB11 and MCP47CXB21) devices are single-channel voltage output devices.
MCP47CXBX2 (MCP47CXB02, MCP47CXB12 and MCP47CXB22) are dual channel voltage output devices.
These devices are offered with 8-bit (MCP47CXB0X), 10-bit (MCP47CXB1X) and 12-bit (MCP47CXB2X) resolutions.
The family offers two memory options: the MCP47CVBXX devices have volatile memory, while the MCP47CMBXX have 32-times programmable nonvolatile memory (MTP).
All devices include an I2C serial interface and a write latch (LAT) pin to control the update of the analog output voltage value from the value written in the Volatile DAC Output register.
The devices use a resistor ladder architecture. The resistor ladder DAC is driven from a software-selectable voltage reference source. The source can be either the device’s internal VDD, an external VREF pin voltage (buffered or unbuffered) or an internal band gap voltage source.
The DAC output is buffered with a low-power and precision output amplifier. This output amplifier provides a rail-to-rail output with low offset voltage and low noise. The gain (1x or 2x) of the output buffer is software configurable.
The devices operate from a single supply voltage. This voltage is specified from 2.7V to 5.5V for full specified operation, and from 1.8V to 5.5V for digital operation. The device operates between 1.8V and 2.7V, but some device parameters are not specified.
The MCP47CMBXX devices also have user-programmable nonvolatile configuration memory (MTP). This allows the device’s desired POR values to be saved or the I2C address to be changed. The device also has general purpose MTP memory locations for storing system-specific information (calibration data, serial numbers, system ID information). A high-voltage requirement for programming on the HVC pin ensures that these device settings are not accidentally modified during normal system operation. Therefore, it is recommended that the MTP memory should only be programmed at the user’s factory.
The main functional blocks are:
- Power-on Reset/Brown-out Reset (POR/BOR)
- Device Memory
- Resistor Ladder
- Output Buffer/VOUT Operation
- I2C Serial Interface Module

4.1 Power-on Reset/Brown-out Reset (POR/BOR)
The internal Power-on Reset (POR)/Brown-out Reset (BOR) circuit monitors the power supply voltage (VDD) during operation. This circuit ensures correct device start-up at system power-up and power-down events.
The device’s RAM Retention Voltage (VRAM) is lower than the POR/BOR Voltage Trip Point (VPOR/VBOR). The maximum VPOR/VBOR voltage is less than 1.8V.
The POR and BOR trip points are at the same voltage, and the condition is determined by whether the VDD voltage is rising or falling (see Figure 4-1). What occurs is different depending on whether the Reset is a POR or BOR Reset.
POR occurs as the voltage rises (typically from 0V), while BOR occurs as the voltage falls (typically from VDD(MIN) or higher).
When VPOR/VBOR < VDD < 2.7V, the electrical performance may not meet the data sheet specifications. In this region, the device is capable of reading and writing to its volatile memory if the proper serial command is executed.

4.1.1 POWER-ON RESET
The Power-on Reset is the case where the device’s VDD has power applied to it from the VSS voltage level. As the device powers up, the VOUT pin floats to an unknown value. When the device’s VDD is above the transistor threshold voltage of the device, the output starts to be pulled low.
After the VDD is above the POR/BOR trip point (VBOR/VPOR), the resistor network’s wiper is loaded with the POR value. The POR value is either mid-scale (MCP47CVBXX) or the user’s MTP programmed value (MCP47CMBXX).

Note: In order to have the MCP47CMBXX devices load the values from nonvolatile memory locations at POR, they have to be programmed at least once by the user; otherwise, the loaded values will be the default ones. After MTP programming, a POR event is required to load the written values from the nonvolatile memory.
Volatile memory determines the Analog Output (V\textsubscript{OUT}) pin voltage. After the device is powered up, the user can update the device memory.

When the rising V\textsubscript{DD} voltage crosses the V\textsubscript{POR} trip point, the following occur:

- The default DAC POR value is latched into the Volatile DAC register.
- The default DAC POR Configuration bit values are latched into the Volatile Configuration bits.
- POR status bit is set ('1').
- The Reset Delay Timer (t\textsubscript{PORD}) starts; when the Reset Delay Timer (t\textsubscript{PORD}) times out, the I\textsubscript{2}C serial interface is operational. During this delay time, the I\textsubscript{2}C interface will not accept commands.
- The Device Memory Address Pointer is forced to 00h.

The Analog Output (V\textsubscript{OUT}) state is determined by the state of the Volatile Configuration bits and the DAC register. This is called a Power-on Reset (event).

Figure 4-1 illustrates the conditions for power-up and power-down events under typical conditions.
4.1.2 BROWN-OUT RESET

A Brown-out Reset occurs when a device had power applied to it and that power (voltage) drops below the specified range.

When the falling \( V_{DD} \) voltage crosses the \( V_{POR} \) trip point (BOR event), the following occurs:

- Serial interface is disabled.
- MTP writes are disabled.
- Device is forced into a power-down state \( (PDxB:PDxA = 1\ 1) \). Analog circuitry is turned off.
- Volatile DAC register is forced to 000h.

Volatile Configuration bits, VRxB:VRxA and Gx, are forced to '0'.

If the \( V_{DD} \) voltage decreases below the \( V_{RAM} \) voltage, all volatile memory may become corrupted.

As the voltage recovers above the \( V_{POR}/V_{BOR} \) voltage, see Section 4.1.1 “Power-on Reset” for further details.

Serial commands not completed due to a brown-out condition may cause the memory location to become corrupted.

Figure 4-1 illustrates the conditions for power-up and power-down events under typical conditions.

4.2 Device Memory

User memory includes the following types:

- **Volatile Register Memory (RAM)**
- **Nonvolatile Register Memory (MTP)**

MTP memory is present just for the MCP47CMBXX devices and has three groupings:

- NV DAC Output Values (loaded on POR event)
- Device Configuration Memory
- General Purpose NV Memory

Each memory location is up to 16 bits wide. The memory-mapped register space is shown in Table 4-1.

The I\(^2\)C interface depends on how this memory is read and written. Refer to Section 6.0 “I\(^2\)C Serial Interface Module” and Section 7.0 “Device Commands” for more details on reading and writing the device’s memory.

4.2.1 VOLATILE REGISTER MEMORY (RAM)

The MCP47CXBXX devices have volatile memory to directly control the operation of the DACs. There are up to five volatile memory locations:

- DAC0 and DAC1 Output Value registers
- VREF Select register
- Power-Down Configuration register
- Gain and Status register

The volatile memory starts functioning when the device \( V_{DD} \) is at (or above) the RAM retention voltage \( (V_{RAM}) \). The volatile memory will be loaded with the default device values when the \( V_{DD} \) rises across the \( V_{POR}/V_{BOR} \) voltage trip point.

After the device is powered-up, the user can update the device memory. Table 4-2 shows the volatile memory locations and their interaction due to a POR event.
### TABLE 4-1: MCP47CXBXX MEMORY MAP (16-BIT)

<table>
<thead>
<tr>
<th>Address</th>
<th>Function</th>
<th>Single</th>
<th>Dual</th>
</tr>
</thead>
<tbody>
<tr>
<td>00h</td>
<td>Volatile DAC Wiper Register 0</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>01h</td>
<td>Volatile DAC Wiper Register 1</td>
<td>—</td>
<td>Y</td>
</tr>
<tr>
<td>02h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>03h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>04h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>05h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>06h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>07h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>08h</td>
<td>Volatile VREF Register</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>09h</td>
<td>Volatile Power-Down Register</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>0Ah</td>
<td>Volatile Gain and Status Register</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td>0Bh</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>0Ch</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
<tr>
<td>0Dh</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
<tr>
<td>0Eh</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
<tr>
<td>0Fh</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
<tr>
<td>10h</td>
<td>Nonvolatile DAC Wiper Register 0</td>
<td>—</td>
<td>Y</td>
</tr>
<tr>
<td>11h</td>
<td>Nonvolatile DAC Wiper Register 1</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>12h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>13h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>14h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>15h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>16h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>17h</td>
<td>Reserved</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>18h</td>
<td>Nonvolatile VREF Register</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>19h</td>
<td>Nonvolatile Power-Down Register</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>1Ah</td>
<td>NV Gain and I(^2)C 7-Bit Slave Address</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>1Bh</td>
<td>NV WiperLock(^{TM}) Technology Register</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>1Ch</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
<tr>
<td>1Dh</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
<tr>
<td>1Eh</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
<tr>
<td>1Fh</td>
<td>General Purpose MTP</td>
<td>(1)</td>
<td></td>
</tr>
</tbody>
</table>

**Legend:**
- Volatile Memory Addresses
- MTP Memory Addresses
- Memory Locations Not Implemented on this Device Family

**Note 1:** On nonvolatile memory devices only (MCP47CMBXX).
4.2.2 NONVOLATILE REGISTER MEMORY (MTP)

This memory option is available only for the MCP47CMBXX devices.

MTP memory starts functioning below the device’s \( V_{POR}/V_{BOR} \) trip point, and once the \( V_{POR} \) event occurs, the Volatile Memory registers are loaded with the corresponding MTP register memory values.

Memory addresses, 0Ch through 1Fh, are nonvolatile memory locations. These registers contain the DAC POR/BOR wiper values, the DAC POR/BOR Configuration bits, the I\(^2\)C Slave address and eight general purpose memory addresses for storing user-defined data as calibration constants or identification numbers. The Nonvolatile DAC Wiper registers and Configuration bits contain the user’s DAC Output and configuration values for the POR event.

The Nonvolatile DAC Wiper registers contain the user’s DAC output and configuration values for the POR event. These nonvolatile values will overwrite the factory default values. If these MTP addresses are unprogrammed, the factory default values define the output state.

The Nonvolatile DAC registers enable the stand-alone operation of the device (without microcontroller control) after being programmed to the desired values.

To program nonvolatile memory locations, a high-voltage source on the LAT\(\bar{H}/V_{HC} \) pin is required. Each register/MTP location can be programmed 32 times. After 32 writes, a new write operation will not be possible and the last successful value written will remain associated with the memory location.

The device starts writing the MTP memory cells at the completion of the serial interface command at the rising edge of the last data bit. The high voltage should remain present on the LAT\(\bar{H}/V_{HC} \) pin until the write cycle is complete; otherwise, the write is unsuccessful and the location is compromised (cannot be used again and the number of available writes decreases by one).

To recover from an aborted MTP write operation, the following procedure must be used:

- Write again any valid value to the same address
- Force a POR condition
- Write again the desired value to the MTP location

It is recommended to keep high voltage on only during the MTP write command and programming cycle; otherwise, the reliability of the device could be affected.

4.2.3 POR/BOR OPERATION WITH WIPERLOCK TECHNOLOGY ENABLED

Regardless of the WiperLock technology state, a POR event will load the Volatile DACx Wiper register value with the Nonvolatile DACx Wiper register value. Refer to Section 4.1 “Power-on Reset/Brown-out Reset (POR/BOR)” for further information.

4.2.4 UNIMPLEMENTED LOCATIONS

4.2.4.1 Unimplemented Register Bits

When issuing read commands to a valid memory location with unimplemented bits, the unimplemented bits will be read as ‘0’.

4.2.4.2 Unimplemented (RESERVED) Locations

There are a number of unimplemented memory locations that are reserved for future use. Normal (voltage) commands (read or write) to any unimplemented memory address will result in a command error condition (I\(^2\)C NACK).

High-voltage commands to any unimplemented Configuration bit(s) will also result in a command error condition.
### TABLE 4-2: FACTORY DEFAULT POR/BOR VALUES (MTP MEMORY UNPROGRAMMED)

<table>
<thead>
<tr>
<th>Address</th>
<th>Function</th>
<th>POR/BOR Value</th>
<th></th>
<th></th>
<th></th>
<th>Address</th>
<th>Function</th>
<th>POR/BOR Value</th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>00h</td>
<td>Volatile DAC0 Register</td>
<td>7Fh</td>
<td>1FFh</td>
<td>7FFh</td>
<td>10h Nonvolatile DAC0 Wiper Register(1)</td>
<td>7Fh</td>
<td>1FFh</td>
<td>7FFh</td>
<td>11h Nonvolatile DAC1 Wiper Register(1)</td>
<td>7Fh</td>
<td>1FFh</td>
</tr>
<tr>
<td>01h</td>
<td>Volatile DAC1 Register</td>
<td>7Fh</td>
<td>1FFh</td>
<td>7FFh</td>
<td>12h Reserved(3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>02h</td>
<td>Reserved(3)</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>13h Reserved(3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>03h</td>
<td>Reserved(3)</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>14h Reserved(3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>04h</td>
<td>Reserved(3)</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>15h Reserved(3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>05h</td>
<td>Reserved(3)</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>16h Reserved(3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>06h</td>
<td>Reserved(3)</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>17h Reserved(3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>07h</td>
<td>Reserved(3)</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>18h Nonvolatile VREF Register(1)</td>
<td>0000h</td>
<td>0000h</td>
<td>0000h</td>
<td>19h Nonvolatile Power-Down Register(1)</td>
<td>0000h</td>
<td>0000h</td>
</tr>
<tr>
<td>08h</td>
<td>Volatile VREF Register</td>
<td>0000h</td>
<td>0000h</td>
<td>0000h</td>
<td>0Ah Volatile Gain and Status Register(4)</td>
<td>0080h</td>
<td>0080h</td>
<td>0080h</td>
<td>1Ah NV Gain and I2C 7-Bit Slave Address(1,2)</td>
<td>0060h</td>
<td>0060h</td>
</tr>
<tr>
<td>09h</td>
<td>Volatile Power-Down Register</td>
<td>0000h</td>
<td>0000h</td>
<td>0000h</td>
<td>0Bh Reserved(3)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>0Ah</td>
<td>General Purpose MTP(1)</td>
<td>0000h</td>
<td>0000h</td>
<td>0000h</td>
<td>0Ch General Purpose MTP(1)</td>
<td>0000h</td>
<td>0000h</td>
<td>0000h</td>
<td>0Dh General Purpose MTP(1)</td>
<td>0000h</td>
<td>0000h</td>
</tr>
<tr>
<td>0Bh</td>
<td>General Purpose MTP(1)</td>
<td>0000h</td>
<td>0000h</td>
<td>0000h</td>
<td>0Eh General Purpose MTP(1)</td>
<td>0000h</td>
<td>0000h</td>
<td>0000h</td>
<td>0Fh General Purpose MTP(1)</td>
<td>0000h</td>
<td>0000h</td>
</tr>
</tbody>
</table>

**Legend:**
- Volatile Memory Address Range
- Nonvolatile Memory Address Range
- Not Implemented

**Note 1:** On nonvolatile devices only (MCP47CMBXX).

1. Default I2C 7-bit Slave address is '110 0000' ('110 00xx' when A1:A0 bits are determined from the A1 and A0 pins).
2. Reading a reserved memory location will result in the I2C command to Not ACK the command byte. The device data bits will output all '1's. A Start condition will reset the I2C interface.
3. The '1' bit is the POR status bit, which is set after the POR event and cleared after address 0Ah is read.
4.2.5 DEVICE REGISTERS

Register 4-1 shows the format of the DAC Output Value registers for the volatile memory locations. These registers will be either 8 bits, 10 bits or 12 bits wide. The values are right justified.

### REGISTER 4-1: DAC0 (00h/10h) AND DAC1 (01h/11h) OUTPUT VALUE REGISTERS (VOLATILE/NONVOLATILE)

<table>
<thead>
<tr>
<th>U-0</th>
<th>U-0</th>
<th>U-0</th>
<th>U-0</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
<th>R/W-n</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>D11</td>
<td>D10</td>
<td>D09</td>
<td>D08</td>
<td>D07</td>
<td>D06</td>
<td>D05</td>
<td>D04</td>
<td>D03</td>
<td>D02</td>
</tr>
</tbody>
</table>

**Legend:**
- R = Readable bit
- W = Writable bit
- U = Unimplemented bit, read as ‘0’
- n = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown
- = 12-bit device
- = 10-bit device
- = 8-bit device

#### 12-bit

**Unimplemented:** Read as ‘0’

<table>
<thead>
<tr>
<th>bit 11-0</th>
<th>—</th>
<th>—</th>
<th><strong>D11:D00:</strong> DAC Output Value bits – 12-bit devices</th>
</tr>
</thead>
<tbody>
<tr>
<td>bit 9-0</td>
<td>—</td>
<td>—</td>
<td><strong>D09:D00:</strong> DAC Output Value bits – 10-bit devices</td>
</tr>
<tr>
<td>bit 7-0</td>
<td>—</td>
<td>—</td>
<td><strong>D07:D00:</strong> DAC Output Value bits – 8-bit devices</td>
</tr>
</tbody>
</table>

**Values:**
- FFFh = Full-scale output value
- 7FFh = Mid-scale output value
- 000h = Zero scale output value
Register 4-2 shows the format of the Voltage Reference Control register. Each DAC has two bits to control the source of the voltage reference of the DAC. This register is for the volatile memory locations. The width of this register is two times the number of DACs for the device.

### REGISTER 4-2: VOLTAGE REFERENCE (VREF) CONTROL REGISTERS (08h/18h) (VOLATILE/NONVOLATILE)

<table>
<thead>
<tr>
<th>Single</th>
<th>Dual</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>R/W-n</td>
<td>R/W-n</td>
</tr>
<tr>
<td>R/W-n</td>
<td>R/W-n</td>
</tr>
</tbody>
</table>

Legend:
- **R** = Readable bit
- **W** = Writable bit
- **U** = Unimplemented bit, read as ‘0’
- **-n** = Value at POR
- **‘1’** = Bit is set
- **‘0’** = Bit is cleared
- **x** = Bit is unknown

### Single Channel Device

- **bit 15-2**: Unimplemented: Read as ‘0’
- **bit 1-0**: VRxB:VRxA: DAC Voltage Reference Control bits
  - **11**: $V_{REF}$ pin (buffered); $V_{REF}$ buffer enabled
  - **10**: $V_{REF}$ pin (unbuffered); $V_{REF}$ buffer disabled
  - **01**: Internal band gap (1.214V typical); $V_{REF}$ buffer enabled, $V_{REF}$ voltage driven when powered down (2)
  - **00**: $V_{DD}$ (unbuffered); $V_{REF}$ buffer disabled, use this state with power-down bits for lowest current

### Dual Channel Device

- **bit 15-4**: VRxB:VRxA: DAC Voltage Reference Control bits
- **bit 3-0**: VRxB:VRxA: DAC Voltage Reference Control bits

**Note 1:** Unimplemented bit, read as ‘0’.

**Note 2:** When the internal band gap is selected, the band gap voltage source will continue to output the voltage on the $V_{REF}$ pin in any of the Power-Down modes. To reduce the power consumption to its lowest level (band gap disabled), after selecting the desired Power-Down mode, the voltage reference should be changed to $V_{DD}$ or the $V_{REF}$ pin unbuffered (‘00’ or ‘10’), which turns off the Internal band gap circuitry. After wake-up, the user needs to reselect the internal band gap (‘01’) for the voltage reference source.
Register 4-3 shows the format of the Power-Down Control register. Each DAC has two bits to control the power-down state of the DAC. This register is for the volatile memory locations and the nonvolatile memory locations. The width of this register is two times the number of DACs for the device.

**REGISTER 4-3: POWER-DOWN CONTROL REGISTERS (09h/19h) (VOLATILE/NONVOLATILE)**

<table>
<thead>
<tr>
<th>Single</th>
<th>Dual</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>R/W-n</td>
<td>R/W-n</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
</tr>
<tr>
<td>R/W-n</td>
<td>R/W-n</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>PD0B</td>
<td>PD0A</td>
</tr>
<tr>
<td>PD1B</td>
<td>PD1A</td>
</tr>
<tr>
<td>PD0B</td>
<td>PD0A</td>
</tr>
</tbody>
</table>

Legend:
- `R` = Readable bit
- `W` = Writable bit
- `U` = Unimplemented bit, read as ‘0’
- `-n` = Value at POR
- `'1'` = Bit is set
- `'0'` = Bit is cleared
- `x` = Bit is unknown
- `Single` = Single channel device
- `Dual` = Dual channel device

**Legend:**
- `R` = Readable bit
- `W` = Writable bit
- `U` = Unimplemented bit, read as ‘0’
- `-n` = Value at POR
- `'1'` = Bit is set
- `'0'` = Bit is cleared
- `x` = Bit is unknown
- `Single` = Single channel device
- `Dual` = Dual channel device

**Single**
- bit 15-2
- bit 1-0

**Dual**
- bit 15-4
- bit 3-0

**Legend:**
- `Unimplemented`: Read as ‘0’
- `PDxB:PDxA`: DAC Power-Down Control bits
  - `11` = Powered down – \( V_{\text{OUT}} \) is open circuit
  - `10` = Powered down – \( V_{\text{OUT}} \) is loaded with a 100 k\( \Omega \) resistor to ground
  - `01` = Powered down – \( V_{\text{OUT}} \) is loaded with a 1 k\( \Omega \) resistor to ground
  - `00` = Normal operation (not powered down)

**Note:**
1. Unimplemented bit, read as ‘0’.
2. See Table 5-5 for more details.
Register 4-4 shows the format of the Gain Control and System Status register. Each DAC has one bit to control the gain of the DAC and two Status bits.

**REGISTER 4-4: GAIN CONTROL AND SYSTEM STATUS REGISTER (0Ah) (VOLATILE)**

<table>
<thead>
<tr>
<th>Bit</th>
<th>Single Channel</th>
<th>Dual Channel</th>
</tr>
</thead>
<tbody>
<tr>
<td>15-9</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>9</td>
<td>—</td>
<td>—</td>
</tr>
<tr>
<td>8</td>
<td>bit 8 G1: DAC1 Output Driver Gain Control bit</td>
<td>bit 8 G0: DAC0 Output Driver Gain Control bit</td>
</tr>
<tr>
<td></td>
<td>1 = 2x gain; not applicable when $V_{DD}$ is used as $V_{RL}$</td>
<td>1 = 2x gain; not applicable when $V_{DD}$ is used as $V_{RL}$</td>
</tr>
<tr>
<td></td>
<td>0 = 1x gain</td>
<td>0 = 1x gain</td>
</tr>
<tr>
<td>7</td>
<td>bit 7 POR: Power-on Reset (Brown-out Reset) Status bit</td>
<td>bit 7 MTPMA: MTP Memory Access Status bit(3)</td>
</tr>
<tr>
<td></td>
<td>This bit indicates if a POR or BOR event has occurred since the last read command of this register. Reading this register clears the state of the POR Status bit.</td>
<td>This bit indicates if the MTP memory access is occurring.</td>
</tr>
<tr>
<td></td>
<td>1 = A POR (BOR) event occurred since the last read of this register; reading this register clears this bit</td>
<td>1 = An MTP memory access is currently occurring (during the POR MTP read cycle or an MTP write cycle is occurring); only serial commands addressing the volatile memory are allowed</td>
</tr>
<tr>
<td></td>
<td>0 = A POR (BOR) event has not occurred since the last read of this register</td>
<td>0 = An MTP memory access is NOT currently occurring</td>
</tr>
<tr>
<td>6</td>
<td>bit 6 MTPMA: MTP Memory Access Status bit(3)</td>
<td>Unimplemented: Read as ‘0’</td>
</tr>
<tr>
<td></td>
<td>This bit indicates if the MTP memory access is occurring.</td>
<td></td>
</tr>
<tr>
<td>5-0</td>
<td>bit 5-0 Unimplemented: Read as ‘0’</td>
<td>Unimplemented: Read as ‘0’</td>
</tr>
</tbody>
</table>

**Legend:**

- **R** = Readable bit
- **W** = Writable bit
- **C** = Clearable bit
- **U** = Unimplemented bit, read as ‘0’
- -n = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown

**Note:**

1. Unimplemented bit, read as ‘0’.
2. The DAC’s Gain bit is ignored and the gain is forced to 1x ($G_x = 0$) when the DAC voltage reference is selected as $V_{DD}$ ($VRxB:VRxA = 00$).
3. For devices configured as volatile memory, this bit is read as ‘0’.
Register 4-5 shows the format of the Nonvolatile Gain Control and Slave Address register. Each DAC has one bit to control the gain of the DAC. \(^2\)C devices also have seven bits that are the \(^2\)C Slave address.

**REGISTER 4-5: GAIN CONTROL AND SLAVE ADDRESS REGISTER (1Ah) (NONVOLATILE)**

<table>
<thead>
<tr>
<th>Single</th>
<th>Dual</th>
<th></th>
<th></th>
<th></th>
<th>R/W-n</th>
<th></th>
<th>R/W-n</th>
<th></th>
<th>R/W-n</th>
<th></th>
<th>R/W-n</th>
<th></th>
<th>R/W-n</th>
<th></th>
<th>R/W-n</th>
</tr>
</thead>
<tbody>
<tr>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>G1</td>
<td>G0</td>
<td>ADD6</td>
<td>ADD5</td>
<td>ADD4</td>
<td>ADD3</td>
<td>ADD2</td>
<td>ADD1</td>
<td>ADD0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>U-0</td>
<td>G1</td>
<td>G0</td>
<td>ADD6</td>
<td>ADD5</td>
<td>ADD4</td>
<td>ADD3</td>
<td>ADD2</td>
<td>ADD1</td>
<td>ADD0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Legend:
- R = Readable bit
- W = Writable bit
- C = Clearable bit
- U = Unimplemented bit, read as ‘0’
- -n = Value at POR
  - ‘1’ = Bit is set
  - ‘0’ = Bit is cleared
  - x = Bit is unknown

Single | Dual
---|---
bit 15-10 | bit 15-10
**Unimplemented:** Read as ‘0’

bit 9-8 | bit 9-8
**Gx:** DAC Output Driver Gain Control bits\(^{(1)}\)
1 = 2x gain
0 = 1x gain

bit 7 | bit 7
**Unimplemented:** Read as ‘0’

bit 6-0 | bit 6-0
**ADD6:ADD0:** \(^2\)C 7-Bit Slave Address bits\(^{(2)}\)

**Note 1:** When the DAC voltage reference is selected as \(V_{DD}\) (VRxB:VRxA = 00), the DAC’s Gain bit is ignored and the gain is forced to 1x (Gx = 0).

**2:** For \(^2\)C devices that have the A1 and A0 pins, the 7-bit Slave address is ADD6:ADD2 + A1:A0. For devices without the A1 and A0 pins, the 7-bit Slave address is ADD6:ADD0.
Register 4-6 shows the format of the DAC WiperLock Technology Status register. The width of this register is two times the number of DACs for the device. WiperLock technology bits only control access to volatile memory. Nonvolatile memory write access is controlled by the requirement of high voltage on the HVC pin, which is recommended to not be available during normal device operation.

**REGISTER 4-6: WiperLock™ TECHNOLOGY CONTROL REGISTER (1Bh) (NONVOLATILE)**

<table>
<thead>
<tr>
<th>Single</th>
<th>Dual</th>
</tr>
</thead>
<tbody>
<tr>
<td>bit 15-2</td>
<td>bit 15-4</td>
</tr>
<tr>
<td>bit 1-0</td>
<td>bit 3-1</td>
</tr>
</tbody>
</table>

**Legend:**
- **R** = Readable bit
- **W** = Writable bit
- **C** = Clearable bit
- **U** = Unimplemented bit, read as '0'
- -n = Value at POR
- ‘1’ = Bit is set
- ‘0’ = Bit is cleared
- x = Bit is unknown
- □ = Single channel device
- ■ = Dual channel device

**Unimplemented:** Read as ‘0’

**WLxB:WLxA:** WiperLock™ Technology Status bits (2)

- 11 = Volatile DAC Wiper register and Volatile DAC Configuration bits are locked
- 10 = Volatile DAC Wiper register is locked and Volatile DAC Configuration bits are unlocked
- 01 = Volatile DAC Wiper register is unlocked and Volatile DAC Configuration bits are locked
- 00 = Volatile DAC Wiper register and Volatile DAC Configuration bits are unlocked

**Note 1:** Unimplemented bit, read as ‘0’.

**Note 2:** The Volatile PDxB:PDxA bits are NOT locked due to the requirement of being able to exit Power-Down mode.
5.0 DAC CIRCUITRY

The Digital-to-Analog Converter circuitry converts a digital value into its analog representation. This description describes the functional operation of the device.

The DAC circuit uses a resistor ladder implementation. Devices have up to two DACs. Figure 5-1 shows the functional block diagram for the MCP47CXBXX DAC circuitry.

The functional blocks of the DAC include:
- Resistor Ladder
- Voltage Reference Selection
- Output Buffer/VOUT Operation
- Latch Pin (LAT)
- Power-Down Operation

![Figure 5-1: MCP47CXBXX DAC Module Block Diagram.](image-url)

Where:
- \( V_{W} = \frac{\text{DAC Register Value}}{\#\text{Resistor in Resistor Ladder}} \times V_{RL} \)

- \# Resistors in Resistor Ladder = 256 (MCP47CXB0X)
- 1024 (MCP47CXB1X)
- 4096 (MCP47CXB2X)
5.1 Resistor Ladder

The resistor ladder is a digital potentiometer with the A Terminal connected to the selected reference voltage and the B Terminal internally grounded (see Figure 5-2). The Volatile DAC register controls the wiper position. The Wiper Voltage ($V_W$) is proportional to the DAC register value divided by the number of Resistor Elements ($R_S$) in the ladder (256, 1024 or 4096) related to the $V_{RL}$ voltage.

The output of the resistor network will drive the input of an output buffer.

The resistor network is made up of three parts:

- Resistor Ladder (string of $R_S$ elements)
- Wiper Switches
- DAC Register Decode

The resistor ladder has a typical impedance ($R_{RL}$) of approximately 71 kΩ. This Resistor Ladder Resistance ($R_{RL}$) may vary from device to device, up to ±10%. Since this is a voltage divider configuration, the actual $R_{RL}$ resistance does not affect the output, given a fixed voltage at $V_{RL}$.

Equation 5-1 shows the calculation for the step resistance.

Note: The maximum wiper position is $2^n - 1$, while the number of resistors in the resistor ladder is $2^n$. This means that when the DAC register is at full scale, there is one Resistor Element ($R_S$) between the wiper and the $V_{RL}$ voltage.

If the unbuffered $V_{REF}$ pin is used as the $V_{RL}$ voltage source, the external voltage source should have a low output impedance.

When the DAC is powered down, the resistor ladder is disconnected from the selected reference voltage.

Note 1: The analog Switch Resistance ($R_W$) does not affect performance due to the voltage divider configuration.

FIGURE 5-2: Resistor Ladder Model
Block Diagram.

EQUATION 5-1: $R_S$ CALCULATION

- $R_S = \frac{R_{RL}}{256}$ 8-Bit Device
- $R_S = \frac{R_{RL}}{1024}$ 10-Bit Device
- $R_S = \frac{R_{RL}}{4096}$ 12-Bit Device
5.2 Voltage Reference Selection

The resistor ladder has up to four sources for the reference voltage. The selection of the voltage reference source is specified with the Volatile VREF1:VREF0 Configuration bits (see Register 4-2). The selected voltage source is connected to the V RL node (see Figure 5-3 and Figure 5-4).

The four voltage source options for the Resistor Ladder are:
1. V DD pin voltage.
2. Internal Band Gap Voltage Reference (V BG).
3. V REF pin voltage – unbuffered.
4. V REF pin voltage – internally buffered.

On a POR/BOR event, the default configuration state or the value written in the Nonvolatile register is latched into the Volatile VREF1:VREF0 Configuration bits.

If the V REF pin is used with an external voltage source, then the user must select between Buffered or Unbuffered mode.

5.2.1 USING V DD AS V REF

When the user selects the V DD as reference, the V REF pin voltage is not connected to the resistor ladder. The V DD voltage is internally connected to the resistor ladder.

5.2.2 USING AN EXTERNAL V REF SOURCE IN UNBUFFERED MODE

In this case, the V REF pin voltage may vary from V SS to V DD. The voltage source should have a low output impedance. If the voltage source has a high output impedance, then the voltage on the V REF pin could be lower than expected. The resistor ladder has a typical impedance of 71 kΩ and a typical capacitance of 29 pF.

If a single V REF pin is supplying multiple DACs, the V REF pin source must have adequate current capability to support the number of DACs. It must be assumed that the Resistor Ladder Resistance (R RL) of each DAC is at the minimum specified resistance and these resistances are in parallel.

If the V REF pin is tied to the V DD voltage, selecting the V DD Reference mode (VREF1:VREF0 = 00) is recommended.
5.2.3 USING AN EXTERNAL VREF SOURCE IN BUFFERED MODE

The VREF pin voltage may be from 0V to VDD. The input buffer (amplifier) provides low offset voltage, low noise, and a very high input impedance, with only minor limitations on the input range and frequency response. Any variation or noises on the reference source can directly affect the DAC output. The reference voltage needs to be as clean as possible for accurate DAC performance.

5.2.4 USING THE INTERNAL BAND GAP AS VOLTAGE REFERENCE

The internal band gap is designed to drive the resistor ladder buffer.

If the internal band gap is selected, then the band gap voltage source will drive the external VREF pins. The VREF0 pin can source up to 1 mA of current without affecting the DAC output specifications. The VREF1 pin must be left unloaded in this mode. The voltage reference source can be independently selected on devices with two DAC channels, but restrictions apply:

- The VDD mode can be used without issues on any channel.
- When the internal band gap is selected as the voltage source, all the VREF pins are connected to its output. The use of the Unbuffered mode is only possible on VREF0, because it’s the only one that can be loaded.
- When using the Internal Band Gap mode on Channel 0, Channel 1 must be put in Buffered External VREF mode or VDD Reference mode and the VREF1 pin must be left unloaded.

The resistance of the Resistor Ladder (RRL) is targeted to be 71 kΩ (±10%), which means a minimum resistance of 63.9 kΩ.

The band gap selection can be used across the VDD voltages while maximizing the VOUT voltage ranges. For VDD voltages below the Gain × VBG voltage, the output for the upper codes will be clipped to the VDD voltage. Table 5-1 shows the maximum DAC register code given device VDD and Gain bit setting.

5.3 Output Buffer/VOUT Operation

The output driver buffers the Wiper Voltage (VW) of the resistor ladder.

The DAC output is buffered with a low-power, precision output amplifier with selectable gain. This amplifier provides a rail-to-rail output with low offset voltage and low noise. The amplifier’s output can drive the resistive and high-capacitive loads without oscillation. The amplifier provides a maximum load current, which is enough for most programmable voltage reference applications. Refer to Section 1.0 “Electrical Characteristics” for the specifications of the output amplifier.

Note: The load resistance must be kept higher than 2 kΩ to maintain stability of the analog output and have it meet electrical specifications.

Table 5-1: VOUT USING BAND GAP

<table>
<thead>
<tr>
<th>VDD</th>
<th>DAC Gain (Gain = 0x or 0x2)</th>
<th>Max DAC Code(1)</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>12-Bit</td>
<td>10-Bit</td>
<td>8-Bit</td>
</tr>
<tr>
<td>5.5</td>
<td>FFFF</td>
<td>3FFF</td>
<td>FFF</td>
</tr>
<tr>
<td>2</td>
<td>FFFF</td>
<td>3FFF</td>
<td>FFF</td>
</tr>
<tr>
<td>2.7</td>
<td>FFFF</td>
<td>3FFF</td>
<td>FFF</td>
</tr>
<tr>
<td>1.8</td>
<td>FFFF</td>
<td>3FFF</td>
<td>FFF</td>
</tr>
<tr>
<td></td>
<td>B Bh</td>
<td>2E Bh</td>
<td>Bh</td>
</tr>
</tbody>
</table>

Note: 1: Without the VOUT pin voltage being clipped. 2: Recommended to use the Gain = 1 setting. 3: When VBG = 1.214V typical.

5.3.1 PROGRAMMABLE GAIN

The amplifier’s gain is controlled by the Gain (G) Configuration bit (see Register 4-4) and the VRL reference selection (see Register 4-2).

The Gain options are:

a) Gain of 1, with either the VDD or VREF pin used as the reference voltage.
b) Gain of 2, only when the VREF pin or the internal band gap is used as the reference voltage. The VREF pin voltage should be limited to VDD/2. When the Reference Voltage Selection (VRL) is the device’s VDD voltage, the Gx bit is ignored and a gain of 1 is used.

Figure 5-5 shows a block diagram of the output driver circuit.

Figure 5-5: Output Driver Block Diagram.

Power-down logic also controls the output buffer operation (see Section 5.5 “Power-Down Operation” for additional information on power-down). In any of the three Power-Down modes, the output amplifier is powered down and its output becomes a high-impedance to the VOUT pin.
Table 5-2 shows the gain bit operation.

<table>
<thead>
<tr>
<th>Gain Bit</th>
<th>Gain</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>2</td>
<td>Limits $V_{RL}$ pin voltages relative to device $V_{DD}$ voltage.</td>
</tr>
</tbody>
</table>

The volatile G bit value can be modified by:
- POR Event
- BOR Event
- I$^2$C Write Commands
- I$^2$C General Call Reset Command

5.3.2 OUTPUT VOLTAGE

The Volatile DAC register values, along with the device's Configuration bits, control the analog $V_{OUT}$ voltage. The Volatile DAC register's value is unsigned binary. The formula for the output voltage is provided in Equation 5-2. Examples of Volatile DAC register values and the corresponding theoretical $V_{OUT}$ voltage for the MCP47CXBXX devices are shown in Table 5-6.

**EQUATION 5-2: CALCULATING OUTPUT VOLTAGE ($V_{OUT}$)**

$$V_{OUT} = \frac{V_{RL} \times DAC \text{ Register Value}}{\# \text{ Resistor in Resistor Ladder}} \times Gain$$

Where:

- # Resistors in R-Ladder = 4096 (MCP47CXB2X)
- 1024 (MCP47CXB1X)
- 256 (MCP47CXB0X)

When Gain = 2 ($V_{RL} = V_{REF}$), if $V_{REF} > V_{DD}/2$, the $V_{OUT}$ voltage is limited to $V_{DD}$. So if $V_{REF} = V_{DD}$, the $V_{OUT}$ voltage does not change for Volatile DAC register values mid-scale and greater, since the output amplifier is at full-scale output.

The following events update the DAC register value, and therefore, the analog Voltage Output ($V_{OUT}$):
- Power-on Reset
- Brown-out Reset
- I$^2$C write command (to Volatile registers) on the rising edge of the last write command bit
- I$^2$C General Call Reset command; the output is updated with default POR data or MTP values
- I$^2$C general call wake-up command; the output is updated with default POR data or MTP values

Next, the $V_{OUT}$ voltage starts driving to the new value after the event has occurred.

5.3.3 STEP VOLTAGE ($V_S$)

The step voltage depends on the device resolution and the calculated output voltage range. One LSb is defined as the ideal voltage difference between two successive codes. The step voltage can easily be calculated by using Equation 5-3 (the DAC register value is equal to ‘1’). Theoretical step voltages are shown in Table 5-3 for several $V_{REF}$ voltages.

**EQUATION 5-3: $V_S$ CALCULATION**

$$V_S = \frac{V_{RL}}{\# \text{ Resistor in Resistor Ladder}} \times Gain$$

Where:

- # Resistors in R-Ladder = 4096 (12-bit)
- 1024 (10-bit)
- 256 (8-bit)

**TABLE 5-3: THEORETICAL STEP VOLTAGE ($V_S$)**

<table>
<thead>
<tr>
<th>Step Voltage</th>
<th>$V_{REF}$</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>5.0</td>
</tr>
<tr>
<td>$V_S$</td>
<td>1.22 mV</td>
</tr>
<tr>
<td></td>
<td>4.88 mV</td>
</tr>
<tr>
<td></td>
<td>19.5 mV</td>
</tr>
</tbody>
</table>

**Note 1:** When Gain = 1x, $V_{FS} = V_{RL}$ and $V_{ZS} = 0V$. 

© 2018-2019 Microchip Technology Inc.  
DS20006089B-page 63
5.3.4 OUTPUT SLEW RATE

Figure 5-6 shows an example of the slew rate of the VOUT pin. The slew rate can be affected by the characteristics of the circuit connected to the VOUT pin.

\[
\text{Slew Rate} = \frac{|V_{\text{OUT}(B)} - V_{\text{OUT}(A)}|}{\Delta T}
\]

**FIGURE 5-6:** VOUT Pin Slew Rate.

5.3.4.1 Small Capacitive Load

With a small capacitive load, the output buffer’s current is not affected by the Capacitive Load (CL). But still, the VOUT pin’s voltage is not a step transition from one output value (DAC register value) to the next output value. The change of the VOUT voltage is limited by the output buffer’s characteristics, so the VOUT pin voltage will have a slope from the old voltage to the new voltage. This slope is fixed for the output buffer, and is referred to as the Buffer Slew Rate (SRBUF).

5.3.4.2 Large Capacitive Load

With a larger capacitive load, the slew rate is determined by two factors:
- The output buffer’s Short-Circuit Current (ISC)
- The VOUT pin’s external load

\( I_{\text{OUT}} \) cannot exceed the output buffer’s Short-Circuit Current (ISC), which fixes the output Buffer Slew Rate (SRBUF). The voltage on the Capacitive Load (CL), VCL, changes at a rate proportional to \( I_{\text{OUT}} \), which fixes a Capacitive Load Slew Rate (SRCL).

The VCL voltage slew rate is limited to the slower of the output buffer’s internally Set Slew Rate (SRBUF) and the Capacitive Load Slew Rate (SRCL).

5.3.5 DRIVING RESISTIVE AND CAPACITIVE LOADS

The VOUT pin can drive up to 100 pF of capacitive load in parallel with a 5 kΩ resistive load (to meet electrical specifications). VOUT drops slowly as the load resistance decreases about 3.5 kΩ. It is recommended to use a load with RL greater than 2 kΩ.

Refer to Section 2.0 “Typical Performance Curves” for a detailed VOUT vs. Resistive Load characterization graph.

Driving large capacitive loads can cause stability problems for voltage feedback output amplifiers. As the load capacitance increases, the feedback loop’s phase margin decreases and the closed-loop bandwidth is reduced. This produces gain peaking in the frequency response with overshoot and ringing in the step response. That is, since the VOUT pin’s voltage does not quickly follow the buffer’s input voltage (due to the large capacitive load), the output buffer will overshoot the desired target voltage. Once the driver detects this overshoot, it compensates by forcing it to a voltage below the target. This causes voltage ringing on the VOUT pin.

So, when driving large capacitive loads with the output buffer, a small Series Resistor (RISO) at the output (see Figure 5-7) improves the output buffer’s stability (feedback loop’s phase margin) by making the output load resistive at higher frequencies. The bandwidth will be generally lower than the bandwidth with no capacitive load.

**FIGURE 5-7:** Circuit to Stabilize Output Buffer for Large Capacitive Loads (CL).

The RISO resistor value for your circuit needs to be selected. The resulting frequency response peaking and step response overshoot for this RISO resistor value should be verified on the bench. Modify the RISO’s resistance value until the output characteristics meet your requirements.

A method to evaluate the system’s performance is to inject a step voltage on the VREF pin and observe the VOUT pin’s characteristics.

**Note:** Additional insight into circuit design for driving capacitive loads can be found in AN884, “Driving Capacitive Loads With Op Amps” (DS00884).
5.4 Latch Pin (LAT)

The Latch pin controls when the Volatile DAC register value is transferred to the DAC wiper. This is useful for applications that need to synchronize the wiper(s) updates to an external event, such as zero-crossing or updates to the other wipers on the device. The LAT pin is asynchronous to the serial interface operation.

When the LAT pin is high, transfers from the Volatile DAC register to the DAC wiper are inhibited. The Volatile DAC register value(s) can continue to be updated. When the LAT pin is low, the Volatile DAC register value is transferred to the DAC wiper.

**Note:** This allows both the Volatile DAC0 and DAC1 registers to be updated while the LAT pin is high, and to have outputs synchronously updated as the LAT pin is driven low.

Figure 5-8 shows the interaction of the LAT pin and the loading of the DAC Wiper x (from the Volatile DAC Register x). The transfers are level-driven. If the LAT pin is held low, the corresponding DAC wiper is updated as soon as the Volatile DAC register value is updated.

**FIGURE 5-8:** LAT and DAC Interaction.

The LAT pin allows the DAC wiper to be updated to an external event and to have multiple DAC channels/devices update at a common event. Since the DAC Wiper x is updated from the Volatile DAC Register x, all DACs that are associated with a given LAT pin can be updated synchronously.

If the application does not require synchronization, then this signal should be tied low.

**Case 1:** Zero-Crossing of Sine Wave to Update the Volatile DAC0 Register (using LAT pin)

---

**Case 2:** Fixed-Point Crossing of Sine Wave to Update the Volatile DAC0 Register (using LAT pin)

---

**Note:** Indicates where LAT pin pulses are active (Volatile DAC0 register updated)

**FIGURE 5-9:** Example Use of LAT Pin Operation.
5.5 Power-Down Operation

To allow the application to conserve power when DAC operation is not required, three Power-Down modes are available. On devices with multiple DACs, each DAC’s Power-Down mode is individually controllable. All Power-Down modes do the following:

- Turn off most of the DAC module’s internal circuits
- Op amp output becomes high-impedance to the VOUT pin
- Retain the value of the Volatile DAC register and Configuration bits

Depending on the selected Power-Down mode, the following will occur:

- VOUT pin is switched to one of the two resistive pull-downs:
  - 100 kΩ (typical)
  - 1 kΩ (typical)
- Op amp is powered down and the VOUT pin becomes high-impedance

The Power-Down Configuration bits (PD1:PD0) control the power-down operation (Table 5-4).

TABLE 5-4: POWER-DOWN BITS AND OUTPUT RESISTIVE LOAD

<table>
<thead>
<tr>
<th>PD1</th>
<th>PD0</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Normal operation</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1 kΩ resistor to ground</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>100 kΩ resistor to ground</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Open circuit</td>
</tr>
</tbody>
</table>

There is a delay (T_PDD) between the PD1:PD0 bits changing from ‘00’ to either ‘01’, ‘10’ or ‘11’ and the op amp no longer driving the VOUT output, and the pull-down resistors’ sinking current.

In any of the Power-Down modes, where the VOUT pin is not externally connected (sinking or sourcing current), as the number of DACs increases, the device’s power-down current will also increase.

Table 5-5 shows the current sources for the DAC based on the selected source of the DAC’s reference voltage and if the device is in normal operating mode or one of the Power-Down modes.

TABLE 5-5: DAC CURRENT SOURCES

<table>
<thead>
<tr>
<th>Device VDD Current Source</th>
<th>PDxB:xA = 00, VREFxB:xA = 11</th>
<th>PDxB:xA = 00, VREFxB:xA = 00</th>
</tr>
</thead>
<tbody>
<tr>
<td>Output Op Amp</td>
<td>Y Y Y Y</td>
<td>Y Y Y Y</td>
</tr>
<tr>
<td>Resistor Ladder</td>
<td>Y N Y</td>
<td>Y N N</td>
</tr>
<tr>
<td>VREF Selection Buffer</td>
<td>N Y N</td>
<td>N N N</td>
</tr>
<tr>
<td>Band Gap</td>
<td>N Y N</td>
<td>N Y N</td>
</tr>
</tbody>
</table>

Note 1: The current is sourced from the VREF pin, not the device VDD.

Note 2: If DAC0 and DAC1 are in one of the Power-Down modes, MTP write operations are not recommended.

The power-down bits are modified by using a write command to the Volatile Power-Down register, or a POR event, which transfers the Nonvolatile Power-Down register to the Volatile Power-Down register.

Section 7.0 “Device Commands” describes the I2C commands for writing the power-down bits. The commands that can update the volatile PD1:PD0 bits are:

- Write
- General Call Reset
- General Call Wake-up

Note 1: The I2C serial interface circuit is not affected by the Power-Down mode. This circuit remains active in order to receive any command that might come from the I2C Master device.

2: A General Call Reset will do the POR event sequence, except that the MTP shadow memory values will be transferred to the Volatile Memory registers.

5.5.1 EXITING POWER-DOWN

The following events change the PD1:PD0 bits to ‘00’, and therefore, exit the Power-Down mode. These are:

- Any I2C Write Command, where the PD1:PD0 bits are ‘00’
- I2C General Call Wake-up Command
- I2C General Call Reset Command

When the device exits Power-Down mode, the following occurs:

- Disabled internal circuits are turned on
- Resistor ladder is connected to the selected Reference Voltage (VRL)
- Selected pull-down resistor is disconnected
- The VOUT output is driven to the voltage represented by the Volatile DAC register’s value and Configuration bits

The DAC Wiper register and DAC wiper value may be different due to the DAC Wiper register being modified while the LAT pin was driven to (and remaining at) VIH.

The VOUT output signal requires time as these circuits are powered up and the output voltage is driven to the specified value, as determined by the Volatile DAC register and Configuration bits.

Note: Since the op amp and resistor ladder were powered off (0V), the op amp’s Input Voltage (V_W) can be considered as 0V. There is a delay (T_PDE) between the PD1:PD0 bits updating to ‘00’ and the op amp driving the VOUT output. The op amp’s settling time (from 0V) needs to be taken into account to ensure the VOUT voltage reflects the selected value.
<table>
<thead>
<tr>
<th>Device</th>
<th>Volatile DAC Register Value</th>
<th>VRL (1)</th>
<th>LSb Gain Selection (2)</th>
<th>VOUT (3)</th>
<th>VRL</th>
<th>( \mu V )</th>
<th>( V )</th>
</tr>
</thead>
<tbody>
<tr>
<td>MCP47CVB2X (12-bt)</td>
<td>1111 1111 1111</td>
<td>5.0V</td>
<td>1x</td>
<td>VRL * (4095/4096) + 1</td>
<td>4.998779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/4096</td>
<td>610.4</td>
<td>1x</td>
<td>2.499390</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (4095/4096) + 2</td>
<td>4.998779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/4096</td>
<td>610.4</td>
<td>1x</td>
<td>1.249390</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (4095/4096) + 2</td>
<td>2.498779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/4096</td>
<td>610.4</td>
<td>1x</td>
<td>0.624390</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (4095/4096) + 2</td>
<td>1.248779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0111 1111 1111</td>
<td>5.0V</td>
<td>1x</td>
<td>VRL * (1023/4096) + 1</td>
<td>2.498779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/4096</td>
<td>610.4</td>
<td>1x</td>
<td>2.498779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (1023/4096) + 2</td>
<td>1.248779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0011 1111 1111</td>
<td>5.0V</td>
<td>1x</td>
<td>VRL * (0/4096) + 1</td>
<td>2.498779</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/4096</td>
<td>610.4</td>
<td>1x</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (0/4096) + 2</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>0000 0000 0000</td>
<td>5.0V</td>
<td>1x</td>
<td>VRL * (0/1024) + 1</td>
<td>4.995117</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/1024</td>
<td>4,882.8</td>
<td>1x</td>
<td>2.497559</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (0/1024) + 2</td>
<td>1.247559</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/1024</td>
<td>4,882.8</td>
<td>1x</td>
<td>1.245117</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (0/1024) + 2</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/1024</td>
<td>4,882.8</td>
<td>1x</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (0/1024) + 2</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>01 1111 1111</td>
<td>5.0V</td>
<td>1x</td>
<td>VRL * (255/1024) + 1</td>
<td>4.995117</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/1024</td>
<td>4,882.8</td>
<td>1x</td>
<td>2.497559</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (255/1024) + 2</td>
<td>1.247559</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/1024</td>
<td>4,882.8</td>
<td>1x</td>
<td>1.245117</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (255/1024) + 2</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/1024</td>
<td>4,882.8</td>
<td>1x</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (255/1024) + 2</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>00 1111 1111</td>
<td>5.0V</td>
<td>1x</td>
<td>VRL * (63/256) + 1</td>
<td>4.980469</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/256</td>
<td>19,531.3</td>
<td>1x</td>
<td>2.490234</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (63/256) + 2</td>
<td>1.240234</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/256</td>
<td>19,531.3</td>
<td>1x</td>
<td>0.615234</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (63/256) + 2</td>
<td>1.230469</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>00 0000 0000</td>
<td>5.0V</td>
<td>1x</td>
<td>VRL * (0/256) + 1</td>
<td>4.980469</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/256</td>
<td>19,531.3</td>
<td>1x</td>
<td>2.490234</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (0/256) + 2</td>
<td>1.240234</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>2.5V</td>
<td>2.5V/256</td>
<td>19,531.3</td>
<td>1x</td>
<td>0</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>2x (2)</td>
<td>VRL * (0/256) + 2</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Note 1:** VRL is the resistor ladder’s reference voltage. It is independent of the VREF1:VREF0 selection.

**Note 2:** Gain selection of 2x (Gx = 1) requires the voltage reference source to come from the VREF pin (VREF1:VREF0 = 10 or 11) and requires VREF pin voltage (or VRL) \( \leq V_{DD}/2 \) or from the internal band gap (VREF1:VREF0 = 01).

**Note 3:** These theoretical calculations do not take into account the offset, gain and nonlinearity errors.
6.0 **I^2C SERIAL INTERFACE MODULE**

The MCP47CXBXX’s I^2C serial interface module supports the I^2C serial protocol specification. This I^2C interface is a two-wire interface (clock and data). Figure 6-1 shows a typical I^2C interface connection.

The I^2C specification only defines the field types, lengths, timings, etc., of a frame. The frame content defines the behavior of the device. The frame content (commands) for the MCP47CXBXX is defined in Section 7.0 “Device Commands”.

An overview of the I^2C protocol is available in Appendix B: “I^2C Serial Interface”.

### 6.1 Overview

This section discusses some of the specific characteristics of the MCP47CXBXX devices’ I^2C serial interface module. This is to assist in the development of your application.

The following sections discuss some of these device-specific characteristics.

- **Interface Pins (SCL and SDA)**
- **Communication Data Rates**
- **POR/BOR**
- **Device Memory Address**
- **General Call Commands**
- **Device I^2C Slave Addressing**
- **Slope Control**

#### 6.1.1 INTERFACE PINS (SCL AND SDA)

The MCP47CXBXX I^2C module SCL pin does not generate the serial clock since the device operates in Slave mode. Also, the MCP47CXBXX will not stretch the clock signal (SCL) since memory read access occurs fast enough.

The MCP47CXBXX I^2C module implements slope control on the SDA pin output driver.

### 6.2 Communication Data Rates

The I^2C interface specifies different communication bit rates. These are referred to as Standard, Fast or High-Speed modes. The MCP47CXBXX supports these three modes. The clock rates (bit rate) of these modes are:

- **Standard mode**: Up to 100 kHz (kbit/s)
- **Fast mode**: Up to 400 kHz (kbit/s)
- **High-Speed mode** (HS mode): Up to 3.4 MHz (Mbit/s)

A description on how to enter High-Speed mode is described in Section 6.8 “Slope Control”.

### 6.3 POR/BOR

On a POR/BOR event, the I^2C serial interface module state machine is reset, which includes forcing the device’s Memory Address Pointer to 00h.

### 6.4 Device Memory Address

The memory address is the 5-bit value that specifies the location in the device’s memory that the specified command will operate on.

On a POR/BOR event, the device’s Memory Address Pointer is forced to 00h.

The MCP47CXBXX retains the last received “Device Memory Address”. That is, the MCP47CXBXX does not “corrupt” the “device memory address” after Repeated Start or Stop conditions.

### 6.5 General Call Commands

The general call commands utilize the I^2C specification reserved general call command address and command codes. The MCP47CXBXX also implements a nonstandard general call command.

The general call commands are:

- **General Call Reset**
- **General Call Wake-up** (MCP47CXBXX defined)

The general call wake-up command will cause all the MCP47CXBXX devices to exit their power-down state.

### 6.6 Multi-Master Systems

The MCP47CXBXX is not a Master device (generates the interface clock), but it can be used in Multi-Master applications.
6.7 Device I2C Slave Addressing

The address byte is the first byte received following the Start (or Repeated Start) condition from the Master device (see Figure 6-2). For nonvolatile devices, the seven bits of the I2C Slave address are user-programmable. The default address is '110 0000'. If the address pins are present on the specific package, the lower two bits of the address are determined by the state of the A1 and A0 pins.

**Table 6-1** shows the four standard orderable I2C Slave addresses and their respective device order codes.

<table>
<thead>
<tr>
<th>Default 7-Bit I2C Address</th>
<th>Device Order Code(1)</th>
<th>Memory</th>
<th>Tape and Reel</th>
</tr>
</thead>
<tbody>
<tr>
<td>'1100000'</td>
<td>MCP47CXBXX-E/XX</td>
<td>Y</td>
<td>Y</td>
</tr>
<tr>
<td></td>
<td>MCP47CXBXXT-E/XX</td>
<td>Y</td>
<td>Y</td>
</tr>
</tbody>
</table>

Note 1: Nonvolatile devices’ I2C Slave address can be reprogrammed by the end user.

6.7.1 CUSTOM I2C SLAVE ADDRESS OPTIONS

Custom I2C Slave address options can be requested. Users can request the custom I2C Slave address via the Nonstandard Customer Authorization Request (NSCAR) process.

**Note:** Non-Recurring Engineering (NRE) charges and minimum ordering requirements for custom orders. Please contact Microchip sales for additional information.

A custom device will be assigned custom device marking.

6.8 Slope Control

The slope control on the SDA output is different between the Fast/Standard Speed and the High-Speed Clock modes of the interface.

6.9 Pulse Gobbler

The pulse gobbler on the SCL pin is automatically adjusted to suppress spikes <10 ns during HS mode.
6.10 Entering High-Speed (HS) Mode

The I^2C specification requires that a High-Speed mode device be ‘activated’ to operate in High-Speed (3.4 Mbit/s) mode. This is done by the Master sending a special address byte following the Start bit. This byte is referred to as the High-Speed Master Mode Code (HSMMC).

The device can now communicate at up to 3.4 Mbit/s on SDA and SCL lines. The device will switch out of the HS mode on the next Stop condition.

The Master code is sent as follows:
1. Start condition (S).
2. High-Speed Master Mode Code (’0000 1xxx’); the ‘xxx’ bits are unique to the High-Speed (HS) Master mode.
3. No Acknowledge (Ã).

After switching to High-Speed mode, the next transferred byte is the I^2C control byte, which specifies the device to communicate with and any number of data bytes plus Acknowledgments. The Master device can then either issue a Repeated Start bit to address a different device (at High-Speed mode) or a Stop bit to return to the bus Fast/Standard Speed mode. After the Stop bit, any other Master device (in a Multi-Master system) can arbitrate for the I^2C bus.

The MCP47CXBXX device does not Acknowledge the HS select byte. However, upon receiving this command, the device switches to HS mode.

See Figure 6-3 for an illustration of the HS mode command sequence.

For more information on the HS mode, or other I^2C modes, refer to the “NXP I^2C Specification”.

---

**FIGURE 6-3:** HS Mode Sequence.
7.0 DEVICE COMMANDS

The I²C protocol does not specify how commands are formatted, so this section specifies the MCP47CXBXX device’s I²C command formats and operation.

The commands can be grouped into the following categories:

- Write Commands (C1:C0 = 00)
- Read Commands (C1:C0 = 11)
- General Call Commands

The supported commands are shown in Table 7-1. These commands allow both single data or continuous data operation. Continuous data operation means that the I²C Master does not generate a Stop bit but repeats the required data/clocks. This allows faster updates since the overhead of the I²C control byte is removed. Table 7-1 also shows the required number of bit clocks for each command’s different mode of operation.

7.1 Write Commands

Write commands are used to transfer data to the desired memory location (from the Host controller). The modes are Single or Continuous. The Continuous mode format allows the fastest data update rate for the device’s memory locations.

See Section 7.5 “Write Command” for a full description of the write commands.

Note: The 8-bit data devices use the same format as 10-bit and 12-bit devices. This allows code migration compatibility at the cost of nine extra clock cycles per data byte transferred.

7.2 Read Commands

Read commands are used to transfer data from the desired memory location to the Host controller. The read command format writes two bytes (Control byte (R/W bit) = 0) and the read command byte (desired memory address and the read command). Then, a Restart condition is followed by a second control byte, but this control byte indicates an I²C read operation (R/W bit = 1). The Master will then supply 16 clocks so the specified address data are transferred. See Section 7.6 “Read Command” for full a description of the read commands.

Note: The 8-bit data devices use the same format as 10-bit and 12-bit devices. This allows code migration compatibility at the cost of nine extra clock cycles per data byte transferred.

Table 7-1: DEVICE COMMANDS – NUMBER OF CLOCKS

<table>
<thead>
<tr>
<th>Command</th>
<th>Code</th>
<th>Mode</th>
<th># of Bit Clocks (1)</th>
<th>Data Update Rate (8-bit/10-bit/12-bit) (Data Words/Second)</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>Write Command (4)</td>
<td>0 0</td>
<td>Single</td>
<td>38</td>
<td>2,632 10,526 89,474</td>
<td></td>
</tr>
<tr>
<td></td>
<td>0 0</td>
<td>Continuous</td>
<td>27n + 11</td>
<td>3,559 14,235 120,996</td>
<td>For ten data words</td>
</tr>
<tr>
<td>Read Command</td>
<td>1 1</td>
<td>Random</td>
<td>48</td>
<td>2,083 8,333 70,833</td>
<td></td>
</tr>
<tr>
<td></td>
<td>1 1</td>
<td>Continuous</td>
<td>18n + 11</td>
<td>4,762 19,048 161,905</td>
<td>For ten data words</td>
</tr>
<tr>
<td></td>
<td>1 1</td>
<td>Last Address</td>
<td>29</td>
<td>3,448 13,793 117,241</td>
<td></td>
</tr>
<tr>
<td>General Call Reset Command</td>
<td>—</td>
<td>Single</td>
<td>20</td>
<td>5,000 20,000 170,000</td>
<td>Note 2</td>
</tr>
<tr>
<td>General Call Wake-up Command</td>
<td>—</td>
<td>Single</td>
<td>20</td>
<td>5,000 20,000 170,000</td>
<td>Note 2</td>
</tr>
</tbody>
</table>

Note 1: “n” indicates the number of times the command operation is to be repeated.
Note 2: Determined by general call command byte after the I²C general call address.
Note 3: There is a minimal overhead to enter into 3.4 MHz mode.
Note 4: This command can be at either normal or high voltage. A high-voltage command requires the HVC pin to be at Vᵦᵦ, for the entire command, until the completion of the MTP cycle.
7.3 General Call Commands

The general call commands utilize the I^2C specification reserved general call command address and command codes. The General Call Reset command format is specified by the "NXP I^2C Specification". The general call wake-up command is a Microchip-defined format. I^2C devices Acknowledge the general call address command (0x00 in the first byte). The meaning of the general call address is always specified in the second byte. The I^2C specification does not allow '00000000' (00h) in the second byte. Also, the '00000100' and '00000110' functionality is defined by the "NXP I^2C Specification". Lastly, a data byte with a '1' in the LSb indicates a "Hardware General Call".

Please refer to the "NXP I^2C Specification" for more details on the general call specifications.

The MCP47CXBXX devices support the following I^2C general calls:
- General Call Reset
- General Call Wake-up

See Section 7.7.1 “General Call Reset” for a full description of the General Call Reset command and the general call wake-up command.

7.4 Aborting a Transmission

A Restart or Stop condition in an expected data bit position will abort the current command sequence, and if the command is a write, that data word will not be written to the MCP47CXBXX. Also, the I^2C state machine will be reset.

7.5 Write Command

The write command can be issued to both the volatile and nonvolatile memory locations. Write commands can also be structured as either single or continuous. The continuous format allows the fastest data update rate for the device's memory locations.

The format of the command is shown in Figure 7-1. The MCP47CXBXX generates the A\/~A bits. The format of the command is shown in Figure 7-1 (single) and Figure 7-3 (continuous); for example, ACK/NACK behavior (see Figure 7-2).

A write command to a volatile memory location changes that location after a properly formatted write command and the rising edge of the D00 bit (last data bit) clock has been detected.

A write command to a nonvolatile memory location will only start a write cycle after a properly formatted write command has been received and the Stop condition has occurred.

Note 1: Writes to volatile memory locations will be dependent on the state of their respective WiperLock Technology bits.

2: During device communication, if the device address/command combination is invalid or an unimplemented device address is specified, then the MCP47CX-BXX will NACK that byte. To reset the I^2C state machine, the I^2C communication must detect a Start bit.

3: Writes to volatile memory locations will be dependent on the state of their respective WiperLock Technology bits.

7.5.1 SINGLE WRITE TO VOLATILE MEMORY

For volatile memory locations, data are written to the MCP47CXBX after every data word transfer (16 bits) during the rising edge of the last data bit. If a Stop or Restart condition is generated during a data transfer (before the last data bit is received), the data will not be written to the MCP47CXBX. After the A bit, the Master can initiate the next sequence with a Stop or Restart condition. (See Figure 7-1 for the write sequence.)

Note: Writes to a Volatile DAC register will not transfer to the output register until the LAT (HVC) pin is transitioned to the \textit{V}_{IL} voltage.

7.5.2 SINGLE WRITE TO NONVOLATILE MEMORY (HVC PIN = \textit{V}_{IL} OR \textit{V}_{IH})

In normal user mode, the MTP memory address cannot be written. Writing to the MTP address space, while the HVC pin is not at \textit{V}_{IH}, will not have any effect; the command is Acknowledged but the memory is not modified.
7.5.3 SINGLE WRITE TO NONVOLATILE MEMORY (HVC PIN = \( V_{IH} \))

**Note:** Writes to MTP memory require the HVC pin at 7.5V. This is not the normal operating conditions of the device; it is designed for factory programming of configuration parameters.

The sequence to write to a single nonvolatile memory location is the same as a single write to volatile memory, with the exception that the MTP Write Cycle (\( t_{WC} \)) is started after a properly formatted command, including the Stop bit, is received. After the Stop condition occurs, the serial interface may immediately be re-enabled by initiating a Start condition.

The HVC pin must be at \( V_{IH} \) until the completion of the MTP Write Cycle (\( t_{WC} \)).

During an MTP write cycle, access to the volatile memory is allowed when using the appropriate command sequence. Commands that address nonvolatile memory are ignored until the MTP Write Cycle (\( t_{WC} \)) completes. This allows the Host controller to operate on the Volatile DAC registers.

Once a write command to a nonvolatile memory location has been received, no other commands should be received before the Stop condition occurs.

**Note:** If a Stop condition does not occur, then the NV Write does not occur and all following command(s) will have an error condition (A). A Start bit is required to reset the command state machine.

Writes to a NV memory location while an MTP write cycle is occurring will force an error condition (A). A Start bit is required to reset the command state machine.

Figure 7-1 shows the waveform for a single write.

![Waveform for a single write](image)

**FIGURE 7-1:** Write Random Address Command.

---

**Legend:**

- **S** I2C Start Bit
- **A** I2C ACK bit\(^{(1)}\)
- **\( \times \)** Reserved, should be Set to ‘0’
- **SA** I2C Slave Address
- **AD** Memory Address
- **D** Register Data (to be written)\(^{(2)}\)
- **P** I2C Stop Bit\(^{(3)}\)

**Note 1:** The Acknowledge bit is generated by the MCP47CXBXX.

**Note 2:** At the rising edge of the SCL signal for the last bit (D00) of the write command, the device updates the value of the specified device register. For DAC Output registers, the output voltage depends on the state of the LAT pin.

**Note 3:** This command sequence does not need to terminate (using the Stop bit) and the write command can be repeated (see continuous write format, Section 7.5.4 “Continuous Writes to Volatile Memory”).
7.5.4 CONTINUOUS WRITES TO VOLATILE MEMORY

A Continuous Write mode of operation is possible when writing to the device's Volatile Memory registers (see Table 7-2). This Continuous Write mode allows writes without a Stop or Restart condition, or repeated transmissions of the I²C control byte. Figure 7-3 shows the sequence for three continuous writes. The writes do not need to be to the same volatile memory address. The sequence ends with the Master sending a Stop or Restart condition.

7.5.5 CONTINUOUS WRITES TO NONVOLATILE MEMORY

If a continuous write is attempted on nonvolatile memory, the missing Stop condition will cause the command to be an error condition (A) on all following bytes. A Start bit is required to reset the command state machine.

Note: All bytes are ignored and not transferred to memory.

### TABLE 7-2: VOLATILE MEMORY ADDRESSES

<table>
<thead>
<tr>
<th>Address</th>
<th>Single Channel</th>
<th>Dual Channel</th>
</tr>
</thead>
<tbody>
<tr>
<td>00h</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>01h</td>
<td>No</td>
<td>Yes</td>
</tr>
<tr>
<td>08h</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>09h</td>
<td>Yes</td>
<td>Yes</td>
</tr>
<tr>
<td>0Ah</td>
<td>Yes</td>
<td>Yes</td>
</tr>
</tbody>
</table>

#### Write 1 Word Command

| Master | Slave Address | RW | Command | ACK | Data Byte | ACK | Data Byte | ACK | P |
|--------|---------------|----|---------|-----|-----------|-----|-----------|-----|
| S      | S A6 S A5 S A4 S A3 S A2 S A1 S A0 0 | | | | | | | |

**Example 1 (No Command Error)**

Master: MCP47CXBXX

I²C Bus: 

**Example 2 (Command Error)**

Master: MCP47CXBXX

I²C Bus: 

**Note:** Once a command error has occurred (Example 2), the MCP47CXBXX will NACK until a Start condition occurs.

**FIGURE 7-2:** I²C ACK/NACK Behavior (Write Command Example).
FIGURE 7-3: Continuous Write Commands (Volatile Memory Only).

Legend:

- **S**: I^2^C Start Bit
- **A**: I^2^C ACK Bit (1)
- **AD**: Memory Address
- **D**: Register Data (to be written)(2)
- **P**: I^2^C Stop Bit(3)
- **Reserved, should be Set to ‘0’**

**Note**:  
1: The Acknowledge bit is generated by the MCP47CXBXX.  
2: At the falling edge of the SCL pin for the write command ACK bit, the MCP47CXBXX device updates the value of the specified device register.  
3: This command sequence does not need to terminate (using the Stop bit) and the write command can be repeated (see continuous write format, **Section 7.5.4 “Continuous Writes to Volatile Memory”**).  
4: Only functions when writing to Volatile registers (AD4:AD0 = 00h through 0Ah).
7.6 Read Command

Read commands are used to transfer data from the specified memory location to the Host controller.

The read command can be issued to both the volatile and nonvolatile memory locations. During an MTP memory write cycle, the read command can only read the volatile memory locations. By reading the Status Register (0Ah), the Host controller can determine when the Write Cycle (t_{wc}) has been completed (via the state of the MTPMA bit).

The read command formats include:

- **Single Read**
  - Single Memory Address
  - Last Memory Address Accessed
- **Continuous Reads**

The MCP47CXBXX retains the last received device memory address. This means the MCP47CXBXX does not corrupt the device memory address after Repeated Start or Stop conditions.

### 7.6.1 SINGLE READ

The read command format writes two bytes, the control byte and the read command byte (desired memory address and the read command), and then has a Restart condition. Then, a second control byte is transmitted, but this control byte indicates an I\(^2\)C read operation (R/W bit = 1).

#### 7.6.1.1 Single Memory Address

Figure 7-4 shows the sequence for reading a specified memory address.

#### 7.6.1.2 Last Memory Address Accessed

This is useful for checking the status of the MTPMA bit or when writes to other I\(^2\)C devices on the bus must occur between these memory reads. The Master must send a Stop or Restart condition after the data word is sent from the Slave. Figure 7-5 shows the waveforms for a single read of the last memory location accessed.

### 7.6.2 CONTINUOUS READS

Continuous reads allow the device’s memory to be read quickly and are valid for all memory locations. Figure 7-7 shows the sequence for three continuous reads.

For continuous reads, instead of transmitting a Stop or Restart condition after the data transfer, the Master continually reads the data byte. The sequence ends with the Master Not Acknowledging and then sending a Stop or Restart.

### 7.6.3 IGNORING AN I\(^2\)C TRANSMISSION AND “FALLING OFF” THE BUS

The MCP47CXBXX expects to receive complete, valid I\(^2\)C commands and will assume any command not defined as a valid command is due to a bus corruption, thus entering a passive high condition on the SDA signal. All signals will be ignored until the next valid Start condition and control byte are received.

---

**Note 1:** During device communication, if the device address/command combination is invalid or an unimplemented address is specified, the MCP47CXBXX will NACK that byte. To reset the I\(^2\)C state machine, the I\(^2\)C communication must detect a Start bit.

2: If the LAT pin is high (V_{IH}), reads of the Volatile DAC register return the current output value, not the internal register value.

3: The read commands operate the same regardless of the state of the High-Voltage Command (HVC) signal.

---

© 2018-2019 Microchip Technology Inc.
FIGURE 7-4:  Read Command – Single Memory Address.

Note 1: The Master device is responsible for the A/Ā signal. If an Ā signal occurs, the MCP47CXBXX will abort this transfer and release the bus.

2: This Acknowledge bit is generated by the Master device.

3: This command sequence does not need to terminate (using the Stop bit) and the read command can be repeated (see Section 7.6.2 “Continuous Reads”).

4: The Master device will Not Acknowledge and the MCP47CXBXX will release the bus so the Master device can generate a Stop or Repeated Start condition.

5: The MCP47CXBXX retains the last received “device memory address”.

6: The non-data bits of the Read Data Word will be output as ‘0’s:
   for 12-bit devices, bits D15:D12 are ‘0’s
   for 10-bit devices, bits D15:D10 are ‘0’s
   for 8-bit devices, bits D15:D8 are ‘0’s
FIGURE 7-5: Read Command – Last Memory Address Accessed.

Note 1: The Master device is responsible for the A/Ā signal. If an Ā signal occurs, the MCP47CXBXX will abort this transfer and release the bus.

2: This Acknowledge bit is generated by the Master device.

3: This command sequence does not need to terminate (using the Stop bit) and the read command can be repeated (see Section 7.6.2 “Continuous Reads”).

4: The Master device will Not Acknowledge and the MCP47CXBXX will release the bus so the Master device can generate a Stop or Repeated Start condition.

5: The MCP47CXBXX retains the last received “Device Memory Address”.

6: The non-data bits of the Read Data Word will be output as ‘0’s:
   for 12-bit devices, bits D15:D12 are ‘0’s
   for 10-bit devices, bits D15:D10 are ‘0’s
   for 8-bit devices, bits D15:D08 are ‘0’s

7: If the last device address written (via the read or write command) is invalid for a read, then the read last memory address command will NACK due to the invalid device memory address.
### FIGURE 7-6:  I²C ACK/NACK Behavior (Read Command Example)

#### Read 1 Word Command

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>SA6</td>
<td>0</td>
<td>Rd</td>
<td>1</td>
</tr>
<tr>
<td>S</td>
<td>SA5</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>SA4</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>SA3</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>SA2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>SA1</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S</td>
<td>SA0</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### Example 1 (No Command Error)

**Master**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>11000000</td>
<td>0</td>
<td>10000111</td>
<td>x1</td>
</tr>
</tbody>
</table>

**MCP47CXBXX**

<table>
<thead>
<tr>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**I²C Bus**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>11000000</td>
<td>0</td>
<td>00000011</td>
<td>x0</td>
</tr>
</tbody>
</table>

**Master (Continued)**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>00001001</td>
<td>1</td>
<td>1111</td>
<td></td>
</tr>
</tbody>
</table>

**MCP47CXBXX (Continued)**

<table>
<thead>
<tr>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>dddddddd</td>
<td>0</td>
</tr>
</tbody>
</table>

**I²C Bus (Continued)**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>11000000</td>
<td>0</td>
<td>00000011</td>
<td>x0</td>
</tr>
</tbody>
</table>

**Example 2 (Command Error)**

**Master**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>11000000</td>
<td>0</td>
<td>10111100</td>
<td>x1</td>
</tr>
</tbody>
</table>

**MCP47CXBXX**

<table>
<thead>
<tr>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

**I²C Bus**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>11000000</td>
<td>0</td>
<td>10111100</td>
<td>x1</td>
</tr>
</tbody>
</table>

**Master (Continued)**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>11000000</td>
<td>1</td>
<td>1111</td>
<td></td>
</tr>
</tbody>
</table>

**MCP47CXBXX (Continued)**

<table>
<thead>
<tr>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>0???????</td>
<td>1</td>
</tr>
</tbody>
</table>

**I²C Bus (Continued)**

<table>
<thead>
<tr>
<th>Slave Address</th>
<th>Command</th>
<th>ACK</th>
<th>Data Byte</th>
<th>ACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>S</td>
<td>11000000</td>
<td>0</td>
<td>10???????</td>
<td>1</td>
</tr>
</tbody>
</table>

**Note 1:** Once a command error has occurred (Example 2), the MCP47CXBXX will NACK until a Start condition occurs.

**Note 2:** For command error case (Example 2), the data read is from the register of the last valid address loaded into the device.
FIGURE 7-7: Continuous Read Command of Specified Address.

Note 1: The Master device is responsible for the A/\text{\AA} signal. If an \text{\AA} signal occurs, the MCP47CXBXX will abort this transfer and release the bus.

2: This Acknowledge bit is generated by the Master device.

3: This command sequence does not need to terminate (using the Stop bit) and the read command can be repeated (see Section 7.6.2 “Continuous Reads”).

4: The Master device will Not Acknowledge and the MCP47CXBXX will release the bus so the Master device can generate a Stop or Repeated Start condition.

5: The MCP47CXBXX retains the last received “Device Memory Address”.

6: The non-data bits of the Read Data Word will be output as ‘0’s:
   - for 12-bit devices, bits D15:D12 are ‘0’s
   - for 10-bit devices, bits D15:D10 are ‘0’s
   - for 8-bit devices, bits D15:D8 are ‘0’s
### 7.7 General Call Commands

The MCP47CXBXX Acknowledges the general call address command (00h in the first byte). General call commands can be used to communicate to all devices on the I^2^C bus (at the same time) that understand the general call command. The meaning of the general call address is always specified in the second byte (see Figure 7-8).

If the second byte has a ‘1’ in the LSb, the specification intends this to indicate a “Hardware General Call”. The MCP47CXBXX will ignore this byte and all following bytes (and A), until a Stop bit (P) is encountered.

The MCP47CXBXX devices support the following I^2^C general call commands:
- **General Call Reset (06h)**
- **General Call Wake-up (0Ah)**

The General Call Reset command format is specified by the I^2^C Specification. The general call wake-up command is a Microchip-defined format. The general call wake-up command will have all devices wake-up (that is, exit the Power-Down mode).

The other two I^2^C specification command codes (04h and 00h) are not supported, and therefore, those commands are NotAcknowledged.

If these 7-bit commands conflict with other I^2^C devices on the bus, the user will need two I^2^C buses to ensure that the devices are on the correct bus for their desired application functionality.

---

**FIGURE 7-8:** General Call Formats.

---

**Table:**

<table>
<thead>
<tr>
<th>General Call Address</th>
<th>7-Bit Command</th>
</tr>
</thead>
<tbody>
<tr>
<td>S 0 0 0 0 0 0 0</td>
<td>A 0 0 0 0 x x x 0 A P</td>
</tr>
</tbody>
</table>

**Legend:**
- **S**: I^2^C Start Bit
- **A**: I^2^C ACK Bit\(^{(t)}\)
- **x x x** GC Command
- **P**: I^2^C Stop Bit\(^{(2,3)}\)

**Note 1:** The Acknowledge bit is generated by the MCP47CXBXX.

**Note 2:** This command sequence does not need to terminate (using the Stop bit) and the general call command can be repeated or another general call command can be sent. Only the first command will be accepted by the MCP47CXBXX.
7.7.1 GENERAL CALL RESET
The I²C General Call Reset command forces a reset event. This is similar to the Power-On Reset, except that the reset delay timer is not started. This command allows multiple devices to be reset synchronously.

The device performs General Call Reset if the second byte is '00000110' (06h). At the acknowledgment of this byte, the device will perform the following tasks:
- Internal reset similar to a POR. The contents of the MTP are loaded into the DAC registers
- Analog output (VOUT) is available after the POR sequence has been completed.

7.7.2 GENERAL CALL WAKE-UP
The I²C General Call Wake-Up command forces the device to exit from its Power-Down state (forces the PDxB:PDxA bits to '00'). This command allows multiple MCP47CXBXX devices to wake up synchronously.

The device performs General Call Wake-Up if the second byte (after the General Call Address) is '00001010' (0Ah). At the acknowledgment of this byte, the device will perform the following task:
- The device’s volatile power-down bits (PDxB:PDxA) are forced to '00'.

Note 1:  The Acknowledge bit is generated by the MCP47CXBXX.
2:  At the falling edge of the SCL pin for the General Call Reset command ACK bit, the MCP47CXBXX device is reset.
3:  This command sequence does not need to terminate (using the Stop bit) and the General Call Reset command can be repeated or the general call wake-up command can be sent. Only the first command will be accepted by the MCP47CXBXX.

FIGURE 7-9: General Call Reset Command.

FIGURE 7-10: General Call Wake-up Command.
8.0 TYPICAL APPLICATIONS

The MCP47CXBXX devices are general purpose, single/dual channel voltage output DACs for various applications where a precision operation with low power is needed.

Applications generally suited for the devices are:
- Set Point or Offset Trimming
- Sensor Calibration
- Portable Instrumentation (Battery-Powered)
- Motor Control

8.1 Connecting to the I^2C Bus Using Pull-up Resistors

The SCL and SDA pins of the MCP47CXBXX devices are open-drain configurations. These pins require a pull-up resistor, as shown in Figure 8-2.

The pull-up resistor values (R_1 and R_2) for SCL and SDA pins depend on the operating speed (standard, fast and high speed) and loading capacitance of the I^2C bus line. A higher value of the pull-up resistor consumes less power, but increases the signal transition time (higher RC time constant) on the bus line; therefore, it can limit the bus operating speed. The lower resistor value, on the other hand, consumes higher power, but allows higher operating speed. If the bus line has higher capacitance due to long metal traces or multiple device connections to the bus line, a smaller pull-up resistor is needed to compensate for the long RC time constant. The pull-up resistor is typically chosen between 1 kΩ and 10 kΩ ranges for Standard and Fast modes, and less than 1 kΩ for High-Speed mode.

8.1.1 DEVICE CONNECTION TEST

The user can test the presence of the device on the I^2C bus line using a simple I^2C command. This test can be achieved by checking an Acknowledge response from the device after sending a read or write command. Figure 8-1 shows an example with a read command. The steps are:

1. Set the R/W bit “High” in the device’s address byte.
2. Check the ACK bit of the address byte.
   If the device Acknowledges (ACK = 0) the command, then the device is connected; otherwise, it is not connected.
3. Send Stop bit.

![FIGURE 8-1: I^2C Bus Connection Test.](image-url)
8.2 Power Supply Considerations

The power source should be as clean as possible. The power supply to the device is also used for the DAC voltage reference internally if the internal $V_{DD}$ is selected as the resistor ladder’s reference voltage ($VRxB:VRxA = 00$).

Any noise induced on the $V_{DD}$ line can affect the DAC performance. Typical applications will require a bypass capacitor in order to filter out high-frequency noise on the $V_{DD}$ line. The noise can be induced onto the power supply’s traces or as a result of changes on the DAC output. The bypass capacitor helps to minimize the effect of these noise sources on signal integrity. Figure 8-2 shows an example of using two bypass capacitors (a 10 µF tantalum capacitor and a 0.1 µF ceramic capacitor) in parallel on the $V_{DD}$ line. These capacitors should be placed as close to the $V_{DD}$ pin as possible (within 4 mm). If the application circuit has separate digital and analog power supplies, the $V_{DD}$ and $V_{SS}$ pins of the device should reside on the analog plane.

FIGURE 8-2: Example Circuit.

$R_1$ and $R_2$ are I²C pull-up resistors:

- $R_1$ and $R_2$: 5 kΩ-10 kΩ for $f_{SCL} = 100$ kHz to 400 kHz
- ~700Ω for $f_{SCL} = 3.4$ MHz

$C_1$: 0.1 µF capacitor = Ceramic
$C_2$: 10 µF capacitor = Tantalum
$C_3$: ~0.1 µF = Optional to reduce noise in $V_{OUT}$ pin
$C_4$: 0.1 µF capacitor = Ceramic
$C_5$: 10 µF capacitor = Tantalum
$C_6$: 0.1 µF capacitor = Ceramic
8.3 Application Examples

The MCP47CXBXX devices are rail-to-rail output DACs designed to operate with a $V_{DD}$ range of 2.7V to 5.5V. The internal output amplifier is robust enough to drive common, small signal loads directly, thus eliminating the cost and size of the external buffers for most applications. The user can use the gain of 1 or 2 of the output op amp by setting the Configuration register bits. The internal $V_{DD}$ or an external reference can be used. There are various user options and easy-to-use features that make the devices suitable for various modern DAC applications.

Application examples include:
- Decreasing Output Step-Size
- Building a “Window” DAC
- Bipolar Operation
- Selectable Gain and Offset Bipolar Voltage Output
- Designing a Double Precision DAC
- Building Programmable Current Source
- Serial Interface Communication Times
- Software I$^2$C Interface Reset Sequence
- Power Supply Considerations
- Layout Considerations

8.3.1 DC SET POINT OR CALIBRATION

A common application for the devices is a digitally controlled set point and/or calibration of variable parameters, such as sensor offset or slope. For example, the MCP47CVB2X provides 4096 output steps. If the voltage reference is 4.096V (where $G_x = 0$), the LSb size is 1 mV. If a smaller output step-size is desired, a lower external voltage reference is needed.

8.3.1.1 Decreasing Output Step-Size

If the application is calibrating the bias voltage of a diode or transistor, a bias voltage range of 0.8V may be desired, with about 200 µV resolution per step. Two common methods to achieve small step-size are to use a lower $V_{REF}$ pin voltage or a voltage divider on the DAC’s output.

Using an external Voltage Reference ($V_{REF}$) is an option if the external reference is available with the desired output voltage range. However, when using a low-voltage reference voltage, occasionally the noise floor causes an SNR error that is intolerable. Using a voltage divider method is another option, and provides some advantages when external voltage reference needs to be very low, or when the desired output voltage is not available. In this case, a larger value reference voltage is used, while two resistors scale the output range down to the precise desired level.

Figure 8-3 illustrates this concept. A bypass capacitor on the output of the voltage divider plays a critical function in attenuating the output noise of the DAC and the induced noise from the environment.

Using an external Voltage Reference ($V_{REF}$) is an option if the external reference is available with the desired output voltage range. However, when using a low-voltage reference voltage, occasionally the noise floor causes an SNR error that is intolerable. Using a voltage divider method is another option, and provides some advantages when external voltage reference needs to be very low, or when the desired output voltage is not available. In this case, a larger value reference voltage is used, while two resistors scale the output range down to the precise desired level.

Figure 8-3 illustrates this concept. A bypass capacitor on the output of the voltage divider plays a critical function in attenuating the output noise of the DAC and the induced noise from the environment.

Using an external Voltage Reference ($V_{REF}$) is an option if the external reference is available with the desired output voltage range. However, when using a low-voltage reference voltage, occasionally the noise floor causes an SNR error that is intolerable. Using a voltage divider method is another option, and provides some advantages when external voltage reference needs to be very low, or when the desired output voltage is not available. In this case, a larger value reference voltage is used, while two resistors scale the output range down to the precise desired level.

Figure 8-3 illustrates this concept. A bypass capacitor on the output of the voltage divider plays a critical function in attenuating the output noise of the DAC and the induced noise from the environment.

Using an external Voltage Reference ($V_{REF}$) is an option if the external reference is available with the desired output voltage range. However, when using a low-voltage reference voltage, occasionally the noise floor causes an SNR error that is intolerable. Using a voltage divider method is another option, and provides some advantages when external voltage reference needs to be very low, or when the desired output voltage is not available. In this case, a larger value reference voltage is used, while two resistors scale the output range down to the precise desired level.

Figure 8-3 illustrates this concept. A bypass capacitor on the output of the voltage divider plays a critical function in attenuating the output noise of the DAC and the induced noise from the environment.

Using an external Voltage Reference ($V_{REF}$) is an option if the external reference is available with the desired output voltage range. However, when using a low-voltage reference voltage, occasionally the noise floor causes an SNR error that is intolerable. Using a voltage divider method is another option, and provides some advantages when external voltage reference needs to be very low, or when the desired output voltage is not available. In this case, a larger value reference voltage is used, while two resistors scale the output range down to the precise desired level.

Figure 8-3 illustrates this concept. A bypass capacitor on the output of the voltage divider plays a critical function in attenuating the output noise of the DAC and the induced noise from the environment.
8.3.1.2 Building a “Window” DAC

When calibrating a set point or threshold of a sensor, typically only a small portion of the DAC output range is utilized. If the LSb size is adequate enough to meet the application’s accuracy needs, the unused range is sacrificed without consequences. If greater accuracy is needed, then the output range will need to be reduced to increase the resolution around the desired threshold.

If the threshold is not near $V_{REF}$, $2 \cdot V_{REF}$ or $V_{SS}$, then creating a “window” around the threshold has several advantages. One simple method to create this “window” is to use a voltage divider network with a pull-up and pull-down resistor. Figure 8-4 and Figure 8-6 illustrate this concept.

![Figure 8-4: Single-Supply “Window” DAC.](image)

\[ EQUATION 8-2: \quad V_{OUT} \quad \text{AND} \quad V_{TRIP} \quad \text{CALCULATIONS} \]

\[
V_{OUT} = V_{REF} \cdot G \cdot \frac{\text{DAC Register Value}}{2^N}
\]

\[
V_{TRIP} = \frac{V_{OUT} \cdot R_{23} + V_{CC} \cdot R_1}{R_1 + R_{23}}
\]

Thevenin Equivalent

\[
\left\{ \begin{array}{l}
R_{23} = \frac{R_2 \cdot R_3}{R_2 + R_3} \\
V_{23} = \frac{(V_{CC} \cdot R_2) + (V_{CC} \cdot R_3)}{R_2 + R_3} \\
\end{array} \right.
\]

\[
V_{OUT} = V_{TRIP} \cdot \frac{R_{23}}{V_{23}}
\]

8.4 Bipolar Operation

Bipolar operation is achievable by utilizing an external operational amplifier. This configuration is desirable due to the wide variety and availability of op amps. This allows a general purpose DAC, with its cost and availability advantages, to meet almost any desired output voltage range, power and noise performance.

Figure 8-5 illustrates a simple bipolar voltage source configuration. $R_1$ and $R_2$ allow the gain to be selected, while $R_3$ and $R_4$ shift the DAC’s output to a selected offset. Note that $R_4$ can be tied to $V_{DD}$ instead of $V_{SS}$ if a higher offset is desired.

![Figure 8-5: Digitally Controlled Bipolar Voltage Source Example Circuit.](image)

\[ EQUATION 8-3: \quad V_{OUT}, V_{OA+} \quad \text{AND} \quad V_{O} \quad \text{CALCULATIONS} \]

\[
V_{OUT} = V_{REF} \cdot G \cdot \frac{\text{DAC Register Value}}{2^N}
\]

\[
V_{OA+} = \frac{V_{OUT} \cdot R_4}{R_3 + R_4}
\]

\[
V_{O} = V_{OA+} \cdot \left(1 + \frac{R_2}{R_1}\right) - V_{DD} \cdot \left(\frac{R_2}{R_1}\right)
\]
8.5 Selectable Gain and Offset Bipolar Voltage Output

In some applications, precision digital control of the output range is desirable. Figure 8-6 illustrates how to use the DAC devices to achieve this in a bipolar or single-supply application.

This circuit is typically used for linearizing a sensor whose slope and offset varies.

The equation to design a bipolar “window” DAC would be utilized if R3, R4 and R5 are populated.

8.5.1 BIPOLAR DAC EXAMPLE

An output step-size of 1 mV, with an output range of ±2.05V, is desired for a particular application.

Step 1: Calculate the range: +2.05V – (-2.05V) = 4.1V

Step 2: Calculate the resolution needed:
4.1V/1 mV = 4100
Since 2^12 = 4096, 12-bit resolution is desired

Step 3: The amplifier gain (R2/R1), multiplied by full-scale VOUT (4.096V), must be equal to the desired minimum output to achieve bipolar operation. Since any gain can be realized by choosing resistor values (R1 + R2), the VREF value must be selected first. If a VREF of 4.096V is used, solve for the amplifier’s gain by setting the DAC to 0, knowing that the output needs to be -2.05V.

The equation can be simplified to:

EQUATION 8-4:
\[
\frac{-R_2}{R_1} = \frac{-2.05}{4.096V} \Rightarrow \frac{R_2}{R_1} = \frac{1}{2}
\]

If R1 = 20 kΩ and R2 = 10 kΩ, the gain will be 0.5.

Step 4: Next, solve for R3 and R4 by setting the DAC to 4096, knowing that the output needs to be +2.05V.

EQUATION 8-5:
\[
\frac{R_4}{R_3 + R_4} = \frac{2.05V + (0.5 \cdot 4.096V)}{1.5 \cdot 4.096V} = \frac{2}{3}
\]

If R4 = 20 kΩ, then R3 = 10 kΩ.

FIGURE 8-6: Bipolar Voltage Source with Selectable Gain and Offset.

EQUATION 8-6: VOUT, VOA+ AND VO CALCULATIONS

\[
V_{OUT} = V_{REF} \cdot G \cdot \frac{DAC \ Register \ Value}{2^N}
\]

\[
V_{OA+} = \frac{V_{OUT} \cdot R_4 + V_{CC} \cdot R_3}{R_3 + R_4}
\]

\[
V_O = V_{OA+} \cdot \left(1 + \frac{R_2}{R_1}\right) - V_{IN} \cdot \left(\frac{R_2}{R_1}\right)
\]

Offset Adjust  Gain Adjust

EQUATION 8-7: BIPOLAR “WINDOW” DAC USING R4 AND R5

Thevenin Equivalent
\[
V_{45} = \frac{V_{CC} \cdot R_4 + V_{CC} \cdot R_5}{R_4 + R_5}
\]

\[
V_{IN+} = \frac{V_{OUT} \cdot R_4 + V_{45} \cdot R_3}{R_3 + R_{45}}
\]

\[
R_{45} = \frac{R_2 \cdot R_4}{R_4 + R_5}
\]

\[
V_O = V_{IN+} \left(1 + \frac{R_2}{R_1}\right) - V_{A+} \cdot \left(\frac{R_2}{R_1}\right)
\]

Offset Adjust  Gain Adjust
8.6 Designing a Double Precision DAC

Figure 8-7 shows an example design of a single-supply voltage output capable of up to 24-bit resolution. This requires two 12-bit DACs. This design is simply a voltage divider with a buffered output.

As an example, if a similar application to the one developed in Section 8.5.1 “Bipolar DAC Example” required a resolution of 1 µV instead of 1 mV, and a range of 0V to 4.1V, then 12-bit resolution would not be adequate.

**Step 1:** Calculate the resolution needed:

\[ \frac{4.1V}{1 \mu V} = 4.1 \times 10^6 \]

Since \( 2^{22} = 4.2 \times 10^6 \), a 22-bit resolution is desired. Since DNL = ±1.0 LSB, this design can be attempted with the 12-bit DAC.

**Step 2:** Since DAC1’s \( V_{OUT1} \) has a resolution of 1 mV, its output only needs to be “pulled” 1/1000 to meet the 1 µV target. Dividing \( V_{OUT0} \) by 1000 would allow the application to compensate for DAC1’s DNL error.

**Step 3:** If \( R_2 \) is 100Ω, then \( R_1 \) needs to be 100 kΩ.

**Step 4:** The resulting transfer function is shown in Equation 8-8.

![Figure 8-7: Simple Double Precision DAC Using MCP47CVBXX2.](image)

**Equation 8-8:** \( V_{OUT} \) Calculation

\[
V_{OUT} = \frac{V_{OUT0} \times R_2 + V_{OUT1} \times R_1}{R_1 + R_2}
\]

Where:

- \( V_{OUT0} = (V_{REF} \times Gx \times DAC0 \text{ Register Value})/4096 \)
- \( V_{OUT1} = (V_{REF} \times Gx \times DAC1 \text{ Register Value})/4096 \)
- \( Gx = \text{Selected Op Amp Gain} \)

8.7 Building Programmable Current Source

Figure 8-8 shows an example of building a programmable current source using a voltage follower. The current sensor resistor is used to convert the DAC voltage output into a digitally-selectable current source.

The smaller \( R_{SENSE} \) is, the less power is dissipated across it. However, this also reduces the resolution that the current can be controlled at.

![Figure 8-8: Digitally-Controlled Current Source.](image)

8.8 Serial Interface Communication Times

Table 7-1 shows the time/frequency of the supported operations of the I²C serial interface for the different serial interface operational frequencies. This, along with the \( V_{OUT} \) output performance (such as slew rate), would be used to determine your application’s Volatile DAC register update rate.
8.9 Software I²C Interface Reset Sequence

At times, it may become necessary to perform a Software Reset sequence to ensure the MCP47CXBXX device is in a correct and known I²C interface state. This technique only resets the I²C state machine.

This is useful if the MCP47CXBXX device powers up in an incorrect state (due to excessive bus noise, etc.), or if the Master device is reset during communication. Figure 8-9 shows the communication sequence to software reset the device.

<table>
<thead>
<tr>
<th>S</th>
<th>'1'</th>
<th>'1'</th>
<th>'1'</th>
<th>'1'</th>
<th>'1'</th>
<th>'1'</th>
<th>'1'</th>
<th>S</th>
<th>P</th>
</tr>
</thead>
<tbody>
<tr>
<td>Start Bit</td>
<td>Nine Bits of '1'</td>
<td>Start Bit</td>
<td>Stop Bit</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**FIGURE 8-9:** Software Reset Sequence Format.

The first Start bit will cause the device to reset from a state in which it is expecting to receive data from the Master device. In this mode, the device is monitoring the data bus in Receive mode and can detect if the Start bit forces an internal Reset.

The nine bits of ‘1’ are used to force a reset of those devices that could not be reset by the previous Start bit. This occurs only if the MCP47CXBXX is driving an A bit on the I²C bus or is in Output mode (from a read command) and is driving a data bit of ‘0’ onto the I²C bus. In both of these cases, the previous Start bit could not be generated due to the MCP47CXBXX holding the bus low. By sending out nine ‘1’ bits, it is ensured that the device will see an A bit (the Master device does not drive the I²C bus low to Acknowledge the data sent by the MCP47CXBXX), which also forces the MCP47CXBXX to reset.

The second Start bit is sent to address the rare possibility of an erroneous write. This could occur if the Master device was reset while sending a write command to the MCP47CXBXX, and then as the Master device returns to normal operation and issues a Start condition, while the MCP47CXBXX is issuing an Acknowledge. In this case, if the second Start bit is not sent (and the Stop bit was sent), the MCP47CXBXX could initiate a write cycle.

The Stop bit terminates the current I²C bus activity. The MCP47CXBXX waits to detect the next Start condition. This sequence does not affect any other I²C devices which may be on the bus, as they should disregard this as an invalid command.

8.10 Design Considerations

In the design of a system with the MCP47CXBXX devices, the following considerations should be taken into account:

- **Power Supply Considerations**
- **Layout Considerations**

8.10.1 POWER SUPPLY CONSIDERATIONS

The typical application requires a bypass capacitor in order to filter high-frequency noise, which can be induced onto the power supply’s traces. The bypass capacitor helps to minimize the effect of these noise sources on signal integrity. Figure 8-10 illustrates an appropriate bypass strategy.

In this example, the recommended bypass capacitor value is 0.1 µF. This capacitor should be placed as close (within 4 mm) to the device power pin (VDD) as possible.

The power source supplying these devices should be as clean as possible. If the application circuit has separate digital and analog power supplies, VDD and VSS should reside on the analog plane.

**FIGURE 8-10:** Typical Microcontroller Connections.
8.10.2 LAYOUT CONSIDERATIONS
Several layout considerations may be applicable to your application. These may include:

- Noise
- PCB Area Requirements

8.10.2.1 Noise
Inductively coupled AC transients and digital switching noise can degrade the input and output signal integrity, potentially masking the MCP47CXBXX device’s performance. Careful board layout minimizes these effects and increases the Signal-to-Noise Ratio (SNR). Multi-layer boards utilizing a low-inductance ground plane, isolated inputs, isolated outputs and proper decoupling are critical to achieving the performance that the silicon is capable of providing. Particularly harsh environments may require shielding of critical signals.

Separate digital and analog ground planes are recommended. In this case, the VSS pin and the ground pins of the VDD capacitors should be terminated to the analog ground plane.

| Note | Breadboards and wire-wrapped boards are not recommended. |

8.10.2.2 PCB Area Requirements
In some applications, PCB area is a criteria for device selection. Table 8-1 shows the typical package dimensions and area for the different package options.

### TABLE 8-1: PACKAGE FOOTPRINT(1)

<table>
<thead>
<tr>
<th>Pins</th>
<th>Package Type</th>
<th>Code</th>
<th>Dimensions (mm)</th>
<th>Area (mm²)</th>
</tr>
</thead>
<tbody>
<tr>
<td>10</td>
<td>MSOP</td>
<td>UN</td>
<td>3.00 4.90</td>
<td>14.70</td>
</tr>
<tr>
<td>10</td>
<td>DFN</td>
<td>MF</td>
<td>3.00 3.00</td>
<td>9.00</td>
</tr>
<tr>
<td>16</td>
<td>QFN</td>
<td>MG</td>
<td>3.00 3.00</td>
<td>9.00</td>
</tr>
</tbody>
</table>

**Note 1:** Does not include recommended land pattern dimensions. Dimensions are typical values.
9.0 DEVELOPMENT SUPPORT

Development support can be classified into two groups:

- Development Tools
- Technical Documentation

9.1 Development Tools

Several development tools are available to assist in your design and evaluation of the MCP47CXBXX devices. The currently available tools are shown in Table 9-1.

Figure 9-1 shows how the ADM00309 bond-out PCB can be populated to easily evaluate the MCP47CXBXX devices. Device evaluation can use the PICkit™ Serial Analyzer to control the DAC Output registers and state of the Configuration, Control and Status registers.

The ADM00309 boards may be purchased directly from the Microchip web site at www.microchip.com.

<table>
<thead>
<tr>
<th>Board Name</th>
<th>Part #</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>MSOP-8 and MSOP-10 Evaluation Board</td>
<td>ADM00309</td>
<td>The MSOP-8 and MSOP-10 Evaluation Board is a bond-out board that allows the system designer to quickly evaluate the operation of Microchip Technology’s devices in any of the following packages: • MSOP (8/10-pin) • DIP (10 pin)</td>
</tr>
</tbody>
</table>

Note 1: Supports the PICkit™ Serial Analyzer. See the User’s Guide for additional information and requirements.

9.2 Technical Documentation

Several additional technical documents are available to assist you in your design and development. These technical documents include Application Notes, Technical Briefs and Design Guides. Table 9-2 lists some of these documents.

<table>
<thead>
<tr>
<th>Application Note Number</th>
<th>Title</th>
<th>Literature #</th>
</tr>
</thead>
<tbody>
<tr>
<td>AN1326</td>
<td>Using the MCP4728 12-Bit DAC for LDMOS Amplifier Bias Control Applications</td>
<td>DS01326</td>
</tr>
<tr>
<td>—</td>
<td>Signal Chain Design Guide</td>
<td>DS21825</td>
</tr>
<tr>
<td>—</td>
<td>Analog Solutions for Automotive Applications Design Guide</td>
<td>DS01005</td>
</tr>
</tbody>
</table>
FIGURE 9-1: MCP47CXBXX Evaluation Board Circuit Using ADM00309.
10.0 PACKAGING INFORMATION

10.1 Package Marking Information

Legend:
- XX...X Customer-specific information
- Y Year code (last digit of calendar year)
- YY Year code (last 2 digits of calendar year)
- WWW Week code (week of January 1 is week '01')
- NNN Alphanumeric traceability code
- * Pb-free JEDEC designator for Matte Tin (Sn)

*This package is Pb-free. The Pb-free JEDEC designator (e3) can be found on the outer packaging for this package.

Note: In the event the full Microchip part number cannot be marked on one line, it will be carried over to the next line, thus limiting the number of available characters for customer-specific information.
Note: For MCP47CVB02, MCP47CVB12, MCP47CVB22, MCP47CMB02, MCP47CMB12 and MCP47CMB22 devices.
10-Lead Plastic Micro Small Outline Package (UN) [MSOP]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging
MCP47CXBXX

10-Lead Plastic Micro Small Outline Package (UN) [MSOP]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging

<table>
<thead>
<tr>
<th>Dimension</th>
<th>Units</th>
<th>MILLIMETERS</th>
<th>MIN</th>
<th>NOM</th>
<th>MAX</th>
</tr>
</thead>
<tbody>
<tr>
<td>Number of Pins</td>
<td>N</td>
<td>10</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Pitch</td>
<td>e</td>
<td>0.50 BSC</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Overall Height</td>
<td>A</td>
<td>-</td>
<td>-</td>
<td>1.10</td>
<td>1.10</td>
</tr>
<tr>
<td>Molded Package Thickness</td>
<td>A2</td>
<td>0.75</td>
<td>0.85</td>
<td>0.95</td>
<td></td>
</tr>
<tr>
<td>Standoff</td>
<td>A1</td>
<td>0.00</td>
<td>-</td>
<td>0.15</td>
<td></td>
</tr>
<tr>
<td>Overall Width</td>
<td>E</td>
<td>4.90 BSC</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Molded Package Width</td>
<td>E1</td>
<td>3.00 BSC</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Overall Length</td>
<td>D</td>
<td>3.00 BSC</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Foot Length</td>
<td>L</td>
<td>0.40</td>
<td>0.60</td>
<td>0.80</td>
<td></td>
</tr>
<tr>
<td>Footprint</td>
<td>L1</td>
<td>0.95 REF</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Foot Angle</td>
<td>( \varphi )</td>
<td>0°</td>
<td>-</td>
<td>8°</td>
<td></td>
</tr>
<tr>
<td>Lead Thickness</td>
<td>c</td>
<td>0.08</td>
<td>-</td>
<td>0.23</td>
<td></td>
</tr>
<tr>
<td>Lead Width</td>
<td>b</td>
<td>0.15</td>
<td>-</td>
<td>0.33</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Pin 1 visual index feature may vary, but must be located within the hatched area.
2. Dimensions D and E1 do not include mold flash or protrusions. Mold flash or protrusions shall not exceed 0.15mm per side.
3. Dimensioning and tolerancing per ASME Y14.5M.
   BSC: Basic Dimension. Theoretically exact value shown without tolerances.
   REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-021C Sheet 2 of 2
10-Lead Plastic Micro Small Outline Package (UN) [MSOP]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging

RECOMMENDED LAND PATTERN

<table>
<thead>
<tr>
<th>Units</th>
<th>DIMENSION LIMITS</th>
<th>MILLIMETERS</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>MIN</td>
<td>NOM</td>
<td>MAX</td>
<td></td>
</tr>
<tr>
<td>Contact Pitch</td>
<td>E</td>
<td>0.50 BSC</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Contact Pad Spacing</td>
<td>C</td>
<td>4.40</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Overall Width</td>
<td>Z</td>
<td>5.80</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Contact Pad Width (X10)</td>
<td>X1</td>
<td>0.30</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Contact Pad Length (X10)</td>
<td>Y1</td>
<td>1.40</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Distance Between Pads</td>
<td>G1</td>
<td>3.00</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Distance Between Pads</td>
<td>GX</td>
<td>0.20</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. Dimensioning and tolerancing per ASME Y14.5M
   BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2021A
10-Lead Plastic Dual Flat, No Lead Package (MF) - 3x3x0.9mm Body [DFN]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging
MCP47CXBXX

10-Lead Plastic Dual Flat, No Lead Package (MF) - 3x3x0.9mm Body [DFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging

<table>
<thead>
<tr>
<th>Units</th>
<th>MILLIMETERS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Dimension</td>
<td>MIN</td>
</tr>
<tr>
<td>Number of Pins</td>
<td>N</td>
</tr>
<tr>
<td>Pitch</td>
<td>e</td>
</tr>
<tr>
<td>Overall Height</td>
<td>A</td>
</tr>
<tr>
<td>Standoff</td>
<td>A1</td>
</tr>
<tr>
<td>Contact Thickness</td>
<td>A3</td>
</tr>
<tr>
<td>Overall Length</td>
<td>D</td>
</tr>
<tr>
<td>Exposed Pad Length</td>
<td>D2</td>
</tr>
<tr>
<td>Overall Width</td>
<td>E</td>
</tr>
<tr>
<td>Exposed Pad Width</td>
<td>E2</td>
</tr>
<tr>
<td>Contact Width</td>
<td>b</td>
</tr>
<tr>
<td>Contact Length</td>
<td>L</td>
</tr>
<tr>
<td>Contact-to-Exposed Pad</td>
<td>K</td>
</tr>
</tbody>
</table>

**Notes:**
1. Pin 1 visual index feature may vary, but must be located within the hatched area.
2. Package may have one or more exposed tie bars at ends.
3. Package is saw singulated.
4. Dimensioning and tolerancing per ASME Y14.5M.
   BSC: Basic Dimension. Theoretically exact value shown without tolerances.
   REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing No. C04-063C Sheet 2 of 2
10-Lead Plastic Dual Flat, No Lead Package (MF) - 3x3x0.9mm Body [DFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at [http://www.microchip.com/packaging](http://www.microchip.com/packaging)

RECOMMENDED LAND PATTERN

<table>
<thead>
<tr>
<th>Units</th>
<th>MILLIMETERS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Dimension</td>
<td>MIN</td>
</tr>
<tr>
<td>Contact Pitch</td>
<td>E</td>
</tr>
<tr>
<td>Optional Center Pad Width</td>
<td>W2</td>
</tr>
<tr>
<td>Optional Center Pad Length</td>
<td>T2</td>
</tr>
<tr>
<td>Contact Pad Spacing</td>
<td>C1</td>
</tr>
<tr>
<td>Contact Pad Width (X10)</td>
<td>X1</td>
</tr>
<tr>
<td>Contact Pad Length (X10)</td>
<td>Y1</td>
</tr>
<tr>
<td>Distance Between Pads</td>
<td>G</td>
</tr>
</tbody>
</table>

**Notes:**
1. Dimensioning and tolerancing per ASME Y14.5M
   BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2063B
16-Lead Plastic Quad Flat, No Lead Package (MG) - 3x3x0.9 mm Body [QFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging
16-Lead Plastic Quad Flat, No Lead Package (MG) - 3x3x0.9 mm Body [QFN]

**Note:** For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging

<table>
<thead>
<tr>
<th>Units</th>
<th>MILLIMETERS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Dimension Limits</td>
<td>MIN</td>
</tr>
<tr>
<td>Number of Pins</td>
<td>N</td>
</tr>
<tr>
<td>Pitch</td>
<td>e</td>
</tr>
<tr>
<td>Overall Height</td>
<td>A</td>
</tr>
<tr>
<td>Standoff</td>
<td>A1</td>
</tr>
<tr>
<td>Contact Thickness</td>
<td>A3</td>
</tr>
<tr>
<td>Overall Width</td>
<td>E</td>
</tr>
<tr>
<td>Exposed Pad Width</td>
<td>E2</td>
</tr>
<tr>
<td>Overall Length</td>
<td>D</td>
</tr>
<tr>
<td>Exposed Pad Length</td>
<td>D2</td>
</tr>
<tr>
<td>Contact Width</td>
<td>b</td>
</tr>
<tr>
<td>Contact Length</td>
<td>L</td>
</tr>
<tr>
<td>Contact-to-Exposed Pad</td>
<td>K</td>
</tr>
</tbody>
</table>

**Notes:**
1. Pin 1 visual index feature may vary, but must be located within the hatched area.
2. Package is saw singulated.
3. Dimensioning and tolerancing per ASME Y14.5M.
   - BSC: Basic Dimension. Theoretically exact value shown without tolerances.
   - REF: Reference Dimension, usually without tolerance, for information purposes only.

Microchip Technology Drawing C04-142A Sheet 2 of 2
16-Lead Plastic Quad Flat, No Lead Package (MG) – 3x3x0.9 mm Body [QFN]

Note: For the most current package drawings, please see the Microchip Packaging Specification located at http://www.microchip.com/packaging

![Recommended Land Pattern Diagram]

<table>
<thead>
<tr>
<th>Units</th>
<th>MILLIMETERS</th>
</tr>
</thead>
<tbody>
<tr>
<td>Dimension Limit</td>
<td>MIN</td>
</tr>
<tr>
<td>Contact Pitch E</td>
<td>0.50 BSC</td>
</tr>
<tr>
<td>Optional Center Pad Width W2</td>
<td></td>
</tr>
<tr>
<td>Optional Center Pad Length T2</td>
<td></td>
</tr>
<tr>
<td>Contact Pad Spacing C1</td>
<td>2.90</td>
</tr>
<tr>
<td>Contact Pad Spacing C2</td>
<td>2.90</td>
</tr>
<tr>
<td>Contact Pad Width (X16) X1</td>
<td></td>
</tr>
<tr>
<td>Contact Pad Length (X16) Y1</td>
<td></td>
</tr>
<tr>
<td>Distance Between Pads G</td>
<td>0.20</td>
</tr>
</tbody>
</table>

Notes:
1. Dimensioning and tolerancing per ASME Y14.5M
   BSC: Basic Dimension. Theoretically exact value shown without tolerances.

Microchip Technology Drawing No. C04-2142A
APPENDIX A: REVISION HISTORY

Revision B (June 2019)

• Corrected the Internal Band Gap voltage throughout the document.
• Updated the Block Diagrams.
• Updated DC Characteristics table.
• Added Section 1.1.2, Latch Pin (LAT) Timing.
• Updated Figure 1-3, Figure 1-4 and Figure 4-1.
• Updated Table 1-3, Table 1-5, Table 3-2 and Table 4-1.
• Updated Section 3.5 “Latch/High-Voltage Command Pin (LAT/HVC)”.
• Updated Section 4.2.2 “Nonvolatile Register Memory (MTP)”.
• Updated Section 5.2.3 “Using an External \( V_{REF} \) Source in Buffered Mode”.
• Updated Section 5.3.2 “Output Voltage”.
• Various typographical edits.

Revision A (September 2018)

• Original release of this document.
APPENDIX B: I²C SERIAL INTERFACE

This I²C is a two-wire interface that allows multiple devices to be connected to the two-wire bus. Figure B-1 shows a typical I²C interface connection.

**Typical I²C Interface Connections**

![Typical I²C Interface Connections](image)

**FIGURE B-1:** Typical I²C Interface.

### B.1 Overview

A device that sends data onto the bus is defined as a transmitter and a device receiving data is defined as a receiver. The bus has to be controlled by a Master device which generates the Serial Clock (SCL), controls the bus access and generates the Start and Stop conditions. Devices that do not generate a serial clock work as Slave devices. Both Master and Slave can operate as transmitter or receiver, but the Master device determines which mode is activated. Communication is initiated by the Master (microcontroller), which sends the Start bit followed by the Slave address byte. The first byte transmitted is always the Slave address byte, which contains the device code, the address bits and the R/W bit.

The I²C interface specifies different communication bit rates. These are referred to as Standard, Fast or High-Speed modes and the MCP47CXBXX supports these three modes. The clock rates (bit rate) of these modes are:

- **Standard mode:** Up to 100 kHz (kbit/s)
- **Fast mode:** Up to 400 kHz (kbit/s)
- **High-Speed mode (HS mode):** Up to 3.4 MHz (Mbit/s)

The I²C protocol supports two addressing modes:

- 7-Bit Slave Addressing
- 10-Bit Slave Addressing (allows more devices on the I²C bus)

Only 7-Bit Slave Addressing will be discussed in this section.

The I²C serial protocol allows multiple Master devices on the I²C bus. This is referred to as “Multi-Master”. For this, all Master devices must support Multi-Master operation. In this configuration, all Master devices monitor their communication. If they detect that they wish to transmit a bit that is a logic high, but is detected as a logic low (some other Master device driving), they “get off” the bus. That is, they stop their communication and continue to listen to determine if the communication is directed towards them.

The I²C serial protocol only defines the field types, field lengths, timings, etc., of a frame. The frame content defines the behavior of the device. For details on the frame content (commands/data), refer to Section 7.0, Device Commands.

The I²C serial protocol defines some commands, called “General Call Addressing”, which allow the Master device to communicate to all Slave devices on the I²C bus.

**Note:** Refer to the "NXP Specification #UM10204", Rev. 06, 4 April 2014 document for more details on the I²C specifications.
B.2 Signal Descriptions

The I2C interface uses two pins (signals). These are:
- SDA (Serial Data)
- SCL (Serial Clock)

B.2.1 SERIAL DATA (SDA)

The Serial Data (SDA) signal is the data signal of the device. The value on this pin is latched on the rising edge of the SCL signal when the signal is an input.

With the exception of the Start (Restart) and Stop conditions, the high or low state of the SDA pin can only change when the clock signal on the SCL pin is low. During the high period of the clock, the SDA pin’s value (high or low) must be stable. Changes in the SDA pin’s value while the SCL pin is high will be interpreted as a Start or a Stop condition.

B.2.2 SERIAL CLOCK (SCL)

The Serial Clock (SCL) signal is the clock signal of the device. The rising edge of the SCL signal latches the value on the SDA pin.

Depending on the Clock Rate mode, the interface will display different characteristics.

B.3 I2C Operation

B.3.1 I2C BIT STATES AND SEQUENCE

Figure B-8 shows the I2C transfer sequence, while Figure B-7 shows the bit definitions. The serial clock is generated by the Master. The following definitions are used for the bit states:
- Start Bit (S)
- Data Bit
- Acknowledge (A) Bit (driven low)/No Acknowledge (A) bit (not driven low)
- Repeated Start Bit (Sr)
- Stop Bit (P)

B.3.1.1 Start Bit

The Start bit (see Figure B-2) indicates the beginning of a data transfer sequence. The Start bit is defined as the SDA signal falling when the SCL signal is “high”.

B.3.1.2 Data Bit

The SDA signal may change state while the SCL signal is low. While the SCL signal is high, the SDA signal MUST be stable (see Figure B-3).

B.3.1.3 Acknowledge (A) Bit

The A bit (see Figure B-4) is typically a response from the receiving device to the transmitting device. Depending on the context of the transfer sequence, the A bit may indicate different things. Typically, the Slave device will supply an A response after the Start bit and eight “data” bits have been received. An A bit has the SDA signal low, while the A̅ bit has the SDA signal high.

<table>
<thead>
<tr>
<th>Event</th>
<th>Acknowledge Bit Response</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>General Call</td>
<td>A</td>
<td></td>
</tr>
<tr>
<td>Slave Address Valid</td>
<td>A</td>
<td></td>
</tr>
<tr>
<td>Slave Address Not Valid</td>
<td>A̅</td>
<td></td>
</tr>
<tr>
<td>Bus Collision</td>
<td>N/A</td>
<td>i2C module resets or is a &quot;Don't Care&quot; if the collision occurs on the Master’s “Start bit”</td>
</tr>
</tbody>
</table>

TABLE B-1: MCP47CXBXX A/Â RESPONSES
B.3.1.4 Repeated Start Bit

The Repeated Start bit (see Figure B-5) indicates the current Master device wishes to continue communicating with the current Slave device without releasing the I²C bus. The Repeated Start condition is the same as the Start condition, except that the Repeated Start bit follows a Start bit (with the Data bits + A bit) and not a Stop bit.

The Start bit is the beginning of a data transfer sequence and is defined as the SDA signal falling when the SCL signal is “high”.

**Note 1:** A bus collision during the Repeated Start condition occurs if:
- SDA is sampled low when SCL goes from low-to-high.
- SCL goes low before SDA is asserted low. This may indicate that another Master is attempting to transmit a data ‘1’.

**FIGURE B-5:** Repeated Start Condition Waveform.

B.3.1.5 Stop Bit

The Stop bit (see Figure B-6) indicates the end of the I²C data transfer sequence. The Stop bit is defined as the SDA signal rising when the SCL signal is “high”.

A Stop bit should reset the I²C interface of the Slave device.

**FIGURE B-6:** Stop Condition Receive or Transmit Mode.

B.3.2 CLOCK STRETCHING

“Clock Stretching” is something the receiving device can do, to allow additional time to “respond” to the “data” that has been received.

B.3.3 ABORTING A TRANSMISSION

If any part of the I²C transmission does not meet the command format, it is aborted. This can be intentionally accomplished with a Start or Stop condition. This is done so that noisy transmissions (usually an extra Start or Stop condition) are aborted before they corrupt the device.

**FIGURE B-7:** Typical 8-Bit I²C Waveform Format.

**FIGURE B-8:** I²C Data States and Bit Sequence.
B.3.4 SLOPE CONTROL
As the device transitions from High-Speed (HS) mode to Fast (FS) mode, the slope control parameter will change from the HS specification to the FS specification.

For FS and HS modes, the device has a spike suppression and a Schmitt Trigger at SDA and SCL inputs.

B.3.5 DEVICE ADDRESSING
The I²C Slave address control byte is the first byte received following the Start condition from the Master device. This byte has seven bits to specify the Slave address and the read/write control bit.

Figure B-9 shows the I²C Slave address byte format, which contains the seven address bits and a Read/Write (R/W) bit.

B.3.6 HS MODE
The I²C specification requires that a High-Speed mode device must be “activated” to operate in High-Speed (3.4 Mbit/s) mode. This is done by the Master sending a special address byte following the Start bit. This byte is referred to as the High-Speed Master Mode Code (HMMC).

The device can now communicate at up to 3.4 Mbit/s on SDA and SCL lines. The device will switch out of the HS mode on the next Stop condition.

The Master code is sent as follows:
1. Start condition (S).
2. High-Speed Master Mode Code ("0000 1xxx"); the ‘xxx’ bits are unique to the HS mode Master.
3. No Acknowledge (A).

After switching to HS mode, the next transferred byte is the I²C control byte, which specifies the device to communicate with, and any number of data bytes plus Acknowledgments. The Master device can then either issue a Repeated Start bit to address a different device (at high speed) or a Stop bit to return to fast/standard bus speed. After the Stop bit, any other Master device (in a Multi-Master system) can arbitrate for the I²C bus.

See Figure B-10 for an illustration of an HS mode command sequence.

For more information on the HS mode, or other I²C modes, refer to the “NXP I²C Specification”.

B.3.6.1 Slope Control
The slope control on the SDA output is different between the Fast/Standard Speed and the High-Speed Clock modes of the interface.

B.3.6.2 Pulse Gobbler
The pulse gobbler on the SCL pin is automatically adjusted to suppress spikes <10 ns during HS mode.

---

**FIGURE B-9:** I²C Slave Address Control Byte.

**FIGURE B-10:** HS Mode Sequence.
B.3.7 GENERAL CALL

The general call is a method the Master device can use to communicate with all other Slave devices. In a Multi-Master application, the other Master devices are operating in Slave mode. The general call address has two documented formats. These are shown in Figure B-11.

The I²C specification documents three 7-bit command bytes.

The I²C specification does not allow ‘00000000’ (00h) in the second byte. Also, the ‘00000100’ and ‘00000110’ functionalities are defined by the specification. Lastly, a data byte with a ‘1’ in the LSb indicates a "Hardware General Call".

For details on the operation of the MCP47CXBXX device’s general call commands, see Section 7.3 “General Call Commands”.

Note: Only one general call command per issue of the general call control byte. Any additional general call commands are ignored and Not Acknowledged.

FIGURE B-11: General Call Formats.
APPENDIX C: TERMINOLOGY

C.1 Resolution

The resolution is the number of DAC output states that divide the Full-Scale Range (FSR). For the 12-bit DAC, the resolution is 2^12, meaning the DAC code ranges from 0 to 4095.

**Note:** When there are 2^N resistors in the resistor ladder and 2^N tap points, the full-scale DAC register code is the resistor element (1 LSB) from the source reference voltage (V_DD or V_REF).

C.2 Least Significant Bit (LSb)

This is the voltage difference between two successive codes. For a given output voltage range, it is divided by the resolution of the device (Equation C-1). The range may be V_DD (or V_REF) to V_SS (ideal); the DAC register codes across the linear range of the output driver (Measured 1) or full scale to zero scale (Measured 2).

**EQUATION C-1: LSb VOLTAGE CALCULATION**

**Ideal**

\[ V_{\text{LSB(Ideal)}} = \frac{V_{\text{DD}}}{2^N} \text{ or } \frac{V_{\text{REF}}}{2^N} \]

**Measured 1**

\[ V_{\text{LSB(Measured)}} = \frac{V_{\text{OUT}(4032)} - V_{\text{OUT}(64)}}{4032 - 64} \]

**Measured 2**

\[ V_{\text{LSB}} = \frac{V_{\text{OUT}(FS)} - V_{\text{OUT}(ZS)}}{2^N - 1} \]

2^N = 4096 (MCP47CVB2X)
    = 1024 (MCP47CVB1X)
    = 256 (MCP47CVB0X)

C.3 Monotonic Operation

The monotonic operation means that the device’s Output Voltage (V_OUT) increases with every one code step (LSb) increment (from V_SS to the DAC’s reference voltage (V_DD or V_REF)).

**FIGURE C-1: V_W (V_OUT)**

Voltage (V_W ≈ V_OUT)
C.4 Full-Scale Error (E_{FS})
The Full-Scale Error, E_{FS} (see Figure C-3), is the error on the V_{OUT} pin relative to the expected V_{OUT} voltage (theoretical) for the maximum device DAC register code (code FFFh for 12-bit, code 3FFh for 10-bit and code FFh for 8-bit); see Equation C-2. The error is dependent on the resistive load on the V_{OUT} pin (and where that load is tied to, such as V_{SS} or V_{DD}). For loads (to V_{SS}) greater than specified, the full-scale error will be greater.

The error in bits is determined by the theoretical voltage step-size to give an error in LSb.

EQUATION C-2: FULL-SCALE ERROR

\[ E_{FS} = \frac{V_{OUT(@FS)} - V_{IDEAL(@FS)}}{V_{LSb(Ideal)}} \]

Where:
E_{FS} is expressed in LSb.
V_{OUT(@FS)} is the V_{OUT} voltage when the DAC register code is at full scale.
V_{IDEAL(@FS)} is the ideal output voltage when the DAC register code is at full scale.
V_{LSb(Ideal)} is the theoretical voltage step-size.

C.5 Zero-Scale Error (E_{ZS})
The Zero-Scale Error, E_{ZS} (see Figure C-2), is the difference between the ideal and measured V_{OUT} voltage with the DAC register code equal to 000h (Equation C-3). The error is dependent on the resistive load on the V_{OUT} pin (and where that load is tied to, such as V_{SS} or V_{DD}). For loads (to V_{DD}) greater than specified, the zero-scale error is greater.

The error in bits is determined by the theoretical voltage step-size to give an error in LSb.

EQUATION C-3: ZERO-SCALE ERROR

\[ E_{ZS} = \frac{V_{OUT(@ZS)}}{V_{LSb(Ideal)}} \]

Where:
E_{ZS} is expressed in LSb.
V_{OUT(@ZS)} is the V_{OUT} voltage when the DAC register code is at zero scale.
V_{LSb(Ideal)} is the theoretical voltage step-size.

C.6 Total Unadjusted Error (E_T)
The Total Unadjusted Error (E_T) is the difference between the ideal and measured V_{OUT} voltage. Typically, calibration of the output voltage is implemented to improve the system’s performance.

The error in bits is determined by the theoretical voltage step-size to give an error in LSb. Equation C-4 shows the total unadjusted error calculation.

EQUATION C-4: TOTAL UNADJUSTED ERROR CALCULATION

\[ E_T = \frac{(V_{OUT(Acctual(@code))} - V_{OUT_Ideal(@code)})}{V_{LSb(Ideal)}} \]

Where:
E_T is expressed in LSb.
V_{OUT_Acctual(@code)} = The measured DAC output voltage at the specified code
V_{OUT_Ideal(@code)} = The calculated DAC output voltage at the specified code (code * V_{LSb(Ideal)})
V_{LSb(Ideal)} = V_{REF}/# Steps
12-bit = V_{REF}/4096
10-bit = V_{REF}/1024
8-bit = V_{REF}/256
C.7  Offset Error (E_{OS})

The Offset Error (E_{OS}) is the delta voltage of the V_{OUT} voltage from the ideal output voltage at the specified code. This code is specified where the output amplifier is in the linear operating range; for the MCP47CXBXX, we specify code 100 (decimal). Offset error does not include gain error, which is illustrated in Figure C-2.

This error is expressed in mV. Offset error can be negative or positive. The error can be calibrated by software in application circuits.

![Figure C-2: Offset Error (Zero Gain Error).](image)

C.8  Offset Error Drift (E_{OSD})

The Offset Error Drift (E_{OSD}) is the variation in offset error due to a change in ambient temperature. The offset error drift is typically expressed in ppm/°C or µV/°C.

C.9  Gain Error (E_{G})

Gain Error (E_{G}) is a calculation based on the ideal slope using the voltage boundaries for the linear range of the output driver (e.g., code 100 and code 4000); see Figure C-3). The gain error calculation nullifies the device’s offset error.

The gain error indicates how well the slope of the actual transfer function matches the slope of the ideal transfer function. The gain error is usually expressed as a percent of Full-Scale Range (% of FSR) or in LSb. FSR is the ideal full-scale voltage of the DAC (see Equation C-5).

![Figure C-3: Gain Error and Full-Scale Error Example.](image)

EQUATION C-5: GAIN ERROR EXAMPLE

\[
E_G = \left( \frac{V_{OUT}(\text{at 4032}) - V_{OS} - V_{OUT, Ideal(\text{at 4032})}}{V_{\text{Full-Scale Range}}} \right) \times 100
\]

Where:

- \(E_G\) is expressed in % of Full-Scale Range (FSR).
- \(V_{OUT(\text{at 4032})}\) = The measured DAC output voltage at the specified code
- \(V_{OUT, Ideal(\text{at 4032})}\) = The calculated DAC output voltage at the specified code (4032 * V_{LSb(Ideal)})
- \(V_{OS}\) = Measured offset voltage
- \(V_{\text{Full-Scale Range}}\) = Expected full-scale output value (such as the V_{REF} voltage)

C.10  Gain Error Drift (E_{GD})

The Gain Error Drift (E_{GD}) is the variation in gain error due to a change in ambient temperature. The gain error drift is typically expressed in ppm/°C (of Full-Scale Range).
C.11 Integral Nonlinearity (INL)

The Integral Nonlinearity (INL) error is the maximum deviation of an actual transfer function, from an ideal transfer function (straight line), passing through the defined end-points of the DAC transfer function (after Offset and Gain Errors have been removed).

For the MCP47CXBXX, INL is calculated using the defined end points, DAC code 64 and code 4032. INL can be expressed as a percentage of Full-Scale Range (FSR) or in LSb. INL is also called relative accuracy. Equation C-6 shows how to calculate the INL error in LSb and Figure C-4 shows an example of INL accuracy.

Positive INL means a $V_{OUT}$ voltage higher than the ideal one. Negative INL means a $V_{OUT}$ voltage lower than the ideal one.

EQUATION C-6: INL ERROR

$$E_{INL} = \frac{V_{OUT} - V_{Calc\_Ideal}}{V_{LSb\_Measured}}$$

Where:
- INL is expressed in LSb
- $V_{Calc\_Ideal} = Code \times V_{LSb\_Measured} + V_{OS}$
- $V_{OUT\_Code = n} = The\ measured\ DAC\ output\ voltage\ with\ a\ given\ DAC\ register\ code$
- $V_{LSb\_Measured} = For\ Measured:\ \frac{(V_{OUT\_4032} - V_{OUT\_64})}{3968}$
- $V_{OS} = Measured\ offset\ voltage$

FIGURE C-4: INL Accuracy.

C.12 Differential Nonlinearity (DNL)

The Differential Nonlinearity (DNL) error (see Figure C-5) is the measure of step-size between codes in an actual transfer function. The ideal step-size between codes is 1 LSb. A DNL error of zero would imply that every code is exactly 1 LSb wide. If the DNL error is less than 1 LSb, the DAC ensures monotonic output and no missing codes. Equation C-7 shows how to calculate the DNL error between any two adjacent codes in LSb.

EQUATION C-7: DNL ERROR

$$E_{DNL} = \frac{(V_{OUT\_Code = n+1} - V_{OUT\_Code = n})}{V_{LSb\_Measured}} - 1$$

Where:
- DNL is expressed in LSb.
- $V_{OUT\_Code = n} = The\ measured\ DAC\ output\ voltage\ with\ a\ given\ DAC\ register\ code$
- $V_{LSb\_Measured} = For\ Measured:\ \frac{(V_{OUT\_4032} - V_{OUT\_64})}{3968}$

FIGURE C-5: DNL Accuracy.
C.13 Settling Time
The settling time is the time delay required for the VOUT voltage to settle into its new output value. This time is measured from the start of code transition to when the VOUT voltage is within the specified accuracy.
For the MCP47CXBXX, the settling time is a measure of the time delay until the VOUT voltage reaches within 0.5 LSb of its final value, when the Volatile DAC register changes from 1/4 to 3/4 of the Full-Scale Range (12-bit device: 400h to C00h).

C.14 Major Code Transition Glitch
Major code transition glitch is the impulse energy injected into the DAC analog output when the code in the DAC register changes the state. It is normally specified as the area of the glitch in nV-Sec and is measured when the digital code is changed by 1 LSb at the major carry transition (Example: 011...111 to 100...000, or 100...000 to 011...111).

C.15 Digital Feedthrough
The digital feedthrough is the glitch that appears at the analog output caused by coupling from the digital input pins of the device. The area of the glitch is expressed in nV-Sec and is measured with a full-scale change (Example: all '0's to all '1's and vice versa) on the digital input pins. The digital feedthrough is measured when the DAC is not being written to the output register.

C.16 -3 dB Bandwidth
This is the frequency of the signal at the VREF pin that causes the voltage at the VOUT pin to fall to -3 dB from a static value on the VREF pin. The output decreases due to the RC characteristics of the resistor ladder and the characteristics of the output buffer.

C.17 Power Supply Sensitivity (PSS)
PSS indicates how the output of the DAC is affected by changes in the supply voltage. PSS is the ratio of the change in VOUT to a change in VDD for mid-scale output of the DAC. The VOUT is measured while the VDD is varied from 5.5V to 2.7V as a step (VREF voltage held constant), and expressed in %/%, which is the % change of the DAC output voltage with respect to the % change of the VDD voltage.

EQUATION C-8: PSS CALCULATION

\[
PSS = \frac{(V_{OUT}(@5.5V) - V_{OUT}(@2.7V)) \cdot V_{OUT}(@5.5V)}{(5.5V - 2.7V) \cdot V_{OUT}(@5.5V)}
\]

Where:
- PSS is expressed in %/%.
- \(V_{OUT}(@5.5V)\) = The measured DAC output voltage with \(V_{DD} = 5.5V\)
- \(V_{OUT}(@2.7V)\) = The measured DAC output voltage with \(V_{DD} = 2.7V\)

C.18 Power Supply Rejection Ratio (PSRR)
PSRR indicates how the output of the DAC is affected by changes in the supply voltage. PSRR is the ratio of the change in VOUT to a change in VDD for full-scale output of the DAC. The VOUT is measured while the VDD is varied ±10% (VREF voltage held constant) and expressed in dB or µV/V.

C.19 VOUT Temperature Coefficient
The VOUT temperature coefficient quantifies the error in the resistor ladder’s resistance ratio (DAC register code value) and output buffer due to temperature drift.

C.20 Absolute Temperature Coefficient
The absolute temperature coefficient quantifies the error in the end-to-end output voltage (nominal output voltage, VOUT) due to temperature drift. For a DAC, this error is typically not an issue due to the ratiometric aspect of the output.

C.21 Noise Spectral Density
The noise spectral density is a measurement of the device’s internally generated random noise and is characterized as a spectral density (voltage per √Hz). It is measured by loading the DAC to the mid-scale value and measuring the noise at the VOUT pin. It is measured in nV/√Hz.
### PRODUCT IDENTIFICATION SYSTEM

To order or obtain information, e.g., on pricing or delivery, refer to the factory or the listed sales office.

<table>
<thead>
<tr>
<th>PART NO.</th>
<th>X(1)</th>
<th>X</th>
<th>/XX</th>
</tr>
</thead>
<tbody>
<tr>
<td>Device</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Tape and Reel</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Temperature Range</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Package</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**Device:** MCP47CXBXX: 1 LSb INL Voltage Output Digital-to-Analog Converters with I2C Interface, 8/10/12-Bit Resolution, Single/Dual Outputs and Volatile/MTP Memory

**Tape and Reel:** T = Tape and Reel

**Temperature Range:**

- E = -40°C to +125°C (Extended)

**Package:**

- MF = Plastic Dual Flat, No Lead Package (DFN), 3x3x0.9 mm, 10-Lead
- MG = Plastic Quad Flat, No Lead Package (QFN), 3x3x0.9 mm, 16-Lead
- UN = Plastic Micro Small Outline Package (MSOP), 10-Lead

#### Examples:

<table>
<thead>
<tr>
<th>Device</th>
<th>Tape and Reel</th>
<th>Temperature Range</th>
<th>Package</th>
</tr>
</thead>
<tbody>
<tr>
<td>a) MCP47CVB01-E/MF:</td>
<td>1 LSb INL Voltage Output Digital-to-Analog Converter, 8-Bit Resolution, Extended Temperature, 10LD DFN, with Volatile Memory.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>b) MCP47CVB01T-E/MF:</td>
<td>1 LSb INL Voltage Output Digital-to-Analog Converter, 8-Bit Resolution, Tape and Reel, Extended Temperature, 10LD DFN, with Volatile Memory.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>a) MCP47CVB12-E/MG:</td>
<td>1 LSb INL Voltage Output Digital-to-Analog Converter, 10-Bit Resolution, Extended Temperature, 16LD QFN, with Volatile Memory.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>b) MCP47CVB12T-E/MG:</td>
<td>1 LSb INL Voltage Output Digital-to-Analog Converter, 10-Bit Resolution, Tape and Reel, Extended Temperature, 16LD QFN, with Volatile Memory.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>a) MCP47CMB21-E/UN:</td>
<td>1 LSb INL Voltage Output Digital-to-Analog Converter, 12-Bit Resolution, Extended Temperature, 10LD MSOP, with Nonvolatile Memory.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>b) MCP47CMB21T-E/UN:</td>
<td>1 LSb INL Voltage Output Digital-to-Analog Converter, 12-Bit Resolution, Tape and Reel, Extended Temperature, 10LD MSOP, with Nonvolatile Memory.</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

#### Note 1:

Tape and Reel identifier only appears in the catalog part number description. This identifier is used for ordering purposes and is not printed on the device package. Check with your Microchip Sales Office for package availability with the Tape and Reel option.
Note the following details of the code protection feature on Microchip devices:

- Microchip products meet the specification contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the intended manner and under normal conditions.
- There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip’s Data Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
- Microchip is willing to work with the customer who is concerned about the integrity of their code.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as “unbreakable.”

Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our products. Attempts to break Microchip’s code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding device applications and the like is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION, INCLUDING BUT NOT LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE, MERCHANTABILITY OR FITNESS FOR PURPOSE. Microchip disclaims all liability arising from this information and its use. Use of Microchip devices in life support and/or safety applications is entirely at the buyer’s risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

Trademarks

- APT, ClockWorks, The Embedded Control Solutions Company, EtherSynch, FlashTech, Hyper Speed Control, HyperLight Load, IntelliMOS, Libero, motorBench, mTouch, Powermate 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet-Wire, SmartFusion, SyncWorld, Temux, TimeCesium, TimeHub, TimePictra, TimeProvider, Vite, WinPath, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2018-2019, Microchip Technology Incorporated, All Rights Reserved.

ISBN: 978-1-5224-4636-1
## Worldwide Sales and Service

### AMERICAS
- **Corporate Office**
  - 2355 West Chandler Blvd.
  - Chandler, AZ 85224-6199
  - Tel: 480-792-7200
  - Fax: 480-792-7277
- Technical Support:
  - [http://www.microchip.com/support](http://www.microchip.com/support)
  - Web Address: [www.microchip.com](http://www.microchip.com)

### ASIA/PACIFIC
- **Australia - Sydney**
  - Tel: 61-2-9888-6733
- **China - Beijing**
  - Tel: 86-10-8569-7000
- **China - Chengdu**
  - Tel: 86-28-8665-5511
- **China - Chongqing**
  - Tel: 86-23-8980-9588
- **China - Dongguan**
  - Tel: 86-769-8702-9880
- **China - Guangzhou**
  - Tel: 86-20-8755-8029
- **China - Hangzhou**
  - Tel: 86-571-8792-8115
- **China - Hong Kong SAR**
  - Tel: 852-2943-5100
- **China - Nanjing**
  - Tel: 86-25-8473-2460
- **China - Qingdao**
  - Tel: 86-532-8502-7355
- **China - Shanghai**
  - Tel: 86-21-3326-8000
- **China - Shenyang**
  - Tel: 86-24-2334-2829
- **China - Shenzhen**
  - Tel: 86-755-9864-2200
- **China - Suzhou**
  - Tel: 86-186-6233-1526
- **China - Wuhan**
  - Tel: 86-27-5980-5300
- **China - Xian**
  - Tel: 86-29-8833-7252
- **China - Xiamen**
  - Tel: 86-592-2386138
- **China - Zhuhai**
  - Tel: 86-756-3210040
- **India - Bangalore**
  - Tel: 91-80-3090-4444
- **India - New Delhi**
  - Tel: 91-11-4160-8631
- **India - Pune**
  - Tel: 91-20-4121-0141
- **Japan - Osaka**
  - Tel: 81-6-6152-7160
- **Japan - Tokyo**
  - Tel: 81-3-6880-3770
- **Korea - Daegu**
  - Tel: 82-53-744-4301
- **Korea - Seoul**
  - Tel: 82-2-554-7200
- **Malaysia - Kuala Lumpur**
  - Tel: 60-3-7651-7906
- **Malaysia - Penang**
  - Tel: 60-4-227-8870
- **Philippines - Manila**
  - Tel: 63-2-634-9065
- **Singapore**
  - Tel: 65-6334-8870
- **Taiwan - Hsin Chu**
  - Tel: 886-3-577-8366
- **Taiwan - Kaohsiung**
  - Tel: 886-7-213-7830
- **Taiwan - Taipei**
  - Tel: 886-2-2508-8600
- **Thailand - Bangkok**
  - Tel: 66-2-694-1351
- **Vietnam - Ho Chi Minh**
  - Tel: 84-28-5448-2100

### EUROPE
- **Austria - Wels**
  - Tel: 43-7242-2244-39
  - Fax: 43-7242-2244-393
- **Denmark - Copenhagen**
  - Tel: 45-4450-2828
  - Fax: 45-4485-2829
- **Finland - Espoo**
  - Tel: 358-9-4520-820
- **France - Paris**
  - Tel: 33-1-69-53-63-20
  - Fax: 33-1-69-30-90-79
- **Germany - Garching**
  - Tel: 49-8931-9700
- **Germany - Haan**
  - Tel: 49-2129-3766400
- **Germany - Heilbronn**
  - Tel: 49-7131-72400
- **Germany - Karlsruhe**
  - Tel: 49-721-625370
- **Germany - Munich**
  - Tel: 49-89-627-144-0
  - Fax: 49-89-627-144-44
- **Germany - Rosenheim**
  - Tel: 49-8031-354-560
- **Israel - Ra’anana**
  - Tel: 972-9-744-7705
- **Italy - Milan**
  - Tel: 39-0331-742611
  - Fax: 39-0331-466781
- **Italy - Padova**
  - Tel: 39-049-7625286
- **Netherlands - Drunen**
  - Tel: 31-416-690399
  - Fax: 31-416-690340
- **Norway - Trondheim**
  - Tel: 47-7288-4388
- **Poland - Warsaw**
  - Tel: 48-22-3325737
- **Romania - Bucharest**
  - Tel: 40-21-407-87-50
- **Spain - Madrid**
  - Tel: 34-91-708-08-90
  - Fax: 34-91-708-08-91
- **Sweden - Gothenberg**
  - Tel: 46-31-704-60-40
- **Sweden - Stockholm**
  - Tel: 46-8-5090-4654
- **UK - Wokingham**
  - Tel: 44-118-921-5800
  - Fax: 44-118-921-5820

---

**Contact Information**

- **Atlanta**
  - Duluth, GA
  - Tel: 678-957-9614
  - Fax: 678-957-1455
- **Austin, TX**
  - Tel: 512-257-3370
- **Boston**
  - Westborough, MA
  - Tel: 774-760-0087
  - Fax: 774-760-0088
- **Chicago**
  - Itasca, IL
  - Tel: 630-285-0071
  - Fax: 630-285-0075
- **Dallas**
  - Addison, TX
  - Tel: 972-918-7423
  - Fax: 972-818-2924
- **Detroit**
  - Novi, MI
  - Tel: 248-848-4000
- **Houston, TX**
  - Tel: 281-894-5983
- **Indianapolis**
  - Noblesville, IN
  - Tel: 317-773-8323
  - Fax: 317-773-5453
  - Tel: 317-536-2380
- **Los Angeles**
  - Mission Viejo, CA
  - Tel: 949-462-9523
  - Fax: 949-462-9608
  - Tel: 951-273-7800
- **Raleigh, NC**
  - Tel: 919-844-7510
- **New York, NY**
  - Tel: 631-435-6000
- **San Jose, CA**
  - Tel: 408-735-9110
  - Tel: 408-436-4270
- **Canada - Toronto**
  - Tel: 905-695-1980
  - Fax: 905-695-2078