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

赣州做网站什么价格杭州百度推广公司有几家

赣州做网站什么价格,杭州百度推广公司有几家,呼伦贝尔北京网站建设,四川省住房和城乡建设厅网站打不开文章目录 前言一、NMS是什么?二、代码展示三、代码实现思路总结 前言 目标检测模型推理后,一般都需要进行NMS操作进行多余框去重,板端部署一般不用opencv自带的NMS,所以记录下手写NMS的代码。 一、NMS是什么? 非极大…

文章目录

  • 前言
  • 一、NMS是什么?
  • 二、代码展示
  • 三、代码实现思路
  • 总结


前言

目标检测模型推理后,一般都需要进行NMS操作进行多余框去重,板端部署一般不用opencv自带的NMS,所以记录下手写NMS的代码。


一、NMS是什么?

非极大值抑制(Non-Maximum Suppression,NMS)算法,用于在一组边界框(BoundingBoxes)中去除高度重叠的边界框,只保留最具代表性的一个。

二、代码展示

#include <iostream>
#include <vector>
#include <algorithm>// 边界框结构
struct BoundingBox {float x, y, w, h, confidence;// 计算边界框的面积float area() const {return w * h;}
};// 计算两个边界框之间的IoU
float iou(const BoundingBox& a, const BoundingBox& b) {const float area_a = a.area();const float area_b = b.area();// 计算重叠区域的坐标范围const float x1 = std::max(a.x, b.x);const float y1 = std::max(a.y, b.y);const float x2 = std::min(a.x + a.w, b.x + b.w);const float y2 = std::min(a.y + a.h, b.y + b.h);// 计算重叠区域的面积const float intersection_area = std::max(0.0f, x2 - x1) * std::max(0.0f, y2 - y1);// 计算并集区域的面积const float union_area = area_a + area_b - intersection_area;// 计算IoUreturn union_area > 0 ? intersection_area / union_area : 0;
}// 非极大值抑制函数
std::vector<BoundingBox> nms(std::vector<BoundingBox>& boxes, float threshold) {// 根据置信度排序std::sort(boxes.begin(), boxes.end(),[](const BoundingBox& a, const BoundingBox& b) { return a.confidence > b.confidence; });std::vector<BoundingBox> result;for (size_t i = 0; i < boxes.size(); ++i) {bool keep = true;for (size_t j = 0; j < result.size(); ++j) {if (iou(boxes[i], result[j]) > threshold) {keep = false;break;}}if (keep) {result.push_back(boxes[i]);}}return result;
}int main() {std::vector<BoundingBox> boxes;// 添加一些示例边界框数据boxes.push_back({10, 10, 20, 20, 0.9});boxes.push_back({15, 15, 25, 25, 0.8});boxes.push_back({30, 30, 20, 20, 0.7});boxes.push_back({40, 40, 15, 15, 0.85});// 运行非极大值抑制算法,保留不重叠的边界框float threshold = 0.5;std::vector<BoundingBox> result = nms(boxes, threshold);// 输出保留下来的边界框std::cout << "保留的边界框:" << std::endl;for (const BoundingBox& box : result) {std::cout << "x: " << box.x << ", y: " << box.y << ", w: " << box.w << ", h: " << box.h << ", confidence: " << box.confidence << std::endl;}return 0;
}

三、代码实现思路

iou(const BoundingBox& a, const BoundingBox& b): 这个函数计算两个边界框a和b之间的交并比(IoU,Intersection over Union)。它首先计算每个边界框的面积,然后计算它们的交集区域的坐标范围和面积。最后,它将交集区域的面积除以并集区域的面积,得到IoU值,即重叠度。

nms(std::vector<BoundingBox>& boxes, float threshold): 这个函数实现了非极大值抑制算法。它接受一个包含边界框的向量 boxes 和一个阈值 threshold 作为参数。首先,它按照边界框的置信度(confidence)对边界框进行降序排序,以便首先处理置信度最高的边界框。

然后,它遍历每个边界框,并检查它是否应该被保留。对于每个边界框,它将其与已经被保留的边界框进行比较,计算它们之间的IoU。如果IoU大于阈值 threshold,则说明两个边界框高度重叠,当前边界框不被保留;否则,当前边界框被保留。

最终,函数返回一个向量 result,其中包含经过非极大值抑制后被保留下来的边界框。


总结

NMS通常用于目标检测中,以去除重叠的检测结果,只保留最具代表性的结果,以提高检测的准确性。
如果阅读本文对你有用,欢迎点赞收藏呀!!!
2023年9月27日15:58:10
在这里插入图片描述

http://www.wangmingla.cn/news/130168.html

相关文章:

  • seo网站收录工具网站查找工具
  • js怎么做网站杭州seo搜索引擎优化
  • 怎么用wordpress建站百度竞价排名广告
  • 南阳网站建站培训十大计算机培训学校
  • 有一个箭头的做网站的软件优化大师电脑版官方免费下载
  • as3 xml 网站模板 下载百度推广和优化哪个好
  • 怎么做网站盈利百度云网盘网页版登录
  • 做网站条件四川旅游seo整站优化
  • 做网站推广如何产品推广网站哪个好
  • 个人怎么注册小型公司seo网站建站
  • 怎么注册免费网站百度竞价登陆
  • 青岛网站seo公司单页网站制作教程
  • 做网站 设备网站免费搭建
  • 网站悬浮qqapp开发教程
  • 做优惠卷网站电脑培训学校能学什么
  • 便宜营销型网站建设优化建站怎么提高关键词搜索权重
  • 网站导航的建设模板推广普通话的文字内容
  • 石家庄网站定制开发广州网络推广万企在线
  • 做网站发布网百度广告收费标准
  • 建设委员会的网站企业在线培训系统
  • 武汉网站改版维护企业网站建站
  • wordpress 百度云加速淘宝seo关键词的获取方法有哪些
  • 唐山网站建设哪家优惠免费搭建个人网站
  • 用php做的网站前后台模板长沙本地推广
  • 一起做网站吧足球比赛今日最新推荐
  • html5 网站框架英文seo外链
  • 南昌做网站的公司哪家好google seo怎么做
  • 如何做网络集资网站网站市场推广
  • 架设网站需要什么河北seo平台
  • 呼和浩特市网站公司电话百度登录个人中心