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

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

?? patternsearchview.cpp

?? 非線性規劃中求解無約束問題中的一個有效方法--模矢法(步長加速法),并用圖表示出來步驟.
?? CPP
字號:
// PatternSearchView.cpp : CPatternSearchView 類的實現
//

#include "stdafx.h"
#include "PatternSearch.h"
#include "math.h"

#include "PatternSearchDoc.h"
#include "PatternSearchView.h"
#include ".\patternsearchview.h"

#define LX	15
#define LY	15
#define RX	335
#define RY	335
#define SPAN	32
#define MAX	2
#define JINGDU	0.1

#ifdef _DEBUG
#define new DEBUG_NEW
#endif

float JiDian[MAX];	//存儲基點數據
float OldJiDian[MAX];
float ShiDian[MAX];
float OldShiDian[MAX];
float tempMatrix[MAX];
float tempJiDian[MAX];
float tempShiDian[MAX];
float BuChang;		//步長
BOOL JustOnce;
BOOL IsShiDian;
BOOL GetIt;


// CPatternSearchView

IMPLEMENT_DYNCREATE(CPatternSearchView, CFormView)

BEGIN_MESSAGE_MAP(CPatternSearchView, CFormView)
	ON_BN_CLICKED(IDC_BUTTON_CALCULATE, OnBnClickedButtonCalculate)
END_MESSAGE_MAP()

// CPatternSearchView 構造/析構

CPatternSearchView::CPatternSearchView()
	: CFormView(CPatternSearchView::IDD)
	, m_cResult(_T(""))
	, m_bStep(FALSE)
	, m_cJiDian(_T(""))
	, m_fBuChang(0)
{
	// TODO: 在此處添加構造代碼
	for(int i=0;i<MAX;i++)
	{
		JiDian[i] = 0;
		OldJiDian[i] = 0;
	}
	
	m_fBuChang = 0.5;
	m_cJiDian = "-3,1";
	m_cResult.Format("\r\n步長加速法\r\n"
		"--------------------------\r\n"
		"模矢法"
		"(Pattern Search)\r\n"
		"Hooke,Jeeves1961提出");
	m_bStep = FALSE;
	JustOnce = TRUE;
	IsShiDian = FALSE;
	GetIt = TRUE;
}

CPatternSearchView::~CPatternSearchView()
{
}

void CPatternSearchView::DoDataExchange(CDataExchange* pDX)
{
	CFormView::DoDataExchange(pDX);
	DDX_Text(pDX, IDC_EDIT_RESULT, m_cResult);
	DDX_Check(pDX, IDC_CHECK_ZHUBU, m_bStep);
	DDX_Text(pDX, IDC_EDIT_JIDIAN, m_cJiDian);
	DDX_Text(pDX, IDC_EDIT_BUCHANG, m_fBuChang);
}

BOOL CPatternSearchView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: 在此處通過修改 CREATESTRUCT cs 來修改窗口類或
	// 樣式
	
	return CFormView::PreCreateWindow(cs);
}

void CPatternSearchView::OnInitialUpdate()
{
	CFormView::OnInitialUpdate();
	GetParentFrame()->RecalcLayout();
	ResizeParentToFit();

}

void CPatternSearchView::OnDraw(CDC *pDC)
{


	CPen Pen;
	Pen.CreatePen(PS_SOLID,1,RGB(0,0,0));

	CPen dPen;
	dPen.CreatePen(PS_DOT,1,RGB(255,255,255));

	CBrush Brush;
	Brush.CreateSolidBrush(RGB(255,255,255));

	CBrush *pOldBrush;
	pOldBrush = pDC->SelectObject( &Brush );
	pDC->SetBkColor(RGB(0,0,0));
	pDC->Rectangle(LX,LY,RX,RY);
	pDC->SelectObject( pOldBrush ); 
	Brush.DeleteObject();

	
	CPen *pOldPen;
	//繪輔助線
	pOldPen = pDC->SelectObject( &dPen );

	for(int i=1;i<(RY-LY)/SPAN;i++)
	{
		pDC->MoveTo( LX,LY+i*SPAN);
		pDC->LineTo( RX,LY+i*SPAN);
		pDC->MoveTo( LX+i*SPAN,LY);
		pDC->LineTo( LX+i*SPAN,RY);
	}

	pDC->SelectObject( pOldPen );
	dPen.DeleteObject();

	//繪坐標軸
	pOldPen = pDC->SelectObject( &Pen);
	pDC->MoveTo( LX,LY+(RY-LY)/2 );
	pDC->LineTo( RX,LY+(RY-LY)/2 );
	pDC->MoveTo( LX+(RX-LX)/2,LY );
	pDC->LineTo( LX+(RX-LX)/2,RY );
	pDC->SelectObject( pOldPen );
	Pen.DeleteObject();
}

