opencv使用sobel算子提取图像的边缘信息

本文介绍如何使用Python和OpenCV库进行图像边缘检测。通过Sobel算子获取水平和垂直方向的边缘梯度,然后结合两个方向的梯度形成完整的图像梯度。最后展示了处理后的图像效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


import cv2
import numpy as np

img = cv2.imread('../data/ren.png', 0)


sobelx = cv2.Sobel(img, cv2.CV_64F, 1, 0)  # 获取水平方向边缘梯度,第二个参数表示获取所有边缘信息不要遗漏
sobely = cv2.Sobel(img, cv2.CV_64F, 0, 1)  # 获取垂直方向边缘梯度,第二个参数表示获取所有边缘信息不要遗漏

sobelx = cv2.convertScaleAbs(sobelx)  # 取绝对值
sobely = cv2.convertScaleAbs(sobely)  # 取绝对值

dst = cv2.addWeighted(sobelx, 1, sobely, 1, 0)  # 将两个方向的梯度结合成新的一个完整图像的梯度

cv2.imshow('dst', dst)
cv2.waitKey()
cv2.destroyAllWindows()

cv2.imwrite('../data/sobel.jpg', dst)

原图
在这里插入图片描述
在这里插入图片描述

2020年,我想给自己好好去爱一次的机会

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值