许可证: mit
标签:
- 视觉
- 图像分割
数据集:
- YouTubeVIS-2021
视频Mask2Former
基于YouTubeVIS-2021实例分割数据集训练的Video Mask2Former模型(微型版本,Swin骨干网络)。该模型由论文Mask2Former for Video Instance Segmentation提出,并首次发布于此代码库。
Video Mask2Former是原版Mask2Former论文的扩展,原论文名为Masked-attention Mask Transformer for Universal Image Segmentation。
免责声明:发布Mask2Former的团队未为此模型编写模型卡,因此本模型卡由Hugging Face团队撰写。
模型描述
Mask2Former采用统一范式处理实例分割、语义分割和全景分割任务:通过预测一组掩码及其对应标签。因此,所有三项任务均被视为实例分割处理。Mask2Former在性能和效率上均超越了前SOTA模型MaskFormer,其改进包括:(i) 用更先进的多尺度可变形注意力Transformer替换像素解码器;(ii) 采用带掩码注意力的Transformer解码器以在不增加计算量的前提下提升性能;(iii) 通过基于采样点计算损失而非整张掩码来提升训练效率。
在论文Mask2Former for Video Instance Segmentation中,作者证明Mask2Former在不修改架构、损失函数甚至训练流程的情况下,同样在视频实例分割任务上达到了最先进水平。

预期用途与限制
此特定检查点可用于实例分割任务。访问模型中心可查找其他可能感兴趣的微调版本。
使用方法
使用方式如下:
import torch
import torchvision
from huggingface_hub import hf_hub_download
from transformers import AutoImageProcessor, Mask2FormerForUniversalSegmentation
processor = AutoImageProcessor.from_pretrained("facebook/video-mask2former-swin-tiny-youtubevis-2021-instance")
model = Mask2FormerForUniversalSegmentation.from_pretrained("facebook/video-mask2former-swin-tiny-youtubevis-2021-instance")
file_path = hf_hub_download(repo_id="shivi/video-demo", filename="cars.mp4", repo_type="dataset")
video = torchvision.io.read_video(file_path)[0]
video_frames = [image_processor(images=frame, return_tensors="pt").pixel_values for frame in video]
video_input = torch.cat(video_frames)
with torch.no_grad():
outputs = model(**video_input)
class_queries_logits = outputs.class_queries_logits
masks_queries_logits = outputs.masks_queries_logits
result = image_processor.post_process_video_instance_segmentation(outputs, target_sizes=[tuple(video.shape[1:3])])[0]
predicted_video_instance_map = result["segmentation"]
更多代码示例详见文档。