// CPatternSearchView 診斷

#ifdef _DEBUG
void CPatternSearchView::AssertValid() const
{
	CFormView::AssertValid();
}

void CPatternSearchView::Dump(CDumpContext& dc) const
{
	CFormView::Dump(dc);
}

CPatternSearchDoc* CPatternSearchView::GetDocument() const // 非調試版本是內聯的
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CPatternSearchDoc)));
	return (CPatternSearchDoc*)m_pDocument;
}
#endif //_DEBUG


// CPatternSearchView 消息處理程序

void CPatternSearchView::OnBnClickedButtonCalculate()
{
	// TODO: 在此添加控件通知處理程序代碼
	UpdateData();
	if(JustOnce)	//第一次執行才運行,初始化數據
	{
		InitializeParameter();
		CopyMatrix(ShiDian,JiDian);
		m_cResult = "";
	}
	JustOnce = FALSE;
	if(m_bStep)
	{
		GetDlgItem(IDC_BUTTON_CALCULATE)->SetWindowText("繼 續");
	}
	else
	{
		GetDlgItem(IDC_BUTTON_CALCULATE)->SetWindowText("計 算");
	}

	//---------------------------------------------------------

	//step one
	CopyMatrix(OldJiDian,JiDian);
	if(!IsShiDian)
	{
		CopyMatrix(ShiDian,JiDian);
	}
	IsShiDian = FALSE;

	//step two
	for(int i=0;i<MAX;i++)
		SheDong(ShiDian,ShiDian,BuChang,i);
	CopyMatrix(OldShiDian,ShiDian);

	//step three
	for(int i=0;i<MAX;i++)
		SheDong(ShiDian,ShiDian,BuChang,i);
	CopyMatrix(JiDian,ShiDian);

	//step four
	CopyMatrix(ShiDian,MatrixOperationTwo( OldJiDian,JiDian ));

	if(TargetFunValue(ShiDian)<TargetFunValue(JiDian))
	{
		CopyMatrix(tempShiDian,ShiDian);
		for(int i=0;i<MAX;i++)
			SheDong(tempShiDian,tempShiDian,BuChang,i);
		if(!GetIt)
		{
			CopyMatrix(JiDian,ShiDian);
		}
		else
		{
			IsShiDian = TRUE;
		}
		Recursion();
		if(BuChang<JINGDU)
			return;
		if(!m_bStep)
			OnBnClickedButtonCalculate();	//結束one
	}
	else
	{
		CopyMatrix(tempShiDian,ShiDian);
		CopyMatrix(tempJiDian,JiDian);
		GetIt = FALSE;
		for(int i=0;i<MAX;i++)
			SheDong(tempShiDian,tempJiDian,BuChang,i);
		if(!GetIt)
		{
			CopyMatrix(tempJiDian,JiDian);
			for(int i=0;i<MAX;i++)
				SheDong(tempJiDian,tempJiDian,BuChang,i);
			if(GetIt)
			{
				Recursion();	
				if(BuChang<JINGDU)
					return;
				if(!m_bStep)
					OnBnClickedButtonCalculate();	//結束two
			}
			else
			{
				BuChang = BuChang/2;
				Recursion();
				if(BuChang<JINGDU)
					return;
				if(!m_bStep)
					OnBnClickedButtonCalculate();//結束three
			}
		}
		if(BuChang<JINGDU)
			return;
	}

	//---------------------------------------------------------
	
}

