opencv3/Python 稠密光流calcOpticalFlowFarneback详解


Posted in Python onDecember 11, 2019

光流是由物体或相机的运动引起的图像对象在两个连续帧之间的视在运动模式.光流方法计算在t和 t+Δtt+Δt时刻拍摄的两个图像帧之间的每个像素的运动位置。这些方法被称为差分,因为它们基于图像信号的局部泰勒级数近似; 也就是说,它们使用关于空间和时间坐标的偏导数。

和稀疏光流相比,稠密光流不仅仅是选取图像中的某些特征点(一般用角点)进行计算;而是对图像进行逐点匹配,计算所有点的偏移量,得到光流场,从而进行配准.因此其计算量会显著大于稀疏光流,但效果一般优于稀疏光流.

函数:

def calcOpticalFlowFarneback(prev, next, flow, pyr_scale, levels, winsize, iterations, poly_n, poly_sigma, flags):

使用Gunnar Farneback算法计算密集光流。

相关参数:

prev 输入前一帧图像(8位单通道);

next 输入后一帧图像(与prev大小和类型相同);

flow 计算的流量图像具有与prev相同的大小并为CV_32FC2类型;

pyr_scale 指定图像比例(\ <1)为每个图像构建金字塔; pyr_scale = 0.5意味着一个古典金字塔,其中每个下一层比前一层小两倍。

levels 金字塔层数包括初始图像; levels = 1意味着不会创建额外的图层,只会使用原始图像。

winsize 平均窗口大小;较大的值会增加算法对图像噪声的鲁棒性,并可以检测更快速的运动,但会产生更模糊的运动场。

iterations 每个金字塔等级上执行迭代算法的迭代次数。用于在每个像素中查找多项式展开的像素邻域;

poly_n大小;较大的值意味着图像将近似于更光滑的表面,产生更稳健的算法和更模糊的运动场,一般取poly_n = 5或7。

poly_sigma用于平滑导数的高斯的标准偏差,用作多项式展开的基础;对于poly_n = 5,可以设置poly_sigma = 1.1,对于poly_n = 7,可以设置poly_sigma = 1.5;

flags 操作标志,可取计算方法有:

OPTFLOW_USE_INITIAL_FLOW 使用输入流作为初始流近似。

OPTFLOW_FARNEBACK_GAUSSIAN 使用Gaussian winsize×winsizewinsize×winsize过滤器代替光流估计的相同大小的盒子过滤器;通常情况下,这个选项可以比使用箱式过滤器提供更精确的流量,代价是速度更低;通常,应将高斯窗口的胜利设置为更大的值以实现相同的稳健性水平。

示例:

#!/usr/bin/python
# coding:utf8

import numpy as np
import cv2

step=10

if __name__ == '__main__':
 cam = cv2.VideoCapture(0)
 ret, prev = cam.read()
 prevgray = cv2.cvtColor(prev, cv2.COLOR_BGR2GRAY)

 while True:
 ret, img = cam.read()
 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
 # 使用Gunnar Farneback算法计算密集光流
 flow = cv2.calcOpticalFlowFarneback(prevgray, gray, None, 0.5, 3, 15, 3, 5, 1.2, 0)
 prevgray = gray
 # 绘制线
 h, w = gray.shape[:2]
 y, x = np.mgrid[step / 2:h:step, step / 2:w:step].reshape(2, -1).astype(int)
 fx, fy = flow[y, x].T
 lines = np.vstack([x, y, x + fx, y + fy]).T.reshape(-1, 2, 2)
 lines = np.int32(lines)

 line = []
 for l in lines:
 if l[0][0]-l[1][0]>3 or l[0][1]-l[1][1]>3:
 line.append(l)

 cv2.polylines(img, line, 0, (0,255,255))
 cv2.imshow('flow', img)

 ch = cv2.waitKey(5)
 if ch == 27:
 break
 cv2.destroyAllWindows()

opencv3/Python 稠密光流calcOpticalFlowFarneback详解

