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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? interpolation.java

?? 實現(xiàn)用于工程計算的的數(shù)學(xué)方法
?? JAVA
?? 第 1 頁 / 共 3 頁
字號:
/*
 * 進行插值的類Interpolation

 * 周長發(fā)編制
 */
package javaalgorithm.algorithm;

/**
 * 進行插值的類Interpolation

 * @author 周長發(fā)
 * @version 1.0
 */
public class Interpolation 
{
	/**
	 * 一元全區(qū)間不等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的值x(i),
	 *            要求x(0)<x(1)<...<x(n-1)
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */
	public static double 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);
	}

	/**
	 * 一元全區(qū)間等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x0 - 存放等距n個結(jié)點中第一個結(jié)點的值
	 * @param xStep - 等距結(jié)點的步長
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */
	public static double getValueLagrange(int n, double x0, double xStep, double[] y, double t)
	{ 
		int i,j,k,m;
	    double z,s,xi,xj;
	    double 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);
	}

	/**
	 * 一元三點不等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的值x(i)
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */
	public static double 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 (Math.abs(t-x[k])<Math.abs(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);
	}

	/**
	 * 一元三點等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x0 - 存放等距n個結(jié)點中第一個結(jié)點的值
	 * @param xStep - 等距結(jié)點的步長
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */
	public static double 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 (Math.abs(t-x0-i*xStep)>=Math.abs(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);
	}

	/**
	 * 連分式不等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的值x(i)
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */
	public static double getValuePqs(int n, double[] x, double[] y, double t)
	{ 
		int i,j,k,m,l;
	    double z,h;
	    double[] b = new double[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 (Math.abs(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);
	}

	/**
	 * 連分式等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x0 - 存放等距n個結(jié)點中第一個結(jié)點的值
	 * @param xStep - 等距結(jié)點的步長
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */
	public static double getValuePqs(int n, double x0, double xStep, double[] y, double t)
	{ 
		int i,j,k,m,l;
	    double z,hh,xi,xj;
	    double[] b = new double[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 (Math.abs(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);
	}

	/**
	 * 埃爾米特不等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的值x(i)
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param dy - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)導(dǎo)數(shù)值y'(i),
	 *             y'(i) = f'(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */
	public static double getValueHermite(int n, double[] x, double[] y, double[] dy, double t)
	{ 
		int i,j;
	    double z,p,q,s;
	    
		// 初值
		z=0.0;
	    
		// 循環(huán)插值
		for (i=1;i<=n;i++)
	    { 
			s=1.0;
	        
			for (j=1;j<=n;j++)
			{
				if (j!=i) 
					s=s*(t-x[j-1])/(x[i-1]-x[j-1]);
			}

	        s=s*s;
	        p=0.0;
	        
			for (j=1;j<=n;j++)
	        {
				if (j!=i) 
					p=p+1.0/(x[i-1]-x[j-1]);
			}

	        q=y[i-1]+(t-x[i-1])*(dy[i-1]-2.0*y[i-1]*p);
	        z=z+q*s;
	    }
	    
		return(z);
	}

	/**
	 * 埃爾米特等距插值
	 * 
	 * @param n - 結(jié)點的個數(shù)
	 * @param x0 - 存放等距n個結(jié)點中第一個結(jié)點的值
	 * @param xStep - 等距結(jié)點的步長
	 * @param y - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param dy - 一維數(shù)組,長度為n,存放給定的n個結(jié)點的函數(shù)導(dǎo)數(shù)值y'(i),
	 *             y'(i) = f'(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數(shù)近似值f(t)
	 */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品一区二区三区不卡 | 丁香网亚洲国际| 欧美喷潮久久久xxxxx| 亚洲综合免费观看高清在线观看| 99久久777色| 亚洲免费观看高清在线观看| aa级大片欧美| 亚洲成a人片在线不卡一二三区 | 欧美成人综合网站| 激情偷乱视频一区二区三区| 久久一日本道色综合| 国产不卡在线一区| 亚洲卡通欧美制服中文| 欧美日韩在线精品一区二区三区激情 | 麻豆精品久久久| 国产午夜亚洲精品理论片色戒 | 成人综合在线网站| 亚洲日本va在线观看| 欧美日韩午夜影院| 国产综合色在线视频区| 国产精品成人午夜| 欧美精品粉嫩高潮一区二区| 久久成人精品无人区| 中文乱码免费一区二区| 欧美日韩免费一区二区三区视频| 手机精品视频在线观看| 久久久久久久网| 欧美性猛片xxxx免费看久爱 | 国产成人h网站| 亚洲综合在线免费观看| 日韩欧美电影一区| caoporen国产精品视频| 三级精品在线观看| 中国av一区二区三区| 欧美三级电影在线观看| 国产另类ts人妖一区二区| 亚洲乱码国产乱码精品精98午夜| 日韩欧美专区在线| 色老综合老女人久久久| 激情欧美一区二区| 亚洲国产精品综合小说图片区| 精品美女在线观看| 欧美性猛片xxxx免费看久爱| 国产99久久久国产精品潘金 | 亚洲免费视频成人| 久久久99精品久久| 欧美日韩精品免费观看视频| 成人激情动漫在线观看| 久久国产三级精品| 亚洲精品成人悠悠色影视| 久久久亚洲综合| 欧美一区二区播放| 在线视频一区二区三| 高清免费成人av| 精品一区二区久久| 视频一区视频二区在线观看| 亚洲免费大片在线观看| 日本一区二区在线不卡| 精品1区2区在线观看| 欧美精品成人一区二区三区四区| 成a人片国产精品| 粉嫩av一区二区三区粉嫩| 精久久久久久久久久久| 日韩精品一级中文字幕精品视频免费观看 | 99精品热视频| 一区二区三区不卡视频| 久久影院视频免费| 欧美中文字幕一二三区视频| 精品一区二区三区视频| 亚洲123区在线观看| 日韩一区二区三区视频在线观看| 91美女福利视频| 激情偷乱视频一区二区三区| 日韩精品一级二级| 伊人色综合久久天天| 国产视频在线观看一区二区三区 | 欧美久久久久久久久中文字幕| 国内精品不卡在线| 日韩高清不卡在线| 麻豆精品久久久| 精品久久99ma| 在线电影国产精品| 色视频成人在线观看免| 在线亚洲免费视频| 色婷婷久久久综合中文字幕| 国产精品18久久久久| 老司机精品视频导航| 五月天丁香久久| 亚洲免费观看在线观看| 亚洲欧洲另类国产综合| 中文字幕不卡一区| 亚洲视频一二区| 国产精品激情偷乱一区二区∴| 精品sm捆绑视频| 精品国产乱码久久久久久浪潮| 91精品久久久久久蜜臀| 欧美日韩精品是欧美日韩精品| 在线免费亚洲电影| 91免费国产视频网站| 93久久精品日日躁夜夜躁欧美| 91丨porny丨首页| 91啪九色porn原创视频在线观看| 99re6这里只有精品视频在线观看| 国产麻豆精品久久一二三| 韩国欧美国产1区| 国产精品一区二区男女羞羞无遮挡| 精一区二区三区| 国产**成人网毛片九色| 9i看片成人免费高清| 99视频在线精品| 欧美精品v日韩精品v韩国精品v| 7777精品伊人久久久大香线蕉的 | 一区二区激情小说| 亚洲成人资源在线| 麻豆精品一二三| 国产成人精品一区二区三区四区| 国产精品一级二级三级| 国产中文字幕精品| 国产91清纯白嫩初高中在线观看| 成人a区在线观看| 欧洲精品视频在线观看| 欧美老女人第四色| 久久精品亚洲乱码伦伦中文| 最好看的中文字幕久久| 五月天激情综合| 韩国一区二区三区| 欧美视频在线不卡| 精品国产髙清在线看国产毛片| 久久亚洲精品国产精品紫薇| 国产精品久久久久久亚洲伦| 一区二区三区**美女毛片| 青青草成人在线观看| 福利一区二区在线| 欧美视频在线一区二区三区| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 亚洲精品写真福利| 日韩avvvv在线播放| 成人a区在线观看| 91精品黄色片免费大全| 国产精品久久影院| 亚洲国产视频在线| 国产激情视频一区二区在线观看| 91天堂素人约啪| 日韩欧美国产一区二区三区| 国产精品久久久久久久久快鸭 | 亚洲区小说区图片区qvod| 日本v片在线高清不卡在线观看| 国产成人精品三级| 日韩视频123| 亚洲激情中文1区| 国产精品影音先锋| 在线不卡的av| 亚洲免费av观看| 国产一区二区不卡| 91精品国产综合久久国产大片| 亚洲婷婷综合久久一本伊一区| 日日夜夜一区二区| 99精品视频中文字幕| 精品国产乱码久久久久久免费| 亚洲精品va在线观看| 成人国产精品免费网站| 日韩免费高清视频| 亚洲高清免费视频| 在线视频国内一区二区| 国产亲近乱来精品视频| 麻豆精品国产传媒mv男同| 欧美性色欧美a在线播放| 亚洲欧洲成人自拍| 国产成人精品免费看| 91精品在线免费观看| 免费观看日韩av| 欧美精品久久久久久久多人混战 | 大尺度一区二区| 久久色.com| 国内精品嫩模私拍在线| 26uuu亚洲综合色| 久久精品国产精品亚洲精品| 717成人午夜免费福利电影| 一级做a爱片久久| 日本高清免费不卡视频| 日韩毛片视频在线看| 99久久精品99国产精品| 中文字幕一区av| 91亚洲精品乱码久久久久久蜜桃 | 一本色道久久加勒比精品| 久久蜜桃av一区精品变态类天堂 | 蜜桃视频免费观看一区| 欧美另类变人与禽xxxxx| 亚洲国产精品久久久男人的天堂| 色婷婷av一区二区三区大白胸| 国产精品久久久久影视| 成人免费av资源| 亚洲欧洲精品一区二区精品久久久| 国内精品久久久久影院薰衣草| 欧美极品aⅴ影院| 丁香激情综合国产| 中文字幕中文乱码欧美一区二区| 成人毛片视频在线观看| 亚洲另类一区二区| 欧美精选在线播放|