| MUSE Pipeline Reference Manual
    1.0.2
    | 
| Data Structures | |
| struct | muse_image | 
| Structure definition of MUSE three extension FITS file.  More... | |
| Functions | |
| muse_image * | muse_image_new (void) | 
| Allocate memory for a new muse_imageobject.  More... | |
| void | muse_image_delete (muse_image *aImage) | 
| Deallocate memory associated to a muse_image object.  More... | |
| static muse_image * | muse_image_load_internal (const char *aFilename, unsigned char aIFU, const char *aID) | 
| Load the three extensions and the FITS headers of a MUSE image.  More... | |
| muse_image * | muse_image_load (const char *aFilename) | 
| Load the three extensions and the FITS headers of a MUSE image from a file.  More... | |
| muse_image * | muse_image_load_from_extensions (const char *aFilename, unsigned char aIFU) | 
| Load the three extensions and the FITS headers of a MUSE image from extensions of a merged file.  More... | |
| muse_image * | muse_image_load_from_raw (const char *aFilename, int aExtension) | 
| Load raw image into the data extension of a MUSE image.  More... | |
| cpl_error_code | muse_image_save (muse_image *aImage, const char *aFilename) | 
| Save the three image extensions and the FITS headers of a MUSE image to a file.  More... | |
| muse_image * | muse_image_duplicate (const muse_image *aImage) | 
| Duplicate the three image extensions and the FITS headers of a MUSE image.  More... | |
| int | muse_image_subtract (muse_image *aImage, muse_image *aSubtract) | 
| Subtract a muse_image from another with correct treatment of bad pixels and variance.  More... | |
| int | muse_image_divide (muse_image *aImage, muse_image *aDivisor) | 
| Divide a muse_image by another with correct treatment of bad pixels and variance.  More... | |
| int | muse_image_scale (muse_image *aImage, double aScale) | 
| Scale a muse_image with correct treatment of variance.  More... | |
| int | muse_image_variance_create (muse_image *aImage, muse_image *aBias) | 
| Create the photon noise-based variance in the stat extension.  More... | |
| cpl_error_code | muse_image_adu_to_count (muse_image *aImage) | 
| Convert the data units from raw adu to count (= electron) units.  More... | |
| cpl_error_code | muse_image_reject_from_dq (muse_image *aImage) | 
| Reject pixels of a muse_image depending on its DQ data.  More... | |
| cpl_error_code | muse_image_dq_to_nan (muse_image *aImage) | 
| Convert pixels flagged in the DQ extension to NANs in DATA (and STAT, if present).  More... | |
These functions wrap the respective CPL functions to easily handle the three-extension muse_image structure.
| cpl_error_code muse_image_adu_to_count | ( | muse_image * | aImage | ) | 
Convert the data units from raw adu to count (= electron) units.
| aImage | input muse_image to work with | 
This function gets the gain value (in count/adu) for each quadrant from the FITS header and then multiplies the data extension with this gain value and multiplies the variance extension with the squared gain value.
| set and return CPL_ERROR_NULL_INPUT | aImage or its header component are NULL | 
| set and return CPL_ERROR_INCOMPATIBLE_INPUT | the header component of aImage does not contain BUNIT or its BUNIT is not "adu" | 
| set and return CPL_ERROR_ILLEGAL_INPUT | the data buffer for the data and/or stat components cannot be retrieved | 
Definition at line 803 of file muse_image.c.
References data, header, muse_pfits_get_gain(), muse_quadrants_get_window(), and stat.
| void muse_image_delete | ( | muse_image * | aImage | ) | 
Deallocate memory associated to a muse_image object.
| aImage | input MUSE image | 
Just calls cpl_image_delete() and cpl_propertylist_delete() for the four components of a muse_image, and frees memory for the aImage pointer. As a safeguard, it checks if a valid pointer was passed, so that crashes cannot occur. 
Definition at line 85 of file muse_image.c.
References data, dq, header, and stat.
Referenced by muse_dar_check(), muse_flux_object_delete(), muse_image_duplicate(), muse_image_load_from_raw(), muse_image_load_internal(), muse_imagelist_delete(), muse_imagelist_set(), muse_postproc_cube_resample_and_collapse(), muse_postproc_process_exposure(), muse_quadrants_overscan_stats(), muse_quality_dark_badpix(), muse_resampling_image(), muse_trace(), muse_wave_calib(), muse_wave_calib_lampwise(), and muse_wcs_locate_sources().
| int muse_image_divide | ( | muse_image * | aImage, | 
| muse_image * | aDivisor | ||
| ) | 
Divide a muse_image by another with correct treatment of bad pixels and variance.
| aImage | image to be changed | 
| aDivisor | the image to divide by | 
Divide the data of aImage by aDivisor and modify the variance image accordingly (by multiplying the variance). The bad pixel extension of both input images are merged.
| return -1 | first input image is NULL | 
| return -2 | second input image is NULL | 
| propagate CPL error | cpl_image_divide, cpl_image_multiply, or cpl_image_add fails | 
Definition at line 631 of file muse_image.c.
| cpl_error_code muse_image_dq_to_nan | ( | muse_image * | aImage | ) | 
Convert pixels flagged in the DQ extension to NANs in DATA (and STAT, if present).
| aImage | the image to process | 
Pixels in the data (and, if present, stat) component of the input muse_image aImage are set as NAN depending on the dq component (all non-zero DQ values are assumed to be bad). The dq component is then deallocated and set to NULL.
This should be used only directly before saving an image, because the pipeline then cannot use DQ or other checks any more.
| return CPL_ERROR_NULL_INPUT | aImage or its data or dq extensions are NULL | 
Definition at line 897 of file muse_image.c.
References data, dq, and stat.
Referenced by muse_postproc_cube_resample_and_collapse().
| muse_image* muse_image_duplicate | ( | const muse_image * | aImage | ) | 
Duplicate the three image extensions and the FITS headers of a MUSE image.
| aImage | input MUSE image | 
muse_image * or NULL on error muse_image_delete().Just calls muse_image_new() and uses CPL to copy the four components.
| set CPL_ERROR_NULL_INPUT, return NULL | aImage is NULL | 
| propagate CPL error code, return NULL | failure to duplicate any of the four components | 
Definition at line 502 of file muse_image.c.
References data, dq, header, muse_image_delete(), muse_image_new(), and stat.
Referenced by muse_combine_images().
| muse_image* muse_image_load | ( | const char * | aFilename | ) | 
Load the three extensions and the FITS headers of a MUSE image from a file.
| aFilename | name of the file to load | 
muse_image * or NULL on error muse_image_delete(). muse_image_new() is used to create a new muse_image *. The primary FITS header is loaded into the header element using cpl_propertylist_load(). The other three extensions are then loaded from the FITS extensions with the expected EXTNAMEs, using cpl_image_load() to allocate and load the three image components of the muse_image.
This function does not display any error messsage, but the user can take the error state to print one, if necessary.
| return NULL, propagate CPL error code | cpl_propertylist_load() fails (this handles the case of an invalid or empty filename) | 
| set MUSE_ERROR_READ_DATA, MUSE_ERROR_READ_DQ, or MUSE_ERROR_READ_STAT depending on failed extension, clean up allocations, and return NULL | failure to load any extension | 
Definition at line 223 of file muse_image.c.
References muse_image_load_internal().
Referenced by muse_basicproc_load_reduced().
| muse_image* muse_image_load_from_extensions | ( | const char * | aFilename, | 
| unsigned char | aIFU | ||
| ) | 
Load the three extensions and the FITS headers of a MUSE image from extensions of a merged file.
| aFilename | name of the file to load | 
| aIFU | IFU number to search for | 
muse_image * or NULL on error muse_image_delete(). muse_image_new() is used to create a new muse_image . The primary FITS header is loaded into the header element using cpl_propertylist_load(). The other three extensions are then loaded from the FITS extensions with the expected EXTNAMEs (CHANnn.NAME, where NAME is one of DATA, DQ, and STAT), using cpl_image_load() to allocate and load the three image components of the muse_image.
This function does not display any error messsage, but the user can take the error state to print one, if necessary.
| return NULL, propagate CPL error code | cpl_propertylist_load() fails (this handles the case of an invalid or empty filename) | 
| set MUSE_ERROR_READ_DATA, MUSE_ERROR_READ_DQ, or MUSE_ERROR_READ_STAT depending on failed extension, clean up allocations, and return NULL | failure to load any extension | 
Definition at line 257 of file muse_image.c.
References muse_image_load_internal().
Referenced by muse_basicproc_load_reduced().
| muse_image* muse_image_load_from_raw | ( | const char * | aFilename, | 
| int | aExtension | ||
| ) | 
Load raw image into the data extension of a MUSE image.
| aFilename | name of the file to load | 
| aExtension | the FITS extension number | 
This function loads the specified extension from a file. The dq image is filled with 0 (no flaws) and the stat image is created (also filled with 0.0); this requires the caller of this function to fill in a correct estimate of the variance later!
The FITS header of the output image are created by merging the primary header with the extension header of the given extension.
Since the returned data is not corrected for the gain, the BUNIT in the header is set to "adu".
| return NULL and propagate CPL error code | cpl_image_load() fails | 
| return NULL but set MUSE_ERROR_CHIP_NOT_LIVE | cpl_image_load() fails but chip is known to be dead | 
Definition at line 287 of file muse_image.c.
References data, dq, header, muse_image_delete(), muse_image_new(), muse_pfits_get_chip_live(), muse_pfits_get_extname(), and stat.
| 
 | static | 
