Skip to content

[CVPR 2024] Official Implementation of "Seamless Human Motion Composition with Blended Positional Encodings".

License

Notifications You must be signed in to change notification settings

BarqueroGerman/FlowMDM

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FlowMDM

Seamless Human Motion Composition with Blended Positional Encodings (CVPR'24)

Project arXiv visits


Human Motion Composition Human Motion Extrapolation

🔎 About


Conditional human motion generation is an important topic with many applications in virtual reality, gaming, and robotics. While prior works have focused on generating motion guided by text, music, or scenes, these typically result in isolated motions confined to short durations. Instead, we address the generation of long, continuous sequences guided by a series of varying textual descriptions. In this context, we introduce FlowMDM, the first diffusion-based model that generates seamless Human Motion Compositions (HMC) without any postprocessing or redundant denoising steps. For this, we introduce the Blended Positional Encodings, a technique that leverages both absolute and relative positional encodings in the denoising chain. More specifically, global motion coherence is recovered at the absolute stage, whereas smooth and realistic transitions are built at the relative stage. As a result, we achieve state-of-the-art results in terms of accuracy, realism, and smoothness on the Babel and HumanML3D datasets. FlowMDM excels when trained with only a single description per motion sequence thanks to its Pose-Centric Cross-ATtention, which makes it robust against varying text descriptions at inference time. Finally, to address the limitations of existing HMC metrics, we propose two new metrics: the Peak Jerk and the Area Under the Jerk, to detect abrupt transitions.

📌 News

  • [2024-05-13] Eval/Gen instructions updated (wrong value in --bpe_denoising_step fixed)
  • [2024-03-18] Code + model weights released!
  • [2024-02-27] FlowMDM is now accepted at CVPR 2024!
  • [2024-02-26] Our paper is available in Arxiv.

📝 TODO List

  • Release pretrained models.
  • Release generation (skeletons + blender support for meshes) + evaluation + training code.
  • Release generation code for demo-style visualizations.

👩🏻‍🏫 Getting started

This code was tested on Ubuntu 20.04.6 LTS + Python 3.8 + PyTorch 1.13.0 While other versions might work as well, we recommend using this conda environment to avoid any issues.

  1. Install ffmpeg (if not already installed):
sudo apt update
sudo apt install ffmpeg

For windows use this instead.

  1. Setup conda env:
conda env create -f environment.yml
conda activate FlowMDM
python -m spacy download en_core_web_sm
pip install git+https://github.com/openai/CLIP.git
pip install git+https://github.com/GuyTevet/smplx.git
conda install ffmpeg -y

This README file contains instructions on how to visualize, evaluate, and train the model.

Note

This repository inherits a lot of work from the original MDM and Guided-Diffusion repositories. Most of FlowMDM's contribution can be found in the model/FlowMDM.py and diffusion/diffusion_wrappers.py files, and the model/x_transformers folder.

📚 Citation

If you find our work helpful, please cite:

@inproceedings{barquero2024seamless,
  title={Seamless Human Motion Composition with Blended Positional Encodings},
  author={Barquero, German and Escalera, Sergio and Palmero, Cristina},
  booktitle={Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition},
  year={2024}
}

🤝🏼 Acknowledgements

  • TEMOS: We inherit a lot of the code from TEMOS.
  • TEACH: We use TEACH in our work, and inherit part of the code from them.
  • MDM: We use MDM in our work, and inherit as well part of the code.
  • PriorMDM: We use PriorMDM in our work, and inherit as well part of the code.
  • x-transformers: BPEs are built on their transformers library.

⭐ Star History

Star History Chart