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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? rosenbrock1.cpp

?? 最優(yōu)化算法
?? CPP
字號:
// RosenBrock1.cpp: implementation of the CRosenBrock class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "RosenBrock.h"
#include "RosenBrock1.h"
#include <math.h>
#include "StringResolution.h"


#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CRosenBrock::CRosenBrock(CString gongshi,CString x1,CString l1,CString &jieguo,float a1,float b1,float e1,int n1)
{
	j=1;
	k=1;
	a=a1;
	b=b1;
	e=e1;
	n=n1;
	d=new float*[n+1];
	p=new float*[n+1];
	q=new float*[n+1];
	l0=new float[n+1];
	l=new float[n+1];
	r=new float[n+1];
	resual=new float[n];
	jisuan.SetFormula(gongshi.GetBuffer(gongshi.GetLength()));


	for(int z=1;z<20;z++)//為x,y,l分配空間
	{
		x[z]=new float[n];
		y[z]=new float[n];		
	}
	string2(x1,x[1],n1);
	string2(l1,&l0[1],n1);

	for(int t=1;t<n+1;t++)//為d(n)分配空間//單位正交方向化
	{
		r[t]=0;
		p[t]=new float[n];
		q[t]=new float[n];
		d[t]=new float[n];	
		float * temp=d[t];
		for(int c=0;c<n;c++)//d的單位矩陣
			temp[c]=0;
		temp[t-1]=1;
		l[t]=l0[t];//l(j)=l0(j)
	}
    transform1(y[1],x[1],n);

	jieguo+="進行第一輪迭代:\r\n";
	themain(jieguo);
	jieguo+="最終結(jié)果:\r\n";
	for(int h=0;h<n;h++)
	{
	CString aa;
	aa.Format("x%d=%f\r\n",h,resual[h]);
	jieguo+=aa;
	}
	
}

CRosenBrock::~CRosenBrock()
{

}
// RosenBrock.cpp : Defines the entry point for the console application.



void CRosenBrock::themain(CString &jieguo)
{
	int leiji=0;//預(yù)防死循環(huán),當leiji>=200時,跳出死循環(huán)
	do
	{
	    float *temp1=new float[n];//步驟2
	    transform1(temp1,y[j],d[j],l[j],n);
	    if(fun(temp1)<fun(y[j]))
	    {
		   transform1(y[j+1],temp1,n);
           r[j]+=l[j];//方向步長累加
		   l[j]=a*l[j];
		//////////////
	    }
	    else
	    {
		   transform1(y[j+1],y[j],n);
		   l[j]=b*l[j];
		/////////////////
	    }
        if(j<n) //步驟3
		{
			j=j+1;
			continue;
		}
	    if(fun(y[n+1])<fun(y[1])) //步驟4 (yes)
    	{
		   transform1(y[1],y[n+1],n);
		   j=1;
		   continue;
	    }
		 if(fun(y[n+1])==fun(y[1])) //步驟4 (no)
		 {
	         if(fun(y[n+1])<fun(x[k])) //步驟5 (yes)/////////////////////
			 {
		         transform1(x[k+1],y[n+1],n); //步驟6
				 float temp[2];
				 transform1(temp,x[k+1],x[k],-1,n);
				 if(fanshu(temp,n)<=e)
				 {
					 transform1(resual,x[k+1],n);
					 break;
				 }
				 else
				 {
				    trans(p,q,d,r,n);
					jieguo+="正交化d:\r\n";///////////顯示中間信息 
					for(int w=1;w<=n;w++)
					{	CString aa;
	                    aa.Format("d(%d)=",w);
						float *temp=d[w];
						for(int y=0;y<n;y++)
						{
							CString bb;
	                         bb.Format("%f  ",temp[y]);
							 aa+=bb;
						}
						aa+="\r\n";
						jieguo+=aa;
					}////////////////////////////////
					transform1(y[1],x[k+1],n);
					k=k+1;
					CString cc;
					cc.Format("%d",k);
                    jieguo+="進行第"+cc+"輪迭代:\r\n";
					j=1;
					for(int t=1;t<n+1;t++)
					{
		               l[t]=1;
					   r[t]=0;
					}
					continue;
				 }
			 }
			 else                             //步驟5 (no)
			 {
				 int flag=1;///標記--判斷是否|l[j]|<=e
				 for(int i=1;i<=n;i++)// |l[j]|<=e是否成立
				 {
					 if(fabsf(l[i])>e)
					 {
						 flag=0;
						 break;
					 }					 
				 }
				 if(flag==1)
				 {
					 transform1(resual,x[k],n);
					 break;
				 }
				 transform1(y[1],y[n+1],n);
				 j=1; 
				 continue;
			 }
		 }
	leiji++;
	}while(leiji<200);
}


