在OpenCV里使用Camshift算法的实现


Posted in Python onNovember 22, 2019

前面学习过Meanshift算法,在观察这个结果标记时,会发现有这样一个问题,如下图:

在OpenCV里使用Camshift算法的实现

汽车比较远时,用一个很小的窗口就可以把它框住,这是符合近大远小的投影原理,当比较近的时候如下:

在OpenCV里使用Camshift算法的实现

相同大小的窗口已经不能包围它了,那么这样跟踪目标对象就成为了一个问题,怎么样来更改它呢?那么就是Camshift (Continuously Adaptive Meanshift)算法引入的原因了。同时还会有一个问题,怎么样判断物体旋转的方向,这个算法也会解决这样的问题。这个算法发表在1998年的论文《Computer Vision Face Tracking for Use in a Perceptual User Interface》里。

这个算法,首先应用meanshift找到最大密度,然后再更新窗口的大小,接着计算最适合外包椭圆;如果不合适又进入一轮迭代过程。直满足meanshift的条件,并且窗口大小也合适为止。

Camshift函数返回两个值,第一个值ret是一个旋转的窗口,第二个值是窗口搜索位置给下一次搜索使用的。例子如下:

#python 3.7.4,opencv4.1
#蔡军生 https://blog.csdn.net/caimouse/article/details/51749579
#
import numpy as np
import cv2
from matplotlib import pyplot as plt
 
capture = cv2.VideoCapture(1)
if not capture.isOpened:
  print('Unable to open: ')
  exit(0)
  
#获取第一帧图片
ret,frame = capture.read()
 
#设置目标窗口
#读取文件
find = cv2.imread('luohu1.png')
h,w = find.shape[:2]
roi = find[10: 120, 10: 120]
x = 10
y = 10
width = 120 - x
height = 120 - y
track_window = (x, y, w, h)
print(track_window)
#跟踪目标
hsv_roi = cv2.cvtColor(roi, cv2.COLOR_BGR2HSV)
mask = cv2.inRange(hsv_roi, np.array((0., 60.,32.)), np.array((180.,255.,255.)))
roi_hist = cv2.calcHist([hsv_roi],[0],mask,[180],[0,180]) #计算直方图
cv2.normalize(roi_hist,roi_hist,0,255,cv2.NORM_MINMAX)
 
#设置迭代条件,每10移动一点
term_crit = ( cv2.TERM_CRITERIA_EPS | cv2.TERM_CRITERIA_COUNT, 10, 1 )
 
while(1):
  ret, frame = capture.read()
 
  if ret == True:
    hsv = cv2.cvtColor(frame, cv2.COLOR_BGR2HSV)
    dst = cv2.calcBackProject([hsv],[0],roi_hist,[0,180],1)#反向投影
 
    #使用 meanshift获得新位置
    ret, track_window = cv2.CamShift(dst, track_window, term_crit)
 
    #显示标记
    pts = cv2.boxPoints(ret)
    pts = np.int0(pts)
    img2 = cv2.polylines(frame,[pts],True, (255,0,0),2)
    cv2.imshow('img2',img2)
 
    cv2.imshow("dst", dst) 
    cv2.imshow("roi", roi)
    keyboard = cv2.waitKey(1)
    if keyboard == ord('q') or keyboard == ord('Q'):
      break
  else:
    break
 
  
capture.release()
cv2.destroyAllWindows()

结果输出如下:

在OpenCV里使用Camshift算法的实现

比较远的照片

在OpenCV里使用Camshift算法的实现

比较近的照片

在OpenCV里使用Camshift算法的实现

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
12步入门Python中的decorator装饰器使用方法
Jun 20 Python
python3中dict(字典)的使用方法示例
Mar 22 Python
python中的字典操作及字典函数
Jan 03 Python
运用TensorFlow进行简单实现线性回归、梯度下降示例
Mar 05 Python
Python中整数的缓存机制讲解
Feb 16 Python
python实现连续变量最优分箱详解--CART算法
Nov 22 Python
浅谈多卡服务器下隐藏部分 GPU 和 TensorFlow 的显存使用设置
Jun 30 Python
Python Celery异步任务队列使用方法解析
Aug 10 Python
OpenCV灰度化之后图片为绿色的解决
Dec 01 Python
Python+Opencv实现把图片、视频互转的示例
Dec 17 Python
python实现ping命令小程序
Dec 28 Python
Python语言规范之Pylint的详细用法
Jun 24 Python
利用Python的sympy包求解一元三次方程示例
Nov 22 #Python
Python matplotlib以日期为x轴作图代码实例
Nov 22 #Python
python快速排序的实现及运行时间比较
Nov 22 #Python
Python实现平行坐标图的绘制(plotly)方式
Nov 22 #Python
Python Celery多队列配置代码实例
Nov 22 #Python
python 协程 gevent原理与用法分析
Nov 22 #Python
python 并发下载器实现方法示例
Nov 22 #Python
You might like
PHP has encountered an Access Violation at 7C94BD02解决方法
2009/08/24 PHP
利用PHP抓取百度阅读的方法示例
2016/12/18 PHP
php使用include 和require引入文件的区别
2017/02/16 PHP
Yii框架日志记录Logging操作示例
2018/07/12 PHP
laravel-admin的图片删除实例
2019/09/30 PHP
JavaScript事件列表解说
2006/12/22 Javascript
发布一个基于javascript的动画类 Fx.js
2010/11/05 Javascript
JS与C#编码解码
2013/12/03 Javascript
jQuery实现鼠标划过添加和删除class的方法
2015/06/26 Javascript
jQuery实现美观的多级动画效果菜单代码
2015/09/06 Javascript
JS如何判断是否为ie浏览器的方法(包括IE10、IE11在内)
2015/12/13 Javascript
深入理解AngularJS中的ng-bind-html指令和$sce服务
2016/09/08 Javascript
Angular.JS中的指令引用template与指令当做属性详解
2017/03/30 Javascript
详解vue前后台数据交互vue-resource文档
2017/07/19 Javascript
详解webpack-dev-server使用方法
2018/09/14 Javascript
在vue项目中使用sass语法问题
2019/07/18 Javascript
js blob类型url的视频下载问题的解决
2019/11/29 Javascript
JS数据类型STRING使用实例解析
2019/12/18 Javascript
用JavaScript实现贪吃蛇游戏
2020/10/23 Javascript
python实现的登陆Discuz!论坛通用代码分享
2014/07/11 Python
python使用socket连接远程服务器的方法
2015/04/29 Python
python笔记:mysql、redis操作方法
2017/06/28 Python
python调用Delphi写的Dll代码示例
2017/12/05 Python
对python3标准库httpclient的使用详解
2018/12/18 Python
Python最小二乘法矩阵
2019/01/02 Python
python 用for循环实现1~n求和的实例
2019/02/01 Python
python之PyQt按钮右键菜单功能的实现代码
2019/08/17 Python
python输出第n个默尼森数的实现示例
2020/03/08 Python
一文详述 Python 中的 property 语法
2020/09/01 Python
使用HTML5 Canvas API控制字体的显示与渲染的方法
2016/03/24 HTML / CSS
英国最大的高品质珠宝和手表专家:Goldsmiths
2017/03/11 全球购物
澳大利亚宠物食品和药物在线:Jumbo Pets
2018/03/24 全球购物
金融专业应届生求职信
2013/11/02 职场文书
幼儿园大班开学教师寄语
2014/04/03 职场文书
安全演讲稿开场白
2014/08/25 职场文书
公共场所卫生管理制度
2015/08/05 职场文书