// 目標函數求值
float CPatternSearchView::TargetFunValue(float fVariable[])
{
	float result=0;
	result = fVariable[0]*fVariable[0]+2*fVariable[1]*fVariable[1]-4*fVariable[0]-2*fVariable[0]*fVariable[1];
	return result;
}

// 初始化手工輸入的參數
void CPatternSearchView::InitializeParameter()
{

	LPTSTR str = new TCHAR[m_cJiDian.GetLength()+1];
	_tcscpy(str, m_cJiDian);
	int i=0;
	char * pch;
	pch = strtok (str,",");
	while (pch != NULL)
	{
		JiDian[i]=atof(pch);
		i++;
		pch = strtok (NULL, ",");
	}
	BuChang = m_fBuChang;
}

// 對獨立變量進行攝動
void CPatternSearchView::SheDong(float MatrixA[],float MatrixB[],float BuChang,int i)
{
	if( TargetFunValue(MatrixOperation( MatrixA,BuChang,i,1))<TargetFunValue(MatrixB))
	{
		CopyMatrix(MatrixA,MatrixOperation( MatrixA,BuChang,i,1));
		GetIt = TRUE;
	}
	else if( TargetFunValue(MatrixOperation( MatrixA,BuChang,i,-1))<TargetFunValue(MatrixB) &&  TargetFunValue(MatrixOperation( MatrixA,BuChang,i,1))>=TargetFunValue(MatrixB))
	{	
		CopyMatrix(MatrixA,MatrixOperation( MatrixA,BuChang,i,-1));
		GetIt = TRUE;
	}
	else
	{
		GetIt = FALSE;
	}

}

// 矩陣運算(可用運算符重載實現)
float * CPatternSearchView::MatrixOperation(float ShiDian[],float BuChang,int i,int Symbol)
{
	CopyMatrix(tempMatrix,ShiDian);
	tempMatrix[i] = tempMatrix[i]+Symbol*BuChang;
	return tempMatrix;
}

// 6.86
float * CPatternSearchView::MatrixOperationTwo(float MatrixA[],float MatrixB[])
{
	for(int i=0;i<MAX;i++)
		tempMatrix[i] = 2*MatrixB[i]-MatrixA[i];
	return tempMatrix;
}

float CPatternSearchView::CopyMatrix(float MatrixA[],float MatrixB[])
{
	for(int i=0;i<MAX;i++)
		MatrixA[i] = MatrixB[i];
	return 0;
}

void  CPatternSearchView::DrawPic()
{
	DrawPoint(OldJiDian);
	DrawPoint(JiDian);
	DrawPoint(OldShiDian);
	DrawPoint(ShiDian);
	DrawLine(OldJiDian,JiDian);
}

void CPatternSearchView::DrawPoint(float Matrix[])
{
	float Point[2] = { LX+(RX-LX)/2+Matrix[0]*SPAN,LY+(RY-LY)/2-Matrix[1]*SPAN };
	float PointR = 2;
	
	CClientDC dc(this);
	CRect rClient;
	GetClientRect(rClient);
	
	CBrush Brush;
	Brush.CreateSolidBrush(RGB(0,0,0));

	CBrush *pOldBrush;
	pOldBrush = dc.SelectObject( &Brush );
	dc.SetBkColor(RGB(0,0,0));
	dc.Ellipse( Point[0]-PointR,Point[1]-PointR,Point[0]+PointR,Point[1]+PointR );

	dc.SelectObject( pOldBrush ); 
	Brush.DeleteObject();
}

