AAM Advances in Applied Mathematics 2324-7991 Scientific Research Publishing 10.12677/AAM.2017.62020 AAM-20007 AAM20170200000_63961507.pdf 数学与物理 算子分裂有限元方法求解二维Burgers方程 The Operator Splitting Finite Element Method for Two-Dimensional Burgers Equation 云云 1 * 3 2 引娣 3 4 2 西安交通大学数学与统计学院,陕西 西安 广东理工学院基础部,广东 肇庆;长安大学理学院,陕西 西安 长安大学理学院,陕西 西安;西安交通大学数学与统计学院,陕西 西安 null * E-mail: 939533015@qq.com(魏云) ; 21 03 2017 06 02 174 182 © Copyright 2014 by authors and Scientific Research Publishing Inc. 2014 This work is licensed under the Creative Commons Attribution International License (CC BY). http://creativecommons.org/licenses/by/4.0/

本文提出了一种求解Burgers方程新的算子分裂有限元方法。该算法采用算子分裂法将Burgers方程分解成纯对流部分和扩散部分:对流方程时间离散采取中心差分格式,空间的离散采用标准的Galerkin有限元法;扩散子方程的时间离散采取向后差分格式,空间的离散仍采用标准的Galerkin有限元法。该方法特点是对流部分特殊的显式处理,对其使用多步法技术从根本上扩大稳定性区域,而且多步格式在选择适当步数的条件下可以呈现出无条件稳定。通过数值实验验证了该算法单步和多步格式的稳定性和收敛性,并对其进行了误差估计。 This paper proposes a new operator splitting finite element method for two-dimensional Burgers equation. The new method is used to decompose the Burgers equation into pure convection and diffusion part: the time discretization of the convection equation solved by the central difference scheme, and the space discretization by the standard Galerkin finite element method; the time discretization of the diffusion equation solved by the backward difference scheme, and the space discretization still using the standard Galerkin finite element method. The characteristic of this method is that the convection part is specially processed, using multi-step technology to expand the stability of the region and selecting the appropriate number of steps, the multi-step scheme can present unconditionally stable. The stability and convergence of the algorithm are verified by numerical experiments.

算子分裂法,Burgers方程,有限元法,多步法, Operator Splitting Method Burgers Equation Finite Elements Multistep Scheme
算子分裂有限元方法求解二维Burgers方程<sup> </sup>

魏云云1,2,史 峰3,张引娣2,3

1广东理工学院基础部,广东 肇庆

2长安大学理学院,陕西 西安

3西安交通大学数学与统计学院,陕西 西安

收稿日期:2017年3月8日;录用日期:2017年3月25日;发布日期:2017年3月28日

摘 要

本文提出了一种求解Burgers方程新的算子分裂有限元方法。该算法采用算子分裂法将Burgers方程分解成纯对流部分和扩散部分:对流方程时间离散采取中心差分格式,空间的离散采用标准的Galerkin有限元法;扩散子方程的时间离散采取向后差分格式,空间的离散仍采用标准的Galerkin有限元法。该方法特点是对流部分特殊的显式处理,对其使用多步法技术从根本上扩大稳定性区域,而且多步格式在选择适当步数的条件下可以呈现出无条件稳定。通过数值实验验证了该算法单步和多步格式的稳定性和收敛性,并对其进行了误差估计。

关键词 :算子分裂法,Burgers方程,有限元法,多步法

Copyright © 2017 by authors and beplay安卓登录

This work is licensed under the Creative Commons Attribution International License (CC BY).

http://creativecommons.org/licenses/by/4.0/

1. 引言

Burgers方程是流体力学中一个非常重要和基本的非线性偏微分方程,广泛的应用于空气、动力学、湍流、热传导、交通流、半导体迷你以及地下水污染等领域;同时Burgers方程可以作为流体动力学中Navier-Stokes方程的简化模型方程,又可以作为浅水波等问题的数学模型。因此讨论这类方程的数值解法,具有重要的理论和现实意义。

