首页
/ PyTorch Vision中COCO数据集对压缩RLE掩码格式的支持

PyTorch Vision中COCO数据集对压缩RLE掩码格式的支持

2025-05-13 19:13:05作者:董灵辛Dennis

在计算机视觉领域,COCO数据集格式因其丰富的标注信息而广受欢迎。PyTorch Vision库提供了对COCO格式的原生支持,但在处理分割掩码时存在一些格式兼容性问题,特别是对于压缩RLE格式的支持不够完善。

COCO数据集中的掩码格式

COCO数据集支持三种主要的分割掩码表示形式:

  1. 多边形格式:当标注中的iscrowd属性为0时使用,表示单个物体,格式为顶点坐标列表
  2. 未压缩RLE格式:当iscrowd为1时使用,表示人群等密集物体,格式为计数字典
  3. 压缩RLE格式:未压缩RLE的编码版本,使用字符串表示计数

问题背景

PyTorch Vision的CocoDetection数据集类及其转换包装器wrap_dataset_for_transforms_v2在处理掩码时,原本只支持多边形和未压缩RLE格式。当遇到压缩RLE格式的掩码时,会抛出值错误,因为内部转换函数segmentation_to_mask无法正确处理字符串形式的计数。

技术解决方案

为解决这一问题,PyTorch Vision团队对掩码处理逻辑进行了改进,增加了对压缩RLE格式的支持。新的处理流程如下:

  1. 首先检查掩码计数是否为字符串格式(压缩RLE)
  2. 如果是字符串格式,直接解码
  3. 如果是字典格式(未压缩RLE),先转换为压缩格式再解码
  4. 如果是多边形格式,先合并多边形再转换为RLE格式

实现细节

改进后的掩码处理函数采用了更健壮的条件判断逻辑:

def segmentation_to_mask(segmentation, *, canvas_size):
    if isinstance(segmentation["counts"], str):
        # 直接处理压缩RLE格式
        pass
    elif isinstance(segmentation, dict):
        # 处理未压缩RLE格式
        segmentation = mask.frPyObjects(segmentation, *canvas_size)
    else:
        # 处理多边形格式
        segmentation = mask.merge(mask.frPyObjects(segmentation, *canvas_size))
    
    return torch.from_numpy(mask.decode(segmentation))

实际应用

这一改进使得PyTorch Vision能够无缝处理各种COCO格式的数据集,包括那些使用压缩RLE格式标注的数据集。用户现在可以像往常一样使用CocoDetection类加载数据集,并通过wrap_dataset_for_transforms_v2进行转换,无需担心底层掩码格式的差异。

总结

PyTorch Vision对压缩RLE掩码格式的支持增强,进一步提升了其在计算机视觉任务中的适用性和灵活性。这一改进使得框架能够处理更广泛的公开数据集和自定义数据集,为研究人员和开发者提供了更强大的工具支持。

对于需要使用COCO格式数据集进行分割任务的用户,现在可以放心地使用PyTorch Vision提供的高级API,而无需担心底层数据格式的兼容性问题。这一改进也体现了PyTorch生态对实际应用场景需求的快速响应能力。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
27
13
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
643
4.19 K
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
Dora-SSRDora-SSR
Dora SSR 是一款跨平台的游戏引擎,提供前沿或是具有探索性的游戏开发功能。它内置了Web IDE,提供了可以轻轻松松通过浏览器访问的快捷游戏开发环境,特别适合于在新兴市场如国产游戏掌机和其它移动电子设备上直接进行游戏开发和编程学习。
C++
57
7
flutter_flutterflutter_flutter
暂无简介
Dart
885
211
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
386
273
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.52 K
868
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
24
0
AscendNPU-IRAscendNPU-IR
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
124
191