<i id='HXkYz'><tr id='HXkYz'><dt id='HXkYz'><q id='HXkYz'><span id='HXkYz'><b id='HXkYz'><form id='HXkYz'><ins id='HXkYz'></ins><ul id='HXkYz'></ul><sub id='HXkYz'></sub></form><legend id='HXkYz'></legend><bdo id='HXkYz'><pre id='HXkYz'><center id='HXkYz'></center></pre></bdo></b><th id='HXkYz'></th></span></q></dt></tr></i><div id='HXkYz'><tfoot id='HXkYz'></tfoot><dl id='HXkYz'><fieldset id='HXkYz'></fieldset></dl></div>
      <tfoot id='HXkYz'></tfoot>
        • <bdo id='HXkYz'></bdo><ul id='HXkYz'></ul>

        <small id='HXkYz'></small><noframes id='HXkYz'>

        <legend id='HXkYz'><style id='HXkYz'><dir id='HXkYz'><q id='HXkYz'></q></dir></style></legend>

      1. Python+Opencv实现图像模板匹配详解

        时间:2023-12-17

          <small id='iNKon'></small><noframes id='iNKon'>

        • <tfoot id='iNKon'></tfoot>

          1. <legend id='iNKon'><style id='iNKon'><dir id='iNKon'><q id='iNKon'></q></dir></style></legend>
              <i id='iNKon'><tr id='iNKon'><dt id='iNKon'><q id='iNKon'><span id='iNKon'><b id='iNKon'><form id='iNKon'><ins id='iNKon'></ins><ul id='iNKon'></ul><sub id='iNKon'></sub></form><legend id='iNKon'></legend><bdo id='iNKon'><pre id='iNKon'><center id='iNKon'></center></pre></bdo></b><th id='iNKon'></th></span></q></dt></tr></i><div id='iNKon'><tfoot id='iNKon'></tfoot><dl id='iNKon'><fieldset id='iNKon'></fieldset></dl></div>
                <bdo id='iNKon'></bdo><ul id='iNKon'></ul>
                  <tbody id='iNKon'></tbody>

                • 这里是“Python+Opencv实现图像模板匹配详解”的攻略,主要介绍了使用Python和OpenCV实现图像模板匹配的过程,以及一些示例说明。

                  1. 简介

                  图像模板匹配是指在一副图像中查找给定的目标图像的位置。它是计算机视觉中的基本问题之一,也是许多更复杂问题的基础。在本教程中,我们将使用Python和OpenCV来实现基本的图像模板匹配。

                  2. 实现过程

                  实现图像模板匹配的主要步骤如下:

                  1. 导入必要的库,包括cv2、numpy和matplotlib。
                  2. 加载原始图像和模板图像。
                  3. 将模板图像与原始图像进行匹配。
                  4. 找到匹配位置。
                  5. 绘制矩形框标记匹配区域。

                  下面是一个基本的示例实现:

                  import cv2
                  import numpy as np
                  from matplotlib import pyplot as plt
                  
                  # 读取原始图像和模板图像
                  img = cv2.imread('image.png', 0)
                  template = cv2.imread('template.png', 0)
                  
                  # 获取模板图像大小
                  w, h = template.shape[::-1]
                  
                  # 应用模板匹配算法
                  res = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)
                  
                  # 设定匹配阈值
                  threshold = 0.8
                  
                  # 获取匹配结果位置
                  loc = np.where(res >= threshold)
                  
                  # 绘制矩形标记匹配区域
                  for pt in zip(*loc[::-1]):
                      cv2.rectangle(img, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 2)
                  
                  # 显示匹配结果
                  plt.imshow(img, cmap='gray')
                  plt.title('Match Result')
                  plt.xticks([]), plt.yticks([])
                  plt.show()
                  

                  在这个示例中,我们首先加载原始图像和模板图像。接着,我们获取模板图像的大小,并使用OpenCV的matchTemplate函数进行模板匹配。这个函数将返回匹配结果的矩阵,我们将其存储在变量res中。

                  接下来,我们设定匹配阈值,用于确定匹配结果是否是有效的。在这个示例中,我们将阈值设置为0.8。将匹配结果与阈值进行比较,然后使用np.where函数检索匹配结果的位置。最后,我们使用OpenCV的rectangle函数在匹配区域周围画出矩形框,并使用imshowshow函数将结果显示出来。

                  3. 示例说明

                  下面是两个示例,以说明如何使用Python和OpenCV实现图像模板匹配。

                  示例1:车辆检测

                  假设我们有一张道路交通的原始图像,要从中检测出汽车的位置。我们可以使用汽车的模板图像对原始图像进行匹配,并将匹配的位置标记出来。

                  以下是示例代码:

                  import cv2
                  import numpy as np
                  from matplotlib import pyplot as plt
                  
                  # 读取原始图像和模板图像
                  img = cv2.imread('traffic.jpg', 0)
                  template = cv2.imread('car.png', 0)
                  
                  # 获取模板图像大小
                  w, h = template.shape[::-1]
                  
                  # 应用模板匹配算法
                  res = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)
                  
                  # 设定匹配阈值
                  threshold = 0.8
                  
                  # 获取匹配结果位置
                  loc = np.where(res >= threshold)
                  
                  # 绘制矩形标记匹配区域
                  for pt in zip(*loc[::-1]):
                      cv2.rectangle(img, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 2)
                  
                  # 显示匹配结果
                  plt.imshow(img, cmap='gray')
                  plt.title('Car Detection')
                  plt.xticks([]), plt.yticks([])
                  plt.show()
                  

                  在这个示例中,我们使用模板图像来匹配原始图像,并找到匹配的位置。最后,我们使用矩形框标记匹配区域,并将结果显示出来。根据匹配结果,我们可以确定原始图像中所有车辆的位置。

                  示例2:疵点检测

                  假设我们有一张PCBA板的原始图像,要从中检测出装配中可能出现的疵点,如短路、开路等。我们可以使用疵点的模板图像对原始图像进行匹配,并将匹配的位置标记出来。

                  以下是示例代码:

                  import cv2
                  import numpy as np
                  from matplotlib import pyplot as plt
                  
                  # 读取原始图像和模板图像
                  img = cv2.imread('pcb.jpg', 0)
                  template = cv2.imread('defect.png', 0)
                  
                  # 获取模板图像大小
                  w, h = template.shape[::-1]
                  
                  # 应用模板匹配算法
                  res = cv2.matchTemplate(img, template, cv2.TM_CCOEFF_NORMED)
                  
                  # 设定匹配阈值
                  threshold = 0.8
                  
                  # 获取匹配结果位置
                  loc = np.where(res >= threshold)
                  
                  # 绘制矩形标记匹配区域
                  for pt in zip(*loc[::-1]):
                      cv2.rectangle(img, pt, (pt[0] + w, pt[1] + h), (0, 0, 255), 2)
                  
                  # 显示匹配结果
                  plt.imshow(img, cmap='gray')
                  plt.title('Defect Detection')
                  plt.xticks([]), plt.yticks([])
                  plt.show()
                  

                  在这个示例中,我们使用模板图像来匹配原始图像,并找到匹配的位置。最后,我们使用矩形框标记匹配区域,并将结果显示出来。根据匹配结果,我们可以确定原始图像中是否存在疵点问题。

                  4. 结论

                  在本教程中,我们介绍了使用Python和OpenCV实现图像模板匹配的基本过程。我们还展示了两个示例,分别用于车辆检测和疵点检测。这个技术在很多领域都有广泛的应用,例如机器视觉、自动化检测等。通过不断的学习和实践,我们可以进一步掌握和应用这个技术,解决实际问题。

                  上一篇:Python 实现opencv所使用的图片格式与 base64 转换 下一篇:python多线程分块读取文件

                  相关文章

                  <tfoot id='clJCE'></tfoot>
                • <legend id='clJCE'><style id='clJCE'><dir id='clJCE'><q id='clJCE'></q></dir></style></legend>
                  • <bdo id='clJCE'></bdo><ul id='clJCE'></ul>

                  <i id='clJCE'><tr id='clJCE'><dt id='clJCE'><q id='clJCE'><span id='clJCE'><b id='clJCE'><form id='clJCE'><ins id='clJCE'></ins><ul id='clJCE'></ul><sub id='clJCE'></sub></form><legend id='clJCE'></legend><bdo id='clJCE'><pre id='clJCE'><center id='clJCE'></center></pre></bdo></b><th id='clJCE'></th></span></q></dt></tr></i><div id='clJCE'><tfoot id='clJCE'></tfoot><dl id='clJCE'><fieldset id='clJCE'></fieldset></dl></div>

                  <small id='clJCE'></small><noframes id='clJCE'>