应用Matlab求解二阶偏微分方程的基…

>利用Matlab求解二阶偏微分方程的一般有以下步骤
    → 题目定义:由方程(3.4.33)和(3.4.35)可以看出,参量 是二阶偏微 分方程的主要参量,只要这几个参量确定,就可以定下偏微分方程的结构。此外要做的事是确定偏微分 方程的求解区域,即边界条件。在PDE ToolBox中有许多类似circleg.m的m文件定义了不同的边界形状。 使用前可以借助help命令查看,或参考其它资料。
    →求解域的网格化:通常采用命令initmesh进行初始网格化,还可以采用命 令refinemesh进行网格的细化和修整。这些命令的用法同样可以使用help命令,如[p,e,t]=initmesh(g) ,这里的参量p、e、t提供给下面的问题求解时使用。
    → 问题的求解:在PDE工具箱中有许多求解我们在上面提到的不同类型 的二阶偏微分方程的指令,主要有:
    ◆assempde    调用格式为:u=assempde(b,p,e,t,c,a,f)
该命令用来求解椭圆型偏微分方程(3.4.31),求解的边界条件由函数b确定,网格类型由p、e和t确 定,c、a、f是椭圆型偏微分方程(3.4.31)
    ◆hyperbolic  调用格式为:u1=hyperbolic (u0,ut0,tlist,b,p,e,t,c,a,f,d)
该命令用来求解双曲型偏微分方程(3.4.35)。
    ◆ parabolic 调用格式为:u1=parabolic (u0,tlist,b,p,e,t,c,a,f,d)
该命令用来求解抛物线型偏微分方程(3.4.33)。
    ◆pdeeig   调用格式为:[v,l]= pdeeig(b,p,e,t,c,a,d,r)
   该命令用来求解特征值型偏微分方程(3.4.37)。
    ◆pdenonlin 调用格式为:[u,res]= pdenonlin(b,p,e,t,c,a,f)
   该命令使用具有阻尼的Newton迭代法,在由参量p、e、t确定的网格上求解非线性椭 圆型偏微分方程(3.4.31)。
  ◆poisolv 该命令在一个矩形网格上求解Poisson方程。    

→结果处理:如Matlab的主要特色一样,在PDE工具箱中提供了丰富的图形显 示,因此用户不但可以对产生的网格进行图形显示和处理,对求解的数据也可以选择多种的图形显示和 处理方法,甚至包括对计算结果的动画显示。用户可以参考相关资料来使用。
相关推荐
matlab中的微分方程-matlab中的微分方程.doc 1510 matlab中的微分方程 第1节  Matlab能够处理什么样的微分方程Matlab提供了解决包括解微分方程在内的各种类型问题的函数: 1. 常规微分方程(ODEs)的初始值问题 初值问题是用MATLAB ODE求解器解决的最普遍的问题。初始值问题最典型的是对非刚性度(?nonstiff)问题应用ODE45,对刚性度(?stiff)问题采用ODE15S。(对于stiffness的解释,请参照“什么是Stiffness”一节。) 2. 微分-代数方程(DAEs)的初值问题 在那些守恒定律规定一些变量之间满足常数关系领域经常遇到这类问题。Matlab 可以用ODE15S 或者 ODE23T解决索引(index)为1的DAEs。(对于索引的解释,请参阅“DAEs与他们的索引”一章。) 3. 边界值问题(BVPs) 这种通常要求微分方程在两边都具有特殊的条件组成。尽管他们通常不象IVPs那样经常遇到,但是他们也是工程应用中比较常见的问题。可以利用函数BVP4C来解决这类问题。 4. 时延微分方程(DDEs) 这类微分方程包含了独立变量的延迟。他们在生物与化学模型这类大量的应用中遇到,可以通过DDE23来解决这类问题。 5. 偏微分方程(PDEs) 采用PDEPE可以解决一维时空的抛物面与椭圆方程的初值、边界值的问题。而那些对更加多的一般的偏微分方程感兴趣的可以利用PDE工具箱。 更多的matlab的综合应用技术的信息请参阅Solution8314。 更多的有关matlab采用的各种求解器的算法的信息请查看下面的URLs: ● ODE 函数 ● BVP 函数 ● DDE 函数 ● PDE 函数 第2节 可以从什么地方获得更多的指导与附加信息?    可以从MATLAB Center、网站的新闻组、文件交换点可以获得一系列资料,可以进一步解释MATLAB解决各种方程(ODE,DAE,BVP,DDE)的求解器的算法和使用。你可以下载各种方程的文章与手册,他们通常带有大量的实例。   可以从 matlab自带的帮助文件的 Mathematics|Differential Equations下找到使用指导。   Cleve Moler的《Numerical Computing with MATLAB》的第七章详细讨论了OEDs的解法,并附带有大量的实例与简单的问题练习。    第3节 对ODE求解器的语法存在有些什么变化? 在MATLAB6.5(R13)中应用ODE求解求解的首选语法是: [t,y]=odesolver(odefun,tspan,y0,options,parameter1,parameter2,…,parameterN); odesolver 是你采用的求解器,例如ODE45或者ODE15S。odefun是微分方程的定义函数,所以odefun定义独立参数(典型的是时间t)的导数y‘ 以及y和其他的参数。在MATLAB6.5(R13)中,推荐使用函数句柄作为odefun。 例如,ode45(@xdot,tspan,y0),而不是用 ode45('xdot',tspan,y0)。 请看采用函数句柄的好处的文档: 采用函数句柄传递你定义MATLAB求解器计算的量、例如大规模矩阵或者Jacobian模式的函数。 如果你喜好采用字符串儿传递你的函数,matlab求解器将回溯匹配。 在老的matlab版本里,通过传递标志来规定求解器的状态和恰当的计算。在MATALB6.0以及其后的版本中,这就没有必要了,可以从matlab自带的文档中发现这个差别。 如果里采用的matlab的ODE求解器的老的语法,你可以看看我们FTP站点上的各种求解器的老的实例: ftp://ftp.mathworks.com/pub/doc/papers/ 前面的站点包含了BVP,DAE与DDE这三个方向的采用老的语法的实例。你可以在下面的站点中找到应用ODE45与ODE23的实例: ftp://ftp.mathworks.com/pub.mathworks/toolbox/matlab/funfun 你可以在MATLAB Center的文件交换站点查看这些例子的更新版本。 第4节  如何减小ODE的阶次? 求解一阶ODE的代码是很直接的。然而,二阶或者三阶的ODE不能够直接应用求解。你必须先将高阶的ODE改写成一阶的ODEs系统,使得它可以采用MATLAB ODE求解器。 这是一个如何将二阶微分方程改写成两个一阶微分
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页