Linear Fit
[1]:
import numpy as np
from smpl import plot
from smpl import io
from smpl import fit
from smpl import functions as f
import uncertainties.unumpy as unp
import uncertainties as unc
[2]:
data = np.loadtxt(io.find_file('test_linear_data.txt',3))
xdata = data[:,0]
xerr = data[:,2]
ydata = data[:,1]
yerr = data[:,3]
x = unp.uarray(xdata,xerr)
y = unp.uarray(ydata,yerr)
[3]:
data
[3]:
array([[0. , 1. , 0.1, 0.2],
[1. , 2. , 0.2, 0.1],
[2. , 3. , 0.3, 0.1],
[3. , 5. , 0.1, 0.4],
[4. , 5. , 0.1, 0.1],
[5. , 6. , 0.1, 0.2]])
SciPy
[4]:
ff = plot.fit(xdata, ydata, fmt='.', label='data', xaxis="x in a.u.",yaxis="y in a.u.",function=f.linear, params=[1])
data:image/s3,"s3://crabby-images/775d2/775d2289c3e21e2d6ebb10a2963db53246942fe6" alt="../../../_images/example_fit_linear_test_linear_5_0.png"
[5]:
ff = plot.fit(xdata, ydata, fmt='.', label='data', xaxis="x in a.u.",yaxis="y in a.u.",function=f.line, params=[1,2])
data:image/s3,"s3://crabby-images/62787/62787dd437c306e76c6eb400548a59dbc58ee7d6" alt="../../../_images/example_fit_linear_test_linear_6_0.png"
[6]:
ff = plot.fit(x, y, fmt='.', function=f.line, params=[1,1], sigmas=1,lpos=2)
data:image/s3,"s3://crabby-images/55a78/55a78c6bb87b8329364889102fe6613c0d5ed701" alt="../../../_images/example_fit_linear_test_linear_7_0.png"
[7]:
ff = plot.fit(xdata, y, fmt='.', function=f.line, params=[1,1], sigmas=1,lpos=2)
print("Chi2 = ",fit.Chi2(xdata,y,f.line,ff))
Chi2 = 6.120448179271708
data:image/s3,"s3://crabby-images/7a6f4/7a6f4b7566b70f0acaf6f994c32fa7c40399a29e" alt="../../../_images/example_fit_linear_test_linear_8_1.png"
Correlations
Let’s take a look at correlations on the example of calculating the y axis intercept. Again:
[8]:
a,b = plot.fit(xdata, ydata, fmt='.', label='data', xaxis="x in a.u.",yaxis="y in a.u.",function=f.line, sigmas=1,extrapolate_min=-2)
data:image/s3,"s3://crabby-images/a4932/a4932f25110ca603961bbc1b2825aaa65942484d" alt="../../../_images/example_fit_linear_test_linear_10_0.png"
Let’s calculated the intersection with the x axis, given by \(-b/a\), with correlation
[9]:
-b/a
[9]:
-1.0648148148148089+/-0.41569533919028134
and without correlations
[10]:
a_nocorr=unc.ufloat(plot.unv(a),plot.usd(a))
b_nocorr=unc.ufloat(plot.unv(b),plot.usd(b))
-b_nocorr/a_nocorr
[10]:
-1.0648148148148089+/-0.3375205305560758
While the mean agrees the uncertainties are not the same.
The Lines drawn in the plot are also correlated and cross the axis at -0.67 and -1.51 corresponding to an uncertainties of -0.42.
Minuit
[11]:
ff = plot.fit(xdata, y, fmt='.', function=f.line, params=[1,1], sigmas=1,lpos=2,fitter=fit.Fitter.MINUIT_LEASTSQUARES)
print("Chi2 = ",fit.Chi2(xdata,y,f.line,ff))
Chi2 = 6.120448179271703
data:image/s3,"s3://crabby-images/68539/685392862999a2137b6e4357ba1d86bc8d088084" alt="../../../_images/example_fit_linear_test_linear_17_1.png"
[12]:
ff = plot.fit(xdata, y, fmt='.', function=f.line, params=[1,1], sigmas=1,lpos=2,fitter=fit.Fitter.SCIPY_ODR)
print("Chi2 = ",fit.Chi2(xdata,y,f.line,ff))
Chi2 = 14.50460743573666
data:image/s3,"s3://crabby-images/7ec98/7ec98d45381c4ab52a9fdf5956a169480f53ebed" alt="../../../_images/example_fit_linear_test_linear_18_1.png"
[ ]: