有限差分法求解偏微分方程_第1页
有限差分法求解偏微分方程_第2页
有限差分法求解偏微分方程_第3页
有限差分法求解偏微分方程_第4页
有限差分法求解偏微分方程_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、有限差分法求解偏微分方程摘要:本文主要使用有限差分法求解计算力学中的系统数学模型,推导了有限差分法的理论基础,并在此基础上给出了部分有限差分法求解偏微分方程的算例验证了推导的正确性及操作可行性。关键词:计算力学,偏微分方程,有限差分法Abstract:This dissertation mainly focuses on solving the mathematic model of computation mechanics with finite-difference method. The theoretical basis of finite-difference is derived

2、 in the second part of the dissertation, and then I use MATLAB to program the algorithms to solve some partial differential equations to confirm the correctness of the derivation and the feasibility of the method.Key words:Computation Mechanics, Partial Differential Equations, Finite-Difference Meth

3、od1 引言机械系统设计常常需要从力学观点进行结构设计以及结构分析,而这些分析的前提就是建立工程问题的数学模型。通过对机械系统应用自然的基本定律和原理得到带有相关边界条件和初始条件的微分积分方程,这些微分积分方程构成了系统的数学模型。求解这些数学模型的方法大致分为解析法和数值法两种,而解析法的局限性众所周知,当系统的边界条件和受载情况复杂一点,往往求不出问题的解析解或近似解。另一方面,计算机技术的发展使得计算更精确、更迅速。因此,对于绝大多数工程问题,研究其数值解法更具有实用价值。对于微分方程而言,主要分为差分法和积分法两种,本论文主要讨论差分法。2 有限差分法理论基础2.1 有限差分法的基本

4、思想当系统的数学模型建立后,我们面对的主要问题就是微分积分方程的求解。基本思想是用离散的只含有限个未知量的差分方程组去近似地代替连续变量的微分方程和定解条件,并把差分方程组的解作为微分方程定解问题的近似解。将原方程及边界条件中的微分用差分来近似,对于方程中的积分用求和或及机械求积公式来近似代替,从而把原微分积分方程和边界条件转化成差分方程组。有限差分法求解偏微分方程的步骤主要有以下几步:n 区域离散,即把所给偏微分方程的求解区域细分成由有限个格点组成的网格,这些离散点称作网格的节点;n 近似替代,即采用有限差分公式替代每一个格点的导数;n 逼近求解,换而言之,这一过程可以看作是用一个插值多项式

5、及其微分来代替偏微分方程的解的过程。从原则上说,这种方法仍然可以达到任意满意的计算精度。因为方程的连续数值解可以通过减小独立变量离散取值的间格,或者通过离散点上的函数值进行插值计算来近似得到。理论上,当网格步长趋近于零时,差分方程组的解应该收敛于精确解,但由于机器字节的限制,网格步长不可能也没有必要取得无限小,那么差分法的收敛性或者说算法的稳定性就显得至关重要。因此,在运用有限差分法时,除了要保证精度外,还必须要保证其收敛性。2.2 系统微分方程的一般形式(1)由于大多数工程问题都是二维问题,所以得到的微分方程一般都是偏微分方程,对于一维问题得到的是常微分方程,解法与偏微分方程类似,故为了不是

6、一般性,这里只讨论偏微分方程。由于工程中高阶偏微分较少出现,所以本文仅仅给出二阶偏微分方程的一般形式,对于高阶的偏微分,可进行类似地推广。二阶偏微分方程的一般形式如下:Axx+Bxy+Cyy=f(x,y,x,y)其中,为弹性体上的某一特征物理量(连续函数)。当A、B、C都是常数时,(1)式称为准线性,有三种准线性方程形式:n 如果=B2-4AC<0,则称为椭圆型方程;n 如果=B2-4AC=0,则称为抛物型方程;n 如果=B2-4AC>0,则称为双曲型方程。椭圆型方程主要用来处理稳态或静态问题,如热传导等问题;抛物线方程主要用来处理瞬态问题,如渗透、扩散等问题;双曲型方程主要用来处