求解Burgers方程的数值方法主要有有限差分法、有限体积法、有限元法 [ 1 ] [ 2 ] [ 3 ] [ 4 ] [ 5 ] 。其中,有限元法由于适合处理复杂几何形状和边界条件而成为计算力学中的优选方法,目前已经发展了多种有限元数值计算方法。标准的Galerkin有限元法实质上采用的是中心差分格式,随着对流项越来越强,呈现强的非线性特性,从而引起数值解的振荡失真。Petrov-Galerkin法(P-G法) [ 6 ] 通过将权函数取为基函数的某种修正形式使计算格式具有人工耗散能力,提高了解的精度,随后发展了多种迎风方法,如流线迎风Petrov-Galerkin法等。上述各方法都包含一个对原Galerkin法的耗散修正项,产生了一个包括二阶空间导数的附加项。Taylor-Galerkin [ 7 ] 有限元法(T-G法)时间方向上的Taylor展开先于空间上的Galerkin离散,相比P-G法不需要使用特殊的权函数,也无需确定人工耗散自由参数来达到高精度。基于特征线的分裂算法(CBS法) [ 8 ] 是结合分裂算法与特征线Galerkin法的一种比较新的算法,在流体和固体动力学问题中得到了广泛的研究。

算子分裂法 [ 9 ] [ 10 ] [ 11 ] 是Yanenko在1971年提出的经典分裂法,该算法具有格式灵活、稳定性好等特点。曹志先 [ 12 ] 等用算子分裂法求解了Burgers方程,用显式差分格式处理扩散算子,用特征线法处理纯对流算子,并分析了该算法的稳定性条件,还对一、二维Burgers方程进行数值解,所得结果与分析解或已有数值解吻合。

本文在文献 [ 13 ] 的基础上,采用基于算子分裂的有限元方法求解二维非定常粘性的Burgers方程,在每个时间层上应用算子分裂技术将Burgers方程分裂成纯对流子方程和扩散子方程,这样可以避免两种不同性质的物理过程在一起求解时计算的困难。对流方程时间离散采取中心差分格式,空间的离散采用标准的Galerkin有限元法,将其结果作为求解扩散子方程的初始值。扩散子方程的时间离散采取向后差分格式,空间的离散仍采用标准的Galerkin有限元法。该方法的另一个创新之处在于对流部分特殊的显式处理,使得在一个步长的扩散修正过程中,对流部分以局部较小的时间步长执行有限次数,这样可以从根本上提高计算格式的稳定性。数值模拟验证了该算法单步和多步格式的稳定性和收敛性。

2. 计算方法

本文主要涉及的是二维粘性Burgers方程:

in

具有的边界条件和初始条件分别为: in

这里的 表示粘性系数。

在这部分我们将推导出一种新的分裂法求解二维粘性的Burgers方程。首先介绍一些符号:剖分时间区间 ,其中 分别代表近似解 处的值,但是当 给定时, 将表示精确解在 处的值; 类似于

2.1. 单步格式

首先采用标准算子分裂技术将对流扩散方程分裂成一个纯对流子方程和一个扩散子方程,在时间推进方面分别用中心差分格式和向后的欧拉格式近似这两个方程,得到:

,其中 ; (2)

我们使用有限元方法分别求解方程(1)(2)的 ,因此需要两个方程的变分形式。直接可以得到方程(2)的变分形式即:找到 使得在边界 ,并且求解

方程(1)的求解比较复杂,因为该格式是隐式还涉及了一个线性化对流方程的解的问题。求解的主要思想还是找到一个显式的格式去计算这个线性化的对流方程。在此我们应用泰勒展开式去计算 即:

再使用对流子方程:

,

可以得到:

利用上述的关系式,方程(1)可以改写为:

注意到方程(1)是一个纯对流方程,仅需要设置来流方向 的边界条件。

给方程(4)两边乘以一个测试函数 ,并且在 上积分,使用分部积分可以得到:

现在我们利用一些有限元方法转向空间的离散。假设 是近似Sobolev空间 有限元空间, 的算子插值。基于变分形式(3) (5),下面提出求解二维粘性Burgers方程的单步算法。

单步算法:

1) 计算初始值 ,对于

2) 找到 使得在 满足 ,并且求解

3) 找到 使得在 满足 ,并且求解

2.2. 多步算法

由于单步格式显示的求解二维粘性Burgers方程的单步算法,其稳定性不够好,为了提高算法的稳定性,我们可以采用在每一步对扩散方程的修正过程中,多次的执行对流步,以至于在对流部分可以使用更小的时间步长。为此我们将步骤2的结果 写成如下的形式:

为了得到 ,多步格式以较小的时间步长 运行对流步 次,即我们要计算:

我们分别称 为局部时间步长和全局时间步长。利用多步迭代(7)代替步骤2,可以得到下面的多步格式。

多步算法:

1) 计算初始值 ,对于

2) 设 ,并计算 ,其中 ,使得在边界 ,对所有的 求解下面的方程:

3) 找到 使得在 满足 ,并且求解

