Canny 边缘检测

步骤

1.降噪

应用高斯滤波器,以平滑图像,滤除噪声。

边缘检测易受噪声影响,所以使用高斯滤波器平滑图像,降低噪声。

2.梯度

计算图像中每个像素点的梯度大小和方向。

计算大小

Sobel算子是一种常用的边缘检测滤波器,用于计算图像中水平和垂直方向上的梯度变化

就是点乘计算

计算方向

3.非极大值抑制

使用非极大值抑制,消除边缘检测带来的不利影响

4.双阈值检测

应用双阈值检测确定真实和潜在的边缘【双阈值检测

阈值 (minVal 和 maxVal) 是基于梯度大小(即边缘强度)来定义的

  • maxVal(高阈值):
    • 梯度值大于 maxVal 的像素点被直接认为是真正的边缘。
  • minVal(低阈值):
    • 梯度值小于 minVal 的像素点被忽略,认为不是边缘。
  • 梯度值介于 minVal 和 maxVal 之间:
    • 如果这些像素点与高于 maxVal 的边缘像素相连,则保留为边缘。
    • 如果没有相连,则丢弃。

实现

它有现成库可以调用啊

python 复制代码
import cv2
import matplotlib.pyplot as plt
import numpy as np

# 读取图像
image_path = r"D:\python\NAFNet-main\demo\tooth.png"  # 替换为你的图片路径
image = cv2.imread(image_path, cv2.IMREAD_GRAYSCALE)

# 高斯模糊去噪
blurred = cv2.GaussianBlur(image, (5, 5), 0)

# Canny 边缘检测
edges = cv2.Canny(blurred, threshold1=5, threshold2=200)#这边就是最大最小边缘


# 显示原图和边缘检测结果
plt.figure(figsize=(10, 5))
plt.subplot(1, 2, 1)
plt.title("Original Image")
plt.imshow(image, cmap="gray")
plt.axis("off")

plt.subplot(1, 2, 2)
plt.title("Canny Edge Detection")
plt.imshow(edges, cmap="gray")
plt.axis("off")

plt.tight_layout()
plt.show()

最后结果

相关推荐
行者常至为者常成10 分钟前
基于LangGraph的自我改进智能体:Reflection与Reflexion技术详解与实现
人工智能
菠菠萝宝32 分钟前
【Java手搓RAGFlow】-9- RAG对话实现
java·开发语言·人工智能·llm·jenkins·openai
福尔摩斯张1 小时前
C语言核心:string函数族处理与递归实战
c语言·开发语言·数据结构·c++·算法·c#
大佬,救命!!!1 小时前
最新的python3.14版本下仿真环境配置深度学习机器学习相关
开发语言·人工智能·python·深度学习·机器学习·学习笔记·环境配置
工业机器视觉设计和实现1 小时前
用caffe做个人脸识别
人工智能·深度学习·caffe
paperxie_xiexuo2 小时前
从研究问题到分析初稿:深度解析PaperXie AI科研工具中数据分析模块在学术写作场景下的辅助逻辑与技术实现路径
人工智能·数据挖掘·数据分析
一水鉴天2 小时前
整体设计 定稿 之9 拼语言工具设计之前 的 备忘录仪表盘(CodeBuddy)
人工智能·架构·公共逻辑
吗~喽2 小时前
【LeetCode】滑动窗口_水果成篮_C++
c++·算法·leetcode
IT_陈寒2 小时前
Python性能提升50%:这5个隐藏技巧让你的代码快如闪电⚡
前端·人工智能·后端
立志成为大牛的小牛2 小时前
数据结构——四十九、B树的删除与插入
数据结构·学习·程序人生·考研·算法