7、理振动问题,如玄震动、薄膜震动等问题。除了上述微分方程外,必须给出定解条件,通常有如下三类:n 第一类边界条件(Dirichlet条件):|=(x,y);n 第二类边界条件(Neumann条件):n|=1(x,y);n 第三类边界条件(Robin条件):n+(x,y)|=(x,y);其中,为求解域的边界,n为的单位外法矢,(x,y)|0 。第二类和第三类边界条件统称为导数边界条件。2.3 有限差分方程的数学基础2.3.1 一元函数导数的差分公式一个函数在x点上的导数,可以近似地用它所临近的两点上的函数值的差分来表示。函数fx在x=x0处的泰勒展式如下:fx=n=01n!fn(x0)x-x0n(

8、2) =fx0+f'xx-x0+12!f''xx-x02+13!f(3)xx-x03+(3)对一个单变量函数fx,以步长x=h将a,b区间等距划分,我们得到一系列节点:x0=a,x1=x0+x=a+h,x2=x1+x=a+2h,xi=xi-1+x=a+ih,xn=b (n=b-ah),然后求出 fx在这些节点上的近似值。与节点xi相邻的节点有xi-h和xi+h,因此在点xi处可以构造如下形式的展开式:fxi-h=fxi-f'xih+12!f''xih2+R2(x)(4)fxi+h=fxi+f'xih+12!f''xih2+

9、R2(x)由式(3)和式(4)可得到:(5)n 一阶向前差分:f'xi=fxi+h-fxih(6)n 一阶向后差分:f'xi=fxi-fxi-hh(7)n 一阶中心差分:f'xi=fxi+h-fxi-h2h不妨,记fi=f(xi),则式(5)、(6)、(7)分别简写为:(8)n 一阶向前差分:fi'=fi+1-fih(9)n 一阶向后差分:fi'=fi-fi-1h(10)n 一阶中心差分:fi'=fi+1-fi-12h根据式(8)、式(9)和式(10),可得二阶差分:(11)n 二阶向前差分:fi''=fi+1'-fi&#

10、39;h=fi+2-2fi+1+fih2(12)n 二阶向后差分:fi''=fi'-fi-1'h=fi-2fi-1+fi-2h2(13)n 二阶中心差分:fi''=fi+1'-fi-1'2h=fi+2-2fi+fi-24h2差分公式(13)是以相隔2h的两结点处的函数值来表示中间结点处的一阶导数值,可称为中点导数公式。式(11)和式(12)是以相邻三结点处的函数值来表示一个端点处的一阶导数值,可称为端点导数公式。应当指出:中点导数公式与端点导数公式相比,精度较高。因为前者反映了结点两边的函数变化,而后者却只反映了结点一边的函数变化

11、。因此,我们总是尽可能应用前者,而只有在无法应用前者时才不得不应用后者。(14)但是,由于式(11)中的各阶导数均使用的是向前差分,导致用到的节点不相邻,同时为了均衡误差,将节点i处用到的一阶差分换成向后差分,则式(11)修正为:fi''=fi+1'-fi'h=fi+1-fih-fi-fi-1hh=fi+1-2fi+fi-1h2同理,根据上述推导过程,可得到任意阶的差分公式:(15)n n阶向前差分:fi(n)=fi+1(n-1)-fi(n-1)h(16)n n阶向后差分:fi(n)=fi(n-1)-fi-1(n-1)h(17)n n阶中心差分:fi(n)=fi

12、+1(n-1)-fi-1(n-1)2h说明,上述公式中各节点处前一阶导数的代入可能存在不一致,可能是向前差分、向后差分或者中心差分,从而使最终的公式在系数上存在差别。当然,也可以对各相邻节点进行需要阶数的泰勒展开,从而建立方程组直接求各阶导数。2.3.2 微分方程转化为线性方程ym(18)由于三种类型的微分方程解法类似,故这里仅以椭圆型微分方程为例,将微分方程转化为代数方程,对于双曲型和抛物型方程依次类推即可。不妨记:2u=uxx+uyy(2称为拉普拉斯算子),fx,y和g(x,y)是求解域上的连续函数。假设求解区域为:R=x,y:0xa,0yb,ba=m/n,将求解区域划分成(n-1)

