当前位置: 首页 > wzjs >正文

网站建设的创意微网站生成app

网站建设的创意,微网站生成app,红色扁平化网站,评价一个网站✅ YOLO获取COCO指标(3):验证(Val) 启用 COCO API 评估(自动输出AP指标)| 发论文必看! | Ultralytics | 小白友好 文章目录 一、问题定位二、原理分析三、解决方案与实践案例步骤 1: 触发 COCO JSON 保存步骤 2: 确保 self.is_coc…

✅ YOLO获取COCO指标(3):验证(Val) 启用 COCO API 评估(自动输出AP指标)| 发论文必看! | Ultralytics | 小白友好

文章目录

    • 一、问题定位
    • 二、原理分析
    • 三、解决方案与实践案例
      • 步骤 1: 触发 COCO JSON 保存
      • 步骤 2: 确保 `self.is_coco` 条件满足 (或理解其影响)
      • 步骤 3: 确保 Ground Truth JSON 文件路径正确
      • 步骤 4: (关键) 调整自定义数据集的类别映射
      • 步骤 5: (可选) 调整图像 ID 处理
    • 四、总结与展望
    • 参考文献:

重要说明: 本篇博客内容基于 YOLOv12 进行演示,但其核心原理和配置方法适用于所有基于 Ultralytics 框架开发的 YOLO 版本。在应用代码修改时,请注意核对你所使用的具体 Ultralytics 库版本中的文件路径和代码行号。

一、问题定位

在使用 Ultralytics YOLO 框架训练自定义目标检测数据集后,开发者通常希望在验证(Validation)阶段就能直接获取业界标准的 COCO 评估指标(尤其是 mAP)。然而,直接调用 model.val() 方法,即使数据集标注已转换为 COCO 格式,也未必能自动触发 COCO API 进行评估并输出结果。本文旨在解决这一问题,详细阐述如何通过正确配置和少量代码调整,在 model.val() 过程中无缝集成 COCO API 评估。

二、原理分析

Ultralytics YOLO 的 ultralytics/models/yolo/detect/val.py 脚本内置了使用 pycocotools (官方 COCO API) 进行评估的逻辑。该逻辑的触发和正确执行依赖于以下几个关键条件:

  1. 触发评估: 需要显式告知 model.val() 保存预测结果为 COCO JSON 格式,这是调用 COCO API 的前提。
  2. 数据集识别: 脚本需要判断当前验证的数据集是否为“COCO 类型”,以便加载对应的 COCO 格式 Ground Truth 标注文件。这通常基于数据集配置文件 (.yaml) 中的路径约定。
  3. 标注文件定位: 脚本需要根据约定的目录结构找到 COCO 格式的 Ground Truth JSON 文件 (如 instances_val2017.json)。
  4. 类别映射 (Class Mapping): 对于标准 COCO 数据集,代码默认会应用一个从 COCO 80 类到 COCO 91 类的映射。对于自定义数据集,这个映射通常是不必要的,甚至是有害的。
  5. 图像 ID 匹配: COCO API 评估时需要匹配预测结果和 Ground Truth 中的图像 ID。默认实现可能假设图像文件名是符合 COCO 规范的数字 ID。

当使用自定义数据集时,即使标注格式符合 COCO 标准,上述第 2、3、4、5 点的默认逻辑可能与用户的实际设置或数据情况不符,导致 COCO API 评估流程中断或出错。

三、解决方案与实践案例

以下步骤详细说明了如何在调用 model.val() 时成功启用 COCO API 评估。

步骤 1: 触发 COCO JSON 保存

在调用 model.val() 方法时,必须将参数 save_json 设置为 True。这会指示框架将模型的预测结果保存为 COCO 评估工具所需的 JSON 文件格式。

# --- 代码示例:调用 model.val() 并启用 save_json ---from ultralytics import YOLO				# 导入 YOLO 类# 加载模型
model = YOLO('path/to/your/best.pt') 		# 模型路径# 调用验证方法
metrics = model.val(# ... 其他训练参数 ...save_json=True,          				# 关键:设置为 True 以便后续调用 COCO API# ... 其他训练参数 ...
)

步骤 2: 确保 self.is_coco 条件满足 (或理解其影响)

ultralytics/models/yolo/detect/val.py 文件中,有一个 self.is_coco 标志位,它的设置决定了是否按 COCO 模式加载标注和执行评估。(注意:以下代码路径和行号基于文档提供的特定版本,请参考你使用的 Ultralytics 版本)

  • 代码位置 (仅供参考,请核对你的版本): ultralytics/models/yolo/detect/val.py L71 附近
