二维卷积c代码
二维信号的卷积原理请参考另外一篇文章:http://blog.csdn.net/carson2005/article/details/43702241
这里直接给出参考代码:
- void Conv2(int** filter, int** arr, int** res, int filterW, int filterH, int arrW, int arrH)
- {
- int temp;
- for (int i=0; i<filterH+arrH-1; i++)
- {
- for (int j=0; j<filterW+arrW-1; j++)
- {
- temp = 0;
- for (int m=0; m<filterH; m++)
- {
- for (int n=0; n<filterW; n++)
- {
- if ((i-m)>=0 && (i-m)<arrH && (j-n)>=0 && (j-n)<arrW)
- {
- temp += filter[m][n]*arr[i-m][j-n];
- }
- }
- }
- res[i][j] = temp;
- }
- }
- }
- void Conv2Test()
- {
- int filterW = 3;
- int filterH = 3;
- int arrW = 5;
- int arrH = 5;
- int resW = filterW + arrW - 1;
- int resH = filterH + arrH - 1;
- int** pFilter = new int*[filterH];
- for (int i=0; i<filterH; i++)
- {
- pFilter[i] = new int[filterW];
- }
- int** arr = new int*[arrH];
- for (int i=0; i<arrH; i++)
- {
- arr[i] = new int[arrW];
- }
- int** res = new int*[resH];
- for (int i=0; i<resH; i++)
- {
- res[i] = new int[resW];
- }
- pFilter[0][0] = 1;
- pFilter[0][1] = 3;
- pFilter[0][2] = 1;
- pFilter[1][0] = 0;
- pFilter[1][1] = 5;
- pFilter[1][2] = 0;
- pFilter[2][0] = 2;
- pFilter[2][1] = 1;
- pFilter[2][2] = 2;
- arr[0][0] = 17;
- arr[0][1] = 24;
- arr[0][2] = 1;
- arr[0][3] = 8;
- arr[0][4] = 15;
- arr[1][0] = 23;
- arr[1][1] = 5;
- arr[1][2] = 7;
- arr[1][3] = 14;
- arr[1][4] = 16;
- arr[2][0] = 4;
- arr[2][1] = 6;
- arr[2][2] = 13;
- arr[2][3] = 20;
- arr[2][4] = 22;
- arr[3][0] = 10;
- arr[3][1] = 12;
- arr[3][2] = 19;
- arr[3][3] = 21;
- arr[3][4] = 3;
- arr[4][0] = 11;
- arr[4][1] = 18;
- arr[4][2] = 25;
- arr[4][3] = 2;
- arr[4][4] = 9;
- printf("pFilter: \n");
- for (int i=0; i<filterH; i++)
- {
- for (int j=0; j<filterW; j++)
- {
- printf("%d ", pFilter[i][j]);
- }
- printf("\n");
- }
- printf("*********************************************** \n");
- printf("arr: \n");
- for (int i=0; i<arrH; i++)
- {
- for (int j=0; j<arrW; j++)
- {
- printf("%d ", arr[i][j]);
- }
- printf("\n");
- }
- printf("*********************************************** \n");
- Conv2(pFilter, arr, res, filterW, filterH, arrW, arrH);
- printf("res: \n");
- for (int i=0; i<resH; i++)
- {
- for (int j=0; j<resW; j++)
- {
- printf("%d ", res[i][j]);
- }
- printf("\n");
- }
- printf("*********************************************** \n");
- }
二维卷积c代码的更多相关文章
- 图像处理之基础---二维卷积c实现
http://wenku.baidu.com/link?url=4RzdmvP9sdaaUbnVEW4OyBD-g67wIOiJjKFF3Le_bu7hIiBS7I6hMcDmCXrQwsHvrsPv ...
- 图像处理之C语言实现二维卷积
在用C语言实现图像处理中,经常要用到二维卷积的运算,这个在matlab中是非常容易实现的,只需要conv2()就OK啦,而且速度非常的快.但是在C语言中就需要四层的for循环来实现了. 首先二维卷积的 ...
- 【转】python中的一维卷积conv1d和二维卷积conv2d
转自:https://blog.csdn.net/qq_26552071/article/details/81178932 二维卷积conv2d 给定4维的输入张量和滤波器张量来进行2维的卷积计算.即 ...
- 卷积神经网络(CNN)之一维卷积、二维卷积、三维卷积详解
作者:szx_spark 由于计算机视觉的大红大紫,二维卷积的用处范围最广.因此本文首先介绍二维卷积,之后再介绍一维卷积与三维卷积的具体流程,并描述其各自的具体应用. 1. 二维卷积 图中的输入的数据 ...
- 深度学习面试题10:二维卷积(Full卷积、Same卷积、Valid卷积、带深度的二维卷积)
目录 二维Full卷积 二维Same卷积 二维Valid卷积 三种卷积类型的关系 具备深度的二维卷积 具备深度的张量与多个卷积核的卷积 参考资料 二维卷积的原理和一维卷积类似,也有full卷积.sam ...
- 4.28 省选模拟赛模拟赛 最佳农场 二维卷积 NTT
第一次遇到二维卷积 不太清楚是怎么做的. 40分暴力比对即可. 对于行为或者列为1时 容易想到NTT做快速匹配.然后找答案即可. 考虑这是一个二维的比对过程. 设\(f_{i,j}\)表示以i,j为右 ...
- JAVA生成二维码图片代码
首先需要导入 QRCode.jar 包 下载地址看这里 http://pan.baidu.com/s/1o6qRFqM import java.awt.Color;import java.awt. ...
- java二维码生成代码
QRCodeUtil.encode(text, "D:/004.jpg", "D:", true, "exp");// 这个方法的第一个参数 ...
- C#--二维码生成代码
需要用到ThoughtWorks.QRCode.dll文件 string str = Server.UrlDecode(Request.QueryString["id"]); QR ...
随机推荐
- 动手写一个快速集成网易新闻,腾讯视频,头条首页的ScrollPageView,显示滚动视图
最终效果 更新示例.gif 示例效果.gif 示例效果1.gif 示例效果2.gif 示例效果3.gif 示例效果4.gif 示例效果5.gif 示例效果6.gif 一.构思部分: 打算分为三个部分, ...
- jsp----在jsp中写java代码(变量和函数方法)
<%@page import="java.text.SimpleDateFormat"%><%@page language="java" im ...
- Web网站与Web应用程序区别
创建时的目录结构不同. WEB应用程序一般处理程序有命名空间,而网站中的没有.(因为应用程序最后要编译成一个DLL文件,会产生命名冲突,而网站每个页面会编译成每一个的DLL,不会文件内产生全名冲突). ...
- Nginx高性能服务器安装、配置、运维 (6) —— Nginx日志及日志分割
七.Nginx日志及日志分割 (1)Nginx日志文件 查看Nginx配置文件: 找到access_log,yum安装默认存储在/var/log/nginx目录下,且默认main格式: main格式定 ...
- JS实现跳转到页面任何地方
要实现两个内容: 1.从A页面跳转到B页面任何地方 方法:用id对要跳转的地方进行标记. 首先,在A页面可以设一个链接 <a href = "b.html#pos" targ ...
- CDOJ-10(栈的应用)
In Galgame We Trust Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Othe ...
- 数据结构与算法JavaScript 读书笔记
由于自己在对数组操作这块比较薄弱,然后经高人指点,需要好好的攻读一下这本书籍,原本想这个书名就比较高深,这下不好玩了.不过看着看着突然觉得讲的东西都比较基础.不过很多东西,平时还是没有注意到,故写出读 ...
- iOS toolbar
初学ios,对toolbar初步了解: self.navigationItem.title=@"显示工具栏"; // 显示工具栏 //self.navigationControll ...
- Android应用不随手机屏幕旋转的方法
在主配置文件里面.在需要设置的activity项后面加上 android:screenOrientation="portrait",这个activity就保持竖屏显示了:在每个ac ...
- jenkins(二)项目构建
通过上一篇“jenkins(一)集成环境搭建示例”,已经完成了jenkins的安装,基本配置,启动,下面继续小结jenkins使用 一.jenkins系统配置 访问jenkins,点击系统管理-> ...