传统图像处理算法总结

2023-10-26

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);
输入图像须为单通道

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

传统图像处理算法总结 的相关文章

  • R2_A_Taming the Herd

    题面 Taming the Herd Early in the morning Farmer John woke up to the sound of splintering wood It was the cows and they we
  • java中值传递和引用传递

    目录 值传递 引用传递 Java 中有两种数据类型 请谈一下值传递与引用传递 Java 中只有值传递么 值传递 package com github hcsp public class Main public static void mai
  • JAVA单元测试框架-6-Enable priority

    1 enabled属性 在Testng中 如果方法前面添加了 Test注释 然后没有其他的属性 那么默认这个用例会被自动运行 当测试用例没有书写完成 或者不想测试时 可以采用注解 Test enable false 来禁止测试用例的执行 E
  • 如何自学图像编程

    如何自学图像编程 现在 图像类信息越来越多了 对图像的编程需求也越来越多 图像类项目的特点是性价比高 单行代码的价格一般是普通的程序的10倍 每行代码能够卖几块钱 很多人把目光放在这个上面 刚才又有网友咨询 做图像要看些什么书 结合我的自学
  • VSCode打开多个文件时实现标签栏多行显示

    默认情况下 VSCode的标签栏是滚动式的 当打开多个文件时是在同一行中显示的 想要选择查看某个文件时很不方便 如果想要实现多行显示标签页 也是可以的 具体方法如下 操作步骤 1 安装Custom CSS and JS Loader插件 2
  • 相关子查询和不相关子查询

    相关子查询 比如 select t id t name t pass from student t where 80 lt select f score from f where f id t id and f name xxx 这就是1个
  • AICG,人工智能自动生成内容——根据文本生成图像,视频,音频

    文章目录 1 什么是AICG 2 Text2Video 3 Text2Image 4 Text2Audio 5 AICG的发展趋势 1 什么是AICG 什么是AICG AICG是指人工智能自动生成内容 通过算法模型 将文本转化为图像 音频
  • [原]通过GitHub Pages建立个人站点(详细步骤)

    1 Git简介 2 为什么使用Github Pages 3 创建Github Pages 3 1 安装git工具 3 2 两种pages模式 3 3 创建步骤 3 4 常用命令 4 使用Jekyll搭建博客 4 1 什么是jekyll 4
  • 【微信小程序】wx.login 和 wx.getUserProfile 同时使用问题

    场景 在使用微信登录时 通常会在调用 wx login 获取 code 后再通过 wx getUserProfile 获取 iv 和 encryptedData 加密数据 一起发到后端进行登录验证 但是 在实际使用中如果在 wx login
  • HTML+CSS实现按钮居中

    居中的方式有很多 这里以button为例 它是一个行内块级元素display inline block 所以处理方式很简单 可以用以下两种方式 方式一 div style text align center div
  • 1116. 打印零与奇偶数

    现有函数 printNumber 可以用一个整数参数调用 并输出该整数到控制台 例如 调用 printNumber 7 将会输出 7 到控制台 给你类 ZeroEvenOdd 的一个实例 该类中有三个函数 zero even 和 odd Z
  • 数据库SQL优化大总结之 百万级数据库优化方案

    网上关于SQL优化的教程很多 但是比较杂乱 近日有空整理了一下 写出来跟大家分享一下 其中有错误和不足的地方 还请大家纠正补充 这篇文章我花费了大量的时间查找资料 修改 排版 希望大家阅读之后 感觉好的话推荐给更多的人 让更多的人看到 纠正
  • 【Xilinx Vivado时序分析/约束系列3】FPGA开发时序分析/约束-保持时间

    目录 基本概念 数据结束时间 Data finish time 时钟到达时间 Clock arrival time 保持时间门限 保持时间余量 Hold Slack 往期系列博客 基本概念 数据结束时间 Data finish time 之
  • win10+中标麒麟双系统安装步骤

    win7 10 中标麒麟双系统安装步骤 场景要求 联想启天M415台机出厂预装的是win10 现在要改成win7和中标麒麟7 0双系统 开机在选择系统界面要有两个系统选择 并且默认进入win7 注 先安装win7 再安装中标麒麟 一开始是用
  • MySQL--order by升序与降序、count计数与子查询

    MySQL order by升序与降序 count计数与子查询 1 创建表格 2 题目部分 1 升序与降序 order by 2 count 计数 3 子查询 3 文末彩蛋 轻松一刻 更多关于数据库知识请加关注哟 若需联系和想安装MySQL
  • 打印预览的时候,总是会多于一个空白页,怎么办?

    media print printTest 要打印的区域 display block width 100 height auto overflow hidden 在页面内加入此样式即可
  • PyTorch-01初见

    PyTorch 01初见 同类框架 PyTorch生态 PyTorch能做什么 1 GPU加速 import torch import time print torch version print torch cuda is availab
  • 零基础!搭建好本地的ChatGPT!

    当搭建好本地的GPT 你可以充分利用OpenAI的功能 无需使用任何魔法 并且免去了许多烦恼和难题 通过魔法访问gpt遇到过很多问题吗 以下是你搭建的本地GPT的一些关键特点 功能全面 你的本地GPT能够使用OpenAI的全部功能 让你体验
  • 11 前端模块化

    文章目录 为什么有前端模块化 以前的解决办法 了解CommonJS es6的模块化 export 导出 import 导入 为什么有前端模块化 首先 如果多人合作开发一个项目 你的a js用了一个变量a 你同事的b js也用了一个变量a 那

