OpenCV—Sobel边缘检测的python代码实现

这篇具有很好参考价值的文章主要介绍了OpenCV—Sobel边缘检测的python代码实现。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、前言

二、主要参数

三、代码实现及效果展示


一、前言

计算机视觉图像处理中,边缘通常包含了有关对象轮廓和结构的重要信息。OpenCV 是一个流行的计算机视觉库,它提供了许多用于边缘检测的工具,其中之一就是Sobel算子。

什么是Sobel算子?

Sobel算子是一种基于卷积的边缘检测算法,它用于检测图像中的水平和垂直边缘。Sobel算子的核(kernel)是一个3x3的矩阵,分别对图像的水平和垂直方向进行卷积操作,从而得到水平和垂直边缘的近似梯度信息。这些梯度信息可以用来确定图像中的边缘位置。

具体原理可查看我的另一篇博客:sobel算子的原理

二、主要参数

cv2.Sobel(src, ddepth, dx, dy, dst, ksize, scale, delta, borderType)
  1. src: 输入图像,即需要进行边缘检测的源图像。

  2. ddepth: 输出图像的深度(数据类型)。它通常设置为-1,表示输出图像的深度与输入图像相同。如果你希望输出的图像是有符号整数(Sobel算子通常会生成负数值),可以选择 cv2.CV_16Scv2.CV_64F 作为输出深度。

  3. dxdy: 分别表示Sobel算子的水平和垂直导数的阶数。通常,dx 设置为1,表示计算水平方向的导数;dy 设置为0,表示不计算垂直方向的导数。你也可以将它们互换以计算垂直导数。

  4. dst: 输出图像,用于存储Sobel操作的结果。这是可选参数,可以省略。

  5. ksize: Sobel核的大小,通常是3,表示3x3的核。这个参数决定了Sobel算子的灵敏度。

  6. scale: 可选参数,用于缩放导数的值。通常设置为1。通过调整这个参数,你可以控制导数值的幅度。

  7. delta: 可选参数,添加到输出图像上的可选值。通常设置为0。

  8. borderType: 可选参数,边界处理的类型,可以是以下之一:

    • cv2.BORDER_DEFAULT: 默认边界处理方式,通常使用0值填充。
    • cv2.BORDER_CONSTANT: 使用用户指定的常数值进行填充。
    • cv2.BORDER_REPLICATE: 使用最边缘像素进行填充。
    • cv2.BORDER_REFLECT: 使用图像的反射边界像素进行填充。

三、代码实现及效果展示

方便理解,我们就用一个简单的图片:yuan.png:

python实现sobel,opencv,python,人工智能

使用Sobel算子进行水平边缘检测

# 导入OpenCV库
import cv2

# 从文件 'yuan.png' 中加载图像,并将其存储在 'yuan' 变量中
yuan = cv2.imread('yuan.png')

# 在窗口中显示加载的图像,窗口标题为 'yuan'
cv2.imshow('yuan', yuan)

# 等待100000毫秒(即100秒),或者等待用户按下键盘上的任意键,然后关闭图像窗口
cv2.waitKey(100000)

# 使用Sobel算子进行水平边缘检测
yuan_x_64 = cv2.Sobel(yuan, cv2.CV_64F, dx=1, dy=0)
# 这一步将默认的uint8数据类型更改为float64,以便能够保存负数的边缘强度

# 将Sobel结果的负数值转换为正数
yuan_x_full = cv2.convertScaleAbs(yuan_x_64)
# 这一步将负数值转换为其绝对值,以便在显示时产生正确的视觉效果

# 在新的窗口中显示Sobel边缘检测后的图像,窗口标题为 'yuan_x_full'
cv2.imshow('yuan_x_full', yuan_x_full)

# 等待100000毫秒(即100秒),或者等待用户按下键盘上的任意键,然后关闭图像窗口
cv2.waitKey(100000)

运行结果:

 python实现sobel,opencv,python,人工智能

 使用Sobel算子进行垂直边缘检测

# 导入OpenCV库
import cv2

# 从文件 'yuan.png' 中加载图像,并将其存储在 'yuan' 变量中
yuan = cv2.imread('yuan.png')

# 在窗口中显示加载的图像,窗口标题为 'yuan'
cv2.imshow('yuan', yuan)
cv2.waitKey(100000)

# 使用Sobel算子进行垂直边缘检测
yuan_y_64 = cv2.Sobel(yuan, cv2.CV_64F, dx=0, dy=1)
# 这一步将默认的uint8数据类型更改为float64,以便能够保存负数的边缘强度

