vace-demo / tests /test_annotators.py
maffia's picture
Upload 94 files
690f890 verified
# -*- coding: utf-8 -*-
# Copyright (c) Alibaba, Inc. and its affiliates.
import os
import unittest
import numpy as np
from PIL import Image
from vace.annotators.utils import read_video_frames
from vace.annotators.utils import save_one_video
class AnnotatorTest(unittest.TestCase):
def setUp(self):
print(('Testing %s.%s' % (type(self).__name__, self._testMethodName)))
self.save_dir = './cache/test_annotator'
if not os.path.exists(self.save_dir):
os.makedirs(self.save_dir)
# load test image
self.image_path = './assets/images/test.jpg'
self.image = Image.open(self.image_path).convert('RGB')
# load test video
self.video_path = './assets/videos/test.mp4'
self.frames = read_video_frames(self.video_path)
def tearDown(self):
super().tearDown()
@unittest.skip('')
def test_annotator_gray_image(self):
from vace.annotators.gray import GrayAnnotator
cfg_dict = {}
anno_ins = GrayAnnotator(cfg_dict)
anno_image = anno_ins.forward(np.array(self.image))
save_path = os.path.join(self.save_dir, 'test_gray_image.png')
Image.fromarray(anno_image).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_gray_video(self):
from vace.annotators.gray import GrayAnnotator
cfg_dict = {}
anno_ins = GrayAnnotator(cfg_dict)
ret_frames = []
for frame in self.frames:
anno_frame = anno_ins.forward(np.array(frame))
ret_frames.append(anno_frame)
save_path = os.path.join(self.save_dir, 'test_gray_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_gray_video_2(self):
from vace.annotators.gray import GrayVideoAnnotator
cfg_dict = {}
anno_ins = GrayVideoAnnotator(cfg_dict)
ret_frames = anno_ins.forward(self.frames)
save_path = os.path.join(self.save_dir, 'test_gray_video_2.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_pose_image(self):
from vace.annotators.pose import PoseBodyFaceAnnotator
cfg_dict = {
"DETECTION_MODEL": "models/VACE-Annotators/pose/yolox_l.onnx",
"POSE_MODEL": "models/VACE-Annotators/pose/dw-ll_ucoco_384.onnx",
"RESIZE_SIZE": 1024
}
anno_ins = PoseBodyFaceAnnotator(cfg_dict)
anno_image = anno_ins.forward(np.array(self.image))
save_path = os.path.join(self.save_dir, 'test_pose_image.png')
Image.fromarray(anno_image).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_pose_video(self):
from vace.annotators.pose import PoseBodyFaceAnnotator
cfg_dict = {
"DETECTION_MODEL": "models/VACE-Annotators/pose/yolox_l.onnx",
"POSE_MODEL": "models/VACE-Annotators/pose/dw-ll_ucoco_384.onnx",
"RESIZE_SIZE": 1024
}
anno_ins = PoseBodyFaceAnnotator(cfg_dict)
ret_frames = []
for frame in self.frames:
anno_frame = anno_ins.forward(np.array(frame))
ret_frames.append(anno_frame)
save_path = os.path.join(self.save_dir, 'test_pose_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_pose_video_2(self):
from vace.annotators.pose import PoseBodyFaceVideoAnnotator
cfg_dict = {
"DETECTION_MODEL": "models/VACE-Annotators/pose/yolox_l.onnx",
"POSE_MODEL": "models/VACE-Annotators/pose/dw-ll_ucoco_384.onnx",
"RESIZE_SIZE": 1024
}
anno_ins = PoseBodyFaceVideoAnnotator(cfg_dict)
ret_frames = anno_ins.forward(self.frames)
save_path = os.path.join(self.save_dir, 'test_pose_video_2.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_depth_image(self):
from vace.annotators.depth import DepthAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/depth/dpt_hybrid-midas-501f0c75.pt"
}
anno_ins = DepthAnnotator(cfg_dict)
anno_image = anno_ins.forward(np.array(self.image))
save_path = os.path.join(self.save_dir, 'test_depth_image.png')
Image.fromarray(anno_image).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_depth_video(self):
from vace.annotators.depth import DepthAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/depth/dpt_hybrid-midas-501f0c75.pt"
}
anno_ins = DepthAnnotator(cfg_dict)
ret_frames = []
for frame in self.frames:
anno_frame = anno_ins.forward(np.array(frame))
ret_frames.append(anno_frame)
save_path = os.path.join(self.save_dir, 'test_depth_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_depth_video_2(self):
from vace.annotators.depth import DepthVideoAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/depth/dpt_hybrid-midas-501f0c75.pt"
}
anno_ins = DepthVideoAnnotator(cfg_dict)
ret_frames = anno_ins.forward(self.frames)
save_path = os.path.join(self.save_dir, 'test_depth_video_2.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_scribble_image(self):
from vace.annotators.scribble import ScribbleAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/scribble/anime_style/netG_A_latest.pth"
}
anno_ins = ScribbleAnnotator(cfg_dict)
anno_image = anno_ins.forward(np.array(self.image))
save_path = os.path.join(self.save_dir, 'test_scribble_image.png')
Image.fromarray(anno_image).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_scribble_video(self):
from vace.annotators.scribble import ScribbleAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/scribble/anime_style/netG_A_latest.pth"
}
anno_ins = ScribbleAnnotator(cfg_dict)
ret_frames = []
for frame in self.frames:
anno_frame = anno_ins.forward(np.array(frame))
ret_frames.append(anno_frame)
save_path = os.path.join(self.save_dir, 'test_scribble_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_scribble_video_2(self):
from vace.annotators.scribble import ScribbleVideoAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/scribble/anime_style/netG_A_latest.pth"
}
anno_ins = ScribbleVideoAnnotator(cfg_dict)
ret_frames = anno_ins.forward(self.frames)
save_path = os.path.join(self.save_dir, 'test_scribble_video_2.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_flow_video(self):
from vace.annotators.flow import FlowVisAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/flow/raft-things.pth"
}
anno_ins = FlowVisAnnotator(cfg_dict)
ret_frames = anno_ins.forward(self.frames)
save_path = os.path.join(self.save_dir, 'test_flow_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_frameref_video_1(self):
from vace.annotators.frameref import FrameRefExtractAnnotator
cfg_dict = {
"REF_CFG": [{"mode": "first", "proba": 0.1},
{"mode": "last", "proba": 0.1},
{"mode": "firstlast", "proba": 0.1},
{"mode": "random", "proba": 0.1}],
}
anno_ins = FrameRefExtractAnnotator(cfg_dict)
ret_frames, ret_masks = anno_ins.forward(self.frames, ref_num=10)
save_path = os.path.join(self.save_dir, 'test_frameref_video_1.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
save_path = os.path.join(self.save_dir, 'test_frameref_mask_1.mp4')
save_one_video(save_path, ret_masks, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_frameref_video_2(self):
from vace.annotators.frameref import FrameRefExpandAnnotator
cfg_dict = {}
anno_ins = FrameRefExpandAnnotator(cfg_dict)
ret_frames, ret_masks = anno_ins.forward(frames=self.frames, mode='lastclip', expand_num=50)
save_path = os.path.join(self.save_dir, 'test_frameref_video_2.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
save_path = os.path.join(self.save_dir, 'test_frameref_mask_2.mp4')
save_one_video(save_path, ret_masks, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_outpainting_1(self):
from vace.annotators.outpainting import OutpaintingAnnotator
cfg_dict = {
"RETURN_MASK": True,
"KEEP_PADDING_RATIO": 1,
"MASK_COLOR": "gray"
}
anno_ins = OutpaintingAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.image, direction=['right', 'up', 'down'], expand_ratio=0.5)
save_path = os.path.join(self.save_dir, 'test_outpainting_image.png')
Image.fromarray(ret_data['image']).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
save_path = os.path.join(self.save_dir, 'test_outpainting_mask.png')
Image.fromarray(ret_data['mask']).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_outpainting_video_1(self):
from vace.annotators.outpainting import OutpaintingVideoAnnotator
cfg_dict = {
"RETURN_MASK": True,
"KEEP_PADDING_RATIO": 1,
"MASK_COLOR": "gray"
}
anno_ins = OutpaintingVideoAnnotator(cfg_dict)
ret_data = anno_ins.forward(frames=self.frames, direction=['right', 'up', 'down'], expand_ratio=0.5)
save_path = os.path.join(self.save_dir, 'test_outpainting_video_1.mp4')
save_one_video(save_path, ret_data['frames'], fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
save_path = os.path.join(self.save_dir, 'test_outpainting_mask_1.mp4')
save_one_video(save_path, ret_data['masks'], fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_outpainting_inner_1(self):
from vace.annotators.outpainting import OutpaintingInnerAnnotator
cfg_dict = {
"RETURN_MASK": True,
"KEEP_PADDING_RATIO": 1,
"MASK_COLOR": "gray"
}
anno_ins = OutpaintingInnerAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.image, direction=['right', 'up', 'down'], expand_ratio=0.15)
save_path = os.path.join(self.save_dir, 'test_outpainting_inner_image.png')
Image.fromarray(ret_data['image']).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
save_path = os.path.join(self.save_dir, 'test_outpainting_inner_mask.png')
Image.fromarray(ret_data['mask']).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_outpainting_inner_video_1(self):
from vace.annotators.outpainting import OutpaintingInnerVideoAnnotator
cfg_dict = {
"RETURN_MASK": True,
"KEEP_PADDING_RATIO": 1,
"MASK_COLOR": "gray"
}
anno_ins = OutpaintingInnerVideoAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.frames, direction=['right', 'up', 'down'], expand_ratio=0.15)
save_path = os.path.join(self.save_dir, 'test_outpainting_inner_video_1.mp4')
save_one_video(save_path, ret_data['frames'], fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
save_path = os.path.join(self.save_dir, 'test_outpainting_inner_mask_1.mp4')
save_one_video(save_path, ret_data['masks'], fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_salient(self):
from vace.annotators.salient import SalientAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/salient/u2net.pt",
}
anno_ins = SalientAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.image)
save_path = os.path.join(self.save_dir, 'test_salient_image.png')
Image.fromarray(ret_data).save(save_path)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_salient_video(self):
from vace.annotators.salient import SalientVideoAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/salient/u2net.pt",
}
anno_ins = SalientVideoAnnotator(cfg_dict)
ret_frames = anno_ins.forward(self.frames)
save_path = os.path.join(self.save_dir, 'test_salient_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_layout_video(self):
from vace.annotators.layout import LayoutBboxAnnotator
cfg_dict = {
"RAM_TAG_COLOR_PATH": "models/VACE-Annotators/layout/ram_tag_color_list.txt",
}
anno_ins = LayoutBboxAnnotator(cfg_dict)
ret_frames = anno_ins.forward(bbox=[(544, 288, 744, 680), (1112, 240, 1280, 712)], frame_size=(720, 1280), num_frames=49, label='person')
save_path = os.path.join(self.save_dir, 'test_layout_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_layout_mask_video(self):
# salient
from vace.annotators.salient import SalientVideoAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/salient/u2net.pt",
}
anno_ins = SalientVideoAnnotator(cfg_dict)
salient_frames = anno_ins.forward(self.frames)
# mask layout
from vace.annotators.layout import LayoutMaskAnnotator
cfg_dict = {
"RAM_TAG_COLOR_PATH": "models/VACE-Annotators/layout/ram_tag_color_list.txt",
}
anno_ins = LayoutMaskAnnotator(cfg_dict)
ret_frames = anno_ins.forward(salient_frames, label='cat')
save_path = os.path.join(self.save_dir, 'test_mask_layout_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_layout_mask_video_2(self):
# salient
from vace.annotators.salient import SalientVideoAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/salient/u2net.pt",
}
anno_ins = SalientVideoAnnotator(cfg_dict)
salient_frames = anno_ins.forward(self.frames)
# mask layout
from vace.annotators.layout import LayoutMaskAnnotator
cfg_dict = {
"RAM_TAG_COLOR_PATH": "models/VACE-Annotators/layout/ram_tag_color_list.txt",
"USE_AUG": True
}
anno_ins = LayoutMaskAnnotator(cfg_dict)
ret_frames = anno_ins.forward(salient_frames, label='cat', mask_cfg={'mode': 'bbox_expand'})
save_path = os.path.join(self.save_dir, 'test_mask_layout_video_2.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_maskaug_video(self):
# salient
from vace.annotators.salient import SalientVideoAnnotator
cfg_dict = {
"PRETRAINED_MODEL": "models/VACE-Annotators/salient/u2net.pt",
}
anno_ins = SalientVideoAnnotator(cfg_dict)
salient_frames = anno_ins.forward(self.frames)
# mask aug
from vace.annotators.maskaug import MaskAugAnnotator
cfg_dict = {}
anno_ins = MaskAugAnnotator(cfg_dict)
ret_frames = anno_ins.forward(salient_frames, mask_cfg={'mode': 'hull_expand'})
save_path = os.path.join(self.save_dir, 'test_maskaug_video.mp4')
save_one_video(save_path, ret_frames, fps=16)
print(('Testing %s: %s' % (type(self).__name__, save_path)))
@unittest.skip('')
def test_annotator_ram(self):
from vace.annotators.ram import RAMAnnotator
cfg_dict = {
"TOKENIZER_PATH": "models/VACE-Annotators/ram/bert-base-uncased",
"PRETRAINED_MODEL": "models/VACE-Annotators/ram/ram_plus_swin_large_14m.pth",
}
anno_ins = RAMAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.image)
print(ret_data)
@unittest.skip('')
def test_annotator_gdino_v1(self):
from vace.annotators.gdino import GDINOAnnotator
cfg_dict = {
"TOKENIZER_PATH": "models/VACE-Annotators/gdino/bert-base-uncased",
"CONFIG_PATH": "models/VACE-Annotators/gdino/GroundingDINO_SwinT_OGC_mod.py",
"PRETRAINED_MODEL": "models/VACE-Annotators/gdino/groundingdino_swint_ogc.pth",
}
anno_ins = GDINOAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.image, caption="a cat and a vase")
print(ret_data)
@unittest.skip('')
def test_annotator_gdino_v2(self):
from vace.annotators.gdino import GDINOAnnotator
cfg_dict = {
"TOKENIZER_PATH": "models/VACE-Annotators/gdino/bert-base-uncased",
"CONFIG_PATH": "models/VACE-Annotators/gdino/GroundingDINO_SwinT_OGC_mod.py",
"PRETRAINED_MODEL": "models/VACE-Annotators/gdino/groundingdino_swint_ogc.pth",
}
anno_ins = GDINOAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.image, classes=["cat", "vase"])
print(ret_data)
@unittest.skip('')
def test_annotator_gdino_with_ram(self):
from vace.annotators.gdino import GDINORAMAnnotator
cfg_dict = {
"RAM": {
"TOKENIZER_PATH": "models/VACE-Annotators/ram/bert-base-uncased",
"PRETRAINED_MODEL": "models/VACE-Annotators/ram/ram_plus_swin_large_14m.pth",
},
"GDINO": {
"TOKENIZER_PATH": "models/VACE-Annotators/gdino/bert-base-uncased",
"CONFIG_PATH": "models/VACE-Annotators/gdino/GroundingDINO_SwinT_OGC_mod.py",
"PRETRAINED_MODEL": "models/VACE-Annotators/gdino/groundingdino_swint_ogc.pth",
}
}
anno_ins = GDINORAMAnnotator(cfg_dict)
ret_data = anno_ins.forward(self.image)
print(ret_data)
@unittest.skip('')
def test_annotator_sam2(self):
from vace.annotators.sam2 import SAM2VideoAnnotator
from vace.annotators.utils import save_sam2_video
cfg_dict = {
"CONFIG_PATH": 'models/VACE-Annotators/sam2/configs/sam2.1/sam2.1_hiera_l.yaml',
"PRETRAINED_MODEL": 'models/VACE-Annotators/sam2/sam2.1_hiera_large.pt'
}
anno_ins = SAM2VideoAnnotator(cfg_dict)
ret_data = anno_ins.forward(video=self.video_path, input_box=[0, 0, 640, 480])
video_segments = ret_data['annotations']
save_path = os.path.join(self.save_dir, 'test_sam2_video')
if not os.path.exists(save_path):
os.makedirs(save_path)
save_sam2_video(video_path=self.video_path, video_segments=video_segments, output_video_path=save_path)
print(save_path)
@unittest.skip('')
def test_annotator_sam2salient(self):
from vace.annotators.sam2 import SAM2SalientVideoAnnotator
from vace.annotators.utils import save_sam2_video
cfg_dict = {
"SALIENT": {
"PRETRAINED_MODEL": "models/VACE-Annotators/salient/u2net.pt",
},
"SAM2": {
"CONFIG_PATH": 'models/VACE-Annotators/sam2/configs/sam2.1/sam2.1_hiera_l.yaml',
"PRETRAINED_MODEL": 'models/VACE-Annotators/sam2/sam2.1_hiera_large.pt'
}
}
anno_ins = SAM2SalientVideoAnnotator(cfg_dict)
ret_data = anno_ins.forward(video=self.video_path)
video_segments = ret_data['annotations']
save_path = os.path.join(self.save_dir, 'test_sam2salient_video')
if not os.path.exists(save_path):
os.makedirs(save_path)
save_sam2_video(video_path=self.video_path, video_segments=video_segments, output_video_path=save_path)
print(save_path)
@unittest.skip('')
def test_annotator_sam2gdinoram_video(self):
from vace.annotators.sam2 import SAM2GDINOVideoAnnotator
from vace.annotators.utils import save_sam2_video
cfg_dict = {
"GDINO": {
"TOKENIZER_PATH": "models/VACE-Annotators/gdino/bert-base-uncased",
"CONFIG_PATH": "models/VACE-Annotators/gdino/GroundingDINO_SwinT_OGC_mod.py",
"PRETRAINED_MODEL": "models/VACE-Annotators/gdino/groundingdino_swint_ogc.pth",
},
"SAM2": {
"CONFIG_PATH": 'models/VACE-Annotators/sam2/configs/sam2.1/sam2.1_hiera_l.yaml',
"PRETRAINED_MODEL": 'models/VACE-Annotators/sam2/sam2.1_hiera_large.pt'
}
}
anno_ins = SAM2GDINOVideoAnnotator(cfg_dict)
ret_data = anno_ins.forward(video=self.video_path, classes='cat')
video_segments = ret_data['annotations']
save_path = os.path.join(self.save_dir, 'test_sam2gdino_video')
if not os.path.exists(save_path):
os.makedirs(save_path)
save_sam2_video(video_path=self.video_path, video_segments=video_segments, output_video_path=save_path)
print(save_path)
@unittest.skip('')
def test_annotator_sam2_image(self):
from vace.annotators.sam2 import SAM2ImageAnnotator
cfg_dict = {
"CONFIG_PATH": 'models/VACE-Annotators/sam2/configs/sam2.1/sam2.1_hiera_l.yaml',
"PRETRAINED_MODEL": 'models/VACE-Annotators/sam2/sam2.1_hiera_large.pt'
}
anno_ins = SAM2ImageAnnotator(cfg_dict)
ret_data = anno_ins.forward(image=self.image, input_box=[0, 0, 640, 480])
print(ret_data)
# @unittest.skip('')
def test_annotator_prompt_extend(self):
from vace.annotators.prompt_extend import PromptExtendAnnotator
from vace.configs.prompt_preprocess import WAN_LM_ZH_SYS_PROMPT, WAN_LM_EN_SYS_PROMPT, LTX_LM_EN_SYS_PROMPT
cfg_dict = {
"MODEL_NAME": "models/VACE-Annotators/llm/Qwen2.5-3B-Instruct" # "Qwen2.5_3B"
}
anno_ins = PromptExtendAnnotator(cfg_dict)
ret_data = anno_ins.forward('一位男孩', system_prompt=WAN_LM_ZH_SYS_PROMPT)
print('wan_zh:', ret_data)
ret_data = anno_ins.forward('a boy', system_prompt=WAN_LM_EN_SYS_PROMPT)
print('wan_en:', ret_data)
ret_data = anno_ins.forward('a boy', system_prompt=WAN_LM_ZH_SYS_PROMPT)
print('wan_zh en:', ret_data)
ret_data = anno_ins.forward('a boy', system_prompt=LTX_LM_EN_SYS_PROMPT)
print('ltx_en:', ret_data)
from vace.annotators.utils import get_annotator
anno_ins = get_annotator(config_type='prompt', config_task='ltx_en', return_dict=False)
ret_data = anno_ins.forward('a boy', seed=2025)
print('ltx_en:', ret_data)
ret_data = anno_ins.forward('a boy')
print('ltx_en:', ret_data)
ret_data = anno_ins.forward('a boy', seed=2025)
print('ltx_en:', ret_data)
@unittest.skip('')
def test_annotator_prompt_extend_ds(self):
from vace.annotators.utils import get_annotator
# export DASH_API_KEY=''
anno_ins = get_annotator(config_type='prompt', config_task='wan_zh_ds', return_dict=False)
ret_data = anno_ins.forward('一位男孩', seed=2025)
print('wan_zh_ds:', ret_data)
ret_data = anno_ins.forward('a boy', seed=2025)
print('wan_zh_ds:', ret_data)
# ln -s your/path/annotator_models annotator_models
# PYTHONPATH=. python tests/test_annotators.py
if __name__ == '__main__':
unittest.main()