GACT: Activation Compressed Training for General Architectures.

Xiaoxuan Liu,Lianmin Zheng,Dequan Wang,Yukuo Cen,Weize Chen,Xu Han,Jianfei Chen,Zhiyuan Liu,Jie Tang,Joey Gonzalez,Michael Mahoney,Alvin Cheung
DOI: https://doi.org/10.48550/arXiv.2206.11357
2022-01-01
Abstract:Training large neural network (NN) models requires extensive memory resources, and Activation Compressed Training (ACT) is a promising approach to reduce training memory footprint. This paper presents GACT, an ACT framework to support a broad range of machine learning tasks for generic NN architectures with limited domain knowledge. By analyzing a linearized version of ACT's approximate gradient, we prove the convergence of GACT without prior knowledge on operator type or model architecture. To make training stable, we propose an algorithm that decides the compression ratio for each tensor by estimating its impact on the gradient at run time. We implement GACT as a PyTorch library that readily applies to any NN architecture. GACT reduces the activation memory for convolutional NNs, transformers, and graph NNs by up to 8.1x, enabling training with a 4.2x to 24.7x larger batch size, with negligible accuracy loss. We implement GACT as a PyTorch library at https://github.com/LiuXiaoxuanPKU/GACT-ICML.
What problem does this paper attempt to address?