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*五、运行结果:改进欧拉格式结果:;}四阶龙格库塔结果:步长分别为:和时,不同结果显示验证了步长减少,对于精度的提高起到很大作用,有效数字位数明显增加。
欧拉法(euler)求解常微分方程的matlab程序及案例

欧拉法(euler)求解常微分方程的matlab程序及案例欧拉方法是最初用于求解常微分方程的数值方法之一,它是一种显式的一步法,具有易于实施的优点,特别适合初学者使用。
本文将介绍欧拉法的原理和使用MATLAB求解常微分方程的具体方法,同时给出一个简单的实例进行说明。
一、欧拉法原理考虑一个一阶常微分方程y'=f(t,y),欧拉法的基本思想是将时间步长Δt均分成n个小步长,从y(t0)开始依次计算每个时刻的值,得到一列估计值y1, y2, …, yn。
欧拉法的计算公式为:(1)y1=y(t0+Δt)=y(t0)+Δtf(t0, y0)(2)y2=y(t0+2Δt)=y(t0+Δt)+Δtf(t0+Δt, y1)(3)yn=y(t0+nΔt)=y(t0+(n-1)Δt)+Δtf(t0+(n-1)Δt, yn-1)可以看出,欧拉法的核心在于利用已知的t和y计算f(t,y),从而获得y的逼近值。
但是需要注意的是,步长Δt越小,计算所需的时间和内存就越多,而精度却并不一定提高。
因此在实际应用中需要结合具体问题选择合适的步长。
二、MATLAB求解常微分方程的具体方法(1)定义常微分方程我们以一个简单的例子开始,考虑求解y'=1-y,y(0)=0.5在[0,1]区间内的积分。
首先定义匿名函数dydt,将其传到ode45中求解:dydt=@(t,y)1-y;[t,y]=ode45(dydt,[0 1],0.5);plot(t,y,'-o')运行以上代码可以得到结果,其中plot函数用于绘制图像。
但是,由于求解过程中计算机执行到ode45函数时可能需要很长时间,因此需要更快捷的方法。
(2)利用欧拉法求解方程欧拉法求解方程首先需要定义步长Δt,这里设Δt为0.1。
定义起始值y=[0.5]、时间向量t=0:Δt:1,然后计算列向量y的估计值:t=0:0.1:1;y=zeros(size(t));y(1)=0.5;for n=1:length(t)-1y(n+1)=y(n)+0.1*(1-y(n));endplot(t,y,'-o')以上代码的执行结果与前面的ode45方法相同,但是速度更快。
欧拉法matlab一阶常微分方程

欧拉法(matlab)一阶常微分方程一、概述微分方程是描述自然界中许多现象的数学模型,它在物理、化学、生物等领域有着广泛的应用。
而欧拉法是求解微分方程的一种数值计算方法,通过利用微分方程的切线近似曲线上的点,来逼近微分方程的解。
在matlab中,欧拉法是求解微分方程的常用方法之一。
本文将介绍欧拉法在matlab中求解一阶常微分方程的具体步骤和实现过程。
二、欧拉法的原理欧拉法是一种基本的数值方法,用于求解形如y' = f(x, y)的一阶常微分方程初值问题。
其基本思想是将微分方程转化为差分方程,通过逐步逼近微分方程的解。
具体步骤如下:1. 确定初值条件,即确定微分方程的初始值(x0, y0)2. 根据微分方程y' = f(x, y)计算斜率f(x, y) = dy/dx3. 根据斜率计算下一个点的坐标,即y1 = y0 + h*f(x0, y0),其中h 为步长4. 更新坐标,即(x0, y0) = (x0+h, y1)5. 重复上述步骤直至达到所需的精度或特定的终止条件通过以上步骤,可以得到微分方程的近似解。
在matlab中,可以利用欧拉法求解一阶常微分方程,具体步骤如下。
三、欧拉法在matlab中的实现1. 编写求解函数我们需要编写一个求解一阶常微分方程的函数。
这个函数的输入参数包括微分方程的函数表达式、初始值、步长和终止条件等。
函数的基本框架如下:```matlabfunction [x, y] = euler_method(f, x0, y0, h, x_end)x = x0:h:x_end; 生成x的序列y = zeros(size(x)); 初始化y的序列y(1) = y0; 设置初始值for i = 2:length(x)y(i) = y(i-1) + h*f(x(i-1), y(i-1)); 根据欧拉法更新y值endend```在上述函数中,f表示微分方程的函数表达式,x0和y0表示初始值,h表示步长,x_end表示终止条件。
matlab欧拉法解常微分方程

