Abstract-Double patterning lithography, where one-layer layout is decomposed into two masks, is believed to be inevitable for 32nm technology node of the ITRS roadmap. However, post-routing layer assignment, which decides the layout pattern on each layer, thus having great impact on double patterning related parameters, has not been explored in the merit of double patterning. In this paper, we propose a post-routing layer assignment algorithm for double patterning optimization. Our solution consists of three major phases: multi-layer assignment, single-layer double patterning, and via reduction. For phase one and three, multi-layer graph is constructed and dynamic programming is employed to solve optimization problem on this graph. In the second phase, single-layer double patterning is proved NPhard and existing algorithm is implemented to optimize single layer double patterning problem. The proposed method is tested on CBL (Collaborative Benchmarking Laboratory) benchmarks and shows great performance. In comparison with single-layer double patterning, our method achieves 73% and 27% average reduction for unresolvable conflicts and stitches respectively, with only 9% increase of via number. When double patterning is constrained on only the bottom two metal layers as in current technology, these numbers become 62%, 8% and 0.42%.
I. INTRODUCTION
As feature sizes keep shrinking to 32nm while new lithography techniques such as extreme ultra violet and high index fluids immersion have yet to come, double patterning lithography has become one of the most promising lithography process for 32nm node and beyond. Double patterning technique strives to decompose features on critical layer of layout with spacing less than a predefined threshold into two masks. Features can be sliced for further decomposition, which results in additional cost of stitches. However, due to the high density of a layout, it is still possible that double patterning conflict cannot be resolved even with feature slicing [1] . The problem of how to minimize the number of the unresolvable double patterning conflict (URC) and stitch number has recently drawn much attention. Much work [1] , [2] , [3] , [4] has been proposed to solve this problem. Although all of these algorithms are heuristics, the complexity of double patterning problem has not been theoretically proved. Only the authors of [2] claimed that they believe double patterning problem is NP-hard.
Kahng et al. [1] formulated the single-layer double patterning problem as an odd cycle elimination problem. In their work, odd cycles are detected after the construction of conflict graph. Then each detected cycle is eliminated by node splitting, which introduces a stitch. The proposed node splitting approach has been widely used in later work. In [4] , double patterning problem is formulated as a max-cut problem. Equipped with graph size reduction techniques, the problem is solved efficiently, which makes it possible to decompose some huge layouts. In spite of the great effort of [1] and [4] on reducing URC's and stitches, there are still many conflicts that cannot be resolved in designs, especially in those with high feature density.
To further reduce the number of unresolvable conflicts, it is better to consider double patterning in early stages of IC design flow. In [2] , [3] , double patterning friendly detailed routing is proposed. Congested features are generally avoided in detailed routing stage, with additive double patterning penalty included in maze routing. This pioneer work focuses on the design patterns of a single layer. Following this direction and extending the design consideration to multiple layers, we propose in this work to use post-routing layer assignment to improve the quality of double patterning. Our proposal is based on two major reasons. First, post-routing layer assignment deals with multiple layers and has a good opportunity to consider the interaction among features from different layers. Secondly, the input data of post-routing layer assignment is the layout after detailed routing, which is the same as existing double * Corresponding author. E-mail: xzeng@fudan.edu.cn patterning techniques. Therefore, it can be effortlessly integrated into the current design flow.
In post-routing layer assignment, wire segments are re-assigned to proper metal layers to improve design parameters such as via numbers and wire capacitance. Via minimization problem has been well studied for several decades. Algorithms for both two-layer assignments [5] , three-layer assignments [6] , and multi-layer assignments [7] have been proposed. In [7] , the multi-layer assignment problem is represented by an extended-continuation-conflict graph and a dynamic programming heuristic is used to solve the optimization problem on the graph. We leverage the similar philosophy and technique in our layer assignment algorithm. However, double patterning optimization makes our problem more challenging.
In this work, we developed a systematic post-routing layer assignment algorithm to effectively and efficiently address the double patterning problem. Our approach contains three major phases: (1) multi-layer assignment considering double patterning risk, (2) single-layer double patterning, and (3) via reduction. In phase one and three, we first construct multi-layer graph. Dynamic programming is then employed to solve optimization problem on this graph. The second phase, singlelayer double patterning, is proved NP-hard. Single-layer double patterning algorithm proposed in [4] is conducted on all layers in this phase. The effectiveness and efficiency of our approach is demonstrated through experiments on several test cases of very different sizes. Compared with directly single-layer double patterning, the number of URC is decreased by 73%, and number of stitches is reduced by 27% in average, with only 9% increase of via numbers. When double patterning is constrained only on the bottom two metal layers as in current technology, these numbers change to 62%, 8% and 0.42%, which is more desired in via number critical designs. Our key contributions include:
• The NP-hardness proof of the single-layer double patterning problem, which settles an important open problem; • The formulation of the double patterning layer assignment problem to achieve better benefits with global view; • The three-phase algorithm that effectively and efficiently solves the double patterning layer assignment problem.
The rest of this paper is organized as follows. The motivation of our work and double patterning layer assignment problem formulation is given in Section II. Section III gives the general flow of our double patterning layer assignment algorithm, and the details of the algorithm phases are individually described in Section IV. NP-hardness of singlelayer double patterning is proved in Section IV-C. Section V gives the experimental results. Section VI concludes this work.
II. MOTIVATION AND PROBLEM FORMULATION
It is well known that feature slicing cannot resolve all double patterning conflicts. As is shown in Fig.1(a) , when single-layer double patterning is conducted directly on the given layout, even with feature slicing, a double patterning conflict is inevitable. In previous double patterning work, area-increasing layout adjustment is required to resolve such conflict. But actually, the conflict can be easily eliminated by exchanging some features between two metal layers with two more vias introduced, as demonstrated in Fig.1(b) . The example shows the potential that, with double patterning consideration in layer assignment, some of URC can be eliminated with a few via increase. This motivates us to consider double patterning during post-routing layer assignment. Notice that although the given layout instance is bidirectionally routed, general layout also have the same chance to eliminate unresolvable conflicts by layer assignment. All the discussions and algorithms through the following sections are appropriate for general layout. We formulate the double patterning layer assignment problem as follows.
978
Given: Post routing valid multi-layer layout; critical distance; position of via candidate insertion points; via size of each via candidate; number of layers that requires double patterning k; minimum distance d dp for double patterning conflict and minimum stitch overlap length o.
Find: Layer assignment and color assignment solution for all features to minimize the cost function,
where α, β, γ are weighting constants, and URC indicates UnResolvable double patterning Conflict, which is the most important factor in our problem. Subject to: (i) The layer and color assignment are both valid (Section IV-A and IV-B) for each feature; (ii) No open or short circuit is induced during the assignment (If that is violated, big penalty number is added into the objective function. Section IV-A).
III. GENERAL IDEA AND FRAMEWORK OVERVIEW Even though layer assignment and double patterning have been studied intensively, the double patterning layer assignment problem has not been attacked. Since the layer assignment is known to be NPhard [6] , and we proved the double patterning problem is also NP-hard in Section IV-C, it is intractable to exactly solve it in polynomial time. A good heuristic algorithm will thus be developed.
In previous double patterning studies [1] , [4] , a double patterning conflict graph is constructed for each layer of layout. Rectangles on the mask are represented by graph nodes, and relationships among them are denoted with double patterning conflict edges and touching edges. Node bi-coloring solution is then found for the graph to maximize the number of differently colored conflicting edges and uniformly colored touching edges.
In traditional multi-layer via minimization layer assignment problem [7] , the extended-continuation-conflict graph is constructed from the multi-layer layout, where wire segments and via candidates are represented by graph nodes and two kinds of edges, conflict edges and continuation edges, exist in the graph. Subsequent optimization program tries to find layer assignments for all nodes to minimize the number of vias without inducing open or short circuit.
We find that the conflict graph in double patterning and the extendedcontinuation-conflict graph in layer assignment have similar structures, which makes it possible to combine them together to solve our multilayer double patterning layer assignment problem. Based on this observation, we develop the Double Patterning Layer Assignment algorithm (DPLA). In DPLA, the double patterning conflict edge in conflict graph of single-layer double patterning is referred as Double Patterning Risk. As shown in Fig. 2 , the DPLA algorithm consists three phases:
• Multi-layer assignment, where double pattering risks and vias are minimized simultaneously; • Single-layer double patterning, where unresolvable conflicts and stitches on each layer are minimized; • Via reduction, where vias number is reduced without increasing unresolvable conflicts.
Post-Routing Layout
Constructing In phase 1, given a valid multi-layer layout, a graph is first constructed to represents all types of relationships among features on all layers. Dynamic programming technique is then employed to solve this optimization problem on iteratively generated induced trees. At the end of these operations, the summation of the numbers of vias and double patterning conflicts is minimized.
In phase 2, double patterning layout decomposition is operated on each of the layers generated in phase 1. We implement the algorithm proposed in [4] for this phase. Due to the double patterning conflict minimization considered in phase 1, the layout decomposition encounters less URC's and stitches.
The first two phases mainly target at the conflicts and the stitches but not the vias. Because of that reason, there are cases where the numbers of URC's and stitches are reduced at a large expenses of extra vias. Redundant vias might be introduced to reduce resolvable conflicts, which makes room for further optimization. Phase 3 is employed to further reduce the redundant vias introduced. In this phase, the graph constructed in phase 1 is updated with coloring information coded on each node (Section IV-B). Based on the new graph, a dynamic programming heuristic is developed to improve the quality of the solution.
IV. LAYER ASSIGNMENT FOR DOUBLE PATTERNING
In this section, we present the detailed algorithms in the first and third phases of our layer assignment for double patterning. We also provide a proof that the single-layer double patterning problem is NP-hard, where we use an existing heuristic [4] to solve the problem.
A. Multi-Layer Assignment
The first phase is an effective multi-layer assignment method to minimize the numbers of both double patterning risks and vias.
Given a post-routing multi-layer layout, the wires are partitioned into a bunch of wire segments based on via candidate insertion positions. Each of the wire segments is mapped to a graph node (vseg). At each end of every wire segment, a via node (vvia) is added to the graph node set. According to the electrical connection relationship, continuation edges (econ) are introduced between segments of the same net. A segment is always connected to its via nodes. Two electrically connected vseg's are separated by a via candidate (vvia), and therefore connection like vsegvseg-econ does not exist. vvia-vvia-econ does not exist, either, because two vvia's should be merged into one if they are electrically connected. After continuation edges are connected, crossing edges (eX ) and double patterning edges (e dp ) are also inserted into the graph. For each node, the distances from itself to all of its neighboring non-econ-connected nodes from different nets are measured. If the distance between two nodes is equal to or less than critical distance, eX is added for this node pair. If the distance is greater than critical distance but smaller than the length of double patterning conflict minimum distance d dp , e dp connects them then. eX and e dp exist between vseg-vvia, vseg-vseg and vvia-vvia. The meaning of the three kinds of edges can be denoted like this:
• econ: node-pair it connects has to be assigned to connected layers in the resultant circuit, otherwise, open circuit is introduced.
• eX : node-pair it connects cannot be assigned to connected layers, otherwise, short circuit is introduced.
• e dp : node-pair it connects should be assigned to unconnected layers as much as possible to minimize the double patterning risks between them. "Connected layers" is used instead of "the same layer" because the layer assignment of vvia is not as simple as vseg. The layer assignment of node is explained in the following part.
We have a decision variable lv giving the layer assigned to each v ∈ V . The range of this variable is different for a segment and a via. It is {0, · · · , k−1} for segments where k is the number of layers. For vias, it is
which is a set of integer pairs. It is inconvenient to handle these two ranges at the same time. So, for vvia, the integer pairs (x, y) are mapped to integers
. Then both vseg and vvia have integral range with different feasible region. They are denoted
vseg and vvia, respectively. The weight of node is stored in a vector wv for v, which denotes via height under different layer assignments for vvia, and is zero vector for vseg.
Edges econ and eX have weight matrix M (u,v) . The size of the matrix is determined by its two connected nodes. Each entry of the matrix stands for the electrical connection correctness of the two connected nodes with corresponding layer assignment. After the layer assignments of nodes are decoded into medal layers, whether the two connected nodes share the same medal layer can be easily checked. Recalling the introduction of econ/eX , if two connected nodes share the same medal layer, they are physically connected. The value of the entry is set to a big number MAX if open/short circuit is introduced by the corresponding layer assignment for its connected nodes. Otherwise, it is set to ZERO. This matrix is used as the penalty function for incorrectness of the resultant circuit. Similar strategy is used for e dp edge. The entry of e dp matrix is the number of double patterning risks of its corresponding nodes layer assignments, where double patterning risk is equivalent to double patterning conflict edge in single-layer double patterning conflict graph. This can be better understood by the following example. Suppose there are two vvia's connected by a e dp , and they are assigned to (0, 2) and (1, 4) layers. Then they have double patterning conflict edges between them on layer 1 and 2. The entry corresponding to such assignment equals 2.
By now, all of the key parts of the multi-layer graph have been explained. We call this graph Multi-layer Graph, which is defined as follows.
Definition 1 (Multi-layer Graph): Multi-layer graph is a graph G = (V, E), whose node set V has two exclusive subsets Vseg, Vvia, and edge set E has three exclusive subsets Econ, EX and E dp . Each element v ∈ V has its relevant layout shape, its layer assignment variable lv, whose range is Lseg for v ∈ Vseg or Lvia for v ∈ Vvia, and its weight vector wv. Each element (u, v) ∈ E has its relevant inter-shape relationship in the layout and its weight matrix M (u,v) .
As an example, the multi-layer graph construction of layout in Fig. 1 is shown in Fig. 3 . Based on the definition of multi-layer graph, the optimization problem in multi-layer assignment can be formulated as follows,
Min
α dp ·
where α dp is used as the weighting constant for double patterning risk.
A larger weight will reduce conflicts at the cost of introducing more vias. This optimization problem has just the same properties as required by [7] , which are,
• The costs are distributed on vertices and edges, and the total cost is the summation of weighted costs over all vertices and edges (Formula 2).
• The cost of a vertex is determined only by its layer assignment (wv(lv)).
• The cost of an edge is determined only by the layer assignment of the two vertices that it connects (M (u,v) (lu, lv)). Therefore, this multi-layer assignment can be optimally solved, if the graph is a tree, and approximately solved for general one, as [7] stated. Maximal induced subtree is first generated and then solved with dynamic programming.
After few iterations of the graph nodes traversal, Problem(2) is solved, but not our multi-layer double patterning layer assignment problem (Problem 1). The entry of the e dp matrix only denotes the number of double patterning risks, which is the potential URC in the final result, because the actual double patterning conflict is not only related to the 9A-4 layer assignment, but also determined by the detailed coloring. Singlelayer double patterning is needed now to decide the color for all of the layout rectangles on each metal layer.
The layer assignment result will be processed in phase 2 for single layer double patterning. In our program, we implement the algorithm of [4] for phase 2. The double pattern partition resulted from phase 2 will be annotated to the multi-layer graph, and used in phase 3.
B. Via Reduction
After phases 1 and 2, there may still be extra vias that could be reduced. This is due to the fact that the objective function optimized in phase 1 is the number of double patterning risks, some of which may be resolved after the real double patterning in phase 2, making some introduced vias in phase 1 unnecessary. Fig. 4 gives such an example. The original layout in Fig.4(a) has two double patterning conflict edges and six vias. And the two conflicts can be solved easily with double patterning. However, after our multi-layer assignment operation, the layout is changed to the one in Fig.4(b) , which has no double patterning conflict but two more vias. To eliminate these unnecessarily vias, another via reduction phase is required. Via reduction is also based on multi-layer graph. However, the original multi-layer in phase 1 needs to be updated due to two sources of modification. The first source is the node splitting in singlelayer double patterning. Node splitting in single-layer double pattering resolves double patterning conflicts with introduction of stitches. As the consequence, vseg-vseg-econ shows up in multi-layer graph to connect the split nodes. With existence of this edge, the small segments belonging to the same original one always change layers at same time to guarantee the electrical connection. So the wires in final layout would not change layers at any other point except for the input via candidates.
The second source of update for multi-layer graph is the color assignment information on each node. Color assignment for vseg is easy to understand. It is just the same as that in single-layer double patterning. Assignment for vvia, on the other hand, is more complicated. Its color cannot be represented by a binary integer, since the via is not only on one metal layer. Besides that, different layer assignments for a via will result in different number of metal layers that the via goes across. To solve these problems and unify color assignment for vseg and vvia, the color information on all metal layers of a node is encoded as a unsigned integer number cv, each two bits of which stand for a metal layer. For each metal layer, the color of the node can be 0 (cv = 00), 1 (cv = 01) or undecided (cv = 1X). Note that only the colors corresponding to the current layer assignment of a node (lv) are useful and need to be determined. For example, considering a via node vvia has (0, 1) as its current layer assignment in a 4 double patterning layers condition, the following two binary integers means the same color information for vvia, 00000101 and 11110101. Only the 0, 1 metal layer related bits, the lower 4 bits, are useful under current layer assignment.
Taking color into consideration, the weight on e dp , (u, v), can be now represented by a 4D matrix F (u,v) (lu, lv, cu, cv) to record the cost of URC. The entry in F (u,v) (lu, lv, cu, cv) denotes the number of metal layers, where u, v are same colored, under layer assignment lu, lv and color assignment cu, cv. As the three properties required in Section IV-A are satisfied, theoretically speaking, it can be solved using the similar way. However, due to the complexity of color information added on each node, if the original algorithm is straightforward applied, the computational cost would be much higher. During the original dynamic programming process, for vseg, k different layers are evaluated, and among which the optimal one is chosen. Now, this number changes to 2k for two colors on each metal layer. Though it is increased, it is still O(k). For vvia, on the other hand, the situation is much worse. This number changes from O(k
, because a via of height k has 2 k different color combinations. Similar situation happens on econ edges, since F (u,v) (lu, lv, cu, cv) is also used for econ, instead of M (u,v) (lu, lv), to record the cost of stitches.
To overcome newly introduced complexity problem of color assignment, we propose the incremental coloring technique. During the layer re-assignment in via reduction phase 3, if any metal layer of a node in its new layer assignment has not been colored before, it is free to choose one from the two colors for this metal layer to make it introduce less URC. If the metal layer had been colored, its color will not be changed any more. This consideration can be better explained with an example as follows. Assuming that a vvia, u, is assigned at (2,3) before via reduction phase, u has only been colored on metal layers 2 and 3 in phase two. If the layer assignment of u is changed to (1, 3) , the color on its metal layer 1 can be either 0 or 1, but metal layer 2, 3 may not change any more. F (u,v) (lu, lv, cu, cv) can be substituted with M (u,v) (lu, lv) for deterministic color assignment of u and v then. So the possible options in dynamic programming for each node remains the same as in Section IV-A. This strategy is reasonable, because of the solution obtained from the single layer double patterning phase should not be changed in via reduction phase. 1. Put all nodes in UNVISITED 2. while UNVISITED = ∅ 3. Randomly choose r from UNVISITED as root 4. Growing a none-e dp -connected induced TREE from r 5. Delete all TREE nodes from UNVISITED 6. for each v in backward traversal of TREE 7.
for each layer assignment lv ∈ Lv 8.
if lv contains uncolored metal layer in cv 9.
Update cv on uncolored layer to minimize URC 10. The goal of this phase is changed, then, to minimizing the sum of stitches and vias without increasing the number of URC. To achieve this objective, each pair of nodes on the same induced tree cannot be connected with e dp . Because incremental coloring strategy requires that all of u's e dp connected nodes have determined layer assignment when assign color for u to minimize the number of URC. However, the layer assignments of tree nodes are not decided until the end of dynamic programming. So, e dp connected nodes with the tree nodes have to be excluded during construction of induced tree. The algorithm is accordingly modified as shown in Fig. 5 . The objective function is iteratively improved in this algorithm. In each iteration (line 2-16), several induced subtrees are constructed (line 3-5) and dynamic programmed (line 6-16) one by one. During the dynamic programming, color information is kept updated as line 9.
C. NP-hardness of Single-Layer Double Patterning
Previous algorithms solving single-layer double patterning problem, including [4] we implemented in phase 2, are all heuristics. However,
9A-4
NP-hardness proof of single-layer double patterning problem is still an open problem. We prove single-layer double patterning problem NPhard as follows.
Given a layout, minimum double patterning conflict distance and overlap margin, a graph can be constructed with double patterning conflict edges and touching edges [1] . Each edge has weight that represents effort needed to overcome the double patterning conflict or handle the stitch. A bi-coloring solution is needed to maximize/minimize the differently colored conflict/touching edge connecting node pairs. With c(u) denoting color of node u, positive w(u, v) denoting weight of edge (u, v) and C, T representing conflict edge set and touching edge set, single-layer double patterning problem (DPP) may be stated as
The decision version of DPP is: Given conflict graph and threshold thc and tht, decide whether there is coloring solution that makes
The decision version of DPP is defined as Sub-DPP (SDPP).
To prove SDPP is NP-complete, a proved NP-complete problem is needed, from which SDPP can be transformed with polynomial reduction. 4-degree Max-Cut problem (4MC) is used as the known NP problem here. The decision version of 4-degree Max-Cut problem (S4MC) can be stated as: In a undirected graph, all of whose nodes have not more than 4 degrees, find a cut whose size is not smaller than thmc.
Theorem 1: Double patterning problem is NP-hard. Proof: NP part: It is easy to see that SDPP ∈ NP, since one can easily tell whether the two required thresholds are satisfied with some given coloring solution in polynomial time.
NP-complete part: Every graph G of maximum degree 4 has a standard mesh drawing [8] . In this drawing, nodes are assigned to different mesh points called vertices, edges are assigned on the mesh lines called curves without going through any vertices and with only finite intersection with other curves. The intersection between any two different curves is called cross point. Besides that, the distance between any cross point pair, vertex pair, and between any vertex and cross point are all at least 10 grids.
To make it proper for our transformation, cross points in standard mesh drawing are modified as Fig.6 shows. It is obvious that we can always find a modified mesh drawing that has all the properties a standard mesh drawing has, since the mesh drawing can be scaled up to prevent any possible property violation. Each cross point on the modified standard mesh drawing is substituted with a gadget shown in Fig.7 . α's are sections of subdivided curves, and β's are appended points. The black line segments α and β can be viewed as 0-width interconnection wire pieces on a mesh based layout. The red edges among them are double patterning edges with double patterning conflict distance equals to √ 2 grids. Weights on these edges w(u, v) = 1. This reduced graph is called G'. As Lemma3 in [8] states, each substituted gadget makes MaxCut(G') 8 more than MaxCut(G) by considering each β connected triangle makes 2 contribution to MaxCut(G'). Besides the gadget substitution, curve is further subdivided to make it 2i (even number) sections connected by 2i − 1 double patterning Fig. 7 . Gadget Used for Substitution edges. As stated in Formula(1) in [8] , the 2i − 1 edges on each curve makes MaxCut(G') 2i − 2 more than MaxCut(G). Notice that, this kind of further subdivision has to be far from the existing gadgets to prevent introducing other double patterning edges. Because the length of the curves are long enough, this subdivision can always be found.
The transformed graph G is actually a special case layout with 0 wire width, √ 2 double pattering conflict length, no touching edge and mesh based routed. If a cut on l-edge 4-degree graph G has a size not less than thmc, after m gadget substitution and curve subdivision leading to 2t sections, a cut on G can be easily found with not less than thmc + 8m + 2t − 2l size. With thc = thmc + 8m + 2t − 2l, the special case of SDPP has the same solvability as S4MC.
The reduction from S4MC to the special case of SDPP is obvious polynomial, because the construction and modification of standard mesh drawing, gadget substitution and curve subdivision are all polynomial time achievable. So the decision version of single layer double patterning problem is NP-complete.
It worths notice that in Fig.7 Euclidean distance is considered. If Hamilton distance is considered as [9] , the two crossing red edges in the center of the gadget do not exist. The constructed graph becomes planar, where MaxCut is polynomial time solvable. The double patterning problem is not NP-hard when Hamilton distance is considered instead of Euclidean distance.
V. EXPERIMENTAL RESULTS

