ECCV22 Paper "Batch-efficient EigenDecomposition for Small and Medium Matrices"
We implement a Pytorch-based batch-efficient ED solver for small and medium matrices (dim<32), which is dedicated to the application scenarios of computer vision. The core part of the algorithm is based on the QR iteration with Double Wilkinson shifts and some other acceleration techniques carefully designed for the best batch efficiency. Our Pytorch-implemented solver performs the ED entirely via batched matrix-matrix multiplication, which processes all the matrices simultaneously and thus fully exploits the parallel computational power of GPUs.
Download utils_ed.py
to your project folder and add the folowing lines to your main code.
# Import batch ed
from utils_ed import Batched_ED
batched_ed = Batched_ED.apply
# Run batch ed for a matrix
eigen_vectors,eigen_values = batched_ed(cov)
The complete exemplery usage and comparison is given in main.py
. For batched matrices of size 512x4x4
, the output log is:
SVD Time 0.4600346565246582
Batched ED Time 0.012771368026733398
torch<=1.7.1
and install mpmath
if you need the ED gradients.
Please refer to Fast Differentiable Matrix Square Root for all the real-world computer vision experiments. We want to maintain this repository as a standalone lib for batch ED. So it should be as clear as possible.
Please consider citing our paper if you think the code is helpful to your research.
@inproceedings{song2022batch,
title={Batch-efficient EigenDecomposition for Small and Medium Matrices},
author={Song, Yue and Sebe, Nicu and Wang, Wei},
booktitle={ECCV},
year={2022}
}
If you have any questions or suggestions, please feel free to contact me. Alternatively, if you are interested in implementing a CUDA version, please drop me an e-mail and create a seperate branch.
yue.song@unitn.it