• Python 模板匹配 匹配多个 识别多个图形


    原文:https://www.cnblogs.com/gezhuangzhuang/p/10724769.html

    原文:https://www.cnblogs.com/FHC1994/p/9123393.html

    原文:https://blog.csdn.net/qq_41603898/article/details/82219291

     识别技巧:

      小图的选择,尽可能的选择最核心的部分,要保证大图里面每个元素有包含了小图

      小图特点:小、每个图都能匹配到、取核心部分

    匹配的几种方式:

      1、TM_SQDIFF:平方差匹配;
        TM_SQDIFF_NORMED:标准平方差匹配。
        利用平方差来进行匹配,最好匹配为0.匹配越差,匹配值越大。

      2、TM_CCORR:相关性匹配;
        TM_CCORR_NORMED:标准相关性匹配。
        采用模板和图像间的乘法操作,数越大表示匹配程度较高, 0表示最坏的匹配效果。

      3、TM_CCOEFF:相关性系数匹配;
        TM_CCOEFF_NORMED:标准相关性系数匹配。
        将模版对其均值的相对值与图像对其均值的相关值进行匹配,
        1表示完美匹配,-1表示糟糕的匹配,0表示没有任何相关性(随机序列)。

    总结:随着从简单的测量(平方差)到更复杂的测量(相关系数),我们可获得越来越准确的匹配(同时也意味着越来越大的计算代价)。

    说明:

      原图(大图):big.jpg

      模板(小图):smart.jpg

    import cv2
    import numpy as np
    from matplotlib import pyplot as plt
    
    
    # 原文:https://www.cnblogs.com/gezhuangzhuang/p/10724769.html
    # 原文:https://blog.csdn.net/qq_21840201/article/details/85084621
    
    # 1. 读入原图和模板
    img_rgb = cv2.imread('big.jpg')
    img_gray = cv2.cvtColor(img_rgb, cv2.COLOR_BGR2GRAY)
    template = cv2.imread('smart.jpg', 0)
    h, w = template.shape[:2]
    
    # 归一化平方差匹配
    res = cv2.matchTemplate(img_gray, template, cv2.TM_CCOEFF_NORMED)
    threshold = 0.8
    
    
    # 返回res中值大于0.8的所有坐标
    # 返回坐标格式(col,row) 注意:是先col后row 一般是(row,col)!!!
    loc = np.where(res >= threshold)
    
    # loc:标签/行号索引 常用作标签索引
    # iloc:行号索引
    # loc[::-1]:取从后向前(相反)的元素
    # *号表示可选参数
    for pt in zip(*loc[::-1]):
        right_bottom = (pt[0] + w, pt[1] + h)
        print(pt)
        cv2.rectangle(img_rgb, pt, right_bottom, (0, 0, 255), 2)
    
    # 保存处理后的图片
    cv2.imwrite('res.png', img_rgb)
    
    
    
    # 显示图片 参数:(窗口标识字符串,imread读入的图像)
    cv2.imshow("test_image", img_rgb)
    
    # 窗口等待任意键盘按键输入 0为一直等待 其他数字为毫秒数
    cv2.waitKey(0)
    
    # 销毁窗口 退出程序
    cv2.destroyAllWindows()

    用到的图片:

    big.jpg

    smart.jpg

      

  • 相关阅读:
    防抖
    promise race
    promise 输出 1 2 3
    promise all
    红绿灯
    vue3 与 vue2 区别
    promise A+ 规范
    【校招VIP】出品:在线实习“职查查”每期简历描述和面试实战
    【校招VIP】出品:“小米手机”场景下的秒杀策略和实现
    【校招VIP】出品:在线实习“校跑腿”每期简历描述和面试实战
  • 原文地址:https://www.cnblogs.com/guxingy/p/12197659.html
Copyright © 2020-2023  润新知