13、15;(m-1)个网格,其中:a=nh,b=mh,如图1所示。记fi,j=f(xi,yj),则根据式(14)可得到:2u=uxx+uyy=ui+1,j-2ui,j+ui-1,jh2+ui,j+1-2ui,j+ui,j-1h2 =ui+1,j+ui-1,j+ui,j+1+ui,j-1-4ui,jh2+O(h2)yj+1yjyj-1y1 x1 xi-1 xi xi+1 xn图1 五点差分公式式(18)也称为五点差分公式,同理根据式(12)和式(13)可分别得到向前差分公式(19)和向后差分公式(20),如图(2所示)。(19)n 向前差分2u=uxx+uyy=ui+2,j-2ui+1,j+ui,j

14、h2+ui,j+2-2ui,j+1+ui,jh2 =ui+2,j+ui,j+2+2ui,j-2ui+1,j-2ui,j+1h2+O(h2)ymym(20)n 向后差分2u=uxx+uyy=ui,j-2ui-1,j+ui-2,jh2+ui,j-2ui,j-1+ui,j-2h2 =ui-2,j+ui,j-2+2ui,j-2ui-1,j-2ui,j-1h2+Oh2x1xi-2xi-1xixi+1xi+2xixnxnx1y1yj-2yj-1yjyjy1yj+1yj+2 ui-2,j2ui,jui,j+2ui,j+1图2 向前差分(左)和向后差分(右)-2ui-1,j-2ui,j-1ui,j-2-2ui

15、,j+12ui,j-2ui+1,jui+2,j-4ui,jui,j-1ui+1,jui-1,j 图3 中心差分、向前差分和向后差分的拉普拉斯算子表示(21)利用中心差分公式(18),由于式(18)在点x,y=(xi,yi)处具有二阶精度(Oh2),所以式(18)可近似改写成下式:2ui,jui+1,j+ui-1,j+ui,j+1+ui,j-1-4ui,jh2根据椭圆方程的具体形式可以将其分为以下三种形式:n 拉普拉斯(Laplace)方程:2u=0n 泊松(Poison)方程:2u=g(x,y)n 赫耳墨次(Helmholtz)方程:2u+fx,yu=g(x,y)根据式(21),可建立三种不同

16、形式椭圆方程的代数方程如下:n 拉普拉斯方程:2u=00=2ui,jui+1,j+ui-1,j+ui,j+1+ui,j-1-4ui,jh2化简后得到拉普拉斯方程的计算公式:(22)ui+1,j+ui-1,j+ui,j+1+ui,j-1-4ui,j=0(23)n 泊松方程:2u=gx,yui+1,j+ui-1,j+ui,j+1+ui,j-1-4ui,j-h2gi,j=0n 赫耳墨次方程:2u+fx,yu=g(x,y)(24)ui+1,j+ui-1,j+ui,j+1+ui,j-1+(h2fi,j-4)ui,j-h2gi,j=02.3.3 建立有限差分方程组根据式(22)(24)建立方程组,但是需要

17、知道对应的边界条件才能使方程组存在定解,根据2.2中可知,边界条件一般分为狄利克雷边界条件和导数边界条件两种,下面分别给出这两种边界条件的有限差分方程组的建立过程:n 狄利克雷边界条件:|=(x,y)对于狄氏条件而言,给出了边界上各节点出的函数计算公式,直接代入节点值(xi,yi)计算即可,如下所示为矩形区域的边界点计算:u(x1,yj)=u1,j=(x1,yj)(1jm)(左边界)(25)u(xn,yj)=un,j=(xn,yj)(1jm)(右边界)u(xj,y1)=uj,1=(xj,y1)(1jn)(下边界)u(xj,yn)=uj,n=(xj,yn)(1jn)(上边界)n 导数边界条件:u

18、(x,y)N=0(26)以右边界点为例,对于右边界点x=xn,根据Neumann条件可得下式:u(x,y)N=u(xn,yj)x=uxxn,yj=0对于拉普拉斯方程,根据计算公式(22),对于边界上的点(xn,yj)可得:(27)un+1,j+un-1,j+un,j+1+un,j-1-4un,j=0(28)显然,上式中的un+1,j在求解域外,是未知量。根据中心差分公式(10)可得到:uxxn,yjun+1,j-un-1,j2h根据式(28)可得到逼近表示:un+1,jun-1,j,并且具有2阶逼近精度,代入式(27)可得下式:(29)2un-1,j+un,j+1+un,j-1-4un,j=0