matlab欧拉法解常微分方程matlab欧拉法解常微分方程欧拉法是解决微分方程数值计算的一种基本方法,是通过估算函数图像的变化来得到函数的近似值。
而matlab是一种强大的数值计算软件,也能轻易地实现欧拉法解常微分方程的计算。
步骤一:选择解题模型选择合适的数学模型很重要。
对于已经给定的微分方程,需要将它化为标准的形式。
例如,我们有如下的微分方程:y’ = 2y - 3,y(0) = 1将其化为标准的形式:dy/dx = 2y -3 将初始值y(0) = 1带入。
步骤二:确定计算步长确定计算步长h。
步长的大小与计算精度有直接关系,步长太小,计算量将很大,而精度较高;步长太大,精度较低。
步长的计算公式为:h = (b-a)/n其中,a和b是区间限制,n是初始步数。
步骤三:使用欧拉法求解微分方程根据欧拉法的公式,假设在t时刻函数y的值是y(t),求在下一个时刻t+h如何估算y值,公式为:y(t+h) = y(t)+ h * y'(t)将y'(t)=2y-3代入上式,得:y(t+h) = y(t)+ h* (2y(t)-3)接下来,根据初始值y(0) = 1,带入计算步长可得出一系列的近似值。
步骤四:绘制函数图像对于计算结果,应绘制出函数的近似图像。
通过matlab绘制y(x)的图像,也可以通过计算的数据进行近似曲线的绘制。
步骤五:测试计算结果通过计算结果与初始值进行比较,看算法是否正确和有效。
也可以将步长不同的计算结果进行比较,判断精度和计算效率的高低。
欧拉法解常微分方程在matlab中的使用,相较于手工计算,更具有高效、准确、方便的优势。
正因如此,在各类数学、物理、工程等领域中都有着广泛的应用。
欧拉法解常微分方程

数学与计算科学学院实验报告实验项目名称Eular方法求解一阶常微分方程数值解所属课程名称偏微分方程数值解实验类型验证性实验日期 2015-3-26班级学号姓名成绩一、实验概述:【实验目的】熟练掌握应用显性Eular法和隐式Eular法求解一般一阶常微分方程的近似数值解。
【实验原理】虽然求解常微分方程有各种各样的解析方法,但解析方法只能用来求解一些特殊类型的方程。
求解从实际问题当中归结出来的微分方程主要靠数值解法。
欧拉方法是一类重要的数值解法。
这类方法回避解y(x)的函数表达式,而是寻求它在一系列离散节点上的近似值,相邻的两个节点的间距称作步长。
假定步长为定数。
欧拉方法是一类离散化方法,这类方法将寻求解y(x)的分析问题转化为计算离散值值的代数问题,从而使问题获得了实质性的简化。
然而随之带来的困难是,由于数据量往往很大,差分方法所归结出的可能是个大规模的代数方程组。
【实验环境】1.硬件环境2.2.软件环境MATLAB7.0二、实验内容:【实验结论】A步长h=0.001时进行数据测试。
结果如下:迭代第一次时,结果与方程描述内容相符。
迭代第二次时,结果与方程描述内容基本相符。
迭代三次时,结果与方程描述内容基本相符。
迭代1000次时,模拟结果已经严重脱离事实,故当选择delta为0.001时,该迭代方法不收敛。
时间与个变量直接的变化关系如图所示:从上述图形可以明显看出,在迭代的不断进行时,各变量与时间的变化越来越大,且严重脱离了方程所描述的现实意义。
B.当选择h=0.00000001时,模拟结果如下:迭代第一次,与A中结果相同。
迭代第二次,跌二次迭代结果明显优于一中。
跌三次迭代结果,并未产生误差。
地1000次迭代结果,结果明显是收敛的。
时间与个变量直接的变化关系如图所示:从图中能够清晰看出,当h=0.00000001时,模拟结果与方程所表示的显示意义相吻合。
说明了显性Eualr方法的收敛性是与步长的选择是相关。
matlab欧拉法求解微分方程例题