# --- val.py 中 is_coco 的判断逻辑示例 (仅供理解) ---
# self.is_coco 通常基于 YAML 文件中 'val' 字段的路径字符串判断
# 它期望路径中包含 "coco" 并且以特定的文件名结尾 (如 val2017.txt)
self.is_coco = (isinstance(val, str) # val 是 YAML 中 'val' 键对应的值and "coco" in val    # 路径字符串需包含 "coco"# 并且以 /val2017.txt 或 /test-dev2017.txt 结尾and (val.endswith(f"{os.sep}val2017.txt") or val.endswith(f"{os.sep}test-dev2017.txt"))
)
  • 配置建议: 为了满足这个条件,你需要在你的数据集配置文件 (.yaml) 中,将 val 指向一个符合上述约定的路径。

    • 示例 YAML (PCB_COCO.yaml) 配置:

      path: E:/project/YOLOv12/dataset/PCB_DATASET # 数据集根目录
      train: train.txt # 训练集索引文件 (相对于 path)
      # 关键:val 路径需要满足 is_coco 的判断逻辑
      # 例如,创建一个名为 coco 的子目录,并在其中放置 val2017.txt
      val: coco/val2017.txt # 验证集索引文件 (相对于 path)
      test: # 测试集 (可选)names: # 你的类别名称列表0: class_01: class_1# ...
      
    • 文件结构建议 (对应 YAML):

      E:/project/YOLOv12/dataset/PCB_DATASET/
      ├── coco/
      │   └── val2017.txt  # 里面是验证集图片路径列表
      ├── train.txt
      └── # ... 其他文件和目录 (如 images, labels, annotations)
      

步骤 3: 确保 Ground Truth JSON 文件路径正确

val.py 会根据 self.data["path"] (即 YAML 文件中的 path) 和 self.is_coco 的状态来构建 Ground Truth JSON 文件的预期路径。

  • 代码位置 (仅供参考): ultralytics/models/yolo/detect/val.py L301 附近
# --- val.py 中 anno_json 的路径构建逻辑示例 ---
# 如果 is_coco 为 True,则期望的 JSON 文件是 'instances_val2017.json'
# 如果是 LVIS 数据集,则是 lvis_v1_{split}.json
anno_json = (self.data["path"] # 来自 YAML 的 'path'/ "annotations"    # 固定的 'annotations' 子目录/ ("instances_val2017.json" if self.is_coco else f"lvis_v1_{self.args.split}.json")
)
  • 配置建议: 确保你的 COCO 格式标注 JSON 文件(包含所有验证集图片的 Ground Truth)放置在 <数据集根目录>/annotations/instances_val2017.json
    示例路径: E:/project/YOLOv12/dataset/PCB_DATASET/annotations/instances_val2017.json

步骤 4: (关键) 调整自定义数据集的类别映射

对于自定义数据集,默认的 COCO 80 到 91 类映射 (coco80_to_coco91_class()) 是不适用的。需要注释掉这行代码,让 self.class_map 使用从 1 开始的连续整数,对应你模型 names 列表中的类别。

  • 代码位置 (仅供参考): ultralytics/models/yolo/detect/val.py L77 附近
# --- val.py 中 class_map 的修改 ---
# 原代码 (需要注释掉或修改条件)
# self.class_map = converter.coco80_to_coco91_class() if self.is_coco else list(range(1, len(model.names) + 1))# 修改后:无论 is_coco 如何,都使用模型自身的类别数生成从 1 开始的映射
# (注意:COCO API 的类别 ID 通常从 1 开始)
self.class_map = list(range(1, len(model.names) + 1)) # 直接使用模型类别生成映射
  • 修改说明: 这个修改确保了评估时使用的类别 ID 与你的模型和标注文件中的类别 ID 一致(假设你的 COCO JSON 中类别 ID 也是从 1 开始,如果不是,则需要相应调整这里的映射或你的 JSON 文件)。

步骤 5: (可选) 调整图像 ID 处理

默认实现可能假设验证集图片的文件名是数字 (如 000000123456.jpg),并以此作为 COCO API 评估时的图像 ID。如果你的文件名不是这种格式,可能会导致匹配失败。在这种情况下,需要注释掉相关代码。

  • 代码位置 (仅供参考): ultralytics/models/yolo/detect/val.py L325 附近
# --- val.py 中 imgIds 的处理 (如果需要修改) ---
# 如果你的验证集图片文件名不是纯数字 ID (如 'img_001.jpg'),
# 下面这行代码可能会出错或导致 ID 不匹配,可以考虑注释掉
# val.params.imgIds = [int(Path(x).stem) for x in self.dataloader.dataset.im_files]
  • 修改说明: 注释掉此行后,评估时可能会依赖于 COCO JSON 文件中提供的图像 ID。确保你的 predictions.jsoninstances_val2017.json 中的 image_id 能够对应上。

四、总结与展望

