以y轴为相对频率生成直方图?

2024-09-30 18:31:36 发布

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

今天我的任务是生成一个直方图,其中y轴是一个相对频率,而不仅仅是一个绝对计数。我找到了另一个与此相关的问题(请参见:Setting a relative frequency in a matplotlib histogram),但是,当我尝试实现它时,我得到了错误消息:

'list' object has no attribute size

尽管答案中给出了完全相同的代码,而且他们的信息也存储在一个列表中。在

另外,我在这里尝试了这个方法(http://www.bertplot.com/visualization/?p=229),但是没有用,因为输出仍然没有显示从0到1的y标签。在

import numpy as np
import matplotlib.pyplot as plt
import random
from tabulate import tabulate
import matplotlib.mlab as mlab

precision = 100000000000

def MarkovChain(n,s) :
    """

  """
    matrix = []
    for l in range(n) :
        lineLst = []
        sum = 0
        crtPrec = precision
        for i in range(n-1) :
            val = random.randrange(crtPrec)
            sum += val
            lineLst.append(float(val)/precision)
            crtPrec -= val
        lineLst.append(float(precision - sum)/precision)
        matrix2 = matrix.append(lineLst)

    print("The intial probability matrix.")    
    print(tabulate(matrix2))
    baseprob = []
    baseprob2 = []
    baseprob3 = []
    baseprob4 = []

    for i in range(1,s): #changed to do a range 1-s instead of 1000

        #must use the loop variable here, not s (s is always the same)
        matrix_n = np.linalg.matrix_power(matrix2, i)
        baseprob.append(matrix_n.item(0))
        baseprob2.append(matrix_n.item(1))
        baseprob3.append(matrix_n.item(2))

    baseprob = np.array(baseprob)
    baseprob2 = np.array(baseprob2)
    baseprob3 = np.array(baseprob3)
    baseprob4 = np.array(baseprob4)

    # Here I tried to make a histogram using the plt.hist() command, but the normed=True doesn't work like I assumed it would.
    '''    
  plt.hist(baseprob, bins=20, normed=True)
  plt.show()
  '''

    #Here I tried to make a histogram using the method from the second link in my post.
    # The code runs, but then the graph that is outputted isn't doesn't have the relative frequency on the y axis.
    '''
   n, bins, patches = plt.hist(baseprob, bins=30,normed=True,facecolor = "green",)
   y = mlab.normpdf(bins,mu,sigma)
   plt.plot(bins,y,'b-')
   plt.title('Main Plot Title',fontsize=25,horizontalalignment='right')
   plt.ylabel('Count',fontsize=20)
   plt.yticks(fontsize=15)
   plt.xlabel('X Axis Label',fontsize=20)
   plt.xticks(fontsize=15)
   plt.show()
   '''
    # Here I tried to make a histogram using the method seen in the Stackoverflow question I mentioned.
    # The figure that pops out looks correct in terms of the axes, but no actual data is posted. Instead the error below is shown in the console.
    # AttributeError: 'list' object has no attribute 'size'


    fig = plt.figure()
    ax = fig.add_subplot(111)
    ax.hist(baseprob, weights=np.zeros_like(baseprob)+1./ baseprob.size)
    n, bins, patches = ax.hist(baseprob, bins=100, normed=1, cumulative=0)
    ax.set_xlabel('Bins', size=20)
    ax.set_ylabel('Frequency', size=20)
    ax.legend
    plt.show()


    print("The final probability matrix.")
    print(tabulate(matrix_n))
    matrixTranspose = zip(*matrix_n)
    evectors = np.linalg.eig(matrixTranspose)[1][:,0]
    print("The steady state vector is:")
    print(evectors)






MarkovChain(5, 1000)

我尝试的方法都被注释掉了,所以为了重现我的错误,请务必删除注释标记。在

正如你所说,我对编程真的很陌生。另外,这是计算机科学课上的家庭作业,所以给我提供代码没有任何道德问题。在


Tags: theinimportsizeisnppltax
1条回答
网友
1楼 · 发布于 2024-09-30 18:31:36

期望的matplotlib函数的输入通常是numpy数组,它具有nparray.size方法。列表没有size方法,因此当在hist函数中调用list.size时,这会导致错误。您需要使用nparray = np.array(list)进行转换。你可以在循环之后用append来构建列表,比如

baseprob = []
baseprob2 = []
baseprob3 = []
baseprob4 = []

for i in range(1,s): #changed to do a range 1-s instead of 1000

 #must use the loop variable here, not s (s is always the same)
     matrix_n = numpy.linalg.matrix_power(matrix, i)
     baseprob.append(matrix_n.item(0))
     baseprob2.append(matrix_n.item(1))
     baseprob3.append(matrix_n.item(2))

 baseprob = np.array(baseprob)
 baseprob2 = np.array(baseprob2)
 baseprob3 = np.array(baseprob3)
 baseprob4 = np.array(baseprob4)

编辑:最小历史示例

^{2}$

所以

enter image description here

相关问题 更多 >