小编给大家分享一下opencv3/C++怎么实现视频背景去除建模,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
视频背景建模主要使用到:
高斯混合模型(Mixture Of Gauss,MOG)
createBackgroundSubtractorMOG2(int history=500, double varThreshold=16,bool detectShadows=true);
K最近邻(k-NearestNeighbor,kNN)
createBackgroundSubtractorKNN(int history=500, double dist2Threshold=400.0, bool detectShadows=true);
history:history的长度。
varThreshold:像素和模型之间马氏距离的平方的阈值。
detectShadows:默认为true,检测阴影并标记它们(影子会被标记为灰色)。 会降低了部分速度。
实例:
#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
VideoCapture capture;
capture.open("E:/image/01.avi");
if(!capture.isOpened())
{
printf("can not open video file \n");
return -1;
}
Mat frame;
namedWindow("input", CV_WINDOW_AUTOSIZE);
namedWindow("MOG2", CV_WINDOW_AUTOSIZE);
namedWindow("KNN", CV_WINDOW_AUTOSIZE);
Mat maskMOG2, maskKNN;
Ptr<BackgroundSubtractor> pMOG2 = createBackgroundSubtractorMOG2(500,25,true);
Ptr<BackgroundSubtractor> pKNN = createBackgroundSubtractorKNN();
Mat kernel = getStructuringElement(MORPH_RECT, Size(5,5));
while (capture.read(frame))
{
imshow("input", frame);
pMOG2->apply(frame, maskMOG2);
pKNN->apply(frame, maskKNN);
//对处理后的帧进行开操作,减少视频中较小的波动造成的影响
morphologyEx(maskMOG2,maskMOG2, MORPH_OPEN, kernel, Point(-1,-1));
morphologyEx(maskKNN,maskKNN, MORPH_OPEN, kernel, Point(-1,-1));
imshow("MOG2", maskMOG2);
imshow("KNN", maskKNN);
waitKey(3);
}
capture.release();
return 0;
}
视频中移动的玻璃球:
MOG分离出的小球区域:
KNN分离出的小球区域:
以上是“opencv3/C++怎么实现视频背景去除建模”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。