python:实现 canny边缘检测算法(附完整源码)

python:实现 canny边缘检测算法

import cv2
import numpy as np
from digital_image_processing.filters.convolve import img_convolve
from digital_image_processing.filters.sobel_filter import sobel_filter
PI = 180
def gen_gaussian_kernel(k_size, sigma)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Canny边缘检测是一种经典的图像边缘检测算法,下面是Python实现代码: ```python import cv2 import numpy as np # 读取图片 img = cv2.imread('image.jpg') # 灰度化处理 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 高斯平滑滤波 gaussian = cv2.GaussianBlur(gray, (5, 5), 0) # 计算梯度 sobelx = cv2.Sobel(gaussian, cv2.CV_64F, 1, 0, ksize=3) sobely = cv2.Sobel(gaussian, cv2.CV_64F, 0, 1, ksize=3) mag = np.sqrt(sobelx**2 + sobely**2) mag = np.uint8(mag) # 非极大值抑制 height, width = mag.shape non_max = np.zeros((height, width), dtype=np.uint8) for i in range(1, height - 1): for j in range(1, width - 1): if sobelx[i, j] == 0: tangent = 1e5 else: tangent = sobely[i, j] / sobelx[i, j] if mag[i, j] >= mag[i-1, j-1] * tangent and mag[i, j] >= mag[i+1, j+1] * tangent: non_max[i, j] = 255 elif mag[i, j] >= mag[i-1, j] and mag[i, j] >= mag[i+1, j]: non_max[i, j] = 255 elif mag[i, j] >= mag[i, j-1] * tangent and mag[i, j] >= mag[i, j+1] * tangent: non_max[i, j] = 255 elif mag[i, j] >= mag[i, j-1] and mag[i, j] >= mag[i, j+1]: non_max[i, j] = 255 # 双阈值和连接边缘 weak = 75 strong = 255 result = np.zeros((height, width), dtype=np.uint8) result[mag > weak] = 1 result[mag > strong] = 255 for i in range(1, height - 1): for j in range(1, width - 1): if result[i, j] == 1: if result[i-1, j-1] == 255 or result[i-1, j] == 255 or result[i-1, j+1] == 255 or result[i, j-1] == 255 or result[i, j+1] == 255 or result[i+1, j-1] == 255 or result[i+1, j] == 255 or result[i+1, j+1] == 255: result[i, j] = 255 else: result[i, j] = 0 # 显示图片 cv2.imshow('Canny Edge Detection', result) cv2.waitKey(0) cv2.destroyAllWindows() ``` 以上代码中使用了OpenCV库实现Canny边缘检测算法,其中包括灰度化处理、高斯平滑滤波、计算梯度、非极大值抑制、双阈值和连接边缘等步骤,最终结果显示在窗口中。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

源代码大师

赏点狗粮吧

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

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

打赏作者

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

抵扣说明:

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

余额充值