# Constructive Placement and Routing for Common-Centroid Capacitor Arrays in Binary-Weighted and Split DACs 

Nibedita Karmokar, Arvind K. Sharma, Jitesh Poojary, Meghna Madhusudan, Ramesh Harjani, and Sachin S. Sapatnekar


#### Abstract

Process variations and the effect of interconnect parasitics can cause significant perturbations in the performance metrics of capacitive digital-to-analog converters (DACs). This paper develops fast constructive procedures for common-centroid placement and routing for binary-weighted and split capacitor array topologies of charge-sharing DACs. Our approach particularly targets FinFET technologies with high wire and via parasitics: in these technology nodes, we show that the switching speed of the capacitor array, as measured by the 3dB frequency, can be severely degraded by these parasitics, and develop techniques to place and route the capacitor array, for both binary-weighted and split DACs, to optimize the switching speed. A balance between 3dB frequency and DAC INL/DNL is shown by trading off via counts with dispersion. The approach delivers high-quality results with low runtimes.


## I. Introduction

Charge-scaling digital-to-analog converters (DACs) (Fig. 1(a)) are widely used in analog design, and their precision, accuracy and performance depend on building well-matched capacitor arrays with binary-weighted capacitor ratios [1], [2]. It is widely recognized that these ratios may be perturbed by systematic or random mismatch and designers have long used the common-centroid (CC) layout technique to cancel the impact of the linear systematic mismatch [3], [4]. This work considers the problem of CC layout for binary-weighted capacitor arrays for DACs, taking advantage of the problem structure to optimize DAC performance metrics. Several related works (e.g., [5], [6]) address CC layout in general, but do not leverage the specific properties of DACs. Among methods that specifically target DAC structures, many prior CC placement methods [6]-[8] ignore the impact of routing parasitics, which are critically important to DAC performance. Methods that do incorporate routing considerations [9]-[11] are based on computationally expensive stochastic search [1], [2], [9], [11]. In this paper, we develop a set of fast, constructive approaches to obtain routability-conscious performance-driven CC capacitor array layout for DACs, with a special emphasis on designing layouts for FinFET technology nodes.

One of the classical approaches for building a capacitive DAC uses a set of binary-weighted capacitors to provide the required capacitor ratios. For an $N$-bit DAC, the number of unit capacitors is $2^{N}$ : as a result, both the silicon area
and total capacitance of a binary-weighted DAC increases exponentially with $N$, causing power dissipation to rise exponentially with the number of bits [12] and resulting in larger settling times due to the large charging time constant required to charge/discharge the capacitors. These problems can be addressed by using a split DAC [13], [14], in which an additional attenuation capacitor is used to separate an $L$-bit LSB capacitor array from an $(N-L)$-bit MSB array in the schematic. This is depicted in Fig. 1(b), where the LSB, $D_{1}$, corresponds to the leftmost switch, and the MSB, $D_{N}$, to the rightmost switch. Let $C_{T}^{L S B}\left[C_{T}^{M S B}\right]$ is the total capacitance from the LSB [MSB] array. The value of the attenuation capacitor, $C_{A}$, is given by

$$
\begin{equation*}
C_{A}=\left(C_{T}^{L S B} / C_{T}^{M S B}\right) C_{u} \tag{1}
\end{equation*}
$$

This value is, in general, not an integer, and is typically not a multiple of the unit capacitor used to build the MSB and LSB capacitors. This may cause poor matching with other capacitors. To resolve this issue [15] proposed to use a unit bridge capacitor and removed the first capacitor from the LSBside array. However, this solution suffers from a 1 LSB gain error. For metal-insulator-metal (MIM) capacitors, it has been shown that the implementation of non-unit sized capacitors can be handled by maintaining their perimeter to area ratio [16].


Fig. 1: Schematic circuit of a charge-scaling (a) binary, and (b) split DAC with the $k^{\text {th }}$ bit set to 1 and all other bits set to 0 .

This work focuses on the layout in FinFET nodes, which
bring forth several new challenges as compared to older bulk technologies. Although bulk technologies are generally better for analog designs than FinFET nodes, the need for integrating analog and digital circuitry together in the same chip forces designers to build analog designs in FinFET nodes. These advanced technologies result in several significant challenges for the design of passive capacitor arrays. First, the per-unit wire/via resistances become higher as technology nodes scale down, and are particularly acute in FinFET nodes. Second, lithography rules dictate that wiring in a single layer must be in the same direction, implying that a change in routing direction invokes the significant resistive penalty of going through a via to another layer. Prior techniques that address older bulk technology nodes do not face these restrictions and cannot easily be adapted to FinFET designs. For example, the routing detours and bends in [17], [18] incur high resistance penalties in FinFET nodes. Third, analog design in FinFET nodes favors Metal-oxide-metal (MOM) capacitors with high capacitance density and low-resistance connections (going through few vias) to the device layer, but prior efforts primarily target MIM capacitors in the upper layers of the interconnect stack. The high cost of going through multiple vias to reach the MIM capacitor layer can cause significant RC-induced degradation on the 3 dB frequency at which the capacitor array can operate. Only a few efforts [10], [11] consider CC layout for MOM capacitors, and none address issues specific to FinFET nodes.

We summarize the chief results and novel aspects of this paper here. First, in contrast to prior iterative/stochastic layout generators for CC capacitor arrays, we build a fast, constructive approach for generating the array layout. Our constructive approaches present a new spiral CC layout that has very few bends, and thus low via counts, resulting in high 3 dB frequencies. We also apply our approach to existing chessboard methods, and we devise a new family of block chessboard placements that can achieve a balance between the dispersion advantages of chessboard layouts and the low via counts of spiral layouts. Second, we address the layout of CC capacitor arrays for both binary-weighted DACs and split DACs; to the best of our knowledge, split DACs have not been addressed in prior work. For the split DAC, we propose a method to determine the size of the non-unit capacitor which is used as the attenuation capacitor. Third, unlike prior work that has focused mainly on bulk technologies, our method specifically targets FinFET technologies, addressing the deleterious impact of high via resistances and per-unit wire resistances. Our capacitor array layouts are specifically designed to have few vias, particularly for the most significant bits, which determine the 3 dB frequency. Moreover, we reduce wire resistances on these connections through the use of parallel wires, which effectively result in the use of wider wires while obeying the FinFET technology requirements of allowing only quantized wire widths. Fourth, we explore the impact of using spiral, chessboard, and block chessboard methods on a variety of DACs and demonstrate the impact of parasitics on 3 dB frequency: in particular, we show that chessboard layouts are very constraining in FinFET technologies. Our spiral placement approach provides large improvements in 3 dB frequency over prior work, with some penalty in the INL/DNL, and our block
chessboard approaches explore intermediate design points by trading off 3 dB frequency with INL/DNL.

## II. Background

## A. Binary-weighted DACs

A digital input code is applied to the binary-weighted chargescaling DAC shown in Fig. 1(a) ${ }^{\text { }}$, which is typically used as part of charge-redistribution ADC. This is used to sample a fixed reference voltage, and the common terminal of the capacitor array is connected to a unity-gain amplifier in Fig. 1(a) to produce the analog output voltage; however, this requires a rail-to-rail input and output buffer. If the voltages are not rail-to-rail, as may happen in a stand-alone DAC, it is possible to compensate for the difference by appropriately amplifying the signal by using a switched-capacitor amplifier with programmable gain [16]. Since our focus is on the binaryweighted capacitor array, for convenience we consider the case when the capacitors are connected to a unity-gain amplifier. The black capacitors correspond to the intentionally inserted capacitances, while those shown in blue, purple, orange, and grey correspond to parasitic capacitances.


Fig. 2: Equivalent circuit of a charge-scaling DAC with the $k^{\text {th }}$ bit set to 1 and all other bits set to 0 .

For the ideal case, we assume that these parasitics are zero and consider only the capacitors shown in black. Let $D_{k}(i)$ be the $k^{t h}$ bit of code $i$; let $C_{T}$ and $C_{O N}(i)\left[C_{O F F}(i)\right]$ be the total capacitance and sum of capacitors whose bottom plates are connected to $V_{R E F}$ [ground] and $R_{k}$ is the parasitic resistance associated with the capacitor $C_{k}$. In a binaryweighted DAC, $C_{k}=n_{k} C_{u}$, where $n_{k}=1$ for $k=0$; $n_{k}=2^{k-1}$ for $k \geq 1$. Noting that $C_{0}=C_{u}$ is always grounded,

$$
\begin{aligned}
C_{T}(i) & =C_{u} \cdot\left(1+1+2+\cdots+2^{N-1}\right)=2^{N} C_{u} \\
C_{O N}(i) & =\sum_{k=1}^{N} D_{k}(i) 2^{k-1} C_{u} ; C_{O F F}(i)=\sum_{k=1}^{N} \bar{D}_{k}(i) 2^{k-1} C_{u}
\end{aligned}
$$

For perfect capacitor matching and an ideal opamp the output voltage can be represented as,
$V_{O U T}^{\text {ideal }}(i)=V_{R E F} \cdot \frac{C_{O N}(i)}{C_{T}}=V_{R E F} \cdot \sum_{k=1}^{N} D_{k}(i) 2^{(k-N-1)}$
Different routing parasitics are seen for capacitor $C_{i}$ in the CC array [19] as shown in Fig. 2: (1) top-plate to ground parasitic capacitance, $C_{i}^{T S}$, (2) top-plate-to-bottom-plate parasitic capacitance, $C_{i}^{T B}$, (3) the bottom plate capacitance $C_{i}^{B S}$ to ground, and (4) bottom [top] plate to bottom [top] plate $C_{i j}^{B B}\left[C_{i j}^{T T}\right]$. If the bottom plates [top plates] of two different capacitors are both at $V_{D D}$ or both at ground, $C_{i j}^{B B}\left[C_{i j}^{T T}\right]$ will be effectively zero, since it depends on the excitation.

However, for the binary-weighted DAC all the top plates of the capacitors have the same potential.

Depending on whether the bottom plate is switched to $V_{D D}$ or ground, the top-plate-to-bottom-plate parasitic capacitance $C_{i}^{T B}$ accumulates to $C_{O N}^{T B}$ or $C_{O F F}^{T B}$, respectively. The parasitics associated with $C^{T S}$ and $C^{T B}$ can alter $V_{O U T}^{i d e a l}$, as shown analytically in Section III-A. Increasing the minimum unit capacitance value $C_{u}$ can reduce these effects. However, it would increase the power consumption. Moreover, with the increase of $C_{u}$, the layout area also increases since in N -bit binary-weighted DAC most of the area is occupied by the $2^{N}$ unit capacitors. The parasitic capacitance associated with the bottom-plates, does not affect DAC linearity, but affects the load for $V_{R E F}$, and impact the power and 3 dB frequency. The impact of routing induced parasitics on 3 dB frequency is explained in Section III-C.

## B. Split DACs

The split DAC structure, shown in Fig. 1(b), contains two sets of switched capacitances, corresponding to the LSB array and the MSB array. The top plates of the capacitors in each array are connected together at two different electrical nodes that are separated by an attenuation capacitor, $C_{A}$. The LSB and MSB arrays each consist of binary-weighted capacitors. In the LSB array, like the binary-weighted DAC, we have $C_{k}=$ $n_{k} C_{u}$, where $n_{k}=1$ for $k=0 ; n_{k}=2^{k-1}$ for $k \geq 1$, and with $C_{0}$ kept permanently grounded. In the MSB array, $C_{k}=$ $n_{k} C_{u}$, but here, $n_{k}=2^{k-1-L}$ - i.e., successive capacitors in both the LSB and MSB array are double the value of their predecessor, but the first capacitance in the MSB array is set to $C_{u}$. Hence, the largest capacitance is well below that in the binary-weighted DAC.

