Python图形D

2024-09-26 18:02:34 发布

您现在位置:Python中文网/ 问答频道 /正文

t方向是x坐标,y坐标是s,但我做不到。如果你能帮忙的话。提前谢谢大家。现在只绘制了tdondur值。如何绘制s值

from math import e, exp,pow 
import pylab
from gaussxw import gaussxwab

Kb=1.3806505*10**-23
V=10**-3
p=6.022*10**28
Qd=428.0


def f(x):
    isisigasi=9*V*p*Kb*(T/Qd)**3
    return(isisigasi*x**4*(exp(x))/(exp(2)-1)**2)

tut=[] 

Tdondur=range(5,501)
tut=[None for T in Tdondur] 

for tsirala, T in enumerate (Tdondur):
    N=50
    a=0
    b=Qd/T
    x,w=gaussxwab(N,a,b)
    s=0.0
    for k in range (N):
        s+=w[k]*f(x[k])    
    print(T,"'in Isı Sığası : ",s)
    print("----------------------------------------------------------")


pylab.plot(Tdondur)
pylab.title('Isı Sığasının Sıcaklığa Göre Değişimi')
pylab.xlabel('Sıcaklık (T)')
pylab.ylabel('Isı Sığası')
pylab.gcf().savefig('isisigasi.png')
pylab.show()

Tags: infromimportforkbisas绘制
1条回答
网友
1楼 · 发布于 2024-09-26 18:02:34

这里的问题是,在循环的每一次迭代中,您都在为s计算一个新值,但是您永远不会保存所计算的值。相反,在进入循环之前为s创建一个数组,并在循环中设置{}。在

from math import e, exp,pow 
import pylab
from gaussxw import gaussxwab

Kb=1.3806505*10**-23
V=10**-3
p=6.022*10**28
Qd=428.0


def f(x):
    isisigasi=9*V*p*Kb*(T/Qd)**3
    return(isisigasi*x**4*(exp(x))/(exp(2)-1)**2)

tut=[] 

Tdondur=range(5,501)
tut=[None for T in Tdondur] 

s = [0. for i in Tdondur]  # initialize s before entering the loop
for tsirala, T in enumerate (Tdondur):
    N=50
    a=0
    b=Qd/T
    x,w=gaussxwab(N,a,b)
    for k in range (N):
        s[k]+=w[k]*f(x[k])    # work on the values within the loop

pylab.plot(Tdondur, s)
#s_np = pylab.array(s)
#pylab.plot(Tdondur, pylab.log10(s_np))
pylab.title('title')
pylab.xlabel('T')
pylab.ylabel('Y')
#pylab.gcf().savefig('')
pylab.show()

结果如下(注意x轴被放大):

enter image description here

通常,对于这样的数据,您需要绘制数据的log,要做到这一点,请在这两行后面取消注释:

^{pr2}$

(请注意,上面的行使用的是numpy,它是通过pylab导入的,对于这类问题,它比list理解更简单。)

enter image description here

相关问题 更多 >

    热门问题