亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? nn-3.cpp

?? 單輸出的神經元網絡擬合有噪聲干擾的函數:y=x1/(1+x1) + x2/(1+x2) + x3/(1+x3) + x4/(1+x4)
?? CPP
字號:
// Neural Networks
// Written by Microsoft Visual C++
// Copyright by UTLab at Tsinghua University

#include "math.h"
#include "stdlib.h"
#include "stdio.h"
#include "conio.h"
#include "UTLab.h"

#define N 4     // number of input neurons (decision variables)
#define H 6     // number of hidden neurons
#define O 1     // number of output neurons
#define D 3000  // number of training data
#define SIMU_PRINT_NUMBER 100

static double BOUND[N+O+1][2], WH[H+1][N+1], WO[O+1][H+1];
static void   Simu(double x[D+1][N+1], double y[D+1][O+1]);
static void   Input_Output(double x[N+1], double y[O+1]);
static void   Train(double original_x[D+1][N+1], double original_y[D+1][O+1],
			  double standard_x[D+1][N+1], double standard_y[D+1][O+1]);
static void   Standarlize(double original_x[D+1][N+1], double original_y[D+1][O+1],
			  double standard_x[D+1][N+1], double standard_y[D+1][O+1]);
static void   BPA(double standard_x[D+1][N+1], double standard_y[D+1][O+1]);
static void   Init_NN(void);
static void   NN(double x[N+1], double y[O+1]);

static void Input_Output(double x[N+1], double y[O+1])
{
   int i;

   for(i=1; i<=N; i++) x[i]=myu(0,2);

   y[1]=x[1]/(1+x[1])+x[2]/(1+x[2])+x[3]/(1+x[3])+x[4]/(1+x[4])+myu(-0.1,0.1);
}

static void InputOutput(double x[N+1], double y[O+1])
{
   int i;

   for(i=1; i<=N; i++) x[i]=myu(0,2);

   y[1]=x[1]/(1+x[1])+x[2]/(1+x[2])+x[3]/(1+x[3])+x[4]/(1+x[4]);
}

int main( void )
{
   double x[D+1][N+1], y[D+1][O+1], standard_x[D+1][N+1], standard_y[D+1][O+1];
   int i, j;
   double xx[5], yy[2], zz[2];
   double a=0,b=0;

   srand(100);
   Simu(x,y);
   Standarlize(x,y,standard_x,standard_y);
   Train(x,y,standard_x,standard_y);

   for(i=1; i<=1000; i++) {
       for(j=1; j<=4; j++) xx[j]=myu(0, 2);
       InputOutput(xx,yy);
       NN(xx,zz);
       a += (yy[1]-zz[1])*(yy[1]-zz[1]);
	   b += pow(myu(-0.1,0.1),2);
   }
   printf("%f,%f",a/2,b/2);
  
   return 1;
}

