Error Feedback Can Accurately Compress Preconditioners
Ionut-Vlad Modoranu, Aleksei Kalinov, Eldar Kurtic, Elias Frantar, Dan Alistarh
TL;DR
The paper tackles the prohibitive memory cost of full-matrix preconditioners in deep learning. It introduces EFCP, an error-feedback-based compression scheme that dramatically reduces the gradient-history memory through sparsity or low-rank representations, while preserving convergence properties. The authors provide algorithmic, data-structure, and CUDA-kernel innovations (including a dynamic sparse ring-buffer) and offer partial theoretical guarantees, complemented by extensive experiments on ImageNet-ResNet and BERT-GLUE showing memory reductions with negligible or no accuracy loss. This approach enables practical usage of full-matrix preconditioners on single-GPU hardware, unlocking the benefits of second-order updates for large-scale models.
Abstract
Leveraging second-order information about the loss at the scale of deep networks is one of the main lines of approach for improving the performance of current optimizers for deep learning. Yet, existing approaches for accurate full-matrix preconditioning, such as Full-Matrix Adagrad (GGT) or Matrix-Free Approximate Curvature (M-FAC) suffer from massive storage costs when applied even to small-scale models, as they must store a sliding window of gradients, whose memory requirements are multiplicative in the model dimension. In this paper, we address this issue via a novel and efficient error-feedback technique that can be applied to compress preconditioners by up to two orders of magnitude in practice, without loss of convergence. Specifically, our approach compresses the gradient information via sparsification or low-rank compression \emph{before} it is fed into the preconditioner, feeding the compression error back into future iterations. Experiments on deep neural networks show that this approach can compress full-matrix preconditioners to up to 99\% sparsity without accuracy loss, effectively removing the memory overhead of full-matrix preconditioners such as GGT and M-FAC. Our code is available at \url{https://github.com/IST-DASLab/EFCP}.
