Skip to main content

A two-channel deconvolution method with Starlet regularization

Project description

STARRED: STARlet REgularized Deconvolution

pipeline status coverage report Python 3.11 License: GPL v3 DOI pypi

STARlet REgularized Deconvolution (STARRED) is a Python deconvolution method powered by Starlet regularization and JAX automatic differentiation. It uses a Point Spread Function (PSF) narrower than the original one as kernel.

The main Documentation can be found here

Installation

Through PyPI

STARRED releases are distributed through the Python Package Index (PyPI). To install the latest version use pip:

$ pip install starred-astro

or, with the optional dependencies:

$ pip install starred-astro[opt]

The correlated field background model relies on NIFTy, which is installed through the dedicated cf extra:

$ pip install starred-astro[cf]

You can also combine extras, e.g. pip install starred-astro[opt,cf].

Through Anaconda

We provide an Anaconda environment that satisfies all the dependencies in starred-env.yml.

$ git clone https://gitlab.com/cosmograil/starred.git
$ cd starred
$ conda env create -f starred-env.yml
$ conda activate starred-env
$ pip install .

In case you have an NVIDIA GPU, this should automatically download the right version of JAX as well as cuDNN. Next, you can run the tests to make sure your installation is working correctly.

# While still in the STARRED directory:
$ pytest . 

Manually handling the dependencies

If you want to use an existing environment, just omit the Anaconda commands above:

$ git clone https://gitlab.com/cosmograil/starred
$ cd starred 
$ pip install .

or if you need to install it for your user only:

$ python setup.py install --user 

STARRED runs much faster on GPUs, so make sure you install a version of JAX that is compatible with your version of CUDA and cuDNN. Refer to the installation page of the JAX documentation.

Requirements

STARRED requires the following Python packages:

  • astropy
  • dill
  • jax
  • jaxlib
  • matplotlib
  • numpy
  • scipy
  • optax
  • tqdm
  • h5py

Additionnaly, the following package needs to be installed if you want to sample posterior distribution:

  • emcee
  • mclmc

Other optional dependencies are required for specific functionalities:

  • scikit-image for the reconstruction of the narrow PSF from a PSF model.
  • pyregion for the reading of DS9 region files.
  • nifty (installed via the cf extra) for the correlated field background model, which parameterizes the deconvolution background as a Gaussian process instead of starlet-regularized free pixels.

Example Notebooks and Documentation

We provide several notebooks to help you get started.

Start here to grasp the basic STARRED workflow.

More example notebooks going in more detail of how the internals work can be found in the notebooks directory:

The mathematical formalism along with further examples are also presented in Millon et al. (2024). All the examples and tests presented in this paper can be reproduced from this repository:

You can also run STARRED from the command line by following these instructions. STARRED is now fully integrated into lightcurver,
which helps you producing light curves by preparing your data in the correct format to be analyzed by STARRED and ensure accurate epoch-to-epoch photometric calibration.

Finally, the full documentation can be found here and a video presentation of STARRED is accessible on Youtube.

STARRED users community

If you want to join the STARRED users community on Slack to ask questions, propose future developments or share your latest results, please send an email to this address to get an invitation link.

Attribution

If you use this code, please cite Michalewicz et al. 2023 and Millon et al. 2024 as indicated in the documentation.

License

STARRED is a free software. You can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation.

STARRED is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY, without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details (LICENSE.txt).

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

starred_astro-1.6.0.tar.gz (147.0 kB view details)

Uploaded Source

Built Distribution

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

starred_astro-1.6.0-py3-none-any.whl (155.3 kB view details)

Uploaded Python 3

File details

Details for the file starred_astro-1.6.0.tar.gz.

File metadata

  • Download URL: starred_astro-1.6.0.tar.gz
  • Upload date:
  • Size: 147.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for starred_astro-1.6.0.tar.gz
Algorithm Hash digest
SHA256 cf708ef28ed5621c0f98b0215c9480c89bcec119b1a31e796ed02213cb581f88
MD5 00390a490405887986ad81b1c9bb2c47
BLAKE2b-256 f7ff40889ac830a70f54f89b892ae71d6c556f6982213ed68b69ea9bfdf17f8b

See more details on using hashes here.

File details

Details for the file starred_astro-1.6.0-py3-none-any.whl.

File metadata

  • Download URL: starred_astro-1.6.0-py3-none-any.whl
  • Upload date:
  • Size: 155.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.14

File hashes

Hashes for starred_astro-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fc7e9edba86e6b698a39c4b332992c099a0932e216d14386cdb8c33b8dddd5e6
MD5 8e7a2939db9b302bb868f5cd1d6a53f7
BLAKE2b-256 f9ae3497c07b1e763e05270f7888b89755e04068e202ff152fb7d2a397e22334

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