For a binary code corresponding to the integer input $i$, let $C_{O N}^{L S B}(i)$ and $C_{O F F}^{L S B}(i)$ be the sum of capacitances whose bottom plates are connected to $V_{R E F}$ and ground, respectively and $R_{O N}^{L S B}\left[R_{O N}^{M S B}\right]$ is the parasitic resistance associated with the capacitor $C_{O N}^{L S B}\left[C_{O N}^{M S B}\right]$, from the LSB capacitive array, and let $C_{O N}^{M S B}(i)$ and $C_{O F F}^{M S B}(i)$ denote the corresponding values for the MSB array. Quantitatively,

$$
\begin{aligned}
C_{O N}^{L S B}(i) & =\sum_{k=1}^{L} D_{k}(i) 2^{k-1} C_{u} \\
C_{O F F}^{L S B}(i) & =\sum_{k=1}^{L} \bar{D}_{k}(i) 2^{k-1} C_{u}+C_{u} \\
C_{O N}^{M S B}(i) & =\sum_{k=L+1}^{N} D_{k}(i) 2^{N-k} C_{u} \\
C_{O F F}^{M S B}(i) & =\sum_{k=L+1}^{N} \bar{D}_{k}(i) 2^{N-k} C_{u}
\end{aligned}
$$

The total LSB [MSB] array capacitance, $C_{T}^{L S B}\left[C_{T}^{M S B}\right]$ is

$$
\begin{align*}
C_{T}^{L S B} & =C_{O N}^{L S B}(i)+C_{O F F}^{L S B}(i)  \tag{4}\\
C_{T}^{M S B} & =C_{O N}^{M S B}(i)+C_{O F F}^{M S B}(i) \tag{5}
\end{align*}
$$

For the scenario where only the capacitors from LSB array are connected to $V_{R E F}$ or ground corresponding to the code $i$, and all capacitors from the other array are connected to ground, as shown in Fig. 3(a), we denote the output voltage by $V_{O U T, i d e a l}^{L S B}$. For the similar case where the LSB capacitors are all grounded and the MSB array implements the corresponding digits of code $i$, shown in Fig. 3(b), we denote the response at the output as $V_{O U T, i d e a l}^{M S B}$. The figures show all capacitors


Fig. 3: Equivalent circuit of a split DAC with excitations applied to (a) the LSB array, and MSB excitations set to 0 , (b) the MSB array, and the LSB excitations set to 0 . The two cases are superposed to determine $V_{O U T}^{L S B}$.
in the system, including the parasitic capacitances shown in purple and grey.

The counterpart of Equation (3) is obtained by superposition, by adding the output voltages for the two scenarios above. From Fig. 3(a), denoting $V_{A}$ as the voltage on the left terminal of $C_{A}$,

$$
\begin{align*}
V_{O U T, \text { ideal }}^{L S B}(i) & =V_{A} \cdot \frac{C_{A}}{C_{A}+C_{T}^{M S B}} \\
& =V_{R E F} \cdot \frac{C_{O N}^{L S B}(i)}{C_{T}^{L S B}+C_{A}^{M S B}} \cdot \frac{C_{A}}{C_{A}+C_{T}^{M S B}} \tag{6}
\end{align*}
$$

where $C_{A}^{M S B}$ is the equivalent capacitance of series connection between attenuation capacitor $C_{A}$ and the MSB capacitors whose bottom plates are connected to the ground, i.e.,

$$
\begin{equation*}
C_{A}^{M S B}=\frac{C_{A} C_{T}^{M S B}}{C_{A}+C_{T}^{M S B}} \tag{7}
\end{equation*}
$$

For the second component of superposition in Fig. 3(b),

$$
\begin{equation*}
V_{O U T, i d e a l}^{M S B}(i)=V_{R E F} \cdot \frac{C_{O N}^{M S B}(i)}{C_{T}^{M S B}+C_{A}^{L S B}} \tag{8}
\end{equation*}
$$

where $C_{A}^{L S B}$ is the equivalent capacitance of series connection between attenuation capacitor $C_{A}$ and the LSB capacitors whose bottom plates are connected to the ground, i.e.,

$$
\begin{equation*}
C_{A}^{L S B}=\frac{C_{A} C_{T}^{L S B}}{C_{A}+C_{T}^{L S B}} \tag{9}
\end{equation*}
$$

For an applied code $i$, the expression for $V_{O U T}^{i d e a l}$ is the superposition of the cases described in Eqs. (6) and (8), i.e.,

$$
\begin{equation*}
V_{O U T}^{\text {ideal }}(i)=V_{O U T, i d e a l}^{M S B}(i)+V_{O U T, i d e a l}^{L S B}(i) \tag{10}
\end{equation*}
$$

Similar to the case of binary-weighted DACs, the parasitics $C^{T S}$ and $C^{T B}$ associated with LSB [MSB] array can alter $V_{O U T, \text { ideal }}^{L S B}\left[V_{O U T, i d e a l}^{M S B}\right]$, and therefore the $V_{O U T}^{i d e a l}$ of the circuit. We will further elaborate on this in Section III-B.

Here too, increasing $C_{u}$ can reduce these effects, at the cost of increased power. The impact of various types of parasitic capacitances on 3 dB switching frequency is explained in Section III-C.

## C. Modeling variations in a DAC capacitor array

To reduce systematic mismatch, the unit capacitors $C_{u}$, which are built as identical-sized capacitor cells (called unit cells) that are placed in a gridded common-centroid matrix [3], [4]. Unit capacitors may be built using a range of technologies. A MIM capacitor consists of two metal layers and a dielectric layer. MOM capacitor structures consist of a set of metal wires that can be connected in various configurations, e.g., alternate polarity MOMs (APMOMs), woven, parallel stacked, or vertical structures [10]. This work focuses on MOM structures in FinFET nodes, although many ideas can be applied to MIM structures.
Taking the origin to be at the center of an $r \times s$ CC array, we can obtain the location $\left(x_{k}, y_{k}\right)$ of a unit capacitor in row $r_{k}$ and column $s_{k}$ by following [20] from its width and height, $W$ and $H$, and the vertical and horizontal spacing, $S_{v}$ and $S_{h}$ between unit capacitors as shown below:

$$
\begin{aligned}
& x_{k}=\left(s_{k}-(s+1) / 2\right)\left(W+S_{h}\right) \\
& y_{k}=\left((r+1) / 2-r_{k}\right)\left(H+S_{v}\right)
\end{aligned}
$$

1) Modeling systematic variation due to a linear gradient: Systematic variations are typically modeled as a gradient across the layout area [5]. At the center of the CC array, if $t_{0}$ denotes the spacing between MOM cap wires, and $C_{u}$ is the unit capacitance, then the oxide thickness at $\left(x_{j}, y_{j}\right)$ is $t_{j}=t_{0}+\gamma\left(x_{j} \cos \theta+y_{j} \sin \theta\right)$. Here, $\gamma$ and $\theta\left(0 \leq \theta \leq 180^{\circ}\right)$ are the linear oxide gradient magnitude and angle at the origin, respectively, where $\gamma$ and $\theta$ randomly differ from array to array (as they are subject to manufacturing variability), but are constant for a given array. A unit capacitor at $\left(x_{j}, y_{j}\right)$ thus has value $C_{u}\left(t_{0} / t_{j}\right)$. Each capacitor value $C_{k}$ is then shifted due to systematic variations to

$$
\begin{equation*}
C_{k}^{*}=\sum_{j} C_{u} \times\left(t_{0} / t_{j}\right) \tag{11}
\end{equation*}
$$

If an ideal capacitor ratio, $C_{0}: \cdots: C_{N}$, shifts to $C_{0}^{*}$ : $\cdots: C_{N}^{*}$ due to a process gradient, then the systematic ratio mismatch is:

$$
\begin{equation*}
M_{s y s}=\max _{p, q \in\{0, \cdots, N\}, p \neq q}\left|\frac{\left(C_{p}^{*} / C_{q}^{*}\right)-\left(C_{p} / C_{q}\right)}{\left(C_{p} / C_{q}\right)}\right| \tag{12}
\end{equation*}
$$

2) Modeling random variations: A unit capacitor has zeromean random variations with variance $\sigma_{u}^{2}=A_{f}^{2} /(W H)$ [21], where $A_{f}$ is similar to a Pelgrom mismatch coefficient [22], $W$ and $H$ are the width and height of the unit capacitor. The correlation coefficient for two unit capacitors $A$ at $\left(x_{1}, y_{1}\right)$ and $B$ at $\left(x_{2}, y_{2}\right)$ in the $(r \times s)$ CC matrix is [6], [23]:

$$
\begin{align*}
\rho_{A B} & =\left(\rho_{u}\right)^{D(A, B)}  \tag{13}\\
\text { where } D(A, B) & =\left(\sqrt{\left(x_{2}-x_{1}\right)^{2}+\left(y_{2}-y_{1}\right)^{2}}\right) / L_{c} \tag{14}
\end{align*}
$$

Here $0<\rho_{u}<1$ and $L_{c}$ are process-specific parameters.

If $C_{p}=p C_{u}\left[C_{q}=q C_{u}\right]$, with $p[q]$ unit capacitors, correlation coefficient $\rho_{p q}=\operatorname{Cov}(p, q) /\left(\sigma_{p} \sigma_{q}\right)$ where

$$
\begin{gathered}
\sigma_{p}^{2}=\sigma_{u}^{2}\left(p+2 S_{p}\right) ; \sigma_{q}^{2}=\sigma_{u}^{2}\left(q+2 S_{q}\right) \\
S_{p}=\sum_{a=1}^{p-1} \sum_{b=a+1}^{p} \rho_{a b} ; S_{q}=\sum_{a=1}^{q-1} \sum_{b=a+1}^{q} \rho_{a b} ; S_{p q}=\sum_{a=1}^{p} \sum_{b=1}^{q} \rho_{a b}
\end{gathered}
$$

## III. Circuit-LEVEL METRICS

In this section, we examine the impact of nonidealities due to parasitic capacitance mismatch on performance metrics for the binary-weighted and split DAC topologies.

The differential nonlinearity ( $D N L$ ) is the difference between the ideal and nonideal step for input code $1 \leq i \leq$ $2^{N}-1$. The DNL at input code $i$ is given by:

$$
\begin{equation*}
D N L(i)=\left(V_{O U T}(i)-V_{O U T}(i-1)-V_{L S B}\right) / V_{L S B} \tag{17}
\end{equation*}
$$

where $V_{L S B}=V_{R E F} / 2^{N}$. The integral nonlinearity (INL) is the deviation between the ideal output and the actual output in the presence of mismatch. By definition, $I N L(0)=0$, and for $1 \leq i \leq 2^{N}-1$,

$$
\begin{equation*}
I N L(i)=\left(V_{O U T}(i)-V_{O U T}^{\text {ideal }}(i)\right) / V_{L S B} \tag{18}
\end{equation*}
$$

## A. Errors in linearity metrics for a binary-weighted DAC

For a binary-weighted DAC, under nonidealities the output voltage can be represented as [8]:

$$
\begin{equation*}
V_{O U T}(i)=V_{R E F} \cdot \frac{C_{O N}(i)+\Delta C_{O N}(i)}{C_{T}+\Delta C_{T}} \tag{19}
\end{equation*}
$$

