栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

Opencv(二)Canny算子的实现

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Opencv(二)Canny算子的实现

Canny的目标是找到一个最优的边缘检测算法,最优边缘检测的含义是:
① 好的检测- 算法能够尽可能多地标识出图像中的实际边缘。
② 好的定位- 标识出的边缘要与实际图像中的实际边缘尽可能接近。
③ 最小响应- 图像中的边缘只能标识一次,并且可能存在的图像噪声不应标识为边缘。
为了满足这些要求Canny使用了变分法,这是一种寻找满足特定功能的函数的方法。最优检测使用四个指数函数项的和表示,但是它非常近似于高斯函数的一阶导数。

环境Anaconda3(Spyder)+Python3.8.8+OpenCV4.5.4.58

实现代码:

import cv2
import numpy as np
 
img = cv2.imread("lena.jpg", 0)

img = cv2.GaussianBlur(img,(3,3),0)
canny=cv2.Canny(img,50,150)

cv2.imshow("canny", canny)
cv2.waitKey(0)
cv2.destroyAllWindows()

原图:

实现结果:

参考链接:
https://baike.baidu.com/item/Canny%E7%AE%97%E5%AD%90/8821789?fr=aladdin

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/605204.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号