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

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

?? imitateview.cpp

?? 主要實現了計算方法中的曲線擬合
?? CPP
字號:
// IMITATEView.cpp : implementation of the CIMITATEView class
//

#include "stdafx.h"
#include "IMITATE.h"
#include "InPut.h"
#include "NUMBER.h"
#include "fstream.h"
#include "math.h"
#include "Mnum.h"


#include "IMITATEDoc.h"
#include "IMITATEView.h"

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

/////////////////////////////////////////////////////////////////////////////
// CIMITATEView

IMPLEMENT_DYNCREATE(CIMITATEView, CView)

BEGIN_MESSAGE_MAP(CIMITATEView, CView)
	//{{AFX_MSG_MAP(CIMITATEView)
	ON_COMMAND(ID_Input, OnInput)
	ON_COMMAND(ID_DWrite, OnDWrite)
	ON_COMMAND(ID_DRead, OnDRead)
	ON_COMMAND(ID_Imitate, OnImitate)
	ON_COMMAND(ID_1_Imitate, On1Imitate)
	ON_COMMAND(ID_2_Imitate, On2Imitate)
	//}}AFX_MSG_MAP
	// Standard printing commands
	ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CIMITATEView construction/destruction

CIMITATEView::CIMITATEView()
{
	// TODO: add construction code here
	NUM=0;
	for(int i=0;i<20;i++)
		Time[i]=0.0;
}

CIMITATEView::~CIMITATEView()
{
}

BOOL CIMITATEView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CIMITATEView drawing

void CIMITATEView::OnDraw(CDC* pDC)
{
	CIMITATEDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	// TODO: add draw code for native data her	

}

/////////////////////////////////////////////////////////////////////////////
// CIMITATEView printing

BOOL CIMITATEView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	return DoPreparePrinting(pInfo);
}

void CIMITATEView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

void CIMITATEView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CIMITATEView diagnostics

#ifdef _DEBUG
void CIMITATEView::AssertValid() const
{
	CView::AssertValid();
}

void CIMITATEView::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

