使用python对于盐度对流差分格式设计与讨论
题目要求如下:
差分格式设计如下:
方案1、蛙跳格式(时间和距离都用中央差)
python代码如下:
"""
Created on %(date)s
@author: %(jixianpu)s
Email : 211311040008@hhu.edu.cn
introduction : keep learning althongh walk slowly
"""
"""
分析说明:μ<1时,蛙跃格式是稳定的,但是会有频散现象发生,耗散比较小,盐度场峰值基本保持不变;μ>1时,明显看到格式不稳定。
"""
import numpy as np
import matplotlib.pyplot as plt
ss=np.zeros((2002,1002))
dx=10
u=1
dt=5
#mu=u*dt/dx;
mu=1.1 #1.01,0.01,0.05
ss[0,300:401]=10
for n in range(2001):
for j in range(1001):
if (n==1)&(j==1):
s1=ss[n,j]
s2=ss[n,j]
ss[n+1,j]=s1+mu*(-ss[n,j+1]+s2)
elif n==1 & j!=1:
s1=ss[n,j]
ss[n+1,j]=s1+mu*(-ss[n,j+1]+ss[n,j-1])
elif j==1 &n!=1:
s2=ss[n,j]
ss[n+1,j]=ss[n-1,j]+mu*(-ss[n,j+1]+s2)
else :
ss[n+1,j]=ss[n-1,j]+mu*(-ss[n,j+1]+ss[n,j-1])
plt.rcParams['axes.unicode_minus'] = False
fig=plt.figure(figsize=(15,15))
ax=fig.add_subplot(1,1,1)
ax.plot(ss[1000])
# ax.set_xlim(0,1000)
# ax.set_ylim(-3,14)
ax.set_xlabel('area range',fontsize=30)
ax.set_ylabel('salinity',fontsize=30)
ax.tick_params(which='major',direction='out', pad=8,labelsize=25,length=10,\
axis='both',bottom=True, left=True, right=False, top=False)
ax.set_title('t=1000s',fontsize=30)
图片如下:
分析结论:
μ<1时,蛙跃格式是稳定的,但是会有频散现象发生,耗散比较小,盐度场峰值基本保持不变;μ>1时,明显看到格式不稳定。
方案2、迎风格式(时间用前差,距离用后差)
python 核心代码如下:
for n in range(2001):
for j in range(1001):
if (j==1):
s1=ss[n,j]
ss[n+1,j]=ss[n,j]-mu*(ss[n,j]-s1)
else :
ss[n+1,j]=ss[n,j]-mu*(ss[n,j]-ss[n,j-1])
图片如下:
分析结论:
在μ<1时,迎风格式是稳定的,没有发生频散,但是发生耗散,盐柱的棱角变得圆滑。μ>1时,格式变得不稳定。。
方案3、欧拉格式(时间用前差,距离用中央差)
python 核心代码:
for n in range(2001):
for j in range(1001):
if (j==1):
s1=ss[n,j]
ss[n+1,j]=ss[n,j]-0.5*mu*(ss[n,j+1]-s1)
else :
ss[n+1,j]=ss[n,j]-0.5*mu*(ss[n,j+1]-ss[n,j-1])
图片如下:
分析结论:
欧拉法是一种绝对不稳定的格式,无论mu取多小,都是不稳定的
方案4、lax格式(在欧拉格式右边增加一个耗散项)
python 核心代码:
mu=1.1
miu2=u*u*dt/(dx*dx)
for n in range(2001):
for j in range(1001):
if (j==1):
s1=ss[n,j]
ss[n+1,j]=ss[n,j]-0.5*mu*(ss[n,j+1])+0.5*mu*s1+miu2*ss[n,j+1]-2*miu2*ss[n,j]+miu2*s1
else :
ss[n+1,j]=ss[n,j]-0.5*mu*(ss[n,j+1])+0.5*mu*ss[n,j-1]+miu2*ss[n,j+1]-2*miu2*ss[n,j]+miu2*ss[n,j-1]
图片如下:
分析结论:
在μ<1时,此格式是稳定的,有少许频散,耗散也比较少,盐度值是比较稳定的。
在μ>1时,格式不稳定。
ps:代码可能有点粗糙,只是简单记录一下,欢迎评论讨论。
一个努力学习python的海洋人
水平有限,欢迎指正!!!
欢迎评论、收藏、点赞、转发、关注。
关注我不后悔,记录学习进步的过程~~