python – 使用numpy解决具有波状初始条件的传输方程
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – 使用numpy解决具有波状初始条件的传输方程,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2210字,纯文字阅读大概需要4分钟。
内容图文
![python – 使用numpy解决具有波状初始条件的传输方程](/upload/InfoBanner/zyjiaocheng/789/81ec88bcfa354fc3b9dd7d514d4c3ba2.jpg)
我正在尝试编写一个python程序,使用具有二阶空间离散和周期边界条件的显式欧拉方法来求解一阶一维波动方程(传输方程).
我是python的新手,我使用numpy编写了这个程序,但我觉得我在某个地方犯了一个错误,因为波被扭曲了.一旦它离开左边界,它似乎变得扭曲,而不是简单地向左转换.我很确定这是一个编程错误,但有可能是舍入错误吗?我没有正确使用numpy吗?有关以更多Python风格的方式编写此程序的任何建议吗?谢谢!
PDE是
它是有限差分形式
解决
这是我尝试的:
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
# wave speed
c = 1
# spatial domain
xmin = 0
xmax = 1
n = 50 # num of grid points
# x grid of n points
X, dx = np.linspace(xmin,xmax,n,retstep=True)
# for CFL of 0.1
dt = 0.1*dx/c
# initial conditions
def initial_u(x):
return np.exp(-0.5*np.power(((x-0.5)/0.08), 2))
# each value of the U array contains the solution for all x values at each timestep
U = []
# explicit euler solution
def u(x, t):
if t == 0: # initial condition
return initial_u(x)
uvals = [] # u values for this time step
for j in range(len(x)):
if j == 0: # left boundary
uvals.append(U[t-1][j] + c*dt/(2*dx)*(U[t-1][j+1]-U[t-1][n-1]))
elif j == n-1: # right boundary
uvals.append(U[t-1][j] + c*dt/(2*dx)*(U[t-1][0]-U[t-1][j-1]))
else:
uvals.append(U[t-1][j] + c*dt/(2*dx)*(U[t-1][j+1]-U[t-1][j-1]))
return uvals
# solve for 500 time steps
for t in range(500):
U.append(u(X, t))
# plot solution
plt.style.use('dark_background')
fig = plt.figure()
ax1 = fig.add_subplot(1,1,1)
# animate the time data
k = 0
def animate(i):
global k
x = U[k]
k += 1
ax1.clear()
plt.plot(X,x,color='cyan')
plt.grid(True)
plt.ylim([-2,2])
plt.xlim([0,1])
anim = animation.FuncAnimation(fig,animate,frames=360,interval=20)
plt.show()
这就是波浪的开始
这就是它在几次迭代后结束的方式
任何人都可以解释为什么这(波浪失真)正在发生?
解决方法:
您的实施是正确的.失真来自相对较大的空间步长dx.在其当前值0.2处,它与波的大小相当,这使得波在图上可见多边形.这些离散误差累积超过500步.这是我从plt.plot(X,U [-1])得到的代码:
这是我使用n = 100(时间和空间步长减半),运行范围(1000)中的t的解决方案以补偿较小的时间步长,并再次绘制plt.plot(X,U [-1 ]):
du / dx的对称差分近似具有与三阶导数成比例的阶数dx ** 3的误差.这些累积的方式很复杂,因为解决方案正在四处移动,但无论如何,如果dt与它成比例,则较小的dx会改善这些问题.
内容总结
以上是互联网集市为您收集整理的python – 使用numpy解决具有波状初始条件的传输方程全部内容,希望文章能够帮你解决python – 使用numpy解决具有波状初始条件的传输方程所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。