Abstract: Putting forward along with the computing intelligence, artificial neural network has been developing. At present the industry considering the neural network (NN) classified as artificial intelligence (AI) may not appropriate, and classified as computational intelligence (CI) more telling. Evolutionary computation, artificial life, and some issues of the fuzzy logic system, are classified as computational intelligence. Despite the limits of computational intelligence and artificial intelligence is not obvious, however, discuss the difference and relationship is beneficial, logical thinking refers to the process according to the rules of logic reasoning; It will first information into the concept and symbol, and then, according to the symbolic operation logic reasoning according to the serial mode; This process can be written as a serial of instruction, let the computer to perform. However, visual thinking is the distributed storage of information together, the result is suddenly an idea or a solution to the problem. And this paper is devoted to general thoughts about neural network processing, as well as computer science and technology under the junior professional class "artificial intelligence" of the fourth algorithm experiment.
Keywords: Artificial intelligence, neural network, the perceptron model
1,神经网络的发展
2.2 响应函数的基本作用
感知器是由美国计算机科学家罗森布拉特(F.Roseblatt)于1957年提出的。单层感知器神经元模型图:
3.1训练步骤
1)对于所要解决的问题,确定输入向量 X,目标向量T,由此确定维数及网络结构参数,n,m;
2) 参数初始化;
3)设定最大循环次数;
4)计算网络输出;
5)检查输出矢量Y与目标矢量T是否相同,如果相同,或以达最大循环次数,训练结束,否则转入6;
6)学习,并返回4。
3.2网络训练
自适应线性元件的网络训练过程可以归纳为以下三个步骤:
1)表达:计算模型的输出矢量A=W*P十B,以及与期望输出之间的误差E=T—A;
2)检查:将网络输出误差的平方和与期望误差相比较,如果其值小于期望误差,或训练已达到事先设定的最大训练次数,则停止训练;
3)学习:采用W—H学习规则计算新的权值和偏差,并返回到1)。
4,问题引入
4.1问题描述
现在来考虑一个较大的多神经元网络的模式联想的设计问题。输入矢量和目标矢量分别为:
P=
{
{1,-1,2},
{1.5,2,1},
{1.2,3,-1.6},
{-0.3,-0.5,0.9}
};
T=
{
{0.5,1.1,3,-1},
{3,-1.2,0.2,0.1},
{-2.2,1.7,-1.8,-1.0},
{1.4,-0.4,-0.4,0.6}
};
4.2解题思路
由输入矢量和目标输出矢量可得:输入向量个数 r=3,输出向量个数 s=4,样本数 q=4。
这个问题的求解同样可以采用线性方程组求出,即对每一个输出节点写出输入和输出之间的关系等式。
实际上要求出这16个方程的解是需要花费一定的时间的,甚至是不太容易的。
对于一些实际问题,常常并不需要求出其完美的零误差时的解。也就是说允许存在一定的误差。
在这种情况下,采用自适应线性网络求解就显示出它的优越性:因为它可以很快地训练出满足一定要求的网络权值。
#include<iostream> #include<ctime> #include<cmath> using namespace std; const int max_learn_length = 100; //最大学习次数 const float study_rate = 0.2; //学习率 const float anticipation_error = 0.01; //期望误差 const int input = 3; //三项输入 const int output = 4; //四项输出 const int sample = 4; //4组样本 float P[sample][input] = //4组3项的输入矢量 { {1,-1,2}, {1.5,2,1}, {1.2,3,-1.6}, {-0.3,-0.5,0.9} }; float T[sample][output] = //4组4项的期望输出矢量 { {0.5,1.1,3,-1}, {3,-1.2,0.2,0.1}, {-2.2,1.7,-1.8,-1.0}, {1.4,-0.4,-0.4,0.6} }; int main(int argc, char **argv) { float precision; //误差精度变量 float W[input][sample]; //3项4组输入对应的网络权值变量 float B[sample]; //4组阈值变量 float A[sample]; //每组实际输出值 int ii, ij, ik, ic; srand(time(0)); //初始化随机函数 for (ii = 0; ii<sample; ii++) { B[ii] = 2 * (float)rand() / RAND_MAX - 1; //阈值变量赋随机值(-1,1) for (ij = 0; ij<input; ij++) //网络权值变量赋随机值 { W[ij][ii] = 2 * (float)rand() / RAND_MAX - 1; } } precision = FLT_MAX ; //初始化精度值 for (ic = 0; ic < max_learn_length; ic++) //最大学习次数内循环 { if (precision<anticipation_error) //循环剪枝函数 { break; } precision = 0; for (ii = 0; ii<sample; ii++) //4组样本循环叠加误差精度 { for (ij = 0; ij<output; ij++) //计算一组中4项实际的输出 { A[ij] = 0.0; for (ik = 0; ik<input; ik++) { A[ij] += P[ii][ik] * W[ik][ij]; } A[ij] += B[ij]; } for (ij = 0; ij<output; ij++) //通过学习率调整网络权值和阈值 { for (ik = 0; ik<input; ik++) { W[ik][ij] += study_rate*(T[ii][ij] - A[ij])*P[ii][ik]; } B[ij] += study_rate*(T[ii][ij] - A[ij]); } for (ij = 0; ij<output; ij++) //计算误差精度 { precision += pow((T[ii][ij] - A[ij]),2); } } } cout << "最大学习次数为:" << max_learn_length << endl; cout << "完成目标的学习次数为:" << ic << endl; cout << endl << "期望误差为:" << anticipation_error << endl; cout << "达成目标学习后的精度为:" << precision <<endl<< endl; cout << "学习后的网络权值为:" << endl; for (ii = 0; ii<sample; ii++) //输出学习后的网络权值 { for (ij = 0; ij<input; ij++) //4组样本每组3个输入 { cout << W[ii][ij] << " "; } cout << endl; } cout <<endl<< "学习后的阈值为:" << endl; for (ii = 0; ii<output; ii++) //输出学习后的阈值:四个样本输出 { cout << B[ii] << " "; } cout << endl<<endl; system("pause"); return 0; }