File: example_derivfunc.py

package info (click to toggle)
lmfit-py 0.8.0%2Bdfsg.1-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 1,776 kB
  • ctags: 1,203
  • sloc: python: 7,041; makefile: 102; sh: 43
file content (85 lines) | stat: -rw-r--r-- 2,091 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#!/usr/bin/env python

from lmfit import Parameters, Minimizer
import numpy as np

try:
    import pylab
    HASPYLAB = True
except ImportError:
    HASPYLAB = False

def func(pars, x, data=None):
	a = pars['a'].value
	b = pars['b'].value
	c = pars['c'].value

	model=a * np.exp(-b * x)+c
	if data is None:
		return model
	return (model - data)

def dfunc(pars, x, data=None):
	a = pars['a'].value
	b = pars['b'].value
	c = pars['c'].value
	v = np.exp(-b*x)
	return [v, -a*x*v, np.ones(len(x))]

def f(var, x):
	return var[0]* np.exp(-var[1] * x)+var[2]

params1 = Parameters()
params1.add('a', value=10)
params1.add('b', value=10)
params1.add('c', value=10)

params2 = Parameters()
params2.add('a', value=10)
params2.add('b', value=10)
params2.add('c', value=10)

a, b, c = 2.5, 1.3, 0.8
x = np.linspace(0,4,50)
y = f([a, b, c], x)
data = y + 0.15*np.random.normal(size=len(x))

# fit without analytic derivative
min1 = Minimizer(func, params1, fcn_args=(x,), fcn_kws={'data':data})
min1.leastsq()
fit1 = func(params1, x)

# fit with analytic derivative
min2 = Minimizer(func, params2, fcn_args=(x,), fcn_kws={'data':data})
min2.leastsq(Dfun=dfunc, col_deriv=1)
fit2 = func(params2, x)

print '''Comparison of fit to exponential decay
with and without analytic derivatives, to
   model = a*exp(-b*x) + c
for a = %.2f, b = %.2f, c = %.2f
==============================================
Statistic/Parameter|   Without   | With      |
----------------------------------------------
N Function Calls   |   %3i       |   %3i     |
Chi-square         |   %.4f    |   %.4f  |
   a               |   %.4f    |   %.4f  |
   b               |   %.4f    |   %.4f  |
   c               |   %.4f    |   %.4f  |
----------------------------------------------
''' %  (a, b, c,
        min1.nfev,   min2.nfev,
        min1.chisqr, min2.chisqr,
        params1['a'].value, params2['a'].value,
        params1['b'].value, params2['b'].value,
        params1['c'].value, params2['c'].value )


if HASPYLAB:
	pylab.plot(x, data, 'ro')
	pylab.plot(x, fit1, 'b')
        pylab.plot(x, fit2, 'k')
	pylab.show()