求解双曲守恒律方程的MUSCL-Hancock熵相容格式
MUSCL-Hancock Entropy Consistent Scheme for Solving Hyperbolic Conservation Laws
摘要: 本文提出了一种基于MUSCL-Hancock方法求解双曲守恒律方程的熵相容格式(EC-MHM格式),新格式在空间上利用MUSCL-Hancock方法对数据进行重构,并对重构后的斜率进行修正,得到高分辨率的熵相容通量;在时间上,利用双曲守恒律方程的差分形式更新下一时刻的值,更新下一时刻变量值时只需计算一次数值通量,从而提高了格式的计算效率;最后对不同的双曲守恒律方程进行数值模拟,结果表明,EC-MHM格式具有无振荡、高分辨率、高精度等良好特性。
Abstract: In this paper, an entropy consistent scheme (EC-MHM scheme) based on the MUSCL-Hancock meth-od for hyperbolic conservation laws is proposed. The new scheme uses the MUSCL-Hancock method to reconstruct the data spatially, and corrects the slope after the reconstruction to obtain a high-resolution entropy consistent flux. The value of the new time moment is updated by conserva-tive difference scheme of the hyperbolic conservation laws, and the numerical flux only needs to be calculated once when the variable value of the next moment is updated, which improves the com-putational efficiency of the scheme. Different hyperbolic conservation laws are numerically solved, and the numerical results show that the EC-MHM scheme has good characteristics such as non-oscillation, high resolution, and robustness.
文章引用:陈柳诗, 封建湖, 王晴. 求解双曲守恒律方程的MUSCL-Hancock熵相容格式[J]. 应用数学进展, 2023, 12(9): 3886-3898. https://doi.org/10.12677/AAM.2023.129382

1. 引言

一维双曲守恒律方程组的一般形式为

t u + x f ( u ) = 0 (1)

其中 u = u ( x , t ) 是守恒型变量, ( x , t ) R × R + R × R + R N ( N 1 ) f ( u ) 是光滑的通量函数。双曲守恒律方程是计算流体力学中一类反映物理现象及其规律的重要方程,如气体动力学中的Euler方程、浅水动力学中的浅水波方程等,这些方程所涉及的物理模型在航天航空、气象、海洋等领域应用广泛,因此对该类方程的求解具有重要意义。研究非线性双曲守恒律的主要困难是:即使初值函数光滑,其解在时间推进的某个时刻也可能会出现间断,产生激波、接触间断等。间断解的出现使双曲守恒律方程的解违背了古典解理论,于是Lax在1954年提出了弱解 [1] 的概念,允许间断解存在,这为数值方法更好的发展打下了良好的基础。但是由于弱解不惟一,很多数值方法无法保证这种弱解具有物理意义。我们知道,任何物理的问题都存在粘性机制,而在数学上求解时可以认为粘性是接近于零的。当“粘性消失”时得到的Cauchy问题的解在任何时刻惟一且有物理意义,这种解称为熵解。1973年Lax从物理学中的热力学第二定律出发,在文献 [2] 中证明了熵稳定条件等价于这种“粘性消失”的机制,并由一个单元熵不等式来表示:

U ( u ) t + F ( u ) x 0 (2)

其中 u 是惟一的具有物理意义的解, U ( u ) u 的凸函数,称为熵函数,满足 U ( u ) > 0 F ( u ) 是熵通量函数。满足式(2)的 U ( u ) F ( u ) 被称为熵对。为了满足熵稳定条件,同时避免非物理解的产生,长期以来人们的做法是引入额外的耗散来控制熵的变化。

为合理地研究熵稳定与数值粘性之间的关系,1987年Tadmor在文献 [3] 里引入熵变量和熵势的概念,构造了一类二阶的熵守恒格式,其数值通量保持总熵不变。他还同时提出一种关于数值粘性更精确量化的比较原则,即:如果一个三点守恒型格式含有比熵守恒格式更多的数值粘性,则该三点守恒型格式是熵稳定的。但是具体应该添加多少数值粘性,一直是研究人员探索的问题。2004年,Tadmor提出一种逐段分解的显式构造方法来得到守恒型方程组的熵守恒数值通量,该方法可用于各种守恒型系统 [4] 。结合熵稳定格式的定义,Tadmor和Zhong把该方法应用于Navier-Stokes方程组 [5] 和浅水波方程 [6] ;数值实验表明这种方法只有在网格划分非常细密时才有效。2006年,Roe提出在熵守恒格式的基础上加上他本人提出的Roe格式的数值粘性的方法,得到了一类熵稳定格式,称为ERoe格式 [7] 。随后Roe和Ismail通过进一步分析得到:对于Euler方程,解在跨过激波时产生了激波强度立方量级的熵增,并在此基础上发展了对数值粘性项更精确量化的熵相容格式 [8] 。熵相容格式是目前对熵的变化估计得最精确的一种熵稳定格式,但Roe和Ismail的熵相容格式只有一阶精度,对间断的分辨率较低。

