數(shù)值分析課程設(shè)計(jì)_第1頁
已閱讀1頁,還剩25頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  數(shù)值分析課程設(shè)計(jì)報(bào)告</p><p>  設(shè)計(jì)題4、6、8、11、12 </p><p>  姓 名 </p><p>  學(xué) 號 </p><p>  院 系 數(shù)學(xué)與信息科學(xué)學(xué)院 </

2、p><p>  專 業(yè) 信息與計(jì)算科學(xué) </p><p>  年 級 2013 級 </p><p>  指導(dǎo)教師 </p><p>  2016年04月25日</p><p><b>  目

3、錄</b></p><p><b>  設(shè)計(jì)題四3</b></p><p>  1.1問題分析與設(shè)計(jì)思路3</p><p><b>  1.2程序清單4</b></p><p>  1.4 結(jié)果分析7</p><p><b>  1.5設(shè)計(jì)總結(jié)

4、7</b></p><p><b>  設(shè)計(jì)題六8</b></p><p>  2.1問題分析與設(shè)計(jì)思路8</p><p><b>  2.2程序清單8</b></p><p>  2.3 運(yùn)行結(jié)果10</p><p>  2.4結(jié)果分析與設(shè)計(jì)總結(jié)10&

5、lt;/p><p><b>  設(shè)計(jì)題八11</b></p><p>  3.1問題分析與設(shè)計(jì)思路11</p><p>  3.2程序清單11</p><p>  3.3 運(yùn)行結(jié)果13</p><p>  3.4結(jié)果分析與設(shè)計(jì)總結(jié)13</p><p><b>

6、;  設(shè)計(jì)題十一14</b></p><p>  4.1問題分析與設(shè)計(jì)思路14</p><p>  4.2程序清單15</p><p>  4.3 運(yùn)行結(jié)果20</p><p>  4.4結(jié)果分析21</p><p>  設(shè)計(jì)題十二………………………………………………………………………………………

7、..22</p><p>  5.1問題分析與設(shè)計(jì)思路……………………………………………………………………22</p><p>  5.2程序清單…………………………………………………………………………………22</p><p>  5.3運(yùn)行結(jié)果…………………………………………………………………………………22</p><p>  5.4結(jié)

8、果分析…………………………………………………………………………………22</p><p>  數(shù)值分析課程設(shè)計(jì)總結(jié)22</p><p><b>  設(shè)計(jì)題四</b></p><p><b>  龍格現(xiàn)象實(shí)驗(yàn)</b></p><p>  1.1問題分析與設(shè)計(jì)思路</p><p&g

9、t;  在計(jì)算方法中,有利用多項(xiàng)式對某一函數(shù)的近似逼近,這樣,利用多項(xiàng)式就可以計(jì)算相應(yīng)的函數(shù)值。例如,在事先不知道某一函數(shù)的具體形式的情況下,只能測量得知某一些分散的函數(shù)值。例如我們不知道氣溫隨日期變化的具體函數(shù)關(guān)系,但是我們可以測量一些孤立的日期的氣溫值,并假定此氣溫隨日期變化的函數(shù)滿足某一多項(xiàng)式。這樣,利用已經(jīng)測的數(shù)據(jù),應(yīng)用待定系數(shù)法便可以求得一個(gè)多項(xiàng)式函數(shù)。應(yīng)用此函數(shù)就可以計(jì)算或者說預(yù)測其他日期的氣溫值。一般情況下,多項(xiàng)式的次數(shù)越

10、多,需要的數(shù)據(jù)就越多,而預(yù)測也就越準(zhǔn)確,這就是龍格現(xiàn)象。</p><p>  對于函數(shù)進(jìn)行拉格朗日插值, 取不同的節(jié)點(diǎn)數(shù)n,在區(qū)間[-5,5]上取等距間隔的節(jié)點(diǎn)為插值點(diǎn),把和插值多項(xiàng)式的曲線畫在同一張圖上進(jìn)行比較。</p><p><b>  1.2程序清單</b></p><p> ?。?)編寫拉格朗日插值函數(shù),將其存到當(dāng)前路徑的M文件中:&

11、lt;/p><p>  function y=lagrange(x0,y0,x) </p><p>  n=length(x0);m=length(x);</p><p>  for i=1:m </p><p><b>  z=x(i); </b></p><p><b>  L=

12、0.0; </b></p><p>  for j=1:n </p><p>  T=1.0; </p><p>  for k=1:n </p><p>  if k~=j </p><p>  T=T*(z-x0(k))/(x0(j)-x0(k));

13、 </p><p><b>  end</b></p><p><b>  end</b></p><p>  L=T*y0(j)+L; </p><p><b>  end</b></p><p><b>  y(i)=L;<

14、;/b></p><p><b>  end</b></p><p> ?。?)分別取不同的n值,作出相對應(yīng)n值的插值多項(xiàng)式的曲線圖。</p><p><b>  n=4時(shí),</b></p><p>  x0=-5:10/4:5;</p><p>  y0=1./(1+

15、x0.^2);</p><p>  x=-5:0.1:5;</p><p>  y=lagrange(x0,y0,x);</p><p>  y1=1./(1+x.^2);</p><p>  plot(x,y,'-k')</p><p><b>  hold on</b><

16、/p><p>  plot(x,y,'-.r')</p><p><b>  n=6時(shí),</b></p><p>  x0=-5:10/6:5;</p><p>  y0=1./(1+x0.^2);</p><p>  x=-5:0.1:5;</p><p> 