void CRosenBrock::transform1(float *p,float *q,int count)//q數(shù)組的值賦值給q數(shù)組,如y(1)=x(1)
{
	for(int i=0;i<count;i++)
		p[i]=q[i];   
}
void CRosenBrock::transform1(float *temp,float *p,float *q,float l,int count)//公式:y(2)=y(1)+l*d(1)
{
	for(int i=0;i<count;i++)
		temp[i]=p[i]+l*q[i];
}
void CRosenBrock::transform1(float *temp,float *q,float l,int count)//公式:y(2)=y(2)+l*d(1)
{
	for(int i=0;i<count;i++)
		temp[i]+=l*q[i];
}
void CRosenBrock::transform3(float *temp,float *q,float l,int count)//公式:y(2)=l*d(1)
{
	for(int i=0;i<count;i++)
		temp[i]=l*q[i];
}
float CRosenBrock::transform2(float *p,float *q,int count)//公式:resual=y(2)*y(1)
{
	float temp=0;
	for(int i=0;i<count;i++)
		temp+=p[i]*q[i];
	return temp;
}
float CRosenBrock::fun(float *x1)
{
	float aa;
	//double *kk=new double[n];
	//aa=x[0]*x[0]+x[1]*x[1]-3*x[0]-x[0]*x[1]+3;
	aa=(x1[0]-3)*(x1[0]-3)+(x1[1]+2)*(x1[1]+2);
	//for(int k=0;k<n;k++)
	//	kk[k]=(double)x1[k];

	//aa=jisuan.computer(kk,jisuan.GetVariantTableSize());
    return aa;
}
void CRosenBrock::trans(float **p,float **q,float **d,float *r,int count)//構(gòu)造新的正交方向
{
	float *temp_p;
	int j,i,k;
	for(j=1;j<=count;j++)       ///計算p(j)的值
	{
      temp_p=p[j];

	  if(r[j]==0)
	  {
		  transform1(temp_p,d[j],count);
	  }
	  else
	  {
		  for(k=0;k<count;k++)
			  temp_p[k]=0;

	      for(i=j;i<=count;i++)
	      {
			  transform1(temp_p,d[i],r[i],count);			  
		  }		  
	  }
	}
    for( j=1;j<=count;j++)       ///計算q(j)的值
	{
		if(j==1)
			transform1(q[j],p[j],count);
		else
		{
			float *temp_q=new float[count];
			float *temp_q1=new float[count];
			for(k=0;k<count;k++)
			  temp_q[k]=0;
			for(i=1;i<=j-1;i++)
			{
			    float temp;
			    temp=transform2(q[i],p[j],count)/transform2(q[i],q[i],count);
				transform1(temp_q,q[i],temp,count);
			}

			transform1(temp_q1,p[j],temp_q,-1,count);
			transform1(q[j],temp_q1,count);
		}
	}
     for( j=1;j<=count;j++)       ///計算d(j)的值
	 {
		 float *temp_q=q[j];
		 float aa=((float)1)/fanshu(q[j],count);
		 transform3(d[j],q[j],aa,count);
		 
	 }

}
float CRosenBrock::fanshu(float *x1,int count)//范數(shù)求值函數(shù)
{
   float temp=0;
	for(int i=0;i<count;i++)
		temp+=x1[i]*x1[i];
	return sqrtf(temp);
}