Van Leer提出的MUSCL数据重构方法 [9] 是求解双曲守恒律方程的一种高阶方法,通过MUSCL数据重构得到了许多高阶格式,如MUSCL-Hancock方法,广义黎曼问题法和斜率限制中心格式等 [9] ;2021年,任璇、封建湖提出了一种以MUSCL数据重构为基础的斜率限制器方法 [10] ,有效地提高了熵相容格式的精度和分辨率;随后沈亚玲等 [11] 将该斜率限制器方法应用到理想磁流体动力学(MHD)方程中,并通过数值模拟验证了该格式是求解MHD方程的一种较为理想的方法。本文进一步研究熵相容格式,利用MUSCL-Hancock方法构造一种在时间和空间上全离散的二阶高分辨率熵相容格式,数值结果表明新格式具有稳健性、高精度性和无振荡性等良好特征并且能够提高计算效率。

2. 熵相容格式

2.1. 一维双曲守恒律方程

2.1.1. 熵守恒格式

一维双曲守恒律方程(1)的半离散格式为

d d t u i ( t ) = 1 Δ x ( f i + 1 / 2 f i 1 / 2 ) (3)

熵守恒格式能够保持总熵不变,在离散条件下满足单元熵等式

d d t U ( u i ( t ) ) + 1 Δ x ( F i + 1 / 2 F i 1 / 2 ) = 0 (4)

其中 U ( u i ( t ) ) 为凸的熵函数, F i + 1 / 2 为数值熵通量函数。Tadmor在文献 [3] 中给出满足上述熵守恒条件的数值通量 f i + 1 / 2 C ,该数值通量与熵变量和熵势的关系为:

[ v ] i + 1 / 2 T f i + 1 / 2 C = [ ψ ] i + 1 / 2 (5)

式(4)中的数值熵通量为 F i + 1 / 2 = v i + 1 / 2 T f i + 1 / 2 C ψ ¯ i + 1 / 2 [ ] i + 1 / 2 = ( ) i + 1 ( ) i [ ] ¯ i + 1 / 2 = ( ) i + 1 ( ) i 2 ,熵势 ψ = v T f F ,则称 f i + 1 / 2 C 是熵守恒格式的数值通量。

当计算标量情况下的双曲守恒律方程时,用公式(5)进行计算,可得到熵守恒通量 f i + 1 / 2 C 的惟一表达形式

f i + 1 / 2 C = [ ψ ] i + 1 / 2 [ v ] i + 1 / 2 = ψ i + 1 ψ i v i + 1 v i (6)

2.1.2. 熵相容格式

熵守恒格式能够保持总熵不变,在光滑区域具有良好的表现且具有二阶精度,但是当间断解出现时熵会增加,使得熵守恒格式的数值解出现伪振荡。2006年Roe提出在熵守恒的基础上添加一个Roe-耗散项得到熵稳定格式,1999年Barth证明了 u v R R T [12] ,将Roe-耗散项进一步调整为如下形式

D i + 1 / 2 E S = 1 2 R i + 1 / 2 | Λ i + 1 / 2 | R i + 1 / 2 T [ v ] i + 1 / 2 (7)

其中 | Λ i + 1 / 2 | = d i a g ( | λ i + 1 / 2 1 | , , | λ i + 1 / 2 N | ) A ( u ) = d f d u 的特征值矩阵, R A ( u ) = d f d u 的右特征向量构成的矩阵,得到熵稳定格式的数值通量 f i + 1 / 2 E S

f i + 1 / 2 E S = f i + 1 / 2 C D i + 1 / 2 E S = f i + 1 / 2 C 1 2 R i + 1 / 2 | Λ i + 1 / 2 | R i + 1 / 2 T [ v ] i + 1 / 2 (8)

