The implementation and experiments of kernel-sharing presented in "A. Azadbakht, S. R. Kheradpisheh, I. Khalfaoui-Hassani, T. Masquelier, Drastically Reducing the Number of Trainable Parameters in Deep CNNs by Inter-layer Kernel-sharing", available at: https://arxiv.org/abs/2210.14151.
Deep convolutional neural networks (DCNNs) have become the state-of-the-art (SOTA) approach for many computer vision tasks: image classification, object detection, semantic segmentation, etc. However, most SOTA networks are too large for edge computing. Here, we suggest a simple way to reduce the number of trainable parameters and thus the memory footprint: sharing kernels between multiple convolutional layers. Kernel-sharing is only possible between "isomorphic" layers, i.e. layers having the same kernel size, input and output channels. This is typically the case inside each stage of a DCNN. Our experiments on CIFAR-10 and CIFAR-100, using the ConvMixer and SE-ResNet architectures show that the number of parameters of these models can drastically be reduced with minimal cost on accuracy. The resulting networks are appealing for certain edge computing applications that are subject to severe memory constraints, and even more interesting if leveraging "frozen weights" hardware accelerators. Kernel-sharing is also an efficient regularization method, which can reduce overfitting.
To register new models with the desired configuration, please refer to the following files: ConvMixer/models/convmixer.py
for ConvMixer models and SEResNet/models/se_resnet.py
for SE-ResNet models.
To create an appropriate environment, execute pip install -r requirements.txt
within a Conda environment.
To train the ConvMixer model on either the Cifar-10 or Cifar-100 dataset, simply execute the convmixer_cifar10_run.sh
or convmixer_cifar100_run.sh
scripts. Similarly, to train the SE-ResNet model, execute the seresnet_cifar10_run.sh
or seresnet_cifar100_run.sh
scripts. These scripts will streamline the training process and ensure optimal performance on your chosen dataset.
The base code for conventional models, including ConvMixer and SE-ResNet, was obtained by cloning their respective repositories on GitHub. ConvMixer's code was sourced from (https://github.com/locuslab/convmixer), while SE-ResNet's code was obtained from (https://github.com/Jyouhou/SENet-cifar10).