Opencv4 c++ 自用笔记 04 图像滤波与边缘检测
图像滤波与边缘检测
直接采集到的图像可能带有噪声的干扰,因此去除噪声是图像预处理中十分重要的一步。图像滤波是图像噪声去除的重要方式。
图像卷积
卷积操作广泛应用于信号处理领域,而图像本质上可以视为一种二维信号数据。
卷积过程可以理解为一个卷积模板(卷积核)在图像上逐像素移动,对模板覆盖区域内的像素值进行加权求和,计算结果作为模板中心位置的输出值。
为避免卷积输出值超出数据表示范围,通常对卷积模板进行归一化处理,使模板中所有元素的和为1。
卷积运算所需函数如下:
filter2D(src, dst, ddepth, kernel, anchor=Point(-1, -1), delta, borderType=BORDER_DEFAULT);
src
与dst
为源图像和输出图像,ddepth
为输出图像的数据类型(深度)
kernel
为卷积模板矩阵,anchor
为模板中心,(-1, -1)表示模板中心位于模板的中心元素。
delta
为偏值,在计算中会将其加上
borderType
为像素外推法选择标志
示例:
#include<opencv2/opencv.hpp>
#include<iostream>
#include<stdio.h>
using namespace std;
using namespace cv;int main(void) {Mat img = imread("test.jpg");Mat gray;cvtColor(img, gray, COLOR_BGR2GRAY);Mat kernel = (Mat_<float>(3, 3) << 1, 2, 1,2, 0, 2,1, 2, 1);Mat kernel_norm = kernel/12; // 归一化Mat result, result_norm;filter2D(img, result,-1 , kernel);filter2D(img, result_norm, -1, kernel_norm);imshow("Original Image", img);imshow("Result Image", result);imshow("Result Image Normalized", result_norm);waitKey(0);return 0;
}
卷积提取特征原理
卷积核通过在图像上滑动,每次只关注一个小的局部区域(感受野),这使得它能够专注于图像中的小块区域,识别局部特征如边缘、角点、纹理等,同时避免全局干扰,不会被图像其他无关区域的信息干扰。
卷积过程本质上是模板匹配。卷积核与图像区域进行点乘求和,计算相似度,当图像区域与卷积核模式相似时,产生强烈的响应值,响应值的大小和位置表明了特征的强度和位置。
并且同一个卷积核在整个图像上共享权重参数,无论特征出现在图像的哪个位置,都能被同一个卷积核检测到,相比全连接层,大大减少了计算的参数数量,且对图像中目标的小幅移动具有一定的容忍度。
线性滤波
图像滤波的主要目的是去除不重要的信息,突出关键特征。主要应用包括:噪声消除和特征提取。
线性滤波操作与图像卷积操作过程相似,此时卷积模板称为滤波模板。
均值滤波
将模板中所有像素值的平均值作为模板中心的输出值。
优点:在像素值变换趋势一致时去除噪声影响。
缺点:缩小像素间的差距,使细节变模糊。
blur(src, dst, ksize, anchor=Point(-1, -1), borderType=BORDER_DEFAULT);
ksize
为滤波模板大小,anchor
为模板基准点
borderType
为像素外推法选择标志
示例:
#include<opencv2/opencv.hpp>
#include<iostream>
#include<stdio.h>
using namespace std;
using namespace cv;int main(void) {Mat img = imread("/home/bandiera/桌面/1/test.jpg");Mat gray;cvtColor(img, gray, COLOR_BGR2GRAY);imshow("Original Image", img);imshow("Gray Image", gray);Mat result1, result2;blur(img, result1, Size(13, 13));//size越大,结果越模糊blur(gray, result2, Size(13, 13));imshow("Blur Image", result1);imshow("Blur Gray Image", result2);waitKey(0);
}
方框滤波
方框滤波是均值滤波的一般形式,可以选择是否对求和结果进行归一化。
boxFilter(src, ast, ddepth, ksize, anchor, normalize, borderType);
normalize
是否进行归一化,默认为true
(此时等同于均值滤波)
当normalize
=false
时,直接输出像素值的和
高斯滤波
高斯滤波主要用于去除高斯噪声,其滤波模板的权重符合高斯分布。
GaussianBlur(src, dst, ksize, sigmaX, sigmaY, borderType);
sigmaX
为X方向高斯核的标准差,sigmaY
为Y方向的标准差,如果为0则等同sigmaX
。若二者均为0,则自动计算。
getGaussianKernel(ksize, sigma, ktype=CV_64F);
ksize
为滤波器尺寸,必须为正奇数,sigma
为标准差,ktype
为滤波器系数数据类型。
这个函数用于生成指定尺寸的高斯滤波器。
可分离滤波
此前的滤波函数使用的滤波器都是固定形式的滤波器,需要手动去调整滤波模板。故opencv4给出了根据根自定义滤波器实现滤波的函数。
滤波过程中不会对原图像进行修改,故滤波是一个并行过程。并且往不同方向分别滤波的结果与整体滤波的结果一致,故有可分离性。
对于某些滤波器,可以将二维滤波分解为两个一维滤波的组合,从而提高计算效率。
opencv4提供了可根据两个方向的滤波器进行联合滤波的函数,如下:
sepFilter2D(src, dst, ddepth. kernelX, kernelY, anchor, delta, borderType);
kernelX
为x方向的滤波器,kernelY
为y方向的滤波器
非线性滤波
非线性滤波的计算结果不是由滤波器内的像素值通过线性组合计算得到的,其过程可能包含排序、逻辑运算等。线性滤波只是令噪声更柔和,而不会完全去除噪声,此时使用非线性滤波的效果可能更好。
非线性滤波主要包含中值滤波和双边滤波。
中值滤波
中值滤波使用滤波器覆盖区域内所有像素值的中位数作为输出,对椒盐噪声具有良好的去除效果。
以滤波器范围内的所有像素值的中值作为输出。由于涉及排序,其处理时间较大。
medianBlur(src, dst, ksize);
ksize
为滤波器大小,只能为大于1的奇数
不能用于两通道和五通道及以上的Mat
双边滤波
双边滤波能够在去除噪声的同时保持边缘信息,是一种边缘保持滤波器。
bilateralFilter(src, dst, d, sigaColor, sigmaSpace, borderType);
d
为滤波过程中每个像素领域的直径,若为非正数,则由sigmaSpace
决定。建议为5
sigmaColor
为颜色空间滤波器的标准差值,参数越大,产生的半相等颜色区域越大。
sigmaSpace
为空间坐标滤波器的标准差值,参数越大,越远的像素会相互影响。
两个差值小于10时滤波效果弱,大于150时过强。
缺点:性能较差
边缘检测
边缘指像素灰度值突然发生变化的地方,可通过计算图像梯度寻找边缘。
计算得到的梯度可能是正数,也可能是负数。以下给出了求矩阵各元素绝对值的函数:
convertScaleAbs(src, dst, alpha = 1, bats = 0);
alpha
为缩放因子,默认参数为1,即不进行缩放
bats
为偏值,默认为不添加
Sobel算子
Sobel
算子是经典的边缘检测算子,可以检测水平和垂直方向的边缘。
Sobel(src, dst, ddepth, dx, dy, ksize=3, scale=1, delta=0, borderType);
dx
为X方向的差分阶数,dy
为Y方向的差分阶数
ksize
为算子大小,必须为1、3、5、7
scale
为缩放因子,delta
为偏置
一般情况下,差分阶数为1,ksize
为3;阶数为2,ksize
为5
Scharr算子
Sobel
对图像中较弱的边缘提取效果较差,故需要加宽像素间的差距
Scharr
算子对弱边缘的检测效果优于Sobel
算子,能够提供更高的检测精度。Scharr
滤波器尺寸固定为3*3。
Scharr(src, dst, ddepth, dx, dy, scale, delta, borderType);
同Sobel
,dx
、dy
不能同时为0
生成边缘检测滤波器
可以通过以下函数获得不同尺寸和阶次的Sobel或Scharr滤波器:
getDerivKernels(kx, ky, dx, dy, ksize, normalize, ktype);
kx
、ky
、dx
、dy
分别为行滤波器的输出矩阵、列滤波器的输出矩阵、X方向的导数阶次、Y方向的导数阶次
ksize
为滤波器大小,可选参数为FILTER_SCHARR
、1、3、5、7
normalize
为归一化
ktype
为滤波器系数类型
Laplacian算子(各项同性)
使用Laplacian算子提取边缘可以不分别检测X方向和Y方向,只需要一次边缘检测。Laplacian是一种二阶导数算子,对噪声敏感,故须配合高斯滤波。
L a p l a c i a n ( f ) = ∂ 2 f ∂ x 2 + ∂ 2 f ∂ y 2 Laplacian(f)=\frac{\partial^2 f}{\partial x^2}+\frac{\partial^2 f}{\partial y^2} Laplacian(f)=∂x2∂2f+∂y2∂2f
Laplacian(src, dst, ddepth, kssize=1, scale, delta, borderType);
ddepth
为输出图像深度,-1为自动设置
ksize
必须为正奇数
Canny算法(常用)
Canny
边缘检测算法是目前最优秀的边缘检测算法之一,能够识别强边缘和弱边缘,并基于连通性给出完整的边缘信息,抗噪声能力强。
其原理分为五个步骤:
1.使用高斯滤波平滑图像。
2.通过Sobel
算子计算各个方向的梯度,随后计算梯度的方向和幅值。
3.应用非极大值抑制算法消除边缘检测带来的杂散影响。
4.应用双阈值法划分强边缘和弱边缘。
5.消除孤立的弱边缘。
Canny(image,edges, threshold1, threshold2, apertureSize=3, L2gradient=false);
image
输入图像,必须是CV_8U
的单通道或三通道图像
edges
输出图像
threshold
滞后阈值
apertureSize Sobel
算子的直径
L2gradient
计算图像梯度幅值的方法
相关文章:
Opencv4 c++ 自用笔记 04 图像滤波与边缘检测
图像滤波与边缘检测 直接采集到的图像可能带有噪声的干扰,因此去除噪声是图像预处理中十分重要的一步。图像滤波是图像噪声去除的重要方式。 图像卷积 卷积操作广泛应用于信号处理领域,而图像本质上可以视为一种二维信号数据。 卷积过程可以理解为一…...

