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

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

?? interpolation.java

?? 實現用于工程計算的的數學方法
?? JAVA
?? 第 1 頁 / 共 3 頁
字號:
/*
 * 進行插值的類Interpolation

 * 周長發編制
 */
package javaalgorithm.algorithm;

/**
 * 進行插值的類Interpolation

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

	/**
	 * 一元全區間等距插值
	 * 
	 * @param n - 結點的個數
	 * @param x0 - 存放等距n個結點中第一個結點的值
	 * @param xStep - 等距結點的步長
	 * @param y - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數近似值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 - 結點的個數
	 * @param x - 一維數組,長度為n,存放給定的n個結點的值x(i)
	 * @param y - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數近似值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 - 結點的個數
	 * @param x0 - 存放等距n個結點中第一個結點的值
	 * @param xStep - 等距結點的步長
	 * @param y - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數近似值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 - 結點的個數
	 * @param x - 一維數組,長度為n,存放給定的n個結點的值x(i)
	 * @param y - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數近似值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 - 結點的個數
	 * @param x0 - 存放等距n個結點中第一個結點的值
	 * @param xStep - 等距結點的步長
	 * @param y - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數近似值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 - 結點的個數
	 * @param x - 一維數組,長度為n,存放給定的n個結點的值x(i)
	 * @param y - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param dy - 一維數組,長度為n,存放給定的n個結點的函數導數值y'(i),
	 *             y'(i) = f'(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數近似值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;
	    
		// 循環插值
		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 - 結點的個數
	 * @param x0 - 存放等距n個結點中第一個結點的值
	 * @param xStep - 等距結點的步長
	 * @param y - 一維數組,長度為n,存放給定的n個結點的函數值y(i),
	 *            y(i) = f(x(i)), i=0,1,...,n-1
	 * @param dy - 一維數組,長度為n,存放給定的n個結點的函數導數值y'(i),
	 *             y'(i) = f'(x(i)), i=0,1,...,n-1
	 * @param t - 存放指定的插值點的值
	 * @return double 型,指定的查指點t的函數近似值f(t)
	 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美女网站一区二区| 精品sm捆绑视频| 亚洲午夜一区二区三区| 欧美色大人视频| 石原莉奈在线亚洲二区| 精品少妇一区二区三区在线视频| 美女诱惑一区二区| 欧美激情一区在线| 97国产精品videossex| 亚洲小说春色综合另类电影| 在线播放欧美女士性生活| 久久精品国产一区二区三| 精品国产凹凸成av人导航| 不卡视频在线看| 亚洲v日本v欧美v久久精品| 日韩黄色免费网站| 欧美精品一区二区三区高清aⅴ | 久久久五月婷婷| 丁香桃色午夜亚洲一区二区三区| 中文字幕一区三区| 日本大香伊一区二区三区| 午夜免费久久看| 国产日韩精品视频一区| 欧美亚洲综合色| 国产裸体歌舞团一区二区| 亚洲欧洲国产日本综合| 日韩精品一区二区三区四区| 久久久www成人免费毛片麻豆 | 欧美一区二区私人影院日本| 国产一区二区视频在线| 国产精品日日摸夜夜摸av| 欧美婷婷六月丁香综合色| 肉丝袜脚交视频一区二区| 亚洲国产成人私人影院tom| 欧美日韩久久久久久| 国产一区999| 亚洲成人精品一区| 国产精品色噜噜| 日韩亚洲欧美中文三级| 色综合久久久久综合| 久久99国产精品麻豆| 亚洲一区在线观看网站| 亚洲国产精品二十页| 欧美久久一区二区| 色综合天天综合色综合av| 精品一区二区久久| 午夜婷婷国产麻豆精品| 国产精品久久久久精k8| 精品国产一区二区三区四区四| 99久久99久久免费精品蜜臀| 国内成+人亚洲+欧美+综合在线| 一区二区三区国产豹纹内裤在线| 久久综合九色综合欧美亚洲| 欧美精品高清视频| 在线免费观看不卡av| 成人免费毛片嘿嘿连载视频| 国产麻豆一精品一av一免费| 日本女优在线视频一区二区| 亚洲宅男天堂在线观看无病毒| 中文字幕亚洲精品在线观看| 国产亚洲视频系列| 精品99久久久久久| 日韩一级免费一区| 91精品视频网| 精品视频一区三区九区| 在线观看一区二区精品视频| 91在线视频网址| 99麻豆久久久国产精品免费 | 欧美mv和日韩mv的网站| 日韩一级二级三级精品视频| 欧美日韩高清影院| 欧美亚日韩国产aⅴ精品中极品| av色综合久久天堂av综合| 盗摄精品av一区二区三区| 国产一区二区三区免费| 国产一区二区三区免费在线观看| 久久精品国产亚洲一区二区三区| 免费欧美高清视频| 久久精品国产99国产| 精品一区二区三区视频在线观看| 日韩电影一二三区| 亚洲不卡av一区二区三区| 亚洲综合激情网| 日韩经典中文字幕一区| 另类中文字幕网| 国产精品一区一区三区| 成人激情午夜影院| 99精品久久久久久| 在线观看91视频| 91麻豆精品国产91久久久资源速度 | 精品视频一区二区三区免费| 欧美性生活一区| 欧美一级片在线| xnxx国产精品| 国产精品久久久久影院色老大| 国产精品丝袜久久久久久app| 国产精品久久久久7777按摩 | 亚洲国产成人私人影院tom| 中文字幕中文字幕在线一区 | 欧美激情一区二区三区不卡| 国产欧美一区二区精品仙草咪| 亚洲欧洲精品一区二区三区不卡| 亚洲精品乱码久久久久久| 亚洲国产日韩av| 免费在线欧美视频| 风流少妇一区二区| 欧美性xxxxxx少妇| 日韩欧美一卡二卡| 国产精品久线在线观看| 亚洲小少妇裸体bbw| 久久av资源站| 色八戒一区二区三区| 日韩一区二区三区精品视频| 日本一区二区免费在线观看视频 | 亚洲va国产va欧美va观看| 久久精品理论片| 91麻豆免费看| 日韩精品一区二区三区视频| 亚洲欧美另类图片小说| 日日欢夜夜爽一区| 成人黄色在线网站| 91麻豆精品国产综合久久久久久| 中文字幕av一区二区三区高 | 五月天激情综合网| 高清国产一区二区| 日韩一区二区三区三四区视频在线观看| 亚洲国产成人午夜在线一区| 午夜精品一区在线观看| 9l国产精品久久久久麻豆| 日韩午夜小视频| 亚洲黄色免费网站| 韩国欧美国产一区| 欧美伦理电影网| 亚洲伦理在线免费看| 国产麻豆9l精品三级站| 911精品产国品一二三产区| 综合欧美亚洲日本| 国内精品久久久久影院色| 欧美日韩午夜影院| 国产精品嫩草影院com| 麻豆成人久久精品二区三区红| 91在线一区二区| 国产精品三级视频| 麻豆91精品视频| 欧美精品久久久久久久久老牛影院 | 久久99精品久久久久婷婷| 91在线观看美女| 国产亚洲成aⅴ人片在线观看| 日本不卡免费在线视频| 在线观看免费亚洲| 一区在线中文字幕| 高清不卡在线观看av| 久久久久久免费| 久久99国产乱子伦精品免费| 欧美日韩不卡在线| 亚洲在线免费播放| 欧美性猛片aaaaaaa做受| 中文字幕日本乱码精品影院| 国产91精品一区二区麻豆亚洲| 亚洲精品在线免费观看视频| 人人狠狠综合久久亚洲| 欧美人牲a欧美精品| 亚洲va欧美va人人爽| 欧美三级一区二区| 午夜精品免费在线观看| 欧美日韩一区三区四区| 午夜精品久久久久久| 7777精品伊人久久久大香线蕉超级流畅 | av激情成人网| 国产精品无遮挡| 成人性色生活片| 国产精品日产欧美久久久久| 成人在线视频一区| 国产精品对白交换视频 | 99视频一区二区三区| 亚洲婷婷在线视频| 一本一本大道香蕉久在线精品 | 午夜精品久久久| 日韩精品中文字幕在线一区| 久久黄色级2电影| 久久亚洲私人国产精品va媚药| 精品在线免费视频| 久久久久久久久久久99999| 丁香亚洲综合激情啪啪综合| 国产精品欧美综合在线| av激情综合网| 午夜av一区二区| 欧美videossexotv100| 粉嫩蜜臀av国产精品网站| 亚洲视频免费观看| 欧美日韩国产在线观看| 美女任你摸久久| 国产精品久久福利| 精品视频一区二区不卡| 久久精品二区亚洲w码| 国产欧美一区二区精品性色| 色综合久久久久综合99| 日韩av电影免费观看高清完整版在线观看| 日韩欧美高清dvd碟片| 风间由美性色一区二区三区|