python正态分布拟合
时间: 2023-07-08 14:52:24 浏览: 341
要进行正态分布拟合,可以使用Python中的Scipy库中的stats模块。
下面给出一个简单的正态分布拟合的例子:
```python
import numpy as np
from scipy.stats import norm
import matplotlib.pyplot as plt
# 生成一组随机数据
data = np.random.normal(0, 1, 1000)
# 拟合正态分布
mu, std = norm.fit(data)
# 绘制直方图
plt.hist(data, bins=50, density=True, alpha=0.6, color='g')
# 绘制拟合的正态分布曲线
xmin, xmax = plt.xlim()
x = np.linspace(xmin, xmax, 100)
p = norm.pdf(x, mu, std)
plt.plot(x, p, 'k', linewidth=2)
# 添加标题和标签
plt.title("Fit results: mu = %.2f, std = %.2f" % (mu, std))
plt.xlabel('data')
plt.ylabel('Probability density')
plt.show()
```
运行上述代码,即可生成一张包含随机数据的直方图以及拟合的正态分布曲线。其中,mu和std分别表示正态分布的均值和标准差。
相关问题
python 正态分布拟合
在Python中,可以使用numpy和matplotlib库来进行正态分布的拟合。以下是三个示例代码,分别展示了不同的方法来绘制正态分布的直方图和拟合曲线。
示例代码1:
```python
import numpy as np
import matplotlib.mlab as mlab
import matplotlib.pyplot as plt
def demo2():
mu, sigma, num_bins = 0, 1, 50
x = mu + sigma * np.random.randn(1000000) # 生成正态分布的数据
n, bins, patches = plt.hist(x, num_bins, normed=True, facecolor='blue', alpha=0.5) # 绘制直方图
y = mlab.normpdf(bins, mu, sigma) # 拟合曲线
plt.plot(bins, y, 'r--') # 绘制拟合曲线
plt.xlabel('Expectation')
plt.ylabel('Probability')
plt.title('Histogram of normal distribution: $\mu = 0$, $\sigma=1$')
plt.subplots_adjust(left=0.15)
plt.show()
demo2()
```
示例代码2:
```python
import numpy as np
import matplotlib.mlab as mlab
import matplotlib.pyplot as plt
def demo1():
mu, sigma = 0, 1
sampleNo = 1000
np.random.seed(0)
s = np.random.normal(mu, sigma, sampleNo)
plt.hist(s, bins=100, normed=True)
plt.show()
demo1()
```
示例代码3:
```python
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.mlab as mlab
import seaborn as sns
sns.set(context='notebook', font='simhei', style='whitegrid') # 设置风格尺度和显示中文
import warnings
warnings.filterwarnings('ignore') # 不发出警告
def demo3():
s = np.loadtxt('D:/dis.txt') # 从文件中读取数据
mu = np.mean(s) # 计算均值
sigma = np.std(s) # 计算标准差
num_bins = 50 # 直方图柱子的数量
n, bins, patches = plt.hist(s, num_bins, normed=1, facecolor='blue', alpha=0.5) # 绘制直方图
y = norm.pdf(bins, mu, sigma) # 拟合一条最佳正态分布曲线
plt.plot(bins, y, 'r--') # 绘制拟合曲线
plt.xlabel('sepal-length') # 绘制x轴
plt.ylabel('Probability') # 绘制y轴
plt.title(r'Histogram: $\mu={}$, $\sigma={}$'.format(mu, sigma)) # 在标题中显示mu和sigma
plt.subplots_adjust(left=0.15) # 调整左边距
plt.show()
demo3()
```
这些示例代码展示了如何使用numpy和matplotlib库来绘制正态分布的直方图和拟合曲线。你可以根据自己的需求选择其中的一种方法来进行正态分布的拟合。
python 使用正态分布拟合点集
在Python中,可以使用NumPy和Matplotlib库来进行正态分布拟合。具体步骤如下:
1. 导入NumPy和Matplotlib库。
2. 生成一组随机数据点。
3. 使用NumPy的mean和std函数计算数据点的均值和标准差。
4. 使用Matplotlib的hist函数绘制数据点的直方图。
5. 使用NumPy的linspace函数生成一组横坐标数据。
6. 使用scipy.stats库的norm函数生成一组纵坐标数据,表示正态分布曲线。
7. 使用Matplotlib的plot函数绘制正态分布曲线。
8. 使用Matplotlib的show函数显示图像。
具体实现可以参考以下代码:
```python
import numpy as np
import matplotlib.pyplot as plt
from scipy.stats import norm
# 生成一组随机数据点
data = np.random.normal(0, 1, 1000)
# 计算数据点的均值和标准差
mu, std = norm.fit(data)
# 绘制数据点的直方图
plt.hist(data, bins=30, density=True, alpha=0.6, color='g')
# 生成一组横坐标数据
x = np.linspace(-4, 4, 100)
# 生成一组纵坐标数据,表示正态分布曲线
y = norm.pdf(x, mu, std)
# 绘制正态分布曲线
plt.plot(x, y, 'r--', linewidth=2)
# 显示图像
plt.show()
```
阅读全文