C#+OpenCV基础(六)_均值中值高斯双边滤波
1.C#+OpenCV学习笔记(目录)-目录2.C#+OpenCV基础(一)_加载创建复制保存图片3.C#+OpenCV基础(二)_灰度化二值化4.C#+OpenCV基础(三)_修改高宽剪切拼接缩放5.C#+OpenCV基础(四)_旋转翻转透视6.C#+OpenCV基础(五)_添加边框
7.C#+OpenCV基础(六)_均值中值高斯双边滤波
8.C#+OpenCV基础(七)_图像金字塔9.C#+OpenCV基础(八)_获取修改图片亮度10.C#+OpenCV基础(九)_拆分合并图层11.C#+OpenCV基础(十)_灰度变化与直方图12.C#+OpenCV基础(十一)_图片基础计算13.C#+OpenCV基础(十二)_图片形态学计算14.C#+OpenCV基础(十三)_图片白平衡矫正15.C#+OpenCV基础(十四)_绘制像素、图形、文字16.C#+OpenCV基础(十五)_图像的基础分割方法17.C#+OpenCV基础(十六)_识别圆、直线、斑点、轮廓18.C#+OpenCV基础(十七)_计算图片相似度19.C#+OpenCV基础(十八)_模版匹配20.C#+OpenCV进阶(一)_人体识别21.C#+OpenCV进阶(二)_文字识别22.C#+OpenCV进阶(三)_操作摄像头与视频文件23.C#+OpenCV进阶(四)_录屏24.C#+OpenCV实战(一)_图片简易角度矫正25.C#+OpenCV实战(二)_春天转秋天26.C#+OpenCV实战(三)_玉米粒计数27.C#+OpenCV实战(四)_特定钢板缺陷检测一、知识
- 卷积核:用来对图像矩阵进行平滑的矩阵,也称为过滤器。
- 锚点:卷积核和图像矩阵重叠,进行内积运算,运算后锚点位置的像素点会被计算值代替。默认其中心点为锚点。
- 步长:卷积核沿着图像矩阵移动的方向。
- 内积:卷积核和图像矩阵对应像素点相乘,然后相加得到一个总和。
二、实现
1、均值滤波
/// <summary>
/// 均值滤波(模糊)
/// 线性模糊
/// </summary>
/// <param name="mat">图片</param>
/// <param name="ksize">滤波模版Kernel的尺寸;必须是正奇数,值越大越模糊;new Size(11, 11)</param>
/// <param name="anchor">锚点;默认为(-1,-1)即kernel的中心点</param>
/// <param name="borderType">外部像素的边界模式</param>
/// <returns></returns>
public static Mat Blur(Mat mat, Size ksize, Point? anchor = null, BorderTypes borderType = BorderTypes.Default)
{
Mat dstMet = new Mat();
Cv2.Blur(mat, dstMet, ksize, anchor, borderType);
return dstMet;
}
2、中值滤波
/// <summary>
/// 中值滤波(模糊)
/// 非线性模糊
/// 对去除斑点噪声和椒盐噪声很有用
/// </summary>
/// <param name="mat">图片</param>
/// <param name="ksize">滤波模版Kernel的尺寸;必须是正奇数,值越大越模糊;11</param>
/// <returns></returns>
public static Mat MedianBlur(Mat mat, int ksize)
{
Mat dstMet = new Mat();
Cv2.MedianBlur(mat, dstMet, ksize);
return dstMet;
}
3、高斯滤波
/// <summary>
/// 高斯滤波(模糊)
/// 线性模糊
/// </summary>
/// <param name="mat">图片</param>
/// <param name="ksize">滤波模版Kernel的尺寸;必须是正奇数,值越大越模糊;new Size(11, 11)</param>
/// <param name="sigmaX">X轴方向的标准差,值越大越模糊</param>
/// <param name="sigmaY">Y轴方向的标准差,值越大越模糊</param>
/// <param name="borderType">外部像素的边界模式</param>
/// <returns></returns>
public static Mat GaussianBlur(Mat mat, Size ksize, double sigmaX,
double sigmaY = 0, BorderTypes borderType = BorderTypes.Default)
{
Mat dstMet = new Mat();
Cv2.GaussianBlur(mat, dstMet, ksize, sigmaX, sigmaY, borderType);
return dstMet;
}
4、双边滤波
双边滤波(非线性模糊),原理为一个与空间距离相关的高斯函数与一个与灰度距离有关的高斯函数相乘。
案例:略
本文来自博客园,作者:꧁执笔小白꧂,转载请注明原文链接:https://www.cnblogs.com/qq2806933146xiaobai/p/18294405
合集:
C#+机器视觉OpenCV
分类:
C#+机器视觉OpenCV
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
2021-07-10 layui的table.render使用
2019-07-10 html根据下拉框选中的值修改背景颜色