"Permission to make digital/hard copy of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage, the copyright notice, the title of the publication and its date appear, and notice is given that copying is by permission of CBL. To copy otherwise, to republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee."
If you choose to cite this report, please add the following entry to your bibliography database: <3techreport{ 1997-TR<aCBL-08-Kapur,' author = "N. Kapur and D.Ghosh and F. Brglez", title = "{Optimization of Placements Driven By the Cost of Wire Crossing}", institution = "{CBL, CS Dept., NCSU, Box 7550, Raleigh, NC 27695}", number = "1997-TRQCBL-08-Kapur", month = "Oct", year = "1997", note = "{Also available at http://www.cbl.ncsu.edu/publications}" } To contact the Collaborative Benchmarking Laboratory via Internet, you may consider:
http://www.cbl.ncsu.edu/ Anonymous FTP :
ftp://ftp.cbl.ncsu.edu For an auto-reply:
benchmarks@cbl.ncsu.edu To deposit a file at CBL: ftp cbl.ncsu.edu cd /pub/Incoming put new-benchmark.tar.Z
I. INTRODUCTION
Area and performance in submicron-technology VLSI circuits are critically dominated by the interconnect. The variations in interconnect that arise after cell placement and routing, such as wire crossings, wire density, wire loading, wire length, etc., may be hard if not impossible to predict. Similarly, the interconnect models associated with the logic implementation and logic testability prior to placement and routing may change considerably after cell placement and routing.
In row-based cell placement, the cost function that continues to dominate the research relates mostly to total wirelength, e.g. the simulated annealing approach [1] . The length of the interconnect in randomized and optimized placements has been formalized in [2] . Abstract placement models, such as presented in [3] , also aim to minimize the channel density.
The crossing number and wire area have been investigated for effective wire lower bounds and edge length in a variety of computational VLSI circuits, using a graph-based grid model [4] . In this paper, we propose a new unit-grid model, derived from the a multi-level bipartite graph in canonical form [5] . We conjecture that good placements can be produced by minimizing two wire crossing numbers in our bipartite graph model: (1) the total wire crossing of all edges, and (2) the maximum wire crossing of all cell channel separator segments.
Crossing theory has been developed to improve the readability of hierarchical structures [6] . The problem for placing the nodes for minimum wire crossing is NP-complete [7] , even for 2-layer graphs. Several heuristics -barycenter [8] , median This research has been supported by contracts from the Semiconductor Research Corporation (94-DJ-553), SEMATECH (94-DJ-800), and DARPA/ARO (P-3316-EL/DAAH04-94-G-2080).
"Permission to make digital/hard copy of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage, the copyright notice, the title of the publication and its date appear, and notice is given that copying is by permission of CBL. To copy otherwise, to republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee." © 1997 CBL [9] , assignment [10] -have been proposed to minimize the wire crossings. A survey of exact and heuristic algorithms is available in [11] . An improvement on the median heuristic has been described in [12] and we use the associated drawing program DOT to support our initial experiments reported in this submission. We are also investigating alternative approaches to minimize wire crossing, subject to constraints specific to VLSI circuits and expect to report on them in the final submission.
We argue that for layout problems in particular, case-bycase evaluations, however detailed, of a few unrelated benchmark circuits are not likely to reveal a set of statistically consistent results that can drive and support important improvements for the new generation of algorithms and tools. To illustrate our point, we analyze grid-based layouts as well as placed-and-routed layouts for a number of equivalence mutant classes introduced in [5] 1 . For convenience of the reviewers, we copy the section on the design of experiments and the mutant classification we used in [5] . In the the final submission, this section will be edited to minimum size. The paper is organized into the following sections :
(2) background and motivation; (3) correlations in 2-layer graphs; (4) notation and definitions; (5) cell and net folding and compaction; (6) design of experiments; (7) summary of experiments; (8) conclusions.
II. BACKGROUND AND MOTIVATION
We use a simple 11-node planar circuit to informally introduce the proposed unit-grid model and illustrate the conjecture that good placements can be produced by minimizing two wire crossing numbers in its directed bipartite graph model representation. A summary of our experiments is shown in Figure 1: (a) The circuit is not drawn in the planar form. Rather, we draw it as an instance of a random placement, in a canonical form, of a bipartite directed acyclic graph [5] . The 'square' and 'triangle' nodes represent net nodes, the circles and ellipses are cell nodes. Each circle represents a logic cell in the original circuit, each ellipse represents a feedthrough cell introduced by the canonical form. We call the horizontal lines, drawn as dotted lines and indexed from 0 to 4, cell separators. We call the vertical lines that could be drawn through the net nodes and indexed from 0 to 3, net separators. The total wire crossing number for all edges in the graph as drawn here, is 54. Starting with the placement shown, not even the state-of-the-art algorithm such as DOT [12] can render the circuit planar (wire crossing is minimized to a value of 7). (b) Analysis of the left-most net-to-cell channel in (a)
shows a total wire crossing of 23, wire length of 23. crossing of edges between net nodes and cell nodes. If an edge between two adjacent nodes crosses no cell separators (shown as dotted lines), we define its length as 0.5, and increase its length by 1 whenever it crosses a cell separator. The critical wire density is evaluated as the maximum number of edges crossing the cell separator. (c) Wire crossing minimization of net-to-cell channels in (b) reduces total wire crossing to 0, wire length to 8.5,
>9
and the critical wire density to 1. (d) An instance of the standard cell layout with OASIS [13] shows a number of wire crossings. In fact, upon translating the specific OASIS placement into the bipartite graph form on the same grid, we have 1 wire crossing in channels (0-1), 3 wire crossings in channels (1-2), and 1 wire crossing in channels (2) (3) . Inspecting the actual layout, we find more wire crossings in each of the channels. (e) Table summarizing an experiment with 100 instances of the netlist of the 11-node planar circuit, each in random order, before submission to wire crossing minimization with DOT [12] . This is the W-ClassD circuit class, a special class of isomorphic mutants in the context of the design of experiments as introduced in [5] . We measure the initial and final value of sample mean, sample variance, and 95% confidence interval of the mean for several parameters we have already defined or will define later in the paper: total wire length (TWL), critical wire length (CWL), total wire crossing (TWC), width of placement (Width), height of placement (Height), and area of placement (Area). (f) Histogram of circuit area for 100 instances of the netlist of the 11-node planar circuit, each in random order, submitted for layout optimization with OASIS [13] . (g) Histogram of circuit minimized wire crossing for 100 instances of the netlist of the 11-node planar circuit, each in random order, submitted for wire crossing minimization with DOT [12] .
Conclusions that we draw from the observations recorded in of the 11-node planar circuit, each listed in different random order, is a random variable and may be far from best possible. (g) Minimized wire crossing for 100 instances of the netlist of the 11-node planar circuit, each listed in different random order, is a random variable. Only relatively few netlists have been returned with the known minimum wire crossing of 0. Unlike in the case of layout in (f), this distribution is not normal since more solutions are clustered to the left of the minimum value -lending support to our conjecture that optimizing the placement by minimizing wire crossing with a good algorithm may be as effective, if not more, than minimizing the wire length estimates. Before we proceed with formal notation and definition, we digress with one more experiment, this time scaling the problem for a 2-layer graph minimization algorithm.
III. CORRELATIONS IN 2-LAYER GRAPHS
The 2-layer subgraphs in the example shown in Figure 1 are too small to analyze correlations between grid-based variables such as wire crossing, wire length, and wire density.
The net-to-channel example in Figure 1 (c) is a special case of a two-layer graphs from several families of parameterized 2-layer directed sparse graphs: Vn+lE3-n (E3-graphs) [14] . Properties of E3-graphs are: number of nodes at level 0 = n+1, number of 1-input nodes at level 1 = 3, number of 2-input nodes at level 1 = n, number of edges = 2*n + 3, number of wire crossings = 0.
We have chosen to analyze a graph with 65 net nodes, 131 edges, and 3+64 cell nodes (3 single-input nodes, 64 2-input nodes). We label its reference graph as V65E3-64. Next, we created 8 wiring signature-invariant equivalence classes, 100 circuits in each class (each with 65 net nodes, 131 edges, and 3+64 cell nodes) [5] .
Here, we again analyze placements of the graph-isomorphic class W.ClassD. Evaluations of all 100 such random placements are shown in Figure 2 (a-c): note the near-normal distribution of wire crossings (ranging from 3400 to 4800) and the near perfect correlation with wire length. As to the maximum wire density, it can vary from 59 to 89 wires.
Next, we submit the same 100 circuits to the drawing program DOT [12] . While much improved, only 14 out of 100 circuits could be placed with wire crossing of 0, optimum wire length of 194.5, and the maximum wire density of 1. The remaining circuits, while much better placed than the initial placement, are suboptimal and can still vary over a relatively large range.
In conclusion, the example in this section re-enforces our conjectures based on the earlier experiment in Figure 1 :
< It is a fallacy to rely on a single measurement of any benchmark circuit -variations for many of the 'improvements' published to date may well be attributed to chance rather than any intrinsic improvement of the algorithm.
• The correlation coefficient between the total wire crossing and total wire length is high before and after wire crossing minimization; minimizing total wire crossing minimizes total wire length. . The correlation coefficient between the total wire crossing and maximum wire density is much higher for random placement than it is for the near-optimal placement. It should be possible to 'improve' maximum wire density without a major change in wire crossing (and wire length). . Any improvements in (1) the total wire crossing of all edges, and (2) the maximum wire crossing of all cell channel separator segments may translate to improved layout area and performance.
IV. NOTATION AND DEFINITIONS
The traditional graph-based models of a directed netlist are not effective for the problem we want to consider in this paper. On the other hand, a model of a netlist as a directed hypergraph is not unique. The important items in this work are the notion of cell level, levels of net pins, and nets-pan .
The canonical form of a bipartite directed graph, a multi-level graph structure of alternating sets of net nodes and cell nodes, is a simple transformation of the underlying netlist: levels of some of its pins are redefined, and a new type of cell node, a feedthrough cell is introduced [5] . 
Properties of grid region R(i,j).

PI In each grid region R(i,j)
, there is at most one cell node. P2 For a cell in R{i,j), there could be several permissible orientations. Each orientation defines the order of the pins of the cell. P3 It is possible to derive consistent co-ordinates for each pin of a node using its label and orientation. For an edge e = (u, v), we define y(u) and y(v) as the co-ordinates of the pins it connects. P4 The cell separators in a channel induce pseudo-edges.
We can use this property to calculate wiring density. These pseudo-edges connect nodes which are at the intersections of net separators and midlines. The co-
The i factor is due to the fact that each crossing is counted exactly twice, once for each of the two edges that produce it.
Critical wire crossings is the maximum number of crossings that appear on any path from an input to an output.
Wiring Density for a channel C, and a cell separator s, is the number of edges that cross s in channel C.
Fig. 3. Elements of grid region R(i,j).
ordinates for these nodes are derived consistently with those of other nodes. P5 The length of each edge e, which connects nodes (ii,ji,ki)A and (12,^2,^2)3 is defined and evaluated as:
where E(C) is the set of edges in channel C.
Critical wire density for a channel C (cell-to-net or net-to-cell) is the maximum number of edges that cross any cell separator in that channel.
wdjcri(C) = Max s£ s(wd(C,s))
len(e) = j Q Total Wire Density for a placement P is the sum of the critical wire densities for all the channels.
P6 Let ei = (wi,vi) and e2 = («2,^2) be edges such that wi, v\ are in the same wire channel and are pins of nodes with the same subscript (A or B) as U2 and V2 respectively. We define a function cross(ei,e2) as follows: cec where C is the set of all the channels in the placement.
Average Wire Density for a placement P, is the mean of the critical wire densities for all the channels.
The wire crossing number for each edge e, is defined as follows:
loc(e) = j> cross(e,ei) (3) neT(e) where T(e) is the set of all edges of the same type as e in the same region as e.
Figures of merit. Let E be the set of edges.
Total wire length is the sum of the wire length contribution of each edge.
wl-tot = Y^ len{e)
Critical wire length is the length of the longest path starting at any primary input and ending at a primary output. This includes feedback primary inputs and outputs based on edges that break the cycle.
iV-l wljcri = Max( uie j |MJV so){y^ len{m, Wt+0}
•=i where I is the set of primary inputs, O is the set of primary outputs and (wi,Wi+i) e £.
Total wire crossings is the total number of crossings in the placement.
awd(P) = wdJot(P) \C\
Width of a channel C is defined as
Width of the placement P is the sum of the widths of all the channels.
pjwidth(P) = ^ width(C) (13) cec
Height of a midline M is defined as
where c(M) is the number of cell nodes in the midline, and f(M) is the number of feedthrough nodes in the midline. The 0.1 factor is an empirical one.
Height of a placement P is the maximum height of any midline.
pJieight(P) = MaxMeM{height(M)}
where M is the set of all midlines in the placement.
Area of a placement P is the product of its height and width.
Area{P) = pJieight{P) x p.width(P)
A Placed Netlist Format. To describe the placement of a netlist in very simple terms, we found it convenient to extend, with structured comment lines, the blif format [15] . The example in Figure 4 highlights a section of a placed blif file that corresponds to the compacted and optimized placement of FA2, full adder circuit. The additional comment lines # wire cut i... denote the order of net nodes in the net separator i. Similarly the comment lines # cell cut i... denote the order of cell nodes and feedthrough nodes in the midline i. With the description of any cell node a comment of # given order or # reverse order is inserted to indicate the orientation of the cell. Following the functional description of each node, there are 2 comment lines, one beginning with # wire channel which gives the wire channel that a cell node and its inputs occupy, the other begins with # cell channel which contains cell channel information about the cell node and its inputs. Feedthrough nodes like c. Iev2 are put in as buffers.
For example, the line # wire channel eQl f Ql gQ2 signifies that the cell node g is located in the wire channel 2 and that there are two net nodes at its inputs, e and f, which are in the wire channel 1. The line # cell channel eQ2 f Ql gQ2 signifies that the cell node g is located in the cell channel 2 and that there are two net nodes at its inputs, e and f, which are in the cell channels 2 and 1, respectively.
V. TOCO PLACEMENT ALGORITHM
The acronym TOCO is based on the four steps of the proposed placement algorithm: Topological sort that places net nodes and cell nodes on the unit-size grid in level order, Optimization of level order placement for minimum total wire crossing subject to the level order, Compaction and folding of the level-order placement into a near-perfect square layout, Optimization of compacted placement for minimum total wire crossing subject to the level order after compaction, and minimum total wire density, subject to order for minimum total wire crossing.
To minimize the total wire crossing, we currently use DOT, which implements a variant of the median heuristic [12] . To minimize the total wire density after total wire crossing minimization, we must assign net nodes and feedthrough cell nodes to grid regions such that critical wire density is minimized in each net-to-cell and cell-to-net channel -subject to node order imposed by the total wire crossing minimization algorithm. Our current approach consists of making a kway partitioning assignment of p net nodes and q feedthrough nodes to k grid regions in each channel, such that the wire crossing on the k-1 cell channel separator segments is minimized, subject to node order from total wire crossing minimization. The implementation of a total wire density optimization algorithm is in progress.
Summary Overview of TOCO.
T opological sort. This procedure may include the search for a minimal FVS in the circuit is sequential. It is the basis for generating the initial placement as a multi-level directed bipartite graph. This procedure assigns a level to every cell and net node in graph G. O ptimization of placement P(G) for minimization of wire crossings. At this point, the level of a node is still constrained by its level in the topologically sorted graph. C compact and fold. Using the optimized placement obtained from the wire-crossing minimization algorithm, we fold the placement into a compacted placement. Basic rules are: Rl Remove all feedthroughs. In our model, feedthroughs have no function other than that of routing nets which span more than one level. R2 Count the cell nodes. If N is the number of cell nodes, then the number of wire channels in the compacted form is [-/N]. The number of cells in a wire channel, wire channel capacity, is determined similarly. R3 If the current number of cell nodes in wire channel i exceeds its wire channel capacity, then fold forward (move excess cell nodes at the top to the top of wire channel i + 1.) R4 If the current number of cell nodes in wire channel i is less than its wire channel capacity, then fold backwards (move deficient cell nodes from the bottom of the next available wire channel to the bottom of wire channel i.) R5 Insert feedthroughs "for nets that span more than 1-wire channel.
R6 Save as a compacted placement, P.Compact{G). O ptimization of placement of compacted P(G). This consists of two distinct phases:
PI Minimize the total wire crossing in the bipartite form embedding of the graph. Net nodes and cell nodes are constrained to the levels assigned to them by the compaction step. P2 Minimize the total wire density in the bipartite form embedding of the graph. Net nodes and cell nodes are constrained to levels and the order assigned to them by the preceding wire crossing minimization phase. Wire crossing remains unchanged in this phase, only the total wire density is reduced.
TOCO implementation and Pseudocode. Implementations of various phases of the TOCO procedure have been optimized. Our annotated blif format seamlessly introduces net nodes for each cell node, as is required in the bipartite form. By using the same names for cell nodes and the net nodes they drive, the complexity of any phase in the procedure is reduced to that of searching in an array. Here our naming convention allows us to lexicographically sort arrays to make multiple simultaneous searches. The complexity of the procedure is dominated by these sorting calls and this can be done emciently in 0(nlogn). Figure 5 shows the pseudo-code for the TOCO placement algorithm. 
VI. DESIGN OF EXPERIMENTS
The capability to synthesize a large number of WSI circuit mutants, based on wire perturbation classes, motivates us to examine the sampling methods that arise in the design of experiments. Such methods, first formalized in [16] , have been adopted widely in many fields of science. In this paper, we adapt them to analyze the performance of important graphbased algorithms in the context of EDA. For each reference circuit, we propose to synthesize equivalence subclasses of circuit mutants, based on 0 to 100% perturbation. Each subclass contains 100 randomly chosen mutant circuits, each listed in a different random order. This sample size is large enough for the sampling distributions to be considered normal or nearly normal; the population parameters may be estimated closely by their corresponding sample statistics. The eight equivalence subclasses, labeled from A to H, are defined in terms of the perturbations we use to generate each class. In order to encourage unbiased experiments with these classes, we have permuted the perturbations relative to the label assignments:
{A,B,C,D,E,F,G,H} =
permutation{0w, \w, 2w, 5%, 10%, 20%, 40%, 100%}
In (17), WSI classes A-H are defined either in terms of q-% wire perturbations or 0-wire, 1-wire, 2-wire (0w, lw, 2w) perturbations. Here, we only disclose that the 0-wire perturbation class is class-D. We plan to identify the labels A-H in terms of the respective perturbation classes in (17) later, once there are additional experiments reported by others and participants have the opportunity to meet and present their results at a joint session of a conference. More details about such plans can" be found under http://www.cbl.ncsu.edu/experiments/. A case study tutorial of average-case performance of two algorithms and their differences has demonstrated that up to six distinct equivalence classes of data are useful to render an unbiased comparison of two well-known sorting algorithms [17] . The long-term goal of this series of experiments, presently starting with eight equivalence classes, is to facilitate generation of similar comparisons for the more complex and diverse algorithms in EDA. Whatever may be decided about the most suitable number of equivalence classes through wider participation later on, the class of 0-wire perturbations will remain important. As demonstrated in this paper as well as earlier [18] , the objective functions used in a number of graph-based algorithms can be very sensitive to the order of nodes in the graph, even when graphs are isomorphic. In our experiments, the 100 netlists in the 0-wire perturbation class are simply isomorphic instances of the reference netlist in a randomized order.
Paraphrasing the context of the traditional treatments and blocks [19] , we propose to archive data in the context of algorithms and equivalence class mutants as shown in Figure  6 (a). For each of the 'a' algorithms we consider '6' mutants in one of the equivalence classes in (17) . For each algorithm Alg.j and mutant M-X_k, X € {A,... ,#}, we record two observations: the initial value of the objective function tuple X_jk-I, and the final value of the objective function tuple X_jk-F. The initial value corresponds to a placebo treatment of the mutant M-X_k: it is the value of the objective function before engaging the algorithm to optimize it. The final value corresponds to the optimized value of the objective function after engaging the algorithm to optimize it.
A number of analyses can be performed once data is archived as shown in Figure 6 (a) and only a few are discussed in this paper. For the most part, we shall concentrate on analyzing data as presented in Figure 6(b) . In particular, for samples associated with each algorithm Alg.j and mutant class M-X, X e {A, ...,H}, we evaluate the 95% confidence interval of the sample mean, the sample mean, and the sample variances as tuples {M-X_j-I} and {M-X_j-F} respectively. We summarize such evaluations in the form shown in Figure 6 (c). The next section provides representative summaries of data samples we generated and archived under http://www.cbl.ncsu.edu/experiments/.
VII. EXPERIMENTS
This section summarizes experiments based on four equivalence classes of circuit mutants of the reference circuit C1355 [20, 21] . The four classes, with 100 mutant circuits in each class, are based on wiring signature-invariant perturbations as defined in Section VI: W.Class_B, W.Class.C, W-ClassJD, and W_Class_E. Notably, W-ClassJ) is the 0-wire perturbation class -all netlists in this class are isomorphic.
Context of experiments. The context in which we propose to perform placement experiments is shown in Figure 7 . The flow may be executed as follows:
1. prepare netlists of appropriate equivalence classes; 2. place any number of equivalence class netlists with any placer e.g TOCO; 3. archive results of placements in a common grid-based format, such as suggested in Figure 4 ; 4. process grid-based placements by either or both:
(a) a common placement evaluator (e.g. place.eval that can process results of any grid-based placement and produce a standardized report in terms of grid-based layout parameters, optionally mapped to technologyspecific parameters from the library database; (b) a common router that can process results of any gridbased placement and produce a layout and a standardized report in terms of technology-specific layout parameters. Ideally, one may be able to correlate the grid-based parameter reported by place.eval, such as total and critical wire crossings, total and critical wire length, total and critical wire density, to comparable parameters measured in actual layouts. If the correlations are reasonable, the grid-based model may be calibrated for fast estimation of cell-based layouts.
Finally, execution of placement experiments, with different algorithms, as suggested in Figure 7 , will allow us to study their behavior and improve them further. Figure 8 -Histograms. Here we contrast layout parameters reported by the placement and routing tool OASIS [13] and grid-based parameters optimized by TOCO and reported by place.eval -for 100 instances of the mutant circuits in W.Class_B. The coefficient of variation (mean/stdev) for layout area reported by OASIS is 4.4%, and 3.8% for the minimized wire crossing reported by T0C0. It would be useful to know whether the placements from T0C0 would improve the layout beyond the one currently shown for OASIS.
It is clear that that wirelength and total layout area, as reported by OASIS, are closely correlated. Minimizing the wirelength does minimize the area. The square of the correlation coefficient of total area to total wirelength as reported by OASIS is 0.835. However, current results with T0C0 show that the correlation of total wire length and total wire crossing is not high. We attribute this behavior to the sub-optimal assignment of net nodes to the respective cell channels. We expect the correlation to improve once we complete the implementation of the channel wire density minimization algorithm. For all these classes, the procedure dramatically reduces the total wire length (TWL), critical wire length (CWL), total wire crossing (TWC) and critical wire crossing (CWC). However the improvements in other parameters such as average wire density (AWD) and width are not as dramatic. We expect to report improved results for the average wire density (AWD) and width in the final version of this paper; upon completion of the channel wire density minimization algorithm implementation.
Statistical interpretations. The reader should observe the sensitivity of algorithms when evaluating the 0-wire perturbation class (W.Class J)) in the table of Figure 8 and elsewhere [5] . Experiments implemented in this paper were designed to begin addressing issues such as • Consider, for a given mutant class, (1) sample mean and standard deviation of the unoptimized objective function, and (2) sample mean and standard deviation of the objective function optimized via algorithm Alg_j. We have to decide: (HO) is the difference in the means due to chance, or (HI) is it due to the effect of algorithm Alg_j? • Consider, for a given algorithm Alg_j, (1) sample mean and standard deviation of the optimized objective function in terms of mutant class A, and (2) sample mean and standard deviation of the optimized objective function in terms of mutant class B. We have to decide: (HO) is the difference in the means due to chance, or (HI) is it due to differences of the two mutant classes? « Consider, for a given mutant class (1) sample mean and standard deviation of the objective function optimized by algorithm Alg_ j 1, and (2) sample mean and standard deviation of the objective function optimized by algorithm Alg_j2. We have to decide: (HO) is the difference in the means due to chance, or (HI) is it due to different performances of the algorithms Alg_jl and Alg_j2? To encourage wider participation, complete tables of all data samples summarized in this paper have been archived on our web site (http://www.cbl.ncsu.edu/experiments/). The archives are updated periodically with additional experiments and cases of more detailed statistical analyses [14] The main conjecture in this paper, that good column-based placements can be produced by minimizing two wire crossing numbers, requires access to an open routing tool that will accept a user-defined placement. Ideally, more than a single routing tool should be used in such a study. We are looking for a partner to assist us in this process. The large number of mutant circuits in equivalence classes provides a sound basis for the design of benchmarking experiments that can prove or disprove this conjecture at a sound level of significance. Collaborative web-based experiments are being initiated under http://www.cbl.ncsu.edu/experiments/. The proposed placement evaluator place.eval will process results of any grid-based placement and produce a standardized report in terms of grid-based layout parameters. We hope that the approach, after testing by several users and some calibration, will prove useful.
