概述
需要对28x28的灰度数字图像进行数字识别。
输入层 28x28个输入节点,分别代表像素点上的灰度大小
输出层10个输出,分别代表0-1的概率
使用sigmoid函数
由于求导过于繁琐,因此这里仅添加了一层隐藏层。
代码如下
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
using namespace std;
char file[]="train-images-idx3-ubyte";
char lc;
#define gc() (lc=getchar())
//#define gc() (lc=(Cs>=Ms?(fread(buf,Ms,1,stdin),Cs=0,buf[Cs++]):buf[Cs++]))
#define sigmoid(x) (1/(1+exp(x)))
int read(int&x)
{
x=0;
char c;
do c=gc();while((c!=EOF)&&(c<'0'||c>'9')&&(c<'a'||c>'z')&&(c<'A'||c>'Z'));
if (lc==EOF)
{
x=-1;
return -1;
}
while(!((c<'0'||c>'9')&&(c<'a'||c>'z')&&(c<'A'||c>'Z')))
{
x=x*10+c-'0';
c=gc();
}
return 1;
}
int n_lay1=28*28;
double w1[28*28][20];
double dw1[28*28][20];
double b1[20];
double db1[20];
double x1[28*28];
double sig1[28*28];
int n_lay2=20;
double w2[20][10];
double dw2[20][10];
double b2[10];
double db2[10];
double mid[60001][20];
double dmid[20];
double out[60001][10];
double train[60001][28*28];
double label[60001][10];
int train_N;
double get_loss(const int &train_n)
{
double loss=0;
for(int i=0;i<train_n;i++)
{
for(int j=0;j<20;j++)
mid[i][j]=b1[j];
for(int j=0;j<28*28;j++)
for(int k=0;k<20;k++)
{
mid[i][k]=mid[i][k]+w1[j][k]*train[i][j];
//printf("%d %lf %lfn",train[i][j],w1[j][k], mid[i][k]);
}
//puts("mid");
for(int j=0;j<20;j++)
mid[i][j]=sigmoid(mid[i][j]);//,printf("%lf, ",mid[i][j]);
//puts("");
for(int j=0;j<10;j++)
out[i][j]=b2[j];
for(int j=0;j<20;j++)
for(int k=<
最后
以上就是有魅力皮皮虾为你收集整理的手搓全连接层神经网络识别手写数字的全部内容,希望文章能够帮你解决手搓全连接层神经网络识别手写数字所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复