matlab欧拉法求解微分方程
MATLAB改进欧拉法与四阶龙格-库塔求解一阶常微分方程

姓名:樊元君学号:02 日期:一、实验目的掌握MATLAB语言、C/C++语言编写计算程序的方法、掌握改进欧拉法与四阶龙格-库塔求解一阶常微分方程的初值问题。
掌握使用MATLAB程序求解常微分方程问题的方法。
:二、实验内容1、分别写出改进欧拉法与四阶龙格-库塔求解的算法,编写程序上机调试出结果,要求所编程序适用于任何一阶常微分方程的数值解问题,即能解决这一类问题,而不是某一个问题。
实验中以下列数据验证程序的正确性。
求,步长h=。
*2、实验注意事项的精确解为,通过调整步长,观察结果的精度的变化^)三、程序流程图:●改进欧拉格式流程图:~|●四阶龙格库塔流程图:]四、源程序:●改进后欧拉格式程序源代码:function [] = GJOL(h,x0,y0,X,Y)format longh=input('h=');…x0=input('x0=');y0=input('y0=');disp('输入的范围是:');X=input('X=');Y=input('Y=');n=round((Y-X)/h);\i=1;x1=0;yp=0;yc=0;for i=1:1:nx1=x0+h;yp=y0+h*(-x0*(y0)^2);%yp=y0+h*(y0-2*x0/y0);%·yc=y0+h*(-x1*(yp)^2);%yc=y0+h*(yp-2*x1/yp);%y1=(yp+yc)/2;x0=x1;y0=y1;y=2/(1+x0^2);%y=sqrt(1+2*x0);%fprintf('结果=%.3f,%.8f,%.8f\n',x1,y1,y);:endend●四阶龙格库塔程序源代码:function [] = LGKT(h,x0,y0,X,Y)。
format longh=input('h=');x0=input('x0=');y0=input('y0=');disp('输入的范围是:');"X=input('X=');Y=input('Y=');n=round((Y-X)/h);i=1;x1=0;k1=0;k2=0;k3=0;k4=0;for i=1:1:n~x1=x0+h;k1=-x0*y0^2;%k1=y0-2*x0/y0;%k2=(-(x0+h/2)*(y0+h/2*k1)^2);%k2=(y0+h/2*k1)-2*(x0+h/2)/(y0+h/2*k1);% k3=(-(x0+h/2)*(y0+h/2*k2)^2);%k3=(y0+h/2*k2)-2*(x0+h/2)/(y0+h/2*k2);% k4=(-(x1)*(y0+h*k3)^2);%k4=(y0+h*k3)-2*(x1)/(y0+h*k3);%…y1=y0+h/6*(k1+2*k2+2*k3+k4);%y1=y0+h/6*(k1+2*k2+2*k3+k4);%x0=x1;y0=y1;y=2/(1+x0^2);%y=sqrt(1+2*x0);%fprintf('结果=%.3f,%.7f,%.7f\n',x1,y1,y);end·end*五、运行结果:改进欧拉格式结果:;}四阶龙格库塔结果:步长分别为:和时,不同结果显示验证了步长减少,对于精度的提高起到很大作用,有效数字位数明显增加。
Matlab求解微分方程

4、求解微分方程:2'xy yy=-,()01y=,h=0.2,区间为[0,1];%建立微分方程函数;function yd=f(x,y)if nargin==2yd=y-2*x/y;endend%欧拉方法程序;%x0为给定的初值x,y0为给定的初值y;%n为需要计算的次数;%h为步长;%f(x)为建立的微分方程函数;function [x,y]=oula(x0,y0,n,h)x0=input('Please enter the value of x0:'); y0=input('Please enter the value of y0:'); n=input('Please enter the value of n:'); h=input('Please enter the value of h:'); y=[y0];x=[x0];for k=1:1:ny1=y0+h*(y0-2*x0/y0);y(k+1)=y1;y0=y1;x0=x0+h;x(k+1)=x0;endend此题中,h=0.2,区间为[0,1],所以n=5,程序运行结果为x= 0 0.2000 0.4000 0.6000 0.8000 1.0000y= 1.0000 1.2000 1.3733 1.5315 1.6811 1.8269%欧拉改进方法程序;%x0为给定的初值x,y0为给定的初值y;%n为需要计算的次数;%h为步长;%f(x)为建立的微分方程函数;function [x,y]=oulagai(x0,y0,n,h)x0=input('Please enter the value of x0:');y0=input('Please enter the value of y0:');n=input('Please enter the value of n:');h=input('Please enter the value of h:');y=[y0];x=[x0];for k=1:1:nyp=y0+h*f(x0,y0);yc=y0+h*f(x0+h,yp);y1=(yp+yc)/2;y(k+1)=y1;y0=y1;x(k+1)=x0+h;x0=x0+h;endend程序运行结果x= 0 0.2000 0.4000 0.6000 0.8000 1.0000 y=1.0000 1.1867 1.3483 1.4937 1.6279 1.7542 若改变微分方程,需将原方程函数改变。
欧拉法求解一阶微分方程matlab