与熵守恒格式相比,熵稳定格式只多了耗散项 D i + 1 / 2 E S ,但是这个耗散项有时不足以抵消跨越间断所产生的熵增,这使得在数值实验中,该耗散项在激波附近仍然可能出现伪振荡。对于Euler方程,Ismail和Roe曾经证明了在有激波时系统的熵增约为密度跳跃的立方 [8] ,因此需要在上述的熵稳定通量中再添加一项使之产生 O ( [ u ] 3 ) 的熵增,本文将采用文献 [10] 中的熵相容通量

f i + 1 / 2 E C = f i + 1 / 2 C D i + 1 / 2 E S D i + 1 / 2 E P f i + 1 / 2 C 1 2 R i + 1 / 2 ( | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ) R i + 1 / 2 T [ v ] i + 1 / 2 (9)

其中, s k 是高斯点, w k 是与高斯点对应的系数,积分区间为[0, 1],在这里采用Gauss-Legendre积分公式,此时 s 1 , 3 = 1 2 ± 15 10 s 2 = 1 2 w 1 , 3 = 5 9 w 2 = 8 9

D i + 1 / 2 = | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ,则上式可简记为

f i + 1 / 2 E C = f i + 1 / 2 C 1 2 R i + 1 / 2 | D i + 1 / 2 | R i + 1 / 2 T [ v ] i + 1 / 2 (10)

在标量情况下,熵相容格式的数值通量为

f i + 1 / 2 E C = f i + 1 / 2 C D i + 1 / 2 E S D i + 1 / 2 E P = f i + 1 / 2 C 1 2 | a ( u i + 1 / 2 ) | [ v ] i + 1 / 2 1 2 | 0 1 ( 2 ξ 1 ) a ( u ( ξ ) ) U u u ( ξ ) d ξ | [ v ] i + 1 / 2 (11)

其中 a ( u ) 是特征速度,记 D i + 1 / 2 = | a ( u i + 1 / 2 ) | + | 0 1 ( 2 ξ 1 ) a ( u ( ξ ) ) U u u ( ξ ) d ξ | ,则上式可简

化为

f i + 1 / 2 E C = f i + 1 / 2 C 1 2 D i + 1 / 2 [ v ] i + 1 / 2 (12)

在文献 [10] 中已证明该熵相容格式是收敛的。

对于一维无粘Burgers方程

u t + f ( u ) x = 0 (13)

其中, f ( u ) = u 2 / 2 ,熵函数为 U ( u ) = u 2 / 2 ,熵通量函数为 F ( u ) = 2 u 2 / 3 ,特征值为 a ( u ) = u ,进而得到熵变量 v ( u ) = U ( u ) = u ,熵势 ψ ( u ) = v ( u ) f ( u ) F ( u ) = u 3 / 6 ,由式(6)可得出Burgers方程的熵守恒数值通量为 f j + 1 / 2 C = ( u j 2 + u j u j + 1 + u j + 1 2 ) / 6 ,最终得到Burgers方程的熵稳定数值通量和熵相容数值通量分别为

f i + 1 / 2 E S = f i + 1 / 2 C 1 4 | u i + u i + 1 | ( u i + 1 u i ) (14)

f i + 1 / 2 E C = f i + 1 / 2 C 1 2 ( 1 2 | u i + u i + 1 | + 1 6 | u i + 1 u i | ) ( u i + 1 u i ) (15)

2.2. 一维浅水波方程

考虑描述浅水情况下流体运动规律的浅水波方程,具有以下守恒格式:

t [ h h u ] + x [ h u g h 2 / 2 + h u 2 ] = 0 (16)

其中 u = ( h , h u ) T ,h是水深,u是速度,g是重力加速度,取熵函数 U ( u ) = ( g h 2 + u 2 h ) / 2 ,熵通量为 F = h u 3 / 2 + g u h 2 ,熵变量为 v = U ( u ) = [ g h u 2 / 2 , u ] T 。熵守恒的数值通量采用Fjordholm在文献 [13] 所提出的浅水波方程的显式熵守恒格式的数值通量:

