IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> Canny算子及代码实现 -> 正文阅读

[人工智能]Canny算子及代码实现

Canny算子
Marr(LoG)边缘检测方法类似,也属于是先平滑后求导数的方法John Canny研究了最优边缘检测方法所需的特性,给出了评价边缘检测性能优劣的三个指标:
1.好的信噪比,即将非边缘点判定为边缘点的概率要低,将边缘点判为非边缘点的概率要低;
2.高的定位性能,即检测出的边缘点要尽可能在实际边缘的中心;
3.对单一边缘仅有唯一响应,即单个边缘产生多个响应的概率要低,并且虚
假响应边缘应该得到最大抑制。
步骤:
4.减少噪音:由于边缘检测易受图像中的噪声影响,因此第一步是使用5x5高斯滤波器去除图像中的噪声.
在这里插入图片描述
5.计算图像梯度:对平滑后的图像使用sobel算子在水平与竖直方向上计算一阶导数,得到图像梯度(Gx和Gy)。根据梯度图找到边界梯度和方向
在这里插入图片描述
根据角度对幅值进行非极大值抑制:将模糊的边界变得清晰(sharp)
1.将其梯度方向近似为以下值中的一个(0,45,90,135,180,225,270,315)(即上下左右和45度方向)
2.比较该像素点,和其梯度方向正负方向的像素点的梯度强度
3.如果该像素点梯度强度最大则保留,否则抑制(删除,即置为0)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
edge = cv2.Canny(image, threshold1, threshold2) 必要参数:
1.第一个参数是需要处理的原图像,该图像必须为单通道的灰度图;
2.第二个参数是阈值1;
3.第三个参数是阈值2。
代码实现:

img = cv.imread('girl.png', cv.IMREAD_GRAYSCALE)
gaussion = cv.GaussianBlur(img, (3, 3), 0)
canny = cv.Canny(gaussion, 32, 80)

fig = plt.figure(figsize = (10, 5))
fig.set(alpha = 0.2)
plt.subplot2grid((1, 2), (0, 0))
plt.imshow(img, 'gray')

plt.subplot2grid((1, 2), (0, 1))
plt.imshow(canny, 'gray')

在这里插入图片描述

#实现在线手动调整threshold1和threshold2的值
img = cv.imread('girl.png', cv.IMREAD_GRAYSCALE)
img = cv.resize(img, (img.shape[1], img.shape[0]))

threshold1_min = 0
threshold1_max = 100

threshold2_min = 100
threshold2_max = 200

def canny_threshold1(x) :
    gaussion = cv.GaussianBlur(img, (3, 3), 0)
    canny = cv.Canny(gaussion, x, threshold2_min)
    cv.imshow('Canny', canny)

def canny_threshold2(x) :
    gaussion = cv.GaussianBlur(img, (3, 3), 0)
    canny = cv.Canny(gaussion, threshold1_min, x)
    cv.imshow('Canny', canny)

cv.namedWindow('Canny', cv.WINDOW_NORMAL | cv.WINDOW_KEEPRATIO)
#创建可调整大小的窗口并在调整窗口大小时保持图像比例不变
cv.createTrackbar('threshold1', 'Canny', threshold1_min, threshold1_max, canny_threshold1)
cv.createTrackbar('threshold2', 'Canny', threshold2_min, threshold2_max, canny_threshold2)
#绑定滑动条和窗口, 且设置滑动条的值
#cv2.createTrackbar(“scale”, “display”, 0, 100, self.opencv_calibration_node.on_scale)
# 第一个参数表示滑动条的名称,
# 第二个表示绑定的窗口名字,
# 第三个和第四设置滑动条的范围,注意的是第三个参数即滑动条的最小值固定为一,调整只是为了从你设定的那个数开始而已
# 第五个参数是回调函数,每次滑动都会调用回调函数。

在这里插入图片描述

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-10-20 12:29:39  更:2021-10-20 12:31:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 11:03:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码