Skip to main content

Bring colors to Euclid tiles!

Project description

Logo

Bring colors to Euclid tiles!

Azul(ero)* is a toolbox which, among others, provides scripts to download and merge VIS and NIR observations over a MER tile. For rendering color images, azul process detects and inpaints bad pixels (cold pixels, saturated stars...), and combines the 4 channels (I, Y, J, H) into an sRGB image. Input data files can be selected with azul find and then downloaded with azul retrieve, which connects to public (SAS) or private (EAS) data archives. Last but not least, azul roam produces flowing videos by panning and zooming images.

*I started this project when Euclid EROs came out...

License

Apache-2.0

Installation and setup

Install the azulero package with:

pip3 install azulero

If you wish to access Euclid-internal data, see azul retrieve documentation to configure authentication.

For azul find, download the geojson file which monitors MER processing, e.g., for DR1: DpdMerFinalCatalog.geojson

Basic usage

The typical workflow is as follows:

  • 🎯 Find the tile indices of your objects or coordinates with azul find.
  • 📥 Download the individual MER-processed FITS files of your tiles with azul retrieve.
  • ✂️ Optionally select the region to be processed with azul crop.
  • 🌟 Blend the channels and inpaint artifacts with azul process.
  • 🎬 Generate a video from the image with azul roam.

Usage:

azul [--workspace <workspace>] find [<objects>] [--radec <coordinates>]
azul [--workspace <workspace>] retrieve [--from <provider>] <tile_indices>
azul [--workspace <workspace>] crop <tile_index>
azul [--workspace <workspace>] process <tile_slicing>
azul [--workspace <workspace>] roam <image> <sequence>

with:

  • <workspace> - The parent directory to save everything, in which one folder per tile will be created (defaults to the current directory).
  • <object> - A space-separated list of object names, e.g. M82 NGC6536.
  • <coordinates> - RA/dec coordinates in decimal degrees, e.g. 266.9397155 +64.0472200; Option --radec can be specified multiple times.
  • <provider> - The data archive name, e.g. sas for public releases.
  • <tile_indices> - The space-separated list of tiles to be downloaded, typically the result of azul find.
  • <tile_index> - A single tile index.
  • <tile_slicing> - A single tile index, optionally followed by a slicing à-la NumPy, typically the result of azul crop.
  • <image> - The path to an input image (not necessarily produced by Azul).
  • <sequence> - The roaming configuration file: see the format description for details.

Example

Here is an example output:

PGC 61356

A field around PGC 61356

The two thick blue rings are artifacts of the VIS instrument known as ghosts. To my knowledge, the galaxy in the center -- PGC 61356 -- has never been resolved this way. Rendering the image allowed me to discover this is a splendid polar-ring galaxy! The previously unseen golden structure top left may be an Einstein ring, possibly with two deflectors -- the question remains open.

Credit: ESA Euclid/Euclid Consortium/NASA/Q1-2025/Antoine Basset (CNES)

The picture above was produced by the following commands:

azul retrieve 102159776 --from sas
azul process 102159776[6000:7000,5000:7000]

From the same tile, here is an example over a region with less artifacts:

UGC 11116

A field around UGC 11116

Credit: ESA Euclid/Euclid Consortium/NASA/Q1-2025/Antoine Basset (CNES)

azul process 102159776[11000:12000,7500:9500]

Advanced usage

Refer to the dedicated pages:

And check the different command help messages:

azul -h
azul find -h
azul retrieve -h
azul crop -h
azul process -h
azul roam -h

Citing Azulero

💞 If you use this software for academic publications, please cite as follows (adapt the version number):

Basset, A., Schirmer, M., Bouvard, T., Gimenez, R., Nguyen-Kim, K., & Candini, G. P. Azulero (Version 1.0.0) [Computer software]. DOI: 10.24400/815952/Azulero.

BibTeX format:

@software{Basset_azulero,
author = {Basset, Antoine and Schirmer, Mischa and Bouvard, Téo and Gimenez, Rollin and Nguyen-Kim, Kane and Candini, Gian Paolo},
license = {Apache-2.0},
title = {{Azulero}},
version = {1.0.0},
year = {2025},
url = {https://github.com/kabasset/azulero},
doi = {10.24400/815952/Azulero}
}

More details in CITATION.cff.

How to help?

  • Report bugs, request features, tell me what you think of the tool and results...
  • Mention myself (Antoine Basset, CNES) and/or Azulero when you publish images processed with this tool (see example credits above). Cite the software in academic publications (see previous section).
  • Share with me your images, I'm curious!

Contributors

  • Mischa Schirmer (MPIA): Azul's color blending is freely inspired by that of Mischa's script eummy.py.
  • Téo Bouvard (Thales): Drafed retrieve.
  • Rollin Gimenez (CNES): Fixed packaging.
  • Kane Nguyen-Kim (IAP): Provided URLs for retrieving public data.
  • Gian Paolo Candini (CSIC): Investigated rendering issues and improved parametrization.

Acknowledgements

  • 🚀 Thanks to my CNES and LISA managers, who let me work a bit on this project on open hours!
  • 🔥 Congratulations to the whole Euclid community; The mosaics are simply unbelievable!
  • 😍 Thank you Euclid astronomers for answering my dummy questions on the contents of the images I posted.

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

azulero-1.1.0.tar.gz (5.5 MB view details)

Uploaded Source

Built Distribution

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

azulero-1.1.0-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

File details

Details for the file azulero-1.1.0.tar.gz.

File metadata

  • Download URL: azulero-1.1.0.tar.gz
  • Upload date:
  • Size: 5.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for azulero-1.1.0.tar.gz
Algorithm Hash digest
SHA256 a74079ce8aaec953571a41279ffc99e633c7a531f27901da8a8fd3ce1bef8064
MD5 4ed6b7907fce49aa45edb814be94675f
BLAKE2b-256 7ff1be0a3883c3cc8af6638cd2a0a9f802e52111c8414739235bef0c89357841

See more details on using hashes here.

File details

Details for the file azulero-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: azulero-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 29.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for azulero-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ded500c32195c5d0ea6ae5575f589e3b53cff9c1bebbd40d171662e59c554903
MD5 91cde6e69f046411efbbbc52be6f3b43
BLAKE2b-256 1009dc5a8566211756a78a41caf865f64e5925facf29050b1f2da41003fdfaa6

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