This is the official implementation of the paper "Multi-hypothesis 3D human pose estimation metrics favor miscalibrated distributions".
Optimizing MPJPE promotes miscalibration in multi-hypothesis human pose lifting,
Pierzchlewicz, P. A., Bashiri, M., Cotton, R. J. & Sinz, F. H.
Multi-hypothesis 3D human pose estimation metrics favor miscalibrated distributions,
Pierzchlewicz, P. A., Cotton, R. J., Bashiri, M. & Sinz, F. H.
This repository hosts the experimental source code for the "Multi-hypothesis 3D human pose estimation metrics favor miscalibrated distributions" paper. However, the Conditional Graph Normalizing Flow (cGNF) model is implemented as part of the PROPOSE framework for PRObabilistic POSe Estimation. You can find the full implementation of the model here.
This project requires that you have the following installed:
Ensure that you have the base image pulled from the Docker Hub. You can get the base image by running the following command:
docker pull sinzlab/pytorch:v3.9-torch1.9.0-cuda11.1-dj0.12.7
- Clone the repository.
- Navigate to the project directory.
- Build the environment with
docker-compose build base
. - Add the necessary data as described in the Data section.
In case you don't want to use Docker, you can install the dependencies after cloning the repository with the following command:
pip install -r requirements.txt
Note however that if you decide to not use Docker, you will not be able to use the docker-compose
command and instead you will have to run scripts manually.
For example:
python -m scripts/preprocess.py --human36m
Due to license restrictions the dataset is not included in the repository. You can download it from the official website.
Download the D3 Positions mono by subject and place them into the data/human36m/raw
directory.
Then run the following command to preprocess the data accordingly.
docker-compose run preprocess --human36m
We provide pretrained model weights which you can either download with the provided link or directly load with the following code snippet.
from propose.models.flows import CondGraphFlow
flow = CondGraphFlow.from_pretrained("ppierzc/propose_human36m/mpii-prod:best")
Table of available models:
Model Name | description | minMPJPE | ECE | Artifact path | Weights |
---|---|---|---|---|---|
Extra Large cGNF Human 3.6m | Extra large model trained on the Human 3.6M dataset with MPII input keypoints. | 48.5 mm | 0.23 | ppierzc/propose_human36m/mpii-prod-xlarge:best |
link |
Large cGNF Human 3.6m | Large model trained on the Human 3.6M dataset with MPII input keypoints. | 49.6 mm | 0.12 | ppierzc/propose_human36m/mpii-prod-large:best |
link |
cGNF Human 3.6m | Model trained on the Human 3.6M dataset with MPII input keypoints. | 53.0 mm | 0.08 | ppierzc/propose_human36m/mpii-prod:best |
link |
cGNF Human 3.6m w/o sample loss | Model trained on the Human 3.6M dataset with MPII input keypoints without the sample loss | 57.5 mm | 0.08 | ppierzc/propose_human36m/mpii-prod-no-mode:best |
link |
You can rerun the training script with any of the model setups given in /experiments/human36m
with the following command:
docker-compose run train --human36m --experiment=mpii-prod
You can evaluate the model with the following command:
docker-compose run eval --human36m --experiment=mpii-prod
You can run the calibration check with the following command:
docker-compose run eval --human36m --experiment=mpii-prod --script=eval.human36m.calibration
For some of the experiments we used models from other authors. In order to reproduce these results we provide the necessary scripts under scripts/external
.
The list to with links to our scripts sorted by external models is given below:
Follow the associated README files for more information.
The code for generating the figures from the paper is available in the /notebooks/
directory.
You can run the notebook server with the following command:
docker-compose run notebook_server
which will start a jupyter notebook server at https://localhost:8888.
- Human3.6M - Human3.6M related experiments (Fig. 1 a, c; Fig. 3.; Supp. Fig. 6; Supp. Fig. 7)
- Toy Problems - Toy problem related experiments (Fig. 1 b, d)
- Supplementary - Supplementary material related experiments (Supp. Fig. 4; Supp. Fig. 5)
A demo notebook is also available to show how to use our cGNF model.
We provide an interactive demo of the model where you can provide your own input image and evaluate the model on it. You can run the demo with the following command:
docker-compose run -p 7860:7860 demo
Then you can open the demo in your browser at https://localhost:7860.
If you use our work in your research, please cite our paper:
@article{
pierzchlewicz2022,
title = {Multi-hypothesis 3D human pose estimation metrics favor miscalibrated distributions},
author = {Pierzchlewicz, Pawe{\l} A., Cotton, R. James, Bashiri, Mohammad, Sinz, Fabian H.},
journal = {arXiv},
year = {2022},
month = {oct},
url = {https://arxiv.org/abs/2210.11179}
}
If you encounter any problems or have suggestions, please open an issue.