Training Binary Neural Networks with Real-to-Binary Convolutions

This paper shows how to train binary networks to within a few percent points ($\sim 3-5 \%$) of the full precision counterpart. We first show how to build a strong baseline, which already achieves state-of-the-art accuracy, by combining recently proposed advances and carefully adjusting the optimization procedure. Secondly, we show that by attempting to minimize the discrepancy between the output of the binary and the corresponding real-valued convolution, additional significant accuracy gains can be obtained. We materialize this idea in two complementary ways: (1) with a loss function, during training, by matching the spatial attention maps computed at the output of the binary and real-valued convolutions, and (2) in a data-driven manner, by using the real-valued activations, available during inference prior to the binarization process, for re-scaling the activations right after the binary convolution. Finally, we show that, when putting all of our improvements together, the proposed model beats the current state of the art by more than 5% top-1 accuracy on ImageNet and reduces the gap to its real-valued counterpart to less than 3% and 5% top-1 accuracy on CIFAR-100 and ImageNet respectively when using a ResNet-18 architecture. Code available at https://github.com/brais-martinez/real2binary.

PDF Abstract ICLR 2020 PDF ICLR 2020 Abstract

Results from the Paper Edit

Task Dataset Model Metric Name Metric Value Global Rank Result Benchmark
Classification with Binary Neural Network CIFAR-100 Real-to-Bin** Top-1 Accuracy 76.2 # 2
Classification with Binary Neural Network ImageNet Real-to-Bin (ours)** Top-1 Accuracy 65.4 # 3