17、 y=lagrange(x0,y0,x);</p><p>  >> y1=1./(1+x.^2);</p><p>  >> plot(x,y1,'-k')</p><p>  >> hold on</p><p>  >> plot(x,y,'--h')<

18、;/p><p><b>  n=8時(shí),</b></p><p>  x0=-5:10/8:5;</p><p>  y0=1./(1+x0.^2);</p><p>  x=-5:0.1:5;</p><p>  y=lagrange(x0,y0,x);</p><p>  y

19、1=1./(1+x.^2);</p><p>  plot(x,y1,'-k')</p><p><b>  hold on</b></p><p>  plot(x,y,'--g')</p><p><b>  n=10時(shí),</b></p><p

20、>  x0=-5:1:5;</p><p>  y0=1./(1+x0.^2);</p><p>  x=-5:0.1:5;</p><p>  y=lagrange(x0,y0,x);</p><p>  y1=1./(1+x.^2);</p><p>  plot(x,y1,'-k')<

21、/p><p><b>  hold on</b></p><p>  plot(x,y,'--m')</p><p><b>  1.3 結(jié)果分析</b></p><p><b>  1.4設(shè)計(jì)總結(jié)</b></p><p>  上述現(xiàn)象及結(jié)果

22、告訴我們,在進(jìn)行數(shù)值計(jì)算時(shí),并不是插值多項(xiàng)式的次數(shù)越高(即插值節(jié)點(diǎn)越多),插值效果越好,精度也不一定隨次數(shù)的提高而升高,這種現(xiàn)象稱為Runge現(xiàn)象。從數(shù)值計(jì)算上可解釋為高次插值多項(xiàng)式的計(jì)算會帶來舍入誤差的增大,從而引起計(jì)算失真。因此,實(shí)際應(yīng)用做插值時(shí)一般只用一次、二次最多用三次插值多項(xiàng)式。</p><p><b>  設(shè)計(jì)題六</b></p><p>  函數(shù)逼近Ma

23、tlab實(shí)現(xiàn)及其應(yīng)用</p><p>  2.1問題思路與設(shè)計(jì)思路</p><p>  在數(shù)值計(jì)算中經(jīng)常要計(jì)算函數(shù)值,如計(jì)算機(jī)中計(jì)算基本初等函數(shù)及其他特殊函數(shù);當(dāng)函數(shù)只在有限點(diǎn)集上給定函數(shù)值,要在包含該點(diǎn)集的區(qū)間上用公式給出函數(shù)的簡單表達(dá)式,這些都涉及在區(qū)間[a,b]上用簡單函數(shù)逼近已知復(fù)雜函數(shù)的問題,這就是函數(shù)逼近問題。常用的有最佳平方逼近、最小二乘法。</p><p

24、><b>  2.2程序清單</b></p><p>  (1)最佳平方逼近:</p><p>  legendre(N)函數(shù):</p><p>  function p=legendre(N)</p><p>  syms t x;%定義符號變量t x</p><p><b> 

25、 for n=1:N</b></p><p>  pp(n)=diff((t^2-1)^(n-1),n-1);%diff函數(shù),求函數(shù)的n階導(dǎo)數(shù)</p><p>  Q(n)=2^(n-1)*prod([1:n-1]);%prod函數(shù),計(jì)算數(shù)組元素的連乘積</p><p><b>  end</b></p><p&

26、gt;<b>  pp(1)=1;</b></p><p><b>  Q=sym(Q);</b></p><p>  p=pp*(inv(diag(Q)));</p><p>  用M文件建立被逼近函數(shù):</p><p>  function F=creat(x)</p><p

27、>  n=length(x);</p><p>  F=x.*cos(x(1:n));</p><p><b>  區(qū)間變換函數(shù)程序:</b></p><p>  function f=convert(a,b,F)</p><p><b>  syms x t;</b></p>

28、<p>  s=2\((b-a)*t+a+b);</p><p>  f=subs(F,x,s);</p><p>  變步長復(fù)化梯形求積公式:</p><p>  function I=tx(g)</p><p><b>  m=1;</b></p><p><b>  h=

29、1-(-1);</b></p><p>  T=zeros(1,100);</p><p>  T(1)=h*(feval(g,-1)+feval(g,1))/2;</p><p><b>  i=1;</b></p><p>  while i<100</p><p><

30、b>  m=2*m;</b></p><p><b>  h=h/2;</b></p><p><b>  s=0;</b></p><p>  for k=1:m/2</p><p>  x=-1+h*(2*k-1);</p><p>  s=s+feva

31、l(g,x);</p><p><b>  end</b></p><p>  T(i+1)=T(i)/2+h*s;</p><p>  if abs(T(i+1)-T(i))<0.00001</p><p><b>  I=T(i+1);</b></p><p>&l

32、t;b>  break;</b></p><p><b>  end</b></p><p><b>  i=i+1;</b></p><p><b>  end</b></p><p>  最佳平法逼近函數(shù)leastp:</p><p&g

33、t;  function [c s]=leastp(a,b,N)</p><p><b>  syms t x;</b></p><p>  F=creat(x);</p><p>  p=legendre(N);</p><p>  f=convert(a,b,F);</p><p>  f=p