where $\Delta C_{O N}(i)\left[\Delta C_{T}\right.$ ] is the shift in $C_{O N}(i)\left[C_{T}\right]$. The shifts in $C_{O N}(i)$ and $C_{T}$ in (2) due to nonidealities are:

$$
\begin{align*}
\Delta C_{O N}(i) & =\sum_{k=1}^{N} D_{k}(i) \Delta C_{k}+C_{O N}^{T B}  \tag{20}\\
\Delta C_{T} & =\sum_{k=0}^{N} \Delta C_{k}+C_{O N}^{T B}+C_{O F F}^{T B}+C^{T S} \tag{21}
\end{align*}
$$

where $C_{O N}^{T B}, C_{O F F}^{T B}$, and $C^{T S}$ represent the parasitics illustrated in Fig. 2; $\Delta C_{k}$ is the sum of the statistical variations, $\Delta C_{k}^{s t a}$, and systematic variations. The systematic variation of the $k^{t h}$ capacitor $\Delta C_{k}^{s y s}$ is given by:

$$
\begin{equation*}
\Delta C_{k}^{s y s}=\left(C_{k}^{*}-n_{k} C_{u}\right) \tag{22}
\end{equation*}
$$

We followed the statistical variation model from the preliminary conference version of this paper [19] using a $3 \sigma$ model. The variances of $\Delta C_{O N}(i)$ and $\Delta C_{T}$ are:

$$
\begin{align*}
\sigma_{\Delta C_{O N}(i)}^{2} & =\sum_{j=1}^{N} \sum_{k=1}^{N} D_{j}(i) D_{k}(i) \operatorname{Cov}(j, k)  \tag{23}\\
\sigma_{\Delta C_{T}}^{2} & =\sum_{j=0}^{N} \sum_{k=0}^{N} \operatorname{Cov}(j, k) \tag{24}
\end{align*}
$$

where $\operatorname{Cov}(i, j)$ is given by (16). Therefore,

$$
\begin{aligned}
\Delta C_{O N}(i) & =\sum_{k=1}^{N} D_{k}(i) \Delta C_{k}+\left(3 \sigma_{\Delta C O N}(i)+C_{O N}^{T B}\right) \\
\Delta C_{T} & =\sum_{k=0}^{N} \Delta C_{k}+\left(3 \sigma_{\Delta C_{T}}+C_{O N}^{T B}+C_{O F F}^{T B}+C^{T S}\right)
\end{aligned}
$$

## B. Errors in linearity metrics for a split DAC

To model the split DAC under nonidealities, as before, we superpose the effect of the LSB and MSB arrays on the output voltage. For an applied code $i$, depending on whether the $k^{\text {th }}$ bit, $D_{k}$, is 0 or 1 , capacitors in each array may be connected to $V_{R E F}$ or ground, respectively; those in the other are grounded for the purposes of superposition calculations.

For a split DAC under nonideal conditions, we update $C_{O N}^{X}(i), C_{T}^{X}$ and $C_{A}^{X}$, where $X \in\{M S B, L S B\}$ in (6) and (8). We will denote the shifts in $C_{O N}^{X}(i), C_{T}^{X}$, and $C_{A}^{X}$ as $\Delta C_{O N}^{X}(i), \Delta C_{T}^{X}$, and $C_{A, \text { nonideal }}^{X}$, respectively. We calculate the output voltage $V_{o u t}^{L S B}$ under nonidealities for the excitation to the LSB array (Fig. 3(a)) by first calculating voltage $V_{A}$ as

$$
\begin{equation*}
V_{A}(i)=V_{R E F} \cdot \frac{C_{O N}^{L S B}(i)+\Delta C_{O N}^{L S B}(i)}{C_{T}^{L S B}+\Delta C_{T}^{L S B}+C_{A, \text { nonideal }}^{M S B}} \tag{25}
\end{equation*}
$$

The output voltage as in Eq. (6) under nonidealities is given by:

$$
\begin{equation*}
V_{O U T}^{L S B}(i)=V_{A}(i) \cdot \frac{C_{A}+C_{A}^{T B}}{C_{A}+C_{A}^{T B}+C_{T}^{M S B}+\Delta C_{T}^{M S B}} \tag{26}
\end{equation*}
$$

For the MSB array (Fig. 3(b)), Eq. (8) is modified to:

$$
\begin{equation*}
V_{O U T}^{M S B}(i)=V_{R E F} \cdot \frac{C_{O N}^{M S B}(i)+\Delta C_{O N}^{M S B}(i)}{C_{T}^{M S B}+\Delta C_{T}^{M S B}+C_{A, \text { nonideal }}^{L S B}} \tag{27}
\end{equation*}
$$

The nonideal counterparts of Eq. (7) and Eq. (9) are represented as $C_{A, \text { nonideal }}^{X}$, where $X \in\{L S B, M S B\}$. These are based on the nonideal version of each of the corresponding capacitors, and are given by the equivalent series capacitance of $\left(C_{A}+C_{A}^{T B}\right)$ with $\left(C_{T}^{X}+\Delta C_{T}^{X}\right)$.

The ideal output voltage, $V_{O U T}(i)$ in Eq. (10) can be modified for the nonideal case superposing Eqs. (26) and (27). To evaluate these two equations, we require the shifted values of the LSB and MSB capacitors in Figs. 3(a) and (b), respectively, which are given by:

$$
\begin{aligned}
\Delta C_{O N}^{L S B}(i)= & \sum_{k=1}^{L} D_{k}(i) \Delta C_{k}+C_{L S B, O N}^{T B} \\
\Delta C_{O N}^{M S B}(i)= & \sum_{k=L+1}^{N} D_{k}(i) \Delta C_{k}+C_{M S B, O N}^{T B} \\
\Delta C_{T}^{L S B}= & \sum_{k=0}^{L} \Delta C_{k}+C_{L S B, O N}^{T B}+C_{L S B, O F F}^{T B}+C_{T S}^{L S B} \\
\Delta C_{T}^{M S B}= & \sum_{k=L+1}^{N} \Delta C_{k}+C_{M S B, O N}^{T B}+C_{M S B, O F F}^{T B} \\
& \quad+C_{T S}^{M S B}
\end{aligned}
$$

As before, $\Delta C_{k}$ represents the shift due to process variations and $D_{0}(i)=0$ for all $i$ as $C_{0}$ is connected to ground.

The extent of statistical variations is given by the $3 \sigma$ points of the statistical summations of $C_{k}$ terms for the variances of $\Delta C_{O N}^{L S B}(i)\left[\Delta C_{O N}^{M S B}(i)\right]$ and $\Delta C_{T}^{L S B}\left[\Delta C_{T}^{M S B}\right]$ for LSB [MSB] bits are shown below:

$$
\begin{align*}
\sigma_{\Delta C_{O N}^{L S B}(i)}^{2} & =\sum_{j=1}^{L} \sum_{k=1}^{L} D_{j}(i) D_{k}(i) \operatorname{Cov}(j, k)  \tag{28}\\
\sigma_{\Delta C_{O N}^{M S B}(i)}^{2} & =\sum_{j=L+1}^{N} \sum_{k=L+1}^{N} D_{j}(i) D_{k}(i) \operatorname{Cov}(j, k)  \tag{29}\\
\sigma_{\Delta C_{T}^{L S B}}^{2} & =\sum_{j=0}^{L} \sum_{k=0}^{L} \operatorname{Cov}(j, k)  \tag{30}\\
\sigma_{\Delta C_{T}^{M S B}}^{2} & =\sum_{j=L+1}^{N} \sum_{k=L+1}^{N} \operatorname{Cov}(j, k) \tag{31}
\end{align*}
$$

Using the $3 \sigma$ model, the shifts in $C_{O N}^{L S B}(i)\left[C_{O N}^{M S B}(i)\right]$ and $C_{T}^{L S B}\left[C_{T}^{M S B}\right]$ can be written as:

$$
\begin{gathered}
\Delta C_{O N}^{L S B}(i)=\sum_{k=1}^{L} D_{k}(i) \Delta C_{k}+3 \sigma_{\Delta C_{O N}^{L S B}(i)}+C_{L S B, O N}^{T B} \\
\Delta C_{O N}^{M S B}(i)=\sum_{k=L+1}^{N} D_{k}(i) \Delta C_{k}+3 \sigma_{\Delta C_{O N}^{M S B}(i)} \\
\quad+C_{M S B, O N}^{T B} \\
\Delta C_{T}^{L S B}=\sum_{k=0}^{L} \Delta C_{k}+C_{L S B, O N}^{T B}+C_{L S B, O F F}^{T B} \\
\quad+C_{T S}^{L S B}+3 \sigma_{\Delta C_{T}^{L S B}} \\
\Delta C_{T}^{M S B}=\sum_{k=L+1}^{N} \Delta C_{k}+C_{M S B, O N}^{T B}+C_{M S B, O F F}^{T B} \\
\quad+C_{T S}^{M S B}+3 \sigma_{\Delta C_{T}^{M S B}}
\end{gathered}
$$

## C. Capacitor $3 d B$ frequency

The switching response of a capacitor array is encapsulated in the 3 dB frequency metric, which defines the maximum speed at which switches can close the bottom plates of the unit capacitors of the DAC. For high-resolution DACs, the routing-induced parasitics may substantially affect the 3 dB frequency. In FinFET technologies in particular, high wire and via parasitics can result in high RC time constants, which degrade the 3 dB frequency.

In our preliminary version of this paper [19], we had shown that this effect is particularly acute when CC layout techniques attempt to increase capacitor dispersion, which requires the connecting wires to use a large number of vias, resulting in high parasitic resistance. We had also shown a model based on [24] to obtain the critical frequency for the binary-weighted DAC. Since each cycle goes through a charge-discharge phase, the 3 dB frequency, $f_{3 d B}$, for a full cycle of a capacitor is represented as:

$$
\begin{equation*}
f_{3 d B}=1 /(2(N+2) \ln (2) \tau) \tag{32}
\end{equation*}
$$

For each capacitor $C_{i}, \tau$ is measured by computing the Elmore delay of the RC mesh to the unit capacitors of $C_{i}$. Over all bits, the charging network with the maximum Elmore delay limits the frequency and is used as $\tau$ in (32). For a binaryweighted DAC, the Elmore delay for a mesh can be computed using standard techniques [25].


Fig. 4: Equivalent circuit of a split DAC with the $k^{\text {th }}$ bit from (a) LSB side, (b) MSB side set to 1 and all other bits set to 0.

To determine the RC product associated with the switching of a specific bit $k$ for a split DAC, we consider the case when bit $k$ is set to 1 and all other bits are 0 . The equivalent circuits for these two cases, when the $k^{t h}$ capacitor $\left(C_{k}^{X}\right)$ is connected to $V_{R E F}$ and other $N-k$ capacitors $\left(C_{T-k}^{X}\right)$ are connected to the ground in the LSB and MSB arrays, where
$X \in\{M S B, L S B\}$, are displayed in Figs. 4(a) and (b). ${ }^{1}$ The equivalent capacitance of Fig. 4(a), excluding the $k^{t h}$ capacitor from the LSB side array which is connected to $V_{R E F}$ with all other capacitors grounded, can be written as
$C_{A, e q}^{L S B}=C_{T-k}^{L S B}+C_{L S B, T-k}^{T B}+\frac{\left(C_{A}+C_{A}^{T B}\right)\left(C_{T}^{M S B}+C_{M S B}^{T B}\right)}{C_{A}+C_{A}^{T B}+C_{T}^{M S B}+C_{M S B}^{T B}}$
(33)

The total equivalent capacitance for excitation to the LSB side array (Fig. 4(a)) can be represented as