3. 数值算例

例1 方程系数和区域如下所示: ,边界条件 ,精确解为:

.

现在我们应用上述的算法求解算例1,确定其在时间和空间方面的收敛精度。空间步长为 的均匀网格,表1显示了在时间方面的收敛精度。表2给出了在固定的时间步长 ,单步算法在空间方面的收敛精度。从表中我们可以清晰的看到单步算法在时间方面是一阶收敛精度,而在空间有二阶的收敛精度。在此说明,本节所示的所有误差是L2范数在终端时刻 的误差,除非另有说明。

从表1中可以看到,当取 时,这对保持包含在对流步的显示时间推进的稳定性是很大的时间步长,但只运用单步算法我们就得到收敛的计算结果,其结果如图1所示。同理,在表2中确定了该算例在空间方面的收敛精度,在 时网格的剖分是很粗的,但是运用上述的单步算法计算结果是收敛的,如图2所示。上述表中的计算的收敛结果说明了单步算法的可行性和实用性。

例2 方程参数如下所示: ,边界条件 ,精确解有如下的形式:

为了确定在空间方面单步格式的实际收敛阶,我们选择了很小的时间步长,观察当空间步长减半的情况下误差的变化。表3显示了当时间步长固定,数值算例在不同网格大小的L2的误差,可以清楚的看到单步格式在空间是二阶收敛精度。

现在我们取 的均匀网格,在如下的时间步长序列运行单步格式,寻找数值格式的稳定区域。数值结果如表4所示,可以观察到 时单步算法是不收敛的,而且虽然 时算法收敛,但计算结果有很大的振荡。因此要得到满意的计算结果,必须采用合适的较小的时间步长。限制这样时间步长是自然的,因为这是我们使用的显示时间推进的稳定性条件所要求的。在下面的部分,可以看到多步格式可以从根本上提高稳定性条件。

从上面可以看到,单步格式可以得到期望的收敛性,而且当它收敛时可以保持精确的收敛精度。然

Error estimation and convergence order of single method wit
order
0.1 0.318725 -
0.1/2 0.147547 1.1112
0.1/22 0.070784 1.0597
0.1/23 0.034646 1.0308
0.1/24 0.017137 1.0156
0.1/25 0.0085221 1.0078
0.1/26 0.00424952 1.0039

表1. 取 ,单步法计算的误差估计及其收敛阶

Error estimation and convergence order of single method wit
order
1/4 0.041588 -
1/8 0.00897586 2.2120
1/16 0.00203951 2.1378
1/32 0.000483367 2.0770
1/64 0.000123786 1.9652

表2. 取 ,单步法计算的误差估计及其收敛阶

Error estimation and convergence order of single method wit
order
1/4 0.362638 -
1/8 0.0817792 2.1487
1/16 0.0196814 2.0549
1/32 0.00493634 1.9953
1/64 0.00123852 1.9948
1/128 0.000312747 1.9855

表3. 取 ,单步法计算的误差估计及其收敛阶

Error estimation and convergence order of single method wit
order
0.1 1.11024e+35 -
0.1/2 0.121862 -
0.1/22 0.0455624 1.4193
0.1/23 0.0223644 1.0267
0.1/24 0.0111191 1.0081
0.1/25 0.00556048 0.9998

表4. 取 ,单步法计算的误差估计及其收敛阶

图1.

图2.

而,这个格式要求合适的较小的时间步长,限制了其在实际应用。多步格式的提出是为了提高单步格式的稳定性,下面是多步格式提高算法稳定性的测试。

在下面的数值实验中,对确定的 ,取 为多步数,运行多步格式直到观察算法收敛并记录相关的多步数。表5显示了计算的数值结果,从表中可以看到,当我们取 时,这对保持对流步的显示时间推进的稳定性是很大的时间步长,但是在 我们仍然得到多步格式的计算结果是收敛的。计算结果已表明对于给定的单步格式可 能不收敛,但当取多步数 合适的大,多步格式计算的结果总是收敛的。因此我们可以总结到,如果给定一个合适的大的 ,多步格式可以被认为是无条件稳定的格式。

我们也计算了在固定的步数 和空间步长 下,多步格式的收敛精度,计算结果如表6所示。将表6结果与利用单步格式计算的表4对比,可以清晰的观察到数值算例收敛的时间序列,多步法的计算结果明显优于单步格式的结果,图3所示了取 的条件下,单步和多步算法数值结果的比较。

