24小时热门版块排行榜    

Znn3bq.jpeg
查看: 2546  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

li52

金虫 (小有名气)

[求助] Matlab求解二阶常微分方程边值问题 已有2人参与

我用bvp4c求解了一个简单的二阶常微分方程边值问题
原方程,其中k是一个常数
边界条件
我想得到不同的k时的结果。需要从别的结果中提取k的值,数量较大,一个一个修改不太现实。
据我尝试,描述微分方程的function的参数只能是(x,y),不能再添加一个k。
怎样能整理成一个function,把k也当作参数呢?

附:k=1的时候,MATLAB计算过程

先转换成一阶微分方程组




求解过程:
1.magFun.m  描述微分方程
  function dy = magFun(x,y)
  k = 1;
  dy = zeros(2,1);
  dy(1) = y(2);
  dy(2) = -k*cos(y(1));
  end
2.magBC.m  描述边界条件
  function res = magBC( ya,yb )
  res = [ ya(1); yb(2) ];
  end
3.magSol.m  求解
  function magSol
  solinit = bvpinit(linspace(0,1,5),[1 0]);
  sol = bvp4c(@magFun,@magBC,solinit);
  x = linspace(0,1);
  y = deval(sol,x);
  plot(x,y(1,: ))

[ Last edited by li52 on 2016-10-8 at 17:10 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yz457694

铁杆木虫 (正式写手)

【答案】应助回帖

★ ★
dbb627: 金币+2, 谢谢指导 2016-10-09 08:59:54
表情干扰了。。。大致上就是把k设为了全局变量,然后加个循环,就可以自己设置k的范围来得到不同结果了
CODE:
function dy = magFun(x,y)
  global k;
  dy = zeros(2,1);
  dy(1) = y(2);
  dy(2) = -k*cos(y(1));
end
  

function res = magBC( ya,yb )
  res = [ ya(1); yb(2) ];
end
  
  function magSol
  clear,clc
  global k; %全局变量k
  yt=[];    %存储要绘图的y数据
  x = linspace(0,1,10);
  for k=1:5
  solinit = bvpinit(x,[1 0]);
  sol = bvp4c(@magFun,@magBC,solinit);
  
  y = deval(sol,x);
  yt=[yt;y(1,:)];
  end
  plot(x,yt)
  legend('1','2','3','4','5')

» 本帖已获得的红花(最新10朵)

5楼2016-10-09 07:19:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
li52: 金币+10 2016-10-09 09:37:29
可以试试用1stOpt计算。假如k范围=【1,4】,变幅0.1
CODE:
LoopConstant k=[1:0.1:4];
Variable x=[0,1],y=0,y'=[,0];
Plot x[x],y,y';
ODEFunction y''=-k*cos(y);

Matlab求解二阶常微分方程边值问题
c261.jpg


Matlab求解二阶常微分方程边值问题-1
c262.jpg

2楼2016-10-08 19:50:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

li52

金虫 (小有名气)

引用回帖:
2楼: Originally posted by dingd at 2016-10-08 19:50:27
可以试试用1stOpt计算。假如k范围=【1,4】,变幅0.1

LoopConstant k=;
Variable x=,y=0,y'=;
Plot x,y,y';
ODEFunction y''=-k*cos(y);


c261.jpg

c262.jpg
...

谢谢!
Google了下,1stOpt应该也是一种数学软件吧。但是之前的计算都是在MATLAB上进行的,再重新学习新软件,然后在软件间转换数据确实比较头疼。
3楼2016-10-08 21:21:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yz457694

铁杆木虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
li52: 金币+40, ★★★★★最佳答案 2016-10-09 09:37:09
function dy = magFun(x,y)
  global k;
  dy = zeros(2,1);
  dy(1) = y(2);
  dy(2) = -k*cos(y(1));
end
  

function res = magBC( ya,yb )
  res = [ ya(1); yb(2) ];
end
  
  function magSol
  clear,clc
  global k; %全局变量k
  yt=[];    %存储要绘图的y数据
  x = linspace(0,1,10);
  for k=1:5
  solinit = bvpinit(x,[1 0]);
  sol = bvp4c(@magFun,@magBC,solinit);
  
  y = deval(sol,x);
  yt=[yt;y(1,];
  end
  plot(x,yt)
  legend('1','2','3','4','5')
Matlab求解二阶常微分方程边值问题-2
figure.jpg

4楼2016-10-09 07:16:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 22408 312求调剂 +24 门路摸摸 2026-04-14 26/1300 2026-04-18 13:04 by wunaiy88
[考研] 求调剂 +9 小聂爱学习 2026-04-16 11/550 2026-04-17 22:34 by chixmc
[考研] 304求调剂 +7 castLight 2026-04-16 7/350 2026-04-17 20:05 by 关一盏灯cd
[考研] 322求调剂 +6 tekuzu 2026-04-17 6/300 2026-04-17 13:48 by Espannnnnol
[考研] 279求调剂 +13 张番茄不炒蛋 2026-04-11 13/650 2026-04-17 10:38 by cuisz
[考研] 294求调剂 +14 淡然654321 2026-04-15 14/700 2026-04-16 21:01 by lpl364211
[考研] 322求调剂 +8 123安康 2026-04-12 15/750 2026-04-16 11:07 by Espannnnnol
[考研] 327求调剂 +26 Xxjc1107. 2026-04-13 29/1450 2026-04-16 10:52 by Espannnnnol
[考研] 297,工科调剂? +10 河南农业大学-能 2026-04-14 10/500 2026-04-15 21:50 by noqvsozv
[考研] 通信工程求调剂!!! +6 zlb770521 2026-04-14 6/300 2026-04-15 20:00 by 学员JpLReM
[考研] 药学求调剂 +11 RussHu 2026-04-12 13/650 2026-04-15 19:07 by zhuwenxu
[考研] 310求调剂 +16 666真好 2026-04-11 18/900 2026-04-15 13:28 by 黑科技矿业
[考研] 297工科调剂? +14 河南农业大学-能 2026-04-13 15/750 2026-04-15 13:25 by 黑科技矿业
[考研] 085600材料与化工349分求调剂 +16 李木子啊哈哈 2026-04-12 17/850 2026-04-14 09:11 by fenglj492
[考研] 一志愿中南大学 0855 机械 286 求调剂 +11 不会吃肉 2026-04-12 11/550 2026-04-13 21:59 by bljnqdcc
[考研] 339求调剂 +4 hanwudada 2026-04-12 4/200 2026-04-13 12:03 by 蓝云思雨
[考研] 一志愿085802 323分求调剂 +13 drizzle_9 2026-04-12 14/700 2026-04-13 10:26 by Faiz5552
[考研] 0831一轮调剂失败求助 +10 小熊睿睿_s 2026-04-11 10/500 2026-04-12 22:43 by 长弓傲
[考研] 一志愿浙大生物325分求调剂 +9 zysheng 2026-04-12 9/450 2026-04-12 22:31 by yuyin1233
[考研] 346分,工科0854求调剂,专硕 +6 moser233 2026-04-12 7/350 2026-04-12 22:11 by fqwang
信息提示
请填处理意见