用Matlab解微分方程
- 格式:doc
- 大小:50.50 KB
- 文档页数:2
matlab解常微分方程组摘要:一、引言1.常微分方程组简介2.Matlab 在解常微分方程组中的应用二、Matlab 解常微分方程组的基本步骤1.安装并配置Matlab2.准备常微分方程组模型3.使用Matlab 求解器求解方程组4.分析解的结果三、Matlab 解常微分方程组的常用命令1.初始化常微分方程组2.定义方程组3.使用ode45 等求解器解方程组4.输出结果四、Matlab 解常微分方程组的实际应用1.物理模型中的应用2.工程领域中的应用3.生物学和经济学模型中的应用五、结论1.Matlab 在解常微分方程组方面的优势2.需要注意的问题和技巧3.展望Matlab 在常微分方程组求解领域的发展前景正文:一、引言常微分方程组在自然科学、工程技术和社会科学等领域中有着广泛的应用。
随着科技的发展,Matlab 作为一种功能强大的数学软件,已经成为常微分方程组求解的重要工具。
本文将介绍Matlab 解常微分方程组的基本方法、常用命令以及实际应用。
二、Matlab 解常微分方程组的基本步骤1.安装并配置Matlab:首先需要在计算机上安装Matlab 软件。
安装完成后,需要对Matlab 进行配置,以便更好地使用相关功能。
2.准备常微分方程组模型:根据实际问题,建立相应的常微分方程组模型。
这包括确定变量、方程和边界条件等。
3.使用Matlab 求解器求解方程组:Matlab 提供了丰富的求解器,如ode45、ode23、ode113 等。
根据问题特点选择合适的求解器,调用相关函数求解常微分方程组。
4.分析解的结果:求解完成后,需要对结果进行分析,检查其合理性和准确性。
可以使用Matlab 内置的图形功能绘制解的图像,直观地了解解的变化规律。
三、Matlab 解常微分方程组的常用命令1.初始化常微分方程组:使用`pdsolve`函数可以求解常微分方程组。
首先需要定义微分方程和边界条件,然后调用`pdsolve`函数求解。
一、概述Matlab是一款功能强大的数学软件,它可以对微分方程组进行求解并得到精确的数值解。
微分方程组是描述自然现象的数学模型,经常出现在物理、化学、生物等领域的科学研究中。
掌握如何使用Matlab 对微分方程组进行求解是非常重要的。
二、微分方程组求解基本原理微分方程组是由多个未知函数及其导数的方程组成。
通常情况下,微分方程组很难直接求解,需要借助数值方法进行近似求解。
Matlab 提供了丰富的工具和函数来解决微分方程组求解的问题,其中最常用的是ode45函数。
三、Matlab微分方程组求解代码示例以下是一个简单的二阶微分方程组的求解代码示例:```function dydt = myODE(t, y)dydt = zeros(2,1);dydt(1) = y(2);dydt(2) = -y(1) - 0.1*y(2);end[t, y] = ode45(myODE, [0 20], [1 0]);plot(t, y(:,1))```在这个示例中,我们首先定义了一个函数myODE来描述微分方程组的右端。
然后使用ode45函数对微分方程组进行求解,得到了微分方程组的数值解,并利用plot函数进行了可视化展示。
四、常见问题及解决方法在使用Matlab进行微分方程组求解时,可能会遇到一些常见问题,以下是一些常见问题及解决方法:1. 参数设置错误:在使用ode45函数时,需要正确设置求解的时间范围和初始条件,否则可能得到错误的结果。
可以通过仔细阅读ode45函数的文档来解决这个问题。
2. 数值稳定性:对于一些复杂的微分方程组,数值求解可能会遇到数值稳定性问题,导致结果不准确。
可以尝试调整ode45函数的参数或者使用其他数值解法来提高数值稳定性。
五、总结通过本文的介绍,我们了解了在Matlab中如何对微分方程组进行求解。
Matlab提供了丰富的工具和函数来解决微分方程组求解的问题,有效提高了微分方程组求解的效率和精度。
第三章 微积分的数学实验3.1极限与一元微积分3.1.1 初等运算1.定义单个或多个符号变量:syms x y z t ;定义单个符号变量或者符号函数还可以用单引号定义,如x=’x ’,f=’sin(x^2)+2*x-1’。
符号表达式的反函数运算g=finverse(f),g 是返回函数f 的反函数。
例1 求sin(1)y x =-的反函数>>syms x>>y=sin(x-1); g=finverse(y),结果为 g=1+asin(t)2. f actor(f) 因式分解函数f3.Collect(f) 对函数f 合并同类项4. expand(f) 将函数f 表达式展开5. simple(f) 找出表达式的最简短形式(有时需要用2次)6. roots (p )对多项式p 求根函数。
7. solve(F) 一般方程的求根函数例2 解方程2510x x +-=解 >>syms x>>solve(x^2+5*x-1)结果为x =[ -5/2+1/2*29^(1/2) -5/2-1/2*29^(1/2)]8.fzero(f,x0)或fzero(f,[a,b]) 在初始点x0处开始或在区间[a,b]上搜索函数的零点,f(a)与f(b)需要符号相反。
3.1.2 Matlab计算函数的极限函数形式:1)limit(F,x,a),求函数F在 x ->a时的极限。
2)limit(F,a),默认其中的变量为极限变量.3)limit (F),默认其中的变量为极限变量且趋向于0.4)limit(F,x,a,'right')或limit(F,x,a,’left') 求函数F在x->a时的右、左极限.例3 >>syms x a t h; %syms作用是申明x,a,t,h是符号变量,不需先赋值再调用。
>>limit(sin(x)/x) %结果为 1>>limit((x-2)/(x^2-4),2) %结果为 1/4>>limit((1+2*t/x)^(3*x),x,inf) %结果为 exp(6*t)>>limit(1/x,x,0,'right') %结果为 inf>>limit(1/x,x,0,'left') %结果为 -inf>>limit((sin(x+h)-sin(x))/h,h,0) %结果为 cos(x)>>v = [(1 + a/x)^x, exp(-x)];limit(v,x,inf,'left') %结果为[exp(a),0]3.1.3 Matlab计算导数与微分1.一元导数和微分diff函数用以计算函数的微分和导数,相关的函数语法有下列4个:diff(f) 返回f对预设独立变量的一次导数值diff(f,'t')或diff(f,t) 返回f对独立变量t的一次导数(值)diff(f,n) 返回f对预设独立变量的n阶导数(值)diff(f,'t',n) 或diff(f,t,n)返回f对独立变量t的n阶导数(值)这里尽管自变量已经作为符号变量,可以不用syms说明,但是在具体执行diff(f)、diff(f,'t')和diff(f,t)会出现差异,有的能够执行,有的不能够,有的执行符号微分,有的执行数值微分,所以比较麻烦。
一、介绍MATLAB是一种广泛用于数学建模和工程仿真的高级技术计算语言和交互式环境。
在MATLAB中,我们可以使用各种工具箱来求解微分方程,包括一阶微分方程。
一阶微分方程是微积分的一个重要分支,其解决了变量之间的关系,具有广泛的实际应用。
在本文中,我们将探讨MATLAB如何解一阶微分方程。
二、一阶微分方程的形式一阶微分方程的一般形式如下:dy/dx = f(x, y)其中,y是未知函数,x是自变量,f(x, y)是已知函数。
通过这个方程,我们可以得到y关于x的函数表达式。
三、MATLAB中的一阶微分方程求解在MATLAB中,一阶微分方程的求解可以通过ODE函数来实现。
ODE函数是MATLAB中专门用于求解常微分方程组的函数,可以处理多种类型的一阶微分方程。
四、一阶微分方程的数值解1. 我们需要定义微分方程的右端函数。
在MATLAB中,我们可以使用函数句柄来定义微分方程的右端函数。
假设我们要解下面的一阶微分方程:dy/dx = x + y我们可以用以下代码定义右端函数:function f = myode(x, y)f = x + y;end其中,myode是函数名,x和y分别是自变量和未知函数。
2. 我们可以使用ODE函数求解微分方程。
在MATLAB中,可以使用ODE函数来求解一阶微分方程。
其语法如下:[t, y] = ode45(myode, tspan, y0)其中,myode是右端函数的函数句柄,tspan是自变量的取值范围,y0是未知函数的初始值。
3. 我们可以绘制微分方程的解曲线。
在得到微分方程的数值解之后,我们可以使用plot函数来绘制解曲线。
可以使用以下代码来绘制dy/dx = x + y的解曲线:plot(t, y)五、一阶微分方程的符号解除了数值解之外,我们还可以使用MATLAB求得一阶微分方程的符号解。
MATLAB中的符号计算工具箱可以帮助我们求解一阶微分方程的符号解。
可以使用dsolve函数来求解一阶微分方程的符号解:syms x yeqn = 'Dy = x + y';sol = dsolve(eqn)MATLAB的符号计算工具箱还可以帮助我们进行微分方程的求解验证和简化。
matlab微分方程谱方法MATLAB是一个功能强大的数学软件,拥有多种求解微分方程的方法,其中谱方法是非常重要的一种。
谱方法是一种基于傅里叶级数的解微分方程的方法,它通过将函数表示为傅里叶级数的形式,利用傅里叶级数的性质,能够高效地求解微分方程。
谱方法的主要思想是利用傅里叶级数展开函数,然后根据微分方程求解出每个傅里叶系数的关系式,最后再利用傅里叶反变换得到函数的解。
谱方法的优点是数值精度高,收敛速度快,适用于各种类型的微分方程,但是在实际应用中,由于计算量较大,需谨慎选择计算参数。
在MATLAB中,使用谱方法求解微分方程的步骤如下:1. 将函数表示为傅里叶级数的形式,即将函数按照正交基函数的形式展开;2. 根据微分方程求解出每个傅里叶系数的关系式,这要涉及到微分方程的离散化;3. 利用傅里叶反变换得到函数的解;4. 对解进行检验,确定计算参数的正确性。
MATLAB中提供了许多谱方法的函数,如chebfun、dct、fft等,这些函数可大大减少编写代码的难度。
下面以使用chebfun求解微分方程为例,演示MATLAB中使用谱方法求解微分方程的步骤。
步骤1:构造函数我们考虑求解下列微分方程:u'' - u = x, 0 < x < pi该微分方程的边界条件为:u(0) = 0, u(pi) = 0首先,我们将函数表示为傅里叶级数的形式,即:u(x) = sum(a_n * cos(n * x) + b_n * sin(n * x))其中,a_n和b_n是待求解的系数。
引入微分算子Df = chebfun(@(x)diff(f(x)),[a b]),可以将微分方程转化为常微分方程组的形式:D2u - u = x, u(0) = 0, u(pi) = 0步骤2:求解系数我们利用微分方程的离散化求解出a_n和b_n的关系式。
假设N表示求和中的上限,则:a_n = (2/N)*sum(f(x)*cos(n*x))b_n = (2/N)*sum(f(x)*sin(n*x))利用MATLAB中的chebfun方法,我们可以轻易地实现以上公式。
MATLAB求微分方程组的解析解引言在科学与工程领域,微分方程组是一种常见的数学模型,用于描述各种物理现象和工程问题。
解析解是指能够用公式表达出来的精确解。
本文将介绍如何使用M ATL A B求解微分方程组的解析解。
1.方程组的建立首先,我们需要确定待求解的微分方程组。
假设我们有一个由n个微分方程组成的方程组,可以写为如下形式:d y1/dt=f1(t,y1,y2,...,yn)d y2/dt=f2(t,y1,y2,...,yn)......d y n/dt=f n(t,y1,y2,...,yn)其中`t`是自变量,`y1,y2,...,y n`是因变量,`f1,f2,...,fn`是给定的函数关系。
我们的目标是求解`y1(t),y2(t),...,yn(t)`的解析解。
2.使用MAT LAB求解M A TL AB提供了强大的求解微分方程组的工具,我们可以使用其中的函数来求解上述方程组的解析解。
首先,我们需要在MA T LA B中定义方程组的函数形式。
可以通过定义一个函数或者使用匿名函数来实现。
例如,我们可以定义一个名为`m yE qu at io ns`的函数,其输入参数为`t`和一个向量`y`,输出为一个向量`d y`,代表方程组的左侧和右侧的变量分别。
函数示例如下:f u nc ti on dy=m yE qua t io ns(t,y)%定义方程组d y=z er os(n,1);d y(1)=f1(t,y(1),y(2),...,y(n));d y(2)=f2(t,y(1),y(2),...,y(n));......d y(n)=fn(t,y(1),y(2),...,y(n));e n d然后,我们可以使用M AT LA B的`d so lv e`函数来求解微分方程组的解析解。
示例如下:s y ms ty1(t)y2(t)...yn(t)a s su me(t,'re al')a s su me(y1(t),'rea l')a s su me(y2(t),'rea l')......a s su me(y n(t),'rea l')e q n1=d if f(y1(t),t)==f1(t,y1(t),y2(t),...,y n(t));e q n2=d if f(y2(t),t)==f2(t,y1(t),y2(t),...,y n(t));......e q nn=d if f(yn(t),t)==fn(t,y1(t),y2(t),...,y n(t));e q ns=[eq n1,e qn2,...,eq nn];S=ds ol ve(e qn s);`S`即为方程组的解析解集合。
一、引言1.1 MATLAB在微分方程组求解中的应用MATLAB作为一种强大的数学工具,被广泛应用于微分方程组的求解与模拟分析。
1.2 本文的研究目的和意义本文旨在探讨MATLAB在求解微分方程组方面的应用方法,帮助读者更好地理解和运用MATLAB进行微分方程组的解法,从而提高数学建模和工程仿真的效率与精度。
二、微分方程组的基本概念2.1 微分方程组的定义微分方程组是由多个未知函数及其偏导数构成的方程组。
常见的微分方程组可以分为线性微分方程组与非线性微分方程组。
2.2 微分方程组的求解方法求解微分方程组的方法包括解析解法、数值解法和符号解法。
而MATLAB在微分方程数值解法中具有独特的优势。
三、MATLAB在微分方程组求解中的基本操作3.1 MATLAB中微分方程组的表示在MATLAB中,微分方程组可以使用符号表达式或者函数形式表示,便于进行数值求解和仿真分析。
3.2 MATLAB中微分方程组的数值求解利用MATLAB中的ode45、ode23等求解微分方程组的函数,可以快速地求得微分方程组的数值解,并且可以灵活地控制求解的精度和速度。
3.3 MATLAB中微分方程组的图像绘制MATLAB提供了丰富的绘图函数,能够直观地展现微分方程组的数值解,帮助用户更直观地理解微分方程组的解法结果。
四、 MATLAB在微分方程组求解中的应用实例4.1 简单的线性微分方程组求解通过一个简单的线性微分方程组的求解实例,展示MATLAB在微分方程组求解中的基本操作和方法。
4.2 复杂的非线性微分方程组求解通过一个包含非线性项的微分方程组求解实例,展示MATLAB在处理复杂微分方程组时的应用能力。
五、MATLAB在微分方程组求解中的进阶应用5.1 高阶微分方程组的数值求解MATLAB可以利用符号运算工具箱对高阶微分方程组进行符号求解,也可以通过数值求解的方式得到高阶微分方程组的数值解。
5.2 特定约束条件下的微分方程组求解MATLAB可以通过引入特定的约束条件,对微分方程组进行求解,满足实际应用中的各种约束条件。
matlab龙格库塔法解微分方程组
一、引言
龙格库塔法是数值计算中常用的一种求解微分方程的方法,其具有较高的精度和稳定性。
在MATLAB中,可以使用ode45函数来实现龙格库塔法求解微分方程组。
二、龙格库塔法简介
龙格库塔法是一种常用的数值积分方法,也可用于求解微分方程。
该方法将微分方程转化为一个初值问题,并采用逐步逼近的方式计算出数值解。
三、使用ode45函数求解微分方程组
在MATLAB中,可以使用ode45函数来求解微分方程组。
该函数使用了龙格库塔法进行数值计算,并提供了较高的精度和稳定性。
四、MATLAB代码实现
以下是一个使用ode45函数求解微分方程组的示例代码:
function dydt = myfun(t,y)
dydt = zeros(2,1);
dydt(1) = y(2);
dydt(2) = -sin(y(1));
end
[t,y] = ode45(@myfun,[0 10],[0;1]);
plot(t,y(:,1),'-o',t,y(:,2),'-o')
xlabel('Time')
ylabel('Solution')
legend('y_1','y_2')
五、总结
龙格库塔法是一种常用的数值计算方法,可以用于求解微分方程。
在MATLAB中,可以使用ode45函数来实现龙格库塔法求解微分方程组。
通过以上示例代码,我们可以看到MATLAB提供了较为简单的方式来实现龙格库塔法求解微分方程组,并且具有较高的精度和稳定性。
Matlab 差分法解偏微分方程1.引言解偏微分方程是数学和工程领域中的一项重要课题,它在科学研究和工程实践中具有广泛的应用。
而 Matlab 差分法是一种常用的数值方法,用于求解偏微分方程。
本文将介绍 Matlab 差分法在解偏微分方程中的应用,包括原理、步骤和实例。
2. Matlab 差分法原理差分法是一种离散化求解微分方程的方法,通过近似替代微分项来求解微分方程的数值解。
在 Matlab 中,差分法可以通过有限差分法或者差分格式来实现。
有限差分法将微分方程中的导数用有限差分替代,而差分格式指的是使用不同的差分格式来近似微分方程中的各个项,通常包括前向差分、后向差分和中心差分等。
3. Matlab 差分法步骤使用 Matlab 差分法解偏微分方程一般包括以下步骤:(1)建立离散化的区域:将求解区域离散化为网格点或节点,并确定网格间距。
(2)建立离散化的时间步长:对于时间相关的偏微分方程,需要建立离散化的时间步长。
(3)建立离散化的微分方程:使用差分法将偏微分方程中的微分项转化为离散形式。
(4)建立迭代方程:根据离散化的微分方程建立迭代方程,求解数值解。
(5)编写 Matlab 代码:根据建立的迭代方程编写 Matlab 代码求解数值解。
(6)求解并分析结果:使用 Matlab 对建立的代码进行求解,并对结果进行分析和后处理。
4. Matlab 差分法解偏微分方程实例假设我们要使用 Matlab 差分法解决以下一维热传导方程:∂u/∂t = α * ∂^2u/∂x^2其中 u(x, t) 是热传导方程的温度分布,α 是热扩散系数。
4.1. 离散化区域和时间步长我们将求解区域离散化为网格点,分别为 x_i,i=1,2,...,N。
时间步长为Δt。
4.2. 离散化的微分方程使用中心差分格式将偏微分方程中的导数项离散化得到:∂u/∂t ≈ (u_i(t+Δt) - u_i(t))/Δt∂^2u/∂x^2 ≈ (u_i-1(t) - 2u_i(t) + u_i+1(t))/(Δx)^2代入原偏微分方程可得离散化的微分方程:(u_i(t+Δt) - u_i(t))/Δt = α * (u_i-1(t) - 2u_i(t) + u_i+1(t))/(Δx)^24.3. 建立迭代方程根据离散化的微分方程建立迭代方程:u_i(t+Δt) = u_i(t) + α * Δt * (u_i-1(t) - 2u_i(t) + u_i+1(t))/(Δx)^24.4. 编写 Matlab 代码使用以上建立的迭代方程编写 Matlab 代码求解热传导方程。
MATLAB是一种用于数学计算、工程和科学应用程序开发的高级技术计算语言和交互式环境。
它被广泛应用于各种领域,尤其在工程和科学领域中被用于解决复杂的数学问题。
微分方程是许多工程和科学问题的基本数学描述,求解微分方程的数值解和解析解是MATLAB算法的一个重要应用。
1. 求解微分方程数值解在MATLAB中,可以使用各种数值方法来求解微分方程的数值解。
其中,常见的方法包括欧拉法、改进的欧拉法、四阶龙格-库塔法等。
这些数值方法可以通过编写MATLAB脚本来实现,从而得到微分方程的近似数值解。
以常微分方程为例,可以使用ode45函数来求解微分方程的数值解。
该函数是MATLAB中用于求解常微分方程初值问题的快速、鲁棒的数值方法,可以有效地得到微分方程的数值解。
2. 求解微分方程解析解除了求解微分方程的数值解外,MATLAB还可以用于求解微分方程的解析解。
对于一些特定类型的微分方程,可以使用符号计算工具箱中的函数来求解微分方程的解析解。
通过符号计算工具箱,可以对微分方程进行符号化处理,从而得到微分方程的解析解。
这对于研究微分方程的性质和特点非常有帮助,也有助于理论分析和验证数值解的准确性。
3. MATLAB算法应用举例在实际工程和科学应用中,MATLAB算法求解微分方程问题非常常见。
在控制系统设计中,经常需要对系统的动态特性进行分析和设计,这通常涉及到微分方程的建模和求解。
通过MATLAB算法,可以对系统的微分方程进行数值求解,从而得到系统的响应曲线和动态特性。
另外,在物理学、生物学、经济学等领域的建模和仿真中,也经常需要用到MATLAB算法来求解微分方程问题。
4. MATLAB算法优势相比于其他数学软件和编程语言,MATLAB在求解微分方程问题上具有明显的优势。
MATLAB提供了丰富的数值方法和工具,能够方便地对各种微分方程进行数值求解。
MATLAB具有直观的交互式界面和强大的绘图功能,能够直观地展示微分方程的数值解和解析解,有利于分析和理解问题。
matlab 常微分方程组
Matlab中求解常微分方程组通常使用的是ODE解算器,如ode45、ode23等。
首先,我们设定微分方程组的解析表达式,然后用MATLAB中的dsolve 函数求解。
例如,考虑一个简单的微分方程组:
dx/dt = y
dy/dt = -x
在MATLAB中,可以这样表示:
syms x y t
dxdt = y;
dydt = -x;
然后我们可以使用dsolve 函数来解这个微分方程组:
sol = dsolve([dxdt, dydt], x(t), t);
这将返回一个符号解。
如果需要数值解,我们可以使用ode45 函数:
[t,y] = ode45(@(t,y) [y(2); -y(1)], [0 10], [1; 1]);
这将返回一个时间向量t 和相应的解向量y。
注意,ode45 函数需要一个匿名函数作为参数,这个函数返回一个列向量,代表方程组的右端。
对于多个微分方程的情况,将方程按照顺序放在一个列向量中即可。
matlab微分方程隐式解在MATLAB中,可以使用ode15i函数来求解隐式微分方程。
ode15i函数用于求解形式为M(x,y,y')=0的微分方程,其中M是关于y和y'的函数。
下面我将详细介绍如何使用ode15i函数来隐式解微分方程。
首先,假设我们有一个形如M(x,y,y')=0的隐式微分方程,我们需要定义这个方程。
然后,我们需要提供一个初始猜测值,以便求解器可以开始迭代过程。
接下来,我们可以使用ode15i函数来求解微分方程。
下面是一个简单的示例:假设我们要解决如下的隐式微分方程:M(x,y,y') = y' x^2 y^2 = 0。
我们首先需要定义这个隐式方程。
在MATLAB中,可以这样做:function res = implicitEquation(x, y, yp)。
res = yp x^2 y^2;end.接下来,我们需要提供初始猜测值。
这些值应该足够接近于方程的解。
然后,我们可以使用ode15i函数来求解微分方程。
下面是一个示例:xSpan = [0 1]; % 定义x的范围。
y0 = 1; % 初始猜测值。
yp0 = 0; % 对y'的初始猜测值。
[xSol, ySol] = ode15i(@implicitEquation, xSpan, y0,yp0);在这个示例中,我们使用ode15i函数来求解隐式微分方程。
@implicitEquation是我们定义的隐式方程的函数句柄。
xSpan定义了x的范围,y0和yp0是我们提供的初始猜测值。
最后,ode15i将返回xSol和ySol,它们分别是方程的解所对应的x和y的值。
需要注意的是,对于复杂的隐式微分方程,可能需要更多的迭代和调整初始猜测值才能得到准确的解。
因此,在使用ode15i函数时,需要仔细选择初始猜测值,并可能需要进行多次尝试才能得到满意的结果。
总之,MATLAB提供了ode15i函数来求解隐式微分方程,通过定义隐式方程、提供初始猜测值并使用ode15i函数进行求解,我们可以得到微分方程的数值解。
用Matlab 软件求解微分方程
1.解析解
(1)一阶微分方程 求21y dx
dy +=的通解:dsolve('Dy=1+y^2','x') 求y x dx
dy -+=21的通解:dsolve('Dy=1+x^2-y','x') 求⎪⎩⎪⎨⎧=+=1
)0(12y y dx dy 的特解:dsolve('Dy=1+y^2',’y(0)=1’,'x')
(2)高阶微分方程 求解⎩⎨⎧-='==-+'+''.
2)2(,2)2(,0)(222πππy y y n x y x y x 其中,21=n ,命令为: dsolve('x^2*D2y+x*Dy+(x^2-0.5^2)*y=0','y(pi/2)=2,Dy(pi/2)=-2/pi','x') 求042=-+'-'''x y y y 的通解,命令为:
dsolve('D3y-2*Dy+y-4*x=0','x')
输出为:
ans=8+4*x+C1*exp(x)+C2*exp(-1/2*(5^(1/2)+1)*x)+C3*exp(1/2*(5^(1/2)-1)*x)
(3)一阶微分方程组
求⎩⎨⎧+-='+=').
(3)(4)(),(4)(3)(x g x f x g x g x f x f 的通解:[f,g]=dsolve('Df=3*f+4*g','Dg=-4*f+3*g','x') 输出为: f =exp(3*x)*(cos(4*x)*C1+sin(4*x)*C2)
g =-exp(3*x)*(sin(4*x)*C1-cos(4*x)*C2)
若再加上初始条件1)0(,0)0(==g f ,则求特解:
[f,g]=dsolve('Df=3*f+4*g','Dg=-4*f+3*g','f(0)=0,g(0)=1','x')
输出为: f =exp(3*x)*sin(4*x)
g =exp(3*x)*cos(4*x)
2.数值解
(1)一阶微分方程
⎪⎩
⎪⎨⎧=≤≤-=.1)0(,10,2y x y x y dx
dy 现以步长h=0.1用“4阶龙格—库塔公式”求数值解: 先建立“函数M —文件”:function f=eqs1(x,y)
f=y-2*x/y;
再命令: 格式为:
[自变量,因变量]=ode45(‘函数文件名’,节点数组,初始值) 命令为: [x,y]=ode45('eqs1',0:0.1:1,1)
若还要画图,就继续命令: plot(x,y)
(2)一阶微分方程组
⎪⎩⎪⎨⎧==+-='≤≤-+='.3.0)0(,2.0)0(,2sin ,10,2cos 21
212211y y y y x y x y y x y 只须向量化,即可用前面方法: function f=eqs2(x,y)
f=[cos(x)+2*y(1)-y(2);sin(x)-y(1)+2*y(2)];
将此函数文件,以文件名eqs2保存后,再下命令:
[x,y]=ode45('eqs2',0:0.1:1,[0.2;0.3])
(注:输出的y 是矩阵,第i 列为函数i y 的数值解)
要画图,继续命令:hold on,plot(x,y(:,1)),plot(x,y(:,2)),hold off
(3)高阶微分方程
先化成一阶微分方程组,再用前面方法。
上机练习:⎩⎨⎧=''='=≤≤=-+'-'''.
0)0(,2.0)0(,1)0(,10,042y y y x x y y y 准备:令y y y y y y ''='==321,,,化成
.02.01)0()0()0(,423212132321⎪⎪⎪⎭
⎫ ⎝⎛=⎪⎪⎪⎭⎫ ⎝⎛⎪⎪⎪⎭⎫ ⎝⎛++-='⎪⎪⎪⎭⎫ ⎝⎛y y y x y y y y y y y 用机器: 函数文件eqs3内容?
命令?
画图?。