在对象检测文献中,通常使用分类器和滑动窗口方法来检测图像中对象的存在,该方法返回一组检测窗口,并使用非极大值抑制解决检测重叠。
有人可以解释在这些检测窗口上执行非最大抑制的算法吗?
谢谢
在对象检测文献中,通常使用分类器和滑动窗口方法来检测图像中对象的存在,该方法返回一组检测窗口,并使用非极大值抑制解决检测重叠。
有人可以解释在这些检测窗口上执行非最大抑制的算法吗?
谢谢
引自http://www.di.ens.fr/willow/events/cvml2012/materials/practical-detection/
图像块的扫描窗口式分类通常会导致目标对象周围的多个响应。处理此问题的标准做法是使用局部最大置信度分数(非最大值抑制或 NMS)移除检测附近的任何检测器响应。NMS 通常应用于图像中置信度高于某个阈值的所有检测。在不同的阈值和不同的图像中尝试 NMS 人脸检测:
也在这里http://www.ens-lyon.fr/LIP/Arenaire/ERVision/detection_exercise_solution.m你可以找到一个 matlab 程序,它可以做所有事情 - 检测窗口上的检测和 NMS
对检测窗口进行非最大抑制的代码是
%%%%%%%%%%%%%%% **************************************************************
%%%%%%%%%%%%%%% **************************************************************
%%%%%%%%%%%%%%% * *
%%%%%%%%%%%%%%% * EXERCISE 3: *
%%%%%%%%%%%%%%% * *
%%%%%%%%%%%%%%% * Non-maxima suppression of multiple responses *
%%%%%%%%%%%%%%% * *
%%%%%%%%%%%%%%% **************************************************************
%%%%%%%%%%%%%%% **************************************************************
%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%% Scanning-window style classification of image patches typically
%%%%%%%%%%%%%%% results in many multiple responses around the target object.
%%%%%%%%%%%%%%% A standard practice to deal with this is to remove any detector
%%%%%%%%%%%%%%% responses in the neighborhood of detections with locally maximal
%%%%%%%%%%%%%%% confidence scores (non-maxima suppression or NMS). NMS is
%%%%%%%%%%%%%%% usually applied to all detections in the image with confidence
%%%%%%%%%%%%%%% above certain threshold.
%%%%%%%%%%%%%%%
%%%%%%%%%%%%%%% TODO:
%%%%%%%%%%%%%%% 3.1 Try out different threshold values to pre-selected windows
%%%%%%%%%%%%%%% passed to the NMS stage, see parameter 'confthresh' below.
%%%%%%%%%%%%%%% 3.2 Try out different threshold values for NMS detections,
%%%%%%%%%%%%%%% see parameter 'confthreshnms'
%%%%%%%%%%%%%%% 3.3 Try detection and with different thresholds for different
%%%%%%%%%%%%%%% included images: 'img1.jpg', 'img2.jpg', 'img3.jpg', 'img4.jpg'
%%%%%%%%%%%%%%%
confthresh=0;
indsel=find(conf>confthresh);
[nmsbbox,nmsconf]=prunebboxes(bbox(indsel,:),conf(indsel),0.2);
%%%%%%%%%%%%%%% display detections above threshold after non-max suppression
%%%%%%%%%%%%%%%
confthreshnms=1;
clf, showimage(img)
indsel=find(nmsconf>confthreshnms);
showbbox(nmsbbox(indsel,:),[1 1 0],regexp(num2str(nmsconf(indsel)'),'\d+\.\d+','match'));
title(sprintf('%d NMS detections above threshold %1.3f',size(nmsbbox,1),confthreshnms),'FontSize',14)
fprintf('press a key...'), pause, fprintf('\n')
您可以在第一个链接中找到所有相关功能。