Skip to main content

Python wrapper for EuclidEmulator2

Project description

EuclidEmulator2 (version 1.0.1)

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: March 2021
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:

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 as ee2
import numpy as np
import matplotlib.pyplot as plt
import scipy, scipy.interpolate

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.

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

euclidemu2-0.0.0.tar.gz (7.2 MB view details)

Uploaded Source

Built Distribution

euclidemu2-0.0.0-cp38-cp38-macosx_10_9_x86_64.whl (7.3 MB view details)

Uploaded CPython 3.8 macOS 10.9+ x86-64

File details

Details for the file euclidemu2-0.0.0.tar.gz.

File metadata

  • Download URL: euclidemu2-0.0.0.tar.gz
  • Upload date:
  • Size: 7.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/52.0.0.post20210125 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.8

File hashes

Hashes for euclidemu2-0.0.0.tar.gz
Algorithm Hash digest
SHA256 670d7733b8bde6a6dd256a398e69045ccfdc06159a00197872412dfc9e14dd90
MD5 cfb583ecc8c66a89a6aa5a945207ac5d
BLAKE2b-256 c297648360d2d7e8c95489e63ea665b8cc14a87820392f4b3fa2bcb3f127813a

See more details on using hashes here.

File details

Details for the file euclidemu2-0.0.0-cp38-cp38-macosx_10_9_x86_64.whl.

File metadata

  • Download URL: euclidemu2-0.0.0-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.7.0 requests/2.25.1 setuptools/52.0.0.post20210125 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.8

File hashes

Hashes for euclidemu2-0.0.0-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 68307f97b626f6fc6a0a3ca3c5073d5db9ec44ddc9e440dac96a60de1864e586
MD5 cf68853c84679cba184fea80c1371ab6
BLAKE2b-256 8f8b23118751b1ad1bdb0d1c832c4d6a236ab3905e5e88cb3cfb8cdd84b6c3d0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page