This is the repository for the paper CapHuman: Capture Your Moments in Parallel Universes.
Chao Liang, Fan Ma, Linchao Zhu, Yingying Deng, Yi Yang.
We concentrate on a novel human-centric image synthesis task, that is, given only one reference facial photograph, it is expected to generate specific individual images with diverse head positions, poses, and facial expressions in different contexts. To accomplish this goal, we argue that our generative model should be capable of the following favorable characteristics: (1) a strong visual and semantic understanding of our world and human society for basic object and human image generation. (2) generalizable identity preservation ability. (3) flexible and fine-grained head control. Recently, large pre-trained text-to-image diffusion models have shown remarkable results, serving as a powerful generative foundation. As a basis, we aim to unleash the above two capabilities of the pre-trained model. In this work, we present a new framework named CapHuman. We embrace the ``encode then learn to align" paradigm, which enables generalizable identity preservation for new individuals without cumbersome tuning at inference. CapHuman encodes identity features and then learns to align them into the latent space. Moreover, we introduce the 3D facial prior to equip our model with control over the human head in a flexible and 3D-consistent manner. Extensive qualitative and quantitative analyses demonstrate our CapHuman can produce well-identity-preserved, photo-realistic, and high-fidelity portraits with content-rich representations and various head renditions, superior to established baselines.
- [2024/04/26] We release the code and checkpoint.
- [2024/02/27] Our paper is accepted by CVPR2024.
- [2024/02/01] We release the Project Page.
conda create -n caphuman python=3.7
pip install -r requirements.txt
Follow INSTALL to install pytorch3d (e.g. 0.7.4, 0.7.6). We provide the whl file.
We provide the script to download data and models conveniently.
bash tools/setup.sh
Otherwise, follow adobe-research/diffusion-rig for DECA setup.
data/
deca_model.tar
generic_model.pkl
FLAME_texture.npz
fixed_displacement_256.npy
head_template.obj
landmark_embedding.npy
mean_texture.jpg
texture_data_256.npy
uv_face_eye_mask.png
uv_face_mask.png
And, download our checkpoint caphuman.ckpt, vae-ft-mse-840000-ema-pruned.ckpt, Realistic_Vision_V3.0.ckpt, 79999_iter.pth and put them into ckpts.
ckpts/
face-parsing/
79999_iter.pth
caphuman.ckpt
Realistic_Vision_V3.0.ckpt
vae-ft-mse-840000-ema-pruned.ckpt
Note: you can download comic-babes, disney-pixar-cartoon-type-a, toonyou for different styles.
python inference.py --ckpt ckpts/caphuman.ckpt --vae_ckpt ckpts/vae-ft-mse-840000-ema-pruned.ckpt --model models/cldm_v15.yaml --sd_ckpt ckpts/Realistic_Vision_V3.0.ckpt --input_image examples/input_images/196251.png --pose_image examples/pose_images/pose1.png --prompt "a photo of a man wearing a suit in front of Space Needle"
Note: you can replace the sd backbone for different styles, e.g. --sd_ckpt disneyPixarCartoon_v10.safetensors
.
If you prefer gradio, you can try the following command:
python -m gradios.gradio_visualization --ckpt ckpts/caphuman.ckpt --vae_ckpt ckpts/vae-ft-mse-840000-ema-pruned.ckpt --model models/cldm_v15.yaml --sd_ckpt ckpts/Realistic_Vision_V3.0.ckpt
If you are familiar with stable-diffusion-webui, please refer to the extension sd-webui-controlnet. Note: we make some modifications to support CapHuman.
@inproceedings{liang2024caphuman,
author={Liang, Chao and Ma, Fan and Zhu, Linchao and Deng, Yingying and Yang, Yi},
title={CapHuman: Capture Your Moments in Parallel Universes},
booktitle={CVPR},
pages={6400--6409},
year={2024}
}
This project is under the CC-BY-NC 4.0 license. See LICENSE for details.
- lllyasviel/ControlNet
- adobe-research/diffusion-rig
- yfeng95/DECA
- CompVis/stable-diffusion
- openai/CLIP
- VamosC/CLIP4STR
- mzhaoshuai/RLCF
- mzhaoshuai/CenterCLIP
- FreeformRobotics/Divide-and-Co-training
- Realistic_Vision_V3.0.ckpt
- comic-babes
- disney-pixar-cartoon-type-a
- toonyou
We sincerely thank Zongxin Yang for valuable discussions.