$$
\begin{equation*}
C_{e q}^{L S B}=\frac{\left(C_{k}^{L S B}+C_{L S B, k}^{T B}\right) C_{A, e q}^{L S B}}{C_{k}^{L S B}+C_{L S B, k}^{T B}+C_{A, e q}^{L S B}} \tag{34}
\end{equation*}
$$

Similarly, the equivalent capacitance for Fig. 4(b) at the right side of the $k^{t h}$ bit from the MSB array which is set to 1 , with all other capacitors connected to the ground is given by

$$
\begin{align*}
C_{A, e q}^{M S B}=C_{T-k}^{M S B}+ & C_{M S B, T-k}^{T B} \\
& +\frac{\left(C_{A}+C_{A}^{T B}\right)\left(C_{T}^{L S B}+C_{L S B}^{T B}\right)}{C_{A}+C_{A}^{T B}+C_{T}^{L S B}+C_{L S B}^{T B}} \tag{35}
\end{align*}
$$

The total equivalent capacitance for Fig. 4(b) is shown below

$$
\begin{equation*}
C_{e q}^{M S B}=\frac{\left(C_{k}^{M S B}+C_{M S B, k}^{T B}\right) C_{A, e q}^{M S B}}{C_{k}^{M S B}+C_{M S B, k}^{T B}+C_{A, e q}^{M S B}} \tag{36}
\end{equation*}
$$

To calculate the 3 dB frequency, the resistance for the RC product corresponds to the parasitic resistance $R_{k}^{L S B}\left[R_{k}^{M S B}\right]$ which is associated with the capacitor from the LSB [MSB] array whose bottom plate is connected to $V_{R E F}$ and capacitance corresponds to the equivalent capacitance from the equivalent circuits (Fig. 4). The frequency calculation is performed by using (32) for each capacitor from the capacitor array, and the minimum of these frequencies is considered as the 3 dB frequency of the circuit.

## D. Non-unit capacitor aspect ratio

In the split DAC, the top plates from the LSB and MSB array are connected via an attenuation capacitor. In a conventional split DAC, the attenuation capacitor is a non-unit capacitor (i.e., not an integer multiple of the unit capacitor $C_{u}$ used to build the binary-weighted (sub)array(s)). The overall dimensions are usually set to between one and two times the unit-sized capacitor $\left(C_{u}\right)$, and the capacitor has a rectangular bounding box [16]. To obtain the correct non-unit capacitive ratio, we will show that the relative error due to process variation for the MOM capacitors is similar to the MIM capacitors, where the relative error is equal to the ideal perimeter-to-area ratio.
Let $N$ be the number of coupled segments as shown in Fig. 5. The capacitance can be represented as

$$
\begin{equation*}
C=N \epsilon\left(\frac{l t}{d}\right) \tag{37}
\end{equation*}
$$

[^0]

Fig. 5: Cross-section of a MOM capacitor in one metal layer.
where $\epsilon, l, t$ and $d$ are the dielectric constant, coupling length, thickness, and distance between the fingers, respectively. Here,

$$
\begin{equation*}
l=w-c ; H=N p \tag{38}
\end{equation*}
$$

where $c$ is a constant, corresponding to the spacing between the top and bottom plates along the direction of $l$ as shown in Fig. 5, $p$ is the pitch between two adjacent wires, and $w$ and $H$ are the width and height of the MOM capacitor. Since $N=H / p$,

$$
\begin{equation*}
C=\left(\frac{\epsilon t}{d p}\right) l H \tag{39}
\end{equation*}
$$

Under process variations, the total capacitance is represented as

$$
\begin{align*}
& \quad C+\Delta C=\left(\frac{\epsilon t}{d p}\right)(l+\Delta l)(H+\Delta H)  \tag{40}\\
& \text { i.e., } \Delta C=\left(\frac{\epsilon t}{d p}\right)(l \Delta H+H \Delta l) \tag{41}
\end{align*}
$$

Neglecting $\Delta l \cdot \Delta H$, the relative error in the capacitance is

$$
\begin{equation*}
\frac{\Delta C}{C}=\frac{l \Delta H+H \Delta l}{l H}=\frac{\Delta H}{H}+\frac{\Delta l}{l} \tag{42}
\end{equation*}
$$

Using notation consistent with the analysis in [16] for MIM capacitors, we assume that under process variations, the coupling length, width, and height of the MOM capacitor change by $2 \delta$, i.e.,

$$
\begin{equation*}
l \rightarrow l+2 \delta ; w \rightarrow w+2 \delta ; H \rightarrow H+2 \delta \tag{43}
\end{equation*}
$$

The relative error in the capacitor is therefore given by

$$
\begin{align*}
\frac{\Delta C}{C} & =\frac{2 \delta}{H}+\frac{2 \delta}{l}  \tag{44}\\
\frac{\Delta C}{C} & =2 \delta\left(\frac{H+l}{H l}\right)=2 \delta\left(\frac{H+w-c}{H(w-c)}\right) \tag{45}
\end{align*}
$$

Thus the relative capacitor error for a MOM capacitor due to process variations has a similar form as that for the MIM capacitor [16], where the relative error is proportional to the the ideal perimeter to ideal area ratio: the difference here is in the use of $w-c$ instead of $w$ in the MIM case. for a given capacitance value $C$, we set the relative error to be the same as that for a unit capacitor on the left-hand side of (45). Together with (39), this yields two equations in two variables that are solved to obtain $H$ and $l$.

## IV. Common-Centroid Placement and Routing

Our constructive routing-friendly common-centroid placement flow optimizes mismatch, interconnect wirelength, parasitic RCs, and 3 dB frequency for both the binary-weighted and split DACs; next, a routing step optimizes DAC performance. We first present the placement and routing algorithms for a binaryweighted DAC in Sections IV-A and IV-B, respectively. Next, we shown how these algorithms are modified to generate the layout for a split DAC in Section IV-C. In our work [19] we presented the formulation for obtaining array size for N -bit binary-weighted DAC.

## A. CC placement for a binary-weighted DAC

1) Placement tradeoffs between wire resistance and dispersion: Good matching under random variations is ensured through dispersion, which reflects the spread of the unit capacitances of $C_{0}$ through $C_{N}$ in the CC array. An additional major consideration is to build routing-friendly placements that optimize interconnect parasitic effects. Previous efforts have not addressed the specific needs of FinFET technologies, with high wire resistance and higher via resistances. As FinFET technologies used reserved-direction routing, especially in the lower metal layers that are used for MOM capacitors, every bend in a wire incurs a via resistance cost due to a layer change.

Reducing via count is critical for reducing interconnect resistance and improving 3 dB frequency. An extension of high-dispersion chessboard placement [8] matches capacitive routing parasitics but neglects resistance: results show high via counts. We consider a range of new constructive placement solutions - spiral placement and block chessboard (BC) methods - to trade off interconnect parasitics with dispersion for the binary-weighted DAC.


Fig. 6: An example illustrating our CC placement algorithm.

## Spiral placement for optimized interconnect parasitics

This placement algorithm reduces the number of bends in the connections and is illustrated for a 6-bit DAC in Fig. 6(a). Since the number of unit capacitors in $C_{0}$ and $C_{1}$ is 1 , an odd number, it is not possible to achieve a common-centroid placement. Instead, we place these as close to the commoncentroid as possible to limit the impact of process variations. Here, we place $C_{0}$ and $C_{1}$ diagonally opposite each other near the center. Next, we place all the capacitors of $C_{2}$, then $C_{3}$, and so on, in a spiral sequence from the center.

Whenever we place a unit capacitor at a location along a spiral, we also place another unit capacitor at its reflection to maintain the CC property. Considering the CC point as the origin (the red dot in the figure), if we place a unit capacitor
in a square $\left(d_{1}, d_{2}\right)$, it will be accompanied by another unit capacitor at location $\left(-d_{1},-d_{2}\right)$. For example, when the spiral places a unit capacitor of $C_{2}$ at $(-1,-1)$ in the figure, we place another unit capacitor of $C_{2}$ at $(+1,+1)$. We place the unit capacitors of $C_{3}$ at the first empty location along the spiral, first at $(1,2)$ and its reflection at $(-1,-2)$, and so on.

Beyond $C_{2}$, this technique naturally aligns numerous unit cells of a capacitor to lie in the same row or column, the method reduces the number of vias (corresponding to wire "bends") required to connect them. This approach maintains adequate dispersion while using a number of bends (corresponding to vias) for the routing connections. Although our proposed placement algorithm is simple, it is different from previous methods: the nearest similar methods are [5], with a mix of rectangles and circles for placement, and [26] with interleaved rows, but it does not achieve good dispersion.
Chessboard placement for optimized dispersion [8] At the other extreme, [8] optimizes dispersion by interspersing unit capacitors in a chessboard pattern, as illustrated for a 6-bit DAC in Fig. 6(b). For a 6-bit DAC, the 32 unit capacitors of $C_{6}$ are first placed in an $8 \times 8$ array on the black squares of a "chessboard"; then the 16 unit capacitors of $C_{5}$ are placed; and so on. However, the routing resistance costs here are large. Block chessboard (BC) approaches A block chessboard approach attempts to find the best of both worlds, by achieving the dispersion of the chessboard approach and the lower routing costs of the spiral approach. Examples of this approach for a 6-bit DAC are shown in Figs. 6(c) and 6(d). The inner core of this structure is a conventional chessboard layout for the capacitors with a smaller number of unit cells (here, $C_{0}$ through $C_{4}$ ): this provides good dispersion, and while it has a high number of bends/vias, its wire RCs are typically smaller than those of the larger capacitors $C_{5}$ and $C_{6}$, and do not constrain the 3 dB frequency, which is determined by the worstcase time constant. The outer corridor here has a width of 2 cells. Since $n_{6}: n_{5}=2: 1$, we first lay out half the cells of $C_{6}$ in clusters and then perform chessboard placement, alternating the remaining cells of $C_{6}$ with $C_{5}$. Two layouts are shown for different granularities in the outer corridor.

Other block chessboard structures may be built with the inner full-chessboard core of $C_{0}-C_{k}$, and an outer block structure for $C_{k+1}-C_{N}$. MSB capacitors do not greatly affect the DAC accuracy since their variation is averaged over more unit capacitors than LSB capacitors. ${ }^{2}$ We design the block chessboard scheme so that MSB capacitors use fewer vias than in the chessboard scheme, resulting in an improved (higher) 3 dB frequency. Our block chessboard placement method is outlined in Algorithm 1. The approach consists of three steps: performing the inner complete chessboard (Step 1), creating the outer block chessboard pattern, and completing the block chessboard (Step 2).

For the block chessboard placement, we focus on reducing

[^1]the number of vias in the highest-order bits, since they have the largest RCs, and to provide good dispersion for the lowerorder bits, which have small capacitors that are susceptible to variation effects. For this reason, we perform an inner complete chessboard for $C_{0}, \cdots, C_{k}$ and block chessboard layout for $C_{k+1}, \cdots, C_{N}$. In practice, it is reasonable to assume that $k$ and $N-k$ is even to obtain a placement without dummies.

We first calculate the number of rows, $\left(r_{c}\right)$, and columns, $\left(s_{c}\right)$, for the inner complete chessboard (line 5). Next, we lay out the inner complete chessboard for $C_{0}-C_{k}$ in a manner similar to [8].