流媒体基础解析:音视频封装格式与传输协议
在视频处理与传输的完整流程中,音视频封装格式和传输协议扮演着至关重要的角色。它们不仅决定了视频文件的存储方式,还影响着视频在网络上的传输效率和播放体验。今天,我们将深入探讨音视频封装格式和传输协议的相关知识。 音视频封装格式 什…...

一个html实现数据库自定义查询
使用场景 应用上线后甲方频繁的找开发查询数据库数据,且没有固定的查询规律,产品经理也没有规划报表需求。 实现方案 后端开放自定义sql查询,屏蔽所有数据库的高危操作,将常用查询的sql放在一个html中的js中直接查询࿰…...
OCC笔记:TopoDS_Edge上是否一定存在Geom_Curve
1. 问题 写occt代码时,访问边的几何数据,通常有以下代码,若边不为空,BRep_Tool::Curve函数是否能返回Curve的有效对象指针呢? //其他略...const TopoDS_Edge& curEdge TopoDS::Edge(edgeExp.Current()); if( cu…...
Python aiohttp 全面指南:异步HTTP客户端/服务器框架
边写代码零食不停口 盼盼麦香鸡味块 、卡乐比(Calbee)薯条三兄弟 独立小包、好时kisses多口味巧克力糖、老金磨方【黑金系列】黑芝麻丸 边写代码边贴面膜 事业美丽两不误 DR. YS 野森博士【AOUFSE/澳芙雪特证】377专研美白淡斑面膜组合 优惠劵 别光顾写…...
更新已打包好的 Spring Boot JAR 文件中的 class 文件
# 1. 解压原始 JAR unzip -q original-app.jar -d temp # 2. 替换 class 文件 cp ~/projects/new-classes/*.class temp/BOOT-INF/classes/com/example/ # 3. 保留原始清单 cp temp/META-INF/MANIFEST.MF . # 4. 重新打包 jar -cf0m new-app.jar MANIFEST.MF -C temp/ . # …...
容器(如 Docker)中,通常不建议运行多个进程或要求进程必须运行在前台
在容器(如Docker)中,通常不建议运行多个进程或要求进程必须运行在前台,这与容器的设计理念、资源管理和生命周期管理机制密切相关。以下是具体原因和深入解析: 一、容器的设计理念:单一职责原则 容器的核…...
conda管理环境指令综合(随时更新)
创建环境和删除环境 #创建环境 conda create --name envname#删除环境 conda env remove --name envname克隆环境 # 查看现有环境列表 conda env list# 执行克隆操作 conda create --name 新环境名称 --clone 原环境名称# 示例:将名为"tf2"的环境克隆…...
从Java的JDK源码中学设计模式之装饰器模式
装饰器模式是一种极具弹性的结构型设计模式,它允许我们通过组合的方式动态扩展对象功能而无需修改原有结构。本文将通过JDK源码中的实际应用和通俗易懂的代码示例,带你深入了解这一强大模式的精髓。 装饰器模式核心原理 装饰器模式的核心思想ÿ…...

