当前位置:首页 > 工业控制 > 电子设计自动化
[导读]#pragma hdrstop #include <stdio.h> #include <iostream.h> const A=30.0; const B=10.0; const MAX=500; //最大训练次数 const COEF=0.0035; //网络的学习效率 const BCOEF=0.001;//网络的阀值调整效率 const ERRO

#pragma hdrstop

#include <stdio.h>

#include <iostream.h>

const A=30.0;

const B=10.0;

const MAX=500; //最大训练次数

const COEF=0.0035; //网络的学习效率

const BCOEF=0.001;//网络的阀值调整效率

const ERROR=0.002 ; // 网络训练中的允许误差

const ACCURACY=0.0005;//网络要求精度

double sample[41][4]={{0,0,0,0},{5,1,4,19.020},{5,3,3,14.150},

{5,5,2,14.360},{5,3,3,14.150},{5,3,2,15.390},

{5,3,2,15.390},{5,5,1,19.680},{5,1,2,21.060},

{5,3,3,14.150},{5,5,4,12.680},{5,5,2,14.360},

{5,1,3,19.610},{5,3,4,13.650},{5,5,5,12.430},

{5,1,4,19.020},{5,1,4,19.020},{5,3,5,13.390},

{5,5,4,12.680},{5,1,3,19.610},{5,3,2,15.390},

{1,3,1,11.110},{1,5,2,6.521},{1,1,3,10.190},

{1,3,4,6.043},{1,5,5,5.242},{1,5,3,5.724},

{1,1,4,9.766},{1,3,5,5.870},{1,5,4,5.406},

{1,1,3,10.190},{1,1,5,9.545},{1,3,4,6.043},

{1,5,3,5.724},{1,1,2,11.250},{1,3,1,11.110},

{1,3,3,6.380},{1,5,2,6.521},{1,1,1,16.000},

{1,3,2,7.219},{1,5,3,5.724}};

double w[4][10][10],wc[4][10][10],b[4][10],bc[4][10];

double o[4][10],netin[4][10],d[4][10],differ;//单个样本的误差

double is; //全体样本均方差

int count,a;

void netout(int m, int n);//计算网络隐含层和输出层的输出

void calculd(int m,int n); //计算网络的反向传播误差

void calcalwc(int m,int n);//计算网络权值的调整量

void calcaulbc(int m,int n); //计算网络阀值的调整量

void changew(int m,int n); //调整网络权值

void changeb(int m,int n);//调整网络阀值

void clearwc(int m,int n);//清除网络权值变化量wc

void clearbc(int m,int n);//清除网络阀值变化量bc

void initialw(void);//初始化NN网络权值W

void initialb(void); //初始化NN网络阀值

void calculdiffer(void);//计算NN网络单个样本误差

void calculis(void);//计算NN网络全体样本误差

void trainNN(void);//训练NN网络

/*计算NN网络隐含层和输出层的输出 */

void netout(int m,int n)

{

int i,j,k;

//隐含层各节点的的输出

for (j=1,i=2;j<=m;j++) //m为隐含层节点个数

{

netin[i][j]=0.0;

for(k=1;k<=3;k++)//隐含层的每个节点均有三个输入变量

netin[i][j]=netin[i][j]+o[i-1][k]*w[i][k][j];

netin[i][j]=netin[i][j]-b[i][j];

o[i][j]=A/(1+exp(-netin[i][j]/B));

}

//输出层各节点的输出

for (j=1,i=3;j<=n;j++)

{

netin[i][j]=0.0;

for (k=1;k<=m;k++)

netin[i][j]=netin[i][j]+o[i-1][k]*w[i][k][j];

netin[i][j]=netin[i][j]-b[i][j];

o[i][j]=A/(1+exp(-netin[i][j]/B)) ;

}

}

/*计算NN网络的反向传播误差*/

void calculd(int m,int n)

