Our new X account is live! Follow @wizwand_team for updates
WorkDL logo mark

GRACE: Globally-Seeded Representation-Aware Cluster-Specific Evolution for Compiler Auto-Tuning

About

Compiler pass selection and phase ordering present a significant challenge in achieving optimal program performance, particularly for objectives like code size reduction. Standard compiler heuristics offer general applicability but often yield suboptimal, program-specific results due to their one-size-fits-all nature. While iterative compilation can find tailored solutions, its prohibitive search cost limits practical use. Machine learning approaches promise faster inference but frequently struggle with generalization to unseen programs. This paper introduces GRACE, a novel framework for compiler auto-tuning, demonstrated for LLVM IR instruction count optimization. GRACE effectively curtails the search space by leveraging pass synergies and a weighted scoring method to generate initial high-quality candidate sequences and a pass pool. It then employs contrastive learning, using pass sequence-based data augmentation, to create program embeddings that facilitate similarity-aware clustering. Evolutionary search within these clusters yields a coreset of $k$ specialized pass sequences designed for robust generalization to unseen programs. At test time, GRACE efficiently selects the best coreset sequence and refines it using lightweight techniques. Experimental results on seven diverse datasets show that GRACE reduces LLVM IR instruction count by an average of 10.09% on LLVM 10.0.0 and 10.19% on LLVM 18.1.6 compared to opt -Oz, while incurring an average tuning time of less than 1s per program, demonstrating its state-of-the-art performance and practical effectiveness.

Haolin Pan, Chao Zha, Jinyuan Dong, Mingjie Xing, Yanjun Wu• 2025

Related benchmarks

TaskDatasetResultRank
Compiler Optimizationcbench
I_O30.3408
13
Compiler Optimizationchstone
I_O332.95
13
Compiler Optimizationtensorflow
I_O30.1225
13
Compiler OptimizationMIBench
I_O324.69
13
Compiler OptimizationBLAS
I_O313.72
13
Compiler Optimizationnpb
I_O329.31
13
Compiler Optimizationopencv
I_O314.98
13
Showing 7 of 7 rows

Other info

Follow for update