2025年C++实现卷积操作

C++实现卷积操作卷积操作的 C 实现 include include include using namespace std using namespace cv Mat Kernel test 3 3 Mat 3 3 0 1 0 1 5 1 0 1 0 void Convlution Mat InputImage Mat

卷积操作的C++实现

#include 
#include
#include

using namespace std;
using namespace cv;

Mat Kernel_test_3_3 = (
Mat_(3, 3) <<
0, -1, 0,
-1, 5, -1,
0, -1, 0);
void Convlution(Mat InputImage, Mat OutputImage, Mat kernel)
{
//计算卷积核的半径
int sub_x = kernel.cols / 2;
int sub_y = kernel.rows / 2;
//遍历图片
for (int image_y = 0; image_y < InputImage.rows - 2 * sub_y; image_y++)
{
for (int image_x = 0; image_x < InputImage.cols - 2 * sub_x; image_x++)
{
int pix_value = 0;
for (int kernel_y = 0; kernel_y < kernel.rows; kernel_y++)
{
for (int kernel_x = 0; kernel_x < kernel.cols; kernel_x++)
{
double weihgt = kernel.at(kernel_y, kernel_x);
int value = (int)InputImage.at(image_y + kernel_y, image_x + kernel_x);
pix_value += weihgt*value;
}
}
OutputImage.at(image_y + sub_y, image_x + sub_x) = (uchar)pix_value;
}
}
}

int main()
{
Mat srcImage = imread("1.jpg", 0);
namedWindow("srcImage", WINDOW_AUTOSIZE);
imshow("原图", srcImage);

//filter2D卷积
Mat dstImage_oprncv(srcImage.rows, srcImage.cols, CV_8UC1, Scalar(0));;
filter2D(srcImage, dstImage_oprncv, srcImage.depth(), Kernel_test_3_3);
imshow("filter2D卷积图", dstImage_oprncv);
imwrite("1.jpg", dstImage_oprncv);

//自定义卷积
Mat dstImage_mycov(srcImage.rows, srcImage.cols, CV_8UC1, Scalar(0));
Convlution(srcImage, dstImage_mycov, Kernel_test_3_3);
imshow("卷积图3", dstImage_mycov);
imwrite("2.jpg", dstImage_mycov);

waitKey(0);
return 0;
}
编程小号
上一篇 2025-02-15 13:11
下一篇 2025-03-19 12:27

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/123961.html