为了更好地理解欧拉法求解一阶微分方程在Matlab中的应用,我们首先来了解一些背景知识。
一阶微分方程是指只含有一阶导数的方程,通常表示为dy/dx=f(x,y),其中f(x,y)是关于x和y的函数。
欧拉法是一种常见的数值解法,用于求解微分方程的近似数值解。
它是一种基本的显式数值积分方法,通过将微分方程转化为差分方程来进行逼近。
在Matlab中,我们可以利用欧拉法求解一阶微分方程。
我们需要定义微分方程的函数表达式,然后选择合适的步长和初始条件,最后使用循环计算逼近解。
下面我们来具体讨论如何在Matlab中使用欧拉法来求解一阶微分方程。
我们假设要求解的微分方程为dy/dx=-2x+y,初始条件为y(0)=1。
我们可以通过以下步骤来实现:1. 我们需要在Matlab中定义微分方程的函数表达式。
在Matlab中,我们可以使用function关键字来定义函数。
在这个例子中,我们可以定义一个名为diff_eqn的函数,表示微分方程的右侧表达式。
在Matlab中,这个函数可以定义为:```matlabfunction dydx = diff_eqn(x, y)dydx = -2*x + y;end```2. 我们需要选择合适的步长和初始条件。
在欧拉法中,步长的选择对于数值解的精度非常重要。
通常情况下,可以先尝试较小的步长,然后根据需要进行调整。
在这个例子中,我们可以选择步长h=0.1,并设置初始条件x0=0,y0=1。
3. 接下来,我们可以使用循环来逼近微分方程的数值解。
在每一步,根据欧拉法的迭代公式y(i+1) = y(i) + h * f(x(i), y(i)),我们可以按照下面的Matlab代码计算逼近解:```matlabh = 0.1; % 步长x = 0:h:2; % 定义计算区间y = zeros(1, length(x)); % 初始化y的值y(1) = 1; % 设置初始条件for i = 1:(length(x)-1) % 欧拉法迭代y(i+1) = y(i) + h * diff_eqn(x(i), y(i));end```通过上述步骤,在Matlab中就可以用欧拉法求解一阶微分方程。
MATLAB常微分方程数值解——欧拉法、改进的欧拉法与四阶龙格库塔方法

