Abstract: In the paper, a new three-layer channel router with 'delayed layering' technique is presented. The delayed layering scheme in the routing can improve the capability of the router to reach comprehensive objectives. This new router not only minimises the tracks used, but also minimises the via usage and maximises the use of preferred routing layers. The delayed layering router consists of two steps: track assignment and layer assignment. The track assignment uses a topological sorting algorithm to determine the horizontal track number of every net. A layerless layout will result from the track assignment. The layer assignment heuristically determines which layers can be used for routing the wire segments in the layerless layout, such that the vias generated are as small as possible. All examples presented in Reference 5, including Deutsch's difficult example, have been used to evaluate our router. The experiments showed that the solution quality with respect to via usage was better than the previous solutions and the number of tracks used in channel was satisfactory.
1

Introduction
The channel routing problem is an important problem in VLSI/LSI layout design automation. In a channel routing problem, terminal locations at the top and bottom of a rectangle are specified, and netlists specifying the interconnection of terminals are given. A number from 0 to n is assigned to each terminal. A net i is a collection of vertical and horizontal wire segments that electrically connect a set of terminals with the same number i, while those terminals with number 0 are unconnected. The channel routing will connect the pins of nets on parallel sides of a rectangle channel. The goals of channel routing are to minimise the channel width and the via usage needed in the routing.
two wire segments of a net on different layers are connected. A crossing is a point where two wire segments of different nets intersect each other. Two cases of the crossing point are shown in Fig. 2 . They are two wire segments that intersect or that have portions which overlap each other. There are two kinds of channel routing. One is restrictive routing, and the other is doglegging routing. The restrictive routing aims for a dogleg-free solution where the number of horizontal tracks on which any net can be positioned is limited to one. In this case any net is routed as a single horizontal segment with vertical branches connecting it to the terminals. The aim of restrictive routing is to determine a horizontal track number for every net. Another kind of routing is doglegging routing. The idea is to remove the constraint of restrictive routing on wire geometry, i.e. to allow net splitting between different tracks. The splitting vertical wire between different horizontal tracks is called dogleg. The introduction of doglegs may decrease the horizontal tracks needed in a channel. However, there are certain penalties to pay for this gain. Each dogleg adds one or two additional vias and this decreases the circuit performance from the electrical standpoint.
Two-layer channel routers were presented in References 1, 2, 3 and 4. They only aimed for the dogleg solutions with minimum tracks used and did not concern the vias minimisation in the routings. In the most current technologies, three layers are available for routing. Four modes, VHV, HVH, overlap, and knock-knee modes, are assumed in the three-layer restrictive channel routing algorithms [S-81. These algorithms produced a large number of vias, although they could obtain optimal solutions for channel width. The algorithm presented in Reference 9 was allowed the doglegs in the routing. Note that the number of tracks needed in a channel for the solution of doglegging routing can be reduced. However, the doglegging routing generates more vias in its solution. From a technological point of view, the number of vias sould be kept small. In IC processing, an increase of vias will cause a decrease of yield, which will affect the circuit performance significantly because of the resitance associated with vias. In addition, the increase in vias will cause an increase in routing space such that the manufacturing cost will be increased. Hence we consider the restrictive routing in this paper, and the via minimisation will also be considered in the routing algorithms.
Previous routers were only considered the track locations of nets when the layering model was fixed, and such that the number of vias introduced in the routing were not important. Delayed layering in our channel routing is an efficient way to minimise via introductions and maximise the use of a preferred routing layer under the routability of each net guaranteed. Our proposed algorithm is divided into two steps : track assignment and layer assignment. The track assignment determines the horizontal track number of each net. A solution called transient layout will result from the track assignment. The transient layout is an incomplete or layerless physical layout in which the topology of nets in the layout has become clear, whereas the wire segments in the layout have not yet been assigned to layers. The layer assignment is to determine which layers can be used for routing the wire segments in the transient layout so that the vias generated are as small as possible. For the routing problem given in Fig. 1 , the layout shown in Fig. 3a is a transient layout in which the horizontal track number of every net is determined. Fig. 3b is a complete physical layout with one via only.
1 5 5 7 0 7 9 9 8 1 2 3 3 2 5 6 5 4 8 8 9 6 3 0 4 2 0 a 1 5 7 0 7 9 9 8 1 2 3 3 2 
2
It must be guaranteed that no two wire segments running in different directions are run on the same layer. Both graphs, (vertical constraint graph (VCG) and horizontal constraint graph (HCG)) are used to avoid the vertical and horizontal conflicts among the nets, respectively.
Graph models of the channel routing problem
230
Let Li and Ri denote a column number of the leftmost and the rightmost terminals for a net i, respectively. The x-interval of a net i is defined by (Li, Ri), and the x-length of a net is the number of columns in its x-interval. Both nets are in horizontal conflict if their x-intervals overlap. There are two cases for non-conlflict in the x-intervals of two nets i and j, as indicated in Fig. 4 The graph in Fig. 5 is a HCG of netlist as given in Fig. 1 . The edge (i, j) in HCG indicates that two x-intervals of net i and net j are not overlapping each other. Hence, two nets can be put into the same track if and only if their corresponding vertices are connected in HCG.
Fig. 5 Horizontal constraint graph
It is easy to see that any two nets must not overlap in a vertical column. A binary relation will be induced from the netlist. This relation, first defined in Reference 1, can be represented by a directed graph VCG where each vertex corresponds a net and a directed edge is connected from vertex i to vertex j , denoted by i + j or (i, j), if & = i and B, = j , 1 < k < n. The VCG of the netlist in 2. The precedence relation in G is irreflexive. In other words, a directed path from vertex k to vertex j is not in G if and only if there is a directed path from vertex j to vertex k in G.
DeJinition 2: A precedence relation which is both transitive and irreflexive is a partial order or topological order.
The order information of nets will be derived from VCG if we route every net from the top track to the bottom track in the channel. The net i will be routed preceding the net j if there is a directed path from vertex i to vertex j in VCG. According to definition 2, the order sequence of nets in VCG is a topological order. The horizontal track number of each net can be decided based on this topological order. However, there are many orders determined by the VCG and each order will produce a possible solution. Therefore, a straightforward way of track assignment is to use a topological sorting to enumerate all orders in the VCG and to find one optimal solution amonst them.
3
Topological order of the track assignment
Note that any two nets can be put in the same track if and only if their corresponding vertices are connected in HCG. Each maximal clique (or complete subgraph) in HCG forms a group of nets which can be routed in the same track. HCG is used to determine how nets can be broken into some groups. To avoid the vertical conflicting in the routing, only nets with corresponding vertices that have no predecessors in VCG should form a subgraph of HCG and be partitioned into some groups by finding the maximal cliques in the subgraph. Nets in each group are order independent because they have no vertical conflict in VCG. Hence, the group is defined as an independent class of nets. Because at most two layers are needed for routing the horizontal wire segments and the remaining layer is preserved for vertical wire segments, two independent classes can be produced simultaneously at each time. The algorithm to determine the topological order proceeds by selecting out two independent classes with vertices in VCG that have no predecessors. Then, vertices in the two independent classes together with all edges leading out from them are deleted from VCG. These two steps are repeated until all vertices have been listed. Let V, be a set of vertices which have no predecessors in VCG. This algorithm can be written as following.
ALGORITHM # I 1. input VCG. Let n be the number of vertices 2. while (I V, I # 0)
3.
partition the vertices in V , into independent classes E by finding all maximal cliques in a subgraph of HCG with corresponding vertices in V,; output two classes Ai and A i + , from E ; delete all vertices in Ai and A i + , and all edges leading out of them from VCG; V, = a set of vertices which have no predecessors in the reduced VCG.
4.
5.
6.
end E N D ALGORITHM # I
The solution for track assignment is to find a topological order of independent classes such that the number of classes in the sequence is minimised. The number of classes is proportional to the number of tracks used in a IEE PROCEEDINGS, Vol. 137, Pt. E, No. 4, JULY 1990 channel. Based on the sequence, the track assigned to nets in each class can be determined. Let A , , A , , . . . , and A, be a topological order of independent classes. Both classes A,i-and A,i are generated at i-th iteration in the algorithm and nets in classes A z i -, and AZi are routed in the track i at two horizontal layers, respectively. It is clearly shown that only one independent class may be generated at the iteration when all vertices in V, form only one maximal clique in HCG. If the set of vertices in V, forms a unique maximal clique in HCG at the i-th iteration, the generated classes will be = V, and A,i = 0, where 0 is a null set. The relation between the number of iterations in the modified algorithm and the channel width of routing problem is described by Lemma 1.
Lemma I: Let { A l , A,, . . . , A,,,} be a topological order of independent classes. The channel width for three-layer routing problem equals m/2.
Proof: Two independent classes are generated at each iteration. The nets in one independent class will be assigned to first horizontal layer and the other for second horizontal layer on the same track. Therefore, the number of independent classes is proportional to both the channel width of three-layer routing problem and the number of iterations in the algorithm # 1.
It is noted that the low bound of channel width, denoted as w, for the three-layer restrictive routing is max (rdmX/21, umX) since at most two layers can be used to route the horizontal wire segments. The optimal solution to three-layer restrictive channel routing problem is to find a topological order of independent classes { A , , A , , .. ., A,,,} such that m = 2 0 and nets in the class Ai and A i + l are assigned to ri/21-th track on two horizontal layers, respectively. Let Ai be the longest path length from vertex i in VCG to the vertex which has no successors, and Si be the dynamic local density of net i . The dynamic local density of net i is defined to be the maximal number of nets which have not been assigned to tracks and are overlapping each other in x-interval of net i . It is clear to show that the algorithm requires at least max (Ai, r6J27) iterations to finish the routing problem since the independent class, which contains the net i, was generated. To prove that the sequence of independent classes is an optimal partial order, the following theorem is required.
Theorem I: The sequence { A l , A , , . . . , A,,,} is an optimal partial order of independent classes if the sequence follows the condition which is defined as
for each net i in class Ai.
Proof: The net i in the class A j is generated at the rj/21-th iteration. It is clear to show that the number of iterations needed for the completion of the algorithm is at least max (Ai, rSJ21) after the net i was routed in the rj/21-th track. Lemma 1 shows that the channel width needed in the routing problem equals the number of iterations in the algorithm. If the low bound of channel width is o, we have and it proves that
The channel routing is a well known NP-complete problem [13] . Therefore, we conjecture that the determination of optimal partial order of independent classes is an NP-complete problem. A heuristic algorithm is presented. In the proposed algorithm, every vertex in HCG is weighted by a cost, and each time two independent classes with maximum weights are selected first. The cost estimated on all vertices in HCG does not only involve the x-length of corresponding net but also consider its longest path length and dynamic local density of the net.
The cost F. of net i in the independent class Ai is evaluated as follows.
(2)
x-length of net i if 2 0 -j > max (24, Si)
The cost of Ai is the summation of cost of all nets in it.
A net with cost p is called dominant net. The p is a dominant cost and forces the independent class which contains the dominant net to be selected first.
Consider the netlist as shown in Fig. 1 , the process on determination of partial order of independent classes for the track assignment is presented in Fig. 7 and its corresponding transient layout is demonstrated in Fig. 3a . In the track assignment, the topological order of independent classes will be generated based on HCG and VCG. The algorithm to determine the topological order is called topological sorting in VCG. After the determination of topological order, each net can be assigned to a track in the channel based on the predetermined order. Nets in an independent class are assigned to same track. Hence, the number of classes in the topological sequence decides the number of tracks needed. In this section, we concentrate on the discussion of topological sorting algorithm. First, the data structure used in the algorithm is introduced, and the algorithm is then explained. The algorithm assumes that VCG is represented by the adjacency list. The adjacency list for VCG is represented as n linked lists while there are n vertices and e edges in VCG. Each list includes both a headnode and list nodes. The headnodes of these lists represent vertices in VCG and contain two fields: C O U N T and L I N K . The C O U N T field contains the in-degree of that vertex and the LINK field is a pointer to the first node in the adjacency list. Each list node contains both VERTEX and LINK fields. The VERTEX field records the index of vertex in VCG and the LINK field is a pointer to next node in the linked list.
The adjacency list for VCG is easy to be set up at the time of input. The C O U N T field of headnode j is incremented by one when an edge (i, j ) is in VCG, and the node with VERTEX field containing index j is linked 232 to the tail of list which is pointed by the headnode i. In the case of a directed graph with n vertices and e edges, this representation requires n headnodes and e list nodes.
For VCG as shown in Fig. 6 , the adjacency list is indicated in Fig. 8 . From observation of the adjacency list, we known that the headnode j with zero count corresponds to a vertex which has no predecessors. The vertices with zero count are maintained in a queue Q. We present the topological sorting algorithm as shown in the following.
ALGOR1 T H M T-SOR T
1. input VCG and set up the adjacency list; 2. for i = 1 to n do/* put all vertices with zero count 3.
if COUNT(i) = 0 then put vertex i into Q; 4. end 5. while Q is not empty do 6. 7.
into Q */ set up a subgraph G with vertices in Q from HCG; output two independent classes Ai and A i , which are two maximal cliques with maximal cost in G, in the topological sequence ; for each vertex k in Ai or A j do 8.
9.
ptr.+ L I M K (k); 10. whde ptr # 0 do 11.
m t V E R T E X b t r ) ; 12. 13. 14. end 15. end 16. end END ALGORITHM T-SORT Line 7 in the algorithm T-SORT is to determine two maximal cliques of the subgraph with vertices in Q. Since it is essential, we first explain it below. Because there is a weight assigned in each vertex in HCG, our problem is to determine the maximum weighted clique in the subgraph of HCG. In general, to find maximum weighted clique in graph is an NP-complete problem [ll] . However, the problem becomes tractable when the graph is restricted to comparability graph. First, we define the comparability graph as follows. An undirected graph which is transitively orientable is called a comparability graph. 
COUNT(m)
Algorithm for layer assignment
The layer assignment assigns every wire segment in the transient layout which results from the track assignment with a layer such that the physical layout is completed with the minimum number of vias. The point where the horizontal wire segment and vertical wire segment of a net are connected in the transient layout is called the via candidate, since the point will be a real via when wire segments connected to it are located at different layers. Therefore, the layer assignment is to determine which layers can be used for routing the wire segments in the transient layout so that the via candidates which are going to be real vias can be minimised. The transient layout can be represented as a graph called SegmentCrossing Graph (SCG) which is denoted as G, = (V,, E, U E,). The graph is constructed as follows. Each vertex in V, represents a wire segment in the transient layout. The edges in G, are divided into two sets which are the set of via-edges (denoted as E,) and the set of cross-edges (denoted as E,). If two wire segments are connected by a via candidate, an edge in E, will connect these two corresponding vertices in SCG. An edge in E,, which is connected two vertices in SCG, means two corresponding wire segments are cross over each other. We use dashed lines and solid lines for two different kinds of IEE PROCEEDINGS, Vol. 137, Pt. E, NO. 4, JULY 1990 c10). G, = (K, E, U E,) can be divided into two subgraphs, which are G: = (V,, E,) and G," = (K, E,). The subgraph G: is to relate the crossing between wire segments, and the subgraph G," is to indicate the interconnection of nets. Each edge in G, U represents a via candidate. Each connected component in G," means the interconnection of a net in the layout.
For a vertex u E V , , both sets of vertices are adjacent to it. For distinguishing between them, we define a set of vertices, which are adjacent to u by the edges in E,, to be an adjacent list of u, and the other set of vertices which are connected to u by the edges in E, is defined as a cluster of U. The adjacent list and the cluster of vertex u are denoted as A(u) and C(u), respectively. For SCG as shown in Fig. 10 , two sets of the vertex s2 are A(s2) = {sl, s3) and C(s2) = {s6, s7, s8, s9, s12). Let layers in three-layer routing be represented by colours 0, 1 and 2, respectively. The layer assignment problem of the three-layer transient routing can be translated to a 3-colourable problem of G,. The layer assignment of wire segments in the transient layout is to assign all vertices in the colourless graph G, with colours when two vertices, which are connected by an edge in E,, are painted by different colours, and such that two vertices, which are connected by an edge in E,, are painted as near the same colour as possible. In other words, a colur painted on the vertex u is different from the colours assigned to the vertices in C(u) and is as similar to the colours assigned to the vertices in A(#) as possiible. For instance, the graph SCG give in Fig. 10 can be coloured as shown in Fig. 11 . Fig. 11 shows that all via candidates except 06 do not change into real vias. The final layout with only one via is completed as presented in Fig. 12 .
0-
A heuristic algorithm for layer assignment is proposed in this section. Let us first consider the basic concept in -------layer 2 or colour 2 via candidates connected to the wire segment which corresponds to U can be eliminated. The elimination of a via candidate means the wire segments connected to it are routed on same layer such that a real via is not created. The colours assigned to the vertices in C(u) are the constrained colours of vertex U. The constrained colour represents a colour to which the vertex U cannot be assigned for avoidance of violating the layout requirement. Therefore, the expected colours of vertex U to eliminate the via candidates are the colours which belong to the recommended colours of vertex U but not the constrained colours of vertex U. For formulating the heuristic algorithm, some definitions associated with each vertex in V, are needed. Let n be the number of vertices in V,. The definitions are listed as follows.
Definition 4 :
A colour that has been assigned to a vertex U is called an active colour of U denoted as 4u). The vertex U that has assigned a colour is called an active vertex, and it is called an inactive vertex if it has not been assigned a colour.
Definition 5 :
The recommended colours of a vertex U, which is denoted as r(u), are the colours that have been assigned to the vertices in A(u). The r(u) can be calculated as following :
Definition 6 : The constrained colours of a vertex U, which is denoted as c(u), are the colours that have been assigned to the vertices in C(u). The c(u) can be defined as following:
c(u) = (a(i) 11 < i < n and i E C(u)}
(4)
Definition 7: The expected colours of vertex U, which is denoted as e(u), are the colours that can be assigned to the vertex U. The (eu) can be defined as following: These definitions can be explained by the subgraph of SCG as shown in Fig. 13 . The example shows that r(u) = (0, 1, 2, 21, c(u) = (0, 0, 01, e(u) = (1, 2) and the vertex U is 1C vertex. On the consideration of above definitions, our proposed heuristic algorithm can be presented step by step and the details will be addressed later.
1. Input a layout and construct a segment-crossing graph G, , and let all vertices in G, be inactive vertices.
2. Select an inactive vertex U in G, .
3. Assign vertex U to a colour, a(u). 4. Calculate r(i) by r(i) = r(i) U u(u), for all i E A(u). c(i) = c(i) U a(u) , for all i E C(u). 6. Repeat steps 2-5 until all vertices in G, are active vertices. Initially, all vertices in G, are inactive vertices. One of them will be selected for assigning a colour to it. Because the result of the algorithm depends on the order of selecting the inactive vertices, we use a priority function to determine the sequence of the selected vertices. The priority function is estimated at each vertex in G, .
234
Calculate c(i) by
Step 2 selects an inactive vertex based on the nonincreasing order of priority of the vertices. Let the valence Val (G:, U) of a vertex U in a graph G', be the number of edges incident with U and val(G:) be the maximum number of valence in graph G : . The priority function of vertex U is defined as follows.
P(u)
In this priority function, the term Val (G:) means the complexity of cross over of wire segments in the routing, and the term Val (G: , U) indicates the number of wire segments which are crossing with the vertex U or the degree of constraints of the vertex U. Definition 8 shows that the inactive vertices may be classified in some kinds based on the I c(u) I. Each inactive vertex is going to be one of OC, lC, 2C and 3C kinds when there are three colours needed for the three-layer routing. Because of Val (Gf) 2 Val (Gg , U), the highest priority vertex is 3C vertex and lowest one is OC vertex. If some inactive vertices belong to the same kind, one with highest degree of constraints will be selected first from them. Initially, all vertices in G, are OC vertices.
In
Step 3, we have to decide the active colour assigned to the vertex selected in Step 2. Let L = (0, 1, 2) be a set of colours corresponding to the three layers used in the routing. The colours which can be assigned to the vertex U must be in the set of L -c(u). However, the feasible colour of 4u) must be in the set of e(u). Therefore, if 4u) 4 e(u) or e(u) = 0 (where fa is null set), some vias will be created. For Fig. 14 I r,(u) I be the number of colour z in r(u) and z E L. For eliminating the maximum number of via candidates, the colour assigned to an inactive vertex U will be a(u) satisfying the feasible condition that is defined below.
u(u) = z, z E (U) and I r k ) I is a maximum
(7)
For the example as shown in Fig. 13 , the a(u) will be 2 to eliminate two via candiates because of Irl(u)l = 1 and The determination of a(u) is different from each kind of inactive vertex U. First, we list the formulae to determine the a(u) of different kinds of vertex U. We explain in detail later.
A: OC vertex U (I c(u) 1 = 0)
A l : r(u) = 0 u(u) = z, z E L with highest priority a(u) = 7, z E r(u) and I r&) I is maximum It is easy to show that the formulae in eqns. 9, 10, 12, and 13 satisfy the feasible condition eqn. 7 of a(u). Therefore, there are Ir,(u)I via candidates to be eliminated in the cases associated with these formulae. In other formulae, the via candiates cannot be eliminated since the corresponding formulae do not follow the feasible condition.
In the case of 3C vertex, the a(u) = 4 indicates that it is in contradiction to 3-colourable assumption. In order to hold the 3-colourable requirement, the colour reassignments of some active vertices are needed during the colour assignment of 3C vertex. This backtracking to reassign the active vertices with new colours will be discussed in the next section.
In eqn. 8 or 11, it derives a question: 'Which colour in L or ( L -c(u)) will be selected first? This is a priority problem of layers in routing. If one objective of the layer assignment is to maximise the total amount of metal, the priority of layers can be set to this order which is IEE PROCEEDINGS, Vol. 137, Pt. E, No. 4, JULY I990 0 > 1 > 2 when both layer 0 and layer 1 are assumed to be two metal layers. However, by trying to maximise the total length of metal wires may incur more vias. At the aim of via minimisation, the priority order of layers is 1 > 0 > 2 since the layer 1 is the middle layer which has more flexible to be assigned than layers 0 and 2. The priority of layers is determined to maximise the use of preferred routing layers and minimise the via usage. Now, we present the heuristic algorithm in the following.
ALGORITHM LAYER-ASSIGNMENT 1. input the layout and construct G,; 2. repeat 3.
4.
5.
6. 7. 8. 9. 10. else a(u) = (12); 11.
13.
else u(u) = (9) for each vertex i in A(u) do
The backtracking will be treated to reassign some of the active vertices with new colours so that the 3C inactive vertex can be assigned to an active colour. Since all colours in L have been assigned to the vertices in the cluster of the 3C vertex U, a colour, which is assigned to some of the vertices in C(u), is selected to be an active colour of U. The vertex in C(u) will change to be inactive after its colour is used to be an active colour of the 3C vertex U. Each vertex in C(u) may be one of the OC, 1C or 2C vertices. If a colour assigned to the 2C vertex in C(u) is selected for the colour assignment of the 3C vertex U, this 2C vertex will change to be a 3C inactive vertex such that the work of backtracking is continued. In the other case of a OC or 1C vertex in C(u), the backtracking will be terminated because the vertex is not going to be a 3C vertex after its colour is assigned to the 3C vertex U. The requirement of selecting a colour is to minimise the number of active vertices which will become 3C vertices after this colour is assigned to the current 3C vertex. For the example as shown in Fig. 15 , all wire segments except s, are active and c(s,) = {si, si, sk}. The wire Segments si, si and sk are corresponding to the OC, 1C and 2C vertices, respectively, and the wire segment s, corresponds to the 3C inactive vertex because of ds,) = 2, a(sj) = 0, and a(& = 1. The colour which is assigned to the OC vertex si will be selected as a colour assignment of the vertex s,, since the vertex si will become a 1C inactive vertex which has more flexibility to reassign. But it is not reasonable for selection of the colour corresponding to the vertex Sk, because the vertex sk will be a 3C inactive vertex after its colour is assigned to s, . Two parameters are needed in the algorithm BACK-TRACK. We have to define the parameters for understanding this algorithm. Note that only one of three colours in the layer assignment will be selected for an active colour of the 3C inactive vertex. Both parameters of k,(u) and I c,(u) I are used to determine the active colour assigned to the 3C vertex. The k,(u) is defined as follows.
k,(u) = max ( I c(i) 1 , for all vertices i E C(u) and 7 = di)) calculate the k,(u) and I c,(u) I for 7 = 0, 1 and 2; a(u) = 7, k,(u) and I c,(u) I are minimum;
if (I c(i) I = 3) and (i does not be marked) then S e i; /* push i into S */
if (S is empty) then return;
else U e S; */ pop from S to U */ (16) The k,(u) = p means some of the vertices in C(u), which have been assigned to a colour 7, are going to be (p + 1) constrained vertices after the 7 colour was selected for an active colour of the 3C vertex U. For the example as shown in Fig. 16 , the inactive wire segment U corresponds to the 3C vertex and the k,(u) = 2, k,(u) = 1, k,(u) = 1. If the colour 0 is assigned to the 3C vertex U, the wire segment s2 will become a 3C inactive vertex, meanwhile, the backtracking will be continued. Therefore, the assigned colour for a 3C vertex U may be 1 or 2. Table 1 . The number of tracks used for all examples except 3b are consistently the minimum. In an average case, the number of vias used is reduced by 30 percent or so. Fig. 18 -23 are the final layout for examples 1, 3a, 3b, 3c, 4b and 5, respectively. The final layout of Deutsch's difficult example is presented in Fig. 24 . In the theoretical discussion of the layer assignment problem, we can assume that the terminal is available on all layers. On the basis of this assumption, the best results shown in Table 1 are reached. However, on the practical manufacturing of IC processing, some applications restrict the availability of terminals to particular layers. If terminals are available for one particular layer, the layer assignments of wire segments connected to terminals will be preassigned to this particular layer and their corresponding vertices in SCG are set to be active. This pre- assignment tasks of particular wire segments can be done in the preprocessor before the algorithm LAYER-ASSIGNMENT is started. Table 2 gives the results of all examples with terminal restriction. The experiments show that the terminal restriction may 273 227 * All terminals are restricted at only one layer ** All terminals can be at any one of two proper layers degrade the performance of layer assignment although the solution quality with respect to via usage was better than for the previous solution.
We have described a new channel router that uses the delayed layering to reduce the via usage. This router has been run successfully on several examples. In all instances, the via usages in their solutions were better than for the previous routers, and the solution quality with respect to channel width was comparable to the previous solutions. The delayed layering router is also able to maximise the use of a preferred layer. The priority of layers can be 1 > 0 > 2 to maximise the total length of metal wires and minimise the via usage.