34、*diag(f);</p><p><b>  for i=1:N</b></p><p>  g=inline(f(i));</p><p><b>  I=tx(g);</b></p><p><b>  u(i)=I;</b></p><p>  

35、Q(i)=2\(2*(i-1)+1);</p><p><b>  end</b></p><p><b>  Q=sym(Q);</b></p><p>  c=double(u*diag(Q));</p><p><b>  S=c*p';</b></p>

36、;<p>  s=subs(S,t,(2*x-a-b)/(b-a));</p><p>  subplot(211),</p><p>  ezplot(s,[a:0.01:b]);</p><p>  subplot(212),</p><p>  ezplot(F,[a,b]);</p><p>  

37、在命令窗口輸入以下代碼:</p><p>  a=0;b=4;N=2;</p><p>  [c s]= leastp(a,b,N);</p><p>  a=0;b=4;N=4; </p><p>  [c s]= leastp(a,b, N);</p><p>  a=0;b=4;N=7;</p>&

38、lt;p>  [c s]= leastp(a,b, N);</p><p><b> ?。?)最小二乘法</b></p><p>  x=[1:1:30]; y=[9,10,11,12,13,14,13,12,11,9,10,11,12,13,14,12,11,10,9,8,7,8,9,11,9,7,6,5,3,1]; a1=polyfit(x,y,3)

39、 </p><p>  a2= polyfit(x,y,9) </p><p>  a3= polyfit(x,y,15) </p><p>  b1=polyval(a1,x) </p><p>  b2= polyval(a2,x) </p><p>  b3= poly

40、val(a3,x) </p><p>  r1= sum((y-b1).^2) </p><p>  r2= sum((y-b2).^2) </p><p>  r3= sum((y-b3).^2) </p><p><b>  2.3結(jié)果分析</b></p&

41、gt;<p><b> ?。?)最佳平方逼近</b></p><p><b>  N=2時(shí),</b></p><p><b>  N=4時(shí),</b></p><p><b>  N=7時(shí), </b></p><p><b> ?。?

42、)最小二乘法</b></p><p><b>  在命令窗口輸入:</b></p><p>  plot(x,y,'*') </p><p>  hold on plot(x,b1, 'r') </p><p>  hold on plo

43、t(x,b2, 'g') </p><p>  hold on plot(x,b3, 'b:o') </p><p><b>  運(yùn)行結(jié)果:</b></p><p><b>  2.4設(shè)計(jì)總結(jié)</b></p><p>  通過本次實(shí)驗(yàn),我不僅對從前

44、所學(xué)的數(shù)值線性代數(shù)的知識有了一定的復(fù)習(xí)和理解,包括最小二乘法,擬合數(shù)據(jù),擬合多項(xiàng)式等有了更好的把握,并且練習(xí)了如何更準(zhǔn)確和熟練地使用Matlab 軟件,該款軟件非常適用于計(jì)算量大的問題,不僅簡單易學(xué)而且編程效率高。它包含很多軟件包,方便又實(shí)用。當(dāng)然,我在實(shí)驗(yàn)過程中也遇到了不少問題,但是在同學(xué)的幫助下都得到了妥善的解決,我認(rèn)為,此次最大的收獲并不是解決了某一個(gè)問題和認(rèn)識了一個(gè)軟件,而是教會我們?nèi)绾巫约喝チ私夂蛯W(xué)習(xí)使用計(jì)算工具,這

45、對我們今后的學(xué)習(xí)和工作有很大的幫助。</p><p><b>  設(shè)計(jì)題八</b></p><p>  常見數(shù)值積分方法的Matlab實(shí)現(xiàn)及其應(yīng)用</p><p>  3.1 問題思路與設(shè)計(jì)思路</p><p>  實(shí)際問題當(dāng)中常常需要計(jì)算積分,有些數(shù)值方法,如微分方程和積分方程的求解,也都和積分計(jì)算相聯(lián)系。依據(jù)人們所熟

46、知的微積分基本定理,對于積分只要找到被積函數(shù)f(x)的原函數(shù)F(x),便有牛頓—萊布尼茨公式:但實(shí)際使用這種求積方法往往有困難,因?yàn)橛写罅康谋环e函數(shù)其原函數(shù)不能用初等函數(shù)表達(dá),故不能用上述公式計(jì)算,因此有必要研究積分的數(shù)值計(jì)算問題。但實(shí)際使用這種求積方法往往有困難,因?yàn)橛写罅康谋环e函數(shù)其原函數(shù)不能用初等函數(shù)表達(dá),故不能用上述公式計(jì)算,因此有必要研究積分的數(shù)值計(jì)算問題。數(shù)值求積方法是近似方法,為要保證精度,我們自然希望求積公式能對盡可能

47、多的函數(shù)準(zhǔn)確的成立,這就提出了所謂代數(shù)精度的概念:如果某個(gè)求積公式對于次數(shù)不超過m的多項(xiàng)式均能準(zhǔn)確的成立,但對于m+1次多項(xiàng)式就不準(zhǔn)確成立,則稱該求積公式具有m次代數(shù)精度。構(gòu)造數(shù)值積分公式最通常的方法是用積分區(qū)間上的n 次插值多項(xiàng)式代替被積函數(shù),由此導(dǎo)出的求積公式稱為插值型求積公式。</p><p><b>  3.2 程序清單</b></p><p>  復(fù)合辛普森