In step 2 (line 7), we lay out $(N-k)$ capacitors in the outer corridor of the inner complete chessboard in a block chessboard pattern using the selected block size, $b_{s}$. For finer [coarser] granularity, a smaller [larger] block size can be chosen. To create a block chessboard layout, starting from $i=k+1$, we place the blocks in chessboard fashion using the selected block size, $b_{s}$, for $C_{i}$. First, we determine the number of blocks for the $i^{\text {th }}$ capacitor (i.e., we define the range of the outer two loops), which can be placed at the upper half of the placement across the block columns and rows. Here, a block column [row] consists of the number of columns [rows] of size $b_{s}$.

The unit capacitors of $C_{i}$ are placed in lines 17-21. We then reflect the solution simultaneously at its diagonal symmetric location with respect to the center to maintain CC symmetry. Next, we calculate the initial column location for other blocks

```
Algorithm 1 Block chessboard placement
    Input: \(C=\left[C_{0}, \cdots, C_{N}\right] ; r\), row; \(s\), column; \(k\), capacitor number for inner
    complete chessboard; \(b_{s}[i]\), a list of block sizes for capacitor \(C_{i}\).
    Output: Common-centroid placement
    //Step 1: Perform inner complete chessboard
    //Calculate row and column for inner complete chessboard for \(C_{0}-C_{k}\) capacitors
    \(r_{c} \leftarrow\left\lceil\sqrt{\sum_{i=0}^{k} C_{i}}\right\rceil, s_{c} \leftarrow\left\lceil\left(\sum_{i=0}^{k} C_{i}\right) / r_{c}\right\rceil\)
    Fill out the inner black and white squares of a chessboard with row and column size
    of \(\left(r_{c}, s_{c}\right)\) using [8].
    : //Step 2: Perform outer block chessboard placement
    ://Place \(\left(C_{k+1}-C_{N}\right)\) capacitors at the outer corridor of inner chessboard
    for \(i=k+1\) to \(N\) by 2 do
        //Calculate row and column for BC placement for \(C_{i}-C_{i+1}\) capacitors
        \(r_{i} \leftarrow\left\lceil\sqrt{\sum_{j=0}^{i+1} C_{j}}\right\rceil, s_{i} \leftarrow\left\lceil\left(\sum_{j=0}^{i+1} C_{j}\right) / r_{i}\right\rceil\)
        \(\left(x_{s}, y_{s}\right) \leftarrow\left(s_{i} / 2-s_{c} / 2, r_{i} / 2-r_{c} / 2\right)\) //Initial (row, column) position
        \(/ / C r e a t e ~ b l o c k ~ c h e s s b o a r d ~ p a t t e r n ~ u s i n g ~ c a p a c i t o r ~ C_{i}\)
        for \(p=1\) to \(\left[\frac{r_{i} / 2}{b_{S}[i]}\right\rceil\) do //Over number of blocks in a block column
            for \(q=1\) to \(\left\lceil\frac{\left(s_{i}-s_{c}\right)}{b_{s}[i]}\right\rceil\) do //Over number of blocks in a block row
                //Create a block of block size \(b_{s}\) for capacitor \(C_{i}\)
                    for \(x=x_{s}\) to \(x_{s}+b_{s}[i]\) do //Over columns
                for \(y=y_{s}\) to \(y_{s}+b_{s}[i]\) do //Over rows
                    Place a unit of \(C_{i}\) at \((x, y)\) and diagonal symmetric of \((x, y)\) location.
                end for
            end for
                Calculate starting column location for the next block across a block row.
            end for
            //Update initialization of starting column location for the next set of blocks
            if \(p \% 2==0\) then
                \(x_{s} \leftarrow 0\)
            else
                \(x_{s} \leftarrow b_{s}[i]\)
            end if
            \(y_{s} \leftarrow y_{s}+b_{s}[i] / /\) Update starting row location for the next set of blocks
        end for
        Place the units of \(C_{i+1}\) at the leftover location, outside of \(\left(r_{c}, s_{c}\right)\)
        within \(\left(r_{i}, s_{i}\right)\).
        \(r_{c} \leftarrow r_{i}, s_{c} \leftarrow s_{i} / / R e s e t ~ t h e ~ o u t e r ~ c o r r i d o r ~ f o r ~ t h e ~ n e x t ~ s e t ~ o f ~ c a p a c i t o r s ~\)
        end for
```

in the row and place them successively. After finishing the placement of blocks in one block row, we reset the starting column location across each block row (lines 25-29) and increment the row by a block size (line 30) to perform the next set of block chessboard placement. Once all unit capacitors of $C_{i}$ have been placed, we place the unit capacitors of the next largest capacitor ( $C_{i+1}$ ) in the rest of the locations of the outer corridor (line 33). To define the next outer corridor for $i=k+3$ if $N-k>2$, here at line 34 we reset the row and column $\left(r_{c}, s_{c}\right)$ of inner chessboard placement. We increment $i$ and repeat the process until $i=N-1$.

## B. Routing for a binary-weighted DAC

There are several routing induced parasitics as discussed in [19], we minimize $C_{i}^{T B}$ as in [9] with nonoverlapped routing that separates the wires that route the top-plate and bottomplate. A detailed description on the bottom plate routing is presented in [19].

1) Connected unit capacitor group formation: To connect all bottom plates of unit capacitors of each $C_{i}$, we first create a connected capacitor group of neighboring unit capacitors of each $C_{i}$. We represent unit capacitors by nodes in graph $G$, with edges between nodes for these neighboring unit capacitors.


Fig. 7: Graph representation of connected capacitor groups.
We apply a breadth first search (BFS) algorithm on graph $G$ to find its connected components (connected capacitor groups). The bottom plates of neighboring unit capacitors in the BFS tree are connected using branch wires: each connection is immediately mirrored to the unit capacitor at the diagonally symmetric location in the common-centroid placement, maintaining symmetric routing. The graph representation of the connected unit capacitor groups for a 6-bit CC array for the placement presented in [9] is shown in Fig. 7.
2) Bottom-plate routing: Bottom-plate routing requires separate routes to connect the unit capacitor groups of each $C_{i}$. For a DAC, the bottom-plate terminals in the capacitive array are connected to switches and drivers that are clustered together outside the array, since these are noisy digital structures and the terminals must go to the bottom of the array.

We use three types of wires for routing (Fig. 8): branch wires are used to connect unit capacitors within capacitor


Fig. 8: Routing topology for $C_{4}$.


Fig. 9: Routing for a CC placement of a 6-bit DAC, (a) Connected capacitor groups formation [bottom-plate connections are shown in red], (b) Bottom plate routing, (c) Parallel wire routing, (d) Top-plate connections are shown in black.
groups, or unit capacitor groups to trunk wires, trunk wires connect disjoint connected capacitor groups along the vertical tracks, and bridge wires connect trunk wires at the periphery of the array (the definition of all the wires are represented in Fig. 8). The detailed routing method is outlined in an Algorithm in our previous work [19], and consists of three steps: channel selection, track assignment, and routing.
In FinFET nodes under discrete wire widths we use multiple parallel wires for critical bits to reduce resistance and improve 3 dB frequency, we use multiple parallel wires for critical bits. Using multiple parallel wires allow multiple parallel vias with every change in wire direction. Fig. 9(c) shows bottom-plate connections using two parallel wires.
3) Top-plate routing: The objective of top-plate routing is to minimize the top-plate to substrate parasitic capacitance $\left(C^{T S}\right)$. We create a graph $G$ such that each vertex $v \in G$ is a unit capacitor for any $C_{i}$ (since all $C_{i}$ top plates must be connected). Each unit capacitor is connected to its north, south, east, and west neighbor (if they exist), with an edge weight corresponding to the horizontal or vertical spacing, as applicable. In our case, since the vertical space between unit capacitors is less than the horizontal spacing for channels, the minimum spanning tree (MST) can be built by simply connecting all unit capacitors in each column using branch
wires, and then connecting the unit capacitors in adjacent columns using a branch wire. The use of this MST minimizes, shown in Fig. 9(d), the parasitic capacitance, $C_{i}^{T S}$.

## C. Layout generation for a split DAC

There are some differences between the common-centroid placement and routing algorithm for the split DAC and the binary-weighted DAC, since in the split DAC, the ratio of the capacitors and the circuit connection diagram is different from the binary-weighted DAC. This section outlines those differences.

1) Array size calculation: As in the binary-weighted DAC, to minimize the impact of systematic variations, the aspect ratio of the rectangular CC array in the split DAC is made as close to a square as possible. We calculate the array size, $r \times s$, by using an approach similar to presented in [19] for the LSB and MSB arrays. For an $N$-bit split DAC, the capacitor ratios are $\left[n_{0}: n_{1}: n_{2}: \cdots: n_{L}: n_{L+1}: n_{L+2}: \cdots\right.$ : $\left.n_{N}\right]=\left[1: 1: 2: \cdots: 2^{L-1}: 1: 2: \cdots: 2^{N-L-1}\right]$. The required number of dummy unit capacitors to complete the array is given by $D_{C}=(r \times s)-\left(\sum_{i=0}^{N} n_{i}+2\right)$. Here, the addition of the number 2 considers the case associated with the non-unit attenuation capacitor, which is implemented using two slots in the capacitor array.


Fig. 10: CC placement and routing for a split DAC.
2) Placement: A modified spiral method can be applied for the placement of the split DAC and is illustrated for 8-bit DAC using $L=4$ in Fig. 10(b), with a non-unit attenuation capacitor. The capacitors are represented by the numbers shown at the top of the schematic in Fig. 10(a). To obtain a common-centroid placement among the unit capacitors of both LSB and MSB capacitive arrays, first, we place two slots of the non-unit attenuation capacitor $C_{5}$, near the center of the array while maintaining the CC property, since it is at the center of the split DAC, connecting LSB and MSB arrays (Fig. 10(a)). Note that the actual size of each of the two capacitors for $C_{5}$ are smaller than $C_{u}$. Therefore, the relative perturbations in their values due to the routing capacitance is liable to be the largest, and can be minimized if they are placed as close to the center as possible.

Next, we consider $C_{0}, C_{1}$, and $C_{6}$, each of which has one unit capacitor, i.e., an odd number. The total number of capacitors having an odd number of unit capacitors is three, also an odd number, and this may cause asymmetry in the CC array. To achieve a CC placement, we place capacitor $C_{0}$ and $D$ (dummy) diagonally opposite to each other near the center of the CC placement to reduce the impact of process variations. We place $C_{1}$ at the first empty location along the spiral and $C_{6}$ at its diagonally symmetric location near the CC point. We also evaluated an alternative approach that places $C_{0}, C_{1}, C_{2}$, and a dummy in the inner four squares, and the two unit capacitors of $C_{5}$ in symmetric locations in the next ring: we did not find a significant difference in performance metrics between this approach and the one outlined above.

After completing the placement of the odd-numbered capacitors, we place all unit capacitors of $C_{2}$ from the LSB array, and then the unit capacitors of $C_{7}$ from the MSB array into the CC matrix, by following the spiral order from the center. The process is continued alternately (e.g., by placing all unit capacitors of $C_{3}$ next, then $C_{8}$, and so on). As in the binary-weighted DAC, whenever we place a unit capacitor at a location along a spiral, we also place another unit capacitor at its reflection to maintain the CC property.

(a)

| 11 | 11 | 5 | 5 | 11 | 11 | 5 | 5 | D |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 11 | 11 | 5 | 5 | 11 | 11 | 5 | 5 | D |
| 10 | 10 | 9 | 3 | 9 | 3 | D | 4 | 4 |
| 10 | 10 | 2 | 1 | 6 | 0 | 8 | 4 | 4 |
| 4 | 4 | 8 | D | 6 | 7 | 2 | 10 | 10 |
| 4 | 4 | D | 9 | 3 | 9 | 3 | 10 | 10 |
| D | 5 | 5 | 11 | 11 | 5 | 5 | 11 | 11 |
| D | 5 | 5 | 11 | 11 | 5 | 5 | 11 | 11 |

