Official Code for DragGAN (SIGGRAPH 2023)
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
ochafik f3777f6e5b Support & instructions for MPS (Silicon Mac M1/M2) and CPU 2 years ago
dnnlib DragGAN code 2 years ago
gradio_utils support gradio demo for DragGAN 2 years ago
gui_utils DragGAN code 2 years ago
scripts build a download_model.bat script for windows user 2 years ago
stylegan_human Support & instructions for MPS (Silicon Mac M1/M2) and CPU 2 years ago
torch_utils DragGAN code 2 years ago
training DragGAN code 2 years ago
viz Support & instructions for MPS (Silicon Mac M1/M2) and CPU 2 years ago
.gitignore modified .gitignore 2 years ago
DragGAN.gif first commit 2 years ago
LICENSE.txt DragGAN code 2 years ago
README.md Support & instructions for MPS (Silicon Mac M1/M2) and CPU 2 years ago
arial.ttf support gradio demo for DragGAN 2 years ago
environment.yml Support & instructions for MPS (Silicon Mac M1/M2) and CPU 2 years ago
gen_images.py Support & instructions for MPS (Silicon Mac M1/M2) and CPU 2 years ago
legacy.py DragGAN code 2 years ago
requirements.txt Add requirements for gradio 2 years ago
visualizer_drag.py DragGAN code 2 years ago
visualizer_drag_gradio.py Update visualizer_drag_gradio.py 2 years ago

README.md

Drag Your GAN: Interactive Point-based Manipulation on the Generative Image Manifold

Xingang Pan · Ayush Tewari · Thomas Leimkühler · Lingjie Liu · Abhimitra Meka · Christian Theobalt

SIGGRAPH 2023 Conference Proceedings


PyTorch Twitter Paper PDF Project Page Huggingface Open In Colab

Requirements

If you have CUDA graphic card, please follow the requirements of https://github.com/NVlabs/stylegan3.

Otherwise (for GPU acceleration on MacOS with Silicon Mac M1/M2, or just CPU) try the following:

cat environment.yml | \
  grep -v -E 'nvidia|cuda' > environment-no-nvidia.yml && \
    conda env create -f environment-no-nvidia.yml
conda activate stylegan3

# On MacOS
export PYTORCH_ENABLE_MPS_FALLBACK=1

Download pre-trained StyleGAN2 weights

To download pre-trained weights, simply run:

sh scripts/download_model.sh

If you want to try StyleGAN-Human and the Landscapes HQ (LHQ) dataset, please download weights from these links: StyleGAN-Human, LHQ, and put them under ./checkpoints.

Feel free to try other pretrained StyleGAN.

Run DragGAN GUI

To start the DragGAN GUI, simply run:

sh scripts/gui.sh

This GUI supports editing GAN-generated images. To edit a real image, you need to first perform GAN inversion using tools like PTI. Then load the new latent code and model weights to the GUI.

You can run DragGAN Gradio demo as well:

python visualizer_drag_gradio.py

Acknowledgement

This code is developed based on StyleGAN3. Part of the code is borrowed from StyleGAN-Human.

License

The code related to the DragGAN algorithm is licensed under CC-BY-NC. However, most of this project are available under a separate license terms: all codes used or modified from StyleGAN3 is under the Nvidia Source Code License.

Any form of use and derivative of this code must preserve the watermarking functionality showing "AI Generated".

BibTeX

@inproceedings{pan2023draggan,
    title={Drag Your GAN: Interactive Point-based Manipulation on the Generative Image Manifold},
    author={Pan, Xingang and Tewari, Ayush, and Leimk{\"u}hler, Thomas and Liu, Lingjie and Meka, Abhimitra and Theobalt, Christian},
    booktitle = {ACM SIGGRAPH 2023 Conference Proceedings},
    year={2023}
}