Skip to content

zshi0616/DeepGate2

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DeepGate2: Functionality-Aware Circuit Representation Learning

We strongly recommand the python-deepgate (only 3 lines to import pretrained DeepGate2): python-deepgate

Code repository for the paper:
DeepGate2: Functionality-Aware Circuit Representation Learning,

Zhengyuan Shi, Hongyang Pan, Sadaf Khan, Min Li, Yi Liu, Junhua Huang, Hui-Ling Zhen, Mingxuan Yuan, Zhufei Chu and Qiang Xu

Abstract

Circuit representation learning aims to obtain neural representations of circuit elements and has emerged as a promising research direction that can be applied to various EDA and logic reasoning tasks. Existing solutions, such as DeepGate, have the potential to embed both circuit structural information and functional behavior. However, their capabilities are limited due to weak supervision or flawed model design, resulting in unsatisfactory performance in downstream tasks. In this paper, we introduce DeepGate2, a novel functionality-aware learning framework that significantly improves upon the original DeepGate solution in terms of both learning effectiveness and efficiency. Our approach involves using pairwise truth table differences between sampled logic gates as training supervision, along with a well-designed and scalable loss function that explicitly considers circuit functionality. Additionally, we consider inherent circuit characteristics and design an efficient one-round graph neural network (GNN), resulting in an order of magnitude faster learning speed than the original DeepGate solution. Experimental results demonstrate significant improvements in two practical downstream tasks: logic synthesis and Boolean satisfiability solving.

Installation

conda create -n deepgate2 python=3.8.9
conda activate deepgate2
pip install -r requirements.txt

Model Training

  1. Prepare Dataset Make sure that there are graphs.npz and labels.npz in ./data/train folder, which are the dataset as mentioned in the paper. If you want to customize the training dataset, the extracted sub-circuits are in ./dataset/rawaig.tar.bz2 and refer the script ./src/prepare_dataset.py for dataset preparation.
cd dataset
tar -jxvf rawaig.tar.bz2
cd ..
python ./src/prepare_dataset.py --exp_id train --aig_folder ./dataset/rawaig # Use the default settings 
  1. Model Training The model training is separated into two stages. Model learns to predict the logic probability in Stage.1, which is the same task with previous version of DeepGate Model learns to predict the pairwise truth table difference of two gates in Stage.2.
bash ./run/stage1_train.sh
python src/reset_model.py prob
bash ./run/stage2_train.sh

Model Inference

This repo supports directly process netlist (.bench or .aig) and generate gate embeddings into file.

This model also support to parse raw data (in .aig or .bench format) and generate gate embeddings into file. If you need to employ the trained model, please use ./src/get_emb_bench.py or ./src/get_emb_aig.py. For example, you can generate the gate-level embeddings for each gate in bench netlist.

cd src
python get_emb_bench.py

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published