opencv-python使用Hu矩进行形状匹配DIY

首先获取质心。参考来源
在这里插入图片描述
在这里插入图片描述

源码案例:

#coding=utf-8
import cv2
import numpy as np
 
img01="S:\\AdobeppPS\\SKOO\\cc23.jpg"
img = cv2.imread(img01) 
# convert image to grayscale image
gray_image = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
 
# convert the grayscale image to binary image
ret,thresh = cv2.threshold(gray_image,127,255,0)
 
# calculate moments of binary image
M = cv2.moments(thresh)
 
# calculate x,y coordinate of center
cX = int(M["m10"] / M["m00"])
cY = int(M["m01"] / M["m00"])
 
# put text and highlight the center
cv2.circle(img, (cX, cY), 5, (255, 255, 255), -1)
cv2.putText(img, "centroid", (cX - 25, cY - 25),cv2.FONT_HERSHEY_SIMPLEX, 0.5, (255, 255, 255), 2)
 
# display the image
cv2.imshow("Image", img)
cv2.waitKey(0)

Image中有多个blob,使用findContours来查找图像中的轮廓数量并找到每个轮廓的中心。然后再计算几何矩。

要找到blob的质心,执行以下步骤具体是:

1.将图像转换为灰度图。

2.对图像执行二值化。

3.计算图像矩后找到图像的中心。

单个blob的质心寻找。pch为预编译文件在这里插入图片描述
在这里插入图片描述
参考官网:https://learnopencv.com/find-center-of-blob-centroid-using-opencv-cpp-python/
位置:在这里插入图片描述

图像矩HU矩

图像像素强度的加权平均值HU矩
实现匹配(通过CV库自带函数)
在这里插入图片描述
py源码如下:

import cv2
def main():
    img01="S:\\AdobeppPS\\SKOO\\cc23.jpg"
    img02="S:\\AdobeppPS\\SKOO\\cc25.jpg"
    img03="S:\\AdobeppPS\\SKOO\\cc8.jpg"
    im1 = cv2.imread(img01,cv2.IMREAD_GRAYSCALE)
    im2 = cv2.imread(img02,cv2.IMREAD_GRAYSCALE)
    im3 = cv2.imread(img03,cv2.IMREAD_GRAYSCALE) 
    m1 = cv2.matchShapes(im1,im2,cv2.CONTOURS_MATCH_I2,0)
    m2 = cv2.matchShapes(im1,im3,cv2.CONTOURS_MATCH_I2,0)
    m3 = cv2.matchShapes(im2,im3,cv2.CONTOURS_MATCH_I2,0) 
    print("Shape Distances Between \n-------------------------") 
    print(format(m1,".6f"))
    print(format(m2,".6f"))
    print(format(m3,".6f")) 
if __name__ == "__main__":
    main()

参考来源1:https://blog.csdn.net/LuohenYJ/article/details/88603274

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

海宝7号

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值