鸿蒙电脑会在国内逐渐取代windows电脑吗?
点击上方关注 “终端研发部” 设为“星标”,和你一起掌握更多数据库知识 10年内应该不会 用Windows、MacOS操作系统的后果是你的个人信息可能会被美国FBI看到,但绝大多数人的信息FBI没兴趣去看 你用某家公司的电脑系统,那就得做好被某些人监视的下场,相信…...

持续领跑中国异地组网路由器市场,贝锐蒲公英再次登顶销量榜首
作为国产远程连接SaaS服务的创领者,贝锐持续引领行业发展,旗下贝锐蒲公英异地组网路由器,凭借出色的技术实力和市场表现,斩获2024年线上电商平台市场销量份额中国第一的佳绩,充分彰显了其在网络解决方案与异地组网领域…...

Spring AI 系列3: Promt提示词
一、Promt提示词 Promt提示是引导 AI 模型生成特定输出的输入, 提示的设计和措辞会显著影响模型的响应。 在 Spring AI 中与 AI 模型交互的最低层级,处理提示有点类似于在 Spring MVC 中管理”视图”。 这涉及创建带有动态内容占位符的大段文本。 这些占…...
Nginx 的配置文件
核心概念: 指令 (Directives): 配置文件的基本构建块。每条指令以分号 ; 结束。指令可以设置参数(如 worker_processes auto;)。 上下文 (Contexts): 指令被组织在特定的块(用花括号 {} 包围)中,称为上下文…...

Redis:安装与常用命令
🌈 个人主页:Zfox_ 🔥 系列专栏:Redis 🔥 安装 Redis 使⽤apt安装 apt install redis -y⽀持远程连接 修改 /etc/redis/redis.conf 修改 bind 127.0.0.1 为 bind 0.0.0.0 修改 protected-mode yes 为 protected-mo…...
[原创](Windows使用技巧): Windwos11如何设置局域网共享访问? (多图详解)
[作者] 常用网名: 猪头三 出生日期: 1981.XX.XX 企鹅交流: 643439947 个人网站: 80x86汇编小站 编程生涯: 2001年~至今[共24年] 职业生涯: 22年 开发语言: C/C++、80x86ASM、Object Pascal、Objective-C、C#、R、Python、PHP、Perl、 开发工具: Visual Studio、Delphi、XCode、…...

Mac 芯片系列 安装cocoapod 教程
安装声明: 本人是在搭梯子的环境下安装成功,前提是必须安装好安装homebrew环境。 1.检测rudy的源 2.查看源(目的:检测rudy的源) gem sources - l 3.移除源(目的:移除rudy自带的源) gem sources --remove https://rubygems.org/ 4.更换源(目的:替换成国…...

智启未来:AI重构制造业供应链的五大革命性突破
一、需求预测:让供应链“未卜先知” 1.1 从经验判断到数据预言 传统供应链依赖人工分析历史数据,但面对市场波动、设备突发故障等不确定性,往往反应滞后。AI通过整合工业物联网(IIoT)传感器数据、生产排程、供应商交…...

Linux进程间通信----简易进程池实现
进程池的模拟实现 1.进程池的原理: 是什么 进程池是一种多进程编程模式,核心思想是先创建好一定数量的子进程用作当作资源,这些进程可以帮助完成任务并且重复利用,避免频繁的进程的创建和销毁的开销。 下面我们举例子来帮助理…...

解锁Java多级缓存:性能飞升的秘密武器
一、引言 文末有彩蛋 在当今高并发、低延迟的应用场景中,传统的单级缓存策略往往难以满足性能需求。随着系统规模扩大,数据访问的瓶颈逐渐显现,如何高效管理缓存成为开发者面临的重大挑战。多级缓存架构应运而生,通过分层缓存设…...

(纳芯微)NCA9548- DTSXR 具有复位功能的八通道 I²C 开关、所有I/O端子均可承受5.5V输入电压
深圳市润泽芯电子有限公司 推荐NOVOSENSE(纳芯微)品牌 NCA9548- DTSXR TSSOP-24封装 NCA9548- DTSXR 具有复位功能的八通道 IC 开关、所有I/O端子均可承受5.5V输入电压 产品描述 NCA9548是通过I2C总线控制的八路双向转换开关。 SCL / SDA上行数据分散到八对下行数据或通道。…...

013旅游网站设计技术详解:打造一站式旅游服务平台
旅游网站设计技术详解:打造一站式旅游服务平台 在互联网与旅游业深度融合的时代,旅游网站成为人们规划行程、预订服务的重要工具。一个功能完备的旅游网站,通过用户管理、订单管理等核心模块,实现用户与管理员的高效交互。本文将…...

2024 CKA模拟系统制作 | Step-By-Step | 12、题目搭建-创建多容器Pod
目录 免费获取题库配套 CKA_v1.31_模拟系统 一、题目 二、考点分析 1. 多容器 Pod 的理解 2. YAML 配置规范 3. 镜像版本控制 三、考点详细讲解 1. 多容器 Pod 的工作原理 2. 容器端口冲突处理 3. 资源隔离机制 四、实验环境搭建步骤 总结 免费获取题库配套 CKA_v…...

优化 Spring Boot API 性能:利用 GZIP 压缩处理大型有效载荷
引言 在构建需要处理和传输大量数据的API服务时,响应时间是一个关键的性能指标。一个常见的场景是,即使后端逻辑和数据库查询已得到充分优化,当API端点返回大型数据集(例如,数千条记录的列表)时࿰…...
PostgreSQL 修改表结构卡住不动
[] 查找卡住的进程 ID(PID) -- 查看当前所有数据库连接及进程信息 SELECTpid,usename,query,age(clock_timestamp(), query_start) AS query_duration FROMpg_stat_activity WHEREquery LIKE %ALTER TABLE%; -- 过滤出正在执行 ALTER TABLE 的语句今天遇…...

【C盘瘦身】给DevEco Studio中HarmonyOSEmulator(鸿蒙模拟器)换个地方,一键移动给C盘瘦身
文章目录 一、HarmonyOSEmulator的安装路径二、修改路径 一、HarmonyOSEmulator的安装路径 之前安装了华为的DevEco Studio,当时没注意,后来C盘告急,想着估计是鸿蒙的模拟器占用空间比较大,一检查还真是躺在C盘。路径如下&#x…...
AutoCompose - 携程自动编排【开源】
AutoCompose - 携程自动编排【开源】 AutoCompose是一款单事件驱动(无状态)的流程引擎。使用本框架,能够轻松实现复杂服务的自动化编排【零配置、零编码】,能够显著提高开发维护效率。支持同步编程、异步编程(已支持Co…...
mybatis和hibernate区别
MyBatis 和 Hibernate 都是 Java 生态中主流的持久层框架,但设计理念和适用场景有显著区别。以下是核心对比: 1. 本质区别 特性HibernateMyBatis框架类型全自动 ORM(对象关系映射)框架半自动 SQL 映射框架核心思想对象优先&#…...

ORACLE 缺失 OracleDBConsoleorcl服务导致https://xxx:port/em 不能访问
这个原因是,操作过一下 ORCL的服务配置变更导致的。 再PATH中添加个环境变量,路径如下 管理员权限运行cmd 等待创建完成 大概3分钟 查看服务 点击第一个访问,下图登录后的截图...
unix/linux source 命令,其历史争议、兼容性、生态、未来展望
现在把目光投向unix/linux source命令的历史争议、兼容性、生态和未来展望,这能让我们更全面地理解一个技术点在更广阔的图景中所处的位置。 一、历史争议与设计权衡 虽然 source (或 .) 命令功能强大且不可或缺,但在其发展和使用过程中,也存在一些微妙的争议或设计上的权衡…...
day42 简单CNN
目录 一、从图像分类任务谈起 二、CNN架构解剖实验室 2.1 卷积层:空间特征的魔法师 2.2 归一化层:加速收敛的隐形推手 2.3 激活函数:非线性的灵魂 三、工程实践避坑指南 3.1 数据增强工程 3.2 调度器工程实战 四、典型问题排查手册 …...