Markov Chain Monte Carlo Using PYMCΒΆ
This example demonstrates Markov Chain Monte Carlo using PYMC (https://pymc-devs.github.io/pymc/) with the MCMC
function.
%matplotlib inline
import sys,os
from numpy import array, double, arange, random
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)
# Define basic function
def f(pars):
a = pars['a']
c = pars['c']
m=double(arange(20))
m=a*(m**2)+c
return m
# Create matk object
prob = matk.matk(model=f)
# Add parameters with 'true' parameters
prob.add_par('a', min=0, max=10, value=2)
prob.add_par('c', min=0, max=30, value=5)
# Run model using 'true' parameters
prob.forward()
# Create 'true' observations with zero mean, 0.5 st. dev. gaussian noise added
prob.obsvalues = prob.simvalues + random.normal(0,0.1,len(prob.simvalues))
# Run MCMC with 100000 samples burning (discarding) the first 10000
M = prob.MCMC(nruns=100000,burn=10000,verbose=False)
[-----------------100%-----------------] 100000 of 100000 complete in 128.1 sec
# Plot results, PNG files will be created in current directory
# It is apparent that the true parameter values and standard deviation
# are recovered as the most likely values.
prob.MCMCplot(M)
Plotting error_std
Plotting c
Plotting a
data:image/s3,"s3://crabby-images/fa2ee/fa2ee48023106ba0d099eaa89315857adbb75634" alt="_images/mcmc_1_1.png"
data:image/s3,"s3://crabby-images/56a0f/56a0fc250f43f9037599e8f2f15b43cc02faa695" alt="_images/mcmc_1_2.png"
data:image/s3,"s3://crabby-images/6e3f3/6e3f3e48b8ddd531f07687f4997463bfa278064c" alt="_images/mcmc_1_3.png"