MATLAB常微分⽅程数值解——欧拉法、改进的欧拉法与四阶龙格库塔⽅法MATLAB常微分⽅程数值解作者:凯鲁嘎吉 - 博客园1.⼀阶常微分⽅程初值问题2.欧拉法3.改进的欧拉法4.四阶龙格库塔⽅法5.例题⽤欧拉法,改进的欧拉法及4阶经典Runge-Kutta⽅法在不同步长下计算初值问题。
步长分别为0.2,0.4,1.0.matlab程序:function z=f(x,y)z=-y*(1+x*y);function R_K(h)%欧拉法y=1;fprintf('欧拉法:x=%f, y=%f\n',0,1);for i=1:1/hx=(i-1)*h;K=f(x,y);y=y+h*K;fprintf('欧拉法:x=%f, y=%f\n',x+h,y);endfprintf('\n');%改进的欧拉法y=1;fprintf('改进的欧拉法:x=%f, y=%f\n',0,1);for i=1:1/hx=(i-1)*h;K1=f(x,y);K2=f(x+h,y+h*K1);y=y+(h/2)*(K1+K2);fprintf('改进的欧拉法:x=%f, y=%f\n',x+h,y);endfprintf('\n');%龙格库塔⽅法y=1;fprintf('龙格库塔法:x=%f, y=%f\n',0,1);for i=1:1/hx=(i-1)*h;K1=f(x,y);K2=f(x+h/2,y+(h/2)*K1);K3=f(x+h/2,y+(h/2)*K2);K4=f(x+h,y+h*K3);y=y+(h/6)*(K1+2*K2+2*K3+K4);fprintf('龙格库塔法:x=%f, y=%f\n',x+h,y);end结果:>> R_K(0.2)欧拉法:x=0.000000, y=1.000000欧拉法:x=0.200000, y=0.800000欧拉法:x=0.400000, y=0.614400欧拉法:x=0.600000, y=0.461321欧拉法:x=0.800000, y=0.343519欧拉法:x=1.000000, y=0.255934改进的欧拉法:x=0.000000, y=1.000000改进的欧拉法:x=0.200000, y=0.807200改进的欧拉法:x=0.400000, y=0.636118改进的欧拉法:x=0.600000, y=0.495044改进的欧拉法:x=0.800000, y=0.383419改进的欧拉法:x=1.000000, y=0.296974龙格库塔法:x=0.000000, y=1.000000龙格库塔法:x=0.200000, y=0.804636龙格库塔法:x=0.400000, y=0.631465龙格库塔法:x=0.600000, y=0.489198龙格库塔法:x=0.800000, y=0.377225龙格库塔法:x=1.000000, y=0.291009>> R_K(0.4)欧拉法:x=0.000000, y=1.000000欧拉法:x=0.400000, y=0.600000欧拉法:x=0.800000, y=0.302400改进的欧拉法:x=0.000000, y=1.000000改进的欧拉法:x=0.400000, y=0.651200改进的欧拉法:x=0.800000, y=0.405782龙格库塔法:x=0.000000, y=1.000000龙格库塔法:x=0.400000, y=0.631625龙格库塔法:x=0.800000, y=0.377556>> R_K(1)欧拉法:x=0.000000, y=1.000000欧拉法:x=1.000000, y=0.000000改进的欧拉法:x=0.000000, y=1.000000改进的欧拉法:x=1.000000, y=0.500000龙格库塔法:x=0.000000, y=1.000000龙格库塔法:x=1.000000, y=0.303395注意:在步长h为0.4时,要将for i=1:1/h改为for i=1:0.8/h。
微分方程数值解之欧拉法在MATLAB下的应用

科教论坛 !"#!$%&$'(') *+&,-./&$01$21(3$&)%)$$%%(3
微分方程数值解之欧拉法在 J7<97F下的应用
梁春叶4王桥明4孙远通4叶晓艳4曾宝莹
玉林师范学院数学与统计学院!广西玉林!(#+$$$
摘4要微分方程在实际应用中十分广泛涉及领域众多但对于微分方程的数值解的计算仍然有很大挑战 本文着重 对微分方程数值解求解的常用的一类基础方法欧拉法进行在 EH#[HC的应用下的一个简单介绍
求出$ 以下为在 50;"0)中实现!
F8/F68& 6'
+'
Copyright©博看网 . All Rights Reserved.
科教论坛
%I&Fh(J>>& 8'hh63t3i8326% KG&( h+ 8&$'hh( 27, % 8h(FG*H%& %I&F#KG&(' 由此得该方程的精确解为!
科技风 "#"$ 年 % 月
8hFJ/E*J>8& 8' 由此得解析解为!8h67 i63 N6N$' $
)% $) $) )% 使用欧拉法求解#如下! A h%3$% >hu& 6#8' 63t(i63t)% 6h+$!A!$%, % -hFJ9%& 6#)' i$% 8$ h+) 27#9%$GF&$#-' , % >G$& h$!8$& &N$'h8$& &' NA!>& 6& &' #8$& &' ' % %&( 8h63t732)%i63t332$)N632$)N$' 2)%% E*G7& 6#8#pGBp#6#8$#pN@p' *%L%&(& p,6?K7p#p,+*%$p' 运行程序可输出结果为!
matlab heun法

