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

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

?? interpolate.cpp

?? 科學與工程數值算法插值類
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
//////////////////////////////////////////////////////////////////////
// Interpolate.cpp
//
// 插值類 CInterpolate 的實現代碼
//
// 周長發編制, 2002/8
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "Interpolate.h"

// 需要調用矩陣運算
#include "Matrix.h"

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

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

//////////////////////////////////////////////////////////////////////
// 基本構造函數
//////////////////////////////////////////////////////////////////////
CInterpolate::CInterpolate()
{
}

//////////////////////////////////////////////////////////////////////
// 析構函數
//////////////////////////////////////////////////////////////////////
CInterpolate::~CInterpolate()
{
}

//////////////////////////////////////////////////////////////////////
// 將字符串轉化為結點的值
//
// 參數:
// 1. CString s - 數字和分隔符構成的字符串
// 2. int n - 結點的個數
// 3. double dblNodes[] - 一維數組,長度為n,返回結點的值
// 4. const CString& sDelim - 數字之間的分隔符,默認為空格
//
// 返回值:int 型,轉換成功的結點的個數
//////////////////////////////////////////////////////////////////////
int CInterpolate::GetNodesFromString(CString s, int n, double dblNodes[], const CString& sDelim /*= " "*/)
{
	// 將結點值初始化為0
	memset(dblNodes, 0, n*sizeof(double));

	// 構造根據指定的分界符將字符串分解為不同的子串的對象
	CTokenizer tk(s, sDelim);

	CString sElement;
	
	// 分解字符串,給結點賦值
	int i = 0;
	while (tk.Next(sElement))
	{
		sElement.TrimLeft();
		sElement.TrimRight();
		double v = atof(sElement);
		dblNodes[i++] = v;

		if (i == n)
			break;
	}

	return i;
}

//////////////////////////////////////////////////////////////////////
// 一元全區間不等距插值
//
// 參數:
// 1. int n - 結點的個數
// 2. double x[] - 一維數組,長度為n,存放給定的n個結點的值x(i),
//                 要求x(0)<x(1)<...<x(n-1)
// 3. double y[] - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
//                 y(i) = f(x(i)), i=0,1,...,n-1
// 4. double t - 存放指定的插值點的值
//
// 返回值:double 型,指定的查指點t的函數近似值f(t)
//////////////////////////////////////////////////////////////////////
double CInterpolate::GetValueLagrange(int n, double x[], double y[], double t)
{ 
	int i,j,k,m;
    double z,s;

	// 初值
    z=0.0;
    
	// 特例處理
	if (n<1) 
		return(z);
    if (n==1) 
	{ 
		z=y[0];
		return(z);
	}
    
	if (n==2)
    { 
		z=(y[0]*(t-x[1])-y[1]*(t-x[0]))/(x[0]-x[1]);
        return(z);
    }
    
	// 開始插值
	i=0;
    while ((x[i]<t)&&(i<n)) 
		i=i+1;
    
	k=i-4;
    if (k<0) 
		k=0;
    
	m=i+3;
    if (m>n-1) 
		m=n-1;
    for (i=k;i<=m;i++)
    { 
		s=1.0;
        for (j=k;j<=m;j++)
		{
			if (j!=i) 
				// 拉格朗日插值公式
				s=s*(t-x[j])/(x[i]-x[j]);
		}

        z=z+s*y[i];
    }
    
	return(z);
}

