AIG Rewriting Using 5-Input Cuts by Li, Nan & Dubrova, Elena
ar
X
iv
:1
10
8.
36
75
v1
  [
cs
.L
O]
  1
8 A
ug
 20
11
1
AIG Rewriting Using 5-Input Cuts
Nan Li Elena Dubrova
Royal Institute of Technology, ES/ICT/KTH, 164 46 Kista, Sweden
Abstract—Rewriting is a common approach to logic optimiza-
tion based on local transformations. Most commercially available
logic synthesis tools include a rewriting engine that may be used
multiple times on the same netlist during optimization. This paper
presents an And-Inverter graph based rewriting algorithm using
5-input cuts. The best circuits are pre-computed for a subset
of NPN classes of 5-variable functions. Cut enumeration and
Boolean matching are used to identify replacement candidates.
The presented approach is expected to complement existing
rewriting approaches which are usually based on 4-input cuts.
The experimental results show that, by adding the new rewriting
algorithm to ABC synthesis tool, we can further reduce the area
of heavily optimized large circuits by 5.57% on average.
Index Terms—Logic optimization, rewriting, NPN classes, cut
enumeration, Boolean matching
I. INTRODUCTION
Logic optimization approaches can be divided into
algorithmic-based methods, which are based on global trans-
formations, and rule-based methods, which are based on local
transformations [1]. Rule-based methods, also called rewriting,
use a set of rules which are applied when certain patterns are
found. A rule transforms a pattern for a local sub-expression,
or a sub-circuit, into another equivalent one. Since rules
need to be described, and hence the type available of oper-
ations/gates must be known, the rule-based approach usually
requires that the description of the logic is confined to a limited
number of operation/gate types such as AND, OR, XOR, NOT
etc. In addition, the transformations have limited optimization
capability since they are local in nature. Examples of rule-
based systems include LSS [2] and SOCRATES [3].
Algorithmic methods use global transformations such as
decomposition or factorization, and therefore they are much
more powerful compared to the rule-based methods. However,
general Boolean methods, including don’t care optimization,
do not scale well for large functions. Algebraic methods
are fast and robust, but they are not complete and thus
often give lower quality results. For this reasons, industrial
logic synthesis systems normally use algebraic restructuring
methods in a combination with rule-based methods.
In this paper, we propose a new rewriting algorithm based
on 5-Input cuts. In the algorithm, the best circuits are pre-
computed for a subset of NPN classes of 5-variable functions.
Cut enumeration technique [4] is used to find 5-input cuts for
all nodes, and some of them are replaced with a best circuit.
The Boolean matcher [5] is used to map a 5-input function
to its canonical form. The presented approach is expected to
complement existing rewriting approaches which are usually
based on 4-input cuts. Our experimental results show that, by
adding the new rewriting algorithm to ABC synthesis tool [6],
we can further reduce the area of heavily optimized large
circuits by 5.57% on average.
The paper is organized as follows. Section II describes
main notions and definitions used in the sequel. Section III
summarises previous work. Section IV presents the proposed
approach. Section V shows experimental results. Section VI
concludes the paper and discusses open problems.
II. BACKGROUND
A Boolean network is a directed acyclic graph, of which the
nodes represent logic gates, and the directed edges represent
connections of the gates. A network is also referred to as a
circuit.
A node of the network has zero or more fanins, and zero or
more fanouts. A fanin of a node n is a node nin such that there
exists an edge from nin to n. Similarly, a fanout of a node n
is a node nout such that there is an edge from n to nout. The
primary inputs (PIs) of a network are the zero-fanin nodes of
the network. The primary outputs of a network are a subset of
all nodes. If a network contains flip-flops, the inputs/outputs
of the flip-flops are treated as POs/PIs of the network.
An And-Inverter graph (AIG) is a network, of which a node
is either a PI or a 2-input AND gate, and an edge is negatable.
An AIG is structurally hashed [7] to ensure uniqueness of the
nodes. The area of an AIG is measured by the number of
nodes in the network.
A cut of a node n is a set C of nodes such that any path from
a PI to n must pass through at least one node in C. Node n
itself forms a trivial cut. The nodes in C are called the leaves
of cut C. A cut C is K-feasible if |C| ≤ K; additionally, C is
called a K-input cut if |C|= K.
The level of a node n is the number of edges of the longest
path from any PI to n. The depth of a network is the largest
level among all internal nodes of the network.
Two Boolean functions, F and G, are NPN-equivalent and
belong to the same NPN equivalence class, if F can be trans-
formed into G through negation of inputs (N), permutation of
inputs (P), and negation of the output (N) [8].
III. PREVIOUS WORK
Rewriting of networks was introduced in the early logic
synthesis systems. SOCRATES [3] and the IBM system [2][9]
performed rewriting under a set of rewriting rules to replace
a combination of library gates with another combination of
gates which had a smaller area or delay. In SOCRATES,
these rules were managed in an expert system deciding which
ones to apply and when. The rules in SOCRATES were
written by human designers, based on personal experience and
observation of experimental results.
2In the MIS system [10], which later developed into SIS [11],
local transformations such as simplification were used to lo-
cally optimize a multi-level network after global optimization.
Two-level minimization methods such as ESPRESSO [1] were
used to minimize the functions associated with the nodes in
the network. Similar methods [12] were also included in works
of [13][14][15].
Rule-based rewriting method was used to simplify AND-
OR-XOR networks in the multi-level synthesis approach pre-
sented in [16].
AIG-based rewriting technique presented in [17] is used as a
way to compress circuits before formal verification. Rewriting
is performed in two steps. In the first step, which happens only
once when the program starts, all two-level AIG subgraphs are
pre-computed and stored in a table by their Boolean functions.
In the second step, the AIG is traversed in topological order.
The two-level AIG subgraphs of each node are found and
the functionally equivalent pre-computed subgraphs are tried
as the implementation of the node, while logic sharing with
existing nodes is considered. The subgraph leading to least
number of overall nodes is used as the replacement of the
original subgraph.
An improved AIG rewriting technique for pre-mapping
optimization is presented in [18]. It uses 4-input cuts instead
of two-level subgraphs in rewriting, and preserves the number
of logic levels so the area is reduced without increasing
delay. Additionally, AIG balancing, which minimizes delay
without increasing area, is used together with rewriting, to
achieve better results. Iterating these two processes forms
a new technology-independent optimization flow, which is
implemented in the sequential logic synthesis and verification
system, ABC [6]. Experiments show that this implementation
scales to very large designs and is much faster than SIS [11]
and MVSIS [19], while resulting in circuits with the same or
better quality.
IV. AIG REWRITING USING 5-INPUT CUTS
The presented algorithm can be divided into two parts:
1) Best circuit generation
2) Cut enumeration and replacement
Part 1 of the algorithm tries to find the optimal circuits for a
subset of “practical” 5-variable NPN classes, and stores these
circuits. Part 2 of the algorithm enumerates all 5-input cuts in
the target circuit, and chooses to replaces a cut with a suitable
best circuit.
In the implementation of rewriting using 4-input cuts
in [18], pre-computed tables of canonical forms and the
transformations are kept for all 216 4-input functions [6][18].
As we extend rewriting to 5-input cuts, the size of these tables
becomes 232. i.e. too large for using in a program that runs on
a regular computer. In our implementation, we use a Boolean
matcher [5] to dynamically calculate the canonical form of
a truth table and the corresponding transformation from the
original truth table.
A. Best circuit generation
Similarly to [18], we pre-compute the candidate circuits
for each NPN class so they can be directly used later. There
are 616126 NPN equivalence classes for 5-input functions,
among which only 2749 classes appear in all IWLS 2005
benchmarks [20] as 5-feasible cuts. We picked 1185 of them
with more than 20 occurrences, and generated best circuits for
representative functions of these classes.
Due to the expanded complexity of the problem, we had to
make some trade-offs between the quality of the circuits and
the time and memory usage of our algorithm. Our implemen-
tation has following differences compared to [18]:
• Use of Boolean matcher to calculate canonical form,
instead of table look-up.
• Use of a hash map to store the candidate into best circuits,
instead of using a full table.
• When deciding whether to store a node in the node list, a
node with the same cost as an existing node is discarded,
instead of being stored in the list.
• Nodes of both canonical functions and the complement of
the canonical functions are used as the candidate circuit,
while in [18] complement functions are not used.
• When the number of nodes reaches an upper limit, a
reduction procedure is performed before the generation
continues, leaving only the nodes used in the circuit table.
We use two structures to store the best circuits: the forest,
list of all nodes, and the table, storing only the pointers to
the nodes in the list, which represent canonical functions or
their complements. In the forest, a node can either be an AND
node or an XOR node, and two incoming edges of a node have
complementation attributes. The cost of a node is the number
of AND nodes plus twice the number of XOR nodes those are
reachable from this node towards the inputs.
First, the constant zero node and five nodes for single
variables are added into the forest. The constant node and one
of the variable nodes are added to the table, since all variable
nodes are NPN equivalent. Then, for each pair of nodes in the
forest, five types of 2-input gates are created, using the pair
as inputs:
• AND gate
• AND gate with first input complemented
• AND gate with second input complemented
• AND gate with both inputs complemented
• XOR gate
A newly created node is stored in the forest if the following
conditions are met, otherwise it is discarded:
• The cost of the node is lower than any other node with
the same functionality.
• The cost of the node is lower than or equal to any other
node with NPN-equivalent functionality.
In addition, the pointer to this node is added to the table if
the following condition is also met:
• The function of the node is the canonical form represen-
tative, or its complement, in the NPN-equivalence class
it belongs to.
When the number of nodes in the forest reaches an upper
limit, a node reduction procedure is performed, where only
the reachable nodes from the nodes in the table are left in the
forest.
3Algorithm 1 GenerateBestCircuits(P, u, nmax): Generate
candidate best circuits for a subset of NPN classes of 5-input
Boolean functions.
1: Add constant zero node to N and C
2: Add variable nodes to N
3: Add node of variable 0 to C
4: for each i from 2 to |N| do
5: for each j from 1 to i− 1 do
6: TryNode(AND, Ni, N j)
7: TryNode(AND, Not(Ni), N j)
8: TryNode(AND, Ni, Not(N j))
9: TryNode(AND, Not(Ni), Not(N j))
10: TryNode(XOR, Ni, N j)
11: if num. of uncovered practical NPN classes ≤ u then
12: return
13: end if
14: if |N|> nmax then
15: ReduceNodes()
16: i← 1
17: break
18: end if
19: end for
20: end for
The algorithm stops when the number of uncovered “prac-
tical” classes is smaller than a threshold value.
Finally, the generated best circuits are stored, so they can
be used later when rewriting takes place.
The pseudo-code of the proposed best circuit
generation algorithm is shown in Algorithm 1. The
GenerateBestCircuits procedure returns a node list
N and a table of nodes C recording the candidate best circuits
for a subset of NPN classes. It takes three parameters.
Parameter P is a set of truth tables of “practical” 5-variable
functions. This set contains about 1200 5-input canonical
NPN representatives with 20 or more occurrence in IWLS
2005 benchmarks. Parameter u is an integer indicating the
acceptable number of uncovered practical NPN classes; nmax
is an integer indicating the limit number of nodes when a
node reduction is needed. In our implementation, u is set to
60, and nmax is set to 10000000.
The pseudo-code for procedure TryNode is shown in Al-
gorithm 2. TryNode creates a node, and determines whether
to put it into the node list and the circuit table. Parameter
T ∈ {AND,XOR} indicates whether the new gate should be
an AND gate or an XOR gate. Parameter n0 and n1 are two
fanins of the new gate.
Procedure ReduceNodes reduces the node list by removing
the nodes that are not used in any circuit in the circuit table.
Procedure Canonicalize calculates the canonical form of
the truth table of a given function.
In the algorithms, variables N, C and M are globally
accessible. N denotes the list of all nodes. C is a hash map
of the candidate circuits; each of its entry is a set of nodes
storing the root node of candidate circuits for the NPN class
of this entry. M is a temporary hash map to store the currently
minimum costs of all functions.
Algorithm 2 TryNode(T , n0, n1): Create a node of type T
with fanins n0 and n1, and determine whether to put it into N
or C.
1: nnew ← CreateNode(T , n0, n1)
2: t ← GetTruth(nnew)
3: if Mt not exist or Mt > Cost(nnew) then
4: Mt ← Cost(nnew)
5: else
6: return
7: end if
8: tcanon ← Canonicalize(t)
9: if ∃n ∈Ctcanon such that Cost(n)< Cost(nnew) then
10: return
11: end if
12: add nnew to the end of list N
13: if t 6= tcanon and t 6= Complement(tcanon) then
14: return
15: end if
16: if ∃n ∈Ctcanon such that Cost(n)> Cost(nnew) then
17: Ctcanon ← /0
18: end if
19: if t = tcanon then
20: Ctcanon ←Ctcanon
⋃
{nnew}
21: else
22: Ctcanon ←Ctcanon
⋃
{Not(nnew)}
23: end if
24: return
B. Cut enumeration and replacement
We use a quite similar cut enumeration and replacement
technique as in [18]. The main difference is that we use a
Boolean matcher to calculate the canonical form of the NPN
representative as well as the transformation to the canonical
form from the original function, while in [18], a faster table
look-up is used.
The Boolean matcher proposed in [5] calculates only the
canonical form representation. We modified the program so it
can simultaneously generate the NPN transformation, which is
needed when connecting the replacement graph to the whole
circuit.
Nodes are traversed in topological order. For each node
starting from the PIs to the POs, all of its 5-input cuts are
listed [4]. The canonical form truth table and the correspond-
ing NPN transformation of each cut are calculated using the
Boolean matcher [5]. Each cut is then evaluated whether
there is a suitable replacement that does not increase the
area of the network. Finally, the cut with the greatest gain
is replaced by a best circuit. In the presented algorithm, zero-
cost replacement is accepted, since it is a useful approach
for re-arranging AIG structure to create more opportunities in
subsequent rewriting [17].
The pseudo-code of the rewriting procedure is shown in
Algorithm 3. For each node in the network, Nbest denotes the
largest number of nodes saved by replacing a cut of the node
by a pre-computed candidate circuit; cbest and ubest denotes
the corresponding candidate circuit and the original cut, re-
spectively. These three variables are updated simultaneously,
4if there exists a possible replacement.
Procedure ConnectToLeaves(N,c,u,Trans) connects the
fanins of candidate circuit c to the leaves of cut u, following
the NPN transformation Trans.
Procedure Reference(N,c) increases the reference count
of the nodes belong to sub-circuit c, in network N, whereas
Dereference(N,c) decreases the reference count. When the
reference count of a node becomes zero, the node does not
belong to the network.
Algorithm 3 RewriteNetwork(N, C): Rewrite a Boolean
network N using candidate circuits stored in hash map C.
1: for each node n in N, in topological order do
2: Nbest ←−1
3: cbest ←NULL
4: ubest ← NULL
5: for each 5-input cut u of n do
6: t ← GetTruth(u)
7: (tcanon,Trans)← Canonicalize(t)
8: for each candidate circuit c in Ctcanon do
9: ConnectToLeaves(N,c,u,Trans)
10: Nsaved ← Dereference(N,u)
11: Nadded ← Reference(N,c)
12: Ngain ← Nsaved−Nadded
13: Dereference(N,c)
14: Reference(N,u)
15: if Ngain ≥ 0 and Nbest < Ngain then
16: Nbest ← Ngain
17: cbest ← c
18: ubest ← u
19: end if
20: end for
21: end for
22: if Nbest =−1 then
23: continue
24: end if
25: Dereference(N,ubest)
26: Reference(N,cbest)
27: end for
In [18], the authors proposed an optimization flow com-
posed of balance, rewrite and refactor processes, and imple-
mented it in the tool ABC [6] with the script resyn2. Compared
to [18], rewriting using 5-input cuts exploits larger cuts and
more replacement options, thus has the potential for getting
resyn2 script out of local minima, providing better rewriting
opportunities.
V. EXPERIMENTAL RESULTS
The presented algorithm is implemented using structurally
hashed AIG as an internal circuit representation and integrated
in ABC synthesis tool as a command rewrite5. To evaluate
its effectiveness, we performed a set of experiments using
IWLS 2005 benchmarks [20] with more than 5000 AIG nodes
after structural hashing. All experiments were carried out
on a laptop with Intel Core i7 1.6GHz (2.8GHz maximum
frequency) quad-core processor, 6 MB cache, and 4 GB RAM.
First, for each benchmark, we applied a sequence of com-
mands resyn2; rewrite5; resyn2 in the modified ABC and
compared the result to two consecutive runs of resyn2 without
rewrite5 in between.
The results are summarized in Table I. Columns labeled by
A give the area in terms of AIG nodes. Columns labeled by t
give the runtime. The improvement of area and the increase of
runtime are then calculated and shown in the last two columns.
Table I shows that the average improvement in area achieved
by adding rewrite5 in between two resyn2 runs is 3.50%, at
the cost of 33.18% of extra runtime. This result indicates that
the proposed rewrite5 method is effective in bringing ABC’s
resyn2 optimization script out of local minima, leading to
better optimization possibilities.
The second experiment is performed similarly, except we
used a longer optimization flow: resyn2; rewrite5; resyn2;
rewrite5; resyn2. The result is compared to three consecutive
runs of resyn2 script.
The result of the second experiment is shown in Table II,
which has the same structure as Table I. The average improve-
ment in area using the new optimization flow is 4.88%, at
the cost of 46.11% of extra runtime. This result shows the
possibility to further extend the resyn2 sequence by inserting
rewrite5 runs, to achieve even better optimization.
Even longer optimization flows were also tested. The
comparison of average results is summarized in Table III.
The improvement in area converges after certain number of
resyn2-rewrite5 iterations. The increase of improvement is
insignificant for more than four runs of resyn2.
improvement in area extra runtime
SS → SWS 3.50% 33.18%
SSS → SWSWS 4.88% 46.11%
SSSS → SWSWSWS 5.39% 47.48%
SSSSS → SWSWSWSWS 5.57% 51.21%
NOTE: S stands for resyn2; W stands for rewrite5.
TABLE III
SUMMARY OF AVERAGE RESULTS.
VI. CONCLUSION
In this paper, we present an AIG-based rewriting technique
that uses 5-input cuts. The technique extends the approach of
AIG rewriting using 4-input cuts presented in [18]. Experi-
mental results show that our algorithm is effective in driving
other optimization techniques, such as resyn2 script in ABC,
out of local minima. The proposed rewriting technique might
be useful in a new optimization flow combining rewriting of
both 4-input and 5-input cuts.
REFERENCES
[1] R. K. Brayton, A. L. Sangiovanni-Vincentelli, C. T. McMullen, and
G. D. Hachtel, Logic Minimization Algorithms for VLSI Synthesis.
Norwell, MA, USA: Kluwer Academic Publishers, 1984.
[2] J. A. Darringer, D. Brand, J. V. Gerbi, W. H. Joyner, and L. Trevillyan,
“LSS: A system for production logic synthesis,” IBM Journal of Re-
search and Development, vol. 28, no. 5, pp. 537 –545, 1984.
[3] D. Gregory, A. de Geus, K. Bartlett, and G. Hachtel, “SOCRATES:
A system for automatically synthesizing and optimizing combinational
logic,” in Design Automation, 1986. 23rd Conference on, 1986, pp. 79
– 85.
5resyn2;resyn2 resyn2;rewrite5;resyn2
benchmark nodes A1 t1 , sec A2 t2 , sec (A1−A2)/A1 (t2− t1)/t1
ac97 ctrl 14244 10222 0.759 10212 0.921 0.10% 21.34%
aes core 21522 20153 3.125 19945 4.079 1.03% 30.53%
b14 1 9471 5902 1.299 4712 1.929 20.16% 48.50%
b15 1 17015 10215 2.067 10012 2.204 1.99% 6.63%
b17 1 51419 31447 5.364 30943 6.948 1.60% 29.53%
b18 1 130418 81185 18.947 78430 25.344 3.39% 33.76%
b19 1 254960 153796 37.618 149269 47.708 2.94% 26.82%
b20 1 21074 13635 2.666 12048 3.819 11.64% 43.25%
b21 1 20538 12845 2.618 10940 3.900 14.83% 48.97%
b22 1 31251 19698 4.109 16986 5.870 13.77% 42.86%
des perf 82650 73724 15.717 73224 23.228 0.68% 47.79%
DMA 24389 22306 2.524 20269 3.129 9.13% 23.97%
DSP 44759 37976 5.635 37728 7.734 0.65% 37.25%
ethernet 86650 55925 5.790 55838 7.879 0.16% 36.08%
leon2 788737 774919 142.645 774065 187.660 0.11% 31.56%
mem ctrl 15325 8518 1.255 8449 1.511 0.81% 20.40%
netcard 803723 516124 93.952 516001 122.749 0.02% 30.65%
pci bridge32 22790 16362 1.719 16271 2.288 0.56% 33.10%
s35932 8371 7843 0.755 7843 1.003 0.00% 32.85%
s38417 9062 7969 0.812 7936 1.149 0.41% 41.50%
s38584 8477 7224 0.720 7188 0.921 0.50% 27.92%
systemcaes 12384 9614 1.705 9391 2.602 2.32% 52.61%
tv80 9635 7084 1.169 6970 1.498 1.61% 28.14%
usb funct 15826 13082 1.439 12892 1.858 1.45% 29.12%
vga lcd 126696 88641 10.517 88659 14.268 -0.02% 35.67%
wb conmax 47853 39163 4.748 38701 5.791 1.18% 21.97%
Average 3.50% 33.18%
TABLE I
EFFECTIVENESS OF IMPROVING DOUBLE resyn2 OPTIMIZATION FLOW USING rewrite5, ON IWLS 2005 BENCHMARKS.
resyn2;resyn2;resyn2 resyn2;rewrite5;resyn2;
rewrite5;resyn2
benchmark nodes A1 t1 , sec A2 t2 , sec (A1−A2)/A1 (t2− t1)/t1
ac97 ctrl 14244 10202 1.084 10180 1.396 0.22% 28.78%
aes core 21522 20044 4.562 19554 6.646 2.44% 45.68%
b14 1 9471 5652 1.702 4350 2.526 23.04% 48.41%
b15 1 17015 10029 2.335 9796 3.231 2.32% 38.37%
b17 1 51419 30107 7.446 29248 10.530 2.85% 41.42%
b18 1 130418 79204 24.658 74827 38.047 5.53% 54.30%
b19 1 254960 149177 49.815 143633 70.876 3.72% 42.28%
b20 1 21074 13405 3.811 10732 5.878 19.94% 54.24%
b21 1 20538 12240 3.603 9379 5.437 23.37% 50.90%
b22 1 31251 18967 5.614 15186 8.595 19.93% 53.10%
des perf 82650 73248 23.235 72322 36.941 1.26% 58.99%
DMA 24389 22288 3.573 20214 4.874 9.31% 36.41%
DSP 44759 37634 8.055 37273 12.465 0.96% 54.75%
ethernet 86650 55803 8.287 55794 12.067 0.02% 45.61%
leon2 788737 774560 213.921 773399 352.054 0.15% 64.57%
mem ctrl 15325 8408 1.726 8313 2.260 1.13% 30.94%
netcard 803723 515961 133.294 515771 181.877 0.04% 36.45%
pci bridge32 22790 16313 2.385 16235 3.650 0.48% 53.04%
s35932 8371 7843 1.034 7843 1.457 0.00% 40.91%
s38417 9062 7947 1.158 7886 1.725 0.77% 48.96%
s38584 8477 7217 1.021 7199 1.312 0.25% 28.50%
systemcaes 12384 9595 2.258 9248 4.043 3.62% 79.05%
tv80 9635 7030 1.618 6879 2.308 2.15% 42.65%
usb funct 15826 13041 2.037 12784 2.880 1.97% 41.38%
vga lcd 126696 88621 15.258 88687 22.223 -0.07% 45.65%
wb conmax 47853 38676 6.759 38095 9.032 1.50% 33.63%
Average 4.88% 46.11%
TABLE II
EFFECTIVENESS OF IMPROVING TRIPLE resyn2 OPTIMIZATION FLOW USING rewrite5, ON IWLS 2005 BENCHMARKS.
6[4] J. Cong, C. Wu, and Y. Ding, “Cut ranking and pruning:
enabling a general and efficient FPGA mapping solution,” in
Proceedings of the 1999 ACM/SIGDA seventh international symposium
on Field programmable gate arrays, ser. FPGA ’99. New
York, NY, USA: ACM, 1999, pp. 29–35. [Online]. Available:
http://doi.acm.org/10.1145/296399.296425
[5] D. Chai and A. Kuehlmann, “Building a better Boolean matcher and
symmetry detector,” in Design, Automation and Test in Europe, 2006.
DATE ’06. Proceedings, vol. 1, 2006, pp. 1 –6.
[6] Berkeley Logic Synthesis and Verification Group. ABC: A system for
sequential synthesis and verification, release 70930. [Online]. Available:
http://www.eecs.berkeley.edu/∼{}alanmi/abc/
[7] M. K. Ganai and A. Kuehlmann, “On-the-fly compression of logical
circuits,” in in International Workshop on Logic Synthesis, 2000.
[8] S. Hurst, D. Miller, and J. Muzio, Spectral Techniques in Digital Logic.
Academic Press, 1985.
[9] J. A. Darringer, W. H. Joyner, C. L. Berman, and L. Trevillyan, “Logic
synthesis through local transformations,” IBM Journal of Research and
Development, vol. 25, no. 4, pp. 272 –280, 1981.
[10] R. Brayton, R. Rudell, A. Sangiovanni-Vincentelli, and A. Wang, “MIS:
A multiple-level logic optimization system,” Computer-Aided Design of
Integrated Circuits and Systems, IEEE Transactions on, vol. 6, no. 6,
pp. 1062 – 1081, 1987.
[11] E. Sentovich, K. Singh, L. Lavagno, C. Moon, R. Murgai,
A. Saldanha, H. Savoj, P. Stephan, R. K. Brayton, and
A. L. Sangiovanni-Vincentelli, “SIS: A system for sequential
circuit synthesis,” EECS Department, University of California,
Berkeley, Tech. Rep. UCB/ERL M92/41, 1992. [Online]. Available:
http://www.eecs.berkeley.edu/Pubs/TechRpts/1992/2010.html
[12] R. Brayton, G. Hachtel, and A. Sangiovanni-Vincentelli, “Multilevel
logic synthesis,” Proceedings of the IEEE, vol. 78, no. 2, pp. 264 –
300, Feb. 1990.
[13] G. Hachtel, M. Lightner, K. Bartlett, D. Bostwick, R. Jacoby, P. Moceyu-
nas, C. Morrison, X. Du, and E. Schwarz, “BOLD: The boulder optimal
logic design system,” in System Sciences, 1989. Vol.I: Architecture
Track, Proceedings of the Twenty-Second Annual Hawaii International
Conference on, vol. 1, Jan. 1989, pp. 59 –73 vol.1.
[14] A. Malik, R. Brayton, A. Newton, and A. Sangiovanni-Vincentelli,
“A modified approach to two-level logic minimization,” in Computer-
Aided Design, 1988. ICCAD-88. Digest of Technical Papers., IEEE
International Conference on, Nov. 1988, pp. 106 –109.
[15] H. Savoj, A. Malik, and R. Brayton, “Fast two-level logic minimizers for
multi-level logic synthesis,” in Computer-Aided Design, 1989. ICCAD-
89. Digest of Technical Papers., 1989 IEEE International Conference
on, Nov. 1989, pp. 544 –547.
[16] T. Sasao, H. Hamachi, S. Wada, and M. Matsuura, “Multi-level logic
synthesis based on pseudo-kronecker decision diagrams and local trans-
formation,” in Proc. Reed-Muller’95, 1995, pp. 152–160.
[17] P. Bjesse and A. Boralv, “DAG-aware circuit compression for formal ver-
ification,” in Computer Aided Design, 2004. ICCAD-2004. IEEE/ACM
International Conference on, 2004, pp. 42 – 49.
[18] A. Mishchenko, S. Chatterjee, and R. Brayton, “DAG-aware AIG
rewriting: a fresh look at combinational logic synthesis,” in Design
Automation Conference, 2006 43rd ACM/IEEE, 2006, pp. 532 –535.
[19] MVSIS Group. MVSIS: Multi-valued logic synthesis system. UC
Berkeley. [Online]. Available: http://www-cad.eecs.berkeley.edu/mvsis/
[20] IWLS 2005 benchmarks. [Online]. Available:
http://iwls.org/iwls2005/benchmarks.html
