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

自己用钢管做里闪弹枪视频和照网站什么叫软文推广

自己用钢管做里闪弹枪视频和照网站,什么叫软文推广,如何调用wordpress函数,调用wordpress文章文章目录 1. 前言2. 原理3. 代码实现 1. 前言 在检测图像中的目标时,一个目标可能会被预测出多个矩形框,而实际上我们只需要一个,如何消除冗余的边界框呢?一种方简单的方案是提升置信度的阈值,过滤掉低置信度的边界框…

文章目录

    • 1. 前言
    • 2. 原理
    • 3. 代码实现

1. 前言

在检测图像中的目标时,一个目标可能会被预测出多个矩形框,而实际上我们只需要一个,如何消除冗余的边界框呢?一种方简单的方案是提升置信度的阈值,过滤掉低置信度的边界框。而另一种方案是使用非极大值抑制NMS。NMS的做法是,选出某个类别得分最高的预测框,然后看哪些预测框跟它的IoU大于阈值,就把这些预测框给丢弃掉。这里IoU的阈值是超参数,需要提前设置。

2. 原理

在二分类的场景下:

  • 根据置信度得分进行排序
  • 选择置信度最高的边界框添加到最终输出列表中,将其从边界框列表中删除
  • 计算剩余边界框与输出列表中的边界框的IoU (IoU原理)
  • 从边界框列表中删除IoU大于阈值的边界框,把小于阈值的边界框追加到输出列表中
  • 重复上述过程,直至边界框列表为空

假设模型输出了11个预测框boxes, 以及对应的置信度scores:

Step0 创建选中列表,keep_list = []

Step1 对置信度进行排序,得到降序排序后边界框的索引位置列表remain_list = [ 3, 5, 10, 2, 9, 0, 1,
6, 4, 7, 8]

Step2 选出boxes[3],此时keep_list为空,不需要计算IoU,直接将其放入keep_list,keep_list =
[3], remain_list=[5, 10, 2, 9, 0, 1, 6, 4, 7, 8]

Step3 选出boxes[5],此时keep_list中已经存在boxes[3],计算出IoU(boxes[3], boxes[5]) =
0.0,显然小于阈值,则keep_list=[3, 5], remain_list = [10, 2, 9, 0, 1, 6, 4, 7, 8]

Step4 选出boxes[10],此时keep_list=[3, 5],计算IoU(boxes[3],
boxes[10])=0.0268,IoU(boxes[5], boxes[10])=0.0268 =
0.24,都小于阈值,则keep_list = [3, 5, 10],remain_list=[2, 9, 0, 1, 6, 4, 7, 8]

Step5 选出boxes[2],此时keep_list = [3, 5, 10],计算IoU(boxes[3], boxes[2]) =
0.88,超过了阈值,直接将boxes[2]丢弃,keep_list=[3, 5, 10],remain_list=[9, 0, 1, 6, 4, 7, 8]

Step6 选出boxes[9],此时keep_list = [3, 5, 10],计算IoU(boxes[3], boxes[9]) =
0.0577,IoU(boxes[5], boxes[9]) = 0.205,IoU(boxes[10], boxes[9]) = 0.88,超过了阈值,将boxes[9]丢弃掉。keep_list=[3, 5, 10],remain_list=[0, 1, 6, 4, 7, 8]

Step7 重复上述Step6直到remain_list为空

最终得到keep_list=[3, 5, 10],也就是预测框3、5、10被最终挑选出来了

在多分类的场景下,其实现与二分类的实现原理相同,区别在于需要对每个类别都做非极大值抑制

3. 代码实现

(1)二分类场景下:

# 非极大值抑制
def nms(bboxes, scores, score_thresh, nms_thresh, pre_nms_topk, i=0, c=0):"""nms"""# 置信度排序,结果降序排列,返回对应的索引inds = np.argsort(scores)inds = inds[::-1]# 输出列表keep_inds = []while(len(inds) > 0):# 每次遍历,从边界框列表中拿出一个框,默认从第一个开始处理cur_ind = inds[0]cur_score = scores[cur_ind]if cur_score < score_thresh:breakkeep = Truefor ind in keep_inds:current_box = bboxes[cur_ind]remain_box = bboxes[ind]iou = box_iou_xyxy(current_box, remain_box)# 过滤大于IoU阈值的边界框if iou > nms_thresh:keep = Falsebreakif keep:keep_inds.append(cur_ind)# 从边界框列表中删除已经处理过的框,因为每次都是从第一个框开始处理,因此把0索引的框删掉inds = inds[1:]return np.array(keep_inds)

(2)多分类场景下:

def multiclass_nms(bboxes, scores, score_thresh=0.01, nms_thresh=0.45, pre_nms_topk=1000, pos_nms_topk=100):batch_size = bboxes.shape[0]class_num = scores.shape[1]rets = []for i in range(batch_size):bboxes_i = bboxes[i]scores_i = scores[i]ret = []#对每一个类别单独做非极大值抑制for c in range(class_num):scores_i_c = scores_i[c]keep_inds = nms(bboxes_i, scores_i_c, score_thresh, nms_thresh, pre_nms_topk, i=i, c=c)if len(keep_inds) < 1:continuekeep_bboxes = bboxes_i[keep_inds]keep_scores = scores_i_c[keep_inds]keep_results = np.zeros([keep_scores.shape[0], 6])keep_results[:, 0] = ckeep_results[:, 1] = keep_scores[:]keep_results[:, 2:6] = keep_bboxes[:, :]ret.append(keep_results)if len(ret) < 1:rets.append(ret)continueret_i = np.concatenate(ret, axis=0)scores_i = ret_i[:, 1]if len(scores_i) > pos_nms_topk:inds = np.argsort(scores_i)[::-1]inds = inds[:pos_nms_topk]ret_i = ret_i[inds]rets.append(ret_i)return rets
http://www.yayakq.cn/news/740234/

相关文章:

  • 做外贸的人常用的网站建设网站的多少钱
  • 做产品类网站有哪些企业网站开发前台模块设计
  • 如何查看网站备案国际重大新闻
  • 叮当网站做appseo上海培训
  • frontpage制作个人网站 技巧公司网站域名是什么意思
  • 北京建设专职查询网站做本地网站
  • 北京建设部网站官网昆山网站建设书生商友
  • 宁夏住房建设厅网站网站1996年推广
  • nodejs 做网站js交件广州网站开发设计
  • 太原网站关键词优化免费网页设计
  • 做网站的前途怎么样拔萝卜在线视频免费观看
  • 如何制作网站图片个人网站备注
  • 个人备案网站改企业备案泰安市人才交流服务中心
  • app网站模板下载不了wordpress auto
  • 学校网站建设栏目有哪些怎么做微课网站
  • 东莞石碣网站建设城乡住房建设部网站造价师网
  • 揭阳网站制作企业微信网站开发工具
  • 网站开发终止协议书建网站企业
  • 啊里网站制作360搜索引擎的特点
  • 海口网站建设设计西安网站制作顶尖
  • 建站宝盒如何使用设计建立企业网站最佳的公司
  • 网站响应是什么问题吗wordpress字体哪个好看
  • 室内设计网站链友之家
  • 介绍网站设计风格dw做网站简单首页
  • 网站开发常用软件网站是否降权查询
  • 哪个网站做淘宝客最合适鹤壁网站建设鹤壁
  • 个人建设网站程序网站建设需求文件
  • 承德网站建设价格自己搭建环境建设网站
  • 找活做的网站济南网站建设维护
  • 长沙网站制作费用百度top风云榜