{

int i,j,k;

double t;

a=count-1;

d[3][1]=(o[3][1]-sample[a][3])*(A/B)*exp(-netin[3][1]/B)/pow(1+exp(-netin[3][1]/B),2);

//隐含层的误差

for (j=1,i=2;j<=m;j++)

{

t=0.00;

for (k=1;k<=n;k++)

t=t+w[i+1][j][k]*d[i+1][k];

d[i][j]=t*(A/B)*exp(-netin[i][j]/B)/pow(1+exp(-netin[i][j]/B),2);

}

}

/*计算网络权值W的调整量*/

void calculwc(int m,int n)

{

int i,j,k;

// 输出层(第三层)与隐含层(第二层)之间的连接权值的调整

for (i=1,k=3;i<=m;i++)

{

for (j=1;j<=n;j++)

{

wc[k][i][j]=-COEF*d[k][j]*o[k-1][i]+0.5*wc[k][i][j];

}

// printf("n");

}

//隐含层与输入层之间的连接权值的调整

for (i=1,k=2;i<=m;i++)

{

for (j=1;j<=m;j++)

{

wc[k][i][j]=-COEF*d[k][j]*o[k-1][i]+0.5*wc[k][i][j];

}

// printf("n");

}

}

/*计算网络阀值的调整量*/

void calculbc(int m,int n)

{

int j;

for (j=1;j<=m;j++)

{

bc[2][j]=BCOEF*d[2][j];

}

for (j=1;j<=n;j++)

{

bc[3][j]=BCOEF*d[3][j];

}

}

/*调整网络权值*/

void changw(int m,int n)

{

int i,j;

for (i=1;i<=3;i++)

for (j=1;j<=m;j++)

{

w[2][i][j]=0.9*w[2][i][j]+wc[2][i][j];

//为了保证系统有较好的鲁棒性,计算权值时乘惯性系数0.9

printf("w[2][%d][%d]=%fn",i,j,w[2][i][j]);

}

for (i=1;i<=m;i++)

for (j=1;j<=n;j++)

{

w[3][i][j]=0.9*w[3][i][j]+wc[3][i][j];

printf("w[3][%d][%d]=%fn",i,j,w[3][i][j]);

}

}

/*调整网络阀值*/

void changb(int m,int n)

{

int j;

for (j=1;j<=m;j++)

b[2][j]=b[2][j]+bc[2][j];

for (j=1;j<=n;j++)

b[3][j]=b[3][j]+bc[3][j];

}

/*清除网络权值变化量wc*/

void clearwc(void)

{

for (int i=0;i<4;i++)

for (int j=0;j<10;j++)

for (int k=0;k<10;k++)

wc[i][j][k]=0.00;

}

/*清除网络阀值变化量*/

void clearbc(void)

{

for (int i=0;i<4;i++)

for (int j=0;j<10;j++)

bc[i][j]=0.00;

}

/*初始化网络权值W*/

void initialw(void)

{

int i,j,k,x;

double weight;

for (i=0;i<4;i++)

for (j=0;j<10;j++)

for (k=0;k<10;k++)

{

randomize();

x=100+random(400);

weight=(double)x/5000.00;

w[i][j][k]=weight;

}

}

/*初始化网络阀值*/

void initialb(void)

{

int i,j,x;

double fazhi;

for (i=0;i<4;i++)

for (j=0;j<10;j++)

{

randomize();

for (int k=0;k<12;k++)

{

x=100+random(400);

}

fazhi=(double)x/50000.00;

b[i][j]=fazhi;

}

}

/*计算网络单个样本误差*/

void calculdiffer(void)

{

a=count-1;

differ=0.5*(o[3][1]-sample[a][3])*(o[3][1]-sample[a][3]);

}

void calculis(void)

{

int i;

is=0.0;

for (i=0;i<=19;i++)

{

o[1][1]=sample[i][0];

o[1][2]=sample[i][1];

o[1][3]=sample[i][2];

netout(8,1);

is=is+(o[3][1]-sample[i][3])*(o[3][1]-sample[i][3]);

}

is=is/20;

}

/*训练网络*/

void trainNN(void)