(c)

Fig. 11: Block chessboard placement for (a) 6-bit, (b) 8-bit, and (c) 10-bit split DAC.

Chessboard and block chessboard placement method can also be applied on split DAC. As in binary-weighted DAC we can create a complete chessboard pattern using the smaller capacitors and block chessboard pattern using larger capacitors where same block size can be applied for the larger capacitors from the LSB and MSB arrays for the same sized capacitors (e.g., block size of $C_{4}$ and $C_{9}$ can be same). During placement we place the blocks of the unit capacitors of same capacitor at the diagonal symmetric location with respect to the center as shown in Fig. 11. Block chessboard pattern can help to increase dispersion among the unit capacitors of same type of capacitor and can improve INL/DNL. However, due to increased dispersion routing induced parasitics will increase.
3) Routing: The following routing method is followed to route the capacitors of the split DAC in the CC array:
(1) Bottom plate routing: For routing the bottom plates of a split DAC for a modified spiral method, we followed a similar routing algorithm as for the binary-weighted DAC by constructing the connected capacitor groups for different capacitors as presented in Section IV-B1; next, we connect the bottom plates of those capacitor groups (Fig. 10(c)) by following the routing Algorithm outlined in [19]. The routing for a CC placement of an 8-bit split DAC shown in Fig. 10(c), where different shades of the same color is used to represent connected capacitor groups as used for the binary-weighted DAC (Fig. 9), and top-plate [bottom-plate] connections are shown in red [black]. The parallel wire routing method can also be applied on split DAC to reduce resistance and improve the 3 dB frequency as presented in [19].
(2) Attenuation capacitor routing: Unlike binary-weighted DAC in split DAC there is a non-unit attenuation capacitor and to connect two slots of the attenuation capacitor we first check for their locations in the CC array. If the slots are adjacent to each other, they can be connected during connected capacitor group formation, but if the slots of the attenuation capacitor are not adjacent an extra vertical track must be assigned to connect them.
(3) Top plate routing: The top plate connection of the capacitors in split DAC is different from the binary-weighted DAC, since the top plates of the capacitors in each side array are connected together at two different electrical nodes that are separated by an attenuation capacitor. The top plate connection between two adjacent unit capacitors of a capacitor for the LSB and MSB capacitive arrays in the horizontal and vertical directions is performed during connected capacitor group formation using breadth-first search (BFS) as presented in Section IV-B1. Later, we again use BFS on the connected capacitor groups of both LSB, and MSB arrays to connect the adjacent capacitor groups as shown in Fig. 10(c) of different capacitors.

The top plates of the connected capacitor groups which are not adjacent to any other capacitor groups in both the LSB and MSB side arrays can be connected using a minimum spanning tree (MST). We create a graph $G$ such that each vertex $v \in G$ is a connected capacitor group for any $C_{i}$ from LSB [MSB] side array. We build an MST over this graph to find an optimal connection between these capacitor groups and complete the top plate routing by connecting the top plates of different capacitors $\left(C_{i}\right)$ from each side array. This type of routing helps to minimize the top plate to substrate parasitics, $C_{L S B}^{T S}$, and $C_{M S B}^{T S}$ (Fig. 3(a) and (b)). Later we connect the attenuation capacitor between the top plates of LSB and MSB side arrays. To minimize the routing induced parasitics, we connect the attenuation capacitor with the top plates of the adjacent unit capacitors from each side array.

## V. Results and Discussion

Our approach is implemented in Python and evaluated on a commercial 12 nm technology for $N$-bit binary-weighted DAC arrays with capacitors ratios of $1: 1: 2: 4: \cdots: 2^{N-1}$, with
$N$ ranging from 6 to 10 . We evaluate four techniques: the placement in [1]; the chessboard placement [8]; spiral placement ("S") and the block chessboard ("BC") [Section IV-A]. Several BC structures are considered, as shown in Fig. 12 and the best BC result is reported. All even/odd bit DACs use the same BC structure with a full chessboard for the inner core.

Our routing approach is applied to the $S$ and BC methods. Since [8] only proposes a placement without routing, we use our router on their placement (Section IV-B).


Fig. 12: 8-bit block chessboard layouts at various granularities.

For systematic variations, the wire spacing $t_{0}$ is based on a wire pitch of 64 nm . Parasitic extraction is performed by considering the foundry-provided per-unit wire resistance $r$ and per-unit wire capacitance $c$ for each metal layer, the resistance and capacitance of a wire segment of length $l$ are, respectively, $(r \cdot l)$ and $(c \cdot l)$. For adjacent wires, if the per-unit coupling capacitance is $c_{c}(s)$ for a spacing of $s$, the coupling capacitance between two segments with overlap length $l_{\text {overlap }}$ is $\left(c_{c}(s) \cdot l_{\text {overlap }}\right)$. The per-unit models for resistance, capacitance to ground, and coupling-capacitance are taken from a commercial 12 nm process. The systematic variation parameters were set to $\gamma=10 \mathrm{ppm}, \rho_{u}=0.9$, $L_{c}=1 \mathrm{~mm}$ [1], [9], and we use $A_{f}^{2}=0.85 \% \times 1 \mathrm{fF}$ [21]. A unit capacitance value of 5 fF is used for all cases for binaryweighted DACs. The MOM capacitors are built in three metal layers, with the bottom-plate and top-plate terminals available in metal1 and metal2, respectively.

Table I shows various parameters associated with the RC parasitics for routing the binary-weighted DAC. The capacitances, $\Sigma C^{T S}$ (total top-plate-to-substrate), $\Sigma C^{\text {wire }}$ (total wiring capacitance), and $\Sigma C^{B B}$ (total bottom-plate to bottomplate), represent the parasitics shown in Fig. 2; $C^{T B}$ is negligible due to nonoverlapped routing (Section IV-B). The next set of metrics $-\Sigma N_{V}$, the total number of vias and $\Sigma L$ the total wire length - are correlated with the total resistance. Since $f_{3 d B}$ only depends on resistances on the critical bit with the largest RC delay, the last column shows the total via resistance, $R_{V}$, and the total wire+via resistance, $R_{\text {total }}$ for the critical bit.

Here, $S$ has low resistive parasitics; BC has moderate parasitics, much lower than [1], [8]. The impact of parasitic resistance can be observed in Fig. 13 for different bit DACs for different placement methods. Both S and BC use our proposed parallel routing method: when parallel routing is used on the MSB, the second-most MSB, then the third-most MSB, etc., may become critical, and parallel routing is used there too. If parallel wires need channel resources, the spacing between
columns is increased appropriately. For any number of bits for S, the only vias are at the input connection. Unit capacitors use nearest-neighbor connections using the same metal layer with no vias.


Fig. 13: Parasitic resistance for different bit DACs.
The $C^{T S}$ values for S and BC are better than those of [1]; we apply the same solution to our routing for [8] (although their subsequent work [18] leads to higher topplate wire lengths, i.e., higher $C^{T S}$ ). For other metrics ( $C^{\text {wire }}, C^{B B}, N_{V}, L$ and $R$ ), the spiral approach provides the best solution and the chessboard method [8] the worst, and the block chessboard method provides an intermediate solution.

Table II shows circuit-level metrics: Area of the routed CC binary-weighted array; $|D N L| /|I N L|$ the maximum absolute $D N L(i)$ (Eq. 17) $/ I N L(i)$ (Eq. 18); $f_{3 d B}$, the 3 dB frequency (Eq. (32)). Like [1], [8], we evaluate DNL/INL under capacitor nonidealities, assuming an ideal opamp. Area is lowest for the spiral method due to low routing overhead and comparable with other methods (except 7-bit and 9-bit solutions for [8], which double the unit capacitors). The table shows the INL/DNL vs. $f_{3 d B}$ tradeoff (particularly for $>8$ bits): $S$ has the best $f_{3 d B}$ but the worst INL/DNL; [8] is the opposite; BC is a good compromise. All INL/DNL values are below 0.5 LSB and are acceptable.

Figs. 14(a) and (b) show a Python-generated view of the placement and routing for an 8-bit DAC in a commercial 12 nm process, using the approach in [8] and our spiral placement


Fig. 14: CC layout in (a) [8] (b) spiral approach. High wirelength for [8] is inevitable: cells are spread for high dispersion.

TABLE I: CC array: Electrical metrics for binary-weighted DACs of various resolutions ( $\left.C_{u}=5 \mathrm{fF}\right)$.

| $\begin{gathered} \hline \text { \# } \\ \text { bits } \end{gathered}$ | $\sum C^{T S}(\mathrm{fF})$ |  |  |  | $\sum C^{\text {wire }}$ ( fF ) |  |  |  | $\sum C^{B B}(\mathrm{fF})$ |  |  |  | $\left(\sum N_{V}, \sum L\right)(\mu \mathrm{m})$ |  |  |  | ( $R_{V}, R_{\text {total }}$ ) ( $\mathrm{K} \Omega$ ) for critical bit |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | [1] | [8] | S | BC | [1] | [8] | S | BC | [1] | [8] | S | BC | [1] | [8] | S | BC | [1] | [8] | S | BC |
| 6 | 0.10 | 0.10 | 0.10 | 0.10 | 3.8 | 8.3 | 2.8 | 7.1 | 5.3 | 9.3 | 2.1 | 5.6 | $(34,321)$ | $(81,686)$ | (118, 243) | $(154,583)$ | (0.2, 1.2) | (1.1, 3.6) | (0.002, 0.05) | (0.01, 1.1) |
| 7 | - | 0.38 | 0.20 | 0.22 | - | 36.9 | 4.5 | 7.0.0 | - | 70.3 | 3.7 | 9.1 | - | $(295,2993)$ | $(76,385)$ | $(110,591)$ | - | (4.1, 14.0) | (0.002, 0.09) | (0.002, 1.7) |
| 8 | 0.40 | 0.38 | 0.38 | 0.38 | 12.3 | 36.6 | 5.8 | 18.5.0 | 17.6 | 73.3 | 6.1 | 15.8 | $(60,1042)$ | $(295,3012)$ | $(60,514)$ | $(234,1535)$ | (0.3, 4.1) | (4.1, 14.0) | (0.002, 0.16) | (0.02, 0.67) |
| 9 | 0.72 | 1.54 | 0.76 | 0.78 | 15.3 | 162.8 | 10.1 | 19.7 | 61.0 | 633.0 | 9.6 | 22.8 | $(143,1319)$ | $(1126,13299)$ | $(78,907)$ | (190, 1682) | (1.2, 6.9) | (15.8, 56.3) | (0.002, 0.28) | (0.002, 3.3) |
| 10 | - | 1.54 | 1.50 | 1.50 | - | 163.9 | 17.6 | 49.5 | - | 634.7 | 16.7 | 66.6 | - | $(1126,13308)$ | $(92,1596)$ | $(473,4165)$ | - | (15.8, 56.3) | (0.002, 0.58) | (0.02, 1.60) |
| ote |  | 8] doubles the number of unit capacitors for odd bits $\Rightarrow$ \{7-bit, 8-bit $\}$, \{9-bit, 10-bit $\}$ results are similar. (2) 7-bit, 9-bit DACs not reported in [1] |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

TABLE II: CC array: Performance metrics for binary-weighted DACs of various resolutions ( $C_{u}=5 \mathrm{fF}$ ).

