數學建模第三次作業_第1頁
數學建模第三次作業_第2頁
數學建模第三次作業_第3頁
數學建模第三次作業_第4頁
數學建模第三次作業_第5頁
已閱讀5頁,還剩6頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、 院 系: 數學學院 專 業: 信息與計算科學 年 級: 2014級 學生姓名: 王繼禹 學 號: 201401050335 教師姓名: 徐霞 6.6 習題3.一個慢跑者在平面上沿著他喜歡的路徑跑步,突然一只狗攻擊他,這只狗以恒定速率跑向慢跑者,狗的運動方向始終指向慢跑者,計算并畫出狗的軌跡。解:(1)模型分析建立:狗的軌跡:在任意時刻,狗的速度向量都指向它的目標慢跑者。假設1:慢跑者在某路徑上跑步,他的運動由兩個函數X(t)和Y(t)描述。假設2:當t=0時,狗是在點(x0,y0)處,在時刻t時,它的位置是(x(t),y(t)那么下列方程成立:(1)狗以恒定速率跑: X2+y2=w2(2)

2、狗的速度向量平行于慢跑者與狗的位置的差向量:將上述方程帶入等式:,可得:再將代入第二個方程,可得狗的軌跡的微分方程:(2)程序及結果dog函數dog.mfunction zs,isterminal,direction = dog(t,z,flag) global w;% w=speed of the dog X=jogger(t);h = X-z;nh=norm(h); if nargin<3 | isempty(flag) zs=(w/nh)*h; else switch(flag) case 'events' zs = nh-1e-3; isterminal = 1;

3、 direction = 0; otherwise error('Unknow flag:' flag); endend慢跑者的運動軌跡方程,水平向右jogger.mfunction s = jogger(t);s = 8*t;0;標記的函數cross.mfunction cross(Cx,Cy,v) Kx = Cx Cx Cx Cx-v Cx+v; Ky = Cy Cy+2.5*v Cy+1.5*v Cy+1.5*v Cy+1.5*v plot(Kx,Ky); plot(Cx,Cy,'o');主程序:靜態顯示main1.mglobal w y0 = 60;70

4、; w=10; options = odeset('RelTol',1e-5,'Events','on');t,Y = ode23('dog',0,20,y0,options);clf;hold on;axis(-10,100,-10,70);plot(Y(:,1),Y(:,2);J=; for h=1:length(t), w = jogger(t(h); J=J;w' endplot(J(:,1),J(:,2),':');p = max(size(Y); cross(Y(p,1),Y(p,2),2)ho

5、ld off;動態顯示main2.mglobal w;y0=60;70;w=10; options = odeset('RelTol',1e-5,'Events','on');t,Y=ode23('dog',0,20,y0,options); J=; for h=1:length(t); w= jogger(t(h); J=J;w'endxmin = min(min(Y(:,1),min(J(:,1); xmax = max(max(Y(:,1),max(J(:,1); ymin = min(min(Y(:,2),min(

6、J(:,2);ymax = max(max(Y(:,2),max(J(:,2);clf;hold on; axis(xmin-10 xmax ymin-10 ymax);title('The jogger and the Dog'); for h = 1:length(t)-1, plot(Y(h,1),Y(h+1,1),Y(h,2),Y(h+1,2),'-','Color','red','EraseMode','none'); plot(J(h,1),J(h+1,1),J(h,2),J(h+1,2

7、),'-','Color','green','EraseMode','none'); drawnow; pause(0.1);endplot(J(:,1),J(:,2),':'); p = max(size(Y); cross(Y(p,1),Y(p,2),2)hold off;結果t=12.2761812635281,在12.27秒后狗追上慢跑者。慢跑者軌跡是橢圓軌跡jogger2.mfunction s=jogger2(t) s=10+20*cos(t) 20+15*sin(t);狗的微分方程do

8、g.mfunction zs,isterminal,direction = dog(t,z,flag) global w;% w=speed of the dogX=jogger2(t);h = X-z; nh=norm(h); if nargin<3 | isempty(flag) zs=(w/nh)*h; else switch(flag) case 'events' zs = nh-1e-3; isterminal = 1; direction = 0; otherwise error('Unknow flag:' flag); endend 主程序

9、main3.mglobal w;y0=60;70;w=10; options = odeset('RelTol',1e-5,'Events','on');t,Y=ode23('dog',0,20,y0,options); J=; for h=1:length(t); w= jogger2(t(h); J=J;w'endxmin = min(min(Y(:,1),min(J(:,1); xmax = max(max(Y(:,1),max(J(:,1); ymin = min(min(Y(:,2),min(J(:,2);yma

10、x = max(max(Y(:,2),max(J(:,2);clf;hold on; axis(xmin-10 xmax ymin-10 ymax);title('The jogger and the Dog'); for h = 1:length(t)-1, plot(Y(h,1),Y(h+1,1),Y(h,2),Y(h+1,2),'-','Color','red','EraseMode','none'); plot(J(h,1),J(h+1,1),J(h,2),J(h+1,2),'-&#

11、39;,'Color','green','EraseMode','none'); drawnow; pause(0.1);endplot(J(:,1),J(:,2),':'); p = max(size(Y); cross(Y(p,1),Y(p,2),2)hold off;結果取w=25有,經過4秒左右狗追上慢跑者。 8.平面上有n(n>=2)個圓,任何兩個圓都相交但無3個圓共點。試問n個圓把平面劃分成多少個不連通的區域?解:一個圓將平面分為2份兩個圓相交將平面分為4=2+2份,三個圓相交將平面分為8=2+2

12、+4份,四個圓相交將平面分為14=2+2+4+6份,平面內n個圓,其中每兩個圓都相交于兩點,且任意三個圓不相交于同一點,則該n個圓分平面區域數f(n)=2+(n-1)n=n2-n+2證明:(1)當n=1時,一個圓把平面分成兩個區域,而12-1+2=2,命題成立(2)假設n=k(k1)時,命題成立,即k個圓把平面分成k2-k+2個區域當n=k+1時,第k+1個圓與原有的k個圓有2k個交點,這些交點把第k+1個圓分成了2k段弧,而其中的每一段弧都把它所在的區域分成了兩部分,因此增加了2k個區域,共有k2-k+2+2k=(k+1)2-(k+1)+2個區域n=k+1時,命題也成立由(1)、(2)知,對

13、任意的nN*,命題都成立9.某人有元錢,他每天買一次物品,每次買物品的品種很單調,或者買一元錢的甲物品,或者買二元錢的乙物品,問他花完這元錢有多少不同的方式?解:設an表示花完這n元錢的方案種數,若n=1,則只能買甲,有一種方法,故a1=1,若n=2,則可以買2個甲,或者1個乙或1個丙,即a2=3,當n3時,花錢的方式由購買甲和購買乙購買丙的種數之和構成,即an=an-1+an-2+an-2=an-1+2an-2則當n3時,an+an-1=2(an-1+an-2),即an+1+an是公比q=2的等比數列,首項為a2+a1=1+3=4,則an+1+an=42n-1=2n+1,an+an-1=2n

14、,兩式相減得an+1-an-1=2n+1-2=2,(n2),若n是奇數,an=2n-1+2n-3+22+a1=(2n+1-1)/3若n是偶數,an=2n-1+2n-3+23+a2=(2n+1+1)/37.6 習題1.在化工生產中常常需要知道丙烷在各種溫度和壓力下的導熱系數。下面是實驗得到的一組數據:/68688787106106140140/KPa9.798113.3249.007813.3559.791814.2779.656312.463K0.08480.08970.07620.08070.06960.07530.06110.0651 試求=99和=10.3xKPa下的K。解:找出溫度T相

15、等時,導熱系數K與壓力P的關系。由于在不同溫度時,僅給出兩個K、P的值,因此采用線性近似,把K、P看作是線性關系。建立M文件:function y=y_lagr1(x0,y0,x)n=length(x0);m=length(x);for i=1:m z=x(i); s=0.0; for k=1:n p=1.0; for j=1:n if j=k p=p*(z-x0(j)/(x0(k)-x0(j); end end s=p*y0(k)+s; end y(i)=s;end主程序:p1=9.7981,13.324; k1=0.0848,0.0897; %T=68p2=9.0078,13.355; k

16、2=0.0762,0.0807; %T=87p3=9.7918,14.277; k3=0.0696,0.0753; %T=106p4=9.6563,12.463; k4=0.0611,0.0651; %T=140a2=polyfit(p2,k2,1); a3=polyfit(p3,k3,1);x1=polyval(a2,10.3); x2=polyval(a3,10.3); %x1,x2分別是P=10.3*103kPa下87和106的K值plot(10.3,x1,'k+',10.3,x2,'k+',p1,k1,p2,k2,p3,k3,p4,k4)xlabel(&

17、#39;丙烷壓力P')ylabel('丙烷導熱系數K')title('在不同溫度下丙烷導熱系數與壓力的關系圖')gtext('T=68'),gtext('T=87'),gtext('T=106'),gtext('T=140')運行后圖中所標點為P=10.3*103kPa時,T=87和T=106對應的導熱系數K值。在T=87和T=106之間仍采用線性近似來求T=99時的導熱系數K。程序如下: x=87,106;y=x1,x2;a=polyfit(x,y,1);z=polyval(a,99)z=0.0729plot(99,z,'k+',x,y)gridxlabel('丙烷溫度T')ylabel('丙烷導熱系數K')title('壓力P=10.3*103kPa時丙烷導熱系數與溫度的關系')運行結果: T=99、P=10.3*103KPa時 K=0.0729。4.用電壓V=10伏的電池給電容器充電,電容器上t時刻的電壓為v(t)=V-(V-V0),其中v0是電容器的初始電壓,是充電常數。試由下面一組t,v數據確定V0和。t/s0.51234579V/伏6.366.487.2

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論