{

long int time;

int i,x[4];

initialw();

initialb();

for (time=1;time<=MAX;time++)

{

count=0;

while(count<=40)

{

o[1][1]=sample[count][0];

o[1][2]=sample[count][1];

o[1][3]=sample[count][2];

count=count+1;

clearwc();

clearbc();

netout(8,1);

calculdiffer();

while(differ>ERROR)

{

calculd(8,1);

calculwc(8,1);

calculbc(8,1);

changw(8,1);

changb(8,1);

netout(8,1);

calculdiffer();

}

}

printf("This is %d times training NN...n",time);

calculis();

printf("is==%fn",is);

if (is<ACCURACY) break;

}

}

//---------------------------------------------------------------------------

#pragma argsused

int main(int argc, char* argv[])

{

double result;

int m,test[4];

char ch='y';

cout<<"Please wait for the train of NN:"<<endl;

trainNN();

cout<<"Now,this modular network can work for you."<<endl;

while(ch=='y' || ch=='Y')

{

cout<<"Please input data to be tested."<<endl;

for (m=1;m<=3;m++)

cin>>test[m];

ch=getchar();

o[1][1]=test[1];

o[1][2]=test[2];

o[1][3]=test[3];

netout(8,1);

result=o[3][1];

printf("Final result is %f.n",result);

printf("Still test?[Yes] or [No]n");

ch=getchar();

}

return 0;

}



来源:向明天进军0次

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

该实验室的创新技术能够增强人工智能边缘解决方案,提高神经网络能力

关键字: 人工智能 神经网络

机器学习将是下述内容的主要介绍对象,通过这篇文章,小编希望大家可以对机器学习的相关情况以及信息有所认识和了解,详细内容如下。

关键字: 机器学习 神经网络 支持向量机

深度学习需要大量的计算。它通常包含具有许多节点的神经网络,并且每个节点都有许多需要在学习过程中必须不断更新的连接。换句话说,神经网络的每一层都有成百上千个相同的人工神经元在执行相同的计算。

关键字: 机器学习 神经网络 TensorFlow

2023年10月18日,中国在第三届“一带一路”国际合作高峰论坛期间发布《全球人工智能治理倡议》,围绕人工智能发展、安全、治理三方面系统阐述了人工智能治理中国方案。

关键字: 人工智能 大模型 代码

我们看到这么多的安全问题,部分原因在于我们对待安全的方式:安全性通常被认为是事后考虑的问题,是在开发结束时才添加到设备上的东西。然而,复杂的系统,尤其是嵌入式系统,有一个很大的攻击面,这让攻击者有机可乘,能够在“盔甲”上...

关键字: 代码 嵌入式系统 软件漏洞

新富人群财务需求多元发展,投顾服务迎来新机遇 上海2023年9月20日 /美通社/ -- 2023年9月19日,上海交通大学上海高级金融学院(高金)与全球领先的金融服务机构嘉信理财(Charles Schwab)联合发...

关键字: BSP ADVANCED INA 代码

北京2023年9月14日 /美通社/ -- 生物医药高科技公司诺诚健华(港交所代码:09969;上交所代码:688428)今日宣布,新型蛋白酪氨酸磷酸酶SHP2变构抑制剂ICP-189联用针对表皮生长因子受体(EGFR)...

关键字: IC HP 代码 ARMA

上海2023年9月1日 /美通社/ -- 2023上半年,安集科技(股票代码:688019)市场拓展规划成效显现,营业收入稳健增长。 全球半导体产业挑战持续存在的情形下,安集科技秉承发扬"克难攻坚,敢打硬...

关键字: 安集科技 BSP 代码 半导体材料

国际酒店运营商升级其在线支付功能 上海2023年8月28日 /美通社/ -- 加拿大金融科技公司Nuvei Corporation(以下简称“Nuvei”或“公司”)(纳斯达克代码:NVEI)(多伦多证券交易所代码:N...

关键字: 代码 IP SE 纳斯达克

2023年上半年收入7.459亿元 同比增长5.1% 毛利率水平上升 海外收入同比增长65.4% 香港2023年8月22日 /美通社/ -- 金邦达宝嘉控股有限公司及其附属公司(以下合称「金邦达」、「...

关键字: 数字化 代码 嵌入式软件 COM
关闭
关闭