# Backward Multiple Time-frame Expansion for Accelerating Sequential SAT 

Kousuke Torii ${ }^{\dagger}$ Kazuhiro Nakamura ${ }^{\dagger} \quad$ Kazuyoshi Takagi ${ }^{\ddagger} \quad$ Naofumi Takagi ${ }^{\ddagger}$<br>${ }^{\dagger}$ Graduate School of Information Science, Nagoya Univercity, Japan<br>\{ktorii, nakamura\}@takagi.i.is.nagoya-u.ac.jp<br>${ }^{\ddagger}$ Graduate School of Informatics, Kyoto Univercity, Japan<br>\{ktakagi,takagi\}@i.kyoto-u.ac.jp


#### Abstract

Sequential SAT is a formal verification proble, which finds an ordered sequence of input assignments to a sequential circuit, such that a desired objective is satisfied, or proving that no such sequence exists. Efficient algorithm for sequential SAT solver is required to deal with sequential circuits which have large state space. In this paper, we demonstrate backward multiple time-frame expansion(BMTE) a circuit expansion method for sequential SAT solver that supports it. Our algorithm improves the efficiency of state reduction and accelerates sequential SAT. Experimental results show that our method can speed up sequential SAT solving.


## I. Introduction

As VLSI technology advances, it becomes possible to design larger and more complex logic circuits. Verification of logic circuits becomes increasingly important as circuit designs are getting larger and more complex. Formal verification is a remarkable method that mathmatically proves the correctness of logic circuits.

Sequential SAT is a formal verification problem[1, 2, 3]. Sequential SAT is the problem of finding an ordered sequence of input assignments to a sequential circuit, such that a desired objective is satisfied, or proving that no sequence exists.

An algorithm for sequential SAT solvers with efficient state reductions has been proposed [1, 3]. The algorithm traces state transitions from the states satisfying a desired objective toward the initial state of sequential circuit. State reductions speed up the solving process by merging states and improve the efficiency of sequential search. Efficient high speed sequential SAT solver is required to deal with sequential circuits which have large state space.

In this paper, we demonstrate backward multiple timeframe expansion(BMTE) and present a new circuit expansion method for sequential SAT solver that supports it. In our approach, first, given sequential circuit is expanded with our circuit-expansion method for BMTE-based sequential SAT. Second, the expandeded sequential circuit
is fed to a sequential SAT solver with the conventional backward single time-frame expansion (BSTE). By the two-step process, we solve the sequential SAT ploblem for given circuit using BMTE.

When the initial state is far from the state satisfying desired objective, compared with BSTE, the proposed BMTE is suitable for merging states in different timeframes and pruning the state space for search. We show our promising experimental result.

The remainder of this paper is organized as follows: Sequential SAT is described in Sect. A.; backward multiple time-frame expansion for accelerating sequential SAT is described in Sect. III.; the proposed method is evaluated in Sect. IV.; and conclusions are presented in Sect. V.

## II. Preliminaries

Definition 2.1 An finite state machine(FSM) $M$ is a 6tuple $\left(S, \Sigma, \Gamma, \delta, \lambda, q_{0}\right)$ where

- $S$ is a finite set of states,
- $\Sigma$ is an input alphabet,
- $\Gamma$ is an output alphabet,
- $\delta: S \times \Sigma \rightarrow S$ is a state transition function,
- $\lambda: S \times \Sigma \rightarrow \Gamma$ is an output function,
- $q_{0}(\in S)$ is the initial state.

The behavior of $M=\left(S, \Sigma, \Gamma, \delta, \lambda, q_{0}\right)$ with respect to an input sequence $a_{1} a_{2} \ldots \ldots a_{n}\left(a_{i} \in \Sigma\right)$ is a sequence of states $q_{0} q_{1} \ldots q_{n}\left(q_{i} \in S\right)$ and a sequence of outputs $o_{1} o_{2} \ldots o_{n}\left(o_{i} \in \Gamma\right)$ satisfying $q_{i}=\delta\left(q_{i-1}, a_{i}\right)$.

