Here we provide the inference (online-finetuning included) code and pretrained weight for our trimap generation module in our paper Attention-guided Temporally Coherent Video Object Matting.
The code, the trained model are for academic and non-commercial use only.
This module is based on STM by Oh et al., code is from here.
Python=3.8
Pytorch=1.6.0
numpy
opencv-python
imgaug
tqdm
yacs
-
Download the pretrained weight here.
-
Prepare the video clip data, make sure the annotated trimap and the RGB image correspond each other. For example, say the video clip has 100 frames and the first, the last, and the 50th frame have their corresponding keyframe trimaps. The video clip folder should have the structure of the following:
|---workspace |---video_clip |---00000_rgb.png |---00000_trimap.png |---00001_rgb.png |---00002_rgb.png |---... |---00049_rgb.png |---00049_trimap.png |---... |---00097_rgb.png |---00098_rgb.png |---00099_rgb.png |---00099_trimap.png
-
Create a training configuration yaml for the video clip. Please refer to
template.yaml
for detail. -
Online-finetuning:
python online_finetune_test.py --cfg /path/to/config.yaml
-
Inference:
python test_mf_2.py --cfg /path/to/config.yaml --load /path/to/finedtuned_weight.pth --save /path/to/results
- If you ran out of memory during the inference, there are two parameters you can tune.
mem_every
: STM 'memorizes' a new feature map every 5 frames by default. Try increasing this number.max_memory
: The maximum number of feature maps inside STM's memory pool. By setting this parameter, STM will 'forget' the oldest feature map (except the ground-truth frame) in the memory pool to cap the GPU memory usage. By default it isNone
, the memory pool will grow indefinitely.
- If you ran out of memory during the inference, there are two parameters you can tune.
-
Ensemble:
python ensemble.py --predroot /path/to/results --dataroot /path/to/workspace [video_clip_folder1] [video_clip_folder2] ...
- By default the script will process all folders under
/path/to/results
. You can also specify the folder name that you want to process in the command-line. - The final result is under
/path/to/results/video_clip_folder/ensemble
.
- By default the script will process all folders under
If you have any questions, please feel free to contact [email protected]
.