图像边缘算法——计算图像边缘(OpenCV)

目录

一、算法描述

二、计算欧氏距离的Python代码

三、完整的代码

四、结果


一、算法描述

        算法的基本原理是:将当前像素与邻接的下部和右部进行比较,如果相似,则将当前像素设置为白色,否则设置为黑色。如何判定像素相似呢?应用欧式距离算法,将一个图像的3个色彩分量映射在三维空间中,如果2个像素点的欧氏距离小于某个常数的阈值,就认为它们相似。

二、计算欧氏距离的Python代码

def get_EuclideanDistance(x,y):
    myx = np.array(x)
    myy = np.array(y)
    return np.sqrt(np.sum((myx-myy)*(myx-myy)))

三、完整的代码

import cv2
import numpy as np

fn = r"C:\Users\LIHAO\Pictures\Saved Pictures\bpic26318.jpg"
def get_EuclideanDistance(x,y):
    myx = np.array(x)
    myy = np.array(y)
    return np.sqrt(np.sum((myx-myy)*(myx-myy)))

if __name__ == "__main__":
    myimg1 = cv2.imread(fn)
    w = myimg1.shape[1]
    h = myimg1.shape[0]
    sz1 = w
    sz0 = h
    # 创建空白图像
    myimg2 = np.zeros((sz0,sz1,3), np.uint8)
    # 对比产生线条
    black = np.array([0,0,0])
    white = np.array([255,255,255])
    centercolor = np.array([125,125,125])
    for y in range(sz0-1):
        for x in range(sz1-1):
            
            mydown = myimg1[y+1,x,:]
            myright = myimg1[y,x+1,:]
            
            myhere = myimg1[y,x,:]
            lmyhere = myhere
            lmyright = myright
            lmydown = mydown
            if get_EuclideanDistance(lmyhere,lmydown)>16 and get_EuclideanDistance(lmyhere,lmyright)>16:
                myimg2[y,x:] = black
            elif get_EuclideanDistance(lmyhere,lmydown)<=16 and get_EuclideanDistance(lmyhere,lmyright)<=16:
                myimg2[y,x:] = white
            else:
                myimg2[y,x:] = centercolor
        print(y)
    cv2.namedWindow('img2')
    cv2.imshow('img2', myimg2)
    cv2.waitKey()
    cv2.destroyAllWindows()
                

四、结果

        第一张为原图,第二张为计算图像边缘的结果

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

凌天傲海

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

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

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

打赏作者

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

抵扣说明:

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

余额充值