# 将Sobel结果的负数值转换为正数
yuan_y_full = cv2.convertScaleAbs(yuan_y_64)
# 这一步将负数值转换为其绝对值,以便在显示时产生正确的视觉效果

# 在新的窗口中显示Sobel垂直边缘检测后的图像,窗口标题为 'yuan_y_full'
cv2.imshow('yuan_y_full', yuan_y_full)
cv2.waitKey(100000)

运行结果:

python实现sobel,opencv,python,人工智能

 合并这两个结果就可以得到完整的边缘检测图像:

import cv2

yuan = cv2.imread('yuan.png')

# 使用Sobel算子进行水平边缘检测
yuan_x_64 = cv2.Sobel(yuan, cv2.CV_64F, dx=1, dy=0)
# 这一步将默认的uint8数据类型更改为float64,以便能够保存负数的边缘强度

# 将Sobel水平边缘检测结果的负数值转换为正数
yuan_x_full = cv2.convertScaleAbs(yuan_x_64)
# 这一步将负数值转换为其绝对值,以便在显示时产生正确的视觉效果

# 使用Sobel算子进行垂直边缘检测
yuan_y_64 = cv2.Sobel(yuan, cv2.CV_64F, dx=0, dy=1)
# 这一步将默认的uint8数据类型更改为float64,以便能够保存负数的边缘强度

# 将Sobel垂直边缘检测结果的负数值转换为正数
yuan_y_full = cv2.convertScaleAbs(yuan_y_64)
# 这一步将负数值转换为其绝对值,以便在显示时产生正确的视觉效果

# 使用addWeighted函数将水平和垂直边缘检测结果叠加,创建合并的边缘检测图像
yuan_xy_full = cv2.addWeighted(yuan_x_full, 1, yuan_y_full, 1, 0)
# 这一步将两个图像叠加在一起,权重都为1,不做亮度调整

# 在新的窗口中显示合并的边缘检测图像,窗口标题为 'yuan_xy_full'
cv2.imshow('yuan_xy_full', yuan_xy_full)
cv2.waitKey(100000)

运行结果:

python实现sobel,opencv,python,人工智能

现在,我们拿一张复杂点的图片试试效果:

import cv2

# 从文件 'zl.png' 中加载灰度图像,并将其存储在 'zl' 变量中
zl = cv2.imread('zl.png', cv2.IMREAD_GRAYSCALE)
# 这里使用了 'cv2.IMREAD_GRAYSCALE' 标志,以确保图像以灰度模式加载

# 在新窗口中显示加载的灰度图像,窗口标题为 'yuantu'
cv2.imshow('yuantu', zl)
cv2.waitKey(100000)

# 使用Sobel算子进行水平边缘检测
zl_x_64 = cv2.Sobel(zl, cv2.CV_64F, dx=1, dy=0)
# 这一步将默认的int8数据类型更改为float64,以便能够保存负数的边缘强度

# 将Sobel水平边缘检测结果的负数值转换为正数
zl_x_full = cv2.convertScaleAbs(zl_x_64)
# 这一步将负数值转换为其绝对值,以便在显示时产生正确的视觉效果

# 使用Sobel算子进行垂直边缘检测
zl_y_64 = cv2.Sobel(zl, cv2.CV_64F, dx=0, dy=1)
# 这一步将默认的int8数据类型更改为float64,以便能够保存负数的边缘强度

# 将Sobel垂直边缘检测结果的负数值转换为正数
zl_y_full = cv2.convertScaleAbs(zl_y_64)
# 这一步将负数值转换为其绝对值,以便在显示时产生正确的视觉效果

# 使用addWeighted函数将水平和垂直边缘检测结果叠加,创建合并的边缘检测图像
zl_xy_sobel_full = cv2.addWeighted(zl_x_full, 1, zl_y_full, 1, 0)
# 这一步将两个图像叠加在一起,权重都为1,不做亮度调整

# 在新的窗口中显示合并的边缘检测图像,窗口标题为 'zl_xy_sobel_full'
cv2.imshow('zl_xy_sobel_full', zl_xy_sobel_full)
cv2.waitKey(100000)

运行结果:

python实现sobel,opencv,python,人工智能文章来源地址https://www.toymoban.com/news/detail-776489.html

到了这里,关于OpenCV—Sobel边缘检测的python代码实现的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包