F i + 1 2 C = ( h ¯ i + 1 2 u ¯ i + 1 2 g 2 ( h 2 ¯ ) i + 1 2 + h ¯ i + 1 2 ( u ¯ i + 1 2 ) 2 ) (17)

其中 ( ) ¯ = ( ( ) i + ( ) i + 1 ) / 2 ( ) 2 ¯ = ( ( ) i 2 + ( ) i + 1 2 ) / 2

最终得到浅水波方程的熵稳定格式和熵相容格式的数值通量分别为

f i + 1 / 2 E S = f i + 1 / 2 C 1 2 R i + 1 / 2 | Λ i + 1 / 2 | R i + 1 / 2 T [ v ] i + 1 / 2 (18)

f i + 1 / 2 E C = f i + 1 / 2 C 1 2 R i + 1 / 2 ( | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ) R i + 1 / 2 T [ v ] i + 1 / 2 (19)

其中 s 1 , 3 = 1 2 ± 15 10 s 2 = 1 2 w 1 , 3 = 5 9 w 2 = 8 9 ,对应雅可比矩阵的特征值矩阵为

Λ = [ u g h u + g h ] (20)

使用Roe平均值计算的平均特征值和特征向量矩阵为

Λ i + 1 / 2 = [ u ¯ g h ¯ u ¯ + g h ¯ ] R i + 1 / 2 = 1 2 g [ 1 1 u ¯ g h ¯ u ¯ + g h ¯ ] (21)

2.3. 一维欧拉方程

考虑无粘可压缩气体动力学中的Euler方程

t [ ρ ρ u E ] + x [ ρ u ρ u 2 + p ( E + p ) u ] = 0 (22)

其中 ρ , u , p 分别代表气体的密度,速度,压力。总熵定义为 E = p / ( γ 1 ) + ρ u 2 / 2 ,总焓为 H = ( E + p ) / ρ γ 为理想气体数字,取 γ = 1.4 。Euler方程的熵对为

U = ρ S γ 1 F = ρ u S γ 1 (23)

其中S为物理熵。由熵变量 v = U u 可知

v = [ γ S γ 1 ρ u 2 2 p , ρ u p , ρ p ] T (24)

本文采用Ismail和Roe所提出的Euler方程的熵守恒格式 [8] ,具体的熵守恒格式的数值通量为

f i + 1 / 2 C = [ ρ ^ u ^ ρ ^ u ^ 2 + p ^ 1 ρ ^ u ^ H ^ ] (25)

其中参数变量Z为

Z = [ z 1 , z 2 , z 3 ] T = ρ / p [ 1 , u , p ] T (26)

( ) ^ 表示在单元交界面处的平均值,满足:

ρ ^ = z 1 ¯ z 3 ln , u ^ = z 2 ¯ / z 1 ¯ , p ^ 1 = z 3 ¯ / z 1 ¯ a ^ = γ p ^ 2 / ρ ^ 2 (27)

p ^ 2 = γ + 1 γ z 3 ln z 1 ln + γ 1 2 γ z ¯ 3 z ¯ 1 , H ^ = a ^ 2 γ 1 + u ^ 2 2 (28)

在上式中, a ¯ = a l + a r 2 表示算术平均, a ln = a l a r ln a i ln a r ( a l a r ) a ln = a l , ( a l = a r ) ,表示对数平均。在这里选用文献 [10] 中的熵稳定通量和熵相容通量,分别为

f i + 1 / 2 E S = f i + 1 / 2 C 1 2 R i + 1 / 2 Λ i + 1 / 2 S i + 1 / 2 R i + 1 / 2 T [ v ] i + 1 / 2 (29)

f i + 1 / 2 E C = f i + 1 / 2 C 1 2 R i + 1 / 2 D i + 1 / 2 S i + 1 / 2 R i + 1 / 2 T [ v ] i + 1 / 2 (30)

其中 D i + 1 / 2 = ( | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ) S i + 1 / 2 = d i a g ( ρ ^ 2 γ , ( γ 1 ) ρ ^ γ , ρ ^ 2 γ ) s 1 3 = 1 2 ± 15 10 s 2 = 1 2 w 1 , 3 = 5 9 w 2 = 8 9 Λ 就是雅可比矩阵A的特征值矩阵,有

Λ = d i a g ( u a , u , u + a ) (31)

3. 基于MUSCL方法的熵相容格式