| $\begin{gathered} \hline \# \\ \text { bits } \end{gathered}$ | Area ( $\mu \mathrm{m}^{2}$ ) |  |  |  | $\{\|D N L\|,\|I N L\|\}$ (LSB) |  |  |  | $f_{3 d B}(\mathrm{MHz})$ |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | [1] | [8] | S | BC | [1] | [8] | S | BC | [1] | [8] | S | BC |
| 6 | 629 | 634 | 622 | 634 | \{0.00,0.02\} | \{0.00,0.02\} | \{0.01,0.02\} | \{0.01,0.02\} | 947 | 313 | 21179 | 3883 |
| 7 | - | 2541 | 1293 | 1421 | - | \{0.01,0.03\} | \{0.02,0.04\} | \{0.02,0.03\} | - | 18 | 5505 | 1197 |
| 8 | 2641 | 2541 | 2509 | 2541 | \{0.00,0.08\} | \{0.01,0.06\} | \{0.05,0.08\} | \{0.02,0.07\} | 56 | 16 | 1411 | 339 |
| 9 | 5354 | 10627 | 5085 | 5224 | \{0.01,0.14\} | \{0.02,0.14\} | \{0.12,0.16\} | \{0.11,0.15\} | 15 | 0.9 | 361 | 123 |
| 10 | - | 10627 | 10076 | 10157 | - | \{0.05,0.30\} | \{0.22,0.31\} | \{0.11,0.30\} | - | 0.8 | 81 | 29 |

TABLE III: CC array: Performance metrics ( $\{|D N L|,|I N L|\}$ (LSB)) for binary-weighted DACs of various resolutions, varying the linear process gradient coefficient, $\gamma\left(C_{u}=5 \mathrm{fF}, \rho_{0}=0.9\right)$.

| $\gamma$ | $[8]$ |  |  |  | S |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 6-bit | 8-bit | 10-bit | 6-bit | -bit | 10-bit |
| 1 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.05,0.31\}$ | $\{0.01,0.02\}$ | $\{0.06,0.08\}$ | $\{0.27,0.31\}$ |
| 10 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.05,0.31\}$ | $\{0.01,0.02\}$ | $\{0.05,0.08\}$ | $\{0.22,0.31\}$ |
| 100 | $\{0.01,0.02\}$ | $\{0.02,0.09\}$ | $\{0.06,0.34\}$ | $\{0.01,0.02\}$ | $\{0.27,0.17\}$ | $\{4.93,2.56\}$ |

TABLE IV: CC array: Performance metrics ( $\{|D N L|,|I N L|\}$ (LSB)) for binary-weighted DACs of various resolutions, varying the correlation coefficient $\rho_{u}\left(C_{u}=5 \mathrm{fF}, \gamma=10 \mathrm{ppm}\right)$.

| $\rho_{u}$ | [8] |  |  |  | S |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 6-bit | 8-bit | 10-bit | 6-bit | -bit | 10-bit |
| 0.10 | $\{0.00,0.02\}$ | $\{0.00,0.08\}$ | $\{0.00,0.31\}$ | $\{0.00,0.02\}$ | $\{0.00,0.08\}$ | $\{0.05,0.30\}$ |
| 0.50 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.01,0.31\}$ | $\{0.02,0.02\}$ | $\{0.02,0.08\}$ | $\{0.03,0.30\}$ |
| 0.70 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.02,0.31\}$ | $\{0.02,0.02\}$ | $\{0.05,0.08\}$ | $\{0.07,0.30\}$ |
| 0.75 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.03,0.31\}$ | $\{0.02,0.02\}$ | $\{0.06,0.08\}$ | $\{0.09,0.30\}$ |
| 0.80 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.03,0.31\}$ | $\{0.01,0.02\}$ | $\{0.06,0.08\}$ | $\{0.13,0.30\}$ |
| 0.85 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.04,0.31\}$ | $\{0.01,0.02\}$ | $\{0.06,0.08\}$ | $\{0.18,0.30\}$ |
| 0.90 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.05,0.31\}$ | $\{0.01,0.02\}$ | $\{0.05,0.08\}$ | $\{0.22,0.30\}$ |
| 0.95 | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.04,0.31\}$ | $\{0.01,0.02\}$ | $\{0.03,0.08\}$ | $\{0.19,0.30\}$ |
| 0.99 | $\{0.00,0.02\}$ | $\{0.00,0.08\}$ | $\{0.01,0.31\}$ | $\{0.00,0.02\}$ | $\{0.01,0.08\}$ | $\{0.02,0.29\}$ |
| 0.999 | $\{0.00,0.02\}$ | $\{0.00,0.08\}$ | $\{0.00,0.31\}$ | $\{0.00,0.02\}$ | $\{0.00,0.08\}$ | $\{0.04,0.29\}$ |

method, respectively. While the former requires five vertical tracks in the vertical channels, the spiral approach, even with parallel routes, requires two routing tracks, resulting in lower $C^{B B}$, as documented by the total $C^{B B}$ number in Table I. The total routing wirelength is significantly higher for the placement of [8], leading to higher $C^{\text {wire }}$ parasitics, as shown in the same table. Both factors degrade the 3 dB frequency of [8]. This effect is worse as the number of bits in the DAC increases.

In FinFET nodes, $N_{V}$ adversely affects performance due to high via resistance. The spiral method uses the fewest vias of all methods, and the chessboard method [8] uses the most. Fig. 15(a) shows the impact of using parallel routes, which reduce interconnect resistance, on the 3 dB frequency for spiral placement. We show the frequency improvement factor, where the ratio of the 3 dB frequency using $k$ wires vs. using one wire (i.e., a value of $\geq 1$ represents an improvement). The increase in parasitic capacitance due to parallel wires is minimal and is dominated by the capacitance in the array, but the wire resistance reduction is significant. As $k$ increases, we see diminishing returns. Similar trends are seen for the block chessboard scheme. When two parallel wires are used, the frequency improvement factor exceeds 2 : for this resistance-
dominated case, the connection from the trunk wire to a branch wire creates a $2 \times 2$ mesh with four vias. The gain lies between $2 \times$ (wire-dominated case) and $4 \times$ (via-dominated case). With more wires, the wire capacitance becomes noticeable, leading to lower improvement and we do not get the improvement in terms of frequency by a factor of k. Fig. 15(b) shows the impact of parallel wires for all methods, normalized to the 3 dB frequency for S . Both BC and [1] improve, but have much lower baseline frequencies than $S$; chessboard [8] is bottlenecked by high via counts.

Table V shows the results for the split DAC with two parallel wires for routing for $C_{u}=5 \mathrm{fF}$ for 6-bit to 12 -bit and 10 fF for 14-bit for both spiral and block chessboard placement. Here, we use similar systematic variation parameters as for the binary-weighted DAC. Various parameters associated with the RC parasitics for routing for the split DAC are shown in the table. The capacitances, $\Sigma C^{T S}, \Sigma C^{\text {wire }}$, and $\Sigma C^{B B}$, represent the total parasitics for the circuit shown in Fig. 3; noting that the parasitics from the LSB and MSB side arrays are added; $C^{T B}$ from each side array is negligible due to nonoverlapped routing used for connected capacitor group formation. The total number of vias $\Sigma N_{V}$, and the total wire length, $\Sigma L$, of the capacitor array are listed next. We

TABLE V: CC array: Electrical and performance metrics for split DACs.

| \# bits bits | $\sum C^{T S}(\mathrm{fF})$ |  | $\sum C^{\text {wire }}$ (fF) |  | $\sum C^{B B}(\mathrm{fF})$ |  | $\left(\sum N_{V}, \sum L\right)(\mu \mathrm{m})$ |  | $\left(R_{V}, R_{\text {total }}\right)(\mathrm{K} \Omega)$ for critical bit  <br> S BC |  | Area ( $\mu \mathrm{m}^{2}$ ) |  | $\{\|D N L\|,\|I N L\|\}$ (LSB) |  | $f_{3 d B}(\mathrm{MHz})$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | S | BC | S | BC | S | BC | S | BC |  |  | S | BC | S | BC | S | BC |
| 6 | 0.03 | 0.03 | 2.37 | 2.97 | 0.58 | 0.72 | $(45,194)$ | $(70,243)$ | (0.02, 0.34) | (0.05, 0.67) | 194 | 193 | (0.01, 0.01) | (0.03, 0.00) | 47569 | 33572 |
| 8 | 0.06 | 0.06 | 3.87 | 5.29 | 1.68 | 1.60 | $(65,319)$ | $(85,433)$ | (0.03, 0.38) | (0.03, 0.73) | 362 | 353 | (0.06, 0.04) | (0.04, 0.03) | 19977 | 15256 |
| 10 | 0.12 | 0.11 | 6.47 | 9.34 | 6.62 | 7.85 | $(68,534)$ | $(105,766)$ | (0.02, 0.71) | (0.05, 0.78) | 724 | 719 | (0.14, 0.10) | (0.12, 0.08) | 8153 | 3615 |
| 12 | 0.20 | 0.21 | 7.98 | 12.4 | 7.16 | 12.23 | $(65,666)$ | $(100,1024)$ | (0.02, 0.72) | (0.03, 0.84) | 1302 | 1339 | (0.17, 0.16) | (0.13, 0.17) | 2136 | 1504 |
| 14 | 0.43 | 0.41 | 11.4 | 23.4 | 24.48 | 26.55 | (72, 970) | $(126,1932)$ | (0.03, 1.61) | (0.05, 1.64) | 2809 | 2719 | (0.49, 0.31) | (0.51, 0.20) | 484 | 169 |

TABLE VI: Runtimes for the proposed CC layout algorithms for binary-weighted DACs

| \#bits | 6 -bit | 7-bit | -bit | 9 -bit | 10 -bit |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Spiral | 0.02 s | 0.04 s | 0.12 s | 0.35 s | 1.11 s |
| BC | 0.03 s | 0.05 s | 0.19 s | 0.38 s | 2.25 s |



Fig. 15: 8-bit CC array with parallel wires: 3 dB frequency improvements for (a) the spiral method. (b) all methods.
also list the total via resistance, $R_{V}$, and the total wire+via resistance, $R_{\text {total }}$ for the critical bit. The capacitive routinginduced parasitics for the split DAC are comparable with the binary-weighted DAC. The resistive parasitics for the split DAC for the critical bit are higher than the binary-weighted DAC since in binary-weighted DAC all the unit capacitors for the critical bit form a connected capacitor group and it requires a very short routing wire to connect the connected capacitor group with the switches and drivers; therefore, we use two parallel wires for routing the capacitors of the split DAC, whereas we used four parallel wires for routing the binaryweighted DAC.

In Table V we also have listed Area; the maximum absolute $D N L(i) / I N L(i) ; f_{3 d B}$ for the split DAC. The INL/DNL for the split DAC as shown in the Table V is comparable with the INL/DNL of the binary-weighted DAC (Table II), at the same time it can provide significantly better area and frequency since the total amount of unit capacitors is lower for the split DAC. The main advantage of the split DAC is that it can provide good performance in terms of INL/DNL and 3 dB frequency $\left(f_{3 d B}\right)$ while using a smaller silicon area than binary-weighted DAC. From the table it can be observed that for block chessboard method the wire parasitics and wire lengths are slightly higher than the spiral, but the INL/DNL is better for block chessboard method from the spiral method.

Fig. 16(a), and (b) show the generated layout, visualized using Virtuoso, based on the GDS generated by our proposed spiral placement approach for 8-bit binary-weighted and split DAC, respectively. As can be observed from the figures and the comparison table (Fig. 16(c)), the layout area for the split DAC is significantly lower than the binary-weighted DAC.

(a)

(b)

