iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python+OpenCV之图像梯度详解
  • 823
分享到

Python+OpenCV之图像梯度详解

2024-04-02 19:04:59 823人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录1. Sobel算子1.1 Sobel介绍1.2 横向Sobel算子1.3 纵向Sobel算子1.4 合并横纵向的方法提取更好的边缘的结果1.5 利用1.3方法绘制素描风格2.

1. Sobel算子

OpenCV系列—本文底页有多个常用方法链接

1.1 Sobel介绍

cv2.Sobel(src, ddepth, dx, dy, ksize)

  • ddepth:图像的深度
  • dx和dy分别表示水平和竖直方向
  • ksize是Sobel算子的大小

import cv2  # opencv读取的格式是BGR


def cv_show(img, name):
    cv2.imshow(name, img)
    cv2.waiTKEy()
    cv2.destroyAllwindows()


img = cv2.imread('../img/pie.png', cv2.IMREAD_GRAYSCALE)
cv2.imshow("img", img)
cv2.waitKey()
cv2.destroyAllWindows()

pie.png原图(右击另存为下载):

1.2 横向Sobel算子

采用上述公式中的 G x G_{x} Gx​滤波器扫描整张图,提取了左右两边有梯度差的位置,但是横向看圆的上顶端和下顶端的梯度不明显所以呈现图片如下上下端为虚线的圆

sobelx = cv2.Sobel(img, cv2.CV_64F, 1, 0, ksize=3)
cv_show(sobelx, 'sobelx')

结果如下:

白-黑是正数,黑-白就是负数了,所有的负数会被截断成0,所以要取绝对值。

sobelx = cv2.Sobel(img, cv2.CV_64F, 1, 0, ksize=3)
sobelx = cv2.convertScaleAbs(sobelx)
cv_show(sobelx, 'sobelx')

加入绝对值后,梯度结果就可以有一个完整的圆:

1.3 纵向Sobel算子

采用上述公式中的 G y G_{y} Gy​滤波器扫描整张图,提取了上下两边有梯度差的位置,但是纵向看圆的左顶端和右顶端的梯度不明显所以呈现图片如左右端为虚线的圆

sobely = cv2.Sobel(img, cv2.CV_64F, 0, 1, ksize=3)
sobely = cv2.convertScaleAbs(sobely)
cv_show(sobely, 'sobely')

1.4 合并横纵向的方法提取更好的边缘的结果

将横向梯度提取滤波器 Gx与纵向梯度提取滤波器Gy相加,即可得到效果较好的圆的边缘梯度信息

sobelxy = cv2.addWeighted(sobelx, 0.5, sobely, 0.5, 0)
cv_show(sobelxy, 'sobelxy')

不推荐

sobelxy = cv2.Sobel(img, cv2.CV_64F, 1, 1, ksize=3)
sobelxy = cv2.convertScaleAbs(sobelxy)
cv_show(sobelxy, 'sobelxy')

结果显示,相对于分开使用横纵向算子边缘重影严重:

1.5 利用1.3方法绘制素描风格

lena.jpg原图,另存为保存:

import cv2  # opencv读取的格式是BGR


img = cv2.imread('../img/lena.jpg', cv2.IMREAD_GRAYSCALE)
sobelx = cv2.Sobel(img, cv2.CV_64F, 1, 0, ksize=3)
sobelx = cv2.convertScaleAbs(sobelx)
sobely = cv2.Sobel(img, cv2.CV_64F, 0, 1, ksize=3)
sobely = cv2.convertScaleAbs(sobely)
sobelxy = cv2.addWeighted(sobelx, 0.5, sobely, 0.5, 0)
cv_show(sobelxy, 'sobelxy')

2. Scharr算子

import cv2  # opencv读取的格式是BGR


img = cv2.imread('../img/lena.jpg', cv2.IMREAD_GRAYSCALE)

scharrx = cv2.Scharr(img, cv2.CV_64F, 1, 0)
scharry = cv2.Scharr(img, cv2.CV_64F, 0, 1)
scharrx = cv2.convertScaleAbs(scharrx)
scharry = cv2.convertScaleAbs(scharry)
scharrxy = cv2.addWeighted(scharrx, 0.5, scharry, 0.5, 0)

二阶动量对纹理细节区分更加丰富结果图如下:

3. Laplacian算子

import cv2  # opencv读取的格式是BGR


img = cv2.imread('../img/lena.jpg', cv2.IMREAD_GRAYSCALE)

laplacian = cv2.Laplacian(img,cv2.CV_64F)
laplacian = cv2.convertScaleAbs(laplacian)   

需要配合其他操作共同使用,单个使用的效果不如上面两个算子,结果图如下:

到此这篇关于python+OpenCV之图像梯度详解的文章就介绍到这了,更多相关OpenCV图像梯度内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Python+OpenCV之图像梯度详解