48、公式求解: </p><p>  function s=xinpusen(fun,a,b,n)</p><p><b>  h=(b-a)/n</b></p><p>  s1=0;s2=0;</p><p>  for k=0:(n-1)</p><p><b>  x=a+h*k;&

49、lt;/b></p><p>  s1=s1+feval(fun,x);</p><p><b>  end</b></p><p>  for k=0:(n-1)</p><p>  x=a+h*(k+1/2);</p><p>  s2=s2+feval(fun,x);</p>

50、;<p><b>  end</b></p><p>  s=h/6*(feval(fun,a)+feval(fun,b)+2*s1+4*s2);</p><p><b>  高斯求積公式求解:</b></p><p>  function g=gaosi(fname,a,b,n,m) </p>

51、<p>  switch m </p><p>  case 1 </p><p><b>  t=0;</b></p><p><b>  A=1; </b></p><p>  case 2 </p><p>  t

52、=[-1/sqrt(3),1/sqrt(3)];</p><p>  A=[1,1]; </p><p>  case 3 </p><p>  t=[-sqrt(0.6),0.0,sqrt(0.6)];</p><p>  A=[5/9,8/9,5/9]; </p><p>  case 4

53、 </p><p>  t=[-0.8612136,-0.339981,0.339981,0.861136]; </p><p>  A=[0.347855,0.652145,0.652145,0.347855]; </p><p>  case 5 </p><p>  t=[-0.906180,-

54、0.538469,0.0,0.538469,0.906180]; </p><p>  A=[0.236927,0.478629,0.568889,0.478629,0.236927]; </p><p>  case 6 </p><p>  t=[-0.932470,-0.661209,-0.238619,0.238619,0.66120

55、9,0.932470]; </p><p>  A=[0.171325,0.360762,0.467914,0.467914,0.360762,0.171325]; </p><p><b>  otherwise</b></p><p><b>  error</b></p><p><b&

56、gt;  end</b></p><p>  x=linspace(a,b,n+1);</p><p><b>  g=0;</b></p><p><b>  for i=1:n</b></p><p>  g=g+gsint(fname,x(i),x(i+1),A,t);</p

57、><p><b>  end</b></p><p>  function g=gsint(fname,a,b,A,t) </p><p>  g=(b-a)/2*sum(A.*feval(fname,(b-a)/2*t+(a+b)/2));</p><p>  龍貝格求積公式求解:</p><p>

58、;  function[t]=romberg(f,a,b,e) </p><p>  t=zeros(15,4); </p><p>  t(1,1)=(b-a)/2*(f(a)+f(b)); </p><p>  for k=2:4 </p

59、><p><b>  sum=0;</b></p><p>  for i=1:2^(k-2)</p><p>  sum=sum+f(a+(2*i-1)*(b-a)/2^(k-1));</p><p><b>  end</b></p><p>  t(k,1)=0.5*t(k

60、-1,1)+(b-a)/2^(k-1)*sum;</p><p><b>  for i=2:k</b></p><p>  t(k,i)=(4^(i-1)*t(k,i-1)-t(k-1,i-1))/(4^(i-1)-1);</p><p><b>  end</b></p><p><b&g

61、t;  end</b></p><p>  for k=5:15 </p><p><b>  sum=0;</b></p><p>  for i=1:2^(k-2)</p><p>  sum=sum+f(a+(2*i-1)*(b-a)/2^(k-1));</p

62、><p><b>  end</b></p><p>  t(k,1)=0.5*t(k-1,1)+(b-a)/2^(k-1)*sum;</p><p><b>  for i=2:4</b></p><p>  t(k,i)=(4^(i-1)*t(k,i-1)-t(k-1,i-1))/(4^(i-1)-

63、1);</p><p><b>  end </b></p><p>  if k>6 </p><p>  if abs(t(k,4)-t(k-1,4))<e </p><p>  disp([num2str(t(k,4))]); </p><

64、;p><b>  break;</b></p><p><b>  end</b></p><p><b>  end</b></p><p><b>  end</b></p><p><b>  if k>=15</b>

65、;</p><p>  disp(['溢出']); </p><p><b>  end</b></p><p><b>  3.3 結(jié)果分析</b></p><p><b>  復(fù)合辛普森公式</b></p><p>  在命令窗

66、口輸入:fun=inline(‘1./(1+x.^2)’);</p><p>  xinpusen(fun,01,10)</p><p><b>  運(yùn)行結(jié)果如下:</b></p><p><b>  高斯求解高斯</b></p><p>  在命令窗口輸入:gaosi(inline(‘1./(1+

67、x.^2)’),0,1,2,3)</p><p><b>  運(yùn)行結(jié)果如下:</b></p><p><b>  龍貝格求積公式</b></p><p><b>  運(yùn)行結(jié)果如下:</b></p><p><b>  3.4 設(shè)計(jì)總結(jié)</b></p&

68、gt;<p>  實(shí)驗(yàn)結(jié)果顯示每一個(gè)算法都接近真實(shí)值,但龍貝格算法相比較復(fù)合辛普森算法,高斯算法來說更加接近.對于代數(shù)精度來說,復(fù)合辛普森的代數(shù)精度為11,龍貝格代數(shù)精度為11,高斯代數(shù)精度為11??梢姶鷶?shù)精度相同時(shí),龍貝格的求積精度最小,所以相同條件下龍貝格求積公式最能接近準(zhǔn)確值。這次課程設(shè)計(jì),用MATLAB實(shí)驗(yàn)對數(shù)值積分進(jìn)行了實(shí)現(xiàn),用了3種不同的數(shù)值積分的方法,實(shí)現(xiàn)過程中發(fā)現(xiàn)了各種方法之間的區(qū)別和聯(lián)系.并且在實(shí)驗(yàn)過程中