| $8-$ bit <br> DAC | Binary- <br> weighted | Split |
| :---: | :---: | :---: |
| Area <br> $\left(\mu m^{2}\right)$ | 2509 | 362 |
| $\mathrm{f}_{3 \mathrm{~dB}}$ <br> $(\mathrm{MHz})$ | 1411 | 19977 |
| $\|\mathrm{DNL}\|$ | 0.05 | 0.06 |
| $\|\mathrm{INL}\|$ | 0.08 | 0.04 |

(c)

Fig. 16: CC layout of 8-bit (a) binary-weighted, and (b) split DAC, (c) comparison result table.

Since the number of unit capacitors for the split DAC is much less than the binary-weighted DAC, 3dB frequency $\left(f_{3 d B}\right)$ is considerably higher for the split DAC. Finally, the absolute maximum INL/DNL values are comparable for both of the DACs as shown in the table attached in Fig. 16(c).

The CPU times for both the spiral method and for each block chessboard are similar and are reported in Table VI for binary-weighted DACs. Because the method is constructive, it is much faster than stochastic optimization, while providing excellent quality of result. For split DAC the number of unit capacitors is much smaller than the binary-weighted DAC with the same number of bits, and the CPU times are therefore much smaller than these already small runtimes for the binary DACs.

The choice of $\rho_{0}=0.9$ and $\gamma=10 \mathrm{ppm}$ is based on prior work [1], [20]. In [23], a variational model for resistors, rather than capacitors is used, and this model has been assumed to be reasonable for other passives such as capacitors; work in [27] develops an exponential model for transistor variations. To our knowledge, there is no reported measured value for correlations in capacitive structures: correlation is alluded to in [21], but only data for uncorrelated variations are reported. The value of $\rho_{0}=0.9$ and $\gamma=10 \mathrm{ppm}$ has cascaded down from older papers such as [6].

Therefore, we show the INL and DNL for a 6-bit, 8-bit, and 10-bit binary-weighted DAC, for a range of values of $\rho_{0}$ and $\gamma$ in Tables IV and III, respectively, under spiral placement and chessboard placement. When $\rho_{0}$ is varied, we keep $\gamma$ fixed at 10 ppm , and when $\gamma$ is varied, we keep $\rho_{0}$ fixed at 0.9 . It can be seen that the precise dependency of the INL and DNL on $\rho_{0}$ and $\gamma$ is not monotonic. This is because the INL and DNL expressions depend on $V_{\text {out }}$, which in turn depend on the relative values of the uncorrelated capacitance variations,
correlated capacitance variations, and the wire parasitics. At different entries of these tables, different components become more dominant, leading to this nonmonotonicity.

It should be noted that in Table III, as $\gamma$ is increased, the variation in the oxide thickness $t$ increases linearly. Since the capacitance $C=C_{u}\left(t_{0} / t\right)$ is nonlinearly related to $t$, the linear approximation to $C$ becomes increasingly inaccurate as $t$ deviates from its nominal value, $t_{0}$. Thus, for higher values of $\gamma$, these nonlinearities become more prominent, reducing the ability of common-centroid layouts to cancel variations. As a result, we see that the DNL and INL generally worsen for large values of $\gamma$, overcoming smaller nonmonotonicities at lower values of $\gamma$.

## VI. Conclusion

A set of routing-conscious, constructive common-centroid placement methods, followed by a routing step, are proposed in this work. These methods attempt to optimize systematic and random mismatches in order to improve performance and accuracy for both binary-weighted and split DACs. To the best of our knowledge, this is the first work in the literature to propose models to evaluate tradeoffs between linearity metrics as well as the 3 dB frequency for binary-weighted DACs, and the first to automate CC layout generation for split DACs. For the split DAC, a method to determine the size of the nonunit capacitor, which is used as the attenuation capacitor, is also presented. Two different types of placement methods, the spiral and block chessboard methods, have been presented and experimental results show that a balance between INL/DNL and 3 dB frequency can be achieved by trading off wire parasitics with dispersion.

## REFERENCES

[1] M. P.-H. Lin, Y.-T. He, V. W.-H. Hsiao, R.-G. Chang, and S.-Y. Lee, "Common-Centroid Capacitor Layout Generation Considering Device Matching and Parasitic Minimization," IEEE Transactions on ComputerAided Design of Integrated Circuits and Systems, vol. 32, pp. 991-1002, 2013.
[2] W.-H. Hsiao, Y.-T. He, M. P.-H. Lin, R.-G. Chang, and S.-Y. Lee, "Automatic Common-Centroid Layout Generation for Binary-Weighted Capacitors in Charge-Scaling DAC," in Proceedings of the IEEE International Conference on Synthesis, Modeling, Analysis and Simulation Methods and Applications to Circuit Design, 2012, pp. 173-176.
[3] A. Hastings, The Art of Analog Layout. Upper Saddle River, NJ: Prentice-Hall, 2001
[4] N. Karmokar, M. Madhusudan, A. K. Sharma, R. Harjani, M. P.-H. Lin, and S. S. Sapatnekar, "Common-Centroid Layout for Active and Passive Devices: A Review and the Road Ahead," in Proceedings of the Asia-South Pacific Design Automation Conference, 2022.
[5] D. Sayed and M. Dessouky, "Automatic Generation of CommonCentroid Capacitor Arrays with Arbitrary Capacitor Ratio," in Proceedings of the Design, Automation \& Test in Europe, 2002, pp. 576-580.
[6] P.-W. Luo, J.-E. Chen, C.-L. Wey, L.-C. Cheng, J.-J. Chen, and W.C. Wu, "Impact of Capacitance Correlation on Yield Enhancement of Mixed-Signal/Analog Integrated Circuits," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 27, pp. 2097-2101, 2008.
[7] C.-C. Huang, J.-E. Chen, and C.-L. Wey, "PACES: A Partition-Centering-Based Symmetry Placement for Binary-Weighted Unit Capacitor Arrays," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 36, pp. 134-145, 2016.
[8] F. Burcea, H. Habal, and H. E. Graeb, "A New Chessboard Placement and Sizing Method for Capacitors in a Charge-Scaling DAC by WorstCase Analysis of Nonlinearity," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 35, pp. 1397-1410, 2015.
[9] M. P.-H. Lin, V. W.-H. Hsiao, C.-Y. Lin, and N.-C. Chen, "ParasiticAware Common-Centroid Binary-Weighted Capacitor Layout Generation Integrating Placement, Routing, and Unit Capacitor Sizing," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 36, pp. 1274-1286, 2017.
[10] N.-C. Chen, P.-Y. Chou, H. Graeb, and M. P.-H. Lin, "High-Density MOM Capacitor Array with Novel Mortise-Tenon Structure for LowPower SAR ADC," in Proceedings of the Design, Automation \& Test in Europe, 2017, pp. 1757-1762.
[11] P.-Y. Chou, N.-C. Chen, M. P.-H. Lin, and H. Graeb, "MatchedRouting Common-Centroid 3-D MOM Capacitors for Low-Power Data Converters," IEEE Transactions on VLSI Systems, vol. 25, pp. 22342247, 2017.
[12] Y. Zhu, U.-F. Chio, H.-G. Wei, S.-W. Sin, U. Seng-Pan, and R. P. Martins, "Linearity Analysis on a Series-Split Capacitor Array for HighSpeed SAR ADCs," in 2008 51st Midwest Symposium on Circuits and Systems. IEEE, 2008, pp. 922-925.
[13] R. J. Baker, CMOS Circuit Design, Layout and Simulation, 3rd ed. Piscataway, NJ: IEEE Press, 2010.
[14] Y. Chen, X. Zhu, H. Tamura, M. Kibune, Y. Tomita, T. Hamada, M. Yoshioka, K. Ishikawa, T. Takayama, J. Ogawa et al., "Split Capacitor DAC Mismatch Calibration in Successive Approximation ADC," IEICE Transactions on Electronics, vol. 93, no. 3, pp. 295-302, 2010.
[15] A. Agnes, E. Bonizzoni, P. Malcovati, and F. Maloberti, "A 9.4-ENOB 1V $3.8 \mu \mathrm{~W} 100 \mathrm{kS} / \mathrm{s}$ SAR ADC with Time-Domain Comparator," in Proceedings of the IEEE International Solid-State Circuits Conference. IEEE, 2008, pp. 246-610.
[16] D. A. Johns and K. Martin, Analog Integrated Circuit Design. John Wiley \& Sons, 2008.
[17] K.-H. Ho, H.-C. Ou, Y.-W. Chang, and H.-F. Tsao, "Coupling-Aware Length-Ratio-Matching Routing for Capacitor Arrays in Analog Integrated Circuits," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 34, pp. 161-172, 2014.
[18] Y. X. Ding, F. Burcea, H. Habal, and H. E. Graeb, "PASTEL: Parasitic Matching-Driven Placement and Routing of Capacitor Arrays With Generalized Ratios in Charge-Redistribution SAR-ADCs," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 39, pp. 1372-1385, 2019.
[19] N. Karmokar, A. K. Sharma, J. Poojary, M. Madhusudan, R. Harjani, and S. S. Sapatnekar, "Constructive common-centroid placement and routing for binary-weighted capacitor arrays," in Proceedings of the Design, Automation \& Test in Europe. IEEE, 2022, pp. 166-171.
[20] C.-W. Lin, J.-M. Lin, Y.-C. Chiu, C.-P. Huang, and S.-J. Chang, "Mismatch-Aware Common-Centroid Placement for Arbitrary-Ratio Capacitor Arrays Considering Dummy Capacitors," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 31, pp. 1789-1802, 2012.
[21] V. Tripathi and B. Murmann, "Mismatch Characterization of Small Metal Fringe Capacitors," IEEE Transactions on Circuits and Systems I, vol. 61, pp. 2236-2242, 2014.
[22] M. J. Pelgrom and A. C. Duinmaijer, "Matching Properties of MOS Transistors," in Proceedings of the European Solid-State Circuits Conference, 1988, pp. 327-330.
[23] C. S. Conroy, W. Lane, and M. Moran, "Statistical design techniques for d/a converters," IEEE Journal of Solid-State Circuits, vol. 24, no. 4, pp. 1118-1128, 1989.
[24] F. Maloberti, Data Converters. New York, NY: Springer, 2007
[25] S. S. Sapatnekar, Timing. Boston, MA: Kluwer, 2004.
[26] G. Chen, B. Liu, S. Nakatake, and B. Yang, "Routability of Twisted Common-Centroid Capacitor Array Under Signal Coupling Constraints," in Proceedings of the IEEE International Midwest Symposium on Circuits and Systems, 2016.
[27] J. Xiong, V. Zolotov, and L. He, "Robust extraction of spatial correlation," IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 26, no. 4, pp. 619-631, 2007.


[^0]:    ${ }^{1}$ Note that this differs from the scenario in Fig. 3, where multiple bits in the MSB/LSB array may be switched on; here, to calculate the 3 dB frequency for bit $k$, only bit $k$ is activated and all others are set to 0 .

[^1]:    ${ }^{2}$ In case of uncorrelated random variations, MSB capacitors will show a lower $\sigma / \mu$ variation, and for a sum of $n$ random variables, $\mu=n \mu_{u}, \sigma=$ $\sqrt{n} \sigma_{u}$, where $\mu_{u}$ and $\sigma_{u}$ are the variances of $C_{u}$. As a result, in general, we observe that the relative variations in MSB capacitance values is less than for LSB capacitors. Note that the deviation in the capacitor ratio (i.e., the ratio of $C_{k} / C_{0}$ ) depends on $C_{0}$, which shows significant variations.

