gpt4 book ai didi

Python Matplotlib Colorbar/Colormap 设置

转载 作者:行者123 更新时间:2023-11-28 16:42:09 26 4
gpt4 key购买 nike

我做了一个 animation of a wave ,但颜色条一直在移动,我不知道为什么。我认为这是因为它在每一帧后都正常化。如何设置颜色图设置以使颜色栏保持不变?

代码:警告:此程序删除其调用目录中的文件夹 png3D。制作所有帧也可能需要一段时间,具体取决于您的计算能力。

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
from matplotlib import cm
import time
import sys,os,shutil
time.clock()

def FUNCTION(p,r,t):
k_0,dx,c = p
x,y = r
x,y = np.meshgrid(x,y)
r = np.sqrt(x**2 + y**2)
z = np.exp(1j*(k_0[0]*x+k_0[1]*y-c*t))*np.exp(-((r-c*t)/(2*dx))**2 )*0.5**(r/x[0][-1]/2)
z = abs(z)
return(x,y,z)

def PRINT_PNG(x,y,t,folder):
x,y,z = FUNCTION(p,r,t)

fig = plt.figure()
sub = fig.gca(projection='3d')
fig.suptitle("3D Wavepackage", size="large")
sub.set_zlim([0,1.5])
sub.set_xlabel("x",size="large")
sub.set_ylabel("y",size="large")
sub.set_zlabel("$Re[\psi(x,t)]$",size="large",ha="right")
sub.text(0.5,0.5,0.5,"t = "+str("%3.1f"%t)+" s",transform = sub.transAxes, ha="right")

surf = sub.plot_surface(x,y,z,linewidth=0,cmap=cm.coolwarm)
fig.colorbar(surf, shrink=0.5, aspect=5)
file_name = os.path.abspath(folder+"/tmp"+str("%04d"%i)+".png")
fig.savefig(file_name)
plt.close()

# Parameters
T = 10
N = 100
n = 24*T # 24 Frames pro Sekunde
t = np.linspace(0,T,n)
k_0 = [1,1]
dx = 1
c = 1
p = [k_0,dx,c]

x = np.linspace(-c*T,c*T,N)
y = np.linspace(-c*T,c*T,N)
r=[x,y]


# Baue Ordner
folder = os.path.abspath("png3D")
if os.path.exists(folder)==True:
shutil.rmtree(folder)
os.makedirs(folder)
else:
os.makedirs(folder)

for i in range(n):
PRINT_PNG(x,y,t[i],folder)
print(str(i+1)+"/"+str(n))

file_name = os.path.abspath("png3D//tmp%04d.png")
os.system("ffmpeg -f image2 -y -i "+file_name+" -r 24 -bit_rate 1800 3D_Wave.mpeg")
shutil.rmtree(folder)
print(time.clock())

最佳答案

您可以将 vminvmax 关键字参数传递给指定绘图值范围的 plot_surface:

surf = sub.plot_surface(x,y,z,linewidth=0,cmap=cm.coolwarm,vmin=0,vmax=1)

参见 the docs了解更多信息。

关于Python Matplotlib Colorbar/Colormap 设置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18035378/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com