0. # Dataset Download
CircuitNet-N28 Dataset Original Download Link: https://circuitnet.github.io/intro/download.html#circuitnet-n28

Note: Please select N28. Do not select N14.

Download Options: Baidu Netdisk (requires VIP membership for faster speeds, otherwise it may take extremely long) or Google Drive (requires VPN).

Action: Click to enter the CircuitNet folder, then select and download the CircuitNet-N28 folder.


1. # Project Introduction
Methodology: In the preprocessing stage, a ViT model is used to extract geometric features, and a GNN model is used to extract topological features. These are fused to obtain a more complete feature set, which serves as the input for both the pre-training and downstream models.

The pre-training model uses a Transformer architecture incorporating an innovative KIND linear layer. The model is trained under the joint supervision of three tasks: Congestion, DRC, and IR-drop. Upon completion of training, Learngenes are extracted from the KIND linear layer. These Learngenes contain both Common Knowledge and Category-Specific Knowledge (Congestion+DRC+IR-drop).

Downstream Tasks: We apply Learngenes to migrate models for four downstream tasks: Congestion, DRC, IR-drop, and Thermal.

Congestion, DRC, IR-drop: Use the Common Knowledge and their corresponding Category-Specific Knowledge from the Learngenes to initialize the downstream Transformer weights.

Thermal: As a new task type (unseen during pre-training), it uses only the Common Knowledge from the Learngenes to initialize the downstream Transformer weights.

Baselines: Baseline algorithms are provided to train and test on all four tasks for comparison.

Extensions:

Timing Prediction: Added as a 5th task. We use the pre-trained model to extract Learngenes and perform model migration. Baseline comparison algorithms are also provided.

3D Thermal Prediction: Added as a 6th task. Note that this task does not use the same 2D fused data (generated_features) as the previous five. We extend the project from 2D to 3D, using a 3D dataset for Learngene extraction and model migration. Baselines for the 3D scenario are also included.


2. # Environment Setup
First, create the environment circuitnet2 (activate this environment for all subsequent commands: conda activate circuitnet2)：
conda create -n circuitnet2 python=3.9.21 -c pytorch -c dglteam/label/th24_cu124 -c nvidia -c conda-forge

Install PyTorch and CUDA:
conda install pytorch=2.4.0=py3.9_cuda12.4_cudnn9.1.0_0 cudatoolkit=11.3.1=hb98b00a_13 pytorch-cuda=12.4=hc786d27_7 -c pytorch -c nvidia -c dglteam/label/th24_cu124

Install DGL:
conda install dgl=2.4.0.th24.cu124=py39_0 -c dglteam/label/th24_cu124

Install and fix core libraries:
conda install numpy mkl intel-openmp -c pytorch -c nvidia -c dglteam/label/th24_cu124 -c defaults -c conda-forge

Install image processing and multimedia libraries:
conda install ffmpeg libpng libjpeg-turbo -c conda-forge -c defaults

Install other tools and dependencies
conda install cffi filelock pip setuptools wheel -c conda-forge -c defaults

Install all pip dependencies:
pip install -r requirements.txt

3. # Our Method
cd Code/cnngnn2

# Pre-train Feature Extractor
python train_vitgnn.py --data_root your_data_root/CircuitNet-N28
The trained checkpoints will be saved in ./results/CircuitNet-N28/your_train_time/gnn.pth and ./results/CircuitNet-N28/your_train_time/vit.pth.

# Save Generated Features
python save_generate.py --data_root your_data_root/CircuitNet-N28 --gnn_checkpoint_root ./results/CircuitNet-N28/your_train_time/gnn.pth --vit_checkpoint_root ./results/CircuitNet-N28/your_train_time/vit.pth
融合特征保存在文件夹./generated_feature/中

# Pre-train Parent Model
python train222.py --data_root your_data_root/CircuitNet-N28 --label all --pretrain 1 --save_model 1  --epochs 200
基因路径和类别路径分别保存在 ./results/gene_knowledge.pth 和 ./results/cls_knowledge.pth

