Parameter StudyΒΆ
This example demonstrates a parameter study of a 4 parameter 5 response model using the parstudy
function.
The models of the parameter study are run using the run
function.
The generation of diagnostic plots is demonstrated using hist
, panels
, and corr
.
%matplotlib inline
import sys,os
try:
import matk
except:
try:
sys.path.append(os.path.join('..','src'))
import matk
except ImportError as err:
print 'Unable to load MATK module: '+str(err)
import numpy
from scipy import arange, randn, exp
from multiprocessing import freeze_support
# Model function
def dbexpl(p):
t=arange(0,100,20.)
y = (p['par1']*exp(-p['par2']*t) + p['par3']*exp(-p['par4']*t))
return y
# Setup MATK model with parameters
p = matk.matk(model=dbexpl)
p.add_par('par1',min=0,max=1)
p.add_par('par2',min=0,max=0.2)
p.add_par('par3',min=0,max=1)
p.add_par('par4',min=0,max=0.2)
# Create full factorial parameter study with 3 values for each parameter
s = p.parstudy(nvals=[3,3,3,3])
# Print values to make sure you got what you wanted
print "\nParameter values:"
print s.samples.values
Parameter values:
[[ 0. 0. 0. 0. ]
[ 0. 0. 0. 0.1]
[ 0. 0. 0. 0.2]
[ 0. 0. 0.5 0. ]
[ 0. 0. 0.5 0.1]
[ 0. 0. 0.5 0.2]
[ 0. 0. 1. 0. ]
[ 0. 0. 1. 0.1]
[ 0. 0. 1. 0.2]
[ 0. 0.1 0. 0. ]
[ 0. 0.1 0. 0.1]
[ 0. 0.1 0. 0.2]
[ 0. 0.1 0.5 0. ]
[ 0. 0.1 0.5 0.1]
[ 0. 0.1 0.5 0.2]
[ 0. 0.1 1. 0. ]
[ 0. 0.1 1. 0.1]
[ 0. 0.1 1. 0.2]
[ 0. 0.2 0. 0. ]
[ 0. 0.2 0. 0.1]
[ 0. 0.2 0. 0.2]
[ 0. 0.2 0.5 0. ]
[ 0. 0.2 0.5 0.1]
[ 0. 0.2 0.5 0.2]
[ 0. 0.2 1. 0. ]
[ 0. 0.2 1. 0.1]
[ 0. 0.2 1. 0.2]
[ 0.5 0. 0. 0. ]
[ 0.5 0. 0. 0.1]
[ 0.5 0. 0. 0.2]
[ 0.5 0. 0.5 0. ]
[ 0.5 0. 0.5 0.1]
[ 0.5 0. 0.5 0.2]
[ 0.5 0. 1. 0. ]
[ 0.5 0. 1. 0.1]
[ 0.5 0. 1. 0.2]
[ 0.5 0.1 0. 0. ]
[ 0.5 0.1 0. 0.1]
[ 0.5 0.1 0. 0.2]
[ 0.5 0.1 0.5 0. ]
[ 0.5 0.1 0.5 0.1]
[ 0.5 0.1 0.5 0.2]
[ 0.5 0.1 1. 0. ]
[ 0.5 0.1 1. 0.1]
[ 0.5 0.1 1. 0.2]
[ 0.5 0.2 0. 0. ]
[ 0.5 0.2 0. 0.1]
[ 0.5 0.2 0. 0.2]
[ 0.5 0.2 0.5 0. ]
[ 0.5 0.2 0.5 0.1]
[ 0.5 0.2 0.5 0.2]
[ 0.5 0.2 1. 0. ]
[ 0.5 0.2 1. 0.1]
[ 0.5 0.2 1. 0.2]
[ 1. 0. 0. 0. ]
[ 1. 0. 0. 0.1]
[ 1. 0. 0. 0.2]
[ 1. 0. 0.5 0. ]
[ 1. 0. 0.5 0.1]
[ 1. 0. 0.5 0.2]
[ 1. 0. 1. 0. ]
[ 1. 0. 1. 0.1]
[ 1. 0. 1. 0.2]
[ 1. 0.1 0. 0. ]
[ 1. 0.1 0. 0.1]
[ 1. 0.1 0. 0.2]
[ 1. 0.1 0.5 0. ]
[ 1. 0.1 0.5 0.1]
[ 1. 0.1 0.5 0.2]
[ 1. 0.1 1. 0. ]
[ 1. 0.1 1. 0.1]
[ 1. 0.1 1. 0.2]
[ 1. 0.2 0. 0. ]
[ 1. 0.2 0. 0.1]
[ 1. 0.2 0. 0.2]
[ 1. 0.2 0.5 0. ]
[ 1. 0.2 0.5 0.1]
[ 1. 0.2 0.5 0.2]
[ 1. 0.2 1. 0. ]
[ 1. 0.2 1. 0.1]
[ 1. 0.2 1. 0.2]]
# Look at sample parameter histograms
out = s.samples.hist(ncols=2,title='Parameter Histograms by Counts')
data:image/s3,"s3://crabby-images/b0bdf/b0bdf61ee35bd1d0f63aaf8fa8eba1e2e1ae29ba" alt="_images/parstudy_1_0.png"
par1:
Count: 27 0 0 0 0 27 0 0 0 27
Bins: 0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
par2:
Count: 27 0 0 0 0 27 0 0 0 27
Bins: 0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2
par3:
Count: 27 0 0 0 0 27 0 0 0 27
Bins: 0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
par4:
Count: 27 0 0 0 0 27 0 0 0 27
Bins: 0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2
# This time use frequency instead of count and turn off printing histogram to screen
out = s.samples.hist(ncols=2,title='Parameter Histograms by Frequency',frequency=True,printout=False)
data:image/s3,"s3://crabby-images/64ce2/64ce2dca36e40ab48dfc8e7ff5fa4c44f1010449" alt="_images/parstudy_2_0.png"
# Run model with parameter samples
s.run( cpus=2, outfile='results.dat', logfile='log.dat',verbose=False)
# Look at response histograms, correlations, and panels
# Note that printout has been set to False in this case to avoid printing histogram output to screen
out = s.responses.hist(ncols=2, bins=30, title='Model Response Histograms',printout=False)
data:image/s3,"s3://crabby-images/fd2fa/fd2fa7989383222bdbc95ac8d83ca18757c27bb8" alt="_images/parstudy_3_0.png"
rescor = s.responses.corr(plot=True, title='Model Response Correlations',printout=False)
data:image/s3,"s3://crabby-images/378ac/378ac3004baa1a93abe044db91ea2403e7ca1366" alt="_images/parstudy_4_0.png"
s.responses.panels(title='Response Panels')
data:image/s3,"s3://crabby-images/40342/403424091768a59b9f864f5c6c551025e779b1d9" alt="_images/parstudy_5_0.png"
# Print and plot parameter/response correlations
print "\nPearson Correlation Coefficients:"
pcorr = s.corr(plot=True,title='Pearson Correlation Coefficients')
Pearson Correlation Coefficients:
obs1 obs2 obs3 obs4 obs5
par1 0.71 0.34 0.30 0.29 0.29
par2 -0.00 -0.44 -0.43 -0.43 -0.43
par3 0.71 0.34 0.30 0.29 0.29
par4 0.00 -0.44 -0.43 -0.43 -0.43
data:image/s3,"s3://crabby-images/7ddf2/7ddf2974cfe4f212d14b44b34ef9c77b38c9e1e2" alt="_images/parstudy_6_1.png"
scorr = s.corr(plot=True,type='spearman',title='Spearman Rank Correlation Coefficients',printout=False)
data:image/s3,"s3://crabby-images/56d8a/56d8a25ebe9ccb533f5900a553ff6fe7a270bc49" alt="_images/parstudy_7_0.png"
s.panels(figsize=(10,8))
data:image/s3,"s3://crabby-images/0fc22/0fc22b2291c7844758d9143d42d886d1a3b8c34f" alt="_images/parstudy_8_0.png"