您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 项目/工程管理 > MATLAB程序代码--神经网络基础问题整理
MATLAB程序代码--神经网络基础问题整理所选问题及解答大部分来源于资料大部分为江南一纪收集整理对其他参与整理的版友(不一一列举)及资料的原创者一并表示感谢因江南对神经网络的理解也不是很多错误之处难勉请谅解有什么问题可以来的『人工神经网络专区』交流*****************************************************************1神经网络的教材哪本比较经典神经网络原理SimonHaykin?叶世?史忠植译神经网络设计神经网络书籍神经网络模型及其matlab仿真程序设计周开利(对神经网络工具箱函数及里面神经网络工具箱的神经网络模型的网络对象及其属性做了详细的论述,后者在神经网络理论与matlab7实现那本书里面是没有的)神经网络理论与matlab7实现(这本书对初学这入门还是挺不错的,看过了,就对matlab神经网络工具箱有教好的了解)神经网络设计(我认为这是一本很好的书,讲理论不是很多,看过之后就会对神经网络的原理有更好的了解)神经网络结构设计的理论与方法(这本书对提高网络的泛化能力的一些方法做了讲述,并且书后有程序,对网络结构的设计应该是挺有帮助的)摘自给初学matlab神经网络的一点建议=1111&keyword=2神经网络理论的发展与前沿问题神经网络理论的发展与前沿问题刘永?摘要系统地论述了神经网络理论发展的历史和现状,在此基础上,对其主要发展趋向和所涉及的前沿问题进行了阐述.文中还作了一定的评论,并提出了新的观点.关键词神经网络理论,神经计算,进化计算,基于神经科学和数学的研?查看原文=5374&keyword=%C9%F1%BE%AD%CD%F8%C2%E73神经网络的权值和阈值分别是个什么概念??权值和阈值是神经元之间的连接,将数据输入计算出一个输出,然后与实际输出比较,误差反传,不断调整权值和阈值假如p1=[11-1]';p2=[1-1-1]';属于不同的类须设计分类器将他们分开这里用单层神经元感知器初始权值w=[0.20.20.3]b=-0.3输出a1a2a1=hardlims(w*p1+b)a2=hardlims(w*p2+b)如果不能分开,还须不断调整w,b这里说明一下权值w阈值b而已简单地说,阈值也可以看作一维权值,只不过它所对应的那一维样本永远是-1(也有的书上说是1),这样就把输入样本增加了一维,更有利于解决问题.=6078&keyword=%C9%F1%BE%AD%CD%F8%C2%E74神经网络归一化看了研学和ai创业研发俱乐部神经网络版及振动论坛部分帖子内容,对归一化做一下整理,冒昧引用了一些他人的观点,有的未列出其名,请谅解-------------------------------------------------------------------------------------------------------关于神经网络归一化方法的整理由于采集的各数据单位不一致,因而须对数据进行[-1,1]归一化处理,归一化方法主要有如下几种,供大家参考:(byjames)1、线性函数转换,表达式如下:y=(x-MinValue)/(MaxValue-MinValue)说明:x、y分别为转换前、后的值,MaxValue、MinValue分别为样本的最大值和最小值。2、对数函数转换,表达式如下:y=log10(x)说明:以10为底的对数函数转换。3、反余切函数转换,表达式如下:y=atan(x)*2/PI-------------------------------------------------------------------------------------------------------归一化是为了加快训练网络的收敛性,可以不进行归一化处理归一化的具体作用是归纳统一样本的统计分布性。归一化在0-1之间是统计的概率分布,归一化在-1--+1之间是统计的坐标分布。归一化有同一、统一和合一的意思。无论是为了建模还是为了计算,首先基本度量单位要同一,神经网络是以样本在事件中的统计分别几率来进行训练(概率计算)和预测的,归一化是同一在0-1之间的统计概率分布;当所有样本的输入信号都为正值时,与第一隐含层神经元相连的权值只能同时增加或减小,从而导致学习速度很慢。为了避免出现这种情况,加快网络学习速度,可以对输入信号进行归一化,使得所有样本的输入信号其均值接近于0或与其均方差相比很小。归一化是因为sigmoid函数的取值是0到1之间的,网络最后一个节点的输出也是如此,所以经常要对样本的输出归一化处理。所以这样做分类的问题时用[0.90.10.1]就要比用[100]要好。但是归一化处理并不总是合适的,根据输出值的分布情况,标准化等其它统计变换方法有时可能更好。-------------------------------------------------------------------------------------------------------关于用premnmx语句进行归一化:premnmx语句的语法格式是:[Pn,minp,maxp,Tn,mint,maxt]=premnmx(P,T)其中P,T分别为原始输入和输出数据,minp和maxp分别为P中的最小值和最大值。mint和maxt分别为T的最小值和最大值。premnmx函数用于将网络的输入数据或输出数据进行归一化,归一化后的数据将分布在[-1,1]区间内。我们在训练网络时如果所用的是经过归一化的样本数据,那么以后使用网络时所用的新数据也应该和样本数据接受相同的预处理,这就要用到tramnmx。下面介绍tramnmx函数:[Pn]=tramnmx(P,minp,maxp)其中P和Pn分别为变换前、后的输入数据,maxp和minp分别为premnmx函数找到的最大值和最小值。(byterry2008)---------------------------------matlab中的归一化处理有三种方法1.premnmx、postmnmx、tramnmx2.restd、poststd、trastd3.自己编程具体用那种方法就和你的具体问题有关了(byhappy)----------------------------------pm=max(abs(p(i,:)));p(i,:)=p(i,:)/pm;和fori=1:27p(i,:)=(p(i,:)-min(p(i,:)))/(max(p(i,:))-min(p(i,:)));end可以归一到01之间0.1+(x-min)/(max-min)*(0.9-0.1)其中max和min分别表示样本最大值和最小值。这个可以归一到0.1-0.95如何查看BP神经网络训练后的权值和阈值呀!!训练好的权值、阈值的输出方法是:输入到隐层权值:w1=net.iw{1,1}隐层阈值:theta1=net.b{1}隐层到输出层权值:w2=net.lw{2,1};输出层阈值:theta2=net.b{2}6训练好的BP神经网络如何保存呀用命令savefilenamenet;保存网络,调用时用命令loadfilenamenet;7用BP逼近非线性函数,如何提高训练精度啊(1)调整网络结构增加网络的层数可以进一步降低误差,提高精度但会使网络复杂化,从而增加网络的训练时间。精度的提高实际上也可以通过增加隐层神经元的数目来获得,其效果更容易观察和掌握,所以应优先考虑。(2)初始值选取为了使误差尽可能小,需要合理选择初始权重和偏置,如果太大就容易陷入饱和区,导致停顿。一般应选为均匀分布的小数,介于(一1,1)。(3)学习速率调整学习速率的选取很重要,大了可能导致系统不稳定,小了会导致训练周期过长、收敛慢,达不到要求的误差。一般倾向于选取较小的学习速率以保持系统稳定,通过观察误差下降曲线来判断。下降较快说明学习率比较合适,若有较大振荡则说明学习率偏大。同时,由于网络规模大小的不同,学习率选择应当针对其进行调整。(4)期望误差期望误差当然希望越小越好,但是也要有合适值。8关于BP网络优缺点的讨论=3409对初学神经网络者的小提示=427&fpage=310神经网络学习的讨论=298011权威!!!BP网络中隐层结点个数的确定!!!=269&fpage=212神经网络混合编程VB6.0中调用nnToolKit工具包程序=1209在VC中使用nntoolkit工具箱=1236cb6.0中调用nnToolKit工具包程序=121013用遗传算法优化BP神经网络的Matlab编程由于BP网络的权值优化是一个无约束优化问题,而且权值要采用实数编码,所以直接利用Matlab遗传算法工具箱。以下贴出的代码是为一个19输入变量,1个输出变量情况下的非线性回归而设计的,如果要应用于其它情况,只需改动编解码函数即可。具体请查看=292514帮我看一下BP神经网络程序出错在哪里,愁死我了p=[1,15,25;2,15,25;3,15,25;4,15,25;1,15,25;2,5,25;2,7.5,25;2,10,25;2,15,25;];t=[0.6169;0.7068;0.7998;0.9052;1.0881;3.4255;1.0509;0.8835;0.7068];[pn,minp,maxp]=premnmx(p);net=newff(minmax(pn),[9,12,1],{'tansig','tansig','purelin'},'traingdm');net.trainparam.show=25;net.trainparam.mc=0.9;net.trainparam.lr=0.05;net.trainparam.epochs=1000;net.trainparam.goal=0.00001;net=init(net);[net,tr]=train(net,p,t);出错的原因是Errorusing==network/trainTargetsareincorrectlysizedfornetwork.Matrixmusthave1rows.---------------------------------------------------------------------------pt的列数要相等在[pn,minp,maxp]=premnmx(p);前面加入:p=p';t=t'。在使用工具箱进行网络训练时,要求训练样本的个体是列向量。=5847&keyword=%C9%F1%BE%AD%CD%F8%C2%E715问各位一个问题,我用一个前向神经网络作分类,希望输出[1;0;0]表示一类;但是输出的是[0.9997;0.0001;0]诸如此类,我该怎么判断分类的成功与否?判断一下
本文标题:MATLAB程序代码--神经网络基础问题整理
链接地址:https://www.777doc.com/doc-4747800 .html