查看单个帖子
旧 2008-12-11, 21:17   #1
幻紫风
初级会员
 
注册日期: 2008-12-11
年龄: 35
帖子: 3
声望力: 0
幻紫风 正向着好的方向发展
默认 [求助]还有一个。。

用变形的Euler方法、二阶Heun方法解初值问题
y'=-y+t+1 ,0<=t<=1,y(0)=1;
并Matlab实现。

源代码:
变形的Euler法的MATlAB实现:
function[x,y]=Euler2(dyfun,xspan,y0,h)
x=xspan(1):h:xspan(2);
y(1)=y0;
for n=1:length(x)-1
K1=feval(dyfun,x(n),y(n));
K2=feval(dyfun,x(n)+h/2,y(n)+h*K1/2);
y(n+1)=y(n)+h*K2;
end
format long
x=x';y=y';
幻紫风 当前离线   回复时引用此帖