当前位置: 首页 > news >正文

图像预处理-图像边缘检测(流程)

一.高斯滤波

        因为图像边缘检测就是把像素值有差异的地方提取出来,所以噪声会有很大影响,因此需要对图像进行平滑处理高斯滤波是流程中常用的方法。

二.计算图像的梯度与方向

过程中通常使用sobel算子进行梯度计算,在OpenCV中,默认使用 G=|G(x)+G(y)| 来计算梯度值。

这个角度值其实是当前边缘的梯度方向,若梯度方向不是0°、45°、90°、135°这种特定角度,那么就要用到插值算法来计算当前像素点在其方向上进行插值的结果,然后进行比较并判断是否保留该像素点。

- 为-22.5°~22.5°,或-157.5°~157.5°,则认为边缘为水平边缘;

- 为22.5°~67.5°,或-112.5°~-157.5°,则认为边缘为45°边缘;

- 为67.5°~112.5°,或-67.5°~-112.5°,则认为边缘为垂直边缘;

- 为112.5°~157.5°,或-22.5°~-67.5°,则认为边缘为135°边缘;

三.非极大值抑制

        经过第二步得到的边缘不经过处理是没办法使用的,因为高斯滤波去噪边缘会模糊,得到的边缘像素点非常多,因此需要对其进行一些过滤操作,而非极大值抑制就是一个很好的方法。即检查每个像素点的梯度方向上的相邻像素,并保留梯度值最大的像素,将其他像素抑制为零

四.双阈值筛选

经过非极大值抑制之后,我们还需要设置阈值来进行筛选。

        当某一像素位置的幅值超过最高阈值时,该像素必是边缘像素;当幅值低于最低阈值时,该像素必不是边缘像素;幅值处于最高像素与最低像素之间时,如果它能连接到一个高于阈值的边缘时,则被认为边缘像素,否则就不会被认为是边缘。

五.实现边缘检测的流程函数

edges = cv2.Canny(image, threshold1, threshold2)

- threshold1阈值,用于决定可能的边缘点。

- threshold2阈值,用于决定强边缘点。

- 即使读到的是彩色图也可以进行处理。

import cv2 as cvimg = cv.imread('../images/lvbo2.png')gray1 = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
# 手动进行高斯滤波再调用canny边缘检测
img2 = cv.GaussianBlur(img, (3, 3), 1)gray2 = cv.cvtColor(img2, cv.COLOR_BGR2GRAY)# 二值化处理方便观察
ret, binary = cv.threshold(gray1, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)
ret, binary1 = cv.threshold(gray2, 0, 255, cv.THRESH_BINARY | cv.THRESH_OTSU)# 利用内置高斯滤波器进行边缘检测
edge = cv.Canny(binary, 30, 70)
edge1 = cv.Canny(binary1, 30, 70)cv.imshow('edge', edge)
cv.imshow('edge1', edge1)
cv.waitKey(0)
cv.destroyAllWindows()

        可以发现,提前手动进行去噪处理效果更好,虽然canny函数内置了高斯滤波,但根据要求进行去噪预处理可以得到更好的效果。

相关文章:

  • 力扣算法ing(60 / 100)
  • 代谢组数据分析(二十四):基于tidymass包从质谱原始数据到代谢物注释结果的实践指南
  • 精益数据分析(5/126):解锁创业成功的关键密码
  • 运算符重载
  • LeetCode(Hot.2)—— 49.字符异位词分组题解
  • 【win 1】win 右键菜单添加 idea pycharm vscode trae 打开文件夹
  • 笔试专题(十一)
  • 什么编程语言市场竞争小,但还易学?
  • Docker应用端口查看器docker-port-viewer
  • 基于springboot的老年医疗保健系统
  • HTML5 应用程序缓存:原理、实践与演进
  • 【Vue】模板语法与指令
  • 图灵奖得主LeCun:DeepSeek开源在产品层是一种竞争,但在基础方法层更像是一种合作;新一代AI将情感化
  • 【Linux】线程ID、线程管理、与线程互斥
  • 【概率论】条件期望
  • rebase和merge的区别
  • 【图片识别改名工具】图片文件区域OCR识别并自动重命名,批量识别指定区域根据指定识别文字批量改名,基于WPF和阿里云的技术方式实现
  • Ethan独立开发产品日报 | 2025-04-18
  • 汽车故障诊断工作原理:从需求到AUTOSAR诊断模块协作的浅析
  • Android 热点二维码简单示例
  • 从“长绳系日”特展看韩天衡求艺之路
  • 2025五一档新片电影总票房破亿
  • 国台办:台商台企有信心与国家一起打赢这场关税战
  • 原国家有色金属工业局副局长黄春萼逝世,享年86岁
  • 笔墨如何“构城”?上海美院城市山水晋京展出
  • 华夏幸福:去年营业收入237.65亿元,同比减亏12亿元