Numerical results of multistep method wit
order
0.1/25 2 0.00557061 -
0.1/24 4 0.0111357 0.9993
0.1/23 8 0.022311 1.0026
0.1/22 16 0.044746 1.0040
0.1/2 32 0.0897277 1.0038
0.1 64 0.179769 1.0025
0.2 128 0.361168 1.0065

表5. 取 ,多步法的计算的数值结果

Numerical results of multistep method with an
order
0.1 0.179769 -
0.1/2 0.0897229 1.0026
0.1/22 0.0447486 1.0036
0.1/23 0.0223207 1.0035
0.1/24 0.0111494 1.0014
0.1/25 0.00558507 0.9973

表6. 取 ,多步法的计算结果

图3. 取 ,左边 右边

4. 结论

本文探讨了一种新的算子分裂算法求解二维粘性Burgers方程。在每一步迭代过程中,先后求解一个纯对流和一个纯扩散的问题。提出了对流问题时间推进的显示格式,但时间推进的显示化可能会引起对时间步长严格的限制,因此提出了在较小的时间步长下显示的多步格式以至于这个方法的结果表现的像无条件稳定的方法。扩散问题在每一步迭代过程中总是自伴的和强制的,以便使用许多存在的最优预条件的迭代求解器可以有效的解决它。通过数值算例呈现了新格式单步和多步方法求解的稳定性、收敛性,以及已经验证了其最优的收敛阶。

文章引用

魏云云,史峰,张引娣. 算子分裂有限元方法求解二维Burgers方程 The Operator Splitting Finite Element Method for Two-Dimensional Burgers Equation[J]. 应用数学进展, 2017, 06(02): 174-182. http://dx.doi.org/10.12677/AAM.2017.62020

参考文献 (References) References 章本照, 印建安, 张宏基. 流体力学数值方法[M]. 北京: 机械工业出版社, 2003. 李荣华, 刘播. 偏微分方程数值解法[M]. 北京: 高等教育出版社, 2009. Quarteroni, A. and Valli, A. (1997) Numerical Approximation of Partial Differential Equations. Springer-Verlag, Berlin, 1997. Donea, J. and Huerta, A. (2003) Finite Element Methods for Flow Problems. Wiley, New York.
https://doi.org/10.1002/0470013826
Liao, W.Y. (2010) A Fourth Order Finite-Difference Method for Solving the System of Two-Dimensional Burgers’ Equation. International Journal for Numerical Methods in Fluids, 64, 565-590.
https://doi.org/10.1002/fld.2163
Brooks, A.N. and Hughes, T.J.R. (1982) Streamline Upwind/Petrov-Galerkin Formulations for Convection Dominated Flows with Particular Emphasis on the Incompressible Navier-Stokes Equations. Computer Methods in Applied Mechanics and Engineering, 32, 199-259.
https://doi.org/10.1016/0045-7825(82)90071-8
Donea, J.A. (1984) Taylor-Galerkin Method for Convective Transport Problems. International Journal for Numerical Methods in Engineering, 20, 101-119.
https://doi.org/10.1002/nme.1620200108
Nithiarasu, P., Zienkiewicz, O.C. and Codina, R. (2006) The Characteristic-Based Split (CBS) Scheme—A Unified Approach to Fluid Dynamics. International Journal for Numerical Methods in Engineering, 66, 1514-1546.
https://doi.org/10.1002/nme.1698
Khan, L.A. and Liu, L.F. (1989) Numerical Analysis of Operator-Splitting Algorithms for the Two-Dimensional Advection-Diffusion Equation. Computer & Fluids, 9, 235-244. Karlsen, K.H. and Risbro, N.H. (1997) An Operator Splitting Method for Nonlinear Convection-Diffusion Equations. Numerische Mathematik, 77, 365-382.
https://doi.org/10.1007/s002110050291
Cui, M. (2001) Operator-Splitting Galerkin Method for One Kind of Oin Reaction Model for the Pollution in Groundwater. Applied Mathematics—A Journal of Chinese Universities, Series B, 16, 297-303.
https://doi.org/10.1007/s11766-001-0069-0
曹志先, 魏良琰. 用算子分裂法解Burgers方程[J]. 武汉水利水电学院学报, 1991, 24 (2): 193-201. Shi, F., Liang, G., Zhao, Y. and Zou. J. (2014) New Splitting Methods for Convection-Dominated Diffusion Problems and Navier-Stokes Equations. Communications in Computational Physics, 16, 1239-1262.
https://doi.org/10.4208/cicp.031013.030614a
Baidu
map