opencv通过3种算子进行边缘提取

Scharr算子是效果比较好的,但从肉眼看sobel算子比较顺眼

python 复制代码
# 导入OpenCV库,用于图像处理
import cv2
import numpy as np
# 从matplotlib库中导入pyplot模块,用于绘制图像
from matplotlib import pyplot as plt
# 创建一个名为'window'的窗口,窗口大小自动调整
cv2.namedWindow('window', cv2.WINDOW_AUTOSIZE)  # cv2.WINDOW_AUTOSIZE: 窗口大小自动调整,不允许用户改变窗口大小
# 使用OpenCV的imread函数读取名为"mao.jpg"的图片,参数1表示读取彩色图像
# cat变量存储读取的图像数据,OpenCV默认以BGR格式读取
# 这里使用了0作为参数,表示读取灰度图像
cat = cv2.imread("mao.jpg", 0)
# 在名为'window'的窗口中显示图像
cv2.imshow('window', cat)
# 使用Sobel算子计算x方向上的梯度,并将结果存储在sobelx变量中
# cv2.CV_64F表示数据类型为64位浮点数
# 1表示x方向上的导数,0表示y方向上的导数
# ksize表示Sobel核的大小
sobelx = cv2.Sobel(cat,cv2.CV_64F,1,0,ksize=3)
# 使用Sobel算子计算y方向上的梯度,并将结果存储在sobely变量中
sobely = cv2.Sobel(cat,cv2.CV_64F,0,1,ksize=3)
# 将sobelx和sobely的梯度图像转换为绝对值形式,并将结果转换为8位无符号整数
sobelx = cv2.convertScaleAbs(sobelx)
sobely = cv2.convertScaleAbs(sobely)
# 将x方向和y方向的梯度图像进行加权求和,得到最终的梯度图像
# 0.5是x方向和y方向的权重,0是gamma校正的常数
sobelxy = cv2.addWeighted(sobelx, 0.5, sobely, 0.5, 0)
# 使用Scharr算子计算x方向上的梯度,并将结果存储在scharrx变量中
# Scharr算子是一种改进的Sobel算子,对边缘的定位更准确
scharrx = cv2.Scharr(cat,cv2.CV_64F,1,0)
# 使用Scharr算子计算y方向上的梯度,并将结果存储在scharry变量中
scharry = cv2.Scharr(cat,cv2.CV_64F,0,1)
# 将scharrx和scharry的梯度图像转换为绝对值形式,并将结果转换为8位无符号整数
scharrx = cv2.convertScaleAbs(scharrx)
scharry = cv2.convertScaleAbs(scharry)
# 将Scharr算子的x方向和y方向的梯度图像进行加权求和
# 注意这里有一个错误,应该是scharrx和scharry进行加权求和,而不是sobelxy和sobely
scharrxy = cv2.addWeighted(scharrx, 0.5, scharry, 0.5,0)
# 使用Laplacian算子计算图像的二阶导数,并将结果存储在laplacian变量中
laplacian = cv2.Laplacian(cat,cv2.CV_64F)
# 将Laplacian的二阶导数图像转换为绝对值形式,并将结果转换为8位无符号整数
laplacian = cv2.convertScaleAbs(laplacian)
# 将sobelxy, scharrxy和laplacian的梯度图像水平堆叠在一起,以便于比较
res = np.hstack((sobelxy,scharrxy,laplacian))
# 在名为'window1'的窗口中显示处理后的梯度图像
cv2.imshow('window1', res)
# 等待按键事件,0表示无限期等待
key = cv2.waitKey(0)
# 检查按下的键是否是'q',如果是则销毁所有窗口
# 0xFF是掩码,用于确保只检查最低8位
if key & 0xFF == ord('q'):  
    print("准备销毁窗口")
    cv2.destroyAllWindows()

原图和提取效果

相关推荐
another heaven5 分钟前
【深度学习 超参调优】lr0与lrf 的关系
人工智能·深度学习
放下华子我只抽RuiKe56 分钟前
深度学习全景指南:硬核实战版
人工智能·深度学习·神经网络·算法·机器学习·自然语言处理·数据挖掘
天空之城_tsf21 分钟前
通用多模态检索——大模型微调
人工智能·深度学习·计算机视觉
财迅通Ai27 分钟前
天立国际携手电子科技大学对话凯文・凯利,共探科技与教育未来
人工智能·科技·天立国际控股
zhojiew1 小时前
在RAG系统中对FAISS,HNSW,BM25向量检索引擎选型的问题
人工智能·机器学习·faiss
深藏功yu名1 小时前
Day24:向量数据库 Chroma_FAISS 入门
数据库·人工智能·python·ai·agent·faiss·chroma
了一梨1 小时前
[T113] 交叉编译 OpenCV 4.5.2 + face 模块
linux·笔记·opencv
OpenBayes贝式计算1 小时前
教程上新|低门槛部署英伟达最新 Physical AI 模型,覆盖人形机器人/人体运动生成/扩散模型微调等
人工智能·深度学习·机器学习
3DVisionary1 小时前
突破3C质检产能瓶颈:XTOM蓝光扫描仪配合自动化转台实现精密件批量检测
运维·人工智能·自动化·xtom扫描仪·自动化检测·消费电子质检·良率控制
子木HAPPY阳VIP1 小时前
Ubuntu 22.04 VMware 设置固定IP配置
人工智能·后端·目标检测·机器学习·目标跟踪