检测评价函数 intersection-over-union ( IOU )

本文详细介绍了IoU(交并比)的概念及其在目标检测任务中的作用,并提供了直观的示例图来帮助理解。此外,还给出了一个用于计算IoU的Python函数实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、概念

在目标检测的评价体系中,有一个参数叫做 IoU ,简单来讲就是模型产生的目标窗口和原来标记窗口的交叠率。具体我们可以简单的理解为: 即检测结果(DetectionResult)Ground Truth 的交集比上它们的并集,即为检测的准确率 IoU :

IOU=DetectionResultGroundTruthDetectionResultGroundTruthIOU=DetectionResult⋂GroundTruthDetectionResult⋃GroundTruth

如下图所示:GT = GroundTruth; DR = DetectionResult;
黄色边框框起来的是:

GTDRGT⋂DR

绿色框框起来的是:
GTDRGT⋃DR

应该够详细了,上幅图直观些。当然最理想的情况就是 DR 与 GT 完全重合,即

IoU=1IoU=1

下面附上图例说明,及 IOU 的python实现,已经测试无误,自行取用。

这里写图片描述

原图:
这里写图片描述

# -*- coding: utf-8 -*-
"""
Created on Sun Aug 07 14:26:51 2016

@author: Eddy_zheng
"""

def IOU(Reframe,GTframe):
    """
    自定义函数,计算两矩形 IOU,传入为均为矩形对角线,(x,y)  坐标。
    """
    x1 = Reframe[0]
    y1 = Reframe[1]
    width1 = Reframe[2]-Reframe[0]
    height1 = Reframe[3]-Reframe[1]

    x2 = GTframe[0]
    y2 = GTframe[1]
    width2 = GTframe[2]-GTframe[0]
    height2 = GTframe[3]-GTframe[1]

    endx = max(x1+width1,x2+width2)
    startx = min(x1,x2)
    width = width1+width2-(endx-startx)

    endy = max(y1+height1,y2+height2)
    starty = min(y1,y2)
    height = height1+height2-(endy-starty)

    if width <=0 or height <= 0:
        ratio = 0 # 重叠率为 0 
    else:
        Area = width*height # 两矩形相交面积
        Area1 = width1*height1
        Area2 = width2*height2
        ratio = Area*1./(Area1+Area2-Area)
    # return IOU
    return ratio,Reframe,GTframe
### Alpha-IoU 损失函数概述 Alpha-IoU (Intersection over Union) 是一种用于提高目标检测精度的损失函数,在传统 IoU 基础上进行了改进。该损失函数旨在解决标准 CIOU 和 GIOU 存在的一些局限性,特别是在处理不同尺度的目标时表现更优[^2]。 ### Alpha-IoU 的特点 Alpha-IoU 主要具有以下几个特性: - **自适应调整**:通过引入参数 α 来动态调节边界框回归的方向和力度。 - **多尺度鲁棒性**:对于大小不同的物体都能保持良好的收敛性和稳定性。 - **增强泛化能力**:不仅提高了模型对训练集的学习效率,也增强了其对外部数据集的预测准确性[^3]。 ### 实现细节 为了实现 Alpha-IoU 损失函数,通常会在现有的框架基础上进行扩展。以下是 Python 中的一个简单示例代码片段展示如何计算两个矩形之间的 Alpha-IoU: ```python import torch def alpha_iou(pred_boxes, target_boxes, alpha=0.5): """ 计算 pred_boxes 与 target_boxes 之间 Alpha-IoU 参数: pred_boxes: 预测边框 Tensor 形状为 [N, 4], 其中 N 表示样本数量. 边框格式应为 [cx, cy, w, h]. target_boxes: 目标边框 Tensor 同样形状为 [N, 4]. 边框格式同样为 [cx, cy, w, h]. alpha: 调节因子,默认值设为 0.5 返回: ious: 所有配对间的 Alpha-IoU 结果 Tensor 形状为 [N] """ # 获取中心坐标差绝对值 |c_x1 - c_x2| 及宽度高度之和 s_w = w1 + w2, s_h = h1 + h2 center_diffs = torch.abs(pred_boxes[:, :2] - target_boxes[:, :2]) sum_sizes = pred_boxes[:, 2:] + target_boxes[:, 2:] # 计算交并比IoU以及额外项E(alpha) inter_wh = torch.max(sum_sizes / 2 - center_diffs, torch.zeros_like(center_diffs)) intersection_area = inter_wh.prod(dim=-1) union_areas = pred_boxes[:, 2:].prod(-1) + \ target_boxes[:, 2:].prod(-1) - intersection_area ious = intersection_area / union_areas.clamp(min=1e-7) e_alpha = ((center_diffs.pow(2).sum(-1)) / (((pred_boxes[:, 2:] * target_boxes[:, 2:]).sqrt().sum(-1)).pow(2))).pow(alpha) return ious - e_alpha ``` 此段代码展示了如何定义 `alpha_iou` 函数来衡量预测框 (`pred_boxes`) 和真实标签框 (`target_boxes`) 间的关系,并返回它们各自的 Alpha-IoU 得分。注意这里使用了 PyTorch 库来进行张量运算操作。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值