已解决
OpenCV12-图像卷积
来自网友在路上 165865提问 提问时间:2023-10-19 14:54:19阅读次数: 65
最佳答案 问答题库658位专家为你答疑解惑
OpenCV12-图像卷积
- 图像卷积
图像卷积
OpenCV中提供了filt2D()
函数用于实现图像和卷积模板之间的卷积运算:
void filter2D(InputArray src, // 输入图像OutputArray dst, // 输出图像int ddepth, // 输出图像数据类型(深度),当为-1时,根据输入图像类型自动选择。InputArray kernel, // 卷积核,CV_32FC1 Point anchor = Point(-1,-1), // 核的基准点,默认值代表内核基准点位于kernel的中心位置。double delta = 0, // 偏移值,卷积结果加上偏移值 int borderType = BORDER_DEFAULT // 像素边界外推标志
);
第6个参数是像素边界外推标志,在 图像几何变换 一文中讲解 wrapAffine()
仿射变换时第一次遇到,在这里我们体会到了什么是像素边界外推,就是对图像的边界,使用卷积核处理时,边界外面没有与卷积核对应的元素,这是如果要对边界元素卷积,则需要填充一些值,填充值的方法如下:
/*
BORDER_CONSTANT:用特定值填充,如用i填充:iiiiii|abcdefgh|iiiiiii
BORDER_REPLICATE:两端复制填充,如两端用a和h填充:aaaaaa|abcdefgh|hhhhhhh
BORDER_REFLECT:倒序填充
BORDER_WRAP:正序填充
BORDER_REFLECT_101:不包含边界值的倒序填充
BORDER_TRANSPARENT:随即填充
BORDER_REFLECT101、BORDER_DEFAULT:同BORDER_REFLECT_101
BORDER_ISOLATED:不关心感兴趣区域之外的部分
*/
enum BorderTypes {BORDER_CONSTANT = 0, //!< `iiiiii|abcdefgh|iiiiiii` with some specified `i`BORDER_REPLICATE = 1, //!< `aaaaaa|abcdefgh|hhhhhhh`BORDER_REFLECT = 2, //!< `fedcba|abcdefgh|hgfedcb`BORDER_WRAP = 3, //!< `cdefgh|abcdefgh|abcdefg`BORDER_REFLECT_101 = 4, //!< `gfedcb|abcdefgh|gfedcba`BORDER_TRANSPARENT = 5, //!< `uvwxyz|abcdefgh|ijklmno`BORDER_REFLECT101 = BORDER_REFLECT_101, //!< same as BORDER_REFLECT_101BORDER_DEFAULT = BORDER_REFLECT_101, //!< same as BORDER_REFLECT_101BORDER_ISOLATED = 16 //!< do not look outside of ROI
};
由于边界外没有任何图像信息,因此可以使用 BORDER_CONSTANT
边界填充0。
下面的例子中,卷积结果偏移了2。归一化后的矩阵中每个元素的数值都在一定范围内。再利用相同的卷积模板对彩色图像进行卷积,虽然卷积前后图像内容一致,但是图像整体变得模糊一些。
#include <opencv2/core/utils/logger.hpp>
#include <opencv2/opencv.hpp>using namespace cv;
using namespace std;int main()
{cout << "OpenCV Version: " << CV_VERSION << endl;utils::logging::setLogLevel(utils::logging::LOG_LEVEL_SILENT);//待卷积矩阵uchar points[25] = {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25};Mat img(5, 5, CV_8UC1, points);//卷积模板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, CV_32F, kernel, Point(-1, -1), 2, BORDER_CONSTANT);filter2D(img, result_norm, CV_32F, kernel_norm, Point(-1, -1), 2, BORDER_CONSTANT);cout << "result:" << endl << result << endl;cout << "result_norm:" << endl << result_norm << endl;//图像卷积Mat lena = imread("lena.png");if (lena.empty()){cout << "请确认图像文件名称是否正确" << endl;return -1;}Mat lena_fillter;filter2D(lena, lena_fillter, -1, kernel_norm, Point(-1, -1), 2, BORDER_CONSTANT);imshow("lena_fillter", lena_fillter);imshow("lena", lena);int k = waitKey(0); // Wait for a keystroke in the windowreturn 0;
}
输出:
result:
[25, 38, 46, 54, 39;54, 86, 98, 110, 78;94, 146, 158, 170, 118;134, 206, 218, 230, 158;95, 158, 166, 174, 109]
result_norm:
[3.9166665, 5, 5.666667, 6.3333335, 5.0833335;6.3333335, 9, 10.000001, 11.000001, 8.333333;9.666667, 14, 15, 16, 11.666668;13, 19, 20.000002, 21.000002, 15.000001;9.750001, 15, 15.666667, 16.333336, 10.916667]
查看全文
99%的人还看了
相似问题
- CNN卷积神经网络Python实现
- 竞赛 题目:基于机器视觉opencv的手势检测 手势识别 算法 - 深度学习 卷积神经网络 opencv python
- 时序预测 | Python实现ConvLSTM卷积长短期记忆神经网络股票价格预测(Conv1D-LSTM)
- 卷积神经网络(CNN)天气识别
- FSOD论文阅读 - 基于卷积和注意力机制的小样本目标检测
- YOLOv8改进 | 如何在网络结构中添加注意力机制、C2f、卷积、Neck、检测头
- 人工智能-卷积神经网络之多输入多输出通道
- 多维时序 | MATLAB实现TCN-selfAttention自注意力机制结合时间卷积神经网络多变量时间序列预测
- 基于轻量级卷积神经网络CNN开发构建打架斗殴识别分析系统
- 利用梯度上升可视化卷积核:基于torch实现
猜你感兴趣
版权申明
本文"OpenCV12-图像卷积":http://eshow365.cn/6-19698-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!