Welcome to aurel's documentation!

Documentation GitHub Python 3.11+ License: GPL v3 PyPI Test build Coverage Email

Aurel is an open source Python package for numerical relativity analysis. Designed with ease of use in mind, it will automatically calculate relativistic terms.

Key Features

  • Comprehensive tensor calculations:

  • Dynamic computation and intelligent caching: Aurel automatically calculates only what’s needed and caches results, significantly improving performance for complex calculations

  • Clear user feedback: Progress bars and informative messages guide you through computations

  • Flexible data input: Works seamlessly with numerical simulation data, analytical solutions, or custom numpy arrays

  • Einstein Toolkit integration: Native support for reading Carpet HDF5 outputs from Einstein Toolkit simulations (documentation, example)

  • Advanced finite difference schemes: Multiple discretization schemes for 3D spatial grids

  • Built-in analytical solutions: Pre-implemented spacetimes for testing and validation (examples)

  • Time evolution support: Tools for analyzing data across multiple time steps (example)

Installation

Install aurel using pip:

pip install aurel

All required dependencies (Python 3.11+, numpy, scipy, sympy, matplotlib, h5py, ipython, jupyter, tqdm) will be installed automatically. To get the latest development version, use:

pip install git+https://github.com/robynlm/aurel.git@development

Getting started

Start your Python session on a jupyter notebook or in a Python script and import the aurel.AurelCore class:


   import aurel

   # Define your grid parameters
   param = {
       'Nx': 64, 'Ny': 64, 'Nz': 64,
       'xmin': -1.0, 'ymin': -1.0, 'zmin': -1.0,
       'dx': 0.03125, 'dy': 0.03125, 'dz': 0.03125,
   }

   # Initialize the finite difference class
   fd = aurel.FiniteDifference(param)

   # Initialize the AurelCore class
   rel = aurel.AurelCore(fd)

At this point you need to provide the spacetime metric, extrinsic curvature and matter fields (see documentation), where these would otherwise be assumed to correspond to Minkowski vacuum. These are passed as numpy arrays to aurel in the following way:

# Define the xx component of the spacetime metric
rel.data['gxx'] = np.ones((param['Nx'], param['Ny'], param['Nz']))

and so on for the other components and required quantities. In this example \(g_{xx} = 1\), but you can pass any numpy array; it can be of numerical relativity simulation data, or an array generated from an analytical expression.

With everything defined, you can call any entity listed in the descriptions list. Just call it as:

rel["name_of_the_entity"]

Aurel will automatically do its best to calculate any relativistic term you ask for.

For a more in depth example, see the example notebook for applications. Additionally, a symbolic counterpart that works in a very similar way is also available via the aurel.AurelCoreSymbolic class, see the symbolic example for details.

Calculations over time

If you want calculations over multiple moments in coordinate time, you can use the aurel.over_time function. First, create a dictionary containing the spacetime and matter fields over time:

# Define the spacetime metric gxx over time
data = {
    'gxx': [np.ones((param['Nx'], param['Ny'], param['Nz'])),
            np.ones((param['Nx'], param['Ny'], param['Nz']))],
    ...
}

That is a data dictionary with keys the names of the quantities, and values a list of numpy arrays, one for each time step. Calculations will be performed for each of these time steps as:

data = aurel.over_time(
   data, fd,
   vars=['name_of_the_entity', ..., {'custom_quantity': custom_quantity}],
   estimates=['name_of_estimate', ..., {'custom_estimate': custom_estimate}],
   **kwargs)

where vars is a list of entities to calculate at each time step (available terms are in the descriptions list, but you can also pass custom functions to calculate your own quantities). Likewise estimates is a list of estimates to calculate at each time step (available functions are in the estimates list, but you can also pass custom functions to calculate your own estimates). See the time evolution example for more details.

Citation

If you use aurel in your work, please cite:

Munoz, R. L. (2025). Aurel: A Python package for automatic relativistic calculations. GitHub. https://github.com/robynlm/aurel
@misc{aurel2025,
  title     = {Aurel: A Python package for automatic relativistic calculations},
  author    = {Munoz, Robyn L.},
  publisher = {GitHub},
  year      = {2025},
  url       = {https://github.com/robynlm/aurel}
}

This code is not published yet, so to add to citation count please also include:

Munoz, R. L., & Bruni, M. (2023). EBWeyl: a Code to Invariantly Characterize Numerical Spacetimes. Classical and Quantum Gravity, 40(13), 135010. https://doi.org/10.1088/1361-6382/acd6cf
@article{R.L.Munoz_M.Bruni_2023,
  title     = {EBWeyl: a Code to Invariantly Characterize Numerical Spacetimes},
  author    = {Munoz, Robyn L. and Bruni, Marco},
  journal   = {Classical and Quantum Gravity},
  volume    = {40},
  number    = {13},
  pages     = {135010},
  year      = {2023},
  month     = {jun},
  doi       = {10.1088/1361-6382/acd6cf},
  archivePrefix = {arXiv},
  eprint    = {2211.08133},
  primaryClass = {gr-qc}
}