亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产精品电影院| 国内成人自拍视频| 丝袜亚洲精品中文字幕一区| 美腿丝袜亚洲综合| 99国产精品99久久久久久| 欧美群妇大交群中文字幕| 中文字幕av在线一区二区三区| 亚洲国产一区二区在线播放| 国产一区欧美日韩| 欧美日韩国产高清一区二区三区| 国产偷国产偷精品高清尤物| 肉肉av福利一精品导航| 99re亚洲国产精品| 久久先锋影音av鲁色资源网| 亚洲综合色噜噜狠狠| 国产高清精品在线| 日韩精品影音先锋| 亚洲成年人影院| 成年人国产精品| 久久夜色精品一区| 美脚の诱脚舐め脚责91| 欧美日韩成人一区| 亚洲www啪成人一区二区麻豆| 不卡一区二区中文字幕| 久久精品人人做人人爽97| 免费人成在线不卡| 91精品欧美综合在线观看最新| 亚洲乱码精品一二三四区日韩在线| 国产精品白丝jk白祙喷水网站| 欧美精品v国产精品v日韩精品 | 亚洲狠狠爱一区二区三区| 国产高清在线精品| 久久久久国色av免费看影院| 精品一区二区三区影院在线午夜| 欧美老女人在线| 中文字幕亚洲电影| 成人激情黄色小说| 国产精品久久久久一区二区三区| 亚洲综合无码一区二区| 91亚洲精品久久久蜜桃网站| 国产精品福利一区二区三区| 成人激情视频网站| 亚洲视频1区2区| 99re成人精品视频| 一区二区三区在线视频播放| 91精品1区2区| 亚洲成人精品在线观看| 欧美美女直播网站| 免费美女久久99| 精品国产露脸精彩对白| 国产老妇另类xxxxx| 欧美国产日韩一二三区| 99久久国产综合色|国产精品| 亚洲欧洲精品一区二区三区不卡| 色综合久久久久网| 婷婷夜色潮精品综合在线| 在线综合亚洲欧美在线视频| 久久99久久99| 国产精品青草久久| 欧美系列日韩一区| 久久精品国产久精国产爱| 久久久.com| 91麻豆国产香蕉久久精品| 亚洲成av人片一区二区三区| 欧美成人女星排名| 成人av片在线观看| 婷婷久久综合九色综合绿巨人| 日韩免费在线观看| 波多野结衣在线一区| 亚洲国产精品麻豆| 久久日韩精品一区二区五区| 91在线免费看| 麻豆精品精品国产自在97香蕉| 亚洲国产激情av| 欧美精品高清视频| 菠萝蜜视频在线观看一区| 午夜精品久久久久影视| 欧美激情一区二区在线| 欧美日韩国产一级片| 成人自拍视频在线观看| 日韩激情一区二区| 亚洲视频每日更新| 欧美精品一区二区三区四区| 91麻豆免费视频| 精品系列免费在线观看| 一区二区三区电影在线播| 久久久久久久久久看片| 欧美私模裸体表演在线观看| 国产一区二区三区免费在线观看| 亚洲人成人一区二区在线观看 | 色8久久人人97超碰香蕉987| 麻豆免费精品视频| 一区二区三区电影在线播| 久久精品夜夜夜夜久久| 欧美男男青年gay1069videost| 岛国精品在线播放| 免费看黄色91| 亚洲午夜久久久久久久久电影网| 国产肉丝袜一区二区| 欧美一区二区三区四区在线观看| 97久久精品人人爽人人爽蜜臀| 久久精品理论片| 亚洲电影中文字幕在线观看| 国产精品乱码一区二区三区软件| 欧美一二三四区在线| 欧美午夜精品久久久久久孕妇 | 一区二区三区蜜桃| 国产精品成人在线观看| 国产校园另类小说区| 日韩欧美123| 91精品欧美久久久久久动漫| 7777精品伊人久久久大香线蕉的| www.视频一区| 不卡高清视频专区| 成人黄色小视频| 国产盗摄一区二区| 国产综合久久久久久久久久久久| 日韩一区精品视频| 亚洲亚洲人成综合网络| 亚洲免费看黄网站| 日韩美女久久久| 国产精品传媒入口麻豆| 国产精品三级久久久久三级| 国产婷婷色一区二区三区在线| 2021中文字幕一区亚洲| 日韩一区二区三区三四区视频在线观看| 欧美体内she精高潮| 欧美日韩高清不卡| 91精品午夜视频| 日韩你懂的在线观看| 欧美本精品男人aⅴ天堂| 欧美mv日韩mv国产网站app| 精品国产亚洲一区二区三区在线观看| 91精品国产高清一区二区三区| 69精品人人人人| 欧美成人a∨高清免费观看| 精品久久人人做人人爰| wwww国产精品欧美| 亚洲国产精品精华液ab| 亚洲色图一区二区三区| 一区二区欧美精品| 蜜臀va亚洲va欧美va天堂 | 国产乱国产乱300精品| 国产suv精品一区二区三区| www.亚洲色图| 欧美日韩亚洲综合在线 | 91精选在线观看| 欧美v亚洲v综合ⅴ国产v| 国产色产综合产在线视频| 成人欧美一区二区三区1314| 亚洲午夜av在线| 紧缚奴在线一区二区三区| 成人性生交大片免费看视频在线| 色网综合在线观看| 精品久久久久久久久久久院品网| 欧美国产一区二区| 午夜精品国产更新| 高清不卡一区二区| 欧美日韩日日夜夜| 国产欧美久久久精品影院| 亚洲一区二区三区三| 成人亚洲一区二区一| 欧美伊人久久久久久久久影院 | 老司机一区二区| 成人av在线资源网| 欧美一区二区三区婷婷月色| 国产精品成人在线观看| 蜜桃视频一区二区三区在线观看| 成人黄色软件下载| 91精品国产色综合久久不卡电影 | 在线观看91精品国产入口| 精品国产乱子伦一区| 亚洲福利视频一区| 成人精品一区二区三区中文字幕| 在线播放91灌醉迷j高跟美女 | 色狠狠一区二区| 精品久久久久久综合日本欧美| 亚洲色欲色欲www| 韩国一区二区在线观看| 欧美日韩免费不卡视频一区二区三区| 久久精品一级爱片| 久久国产三级精品| 欧美日韩大陆一区二区| 亚洲免费av高清| 成人丝袜18视频在线观看| 欧美成人乱码一区二区三区| 婷婷开心久久网| 欧美日韩综合一区| 亚洲精品成人天堂一二三| 成人免费视频视频在线观看免费| 日韩一级二级三级| 日韩中文欧美在线| 欧美日韩国产经典色站一区二区三区| 中文字幕中文字幕在线一区| 国产精品99久久久久久似苏梦涵| 日韩精品一区二区三区老鸭窝| 丝袜美腿亚洲色图| 在线播放一区二区三区| 午夜精品一区二区三区三上悠亚| 91久久免费观看|