PREtty PIctures using PYthon
This package provides the ability to stretch and combine astronomical images from multiple bands into (RGB) colour images.
Images can be created in two main modes:
- JPEG image containing only the image in the pixel scale of the input, including coordinate information readable by e.g. Aladin.
- DEVELOPMENT Matplotlib image containing one ore more RGB conmibations from different bands in a grid layout. World coordinate axes are plotted on the images if available in the original input files. An additional sup-header containing the source name can be included. This mode also supportes multiple different options, such as plotting grid lines on top of the image, marking the center point in the image, of marking additional points of interest within the image, specified by world coordinates. By default, these images are saved in the pdf format.
- Create an astrometric solution for input images. This must be provided in the FITS headers of the input images. Use a tool like e.g. SCAMP for this task.
- Resample the individual images to the same pixel scale. Input images must match exactly in terms of pixel scale, orientation and size (number of pixels along each axis). Prepipy assumes the input images can simply be added on a pixel-by-pixel basis. Use a tool like e.g. SWarp for this task.
Add text about example image, bands etc.
Current way to use from command line: run the rgbcombo
script with arguments as described in the help message.
Development feature, not part of the current release.
The input images are expected to fullfill the following criteria:
- FITS format images with the images data appearing in the primary HDU.
- Pixel scale and position matching across all input images. No additional resampling/reprojection is performed.
- WCS information is present in the FITS files.
The package currently uses two YAML configuration files to specify various options. These are referred to as the (general) config
file and the bands
file containing meta-information about the bands used in the original data.
If these files are not placed in the working directory, the path to them needs to be specified using the -c
and -b
command line options.
Data class used to store information about a passband.
The recommended way to construct instances is via a YAML config file.
Use the Band.from_yaml_file(filename)
constructor to do so.
Alternatively, a minimalistic instance can be created by just providing the band name: Band('foo')
. This will create a useable instance with all other parameters containing default or placeholder values.
A Frame
is an individual image taken in a given Band
. Instances can be created manually or (recommended) either from a astropy.io.fits.ImageHDU
object, astropy.io.fits.HDUList
object plus an index or directly from a FITS file. Use the from_hdu(hdu_object, band)
, from_hdul(hdu_list_object, band, hdu_index)
or from_fits(filename, band, hdu_index)
contructors respectively.
Operations like clipping, normalisation and stretching are performed as methods of the Frame
class. Individual frames can be saved as single-HDU FITS files (Frame.save_fits(filename)
).
A Picture
is a collection of one or more Frame
objects. Frames can be added from a FITS file via Picture.add_frame_from_file(filename, band)
, where band
can be an instance of Band
or, in the minimalistic case, a string containing the band name only. Frames can also be added directly from a 2D numpy array: Picture.add_frame(image_array, band, header)
, where header
can be an instance of astropy.io.fits.Header
or None
. A third option is to add Frame
objects manually to the Picture.frames
list. This has the downside that the frames's band is not checked against the other frames' bands already present in the picture. Normally, only one frame per band is allowed in a picture.
It is also possible to construct a Picture
object from a 3D array containing 2D images, or to construct multiple instances from a 4D array. Warning: These features are currently highly experimental, not tested and not well documented.
The Picture
class also provides a number of convenience properties, including bands
, primary_frame
, image
, coords
, center
, center_coords
, center_coords_str
, image_size
, pixel_scale
and image_scale
.
RGBPicture
- subclass of Picture
for handling 3-channel color composite images. A color channel is just a Frame
object that is included in the RGBPicture.rgb_channels
list. This attribute is set by calling the select_rgb_channels(combination)
method. It is possible (and intended) to provide more than three frames for a RGBPicture
, if multiple color composite images from different band combinations are desired. In this case, select_rgb_channels(combination)
is called multiple times. Some operations modify only the frames which are set as color channels, so when processing multiple combinations, deep copies of the frames are created before they are modified as color channels.
JPEGPicture
- subclass of RGBPicture
for saving the final image as a JPEG (aka jpg) file. Currently one contains one method, save_pil(filename, quality)
, which uses the interface provided by the Pillow
package (version 9.4+ is required) to save the image. NOTE: in most cases, this is the class you'll want to use when actually dealing with color composite images, unless you want to manually process the 3D array containing the 3-channel image data in some other way.
This package was initially developed in the course of the NEMESIS project at the University of Vienna. The NEMESIS project has received funding from the European Union's Horizon 2020 research and innovation programme under grant agreement No. 101004141.