The Transformational Measures (tmeasures
) library allows neural network designers to evaluate the invariance, equivariance and other properties of their models with respect to a set of transformations. Support for Pytorch (current) and Tensorflow/Keras (coming).
tmeasures
allows computing invariance, same-equivariance and other transformational measures, and contains helpful functions to visualize these. The following are some examples of the results you can obtain with the library:
Each column shows the invariance to rotation of a layer of a Neural Network. Each row/block inside each column indicates the invariance of a feature map or single neuron, depending on the layer.
Plot the transformational and sample invariance to rotations of a simple neural network trained on MNIST, with and without data augmentation. The X axis indicates the layer, while the Y axis shows the average invariance of the layer.
Plot of the invariance to rotations of several well-known models trained on CIFAR10. The number of layers of each model is streched on a percentage scale, so that different models can be compared.
These notebooks contain step-by-step code and explanations to measure invariance in both custom and pretrained model, both using predefined and custom transformations. They can be executed in google colab directly. Alternatively, you can download them for local execution, but be aware you will have to provide your own virtualenv with torch
and torchvision
installed.
- Measuring invariance to brightness changes on a pretrained ResNet18 on TinyImageNet
- Measuring invariance to rotations on a custom CNN on MNIST
Other examples with multiple measures and pretrained models can be found in the doc folder of this repository.
We are still developing the Tensorflow API.
You can find many uses of this library in the repository with the code for the article Measuring (in)variances in Convolutional Networks, where this library was first presented. Also, in the code for the experiments of the PhD Thesis "Invariance and Same-Equivariance Measures for Convolutional Neural Networks" (spanish).
If you use this library in your research, we kindly ask you to cite Invariance and Same-Equivariance Measures for Convolutional Neural Networks.
@article{quiroga20,
author = {Facundo Quiroga and
Laura Lanzarini},
title = {Invariance and Same-Equivariance Measures for Convolutional Neural Networks},
journal = {J. Comput. Sci. Technol.},
volume = {20},
number = {1},
pages = {06},
year = {2020},
url = {https://doi.org/10.24215/16666038.20.e06},
doi = {10.24215/16666038.20.e06},
}