Let $\Sigma^{*}$ be a set of all input sequences over $\Sigma$, and $\Sigma^{k}$ be a set of input sequences with length $k$. We use $\varepsilon$ as the sequence of length 0 .

To represent the behavior of $M$, the domain of $\delta$ and $\lambda$ are extended, and $\delta^{*}: S \times \Sigma^{*} \rightarrow S$ and $\lambda^{*}: S \times \Sigma^{*} \rightarrow \Gamma^{*}$ are introduced.

Definition $2.2 \delta^{*}: S \times \Sigma^{*} \rightarrow S$ is defined as follows.

$$
\begin{aligned}
& \text { - } \delta^{*}(q, \varepsilon)=q \\
& \text { - } \delta^{*}(q, x a)=\delta\left(\delta^{*}(q, x), a\right),\left(a \in \Sigma, x \in \Sigma^{*}\right)
\end{aligned}
$$

Definition 2.3 A set of reachable states $(R S)$ from the initial state $q_{0}$ of an FSM $M$ is defiened as follows.

- $R S(M)=\left\{q \mid \exists \omega \in \Sigma^{*}, q=\delta^{*}\left(q_{0}, \omega\right)\right\},\left(\omega \in \Sigma^{*}\right)$
A. Sequential SAT

Sequential SAT is the problem of finding an ordered sequence of input assignments to a sequential circuit, such that a desired objective is satisfied, or proving that no such sequence exists $[1,2,3]$. By setting the objectives as not to satisfy the property, e.g., $G(\neg p)$, sequential SAT solvers can be used for reachability analysis to the state with unbounded cycles.

Relevant part of the sequential SAT algorithm[3] is described in Algorithm 1. The procedure select-a-frameobjective() selects a state named frame objective $\left(f_{o}\right)$ to be solved next from objective lists $(O L)$ which is storing reached states in search. The procedure SAT-solve() performs backward time-frame expansion $[1,3]$ by solving the SAT problem to find a new state named frame solution $f_{s}$ from $f_{o}$ on combinational part $C$ of given sequential circuit. In the algorithm, it is assumed that each frame objective produces at most one frame solution $f_{s}$, where a direct single state transition from $f_{s}$ to $f_{o}$ exists.
The procedure solution-state-reduction() performs solution state reduction [1, 3]. It can merge states in the same time-frame, where time-frame is the set of the states that satisfy a desired objective within the same number of transitions. The state reduction speed up the algorithm by merging states to prune the state space for search. Fig. 1 shows solution state reduction. In Fig. 1, state transitions of a sequential circuit and backward traversal of sequential SAT are denoted with thin and bold arrows, respectively. The state 1111 is the desired initial objective state. In Fig. 1, time-frame 0,1 and 2 are describes. The state 1011 is a $f_{s}$ obtained from $f_{o}, 1111$. 0011 has also direct state transition to 1111, hence, it is merged with 1011 and, subsequently, the merged state -011 is obtained. Here, "-" means unnecessary value assignment. The procedure convert-to-clause() converts $f_{s}^{\prime}$ into state constraints for avoiding a state included in $f_{s}^{\prime}$ is obtained again by backward time-frame expansion. The solving process continues until either one of the following two cases is occurred. One case is when $f_{s}^{\prime}$ includes the initial state $q_{0}$ of given sequential circuit. In this case, the solution is found(SAT). The other case is when objective list becomes empty. In this case, the solution has never found. So, the answer of the original problem is also UNSAT.

