# EE 505 Lecture 12

### DAC Design

- DAC Architectures
- Sring DACs

**Review from last lecture** 

#### Random Offset Voltages

Typical offset voltages:

MOS - 5mV to 50MV BJT - 0.5mV to 5mV

These can be scaled with extreme device dimensions

Often more practical to include offset-compensation circuitry

#### Review from last lecture Summary of Offset Voltage Issues

- Random offset voltage is generally dominant and due to mismatch in device and model parameters
- MOS Devices have large V<sub>OS</sub> if area is small
- $\sigma$  decreases approximately with  $1/\sqrt{A}$
- Multiple fingers for MOS devices offer benefits for common centroid layouts but too many fingers will ultimately degrade offset because perimeter/area ration will increase (A<sub>W</sub> and A<sub>L</sub> will become of concern)
- Offset voltage of dynamic comparators is often large and analysis not straightforward
- Offset compensation often used when low offsets important MOS:  $\sigma_{V_{OS}}^2 \cong 2 \left[ \frac{A_{VTO\,n}^2}{W_n L_n} + \frac{\mu_p}{\mu_n} \frac{L_n}{W_n L_n^2} A_{VTO\,p}^2 \right]$

Bipolar: 
$$\sigma_{V_{OS}}^2 \cong 2V_t^2 \left[ \frac{A_{Jn}^2}{A_{En}} + \frac{A_{Jp}^2}{A_{Ep}} \right]$$

Types (Nyquist Rate)

- Voltage Scaling
  - Resistor String DACs (string DACs)
  - Interpolating
- Current Steering
  - Binary Weighted Resistors
  - R-2R Ladders
  - Current Source Steering
    - Thermometer Coded
    - Binary Weighted
    - Segmented
- Charge Redistribution
  - Switched Capacitor
- Serial
  - Algorithmic
  - Cyclic or Re-circulating
  - Pipelined
- Integrating
- Resistor Switching
- MDACs (multiplying DACs)

### Observations

- Yield Loss is the major penalty for not appropriately managing parasitics and matching and this loss can be ruthless
- The ultimate performance limit of essentially all DACs is the yield loss associated with parasitics and matching
- Many designers do not have or use good statistical models that accurately predict data converter performance
- If you work of a company that does not have good statistical device models
  - Convince model groups of the importance of developing these models
  - (or) develop appropriate test structures to characterize your process
- Existing nonlinear device models may not sufficiently accurately predict device nonlinearities for high-end data converter applications

Structures

- Hybrid or Segmented
- Mode of Operation
  - Current Mode
  - Voltage Mode
  - Charge Mode
- Self-Calibrating
  - Analog Calibration
    - Foreground
    - Background
  - Digital Calibration
    - Foreground
    - Background
  - Dynamic Element Matching
- Laser or Link Trimmed
- Thermometer Coded or Binary
- Radix 2 or non-radix 2
- Inherently Monotone

- Type of Classification may not be unique nor mutually exclusive
- Structure is not mutually exclusive
- All approaches listed are used (and probably some others as well)
- Some are much more popular than others
  - Popular Architectures
    - Resistor String (interpolating)
    - Current Source Steering (with segmentation)
    - Charge Redistribution
- Many new architectures are possible and some may be much better than the best currently available
- All have perfect performance if parasitic and matching performance are ignored !
- Major challenge is in determining appropriate architecture and managing the parasitics

#### Nonideal Effects of Concern

- Matching
- Parasitic Capacitances (including Charge injection)
- Loading
- Nonlinearities
- Interconnect resistors
- Noise
- Speed
- Jitter
- Temperature Effects
- Aging
- Package stress

#### **Observations**

- Experienced Designers/Companies often produce superior data converter products
- Essentially all companies have access to the same literature, regularly reverse engineer successful competitors products and key benefits in successful competitors products are generally not locked up in patents
- High-end designs( speed and resolution) may get attention in the peer community but practical moderate performance converters usually make the cash flow
- Area (from a silicon cost viewpoint) is usually not the driving factor in high-end designs where attractive price/mfg cost ratios are common
- Considerable ongoing demand for data converter designers particularly in ASICs where DAC optimized for specific application



 $X_{IN}$  is decoded to close one switch



**Basic R-String DAC including Logic to Control Switches** 



#### **Current Steering**





**Current Steering** 



#### Inherently Insensitive to Nonlinearities in Switches and Resistors

- Termed "top plate switching"
- Thermometer coded
- Based upon unary cell
- Speed limited by Op Amp and clock transients



Unary bit cell



**Current Steering** 



#### Inherently Insensitive to Nonlinearities in Switches and Resistors Smaller ON resistance and less phase-shift from clock edges

- Termed "bottom plate switching"
- Thermometer coded
- Based upon unary cell
- Speed limited by Op Amp





