Skip to content

Latest commit

 

History

History
56 lines (36 loc) · 3.51 KB

README.md

File metadata and controls

56 lines (36 loc) · 3.51 KB

bicme - Bayesian analysis of Ion-Channels with Missed Events

This is code used in our recent paper "Bayesian Statistical Inference in Ion-Channel Models with Exact Missed Event Correction" that appeared in Biophysical Journal in 2016 (doi: 10.1016/j.bpj.2016.04.053), available here

Please feel free to contact me at my email address listed on my "miepstei" git profile with comments and feedback.

Prequisites

  1. A C++11 compiler installed - required for steps 2 and 4.
  2. Install the DCPROGS c++ library - this is a reimplementation of the Colquhoun & Hawkes likelihood calculation originally written in Fortran. The library is available here with required documentation and installation wiki.
  3. Matlab 2014b installed.
  4. An ability to compile mex functions using the command line. Scripts are provided for Mac OSX (10.11) and Linux but may need some caressing to compile the mex functions so that they can be called in matlab.

Installation and Testing steps

Command line steps

  1. Check out the bicme repo at github by running git clone [email protected]:miepstei/bicme.git .
  2. Compile the mex functions from the command line. There is a shell script in C/compile_mex.sh which can serve as a template for compilation. This step compiles the mex files which wrap around calls to the C++ library so they can be called from MATLAB.

MATLAB steps

  1. Within MATLAB, add the base of the repo to the MATLAB path from the directory tree (right-click -> "add to path")
  2. Run the Unit tests. There are tests in the Tests/ directory that test models, likelihood calculations and data parsing. To run the tests: cd Tests tests = matlab.unittest.TestSuite.fromFolder('.') run(tests)

To run the examples from the paper...

There is a single main script called RunAllExperiments which should be on the MATLAB path. This will take a long time to complete. Instead, each set of experiments can be run individually. This requires setting a replicateNo that seeds the RNG.

  1. The synthetic experiments (Figures 3, 4 and 5) can be run as follows: synthetic = 2; replicateNo = 10; removeFigures = 0; RunExperiment(synthetic, replicateNo); GenerateFigures(synthetic, replicateNo, removeFigures)

  2. The experiments on the real data (Figures 6, 7, 8) can be run as follows: real = 3; replicateNo = 10; removeFigures = 0; RunExperiment(real, replicateNo); GenerateFigures(synthetic, replicateNo, removeFigures)

  3. The comparison experiment (Figure10) can be plotted as follows. This performs just the HJCFit likelihood calculation against prior derived results from Siekmann et al. 2012 comparison = 4; replicateNo = 10; RunExperiment(comparison, replicateNo); GenerateFigures(comparison, replicateNo, removeFigures)

All the plotted eps output is produced in Results/Figures/Paper. Setting removeFigures = 1 removes the output from the directory. All the MCMC output is in Results.

Third party acknowledgements

I have vectorised a version of John D'Errico's Hessian calculation available on Mathworks to calculate the Hessian numerically using finite differences. I have modified plotting functions described in this UCL presentation in order to produce reasonable MATLAB figures.