Skip to main content

A Halo Model calculator built on hmf

Project description

https://github.com/steven-murray/halomod/workflows/Tests/badge.svg https://badge.fury.io/py/halomod.svg https://codecov.io/gh/steven-murray/halomod/branch/master/graph/badge.svg https://img.shields.io/pypi/pyversions/halomod.svg https://img.shields.io/badge/code%20style-black-000000.svg

halomod is a python application that provides a flexible and simple interface for dealing with the Halo Model of Dark Matter Halos, built on hmf.

It also has a full-feature web application at https://thehalomod.app – check it out!

Full Documentation

Read the docs.

Features

  • All the features of hmf (several transfer function models, 15+ HMF fitting functions, efficient caching etc.)

  • Extended components for halo model:

    • 10+ halo bias models, plus scale-dependent bias from Tinker (2005).

    • 3+ basic concentration-mass-redshift relations, including the analytic Bullock (2001) model

    • Several plug-and-play halo-exclusion models (including ng-matched from Tinker+2005).

    • 5+ built-in HOD parametrisations.

    • Many built-in halo profiles, including NFW, generalised NFW, Hernquist etc.

    • Support for WDM models.

  • All basic quantities such as 3D correlations and power spectra, and projected 2PCF.

  • Several derived quantities (eg. effective bias, satellite fraction).

  • All models/components specifically written to be easily extendable.

  • Simple routine for populating a halo catalogue with galaxies via a HOD.

  • CLI script for producing any quantity included.

Usage

halomod can be used interactively (for instance in ipython or a jupyter notebook) or in a script. To use interactively, in ipython do something like the following:

>>> from halomod import HaloModel
>>> hm = HaloModel()  # Construct the object
>>> help(hm)          # Lists many of the available quantities.
>>> galcorr = hm.corr_auto_tracer
>>> bias = hm.bias
>>> ...

All parameters to HaloModel have defaults so none need to be specified. There are quite a few that can be specified however. Check the docstring to see the details. Furthermore, as halomod extends the functionality of hmf, almost all parameters accepted by hmf.MassFunction() can be used (check its docstring).

To change the parameters (cosmological or otherwise), one should use the update() method, if a HaloModel() object already exists. For example

>>> hm.update(rmin=0.1,rmax=1.0,rnum=100) #update scale vector
>>> corr_2h = hm.corr_2h_auto_tracer #The 2-halo term of the galaxy correlation function

Since HaloModel is a sub-class of MassFunction, all the quantities associated with the hmf are also included, so for example

>>> mass_variance = hm.sigma
>>> mass_function = hm.dndm
>>> linear_power = hm.power

Any parameter which defines a model choice (eg. a bias model) is named <component>_model, so for example, the bias model is called bias_model. Every model has an associated parameter called <component>_params, which is a dictionary of parameters to that model. The available choices for this dictionary depend on the model chosen (so that the Sheth-Tormen HMF has a different set of parameters than does the Tinker+2008 model). Within the constructed object, the actual model is instantiated and saved as <component>, so that this object can be accessed, and several internal methods can be called. Some of these are exposed directly by the HaloModel class (eg. one can call hm.n_sat directly, which itself calls a method of the hm.hod component).

Using the CLI

You can also run halomod from the command-line. For basic usage, do:

halomod run --help

Configuration for the run can be specified on the CLI or via a TOML file (recommended). An example TOML file can be found in examples/example_run_config.toml. Any parameter specifiable in the TOML file can alternatively be specified on the commmand line after an isolated double-dash, eg.:

halomod run -- z=1.0 hmf_model='SMT01' bias_model='Tinker10'

Acknowledgments

Thanks to Florian Beutler, Chris Blake and David Palamara who have all contributed significantly to the ideas, implementation and testing of this code.

Some parts of the code have been adapted from, influenced by or tested against:

Along with these, several other private codes have been compared to.

Attribution

Please cite

  1. Murray, Power and Robotham (2013) and/or https://ascl.net/1412.006 (whichever is more appropriate)

  2. Murray, Diemer and Chen (2020)

if you find this code useful in your research. Please also consider starring the GitHub repository.

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

halomod-2.1.0.tar.gz (24.0 MB view details)

Uploaded Source

Built Distribution

halomod-2.1.0-py2.py3-none-any.whl (6.9 MB view details)

Uploaded Python 2 Python 3

File details

Details for the file halomod-2.1.0.tar.gz.

File metadata

  • Download URL: halomod-2.1.0.tar.gz
  • Upload date:
  • Size: 24.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for halomod-2.1.0.tar.gz
Algorithm Hash digest
SHA256 a6314e2895370b15440245da3533ad9cea7ec37ff53f88f0c5d4b0bfc14cb83e
MD5 7ca8415ea7f1dacc42dc5bd5f57b7c7b
BLAKE2b-256 774f2d9a908549e107a550dc5def500e018d2fadce89f0f5b790f0ec555c296e

See more details on using hashes here.

File details

Details for the file halomod-2.1.0-py2.py3-none-any.whl.

File metadata

  • Download URL: halomod-2.1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 6.9 MB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.6

File hashes

Hashes for halomod-2.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 2f8ee60d1da849179775c23092f766475f171f4e1cf9385029c338b8eaa83a50
MD5 7ebbce8fcacdbbc2a0c28b1aa4b4c95c
BLAKE2b-256 8c2d905f5762d2765082ef2d8c8eb1be369c019189e4fd61c47139e9ceec75a0

See more details on using hashes here.

Supported by

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