Skip to content

Files

Latest commit

 

History

History
128 lines (98 loc) · 12.1 KB

features.md

File metadata and controls

128 lines (98 loc) · 12.1 KB

Features

Img2Vid

I believe that there are better ways to do i2v. New methods will be implemented soon and this old and unstable way might be subject to removal.

You need to go to img2img and submit an init frame via A1111 panel. You can optionally submit a last frame via extension panel.

By default: your init_latent will be changed to

init_alpha = (1 - frame_number ^ latent_power / latent_scale)
init_latent = init_latent * init_alpha + random_tensor * (1 - init_alpha)

If you upload a last frame: your init_latent will be changed in a similar way. Read this code to understand how it works.

Prompt Travel

Write positive prompt following the example below.

The first line is head prompt, which is optional. You can write no/single/multiple lines of head prompts.

All following lines in format frame number: prompt are for prompt interpolation. Your frame number should be in ascending order, smaller than the total Number of frames. The first frame is 0 index.

The last line is tail prompt, which is optional. You can write no/single/multiple lines of tail prompts. If you don't need this feature, just write prompts in the old way.

1girl, yoimiya (genshin impact), origen, line, comet, wink, Masterpiece, BestQuality. UltraDetailed, <lora:LineLine2D:0.7>,  <lora:yoimiya:0.8>, 
0: closed mouth
8: open mouth
smile

FreeInit

It allows you to use more time to get more coherent and consistent video frames.

The default parameters provide satisfactory results for most use cases. Increasing the number of iterations can yield better outcomes, but it also prolongs the processing time. If your video contains more intense or rapid motions, consider switching the filter to Gaussian. For a detailed explanation of each parameter, please refer to the documentation in the original repository.

without FreeInit with FreeInit (default params)
00003-1234 00002-1234

ControlNet V2V

You need to go to txt2img / img2img-batch and submit source video or path to frames. Each ControlNet will find control images according to this priority:

  1. ControlNet Single Image tab or Batch Folder tab. Simply upload a control image or a path to folder of control frames is enough.
  2. Img2img Batch tab Input directory if you are using img2img batch. If you upload a directory of control frames, it will be the source control for ALL ControlNet units that you enable without submitting a control image or a path to ControlNet panel.
  3. AnimateDiff Video Path. If you upload a path to frames through Video Path, it will be the source control for ALL ControlNet units that you enable without submitting a control image or a path to ControlNet panel.
  4. AnimateDiff Video Source. If you upload a video through Video Source, it will be the source control for ALL ControlNet units that you enable without submitting a control image or a path to ControlNet panel.

Number of frames will be capped to the minimum number of images among all folders you provide, unless it has a "keyframe" parameter.

SparseCtrl: Sparse ControlNet is for video generation with key frames. If you upload one image in "single image" tab, it will control the following frames to follow your first frame (a probably better way to do img2vid). If you upload a path in "batch" tab, with "keyframe" parameter in a new line (see below), it will attempt to do video frame interpolation. Note that I don't think this ControlNet has a comparable performance to those trained by @lllyasviel. Use at your own risk.

