A statistical and physical model to optimize chronologies of paleoclimatic sites.
This manual is a documentation on how to use the paleochrono software.
It is not a description of the paleochrono principles. Please read to the scientific articles
describing IceChrono for that purpose:
Parrenin, F., Bazin, L., Capron, E., Landais, A., Lemieux-Dudon, B. and Masson-Delmotte, V.:
IceChrono1: a probabilistic model to compute a common and optimal chronology for several ice cores,
Geosci. Model Dev., 8(5), 1473–1492, doi:10.5194/gmd-8-1473-2015, 2015.
It is not an operating system or python documentation.
Please use your operating system or python documentation instead.
A mailing list has been set up on Google Groups:
https://groups.google.com/forum/?hl=en#!forum/icechrono
You just need a google account to access this mailing list.
You can also directly email to Frédéric Parrenin: [email protected]
Go here:
https://github.com/parrenin/paleochrono/
and click on the donwload button.
In the downloaded folder, you will find the following files:
- README.md : is the current documentation of paleochrono.
- LICENCE : is the paleochrono licence file.
- paleochrono.py : is the main paleochrono program that you will run.
- pccfg.py, pcmath.py, pcsite.py and pcsitepair.py : are python modules used by paleochrono.py
- Clean.py : is a python script to clean a dating experiment directory
- AICC2012-Hulu : is an example experiment directory: it contains all the necessary numerical settings, prior information and observations for the different ice cores in the AICC2012 dating experiment and for the MSD and MSL Hulu speleothem. It takes <1 mn to run an a recent computer.
paleochrono is a scientific python3 software, therefore you need a scipy distribution.
paleochrono is developed and tested using the anaconda distribution, therefore we recommend it.
Anaconda can be downloaded here (use the python3 version):
http://continuum.io/downloads
Paleochrono probably works on other scipy distributions, provided they contain the following python modules:
- sys
- os
- time
- math
- numpy
- matplotlib
- multiprocessing
- warnings
- scipy
Assuming you use anaconda, you can go in the spyder shell and type the following commands in the ipython interpreter:
cd path-to-palechrono
run paleochron.py exp_directory/
where path-to-paleochrono
is the directory containing IceChrono and exp_directory
is the name of
your experiment directory.
The AICC2012-Hulu
experiment directory is provided for you convenience.
It is an AICC2012 + Hulu experiment.
It takes <1 mn to run on a recent computer.
If the run went correctly, it has created output files.
In the main directory, you have the following output file:
output.txt
: only contains the program execution time for now.
In each site directory, you have the following output files:
output.txt
: is the main output file. It gives you the posterior estimates and uncertainties of the three input variables (accumulation, LID and thinning) and of the output variables (ice age, air age, Δdepth, etc.). The header in the file tells you which column is which variable.restart.txt
: is a restart file, which can be used to start an optimization experiment from the result of a previous optimization experiment, for a faster convergence.deposition.pdf
: is the deposition rate figureage.pdf
: is the age for a non-ice-core archiveice_age.pdf
andair_age.pdf
: are the ice and air age figures for an ice coredelta_depth.pdf
: is the Δdepth figure for an ice coreice_layer_thickness
andair_layer_thickness.pdf
: are the ice and air layer thickness figures for an ice corelock_in_depth.pdf
: is the Lock-In Depth figure for an ice corethinning.pdf
: is the thinning figure for an ice core
In each site-pair directory, you have the following output files:
synchro.pdf
: is the stratigraphic links figure for a pair of non-ice-cores archivesice_synchro.pdf
: is the ice stratigraphic links figure when there is one ice core in the pairair_synchro.pdf
: is the air stratigraphic links figure when there is one ice core in the pairair_air_synchro.pdf
: is the air-air stratigraphic links figure for a pair of ice coresair_ice_synchro.pdf
: is the air-ice stratigraphic links figure for a pair of ice coresice_air_synchro.pdf
: is the ice-air stratigraphic links figure for a pair of ice coresice_ice_synchro.pdf
: is the ice-ice stratigraphic links figure for a pair of ice cores
If your run was successful, it has produced output files and figure files. To clean it from the results files, you can run the following command in ipython:
run Clean.py exp_directory/
You can have a look at the provided AICC2012-Hulu
directory.
You need to specify your prior scenarios for deposition rate (in all cases) and LID and thinning
(for an ice core) and your age observations.
You have five general files:
parameters.yml
: contains general parameters for the experimentparameters_all_sites.yml
: defines site parameters that are the same for all sites (there are overidded by site specific parameters).parameters_covariance_observations_all_sites.py
: defines the covariance of the observations that are the same for all sites (there are overidded by site specific parameters).parameters_covariance_observations_all_site_pairs.py
: defines the covariance for the observations that are the same for all site pairs (there are overidded by site pair specific parameters).
Then you have one directory per site, which contains:
parameters.yml
: all the site specific parametersparameters_covariance_observations.py
: this file allows to define the correlation of site specific observationsdeposition.txt
: depth / background accu (in ice-equivalent) / standard deviation (opt, in %)age_horizons.txt
: depth / age / sigma for dated horizons for a non-ice-coreage_intervals.txt
: epth_top / depth_bottom / duration / sigma for intervals for a non-ice-coreice_age_horizons.txt
: depth / age / sigma for ice dated horizons for an ice coreair_age_horizons.txt
: depth / age / sigma for air dated horizons for an ice coreice_age_intervals.txt
: depth_top / depth_bottom / duration / sigma for ice intervals for an ice coreair_age_intervals.txt
: depth_top / depth_bottom / duration / sigma for air intervals for an ice coredensity.txt
: depth / relative density for an ice corelock_in_depth.txt
: depth / Lock-in-Depth / standard deviation (opt, in %) for an ice corethinning.txt
: depth / thinning function / standard deviation (opt, in %) for an ice coredelta_depths.txt
: depth / Delta-depth / standard deviation for an ice core
Then you have one directory per site pair, which contains:
parameters_covariance_observations.py
: this file allows to define the correlation of site pair specific observations- `
ice_depth.txt
: depth1 / depth2 / sigma on age for ice-ice stratigraphic links observationsair_depth.txt
: depth1 / depth2 / sigma on age for air-air stratigraphic links observationsiceair_depth.txt
: depth1 / depth2 / sigma on age for ice-air stratigraphic links observationsairice_depth.txt
: depth1 / depth2 / sigma on age for air-ice stratigraphic links observations
A few things you need to know to use paleochrono:
- You can use whatever units you want but they need to be consistent. For example, if you use meters for the depths and years for the dated horizons, you need to use meters per years for the accumulation rates.
- The site specific parameters override the general parameters for all sites. In the very same way, the site-pair specific parameters override the general parameters for all site-pairs.
- The standard deviations defined in the parameters-Covariance*.py override the standard deviation defined in the observation or prior files.
- Most of these files are optional. If there is no file for an certain type of observations, that means that there is no observation of this type. If a covariance matrix is not defined for a prior or an observation type, that means that the correlation matrix is supposed to be equal to identity and that the standard deviation is given in the prior or observation file.
It contains the list of sites, the optimization method to be used and some settings for the figures.
It is where you define the names of your sites.
Have a look at the file AICC2012-Hulu/parameters.yml
, it is commented.
It defines age at the top of the core, the unthinned depth at the top of the core, the age equation grid, the correction functions grids and the type of representation of the prior accu scenario (linear or staircase). You can also define other parameters that are used to defined the covariance matrices of the priors.
Have a look at the files AICC2012-Hulu/EDC/parameters.yml
, it is commented.
You need to know a little bit of python to do that. Feel free to send an email on the mailing list if you need assistance.
For site specific observations, you set up the correlation matrices in the file parameters-CovarianceObservations.py
in the site directory.
self.icemarkers_correlation
: for ice dated horizonsself.airmarkers_correlation
: for air dated horizonsself.iceintervals_correlation
: for ice dated intervalsself.airintervals_correlation
: for air dated intervalsself.Ddepth_correlation
: for Delta-depth observations
For site pair specific observations (stratigraphic links), you set up the correlation matrices in the file parameters-CovarianceObservations.py
in the site pair directory.
self.iceicemarkers_correlation
: for ice-ice stratigraphic linksself.airairmarkers_correlation
: for air-air stratigraphic linksself.iceairmarkers_correlation
: for ice-air stratigraphic linksself.airicemarkers_correlation
: for air-ice stratigraphic links
Let us take a concrete example and assume we want a correlation matrix for ice dated horizons with ones in the diagonal and with a constant correlation factor k outside the diagonal, you can write:
self.icemarkers_correlation=k*np.ones((np.shape(self.icemarkers_correlation)))+(1-k)*np.diag(np.ones(np.shape(self.icemarkers_correlation)[0]))
Don't forget that if you find the use of python and the IceChrono internal variables too difficult, you can define your correlation matrices outside IceChrono and import them here by using for example the np.loadtxt
function.
Some errors can be eliminated by restarting the kernel in spyder (under "Console">"Restart kernel"). If the problem persist, please post an email to the author or on the mailing list with the error message appearing on the command line.