- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第六章 微分方程问题的解法;6.1 微分方程的解析解方法;例:
syms t; u=exp(-5*t)*cos(2*t+1)+5;
uu=5*diff(u,t,2)+4*diff(u,t)+2*u
uu =
87*exp(-5*t)*cos(2*t+1)+92*exp(-5*t)*sin(2*t+1)+10
syms t y;
y=dsolve([D4y+10*D3y+35*D2y+50*Dy+24*y=,...
87*exp(-5*t)*cos(2*t+1)+92*exp(-5*t)*sin(2*t+1)+10]);
y=dsolve([D4y+10*D3y+35*D2y+50*Dy+24*y=,...
87*exp(-5*t)*cos(2*t+1)+92*exp(-5*t)*sin(2*t+1) ... +10], y(0)=3, Dy(0)=2, D2y(0)=0, D3y(0)=0);分别处理系数,如:
[n,d]=rat(double(vpa(-445/26*cos(1)-51/13*sin(1)-69/2)))]
ans =
-8704 185 % rat()最接近有理数的分数
判断误差:
vpa(-445/26*cos(sym(1))-51/13*sin(1)-69/2+8704/185)
ans =
.114731975864790922564144636e-4;
y=dsolve([D4y+10*D3y+35*D2y+50*Dy+24*y=,...
87*exp(-5*t)*cos(2*t+1)+92*exp(-5*t)*sin(2*t+1) + ... 10],y(0)=1/2,Dy(pi)=1,D2y(2*pi)=0,Dy(2*pi)=1/5);
如果用推导的方法求Ci的值,每个系数的解析解至少要写出10数行,故可采用有理式近似 的方式表示.
vpa(y,10) %有理近似值
ans =
1.196361839*exp(-5.*t)+.4166666667-.4785447354*sin(t)*cos(t)*exp(-5.*t)-.4519262218e-1*cos(2.*t)*exp(-5.*t)-2.392723677*cos(t)^2*exp(-5.*t)+.2259631109*sin(2.*t)*exp(-5.*t)-473690.0893*exp(-3.*t)+31319.63786*exp(-2.*t)-219.1293619*exp(-1.*t)+442590.9059*exp(-4.*t) ;例:求解
[x,y]=dsolve(D2x+2*Dx=x+2*y-exp(-t), … Dy=4*x+3*y+4*exp(-t));例:
syms t x
x=dsolve(Dx=x*(1-x^2))
x =
[ 1/(1+exp(-2*t)*C1)^(1/2)]
[ -1/(1+exp(-2*t)*C1)^(1/2)]
syms t x; x=dsolve(Dx=x*(1-x^2)+1)
Warning: Explicit solution could not be found; implicit solution returned.
In D:\MATLAB6p5\toolbox\symbolic\dsolve.m at line 292
x =
t-Int(1/(a-a^3+1),a=``..x)+C1=0
故只有部分非线性微分方程有解析解。;6.2 微分方程问题的数值解法6.2.1 微分方程问题算法概述;微分方程求解的误差与步长问题:;;;6.2.2 四阶定步长Runge-Kutta算法 及 MATLAB 实现; function [tout,yout]=rk_4(odefile,tspan,y0) %y0初值列向量
t0=tspan(1); th=tspan(2);
if length(tspan)=3, h=tspan(3); % tspan=[t0,th,h]
else, h=tspan(2)-tspan(1); th=tspan(end); end %等间距数组 tout=[t0:h:th]; yout=[];
for t=tout
k1=h*eval([odefile ‘(t,y0)’]); % odefile是一个字符串变量,为表示微分方程f( )的文件名。
k2=h*eval([odefile (t+h/2,y0+0.5*k1)]);
您可能关注的文档
最近下载
- 【地理】河流与湖泊 课件-2025-2026学年地理人教版(2024)八年级上册.pptx VIP
- 2.1《职场应用写作与交流(一)求职和应聘》优秀获奖课件.pptx VIP
- 高中历史教学中人工智能协作学习评价与反馈体系构建教学研究课题报告.docx
- 电力系统微机继电保护教学课件电子教案全套课件.pptx VIP
- 2022年船载危险货物申报员和集装箱检查员从业资格考核全国统考试题.pdf VIP
- 石油小知识.ppt VIP
- 托福词汇词以类记-张红岩(完整有目录).pdf VIP
- 中考英语篇完型填空练习(附答案).pdf VIP
- 水浒传-林冲(共47张课件).pptx VIP
- 乡村医生考试题库及答案完整版.doc VIP
文档评论(0)