69、,使自己對數(shù)值積分和MATLAB更加的熟悉.做到了學(xué)習(xí)和實(shí)踐相聯(lián)系。</p><p><b>  設(shè)計(jì)題十一 </b></p><p>  非線性方程的數(shù)值解法的Matlab實(shí)現(xiàn)及其應(yīng)用 </p><p>  4.1 問題思路與設(shè)計(jì)思路</p><p>  非線性是實(shí)際問題中經(jīng)常出現(xiàn)的,并且在科學(xué)與工程計(jì)算中的地位越來越

70、重要,很多我們熟悉的線性模型都是在一定條件下由非線性問題簡化得到的。非線性問題一般不存在直接的求解公式,故沒有直接方法求解,都要使用迭代法求解,迭代法要求先給出根的一個(gè)近似,若且,根據(jù)連續(xù)函數(shù)性質(zhì)可知在內(nèi)至少有一個(gè)實(shí)根,這時(shí)稱為方程的有根區(qū)間,通常可通過逐次搜索法求得方程的有根區(qū)間。對于方程,如果是線性函數(shù),則它的求根是容易的。牛頓法實(shí)質(zhì)上是一種線性化方法,其基本思想是將非線性方程逐步歸結(jié)為某種線性方程來求解。設(shè)已知方程有近似根,將函數(shù)

71、在點(diǎn)展開,有,于是方程可近似地表示為: ,這是個(gè)線性方程</p><p>  記其根為 ,則 的計(jì)算公式為: ,這就是牛頓法。二分法的基本思想是將方程根的區(qū)間平分為兩個(gè)小區(qū)間,把有根的小區(qū)間再平分為兩個(gè)更小的區(qū)間,進(jìn)一步考察根在哪個(gè)更小的區(qū)間內(nèi)。如此繼續(xù)下去,直到求出滿足精度要求的近似值。</p><p><b>  4.2 程序清單</b></p>&

72、lt;p>  迭代法:求方程的一個(gè)近似解,給定初值為,誤差不超過。</p><p>  function[p,k,err,P]=fixpt(f1021,p0,tol,max1)</p><p>  P(1) = p0; </p><p>  for k = 2:max1 </p><p>  P(k) = feval

73、('f1021', P(k-1)); </p><p>  k, err = abs(P(k) - P(k-1)) </p><p>  p = P(k); </p><p>  if(err<tol), </p><p><b>  break;

74、 </b></p><p><b>  end</b></p><p>  if k == max1 </p><p>  disp('maximum number of iterations exceeded'); </p><p><b>  end<

75、;/b></p><p><b>  end</b></p><p><b>  P=P;</b></p><p>  定義一個(gè)名為f1021.m的函數(shù)文件</p><p>  function y = f1021(x) </p><p>  y = sin(x

76、)/x;</p><p>  割線法:求方程的一個(gè)近似解,給定初值-1.5,-1.52,誤差不超過。</p><p>  function [p1, err, k, y] = secant(f1042, p0, p1, delta, max1) </p><p>  p0, p1, feval('f1042', p0), feval('f10

77、42',p1), k = 0; </p><p>  for k = 1:max1</p><p>  p2 = p1 - feval('f1042',p1)*(p1-p0)/(feval('f1042',p1) - feval('f1042',p0)); </p><p>  err = abs(p

78、2-p1); </p><p>  p0 = p1; </p><p>  p1 = p2; </p><p>  p1, err, k, y = feval('f1042', p1); </p><p>  if (err < delta) | (y == 0),</p>&

79、lt;p>  break, </p><p><b>  end</b></p><p><b>  end</b></p><p>  先定義一個(gè)名為f1042.m的函數(shù)文件</p><p>  function y = f1042(x) </p><

80、;p>  y = x^3-x + 2;</p><p>  建立一個(gè)主程序prog1042.m</p><p><b>  clc</b></p><p><b>  clear</b></p><p>  secant(‘f1042’,-1.5,-1.52,10^(-6),11)</p

81、><p>  牛頓法:求解方程的一個(gè)近似解,給定初值為1.2,誤差不超過。</p><p>  function [p1,err,k,y]=newton(f1041,df1041,p0,delta,max1) </p><p>  p0, feval('f1041',p0) </p><p>  for k=1:max1