以上这篇opencv3/Python 稠密光流calcOpticalFlowFarneback详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python装饰器decorator介绍
Nov 21 Python
Python设计实现的计算器功能完整实例
Aug 18 Python
python命令行解析之parse_known_args()函数和parse_args()使用区别介绍
Jan 24 Python
Python迭代器和生成器定义与用法示例
Feb 10 Python
利用Python批量提取Win10锁屏壁纸实战教程
Mar 27 Python
对python3中的RE(正则表达式)-详细总结
Jul 23 Python
Python实现报警信息实时发送至邮箱功能(实例代码)
Nov 11 Python
关于numpy.where()函数 返回值的解释
Dec 06 Python
Python读取Excel数据并生成图表过程解析
Jun 18 Python
python中@property的作用和getter setter的解释
Dec 22 Python
Python关于OS文件目录处理的实例分享
May 23 Python
Python答题卡识别并给出分数的实现代码
Jun 22 Python
centos7中安装python3.6.4的教程
Dec 11 #Python
python3 使用Opencv打开USB摄像头,配置1080P分辨率的操作
Dec 11 #Python
Python3 中作为一等对象的函数解析
Dec 11 #Python
opencv3/C++图像像素操作详解
Dec 10 #Python
Pandas时间序列重采样(resample)方法中closed、label的作用详解
Dec 10 #Python
Python3的unicode编码转换成中文的问题及解决方案
Dec 10 #Python
用OpenCV将视频分解成单帧图片,图片合成视频示例
Dec 10 #Python
You might like
浅析php单例模式
2014/11/25 PHP
php用ini_get获取php.ini里变量值的方法
2015/03/04 PHP
WordPress迁移时一些常见问题的解决方法整理
2015/11/24 PHP
PHP反射机制原理与用法详解
2017/02/15 PHP
javascript编程起步(第五课)
2007/01/10 Javascript
用js 让图片在 div或dl里 居中,底部对齐
2008/01/21 Javascript
js 日期转换成中文格式的函数
2009/07/07 Javascript
JavaScript 读取元素的CSS信息的代码
2010/02/07 Javascript
jQuery旋转插件—rotate支持(ie/Firefox/SafariOpera/Chrome)
2013/01/16 Javascript
深入浅析JavaScript系列(13):This? Yes,this!
2016/01/05 Javascript
jQuery form 表单验证插件(fieldValue)校验表单
2016/01/24 Javascript
javascript实现数字倒计时特效
2016/03/30 Javascript
浅谈JavaScript前端开发的MVC结构与MVVM结构
2016/06/03 Javascript
jQuery tagsinput在h5邮件客户端中应用详解
2016/09/26 Javascript
浅谈Node.js之异步流控制
2017/10/25 Javascript
浅谈vue中慎用style的scoped属性
2017/11/28 Javascript
mui back 返回刷新页面的实例
2017/12/06 Javascript
Vue页面跳转动画效果的实现方法
2018/09/23 Javascript
解决echarts的多个折现数据出现坐标和值对不上的问题
2018/12/28 Javascript
简单说说如何使用vue-router插件的方法
2019/04/08 Javascript
JS中数据结构与算法---排序算法(Sort Algorithm)实例详解
2019/06/17 Javascript
Python 异常处理实例详解
2014/03/12 Python
Python 'takes exactly 1 argument (2 given)' Python error
2016/12/13 Python
pandas dataframe的合并实现(append, merge, concat)
2019/06/24 Python
python GUI库图形界面开发之PyQt5布局控件QHBoxLayout详细使用方法与实例
2020/03/06 Python
分布式全文检索引擎ElasticSearch原理及使用实例
2020/11/14 Python
eDreams澳大利亚:预订机票、酒店和度假产品
2017/04/19 全球购物
加拿大时尚潮流大码女装购物网站:Addition Elle
2018/04/02 全球购物
四年大学生活的自我评价范文
2014/02/07 职场文书
2014年药店店长工作总结
2014/11/17 职场文书
2015年老干部工作总结
2015/04/23 职场文书
离职证明范本
2015/06/12 职场文书
经营场所使用证明
2015/06/19 职场文书
外科护士长工作总结
2015/08/12 职场文书
建立共青团委员会的请示
2019/04/02 职场文书
详解PHP设计模式之依赖注入模式
2021/05/25 PHP