前言

前面博客讲了矩阵之间的卷积操作,在图像处理中,使用一些标准的模板的卷积核与原图像进行运算,可以改变像素强度,从而影响周围其他像素的强度,常用于图像模糊、锐化及边缘检测等。

Sobel算子

1.Sobel算子主要用作边缘检测,在技术上,它是一离散性差分算子,用来运算图像亮度函数的灰度之近似值。在图像的任何一点使用此算子,将会产生对应的灰度矢量或是其法矢量。
Sobel算子的两个卷积核:

该算子包含两组3x3的矩阵,分别为横向及纵向,将之与图像作平面卷积,即可分别得出横向及纵向的亮度差分近似值。如果以A代表原始图像,Gx及Gy分别代表经横向及纵向边缘检测的图像灰度值,其公式如下:


2.Sobel算子API
(1)在OpenCV中的Sobel算子的API是Sobel(),函数原型如下:

C++: void Sobel (  InputArray src,OutputArray dst,int ddepth,int dx,  int dy,  int ksize=3,  double scale=1, double delta=0,  int borderType=BORDER_DEFAULT );

参数说明:
第一个参数,InputArray 类型的src,为输入图像,填Mat类型即可。
第二个参数,OutputArray类型的dst,即目标图像,函数的输出参数,需要和源图片有一样的尺寸和类型。
第三个参数,int类型的ddepth,输出图像的深度,支持如下src.depth()和ddepth的组合:
若src.depth() = CV_8U, 取ddepth =-1/CV_16S/CV_32F/CV_64F
若src.depth() = CV_16U/CV_16S, 取ddepth =-1/CV_32F/CV_64F
若src.depth() = CV_32F, 取ddepth =-1/CV_32F/CV_64F
若src.depth() = CV_64F, 取ddepth = -1/CV_64F
第四个参数,int类型dx,x 方向上的差分阶数。
第五个参数,int类型dy,y方向上的差分阶数。
第六个参数,int类型ksize,有默认值3,表示Sobel核的大小;必须取1,3,5或7。
第七个参数,double类型的scale,计算导数值时可选的缩放因子,默认值是1,表示默认情况下是没有应用缩放的。我们可以在文档中查阅getDerivKernels的相关介绍,来得到这个参数的更多信息。
第八个参数,double类型的delta,表示在结果存入目标图(第二个参数dst)之前可选的delta值,有默认值0。
第九个参数, int类型的borderType,我们的老朋友了(万年是最后一个参数),边界模式,默认值为BORDER_DEFAULT。这个参数可以在官方文档中borderInterpolate处得到更详细的信息。
(2)代码演示

void mySobel(Mat &src,Mat &abs_gradient_x,Mat &abs_gradient_y, Mat &dst3)
{Mat gradient_x, gradient_y;//求X方向梯度Sobel( src, gradient_x, CV_16S, 1, 0, 3, 1, 1, BORDER_DEFAULT );convertScaleAbs( gradient_x,  abs_gradient_x);Mat abs_x = abs_gradient_x.clone();putText(abs_gradient_x,"X Directional gradient",Point(50,60),FONT_HERSHEY_SIMPLEX,2,Scalar(255,23,0),2,8);//求Y方向梯度Sobel( src, gradient_y, CV_16S, 0, 1, 3, 1, 1, BORDER_DEFAULT );convertScaleAbs( gradient_y, abs_gradient_y );Mat abs_y = abs_gradient_y.clone();putText(abs_gradient_y,"Y Directional gradient",Point(50,60),FONT_HERSHEY_SIMPLEX,2,Scalar(255,23,0),2,8);//合并梯度addWeighted(abs_x, 0.5, abs_y, 0.5, 0, dst3 );putText(dst3,"Merging gradient",Point(50,60),FONT_HERSHEY_SIMPLEX,2,Scalar(255,23,0),4,8);
}

3.运行效果
(1)

(2)

(3)