```
Algorithm 1 SequentialSAT-solver \(\left(C, o b j, q_{0}\right)\)
\(C\) : combinational part of given sequential circuit
obj: desired initial objective states
\(q_{0}\) : initial states
\(f_{o}, f_{s}\) : frame objective, frame solution
\(S C\) : state constraints(initial constraint \(S C=\emptyset\) )
\(O L\) : objective list (initially \(O L=\{o b j\}\) )
    while \(O L \neq \emptyset\) do
        \(f_{o} \leftarrow\) select-a-frame-objective \((O L)\);
        \(f_{s} \leftarrow \operatorname{SAT}\)-solve \(\left(C, f_{o}, S C\right)\);
        if \(f_{s} \neq N U L L\) then
        \(f_{s}^{\prime} \leftarrow\) solution-state-reduction \(\left(C, f_{s}\right)\);
        if \(q_{0} \in f_{s}^{\prime}\) then
                return SAT
        else
            \(s c \leftarrow\) convert-to-sc \(\left(f_{s}^{\prime}\right) ;\)
            \(S C \leftarrow s c+\{s c\} ;\)
            \(O L \leftarrow O L+\left\{f_{s}^{\prime}\right\} ;\)
        end if
        end if
    end while
    return UNSAT
```



## III. Backward Multiple Time-frame Expansion for Accelerating Sequential SAT

## A. Backward Multiple Time-frame Expansion

In this paper, we classify two types of backward timeframe expansion in sequential SAT algorithm according to the number of state transitions between $f_{s}$ and $f_{0}$ : backward single time-frame expansion(BSTE) and backward multiple time-frame expansion(BMTE).

BSTE-based sequential SAT solver traces state transitions from the states satisfying a desired objective toward the initial state using backward single time-frame expansion, which back traces one state transition. BMTEbased sequential SAT solver traces state transitions from the states satisfying a desired objective toward the initial state using backward multiple time-frame expansion, which back-traces more then one state transitions.

The backward time-frame expansion used in sequential SAT solver [1, 3] based on Algorithm 1 is classified as a BSTE, where the number of state transitions between $f_{s}$ and $f_{o}$ is one. In this paper, we propose a new algorithm that supports BSTE.

## B. A New Algorithm for Accelerating Sequential SAT

In BSTE-based sequential SAT solver, a frame solution $f_{s}$ is computed from the frame objective $f_{o}$ by using SATsolve() as shown in Algorithm 1. In the while-loop in Algorithm 1, SAT solver is used to obtain $f_{s}$ from $f_{o}$ repeatedly. When the initial state is far from the state satisfying desired objective, a number of SAT-solve() are


Fig. 1. Solution state reduction.
called, it spends much time. Furthermore, BSTE-based sequential SAT solver can not merge states in different time-frames.
We speed up solving process by using BMTE which traces multiple state transitions at once. Furthermore, we improve solution state reduction by using BMTE which can deal with states in different time-frames. For achieving these two effects, we propose a circuit expansion method. In our approach, first, given sequential circuit is transformed. Second, the transformed sequential circuit is fed to BSTE-based sequential SAT solver. By this way, BMTE-based sequential SAT is performed to original given circuit.
BMTE-based sequential SAT solver traces state transitions from the states satisfying a desired objective toward the initial state using backward multiple time-frame expansion which back traces more than one state transitions.

Our BMTE-based sequential SAT algorithm is described in Algorithm 2. The procedure circuitexpansion() performs the circuit expansion which enables backward multiple time-frame expansion(BMTE) to accelerate solving process, and transformed circuit $C C$ is obtained. The procedure select-a-frame-objective() and convert-to-sc() are the same in Algorithm 1. The procedure SAT-solve() solves the SAT problem to find a new $f_{s}$ from $f_{o}$ on $C C$. The procedure solution-state-reduction() performs solution state reduction on $C C$. It merges states in single time-frame on $C C$, in the multiple time frames on $C$. The state reduction speed up the algorithm by merging states to prune the state space for search. The pruned space in Algorithm 2 is larger than that of Algorithm 1. In the algorithm, it is assumed that each frame objective produces at most one frame solution, where a direct single state transition on $C C$, a direct multiple state transitions on $C$, from $f_{s}$ to $f_{o}$ exists. The solving process continues until either one of the following two case is occurred. One case is when $f_{s}^{\prime}$ includes the initial state $q_{0}$ of given sequential circuit. In this case, the solution is found(SAT).

