SAT-Based Logic Synthesis (yes, Logic Synthesis Is Everywhere!)

Slides:



Advertisements
Similar presentations
Proofs from SAT Solvers Yeting Ge ACSys NYU Nov
Advertisements

Aaron Bradley University of Colorado, Boulder
DAG-Aware AIG Rewriting Alan Mishchenko, Satrajit Chatterjee, Robert Brayton Department of EECS, University of California Berkeley Presented by Rozana.
On the Relation between SAT and BDDs for Equivalence Checking Sherief Reda Rolf Drechsler Alex Orailoglu Computer Science & Engineering Dept. University.
Boolean Functions 1 ECE 667 ECE 667 Synthesis and Verification of Digital Circuits Boolean Functions Basics Maciej Ciesielski Univ.
Enhancing Model Checking Engines for Multi-Output Problem Solving Alan Mishchenko Robert Brayton Berkeley Verification and Synthesis Research Center Department.
Resolution Proofs as a Data Structure for Logic Synthesis John Backes Marc Riedel Electrical.
A Toolbox for Counter-Example Analysis and Optimization
Reducing Structural Bias in Technology Mapping
Automatic Test Generation
Introduction to Formal Verification
Synthesis for Verification
SAT-based Methods: Logic Synthesis and Technology Mapping
Alan Mishchenko UC Berkeley
Delay Optimization using SOP Balancing
Faster Logic Manipulation for Large Designs
Enhancing PDR/IC3 with Localization Abstraction
SAT-Based Logic Optimization and Resynthesis
New Directions in the Development of ABC
Logic Synthesis Primer
Logic Synthesis: Past, Present, and Future
Applying Logic Synthesis for Speeding Up SAT
Robert Brayton Alan Mishchenko Department of EECS UC Berkeley
Versatile SAT-based Remapping for Standard Cells
SAT-based Methods: Logic Synthesis and Technology Mapping
Integrating an AIG Package, Simulator, and SAT Solver
A Boolean Paradigm in Multi-Valued Logic Synthesis
Synthesis for Verification
SAT-Based Logic Synthesis (yes, Logic Synthesis Is Everywhere
LPSAT: A Unified Approach to RTL Satisfiability
Standard-Cell Mapping Revisited
Property Directed Reachability with Word-Level Abstraction
The Synergy between Logic Synthesis and Equivalence Checking
The Synergy between Logic Synthesis and Equivalence Checking
Faster Logic Manipulation for Large Designs
Introduction to Formal Verification
SAT-Based Area Recovery in Technology Mapping
Alan Mishchenko University of California, Berkeley
Canonical Computation without Canonical Data Structure
ECE 667 Synthesis and Verification of Digital Circuits
SAT-Based Optimization with Don’t-Cares Revisited
Canonical Computation Without Canonical Data Structure
Robert Brayton UC Berkeley
Scalable and Scalably-Verifiable Sequential Synthesis
Improvements to Combinational Equivalence Checking
SAT-based Methods for Scalable Synthesis and Verification
ECE 667 Synthesis and Verification of Digital Systems
Resolution Proofs for Combinational Equivalence
SAT-Based Logic Synthesis (yes, Logic Synthesis Is Everywhere!)
Integrating an AIG Package, Simulator, and SAT Solver
Introduction to Logic Synthesis
Canonical Computation without Canonical Data Structure
SAT-Based Logic Synthesis
Technology Mapping I based on tree covering
SAT-based Methods: Logic Synthesis and Technology Mapping
Alan Mishchenko UC Berkeley
Recording Synthesis History for Sequential Verification
SAT-based Methods: Logic Synthesis and Technology Mapping
Logic Synthesis: Past, Present, and Future
Delay Optimization using SOP Balancing
Alan Mishchenko UC Berkeley
Logic Synthesis: Past and Future
Canonical Computation without Canonical Data Structure
SAT-based Methods: Logic Synthesis and Technology Mapping
SAT-Based Logic Synthesis (yes, Logic Synthesis Is Everywhere!)
Introduction to Logic Synthesis with ABC
SAT-Based Logic Synthesis
Alan Mishchenko Department of EECS UC Berkeley
Faster Extraction of High-Level Minimal Unsatisfiable Cores
Integrating AIG Package, Simulator, and SAT Solver
Presentation transcript:

SAT-Based Logic Synthesis (yes, Logic Synthesis Is Everywhere!) Robert Brayton Alan Mishchenko Department of EECS, UC Berkeley Mathias Soeken Integrated Systems Laboratory, EPFL Luca Amarù Design Group, Synopsys Inc., Mountain View, CA

Overview Logic synthesis Boolean satisfiability SAT-based logic synthesis Canonical SOP computation Boolean decomposition, resubstitution, ECO, etc The use of don’t-cares Agile SAT solving Conclusions 2

Logic Synthesis Given a Boolean function, logic synthesis derives a new circuit to represent it (or improves an old one) Logic synthesis is used in hardware design and in such areas as formal verification, artificial intelligence, risk analysis, etc The original problem (deriving an optimal circuit structure for a given function) is very hard and solved heuristically in most cases The emphasis in logic synthesis computations is on scalability handling larger problem and getting solutions faster In recent years, traditional implementations based on SOPs and BDDs have been gradually replaced by SAT-based implementations both quality and runtime is often improved

Boolean Satisfiability Boolean variable can take value 0 or 1 (for example, a) Literal is Boolean variable with its value (for example, a) Clause is a disjunction of literals: a + b CNF is a conjunction of clauses: (a + b) & (a + c) Given CNF representing a Boolean function, a SAT solver checks whether the function is constant 0 Example of a satisfiabile problem: (a + b) & (a + c) - one solution is a = 1, b = 1, c = 1 Example of an unsatisfiable problem: (a + b) & (a + b) & (a + b) & (a + b) - no solution exists

SAT Solver in Practical Applications Netlist Answer: “SAT” or “UNSAT” CNF SAT solver CNF generator CNF Design constraints If SAT, a counter-example If UNSAT, a proof (both counter-examples and proofs are very useful in practice) User cost functions Miter Typical application: Equivalence Checking Build circuit Miter = (Specification != Implementation) Convert Miter into CNF and run SAT solver - If UNSAT, equivalence checking succeeds - If SAT, use the counter-example to debug the design Output Spec Impl Inputs

Incremental SAT Solver Initial CNF Round 1: SAT solver Initial assumptions Additional CNF Round 2: SAT solver New assumptions Additional CNF Round 3: SAT solver New assumptions (assumptions are CNF clauses used only in the current round – they are handled differently from the rest) Typical application: Bounded Model Checking Load init and the first time frame until (SAT solver returns “UNSAT”) { add clauses for the next time frame } P P P T1 T2 T3 … Init

A Note on Counter-Examples Counter-example (CEX) is an assignment of SAT variables that makes all CNF clauses satisfied For this, we check whether ONSET(x) = 1 is true CNF-based SAT solvers (in particular, MiniSAT), always return a complete assignment of variables (a minterm) In practice incomplete assignments are often preferred For this, we need to expand an assignment minterm by dropping (expanding) some of its literals, making it a cube To expand an assignment, we use the off-set (similar to “expanding a cube against the off-set” in ESPRESSO) We solve SAT instance: ONSET_minterm(x) & OFFSET(x) = 0 A proof of unsatisfiability gives us literals remaining in the cube

A Note on Proofs Proof of unsatisfiability (POU), is a sequence of resolution steps, which derives empty clause (contradiction) from the original clauses POU can be used to compute an UNSAT core (a subset of original clauses, which make the problem UNSAT) Computing the full POU/core is often not necessary A practical alternative is to compute an abstraction of the core in the form of a subset of assumptions needed for the problem to be UNSAT This is achieved by a dedicated API of the SAT solver (analyze_final) This API is very fast because it simply performs conflict analysis one more time, on the top level This API is very practical because it allows UNSAT runs to be as useful as SAT ones, without recording and traversing the complete POU

ISOP Computation ISOP is a Sum-of-Products (SOP) that is prime and irredundant F = ab + cd is an ISOP; G= ab + a is not an ISOP Logic synthesis derives circuit structure from functional description or improves given structure Deriving ISOP and factoring it can be useful for this Minato-Morreale ISOP computation is a BDD-based method widely used in practice However, this method is not scalable; better methods are needed

SAT-Based ISOP Computation Disclaimer! This is a simplified formulation of ISOP computation assumes that only one phase of the SOP is computed (in practice, we compute both) Algorithm Input Boolean function as two (shared) circuits (ON-set and OFF-set) Convert these to CNF Initialize two SAT solvers (S1 for ON-set; S2 for OFF-set) Iterate until S1 returns “UNSAT”: Get one minterm of the ON-set (satisfiable assignment computed by S1) Expand it into a prime against the OFF-set (proof computed by S2) Add this prime to the SOP and block it in the ON-set (add clause to S1) Post-process the SOP by removing redundant cubes (done using new solver S3) Resulting ISOP is canonical because the same fixed variable order is used to compute one satisfiable minterm to expand minterm into a prime to remove redundant primes if present Canonicity (as in the case of BDDs) guarantees that the result is the same for any structure of the circuit for any CNF generation algorithm for any SAT solver for any operating system

SAT-based ISOP Computation one minterm SAT solver S1 (ON-set) SAT solver S2 (OFF-set) SAT solver S3 (sat assignment) redundant SOP irredundant SOP one prime cube CNF CNF blocking clause (analyze_final) Factoring Original circuit {ON-set, OFF-set} Factored form SOP generator Improved circuit

Achieving Canonicity of the SOP Canonicity means that, for the given function, with the given variable order, we get the same SOP independent of circuit structure, CNF, SAT solver, OS, etc To this end, we have to canonicize the following steps minterm selection (a non-trivial task) cube expansion redundant cube removal Minterm is selected canonically by making sure that it is the lexicographically smallest SAT assignment under the variable order Cube is expanded canonically by making sure that literals are removed in the given order Redundant cubes are removed canonically by ordering them This is joint work with Mathias Soeken and Giovanni De Micheli at EPFL

The LEXSAT Algorithm Efficiently computes the lexicographically smallest assignment The main building block of the canonical ISOP computation if canonicity is not required, we can use any assignment Pseudo-code assignment LEXSAT_rec( assigned vars A, unassigned vars U, cnf F ) { if ( F is UNSAT under assumptions in A ) return ‘none’; // no satisfiable assignment if ( U ==  ) return Const1; // constant 1 Boolean function v = next unassigned variable in U in the given order; result = LEXSAT_rec( A  v=0, U / v, F ); if ( result != ‘none’ ) return !v & result; // found assignment with v == 0 return v & LEXSAT_rec( A  v=1, U / v, F ); // found assignment with v == 1 } assignment LEXSAT( ordered set of vars V, cnf F ) { return LEXSAT_rec( , V, F ); LEXSAT is mentioned in Donald Knuth, Art of Computer Programming, Volume 4 (6A): http://www-cs-faculty.stanford.edu/~uno/fasc6a.ps.gz - Implementing LEXSAT by iterative SAT calls (Ex. 109, page 150) - LEXSAT as modification of another algorithm (Ex. 275, page 165)

Boolean Resubstitution Given a functional specification a logic network whose functionality has to be preserved (in synthesis) or achieved (in ECO) Given a set of candidate divisors these are nodes found in the specification network or nodes with desirable properties to be synthesized Formulate a SAT problem, which Selects the divisors among the candidates Finds a new function of the node When the node is updated, the functionality of the network is preserved (in synthesis) or restored (in ECO) while achieving the optimization goal (such as area minimization)

Localizing Computation at a Node Definition A window for a node in the network is the context, in which its functionality is considered A window includes k levels of the TFI m levels of the TFO all re-convergent paths captured in this scope Window POs Window PIs k = 3 m = 3

Don’t-Cares as Constraints Applied to a SAT-Based Formulation Constructing a “don’t-care miter”: Collect candidate divisors di of node n Divisors are not in the TFO of n Their support is a subset of that of node n Duplicate the window of node n Use the same input variables Add inverter for node n in one copy Create comparator for the outputs of two copies Assume the comparator output to be 1 This is the care set of node n Convert all gates to CNF C(x)=1 … d2 n n d1 How the constraint is used: Add the constraint to the SAT solver Now, any solution found by the SAT solver is guaranteed to hold on the care-set (that is, it takes into account don’t-cares) X

SAT-Based Formulation Constructing a “resubstitution miter” Note use of care set C Resubstitution function exists if and only if the SAT problem is unsatisfiable Function f = F(d) is computed using cube enumeration, by expanding onset minterms (CNF A) against the offset (CNF B), as in ISOP computation

Agile SAT Solving Use simulation and circuit structure analysis whenever possible to avoid unnecessary SAT calls Simplify SAT-based formulations avoid QBF if regular SAT can be used experiment with different encodings try to reduce the number of variables and clauses reduce complexity of the constraints, even if it takes more variables counter-intuitively, sometimes larger CNFs have shorter runtimes Create formulations resulting in fast incremental runs in most of practical applications in logic synthesis, a well-tuned formation results in SAT runtimes not exceeding 1 sec per call (in fact, it is a fraction of a second on average) If constraints are complex, use lazy constraint addition Whenever possible, give initial solution to the SAT solver

Conclusion Reviewed logic synthesis and Boolean satisfiability Discussed a number of problems in logic synthesis that can be solved using Boolean satisfiability Shared practical advice on developing efficient SAT based applications In the rest of this tutorial, my collaborators will talk about exact delay optimization synthesis for emerging technologies

Abstract In the first part, it is shown how SAT solvers can be used to implement classical logic synthesis algorithms, such as technology mapping, LUT mapping, collapsing, and logic rewriting, in order to obtain better quality and higher flexibility. Key is to tightly integrate one or more SAT solvers into the algorithm and use them in an agile and reliable way. It is shown how SAT solvers can be used to generate canonical solutions. Consequently, SAT solvers can be used as a replacement for decision diagrams, retaining all their benefits but avoiding drawbacks such as memory explosion. The second part introduces new algorithms and data structures for delay optimization, a crucial optimization criteria. An enumeration based algorithm is introduced that allows to find optimum networks for given delay constraints. Majority-inverter graphs are introduced as a logic data structure that allows for significant delay optimization due to effective algebraic rewriting techniques. The third part illustrates an emerging application of logic synthesis. It shows how classical logic synthesis algorithms can be applied for the scalable design of quantum computers. Recent progress in fabrication makes the practical application of quantum computers a tangible prospect. And as quantum computers scale up to tackle problems in computational chemistry, machine learning, and cryptoanalysis, logic synthesis and design automation will be necessary to fully leverage the power of this emerging computational model.