版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> 課 程 設(shè) 計 報 告</p><p> 課程名稱 </p><p> 課題名稱 </p><p> 專 業(yè) </p><p> 班 級 <
2、/p><p> 學(xué) 號 </p><p> 姓 名 </p><p> 指導(dǎo)教師 </p><p> 2009年 12 月 15 日</p&
3、gt;<p> 課 程 設(shè) 計 任 務(wù) 書</p><p> 課程名稱 數(shù)值分析 </p><p> 課 題 初值問題、邊值問題 </p><p> 專業(yè)班級 </p><p> 學(xué)生姓名 </p><p
4、> 學(xué) 號 </p><p> 指導(dǎo)老師 </p><p> 審 批 </p><p> 任務(wù)書下達(dá)日期 2011 年 12 月 5 日</p><p> 任務(wù)
5、完成日期 2011 年 12 月 15日</p><p><b> 目 錄</b></p><p> 一、設(shè)計內(nèi)容與要求..............................................................................4</p><p> 二、問題提出的背景........
6、.......................................................................6</p><p> 三、問題的提出.......................................................................................6</p><p> 四、算法的理論
7、依據(jù)及推導(dǎo)...................................................................7</p><p><b> 五、程序模塊</b></p><p> 1、函數(shù)模塊......................................................................
8、.......13</p><p> 2、模塊流程圖.........................................................................14</p><p> 六、實驗結(jié)果與調(diào)試..........................................................................
9、....24</p><p> 七、心得體會..........................................................................................27八、附件.........................................................................................
10、.........28</p><p> 一、設(shè)計內(nèi)容與設(shè)計要求</p><p><b> 1.設(shè)計內(nèi)容:</b></p><p> 對課程《計算方法》中的常見算法進(jìn)行綜合設(shè)計或應(yīng)用(具體課題題目見后面的供選題目)。</p><p><b> 2.設(shè)計要求:</b></p>&
11、lt;p> 課程設(shè)計報告正文內(nèi)容</p><p> 問題的描述及算法設(shè)計;</p><p> 算法的流程圖(要求畫出模塊圖);</p><p> 算法的理論依據(jù)及其推導(dǎo);</p><p> 相關(guān)的數(shù)值結(jié)果(通過程序調(diào)試),;</p><p> 數(shù)值計算結(jié)果的分析;</p><p&g
12、t; 附件(所有程序的原代碼,要求對程序?qū)懗霰匾淖⑨專?lt;/p><p><b> 書寫格式</b></p><p> a.要求用A4紙打印成冊</p><p> b.正文格式:一級標(biāo)題用3號黑體,二級標(biāo)題用四號宋體加粗,正文用小四號宋體;行距為22。</p><p> c.正文的內(nèi)容:正文總字?jǐn)?shù)要求在300
13、0字左右(不含程序原代碼)。</p><p> d.封面格式如下頁。</p><p><b> 考核方式</b></p><p> 指導(dǎo)老師負(fù)責(zé)驗收程序的運行結(jié)果,并結(jié)合學(xué)生的工作態(tài)度、實際動手能力、創(chuàng)新精神和設(shè)計報告等進(jìn)行綜合考評,并按優(yōu)秀、良好、中等、及格和不及格五個等級給出每位同學(xué)的課程設(shè)計成績。具體考核標(biāo)準(zhǔn)包含以下幾個部分:<
14、;/p><p> a.平時出勤 (占10%)</p><p> b.系統(tǒng)需求分析、功能設(shè)計、數(shù)據(jù)結(jié)構(gòu)設(shè)計及程序總體結(jié)構(gòu)合理與否(占10%)</p><p> c.程序能否完整、準(zhǔn)確地運行,個人能否獨立、熟練地調(diào)試程序(占40%)</p><p> d.設(shè)計報告(占30%)</p><p> 注意:不得抄襲他人的報
15、告(或給他人抄襲),一旦發(fā)現(xiàn),成績?yōu)榱惴帧?lt;/p><p> e.獨立完成情況(占10%)。</p><p><b> 課程驗收要求</b></p><p> a.判定算法設(shè)計的合理性,運行相關(guān)程序,獲得正確的數(shù)值結(jié)果。</p><p><b> b.回答有關(guān)問題。</b></p>
16、;<p> c.提交課程設(shè)計報告。</p><p> d.提交軟盤(源程序、設(shè)計報告文檔)。</p><p> e.依內(nèi)容的創(chuàng)新程度,完善程序情況及對程序講解情況打分。</p><p><b> 2、進(jìn)度安排</b></p><p><b> 班級:</b></p>
17、;<p> 主講教師:輔導(dǎo)教師: </p><p><b> 上機時間安排:</b></p><p> 第 12 周 星期一 8時:30分——11時:30分</p><p> 星期三 8時:30分——11時:30分</p><p> 星期五 8時:30分——11時:30分</p&g
18、t;<p> 第 13 周 星期三 8時:30分——11時:30分</p><p> 星期五 8時:30分——11時:30分</p><p><b> 二、問題提出的背景</b></p><p> 人類社會進(jìn)入20世紀(jì)以來,在科學(xué)技術(shù)和生產(chǎn)力飛速發(fā)展的同時</p><p> 世界各國的人
19、口也以空前的規(guī)模增長。我們知道人口是反應(yīng)國情、國力基本情況的重要指標(biāo),例如評價一個國家或一個地區(qū)的發(fā)展?jié)摿r離不開現(xiàn)在與今后各類人口數(shù)量比例指數(shù)和年齡分布。故人口的預(yù)測是制定和順利實現(xiàn)社會經(jīng)濟各項戰(zhàn)略設(shè)想的基礎(chǔ)和出發(fā)點,制定正確人口政策的科學(xué)依據(jù)。</p><p><b> 三、問題的提出</b></p><p> 常用的用于人口預(yù)測的模型是阻滯增長模型,即Log
20、istic模型。</p><p> 該模型的微分方程為:</p><p> ?。ㄆ渲校簽楣逃性鲩L率(即人口平均增長率),表示平均人口死亡率,表示在自然資源和環(huán)境條件允許的條件下所能容納的最大人口數(shù)量,稱為人口容量。)</p><p> 利用分離變量法可以求解得:</p><p> 對該微分方程,分別用顯示歐拉法,隱式歐拉法,改進(jìn)歐拉法,
21、梯形公式,經(jīng)典龍格—庫塔法,理查德森外推法近似求解,得出估算人口;</p><p> 有限差分法求解方程:</p><p> 四、算法的理論基礎(chǔ)及其推導(dǎo)</p><p><b> 1、顯示歐拉公式:</b></p><p> 推導(dǎo):把區(qū)間[a,b]分成n等分,記分點為</p><p>&l
22、t;b> 那么由上式有:</b></p><p> 用向前差商法近似代替導(dǎo)數(shù)得:</p><p><b> 即: </b></p><p> 若用近似值代替,可得顯示歐拉公式。</p><p><b> 2、隱式歐拉公式:</b></p><p&g
23、t; 推導(dǎo):把區(qū)間[a,b]分成n等分,記分點為</p><p> 用向后差商法近似代替導(dǎo)數(shù)得:</p><p><b> 即: </b></p><p><b> 亦即:</b></p><p> 若用近似值代替,可得顯示歐拉公式。</p><p><b&
24、gt; 3、梯形公式:</b></p><p> 推導(dǎo):把區(qū)間[a,b]分成n等分,記分點為</p><p> 分別由顯示歐拉公式和隱式歐拉公式,求其平均值可得。</p><p><b> 改進(jìn)歐拉方法:</b></p><p> 推導(dǎo):把區(qū)間[a,b]分成n等分,記分點為</p>&
25、lt;p> 由顯示歐拉公式和梯形公式,可得改進(jìn)歐拉公式。</p><p> 經(jīng)典龍格—庫塔公式:</p><p> 推導(dǎo):由微分中值定理知</p><p><b> 從而得到:</b></p><p> 若簡單地取左端點處的斜率:</p><p> 作為平均斜率的近似值,則得&l
26、t;/p><p> 若用點處的斜率近似值與右端點處的斜率近似值</p><p> 的算術(shù)平均值作為斜率的近似值,則得</p><p> 由上式可知,利用兩個點上斜率近似值與的加權(quán)平均值作為平均斜率的近似值,利用歐拉公式預(yù)估,可構(gòu)造形如:</p><p> 的計算公式(稱為二階龍格—庫塔法),為確定系數(shù)與,將在處泰勒展開,并注意到,就有&l
27、t;/p><p><b> 另一方面:</b></p><p><b> 由上兩式知:</b></p><p> 利用類似的推導(dǎo)法即可求得四階龍格—庫塔法.</p><p> 理查德森外推法公式(歐拉步長自適應(yīng)法):</p><p> 推導(dǎo):從結(jié)點出發(fā),先以h為步長,經(jīng)
28、一步計算出的近似值,如果使用的是p階的方法,則:</p><p> ...............(1)</p><p> 在一般情況下,式中系數(shù)c既依賴于h,又依賴于,但當(dāng)h較小時,可近似地看作常數(shù)。</p><p> 然后將步長折半,即以為步長,仍從出發(fā),經(jīng)兩步計算求得的另一個近似值,其中每一步的截斷誤差約為,故:.............(2)</
29、p><p> 以乘以(1),并與(2)相減,得:</p><p><b> 即:</b></p><p> .....................(3)</p><p><b> 若取:</b></p><p> ..........................
30、................(4)</p><p> 作為的近似值,則其精度顯然比與都要高,這種修正的思想實際上與龍貝格數(shù)值積分法思想是一致的。</p><p> 若將(4)式改寫為:</p><p><b> 則由立即可得:</b></p><p> 由此可見,若以作為的近似值,則其誤差可用前后兩次計算結(jié)果
31、之差來表示,即可用:</p><p> 來判斷所選取色步長是否適當(dāng)。具體的做法是:</p><p> 若(由精度要求確定),則反復(fù)將步長折半進(jìn)行計算,直至,并取最后一次步長所得值作為;</p><p> 若,則反復(fù)將步長加倍進(jìn)行計算,直至,并取上一次步長所得值作為.</p><p> 有限差分法:將區(qū)間[a,b]N等分,記分點為<
32、;/p><p><b> 在內(nèi)結(jié)點 處有</b></p><p><b> 由上兩式知:</b></p><p><b> 故:</b></p><p> 當(dāng)h較小時,略去式中余項,則得確定近似值的線性方程組:</p><p> 將它稍加整理后寫成
33、矩陣形式,即:</p><p><b> 其中:</b></p><p> 方程組的,,系數(shù)矩陣為對角占優(yōu)的三對角線矩陣,可用追趕法解之。</p><p><b> 五、程序模塊</b></p><p><b> 函數(shù)模塊</b></p><p>
34、; void GJEulerMethord(double N,int a,int b,double y0,double xm,double b2,double l)</p><p><b> //改進(jìn)歐拉公式</b></p><p> void ExplicitEulerMethord(double N,int a,int b,double y0,double
35、xm,double b2,double l)</p><p><b> //顯示歐拉公式</b></p><p> void ImplicitEulerMethord(double N,int a,int b,double y0,double xm,double b2,double l)</p><p><b> //隱式歐拉公
36、式</b></p><p> void TxingMethord(double N,int a,int b,double y0,double xm,double b2,double l)</p><p><b> //梯形公式</b></p><p> void R_KMethord(double N,int a,int b,
37、double y0,double xm,double b2,double l)</p><p> //經(jīng)典龍格—庫塔公式</p><p> void JSuMethord(double N,int a,int b,double y0,double xm,double b2,double l)</p><p> //理查德森外推公式</p><
38、;p> void FiniteDifferenceMethod(double f[],double a1[],double b1[],double c[],int max)</p><p><b> //有限差分法</b></p><p><b> 模塊流程圖</b></p><p> ?。?)改進(jìn)歐拉公式:&
39、lt;/p><p><b> (2)顯示歐拉法:</b></p><p><b> ?。?)隱式歐拉法:</b></p><p><b> (4)梯形公式:</b></p><p><b> ?。?)龍格庫塔法:</b></p><p&
40、gt; (6)理查德森外推法:</p><p><b> 有限差分法</b></p><p><b> 六、實驗結(jié)果與調(diào)試</b></p><p> 選擇1,改進(jìn)歐拉法實現(xiàn);</p><p> 選擇2,顯示歐拉法實現(xiàn);</p><p> 選擇3,隱式歐拉法實現(xiàn);&
41、lt;/p><p> 選擇4,梯形公式實現(xiàn);</p><p> 選擇5,經(jīng)典龍格—庫塔法實現(xiàn);</p><p> 選擇6,理查德森外推法實現(xiàn);</p><p> 選擇7,有限差分法解方程組;</p><p><b> 七、心得體會</b></p><p> 兩周的課
42、程設(shè)計很快就結(jié)束了,回顧這兩周的課程設(shè)計,真是布滿了艱辛與坎坷。由于聶老師是一個非常細(xì)致,嚴(yán)謹(jǐn)?shù)娜?,對我們的要求也很?yán)格,這使得我備受壓力,深怕自己不能按時完成老師指定的任務(wù),但是在老師細(xì)心的指導(dǎo)下,我逐步找到了問題的突破口,不再舉手無措。</p><p> 在實驗過程中,我都是嚴(yán)格按著老師的要求,先理清問題的解題思路,然后一步一步的翻譯成計算機語言程序,上機操作,不斷調(diào)試。最初,在調(diào)試的過程中出現(xiàn)了很多的錯誤
43、,例如:語法錯誤,算法錯誤,層出不窮。但是在老師的指導(dǎo)下,經(jīng)過幾天的實踐操作后,出現(xiàn)的錯誤逐漸減少了。特別是在寫到理查德森外推法和隱式歐拉法時,花費了我很多很多的時間,我一遍一遍的翻閱教科書,在圖書館查閱相關(guān)的資料,同時不斷的征求老師的意見,與周圍的同學(xué)不斷討論,不斷的修正。最終,問題解決了</p><p> 通過這次課程設(shè)計使我懂得了理論與實際相結(jié)合是很重要的,使自己的實際動手能力和獨立思考的能力能得到很大的
44、提高。雖說困難重重,但是只要你不斷的堅持,只要你有足夠的耐心,只要你努力,勝利就一定是屬于你的。</p><p><b> 八、附件(源代碼)</b></p><p> #include<iostream></p><p> #include<stdio.h></p><p> #incl
45、ude<math.h></p><p> using namespace std;</p><p> #define esp 0.01</p><p> double q(double x)</p><p><b> {</b></p><p><b> retur
46、n 1;</b></p><p><b> }</b></p><p> double r(double x)</p><p><b> {</b></p><p><b> return x;</b></p><p><b&g
47、t; }</b></p><p> double f(double x,double y,double b2,double l) </p><p><b> {</b></p><p> return ((b2*y)-(l*y*y));</p><p><b> }</b>&l
48、t;/p><p><b> void p()</b></p><p><b> {</b></p><p> printf("以下為近十年來的人口計算情況:\n\n");</p><p><b> }</b></p><p>
49、void GJEulerMethord(double N,int a,int b,double y0,double xm,double b2,double l)//檢查正確</p><p><b> {</b></p><p><b> int k;</b></p><p> double h,x,t1,t2,y,y
50、1,m;</p><p> h=(b-a)/N;</p><p><b> x=a;</b></p><p><b> y=y0;</b></p><p><b> m=xm/y-1;</b></p><p> for(k=0;k<N;k
51、++)</p><p><b> {</b></p><p> t1=y+h*f(x,y,b2,l);</p><p><b> x=x+h;</b></p><p> y1=xm/(1+m*exp(-(b2)*x));</p><p> t2=y+h*f(x,t1
52、,b2,l);</p><p> y=(t1+t2)/2;</p><p> printf("年份:~%.0f",x);</p><p> printf("");</p><p> printf("估計人口(千萬):%f",y);</p><p>
53、 printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p><p><b> }</b></p><p><b> }</b></p><p> void ExplicitEulerMethord(do
54、uble N,int a,int b,double y0,double xm,double b2,double l)//檢查正確</p><p><b> {</b></p><p><b> int i;</b></p><p> double h,x,y,y1,m;</p><p> h
55、=(b-a)/N;</p><p><b> x=a;</b></p><p><b> y=y0;</b></p><p><b> m=xm/y-1;</b></p><p> for(i=0;i<10;i++)</p><p><
56、;b> {</b></p><p> y=y+h*f(x,y,b2,l);</p><p><b> x=x+h;</b></p><p> y1=xm/(1+m*exp(-(b2)*x));</p><p> printf("年份:~%.0f",x);</p>
57、<p> printf("");</p><p> printf("估計人口(千萬):%f",y);</p><p> printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p><p>&l
58、t;b> }</b></p><p><b> }</b></p><p> void ImplicitEulerMethord(double N,int a,int b,double y0,double xm,double b2,double l)//檢查正確</p><p><b> {</b>
59、;</p><p><b> int k,i;</b></p><p> double h,x,y[20],yy,yp,m,y1;</p><p> h=(b-a)/N;</p><p><b> y[0]=y0;</b></p><p><b> x=a
60、;</b></p><p> m=xm/y0-1;</p><p> for(i=0;i<10;i++)</p><p><b> {</b></p><p> y[i+1]=y[i]+h*f(x,y[i],b2,l);</p><p><b> k=0;&l
61、t;/b></p><p> while(k++<100005)</p><p><b> {</b></p><p> yy=y[i]+h*f(x+h,y[i+1],b2,l)-y[i+1];</p><p> yp=h*(b-2*l*y[i+1])-1;</p><p>
62、 y1=xm/(1+m*exp(-(b2)*(x+h)));</p><p> if(fabs(yp)<0.0000001)</p><p><b> {</b></p><p> printf("年份:~%.0f",x+h);</p><p> printf(""
63、);</p><p> printf("估計人口(千萬):%f",y[i+1]);</p><p> printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p><p><b> break;</b><
64、;/p><p><b> }</b></p><p> yy=y[i+1]-yy/yp;</p><p> if(fabs(yy-y[i+1])<esp)</p><p><b> {</b></p><p> printf("年份:~%.0f"
65、;,x+h);</p><p> printf("");</p><p> printf("估計人口(千萬):%f",y[i+1]);</p><p> printf("");</p><p> printf("計算人口(千萬):%f\n",y1);&
66、lt;/p><p><b> break;</b></p><p><b> }</b></p><p><b> else</b></p><p> y[i+1]=yy;</p><p><b> }</b></p&g
67、t;<p><b> x=x+h;</b></p><p><b> }</b></p><p><b> }</b></p><p> void TxingMethord(double N,int a,int b,double y0,double xm,double b2,do
68、uble l)//檢查正確</p><p><b> {</b></p><p><b> int k,i;</b></p><p> double h,x,y[20],yy,yp,m,y1,g[20];</p><p> h=(b-a)/N;</p><p><
69、;b> y[0]=y0;</b></p><p><b> x=a;</b></p><p> m=xm/y0-1;</p><p> for(i=0;i<10;i++)</p><p><b> {</b></p><p> y[i+1]
70、=y[i]+h*f(x,y[i],b2,l);</p><p><b> k=0;</b></p><p> while(k++<100)</p><p><b> {</b></p><p> yy=y[i]+h*f(x+h,y[i+1],b2,l)-y[i+1];</p>
71、;<p> yp=h*(b-2*l*y[i+1])-1;</p><p> y1=xm/(1+m*exp((-b2)*(x+h)));</p><p> if(fabs(yp)<0.0000001)</p><p><b> {</b></p><p> g[i+1]=y[i]+h/2*(f
72、(x+h,y[i],b2,l)+f(x,y[i+1],b2,l));</p><p> printf("年份:~%.0f",x+h);</p><p> printf("");</p><p> printf("估計人口(千萬):%f",g[i+1]);</p><p>
73、printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p><p><b> break;</b></p><p><b> }</b></p><p> yy=y[i+1]-yy/yp;</p&g
74、t;<p> if(fabs(yy-y[i+1])<esp)</p><p><b> {</b></p><p> g[i+1]=y[i]+h/2*(f(x+h,y[i],b2,l)+f(x,y[i+1],b2,l));</p><p> printf("年份:~%.0f",x+h);</
75、p><p> printf("");</p><p> printf("估計人口(千萬):%f",g[i+1]);</p><p> printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p>&
76、lt;p><b> break;</b></p><p><b> }</b></p><p><b> else</b></p><p> y[i+1]=yy;</p><p><b> }</b></p><p>
77、;<b> x=x+h;</b></p><p><b> }</b></p><p><b> }</b></p><p> void R_KMethord(double N,int a,int b,double y0,double xm,double b2,double l)//檢查正確&
78、lt;/p><p><b> {</b></p><p><b> int k;</b></p><p> double h,x,k1,k2,k3,k4,y,y1,m;</p><p> h=(b-a)/N;</p><p><b> x=a;</b&g
79、t;</p><p><b> y=y0;</b></p><p><b> m=xm/y-1;</b></p><p> for(k=0;k<N;k++)</p><p><b> {</b></p><p> k1=f(x,y,b2,
80、l);</p><p> k2=f(x+h/2,y+(h*k1)/2,b2,l);</p><p> k3=f(x+h/2,y+(h*k2)/2,b2,l);</p><p> k4=f(x+h,y+h*k3,b2,l);</p><p> y=y+h*(k1+2*k2+2*k3+k4)/6;</p><p>
81、<b> x=x+h;</b></p><p> y1=xm/(1+m*exp(-(b2)*x));</p><p> printf("年份:~%.0f",x);</p><p> printf("");</p><p> printf("估計人口(千萬):%
82、f",y);</p><p> printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p><p><b> }</b></p><p><b> }</b></p><p&
83、gt; void JSuMethord(double N,int a,int b,double y0,double xm,double b2,double l)//算法待定</p><p><b> {</b></p><p><b> int i,c;</b></p><p> double h,x,y[20],
84、p[20],y1,m;</p><p> h=(b-a)/N;</p><p><b> y[0]=y0;</b></p><p><b> x=a;</b></p><p> m=xm/y0-1;</p><p> for(i=0;i<10;i++)<
85、/p><p><b> {</b></p><p> h=(b-a)/N;</p><p> y[i+1]=y[i]+h*f(x,y[i],b2,l);</p><p> p[i+1]=y[i]+h/2*f(x,y[i],b2,l);</p><p> x=(i+1)*h;</p>
86、;<p> y1=xm/(1+m*exp(-(b2)*x));</p><p> printf("年份:~%.0f",x);</p><p> printf("");</p><p> if(fabs(y[i+1]-p[i+1])>=0.01)</p><p><b&
87、gt; c=1;</b></p><p><b> else</b></p><p><b> c=-1;</b></p><p><b> switch(c)</b></p><p><b> {</b></p>&l
88、t;p> case 1: while(fabs(y[i+1]-p[i+1])>=0.01)</p><p><b> {</b></p><p><b> h=h/2.0;</b></p><p> y[i+1]=y[i]+h*f(x,y[i],b2,l);</p><p>
89、p[i+1]=y[i]+h/2*f(x,y[i],b2,l);</p><p> y[i]=y[i+1];</p><p> if(fabs(y[i+1]-p[i+1])<0.01)</p><p><b> {</b></p><p> printf("估計人口(千萬):%f",y[i
90、+1]);</p><p> printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p><p><b> break;</b></p><p><b> }</b></p><p&g
91、t;<b> };break;</b></p><p> case -1: while(fabs(y[i+1]-p[i+1])<0.01)</p><p><b> {</b></p><p><b> h=h*2.0;</b></p><p> y[i+1]=
92、y[i]+h*f(x,y[i],b2,l);</p><p> p[i+1]=y[i]+h/2*f(x,y[i],b2,l);</p><p> y[i]=y[i+1];</p><p> if(fabs(y[i+1]-p[i+1])>=0.01)</p><p><b> { </b></p>
93、;<p> printf("估計人口(千萬):%f",y[i+1]);</p><p> printf("");</p><p> printf("計算人口(千萬):%f\n",y1);</p><p><b> break;</b></p>&l
94、t;p><b> }</b></p><p><b> };break;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p>
95、<p> void FiniteDifferenceMethod(double f[],double a1[],double b1[],double c[],int max)//有限差分法</p><p><b> {</b></p><p><b> int i,k;</b></p><p> doub
96、le n[10],y[10],x[10],y0,y1,h,x1,k1,k2;</p><p> cout<<"請輸入y0"<<endl;</p><p><b> cin>>y0;</b></p><p> cout<<"請輸入y1"<<e
97、ndl;</p><p><b> cin>>y1;</b></p><p> cout<<"請輸入k1"<<endl;</p><p><b> cin>>k1;</b></p><p> cout<<&quo
98、t;請輸入k2"<<endl;</p><p><b> cin>>k2;</b></p><p> cout<<"請輸入k"<<endl;</p><p><b> cin>>k;</b></p><p&g
99、t; h=(k1-k2)/k;</p><p> for(i=1;i<=max-1;i++)</p><p><b> {</b></p><p> //cout<<"請輸入c["<<i<<"]"<<endl;</p><p
100、> //cin>>c[i];</p><p> //cout<<endl;</p><p><b> c[i]=1;</b></p><p><b> }</b></p><p> for(i=1;i<=max;i++)</p><p
101、><b> {</b></p><p> //cout<<"請輸入b1["<<i<<"]"<<endl;</p><p> //cin>>b1[i];</p><p> //cout<<endl;</p>
102、<p><b> x1=h*i;</b></p><p> b1[i]=-2-q(x1)*h*h;</p><p><b> }</b></p><p> for(i=2;i<=max;i++)</p><p><b> {</b></p>
103、<p> //cout<<"請輸入a1["<<i<<"]"<<endl;</p><p> //cin>>a1[i];</p><p> //cout<<endl;</p><p><b> a1[i]=1;</b&g
104、t;</p><p><b> }</b></p><p> for(i=0;i<max;i++)</p><p><b> {</b></p><p> //cout<<"請輸入f["<<i<<"]"<
105、<endl;</p><p> //cin>>f[i];</p><p> //cout<<endl;</p><p><b> x1=h*i;</b></p><p> f[i]=r(x1)*h*h;</p><p><b> }</b&g
106、t;</p><p> f[0]=f[0]-y0;</p><p> f[max-1]=f[max-1]-y1;</p><p> n[1]=c[1]/b1[1];</p><p> for(i=2;i<=max-1;i++)</p><p><b> {</b></p>
107、;<p> n[i]=c[i]/(b1[i]-a1[i]*n[i-1]);</p><p><b> }</b></p><p> y[1]=f[0]/b1[1];</p><p> for(i=2;i<=max;i++)</p><p><b> {</b></
108、p><p> y[i]=(f[i-1]-a1[i]*y[i-1])/(b1[i]-a1[i]*n[i-1]);</p><p><b> }</b></p><p> x[max]=y[max];</p><p> printf("利用追趕法求得結(jié)果如下:\n");</p><
109、p> printf("");</p><p> printf("x[%d]=%f\n",max-1,x[max]);</p><p> for(i=max-1;i>=1;i--)</p><p><b> {</b></p><p> x[i]=y[i]-n
110、[i]*x[i+1];</p><p> printf("");</p><p> printf("x[%d]=%f\n",i-1,x[i]);</p><p><b> }</b></p><p><b> }</b></p><
111、;p> void main()</p><p><b> {</b></p><p> int a=0,b=100,N=10,max,d;</p><p> double l,b2;</p><p> doublexm;</p><p> double y0,f[9];<
112、/p><p> double c[100],a1[100],b1[100];</p><p><b> char e;</b></p><p> printf("對logistic人口預(yù)測模型運用數(shù)值方法進(jìn)行人口預(yù)測:\n\n\n");</p><p> printf("****
113、****************\n");</p><p> printf("*1:改進(jìn)歐拉法 *\n");</p><p> printf("*2:顯示歐拉法 *\n");</p><p> printf("*3:隱式歐拉法 *\n");&l
114、t;/p><p> printf("*4:梯形公式 *\n");</p><p> printf("*5:經(jīng)典龍格-庫塔法 *\n");</p><p> printf("*6:理查森外推法 *\n");</p><p> printf(&q
115、uot;*7:線性有限差分法 *\n");</p><p> printf("********************\n\n\n");</p><p><b> do</b></p><p><b> {</b></p><p> printf(
116、"請選擇進(jìn)行人口預(yù)測所使用的算法(1、2、3、4、5、6、7):\n");</p><p><b> cin>>d;</b></p><p><b> if(d==1)</b></p><p><b> { p();</b></p><p&g
117、t; printf("請輸入該國的平均人口出生率:\n");</p><p><b> cin>>b2;</b></p><p> printf("請輸入該國十年前的人口數(shù)量(千萬):\n");</p><p><b> cin>>y0;</b><
118、;/p><p> printf("請輸入該國的最大人口容載量(千萬):\n");</p><p><b> cin>>xm;</b></p><p><b> l=b2/xm;</b></p><p> GJEulerMethord(N,a,b,y0,xm,b2,
119、l);</p><p><b> }</b></p><p><b> if(d==2)</b></p><p><b> { p();</b></p><p> printf("請輸入該國的平均人口出生率:\n");</p>&l
120、t;p><b> cin>>b2;</b></p><p> printf("請輸入該國十年前的人口數(shù)量(千萬):\n");</p><p><b> cin>>y0;</b></p><p> printf("請輸入該國的最大人口容載量(千萬):\n&q
121、uot;);</p><p><b> cin>>xm;</b></p><p><b> l=b2/xm;</b></p><p> ExplicitEulerMethord(N,a,b,y0,xm,b2,l);</p><p><b> }</b><
122、;/p><p><b> if(d==3)</b></p><p><b> { p();</b></p><p> printf("請輸入該國的平均人口出生率:\n");</p><p><b> cin>>b2;</b></p&
123、gt;<p> printf("請輸入該國十年前的人口數(shù)量(千萬):\n");</p><p><b> cin>>y0;</b></p><p> printf("請輸入該國的最大人口容載量(千萬):\n");</p><p><b> cin>>
124、xm;</b></p><p><b> l=b2/xm;</b></p><p> ImplicitEulerMethord(N,a,b,y0,xm,b2,l);</p><p><b> }</b></p><p><b> if(d==4)</b>&l
125、t;/p><p><b> { p();</b></p><p> printf("請輸入該國的平均人口出生率:\n");</p><p><b> cin>>b2;</b></p><p> printf("請輸入該國十年前的人口數(shù)量(千萬):\n&
126、quot;);</p><p><b> cin>>y0;</b></p><p> printf("請輸入該國的最大人口容載量(千萬):\n");</p><p><b> cin>>xm;</b></p><p><b> l=b2/
127、xm;</b></p><p> TxingMethord(N,a,b,y0,xm,b2,l);</p><p><b> }</b></p><p><b> if(d==5)</b></p><p><b> { p();</b></p>
128、<p> printf("請輸入該國的平均人口出生率:\n");</p><p><b> cin>>b2;</b></p><p> printf("請輸入該國十年前的人口數(shù)量(千萬):\n");</p><p><b> cin>>y0;<
129、/b></p><p> printf("請輸入該國的最大人口容載量(千萬):\n");</p><p><b> cin>>xm;</b></p><p><b> l=b2/xm;</b></p><p> R_KMethord(N,a,b,y0,x
130、m,b2,l);</p><p><b> }</b></p><p><b> if(d==6)</b></p><p><b> { p();</b></p><p> printf("請輸入該國的平均人口出生率:\n");</p>
131、<p><b> cin>>b2;</b></p><p> printf("請輸入該國十年前的人口數(shù)量(千萬):\n");</p><p><b> cin>>y0;</b></p><p> printf("請輸入該國的最大人口容載量(千萬):
132、\n");</p><p><b> cin>>xm;</b></p><p><b> l=b2/xm;</b></p><p> JSuMethord(N,a,b,y0,xm,b2,l);</p><p><b> }</b></p>
133、;<p><b> if(d==7)</b></p><p><b> {</b></p><p> cout<<"請輸入結(jié)點個數(shù) max= ";</p><p><b> cin>>max;</b></p><p
134、> cout<<endl;</p><p> FiniteDifferenceMethod(f,a1,b1,c,max);</p><p><b> }</b></p><p> printf("是否繼續(xù)選擇其他算法(Y/N):\n");</p><p><b>
135、 cin>>e;</b></p><p> printf("\n");</p><p> }while(e=='y'||e=='Y');</p><p><b> }</b></p><p> 數(shù)理系課程設(shè)計評分表</p>
溫馨提示
- 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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 分?jǐn)?shù)微分方程的初值問題和邊值問題.pdf
- 幾類分?jǐn)?shù)微分方程的初值問題和邊值問題.pdf
- 非線性方程初值問題與多點邊值問題的解.pdf
- 非線性分?jǐn)?shù)階微分方程邊值問題和初值問題解的存在性
- 奇異攝動初值問題的穩(wěn)定性分析和數(shù)值分析.pdf
- 非線性分?jǐn)?shù)階微分方程邊值問題和初值問題解的存在性.pdf
- 一類高階非線性拋物型方程的初值問題和初邊值問題.pdf
- 邊界值方法解初值問題.pdf
- 模糊微分方程的初值問題.pdf
- 迭代學(xué)習(xí)控制的初值問題研究.pdf
- 一類分?jǐn)?shù)階微分方程初值問題的數(shù)值方法.pdf
- 分?jǐn)?shù)階泛函分方程的初值問題.pdf
- 求解奇異初值問題的改進(jìn)再生核方法.pdf
- 13840.時間分?jǐn)?shù)階擴散方程反初值問題
- 耦合非線性Schrodinger方程組的初值問題.pdf
- 幾類隨機Schrǒdinger方程初值問題的適定性研究.pdf
- 兩類非線性發(fā)展方程的初值問題.pdf
- 空間-時間分?jǐn)?shù)階擴散方程的反初值問題.pdf
- 幾類非線性分?jǐn)?shù)階微分方程初值問題的數(shù)值求解及動力性質(zhì).pdf
- Fujita型反應(yīng)擴散方程初值問題的幾個推廣研究.pdf
評論
0/150
提交評論