matlab欧拉法求解微分方程例题当使用Matlab的欧拉法(Euler's method)求解微分方程时,需要将微分方程转化为离散的差分方程。
下面以一个简单的一阶常微分方程为例来说明。
假设我们要求解以下的微分方程:dy/dx = x + y并给定初始条件 y(0) = 1。
我们可以使用欧拉法来逼近该微分方程的解。
在Matlab中,可以按照以下步骤进行求解:1. 定义步长和计算步数:h = 0.1; % 步长 N = 10; % 计算步数2. 初始化变量并给定初始条件:x = zeros(N+1, 1); % 初始化 x 数组 y = zeros(N+1, 1); % 初始化 y 数组 x(1) = 0; % 初始条件 x(0) = 0 y(1) = 1; % 初始条件 y(0) = 13. 使用欧拉法进行迭代计算:for i = 1:N x(i+1) = x(i) + h; % 计算下一个 x 值 y(i+1) = y(i) + h * (x(i) + y(i)); % 根据差分方程计算下一个 y 值end4. 绘制结果:plot(x, y, 'o-'); % 绘制连线图 xlabel('x'); ylabel('y'); title('Approximate Solution using Euler''s Method');完整的代码如下:h = 0.1; % 步长 N = 10; % 计算步数 x = zeros(N+1, 1); % 初始化 x 数组 y = zeros(N+1, 1); % 初始化 y 数组 x(1) = 0; % 初始条件 x(0) = 0 y(1) = 1; % 初始条件 y(0) = 1 for i = 1:N x(i+1) = x(i) + h; % 计算下一个 x 值y(i+1) = y(i) + h * (x(i) + y(i)); % 根据差分方程计算下一个 y 值 end plot(x, y, 'o-'); % 绘制连线图xlabel('x'); ylabel('y'); title('Approximate Solution using Euler''s Method');运行该代码,将得到近似的解曲线图,表示微分方程的数值解。
matlab_常微分方程数值解法

dt 2
简朴问题可以求得解析解,多数实际问题靠数值求解 。
第4页
一阶常微分方程(ODE )初值问题 : ODE :Ordinary Differential Equation
dy
f
(x,
y)
dx
x0 x xn
y(x0 ) y0
数值解法就是求y(x)在某些分立旳节点 xn 上旳近似值 yn,用以近似y(xn)
x0
y0
x1 f y(x), x dx
x0
x2 f y(x), x dx
x1
y(x1) f y(x1), x1 h
第17页
同样,在[x0,xn+1] ,积分采用矩形近似,得:
y(xn1) y0
f xn1
x0
y(x), x dx
y(xn ) f y(xn ), xn h
yn y(xn )
第5页
2、欧拉近似办法
2.1 简朴欧拉(L.Euler, 1707-1783)办法。
dy
dx
f
(y, x)
y(x0 ) y0
欧拉数值算法就是由初值通过递推求解,递推求解
就是从初值开始,后一种函数值由前一种函数值得到。核 心是构造递推公式。
y0 y1 y2 yn
第6页
i 1,2,...
第36页
没有一种算法可以有效地解决所有旳 ODE 问题,因此 MATLAB 提供了多种ODE函数。
函数 ODE类
特点
阐明
型
ode45
非刚性 单步法;4,5 阶 R-K 措施;合计 大部分场合旳首选措施
截断误差为 (△x)3
ode23
非刚性 单步法;2,3 阶 R-K 措施;合计 使用于精度较低旳情形
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。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
matlab用欧拉法求解常微分方程
在数学和科学领域中,常微分方程是一种非常有用的工具,用于描述许多自然和物理现象。
MATLAB是一种强大的数学软件,可以用来解决许多数学问题。
本文将介绍如何使用欧拉法在MATLAB中求解常微分方程。
欧拉法是一种基本的数值方法,用于近似解决微积分方程问题。
该方法使用离散时间步长,将微积分方程转换成差分方程,并不断迭代求解。
欧拉法的实现非常简单,因此它很适合初学者。
下面是使用欧拉法在MATLAB中求解常微分方程的步骤:
1. 定义常微分方程
以 y' = -0.5y + 3sin(t) 为例,我们先定义常微分方程。
在MATLAB中,可以使用 anonymous functions 实现:
dydt = @(t,y) -0.5*y + 3*sin(t);
2. 定义时间范围和时间步长
我们需要定义时间范围和时间步长,以便在一定时间范围内求解差分方程。
在这个例子中,我们定义时间范围为 0 到 10,并定义时间步长为 0.1:
tspan = [0 10];
h = 0.1;
3. 定义初始条件
我们需要定义初始条件,即 y(0) 的值。
在这个例子中,我们假设 y(0) = 1:
y0 = 1;
4. 求解差分方程
现在我们可以使用欧拉法求解差分方程了。
在MATLAB中,可以使用 odeEuler 函数(需要自己编写):
[t,y] = odeEuler(dydt,tspan,y0,h);
5. 可视化结果
最后,我们可以将结果可视化,以便更好地理解求解过程。
在这个例子中,我们可以用 plot 函数将求解结果绘制出来:
plot(t,y)
xlabel('Time')
ylabel('y(t)')
title('Solution of y'' = -0.5y + 3sin(t) using Euler''s method')
以上就是使用欧拉法在MATLAB中求解常微分方程的基本步骤。
当然,对于复杂的微积分方程,需要使用更高级的数值方法,否则得到的近似解可能不够准确。
但是,欧拉法是所有数值方法的基础,因此理解这个方法对于更深入地理解微积分方程是非常有帮助的。
总之,MATLAB是一个非常有用的数学工具,可以用来解决各种数学问题。
使用欧拉法求解常微分方程只是其中的一个例子,但通过这个例子,我们可以学习到很多有用的数值方法和MATLAB的使用技巧。