//////////////////////////////////////////////////////////////////////
// 一元全區間等距插值
//
// 參數:
// 1. int n - 結點的個數
// 2. double x0 - 存放等距n個結點中第一個結點的值
// 3. double xStep - 等距結點的步長
// 4. double y[] - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
//                 y(i) = f(x(i)), i=0,1,...,n-1
// 5. double t - 存放指定的插值點的值
//
// 返回值:double 型,指定的查指點t的函數近似值f(t)
//////////////////////////////////////////////////////////////////////
double CInterpolate::GetValueLagrange(int n, double x0, double xStep, double y[], double t)
{ 
	int i,j,k,m;
    double z,s,xi,xj;
    float p,q;
    
	// 初值
	z=0.0;
    
	// 特例處理
	if (n<1) 
		return(z);
    if (n==1) 
	{ 
		z=y[0]; 
		return(z);
	}
    if (n==2)
    { 
		z=(y[1]*(t-x0)-y[0]*(t-x0-xStep))/xStep;
        return(z);
    }
    
	// 開始插值
	if (t>x0)
    { 
		p=(t-x0)/xStep; 
		i=(int)p; 
		q=(float)i;
        
		if (p>q) 
			i=i+1;
    }
    else 
		i=0;
    
	k=i-4;
    if (k<0) 
		k=0;
    
	m=i+3;
    if (m>n-1) 
		m=n-1;
    
	for (i=k;i<=m;i++)
    { 
		s=1.0; 
		xi=x0+i*xStep;
        
		for (j=k; j<=m; j++)
        {
			if (j!=i)
            { 
				xj=x0+j*xStep;
                // 拉格朗日插值公式
				s=s*(t-xj)/(xi-xj);
            }
		}

        z=z+s*y[i];
    }
    
	return(z);
}

//////////////////////////////////////////////////////////////////////
// 一元三點不等距插值
//
// 參數:
// 1. int n - 結點的個數
// 2. double x[] - 一維數組,長度為n,存放給定的n個結點的值x(i)
// 3. double y[] - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
//                 y(i) = f(x(i)), i=0,1,...,n-1
// 4. double t - 存放指定的插值點的值
//
// 返回值:double 型,指定的查指點t的函數近似值f(t)
//////////////////////////////////////////////////////////////////////
double CInterpolate::GetValueLagrange3(int n, double x[], double y[], double t)
{ 
	int i,j,k,m;
    double z,s;
    
	// 初值
	z=0.0;
    
	// 特例處理
	if (n<1) 
		return(z);
    if (n==1) 
	{ 
		z=y[0]; 
		return(z);
	}
    if (n==2)
    { 
		z=(y[0]*(t-x[1])-y[1]*(t-x[0]))/(x[0]-x[1]);
        return(z);
    }
    
	// 開始插值
	if (t<=x[1]) 
	{ 
		k=0; 
		m=2;
	}
    else if (t>=x[n-2]) 
	{ 
		k=n-3; 
		m=n-1;
	}
    else
    { 
		k=1; 
		m=n;
        while (m-k!=1)
        { 
			i=(k+m)/2;
            
			if (t<x[i-1]) 
				m=i;
            else 
				k=i;
        }
        
		k=k-1; 
		m=m-1;
        
		if (fabs(t-x[k])<fabs(t-x[m])) 
			k=k-1;
        else 
			m=m+1;
    }
    
	z=0.0;
    for (i=k;i<=m;i++)
    { 
		s=1.0;
        for (j=k;j<=m;j++)
        {
			if (j!=i) 
                // 拋物線插值公式
				s=s*(t-x[j])/(x[i]-x[j]);
		}

        z=z+s*y[i];
    }
    
	return(z);
}

//////////////////////////////////////////////////////////////////////
// 一元三點等距插值
//
// 參數:
// 1. int n - 結點的個數
// 2. double x0 - 存放等距n個結點中第一個結點的值
// 3. double xStep - 等距結點的步長
// 4. double y[] - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
//                 y(i) = f(x(i)), i=0,1,...,n-1
// 5. double t - 存放指定的插值點的值
//
// 返回值:double 型,指定的查指點t的函數近似值f(t)
//////////////////////////////////////////////////////////////////////
double CInterpolate::GetValueLagrange3(int n, double x0, double xStep, double y[], double t)
{ 
	int i,j,k,m;
    double z,s,xi,xj;
    
	// 初值
	z=0.0;
    
	// 特例處理
	if (n<1) 
		return(z);
    if (n==1) 
	{ 
		z=y[0]; 
		return(z);
	}
    if (n==2)
    { 
		z=(y[1]*(t-x0)-y[0]*(t-x0-xStep))/xStep;
        return(z);
    }
    
	// 開始插值
	if (t<=x0+xStep) 
	{ 
		k=0; 
		m=2;
	}
    else if (t>=x0+(n-3)*xStep) 
	{ 
		k=n-3; 
		m=n-1;
	}
    else
    { 
		i=(int)((t-x0)/xStep)+1;

        if (fabs(t-x0-i*xStep)>=fabs(t-x0-(i-1)*xStep))
        { 
			k=i-2; 
			m=i;
		}
        else 
		{
			k=i-1; 
			m=i+1;
		}
    }
    
	z=0.0;
    for (i=k;i<=m;i++)
    { 
		s=1.0; 
		xi=x0+i*xStep;

        for (j=k;j<=m;j++)
        {
			if (j!=i)
            { 
				xj=x0+j*xStep; 
                // 拋物線插值公式
				s=s*(t-xj)/(xi-xj);
			}
		}

        z=z+s*y[i];
    }
    
	return(z);
}

