news 2026/4/16 11:29:49

对coco格式的分割标注生成二值mask

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
对coco格式的分割标注生成二值mask

@对coco格式的分割标注生成二值mask

对coco格式的分割标注生成二值mask

给定_annotations.coco.json文件,将里面的特定类别解码批量生成二值mask,代码如下:

import json from pathlib import Path import numpy as np from PIL import Image from pycocotools import mask as maskUtils def decode_coco_rle(rle: dict) -> np.ndarray: """ 使用 pycocotools 官方实现解码 COCO RLE,返回 0/255 的二值掩码。 rle 形如 {"counts": "...", "size": [height, width]}。 """ # 有些版本要求 counts 为 bytes,这里兼容处理一下 if isinstance(rle.get("counts"), str): rle = rle.copy() rle["counts"] = rle["counts"].encode("utf-8") mask = maskUtils.decode(rle) # H x W,0/1 uint8 # 统一转为 0/255 mask = (mask.astype(np.uint8)) * 255 return mask def main(): root = Path(__file__).resolve().parent coco_path = root / "_annotations.coco.json" images_dir = root / "images" masks_dir = root / "mask" masks_dir.mkdir(exist_ok=True) # 只保留的类别 id TARGET_CATEGORY_ID = 1 with coco_path.open("r", encoding="utf-8") as f: coco = json.load(f) # image_id -> image_info image_map = {img["id"]: img for img in coco["images"]} # image_id -> 该图像下、且 category_id == 1 的所有标注 annos_by_image = {} for anno in coco["annotations"]: if anno.get("category_id") != TARGET_CATEGORY_ID: # 忽略 category_id 为 0 或其它的标注 continue img_id = anno["image_id"] annos_by_image.setdefault(img_id, []).append(anno) # 对每张图,合成只包含 category_id == 1 的 mask for image_id, info in image_map.items(): height = info["height"] width = info["width"] mask = np.zeros((height, width), dtype=np.uint8) for anno in annos_by_image.get(image_id, []): seg = anno["segmentation"] # 只处理 RLE 字典形式 if not isinstance(seg, dict) or "counts" not in seg: continue decoded = decode_coco_rle(seg) # 多个实例取最大,合并为一张前景=255 的二值图 mask = np.maximum(mask, decoded) # 保存为灰度图(0/255) out_path = masks_dir / info["file_name"] Image.fromarray(mask, mode="L").save(out_path) print(f"saved: {out_path}") print("全部处理完成。") if __name__ == "__main__": main()

coco格式的存储形式示例如下:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:07:10

21、集成UNIX/Linux服务器和客户端到Windows域

集成UNIX/Linux服务器和客户端到Windows域 在网络环境中,将UNIX/Linux服务器和客户端集成到Windows域是一项常见需求。下面将详细介绍如何实现这一目标,包括将Samba服务器加入Active Directory域,以及让UNIX/Linux客户端使用Windows网络凭证进行登录。 1. Samba-3服务器加…

作者头像 李华
网站建设 2026/4/16 10:56:26

为什么你的 TikTok 达人合作效率低?问题往往不在达人身上

在 TikTok 达人营销这条路上,很多跨境团队都会经历一个阶段:达人越找越多,私信越发越勤,样品寄出去不少,但整体转化却始终不稳定。于是大家开始怀疑达人质量,甚至怀疑平台环境、产品本身。 但在真实复盘中你…

作者头像 李华
网站建设 2026/4/16 12:53:14

Linly-Talker能否挑战Synthesia?开源数字人实战解析

Linly-Talker能否挑战Synthesia?开源数字人实战解析 在电商客服页面上,一个穿着职业装的虚拟助手微笑着向你问好:“您好,请问有什么可以帮您?”她不仅对答如流,语调亲切自然,连唇形都与声音完美…

作者头像 李华
网站建设 2026/4/16 10:07:53

文件粉碎神器,彻底粉碎文件防恢复,数据安全拉满!

下载:https://tool.nineya.com/s/1jbp8f584 在日常电脑使用中,我们时常会有一些极为重要的文件,删除时生怕信息泄露,普通删除又担心被恢复。 今天就给大家带来一款超给力的文件粉碎机 ——RainCrack。别看它身形小巧&#xff0c…

作者头像 李华
网站建设 2026/4/16 10:16:41

YOLO模型如何实现多语言标签输出?

YOLO模型如何实现多语言标签输出? 在智能制造工厂的监控中心,一张来自德国产线的实时画面正被分析:屏幕上,“Person”“Fahrzeug”“Fahrrad”等德文标签清晰标注着检测到的对象。而在地球另一端的中国分公司,同一套系…

作者头像 李华