- Unary bit cells usually bundled to make resistors
- Same number of unary cells needed as for thermometer coded structure
- Need for decoder eliminated !
- DNL may be a major problem
- INL performance about same as thermometer coded if same unit resistors used
- Sizing and layout of switches is critical

Observe thermometer coding and binary weighted both offer some major advantages and some major limitations







By superposition:

$$V_{OUT} = V_{REF} d_3 \cdot \frac{1}{2} + V_{REF} d_2 \cdot \frac{1}{4} + V_{REF} d_1 \cdot \frac{1}{8} + V_{REF} d_0 \cdot \frac{1}{16} = V_{REF} \sum_{k=0}^{3} \frac{d_k}{2^{4-k}} = V_{REF} \sum_{k=1}^{4} \frac{d_{4-k}}{2^k} = V_{REF} \sum_{k=0}^{4} \frac{d_{4-k}}{2^k} =$$



**R-2R** Resistor Arrays



**Charge Redistribution** 





$$Q_{SET} = V_{REF} \sum_{i=0}^{n-1} d_i \frac{C}{2^{n-i}}$$
$$Q_{RDIS} = V_{OUT} \left( \sum_{i=0}^{n-1} C_i + \left[ C_0 \right] \right) = V_{OUT} \left( \sum_{i=0}^{n-1} \frac{C}{2^{n-i}} + \left[ \frac{C}{2^n} \right] \right) = V_{OUT} C$$

 $Q_{SET} = Q_{RDIS}$ 

$$V_{REF} \sum_{i=0}^{n-1} d_i \frac{C}{2^{n-i}} = V_{OUT}C$$
$$V_{OUT} = V_{REF} \sum_{i=0}^{n-1} \frac{d_i}{2^{n-i}}$$





#### **MDAC**



 $V_{\text{REF}}$  fixed or limited range

$$V_{OUT} = V_{REF} \bullet \left[ \vec{D}_{IN} \right]_{DECIMAL}$$



- Some define MDACs to be DAC structures that have current outputs
- Many DAC structures can perform well as a MDAC (possibly one quadrant)
- Performance of some DAC structures limited if  $V_{REF}$  is varied





#### Single Slope



Single-Slope DAC



#### **Dual Slope**





Conceptual

- Simple structure
- □ Inherently monotone
- Very low DNL
- Potential for being very fast
- □ Low Power Dissipation
- □ Widely Used Approach (with appropriate considerations)

#### Challenges:

- Managing INL
- Large number of devices for n large (2<sup>n</sup> or 2<sup>n+1</sup> lines)
- Decoder
- Routing thermometer/bubble clocks
- Transients during Boolean transitions
- Switch implementation
- Thevenin impedance facing V<sub>OUT</sub> highly code dependent



### Switch Implementation



Other switch structures (such as bootstrapped switch) used but not for basic string DACs

## Switch Assignment



Challenges:

### Switch Impedances





## **Switch Parasitics**



- $C_{BD}$  and  $C_{BS}$  can be significant and cause rise-fall times to be position dependent
- C<sub>GDOL</sub> can cause "kickback" or feed-forward
- C<sub>GS</sub> can slow turn-on and turn-off time of switch



Additional Challenges:

- Capacitance on V<sub>OUT</sub> can be large
  - larger for p-channel devices
  - even larger for TG switches
- Switch impedances position dependent
- Kickback from switches to R-string
- Capacitance on each node (though small) of Rstring from switch
- Thevenin impedance facing V<sub>OUT</sub> highly code dependent



#### Additional Challenges

- Delay in Decoder may be significant
- Delay in Decoder may be previous code and current code dependent
- Intermediate undesired Boolean outputs
  may occur
  - These may cause undesired opening and closing of switches
  - Could momentarily short out taps on R-string
  - Could introduce transients on all nodes of R-string that are code and previous code dependent



Capacitive loading due to switches



- Uses matrix decoder as analog MUX
- Implements binary to decimal conversion with pass transistor analog logic
- Very structured layout
- Interconnection points are switches (combination of n-channel and p-channel)

#### Challenges

- Still many signals to route
- Large capacitance on V<sub>OUT</sub> (over 2<sup>n+1</sup> diff caps)
- Multiple previous code dependencies cause output transition time to be quite unpredictable
- Considerable transients introduced on R-string



Parasitic Capacitances in Tree Decoder



#### **Previous-Code Dependent Settling**

Assume all C's initially with 0V Red denotes  $V_3$ , black denotes 0V, Purple some other voltage



#### **Previous-Code Dependent Settling**

Assume all C's initially with 0V

Red denotes  $V_3$ , green denotes  $V_6$ , black denotes 0V, Purple some other v



#### **Previous-Code Dependent Settling**

Assume all C's initially with 0V

Red denotes V<sub>3</sub>, green denotes V<sub>6</sub>, black denotes 0V, Purple some other voltage

### End of Lecture 12