Skip to main content

A Python package for analyzing tree data and especially merger trees.

Project description

ytree

CircleCI codecov pre-commit.ci status Documentation Status PyPI version Anaconda-Server Badge DOI DOI yt-project

This is ytree, a yt extension for working with tree data and especially merger trees.

Generally speaking, tree data defines a one-directional relationship between a series of objects. In trees, objects can have one or more ancestors, but only a single descendent.

Structure formation in cosmology proceeds in a hierarchical fashion, where dark matter halos grow via mergers with other halos. This type of evolution can be conceptualized as a tree, with small branches connecting to successively larger ones, and finally to the trunk. A merger tree describes the growth of halos in a cosmological simulation by linking a halo appearing in a given snapshot to its direct ancestors in a previous snapshot and its descendent in the next snapshot.

Merger trees are computationally expensive to generate and a great number of codes exist for computing them. However, each of these codes saves the resulting data to a different format. ytree is Python package for reading and working with merger tree data from multiple formats. If you are already familiar with using yt to analyze snapshots from cosmological simulations, then think of ytree as the yt of merger trees.

To load a merger tree data set with ytree and print the masses of all the halos in a single tree, one could do:

>>> import ytree
>>> a = ytree.load('tree_0_0_0.dat')
>>> my_tree = a[0]
>>> print(my_tree['tree', 'mass'].to('Msun'))
[6.57410072e+14 6.57410072e+14 6.53956835e+14 6.50071942e+14 ...
 2.60575540e+12 2.17122302e+12 2.17122302e+12] Msun

A list of all currently supported formats can be found in the online documentation. If you would like to see support added for another format, we would be happy to work with you to make it happen. In principle, any type of tree-like data where an object has one or more ancestors and a single descendent can be supported.

Installation

ytree can be installed with pip or conda:

pip installation

pip install ytree

conda installation

conda install -c conda-forge ytree

source installation

To get the development version, clone this repository and install like this:

git clone https://github.com/ytree-project/ytree
cd ytree
pip install -e .

Getting Started

The ytree documentation will walk you through installation, get you started analyzing merger trees, and help you become a contributor to the project. Have a look!

Sample Data

Sample data for all merger tree formats supported by ytree is available on the yt Hub in the ytree data collection.

Contributing

ytree would be much better with your contribution! As an extension of the yt Project, we follow the yt guidelines for contributing.

Citing ytree

If you use ytree in your work, please cite the following:

Smith et al., (2019). ytree: A Python package for analyzing merger trees.
Journal of Open Source Software, 4(44), 1881,
https://doi.org/10.21105/joss.01881

For BibTeX users:

  @article{ytree,
    doi = {10.21105/joss.01881},
    url = {https://doi.org/10.21105/joss.01881},
    year  = {2019},
    month = {dec},
    publisher = {The Open Journal},
    volume = {4},
    number = {44},
    pages = {1881},
    author = {Britton D. Smith and Meagan Lang},
    title = {ytree: A Python package for analyzing merger trees},
    journal = {Journal of Open Source Software}
  }

If you would like to also cite the specific version of ytree used in your work, include the following reference:

  @software{britton_smith_2025_16983993,
    author       = {Britton Smith and
                    Meagan Lang and
                    John Wise and
                    Juanjo Bazán},
    title        = {ytree-project/ytree: ytree 3.3.0 Release},
    month        = aug,
    year         = 2025,
    publisher    = {Zenodo},
    version      = {ytree-3.3.0},
    doi          = {10.5281/zenodo.16983993},
    url          = {https://doi.org/10.5281/zenodo.16983993},
  }

Resources

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

ytree-3.3.1.tar.gz (849.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ytree-3.3.1-py3-none-any.whl (142.2 kB view details)

Uploaded Python 3

File details

Details for the file ytree-3.3.1.tar.gz.

File metadata

  • Download URL: ytree-3.3.1.tar.gz
  • Upload date:
  • Size: 849.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for ytree-3.3.1.tar.gz
Algorithm Hash digest
SHA256 5ea8de083048d8d877203af3aeff450b9a2ef385d52361cdce1c3422fd4fa1cb
MD5 17b817e36d4a2d7d9925106f573b54d6
BLAKE2b-256 2b0141fd3fe5080561baad2add2189aaa0fc90de247e52a8d72ef188d714a74c

See more details on using hashes here.

File details

Details for the file ytree-3.3.1-py3-none-any.whl.

File metadata

  • Download URL: ytree-3.3.1-py3-none-any.whl
  • Upload date:
  • Size: 142.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for ytree-3.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 daca518da74dd3e954e201a6900684cacf08ffc5cd6b62c4aa0a42301eb32595
MD5 a4973e69c6f55b2b71857732be44d50e
BLAKE2b-256 4b0a4093361df8bf2966bd1c7379de56c1ec79259fccb74c3df8da2e12185883

See more details on using hashes here.

Supported by

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