本文链接: https://www.lsjlt.com/news/120619.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python+OpenCV之图像梯度详解
    目录1. Sobel算子1.1 Sobel介绍1.2 横向Sobel算子1.3 纵向Sobel算子1.4 合并横纵向的方法提取更好的边缘的结果1.5 利用1.3方法绘制素描风格2. ...
    99+
    2024-04-02
  • OpenCV学习之图像梯度算子详解
    目录1.Sobel算子2.Scharr算子3.laplacian算子本文是OpenCV图像视觉入门之路的第12篇文章,本文详细的介绍了图像梯度算子的各种操作,例如:Sobel算子Sc...
    99+
    2023-02-15
    OpenCV图像梯度算子 OpenCV 算子 OpenCV图像
  • python中的opencv 图像梯度
    目录图像梯度Sobel理论基础计算水平方向偏导数的近似值计算垂直方向偏导数的近似值Sobel算子及函数使用方向计算x方向和y方向的边缘叠加Scharr算子及函数使用Sobel算子和S...
    99+
    2024-04-02
  • python中的opencv图像梯度实例分析
    本文小编为大家详细介绍“python中的opencv图像梯度实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“python中的opencv图像梯度实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。图像梯...
    99+
    2023-06-30
  • Python+OpenCV之图像轮廓详解
    目录1. 图像轮廓1.1 findContours介绍1.2 绘制轮廓1.3 轮廓特征2. 轮廓近似2.1 轮廓2.2 边界矩形2.3 外界多边形及面积1. 图像轮廓 1.1 fin...
    99+
    2024-04-02
  • OpenCV 图像梯度的实现方法
    目录概述梯度运算礼帽黑帽Sobel 算子计算 x计算 y计算 x+y融合概述 OpenCV 是一个跨平台的计算机视觉库, 支持多语言, 功能强大. 今天小白就带大家一起携手走进 Op...
    99+
    2024-04-02
  • OpenCV-Python实现图像梯度与Sobel滤波器
    目录图像梯度Sobel滤波器图像梯度 图像梯度计算的是图像变化的速度。对于图像的边缘部分,其灰度值变化较大,梯度值也较大;相反,对于图像中比较平滑的部分,其灰度值变化较小,相应的梯度...
    99+
    2024-04-02
  • OpenCV半小时掌握基本操作之图像梯度
    目录概述梯度运算礼帽黑帽Sobel 算子计算 x计算 y计算 x+y融合【OpenCV】⚠️高手勿入! 半小时学会基本操作⚠️图像...
    99+
    2024-04-02
  • OpenCV图像处理之图像拼接详解
    目录图像拼接技术一、需求分析二、具体步骤三、代码实现图像拼接技术 一、需求分析 将下面两张图像进行拼接 拼接得到一张完整的图像 二、具体步骤 1.选择特征点 //1、选...
    99+
    2022-11-13
    OpenCV 图像处理 图像拼接 OpenCV 图像拼接 OpenCV 图像处理
  • OpenCV图像梯度算子方法怎么使用
    本篇内容介绍了“OpenCV图像梯度算子方法怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.Sobel算子Sobel算子是一种图像...
    99+
    2023-07-05
  • OpenCV-Python图像轮廓之轮廓特征详解
    目录前言一、轮廓的矩二、轮廓的面积三、轮廓的长度四、轮廓的近似多边形五、轮廓的凸包六、轮廓的直边界矩形七、轮廓的旋转矩形八、轮廓的最小外包圆九、轮廓的拟合椭圆十、轮廓的拟合直线十一、...
    99+
    2024-04-02
  • Python-OpenCV教程之图像的位运算详解
    1、按位取反bitwise_not() 按位取反就是将数值根据每个bit位1变0,0变1,比如0xf0按位取反就变成了0x0f,如果是uint8类型的数据,取反前...
    99+
    2024-04-02
  • Python图像运算之图像灰度直方图对比详解
    目录一.灰度增强直方图对比二.灰度减弱直方图对比三.图像反色直方图对比四.图像对数变换直方图对比五.图像阈值化处理直方图对比六.总结一.灰度增强直方图对比 图像灰度上移变换使用的表达...
    99+
    2024-04-02
  • Python图像运算之图像灰度线性变换详解
    目录一.灰度线性变换二.图像灰度上移变换三.图像对比度增强变换四.图像对比度减弱变换五.图像灰度反色变换六.总结一.灰度线性变换 图像的灰度线性变换是通过建立灰度映射来调整原始图像的...
    99+
    2024-04-02
  • OpenCV图像缩放之cv.resize()函数详解
    目录系列前言API函数详解参数列表缩放方式其一缩放方式其二两种方式的优先级关于插值方式扩展 —— 相关函数总结系列前言 这个系列是我第一个想要更下去的系列。每...
    99+
    2024-04-02
  • Opencv图像处理之详解掩膜mask
    1.在OpenCV中我们经常会遇到一个名字:Mask(掩膜)。很多函数都使用到它,那么这个Mask到底什么呢? 2.如果我们想要裁剪图像中任意形状的区域时,应该怎么办呢? 答案是,...
    99+
    2024-04-02
  • OpenCV图像卷积之cv.filter2D()函数详解
    目录APIC++Python函数详解HelloWorld参数详解srcddepthkernel & anchordeltaborderType扩展——...
    99+
    2024-04-02
  • Python图像运算之图像灰度非线性变换详解
    目录一.图像灰度非线性变换二.图像灰度对数变换三.图像灰度伽玛变换四.总结一.图像灰度非线性变换 原始图像的灰度值按照DB=DA×DA/255的公式进行非线性变换,其代码...
    99+
    2024-04-02
  • opencv-python基本图像处理详解
    目录一、使用matplotlib显示图1、显示热量图 2、显示灰度图二、使用cv.imread显示图像1、显示灰度图像总结一、使用matplotlib显示图 impor...
    99+
    2024-04-02
  • 超详细注释之OpenCV旋转图像任意角度
    上一篇博客介绍了 如何使用Python,OpenCV上下左右(或任意组合)平移图像。这篇博客将介绍如何使用OpenCV旋转图像任意角度。并演示如何使用imutils库中的两个函数im...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作