Skip to main content

Containerized Automated Radio Astronomy Calibration

Project description

CARACal

CARACal stands for Containerized Automated Radio Astronomy Calibration and is a pipeline for radio interferometry data reduction

Main website: caracal.rtfd.io

It includes the Install & Run instructions described below, and much more.

Installation & Run

Usage and publication policy

When using CARACal please be aware of and adhere to the CARACal publication policy.

Requirements

  • Python 3.9 - 3.12. (For Python version below 3.12 if working on Ubuntu> 22.04. Install the earlier Python version through this link)

  • Container technology of your choice. It can be one of the following:
    • Docker

    • Podman

    • Singularity 3.5 - 4.1 (nearly all functionality available for > 2.6.0-dist, see here for further information)
      • Apptainer does not support all CARACal functionalities (at the moment).

Installation

We strongly recommend and describe an installation using a Python3 virtual environment. Only try outside a virtual environment if you know what you are doing. Any name as ${name} occurring in the description below can be chosen arbitrarily. If it symbolises directories or files, those directories or files should exist and the user should have write access.

There are three (3) available methods to install the caracal pipeline:

1. Manual

Choose the name of the virtual environment ${caracal-venv}. Then:

$ python3 -m venv ${caracal-venv}  # Ensure Python version is between 3.9 and 3.12.

OR, if the command above does not work

virtualenv -p python3 ${caracal-venv}
source ${caracal-venv}/bin/activate
pip install -U pip setuptools wheel

For a CARACal stable release run:

pip install -U caracal

And CARACal developer version which is not recommended for users:

pip install -U 'caracal @ git+https://github.com/caracal-pipeline/caracal.git@master'

Ignore any error messages concerning `pyregion`.

1.1 container configuration

In case you are not carrying out a fresh installation, remove earlier Stimela images with:

stimela clean -ac

Then, if using Docker:

stimela pull

If using Singularity, choose a pull folder ${singularity_pull_folder}, where the Singularity images are stored and define an environment variable by adding this in the rc file of your shell (e.g. .bashrc):

export SINGULARITY_PULLFOLDER=${WORKSPACE_ROOT}/singularity_images

and run:

stimela pull -s

If using Podman:

stimela pull -p

2. caratekit.sh script

Download the installation script caratekit.sh . Choose the parent directory ${workspace} and the name of the CARACal directory ${caracal_dir}. Any name as ${name} occurring in the description below can be chosen arbitrarily. If it symbolises directories or files, those directories or files should exist and the user should have write acccess.

If using Docker:

caratekit.sh -ws ${workspace} -cr -di -ct ${caracal_dir} -rp install -f -kh

If using Singularity:

caratekit.sh -ws ${workspace} -cr -si -ct ${caracal_testdir} -rp install -f -kh

3. Poetry (For developers)

Installation from source using poetry. First, install poetry:

pip install poetry

In the working directory where source is checked out run poetry install or to include all optional dependencies:

poetry install

Installation on (ILIFU) slurm environment

The installation of CARACal on ilifu has been tried and tested on the Ubuntu 20.0 operating system, although, it should also work on other OS versions. On the login node, follow these instructions:

cd /path/to/working/area
module add python/3.9.4
python3 -m venv <venv-name>
source <venv-name>/bin/activate
pip install -U pip setuptools wheel
git clone https://github.com/caracal-pipeline/caracal.git
pip install -U -e caracal
deactivate

where /path/to/working/area is the actual path to the directory where you wish to install CARACal. In principle, this can also be done in the Slurm environment of ILIFU by submitting an sbatch script. Please amend your pip install command with [all] option when needed in accordance with the instructions above. Install the latest release with:

pip install -U caracal

NB: The latest version of stimela singularity images needed for CARACal are stored in this location: /idia/software/containers/STIMELA_IMAGES/. For older versions, refer to the legacy directory: /idia/software/containers/STIMELA_IMAGES_legacy/.

Running

If you installed CARACal manually, activate the virtual environment with:

source ${caracal-venv}/bin/activate

If you installed CARACal with the caratekit.sh script, activate the virtual environment with:

source ${workspace}/${caracal_dir}/caracal_venv/bin/activate

If using Docker run CARACal with:

caracal -c ${your-configuration-file}

If using Singularity run CARACal with:

caracal -ct singularity -c ${your-configuration-file}

For more detailed installation instructions, troubleshooting tips and a full user manual please see caracal.readthedocs.io.

New issues

We encourage users who experience problems installing or running CARACal to check for known issues or open a new issue at our GitHub issues page.

When opening a new issue, please include your:
  1. installation type (e.g., Docker, Singularity)

  2. software version (both CARACal and Stimela)

  3. CARACal configuration file

  4. CARACal log files.

License

This project is licensed under the GNU General Public License v2.0 - see license for details.

Contribute

Contributions are always welcome! Please ensure that you adhere to our coding standards pep8.

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

caracal-1.2.1.tar.gz (58.1 MB view details)

Uploaded Source

Built Distribution

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

caracal-1.2.1-py3-none-any.whl (58.2 MB view details)

Uploaded Python 3

File details

Details for the file caracal-1.2.1.tar.gz.

File metadata

  • Download URL: caracal-1.2.1.tar.gz
  • Upload date:
  • Size: 58.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.24

File hashes

Hashes for caracal-1.2.1.tar.gz
Algorithm Hash digest
SHA256 0e4805e82c4e33150c5d85271327962e861b768c7433ea412cdf5dddedc3cc18
MD5 5dd82351ceaf18b6c2419e1c60d121f9
BLAKE2b-256 1d6f6fbcd4b1db0dd99172ead01fd79dc1b06287e949fe5ae4ed1e2a08efd002

See more details on using hashes here.

File details

Details for the file caracal-1.2.1-py3-none-any.whl.

File metadata

  • Download URL: caracal-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 58.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.24

File hashes

Hashes for caracal-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c206d9aca283d7c46bd22cf7a5e82d47eb21280d2678014ba7544f4ad4d007d2
MD5 df7bbeacde11e2c218dca4185e2f9983
BLAKE2b-256 460d942c6a3dfcbadb8e2063f4358f8828111fa2fc2680e4bee6e03b2fa3dacd

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