邢麗
一維插值算法在實(shí)際問(wèn)題中的應(yīng)用和比較
邢麗
(上海第二工業(yè)大學(xué)理學(xué)院,上海201209)
通過(guò)分別介紹拉格朗日插值法、分段線性插值法和三次樣條插值法的理論知識(shí),結(jié)合數(shù)學(xué)軟件Matlab編程工具,對(duì)機(jī)床加工零件問(wèn)題展開(kāi)研究。針對(duì)3種插值方法所得到的圖像曲線,比較它們的適宜性,分析和判斷哪一條曲線最能反映出實(shí)際問(wèn)題中的關(guān)系。
一維插值;拉格朗日插值;分段線性插值;三次樣條插值
在工程實(shí)踐中,如信息技術(shù)中的圖像重建、圖像放大過(guò)程中為避免圖像失真與扭曲而增加的插值補(bǔ)點(diǎn)、建筑工程中的外觀設(shè)計(jì)、化學(xué)工程中的實(shí)驗(yàn)數(shù)據(jù)與模型分析、天文觀測(cè)數(shù)據(jù)、地理信息數(shù)據(jù)的處理等方面,插值技術(shù)的應(yīng)用是不可或缺的。插值技術(shù)的主要思想是要從一組試驗(yàn)觀測(cè)數(shù)據(jù)(xi,yj) (i=0,1,···,n)之中找到自變量x與因變量y之間的函數(shù)關(guān)系,一般可用一個(gè)近似函數(shù)y=g(x)來(lái)表示。插值主要是要求近似函數(shù)y=g(x)在每一個(gè)觀測(cè)點(diǎn)xi處一定要滿(mǎn)足yi=g(xi),i=0,1,···,n。在實(shí)際問(wèn)題中插值理論上的方法有很多,關(guān)鍵在于什么情況下使用、怎樣使用、使用何種插值方法。本文針對(duì)同一實(shí)際問(wèn)題,采用不同的插值方法,分析比較每種方法的優(yōu)缺點(diǎn)。
1.1拉格朗日(Lagrange)插值法
拉格朗日插值是一種最常見(jiàn)的多項(xiàng)式插值法,也是一種最常用的逼近工具。拉格朗日的思想:已知函數(shù)y=f(x)在區(qū)間[a,b]上n+1個(gè)互異點(diǎn)xj的函數(shù)值為yj=f(xj),則在構(gòu)造一組基函數(shù)
顯然Li(x)是基于節(jié)點(diǎn)的n次多項(xiàng)式且滿(mǎn)足
則得到過(guò)n+1個(gè)點(diǎn)的次數(shù)最高為n的多項(xiàng)式pn(x)的構(gòu)造函數(shù)為[1]
1.2分段線性(Piecewise Linearity)插值法
分段線性插值法的思想:假設(shè)區(qū)間[a,b]上的連續(xù)函數(shù)f(x)在n+1個(gè)節(jié)點(diǎn)a=x0<x1<···<xn=b上的函數(shù)值f(xj)=yj(j=0,1,···,n),則可得到xy平面上的n+1個(gè)數(shù)據(jù)點(diǎn)(xj,yj)。連接相鄰數(shù)據(jù)點(diǎn)(xj,yj)、(xj+1,yj+1)得到n條線段,它們組成一條折線。把區(qū)間[a,b]上這n條折線段表示的函數(shù)稱(chēng)為被插函數(shù)f(x)關(guān)于這n+1個(gè)數(shù)據(jù)點(diǎn)的分段線性插值函數(shù),記作S(x),則通過(guò)拉格朗日多項(xiàng)式可用來(lái)表示分段線性曲線:
則線性樣條函數(shù)可表示為[2]
1.3三次樣條(Cubic Spline)插值法
三次樣條插值法的思想:區(qū)間[a,b]上的連續(xù)函數(shù)f(x)有n+1個(gè)節(jié)點(diǎn),其中a=x0<x1<···<xn=b,如果存在n個(gè)三次多項(xiàng)式Si(x),滿(mǎn)足
則稱(chēng)函數(shù)S(x)為三次樣條函數(shù)。
計(jì)算實(shí)例1待加工零件的外形根據(jù)工藝要求由一組數(shù)據(jù)(x,y)給出(在平面情況下),用程控銑床加工時(shí)每一刀只能沿x方向和y方向走非常小的一步,這就需要從已知數(shù)據(jù)得到加工所要求的步長(zhǎng)很小的(x,y)坐標(biāo)。表1中給出的x,y數(shù)據(jù)位于機(jī)翼斷面的下輪廓線上,假設(shè)需要得到x坐標(biāo)每改變0.1時(shí)的y坐標(biāo),試畫(huà)出曲線。
表1 已知數(shù)據(jù)表Tab.1 Known data table
用上述3種插值方法構(gòu)造一維插值函數(shù)曲線。
通過(guò)Matlab編程[3]可以直觀地畫(huà)出通過(guò)拉格朗日插值法所得到的插值曲線(見(jiàn)圖1)。把3種插值函數(shù)曲線放在同一個(gè)圖形界面中,觀察各個(gè)曲線的光滑性和適用性。
圖1 3種插值函數(shù)曲線及10個(gè)插值節(jié)點(diǎn)Fig.1 Three interpolation function curve and 10 interpolation nodes
可以清楚地看出,利用拉格朗日插值法得出的結(jié)果根本不能應(yīng)用,原因在于它的插值曲線走勢(shì)陡峭,不夠穩(wěn)定,高次插值(n>7)收斂性差[4],在x=1.0和x=3.8處有明顯的急彎。分段線性插值得出的結(jié)果光滑性較差,觀察到的曲線有略微明顯的急彎,尤其在x=14處不夠圓滑,但比拉格朗日插值曲線的收斂性、穩(wěn)定性強(qiáng),而且方法簡(jiǎn)單適用、計(jì)算量小。相對(duì)于拉格朗日和分段線性插值法,三次樣條插值的結(jié)果就比較好,它克服了拉格朗日插值函數(shù)的缺點(diǎn),不僅收斂性、穩(wěn)定性強(qiáng),而且也很容易實(shí)現(xiàn),應(yīng)用也十分廣泛。所以建議選用三次樣條插值的結(jié)果。
計(jì)算實(shí)例2通過(guò)Matlab編程得到的圖像如圖2所示。
從圖2(a)中可以看出,拉格朗日插值在起始節(jié)點(diǎn)處波動(dòng)很大,不太符合實(shí)際情況。圖2(c)和圖2(d)是分別使用非扭結(jié)邊界條件和邊界為兩階導(dǎo)數(shù)的三次樣條插值,可以看出,使用非扭結(jié)邊界條件在邊界處波動(dòng)稍大,第二種邊界條件更好。而如圖2(b)所示的分段線性插值在有些地方不是很光滑。
表2 北部灣藍(lán)圓鲹體長(zhǎng)和體重的實(shí)測(cè)原始數(shù)值Tab.2 Beibu Gulfround scad body length and weightofthe originalvalue of the measured
圖2 3種插值方法得到的插值曲線Fig.2 Three interpolation function curve
拉格朗日插值是一種最常見(jiàn)的多項(xiàng)式插值法,也是一種最常用的逼近工具。利用兩個(gè)計(jì)算實(shí)例給出的數(shù)據(jù),結(jié)合Matlab編制程序,可以直觀地畫(huà)出所需數(shù)據(jù)的插值曲線,從圖中不難看出,拉格朗日插值的方法并不適合,它的光滑和穩(wěn)定性很差。否定了拉格朗日插值法后,接著利用分段線性插值法,以同樣的方式作出曲線后發(fā)現(xiàn),分段線性插值法的光滑性較拉格朗日插值法強(qiáng),但觀察到的曲線也有略微明顯的急彎,穩(wěn)定性弱。最后,再利用三次樣條插值法以同樣的步驟構(gòu)造曲線后,發(fā)現(xiàn)得出的圖像不僅收斂性、穩(wěn)定性強(qiáng),而且也很容易實(shí)現(xiàn)。
[1]MATHEWS J H,FINK K D.數(shù)值方法(Matlab法)[M]. 4版.周璐,陳渝,錢(qián)方,等譯.北京:電子工業(yè)出版社, 2005.
[2]李岳生.樣條與插值[M].上海:上海科學(xué)技術(shù)出版社, 2009.
[3]趙靜,但琦.數(shù)學(xué)建模與數(shù)學(xué)實(shí)驗(yàn)[M].北京:高等教育出版社,2003.
[4]BURDEN R L,FAIRES J D.Numericalanalysis[M].7th ed.Boston:PWS,2001.
Application and Comparison ofthe One-DimensionalInterpolation Algorithm in PracticalProblems
XING Li
(Schoolof Science,ShanghaiSecond Polytechnic University,Shanghai201209,P.R.China)
Lagrange interpolation,piecewise linear interpolation and cubic spline interpolation methods of theoretical knowledge is focused on,combined with mathematicalsoftware Matlab programming toolfor machining parts problems to study and compare their suitability of the curves obtained by the three interpolation methods.Atthe same time,itis analyzed and determined which curve best reflects the relationship between the actualproblems.
one-dimension interpolation;Lagrange interpolation;piecewise linear interpolation;cubic spline interpolation
P315.31
A
1001-4543(2013)04-0311-04
2013-08-28;
2013-10-28
邢麗(1978–),女,山東人,副教授,碩士,主要研究方向?yàn)槠⒎址匠虜?shù)值解,電子郵箱xingli@sspu.edu.cn。
上海第二工業(yè)大學(xué)學(xué)報(bào)2013年4期