# Train Child Models (Learngene Method)
python train222.py --pretrain 0 --save_model 0 --label congestion --lr 0.0001 --gene_knowledge_path ./results/gene_knowledge.pth --cls_knowledge_path ./results/cls_knowledge.pth --data_root your_data_root/CircuitNet-N28
python train222.py --pretrain 0 --save_model 0 --label drc --lr 0.0001 --gene_knowledge_path ./results/gene_knowledge.pth --cls_knowledge_path ./results/cls_knowledge.pth --data_root your_data_root/CircuitNet-N28
python train222.py --pretrain 0 --save_model 0 --label ir_drop --lr 1e-05 --gene_knowledge_path ./results/gene_knowledge.pth --cls_knowledge_path ./results/cls_knowledge.pth --data_root your_data_root/CircuitNet-N28
python train22222.py --pretrain 0 --save_model 0 --label thermal --lr 0.01 --gene_knowledge_path ./results/gene_knowledge.pth --cls_knowledge_path ./results/cls_knowledge.pth --data_root your_data_root/CircuitNet-N28

# Train Child Models (Xavier Method / From Scratch)
python train222.py --pretrain 1 --save_model 0 --label congestion --lr 3e-07 --data_root your_data_root/CircuitNet-N28
python train222.py --pretrain 1 --save_model 0 --label drc --lr 1e-07 --data_root your_data_root/CircuitNet-N28
python train222.py --pretrain 1 --save_model 0 --label ir_drop --lr 1e-07 --data_root your_data_root/CircuitNet-N28
python train222.py --pretrain 1 --save_model 0 --label thermal --lr 0.003 --data_root your_data_root/CircuitNet-N28

4. # baseline

## circuitnet

cd Code/circuitnet

### pretrain

In the pre-training stage, we use the combined features of Congestion, IR, and DRC to train on these three tasks simultaneously

python train.py --model GPDL --pretrain 1 --label all --data_root your_data_root/CircuitNet-N28
python train.py --model RouteNet --pretrain 1 --label all --data_root your_data_root/CircuitNet-N28

### finetune

In the fine-tuning stage, the new task (Thermal) is introduced. Use the weight file checkpoint.pth obtained from the pre-training stage (stored in result/task_name)

python train.py --model GPDL --pretrain 0 --label thermal --data_root your_data_root/CircuitNet-N28
python train.py --model RouteNet --pretrain 0 --label thermal --data_root your_data_root/CircuitNet-N28

## netlistgnn

cd Code/netlistgnn

Before running training, the graphs must be constructed.

Construct graphs for the Pre-training stage (stored in CircuitNet-N28/netlistgnn0):
python train.py --pretrain 1 --label all --data_root your_data_root/CircuitNet-N28

Construct graphs for the Fine-tuning stage (stored in CircuitNet-N28/netlistgnn1):
python train.py --pretrain 0 --label thermal --data_root your_data_root/CircuitNet-N28

# pretrain
Use the combined features of Congestion, IR, and DRC to train on these three tasks. Checkpoints are saved in the corresponding result folder.
python train.py --model netlistgnn --label all --pretrain 1 --data_root your_data_root/CircuitNet-N28
python train_gnn.py --model GAT --label all --pretrain 1 --data_root your_data_root/CircuitNet-N28
python train_gnn.py --model SAGE --label all --pretrain 1 --data_root your_data_root/CircuitNet-N28
python train_gnn.py --model GCN --label all --pretrain 1 --data_root your_data_root/CircuitNet-N28

# finetune
从对应的checkpoint中加载网络，使用单独新任务训练。
python train.py --model netlistgnn --pretrain 0 --label thermal --data_root your_data_root/CircuitNet-N28

python train_gnn.py --model GAT --pretrain 0 --label thermal --data_root your_data_root/CircuitNet-N28
python train_gnn.py --model SAGE --pretrain 0 --label thermal --data_root your_data_root/CircuitNet-N28
python train_gnn.py --model GCN --pretrain 0 --label thermal --data_root your_data_root/CircuitNet-N28