CIMITATEDoc* CIMITATEView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CIMITATEDoc)));
	return (CIMITATEDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CIMITATEView message handlers

void CIMITATEView::OnInput() 
{
	// TODO: Add your command handler code here
	InPut input;
	NUMBER num;

	if(num.DoModal()==IDOK)
		NUM=num.m_Num;
    
	for(int i=0;i<num.m_Num;i++)
	{
		if(input.DoModal()==IDOK)//調用輸入對話框
		{
			Time[i]=input.m_Time;//輸入
		    C[i]=input.m_C;

		    input.m_Time=0.0;//清0
		    input.m_C=0.0;//清0
		}
	}
}

/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::OnDWrite() 
{
	// TODO: Add your command handler code here

	CFileDialog dlg(FALSE,"*.txt","*.txt");
	CString path;
	
	if(dlg.DoModal()==IDOK)//調用文件保存對話框
	{
		path=dlg.GetFileName();
	}

	else
		exit(0);
	
	ofstream fout(path);
	fout<<NUM<<" ";//保存數據組數
	for(int i=0;i<NUM;i++)
	{
		
		if(!fout)//出錯
		{
			MessageBox("文件不存在!");
			exit(0);
		}
		fout<<Time[i]<<" "<<C[i]<<" ";//依次保存時間和濃度
	

	}
		fout.close();//文件關閉
}

/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::OnDRead() 
{
	// TODO: Add your command handler code here

	CFileDialog dlg(TRUE,"*.txt","*.txt");
	CString path;
	
	if(dlg.DoModal()==IDOK)//調用打開對話框
	{
		path=dlg.GetFileName();

	}
	else
		exit(1);

	ifstream fin(path);
	if(!fin)//文件不存在
	{
		MessageBox("文件不存在!");
		exit(0);
	}
	fin>>NUM;//讀出組數
    
	for(int i=0;i<NUM;i++)
		fin>>Time[i]>>C[i];//依次讀出時間和濃度

	fin.close();//文件關閉

	OutPut();//輸出函數
    		

	
}

/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::Gauss(double sz[][20],int n)
{
	int j, t;//t記錄最大下標
    double s,c,p; //s交換中間變量
                                 
    for(int k=0;k<n;k++)                         
	{
		p=0;
        for(int i=k;i<n+1;i++)           
        {
			if(p<fabs(sz[i][k])) //找最大行
            {
			   p=fabs(sz[i][k]);
               t=i;//記錄行標
             }
		}

		if(k!=t) //交換
        for( j=k;j<n+2;j++)
        {
			s=sz[k][j];
            sz[k][j]=sz[t][j];
            sz[t][j]=s;
         }
		
		j=k+1;
        while(j<n+1)             
		{ 
			c=sz[j][k]/sz[k][k];//變換系數
			for(i=k;i<n+1;i++)
			     sz[j][i]=sz[j][i]-c*sz[k][i];
		    j++;
		}
    }
}

/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::OnImitate() 
{
	// TODO: Add your command handler code here
    if(IsEmpty()==0)
		MessageBox("請先讀入數據!");
	else{

    Mnum nu;
	nu.DoModal();//調用次數對話框

	Nihe(Time,C,nu.m_mnum);//根據輸入求解方程

	CString Result="擬合曲線方程為:\n";
	CString str;
	str.Format("y=%.6f",X[0]);
	Result+=str;
	for(int i=1;i<nu.m_mnum+1;i++)//定制輸出
	{
		str.Format("+(%.4f)t^%d",X[i],i);
		Result+=str;
	}
	MessageBox(Result);
	}
}	
	
/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::Nihe(double t[],double y[],int m)
{
	int i,j,k=0;
	double sz[N][N+1]={0},S[N]={0},T[N]={0};
	
	for(i=0;i<NUM;i++)
	{
		for(k=0;k<=2*m;k++)
		{
			S[k]=S[k]+pow(t[i],k);
			T[k]=T[k]+y[i]*(pow(t[i],k));
		}
	}
	
	for(i=0;i<m+1;i++)//構造系數矩陣
	{
		for(j=0;j<m+1;j++)
		{
			sz[i][j]=S[i+j];
		}
	}
	
	for(i=0;i<m+1;i++)
	{
		sz[i][m+1]=T[i];
	}
	Gauss(sz,m+1);

	double s=0.0;
	X[m]=sz[m][m+1]/sz[m][m];          //先求得最后一個解
    for(i=m-1;i>=0;i--)
	{  
		for(j=i+1;j<m+1;j++)
			s+=(sz[i][j]*X[j]);         
            X[i]=(sz[i][m+1]-s)/sz[i][i];        //回代公式求解
	        s=0;
	}
}

/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::On1Imitate() 
{
	// TODO: Add your command handler code here

	double Cc[20]={0.0};

	if(IsEmpty()==0)
		MessageBox("請先讀入數據!");
	else{


	for(int i=0;i<NUM;i++)
	{
		Cc[i]=1.0/C[i];//濃度求倒數
	}
		
	Nihe(Time,Cc,1);//一次擬合

	CString Result="擬合曲線方程為:\n";
	CString str;
	str.Format("1/y=1/%.6f",1/X[0]);
	Result+=str;
    str.Format("-(%.6f/%.6f)*t",X[1]/X[0],1/X[0],1);
	Result+=str;

	MessageBox(Result);//輸出

	}
}

/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::On2Imitate() 
{
	// TODO: Add your command handler code here

	double time[20],c[20];

	if(IsEmpty()==0)
		MessageBox("請先讀入數據!");
	else{

	for(int i=0;i<NUM;i++)
	{
	     time[i]=1.0/Time[i];//時間求倒數
		 c[i]=log(C[i]);//濃度取對數
	}

    Nihe(time,c,1);//一次線形擬合

	CString Result="擬合曲線方程為:\n\n";
	CString str;
	str.Format("y=%.6fe^",exp(X[0]));
	Result+=str;
    str.Format("((%.6f)/t)",X[1],1);
	Result+=str;
	
	MessageBox(Result);//輸出
	}
}

/////////////////////////////////////////////////////////////////////////////

void CIMITATEView::OutPut()
{
	CDC*pDC=GetDC();
	CString str;//用于輸出


	pDC->TextOut(10,0,"數據清單如下:");
	for(int i=0;i<NUM;i++)
	{
		str.Empty();
		str.Format("時間:%lf     濃度:%lf",Time[i],C[i]);//定制格式
		pDC->TextOut(10,(i+1)*20,str);
	}
}

/////////////////////////////////////////////////////////////////////////////

int CIMITATEView::IsEmpty()//判空
{
	if(Time[0]==0)
	     return 0;
	 else
		 return 1;

}
/////////////////////////////////////////////////////////////////////////////

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人成网站影音先锋播放| 亚洲最大的成人av| 在线免费观看日韩欧美| 国产成人精品午夜视频免费| 老司机精品视频导航| 天堂一区二区在线免费观看| 亚洲成av人片一区二区| 一区二区三区在线看| 亚洲一区二区不卡免费| 亚洲精品老司机| 亚洲成人免费看| 天天色综合天天| 久久精品av麻豆的观看方式| 精品无码三级在线观看视频| 精品一区二区三区的国产在线播放| 成人福利在线看| 亚洲成人免费观看| 美女一区二区在线观看| 一区二区三区四区在线免费观看| 亚洲另类中文字| 亚洲午夜国产一区99re久久| 欧美日韩久久久一区| 国产精品久久看| 亚洲美女偷拍久久| 免费在线看成人av| 午夜一区二区三区在线观看| 亚洲精品欧美在线| 欧美亚洲一区三区| 精品一区二区免费| 成人永久免费视频| 国产精品一区二区果冻传媒| www.av精品| 欧美艳星brazzers| 欧美tickling网站挠脚心| 国产夜色精品一区二区av| 亚洲女人小视频在线观看| 日韩精品电影在线| 国产一区二区三区免费观看| 色哟哟精品一区| 久久综合久久久久88| 国产精品福利一区| 视频一区免费在线观看| 韩国一区二区视频| 91麻豆swag| 精品福利在线导航| 亚洲一区二区av在线| 国产麻豆视频一区| 欧美剧情电影在线观看完整版免费励志电影| 日韩欧美综合在线| 亚洲精品你懂的| 日本美女一区二区三区视频| 国产精品亚洲第一| 91精品国产色综合久久不卡蜜臀| 国产午夜亚洲精品不卡| 日韩av一区二区在线影视| 99免费精品在线| 久久美女艺术照精彩视频福利播放| 一区二区在线观看不卡| 国产精品538一区二区在线| 欧美日韩国产小视频| 最近日韩中文字幕| 国产精品一二一区| 精品99一区二区三区| 日韩激情在线观看| 色婷婷狠狠综合| 最新日韩av在线| 懂色av噜噜一区二区三区av| 日韩精品在线网站| 日本午夜精品一区二区三区电影| 91最新地址在线播放| 中文字幕第一区第二区| 国产成人精品综合在线观看 | 在线免费观看视频一区| 国产精品久久毛片a| 国产剧情一区二区| 久久综合久久久久88| 久久国产乱子精品免费女| 欧美精选午夜久久久乱码6080| 国产精品的网站| 91啪九色porn原创视频在线观看| 中文字幕乱码一区二区免费| 成人午夜电影网站| 综合av第一页| 91小视频在线免费看| 亚洲日本va午夜在线影院| 91丨porny丨首页| 一区二区三区高清在线| 欧美在线一区二区三区| 亚瑟在线精品视频| 欧美xxxxxxxx| 成人午夜视频福利| 亚洲日本欧美天堂| 欧美日韩性生活| 毛片一区二区三区| 精品福利一二区| 成人黄色小视频| 亚洲欧洲性图库| 欧美日韩成人综合| 久久99最新地址| 中文字幕乱码亚洲精品一区| av中文字幕一区| 日韩你懂的电影在线观看| 国产精品国产成人国产三级| av亚洲精华国产精华| 亚洲激情成人在线| 欧美激情在线免费观看| 91麻豆.com| 日本中文字幕一区二区视频| 久久久www成人免费无遮挡大片| 99久久精品费精品国产一区二区| 亚洲一区精品在线| 国产夜色精品一区二区av| 欧美色爱综合网| 国产在线日韩欧美| 亚洲精品免费在线播放| 久久综合精品国产一区二区三区 | 亚洲久草在线视频| 日韩欧美中文一区二区| 97国产一区二区| 免费欧美高清视频| 亚洲免费看黄网站| 久久综合五月天婷婷伊人| 亚洲第一成人在线| 欧美日韩亚洲丝袜制服| 国产91富婆露脸刺激对白| 一区在线播放视频| 日韩免费观看高清完整版在线观看| 99久久免费视频.com| 日本成人在线网站| 亚洲猫色日本管| 国产色一区二区| 精品国产一区二区三区不卡| 欧美最猛性xxxxx直播| 成人a免费在线看| 狠狠色狠狠色合久久伊人| 图片区小说区区亚洲影院| 国产精品不卡在线| 精品福利av导航| 777亚洲妇女| 欧美三级在线视频| 91丨porny丨首页| eeuss国产一区二区三区| 国产伦精品一区二区三区在线观看| 亚洲欧美另类在线| 国产精品大尺度| 国产精品视频一二| 国产欧美日韩三区| 国产欧美综合在线观看第十页 | 黄网站免费久久| 蜜臀av一级做a爰片久久| 日日夜夜免费精品| 一区二区三区国产精品| 亚洲日本韩国一区| 亚洲精品视频免费看| 亚洲欧美激情视频在线观看一区二区三区| 26uuu色噜噜精品一区二区| 日韩精品一区在线| 日韩午夜精品视频| 日韩视频一区二区三区在线播放 | 欧美tickling挠脚心丨vk| 日韩精品最新网址| 欧美大白屁股肥臀xxxxxx| 欧美va亚洲va| 精品剧情v国产在线观看在线| 日韩一区二区在线观看视频播放| 91精品久久久久久久99蜜桃| 欧美日韩大陆在线| 精品久久国产97色综合| 精品国产一区a| 国产喂奶挤奶一区二区三区| 国产精品无遮挡| 一区二区三区在线影院| 午夜不卡av在线| 精品在线免费观看| 成人一区在线观看| 91片黄在线观看| 91精品国产综合久久福利软件| 欧美一区永久视频免费观看| 日韩三级av在线播放| 国产精品素人一区二区| 一区二区三区欧美亚洲| 日本女优在线视频一区二区| 国产成人亚洲综合a∨婷婷 | 久久久天堂av| 亚洲欧美在线观看| 日韩主播视频在线| 国产一区二区导航在线播放| 91蜜桃婷婷狠狠久久综合9色| 欧美日韩国产成人在线91| 精品国产91乱码一区二区三区| 国产精品久久久久久久久久免费看| 亚洲一区二区精品3399| 国产综合色视频| 欧美午夜精品久久久| 精品久久一区二区| 亚洲综合一区二区| 盗摄精品av一区二区三区| 欧美日韩不卡在线| 国产精品久久久久久亚洲伦| 日本欧美大码aⅴ在线播放|