//////////////////////////////////////////////////////////////////////
// 連分式不等距插值
//
// 參數:
// 1. int n - 結點的個數
// 2. double x[] - 一維數組,長度為n,存放給定的n個結點的值x(i)
// 3. double y[] - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
//                 y(i) = f(x(i)), i=0,1,...,n-1
// 4. double t - 存放指定的插值點的值
//
// 返回值:double 型,指定的查指點t的函數近似值f(t)
//////////////////////////////////////////////////////////////////////
double CInterpolate::GetValuePqs(int n, double x[], double y[], double t)
{ 
	int i,j,k,m,l;
    double z,h,b[8];
    
	// 初值
	z=0.0;
    
	// 特例處理
	if (n<1) 
		return(z);
    if (n==1) 
	{ 
		z=y[0]; 
		return(z);
	}
    
	// 連分式插值
	if (n<=8) 
	{ 
		k=0; 
		m=n;
	}
    else if (t<x[4]) 
	{ 
		k=0; 
		m=8;
	}
    else if (t>x[n-5]) 
	{ 
		k=n-8; 
		m=8;
	}
    else
    { 
		k=1; 
		j=n;
        
		while (j-k!=1)
        { 
			i=(k+j)/2;
            if (t<x[i-1]) 
				j=i;
            else 
				k=i;
        }
        
		k=k-4; 
		m=8;
    }
    
	b[0]=y[k];
    for (i=2;i<=m;i++)
    { 
		h=y[i+k-1]; 
		l=0; 
		j=1;
        
		while ((l==0)&&(j<=i-1))
        { 
			if (fabs(h-b[j-1])+1.0==1.0) 
				l=1;
            else 
				h=(x[i+k-1]-x[j+k-1])/(h-b[j-1]);
              
			j=j+1;
        }
        
		b[i-1]=h;
        
		if (l!=0) 
			b[i-1]=1.0e+35;
    }
    
	z=b[m-1];
    for (i=m-1;i>=1;i--) 
		z=b[i-1]+(t-x[i+k-1])/z;
    
	return(z);
}

//////////////////////////////////////////////////////////////////////
// 連分式等距插值
//
// 參數:
// 1. int n - 結點的個數
// 2. double x0 - 存放等距n個結點中第一個結點的值
// 3. double xStep - 等距結點的步長
// 4. double y[] - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
//                 y(i) = f(x(i)), i=0,1,...,n-1
// 5. double t - 存放指定的插值點的值
//
// 返回值:double 型,指定的查指點t的函數近似值f(t)
//////////////////////////////////////////////////////////////////////
double CInterpolate::GetValuePqs(int n, double x0, double xStep, double y[], double t)
{ 
	int i,j,k,m,l;
    double z,hh,xi,xj,b[8];
    
	// 初值
	z=0.0;
    
	// 特例處理
	if (n<1) 
		return(z);
    if (n==1) 
	{ 
		z=y[0]; 
		return(z);
	}
    
	// 連分式插值
	if (n<=8) 
	{ 
		k=0; 
		m=n;
	}
    else if (t<(x0+4.0*xStep)) 
	{ 
		k=0; 
		m=8;
	}
    else if (t>(x0+(n-5)*xStep)) 
	{ 
		k=n-8; 
		m=8;
	}
    else 
	{ 
		k=(int)((t-x0)/xStep)-3; 
		m=8;
	}
    
	b[0]=y[k];
    for (i=2;i<=m;i++)
    { 
		hh=y[i+k-1]; 
		l=0; 
		j=1;
        
		while ((l==0)&&(j<=i-1))
        { 
			if (fabs(hh-b[j-1])+1.0==1.0) 
				l=1;
            else
            { 
				xi=x0+(i+k-1)*xStep;
                xj=x0+(j+k-1)*xStep;
                hh=(xi-xj)/(hh-b[j-1]);
            }
        
			j=j+1;
        }

        b[i-1]=hh;
        if (l!=0) 
			b[i-1]=1.0e+35;
    }
    
	z=b[m-1];
    for (i=m-1;i>=1;i--)
		z=b[i-1]+(t-(x0+(i+k-1)*xStep))/z;
    
	return(z);
}

