http://hihocoder.com/contest/tupu2018/problem/2

题目2 : ​Standard 2D Convolution

时间限制:5000ms
单点时限:1000ms
内存限制:256MB

描述

Implement such below standard convolution

conv2d(input tensor, filters = 8, kernel size=[5,5], stride = 2, zero padding = 'SAME', activation = relu)

The shape of input tensor:  [height = 32, width = 32, channels = 3]

输入

The first line will contain an image. The value of pixels is [0, 255]. The image should be preprocessed (/127.5 - 1) before fed into the convolution function. Weights[kernel height, kernel width, input channels, output channels] and biases[output channels] are followed in the next two lines respectively.

输出

Print the result tensor in one line printed in the same way as input file. The precision is (1E-4).

注意

All data are arranged into one line using C-like order, with the last axis index changing fastest, back to the first axis index changing slowest.

样例输入
Download the sample input from:
https://media.hihocoder.com/contests/tupu-campus-hiring-2017/conv_sample_input.txt 
样例输出
Download the sample output from:
https://media.hihocoder.com/contests/tupu-campus-hiring-2017/conv_sample_output.txt 

题意:实现conv2d()卷积函数。

卷积神经网络

#input channels = 3, output channels = 8

#input_tensor = 32 * 32 * 3

#weights = 5 * 5 * 3 * 8

#biases = 1*8

参数解释:stride是步长参数;zero padding表示是否用零填充边缘进行,same表示在stride = 1的时候输出矩阵大小不变; activation是激励函数;ReLU函数为f(x) = max(x, 0)。

 #include <iostream>
 #include <stdio.h>
 #include <cmath>
 #include <vector>
 #include <string>
 using namespace std;
 #define Height 32
 #define Width 32
 #define Channels 3
 #define Filters 8
 #define kernel 5
 #define Eps 1e-5
 float weight[kernel][kernel][Channels][Filters];
 float biases[Filters];
 , , , string padding = "SAME", string activation = "relu")
 {
     int feaMapH = ceil(Height * 1.0 / stride);
     ) * stride + kernelSize;
     ;
     int paddingR = (HeightAfterPadding - Height) - paddingL;
     vector<vector< vector<float> > >a;

     ;i < HeightAfterPadding;i++){
         vector< vector<float> >b;
         ; j < HeightAfterPadding;j++){
             vector<float>c;
             ;k < Channels;k++){
                 c.push_back();
             }
             b.push_back(c);
         }
         a.push_back(b);
     }
     //cout << HeightAfterPadding << endl;

     ;i < Height;i++){
         ; j < Width;j++){
             ;k < Channels;k++){
                 a[paddingL + i][paddingL + j][k] = ((float)(inputTensor[i][j][k])) / 127.5 - 1.0;
             }
         }
     }

     ;i <= HeightAfterPadding - kernelSize;i += stride){
         ; j <= HeightAfterPadding - kernelSize;j += stride){

             ;nn < filters;nn++){
                 ;
                 ;k < kernelSize;k++){
                     ;l < kernelSize;l++){
                         ;mm < Channels;mm++){
                             sum += a[i + k][j + l][mm] * weight[k][l][mm][nn];
                         }
                     }
                 }
                 sum += biases[nn];
                 if(sum < Eps) cout << "0.0000 " ;
                 else printf("%.4f ",sum);
             }
             //cout << endl;
         }
     }
     return ;
 }
 int main()
 {
     int a[Height][Width][Channels];
     //freopen("conv_sample_input.txt","r",stdin);
     ;i < Height;i++){
         ;j < Width;j++){
             ;k < Channels;k++){
                 cin >> a[i][j][k];
             }
         }
     }

     ;i < kernel;i++){
         ;j < kernel;j++){
             ;k < Channels;k++){
                 ;l < Filters;l++){
                     cin >> weight[i][j][k][l];
                 }
             }
         }
     }

     ;l < Filters;l++){
         cin >> biases[l];
     }
     conv2d(a,Filters,kernel);
     ;
 }

附:FFT矩阵卷积的快速乘法

