/LOVECon

Official implementation for "LOVECon: Text-driven Training-free Long Video Editing with ControlNet"

Primary LanguagePythonMIT LicenseMIT

LOVECon: Text-driven Training-free Long Video Editing with ControlNet


Zhenyi Liao, Zhijie Deng

πŸ‘‡Demo for 48 frames

| A woman with a white hat -> A woman with a pink hat | Attribute Editing

hat_comparison.mp4

| Flamingos -> Flamingos in the blue water | Background Editing

flamingo_comparison.mp4

| A boat -> A boat, Van Gogh's Starry Night style | Style transfer

boat_comparison.mp4

We adapt ControlNet-I and ControlNet-II for comparisons.

πŸ‘‡ Abstract

TL; DR: LOVECon can perform text-driven long video editing with ControlNet in training-free and auto-regressive way with the help of cross-window attention and a video interpolation model, and precise control with mask obtained from DDIM inversion.

Click to check the full version

Leveraging pre-trained conditional diffusion models for video editing without further tuning has gained increasing attention due to its promise in film production, advertising, etc. Yet, seminal works in this line fall short in generation length, temporal coherence, or fidelity to the source video. This paper aims to bridge the gap, establishing a simple and effective baseline for training-free diffusion model-based long video editing. As suggested by prior arts, we build the pipeline upon ControlNet, which excels at various image editing tasks based on text prompts. To break down the length constraints caused by limited computational memory, we split the long video into consecutive windows and develop a novel cross-window attention mechanism to ensure the consistency of global style and maximize the smoothness among windows. To achieve more accurate control, we extract the information from the source video via DDIM inversion and integrate the outcomes into the latent states of the generations. We also incorporate a video frame interpolation model to mitigate the frame-level flickering issue. Extensive empirical studies verify the superior efficacy of our method over competing baselines across scenarios, including the replacement of the attributes of foreground objects, style transfer, and background replacement. In particular, our method manages to edit videos with up to 128 frames according to user requirements.。

πŸ‘‡ Overview

We present our pipeline for editing the videos using Stable Diffusion and ControlNet. pipeline

πŸ‘‡ Environment

You can create a virtual environment with running the following commands.

conda create -n lovecon python=3.8
conda activate lovecon
pip install -r requirements.txt

For the installation of Xformer, you can try the following commands.

wget https://github.com/ShivamShrirao/xformers-wheels/releases/download/4c06c79/xformers-0.0.15.dev0+4c06c79.d20221201-cp38-cp38-linux_x86_64.whl
pip install xformers-0.0.15.dev0+4c06c79.d20221201-cp38-cp38-linux_x86_64.whl

πŸ‘‡ Video Editing

😊 Model loading

Download the pretrained model Stable Diffusion v1.5 and ControlNet and arrange them like the following directorory structure.

  • ckpt
    • stable-diffusion-v1-5
      • feature_extractor
      • safety_checker
      • scheduler
      • text_encoder
      • tokenizer
      • unet
      • vae
      • model_index.json
      • v1-5-pruned-emaonly.ckpt (or any other ckpts)
    • sd-controlnet-canny
      • config.json
      • diffusion_pytorch_model.bin (or any other ckpts)
    • sd-controlnet-hed
    • sd-controlnet-depth

You may use other diffusion models you interest or place them at your will, but do not forget to modify the beginning of the editing configuration, where it indicates the location of models.

😊 Reproduction

You can download the source videos of 48 frames from videos and put them in ./videos. We categorize editing tasks into three types, attribute, background editing and style transfer. We give some examples in the folder ./Examples. If interested, you could reproduce them by the following command.

CUDA_VISIBLE_DEVICES=0 python test_lovecon.py --config test_config/hat.yaml

You can specify the parameters of the configuration to get different editing results for the video.

😊 Edit Your Own Video

You are welcome to edit your own video at your will. You only need to write a configuration file to specify the parameters in the editing process.

The first three lines are for indicating the base diffusion model (default as Stable Diffusion v1.5) and ControlNet.\ Now control_type only support canny, hed and depth.

Dataset_config is for prepaing the data and DDIM inversion.
Video_path indicates the path of the source video in mp4 or gif form.
Prompt is the source prompt.
N_sample_frame specify the frame number we desire to edit from the source video, default as the first n_sample_frame frames.
Sampling_rate represents the sampling schedule for the source video.
The rest is for resize the video.

Editing_config is for controlling the editing process.
The first two lines indicate whether to use DDIM inversion and the attention, both default True.
Editing_type can choose from attribute, background and style. When masks are used, the boundary is not that accurate and may not cover the object, so dilation_kernel is used to boarden the boundary. When we perform attribute editing, editing_phrase indicates the editing object, while in background editing, editing_phrase represents the unchanged object, and we set it empty string for style transfer.

You can make modifications to the source code according to your needs.

πŸ‘‡ Demo for 128 Frames

| A car -> A red car |

A.car-A.red.car.mp4

| A girl -> A girl, disney style |

A.girl-.A.girl.disney.style.mp4

If you need to edit a long video, you just need to modify the N_sample_frame parameter in the config file (eg. 128). You can also make modification to the fusion hyperparameter to trade off between fidelity and the editing so that you can get the results you desire.

πŸ‘‡ Todo

β–  Add shape editing to our pipeline.

πŸ‘‡ Acknowledgment

This repository borrows heavily from FateZero. Thanks to the authors for sharing their codes.

πŸ‘‡ Citation

Please cite our paper if you find our work useful and use it in your work.

@article{liao2023lovecon,
  title={LOVECon: Text-driven Training-Free Long Video Editing with ControlNet},
  author={Liao, Zhenyi and Deng, Zhijie},
  journal={arXiv preprint arXiv:2310.09711},
  year={2023}
}