This repository provides simple Cadabra and Ada codes for 3+1 numerical evolutions of Kasner initial data.
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.
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.
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.
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.
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/
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.
You will need an Ada compiler and the Cadabra/Python/SymPy software.
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 is easy to compile and install. Full details can be found on the Cadabra repository.
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
.
All files in this collection are distributed under the MIT license. See the file LICENSE.txt for the full details.