包含一个隐层的一般bp网络.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
包含一个隐层的一般bp网络

//包含一个隐层的一般bp网络 //输出不止一个单元 //用此网络解决XOR问题的程序如下 #include?stdio.h #include?math.h #define?TRAINNUM?3??????????//训练集总数 #define?INPUTNUM?10??????????//输入层单元个数 #define?OUTPUTNUM?1?????????//输出层单元个数 #define?MASKNUM?5???????????//隐层单元个数 #define?SWIT?1??????????????//洗牌开关 #define?BETA?1??????????????//Segmiod函数中的参数Beta #define?ETA??0.08????????????//学习率 #define?VAREPSILON?0.0000005???//误差控制 #define?TIMES?50000??????????//迭代次数控制 double?E;??????????????????????????????????????????//误差 int????Cycletimes;?????????????????????????????????//迭代次数 int????RandomSequence[TRAINNUM];???????????????????//随机训练序列 int????mll[TRAINNUM+1]; int????Input[TRAINNUM+1][INPUTNUM+1];??????????????//输入向量 int????Expectation[TRAINNUM+1][OUTPUTNUM+1];???????//期望输出向量 double?Output[TRAINNUM+1][OUTPUTNUM+1];????????????//实际输出向量 double?w_in[MASKNUM+1][INPUTNUM+1];????????????????//输入层和隐层之间的权值 double?w_out[OUTPUTNUM+1][MASKNUM+1];??????????????//输出层和隐层之间的权值 /********************读取训练集********************/ int?ReadData() { int?j,n,m; FILE?*fp; if((fp=fopen(dut.txt,r))==NULL) { printf(cannot?open?this?file\n); return(1); } for(j=1;j=TRAINNUM;j++) { for(n=1;n=INPUTNUM;n++) fscanf(fp,%d,Input[j][n]);//输入向量 //fscanf(fp,%d,mll[j]); for(m=1;m=OUTPUTNUM;m++) fscanf(fp,%d,Expectation[j][m]);//期望输出向量 } fclose(fp); return(0); } /********************输出结果********************/ int?WriteData() { int?j,m; FILE?*fp; fp=fopen(result.txt,a+); if((Cycletimes==(TIMES+1))(EVAREPSILON)) { fprintf(fp,失败!!!!!!!!\n); fprintf(fp,Don;;t?give?up,come?on!~?:)\n); } else{ fprintf(fp,Success!!!!!!!!\n); fprintf(fp,You?did?a?good?job!~?:)\n); fprintf(fp,迭代次数:); fprintf(fp,%d\n,Cycletimes); fprintf(fp,误????差:); fprintf(fp,%f\n,E); fprintf(fp,实际输出:\n); for(j=1;j=TRAINNUM;j++) { for(m=1;m=OUTPUTNUM;m++) { fprintf(fp,%f\n,Output[j][m]); } } } fprintf(fp,/////////////////////////////////////\n); fclose(fp); return(0); } /********************随机赋初始权值********************/ void?PrimalWeight() { int?i,j; double?RandomSgn; srand((unsigned)time(NULL));

文档评论(0)

tangtianbao1 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档