1、科学计算与数据处理综合设计实验四科学计算与数据处理综合设计实验四作者: 日期: 科学计算与数据处理实验报告学 号S3136005姓 名王腾祥实验名称科学计算与数据处理综合设计实验实验目的1、 深入研究MATLA在计算机相关的某一专业领域的综合应用2、 熟悉TLAB中专业级oolbox或Simulink的功能和用法3、 学会综合运用MATLA解决并行运算与神经网络-基于CPUP的并行神经网络运算实验方案U并行一、标准单线程的神经网络训练与仿真过程x,t=housdaase;net1=dforane(10);nettrain(net1,x,);=sm(e2,x);二、打开MTABworrsmata
2、bpolopen检查wrkr数量oolsize=tlabpol(iz)三、设置rain与im函数中的参数“Useparale”为“ys”。net=tn(net,x,,Ueparl,ye)y=sm(nt,x,Useprall,yes)四、使用“howesource”选项证实神经网络运算确实在各个worker上运行。nettrai(t1,x,t,ePalll,yes,showResourcs,yes);y=sm(nt2,x,useParalll,yes,shoResurce,ye);五、将一个数据集进行随机划分,同时保存到不同的文件fr 1:matlapol(sz)=and(,1000);sve(
3、inutsnumr(i),x)t=x(1,:)*x(2,:)*(x(1,:)x(2,:) ;sve(tagt n2str(i),t);clearx tend六、实现并行运算加载数据集 fri:matap(siz) dat=ld(inputs um2sr(i),x) ci=dat.x data=load(arget numtr(i),t) =ata.t; clr dataend=cngue(ne2,1,tc1);nt2=rin(net2,c,c);yc=im(ne,xc)七、得到各个woke返回的mpsite结果f i=1:matlbpoo(size) i=yciend八、GP并行cntgpue
4、viceCountu1gpevce(1)puCor1gu1.MltiroessorCount*g1.SMidthnet2=tran(net,x,t,eGPU,ys)y=im(ne,x,uePU,ys)nt1.trainFcn=tracg;n2=rin(nt1,x,t,usGU,yes,showReouces,ye); Mata神经网络4个案例分析九、并行运算与神经网络-基于CPU/GP的并行神经网络运算 王小川(王小川_atla) Emai: 十、清空环境变量clar alllcwaringoff十一、打开matlabooatlaboopnpolsize=mtbpool(e);十二、加载数据l
5、oadbodyfadatasetinputs = bodfatIputs;targs = bodyatTrges;十三、创建一个拟合神经网络hiddenLayeri 10; 隐藏层神经元个数为10nt itnet(hiddenLayrSe); 创建网络十四、指定输入与输出处理函数(本操作并非必须)net.iputs1.oceFcns = emovecontantrows,mapinax;net.ouput2.poceF= emovenstanros,pminma;十五、设置神经网络的训练、验证、测试数据集划分et.dvidecn = diider; 随机划分数据集ne.iideMdsamle;
6、 划分单位为每一个数据et.dePar.tainRtio =700; 训练集比例e.divideParam.lRati 15/00; 验证集比例n.dvdePamtetRi =1/00; 测试集比例十六、设置网络的训练函数ne.rainFn rainl; Levbeg-arqudt十七、设置网络的误差函数ne.rformcn = mse; Measqured error十八、设置网络可视化函数net.plotFcs =pltpeform,plottrainte,ploterrhist,. ltrgreion, plotfit;十九、单线程网络训练cet1,tr1=rai(net,inpus,t
7、ages);t1=to;sp(单线程神经网络的训练时间为,nustr(1),秒);二十、并行网络训练tiet2,t2 = tai(ne,iputs,targe,usParll,ys,showResores,s);t2=toc;disp(并行神经网络的训练时间为,um2str(2),秒);二十一、网络效果验证outputs sm(net1,npus);oututs si(net2,iputs);erors = sbtrac(targs,outpu1);rors2 = gsact(targts,outpts2);peormance1 prform(net1,trget,outpus)perfrac
8、 = perform(net,trts,outpu2)二十二、神经网络可视化igre, lotperform(r1);figu, pterfom(tr2);figue,potrainstate(tr);fgre,plottainate(tr2);figr,plreresion(tarets,outps1);ire,lotregrssion(targets,utputs2);figur,oterrht(ero1);figue,ploterhist(es2);atlapolclsey=(net2,, useGPU,yes,howReoucs,ye);实验记录实验总结1、并行平台的通信模型:共享数据
9、(OSX、winow线程、OpeMP)、消息交换(IPVM) 并行算法模型: 数据并行模型、任务依赖图模型、工作池模型、管理者-工作者模型、消费者模型对于并行计算一个任务可能涉及到的问题: 任务分解、任务依赖关系、任务粒度分配、并发度、任务交互。并行算法性能的常见度量值: 并行开销、加速比、效率(加速比CP数)、成本(并行运行时间*CPU数)。2、人工神经网络就是模拟人思维的第二种方式。这是一个非线性动力学系统,其特色在于信息的分布式存储和并行协同处理。虽然单个神经元的结构极其简单,功能有限,但大量神经元构成的网络系统所能实现的行为却是极其丰富多彩的。3、总结:人工神经网络可通过硬件或软件方式
10、来实现。硬件方式即神经计算机。目前 较常用的还是软件实现方式。已有许多公司和研究单位设计了通用的ANN程序以方便人们使用,alab提供的神经网络工具箱就是其重要代表。 神经网络工具箱是在atlab环境下所开发出来的许多工具箱之一,它是以人工神经网络理论为基础,用matab语言构造出典型神经网络的激活函数,如S型、线性、竞争层、饱和线性等激活函数,使设计者对所选定网络输出的计算变成对激活函数的调用。另外,根据各种典型的修正网络权值的规定,加上网络的训练过程,用mab编写出各种网络设计与训练所涉及的公式运算、矩阵操作和方程求解等大部分子程序,网络的设计者可以根据自己的需要进行调用,免除了自己编写复杂而庞大的算法程序的困扰,集中精力去思考需要解决的问题,提高工作效率和解题质量。 目前malb几乎完整地概括了神经网络的基本成果,对于各种网络模型,神经网络工具箱集成了多种学习算法,为用户提供了极大的方便。 同时,mal的其他工具箱也为我们在神经网络工具箱的基础上开发研究模糊与神经网络的结合、神经网络的样条算法等问题提供了辅助手段。
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1