static void BPA(double x[D+1][N+1],double y[D+1][O+1])
{	
	
	double E0 = 0.001;
    double EE0 = 0.001;
	double TOLERANCE=0.0001;// *((N+1+O)*H+O);
	int    i,j,k,step=0;
	double ALPHA=0.05;
	double BETA=4./3;
	double ETA=0.5;
	double MU=1.;
	double DETA_WH[H+1][N+1],DETA_WO[O+1][H+1];
	double E_WO[O+1],E_WH[H+1],h[H+1],NN_y[O+1];
	double e[O+1],lambda,E,EE,TD,temp;
	
	Init_NN();
    for( i=1; i<=H; i++ )
		for( j=0; j<=N; j++ )
			DETA_WH[i][j] = 0.;
	for( i=1; i<=O; i++ )
		for( j=0; j<=H; j++ )
			DETA_WO[i][j] = 0.;

	lambda=1.;
	do
	{	step++; 
	    E=0.;
		TD=0.;
		EE=0.;
		for( k=1; k<=D; k++)
		{	/*calculate the output of the hidden neurons*/
			h[0]=1.;
			for( i=1; i<=H; i++ )
			{	h[i] = WH[i][0];
				for( j=1; j<=N; j++ )
					h[i] += WH[i][j] * x[k][j];
				h[i] = tanh(h[i]);
			}

			/*calculate the output of the outlayer neurons*/
			for( i=1; i<=O; i++ )
			{	NN_y[i] = WO[i][0];
				for( j=1; j<=H; j++)
					NN_y[i] += WO[i][j] * h[j];
			}

			/*adjust the weights of WO:*/
			for( i=1; i<=O; i++ )
			{	e[i] = y[k][i] - NN_y[i];
				E_WO[i] = lambda*e[i] + (1-lambda)*tanh(BETA*e[i]);
				for( j=0; j<=H; j++ )
				{	DETA_WO[i][j] = ETA*DETA_WO[i][j] + ALPHA*E_WO[i]*h[j];
					TD += fabs(DETA_WO[i][j]);
					WO[i][j] += DETA_WO[i][j];
				}
			}

			/*adjust the weights of WH:*/
			for( j=1; j<=H; j++ )
			{	for( i=1,temp=0.; i<=O; i++ )
					temp += E_WO[i] * WO[i][j];
				E_WH[j] = ( 1-h[j]*h[j])*temp;
				DETA_WH[j][0] = ETA*DETA_WH[j][0] +ALPHA*E_WH[j];
				TD += fabs(DETA_WH[j][0]);
				WH[j][0] += DETA_WH[j][0];
				for( i=1; i<=N; i++ )
				{   DETA_WH[j][i]= ETA*DETA_WH[j][i] +ALPHA*E_WH[j]*x[k][i];
					TD += fabs(DETA_WH[j][i]);
					WH[j][i] += DETA_WH[j][i];
				}
			}

			/*calculate the total errors*/
			for( i=1; i<=H; i++ )
			{	h[i] = WH[i][0];
				for( j=1; j<=N; j++ )
					h[i] += WH[i][j]*x[k][j];
				h[i] = tanh(h[i]);
			}
			for( i=1; i<=O; i++ )
			{	NN_y[i] = WO[i][0];
				for( j=1; j<=H; j++)
					NN_y[i] += WO[i][j] * h[j];
			}
			for( i=1; i<=O; i++ )
			{	e[i] = y[k][i] - NN_y[i];
				EE += fabs(e[i])/D;
				E += 0.5*e[i]*e[i];
			}
		}
		lambda = exp( -MU/(E*E));
		TD=TD/D;
		if(step%100==0) printf("\nBPA_%d  (Std)Sum-squared-E=%f  Average-E=%f  Gradient=%f;",step,E,EE,TD);
	} while ( step<3000 && TD>TOLERANCE && E>E0 && EE>EE0);
	printf("\nBPA_%d  (Std)Sum-squared-E=%f  Average-E=%f  Gradient=%f;",step,E,EE,TD);
}

static void Simu(double x[D+1][N+1], double y[D+1][O+1])
{
   int	i, j;
   double xx[N+1], yy[O+1];
   float read;
   FILE  *fp;

   if((fp=fopen("TRAIN3.dat","r"))==NULL) {
     mark:
     fp=fopen("TRAIN3.dat","w");
     for(i=1; i<=D; i++) {
       Input_Output(xx, yy);
       if(i%SIMU_PRINT_NUMBER==0) 
		  printf("\n%d input-output Data have been generated",i);
       for(j=1; j<=N; j++) {
          x[i][j]=xx[j];
          fprintf(fp,"%3.6f ",xx[j]);
       }
       for(j=1; j<=O; j++) {
          y[i][j]=yy[j];
          fprintf(fp,"%3.6f ",yy[j]);
       }
	   fprintf(fp,"\n");
     }
     fclose(fp);
   }
   else {
     printf("The training data <<TRAIN3.dat>> already exists. Renew it? (y/n)");
     if(getche()=='y') goto mark;
     for(i=1; i<=D; i++) {
        for(j=1; j<=N; j++) {
          fscanf(fp,"%f",&read);
          x[i][j]=read;
        }
        for(j=1; j<=O; j++) {
          fscanf(fp,"%f",&read);
          y[i][j]=read;
        } 
     }
   }
   fclose(fp);
}


