给定一个均值和方差,是否有一个简单的函数调用可以绘制正态分布?
给定一个均值和方差,是否有一个简单的函数调用可以绘制正态分布?
Answers:
import matplotlib.pyplot as plt
import numpy as np
import scipy.stats as stats
import math
mu = 0
variance = 1
sigma = math.sqrt(variance)
x = np.linspace(mu - 3*sigma, mu + 3*sigma, 100)
plt.plot(x, stats.norm.pdf(x, mu, sigma))
plt.show()
scipy.stats.norm.pdf(x, mu, sigma),而不是mlab.normpdf(x, mu, sigma)
                    math在已经导入numpy并可以使用时导入np.sqrt?
                    math用于标量运算,例如,math.sqrt与在标量上进行运算相比,它的速度要快得多np.sqrt。
                    我认为没有一个函数可以在一个调用中完成所有这些操作。但是,您可以在中找到高斯概率密度函数scipy.stats。
因此,我想出的最简单方法是:
import numpy as np
import matplotlib.pyplot as plt
from scipy.stats import norm
# Plot between -10 and 10 with .001 steps.
x_axis = np.arange(-10, 10, 0.001)
# Mean = 0, SD = 2.
plt.plot(x_axis, norm.pdf(x_axis,0,2))
plt.show()资料来源:
norm.pdf为norm(0, 1).pdf。这使得更容易适应其他情况/了解生成的对象代表随机变量。
                    使用seaborn代替我正在使用均值= 5 std = 3的1000值的seaborn的distplot
value = np.random.normal(loc=5,scale=3,size=1000)
sns.distplot(value)您将获得正态分布曲线
我刚刚回到这个问题,我不得不安装scipy,因为MatplotlibDeprecationWarning: scipy.stats.norm.pdf在尝试上述示例时,matplotlib.mlab给了我错误消息。现在的示例是:
%matplotlib inline
import math
import matplotlib.pyplot as plt
import numpy as np
import scipy.stats
mu = 0
variance = 1
sigma = math.sqrt(variance)
x = np.linspace(mu - 3*sigma, mu + 3*sigma, 100)
plt.plot(x, scipy.stats.norm.pdf(x, mu, sigma))
plt.show()您可以轻松获得CDF。所以通过cdf pdf
    import numpy as np
    import matplotlib.pyplot as plt
    import scipy.interpolate
    import scipy.stats
    def setGridLine(ax):
        #http://jonathansoma.com/lede/data-studio/matplotlib/adding-grid-lines-to-a-matplotlib-chart/
        ax.set_axisbelow(True)
        ax.minorticks_on()
        ax.grid(which='major', linestyle='-', linewidth=0.5, color='grey')
        ax.grid(which='minor', linestyle=':', linewidth=0.5, color='#a6a6a6')
        ax.tick_params(which='both', # Options for both major and minor ticks
                        top=False, # turn off top ticks
                        left=False, # turn off left ticks
                        right=False,  # turn off right ticks
                        bottom=False) # turn off bottom ticks
    data1 = np.random.normal(0,1,1000000)
    x=np.sort(data1)
    y=np.arange(x.shape[0])/(x.shape[0]+1)
    f2 = scipy.interpolate.interp1d(x, y,kind='linear')
    x2 = np.linspace(x[0],x[-1],1001)
    y2 = f2(x2)
    y2b = np.diff(y2)/np.diff(x2)
    x2b=(x2[1:]+x2[:-1])/2.
    f3 = scipy.interpolate.interp1d(x, y,kind='cubic')
    x3 = np.linspace(x[0],x[-1],1001)
    y3 = f3(x3)
    y3b = np.diff(y3)/np.diff(x3)
    x3b=(x3[1:]+x3[:-1])/2.
    bins=np.arange(-4,4,0.1)
    bins_centers=0.5*(bins[1:]+bins[:-1])
    cdf = scipy.stats.norm.cdf(bins_centers)
    pdf = scipy.stats.norm.pdf(bins_centers)
    plt.rcParams["font.size"] = 18
    fig, ax = plt.subplots(3,1,figsize=(10,16))
    ax[0].set_title("cdf")
    ax[0].plot(x,y,label="data")
    ax[0].plot(x2,y2,label="linear")
    ax[0].plot(x3,y3,label="cubic")
    ax[0].plot(bins_centers,cdf,label="ans")
    ax[1].set_title("pdf:linear")
    ax[1].plot(x2b,y2b,label="linear")
    ax[1].plot(bins_centers,pdf,label="ans")
    ax[2].set_title("pdf:cubic")
    ax[2].plot(x3b,y3b,label="cubic")
    ax[2].plot(bins_centers,pdf,label="ans")
    for idx in range(3):
        ax[idx].legend()
        setGridLine(ax[idx])
    plt.show()
    plt.clf()
    plt.close()
%matplotlib inline让情节出现