82、 </p><p>  p1=p0-feval('f1041',p0)/feval('df1041',p0); </p><p>  err=abs(p1-p0); </p><p>  p0=p1; </p><p>  p1,err,k,y=feval('

83、;f1041', p1) </p><p>  if (err < delta)| (y == 0), </p><p>  break, </p><p><b>  end</b></p><p>  p1,err,k,y=feval('f104

84、1', p1)</p><p><b>  end</b></p><p>  先用m文件定義兩個(gè)名為f1014.m和df1041.m的函數(shù)文件</p><p>  function y=f1041(x) </p><p>  y=x^4-4*x+2;</p><p>  func

85、tion y=df1041(x)</p><p>  y=4*x^3-4;</p><p>  建立一個(gè)主程序prog1041.m</p><p><b>  clear</b></p><p>  newton(‘f1041’,’df1041’,1.2,10^(-6),18)</p><p>&

86、lt;b>  二分法:</b></p><p>  function er_fen(f,a,b,esp);</p><p>  f1=subs(f,a);</p><p>  f2=subs(f,b);</p><p>  if f1*f2>0</p><p>  disp('該方程在【

87、a,b】上無解');</p><p>  elseif f1==0</p><p><b>  root=a;</b></p><p>  elseif f2==0</p><p><b>  root=b;</b></p><p><b>  else&l

88、t;/b></p><p><b>  a0=a;</b></p><p><b>  b0=b;</b></p><p><b>  A=[];</b></p><p>  while abs((b0-a0)/2)>=esp</p><p>

89、;  half=(a0+b0)/2;</p><p>  fa=subs(f,a0);</p><p>  fb=subs(f,b0);</p><p>  fhalf=subs(f,half);</p><p>  if fhalf==0</p><p>  root=half;</p><p&g

90、t;<b>  break;</b></p><p>  elseif fa*fhalf<0</p><p><b>  b0=half;</b></p><p><b>  else</b></p><p><b>  a0=half;</b>&l

91、t;/p><p><b>  end </b></p><p>  A=[A,half];</p><p><b>  end</b></p><p>  root=(b0+a0)/2;</p><p><b>  end</b></p>

92、<p><b>  root</b></p><p><b>  A</b></p><p><b>  4.3 結(jié)果分析</b></p><p><b>  迭代法:</b></p><p><b>  在命令窗口輸入:</b&

93、gt;</p><p><b>  clc</b></p><p><b>  clear all</b></p><p>  fixpt(‘f1021’,0.5,10^(-5),20)</p><p><b>  運(yùn)行結(jié)果如下:</b></p><p>

94、;<b>  k = 2</b></p><p>  err =0.4589</p><p><b>  k = 3</b></p><p>  err = 0.1052</p><p><b>  k = 4</b></p><p>  err = 0

95、.0292</p><p><b>  k =5</b></p><p>  err = 0.0078</p><p><b>  k = 6</b></p><p>  err = 0.0021</p><p><b>  k = 7</b></

96、p><p>  err = 5.7408e-004</p><p><b>  k = 8</b></p><p>  err = 1.5525e-004</p><p><b>  k = 9</b></p><p>  err = 4.1975e-005</p>

97、<p><b>  k = 10</b></p><p>  err =1.1350e-005</p><p><b>  k =11</b></p><p>  err =3.0688e-006</p><p>  ans =0.8767</p><p><

98、;b>  割線法:</b></p><p>  在命令窗口輸入:clc</p><p><b>  clear </b></p><p>  secant('f1042',-1.5,-1.52,10^(-6),11)</p><p><b>  運(yùn)行結(jié)果如下:</b>

99、;</p><p>  p0 =-1.5000</p><p>  p1 =-1.5200</p><p>  ans =0.1250</p><p>  ans =0.0082</p><p>  p1 =-1.5214</p><p>  err = 0.0014</p>&l

100、t;p><b>  k = 1</b></p><p>  p1 =-1.5214</p><p>  err =2.2961e-005</p><p><b>  k =2</b></p><p>  p1 =-1.5214</p><p>  err =2.431

101、8e-008</p><p><b>  k =3</b></p><p>  ans = -1.5214</p><p><b>  牛頓法:</b></p><p>  在命令窗口輸入:clear </p><p>  newton('f1041',&#

102、39;df1041',1.2, 10^(-6), 18)</p><p><b>  運(yùn)行結(jié)果如下:</b></p><p>  p0 =1.2000</p><p>  ans =-0.7264</p><p>  p1 =1.4495</p><p>  err =0.2495<

103、/p><p><b>  k =1</b></p><p>  y = 0.6160</p><p>  p1 =1.4495</p><p>  err = 0.2495</p><p><b>  k =1</b></p><p>  y = 0.61

104、60</p><p>  p1 =1.3741</p><p>  err = 0.0753</p><p><b>  k =2</b></p><p>  y = 0.0690</p><p>  p1 = 1.3741</p><p>  err = 0.0753&l

105、t;/p><p><b>  k = 2</b></p><p><b>  y =0.0690</b></p><p>  p1 =1.3633</p><p>  err = 0.0108</p><p><b>  k = 3</b></p>

106、;<p><b>  y =0.0013</b></p><p>  p1 = 1.3633</p><p>  err = 0.0108</p><p><b>  k = 3</b></p><p><b>  y =0.0013</b></p>

107、<p>  p1 = 1.3631</p><p>  err =2.1510e-004</p><p><b>  k = 4</b></p><p>  y =5.1591e-007</p><p>  p1 =1.3631</p><p>  err =2.1510e-004&l

108、t;/p><p><b>  k =4</b></p><p>  y =5.1591e-007</p><p>  p1 = 1.3631</p><p>  err = 8.4146e-008</p><p><b>  k = 5</b></p><p&

109、gt;  y = 7.9048e-014</p><p>  ans = 1.3631</p><p><b>  二分法:</b></p><p>  在命令窗口輸入:syms x;er_fen(sin(x),-2,1,1.0e-2)</p><p><b>  運(yùn)行結(jié)果如下:</b></p

110、><p><b>  4.4 設(shè)計(jì)總結(jié)</b></p><p>  求解非線性方程的問題有以下幾種基本方法。二分法簡單易行,但收斂較慢,僅有線性收斂速度。而且該方法不能用于求偶數(shù)重根或復(fù)根,但可以用來確定迭代法的初始值。牛頓法是方程求根中常用的一種迭代方法,它除了具有簡單迭代法的優(yōu)點(diǎn)外,還具有二階收斂速度(在單根鄰近處)的特點(diǎn),但牛頓法對初始值選取比較苛刻(必須充分靠近方

111、程的根)否則牛頓法可能不收斂。根據(jù)二分法求解非線性方程根的原理,將所求方程根所在的區(qū)間平分為兩個(gè)小區(qū)間,在判斷根屬于哪個(gè)小區(qū)間;把有根的小區(qū)間再平分為二,再判斷根所在的更小的區(qū)間對分;重復(fù)這一過程,最后求出所要的近似值。當(dāng)所分的小區(qū)間的間距越小的時(shí)候,得出的方程根結(jié)果就越精確,其原因就是所分的小區(qū)間間距越小,則就越接近方程等于0的根。所以最后的結(jié)果的精度越高,得到的誤差越小;而對于簡單迭代法,只有在滿足一定條件的情況下,才能求解出在區(qū)間

112、上有唯一根使迭代序列收斂于。根據(jù)牛頓迭代法的原理,求解出非線性方程根的結(jié)果可以看出,牛頓迭代法具有平方收斂的速度,所以在迭代過程中只要迭代幾次就會得到比較精確的解,并不像簡單迭代法,需要迭代多次才能解出較為精確的結(jié)果,但是用牛頓迭代法求解時(shí)選定的初值要接</p><p><b>  設(shè)計(jì)題十二 </b></p><p>  常微分方程的數(shù)值解法及Matlab實(shí)現(xiàn)

113、</p><p>  5.1 問題思路與設(shè)計(jì)思路</p><p>  歐拉方法是解常微分方程初值問題最簡單最古老的一種數(shù)值方法,其基本思路就是把中的導(dǎo)數(shù)項(xiàng)用差商逼近,從而將一個(gè)微分方程轉(zhuǎn)化為一個(gè)代數(shù)方程,以便求解。</p><p>  龍格-庫塔方法的基本思路是想辦法計(jì)算f(x,y)在某些點(diǎn)上的函數(shù)值,然后對這些函數(shù)值做數(shù)值線性組合,構(gòu)造出一個(gè)近似的計(jì)算公式;再把近

114、似的計(jì)算公式和解的泰勒展開式相比較,使得前面的若干項(xiàng)相吻合,從而達(dá)到較高的精度。</p><p><b>  5.2 程序清單</b></p><p><b>  (1)歐拉法:</b></p><p>  創(chuàng)建M文件euler.m</p><p>  function [x,y]=euler1(f

115、un,x0,xfinal,y0,n)</p><p>  if nargin<5,n=50;</p><p><b>  end</b></p><p>  h=(xfinal-x0)/n;</p><p>  x(1)=x0;y(1)=y0;</p><p><b>  for

116、i=1:n</b></p><p>  x(i+1)=x(i)+h;</p><p>  y(i+1)=y(i)+h*feval(fun,x(i),y(i));</p><p><b>  end</b></p><p>  定義函數(shù)方程組中的函數(shù)f1,創(chuàng)建f1.m文件</p><p>

117、;  function f=f1(x,y)</p><p><b>  f=y-2*x/y</b></p><p>  在matlab命令窗口輸入:</p><p>  (2)龍格-庫塔方法:</p><p>  function [ ] = LGKT(h,x0,y0,X,Y)</p><p> 

118、 format long </p><p>  h=input('h='); </p><p>  x0=input('x0='); </p><p>  y0=input('y0=');</p><p>  disp('輸入的范圍是:');</p><p&g

119、t;  X=input('X=');Y=input('Y=');</p><p>  n=round((Y-X)/h); </p><p>  i=1;x1=0;k1=0;k2=0;k3=0;k4=0;</p><p>  for i=1:1:n </p><p><b>  x1=x0+h;<

120、;/b></p><p>  k1=-x0*y0^2; </p><p>  k2=(-(x0+h/2)*(y0+h/2*k1)^2); </p><p>  k3=(-(x0+h/2)*(y0+h/2*k2)^2);</p><p>  k4=(-(x1)*(y0+h*k3)^2);</p><p>  y1=

121、y0+h/6*(k1+2*k2+2*k3+k4);</p><p>  x0=x1;y0=y1;</p><p>  y=2/(1+x0^2); </p><p>  fprintf('結(jié)果=%.3f,%.7f,%.7f\n',x1,y1,y); </p><p><b>  end</b></p

122、><p><b>  end</b></p><p><b>  5.3 結(jié)果分析</b></p><p><b> ?。?)歐拉法</b></p><p>  在matlab命令窗口輸入:</p><p>  plot(x,y,'r*-‘,x,sq

123、rt(1+2*x),’g+--‘;xlabel(‘x’);ylabel(‘y’);title(‘y’=y-2x/y’);legend(‘?dāng)?shù)值解’,’精確解’)</p><p><b>  運(yùn)行結(jié)果如下:</b></p><p><b>  (2)龍格-庫塔法</b></p><p>  在命令窗口輸入:LGKT</p

124、><p><b>  h=0.25</b></p><p><b>  x0=0</b></p><p><b>  y0=2</b></p><p>  運(yùn)行結(jié)果如下: LGKT</p><p><b>  h=0.25</b>&

125、lt;/p><p><b>  x0=0</b></p><p><b>  y0=2</b></p><p><b>  h=0.25</b></p><p><b>  x0=0</b></p><p><b>  y0=

126、2</b></p><p><b>  輸入的范圍是:</b></p><p><b>  X=0</b></p><p><b>  Y=5</b></p><p>  結(jié)果=0.250,1.8823080,1.8823529</p><p&g

127、t;  結(jié)果=0.500,1.5998962,1.6000000</p><p>  結(jié)果=0.750,1.2799478,1.2800000</p><p>  結(jié)果=1.000,1.0000271,1.0000000</p><p>  結(jié)果=1.250,0.7805556,0.7804878</p><p>  結(jié)果=1.500,0.6

128、154594,0.6153846</p><p>  結(jié)果=1.750,0.4923742,0.4923077</p><p>  結(jié)果=2.000,0.4000543,0.4000000</p><p>  結(jié)果=2.250,0.3299396,0.3298969</p><p>  結(jié)果=2.500,0.2758952,0.2758621

129、</p><p>  結(jié)果=2.750,0.2336023,0.2335766</p><p>  結(jié)果=3.000,0.2000200,0.2000000</p><p>  結(jié)果=3.250,0.1729886,0.1729730</p><p>  結(jié)果=3.500,0.1509558,0.1509434</p><

130、p>  結(jié)果=3.750,0.1327899,0.1327801</p><p>  結(jié)果=4.000,0.1176550,0.1176471</p><p>  結(jié)果=4.250,0.1049245,0.1049180</p><p>  結(jié)果=4.500,0.0941229,0.0941176</p><p>  結(jié)果=4.750,

131、0.0848850,0.0848806</p><p>  結(jié)果=5.000,0.0769267,0.0769231</p><p><b>  5.4 設(shè)計(jì)總結(jié)</b></p><p>  常微分方程在科學(xué)技術(shù)和工程中占有重要的地位,這里主要應(yīng)用的是歐拉方法、龍格-庫塔法。它們都是都是采用單步法求常微分方程的數(shù)值解。從構(gòu)造過程看來,它們互相聯(lián)

132、系,但它們又互有差異,它們的精度不同,在每步的迭代過程產(chǎn)生的誤差不一樣。一般來說,歐拉方法較大,而龍格-庫塔法法產(chǎn)生的誤差較小。因此,我們可以根據(jù)實(shí)際的需要,采取不同的方法求常微分方程的數(shù)值解。</p><p>  數(shù)值分析課程設(shè)計(jì)總結(jié)</p><p>  通過此次課程設(shè)計(jì),使我更加扎實(shí)的掌握了MATLAB方面的知識,在設(shè)計(jì)過程中雖然遇到了一些問題,但經(jīng)過一次又一次的思考,一遍又一遍的檢查

133、終于找出了原因所在,也暴露出了前期我在這方面的知識欠缺和經(jīng)驗(yàn)不足。實(shí)踐出真知,通過親自動(dòng)手制作,使我們掌握的知識不再是紙上談兵。由于能力有限,部分功能尚未實(shí)現(xiàn),但是我想至少我做了,也掌握了不少課外的知識。 過而能改,善莫大焉。在課程設(shè)計(jì)過程中,我們不斷發(fā)現(xiàn)錯(cuò)誤,不斷改正,不斷領(lǐng)悟,不斷獲取。最終的檢測調(diào)試環(huán)節(jié),本身就是在踐行“過而能改,善莫大焉”的知行觀。這次課程設(shè)計(jì)終于順利完成了,在設(shè)計(jì)中遇到了很多問題,最后在老師的指導(dǎo)下,終于游逆

134、而解。在今后社會的發(fā)展和學(xué)習(xí)實(shí)踐過程中,一定要不懈努力,不能遇到問題就想到要退縮,一定要不厭其煩的發(fā)現(xiàn)問題所在,然后一一進(jìn)行解決,只有這樣,才能成功的做成想做的事,才能在今后的道路上劈荊斬棘,而不是知難而退,那樣永遠(yuǎn)不可能收獲成功,收獲喜悅,也永遠(yuǎn)不可能得到社會及他人對你的認(rèn)可! 課程設(shè)計(jì)誠然是一門專業(yè)課,給我很多專業(yè)知識以及專業(yè)技能上的提升,同時(shí)又是一門講道課,一門辯思課,給了我許多道,給了我很多思,給了我莫大的空間。</p&

135、gt;<p>  我認(rèn)為,在這學(xué)期的課程設(shè)計(jì)中,不僅培養(yǎng)了獨(dú)立思考、動(dòng)手操作的能力,在各種其它能力上也都有了提高。更重要的是,在實(shí)驗(yàn)課上,我們學(xué)會了很多學(xué)習(xí)的方法。而這是日后最實(shí)用的,真的是受益匪淺。要面對社會的挑戰(zhàn),只有不斷的學(xué)習(xí)、實(shí)踐,再學(xué)習(xí)、再實(shí)踐。這對于我們的將來也有很大的幫助。</p><p>  回顧起此課程設(shè)計(jì),至今我仍感慨頗多,從理論到實(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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論