Official implementation of Stable-Pose: Leveraging Transformers for Pose-Guided Text-to-Image Generation.
Stable-Pose is a novel adapter that leverages vision transformers with a coarse-to-fine pose-masked self-attention strategy, specifically designed to efficiently manage precise pose controls during Text-to-Image (T2I) generation.
The overall structure of Stable-Pose:
Table of Contents
To get started, first prepare the required environment:
# create an environment
conda create -n stable-pose python=3.8.5
# activate the created environment
conda activate stable-pose
# recommended pytorch version
conda install pytorch==1.12.1 torchvision==0.13.1 torchaudio==0.12.1 cudatoolkit=11.3 -c pytorch
# install required packages
pip install -r requirements.txt
During evaluation, a pretrained pose estimator is needed to predict poses of generated humans. Hence, you might need to install MMPose following this guide.
It's highly recommended to follow our file structure, which allows you to extend the repository to other SOTA techniques easily.
We put all the pretrained models we need under 'models' directory:
|-- models
|-- v1-5-pruned.ckpt # stable diffusion
|-- higherhrnet_w48_humanart_512x512_udp.pth # pose esitimator
|-- init_stable_pose.ckpt # initialized model for Stable-Pose
You may download the Stable Diffusion model from Hugging Face and pose esitimator from HumanSD.
Note that init_stable_pose.ckpt
is the initialized model for Stable-Pose, you might refer to Usage for details.
We trained and evaluated on Human-Art and Laion-Human, where we follow HumanSD to download and structure the data. Further, we evaluated on three video datasets: UBC Fashion, DAVIS, and Dance Track, where we extracted video frames and built datasets to test (Codes for preparing video datasets will be released soon). The data path is specified in config files.
Config files are structured as:
|-- configs
|-- stable_pose
|-- humanart.yaml
|-- mmpose
|-- ...
Stable-Pose and the training/evaluation datasets are configured in the above YAML file, please feel free to make any changes. The 'mmpose' directory contains the config for pose detector, which will be used in evaluation.
Checkpoints and training logs for stable-pose are stored under 'experiments' directory:
|-- experiments
|-- stable_pose
|-- run_name (specified in config file)
|-- last.ckpt
|-- lightning logs
|-- log_images
|-- final.pth
We provided the trained Stable-Pose checkpoints on Human-Art and LAION-Human dataset here: Google Drive.
Evaluation results are also stored similarly:
|-- outputs
|-- stable_pose
|-- run_name (specified in config file)
|-- metrics (saved metrics as csv files)
|-- images (generated images)
We've released training and test codes with sample commands. Before training, you might need to initialize the Stable-Pose model with weights of Stable Diffusion model, following ControlNet:
python prepare_weights.py models/v1-5-pruned.ckpt configs/stable_pose/humanart.yaml models/init_stable_pose.ckpt
Training and evluation commands are provided:
# please specify config path and initialized model path
python train.py --config configs/stable_pose/humanart.yaml --max_epochs 1 --control_ckpt models/init_stable_pose.ckpt --devices 2 --scale_lr false
# please specify config path and checkpoint path
python eval_pose.py --config_model configs/stable_pose/humanart.yaml --ckpt experiments/stable_pose/run_name/final.pth --scale 7.5
For evaluation of image quality (FID, KID), you might need another script:
python eval_quality.py
Note that for Human-Art, we followed HumanSD and evaluated the quality on each scenario (e.g. cartoon, dance), and the json files are provided in val_jsons
directory.
If you find StablePose useful in your research, please cite our paper:
@article{stablepose2024,
author = {Jiajun Wang, Morteza Ghahremani, Yitong Li, Björn Ommer, Christian Wachinger},
title = {Stable-Pose: Leveraging Transformers for Pose-Guided Text-to-Image Generation},
journal = {Advances in Neural Information Processing Systems (NeurIPS)},
year = {2024},
}
This repository is built upon ControlNet and HumanSD, thanks to their great work!