opencv-python 二值图像的模板匹配实现

之前写过如何获得一个指静脉的二值化特征图像,传送门:opencv-python 用Gabor滤波器实现指静脉血管区域二值化纹理特征提取

然后这篇文章记录我是如何来做特征模板匹配的。

匹配评分原理:

原理:根据上述二值纹理特征提取方法,获取手指静脉纹路的二值

纹理图像将已注册图像的 ROI 区域与待认证图片的 ROI 区域均采用二值纹理特征提取方法获得两张纹理前景图像,然后计算两张纹理前景图像的交集(重叠)像素点数与两张纹理前景图像的并集像素点数之比,这个比值即为两张图像的匹配分数。

但是在匹配过程中,为了使得模板同类图片(同一手指图片)在匹配中得到更高的分数,同时让其他类图片的分数(相对)更小。我自己设计了基于像素对比的另外一种方法:用模板和待认证图片的交集比上模板的非运算和待认证图片的交集。用式子表示为:

 

尺寸匹配:

要对得到的ROI区域二值特征进行逐个像素的比对,必须使得输入的待匹配图片和原来的图像尺寸一致。在opencv中,可以采用:


Dst=cv.resize(Src,(cols,rows),0,0,interpolation=cv.INTER_NEAREST)

我选择的是最近邻插值法(cv.INTER_NEAREST),原因很简单:因为参与对比的图片都是0,255的二值图像,如果采用双线性插值法,将会计算出其他的像素值,这不便于后期的处理。

开始匹配:

接下来就很简单了,无非是bitwise_or()和bitwise_and()和,由于图片中的像素值都是255,直接用 img.sum()/255就可以知道图片里面有多少个非零像素了。这里贴一下我的代码和效果:

def bf_match(template,bf1):  # template is template,bf1 is the test image,they are both binary feature(0 or 255)
    rows,cols=template.shape
    inv_template=cv.bitwise_not(template)
    #plt.imshow(inv_template);plt.show()
    bf1=cv.resize(bf1,(cols,rows),0,0,interpolation=cv.INTER_NEAREST)
    and_img=cv.bitwise_and(template,bf1)
    #or_img=cv.bitwise_or(template,bf1)
    and_inv_img=cv.bitwise_and(inv_template,bf1)
    #result=result_img.sum()/or_img.sum()
    result=and_img.sum()/and_inv_img.sum()
    plt.imshow(and_img)
    plt.show()
    return result

效果如下:

 (感觉之前基于Gabor的二值特征提取还是做的太粗糙了!!)

 

点个赞噢亲~

 

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenCV-Python提供了一系列用于图像处理和计算机视觉任务的功能,其中包括图像匹配。图像匹配是指在一幅图像中寻找与目标图像相似的区域。通过OpenCV-Python,你可以使用模板匹配技术来实现图像匹配。 模板匹配是一种基于像素值相似度的匹配方法,它通过在输入图像中滑动一个模板图像,并计算模板与滑动窗口区域的相似度来找到最佳匹配位置。在OpenCV-Python中,你可以使用cv2.matchTemplate()函数来实现模板匹配。 下面是一个简单的图像匹配的例子代码: ```python import cv2 import numpy as np # 读取输入图像和目标图像 input_img = cv2.imread('input_img.jpg') target_img = cv2.imread('target_img.jpg') # 将输入图像和目标图像转换为灰度图像 input_gray = cv2.cvtColor(input_img, cv2.COLOR_BGR2GRAY) target_gray = cv2.cvtColor(target_img, cv2.COLOR_BGR2GRAY) # 执行模板匹配 result = cv2.matchTemplate(input_gray, target_gray, cv2.TM_CCOEFF_NORMED) # 获取最佳匹配位置 min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result) top_left = max_loc # 获取目标图像的宽度和高度 target_width, target_height = target_gray.shape[::-1] # 绘制矩形框标记目标图像 cv2.rectangle(input_img, top_left, (top_left + target_width, top_left + target_height), (0, 255, 0), 2) # 显示结果图像 cv2.imshow('Result', input_img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 在这个例子中,我们首先读取了输入图像和目标图像,并将它们转换为灰度图像。然后,我们使用cv2.matchTemplate()函数执行模板匹配,并通过获取最佳匹配位置来找到目标图像在输入图像中的位置。最后,我们使用cv2.rectangle()函数在输入图像上绘制一个矩形框来标记目标图像的位置,并显示结果图像。 请注意,这只是一个简单的图像匹配示例,你可以根据自己的需求进行更复杂的图像匹配操作,例如使用不同的匹配方法、应用阈值、使用多个目标图像等。同时,确保你已经安装了OpenCV-Python库,并准备好了输入图像和目标图像以供匹配使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值