```
Algorithm 2 BMTE-SequentialSAT-solver ( \(C\), obj, \(q_{0}, n\) )
\(C\) : combinational part of given sequential circuit
\(n\) : the number of BMTE
\(C C\) : combinational part of the transformed circuit
obj: desired initial objective states
\(q_{0}\) : initial states
\(f_{o}, f_{s}\) : frame objective, frame solution
\(S C\) : state constraints(initial constraint \(S C=\emptyset\) )
\(O L\) : objective list (initially \(O L=\{o b j\}\) )
    \(C C \leftarrow\) circuit-expansion \((C, n)\)
while \(O L \neq \emptyset\) do
    \(f_{o} \leftarrow\) select-a-frame-objective \((O L)\);
    \(f_{s} \leftarrow \operatorname{SAT}-\) solve \(\left(C C, f_{o}, S C\right)\);
    if \(f_{s} \neq N U L L\) then
        \(f_{s}^{\prime} \leftarrow\) solution-state-reduction \(\left(C C, f_{s}\right)\);
        if \(q_{0} \in f_{s}^{\prime}\) then
                return SAT
        else
            \(s c \leftarrow \operatorname{convert-to-sc}\left(f_{s}^{\prime}\right)\);
            \(S C \leftarrow s c+\{s c\} ;\)
                \(O L \leftarrow O L+\left\{f_{s}^{\prime}\right\} ;\) the n copies of circuit \(C\)
        end if
    end if
end while
return UNSAT
```



The other case is when objective list becomes empty. In this case, the solution has never found(UNSAT). So, the answer of the original problem is UNSAT, too.

## C. Circuit Expansion for BMTE

We propose a circuit-expansion method which enables BMTE to accelerate sequential SAT solving process. For a given number of cycles $n$, the circuit-expansion method generates a sequential circuit whose 1-cycle behavior is at most n-cycle behavior, one of 1-cycle, 2-cycle, ..., ncycle behavior, of the original sequential circuit. It is a reachability-preserving circuit-expansion method.
Fig. 2 shows the circuit-expansion for BMTE. In Fig. 2, C, FFs, PI, PO, PPI and PPO represent combinational part, flip-flops, primary inputs, primary outputs, pseudo primary inputs and pseudo primary outputs of transformed sequential circuit, respectively. FFs in the transformed and the original circuit are identical. Combinational part of transformed circuit $C C$ consists of $n$ Cs, where C is combinational part of the original circuit. In Fig. 2, PI $i, \mathrm{PPI} i, \mathrm{PO} i$, and PPO $i$ represent PI, PPI, PO and PPO of $i$-th C, respectively, where $i=1,2, \ldots, n$. PI' consists of PI $i$ 's and a new $\lceil\log n\rceil$-bit input newin, where $i=1,2, \ldots, n$. The value of PPO' is decided from PPO1, $\mathrm{PPO} 2, \ldots, \mathrm{PPO} n$ by the selector, where $\mathrm{PPO}^{\prime}=\mathrm{PPO} n$ when the value of newin is $n$. The value of PO' is decided


Fig. 2. Circuit-expansion for BMTE.
from $\mathrm{PO} 1, \mathrm{PO} 2, \ldots, \mathrm{PO} n$ by the selector, where $\mathrm{PO}^{\prime}=$ $\mathrm{PO} n$ when the value of newin is $n$.

In our approach, sequential SAT solving process is performed to the circuit obtained by the circuit-expansion in place of the original one. The transformed circuit and the original circuit have the same result of sequential SAT. When the result of sequential SAT for the original circuit is UNSAT(SAT), then that for the transformed circuit is UNSAT(SAT), and vice versa.
D. Solution State reduction in BMTE-based Sequential SAT


Fig. 3. Solution state reduction in BMTE-based sequential SAT.

Solution state reduction, which is performed in our BMTE-based sequential SAT algorithm (line 6 in Algorithm 2), is shown in Fig. 3. In Fig. 3, state transitions of

TABLE I
Application to a 20-bit counter.