本文所涉及的熵稳定格式、熵相容格式和基于MUSCL数据重构的熵相容格式,为了在时间方向达到二阶精度,对半离散格式均采用二阶精度的强稳定的两步Runge-Kutta方法 [14]

{ u * = u n + Δ t L ( u n ) u * * = u * + Δ t L ( u * ) u n + 1 = 0.5 ( u n + u * * ) (32)

t n 层的单元边界处进行重构, u ( x ) 表示双曲守恒律方程的精确解,在每个控制单元 I i = [ x i 1 / 2 , x i + 1 / 2 ] 上可以表示为分段的精确解 u i ( x ) ,在这里对每个 u i ( x ) 进行线性重构,记重构后的函数为 R i ( x ) ,表示如下:

R i ( x ) = u i n + ( u x ) i ( x x i ) , x j 1 / 2 < x < x j + 1 / 2 (33)

R i ( x ) 在左右两个交界面处的极限值分别为

R i L = R i ( x i 1 / 2 ) = u i n 1 2 Δ x ( u x ) i R i R = R i ( x i + 1 / 2 ) = u i n + 1 2 Δ x ( u x ) i (34)

R i L R i R 被称为边界外推值。通过MUSCL数据重构,得到的基于MUSCL数据重构的熵相容格式在大梯度附近会产生杂散振荡,为此我们采用广义的minmod限制器,使得解在光滑区域选择高阶的数据重构,在间断区域选择原始数据,从而避免产生伪振荡。具体形式如下(在第5节的算例中 α 值取2):

( u x ) i = min mod ( α u i u i 1 Δ x , u i + 1 u i 1 2 Δ x , α u i + 1 u i Δ x ) , 1 < α < 2 (35)

其中,minmod函数定义为

min mod ( a 1 , a 2 , a 3 , ) : = { min { a i } , a i > 0 , i max { a i } , a i < 0 , i 0 , otherwise (36)

将公式(34)分别代入Burgers方程、浅水波方程、Euler方程的熵相容通量,得到基于MUSCL数据重构的熵相容通量:

f i + 1 / 2 E C M U S C L = f i + 1 / 2 C 1 2 ( 1 2 | R i + 1 L + R i R | + 1 6 | R i + 1 L R i R | ) ( R i + 1 L R i R ) (37)

f i + 1 / 2 E C M U S C L = f i + 1 / 2 C 1 2 R i + 1 / 2 ( | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ) R i + 1 / 2 T [ v ] i + 1 / 2 L i m i t e d 1 (38)

f i + 1 / 2 E C M U S C L = f i + 1 / 2 C 1 2 R i + 1 / 2 ( | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ) S i + 1 / 2 R i + 1 / 2 T [ v ] i + 1 / 2 L i m i t e d 1 (39)

其中 [ v ] i + 1 / 2 L i m i t e d 1 是重构后的熵变量值。在双曲守恒律方程中,上述的构造方法是先将守恒变量 u 转化为原始变量进行重构,再将重构后的值代回熵变量,最终得到基于MUSCL重构的高分辨率熵相容通量 f i + 1 / 2 E C M U S C L

4. 基于MUSCL-Hancock方法的熵相容格式

第3节提及的两步龙格库塔法需要在单元边界处需要求解两次数值通量,但采用MUSCL-Hancock方法来更新下一时间层的物理量,是一个全离散过程,在单元交界面处只需求解一次数值通量,从而可以有效地提高格式的计算效率。计算过程如下:

第一步:在 t n 层重构 u i ( x ) 在单元交界面处的左右极限值,与第3节的过程一致,结果为 R i L R i R

第二步:利用下式将 t n 层的边界外推值 R i L R i R 推进到 t n + 1 / 2 层得到相应的边界外推值:

R ¯ i L = R i L 1 2 Δ t Δ x [ f ( R i R ) f ( R i L ) ] R ¯ i R = R i R 1 2 Δ t Δ x [ f ( R i R ) f ( R i L ) ] (40)

第三步:利用4.2得到的边界外推值分别代入Burgers方程、浅水波方程、Euler方程的熵相容通量得到基于MUSCL-Hancock方法的熵相容通量:

f i + 1 / 2 E C M H M = f i + 1 / 2 C 1 2 ( 1 2 | R ¯ i + 1 L + R ¯ i R | + 1 6 | R ¯ i + 1 L R ¯ i R | ) ( R ¯ i + 1 L R ¯ i R ) (41)

f i + 1 / 2 E C M H M = f i + 1 / 2 C 1 2 R i + 1 / 2 ( | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ) R i + 1 / 2 T [ v ] i + 1 / 2 L i m i t e d 2 (42)

f i + 1 / 2 E C M H M = f i + 1 / 2 C 1 2 R i + 1 / 2 ( | Λ i + 1 / 2 | + | k = 1 q w k ( 2 s k 1 ) Λ ( u ( s k ) ) | ) S i + 1 / 2 R i + 1 / 2 T [ v ] i + 1 / 2 L i m i t e d 2 (43)

在这里熵相容的通量的计算方法与第3节相同。

利用上述得到的基于MUSCL-Hancock方法的熵相容通量 f i + 1 / 2 E C M H M ,在这里我们可以更新 t n + 1 时刻的单元平均值,公式如下:

u j n + 1 = u j n Δ t Δ x ( f i + 1 / 2 E C M H M f i 1 / 2 E C M H M ) (44)

5. 数值算例

Burgers方程、一维浅水波方程、一维欧拉方程的熵稳定通量分别为(14),(18),(29),熵相容通量分别为(15),(19),(30),基于MUSCL方法的熵相容通量分别为(37),(38),(39),基于MUSCL-Hancock方法的熵相容通量分别为(41),(42),(43),进行数值模拟,通过数值结果说明所构造的EC-MHM格式具有更好的性质。

符号约定:

ES:熵稳定格式;EC:熵相容格式;EC-MUSCL:基于MUSCL重构的熵相容格式;EC-MHM:基于MUSCL-Hancock方法的熵相容格式;Exact:精确解;Ref:参考解。

5.1. 一维Burgers方程

对于一维Burgers方程的不同初值问题,在下面的实验中均采取40网格进行计算。

5.1.1. 间断初值问题

在区间[−1, 1]上考虑初值问题

u ( x , 0 ) = { 1 , if 1 / 3 | x | 1 1 , if | x | < 1 / 3

该问题的解析解为

u ( x , t ) = { 1 , if t 1 / 3 < x < 1 / 3 ( x + 1 3 ) / t , if t 1 / 3 < x < t 1 / 3 1 , otherwise

使用Neumann边界条件,计算至t = 0.32,CFL = 0.3,计算结果如图1所示,ES格式在激波附近会产生振荡,相比之下,EC格式具有更高的分辨率,并且能够更准确的捕捉激波,但二者在稀疏波区域的音速点处仍会产生膨胀激波。而EC-MUSCL格式和EC-MHM格式则具有更好的数值结果,能够准确捕捉稀疏波和激波,并消除振荡。从熵耗散图可以看出EC-MUSCL格式和EC-MHM格式的熵耗散介于ES格式和EC格式之间,既提高了稳定性也提高了计算结果的准确性;二者相比,EC-MHM格式比EC-MUSCL格式耗散更少,同时也具有更高的分辨率。

Figure 1. Results of example 1

图1. 算例1数值结果

5.1.2. 可压缩波问题

在区域[−1, 1]上考虑初值问题

u ( x , 0 ) = { u 0 , if | x | > 1 u 0 u 1 sin ( π x ) , if | x | 1

其中振幅 u 1 = 0.5 u 0 = 0 。它的解析解为

u ( x , t ) = u 0 u 1 sin ( π x u u 1 u 1 t )

使用Neumann边界条件,计算至t1 = 0.32,CFL = 0.3,计算结果如图2所示,在解的连续区域,ES格式和EC格式对解的捕捉效果差别甚微,而EC-MUSCL格式和EC-MHM格式的计算结果则更优;在表1中给出了EC-MUSCL格式和EC-MHM格式在t1 = 0.32时的L1误差和阶数,结果表明EC-MHM格式比EC-MUSCL格式具有更小的误差和更高的精度,因此EC-MHM格式的计算结果也是最佳的;在表2中给出了EC-MUSCL格式和EC-MHM格式在t1 = 0.32时程序的计算时间及EC-MHM格式和EC-MUSCL格式计算时间的比值,结果表明EC-MHM格式具有更高的计算效率,这与前文的理论分析也是一致的。

Figure 2. Results of example 2

图2. 算例2数值结果

Table 1. EC-MUSCLand EC-MHM scheme computers the order of error and convergence up to t = 0.32 s

表1. EC-MUSCL和EC-MHM格式计算到t = 0.32 s的误差和收敛阶

Table 2. Comparison of computation time between EC-MUSCL and EC-MHM scheme

表2. EC-MUSCL和EC-MHM格式的计算时间比较

5.2. 一维浅水波方程

考虑在不同初始条件的溃坝问题,都使用Neumann边界条件,这些问题的精确解都是由一个向左的稀疏波和一个向右的激波组成。在区域[−1, 1]上,设初始条件为

h ( x , 0 ) = { 2 x < 0 1.5 x 0 u ( x , 0 ) = 0

取100个网格点,CFL = 0.45,计算至t = 0.4。

该问题的参考解为1200网格点时Roe格式的计算结果。从图3中可以看出,ES格式和EC格式均可以抑制膨胀激波的产生,但是二者都有明显的抹平现象,而EC-MUSCL格式和EC-MHM格式具有更小的熵耗散,因此可以更好地捕捉稀疏波和激波;与EC-MUSCL格式相比,EC-MHM格式对稀疏波和激波的捕捉效果都要更好,具有更高的分辨率。

5.3. Euler方程

5.3.1. Lax激波管问题

考虑在区间[0, 1]上的初值问题

( ρ , u , p ) = { ( 0.445 , 0.698 , 3.528 ) , if x < 0.5 ( 0.5 , 0 , 0.571 ) , otherwise

使用Neumann边界条件,CFL = 0.15,取200个网格点,计算至t = 0.16。

该问题的精确解由一个左稀疏波,一个中间的接触间断和一个右激波。关于密度的计算结果和总熵随时间的变化图如图4所示,EC格式和ES格式在间断位置的抹平都比较严重,相比之下,EC-MUSCL格式和EC-MHM格式在激波和接触间断处则表现出更准确的捕捉效果;EC-MUSCL格式在接触间断结束的位置会出现轻微的振荡,而EC-MHM格式能够更好的捕捉接触间断而不会产生振荡。

Figure 3. Results of example 3

图3. 算例3数值结果

Figure 4. Results of example 4

图4. 算例4数值结果

5.3.2. Shu-Osher问题

该问题是关于激波和熵波相互作用的问题 [15] ,它的解既包含激波又包含复杂的连续解,考虑在区间[−5, 5]上的Shu-Osher问题,给定初始条件

( ρ , u , p ) = { ( 3.857143 , 2.629369 , 10.333333 ) , 5 x < 4 ( 1 + 0.2 sin ( 5 x ) , 0 , 1 ) , 4 x < 5

使用Neumann边界条件,CFL = 0.1分别取400个网格点和800个网格点,计算至t = 1.8。

以4000网格的高分辨率熵相容格式 [16] 的数值结果作为参考解。关于密度的计算结果如图5所示,ES格式和EC格式能够捕捉精确解的结构,但是抹平现象严重,而EC-MHM格式和EC-MUSCL格式则具有更高的分辨率,从密度图中可以明显看出,EC-MHM格式比EC-MUSCL格式能够更准确地捕捉精确解,这也说明EC-MHM具有一定的实用性。

Figure 5. Results of example 5

图5. 算例5数值结果

5.3.3. 爆炸波问题

考虑在区域[−0.5, 0.5]上的爆炸波问题,给定初始条件

( ρ , u , p ) = { ( 1.0 , 0 , 1000 ) , 0.5 < x < 0.4 ( 1.0 , 0 , 0.01 ) , 0.4 < x < 0.4 ( 1.0 , 0 , 100 ) , 0.4 < x < 0.5

使用反射边界条件,取CFL = 0.005,计算至0.038,空间网格数为N = 400和800。

爆炸波解的结构很复杂,常用来检验数值格式捕捉激波的能力。从图6中可以看出四种格式都可以用来计算这个问题,但是EC-MHM具有更好的分辨力。因此在解决复杂波问题时,EC-MHM格式既能够更好地模拟精确解的结构同时还可以提高计算效率,节省时间。

Figure 6. Results of example 6

图6. 算例6数值结果

6. 结论

本文构造了一种基于MUSCL-Hancock方法的熵相容格式,相比其它的熵相容格式而言,新的EC-MHM格式具有二阶精度,同时它只需在每个时间层 [ t n , t n + 1 ] 的中间时刻tn+1计算一次数值通量,从而达到提高计算效率的目的;若干数值结果表明,新的EC-MHM格式具有高精度、高分辨率和鲁棒等特性。该格式是求解双曲守恒律方程的一种较好的方法,后续可以将这种方法进一步推广到二维甚至更高维。

NOTES

*通讯作者。

参考文献

[1] Lax, P.D. (1954) Weak Solutions of Nonlinear Hyperbolic Equations and Their Numerical Computation. Communica-tions on Pure & Applied Mathematics, 7, 159-193.
https://doi.org/10.1002/cpa.3160070112
[2] Lax, P.D. (1973) Hyperbolic Systems of Conservation Laws and the Mathematical Theory of Shock Waves. Society for Industrial and Ap-plied Mathematics, University City, 1-48.
https://doi.org/10.1137/1.9781611970562.ch1
[3] Tadmor, E. (1987) The Numerical Viscosity of Entropy Stable Schemes for Systems of Conservation Laws. I. Mathematics of Computation, 49, 91-103.
https://doi.org/10.1090/S0025-5718-1987-0890255-3
[4] Tadmor, E. (2003) Entropy Stability Theory for Difference Approximations of Nonlinear Conservation Laws and Related Time-Dependent Problems. Acta Numerica, 12, 451-512.
https://doi.org/10.1017/S0962492902000156
[5] Tadmor, E. and Zhong, W. (2006) Entropy Stable Approximations of Navier-Stokes Equations with No Artificial Numerical Viscosity. Journal of Hyperbolic Differential Equations, 3, 529-559.
https://doi.org/10.1142/S0219891606000896
[6] Tadmor, E. and Zhong, W. (2008) Energy-Preserving and Stable Approximations for the Two-Dimensional Shallow Water Equations. Springer, Berlin.
https://doi.org/10.1007/978-3-540-68850-1_4
[7] Roe, P.L. (2006) Affordable, Entropy-Consistent Euler Flux Functions. The 11th International Conference on Hyperbolic Problems: Theory, Numerics, Applications, Lyon, 17-21 July 2006, 9-15.
[8] Ismail, F. and Roe, P.L. (2009) Affordable, Entropy-Consistent Euler Flux Functions II: Entropy Production at Shocks. Journal of Computational Physics, 228, 5410-5436.
https://doi.org/10.1016/j.jcp.2009.04.021
[9] Toro, E.F. (2009) Riemann Solvers and Numerical Methods for Fluid Dynamics: A Practical Introduction. Springer, Berlin.
https://doi.org/10.1007/b79761
[10] 任璇. 基于斜率限制器的高分辨率熵相容格式研究[D]: [硕士学位论文]. 西安: 长安大学, 2021.
[11] 沈亚玲, 封建湖, 郑素佩, 等. 一种基于新型斜率限制器的理想磁流体方程的高分辨率熵相容格式[J]. 计算物理, 2022, 39(3): 297-308.
[12] Barth, T.J. (1999) Numerical Methods for Gas Dynamic Systems on Unstructured Meshes. Springer, Berlin, 195-285.
https://doi.org/10.1007/978-3-642-58535-7_5
[13] Fjordholm, U.S., Mishra, S. and Tadmor, E. (2009) Energy Preserving and Energy Stable Schemes for the Shallow Water Equations. In: Cucker, F., et al., Eds., Foundations of Computational Mathematics, Hong Kong 2008, Cambridge University Press, Cambridge, 93-139.
https://doi.org/10.1017/CBO9781139107068.005
[14] Shu, C.W. and Osher, S. (1988) Efficient Implementation of Essentially Non-Oscillatory Shock-Capturing Schemes. Journal of Computational Physics, 77, 439-471.
https://doi.org/10.1016/0021-9991(88)90177-5
[15] Shu, C.W. and Osher, S. (1989) Efficient Implementation of Essentially Non-Oscillatory Shock-Capturing Schemes, II. Journal of Computational Physics, 83, 32-78.
https://doi.org/10.1016/0021-9991(89)90222-2
[16] 任炯, 封建湖, 刘友琼, 等. 求解双曲守恒律方程的高分辨率熵相容格式[J]. 计算物理, 2014, 31(5): 539-551.