在cernROOT中用python对数据做fit拟合、Gaussian 拟合
时间: 2024-11-25 15:09:30 浏览: 66
在CERN ROOT框架中使用Python进行数据拟合,特别是Gaussian分布拟合,通常涉及以下几个步骤:
1. **导入所需库**:
首先,需要导入`root`, `numpy`, 和 `scipy.stats` 库,因为它们包含了处理ROOT文件和进行统计分析的功能。
```python
import ROOT as rt
import numpy as np
from scipy.optimize import curve_fit
```
2. **读取数据**:
使用`TTree`或`TH1F`等数据结构从ROOT文件加载数据,例如,假设有一个名为`histogram`的`TH1F`。
```python
hist = rt.TH1F('histogram', 'Histogram title', bins, xmin, xmax)
hist.ReadFile('your_data.root')
data = hist.GetEntries()
x_values = hist.GetXaxis().Getbins()[:-1] + 0.5 * (hist.GetXaxis().GetBinWidth(1) - hist.GetXaxis().GetBinCenter(1))
y_values = hist.GetBinContent(np.arange(data)).tolist()
```
3. **Gaussian函数定义**:
定义一个表示高斯分布的函数,它接受两个参数(均值μ和标准差σ)以及x轴的值作为输入。
```python
def gaussian(x, mu, sigma):
return 1 / (sigma * np.sqrt(2 * np.pi)) * np.exp(-((x - mu)**2) / (2 * sigma**2))
```
4. **曲线拟合**:
使用`curve_fit`函数从`scipy.optimize`模块进行非线性最小二乘法拟合。
```python
params, _ = curve_fit(gaussian, x_values, y_values)
mu, sigma = params
```
5. **结果检查和可视化**:
可以打印出拟合的结果,并使用新的参数生成一个新的拟合曲线,然后画出来对比原始数据。
```python
print(f"Fit results: Mean={mu}, Standard Deviation={sigma}")
# Generate fit line and plot
fit_y = [gaussian(val, mu, sigma) for val in x_values]
plt.plot(x_values, fit_y, label='Fit Line')
plt.hist(x_values, weights=y_values, bins=x_values, alpha=0.5, label='Data')
plt.legend()
plt.show()
```
阅读全文