static void Train(double x[D+1][N+1], double y[D+1][O+1],double standard_x[D+1][N+1], double standard_y[D+1][O+1])
{
   int i, j, k;
   double E1, E2, a, xx[N+1], yy[O+1];
   float read;
   FILE *fp;

   if((fp=fopen("WEIGHT3.dat","r"))==NULL) {
        mark:
        BPA(standard_x,standard_y);
        E1=0;
        E2=0;
        for(i=1; i<=D; i++) {
           for(j=1; j<=N; j++) xx[j]=x[i][j];
           NN(xx,yy);
           a=0;
           for(j=1; j<=O; j++) a += (yy[j]-y[i][j])*(yy[j]-y[i][j]);
           E1=E1+a;
           E2=E2+sqrt(a);
        }
        E1=E1/2;
        E2=E2/D;
        printf("\n\nSum-Squared Error = %3.4f",E1);
        printf("\nAverage Error = %3.4f\n\n",E2);
        for(i=1; i<=18; i++){
           k=(int)myu(1,D);
           for(j=1; j<=N; j++) xx[j]=x[k][j];
           NN(xx,yy);
           printf("Sample %2d: y=(",i);
		   for(j=1; j<=O; j++) {
			   if(j<O) printf("%3.4f,",y[k][j]);
			   else printf("%3.4f",y[k][j]);
		   }
		   printf(") Dif.=(");
           for(j=1; j<=O; j++) {
			   if(j<O) printf("%3.4f,",yy[j]-y[k][j]);
			   else printf("%3.4f",yy[j]-y[k][j]);
		   }
           printf(")\n");
        }
        printf("\nAre you satisfactory?(y/n)");
        if(getche()=='n') goto mark;
		printf("\n");

        fp=fopen("WEIGHT3.dat","w");
        for(i=1; i<=H; i++) {
           for(j=0; j<=N; j++) fprintf(fp,"%3.4f ",WH[i][j]);
           fprintf(fp,"\n");
        }
        for(i=1; i<=O; i++) {
          for(j=0; j<=H; j++) fprintf(fp,"%3.4f ",WO[i][j]);
          fprintf(fp,"\n");
        }
        fclose(fp);

   }
   else {
     printf("\nThe weight data <<WEIGHT3.dat>> already exists. Renew it? (y/n)");
     if(getche()=='y') goto mark;
     for(i=1; i<=H; i++)
        for(j=0; j<=N; j++) {
 	     fscanf(fp, "%f", &read);
        WH[i][j]=read;
     }
	  for(i=1; i<=O; i++)
		  for(j=0; j<=H; j++) {
			  fscanf(fp,"%f", &read);
           WO[i][j]=read;
        }
     fclose(fp);
   }
}



static void Standarlize(double x[D+1][N+1],double y[D+1][O+1],double xx[D+1][N+1],double yy[D+1][O+1])
{  
	int i,k;
	for(i=1; i<=N; i++) {
		BOUND[i][0]=x[1][i];
		BOUND[i][1]=x[1][i];
	}
	for( i=1; i<=O; i++ ) {
		BOUND[N+i][0]=y[1][i];
		BOUND[N+i][1]=y[1][i];
	}
	for( k=2; k<=D; k++ ) {
		for( i=1; i<=N; i++ )
		{   if(BOUND[i][0]>x[k][i])	
				BOUND[i][0]=x[k][i];
			if(BOUND[i][1]<x[k][i])	
				BOUND[i][1]=x[k][i];
		}
		for( i=1; i<=O; i++ )
		{   if(BOUND[N+i][0]>y[k][i])	
				BOUND[N+i][0]=y[k][i];
			if(BOUND[N+i][1]<y[k][i])	
				BOUND[N+i][1]=y[k][i];
		}
	}
	for( i=1; i<=N+O; i++ )
		BOUND[i][1]=BOUND[i][1] - BOUND[i][0];
	for( k=1; k<=D; k++ )
	{	for( i=1; i<=N; i++ )
			xx[k][i]=(x[k][i]-BOUND[i][0])/BOUND[i][1];
		for( i=1; i<=O; i++ )
			yy[k][i]=(y[k][i]-BOUND[N+i][0])/BOUND[N+i][1];
	}
}