matlab heun法Heun法是一种数值求解常微分方程的方法,也称为改进的欧拉法或者梯形法。
它是一种显式的Runge-Kutta方法,用于求解一阶常微分方程初值问题。
在MATLAB中,可以使用Heun法来数值求解常微分方程。
Heun法的基本思想是通过使用梯形法来估计下一个时间步长的值。
首先,利用当前的状态估计下一个时间步长的斜率,然后利用这个斜率来计算下一个时间步长的值。
具体来说,Heun法的迭代步骤如下:1. 根据当前的状态计算出当前的斜率。
2. 利用当前的斜率来估计下一个时间步长的状态。
3. 根据下一个时间步长的状态计算出下一个时间步长的斜率。
4. 利用下一个时间步长的斜率来计算出真正的下一个时间步长的状态。
在MATLAB中,可以使用ode45函数来实现Heun法。
该函数可以接受一个指定的微分方程函数和初始条件,并返回在指定时间范围内的数值解。
具体来说,可以使用MATLAB代码类似于下面这样来实现Heun法:matlab.function dydt = myODE(t, y)。
dydt = % 指定的微分方程。
end.tspan = % 时间范围。
y0 = % 初始条件。
[t, y] = ode45(@myODE, tspan, y0);在这个例子中,myODE函数是指定的微分方程函数,tspan是时间范围,y0是初始条件。
通过调用ode45函数,可以得到在指定时间范围内的数值解。
总之,Heun法是一种常用的数值求解常微分方程的方法,在MATLAB中可以使用ode45函数来实现。
通过合理选择微分方程函数和初始条件,可以得到准确的数值解。
用MATLAB求解微分方程

1. 微分方程的解析解
求微分方程(组)的解析解命令:
dsolve(‘方程1’, ‘方程2’,…‘方程n’, ‘初始条件’, ‘自变量’)
结 果:u = tan(t-c)
解 输入命令:dsolve('Du=1+u^2','t')
STEP2
STEP1
解 输入命令: y=dsolve('D2y+4*Dy+29*y=0','y(0)=0,Dy(0)=15','x')
导弹追踪问题
设位于坐标原点的甲舰向位于x轴上点A(1, 0)处的乙舰发射导弹,导弹头始终对准乙舰.如果乙舰以最大的速度v0(是常数)沿平行于y轴的直线行驶,导弹的速度是5v0,求导弹运行的曲线方程.又乙舰行驶多远时,导弹将它击中? 解法一(解析法)
由(1),(2)消去t整理得模型:
解法二(数值解)
结 果 为:x = (c1-c2+c3+c2e -3t-c3e-3t)e2t y = -c1e-4t+c2e-4t+c2e-3t-c3e-3t+c1-c2+c3)e2t z = (-c1e-4t+c2e-4t+c1-c2+c3)e2t
2、取t0=0,tf=12,输入命令: [T,Y]=ode45('rigid',[0 12],[0 1 1]); plot(T,Y(:,1),'-',T,Y(:,2),'*',T,Y(:,3),'+')
3、结果如图
图中,y1的图形为实线,y2的图形为“*”线,y3的图形为“+”线.
MATLAB Euler法解常微分方程