//////////////////////////////////////////////////////////////////////
// 埃爾米特不等距插值
//
// 參數:
// 1. int n - 結點的個數
// 2. double x[] - 一維數組,長度為n,存放給定的n個結點的值x(i)
// 3. double y[] - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
//                 y(i) = f(x(i)), i=0,1,...,n-1
// 4. double dy[] - 一維數組,長度為n,存放給定的n個結點的函數導數值y'(i),
//                 y'(i) = f'(x(i)), i=0,1,...,n-1
// 5. double t - 存放指定的插值點的值
//
// 返回值:double 型,指定的查指點t的函數近似值f(t)
//////////////////////////////////////////////////////////////////////
double CInterpolate::GetValueHermite(int n, double x[], double y[], double dy[], double t)
{ 
	int i,j;
    double z,p,q,s;
    
	// 初值

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲高清一区二区三区不卡| 激情综合网最新| 亚洲欧洲在线观看av| 久久色成人在线| 久久久噜噜噜久噜久久综合| 精品卡一卡二卡三卡四在线| 日韩一区二区三区观看| 日韩你懂的电影在线观看| 精品国产露脸精彩对白| 国产无人区一区二区三区| 中文字幕av一区二区三区| 中文字幕日韩一区| 一区二区三区毛片| 秋霞电影一区二区| 国产精品亚洲视频| 91浏览器入口在线观看| 欧美日韩精品免费| 精品人在线二区三区| 欧美韩国日本一区| 一区二区成人在线观看| 麻豆国产欧美日韩综合精品二区 | 在线免费观看成人短视频| 91蝌蚪porny九色| 欧美日韩综合不卡| 日韩欧美资源站| 中文字幕国产一区二区| 亚洲电影欧美电影有声小说| 极品少妇xxxx精品少妇偷拍| www.爱久久.com| 欧美一区二区视频观看视频| 国产蜜臀97一区二区三区| 亚洲午夜久久久| 国产成人在线观看免费网站| 日本丶国产丶欧美色综合| 日韩精品一区二区三区中文不卡 | 亚洲一区精品在线| 麻豆91在线播放免费| 成人小视频免费观看| 欧美日韩精品福利| 欧美影片第一页| 69堂国产成人免费视频| 国产一区二区三区黄视频 | 国精品**一区二区三区在线蜜桃| 欧美一级二级三级乱码| 国内成人精品2018免费看| 国产午夜一区二区三区| a美女胸又www黄视频久久| 亚洲精品国产视频| 91精品婷婷国产综合久久性色| 天天做天天摸天天爽国产一区| 3atv一区二区三区| 国产精品亚洲人在线观看| 国产精品白丝在线| 色婷婷狠狠综合| 美女网站色91| 国产精品私人自拍| 欧美午夜在线观看| 国产一区在线不卡| 亚洲精品综合在线| 日韩三级精品电影久久久| 成人在线视频首页| 日韩影院精彩在线| 国产欧美日韩综合精品一区二区| 色综合天天做天天爱| 久久99九九99精品| 亚洲欧美日韩国产手机在线 | 欧美一区中文字幕| 国产成人精品亚洲777人妖| 亚洲女同一区二区| 26uuu亚洲| 欧美性生活久久| 国产精品一区免费视频| 亚洲aⅴ怡春院| 2021国产精品久久精品| 色婷婷亚洲综合| 国内外成人在线| 午夜久久久久久久久久一区二区| 欧美精品一区二区在线播放| 日本久久一区二区三区| 国产一区二区在线观看视频| 亚洲一区二区三区视频在线| 久久久精品一品道一区| 8v天堂国产在线一区二区| 成人免费看的视频| 久草这里只有精品视频| 午夜激情久久久| 亚洲三级在线观看| 久久久精品国产免大香伊| 欧美情侣在线播放| 99久久99久久精品免费观看 | 欧洲一区在线电影| 成人性生交大片免费看中文网站| 毛片av中文字幕一区二区| 亚洲午夜在线视频| 亚洲你懂的在线视频| 久久亚洲综合色| 日韩精品影音先锋| 欧美日本在线看| 欧美探花视频资源| 欧美午夜电影网| 欧美性猛交xxxx黑人交 | 国产ts人妖一区二区| 美女一区二区视频| 蜜臀a∨国产成人精品| 午夜精品在线看| 亚洲一区欧美一区| 亚洲午夜激情av| 一区二区成人在线视频| 樱花影视一区二区| 亚洲精品国产精华液| 亚洲欧美一区二区三区国产精品| 久久久精品日韩欧美| 国产视频一区二区三区在线观看| www成人在线观看| 欧美大尺度电影在线| 欧美变态tickle挠乳网站| 日韩欧美一区在线观看| 欧美大片一区二区三区| 欧美一区二区三区视频在线| 欧美一区日本一区韩国一区| 日韩欧美一区二区视频| 欧美电视剧免费观看| 精品福利一二区| 国产欧美精品一区二区色综合 | 久久综合视频网| 久久青草欧美一区二区三区| 国产婷婷精品av在线| 国产精品欧美一区喷水| 亚洲视频在线一区观看| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美理论电影在线| 欧美一区二区三区色| 精品人在线二区三区| 国产精品女上位| 一区二区三区免费网站| 日本亚洲免费观看| 国产馆精品极品| 91国偷自产一区二区三区观看| 欧美夫妻性生活| 久久伊人蜜桃av一区二区| 日韩一区在线看| 丝袜美腿亚洲综合| 成人一区二区三区视频在线观看| 91网站视频在线观看| 日韩欧美国产系列| 亚洲欧洲性图库| 蜜桃av噜噜一区二区三区小说| 国产999精品久久| 欧美日韩一区二区三区在线| 精品处破学生在线二十三| 成人欧美一区二区三区小说| 一区二区三区丝袜| 国产乱码精品一品二品| 欧美丝袜自拍制服另类| 久久综合色婷婷| 亚洲一区二区三区爽爽爽爽爽 | 久久久国产精品午夜一区ai换脸| 亚洲欧洲日韩av| 九色|91porny| 欧美日韩色一区| 国产丝袜欧美中文另类| 手机精品视频在线观看| 成人av电影在线观看| 91精品国产综合久久国产大片| 成人免费在线播放视频| 久久草av在线| 欧美日韩国产在线播放网站| 中文字幕日韩一区| 国产精品自拍三区| 91精品国产一区二区人妖| 成人免费一区二区三区在线观看 | 青青草国产精品97视觉盛宴| 91影视在线播放| 国产人妖乱国产精品人妖| 日产国产欧美视频一区精品| 色婷婷精品大在线视频| 亚洲欧洲另类国产综合| 国产美女一区二区三区| 91精品国产91久久久久久一区二区| 亚洲精品视频在线观看网站| 国产91精品精华液一区二区三区| 日韩欧美美女一区二区三区| 亚洲高清不卡在线| 欧美日韩在线播放三区| 亚洲激情网站免费观看| 99re这里都是精品| 国产精品久久免费看| 国产成人日日夜夜| 久久久五月婷婷| 国产一区二区成人久久免费影院| 制服丝袜激情欧洲亚洲| 免费在线观看精品| 日韩欧美不卡一区| 精品一区免费av| 精品99999| 国产精品一区二区视频| 欧美激情艳妇裸体舞| 成人三级在线视频| 国产精品电影一区二区三区| 99re热这里只有精品视频|