static void NN( double x[], double y[] )
{	
	double h[H+1];
	int i,j;
	for( i=1; i<=H; i++ )
	{	h[i] = WH[i][0];
		for( j=1; j<=N; j++ )
			h[i] += WH[i][j] * (x[j]-BOUND[j][0])/BOUND[j][1];
		h[i] = tanh( h[i] );
	}
	for( i=1; i<=O; i++ )
	{	y[i] = WO[i][0];
		for( j=1; j<=H; j++)
			y[i] += WO[i][j] * h[j];
		y[i] = y[i]*BOUND[N+i][1] + BOUND[N+i][0];
	}
}

static void Init_NN(void)
{
   int i, j;
   for(i=1; i<=H; i++)
      for(j=0; j<=N; j++)
         WH[i][j]= myu(-0.3,0.3);
   for(i=1; i<=O; i++)
      for(j=0; j<=H; j++)
         WO[i][j]= myu(-0.3,0.3);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品福利av导航| 蜜桃视频在线一区| 麻豆高清免费国产一区| 成人av免费在线播放| 日韩三级视频中文字幕| 亚洲美女区一区| 成人综合婷婷国产精品久久免费| 欧美日韩国产在线播放网站| 一区视频在线播放| 国产精品亚洲成人| 日韩三级电影网址| 亚洲mv在线观看| 欧美日韩久久久久久| 成人欧美一区二区三区白人| 国产精品白丝jk黑袜喷水| 欧美一二三在线| 婷婷成人综合网| 欧美日韩在线播| 午夜影院在线观看欧美| 在线观看一区不卡| 一区二区三区欧美激情| 色综合天天综合网国产成人综合天 | 91欧美激情一区二区三区成人| 久久伊99综合婷婷久久伊| 男女性色大片免费观看一区二区| 在线观看网站黄不卡| 亚洲一区二区三区三| 日本乱人伦aⅴ精品| 一片黄亚洲嫩模| 欧美亚洲综合一区| 亚洲成人资源网| 欧美一级在线观看| 黄色日韩网站视频| 久久久久久电影| jlzzjlzz欧美大全| 亚洲免费av在线| 欧美午夜一区二区三区| 五月开心婷婷久久| 欧美成人性战久久| 国产剧情在线观看一区二区| 国产欧美综合在线观看第十页| 国产福利一区二区三区| 国产精品欧美久久久久无广告| 99久久伊人久久99| 亚洲精品国产无天堂网2021| 欧美日韩国产免费一区二区| 日韩高清国产一区在线| 精品国产乱码久久久久久老虎| 国产在线不卡一卡二卡三卡四卡| 欧美国产日韩a欧美在线观看 | 国产一区二区三区不卡在线观看 | 欧美在线999| 日韩高清在线观看| 精品国产乱码91久久久久久网站| 国产成人亚洲精品青草天美| 亚洲乱码日产精品bd| 911精品国产一区二区在线| 久久精品国产免费看久久精品| 午夜影院久久久| 久久久久久久久久久电影| 91在线观看免费视频| 男男gaygay亚洲| 综合网在线视频| 日韩欧美在线影院| 99国产精品久久久| 麻豆精品精品国产自在97香蕉| 国产精品欧美综合在线| 欧美乱熟臀69xxxxxx| 懂色av一区二区在线播放| 亚洲综合激情小说| 久久男人中文字幕资源站| 91麻豆国产自产在线观看| 日韩av一二三| 亚洲品质自拍视频网站| 日韩免费视频一区二区| 91浏览器在线视频| 紧缚捆绑精品一区二区| 亚洲小说欧美激情另类| 久久亚洲综合色一区二区三区| 91免费在线看| 国精品**一区二区三区在线蜜桃| 一区二区三区影院| 久久久不卡网国产精品一区| 91久久人澡人人添人人爽欧美| 精品在线播放免费| 亚洲愉拍自拍另类高清精品| 国产精品色一区二区三区| 欧美一级免费观看| 日本久久电影网| 国产九九视频一区二区三区| 亚洲第一主播视频| 亚洲男同性恋视频| 国产欧美日产一区| 精品久久五月天| 日韩午夜小视频| 色94色欧美sute亚洲线路一ni| 国内成人免费视频| 美女在线视频一区| 日本一区中文字幕| 一区二区三区在线免费观看| 久久久久国产成人精品亚洲午夜| 91麻豆精品国产91久久久资源速度| 色综合久久久久久久久久久| 国产福利一区二区三区在线视频| 日本成人在线视频网站| 国产成人午夜片在线观看高清观看| 免费看欧美美女黄的网站| 午夜久久久久久久久久一区二区| 亚洲国产欧美日韩另类综合| 亚洲一区二区在线免费观看视频 | 美腿丝袜亚洲三区| 美女视频一区二区三区| 免费人成黄页网站在线一区二区| 亚洲一区中文在线| 性欧美疯狂xxxxbbbb| 亚洲成人你懂的| 日韩精品电影一区亚洲| 日本欧美在线观看| 久久成人免费日本黄色| 狠狠网亚洲精品| 国产精华液一区二区三区| 风间由美中文字幕在线看视频国产欧美| 国产精品一线二线三线| 国产成人综合自拍| 97超碰欧美中文字幕| 色999日韩国产欧美一区二区| 欧洲激情一区二区| 日韩免费一区二区| 欧美国产乱子伦| 亚洲乱码精品一二三四区日韩在线| 一区二区在线观看免费| 三级欧美在线一区| 精品一二三四在线| 成人深夜福利app| 在线中文字幕不卡| 日韩女优视频免费观看| 国产欧美精品一区二区三区四区 | 自拍偷自拍亚洲精品播放| 一区二区三区日韩欧美精品 | 懂色av一区二区三区免费观看 | 午夜欧美在线一二页| 国内精品久久久久影院薰衣草 | 丁香婷婷综合色啪| 在线观看一区二区精品视频| 日韩午夜激情视频| 国产精品不卡一区| 日韩av午夜在线观看| 成人中文字幕在线| 欧美日韩色一区| 久久久777精品电影网影网 | 欧美精选午夜久久久乱码6080| 精品sm捆绑视频| 亚洲精品五月天| 国产精品69毛片高清亚洲| 色狠狠色狠狠综合| 久久久一区二区| 婷婷久久综合九色综合绿巨人 | 亚洲狼人国产精品| 久久99久久99| 欧美视频一区二| 中文字幕制服丝袜成人av | 亚洲国产日日夜夜| 国产福利精品导航| 日韩一区二区三区三四区视频在线观看| 国产精品美女久久久久高潮| 日韩黄色免费电影| 99精品国产91久久久久久 | 日韩精品一区二区三区在线观看| 国产精品久久毛片| 国产综合色视频| 欧美日韩免费电影| 亚洲女与黑人做爰| 成人美女在线观看| 久久久久久久久久久久久久久99| 亚洲大型综合色站| 在线视频欧美精品| 中文字幕中文字幕在线一区 | 91视视频在线观看入口直接观看www | 欧美日韩精品三区| 亚洲精品福利视频网站| 不卡的看片网站| 国产欧美一区二区三区沐欲| 蜜臀精品一区二区三区在线观看 | 狠狠色丁香久久婷婷综| 欧美国产一区二区| 国产精品一区二区免费不卡| 欧美一区二区三区日韩| 日韩精品一二区| 欧美精品乱码久久久久久按摩| 亚洲在线一区二区三区| 色综合久久中文字幕| 亚洲色图视频免费播放| 99久久久久久| 亚洲少妇30p| 91黄色免费看| 亚洲夂夂婷婷色拍ww47| 欧美日韩综合不卡| 亚洲成人1区2区| 91.成人天堂一区| 免费观看在线色综合|