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/703b4/703b47249f0baf52b040d44f040fe6b9c65dfc65" 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/1991c/1991c669f5ee2c7689a2fc2d58bd27e9a10455d9" 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/510a2/510a2b689190574e1a65b962eabf7a2ec75b0c33" alt="_images/parstudy_3_0.png"
rescor = s.responses.corr(plot=True, title='Model Response Correlations',printout=False)
data:image/s3,"s3://crabby-images/4d233/4d2335d6ca62aa8b7cb049e8adada644a4fe3304" alt="_images/parstudy_4_0.png"
s.responses.panels(title='Response Panels')
data:image/s3,"s3://crabby-images/d5950/d595083c75f9e09b848aad253d0be2810ce9c561" 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/4895c/4895c0e884aaf46dedc4eab25d6c6f1505726ab1" 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/008be/008be55d49ae8373f2800b396ababe17a54ffe4d" alt="_images/parstudy_7_0.png"
s.panels(figsize=(10,8))
data:image/s3,"s3://crabby-images/9e0a3/9e0a38a3aacbb558d83e310477565acfc1fe7a35" alt="_images/parstudy_8_0.png"