NeuroFlux: Memory-Efficient CNN Training Using Adaptive Local Learning
Dhananjay Saikumar, Blesson Varghese
TL;DR
NeuroFlux addresses the challenge of memory-inefficient on-device CNN training by replacing end-to-end Backpropagation with adaptive local learning. It introduces adaptive auxiliary networks and adaptive batch sizes within a block-based training framework, enabling memory-budgeted training on edge devices while preserving accuracy. The system caches activations, partitions networks into memory-homogeneous blocks, and selects compact early-exit CNNs, delivering 2.3×–6.1× training speedups over BP and 10.9×–29.4× fewer parameters in the final model, with 1.61×–3.95× inference throughput gains. This approach expands the practicality of on-device learning for privacy-preserving and personalized AI at the edge, with potential extensions to speech, transformers, and federated settings.
Abstract
Efficient on-device Convolutional Neural Network (CNN) training in resource-constrained mobile and edge environments is an open challenge. Backpropagation is the standard approach adopted, but it is GPU memory intensive due to its strong inter-layer dependencies that demand intermediate activations across the entire CNN model to be retained in GPU memory. This necessitates smaller batch sizes to make training possible within the available GPU memory budget, but in turn, results in substantially high and impractical training time. We introduce NeuroFlux, a novel CNN training system tailored for memory-constrained scenarios. We develop two novel opportunities: firstly, adaptive auxiliary networks that employ a variable number of filters to reduce GPU memory usage, and secondly, block-specific adaptive batch sizes, which not only cater to the GPU memory constraints but also accelerate the training process. NeuroFlux segments a CNN into blocks based on GPU memory usage and further attaches an auxiliary network to each layer in these blocks. This disrupts the typical layer dependencies under a new training paradigm - $\textit{`adaptive local learning'}$. Moreover, NeuroFlux adeptly caches intermediate activations, eliminating redundant forward passes over previously trained blocks, further accelerating the training process. The results are twofold when compared to Backpropagation: on various hardware platforms, NeuroFlux demonstrates training speed-ups of 2.3$\times$ to 6.1$\times$ under stringent GPU memory budgets, and NeuroFlux generates streamlined models that have 10.9$\times$ to 29.4$\times$ fewer parameters.
