Python wrapper for EuclidEmulator2
Project description
EuclidEmulator2 (version 1.0.1 of emulator, version 1.2.1 of wrapper)
This package includes a python wrapper of EuclidEmulator2, a fast and accurate tool to estimate the non-linear correction to the matter power spectrum developed by M. Knabenhans. EuclidEmulator2 allows for 8-parameter cosmological models including massive neutrinos (assuming a degenerate hierarchy) and dynamical dark energy. The source for EuclidEmulator2 is written in C++, with most main functions accessed through the python wrapper.
Authors: M. Knabenhans (emulator), Pedro Carrilho (python wrapper)
Date of last update: December 2022
Reference: Euclid Consortium: Knabenhans et al. (submitted), https://arxiv.org/abs/2010.11288
If you use EuclidEmulator2 in any way (for a publication or otherwise), please cite this paper.
Contact information: If you have any questions and/or remarks related to this work, please do not hesitate to send an email to (p.gregoriocarrilho@qmul.ac.uk)
Currently implemented features in this python wrapper:
-
emulation of the non-linear correction factor B(k,z)
-
large allowed redshift interval: z in the interval [0.0,10.0]
-
spatial scales spanning more than three orders of magnitude: 8.73 x 10-3 h / Mpc ≤ k ≤ 9.41 h / Mpc.
-
Cosmology defined via parameter dictionary
-
Outputs numpy arrays
-
Can output in custom k-range with extrapolation outside default range
See below for a tutorial on usage explaining these functionalities
Quick start
Prerequisites
In any case you need:
- C++11 or later
- GNU Scientific Library version 2.5 or higher (GSL; see https://www.gnu.org/software/gsl/)
- g++ version 4.9.1 or higher
GSL install
On most machines, building GSL is relatively simple. To install it locally, e.g. in ~/local/gsl
, use
mkdir -p $HOME/local/gsl && cd $HOME/local
wget -c ftp://ftp.gnu.org/gnu/gsl/gsl-latest.tar.gz -O - | tar zxv
The install procedure follows standard steps, but each one might take several minutes. Execute each command separately and only continue if there are no errors.
./configure --prefix=$HOME/local/gsl
make
make check
make install
Once done, make sure to add the GSL library to your library path with
export LD_LIBRARY_PATH=$HOME/local/gsl/lib${LD_LIBRARY_PATH:+:$LD_LIBRARY_PATH}
Usage
To load the package in python use
import euclidemu2
The main function is get_boost(cosmo_par, redshifts, k_custom=None)
that takes a dictionary of cosmological parameters, an array with the requested redshifts and an optional array with a custom range of wave numbers. It outputs an array with the k values used and a dictionary with the boosts, indexed in the same order as the chosen redshifts. An example run looks like
import euclidemu2
import numpy as np
import matplotlib.pyplot as plt
ee2=euclidemu2.PyEuclidEmulator()
cosmo_par={'As':2.1e-09, 'ns':0.966, 'Omb':0.04,'Omm':0.3,'h':0.68,'mnu':0.15,'w':-1.0,'wa':0.0}
redshifts=[0,2,4,6,8,10]
k, b = ee2.get_boost(cosmo_par,redshifts)
for i in range(len(redshifts)):
plt.loglog(k,b[i],label="z="+str(redshifts[i]))
plt.legend()
plt.show()
If everything is correctly installed, this should produce a plot of the boosts for the chosen redshifts.
Should the user have installed classy
, it is also possible to compute the full non-linear power spectrum via
k, pnl, plin, b = ee2.get_pnonlin(cosmo_par, redshifts, k_custom)
which will now output pnl
in addition to the linear power spectrum plin
and the boost b
, which are all indexed in the same way as the boost from get_boost
.
If classy
is not installed, a warning will appear when loading euclidemu2
and the get_pnonlin
function will not work. The get_boost
function will always work.
Warning: In the most recent versions of Python (e.g. 3.8) classy
may not work unless it is the first package to be imported. This is taken into account when calling euclidemu2
, but implies that euclidemu2
must be the first package to be imported. This has been verified not to be a problem for older versions of python (e.g. 3.6).
License
EuclidEmulator2 is free software, distributed under the GNU General Public License. This implies that you may freely distribute and copy the software. You may also modify it as you wish, and distribute these modified versions. You must always indicate prominently any changes you made in the original code and leave the copyright notices, and the no-warranty notice intact. Please read the General Public License for more details.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file euclidemu2-1.2.1.tar.gz
.
File metadata
- Download URL: euclidemu2-1.2.1.tar.gz
- Upload date:
- Size: 7.2 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.8.1 requests/2.26.0 setuptools/59.4.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 32ec6df22a47086205af476a1c4dd233595d36c39f9e1ca71a333437f8505a19 |
|
MD5 | c3df2885f6957763155303c376cd3ca8 |
|
BLAKE2b-256 | 03d9d11b147735413bbd9e65384f8f2848ff5b5a6f3dacf21bbb71e54488890c |
File details
Details for the file euclidemu2-1.2.1-cp38-cp38-macosx_10_9_x86_64.whl
.
File metadata
- Download URL: euclidemu2-1.2.1-cp38-cp38-macosx_10_9_x86_64.whl
- Upload date:
- Size: 7.3 MB
- Tags: CPython 3.8, macOS 10.9+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.8.1 requests/2.26.0 setuptools/59.4.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9e7685d70462689f3c1137cb8a7965ab6402d7a0f17a28aee2d28d37e9344b0d |
|
MD5 | ab430ecb4d6ac10766e972f59f0ed203 |
|
BLAKE2b-256 | b7ba831e33f538ce86b653ffbfdfc2df0078ccd1ef6f16a4c556daa968483895 |