Euler 法解常微分方程Euler 法解常微分方程算法:Step 1 分别取积分上限、积分下限、步长Step 2计算h n n +=判断b n ≤是否成立,成立转到Step 3,否则继续进行Step 4 Step 3 计算),(1n n n n y x hf y y +=+Step 4 ),(1n n n n y x hf y y +=+Euler 法解常微分方程算程序:function euler2(fun,y0,A,h)%fun--y'%y0---初值%A----x 取值范围%a----x 左区间端点值%b----x 右区间端点值%h----给定步长x=min(A);b=max(A);y=y0;while x<b-hb=y;y=y+h*feval(fun,x,b)x=x+h;end例:用Euler 法计算下列初值问题(取步长h=0.2))6.00(1)0('2≤≤⎩⎨⎧=--=x y xy y y输入:fun=inline('-y-x*y^2')euler2(fun,1,[0 0.6],0.2)得到:y =0.8000y =0.6144y =0.4613指导教师: 年 月 日改进Euelr 法解常微分方程改进Euler 法解常微分方程算法:Step 1 分别取积分上限、积分下限、步长Step 2 取一个以h 为步长,a ,b 分别为左右端点的矩阵Step 3 (1)做显性Euler 预测),(1n n i i y x hf y y +=+(2)将1+i y 带入)],(),([2h 111+++++=i i i i i i y x f y x f y y Step 4计算h n n +=判断b n ≤是否成立,成立返回Step 3,否则继续进行Step 5 Step 5 )],(),([2h 111+++++=i i i i i i y x f y x f y y 改进Euler 法解常微分方程算程序:function gaijineuler2(fun,y0,A,h)%fun--y'%y0---初值%A----x 取值范围%a----x 左区间端点值%b----x 右区间端点值%h----给定步长a=min(A);b=max(A);x=a:h:b;y(1)=y0;for i=1:length(x)-1w1=feval(fun,x(i),y(i));y(i+1)=y(i)+h*w1;w2=feval(fun,x(i+1),y(i+1));y(i+1)=y(i)+h*(w1+w2)/2;endx=x'y=y'例:用改进Euler 法计算下列初值问题(取步长h=0.25) )50(2)0('2≤≤⎩⎨⎧=-=x y xy y 输入:fun=inline('-x*y^2')gaijineuler2(fun,2,[0 5],0.25)得到:x =0.25000.50000.75001.00001.25001.50001.75002.00002.25002.50002.75003.00003.25003.50003.75004.00004.25004.50004.75005.0000y =2.00001.87501.59391.28241.00960.79320.62820.50370.40970.33790.28240.23890.20430.17650.15380.13520.11960.10660.09550.08610.0779指导教师:年月日。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
matlab欧拉法求解微分方程
Matlab是一款用于科学计算、数据处理和可视化的工具软件,它不仅可以处理数字、符号运算,还可以用于各种重要的数学应用。
欧拉法是最简单的数值解微分方程的方法之一,它可以在Matlab中进行实现。
欧拉法的实现过程如下:
1. 设定初始条件。
对于一个一阶微分方程$y' = f(t,y)$,需要给出初值$y(t_0) =y_0$和一定的步长$h$,即$t_n = t_0 + nh$。
其中,$n$为正整数。
可以将$t_n$与$y_n$一起存放到两个向量$t$和$y$中。
2. 设定迭代方程。
使用泰勒公式将$y(t + h)$展开,得到$y(t+h) =
y(t)+hy'(t)+\frac{h^2}{2}y''(t)+O(h^3)$,由于这是一个微分方程的一阶泰勒公式,$y''$一般很难求得,可以将其忽略得到:$y(t + h) \approx y(t) + hf(t,y(t))$
从而,欧拉法的迭代方程就得到了。
可以在Matlab中用一行代码来实现:
y(n+1) = y(n) + h*f(t(n),y(n));
其中,$t(n)$和$y(n)$表示当前时刻$t$和对应的$y$值,而
$f(t(n),y(n))$表示在$t(n)$和$y(n)$处方程的斜率。
3. 进行迭代计算。
根据上述迭代方程循环进行计算即可。
以下是一个示例程序:
t0 = 0;
y0 = 1;
h = 0.1; % 步长
tf = 1; % 计算到1s
N = round(tf/h)+1; % 总步数
t = linspace(t0,tf,N); % 时间向量
y = zeros(size(t)); % 初始值向量
y(1) = y0;
for n = 1:N-1
y(n+1) = y(n) + h*func(t(n),y(n));
end
plot(t,y) % 绘制y-t图像
其中,func为微分方程的右端函数。
欧拉法的优点是简单易行,可以提供一个初步接触微分方程解法
的方法。
它的缺点是精度较低,误差会随着步长的增大而增加。
因此,在高精度的数值计算中,需要使用其他更为复杂的方法,如四阶龙格
库塔法等。
总之,Matlab欧拉法求解微分方程是一种简单而实用的方法,可以应用于各种科学和工程领域的数值计算。
在实际应用中,需要根据
实际情况选择不同的数值解法以及适当的步长。