微分方程求解

1. 欧拉方法

通过计算:

  

求[a,b]上的初值问题 y'=f(t,y),y(a)=y0的近似解。

function E=euler(f,a,b,ya,M)
%Input  - f is the function entered  as a string 'f'
%       - a and b are the left and right end points
%       - ya is the initial condition y(a)
%       - M is the number of steps
%Output - E=[T' Y'] where T is the vector of abscissas and
%         Y is the vector of ordinates
h=(b-a)/M;
Y=zeros(1,M+1);
T=a:h:b;
Y(1)=ya;
for j=1:M
    Y(j+1)=Y(j+h*feval(f,T(j),Y(j)));
end
E=[T' Y'];
end

 2.四阶龙格-库塔法

计算公式为:

  

求[a,b]上的初值问题 y'=f(t,y),y(a)=y0的近似解。

function R=rk4(f,a,b,ya,M)
%Input  - f is the function entered  as a string 'f'
%       - a and b are the left and right end points
%       - ya is the initial condition y(a)
%       - M is the number of steps
%Output - R=[T' Y'] where T is the vector of abscissas and
%         Y is the vector of ordinates
%
h=(b-a)/M;
T=zeros(1,M+1);
U=zeros(4,M+1);
T=a:h:b; 
Y(1)=ya;
for j=1:M
    k1=h*feval(f,T(j),Y(j));
    k2=h*feval(f,T(j)+h/2,Y(j)+k1/2);
    k3=h*feval(f,T(j)+h/2,Y(j)+k2/2);
    k4=h*feval(f,T(j)+h,Y(j)+k3);
    Y(j+1)=Y(j)+(k1+2*k2+2*k3+k4)/6;
end
R=[T' Y'];
end

 

转载于:https://www.cnblogs.com/guojun-junguo/p/10139104.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值