目标检测中几个算法的正负样本划分策略

参考:
yolov5与Faster-RCNN 训练过程正负样本和评价指标 https://blog.csdn.net/norman_sen/article/details/121975655
目标检测: 一文读懂 YOLOV5 Loss 正样本采样 https://blog.csdn.net/weixin_46142822/article/details/123820031
目标检测正负样本区分策略和平衡策略总结(一) https://zhuanlan.zhihu.com/p/138824387
faster rcnn中RPN和后面分类器正负样本的设定? https://www.zhihu.com/question/265171400
关于 Faster RCNN正负样本选取的问题 https://blog.csdn.net/qq_34945661/article/details/120589053


Faster-RCNN, RetinaNet, EfficientDet
positive_thres
negative_thres

RPN:
negative_thres=0.3, positive_thres=0.7
1.GT从所有anchors中找到与之有最大iou的那个anchor, 为正样本
1.与某个GT的iou超过positive_thres的anchor为正样本, 负责iou最大的GT
2.与所有GT的最大iou低于negative_thres的anchor为负样本
4.与所有GT的最大iou在negative_thres~positive_thres之间的anchor被忽略
5.为了解决正负样本不平衡, 随机选择256个anchors参与训练, 其中正负样本比例1:1. 如果正样本小于128, 负样本数量就算256-128
RPN总anchors数量: (H/16)*(W/16)*9~20000

RCNN:
negative_thres=0.5, positive_thres=0.5
1.从RPN输出的anchors(大概2000个), 与某个GT的iou超过positive_thres的anchor为正样本, 负责iou最大的GT
2.剩下的anchors是负样本
3.正样本大概选取32个, 负样本大概选取96个, 正负样本比例1:3

RetinaNet:
negative_thres=0.4, positive_thres=0.5
参照RPN, 没有5

EfficientDet:
与RetinaNet一样?


SSD
default box=anchor
1.GT从所有的default boxes找到与之有最大iou的那个box, 作为正样本
2.default boxes与GT的iou超过阈值(0.5), 作为正样本
3.(Hard negative mining): 剩余的default boxes, 按照confidence loss排序, 选择topN个作为负样本, 使得负样本:正样本=3:1
每个gt一定至少匹配1个default box, 并且可能和多个default boxes匹配,


YOLOv2, YOLOv3
1.确定GT落在那个cell, 计算这个cell的anchor与GT的iou, 计算时只考虑wh(因为anchor没有xy坐标信息)
2.与GT有最大iou的anchor作为正样本, 这样使得每个GT一定有唯一的anchor对应
3.对于正样本以外的样本, 与GT的iou大于阈值(0.7)的anchor被忽略, 这个iou是每个位置的anchor预测值和所有GT计算的
4.多尺度预测, 根据max iou原则会将GT分配到不同的预测层, 然后在每个层上单独计算正负样本)
 

YOLOv5
(待补充)


采样名词
OHEM(online hard example mining)
Hard negative mining(SSD)








 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
根据引用提到的,小目标的检测性能差主要是由于网络模型的局限性和训练数据集的不平衡所成的。同时,引用也指出了小目标存在分辨率低的问题,可视化信息少,难以提取到具有鉴别力的特征,并且易受到环境因素的干扰。 在小目标检测正负样本的定义是非常重要的。根据引用提到的问题,现有的Anchor设计难以获得平衡小目标召回率与计算成本之间的矛盾。这意味着设计的锚框可能会过大,导致小目标无法被正确定位,或者过小,导致没有足够的正样本。这种情况下,正样本与负样本的比例可能会极度不均衡,使得模型更加关注于大目标的检测性能,而忽视了小目标的检测。 为了解决这个问题,研究人员开始探索无Anchor的机制。无Anchor的方法主要有两种。这些方法通过在特征层上应用不同的检测策略,来避免传统的Anchor设计所带来的问题。这些方法可以通过在特征层上进行密集的特征提取,以捕获小目标的更多信息,并且无需预定义的锚框。这样可以有效地平衡小目标与大目标之间的检测性能,并提高小目标的检测准确率。 综上所述,在弱小目标检测正负样本的定义是根据目标的尺寸和分辨率来确定的。在无Anchor的方法,为了保证对小目标的有效检测,采用了一种密集的特征提取策略,以提高小目标的检测性能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [MATLAB算法实战应用案例精讲-【图像处理】小目标检测(附matlab代码实现)](https://blog.csdn.net/qq_36130719/article/details/128676075)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值