Skip to main content

Imaging radio interferometric data with neural networks

Project description

radionets Actions Status codecov DOI

Radionets logo. Deep-learning based imaging in radio interferometry.

Imaging Radio Interferometric Data with Neural Networks

Deep-learning framework for the simulation and analysis of radio interferometric data in Python. The goal is to reconstruct calibrated observations with convolutional Neural Networks to create high-resolution images. For further information, please have a look at our paper.

Analysis strategies leading to reproducible processing and evaluation of data recorded by radio interferometers:

  • Simulation of datasets (see also the radiosim repository)
  • Simulation of radio interferometer observations (see also the pyvisgen repository)
  • Training of deep learning models
  • Reconstruction of radio interferometric data

Installation

This repository is built as a python package. We recommend creating a mamba environment to handle the dependencies of all packages. You can create one by running the following command in this repository:

$ mamba env create -f environment.yml

Depending on your cuda version you have to specify the cudatoolkit version used by pytorch. If you are working on machines with cuda versions < 10.2, please change the version number in the environment.yml file. Since the package pre-commit is used, you need to execute

$ pre-commit install

after the installation.

Usage

For each task, executables are installed to your PATH. Each takes toml configuration files as input to manage data paths and options. Simulated data is saved in hdf5; trained models are saved as pickle files.

  • radionets_simulations <...> This script is used to simulate radio interferometric data sets for the training of deep learning models.
  • radionets_training <...> This script is used to train a model on events with known truth values for the target variable, usually Monte Carlo simulations.
  • radionets_evaluation <...> This script is used to evaluate the performance of the trained deep-learning models.

Default configuration files can be found in the examples directory. The examples directory contains jupyter notebooks, which show an example analysis pipeline and the corresponding commands. (need a rework)

Structure of the Repository

dl_framework

The used deep learning framework is based on pytorch and fastai. An introduction to Neural Networks and an overview of the use of fastai to train deep learning models can be found in Practical Deep Learning for Coders, v3 and fastbook.

dl_training

Functions for handling the different training options. Currently, there are the training, the learning rate finder, and the loss plotting mode available.

simulations (further developed in pyvisgen repository)

Functions to simulate and illustrate radio interferometric observations. At the moment simulations based on the MNIST dataset and simulations of Gaussian sources are possible. We are currently working on simulating visibilities directly in Fourier space. For more information, visit our corresponding repository pyvisgen. In the future, the simulations will be created using the pyvisgen repository, while the radionets repository contains the training and evaluation methods.

evaluation

Functions for the evaluation of the training sessions. The available options reach from single, exemplary plots in (u, v) space and image space to methods computing characteristic values on large test datasets. In detail:

  • Amplitude and phase for the prediction and the truth. Example image below includes the difference between prediction and truth.
  • Reconstructed source images with additional features, such as MS-SSIM values or the viewing angle. Example image below.
  • Histogram of differences between predicted and true viewing angles. The image includes a comparison with wsclean.
  • Histogram of the ratio between predicted and true source areas. The image includes a comparison with wsclean.
  • Histogram of flux difference in the core component. The image includes a comparison with wsclean.
  • Included, but not yet fully operational
    • Histogram of differences between predicted and true MS-SSIM values on a dedicated test dataset
    • Histogram of differences between predicted and true dynamic range values on a dedicated test dataset

All histograms are created on a dedicated test dataset.

Contributors

Versions used and tested

  • Python >= 3.8
  • pyTorch >= 1.11.0
  • torchvision >= 0.12.0
  • cudatoolkit >= 11.3

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

radionets-0.4.0.tar.gz (96.4 kB view details)

Uploaded Source

Built Distribution

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

radionets-0.4.0-py3-none-any.whl (81.2 kB view details)

Uploaded Python 3

File details

Details for the file radionets-0.4.0.tar.gz.

File metadata

  • Download URL: radionets-0.4.0.tar.gz
  • Upload date:
  • Size: 96.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for radionets-0.4.0.tar.gz
Algorithm Hash digest
SHA256 76d3180ae29b17bd4541eb181f36158976faf0d9232da0fc77c4d51a88721bf1
MD5 d3ea404270ca776d8ee405915730e74a
BLAKE2b-256 0f6ac529f711565d64d59c0f8e3229976399c4b96d002325ad940d88580ea165

See more details on using hashes here.

Provenance

The following attestation bundles were made for radionets-0.4.0.tar.gz:

Publisher: pypi-publish.yml on radionets-project/radionets

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file radionets-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: radionets-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 81.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for radionets-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3bd447b916a3bcff7d8691ef21b865230f980b6652da711eb54d7f5fc120ba11
MD5 a665bdb9cffff3546ce98b808e545223
BLAKE2b-256 fa77f8997081244e115ae7a00ca79803e32bb58e299a614412b01409c321061e

See more details on using hashes here.

Provenance

The following attestation bundles were made for radionets-0.4.0-py3-none-any.whl:

Publisher: pypi-publish.yml on radionets-project/radionets

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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