opencv3/C++实现视频背景去除建模(BSM)


Posted in Python onDecember 11, 2019

视频背景建模主要使用到:

高斯混合模型(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;

}

视频中移动的玻璃球:

opencv3/C++实现视频背景去除建模(BSM)

MOG分离出的小球区域:

opencv3/C++实现视频背景去除建模(BSM)

KNN分离出的小球区域:

opencv3/C++实现视频背景去除建模(BSM)

以上这篇opencv3/C++实现视频背景去除建模(BSM)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用python 获取进程pid号的方法
Mar 10 Python
一个月入门Python爬虫学习,轻松爬取大规模数据
Jan 03 Python
Python Series从0开始索引的方法
Nov 06 Python
基于python实现高速视频传输程序
May 05 Python
浅谈Django+Gunicorn+Nginx部署之路
Sep 11 Python
python scrapy重复执行实现代码详解
Dec 28 Python
python:批量统计xml中各类目标的数量案例
Mar 10 Python
python3将变量输入的简单实例
Aug 19 Python
Pytest单元测试框架如何实现参数化
Sep 05 Python
使用scrapy ImagesPipeline爬取图片资源的示例代码
Sep 28 Python
Ubuntu 20.04安装Pycharm2020.2及锁定到任务栏的问题(小白级操作)
Oct 29 Python
Python+腾讯云服务器实现每日自动健康打卡
Dec 06 Python
opencv3/C++实现视频读取、视频写入
Dec 11 #Python
django框架两个使用模板实例
Dec 11 #Python
Python enumerate函数遍历数据对象组合过程解析
Dec 11 #Python
django框架基于queryset和双下划线的跨表查询操作详解
Dec 11 #Python
django框架ModelForm组件用法详解
Dec 11 #Python
django框架中ajax的使用及避开CSRF 验证的方式详解
Dec 11 #Python
通过实例解析Python调用json模块
Dec 11 #Python
You might like
防止MySQL注入或HTML表单滥用的PHP程序
2009/01/21 PHP
PHP session有效期问题
2009/04/26 PHP
PHP中$_FILES的使用方法及注意事项说明
2014/02/14 PHP
PHP网页安全认证的实例详解
2017/09/28 PHP
PhpSpreadsheet设置单元格常用操作汇总
2020/11/13 PHP
javascript 定义初始化数组函数
2009/09/07 Javascript
jQuery焦点图切换特效插件封装实例
2013/08/18 Javascript
javascript删除字符串最后一个字符
2014/01/14 Javascript
教你用AngularJS框架一行JS代码实现控件验证效果
2014/06/23 Javascript
js删除Array数组中指定元素的两种方法
2016/08/03 Javascript
浅谈javascript中的数据类型转换
2016/12/27 Javascript
Js实现京东无延迟菜单效果实例(demo)
2017/06/02 Javascript
vue-cli 2.*中导入公共less文件的方法步骤
2018/11/22 Javascript
微信公众平台 发送模板消息(Java接口开发)
2019/04/17 Javascript
解决vue语法会有延迟加载显现{{xxx}}的问题
2019/11/14 Javascript
微信小程序实现搜索功能
2020/03/10 Javascript
jQuery-App输入框实现实时搜索
2020/11/19 jQuery
Python之PyUnit单元测试实例
2014/10/11 Python
Python操作使用MySQL数据库的实例代码
2017/05/25 Python
python中map()函数的使用方法示例
2017/09/29 Python
python不换行之end=与逗号的意思及用途
2017/11/21 Python
python实现用户答题功能
2018/01/17 Python
pygame实现简易飞机大战
2018/09/11 Python
浅谈Keras参数 input_shape、input_dim和input_length用法
2020/06/29 Python
解决python运行效率不高的问题
2020/07/20 Python
Talbots官网:美国成熟女装品牌
2019/11/15 全球购物
酒店管理求职信范文
2014/04/06 职场文书
论文指导教师评语
2014/04/28 职场文书
党务工作者主要事迹材料
2015/11/03 职场文书
《颐和园》教学反思
2016/02/19 职场文书
游戏开发中如何使用CocosCreator进行音效处理
2021/04/14 Javascript
Python实现拼音转换
2021/06/07 Python
实操Python爬取觅知网素材图片示例
2021/11/27 Python
Java 多线程协作作业之信号同步
2022/05/11 Java/Android
Mysql索引失效 数据库表中有索引还是查询很慢
2022/05/15 MySQL
HttpClient实现表单提交上传文件
2022/08/14 Java/Android