A. Experimental Setup
Our DPLA algorithm is implemented in C++. All of the experiments are performed on a Linux workstation with 3.0GHz CPU and 2.0GB memory. Since none of the previous double patterning work is tested on multi-layer interconnect layout, DPLA is tested on the benchmarks provided by the authors of [7] , which are also available at the Collaborative Benchmarking Laboratory (CBL). The layouts are scaled down to 30nm for the experiment.
B. Multi-Layer Double Patterning Results
Since none of the existing work focuses on the double patterning aware layer assignment problem, we compare our solution with SingleLayer Double Patterning [4] conducted on all layers separately. Since the same single-layer double patterning method is used in phase 2 of our DPLA, this comparing strategy guarantees that the performance enhancement is caused by the proposed framework. With better singlelayer double patterning implementation in phase 2, the DPLA result should also improve.
On the other hand, DPLA changes the number of vias. We compared with the via minimization result in [7] as the baseline of via number. It is desired that the output result of DPLA does not induce too many extra vias comparing with the via-minimized solution.
The detailed results are listed in TableI. The columns #Node and #Edge correspond to the number of nodes and edges in multi-layer graph. The column titled #URC (#Stitch) denotes the number of unresolvable double patterning conflicts (stitches) in the circuit. The #Via column shows the number of vias in the layout result. It is obvious that the quality of double patterning layout decomposition is significantly enhanced by DPLA. Both URC and stitches are dramatically reduced by 72.56% and 27.34% (up to 81.95% and 40.34% for the best case). On the other hand, the vias number only increase by about 9.52% in average, even compared with the via minimized results. The running time of DPLA is also compared with Via Minimization [7] in column Time. It has the same order of magnitude as [7] .
C. Double Patterning Constrained on Two Bottom Layers
In current technology, double patterning is usually conducted on the bottom two metal layers instead of all layers, because feature density is higher on these two layers. To demonstrate our method's effectiveness in current technology, DPLA is run on all cases with only the bottom two layers. The result is shown in TableII. Although the layer assignment is constrained on only two layers, which makes the resource on higher layers unavailable, DPLA flow still works very well. There are still 61.78% and 7.56% in URC and stitch reductions in average. Furthermore, via increment changes dramatically from 9.52% to 0.42% at the same time. This is because each time a segment reassigned to the other metal layer, via increment is at most 2, that is much smaller than unconstrained situation. This promising result shows that our DPLA is profitable for current IC designs, especially the via number critical ones. Besides that, since the constructed multi-layer graph is much simpler than layer unconstrained condition, running DPLA is faster.
D. Necessity of Via Reduction Phase
Based on our observation, the majority of the URC and stitch reduction has been achieved during the first two phases. But the output of phase 2 is still far from optimality considering cases like Fig. 4 . The elimination of unnecessary introduced vias only depends on the last via reduction phase. Table III demonstrates the necessity of the via reduction phase. Differences on #URC, #stitch and #via before and after phase 3 in layer unconstrained experiments are listed for comparison. In the experiment, vias and stitches have the same importance as their weighting constants β, γ are the same. It is convenient to change the importance of these objectives by adjusting the weighting constants differently. After phase 3, the total number of vias in the layout is well reduced with relatively small increase of stitches, and the URC number also reduced simultaneously. In other words, the goal of via reduction phase, minimizing the sum of stitches and vias without increase the number of URC, has obviously been achieved in all cases.
VI. CONCLUSIONS High performance double patterning methodology is desperately needed, since the lithography process has become more and more critical in IC manufacture. In this paper, we propose a post-routing layer assignment algorithm DPLA to efficiently address the double patterning problem. We formulate the double patterning layer assignment problem with the introduction of multi-layer graph. A dynamic programming based three-phase approach is developed to find the global solution during the flow. Experiments on the test cases of very different sizes demonstrate the high efficiency of our approach.
VII. ACKNOWLEDGEMENT
