传统图像处理算法总结

传统图像处理算法总结1.图像滤波目的:保证图像细节特征的条件下抑制图像噪声。1.1线性滤波1.11方框滤波原图像与内核的系数加权求和方框滤波的核:normalize=true时,方框滤波就变成了均值滤波。也就是说,均值滤波是方框滤波归一化(normalized)后的特殊情况。方框滤波的缺点:丢失了图像的边缘信息。opencv函数:boxFilter(src,dst,-1,…

大家好,又见面了,我是你们的朋友全栈君。

1. 图像滤波

目的:保证图像细节特征的条件下抑制图像噪声。

1.1 线性滤波

1.11 方框滤波

原图像与内核的系数加权求和
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
方框滤波的核:
在这里插入图片描述
normalize = true 时,方框滤波就变成了均值滤波。也就是说,均值滤波是方框滤波归一化(normalized)后的特殊情况。

方框滤波的缺点:丢失了图像的边缘信息。

opencv 函数 :boxFilter(src, dst, -1, Size(10, 10));
效果图:
在这里插入图片描述

1.12 均值滤波

内核中心点的像素值为内核中所有点像素的平均值
均值滤波的核:
在这里插入图片描述在这里插入图片描述

均值滤波的缺点:在图像去噪的同时也破坏了图像的细节部分,使图像模糊。

opencv 函数 :blur(src, dst, Size(10, 10));
效果图:
在这里插入图片描述

1.13 高斯滤波

原图像与满足正态分布的内核做卷积
由于正态分布也被称为高斯分布,因此这项技术被称为高斯模糊。

高斯滤波的核:
在这里插入图片描述

高斯滤波的优点:对于 抑制服从正态分布的(高斯)噪声非常有效。

**opencv 函数: GaussianBlur(src, dst, Size(5, 5), 0, 0); **
// sigmaX 和 sigmaY 都是0,就由 ksize.width 和 ksize.height 计算出来
// Size w,h 必须为奇数

效果图:
在这里插入图片描述

1.2 非线性滤波

1.2.1 中值滤波

内核中心点的像素值为内核中所有点像素的中值。
均值滤波的核:

在这里插入图片描述
在这里插入图片描述
中值滤波的特点:对椒盐噪声表现较好,对高斯噪声表现较差。
椒盐噪声:又称脉冲噪声,它随机改变一些像素值,在二值图像上表现为使一些像素点变白,一些像素点变黑。而中值滤波则不受极大极小值影响
opencv 函数: medianBlur ( image, out, 7)

1.2.2 双边滤波

滤波器由两个函数构成,一个由几何空间距离决定滤波器系数,另一个由像素差值决定滤波器系数。
双边滤波的优点:保留边界的同时去除噪声。
opencv 函数:bilateralFilter (image, out, 100, 0, 0 ); 参数3:每个像素领域的直径d,参数4、5:颜色空间和坐标空间的sigma。

1.3 形态学滤波

1.3.1 腐蚀

操作过程:构建一个核,并指定核的锚点,用该核与图像卷积,计算核覆盖区域的像素点最小值,将其作为图像在锚点位置的像素值
效果:使暗的更暗

在这里插入图片描述

1.3.2 膨胀

操作过程:构建一个核,并指定核的锚点,用该核与图像卷积,计算核覆盖区域的像素点最大值,将其作为图像在锚点位置的像素值
效果:使亮的更亮
在这里插入图片描述

1.3.3 开运算

操作过程: 先腐蚀,再膨胀
效果:消除小物体。

1.3.4 闭运算

操作过程: 先膨胀,再腐蚀
效果:排除小型黑洞。

1.3.5 形态学梯度

操作过程: 膨胀 – 腐蚀
效果:保留物体边缘轮廓。

1.3.6 顶帽

操作过程: 原图 – 开运算
效果:背景提取。

1.3.7 黑帽

操作过程: 闭运算 – 原图
效果:轮廓提取。

2. 阈值化

2.1 阈值化的目的

对图像像素进行取舍,直接剔除一些低于或高于一定值的像素。

2.2 固定阈值函数

double threshold(InputArray src, OutputArray dst, double thresh, double maxval, int type)
thresh: 决策阈值的大小
maxval: 将大于thresh的值置为maxval值
type:二值化方法,常用THRESH_BINARY
二值化示例:threshold(img, result, 170, 255, CV_THRESH_BINARY);

3. 图像金字塔

3.1 高斯金字塔

3.1.1 向下采样

操作步骤:
①. 用高斯核对图像进行卷积操作。
②. 删除偶数行和列。
效果:
①. 图像缩小为原来的1/4。
②. 图像部分信息丢失,变模糊。

3.1.2 向上采样

操作步骤:
①. 将图像在每个方向上扩大为原来的二倍,新增的行和列用0填充。
②. 用高斯核进行卷积模糊操作。
效果:
①. 图像缩小为原来的4倍。
②. 图像部分信息丢失,比原图模糊。

3.2 拉普拉斯金字塔

3.2.1 求解方式

第 i 层 拉普拉斯金字塔 = 第 i 层高斯金字塔 – 其先下采样再上采样。
(拉普拉斯金字塔是通过源图像减去先缩小后再放大的图像的一系列图像构成的。)

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

3.2.2 拉普拉斯金字塔作用

可以获得高斯金字塔下采样再上采样中间丢失的图像信息。

3.3 resize函数

作用:完成图像缩放
函数参数:void resize(InputArray src, OutputArray dst, Size dsize, double fx=0, double fy=0, int interpolation=INTER_LINEAR )
fx、fy为缩放系数
interpolation: 插值方法
缩小图像一般用INTER_AREA – 区域插值(利用像素区域关系的重采样插值)
放大图像一般用INTER_LINEAR – 线性插值

4. 边缘检测

4.1 Sobel 算子

4.1.1 Sobel 计算流程

在这里插入图片描述在这里插入图片描述
Gx 用于检测横向灰度值,Gy 用于检测纵向灰度值
在这里插入图片描述
在这里插入图片描述

4.1.2 Sobel 函数

Sobel ( const cvArr* src, CvArr* dst, int xorder, int yorder, int aperture_size =3 )
xorder = 1则计算图像x方向导数,yorder = 1则计算图像y方向导数。aperture_size: sobel 核大小,只能为1, 3, 5, 7。
cvSobel( src, dstx, 1, 0, 7 ); //sobel
cvSobel( src, dsty, 0, 1, 7 );
cvAddWeighted(dstx, 0.5, dsty, 0.5, 0, dst);

4.1.3 Sobel的改进——Scharr 滤波器

Scharr( src_gray, grad_x, ddepth, 1, 0, scale, delta, BORDER_DEFAULT );
Scharr( src_gray, grad_x, ddepth, 0, 1, scale, delta, BORDER_DEFAULT );
在这里插入图片描述
Sobel 滤波器只支持 size = 3的核。

4.2 Laplacian算子(二阶微分算子)

4.2.1 Laplacian算子

在这里插入图片描述

4.2.1 Laplacian函数

Laplacian( src_gray, dst, ddepth, kernel_size, scale, delta, BORDER_DEFAULT );
src_gray: 输入图像须为单通道图像。
Laplacian(src,dst,CV_16S, 3);

4.3 Canny 算子

4.3.1 Canny 计算流程

①. 高斯滤波减少噪声
②. 利用sobel算子计算梯度幅值和方向
③. 非极大值抑制
④. 设置高低阈值(2:1 ~ 3:1)
case 1. 若像素值 > 高阈值, 该像素为边缘
case2. 若像素值 < 低阈值, 该像素不是边缘
case3. 若像素值在两者之间,该像素仅仅在连接到一个高于高阈值的像素时被保留。

4.3.2 非极大值抑制 ===== 》 保留局部像素最大值点

步骤:
①. 确定像素点C的灰度值在其8值邻域内是最大的。
②. 判断C在其梯度方向是否最大,即与dTmp1和dTmp2比较。
(如果C点灰度值小于这两个点中的任一个,那就说明C点不是局部极大值,那么则可以排除C点为边缘。)
③. 采用插值求解梯度方向与
g1和g2对dTmp1进行插值,根据g3和g4对dTmp2进行插值(以得到dTmp1、dTmp2两个位置处的像素值),这要用到其梯度方向,这也是Canny算法中要求解梯度方向矩阵Thita的原因(算法的第二步)。**
在这里插入图片描述

4.4 直方图均衡化

4.4.1 直方图均衡化目的

对图像进行非线性拉伸,使图像直方图分布均匀,常用于图像增强处理中。

4.4.2 直方图均衡化函数

equalizeHist(image, image);
输入图像须为单通道

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/145810.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 《王道操作系统》学习笔记总目录+思维导图[通俗易懂]

    《王道操作系统》学习笔记总目录+思维导图[通俗易懂]本篇文章是对《2021操作系统》所有知识点的笔记总结归档,会一直更新下去之后我也会写组成原理、计算机网络、数据结构与算法、Java、Linux等底层和应用层的技术文章,并总结目录希望在自己可以复习的同时,也能将这些知识点总结归纳分享给大家欢迎大家关注我的个人博客网站:www.bithachi.cn,一起交流学习。文章总目录:第1章计算机系统概述1.1操作系统的基本概念第1…

    2022年7月14日
    20
  • 10款滑动门代码_jquery 滑动门_js滑动门_tab滑动门_jquery 选项卡_js选项卡_tab选项卡效果(三)

    10款滑动门代码_jquery 滑动门_js滑动门_tab滑动门_jquery 选项卡_js选项卡_tab选项卡效果(三)jquerytab选项卡插件滑动选项卡淡隐淡现选项卡jquerytab选项卡插件轻量级tab选项卡插件支持鼠标滑过、点击、自动切换、数据回调等功能jquery选项卡插件jquerytab选项卡支持垂直选项卡滚动、水平选项卡滚动、自动选项卡切换等。jquerytab选项卡ajax选项卡静态选项卡鼠标点击选项卡鼠标滑过选项卡jquery图片延迟加载插件制作tab选项卡图片异步加载…

    2025年6月5日
    0
  • 卷积神经网络的网络结构_典型卷积神经网络结构

    卷积神经网络的网络结构_典型卷积神经网络结构GoogLeNet原文地址:GoingDeeperwithConvolutions:https://www.cv-foundation.org/openaccess/content_cvpr_2015/papers/Szegedy_Going_Deeper_With_2015_CVPR_paper.pdfGoogLeNet在2014年由ChristianSzegedy提出,它是一种全新的深度学习结构。GoogLeNet网络的主要创新点在于:提出Inception结构在多个尺寸上同时进行卷积再聚合;

    2022年8月14日
    4
  • scope=prototype有什么作用_prototype设计模式

    scope=prototype有什么作用_prototype设计模式@Scope(“prototype”)//多例模式

    2022年8月19日
    5
  • Mysql端口设置

    Mysql端口设置1.查看showglobalvariableslike’port’;2.修改修改配置文件(注意重启MySQL)

    2022年10月3日
    0
  • String,StringBuffer与StringBuilder的区别??

    String,StringBuffer与StringBuilder的区别??String字符串常量StringBuffer字符串变量(线程安全)StringBuilder字符串变量(非线程安全) 简要的说,String类型和StringBuffer类型的主要性能区别其实在于String是不可变的对象,因此在每次对String类型进行改变的时候其实都等同于生成了一个新的String对象,然后将指针指向新的String对象,所以经常改变内容的字

    2022年6月28日
    19

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号