void CPatternSearchView::DrawLine(float MatrixA[],float MatrixB[])
{
	float PointOne[2] = { LX+(RX-LX)/2+MatrixA[0]*SPAN,LY+(RY-LY)/2-MatrixA[1]*SPAN };
	float PointTwo[2] = { LX+(RX-LX)/2+MatrixB[0]*SPAN,LY+(RY-LY)/2-MatrixB[1]*SPAN };

	CClientDC dc(this);
	CRect rClient;
	GetClientRect(rClient);

	CPen Pen;
	Pen.CreatePen(PS_SOLID,1,RGB(255,0,0));
	CPen *pOldPen;
	pOldPen = dc.SelectObject( &Pen );
	dc.MoveTo( PointOne[0],PointOne[1] );
	dc.LineTo( PointTwo[0],PointTwo[1] );

	dc.SelectObject( pOldPen );
	Pen.DeleteObject();	
}


void CPatternSearchView::DisplayZB(void)
{
	CString tempResult;
	tempResult.Format("(%f,%f)\r\nf(X)=%f\r\n",JiDian[0],JiDian[1],TargetFunValue(JiDian));
	m_cResult = tempResult + "\r\n" + m_cResult;

	//狀態欄坐標顯示
	CPatternSearchDoc * pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	CString strPointX,strPointY;
	CStatusBar * pStatus = (CStatusBar *)AfxGetApp()->m_pMainWnd->GetDescendantWindow(ID_VIEW_STATUS_BAR);
	strPointX.Format("x:%f",JiDian[0]);
	strPointY.Format("y:%f",JiDian[1]);
	pStatus->SetPaneText(1,strPointX);
	pStatus->SetPaneText(2,strPointY);
}

