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