吾生有涯 学海无涯
析模有界 知识无界

【Python-CFD】03:CFL条件

内容纲要

在前面【Python-CFD】02:线性对流方程中,所采用的计算参数是固定的(具有固定的时间步长和网格尺寸),下面尝试着更改这些参数,看看对于计算结果是否存在影响。

还是用上次的代码做测试,为了方便测试,对代码进行简单封装,代码如下(相同的代码,这里就不注释了):

import numpy as np
import matplotlib.pyplot as plt

def linearconv(nx):
   dx = 2/(nx -1)
   nt = 20
   dt = 0.025
   c = 1
   u = np.ones(nx)
   u[int(0.5/dx):int(1/dx+1)] = 2
   un = np.ones(nx)
   plt.plot(np.linspace(0,2,nx),u,'b',lw=3,label='origin')
   for n in range(nt):
       un = u.copy()
       for i in range(1,nx):
           u[i] = un[i]- c* dt / dx * (un[i] - un[i-1])
   plt.plot(np.linspace(0,2,nx),u,'r',lw=3,label='current')
   plt.legend()
   plt.show()

下面通过改变网格尺寸(即dx的数量),来观察计算结果。

linearconv(41) #网格数为41

这里用step1的参数计算结果作为参考,这里可以看到,波形存在较大的扩散,随时间推移,波形与初始形状偏离严重。

linearconv(61)


可以看出,随着网格数量增加,波形失真在减小。

linearconv(71)


波形与初始形状越来越接近。 

linearconv(81)

随着网格数量增加,波形失真越来越小,可以认为是计算越来越精确。

linearconv(91)


发生了什么情况,计算已经完全偏离了初始波形,出现了错误。这其中发生了什么呢?要回答这个问题,我们必须考虑一下代码中实际发生了什么。

在时间循环的每一次迭代中,我们使用当前时刻的波的数据来估计下一个时刻中的波的速度。最初,网格点数的增加返回了更准确的答案。数值扩散较少,波形看起来比第一个例子更像方波。 

在每个时间步长内,波的传播距离大于网格尺寸dx。网格尺寸dx与总网格数量nx有关。因此,稳定计算条件需要满足下式: 

这里u为波速,σ常称之为Courant数,其值决定了计算是否稳定。在在新版本的代码中,我们采用CFL数来根据dx来计算合适的dt。

提示:

童鞋们尝试着增大时间步长试试,看看会发生什么情况。

下面改写代码:

#新代码
import numpy as np
import matplotlib.pyplot as plt
def linearconv_m(nx):
   dx = 2 / ( nx - 1 )
   nt = 20
   c = 1
   sigma = 0.5
   dt = sigma * dx
   u = np.ones(nx)
   u[int(0.5 / dx):int(1 / dx + 1)] = 2
   plt.plot(np.linspace(0,2,nx),u,'b',lw=3,label='origin')
   un = np.ones(nx)
   for n in range(nt):
       un = u.copy()
       for i in range(1,nx):
           u[i] = un[i]- c* dt / dx * (un[i] - un[i-1])
   plt.plot(np.linspace(0,2,nx),u,'r',lw=3,label='current')
   plt.legend()

测试一下新的程序代码: 

linearconv_m(90)

 

linearconv_m(180)

嗯,满足了CFL条件后,不管网格怎么加密,计算结果依然不会崩溃。

本篇文章来源于微信公众号: CFD之道

赞(1) 打赏
版权声明:未经允许,请勿随意用于商业用途。
文章名称:《【Python-CFD】03:CFL条件》
文章链接:https://www.topcfd.cn/5700/
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
分享到

说两句 抢沙发

评论前必须登录!

 

觉得文章有用就打赏一下文章作者吧

非常感谢你的打赏,我们将继续给力更多优质内容,让我们一起创建更加美好的网络世界!

支付宝扫一扫

微信扫一扫

登录

找回密码

注册