| Property | CPU time [sec] |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | org. [3] | $\begin{gathered} \text { ours } \\ (2 \text { steps }) \\ \hline \end{gathered}$ | $\begin{gathered} \text { ours } \\ (3 \text { steps }) \\ \hline \end{gathered}$ | $\begin{gathered} \text { ours } \\ (4 \text { steps }) \\ \hline \end{gathered}$ | $\begin{gathered} \text { ours } \\ (5 \text { steps }) \\ \hline \end{gathered}$ |
| $\mathrm{F}($ out17 $=1)$ | 173.2 | 24.0 | 28.7 | 22.7 | 17.9 |
| $\mathrm{F}($ out18 $=1)$ | 1126.5 | 536.7 | 273.8 | 121.8 | 340.1 |
| $\mathrm{F}($ out19 $=1)$ | 5526.4 | 1464.3 | 1497.1 | 795.6 | 1718.3 |

a sequential circuit and backward traversal of sequential SAT are denoted with thin and bold arrows, respectively. State transitions in Fig. 3 are obtained from state transitions in Fig. 1 by our circuit-expansion. The state 1111 is the desired initial objective state. Because of existence of new two state transitions, from the state 1001 to the state 1111 and from the state 0001 to the state 1111, there are two time-frames in Fig. 3, which are 0 and 1.

The state 1011 is a frame solution, $f_{s}$, obtained from the state $1111, f_{o}$, by the procedure SAT-solve() (Algorithm 2) Here, states 0011,1001 and 0001 are in the same timeframe 1 with $f_{s}$, and they have direct state transition to $f_{o}$. Hence, they are effectively merged with $f_{s}$, by the procedure solution-state-reduction() (Algorithm 2) and the merged state $-0-1, f_{s}^{\prime}$, is obtained. Here, $-0-1$ is a cube representing the four states. The state space of merged state in BMTE is larger than that in BSTE (Fig. 1). It prunes a larger state space needed to be search.

Theorem 1 Given an FSM $M$ having an initial state $q_{0}$. Let $M^{\prime}$ be a new FSM which is derived from $M$ by adding transitions from every state $q_{i}$ to the states which are reachable from $q_{i}$ within $n$ state transitions. Then $R S(M)=R S\left(M^{\prime}\right)$.

The above theorem ensures that by adding transitions from every state $q_{i}$ to the states which are reachale from $q_{i}$ within $n$ transitions, the set of reachable states from the initial state of the machine and reachability from the initial state to the states which satisfying a desired objective are not altered.

## IV. Experimental Results

We have compared our BMTE-based sequential SAT solver and BSTE-based sequential SAT solver which is $S e q-S A T[3]$. In our BMTE-based sequential SAT solver, given circuit is firstly transformed to the circuit for BMTE-based sequential SAT. Secondly, the transformed circuit is fed to BSTE-based sequential SAT solver which Seq-SAT [3].

Table I shows the experimental results, where BMTEbased and BSTE-based sequential SAT solvers are applied to 20-bit binary counter. In Table I, "org." is elapsed CPU seconds of MSTE-based sequential SAT solver, Seq$S A T[3]$. "ours" is elapsed CPU seconds of our BMTE-

TABLE II
Comparison of processing time using s13207 (time limit is $140,000 \mathrm{~s}$ ).

| Property | CPU time [sec] |  | Result |
| :--- | ---: | ---: | :---: |
|  | org. $[3]$ | ours <br> (2 steps $)$ |  |
| F $(\mathrm{g} 4267=1)$ | time-out | 79297 | SAT |
| $\mathrm{F}(\mathrm{g} 4316=1)$ | 1293 | 628 | UNSAT |
| $\mathrm{F}(\mathrm{g} 4370=1)$ | time-out | 28943 | SAT |
| $\mathrm{F}(\mathrm{g} 4371=1)$ | time-out | 76909 | SAT |
| $\mathrm{F}(\mathrm{g} 4372=1)$ | time-out | 78618 | SAT |
| $\mathrm{F}(\mathrm{g} 4373=1)$ | time-out | 64461 | SAT |
| $\mathrm{F}(\mathrm{g} 4655=1)$ | 857 | 162 | SAT |
| $\mathrm{F}(\mathrm{g} 4661=1)$ | time-out | time-out | - |

