# Logic Synthesis with Generative Deep Neural Networks

## Xihan Li<sup>1</sup>, Xing Li<sup>2</sup>, Lei Chen<sup>2</sup>, Xing Zhang<sup>2</sup>, Mingxuan Yuan<sup>2</sup> and Jun Wang<sup>1</sup>

1. Department of Computer Science, University College London

2. Huawei Noah's Ark Lab, Hong Kong, China

## Abstract

In this work, we introduced the first logic synthesis operator powered by generative deep neural networks. More specifically, a rewriting operator is developed based on the Circuit Transformer model, named ctrw (Circuit Transformer Rewriting), which incorporates the following techniques: (1) a two-stage training scheme for the Circuit Transformer tailored for logic synthesis, with iterative improvement of optimality through selfimprovement training; (2) integration of the Circuit Transformer with state-of-the-art rewriting techniques to address scalability issues, allowing for guided DAG-aware rewriting. Experimental results on the IWLS 2023 contest benchmark demonstrate the effectiveness of our proposed rewriting methods.

#### 4. Iterative Self-Improvement Training

Iteratively fine-tune the model to generate more compact circuits with Monte-Carlo tree search (MCTS) based self-improving.

- **Training stage:** fine-tune the model with parallel data
- **Improvement stage**: generate new parallel data with finetuned model and MCTS



### **1. Circuit Transformer: Sequential Generation of Circuits with Equivalence Preserved**

This work is based on Circuit Transformer [1], a generative deep neural network which has two features:

- 1. It allows sequential generation of circuits with next token prediction, just like ChatGPT to natural languages.
- 2. The generated circuit is precisely equivalent to an existing input circuit.

[1] <u>https://arxiv.org/abs/2403.13838</u>



### **5. Cooperate Circuit Transformer with Fanout-Free Window Rewriting**

We leverage the fanout-free window rewriting framework in [2], and apply our trained Circuit Transformer with self-improvement to replace each fanout-free window by a more compact one. MCTS can also be applied during the rewriting. Such replacement enables additional flexibility that the replaced circuit does not require to be equivalent to the sub-circuit it replaces.

[2] https://ieeexplore.ieee.org/document/10247727

### 2. Train a Circuit Transformer for Small-sized Logic Synthesis

End-to-end, supervised learning with:

- **Input:** randomly generated circuits with unique canonicalizations (realistic circuits do NOT work well)
- **Output:** optimized circuits with existing optimizers (resyn2)

#### 3. Circuit Size Minimization as a Markov Decision Process

We can minimize the number of AND gates of the generated circuit by attaching an immediate reward function  $R(s_1, \dots, s_t, s)$  to the generation of token s at step t, so that the generation process can be modelled as an MDP.

- State at step  $t: g_1, \dots, g_t$  Action: g
- $\bullet$

#### 6. Guided DAG-aware Rewriting

We refined the immediate reward to reflect the node merging in the rewriting process. Then MCTS is guided by the reward function to minimize the size of final rewritten circuit after node merging.



| Step (Node ID)    | 1  | 2                     | 3  | 4                     | 5                     | 6  | 7  | 8                   | 9                     | 10                    | 11 | 12                    | 13                    |
|-------------------|----|-----------------------|----|-----------------------|-----------------------|----|----|---------------------|-----------------------|-----------------------|----|-----------------------|-----------------------|
| Token             | Λ  | <i>C</i> <sub>1</sub> | Λ  | <i>C</i> <sub>2</sub> | <i>C</i> <sub>3</sub> | Λ  | Λ  | $\overline{\wedge}$ | <i>c</i> <sub>1</sub> | <i>C</i> <sub>4</sub> | Λ  | <i>C</i> <sub>3</sub> | <i>C</i> <sub>4</sub> |
| Immediate Reward  | -1 | 0                     | -1 | 0                     | 0                     | -1 | -1 | -1                  | 0                     | 1                     | -1 | 0                     | 2                     |
| Cumulative Reward | -1 | -1                    | -2 | -2                    | -2                    | -3 | -4 | -5                  | -5                    | -4                    | -5 | -5                    | -3                    |

#### **7. Experiments**

| Methods                                           | Avg. Improv. | Time cost  |
|---------------------------------------------------|--------------|------------|
| Drw Rewriting (ABC)                               | 15.42%       | <0.01s     |
| MFFW Rewriting (in Python)                        | 21.16%       | 1-300s     |
| Ctrw (w/o self-improvement)                       | 18.55%       | 1-250s     |
| Ctrw                                              | 23.23%       | 1-285s     |
| Ctrw with MCTS                                    | 26.02%       | 300-31000s |
| Ctrw with MCTS and guided DAG-<br>aware Rewriting | 30.19%       | 240-35000s |

Immediate reward:  $R(g_1, ..., g_t, g) = \Delta + \begin{cases} -1, g = \Lambda \text{ or } g = \overline{\Lambda} \\ 0 & 1 \end{cases}$ 0, otherwise

(In which  $\Delta$  reflects the refinement of equivalent node merging)

Cumulative reward: negative number of AND nodes in the generated circuits





| Step (Node ID)    | 1  | 2                     | 3  | 4                     | 5                     | 6  | 7  | 8                   | 9                     | 10                    |
|-------------------|----|-----------------------|----|-----------------------|-----------------------|----|----|---------------------|-----------------------|-----------------------|
| Token             | ٨  | <i>c</i> <sub>1</sub> | Λ  | <i>C</i> <sub>2</sub> | <i>C</i> <sub>3</sub> | Λ  | Λ  | $\overline{\wedge}$ | <i>c</i> <sub>1</sub> | <i>C</i> <sub>4</sub> |
| Immediate Reward  | -1 | 0                     | -1 | 0                     | 0                     | -1 | -1 | -1                  | 0                     | 1                     |
| Cumulative Reward | -1 | -1                    | -2 | -2                    | -2                    | -3 | -4 | -5                  | -5                    | -4                    |

Our proposed approach successfully generated strictly feasible circuits (checked via cec), and demonstrated significant effectiveness in reducing circuit size. (However, the efficiency still needs to be improved, especially for MCTS)

Scan the QR code for the full paper, poster and future updates. Or visit:

https://snowkylin.github.io/publications

Correspondence email: xihan.li@cs.ucl.ac.uk