OpenCV图像处理使用笔记(八)——Sobel算子相关推荐

  1. 2020.11.07 使用OpenCV进行图像边缘提取(Sobel算子)【OpenCV C++ Sobel】

    图像边缘提取,采用的算子为Sobel 使用API:Sobel()以及增强了权重的Scharr() 处理流程: 1.进行高斯滤波 2.转化为灰度图像 3.进行X,Y轴的Sobel处理 4.对X,Y处理后 ...

  2. opencv-python图像处理 ----图像梯度、Sobel算子

    一.图像的梯度处理 1.Sobel算子 梯度可以按照x方向或者y方向求梯度,其实就是在看像素点的差异变化情况,比如黑白物体的交界,其像素值变化差异是非常大的. 求梯度计算使用的函数就叫做Sobel算子 ...

  3. OpenCV图像处理学习十八,霍夫变换实现交通车道线检测

    一.霍夫变换 经典霍夫变换用来检测图像中的直线,后来霍夫变换经过扩展可以进行任意形状物体的识别,例如圆和椭圆.霍夫变换运用两个坐标空间之间的变换,将在一个空间中具有相同形状的曲线或直线映射到另一个坐标 ...

  4. OpenCV图像处理使用笔记(七)——卷积运算原理

    前言 1.在图像处理中,特别在深度学习图像处理,最常看到图像卷积操作,那什么是卷积呢,卷积就是两个原函数产生一个新的函数,两个函数之间的这种操作就称着卷积,在图像这里的图像卷积也用输入的图像矩阵与一个 ...

  5. OpenCV图像处理使用笔记(六)——图像滤波

    前言 1.图像滤波也叫图像模糊,是平滑图像像素常用处理的方式,通常是为了达到减少图像噪声和伪影,或者降低图像分辨率,OpenCV提供了常用的五种图像模糊操作. 2.我的这里演示的系统环境是Linux, ...

  6. OpenCV图像处理使用笔记(四)——图像融合

    前言常用 1.在OpenCV中定义了好多函数用来操作图像矩阵,有两个矩阵相加的,相减的,混合的,下面我使用QT加OpenCV演示图像融合这个函数. 2.我的IDE是Qt creator,OpenCV的 ...

  7. OpenCV图像处理使用笔记(五)——图像边界拓展

    前言 1.在OpenCV滤波和卷积算法中,在进行核运算的过程时候,矩阵边界拓展是一个非常重要的处理,OpenCV提供的函数copyMakeBorder()来拓展边界. 2.我的系统环境是Linux,加 ...

  8. OpenCV图像处理使用笔记(二)——图像矩阵的掩膜操作

    前言 1.数字图像处理中的掩膜的概念是起源于于PCB制版的过程,在半导体制造中,许多芯片工艺步骤采用光刻技术,用于这些步骤的图形"底片"称为掩膜(也称作"掩模" ...

  9. OpenCV图像处理使用笔记(一)——使用鼠标选取任何形状的ROI

    前言 1.在图像处理中,会用鼠标选择一个感兴趣的区域进行相关的操作,我这里演示如何用鼠标选择任何形状的ROI,就你Ps的抠图一样,使用鼠标左键选择一个任何形状的区域,生成新的图像. 2.我演示的代码环 ...

最新文章

  1. DenthDepth:深度估计(三维场景构建)——单目视觉挑战激光雷达
  2. Android之自定义控件一起制作自定义标签
  3. 如何使用CodeSmith批量生成代码
  4. 每个[NET]开发人员现在应该下载的十种必备工具
  5. 根据图片地址得到文件流
  6. 什么是协议转换器?协议转换器的定义
  7. 计算android view的FPS,使用Android SurfaceView的低FPS
  8. linux hive的作用,Hive的基本应用 - Hadoop和Hive的实践应用_服务器应用_Linux公社-Linux系统门户网站...
  9. 2021年中国宠物玩具与训练市场趋势报告、技术动态创新及2027年市场预测
  10. 我是如何在六个月内学会 Python 的?
  11. 浅析Comet技术在Java Web实时系统开发中的应用
  12. oracle中的删除与数据库中的回收站
  13. 互联网发展阶段的三阶段是什么?从门户到搜索,到移动互联网
  14. 命名实体消歧的代码实现
  15. 识读第三角视图(机械识图)
  16. 袋鼠!沃尔沃的无人车就是搞不定这种动物
  17. 网速慢的几种原因--冤枉的几天呀(网线的问题)
  18. 医疗器械软件网络安全相关
  19. 移动端GPGPU 架构
  20. Python之turtle库的学习与使用——画图

热门文章

  1. sql server insert 锁表_SQL简单优化
  2. 【数学与算法】二部图、匈牙利匹配、稳定婚配
  3. 【数学与算法】曲线上各点的曲率kappa和倾角theta
  4. Programming Computer Vision with Python (学习笔记九)
  5. Tomcat8源码编译及导入Eclipse中研究
  6. 《JAVA与模式》之状态模式
  7. 十个免费的WEB压力测试工具
  8. 通过索引优化含ORDER BY的MySQL语句
  9. 简明python教程 --C++程序员的视角(八):标准库
  10. Python爬虫入门(5):URLError异常处理