void CPatternSearchView::Recursion(void)
{
	DisplayZB();
	DrawPic();
	UpdateData(FALSE);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美aaaaaa午夜精品| 欧美区视频在线观看| 欧美日韩一区二区在线视频| 精品三级在线看| 亚洲免费观看高清完整版在线| 蜜臀av性久久久久蜜臀aⅴ| 在线看国产一区| 国产精品日韩精品欧美在线| 久久99精品久久久久久| 欧美日韩国产综合一区二区三区| 中文字幕在线免费不卡| 国产麻豆精品在线| 欧美成人伊人久久综合网| 亚洲第一福利一区| 色狠狠一区二区| 亚洲特级片在线| 不卡av在线免费观看| 久久久国产精品不卡| 久久成人免费网| 欧美一区二区三区日韩视频| 亚洲午夜精品网| 色综合久久精品| 亚洲色图视频免费播放| 99久久综合99久久综合网站| 国产欧美日韩久久| 国产电影一区在线| 国产亚洲精品aa| 国产91精品精华液一区二区三区 | 欧美三区免费完整视频在线观看| 中文字幕 久热精品 视频在线| 精品一区二区三区在线播放视频| 91精品国产色综合久久| 日韩av网站免费在线| 欧美一级黄色录像| 伦理电影国产精品| 精品日韩成人av| 韩国欧美国产一区| 国产日产精品1区| 国产激情一区二区三区| 国产精品久久久久久久久动漫 | 538prom精品视频线放| 亚洲午夜久久久久久久久电影网| 欧美日韩免费不卡视频一区二区三区| 亚洲精品国产成人久久av盗摄| 日本高清免费不卡视频| 亚洲444eee在线观看| 日韩欧美资源站| 国产精品1024| 自拍视频在线观看一区二区| 在线观看不卡视频| 热久久久久久久| 精品91自产拍在线观看一区| 岛国精品在线观看| 亚洲精品国产精品乱码不99 | eeuss国产一区二区三区| 中文字幕一区二区在线观看| 日本韩国一区二区三区| 石原莉奈在线亚洲三区| 久久婷婷一区二区三区| 91女神在线视频| 日韩中文字幕区一区有砖一区| 日韩欧美国产午夜精品| 成年人网站91| 日韩精品乱码av一区二区| 久久久久久电影| 欧美亚洲国产bt| 国内欧美视频一区二区| 亚洲三级视频在线观看| 日韩一本二本av| 91麻豆精品在线观看| 日韩av一区二区在线影视| 国产精品亲子伦对白| 欧美三级一区二区| 国产成人av一区二区三区在线| 亚洲国产精品一区二区www在线| 精品久久五月天| 欧美亚洲一区三区| 国产成人精品免费一区二区| 日韩激情av在线| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲欧洲精品一区二区精品久久久 | 色妞www精品视频| 久久精品国产精品亚洲精品| 亚洲精品精品亚洲| 国产精品嫩草影院com| 777久久久精品| 91黄色激情网站| 成人深夜在线观看| 久久国产福利国产秒拍| 亚洲成av人片一区二区三区 | 久久女同性恋中文字幕| 欧美日产在线观看| 91片黄在线观看| 福利一区二区在线观看| 精品一区二区精品| 日本成人超碰在线观看| 舔着乳尖日韩一区| 尤物在线观看一区| 国产精品视频在线看| 2023国产精品| 久久综合av免费| 欧美大肚乱孕交hd孕妇| 欧美一区午夜视频在线观看 | 在线看日韩精品电影| 99re热这里只有精品视频| 国产精品影视网| 国产精品一区二区你懂的| 久久国产精品99精品国产| 免费在线观看一区二区三区| 亚洲成年人影院| 午夜av一区二区三区| 亚洲成人免费在线观看| 亚洲国产日韩精品| 亚洲国产视频一区| 日本三级亚洲精品| 日本中文在线一区| 国产在线一区二区| 成人丝袜高跟foot| 97久久超碰国产精品| 91片在线免费观看| 欧美日韩综合色| 欧美二区三区91| 日韩欧美高清在线| 国产日韩影视精品| 国产精品国产三级国产普通话99 | 中文字幕一区二区三区在线不卡 | 亚洲高清在线精品| 日韩一区精品字幕| 国内精品久久久久影院一蜜桃| 韩国欧美一区二区| 盗摄精品av一区二区三区| 色婷婷综合久久久久中文| 欧美日韩卡一卡二| 精品嫩草影院久久| 日本一二三不卡| 亚洲综合在线视频| 日本中文字幕一区| 成人一区在线看| 在线观看一区不卡| 精品久久久久久久久久久久久久久| 精品av久久707| 亚洲精品国产无天堂网2021| 日本三级亚洲精品| 成人国产视频在线观看| 91国产福利在线| 日韩精品一区二区三区视频| 国产精品久久一卡二卡| 五月婷婷久久综合| 国产成人精品亚洲午夜麻豆| 色婷婷av一区| 国产午夜一区二区三区| 亚洲自拍偷拍图区| 国产经典欧美精品| 欧美人体做爰大胆视频| 中文字幕欧美激情一区| 日韩精品亚洲一区| 91麻豆123| 国产清纯在线一区二区www| 一区二区高清在线| 国产精品996| 91精品国产综合久久久久久 | 欧美日韩一级大片网址| 国产婷婷精品av在线| 婷婷国产v国产偷v亚洲高清| 成人app网站| 精品国产一区二区三区四区四| 亚洲免费资源在线播放| 国产精品456| 欧美一区二区视频在线观看2022 | 91精品在线一区二区| 综合中文字幕亚洲| 国内成+人亚洲+欧美+综合在线 | 日本特黄久久久高潮| 在线视频综合导航| 国产精品久久久久久久久久免费看 | www成人在线观看| 亚洲123区在线观看| fc2成人免费人成在线观看播放| ww久久中文字幕| 九九在线精品视频| 欧美高清性hdvideosex| 亚洲一区二区三区四区五区中文 | 一区二区三区四区五区视频在线观看| 激情国产一区二区| 日韩一级在线观看| 婷婷国产在线综合| 在线不卡一区二区| 亚洲成人av在线电影| 欧美性大战久久久| 亚洲一区二区三区中文字幕| 91国偷自产一区二区三区成为亚洲经典| 中文字幕av一区二区三区| 国产精品夜夜爽| 国产欧美日韩精品在线| 懂色av中文一区二区三区 | 日韩va亚洲va欧美va久久| 欧美日韩成人在线| 日韩黄色小视频| 精品免费日韩av| 国内偷窥港台综合视频在线播放|