99
v1v2v3 (latest)

Pruner: A Draft-then-Verify Exploration Mechanism to Accelerate Tensor Program Tuning

Main:14 Pages
16 Figures
Bibliography:3 Pages
13 Tables
Abstract

Tensor program tuning is essential for the efficient deployment of deep neural networks. Search-based approaches have demonstrated scalability and effectiveness in automatically finding high-performance programs for specific hardware. However, the search process is often inefficient, taking hours or even days to discover optimal programs due to the exploration mechanisms guided by an accurate but slow-learned cost model. Meanwhile, the learned cost model trained on one platform cannot seamlessly adapt online to another, which we call cross-platform online unawareness.In this work, we propose Pruner and MoA-Pruner. Pruner is a "Draft-then-Verify" exploration mechanism that accelerates the schedule search process. Instead of applying the complex learned cost model to all explored candidates, Pruner drafts small-scale potential candidates by introducing a naive Symbol-based Analyzer (draft model), then identifies the best candidates by the learned cost model. MoA-Pruner introduces a Momentum online Adaptation strategy to address the cross-platform online unawareness.We incorporate Pruner into the TVM and conduct extensive experiments on three GPU-based platforms. Results show considerable speedup in schedule search time. In online tuning scenarios, Pruner and MoA-Pruner achieve an average speedup of 2.6×2.6 \times and 4.82×4.82 \times compared to Ansor. In offline tuning scenarios, Pruner achieves an average speedup of 4.75×4.75 \times and 4.05×4.05\times compared to TenSet and TLP, respectively. Furthermore, Pruner achieves an average speedup of 4.08×4.08 \times compared to MetaSchedule on TensorCore.

View on arXiv
Comments on this paper