GGR is a superfast full-scale GPU-accelerated global router developed by the research team supervised by Prof. Evangeline F. Y. Young and Prof. Martin D.F. Wong at The Chinese University of Hong Kong (CUHK). It includes an efficient and high-quality Z-shape pattern routing and a GPU-accelerated maze router GAMER.
More details are in the following paper:
Shiju Lin, Jinwei Liu, Evangeline F.Y. Young and Martin D.F. Wong. "GAMER: GPU-Accelerated Maze Routing". In IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, vol. 42, no. 2, pp. 583-593, Feb. 2023.
Shiju Lin and Martin D. F. Wong. "Superfast Full-Scale GPU-Accelerated Global Routing". In Proceedings of the 41st IEEE/ACM International Conference on Computer-Aided Design (ICCAD '22). Association for Computing Machinery, New York, NY, USA, Article 51, 1–8.
GGR is integrated in Xplace now!
- We default use
N=0
(without CUDA graph optimization). WhenN >= 1
, an unknown error would occur before terminating the Python process. To enable CUDA graph optimization, please setuse_tf = true
incpp_to_py/gpugr/gr/MazeRoute.cu
and re-compile the project. - GGR is deterministic when
N=0
but not test inN >= 1
. - We currently only support LEF/DEF format.
- The runtime of this version is a little bit slower than the version described in the GGR paper because we use a stronger but slower parser and make the algorithm deterministic yet robust while sacrificing the runtime.
Please refer to cpp_to_py/gpugr/PyBindCppMain.cpp
.
device_id
: GPU id.route_xSize
/route_ySize
: Given GR GridGraph size. If the given size is0
, use theGRIDGRAPH
definition in DEF file. If the given size is0
and there is no definition in DEF, we set it as512
.rrrIters
: The number of rip-up and re-route iterations (maze route). IfrrrIters = 0
, perform the pattern route only.csrn_scale
: The size of coarsen grid in maze routing.route_guide
: The file name of output route guide.
If you find GGR useful in your research, please consider to cite:
@inproceedings{lin2022ggr,
author = {Lin, Shiju and Wong, Martin D. F.},
booktitle = {Proceedings of the 41st IEEE/ACM International Conference on Computer-Aided Design},
title = {Superfast Full-Scale GPU-Accelerated Global Routing},
year = {2022},
}
@article{lin2023gamer,
author={Lin, Shiju and Liu, Jinwei and Young, Evangeline F. Y. and Wong, Martin D. F.},
journal={IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems},
title={GAMER: GPU-Accelerated Maze Routing},
year={2023},
# main_test_gr.py
import torch
import time
from utils import IOParser
from cpp_to_py import gpugr
from src import Flute
from src.core.route_force import calc_gr_wl_via, estimate_num_shorts
num_threads = 20
gpu_id = 0
Flute.register(num_threads)
torch.cuda.synchronize("cuda:{}".format(gpu_id))
# 1) Benchmark Setting
root = "your_path"
design_name = "ispd19_test9"
params = {
"benchmark": "iccad2019",
"lef": "%s/%s/%s.input.lef" % (root, design_name, design_name),
"def": "%s/%s/%s.input.def" % (root, design_name, design_name),
"design_name": design_name,
}
route_guide_file = "test.guide"
# 2) LEF/DEF Parser
print("--- Start GR ---")
start_gr_time = time.time()
parser = IOParser()
rawdb, gpdb = parser.read(
params, verbose_log=True, lite_mode=True, random_place=False, num_threads=num_threads
)
# 3) Construct Global Routing Database and Run GGR
gpugr.load_gr_params(
{
"device_id": gpu_id,
"route_xSize": 0,
"route_ySize": 0,
"rrrIters": 1,
"route_guide": route_guide_file,
}
)
grdb = gpugr.create_grdatabase(rawdb, gpdb)
routeforce = gpugr.create_routeforce(grdb)
routeforce.run_ggr()
end_gr_time = time.time()
print("--- End GR ---")
# 4) Report Global Routing Statistics
skip_m1_route = True
m1direction = gpdb.m1direction() # 0 for H, 1 for V, metal1's layer idx is 0
hId = 1 if m1direction else 0
vId = 0 if m1direction else 1
if skip_m1_route:
hId = hId + 2 if hId == 0 else hId
vId = vId + 2 if vId == 0 else vId
dmd_map, wire_dmd_map, via_dmd_map = routeforce.dmd_map()
cap_map: torch.Tensor = routeforce.cap_map()
cg_mapH = dmd_map[hId::2].sum(dim=0) / cap_map[hId::2].sum(dim=0)
cg_mapV = dmd_map[vId::2].sum(dim=0) / cap_map[vId::2].sum(dim=0)
cg_mapHV = torch.stack((cg_mapH, cg_mapV))
cg_mapHV = torch.where(cg_mapHV > 1, cg_mapHV - 1, 0)
numOvflNets = routeforce.num_ovfl_nets()
gr_wirelength, gr_numVias = calc_gr_wl_via(grdb, routeforce)
gr_numShorts = estimate_num_shorts(routeforce, gpdb, cap_map, wire_dmd_map, via_dmd_map)
gr_time = end_gr_time - start_gr_time
print(
"#OvflNets: %d, GR WL: %d, GR #Vias: %d, #EstShorts: %d | GR Time: %.4f"
% (numOvflNets, gr_wirelength, gr_numVias, gr_numShorts, gr_time)
)
Shiju Lin ([email protected]) and Lixin Liu ([email protected])
GGR is an open source project licensed under a BSD 3-Clause License that can be found in the LICENSE file.