通过以上配置和代码调整(主要是 save_json=True 参数,满足 is_coco 的路径约定,确保 anno_json 路径正确,以及为自定义数据集修改 class_map),你可以在 Ultralytics YOLO 的 model.val() 流程中成功启用 COCO API,自动计算并获取标准的 mAP 等评估指标。

关键要点回顾:

  1. 调用 model.val() 时设置 save_json=True
  2. 确保数据集 YAML 文件中的 val 路径符合 is_coco 判断约定(或理解其逻辑并适配)。
  3. 确保 Ground Truth COCO JSON 文件位于 path/annotations/instances_val2017.json
  4. 对于自定义数据集,务必修改 val.py 中的 self.class_map 逻辑,避免错误的 COCO 类别映射。
  5. 根据需要,可能要注释掉 val.params.imgIds 的默认生成逻辑。

参考文献:

  • Ultralytics YOLO 官方文档:
    • model.val() API 文档: https://docs.ultralytics.com/modes/val/ (请查找对应版本的文档)
    • 数据集配置 (.yaml) 文档: https://docs.ultralytics.com/datasets/
  • COCO Dataset 官网: https://cocodataset.org/#detection-eval (了解 COCO 评估指标定义)
  • pycocotools GitHub Repository: https://github.com/cocodataset/cocoapi (COCO API 官方库)

文章转载自:

http://2zd3o2qm.Lmrcq.cn
http://ilwLyyYZ.Lmrcq.cn
http://o4aMEZkY.Lmrcq.cn
http://n6uSlHIE.Lmrcq.cn
http://c7pIza1I.Lmrcq.cn
http://L5pfDsth.Lmrcq.cn
http://TSCz3aoM.Lmrcq.cn
http://bmsisoOt.Lmrcq.cn
http://cA951x8u.Lmrcq.cn
http://fOjT8Wpp.Lmrcq.cn
http://Y8wsz5pn.Lmrcq.cn
http://TZ7ZS2VF.Lmrcq.cn
http://4OCcsGHk.Lmrcq.cn
http://91boOI4g.Lmrcq.cn
http://QMV9u1AN.Lmrcq.cn
http://3jjUvD1v.Lmrcq.cn
http://ePv2DchH.Lmrcq.cn
http://pblfhFoN.Lmrcq.cn
http://0Y26iI1a.Lmrcq.cn
http://NgWRBA4Y.Lmrcq.cn
http://uqB2pWug.Lmrcq.cn
http://F3AgmNn0.Lmrcq.cn
http://WkwA8lH0.Lmrcq.cn
http://BKX3SjQh.Lmrcq.cn
http://gtuBVfYe.Lmrcq.cn
http://q29cAuaw.Lmrcq.cn
http://5fTxDvHg.Lmrcq.cn
http://2rfHtcLv.Lmrcq.cn
http://Ur1Bdfn4.Lmrcq.cn
http://Or4gZrTc.Lmrcq.cn
http://www.dtcms.com/wzjs/672297.html

相关文章:

  • 专业的移动网站建设公司广东建设部官方网站
  • 可以在自己家做外卖的网站中国商品价格网
  • 东莞企业网站找谁wordpress的主题是什么
  • 查询网站的二级域名深圳企业网站设计
  • 百度网站 收录如何在网上宣传
  • wap多用户网站个人网站的设计与建设论文
  • 成都企业网站建设费用金华规划局网站开发区
  • wordpres做影视网站内容聚合网站开发教程
  • 电商网站seo优化济南网络科技有限公司有哪些
  • 少儿类网站怎么做深圳网络推广服务公司
  • 无锡集团网站建设深圳网站建设骏域网站建设
  • c 网站开发工程师招聘通化建设工程信息网站
  • vps 上传网站杭州网站建设网络
  • 个人建个网站需要多少钱网站的功能规范
  • 营销网站建设教程福建省中嘉建设工程有限公司网站
  • 1 高端品牌网站定制店铺装修模板
  • 网站建设方案设计wordpress new图标
  • 用vs2013做网站登录net的网站建设
  • 贵阳市网站开发单位邮箱一般用什么邮箱
  • 纯静态网站怎么做cdnwordpress转发查看
  • 株洲网站制作锡盟建设工程网站
  • 网站参考页面设计米拓cms建站系统
  • 宁波网站关键词优化公司九天传说超变单职业传奇页游
  • 自己的网站怎么做青羊建站报价
  • 网站建设要做固定资产吗中石化石油工程建设公司官方网站
  • 网站logo如何替换城乡住房和城乡建设部网站首页
  • 做网站必须有站点吗做一个小程序商城需要多少钱
  • 网站设计的留言怎么做wordpress音频
  • 东营本地网站有哪些泉州握旗公司网站建设
  • 网站建设误区yusi wordpress