随机推荐

  • mybatis学习文档

    mybatis 9 28 环境 JDK1 8 mysql 8 0 16 maven3 6 1 IDEA 回顾 JDBC mysql jave基础 Maven junit 1 简介 1 1 什么是mybatis mybatis是支持普通SQL
  • StackExchange.Redis加锁机制实例

    1 redis下载安装 Github下载地址 https github com MicrosoftArchive redis releases 安装过程不做写明 1 VS引用StackExchange Redis 通过 工具 库程序包管理器
  • 软件测试 - sql - 与数据对话的语言

    初识数据库 一 数据库简介 1 1 常见数据库 1 2 数据库模型 1 3 关系型数据库 二 软件的安装与使用 mysql navicat 2 1 安装 2 2 启动关闭mysql服务 2 3 mysql连接navicat 三 数据库基本概
  • clickhouse 数据模型之有序漏斗分析(windowFunnel)

    什么是有序漏斗 有序漏斗需要满足所有用户事件链上的操作都是逡巡时间先后关系的 且漏斗事件不能有断层 触达当前事件层的用户也需要经历前面的事件层 介绍 windowFunnel 搜索滑动时间窗中的事件链 并计算从链中发生的最大事件数 该函数采
  • vs2010 内置了可应用于流的utf8和utf16的编码

    std wifstream is is open T E utf8 txt std ios base binary UTF 8编解码的关健代码 is imbue std locale std locale classic new std c
  • TCP/IP常见面试问题

    TCP IP常见面试问题 1 OSI七层协议以及四层协议 实际使用时只包含四层协议 从上到下依次是 应用层 http 传输层 tcp udp 网络层 ip 网络接口层 以太网协议 2 在网络中具体的传输过程 从上图可见传输的数据每经过一层
  • 【毕业论文】

    博客主页 肩匣与橘 欢迎点赞 收藏 留言 如有错误敬请指正 本文由肩匣与橘编写 首发于CSDN 生活依旧是美好而又温柔的 你也是 基于Unity3D引擎的冒险游戏的设计与实现 前言 摘要 Abstract 1 绪论 1 1 选题背景 1 2
  • rust物品图标_《腐蚀rust》全新XP建造系统图文介绍

    腐蚀rust 全新XP建造系统图文介绍 2016 06 23 15 05 28来源 贴吧编辑 评论 0 腐蚀rust 出了一个新的建造系统 XP建造系统 小编带来相关介绍 一起看一下吧 XP系统在测试服不断的更新完善 现在已经有了比较清晰的
  • 【docker】docker学习(4)——docker-compose常用语法与编写实战

    大家好 我是好学的小师弟 今天和大家分享下docker compose的一些常用语法和编写实战 docker compose是一个二进制文件 我们通常都是通过github把它下载下来 然后给他执行的权限 下载docker compose 在
  • 服务器中激活刚安装好的anaconda

    在服务器安装anaconda的过程中 最后一步是初始化 选择yes 然后在命令行输入conda info envs 发现conda not found 是因为conda环境未激活 此时直接输入source bashrc 即可成功激活环境 一
  • element-ui表格+分页器数据分页展示

  • SpringBoot从0到实战8:简单使用Swagger生成接口开发文档

    初识Swagger Swagger 是一个规范和完整的框架 广泛用于生成 描述 调用和可视化 RESTful 风格的 Web服务 总体目标是使客户端和文件系统作为服务器以相同速度更新 文件的方法 参数和模型紧密集成到服务器端的代码 允许AP
  • 测量学4_距离测量

    测量学 lesson 4 距离测量是确定地面点位时的基本测量工作之一 距离测量的方法有钢尺量距 视距测量和电磁波测距等 距离测量 钢尺量距 利用卷钢尺直接沿地面丈量距离 受地形影响较大 仅用于平坦地区的近距离测量 地面上两点之间距离较远时
  • Windbg+VMware双机调试/1394/串口/常见问题处理+下载符号文件离线包

    目录 1 调试工具VisualDDK 2 Vista以下的版本系统设置 3 Vista以上的版本系统设置 4 1394火线调试 5 使用串口线双机调试 6 调试过程中出现的问题及解决方案 7 快速下载符号文件离线包 1 调试工具Visual
  • SQL IF语句实际应用--返回输出

    SQL IF语句输出 SQL IF语句我们有时会用到用到这个通常是对某个属性进行判断操作 类似我们编程那种三元表达式一样 但有时候业务上不会让你去简简单单去判断操作 还会让你把结果返回过去 通过接口展示出去在前端 你写一个带有if的查询结果
  • B tree、B- tree、B+ tree、B*tree

    目录 1 B tree B tree 2 B tree B 树 2 1为什么需要B 树 B 树比B树更好呢 2 1数据库索引采用B 树的主要原因 3 B tree B 树 4 小结 1 B tree B tree B树 B tree 是一种
  • Pytorch-GPU配置

    自己电脑Window 10下pytorch GPU的配置 CUDA 10 1 cuDNN v7 6 4 pytorch 1 4 参考 1 Windows10安装cuda cudnn pytorch jupyter fastai 2 wind
  • C#系列-基础

  • 理解广度优先遍历(持续更新)

    文章的目录如下方便翻阅 广度优先搜索 BFS 如何实现广度优先搜索 简单的描述广度优先搜索的大致过程 下面结合例题理解广度优先搜索 广度优先遍历在树中的应用 广度优先遍历在数组中的应用 last 广度优先搜索 BFS 如何理解广度优先搜索
  • 传统图像处理算法总结

    1 图像滤波 目的 保证图像细节特征的条件下抑制图像噪声 1 1 线性滤波 1 11 方框滤波 原图像与内核的系数加权求和 方框滤波的核 normalize true 时 方框滤波就变成了均值滤波 也就是说 均值滤波是方框滤波归一化 nor