云计算百科
云计算领域专业知识百科平台

opencv计算机视觉--模板匹配&物体跟踪

一、模板匹配

cv2.matchTemplate(image, templ, method)

image:待搜索图像

templ:模板图像

method:计算匹配程度的方法:

TM_SQDIFF平方差匹配法:该方法采用平方差来进行匹配;匹配越好,值越小;匹配越差,值越大。

TM_CCORR相关匹配法:该方法采用乘法操作;数值越大表明匹配程度越好。

TM_CCOEFF相关系数匹配法:数值越大表明匹配程度越好。

TM_SQDIFF_NORMED归一化平方差匹配法,匹配越好,值越小;匹配越差,值越大。

TM_CCORR_NORMED归一化相关匹配法,数值越大表明匹配程度越好。

TM_CCOEFF_NORMED 归一化相关系数匹配法,数值越大表明匹配程度越好。

相关代码

import cv2

# 读取图像
kele = cv2.imread('kele.png')
kele=cv2.resize(kele,dsize=None,fx=1.5,fy=1.5)
tubiao = cv2.imread('tubiao.png')
tubiao=cv2.resize(tubiao,dsize=None,fx=1.5,fy=1.5)
cv2.imshow('kele', kele)
cv2.waitKey(0)
cv2.imshow('tubiao', tubiao)
cv2.waitKey(0)
h, w = tubiao.shape[:2] # 获取模板图像的高度和宽度

# 使用模板匹配方法
res = cv2.matchTemplate(kele, tubiao, cv2.TM_CCOEFF_NORMED)

min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(res)
# min_val:最小匹配值
# max_val:最大匹配值(最匹配的位置)
# min_loc:最小匹配值的位置坐标
# max_loc:最大匹配值的位置坐标(最佳匹配位置)

top_left = max_loc
bottom_right = (top_left[0] + w, top_left[1] + h)

kele_tubiao = cv2.rectangle(kele, top_left, bottom_right, (0, 255, 0), 2)
cv2.imshow('kele_tubiao', kele_tubiao)
cv2.waitKey(0)
cv2.destroyAllWindows()

注:模板的大小,要和图形中的所对应模板大小相同

二、物体跟踪

1、概念

物体跟踪是计算机视觉中的一个重要任务,指在视频序列中持续定位和追踪特定目标对象的位置。它不同于物体检测(每帧独立检测),跟踪需要维护目标的身份信息,在连续的帧中跟随同一个目标。

2、实际运用
1. 创建跟踪器

tracker = cv2.TrackerCSRT_create()

  • cv2.TrackerCSRT_create(): 创建 CSRT 跟踪器

  • OpenCV 提供了多种跟踪算法:

    • TrackerCSRT_create(): 高精度,速度较慢

    • TrackerKCF_create(): 平衡精度和速度

    • TrackerMOSSE_create(): 速度最快,精度较低

    • TrackerMIL_create(): 中等性能

2. 选择目标区域

roi = cv2.selectROI(windowName='Tracking', img=frame, showCrosshair=False)

  • cv2.selectROI(): 让用户在图像上选择矩形区域

  • 参数:

    • windowName: 窗口名称

    • img: 要选择ROI的图像

    • showCrosshair: 是否显示十字准线

  • 返回值:(x, y, width, height) 元组

3. 初始化跟踪器

tracker.init(frame, roi)

  • tracker.init(): 用第一帧和初始边界框初始化跟踪器

  • 参数:

    • frame: 第一帧图像

    • roi: 初始边界框

4. 更新跟踪器

success, box = tracker.update(frame)

  • tracker.update(): 在后续帧中更新跟踪器

  • 参数:当前帧图像

  • 返回值:

    • success: 布尔值,跟踪是否成功

    • box: 跟踪到的边界框 (x, y, width, height)

5. 绘制跟踪结果

cv2.rectangle(frame, pt1=(x, y), pt2=(x + w, y + h), color=(0, 255, 0), thickness=2)

  • 在跟踪到的位置上绘制绿色矩形框

完整代码

import cv2
# 创建一个CSRT跟踪器实例
tracker = cv2.TrackerCSRT_create()
# 跟踪标志,默认为False
tracking = False
# 打开默认摄像头(通常编号为0)
cap = cv2.VideoCapture(0)
while True:
# 从摄像头读取一帧图像
ret, frame = cap.read()
# 如果没有正确读取到图像,则退出循环
if not ret:
break
# 检查是否有按键被按下,如果是'a'键,则设置跟踪标志为True,并选择ROI
if cv2.waitKey(1) == ord('s'):
tracking = True
# 让用户在当前帧中选择一个矩形区域作为要跟踪的对象
roi = cv2.selectROI(windowName='Tracking', img=frame, showCrosshair=False) # 是否显示十字线
# 初始化跟踪器,传入当前帧和选定的ROI
tracker.init(frame, roi)
# 如果跟踪标志为True,则更新跟踪器
if tracking:
success, box = tracker.update(frame)
# 如果跟踪成功,获取对象的位置
if success:
x, y, w, h = [int(v) for v in box] # 确保所有坐标都是整数
# 在frame上绘制矩形框以显示跟踪结果
cv2.rectangle(frame, pt1=(x, y), pt2=(x + w, y + h), color=(0, 255, 0), thickness=2)
# 显示处理后的帧
cv2.imshow('Tracking',frame)
# 检查是否按下ESC键(ASCII码27),如果按下则退出循环
if cv2.waitKey(1) == 27:
break
# 释放摄像头资源
cap.release()
# 关闭所有OpenCV创建的窗口
cv2.destroyAllWindows()

赞(0)
未经允许不得转载:网硕互联帮助中心 » opencv计算机视觉--模板匹配&物体跟踪
分享到: 更多 (0)

评论 抢沙发

评论前必须登录!