PICO computes Cosmic Microwave Background power spectra and matter transfer functions orders of magnitude faster than CAMB or CLASS. It does so by fitting an interpolating function to various training data (much of this training data is computed by volunteers at Cosmology@Home). This is accurate enough for parameter estimation from Planck satellite data.
The original PICO was described in https://arxiv.org/abs/astro-ph/0606709 and https://arxiv.org/abs/0712.0194, although only the very basic idea of those papers remain in the current version. No updated paper exists, however, so please cite those papers if you are using PICO. Feel free to file an Issue if you find bugs or need any help.
You can install PICO via Pip:
pip install git+https://github.com/marius311/pypico [--user] [--upgrade]
or you can install from source by cloning this repostory and running:
git clone https://github.com/marius311/pypico
cd pypico
python setup.py build
python setup.py install [--user]
- If you don't have root access, the
--useroption installs PICO in your home directly. - The
--upgradeoption forces the newest version to be installed.
- Python 3.X
- NumPy (>=1.6.1)
- SciPy (>=0.10.1)
Once you have PICO installed, to do anything you'll need some data files which actually contain interpolated data. You can find them here.
After that, PICO is used from the Python shell. Typical usage starts by loading a PICO data file:
>> import pypico
>> pico = pypico.load_pico("example_pico_file.dat") To show accepted input parameters call:
>> pico.inputs()and to show outputted quantities call:
>> pico.outputs()Finally, to run PICO call:
>> result = pico.get(outputs, **inputs)where outputs is a list of outputs you actually want (or leave it unspecified to calculate all outputs), and **inputs is a dictionary of parameter values with keys for each input returned above. The return value result is a dictionary with a key corresponding to each output you requested.
-
Each PICO datafile is trained on a particular region of parameter space, generally one large enough to be relevant for typical analyses. If PICO is called for a set of parameters outside this range, a
CantUsePICOerror will be raised, and you should use CAMB instead. If you are running an MCMC chain, this can slow you down significantly before the chain is burned in. To remedy this, setforce=Trueto force PICO to return results even outside its training region. The results won't be guaranteed to be accurate, but will likely be good enough to get your chain to converge to the region where PICO is accurate. -
The PICO convention for multipole indexing is that an array entry
arr[l]corresponds to the l-th multiple. Since Python is 0-indexed, this means the first entry in an array is the 0-th multiple. -
The specification
pico.get(outputs, **inputs)meansgetcan be called in several ways, including>> pico.get(param1=val1, params2=val2) >> pico.get(**{'param1':val1, 'param2':val2}) >> pico.get(**dict(param1=val1, param2=val2)) >> pico.get(param1=val1, **{'param2':val2})
-
Certain data files may contain a set of example input values which can be accessed with:
pico.example_inputs()
PICO can be called from C/C++ and Fortran.
To call PICO from C/C++, you should include the following two header files:
#include <python.h>
#include "pico.h"Documentation for the functions defined in pico.h can be found in the pico.pyx file.
To call PICO from Fortran, you should use the following module:
use fpicoDocumentation for the functions in the fpico module can be found in the fpico_interface.f90 file.
- Note that the Fortran interface is built on C, and to ensure integer/real byte-sizes are the same between Fortran and C, independent of compiler, they are defined by hand as
fprealandfpintinfpico_interface.f90andpico.pyx.
When you installed PICO, a static library libpico.a was created. To link your code against this library, PICO provides an easy way to get include and link flags on your platform. To print out the necessary flags, call:
python -c "import pypico; print(pypico.get_include())"
python -c "import pypico; print(pypico.get_link())"You should put these calls directly in your Makefile via:
$(shell python -c "import pypico; print(pypico.get_link())")The fortran interface file fpico_interface.f90 should be recompiled each time along side your program, as it must use the same Fortran compiler. The location of this file can be accessed from your Makefile via:
$(shell python -c "import pypico; print(pypico.get_folder())")/fpico_interface.f90As of Apr 2014, partial PICO support is built into CosmoMC. See http://cosmologist.info/cosmomc/ for instructions.
If you have a code which currently calls CAMB_GetResults, its easy to swap in PICO_GetResults which uses PICO instead (and falls back on the CAMB version for parameters ouside of the PICO training region).
To install the CAMB plugin:
- Copy
plugins/camb/pico_camb.f90to the folder containing your code - In your Makefile, make sure
pico_camb.f90gets compiled andpico_camb.ogets included in your executable. - Add a call
fpico_load(file)to load a PICO datafile. - Replace
CAMB_GetResultswithPICO_GetResults - Add
use pico_cambwherever you needPICO_GetResults - Compile your code, making sure to use the correct include/link flags (see
Compiling and Linking_).
-fastwith Intel Fortran does not work in some cases.
PICO is written by Marius Millea. The CosmoMC plugin was largely written by Antony Lewis and Silvia Galli. PICO was originally created by Chad Fendt and Ben Wandelt.