Example input parameter fill-in:

  1. Fill-in seperate control inputs for different ControlNet units.
    1. Control all frames with a single control input. Exception: SparseCtrl will only control the first frame in this way.

      IP-Adapter Output
      ipadapter-single ipadapter-single
    2. Control each frame with a seperate control input. You are encouraged to try multi-ControlNet.

      Canny Output
      controlnet-batch 00005-1961300716
    3. ControlNet inpaint unit: You are encouraged to use my Segment Anything extension to automatically draw mask / generate masks in batch.

      • specify a global image and draw mask on it, or upload a mask. White region is where changes will apply.
      • "mask" parameter for ControlNet inpaint in batch. Type "ctrl + enter" to start a new line and fill in "mask" parameter in format mask:/path/to/mask/frames/.
      single image batch
      inpaint-single inpaint-batch
    4. "keyframe" parameter.

      • IP-Adapter: this parameter means "IP-Adapter prompt travel". See image below for explanation. ipadapter-keyframe You will see terminal log like
        ControlNet - INFO - AnimateDiff + ControlNet ip-adapter_clip_sd15 receive the following parameters:
        ControlNet - INFO -   batch control images: /home/conrevo/SD/dataset/upperbodydataset/mask/key-ipadapter/
        ControlNet - INFO -   batch control keyframe index: [0, 6, 12, 18]
        ControlNet - INFO - IP-Adapter: control prompts will be traveled in the following way:
        ControlNet - INFO -   0: /home/conrevo/SD/dataset/upperbodydataset/mask/key-ipadapter/anime_girl_head_1.png
        ControlNet - INFO -   6: /home/conrevo/SD/dataset/upperbodydataset/mask/key-ipadapter/anime_girl_head_2.png
        ControlNet - INFO -   12: /home/conrevo/SD/dataset/upperbodydataset/mask/key-ipadapter/anime_girl_head_3.png
        ControlNet - INFO -   18: /home/conrevo/SD/dataset/upperbodydataset/mask/key-ipadapter/anime_girl_head_4.png
      • SparseCtrl: this parameter means keyframe. SparseCtrl has its special processing for keyframe logic. Specify this parameter in the same way as IP-Adapter above.
      • All other ControlNets: we insert blank control image for you, and the control latent for that frame will be purely zero. Specify this parameter in the same way as IP-Adapter above.
  2. Specify a global Videl path and Mask path and leave ControlNet Unit Input Directory input blank.
    • You can arbitratily change ControlNet Unit tab to Single Image / Batch Folder / Batch Upload as long as you leave it blank.
    • If you specify a global mask path, all ControlNet Units that you do not give a Mask Directory will use this path.
    • Please only have one of Video source and Video path. They cannot be applied at the same time. cn2
  3. img2img batch. See the screenshot below.i2i-batch

There are a lot of amazing demo online. Here I provide a very simple demo. The dataset is from streamline, but the workflow is an arbitrary setup by me. You can find a lot more much more amazing examples (and potentially available workflows / infotexts) on Reddit, Twitter, YouTube and Bilibili. The easiest way to share your workflow created by my software is to share one output frame with infotext.

input output

Model Spec

BREAKING CHANGE: You need to use Motion LoRA, HotShot-XL and AnimateDiff V3 Motion Adapter from my HuggingFace repository instead of the original one.

Motion LoRA

Download and use them like any other LoRA you use (example: download Motion LoRA to stable-diffusion-webui/models/Lora and add <lora:mm_sd15_v2_lora_PanLeft:0.8> to your positive prompt). Motion LoRAs can only be applied to V2 motion module.

V3

AnimateDiff V3 has identical state dict keys as V1 but slightly different inference logic (GroupNorm is not hacked for V3). You may optionally use adapter for V3, in the same way as how you apply LoRA. You MUST use my link instead of the official link. The official adapter won't work for A1111 due to state dict incompatibility.

AnimateLCM

  • You can download the motion module from here. The original weights should also work, but I recommend using my safetensors fp16 version.
  • You should also download Motion LoRA from here and use it like any LoRA.
  • You should use LCM sampler and a low CFG scale (typically 1-2).

SDXL

AnimateDiff-XL and HotShot-XL have identical architecture to AnimateDiff-SD1.5. The only difference are

  • HotShot-XL is trained with 8 frames instead of 16 frames. You are recommended to set Context batch size to 8 for HotShot-XL.
  • AnimateDiff-XL is still trained with 16 frames. You do not need to change Context batch size for AnimateDiff-XL.
  • AnimateDiff-XL & HotShot-XL have fewer layers compared to AnimateDiff-SD1.5 because of SDXL.
  • AnimateDiff-XL is trained with higher resolution compared to HotShot-XL.

Although AnimateDiff-XL & HotShot-XL have identical structure as AnimateDiff-SD1.5, I strongly discourage you from using AnimateDiff-SD1.5 for SDXL, or using HotShot-XL / AnimateDiff-XL for SD1.5 - you will get severe artifect if you do that. I have decided not to supported that, despite the fact that it is not hard for me to do that.

Technically all features available for AnimateDiff + SD1.5 are also available for (AnimateDiff / HotShot) + SDXL. However, I have not tested all of them. I have tested infinite context generation and prompt travel; I have not tested ControlNet. If you find any bug, please report it to me.

Unfortunately, neither of these 2 motion modules are as good as those for SD1.5, and there is NOTHING I can do about it (they are just poorly trained). Also, there seem to be no ControlNets comparable to what @lllyasviel had trained for Sd1.5. I strongly discourage anyone from applying SDXL for video generation. You will be VERY disappointed if you do that.