Skip to content

Simple codes to run 3+1 ADM and BSSN evolutions of Kasner initial data

License

Notifications You must be signed in to change notification settings

leo-brewin/adm-bssn-numerical

Repository files navigation

Evolving initial data using the ADM and BSSN equations.

This repository provides simple Cadabra and Ada codes for 3+1 numerical evolutions of Kasner initial data.

Rationale

There is no need for yet another elementary code that does nothing more than evolve Kasner initial data. That job can be adequately done using existing codes (such as the Einstein Toolkit or Cactus). But if you want to do something slightly less standard (off piste), e.g., evolve the initial data with respect to a modified evolution scheme, then you are faced with a serious question. Should you invest the time to understand the inner workings of the existing software so that you can be assured that your changes actually do what you want them to do? Or do you use that same time to write your own code from the ground up? The later case is certainly an example of reinventing the wheel but once you have your new wheel your are in complete charge. The risk you take is that your code will contain bugs and that it will not have all the features of other codes.

The codes on which this project is based were written mainly because I did not have the time, the patience or the inclination to delve into the inner workings of Cactus. I did not need all of the features of Cactus. So I wrote a code that met my limited needs. I am sharing them here so that if anyone else feels inclined to write their own own (which I strongly encourage) you may find this code a useful guide (or maybe not). The bulk of the Ada code is standard (simple uni-grid code, periodic boundaries and second order centred finite differences). The things that might be of interest are the multi-tasking (using native Ada constructs) and the modular structure of the code (using Ada packages for the various tasks, e.g., I/O, time stepping, constraints).

The code uses Cadabra to convert the tensor equations to bare C-code. Other tools are used to integrate these into larger programs written in Ada. The result is a bridge between the formal equations on one side (the ADM or BSSN equations) and the numerical or graphical results on the other side (the data generated by the codes).

Having an automated system that converts the tensor equations to code and then runs that code to produce numerical or graphical results does make experimentation very easy. Your time can be spent on the mathematics rather than on writing low level code. This also reduces the chances of (human) coding errors.

This philosophy (of having computers do all the work) is not new. See for example the NRPY+ software and the Einstein Toolkit.

Why Cadabra?

Cadabra is a symbolic algebra system ideally suited to tensor computations in General Relativity. The core software is written in C++. Cadabra uses a subset of LaTeX for the tensor equations and Python to control the computations. Cadabra is mostly used to do abstract tensor computations (e.g., showing that the Levi-Civita connection is metric compatible) as well as component computations (e.g., computing the Riemann components for a Schwarzschild metric in isotropic coordinates).

Using familiar tools like LaTeX and Python means that the learning curve for Cadabra is very gentle (and that's a big plus).

A detailed tutorial on Cadabra can be found here.

Why Ada?

Most codes in computational relativity are written either in C/C++ or Fortran or some combination. So why does this project use Ada? The simple answer is that I like to do things outside the triangle. The better answer is that Ada is a superb language (IMHO) for any large scale computational project. Here are a few of its features.

  • Strong typing. Ada forces you to declare the type of every object. You can create your own types or use predefined types. This information is used by the compiler to avoid the classic apples and oranges errors.
  • Native multitasking. The Ada language contains explicit rules for multi-tasking and distributed computing.
  • Exception handling. Easily catch and handle any exceptions (array bounds error, floating point errors, file and i/o errors).
  • Platform agnostic. Ada codes can be ported from one platform to another without change. The usual #ifdef constructs in C/C++ have no counterparts in Ada. All platform dependencies are resolved in the compiler.
  • Interface with C and Fortran. Ada has precisely defined rules for communicating with C and Fortran codes. This makes it easy to access external libraries.

Installation

To build everything from scratch just run

$ source SETPATHS; make

from the top directory. This will build, install and run the Ada, Cadabra and LaTeX codes. The end result will be a pdf file adm-bssn-plots.pdf showing the evolution of the Kasner initial data for both the ADM and BSSN equations.

Note that the simple make command will install various files before running the ADM and BSSN codes. The files will be installed in the directories

Directory Content Path variable
$HOME/local/adm-bssn/bin/ Ada binaries, Python and Shell scripts $PATH
$HOME/local/adm-bssn/lib/ Python libraries $PYTHONPATH
$HOME/local/adm-bssn/tex/ LaTeX files $TEXINPUTS

The command source SETPATHS will prepend the directories to the appropriate paths. This ensures that the newly installed files can be found when the subsequent make command is run. If you need to recover the original paths, just run source OLDPATHS.

If you prefer to install the files in some other directory then you can run the command

$ source SETPATHS /full/path/to/dir/; make install

where /full/path/to/dir/ is the full path to your prefered directory. The bin, lib and tex directories will be ceated underneath this directory.

You can also compile and install these tools by hand. See the INSTALL.txt and utilities/INSTALL.txt for full details.

Uninstall

To remove all of the files installed outside of this repo, run

$ UNINSTALL.sh

However, if you chose to install the files in a location other than the default ($HOME/local/adm-bssn/bin/) you should run

$ UNINSTALL.sh /full/path/to/dir/

Tinkering with the codes

Most of the directories contain a Makefile and a build.sh file. These are useful when compiling and running the codes. You may want to look inside these files to see which make targets are available. The Makefile contains many targets while the build.sh script is a one-trick-pony (usually to just rebuild the files). In most cases build.sh is simply a wrapper to gprbuild.

You may notice that all of the Ada codes are compiled using gprbuild. This is a standard tool for Ada programs. It makes intelligent decisions about which files are out of date and which files need to be recompiled. The nice thing about gprbuild is that it determines the dependencies by inspection of the Ada files (compare this with make where the dependencies must be explicitly encoded in the Makefile).

If you make changes to any of the Cadabra codes in the bssn directory (for example) you will need to recompile the Cadabra codes then compile and run the Ada codes. This can be done using

cd bssn/cadabra
build.sh
cd ../bssn/code
build.sh
bssninitial.sh
bssnevolve.sh

If you make changes only to the Ada codes in bssn/code/src then you need only run

cd bssn/code
build.sh

Creating the initial data and running the evolution code for the BSSN equations can be done using

cd bssn/code
bssninitial.sh
bssnevolve.sh

All of the above tasks can also be run using selected targets in the Makefile. Similar steps can be taken when tinkering with the ADM codes.

Note that any changes to the ADM codes will have no effect on the BSSN codes and vice-versa. The single point of connection between the ADM and BSSN codes is that they share the support library.

Dependencies

You will need an Ada compiler and the Cadabra/Python/SymPy software.

Ada

Ada is part of the GNU compiler collection and compilers are available for a wide variety of platforms (including macOS, Linux and Windows). The compiler can be installed using standard package tools (e.g., sudo apt install gnat on Debian and friends) or by downloading the gnat community edition from the Adacore website.

Cadabra

Cadabra is easy to compile and install. Full details can be found on the Cadabra repository.

Python/SymPy

The codes have been tested with both Python2 and Python3. Since Python2 is deprecated it would be wise to use Python3. A popular distribution of Python3 can be found at the Anaconda website.

If you are not using the latest Anaconda distribution you may need to check that your version of SymPy is at least 1.7 (this is required only during the Ada code generation). You can install the latest version of SymPy in Anaconda using conda install sympy.

License

All files in this collection are distributed under the MIT license. See the file LICENSE.txt for the full details.

About

Simple codes to run 3+1 ADM and BSSN evolutions of Kasner initial data

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published