Hihocoder之conv2d()的更多相关文章

  1. hihocoder -1121-二分图的判定

    hihocoder -1121-二分图的判定 1121 : 二分图一•二分图判定 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 大家好,我是小Hi和小Ho的小伙伴Net ...

  2. Hihocoder 太阁最新面经算法竞赛18

    Hihocoder 太阁最新面经算法竞赛18 source: https://hihocoder.com/contest/hihointerview27/problems 题目1 : Big Plus ...

  3. hihoCoder太阁最新面经算法竞赛15

    hihoCoder太阁最新面经算法竞赛15 Link: http://hihocoder.com/contest/hihointerview24 题目1 : Boarding Passes 时间限制: ...

  4. 【hihoCoder 1454】【hiho挑战赛25】【坑】Rikka with Tree II

    http://hihocoder.com/problemset/problem/1454 调了好长时间,谜之WA... 等我以后学好dp再来看为什么吧,先弃坑(╯‵□′)╯︵┻━┻ #include& ...

  5. 【hihocoder#1413】Rikka with String 后缀自动机 + 差分

    搞了一上午+接近一下午这个题,然后被屠了个稀烂,默默仰慕一晚上学会SAM的以及半天4道SAM的hxy大爷. 题目链接:http://hihocoder.com/problemset/problem/1 ...

  6. 【hihoCoder】1148:2月29日

    问题:http://hihocoder.com/problemset/problem/1148 给定两个日期,计算这两个日期之间有多少个2月29日(包括起始日期). 思路: 1. 将问题转换成求两个日 ...

  7. 【hihoCoder】1288 : Font Size

    题目:http://hihocoder.com/problemset/problem/1288 手机屏幕大小为 W(宽) * H(长),一篇文章有N段,每段有ai个字,要求使得该文章占用的页数不超过P ...

  8. 【hihoCoder】1082: 然而沼跃鱼早就看穿了一切

      题目:http://hihocoder.com/problemset/problem/1082 输入一个字符串,将其中特定的单词替换成另一个单词   代码注意点: 1. getline(istre ...

  9. 【hihoCoder】1121:二分图一·二分图判定

      题目   http://hihocoder.com/problemset/problem/1121 无向图上有N个点,两两之间可以有连线,共有M条连线. 如果对所有点进行涂色(白/黑),判定是否存 ...

随机推荐

  1. MySQL数据库引擎、事务隔离级别、锁

    MySQL数据库引擎.事务隔离级别.锁 数据库引擎InnoDB和MyISAM有什么区别 大体区别为: MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISAM类型的表强调的是性能 ...

  2. Win环境 Android Studio使用Git 教程 ( 一 )

    一. 安装 下载安装完成Git后 进入命令行 输入命令git --version,如果能显示版本则说明安装成功,如果没有显示版本,需要配置环境变量: 在path中添加git的安装位置 二 . 配置信息 ...

  3. python游戏编程——乌龟和鱼类场景编程

    综合举例: 游戏编程:按以下要求定义一个乌龟类和鱼类并尝试编写游戏. O    假设游戏场景为范围(x, y)为0<=x<=10,0<=y<=10 ·       游戏生成1只 ...

  4. 【Shader】这是一篇记录随笔,我要开始学Shader了!

    背景: 前天学校有场招聘会,转了一圈只看到一家和unity有关的公司,还是做VR游戏的,然后HR也很好说话.和我说话的HR正好是做UnityVR方面的,聊了会受益匪浅,自己就像是找到了方向似的,突然很 ...

  5. 如何把word ppt 思维导图这类文件转化为高清晰度的图片(要干货只看粗体黑字)

    我使用思维导图做学习笔记,最终绘制了一张比较满意的思维导图,想要分享出去,但由于现在思维导图软件众多,成品文件格式差别蛮大,不利于传播和打开,所以需要转化为普通图片,但笔者使用的导图软件导出转化成的图 ...

  6. 基于C#的机器学习--惩罚与奖励-强化学习

    强化学习概况 正如在前面所提到的,强化学习是指一种计算机以“试错”的方式进行学习,通过与环境进行交互获得的奖赏指导行为,目标是使程序获得最大的奖赏,强化学习不同于连督学习,区别主要表现在强化信号上,强 ...

  7. nginx 在ubuntu上使用笔记(绑定域名)

    1. 重启nginx的两个语句: sudo service nginx restart sudo nginx -s reload 2. nginx配置文件路径: etc/nginx/ 尤其是 site ...

  8. [BUAA OO]第四次博客作业

      一.      测试与正确性论证的区别 在最后一个单元的OO作业中,我们主要进行了代码的测试与正确性论证工作.这俩者在作业中的体现分别是junit单元测试以及jsf论述语言.这两者在java代码开 ...

  9. mysql hibernate 关于默认值

    字段的默认值 写 NOT NULL DEFAULT 0 等等 一直不行, 算了  干脆在创建的时候 在代码set好了 版权声明:本文为博主原创文章,未经博主允许不得转载.

  10. BNUOJ 52303 Floyd-Warshall Lca+bfs最短路

    题目链接: https://www.bnuoj.com/v3/problem_show.php?pid=52303 Floyd-Warshall Time Limit: 60000msMemory L ...