void CRosenBrock::string2(CString str1, float *zhi, int n0)
{
	int temp=0;
	CString str=str1;
	str.TrimLeft();
	str.TrimRight();
	str+=",";
		for(int e=0;e<n0;e++)      
		{
          zhi[e]=atof(str.Mid(temp,str.Find(",",temp)-temp));
          temp=str.Find(",",temp)+1;
		}

}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
爽好多水快深点欧美视频| 欧美老肥妇做.爰bbww| 蜜桃av噜噜一区| 午夜精品视频一区| 亚洲一二三四区不卡| 亚洲男帅同性gay1069| 国产精品麻豆久久久| 中文字幕亚洲成人| 亚洲日本丝袜连裤袜办公室| 亚洲啪啪综合av一区二区三区| 国产午夜精品久久| 中文字幕免费一区| 国产精品福利一区| 亚洲一区自拍偷拍| 日韩精品每日更新| 国产麻豆视频一区二区| 高清在线成人网| 99久久国产综合精品麻豆| 欧美在线小视频| 在线成人免费视频| 久久免费视频色| 亚洲色图欧洲色图| 日韩精品福利网| 国精品**一区二区三区在线蜜桃| 国产高清不卡一区| 日本道色综合久久| 欧美xxxx在线观看| 成人免费视频在线观看| 亚洲丶国产丶欧美一区二区三区| 久久99精品国产91久久来源 | 色网站国产精品| 欧美专区在线观看一区| 91福利国产成人精品照片| 欧美电影一区二区| 中文字幕中文字幕中文字幕亚洲无线| 亚洲欧洲日韩一区二区三区| 亚洲九九爱视频| 久99久精品视频免费观看| 99久久精品国产观看| 日韩午夜三级在线| 亚洲欧美日韩国产成人精品影院| 午夜亚洲国产au精品一区二区| 日本一不卡视频| 91视频在线观看免费| 日韩免费电影一区| 国产精品二区一区二区aⅴ污介绍| 肉色丝袜一区二区| 一本一道久久a久久精品综合蜜臀| 日韩欧美中文一区二区| 一区二区三区中文在线观看| 国产一区视频导航| 在线成人高清不卡| 亚洲永久免费av| 不卡av免费在线观看| 久久综合网色—综合色88| 亚洲福利一区二区| 91啪在线观看| 国产精品视频九色porn| 久久国产精品99久久人人澡| 欧洲色大大久久| 136国产福利精品导航| 国产精品一二三| 日韩欧美国产系列| 五月婷婷激情综合网| 色偷偷久久人人79超碰人人澡| 久久精品一区二区三区av| 毛片基地黄久久久久久天堂| 欧美三级电影在线观看| 国产色综合久久| 国产剧情一区二区| 久久综合成人精品亚洲另类欧美| 视频一区二区欧美| 欧美高清视频一二三区 | 在线播放国产精品二区一二区四区| 久久久久国色av免费看影院| 麻豆国产精品一区二区三区 | 亚洲柠檬福利资源导航| 成人免费看片app下载| 久久久久9999亚洲精品| 久久99精品久久久久| 精品粉嫩aⅴ一区二区三区四区| 免费人成精品欧美精品| 日韩免费在线观看| 国内精品国产成人国产三级粉色| 欧美精品一区二区三区蜜桃视频| 麻豆一区二区三| 2022国产精品视频| 成人一二三区视频| 亚洲自拍另类综合| 日韩一区二区三区三四区视频在线观看 | 另类综合日韩欧美亚洲| 欧美成人video| 国产在线日韩欧美| 亚洲午夜精品17c| 日韩午夜中文字幕| 国产九色精品成人porny| 中文字幕免费观看一区| 91亚洲精品一区二区乱码| 亚洲一区二区三区四区在线| 欧美精品第1页| 狠狠色狠狠色综合日日91app| 国产欧美日韩另类一区| 91黄色免费版| 麻豆成人在线观看| 国产精品成人免费| 欧美撒尿777hd撒尿| 激情图片小说一区| 亚洲综合视频网| 欧美xxxxxxxx| 色94色欧美sute亚洲线路一ni| 日本午夜精品一区二区三区电影| 久久久五月婷婷| 欧美视频一区二区在线观看| 黄色资源网久久资源365| 亚洲视频网在线直播| 日韩一级大片在线| 色婷婷综合中文久久一本| 精品在线观看视频| 亚洲成人av电影| 国产精品精品国产色婷婷| 欧美一区二区视频在线观看2022| 成人v精品蜜桃久久一区| 日本欧美一区二区在线观看| 中文字幕一区在线| 2020国产精品| 日韩三级免费观看| 在线观看视频一区| av网站一区二区三区| 老司机一区二区| 日欧美一区二区| 一区二区三区不卡在线观看| 国产精品视频看| 久久影视一区二区| 日韩欧美国产一区二区三区 | 韩国视频一区二区| 手机精品视频在线观看| 自拍偷拍国产精品| 久久麻豆一区二区| 日韩一级完整毛片| 欧美日韩成人综合天天影院 | 国产三级一区二区| 久久久久国产免费免费| 日韩精品中文字幕一区| 欧美日韩一区不卡| 在线免费不卡视频| 在线免费观看视频一区| 99九九99九九九视频精品| 国产99精品在线观看| 国产精品18久久久久久久久| 久久99国产精品麻豆| 久久99国内精品| 韩国成人在线视频| 国产尤物一区二区| 国产精品亚洲一区二区三区在线| 精品影视av免费| 国产呦精品一区二区三区网站| 极品少妇xxxx精品少妇偷拍| 国产综合成人久久大片91| 韩国av一区二区三区在线观看| 精品一区二区成人精品| 久久99精品久久久| 国产福利一区在线| 94-欧美-setu| 在线观看一区不卡| 91精品欧美一区二区三区综合在 | 麻豆国产欧美一区二区三区| 免费不卡在线视频| 国产精品性做久久久久久| 成人黄色小视频| 在线观看不卡一区| 欧美一区二区三区四区五区| 日韩精品一区二区三区视频| 久久精品亚洲国产奇米99| 亚洲欧美影音先锋| 性欧美大战久久久久久久久| 精品一区二区三区不卡| 成人h动漫精品| 欧美狂野另类xxxxoooo| 国产亚洲欧洲997久久综合| 日韩毛片一二三区| 轻轻草成人在线| 成人动漫av在线| 欧美精品粉嫩高潮一区二区| 久久色成人在线| 一区二区成人在线观看| 成人午夜在线视频| 91成人免费网站| 亚洲精品一区二区三区影院 | 男人的天堂亚洲一区| 成人亚洲一区二区一| 欧美日免费三级在线| 日韩一级精品视频在线观看| 成人免费在线播放视频| 久久成人免费电影| 色综合久久精品| 久久精品在这里| 日韩av高清在线观看| 97久久久精品综合88久久| 欧美一级艳片视频免费观看| 亚洲视频一区二区在线观看|