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

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

?? nn-1.cpp

?? 單輸出神經網絡擬合如下函數:y=sinx1+xinx2+sinx3+sinx4
?? 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)。4個輸入神經元
#define H 10     // number of hidden neurons。10個隱藏神經元
#define O 1     // number of output neurons 。1個輸出神經元
#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;
   double pi=3.1415926;

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

   y[1]=sin(x[1])+sin(x[2])+sin(x[3])+sin(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];

   srand(100);
   // 產生輸入-輸出樣本
   Simu(x,y);
   Standarlize(x,y,standard_x,standard_y);
   Train(x,y,standard_x,standard_y);

  
   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<2000 && 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("TRAIN1.dat","r"))==NULL) {
     mark:
     fp=fopen("TRAIN1.dat","w");
     for(i=1; i<=D; i++) {
	   // 產生一個輸入-輸出對,輸入、輸出值都從第2個位置開始放置!
       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 <<TRAIN1.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("WEIGHT1.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("WEIGHT1.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 <<WEIGHT1.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一区二区三区免费野_久草精品视频
日韩二区在线观看| 亚洲欧洲日产国码二区| 日韩精品成人一区二区三区| 欧美日韩综合一区| 日本免费新一区视频| 欧美一区二区精美| 国产一区二区久久| 日本一区二区成人在线| 色香蕉成人二区免费| 亚洲电影你懂得| 日韩午夜小视频| 91成人在线观看喷潮| 日韩福利视频导航| 国产午夜精品理论片a级大结局| 成人一级视频在线观看| 日韩美女啊v在线免费观看| 欧美无砖砖区免费| 国产一区二区调教| 一区二区三区精密机械公司| 制服丝袜激情欧洲亚洲| 国产乱国产乱300精品| 亚洲日本va在线观看| 欧美日韩免费观看一区二区三区| 免费人成黄页网站在线一区二区 | 免费成人你懂的| 亚洲精品在线一区二区| 成人福利视频网站| 五月天激情小说综合| 久久嫩草精品久久久久| 91麻豆文化传媒在线观看| 蜜乳av一区二区三区| 中文字幕av一区二区三区高| 欧美情侣在线播放| 成人激情黄色小说| 男女性色大片免费观看一区二区 | 精品视频在线看| 国产剧情一区二区三区| 亚欧色一区w666天堂| 精品av久久707| 欧美体内she精高潮| 成人午夜免费av| 麻豆精品久久久| 亚洲最大的成人av| 中文字幕av在线一区二区三区| 欧美一区二区不卡视频| 91蜜桃在线免费视频| 国产乱人伦精品一区二区在线观看| 亚洲一区免费在线观看| 久久精品视频免费观看| 欧美一区三区四区| 91精品办公室少妇高潮对白| 国产精品69毛片高清亚洲| 日韩电影免费在线看| 亚洲制服丝袜在线| 国产欧美日韩另类视频免费观看| 91精品久久久久久久99蜜桃| 在线观看日韩一区| 不卡av免费在线观看| 国产精品一二三四五| 免费国产亚洲视频| 日韩激情在线观看| 亚洲高清免费视频| 亚洲国产精品一区二区久久恐怖片| 国产在线国偷精品免费看| 五月天亚洲精品| 亚洲国产裸拍裸体视频在线观看乱了| 国产精品美女久久久久aⅴ国产馆| 337p日本欧洲亚洲大胆色噜噜| 91精品久久久久久久91蜜桃| 欧美精品日韩综合在线| 欧美视频精品在线| 欧美日本韩国一区| 色婷婷亚洲综合| 91久久精品一区二区三区| 91在线免费视频观看| 色综合天天综合网国产成人综合天 | 粉嫩13p一区二区三区| 国产乱子伦一区二区三区国色天香 | 日韩精品一区二区三区四区视频| 在线播放中文字幕一区| 91精品国模一区二区三区| 91精品国产手机| 日韩一区二区精品在线观看| 欧美精品国产精品| 欧美年轻男男videosbes| 在线成人免费视频| 欧美精三区欧美精三区| 亚洲国产aⅴ天堂久久| 亚洲国产中文字幕在线视频综合| 亚洲综合免费观看高清完整版| 亚洲国产精品久久一线不卡| 日本成人超碰在线观看| 国产在线播精品第三| 国产成人午夜视频| heyzo一本久久综合| 91丝袜呻吟高潮美腿白嫩在线观看| 91视频www| 欧美精品一二三区| 久久久精品欧美丰满| 国产亚洲精品aa午夜观看| 国产精品久线观看视频| 亚洲中国最大av网站| 另类的小说在线视频另类成人小视频在线| 蜜桃传媒麻豆第一区在线观看| 国产精品系列在线观看| 91亚洲男人天堂| 在线播放中文字幕一区| 久久综合久久鬼色中文字| 国产精品久久久久久久久果冻传媒| 一区二区三区中文字幕| 日韩不卡一区二区三区| 懂色av一区二区三区免费观看| 在线一区二区三区四区五区 | 日韩欧美在线一区二区三区| 国产色产综合产在线视频| 亚洲精品伦理在线| 青青草国产精品亚洲专区无| 成人一道本在线| 欧美日韩国产系列| 国产亚洲一区二区在线观看| 亚洲影院久久精品| 国产成人啪免费观看软件| 精品视频999| 国产精品理伦片| 黄色资源网久久资源365| 97精品国产露脸对白| 欧美成人激情免费网| 一区二区三区精品| 成人性生交大片免费看中文网站| 欧美日韩一区视频| 国产精品久久午夜| 美脚の诱脚舐め脚责91| 色妹子一区二区| 久久久久久久久97黄色工厂| 午夜精品久久久久久久久久| 成人污视频在线观看| 日韩欧美国产精品| 一区二区三区欧美在线观看| 成人一区在线观看| 精品国产在天天线2019| 亚洲愉拍自拍另类高清精品| 成人av在线观| 国产亚洲午夜高清国产拍精品| 午夜伦欧美伦电影理论片| 97精品久久久午夜一区二区三区 | 日韩欧美综合在线| 亚洲一区二区精品久久av| yourporn久久国产精品| 精品国产精品网麻豆系列| 天堂在线一区二区| 色香蕉久久蜜桃| 亚洲欧美激情在线| 99视频在线精品| 国产女主播在线一区二区| 狠狠狠色丁香婷婷综合激情| 日韩一区二区免费高清| 蜜桃久久久久久久| 91精品国产91久久久久久一区二区| 亚洲午夜免费电影| 欧美色男人天堂| 亚洲午夜成aⅴ人片| 色综合色狠狠综合色| 亚洲私人黄色宅男| 99久久综合精品| 亚洲色图另类专区| 99久久国产综合色|国产精品| 久久精品视频网| 成人午夜激情在线| 国产精品视频一二三| 成人午夜视频福利| ●精品国产综合乱码久久久久| 成人激情动漫在线观看| 1000精品久久久久久久久| 91香蕉视频污在线| 亚洲动漫第一页| 91精品国产综合久久国产大片| 视频一区视频二区中文字幕| 欧美一区二区三区视频免费播放| 奇米一区二区三区| 精品久久久久99| 国产jizzjizz一区二区| 亚洲日本韩国一区| 欧美性受xxxx黑人xyx性爽| 日日噜噜夜夜狠狠视频欧美人| 欧美一区二区大片| 国产成人综合在线| 亚洲视频小说图片| 欧美电影一区二区三区| 久久国产精品露脸对白| 亚洲国产精华液网站w| 99久久久无码国产精品| 一区二区三区中文字幕| 69堂精品视频| 国产乱色国产精品免费视频| 中文字幕一区免费在线观看| 欧美日韩久久不卡| 国产精品自拍一区| 亚洲黄色av一区| 欧美一级夜夜爽| 国产.欧美.日韩|