19、同理,对于其它边界可获得如下边界方程:(30)2ui,2+ui-1,1+ui+1,1-4ui,1=0(下边界)2ui,m-1+ui-1,m+ui+1,m-4ui,m=0(上边界)2u2,j+u1,j+1+u1,j-1-4u1,j=0(左边界)图4 Neumann条件算子对于泊松方程和赫耳墨次方程同样根据上述方法,获得边界条件的线性方程,然后将这些方程添加到式(22)(24)所建立的方程组中,从而建立起(n-1)个(m-1)元的线性方程组,解该方程组即可获得各节点的函数值。对于上述过程建立的线性方程组的求解,可采用多种方法,比如Jacob迭代法、Gauss-Seidel迭代法、超松弛迭代法(SO

20、R法)、高斯消元法等方法求解。2.4 有限差分法的收敛性和稳定性由于迭代法必须保证收敛性,所以在解有限差分方程组时还应保证其收敛性,也就是通常所说的算法稳定性。有限差分法的算法稳定性可以通过特征值方法、傅里叶变换(冯诺依曼条件)以及能量估计等方法来判断,下面给出常用的冯诺依曼条件:n 向前差分:r1,绝对收敛;n 向后差分:r>0,绝对收敛;n 中心差分:对任何的r对不收敛;假设求解域内x方向网格划分的步长为h,y方向网格划分的步长为k,将偏微分方程化为标准形式,具体来说标准形式如下:(31)n 双曲方程:2uy2=c22ux2(c>0)对于式(31)所示的双曲方程,冯诺依曼条件为

21、:r=ckh.(32)n 抛物方程:uy=a2ux2对于式(32)所示的抛物方程,冯诺依曼条件为:r=ckh2.(33)n 椭圆方程:c22ux2+2uy2=0对于式(33)所示的椭圆方程,冯诺依曼条件为:r=ckh.(34)为了使算法在任何情况下都能保持稳定性,去掉对网格划分的冯诺依曼条件,通常采用隐式方案,对五点差分公式中的节点所在的行做差分,然后把这些差分的加权作为中心点的差分值,则拉普拉斯算子可修正为:uxx=ui+1,j+1-2ui,j+1+ui-1,j+1h2+1-2ui+1,j-2ui,j+ui-1,jh2+ui+1,j-1-2ui,j-1+ui-1,j-1h2(01)利用式(3

22、4)进行计算时,稳定性没有任何限制。取不同的值得到不同的差分公式,通常取=1/4.(35)为了提高计算精度,很明显的一个措施就是网格细分,但是由于随着网格步长的减小,未知量的数目将会呈指数增长,网格划分太细会导致计算量过于庞大而无法计算。通常,我们可以通过提高逼近的精度,采用更高精度的差分公式,例如对公式(21)进行修改,可得到九点差分公式:2ui,j16h2ui+1,j+1+ui-1,j+1+ui+1,j-1+ui-1,j-1+4ui+1,j+4ui-1,j+4ui,j-1+4ui,j+1-20ui,j+O(h4)ui-1,j+14ui-1,jui-1,j-14ui+1,j-20ui,j4u

23、i-1,j4ui,j+1ui-1,j+1ui+1,j+1xi+1xixi-1x1yj+1yj-1yjy1ym图5 九点差分公式3 有限差分法求解实例根据上述推导有限差分法理论,对于不同类型的偏微分方程建立有限差分方程组,采用mat lab编程给出一些计算实例如下:1. 椭圆型方程n 拉普拉斯方程:2u=0;求解域:R=x,y:0x1.5,0y1.5下面分别给出拉普拉斯方程在不同的边界条件下的解。a) 狄利克雷边界条件:下边界:ux,0=x4上边界:ux,1.5=x4-13.5x2+5.0625左边界:u0,y=y4右边界:u1.5,y=y4-13.5y2+5.0625图6 狄利克雷边界条件下拉普拉斯方程的解b) Neumann边界条件:u(x,y)N=0下边界:ux,0=0上边界:ux,1.5=400左边界:u0

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论