基于神经网络的数据分类.pptVIP

  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文档。上传文档
查看更多
文章如果有不当或者不妥的地方,请您联系我修改文章或者删除文章,文章来源于网络收集,如果有侵权的问题,请联系我沟通协调改正,非常感谢您! 基于神经网络的数据分类 花萼长度 花萼宽度 花瓣长度 花瓣宽度 类别 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%

文档评论(0)

159****1748 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档