Skip to main content

Interface to data produced by the Simulating eXtreme Spacetimes collaboration

Project description

Test Status Documentation Status PyPI Version Conda Version MIT License Binder

Simulating eXtreme Spacetimes package

The sxs python package provides a high-level interface for using data produced by the SXS collaboration. In particular, the function sxs.load can automatically find, download, and load data, returning objects that provide common interfaces to the various types of data, without forcing the user to worry about details like data formats or where to find the data. It can also automatically select the newest or highest-resolution dataset for a given simulation, or return a range of versions or resolutions. Currently, the high-level objects encapsulate

  • Simulations — a catalog of all simulations produced by the SXS collaboration
  • Simulation — an object encapsulating all data for a single simulation
  • Metadata — data describing the simulation parameters
  • Horizons — time-series data describing the apparent horizons
  • Waveforms — time-series data describing the extrapolated gravitational-wave modes

Installation

Because this package is pure python code, installation is very simple. In particular, with a reasonably modern installation, you can just run a command like

conda install -c conda-forge sxs

or

python -m pip install sxs

Here, conda requires the conda installation of python, which is the most recommended approach for scientific python; the second command assumes that you have an appropriate python environment set up in some other way. Either of these commands will download and install the sxs package and its most vital requirements.

If you want to install all the goodies that enable things like jupyter notebooks with plots and interactive tables, you could run

conda install -c conda-forge sxs-ecosystem

or

python -m pip install sxs[ecosystem]

You will probably also want to set some sensible defaults to automatically download and cache data:

python -c "import sxs; sxs.write_config(download=True, cache=True)"

This will write a configuration file in the directory returned by sxs.sxs_directory("config"), and downloaded data will be cached in the directory returned by sxs.sxs_directory("cache"). See that function's documentation for details.

Usage

An extensive demonstration of this package's capabilities is available here, in the form of interactive jupyter notebooks that are actually running this code and some pre-downloaded data. The following is just a very brief overview of the sxs package's main components.

There are five important objects to understand in this package:

import sxs

simulations = sxs.load("simulations")
sxs_bbh_1234 = sxs.load("SXS:BBH:1234")
metadata = sxs_bbh_1234.metadata
horizons = sxs_bbh_1234.horizons
h = sxs_bbh_1234.h

The simulations object contains information about every simulation in the catalog, including all available data files, and information about how to get them. You probably don't need to actually know about details like where to get the data, but simulations can help you find the simulations you care about. It is a dict object, where the keys are names of simulations (like "SXS:BBH:0123") and the values are the same types as the metadata object, which contains metadata about that simulation — things like mass ratio, spins, etc. This metadata reflects the actual output of the simulations, which leads to some inconsistencies in their formats. A more consistent interface (though it is biased toward returning NaNs where a human might glean more information) is provided by simulations.dataframe, which returns a pandas DataFrame with specific data types for each column.

The actual data itself is primarily contained in the next two objects. The horizons object has three attributes — horizons.A, horizons.B, and horizons.C — typically representing the original two horizons of the black-hole binary and the common horizon that forms at merger. In matter simulations, one or more of these may be None. Otherwise, each of these three is a HorizonQuantities object, containing several timeseries relating to mass, spin, and position.

Finally, the waveform encapsulates the modes of the waveform and the corresponding time information, along with relevant metadata like data type, spin weight, etc., and useful features like numpy-array-style slicing.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sxs-2024.0.24.tar.gz (9.7 MB view details)

Uploaded Source

Built Distribution

sxs-2024.0.24-py3-none-any.whl (240.4 kB view details)

Uploaded Python 3

File details

Details for the file sxs-2024.0.24.tar.gz.

File metadata

  • Download URL: sxs-2024.0.24.tar.gz
  • Upload date:
  • Size: 9.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for sxs-2024.0.24.tar.gz
Algorithm Hash digest
SHA256 9ccac53d6786c538934377c90c7e7b48eced14bcff1325351efcd24ffa402de0
MD5 dadb6c9eca26513d1f1c4e126cc53f70
BLAKE2b-256 bab54f58e76a2c283adcd7731fce2f93b825996292735487cef5b7e0c803da83

See more details on using hashes here.

File details

Details for the file sxs-2024.0.24-py3-none-any.whl.

File metadata

  • Download URL: sxs-2024.0.24-py3-none-any.whl
  • Upload date:
  • Size: 240.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for sxs-2024.0.24-py3-none-any.whl
Algorithm Hash digest
SHA256 91063972f2b053f49130860b9cbbfcb0b91378fee7b413be717e39b281aa8f10
MD5 af1b4f355c96b7c04a46a10d9aaee483
BLAKE2b-256 a01c86d842bc46643b638a6b03555f3f0e509256c1e7060bc4c412012aa66a28

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