卷积神经网络 c语言,图像处理之C语言实现二维卷积

在用C语言实现图像处理中,经常要用到二维卷积的运算,这个在matlab中是非常容易实现的,只需要conv2()就OK啦,而且速度非常的快。但是在C语言中就需要四层的for循环来实现了。

首先二维卷积的原理是:

1 2 3               2 2 2

A=  1 2 3         B= 1 1 1

1 2 3               3 3 3

单我们使用A和B卷积时,首先需要将B旋转180度。即

3 3 3

1 1 1    逐渐右移

2 2 2

1 2 3

1 2 3

1 2 3

可得(full):

2     6    12    10     6

3     9    18    15     9

6    18    36    30    18

4    12    24    20    12

3     9    18    15     9

但是我们在图像处理中一般只选择与A维数相同的矩阵即:

9    18    15

18    36    30

12    24    20

所以可以得以下程序(给出部分代码):

#define N1 512

#define M1 512

#define N2 3

#define M2 3

/*x相当于矩阵A,y相当于J矩阵B,z相当于矩阵full时的输出,z2相当于矩阵与A维数相同时的输出,这里的参数类型根据实际情况作出修改。如果矩阵很大,运算时间比较久*/

void conv2(unsigned char x[N1][M1],int y[N2][M2],float z[N1+N2-1][M1+M2-1],float z2[N1][M1])

{

int i,j;

int n,m;

for(i=0; i

for(j=0; j

{

float temp = 0;

for(m=0; m

for(n=0; n

if((i-m)>=0&&(i-m)=0&&(j-n)

temp+=x[m][n]*y[i-m][j-n];

z[i][j]=temp;

}

for(i=0; i

for(j=0; j

{

z2[i][j]=z[i+(N2-1)/2][j+(M2-1)/2];

}

}

————————————————

版权声明:本文为CSDN博主「No威_」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/gotowu/article/details/48806397

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值