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

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

?? interpolate.cpp

?? 插值計算器
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
//////////////////////////////////////////////////////////////////////
// Interpolate.cpp
//
// 插值類 CInterpolate 的實現代碼
//
// 周長發編制, 2002/8
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "Interpolate.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;
    
	// 初值
	z=0.0;
    

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品区一区二区三| 成人av午夜电影| 成人网在线免费视频| 欧美日韩国产免费| 日韩理论片网站| 精品一区二区三区av| 欧美日韩精品一区二区天天拍小说 | 91麻豆国产在线观看| 亚洲精品在线免费观看视频| 亚洲a一区二区| 色综合久久久久久久| 国产欧美日韩综合| 久久99精品久久久久久| 欧美日韩免费电影| 亚洲精品写真福利| 99视频国产精品| 中文字幕av一区二区三区免费看| 日韩电影在线观看一区| 欧美日韩国产不卡| 夜夜精品浪潮av一区二区三区| caoporn国产精品| 国产午夜精品在线观看| 精品系列免费在线观看| 欧美一区二区成人6969| 日韩国产精品91| 国产精品女主播av| 国内精品国产成人| 精品国产不卡一区二区三区| 男人的j进女人的j一区| 制服丝袜中文字幕一区| 亚洲r级在线视频| 制服.丝袜.亚洲.另类.中文| 天天综合色天天| 欧美一区中文字幕| 欧美a级一区二区| 精品久久久三级丝袜| 国产综合色视频| 中文字幕欧美激情一区| 成人福利在线看| 亚洲精品国产成人久久av盗摄| 91福利在线播放| 日本三级韩国三级欧美三级| 精品久久五月天| 福利一区在线观看| 综合久久国产九一剧情麻豆| 在线免费观看不卡av| 一区二区久久久久| 91.com在线观看| 国产高清一区日本| 一区二区三区在线观看欧美 | 日韩精品资源二区在线| 国产在线播放一区三区四| 中文字幕 久热精品 视频在线 | 一区二区三区毛片| 欧美伦理电影网| 久久99久久99| 中文字幕第一区| 欧美色图12p| 久久国产精品第一页| 国产精品欧美精品| 欧美乱妇一区二区三区不卡视频 | 日韩av一区二区三区四区| 久久久久久一级片| 91福利国产精品| 韩国成人精品a∨在线观看| 综合欧美一区二区三区| 日韩欧美国产三级电影视频| 成人国产精品免费观看动漫| 亚洲h在线观看| 国产精品情趣视频| 91精品国产综合久久久久久久| 国产裸体歌舞团一区二区| 亚洲综合男人的天堂| 久久亚区不卡日本| 欧美性感一区二区三区| 国产成人a级片| 日本亚洲三级在线| 亚洲卡通动漫在线| 久久精品一区二区三区av| 欧美三级在线播放| www.av精品| 激情综合五月婷婷| 午夜精彩视频在线观看不卡| 国产色一区二区| 欧美日韩高清在线播放| av福利精品导航| 国产一区二区按摩在线观看| 亚洲成人精品在线观看| 国产精品国产三级国产有无不卡| 欧美日韩中文一区| 97se亚洲国产综合自在线不卡 | 蜜桃一区二区三区在线| 一区二区久久久| 国产精品精品国产色婷婷| 91精品国产色综合久久不卡电影 | av电影在线观看一区| 久久精品99久久久| 日韩一区欧美二区| 亚洲一区电影777| 亚洲视频一区在线观看| 国产精品无码永久免费888| 日韩女同互慰一区二区| 91精品国产综合久久福利| 欧美日韩在线观看一区二区| 97久久超碰国产精品电影| 成人av免费在线观看| 国产精品综合av一区二区国产馆| 欧美a级理论片| 天天影视色香欲综合网老头| 污片在线观看一区二区| 午夜久久久久久久久久一区二区| 亚洲午夜激情av| 亚洲一区在线观看视频| 一区二区三区日本| 亚洲免费视频成人| 亚洲精品成a人| 亚洲精品久久久蜜桃| 一区二区三区丝袜| 一区2区3区在线看| 亚洲高清视频在线| 日韩精品一卡二卡三卡四卡无卡| 亚洲成a人片综合在线| 日韩精品一二区| 欧美系列日韩一区| 欧美色综合天天久久综合精品| 91丝袜国产在线播放| 日本道免费精品一区二区三区| 欧美三电影在线| 欧美日本精品一区二区三区| 日韩午夜小视频| 久久综合久久综合久久| 中文字幕精品综合| 亚洲欧美视频在线观看| 亚洲成av人影院| 国产在线看一区| av电影天堂一区二区在线| 在线观看网站黄不卡| 日韩欧美在线123| 久久精品免视看| 亚洲激情网站免费观看| 三级不卡在线观看| 国产毛片精品视频| 91网站在线观看视频| 欧美一区二区播放| 国产精品丝袜一区| 日韩中文字幕av电影| 国产高清亚洲一区| 欧美日韩在线观看一区二区 | 欧美一区二区三区免费| 欧美国产日产图区| 亚洲国产精品久久一线不卡| 久久成人久久鬼色| 91黄视频在线| 精品裸体舞一区二区三区| 亚洲精品国产无套在线观| 久久99国产精品久久99| 色8久久精品久久久久久蜜| 日韩精品中文字幕在线一区| 亚洲精品老司机| 国产精品一区久久久久| 91精品国产品国语在线不卡| 中文字幕免费在线观看视频一区| 天天av天天翘天天综合网色鬼国产| 国产精品一区二区在线看| 欧美日本在线视频| 亚洲欧美另类小说| 国产成人综合视频| 日韩一级精品视频在线观看| 亚洲日本一区二区三区| 国产精品69毛片高清亚洲| 7777精品伊人久久久大香线蕉 | 成人妖精视频yjsp地址| 欧美一区二区视频在线观看2022| 国产精品国产三级国产有无不卡 | 欧美激情一区二区三区蜜桃视频| 日韩有码一区二区三区| 欧洲在线/亚洲| 国产精品国产三级国产aⅴ无密码| 秋霞成人午夜伦在线观看| 日本二三区不卡| 亚洲欧美影音先锋| 国产精品一区二区男女羞羞无遮挡 | 亚洲精品五月天| 国产91露脸合集magnet| 日韩天堂在线观看| 天堂va蜜桃一区二区三区 | aaa欧美日韩| 中文字幕成人网| 国产河南妇女毛片精品久久久| 日韩欧美一区二区视频| 日日骚欧美日韩| 欧美日韩一区二区三区免费看| 亚洲综合久久久| 在线亚洲欧美专区二区| 亚洲少妇屁股交4| caoporm超碰国产精品| 亚洲欧洲制服丝袜| 一本色道综合亚洲| 一区二区三区在线观看国产| 91色porny在线视频|