版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p> 《數(shù)值分析課程設(shè)計》</p><p><b> 報 告</b></p><p> 【摘要】 本文簡介拉格朗日插值和牛頓插值。拉格朗日插值的算法及程序和拉格朗日在實際生活中的運用。運用了拉格朗日插值的公式,以及它在MATLAB中的算法程序,并用具體例子說明。拉格朗日插值在很多方面都可以運用,具有很高的應(yīng)用價值。關(guān)于牛頓插值法,本文首先給出差商
2、的定義及性質(zhì),由差商遞推得到Newton插值公式。在增加一個插值節(jié)點后,只需計算新增插值節(jié)點帶來的計算,而不必重新計算整個插值公式。然而并不是插值節(jié)點越多越好,插值多項式隨節(jié)點的增多而振動增多,反而不能更好的接近被插函數(shù),這就是龍格現(xiàn)象。龍格現(xiàn)象從根本上否定了增多節(jié)點一提高插值多項式的次數(shù)來達到更好近似的可行性,從而產(chǎn)生了質(zhì)的飛躍。</p><p> 【關(guān)鍵詞】 均差 ; 牛頓插值多項式 ; 龍格現(xiàn)象拉
3、格朗日;插值;公式;算法程序;應(yīng)用;科學(xué)。</p><p> 題目:用拉格朗日插值法和牛頓插值法求近似值</p><p><b> 二、理論</b></p><p> Lagrange插值法的理論:</p><p><b> 1、基本概念</b></p><p>
4、已知函數(shù)y=f(x)在若干點的函數(shù)值=(i=0,1,,n)一個差值問題就是求一“簡單”的函數(shù)p(x):p()=,i=0,1,,n, (1)</p><p> 則p(x)為f(x)的插值函數(shù),而f(x)為被插值函數(shù)會插值原函數(shù),,,,...,為插值節(jié)點,式(1)為插值條件,如果對固定點求f()數(shù)值解,我們稱為一個插值節(jié)點,f()p()稱為點的插值,當(dāng)[min(,,,...,),max(
5、,,,...,)]時,稱為內(nèi)插,否則稱為外插式外推,特別地,當(dāng)p(x)為不超過n次多項式時稱為n階Lagrange插值。</p><p> Lagrange插值公式</p><p><b> ?。?)線性插值</b></p><p> 設(shè)已知 , 及=f() ,=f(),為不超過一次多項式且滿足=,=,幾何上,為過(,),(,)的直線
6、,從而得到</p><p> =+(x-). (2)</p><p> 為了推廣到高階問題,我們將式(2)變成對稱式</p><p><b> =(x)+(x).</b></p><p><b> 其中,</b></p><p> (x)=,(x)=。均為
7、1次多項式且滿足</p><p> ?。▁)=1且(x)=0。或(x)=0且(x)=1。</p><p> 兩關(guān)系式可統(tǒng)一寫成= 。 (3)</p><p> (2)n階Lagrange插值</p><p> 設(shè)已知,,,...,及=f()(i=0,1,.....,n),為不超過n次多項式且滿足(i=0,1,...n).</p&
8、gt;<p> 易知=(x)+....+.</p><p> 其中,均為n次多項式且滿足式(3)(i,j=0,1,...,n),再由(ji)為n次多項式的n個根知=c.最后,由</p><p> c=,i=0,1,...,n.</p><p> 總之,=,=式為n階Lagrange插值公式,其中,(i=0,1,...n)稱為n階Lagrange
9、插值的基函數(shù)。</p><p> 3,Lagrange插值余項</p><p> 設(shè),,,...,[a,b],f(x)在[a,b]上有連續(xù)的n+1階導(dǎo)數(shù),為f(x)關(guān)于節(jié)點,,,...,的n階Lagrange插值多項式,則對任意x[a,b],</p><p> 其中,位于,,,...,及x之間(依賴于x),(x)=</p><p>
10、牛頓插值多項式的理論依據(jù):</p><p><b> 1. 均差定義</b></p><p> 利用插值基函數(shù)很容易得到拉格朗日插值多項式,公式結(jié)構(gòu)緊湊,在理論分析中甚為方便,但當(dāng)插值節(jié)點增減時全部插值基函數(shù)均要隨之變化,整個公式也將發(fā)生變化,這在實際計算中是很不方便的,可把插值多項式表示為如下便于計算的形式</p><p><b&g
11、t; ,</b></p><p> 其中為待定系數(shù),可又插值條件</p><p><b> 確定.</b></p><p><b> 當(dāng)時,.</b></p><p><b> 當(dāng)時,,推得 </b></p><p> ,
12、 ··· ···</p><p> 依此遞推可得到.為寫出系數(shù)的一般表達式,先引進如下均差定義.</p><p> 定義1.1 記為f的零階均差,零階均差的差商記為 稱為函數(shù)關(guān)于點的一階均差.一般地,記(k-1)階均差的差商為 (1.1)稱為f關(guān)于點的k階均差.</p>&l
13、t;p> 2. 均差的基本性質(zhì)</p><p> ?。保A均差可表為函數(shù)值的線性組合,即</p><p><b> ?。 ?1.2)</b></p><p> 這個性質(zhì)可用歸納法證明.這性質(zhì)也表明均差于節(jié)點的排列次序無關(guān),稱為均差的對稱性.即</p><p><b> ?。?lt;/b>&l
14、t;/p><p> ?。 ?1.3)</p><p> , (1.4)</p><p> 2.由性質(zhì)1及(1.1)可得</p><p> ?。常粼谏洗嬖陔A導(dǎo)數(shù),且節(jié)點則階均差與導(dǎo)數(shù)關(guān)系如下:</p><p> 這公式可直接用羅爾定理證明。</p><p>
15、均差計算可列均差表如下(表1-1)。</p><p><b> 表1-1</b></p><p><b> 3. 牛頓插值公式</b></p><p> 根據(jù)均差定義,把看成上一點,可得</p><p><b> ,</b></p><p>&l
16、t;b> ,</b></p><p><b> ……</b></p><p><b> ?。?lt;/b></p><p> 只要把后一式代入前一式,就得到</p><p><b> 其中</b></p><p><b>
17、 (1.5)</b></p><p> 插值余項為 , (1.6)</p><p> 多項式顯然滿足插值條件,且次數(shù)不超過,.</p><p> 我們稱為牛頓(Newton)均差插值多項式.系數(shù)就是均差表1-1中加橫線的各階均差。</p><p> 三、方法、算法與程序設(shè)計</p><
18、p> Lagrange插值算法和程序:</p><p> function yy=nalagr(x,y,xx) </p><p> %用途:Lagrange插值法數(shù)值求解;格式:yy=nalagr(x,y,xx)</p><p> %x是節(jié)點向量,y是節(jié)點上的函數(shù)值,xx是插值點(可以多個),yy返回插值</p><p> m
19、=length(x);n=length(y);</p><p> if m~=n,error('向量x與y的長度必須一致');end</p><p><b> s=0;</b></p><p><b> for i=1:n</b></p><p> t=ones(1,leng
20、th(xx));</p><p> for j=1:n </p><p><b> if j~=i</b></p><p> t=t.*(xx-x(i))/(x(i)-x(j));</p><p><b> end</b></p><p><b> en
21、d</b></p><p> s=s+t*y(i);</p><p><b> end</b></p><p><b> yy=s;</b></p><p><b> 牛頓插值:</b></p><p> 1.newton插值多項式
22、的表達式如下:</p><p> 其中每一項的系數(shù)ci的表達式如下:</p><p> 即為f (x)在點處的i階差商,(,),由差商的性質(zhì)可知:</p><p> 2.牛頓插值的程序?qū)崿F(xiàn)方法:</p><p><b> 第一步:計算。</b></p><p> 第二步:計算牛頓插值多項
23、式中,,得到n個多項式。</p><p> 第三步:將第二步得到的n個多項式相加,得到牛頓插值多項式。</p><p> 第四步:利用所得到的插值多項式,估算取其它值時的值。</p><p> 第五步:作出所求多項式在插值結(jié)點周圍的函數(shù)圖像。</p><p> 3.牛頓插值的程序設(shè)計:</p><p> fu
24、nction [p2,z]=newTon(x,y,t) </p><p> %輸入?yún)?shù)中x,y為元素個數(shù)相等的向量,t為待估計的點,可以為數(shù)字或向量。</p><p> %輸出參數(shù)中p2為所求得的牛頓插值多項式,z為利用多項式所得的t的函數(shù)值。</p><p> n=length(x);</p><p> chaS(1)=y(1);&
25、lt;/p><p><b> for i=2:n</b></p><p> x1=x;y1=y;</p><p> x1(i+1:n)=[];</p><p> y1(i+1:n)=[];</p><p> n1=length(x1);</p><p><b&g
26、t; s1=0;</b></p><p> for j=1:n1</p><p><b> t1=1;</b></p><p> for k=1:n1</p><p><b> if k==j</b></p><p><b> continu
27、e;</b></p><p><b> else</b></p><p> t1=t1*(x1(j)-x1(k));</p><p><b> end</b></p><p><b> end</b></p><p> s1=s1+
28、y1(j)/t1;</p><p><b> end</b></p><p> chaS(i)=s1;</p><p><b> end</b></p><p> b(1,:)=[zeros(1,n-1) chaS(1)];</p><p> cl=cell(1,n
29、-1);</p><p><b> for i=2:n</b></p><p><b> u1=1;</b></p><p> for j=1:i-1</p><p> u1=conv(u1,[1 -x(j)]);</p><p> cl{i-1}=u1;</
30、p><p><b> end</b></p><p> cl{i-1}=chaS(i)*cl{i-1};</p><p> b(i,:)=[zeros(1,n-i),cl{i-1}];</p><p><b> end</b></p><p> p2=b(1,:);&l
31、t;/p><p><b> for j=2:n</b></p><p> p2=p2+b(j,:);</p><p><b> end</b></p><p> if length(t)==1</p><p><b> rm=0;</b></
32、p><p><b> for i=1:n</b></p><p> rm=rm+p2(i)*t^(n-i);</p><p><b> end</b></p><p><b> z=rm;</b></p><p><b> else<
33、;/b></p><p> k1=length(t);</p><p> rm=zeros(1,k1);</p><p> for j=1:k1</p><p><b> for i=1:n</b></p><p> rm(j)=rm(j)+p2(i)*t(j)^(n-i);<
34、;/p><p><b> end</b></p><p><b> z=rm;</b></p><p><b> end</b></p><p><b> end</b></p><p> plot(t,z,'y
35、9;,x,y,'*r')</p><p><b> 四、算例、應(yīng)用實例</b></p><p> 例1已知函數(shù)表sin=0.5000,sin=0.7071,sin=0.8660,分別由線性插值與拋物插值求sin的數(shù)值解,并由余項公式估計計算結(jié)果的精度。</p><p> 解:(1)這里有三個節(jié)點,線性插值需要兩個節(jié)點,根據(jù)
36、余項公式,我們選取前兩個節(jié)點,易知:</p><p> sin()=0.5000+(-)</p><p> =0.5000+0.2071=0.6381</p><p><b> 截斷誤差,</b></p><p><b> =,</b></p><p> 得知結(jié)果至
37、少有1位有效數(shù)字。</p><p><b> 易知sin</b></p><p> 0.7071+=0.8660=0.6434</p><p><b> 截斷誤差為:</b></p><p> 得知結(jié)果至少有兩位數(shù)字。</p><p> 比較本題精確解sin=0.6
38、42787609...,實際誤差限分別為0.0047和0.00062。</p><p> 用上述程序的1的結(jié)果為</p><p> >> x=pi*[1/6 1/4];y=[0.5 0.7071];xx=2*pi/9;</p><p> >> yy1=nalagr(x,y,xx)</p><p><b>
39、; yy1 =</b></p><p><b> -0.5690</b></p><p> >> x=pi*[1/6 1/4 1/3];y=[0.5 0.7071 0.866];</p><p> >> yy2=nalagr(x,y,xx)</p><p><b>
40、 yy2 =</b></p><p><b> 0.8023</b></p><p> >> fplot('sin',[pi/6,pi/3]);hold on;</p><p> >> plot(x,y,'o',xx,0.6381,'g^',xx,0.64
41、34,'rv');hold off;</p><p><b> 圖形為</b></p><p> Lagrange插值應(yīng)用實例:</p><p> 在物理化學(xué),資產(chǎn)價值鑒定工作和計算某一時刻的衛(wèi)星坐標和鐘差等這些方面可以應(yīng)用Lagrange插值。采用拉格朗日插值法計算設(shè)備等功能重置成本,計算精度較高,方法快捷。但是這方法只
42、能針對可比性較強的標準設(shè)備,方法本身也只考慮了單一功能參數(shù),它的應(yīng)用范圍因此受到了一定的限制。作為一種探索,我們可以將此算法以及其它算法集成與計算機評估分析系統(tǒng)中,作為傳統(tǒng)評估分析方法的輔助參考工具,以提高資產(chǎn)價值鑒定工作的科學(xué)性和準確性。</p><p> 2. Newton基本插值公式</p><p> 由均差可以導(dǎo)出n次Newton插值多項式</p><p&g
43、t;<b> 其余項公式為</b></p><p> 2.Newton基本插值公式的程序</p><p><b> 2.1 程序Ⅰ</b></p><p> 按上述公式編寫Matlab程序(文件名New_Int.m).</p><p> function yi = New_Int(x,y,
44、xi)</p><p> % Newton基本插值公式,其中,</p><p> % x向量,全部的插值節(jié)點,按行輸入;</p><p> % y向量,插值節(jié)點處的函數(shù)值,按行輸入;</p><p> % xi向量,自變量x;</p><p> % yi為xi處的函數(shù)估計值.</p><p
45、> n = length(x);m=length(y);</p><p> % s輸入的插值點與他的函數(shù)值應(yīng)有相同的個數(shù).</p><p><b> if n ~= m</b></p><p> error('The lengths of X and Y must be equal!');</p>&
46、lt;p><b> return;</b></p><p><b> end</b></p><p><b> %計算均差表Y.</b></p><p> Y=zeros(n);Y(:,1) = y';</p><p> for k = 1:n-1<
47、;/p><p> for i = 1:n-k</p><p> % 輸入的插值節(jié)點必須互異.</p><p> if abs(x(i+k)-x(i))< eps</p><p> error('the DATA is error!');</p><p><b> return;&l
48、t;/b></p><p><b> end</b></p><p> Y(i,k+1)=(Y(i+1,k)-Y(i,k))/(x(i+k)-x(i));</p><p><b> end</b></p><p><b> end</b></p>&
49、lt;p> % 計算Newton插值公式N(xi)</p><p><b> yi=0;</b></p><p> for i = 1:n</p><p><b> z=1;</b></p><p> for k = 1:i-1</p><p> z = z
50、*(xi-x(k));</p><p><b> end</b></p><p> yi = yi+Y(1,i)* z;</p><p><b> End</b></p><p><b> Matlab演示:</b></p><p> 例2:已
51、知=1,=2,=3,用Newton插值公式求的近似值。</p><p> 在matlab軟件中,程序執(zhí)行如下:</p><p> >>x = [1 4 9]; y = [1 2 3]; xi = 5;</p><p> >> yi = New_Int(x,y,xi)</p><p><b> yi =
52、</b></p><p><b> 2.2667</b></p><p><b> 2.2 程序Ⅱ</b></p><p> 建立一個M文件,命名為newpoly.m.Matlab命令程序如下:</p><p> function[c,d]=newpoly(x,y)</p&
53、gt;<p> % c為所求的Newton插值多項式的系數(shù)構(gòu)成的向量</p><p> n = length(x);</p><p> d = =zeros(n,n);</p><p> d(:,1)= y';</p><p> for j = 2:n</p><p> for k =
54、 j:n</p><p> d(k,j)= (d(k,j-1)-d(k-1,j-1))/(x(k)-x(k-j+1));</p><p><b> end</b></p><p><b> end</b></p><p> c = d(n,n);</p><p>
55、for k =(n-1):-1:1</p><p> c = conv(c,poly(x(k)));</p><p> m = length(c);</p><p> c(m)=c(m)+d(k,k);</p><p><b> end</b></p><p><b> Mat
56、lab演示:</b></p><p> 例3:已知函數(shù)的觀測數(shù)據(jù)見下表,試用上述程序求牛頓插值多項式。</p><p><b> 在命令窗口輸入</b></p><p> >> newpoly([1 2 3 4 5 6],[-3 0 15 48 105 192])</p><p><b
57、> ans =</b></p><p> 0 0 1 0 -4 0</p><p> 所以牛頓插值多項式為 </p><p> 牛頓插值法的應(yīng)用實例:與拉格朗日插值法相比較更為方便,它不僅克服了“增加一個節(jié)點時整個計算工作必須重新開始”的缺點,而且可以節(jié)省乘除法運算次數(shù)。同時,在牛頓插值多項式中用到的差分與差商等概念,與數(shù)值計
58、算的其他方面有著密切的關(guān)系。牛頓插值法來源于生產(chǎn)實踐,其應(yīng)用也日益廣泛。特別是在計算機的使用和航空、造船、精密機械加工,冶金工程等領(lǐng)域都獲得了極為廣泛的應(yīng)用。</p><p> 例4(分別用拉格朗日插值法和牛頓插值法求近似值) 已知</p><p> 分別用Lagrange插值法和牛頓插值法來求log0.78的近似值。</p><p> 解:用拉格朗日方法在m
59、atlab中編寫程序,得到結(jié)果如下:</p><p> >> clear all;</p><p> >> x=[0.4,0.5,0.6,0.7,0.8,0.9];</p><p> >> y=[log(0.4),log(0.5),log(0.6),log(0.7),log(0.8),log(0.9)];</p>
60、<p> >> x0=[0.78];</p><p> >> disp('差值點')</p><p><b> 差值點</b></p><p> >> du=[0.78]</p><p><b> du =</b><
61、/p><p><b> 0.7800</b></p><p> >> disp('差值結(jié)果')</p><p><b> 差值結(jié)果</b></p><p> >> yt=Lagrange(x,y,x0)</p><p><
62、b> yt =</b></p><p><b> -0.2485</b></p><p> >> disp('log函數(shù)值')</p><p><b> log函數(shù)值</b></p><p> >> yreal=[log(0.78)
63、]</p><p><b> yreal =</b></p><p><b> -0.2485</b></p><p> >> disp('差值與函數(shù)值誤差')</p><p><b> 差值與函數(shù)值誤差</b></p><
64、;p> >> dy=yt-yreal</p><p><b> dy =</b></p><p> 8.1720e-006</p><p> 用牛頓插值法在matlab中編寫程序,結(jié)果如下:</p><p> >> clear all;</p><p>
65、 >> x=[[0.4,0.5,0.6,0.7,0.8,0.9];];</p><p> >> y=[-0.916291-0.693147-0.510826-0.357762-0.223144-0.105361];</p><p> >> x0=0.78;</p><p> >> disp('用
66、牛頓插值法在x=1.4處插值:')</p><p> 用牛頓插值法在x=1.4處插值:</p><p> >> yx=Newtoninter(x,y,x0)</p><p><b> yx =</b></p><p><b> -0.7555</b></p>
67、<p><b> 圖形如下:</b></p><p><b> 五、附錄</b></p><p> 本文簡介拉格朗日插值和牛頓插值。拉格朗日插值的算法及程序和拉格朗日在實際生活中的運用。運用了拉格朗日插值的公式,以及它在MATLAB中的算法程序,并用具體例子說明。拉格朗日插值在很多方面都可以運用,具有很高的應(yīng)用價值。關(guān)于牛頓插值
68、法,本文首先給出差商的定義及性質(zhì),由差商遞推得到Newton插值公式。在增加一個插值節(jié)點后,只需計算新增插值節(jié)點帶來的計算,而不必重新計算整個插值公式。然而并不是插值節(jié)點越多越好,插值多項式隨節(jié)點的增多而振動增多,反而不能更好的接近被插函數(shù),這就是龍格現(xiàn)象。龍格現(xiàn)象從根本上否定了增多節(jié)點一提高插值多項式的次數(shù)來達到更好近似的可行性,從而產(chǎn)生了質(zhì)的飛躍。</p><p><b> 六、參考文獻</
69、b></p><p> 1,約瑟夫·拉格朗日</p><p> 2,作者,張玲。文章名,拉格朗日插值在資產(chǎn)評估中的應(yīng)用。</p><p> 3,作者,宮厚誠,李全海。文章名,基于IGS精密星歷的衛(wèi)星坐標和鐘差插值。</p><p> 4,作者,吳法倫,趙占芬。文章名,利用計算機繪制物理化學(xué)實驗中的曲線——拉格朗日插值&
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- (1)拉格朗日插值法和牛頓插值法matlab
- 拉格朗日插值法與牛頓插值法的比較
- 數(shù)值分析課程設(shè)計---牛頓插值、高斯消去法
- 拉格朗日插值和牛頓插值多項式的c程序算法
- 拉格朗日_牛頓_埃米特插值問題的課程設(shè)計
- 計算方法課程設(shè)計--用newton插值多項式求函數(shù)的近似值
- 拉格朗日插值的fortran程序代碼
- 拉格朗日插值算法在工程中的應(yīng)用
- 克里格插值法
- 數(shù)值插值與擬合課程設(shè)計論文
- 牛頓插值法在凸輪修正設(shè)計中的應(yīng)用數(shù)值分析小論文
- 數(shù)值分析冪法課程設(shè)計---用冪法求矩陣的最大特征值
- 數(shù)值分析課程設(shè)計--三次樣條插值
- 課程設(shè)計---hermite 插值法的程序設(shè)計及應(yīng)用
- 數(shù)值分析4-計算方法4插值法
- 數(shù)值分析課程設(shè)計---多項式插值的振蕩現(xiàn)象
- 插值法及其應(yīng)用【文獻綜述】
- 插值法及其應(yīng)用【開題報告】
- 近似值—有效數(shù)字
- 數(shù)值分析課程設(shè)計---驗證樣條插值的收斂性
評論
0/150
提交評論