MATLAB 用四阶龙格库塔解微分方程组
上面的微分方程组,ABCDEF均为已知量,求y1和y2分别随t的变化曲线t的取值从0到1步长0.1。求程序代码或者思路。用四阶龙格库塔方法。y1初值0.000001y2初...
上面的微分方程组,ABCDEF均为已知量,求y1和y2分别随t的变化曲线 t的取值从0到1 步长0.1 。求程序代码或者思路。用四阶龙格库塔方法。
y1初值0.000001 y2初值1000000 展开
y1初值0.000001 y2初值1000000 展开
- 你的回答被采纳后将获得:
- 系统奖励15(财富值+成长值)+难题奖励10(财富值+成长值)+提问者悬赏100(财富值+成长值)
展开全部
可以用ode45求解。
需定义mass函数,用以计算质量矩阵,即化为下述形式求解:
M(t,y) * dy/dt = f(t,y)。
请给出ABCDEF的具体值。
需定义mass函数,用以计算质量矩阵,即化为下述形式求解:
M(t,y) * dy/dt = f(t,y)。
请给出ABCDEF的具体值。
追问
参数值还没确定。我只是想知道方法 参数值就随便设一下吧
追答
其实方法我上面已经说过了。
参考代码:
function zd1959859560446863460
% 常数定义
[A,B,C,D,E,F] = deal(1,2,3,4,5,6);
% 微分方程求解
opt = odeset('Mass',@mass);
y0 = [0.000001; 1000000];
[t,y] = ode45(@ode,0:0.1:1,y0,opt);
% 结果绘图
subplot 211
plot(t,y(:,1))
subplot 212
plot(t,y(:,2))
function f = ode(t,y)
y1 = y(1);
y2 = y(2);
f = [y1^3*(y2-D/y1); (y2-E)*y1/(y2*y1^3-F)];
end
function M = mass(t,y)
y1 = y(1);
y2 = y(2);
M = [ ...
A/y1 - y1^2*(y2-B/y1) - (y1^3+C)/y1^2, -y1^3; ...
1/y1, 1];
end
end
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
东莞大凡
2024-11-14 广告
2024-11-14 广告
标定板认准大凡光学科技,专业生产研发厂家,专业从事光学影像测量仪,光学投影测量仪.光学三维测量仪,光学二维测量仪,光学二维测量仪,光学三维测量仪,光学二维测量仪.的研发生产销售。东莞市大凡光学科技有限公司创立于 2018 年,公司总部坐落于...
点击进入详情页
本回答由东莞大凡提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询