- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
文章如果有不当或者不妥的地方,请您联系我修改文章或者删除文章,文章来源于网络收集,如果有侵权的问题,请联系我沟通协调改正,非常感谢您! 基于神经网络的数据分类 花萼长度 花萼宽度 花瓣长度 花瓣宽度 类别 5.4 3.9 1.7 0.4 1 5 3.4 1.5 0.2 1 6.2 2.2 4.5 1.5 2 5.5 2.3 4 1.3 2 6.1 2.8 4.7 1.2 2 7.9 3.8 6.4 2 3 6.3 2.8 5.1 1.5 3 有一批花可分为三个品种, 利用神经网络算法, 依据花萼长度, 花萼宽度, 花瓣长度和花瓣宽度对其进行分类。 样本包含150组数据, 选择90组作为训练样本, 60组作为测试样本。输入数据为[花萼长度 花萼宽度 花瓣长度 花瓣宽度], 输出数据为花品种类别。 要做工作: 1.建立一个神经网络 2.使用样本训练这个网络 3.使用新数据集测试这个网络分类正确性 BP神经网络 网络层数: 2输入层节点数: 4 输出层节点数: 1 隐层节点数: m=sqrt(n+l)+a (n为输入层节点数, l为输出层节点数, a为1~10之间常数) %导入训练样本数据 data=load(‘data.txt’); p=data(:,1:4)‘; %输入量 t=data(:,5)‘; %输出量 %数据归一化到[-1 +1] [pn,ps] = mapminmax(p); %导入测试样本数据 testdata=load(‘testdata.txt’); p_test=testdata(:,1:4)‘; %输入量 t_test=testdata(:,5)‘; %输出量 %数据归一化到[-1 +1] [pn_test,ps] = mapminmax(p_test); 1.数据预处理: data.txt中有90组数据, 作为训练样本; testdata.txt中有60组数据, 作为测试样本。 3.训练参数选择: net.trainParam.show = 50; %显示训练结果间隔步数 net.trainParam.epochs=1000; %最大训练次数 net.trainParam.goal=0.001; %训练目标误差 net.trainParam.lr = 0.01; %学习系数 net=train(net,pn,t); %开始训练 2.创建一个新BP神经网络: net = newff(minmax(pn),[10 1],{tansigpurelin},traingdx); %隐含层传输函数为transing; %输出层传输函数为purelin; %训练函数为traingdx(有动量和自适应lr梯度下降法) 4.仿真并绘制结果: a = sim(net,pn_test); a=round(a); %四舍五入取整 figure(1) plot(a,:or) hold on plot(t_test,-*); legend(‘估计类别‘,’实际类别’) title(‘BP网络估计输出) ylabel(‘类别) xlabel(‘样本’) %估计误差 error=a-t_test; figure(3) plot(error,-*) title(‘BP网络估计误差) ylabel(‘误差) xlabel(‘样本) figure(3) count=0; %误分类次数 hold on; for i=1:60 %估计与实际类别都为1 if a(i)1.5 if t(i)1.5 plot(p(1,i),p(4,i),‘ro’); else plot(p(1,i),p(4,i),r*); count=count+1; End %估计与实际类别都为3 elseif a(i)2.5 if t_test(i)2.5 plot(p(1,i),p(4,i),go); else plot(p(1,i),p(4,i),g*); count=count+1; end %估计与实际类别都为1 else if(t_test(i)=2.5)(t_test(i)=1.5) plot(p(1,i),p(4,i),bo); else plot(p(1,i),p(4,i),b*); count=count+1; end end end rate=(60-count)/60 %正确率 5.显示分类结果: 图中红色为第一类, 蓝色为第二类, 绿色为第三类。结果显示有一个数据分类错误, 分类正确率为98.33%
您可能关注的文档
最近下载
- 大作业:如何理解“作风建设永远在路上,永远没有休止符”?我们应如何加强作风建设?.docx VIP
- 教师实习心得:教育反思与教师实习心得:有效的教学离不开有效的反思合集.doc VIP
- 《中华人民共和国基本医疗卫生与健康促进法》全文.pdf VIP
- 代数式的值-新浙教版-七上数学.pptx VIP
- 浙教版初中数学八年级上册第二章《特殊三角形》单元测试卷(含答案解析)(困难).docx VIP
- 浙教版初中数学八年级上册第二章《特殊三角形》单元测试卷(含答案解析)(标准困难).docx VIP
- 村两委换届调研报告大全一.doc VIP
- 2024-2030年中国面食行业市场深度分析及前景趋势与投资研究报告.docx
- 《护士条例》落实情况监督检查表.docx VIP
- 中国宠物行业2025年宠物医疗市场发展趋势与挑战分析报告.docx
文档评论(0)