IBM Labs in Haifa © Copyright IBM SVRH: Non-local stochastic CSP solver with learning of high-level topography characteristics Yehuda Naveh Simulation Based Verification Technologies System Verification and Modeling
IBM Labs in Haifa Copyright IBM 2 CSP for simulation-based hardware verification CSP is a fundamental technology for Simulation-Based Verification The basis of all our generators: X-Gen, GenesysPro, Piparazzi, DeepTrans, FPgen The Generation Core (GEC) provides a tool-box for stimuli generation With focus on CSP: modeling, representation, solution Octopus provides an umbrella for non-GEC activities SVRH …
IBM Labs in Haifa Copyright IBM 3 This Presentation CSP for test generation (brief) The stochastic solver (using SVRH algorithm) Future considerations
IBM Labs in Haifa Copyright IBM 4 Constraints in test case generation EA: 0x????????_???????? Huge Domains (2 64 ) RA: 0x????????_???????? Quality of solution: Random uniformity Architecture: Effective address translates into real address in a complex way. Testing knowledge:Contention on cache row. Verification task:Real address in some corner memory space, Effective address aligned to 64K. EA: 0x0002FF00_ RA: 0x0002FF00_ Correct, but worthless! (e.g., Dechter et. al., 2002) EA: 0x????????_????0000 Huge Domains (2 64 ) RA: 0x0002FF??_???????? Quality of solution: Random uniformity EA: 0x????????_????0000 Huge Domains (2 64 ) RA: 0x0002FF??_??A4D??? Quality of solution: Random uniformity EA: 0x0B274FAB_0DBC0000 Huge Domains (2 64 ) RA: 0x0002FFC5_90A4D000 Quality of solution: Random uniformity
IBM Labs in Haifa Copyright IBM 5 Systematic Methods (DPLL, MAC, k-consistency, …) EA-RA Translation RA EA User: Special RA’s User: Aligned EA X X 1.Reach a level of consistency through successive reductions of sets 2.Choose an assignment for a variable, and maintain the consistency
IBM Labs in Haifa Copyright IBM 6 Systematic Methods RA EA User: Special RA’s User: Aligned EA X EA-RA Translation X X X X X
IBM Labs in Haifa Copyright IBM 7 Limitations of Systematic Methods: An example Only solution: Local consistency at onset: Choose randomly with probability 1/N of being correct (Solution reached at 600 million years)
IBM Labs in Haifa Copyright IBM 8 Limitations of Systematic Methods: Another example Already a single reduction of domains is hard
IBM Labs in Haifa Copyright IBM 9 Stochastic approaches: defining the metrics State: a tuple representing a single assignment to each variable (a, b, c) out of 2 64x3 states Cost: A function from the set of states to {0} U R + Cost = 0 iff all constraints are satisfied by the state. Simulated Annealing GSAT ….. All are local search
IBM Labs in Haifa Copyright IBM 10 SVRH: Simulated variable range hopping Non-local search If a state is represented by bits, many bits may be flipped in a single step. Check states on all length-scales in the problem. Hop to a new state if better. Learn the topography Get domain-knowledge as input strategies
IBM Labs in Haifa Copyright IBM 11 SVRH: Learning Cost normalization Topography parameters Length scales Preferred directions (rigidity, correlations between variables) Decision-making parameters (“learning the heuristics”) Should the next hop be domain-knowledge-based or stochastic? Should it rely on step-size learning? Should it rely on correlation learning? Never abandon totally stochastic trials!
IBM Labs in Haifa Copyright IBM 12 SVRH: Domain-knowledge strategies Variables:a, b, c : 128 bit integers Constraints: a = b = c a = … b = … c = … Strategy: Check all bits, one at a time. Solution guaranteed in 384 steps.
IBM Labs in Haifa Copyright IBM 13 SVRH: Domain-knowledge strategies Variables:a, b, c : 128 bit integers Constraints: a = b = c a = … b = … c = … Strategy: Check all bits, one at a time. Solution guaranteed in 384 steps.
IBM Labs in Haifa Copyright IBM 14 SVRH: Domain-knowledge strategies Variables:a, b, c : 128 bit integers Constraints: a = b = c a = … b = … c = … Strategy: Check all bits, one at a time. Solution guaranteed in 384 steps.
IBM Labs in Haifa Copyright IBM 15 SVRH: Domain-knowledge strategies Variables:a, b, c : 128 bit integers Constraints: c = (a * b) msb, number of 1’s in c = 5 a = … b = … c = … Strategy: Flip simultaneously all permutations of adjacent bits
IBM Labs in Haifa Copyright IBM 16 SVRH: Decision algorithm Decide type (‘random’, ‘learned’, ‘user-defined’) according to previous successes If ‘random’ Choose a random step-size create a random attempt with chosen step-size If ‘learned’: decide learn-type (‘step-size’, ‘direction’, ‘…’) according to previous successes if ‘step-size’: Choose a step-size which was previously successful (weighted) create a random attempt with chosen step size. if ‘direction’ Choose a direction which was previously successful (weighted) create a random attempt with chosen direction etc. If ‘user-defined’ Get next user-defined attempt
IBM Labs in Haifa Copyright IBM 17 SVRH: Usage Variables A set of bits Constraints Cost function Suggest initialization: random but consistent Remove fully constrained bits from problem Domain-Knowledge Strategies User provides sets of bits to be flipped. Engine decides when to use Commonly used constraints and strategies are provided as building blocks See also: Nareyek ’01, Michel and Van Hentenryck ’02, ’03.
IBM Labs in Haifa Copyright IBM 18 Local consistency at onset: Choose randomly with probability 1/N of being correct (Solution reached at 600 million years) SVRH: Solution reached in less then a second (similarly for N = ) Results: toy example Only solution:
IBM Labs in Haifa Copyright IBM 19 Results: FP-Gen Comparison with ZChaff for floating-point multiply benchmark (133 solvable tasks) ZChaffSVRH Max length64 bit128 bit Average time200.5 sec0.97 sec Best ratio2861 sec0.3 sec Worst ratio25 sec5.7 sec Quality (extreme case)0p0=0x43F p1=0xB p0=0x070E FFA 0p1=0x9560F399ECF4E191 Reports UNSATYesNo
IBM Labs in Haifa Copyright IBM 20 Results: FP-Gen Comparison with all engines for all-instructions benchmark (150 tasks) LionZChaffMixedSVRH Number of successes Average time per success (seconds)
IBM Labs in Haifa Copyright IBM 21 Results: Low Autocorrelation Binary Sequence (LABS) Hard combinatorial problem, well known optimization benchmark Objective: minimize the autocorrelation on a string of N 1’s and -1’s CLS is a special-purpose algorithm designed for this problem NCLS backtracksSVRH attemptsCLS hoursSVRH hours X X > 5.00
IBM Labs in Haifa Copyright IBM 22 Future Basic Input language Static learning More on next slide Test Generation Piparazzi G-Pro X-Gen Formal verification Bounded model checking, SAT FormalSim
IBM Labs in Haifa Copyright IBM 23 Future – more basic aspects Pruning steps in an overall SVRH (stochastic) framework Hybrid algorithm – extensive literature Report UNSAT (holy grail) First experiments on SAT: somewhat encouraging, but only at infancy More sophisticated learning Correlations (bayesian?), dynamics, other… Nothing done yet, cannot predict usefulness