TABLE III
Comparison of processing time using s13207.1 (time limit is $140,000 \mathrm{~s})$.

| Property | CPU time [sec] |  | Result |
| :--- | ---: | ---: | :---: |
|  | org. [3] | ours <br> (2 steps $)$ |  |
| $\mathrm{F}(\mathrm{g} 4267=1)$ | time-out | 13742 | SAT |
| $\mathrm{F}(\mathrm{g} 4316=1)$ | 958 | 52 | SAT |
| $\mathrm{F}(\mathrm{g} 4370=1)$ | time-out | 9229 | SAT |
| $\mathrm{F}(\mathrm{g} 4371=1)$ | time-out | 22485 | SAT |
| $\mathrm{F}(\mathrm{g} 4372=1)$ | time-out | 14938 | SAT |
| $\mathrm{F}(\mathrm{g} 4373=1)$ | time-out | 44655 | SAT |

based sequential SAT solver. The number of steps of our circuit-expansion are 2,3 a, 4 and 5 . We assumed that the initial value of each flip-flop is " 0 " value. We checked whether each primary output of the circuit will become " 1 " in the future, where 17 -th, 18 -th and 19 -th primary outputs were checked. All results of sequential SAT were SAT. All of the experiments were run on Xeon X5270 X 2 with 4GB memory. From the result, we can see that our circuit-expansion method accelerated sequential SAT solving process.
Table II and III show the experimental results, where BMTE-based and BSTE-based sequential SAT solvers are applied to some of the ISCAS89 benchmarks, s13207 and s13207.1. Note that several primary outputs of these are hard to check whether it has " 1 " value in the future by Seq-SAT[3] and it was reported in [3]. In this experiment, we selected such hard 14 primary outputs, g4267, g4316, g4370, g4371, g4372, g4373, g4655 and g4661 in s13207, and g4267, g4316, g4370, g4371, g4372 and g4373 in s13207.1. In Table II and III, "org." column gives the time spent for sequential SAT execution with BSTEbased sequential SAT solver, Seq-SAT[3]. "ours" column gives that with our BMTE-based sequential SAT solver.

The number of steps of our circuit-expansion is 2. Experiments with our BMTE were run on Xeon X5270 X 2 with 4GB memory, while experiments with BSTE were run on Xeon X5272 X 2 with 16GB memory, where higher spec WS was used for BMTE. From this experimental results, we can see that results of sequential SAT were obtained in 12 of 14 benchmarks with BMTE within time limit, 140,000 seconds.
These experimental results show that the proposed sequential SAT algorithm with BMTE is an improvement in sequential SAT algorithms through efficient state reduction and tracing multiple state transitions at once.

## V. Conclusions

We have presented circuit-expansion method for BMTE and proposed sequential SAT algorithm that supports it. Experimental results show that the proposed method may speed up solving process of sequential SAT. Our future work includes sophisticated circuit-expansion method to make sequential SAT solver even faster.

## References

[1] M. K. lyer, G. Partharathy, K.-T. Cheng, "SATORI - A Fast Sequential SAT Engine for Circuits". In Proc. the 2003 IEEE/ACM international conference on Computer-aided design, pp. 320-325, 2003.
[2] G. Partharathy, M. K. Iyer, K.-T. Cheng, Li-C. Wang, "Satisfy Property Verification Using Sequential SAT and Bounded Model Checking", IEEE Design and Test of Computers, vol. 21, no. 2, pp. 132-143, Mar/Apr, 2004.
[3] F. Lu, M. K. Iyer, G. Parthasarathy and K.-T. Cheng, "An Efficient Sequential SAT Solver With Improved Search Strategies". In Proc. Design, Automation \& Test in Europe, pp. 1102-1107, Mar. 7-11, 2005