Load the three extensions and the FITS headers of a MUSE image.
| aFilename | name of the file to load | 
| aIFU | IFU number to search for, or 0 if loading directly. | 
| aID | function name to use for messages | 
Definition at line 117 of file muse_image.c.
References data, dq, header, muse_image_delete(), muse_image_new(), and stat.
Referenced by muse_image_load(), and muse_image_load_from_extensions().
| muse_image* muse_image_new | ( | void | ) | 
Allocate memory for a new muse_image object. 
muse_image * or NULL on error muse_image_delete(). cpl_image_new() or cpl_propertylist_new(), respectively, or equivalent functions.Simply allocate memory to store the pointers of the muse_image structure. 
Definition at line 66 of file muse_image.c.
Referenced by muse_dar_check(), muse_datacube_collapse(), muse_datacube_load(), muse_euro3dcube_collapse(), muse_flux_integrate_std(), muse_image_duplicate(), muse_image_load_from_raw(), muse_image_load_internal(), muse_pixtable_to_imagelist(), muse_quadrants_overscan_stats(), muse_quadrants_trim_image(), muse_quality_dark_badpix(), muse_resampling_collapse_pixgrid(), muse_resampling_image(), muse_trace(), muse_wave_calib(), muse_wave_calib_lampwise(), and muse_wcs_locate_sources().
| cpl_error_code muse_image_reject_from_dq | ( | muse_image * | aImage | ) | 
Reject pixels of a muse_image depending on its DQ data.
| aImage | the image to process | 
Pixels in the data (and, if present, stat) extension of the input muse_image aImage are set as bad depending on the dq extension (all non-zero DQ values are assumed to be bad), using cpl_image_reject(). This is useful to let CPL functions automatically ignore the bad pixels.
| return CPL_ERROR_NULL_INPUT | aImage or its data or dq extensions are NULL | 
Definition at line 856 of file muse_image.c.
References data, dq, and stat.
Referenced by muse_dar_check(), muse_sky_create_skymask(), muse_trace(), and muse_wcs_locate_sources().
| cpl_error_code muse_image_save | ( | muse_image * | aImage, | 
| const char * | aFilename | ||
| ) | 
Save the three image extensions and the FITS headers of a MUSE image to a file.
| aImage | input MUSE image | 
| aFilename | name of the output file | 
muse_image structure. Just calls cpl_image_save() for the three components of a muse_image, using the keywords in the header element of the muse_image structure for construction of the primary header.
This function uses muse_utils_set_hduclass() to add the special FITS headers to support the ESO format.
The data unit ("BUNIT") of the DATA and STAT extensions are set to be the incoming BUNIT (from the header component) and (BUNIT)**2, respectively.
| return CPL_ERROR_NULL_INPUT | aImage, its data component, or aFilename are NULL | 
| return CPL_ERROR_INCOMPATIBLE_INPUT | the header component of aImage does not contain a BUNIT | 
| return CPL error code | failure to save any of the three components, if the respective component is non-NULL | 
Definition at line 399 of file muse_image.c.
References data, dq, header, muse_utils_set_hduclass(), and stat.
Referenced by muse_dar_check(), muse_processing_save_image(), muse_quadrants_trim_image(), muse_quality_dark_badpix(), muse_sky_subtract_rowbyrow(), muse_wave_lines_search(), and muse_wcs_locate_sources().
| int muse_image_scale | ( | muse_image * | aImage, | 
| double | aScale | ||
| ) | 
Scale a muse_image with correct treatment of variance.
| aImage | image to be changed | 
| aScale | the scale factor | 
Apply the scale to the input data extension and apply it squared to the stat extension to keep the varianace in sync with the data.
| return -1 | input image is NULL | 
| propagate CPL error | cpl_image_multiply_scalar fails | 
Definition at line 695 of file muse_image.c.
Referenced by muse_imagelist_scale_exptime().
| int muse_image_subtract | ( | muse_image * | aImage, | 
| muse_image * | aSubtract | ||
| ) | 
Subtract a muse_image from another with correct treatment of bad pixels and variance.
| aImage | image to be changed | 
| aSubtract | the image to subtract | 
Subtract the image aSubtract from input image aImage and modify the variance image accordingly (by adding to the variance). The bad pixel extension of both input images are merged.
| return -1 | first input image is NULL | 
| return -2 | second input image is NULL | 
| propagate CPL error | cpl_image_subtract or cpl_image_add fails | 
Definition at line 585 of file muse_image.c.
| int muse_image_variance_create | ( | muse_image * | aImage, | 
| muse_image * | aBias | ||
| ) | 
Create the photon noise-based variance in the stat extension.
| aImage | input muse_image to work with | 
| aBias | input bias image to take the RON from | 
This function computes the photon noise part of the variance formula (but in units of adu**2) i.e. sigma_photon^2 = (counts - bias) / gain (where gain is the conversion factor with the unit count/adu). The resulting sigma_photon^2 is ensured to be larger than zero by cutting off low values (that can occur due to noise in the bias level at low count values).
| return -1 | input image is NULL | 
| return -2 | input bias is NULL | 
| return -3 | input images are of different size | 
Definition at line 739 of file muse_image.c.
References data, header, muse_pfits_get_gain(), muse_quadrants_get_window(), and stat.
 1.8.9.1
 1.8.9.1