《線性代數(shù)》課件D1-3_第1頁
《線性代數(shù)》課件D1-3_第2頁
《線性代數(shù)》課件D1-3_第3頁
《線性代數(shù)》課件D1-3_第4頁
《線性代數(shù)》課件D1-3_第5頁
已閱讀5頁,還剩11頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

第一章§3選用和設(shè)計算法時

應(yīng)遵循的原則

一﹑選用數(shù)值穩(wěn)定的計算公式,控制舍入誤差的傳播三﹑盡量避免兩個相近的數(shù)相減二﹑盡量簡化計算步驟以便減少運算次數(shù)四﹑絕對值太小的數(shù)不宜作除數(shù)五﹑合理安排運算次序,防止大數(shù)“吃掉”小數(shù)2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則2一﹑選用數(shù)值穩(wěn)定的計算公式,控制舍入誤差的傳播對于一個數(shù)值算法,如果原始數(shù)據(jù)或某一步有舍入誤差,但在計算過程中,這些誤差能得到控制(即誤差不會放大或不影響結(jié)果的精度要求),則稱該數(shù)值方法是穩(wěn)定的;否則,若誤差在計算中傳播使計算結(jié)果的誤差增長很快,稱它是不穩(wěn)定的。2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則3

計算并估計誤差.

由分部積分可得計算的遞推公式

算法1

先計算I0,再由上式依次計算I1,···,I8.設(shè)In的計算值為In*,則In*=1-nIn-1*,絕對誤差n=1,2,···,8.為E(In*)=In*

-In=-n(In-1*-In-1)=-nE(In-1*),2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則4I0=1-exp(-1)≈0.63212055882856,取I0*

=0.6321,

記初始誤差E(I0*)=I0*

-I0=-δ,則E(I1*)=-E(I0*)=δ,

E(I2*)=-2E(I1*)=-2δ,

E(I3*)=-3E(I2*)=3!δ,

………E(I8*)=-8!δ=-40320δ≈-0.83,

誤差在計算過程中傳播,增長很快!所以,這是一個不穩(wěn)定的算法。E(In*)=-nE(In-1*)2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則5k=9;I=zeros(k,1);I(1)=0.6321;forn=1:k-1I(n+1)=1-n*I(n);endformatlong;I算算看:

I8*=-0.72800000000019得到:>>f=inline('x.^8.*exp(x-1)');I8=quad(f,0,1)利用Matlab數(shù)值積分內(nèi)置函數(shù)quad檢驗結(jié)果:I8=0.10093212627740得到:

2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則6這樣的誤差還可以接受。但是若k繼續(xù)增加,當(dāng)k=19,計算I19*,則誤差E(I19*)=-19!δ

=1.216451004088320e+017δ足夠大,使I19*<0.

如果就取I0*

=0.63212055882856,則初始誤差

回顧:I0=1-exp(-1)≈0.63212055882856,

E(I0*)=δ<10-13,E(I8*)=40320δ<10-8,

結(jié)論:即使現(xiàn)在計算機(jī)的計算精度大為提高,誤差的傳播仍然可能使得計算結(jié)果完全失真。2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則7k=19;I=zeros(k,1);I(1)=1-exp(-1);forn=1:k-1I(n+1)=1-n*I(n);endformatlong;I算算看:

I19*=-0.02945367075154得到:>>f=inline('x.^19.*exp(x-1)');I19=quad(f,0,1)利用Matlab數(shù)值積分內(nèi)置函數(shù)quad檢驗結(jié)果:I19

=0.04772276471237得到:

2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則8怎樣計算I40?注意到0≤x≤1時,1≤ex≤e,把計算In的遞推公式

改寫一下,得算法2

先計算I40,再由上式依次計算I39,···,I19.(n=40,39,...,20)即可取2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則9或干脆取

設(shè)In的計算值為In*,則In-1*=(1-In*)/n,誤差E(In-1*)=In-1*

-In-1=E(In*)/(-n),n=40,39,···,20.若E(I40*)=δ,則E(I19*)=-19!δ/(40!),初始誤差的影響逐步減少,到最后甚至可以忽略,算法穩(wěn)定。小結(jié):要選用數(shù)值穩(wěn)定的計算公式,控制舍入誤差的傳播2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則10k=41;I=zeros(k,1);I(1)=0;forn=k:-1:21I(n-1)=(1-I(n))/(n-1);endformatlong;I(20)算算看:

I19*=0.04772275579621得到:>>f=inline('x.^19.*exp(x-1)');I19=quad(f,0,1)利用Matlab數(shù)值積分內(nèi)置函數(shù)quad檢驗結(jié)果:I19

=0.04772276471237得到:

2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則11二﹑盡量簡化計算步驟以便減少運算次數(shù)例計算多項式

次乘法和

n次加法.若用秦九韶算法(又稱Horner算法)的值,若直接計算再逐項相加,一共需做

2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則12只需做n次乘法和n次加法運算。Matlab命令horner

將符號多項式表為嵌套形式。2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則13三﹑盡量避免兩個相近的數(shù)相減(減法)要盡量避免兩個相近的數(shù)相減,損失有效位數(shù)。四則運算中的穩(wěn)定性問題

如若取4位有效數(shù)字計算,則這個結(jié)果只有1位有效數(shù)字計算,損失了3位有效數(shù)字,嚴(yán)重影響了計算結(jié)果的精度。2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則14如果改變計算公式,避免兩個相近的數(shù)相減,它仍有4位有效數(shù)字。又如在實驗課上,用Matlab運行此例,結(jié)果如何?在16位,32位或64位計算機(jī)上,舉出合適例子,說明以上問題,并在實驗課上,用Matlab運行。2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則15四﹑絕對值太小的數(shù)不宜作除數(shù)(除法)分母稍微改變:0.001→0.0011在實驗課上,用Matlab運行此例,結(jié)果如何?不僅要盡量避免兩個相近的數(shù)相減,還要特別注意避免再用這個差作除數(shù)。2023/4/22第一章第三節(jié)選用和設(shè)計算法時應(yīng)遵循的原則16(加法)要防止大數(shù)吃掉小數(shù):注意數(shù)

溫馨提示

  • 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. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論