Skip to content

Latest commit

 

History

History
55 lines (39 loc) · 3.43 KB

Readme.md

File metadata and controls

55 lines (39 loc) · 3.43 KB

Modular Quantization-Aware Training for 6D Object Pose Estimation

Saqib Javed, Chengkun Li, Andrew Price, Yinlin Hu, Mathieu Salzmann

Website arXiv

We introduce Modular Quantization-Aware Training (MQAT), a novel mixed-precision Quantization-Aware Training (QAT) approach that leverages the modular structure of modern architectures for efficient neural network compression. MQAT is the first to exploit the modular trend, using an optimized module-wise quantization sequence shown to be effective for 6D pose estimation networks. With MQAT, we achieve substantial accuracy gains over competitive QAT methods, even surpassing full-precision accuracy for certain single-stage 6D pose estimation networks. Extensive validation across datasets, architectures, and quantization algorithms demonstrates MQAT’s robustness and versatility.

Citation

If you find our work useful. Please consider giving a star ⭐ and a citation.

@article{javed2024modular,
  author    = {Javed, Saqib and Li, Chengkun and Price, Andrew and Hu, Yinlin and Salzmann, Mathieu},
  title     = {Modular Quantization-Aware Training for 6D Object Pose Estimation},
  journal   = {TMLR},
  year      = {2024},
  url       = {https://openreview.net/forum?id=lIy0TEUou7}
}

Installation

In the following, I assume you have pulled the repository to your local machine at your home folder, which I will denote with ~.

First, install Horovod's prerequisites by following the official guide.

Then, install prerequisites using

$ ./setup.sh

For data and logs configuration, edit cfg/hard_storage.json and add path to the base directory of your repository. Put data under data directory and your logs will be stored under logs directory. You can download data from here.

Pretrained model can be downloaded from here.

Running

If you want to train the network with MQAT, current codebase is only for 2 bit FPN. To run the Swisscube example, simply run train.sh or invoke the below command.

$ CUDA_VISIBLE_DEVICES="0" python3 main.py --problem=SwissCube --topology=Widedepth

You have to uncomment few lines problems/Swisscube/Widedepth/quantize.py to quantize other parts of the network. We will clean and provide the whole codebase soon. Furthermore, problems/Swisscube/Widedepth/config.json must be edited and path of pretrained WDR model should be provided under experiment/url. Other parts of the config file are self explanatory.

For testing the provided quantized model for Widedepth with 2 bit FPN, run test.sh or invoke the below command.

$ CUDA_VISIBLE_DEVICES="0" python3 main.py --problem=SwissCube --topology=Widedepth --mode="test"

Acknowledgements

Our code is based on Quantlab and WDR-Pose repository. We thank the authors for releasing their code.