The version of DrizzlePac can be identified using
> python >>> import drizzlepac >>> drizzlepac.__version__
The following notes provide some details on what has been revised for each version in reverse chronological order (most recent version at the top of the list). The number at the end of each item is the Github Pull Request (PR) number of the code change for that issue. These PRs can be viewed at:
https://github.com/spacetelescope/drizzlepac/pulls
- Fixed an incompatibility in the
minmed
code for cosmic ray rejection with thenumpy
version>=1.25
. [#1573]
- Force the version of matplotlib to be <= 3.6.3 as the newer versions of the library cause problems with the calcloud preview generation. This is a temporary restriction.
- Modified the pyproject.toml file to ensure the tweakwcs version is greater than 0.8.2 as the issue of taking a very long time to compute the bounding polygon now defaults to an approximate method which is significantly faster. [#1565]
- Modified Projection Cell 0 declination coordinate of the center to be -89.999999999997 and the Projection Cell 2643 declination coordinate to be 89.999999999997 to shift the WCS CRVAL position slightly off the pole. [#1560]
- Modified the criteria for the rejection of catalogs based upon the cosmic ray criterion. An empty catalog (n_sources=0) should not be rejected by the CR contamination. Also, if a catalog is empty, it should not trigger the rejection of the other "type" of catalog (type=point vs segment). [#1559]
- For WFPC2 datasets which turn out to have no viable data to process and a manifest file has been requested, force an empty manifest file to be generated and issue the exit code NO_VIABLE_DATA (65). [#1550]
- Protect against writing the S_REGION keyword in intentionally empty DRZ/DRC
files in
processinput.process
to avoid messy crash. [#1547] - Fix a bug in
processinput.buildFileListOrig
due to which astrodrizzle might crash whenupdatewcs
is set toTrue
. [#1549] - Turn off use of
verify_guiding()
for WFPC2 images only as its use incorrectly recognizes diffraction spikes from saturated stars as evidence of loss of lock and flags those exposures as 'bad'. [#1511] - Ensure processing of all IMAGETYP=EXT WFPC2 targets. [#1505]
- Properly identify neighbor Projection Cells which overlap input exposures. [#1503]
- Updates identify and remove any WFPC2 calibration exposures that cannot be processed during standard pipeline alignment and drizzling. The list of recognized calibration target names was updated to accommodate WFPC2 and to identify exposures to be skipped and deleted after converting the D0M images into FLT images. [#1514]
- Compute a default kernel for use with astrometric_utils.extract_sources() function when the kernel parameter is None. The default kernel is based on the fwhm parameter of the same function. [#1519]
- Address many ReadTheDocs issues. [#1521 - #1529]
- Write the EXPNAME keyword to the ACS SVM and MVM headers to avoid errors and enforce consistency with WFC3. [#1530]
- Properly populate the S_REGION keyword with a closed polygon for the pipeline FLT/FLC images. [#1533]
- Compute the S_REGION values for pipeline drizzled products. [#1535]
- Ensure the DATE keyword is written to the primary header of all output drizzled products. The DATE represents the date the file was written. [#1537]
- Update to ensure the SVM FLT/FLC files all contain the S_REGION keyword and the value of the keyword is a closed polygon. [#1536]
- Turn on use of
verify_guiding()
to ignore exposures where guide star lock was lost and the stars are trailed. [#1443] - Ensure when no sources are found and the variable thresh is zero, the
verify_crthesh()
properly indicates the catalog failed the CR threshold. [#1450] - Added informational text when the catalog service fails (e.g., service cannot be reached or the request was somehow malformed) to make the default response more helpful. The request specification is also sent to the log, so the user can see what was actually requested. [#1451]
- Protect against there being no sources left to measure
the properties after cleaning cosmic rays from the input
in
verify_guiding()
. [#1466] - Check the SCI extension(s) of the output FLT/FLC and DRZ/DRC files. If the active WCS solution is 'a priori', delete the following keywords if they are associated with the active WCS as they are residue from a previous 'a posteriori' solution: NMATCHES, RMS_RA/RMS_DEC, FITGEOM, and CRDER1/CRDER2. Ensure the WCSTYPE is based upon the active WCSNAME to clean up any confusion. [#1465]
- Protect against inability to find a FWHM due to a fitting problem. [#1467]
- Implement photometric equalization for standard pipeline processing (runastrodriz) of WFPC2 data. [#1471]
- Update required to the compute_2d_background() function of the astrometric_utils module to accommodate changes in the PhotUtils API. [#1480]
- Introduced a new
apply_tweak()
function as a replacement to thetweakback()
.apply_tweak()
preserves the functionality oftweakback
with a re-designed API. Existingtweakback
was deprecated. [#1372] - Updated segmentation source catalog generation to use ICRS as input RADESYS when input images have an unsupported REFFRAME value (like OTHER or B1950). [#1423]
- Refactored code to work with changes in
tweakwcs
version 0.8.0. [#1430] - Ignore non-CTE-corrected exposures when SVM or MVM products also include CTE-corrected exposures as inputs. [#1433]
- This release includes includes updates for these features in addition to various bug fixes:
- Initial support for aligning and creating SVM and MVM products for WFPC2 data based on unoptimized processing parameters
- Python 3.10 support
- Photutils 1.4.0 (and newer) support
- Updated documentation on SVM processing and output mosaics
The list of specific changes for the significant issues includes:
- Fixed skycell size in pixels as quoted in the documentation. (#1387)
- Ensure Ramp filter data is not used for MVM processing (#1393)
- Added requested values and clarification text regarding photometry to the catalogs (#1390)
- Modified the docstring which defines the HAPLEVEL and its associated meaning (#1395)
- Modified the "exposure level" products to have a HAPLEVEL = 1 (#1398)
- Get full S_REGION outline (#1401)
- Update readthedocs for SVM catalog generation (#1400)
- Delete all reference catalogs during SVM processing (#1409)
- Update runastrodriz to work with WFPC2 data as singletons (#1412)
- Revert sky matching to use local sky minimization upon any error (#1411)
- Update SVM to support processing WFPC2 exposures (#1418)
- Add support for Python 3.10 (#1420)
- Add WFPC2 support for MVM processing (#1422)
- Support additional RADESYS options for input files (#1423)
- Ensure the gain variables are defined for all detectors (#1425)
- Essentially remove restriction on PhotUtils package version (#1426)
This release addresses a number of issues related to SVM and MVM processing.
- Reset tasknames to work with TEAL (#1285)
- Protect computations when photflam is equal to 0.0 (#1295)
- MVM: Define MVM-specific processing parameters for drizzling (#1277)
- Remove IPPPSSOO keyword from MVM product headers (again) (#1297)
- Fix problem with astropy 5.0 table interpretation (#1292)
- Statistics for SVM and MVM (#1300)
- SVM: add/remove/update Astrodrizzle Parameter files (#1303)
- Explicitly update boolean column in ASN tables (#1307)
- Synchronize output WCS specifications for SVM processing (#1312)
- Smooth out determination of S_REGION vertices (#1315)
- Ensure units of catalog variables comply with Astropy (#1316)
- Apply default alignment fit parameters for zero exptime exposures (#1319)
- Fix bug caused by Astropy Tables being interpreted as QTables (#1320)
- Revise logic for when mask keywords are computed (#1323)
- Restrict version of Photutils to < 1.4.0. (#1326)
- Add MEANWHT and MEDWHT keywords to drizzle products (#1324, #1349)
- Add documentation describing mvm products and artifacts (#1322)
- Add release notes for 3.4.1final (#1328)
- Fix typo in ACS MVM header rules file (#1332)
- Update astropy min version to 5.0.4 (#1335)
- Avoid archiving duplicate WCS solutions in SVM processing (#1333)
- Update installation dependencies for fitsblender and skypac (#1354)
- Flag and ignore bad images based on detecting linear features (#1351)
- Improve algorithm for identifying and filtering large segments (#1357)
- Carry over IDCSCALE keyword when updating WCS to match Grism WCS (#1355)
- Ignore MVM layers with no overlapping exposures (#1360)
- Update crder units (#1362)
- This change addresses bugs associated with the big_segments attribute of the segmentation image (#1365)
- Update the WFC3 rules files (#1366)
- Only allow "verify_guiding" check for MVM processing (#1368)
- Fix the size of the HAPEXPNAME column in the HDRTAB of the MVM output DRZ/DRZ file (#1371)
- Pass along default WCSNAME (#1370)
- Re-design tweakback (#1372)
- Bugfix: point-cat-fxm files being left around (#1369)
This release addresses issues found in v3.4.0. The most significant issues were:
- Add documentation describing mvm products and artifacts (#1322)
- Revise logic for when mask keywords are computed (#1323)
- Restrict version of Photutils to < 1.4.0. (#1326)
- Add MEANWHT and MEDWHT keywords to drizzle products (#1324)
- Modify the units of the catalog variables so they are astropy-compatible (#1318)
- Smooth out determination of S_REGION vertices (#1315)
- Apply default alignment fit parameters for zero exptime exposures (#1319)
- fix for tasknames to once again work with TEAL (#1289)
- Revise code to properly support Astropy v5.0 (#1286 , #1290 , #1292, #1296, #1307)
- Protect computations in catalog generation when photflam is equal to 0.0 (#1295)
- Define MVM-specific and SVM-specific processing parameters for drizzling (#1277, #1303)
- Remove IPPPSSOO keyword from header of output SVM or MVM drizzle products (#1297)
- Insure correct statistics are reported in MVM headers (#1300)
This major release adds support for multi-visit mosaic (MVM) processing, in addition to including numerous revisions to try to align more datasets successfully to GAIA during pipeline and single-visit mosaic (SVM) processing. Multi-visit mosaics (MVM) introduce the concept of SkyCells with new code added to define them. SkyCells are subarrays of pre-defined tangent planes spaced regularly on the sky as standardized definitions of mosaics to be created from all HST observations taken of each part of the sky.
New features added in this version include:
- Support for creating MVMs as generated
by the 'drizzlepac/hapmultisequencer.py' module or using the
new command-line task
runmultihap
. - Tools for generating cutouts of MVM products found in the
drizzlepac/haputils/hapcut_utils.py
module.
The most significant revisions and bug fixes that affect output products of this version of the code include:
- Detect extension name from WFPC2 flat-field files. [#1193]
- Refactored the build system to be PEP-517 ad PEP-518 compliant. [#1244]
- Fixed a bug in the drizzle algorithm due to which input pixels with zero weights may still contribute to the output image. [#1222]
- Added Sphinx documentation describing tools used for working with MVM products. [#1144, #1150]
- Changed names of "ISO" columns in Segmentation catalog to be unique [#1155]
- Add WCS keyword values to catalog metadata [#1160]
- Enforced a minimum number of cross-matches for alignment to be 4 sources [#1187, #1218]
- Revised 2D background determination for smaller detectors to improve source detection during alignment. [#1187]
- Create empty catalogs when exposures are effectively blank. [#1199]
- Cut processing time from days to minutes for exposures of crowded fields of faint sources or fields dominated by a single large extended source. [#1198]
- Report correct value of NMATCHES keyword for number of sources actually used in alignment fit to GAIA. [#1217]
- Prevent older distortion models from overriding new distortion models when performing a posteriori alignment to GAIA. [#1220]
- Add explicit dependency on spherical-geometry package. [#1232]
- Update how make_poller_files.py generates visit numbers. [#1221]
- Insure both FLT and FLC headers have same a posteriori fit keywords. [#1238]
- MVM: Make tool to quantify quality of GAIA alignment generic for general use. [#1241]
- Fix logic to not align grism data in standard pipeline. [#1243]
- Remove nictools as a dependency for this package. [#1245]
- RickerWavelet Kernel for SBC to separate crowded PSFS needs to have dimensions which are odd [#1246]
- Refine headers for filter and total products to allow keywords like IPPPSSOO and ASN_ID which only apply to single exposures (or data from the same ASN) to be removed from SVM filter and total drizzle products and from MVM layers drizzle products [#1249]
- Remove logic from align that related to checking for alignment results in align.py when it was not necessary so that more data can successfully align to GAIA. [#1250]
- Add support for using astropy 5.0. [#1280]
This version provides bug fixes primarily for the single-visit mosaic (SVM) processing.
- Insure a compatible version of photutils gets installed. [#1151]
- Improve handling of segmentation catalog generation for mostly or completely blank images. [#1152]
- Changed default floating point value in catalogs from -9999.9 to -9999.0. [#1165]
- Avoid creating an empty manifest file when no images get drizzled by SVM processing, unless the visit was comprised solely of Grism/Prism data. [#1174, #1181]
- Update total catalog to only remove sources which were not measured successfully in any filter. [#1175]
- Fix the units of a few variables in the output Point and Segmentation catalogs [#1178]
This version includes all the functionality needed to generate source catalogs, both point source and extended (segment) source catalogs, during single-visit mosaic (SVM) processing. In fact,
- Updated code to work with Python >= 3.7
- GAIAeDR3 catalog now the initial catalog of choice for a posteriori alignment during standard pipeline processing, as well as for SVM/MVM processing.
- SVM/MVM processing will loop over catalogs, fit methods and fit geometries in
looking for a successful fit, using the first successful fit it computes.
- CATALOGS used: GAIAeDR3, GSC242, 2MASS (in this order)
- methods: relative, image-by-image
- geometries: rscale, rshift, shift (each with different minimum cross-matches)
- SVM processing will always generate both point source and extended source catalogs, even
if the catalogs contain no rows of sources and measurements.
- point source catalog will be generated using TinyTim PSF-based detection
- extended source (segment) catalog will only have sources larger than the PSF kernel deblended.
- catalog columns will closely resemble the Hubble Legacy Archive (HLA) catalogs columns
- Grism/Prism exposures do not get aligned, but instead get the WCS correction from direct images
- Added logic to handle visits where there are only Grism/Prism exposures with no direct images
S_REGION
keyword:- added to FLT/FLC file headers
- revised region computation to match closely the actual exposure footprint within mosaic
- Always runs
updatewcs
on input files to insure pipeline-default WCSs are always present- Add
WCSNAME=OPUS
if noIDCTAB
WCS was created byupdatewcs
(NGOODPIX=0
, ...).
- Add
These changes, and additional significant bug fixes, were implemented using the following github PRs:
- Implemented deblending of segmentation source catalogs ONLY for sources larger than the PSF kernel. [#1131]
- Insure SVM processing always generates point-source and segmentation (extended) source catalogs, even if empty. [#1129]
- Implemented an efficient single-image identifier of possible cosmic-rays/defects, and applied it to help make image alignment more reliable. [#1129]
- Update logic for fitting between source lists to minimize/eliminate use of fitting with less than 4 sources. [#1129]
- Implemented model PSF-based point-source identification for SVM point-source catalog generation. [#903, #971, #1127]
- Removed dependence on private photutils functions while enabling support for all photutils versions >= 1.0.0. [#1127, #1117, #1116, #1096]
- Set values for crowding, biggest source, and source fraction for use when to use the RickerWavelet kernel and when to deblend sources when identifying extended sources using segmentation for the segment catalog. [#1115]
- Implemented a more efficient algorithm based on Harris corner
detection for computing the
S_REGION
keyword for pipeline and SVM drizzle products. [#1106] - Fix a memory corruption issue in
interpolate_bilinear()
incdrizzleblot.c
which could result in segfault. [#1048] - Fixed multiprocessing incompatibility with
Python >= 3.8
. [#1101] - Add support for environment variable switch,
PIPELINE_RESET_IDCTAB
, torunastrodriz
which will automatically resetIDCTAB
in FLT/FLC files if different fromIDCTAB
in RAW files. [#1046] - Update documentation based on revisions to the code. [#941, #947, #953]
- Update default astrometry catalogs for alignment to try alignment to
the
GAIA eDR3
catalog first. [#986, #1012] - Enable user epoch selection when a user requests a GAIA catalog from the astrometry catalog web service. [#1006]
- Insure that
HDRNAME
is always valid for updated WCS solutions. [#966] - Revised
S_REGION
keyword value to reflect actual outline of chips in drizzle products. [#951] - Sky Subtraction step will automatically downgrade from
match
tolocalmin
, and fromglobalmin+match
toglobalmin
when sky matching runs into an Exception. [# 1007] - Changed to insure that
EXTNAME
andEXTVER
are always removed from simple FITS drizzle product headers. [#954] - Changed to insure that all the distortion keywords (e.g.,
TDD*
,D2IM*
,...) are removed from from the output drizzle product headers [#954]. - Set a common active WCS for direct as well as corresponding Grism/Prism images [#929, #946]
- Fix a bug in
tweakback
that may cause incorrect "updated" WCS to be picked up from the drizzled image. [#913] - Added
DRIZPARS
keyword to final output drizzle product primary header to document the name of the associated trailer file. [#934, #1078]
In addition, numerous changes were made to insure this code stayed compatible with numpy versions > 1.20 and astropy versions > 4.1.
Updates to the STWCS
package version >= 1.6.0 also translated to
the following changes to the Drizzlepac processing:
- Insure HDRNAME keyword is never empty
- Remove duplicate headerlet extensions when running updatewcs
- Compute new a priori WCS solutions for new IDCTAB not already in astrometry database
*API Changes:*
- imageObject.py:
- class imageObject: Added parameter
output
to enable determination of rootname for use in processing of each detector.
- class imageObject: Added parameter
- adrizzle.py:
- drizSeparate: Added optional parameter
logfile
for specifying what file to use for log messages. - drizFinal: Added optional parameter
logfile
for specifying what file to use for log messages.
- drizSeparate: Added optional parameter
- wcs_functions.py:
- Removed
hdulist
as parameter fromget_hstwcs
.
- Removed
- haputils/analyze.py:
- analyze_data: Added parameter
type
to customize logic for SVM processing.
- analyze_data: Added parameter
- haputils/astrometric_utils.py:
- retrieve_observation: Added parameter
product_type
to allow for selection of type of products to be returned; pipeline, HAP, or both.
- retrieve_observation: Added parameter
- haputils/make_poller_files.py:
- New function
generate_poller_file
added to create inputs for SVM processing from files on disk.
- New function
- haputils/processing_utils.py:
- New function
find_footprint
added to determine corners of all chips in an image for computation ofS_REGION
keyword. - New function
interpret_sregion
added to convertS_REGION
keyword value into list of RA/Dec points for visualization.
- New function
- Fix problems with testing code for this package [#940]
This version provides the first operational implementation of the single-visit mosaic processing used to create the single-visit mosaics products.
- revise naming convention for the StaticMask file so that it has a dataset-specific name instead of a generic common name. [#876]
- Update
runastrodriz
to work under Windows while adding documentation to tell the user to run withnum_cores
set to 1. [#794] - Fixed a bug in
TweakReg
due to whichTweakReg
would crash whenupdatehdr
was set to False. [#801]
A number of changes have been implemented to either correct problems or improve the processed results. The most significant of the changes are:
- rscale only used for alignment.
- a minimum of 6 sources now gets used for alignment
- no proper motions used in astrometric (GAIA) catalog when attempting a posteriori fitting
- chip-to-chip alignment errors were corrected
In addition to a few dozen bug fixes, the following updates to the algorithms were also implemented.
- Simplified the logic in
tweakreg
for deciding how to archive primary WCS resulting in a reduction of duplicate WCSes in image headers. [#715] - Added polynomial look-up table distortion keywords to the list of distortion
keywords used by
outputimage.deleteDistortionKeywords
so that distortions can be removed from ACS images that useNPOLFILE
. This now allows removal of alternate WCS from blotted image headers. [#709] - Added
rules_file
parameter to AstroDrizzle to enable use of custom files in pipeline processing. [#674] - Only apply solutions from the astrometry database which were non-aposteriori WCS solutions as the PRIMARY WCS. This allows the pipeline to compare the true apriori WCS solutions (e.g., GSC or HSC WCSs) to aposteriori solutions computed using the latest distortion-models and alignment algorithms being used at the time of processing. [#669]
- Verification using a similarity index gets reported in the trailer file and does not get used as a Pass/Fail criteria for alignment. [#619]
- If verification fails for either pipeline-default or apriori solution, reset cosmic-ray(CR) flag (4096) in DQ arrays. This will allow subsequent attempt to align the images to not be impacted by potentially mis-identified CRs that most likely blanked out real sources in the field. As a result, the image alignment process became more robust when computing the aposteriori alignment. [#614]
- Fix a crash in
tweakreg
when finding sources in very large images due to a bug inscipy.signal.convolve2d
. [#670] - Fix a bug in
tweakreg
due to which the number of matched sources needed to be strictly greater thanminobj
. Now the minimum number of matched sources maust be at least equal or greater thanminobj
. [#604] - Fix a crash in
tweakreg
when2dhist
is enabled andnumpy
version is1.18.1
and later. [#583, #587] - Update calibrated (FLC/FLT) files with RMS and NMATCH keywords when it successfully aligns the data to GAIA using the a posteriori fit. Headerlet files for this fit which already have these keywords are now retained and provided as the final output headerlets as well. [#555]
- Insure HDRNAME keyword gets added to successfully aligned FLC/FLT files. [#580]
- Fix problem with 'tweakback' task when trying to work with updated WCS names. [#551]
- Fix problems found in processing data with NGOODPIX==0, DRC files not getting generated for singletons, alignment trying to use a source too near the chip edge, catch the case were all inputs have zero exposure time, lazily remove alignment sub-directories, fixed a bug in overlap computation that showed up in oblong mosaics, recast an input to histogram2d as int, defined default values for tables when no sources were found. [#593]
- Updated to be compatible with tweakwcs v0.6.0 to correct chip-to-chip alignment issues in aposteriori WCS solutions. [#596]
- Correctly define output drizzle product filename during pipeline processing for exposures with 'drz' in the rootname. [#523]
- Implement multiple levels of verification for the drizzle products generated during pipeline processing (using runastrodriz); including overlapp difference computations [#520], and magnitude correlation [#512].
- Replace alignimages module with O-O based align [#512]
- Fix problem with NaNs when looking for sources to use for aligning images [#512]
- Fixed code that selected the brightest sources to use for alignment allowing alignment to work (more often) for images with saturated sources. [#512]
- Use logic for defining the PSF extracted from the images to shrink it in each axis by one-half for images of crowded fields to allow for more sources to be extracted by daofind-like algorithm. This enables source finding and alignment to work more reliably on crowded field images. [#512]
- Insure all input files, especially those with zero exposure time or grism images, get updated with the latest pipeline calibration for the distortion. [ #495]
This version also relies on updates in the following packages to get correctly aligned and combined images with correctly specified WCS keywords:
- TWEAKWCS 0.6.4: This version corrects problems with the chip-to-chip separation that arose when applying a single fit solution to the entire observation.
- STWCS 1.5.4: This version implements a couple of fixes to insure that use of headerlets defines the full correct set of keywords from the headerlet for the PRIMARY WCS in the science exposure without introducing multiple copies of some keywords.
- Numpy 1.18: Changes in numpy data type definitions affected some of the code used for computing the offset between images when performing aposteriori alignment during pipeline processing and when running the 'tweakreg' task.
- Fixed a bug in the
updatehdr.update_from_shiftfile()
function that would crash while reading shift files. [#448] - Migration of the HAP portion of the package to an object-oriented implemenation. [#427]
- Added support for providing HSTWCS object as input to 'final_refimage' or 'single_refimage' parameter. [#426]
- Implementation of grid definition interface to support returning SkyCell objects that overlap a mosaic footprint. [#425]
- Complete rewrite of
runastrodriz
for pipeline processing to include multi-level verification of alignment. [#440]
- Removed deprecated parameter
coords
from the parameter list ofpixtopix.tran()
function. [#406] - Modified the behavior of the
verbose
parameter inpixtopix.tran()
to not print coordinates when not run as a script and whenoutput
is None. [#406] - Fixed a compatibility issue in
tweakutils
that would result in crash inskytopix
when converting coordinates inhms
format. [#385] - Fixed a bug in the
astrodrizzle.sky
module due to which sky matching fails with "Keyword 'MDRIZSKY' not found" error when some of the input images do not overlap at all with the other images. [#380] - Fixed a bug in the
util.WithLogging
decorator due to which incorrect log file was reported when user-supplied log file name does not have.log
extension. [#365] - Fixed a bug introduced in #364 returning in
finally
block. [#365] - Improved
util.WithLogging
decorator to handle functions that return values. [#364] - Fixed a bug in the automatic computation of the IVM weights when IVM was not provided by the user. [#320]
- Fixed a bug in the 2D histogram code used for estimating shifts for catalog pre-matching. This may result in better matching. [#286]
- Now
tolerance
(intweakreg
) is no longer ignored whenuse2dhist
is enabled. [#286] - Fixed VS compiler errors with pointer artithmetic on void pointers. [#273]
- Fix logic so that code no longer tries to update headers when no valid fit could be determined. [#241]
- Fixed a bug in the computation of interpolated large scale flat field
for STIS data. The bug was inconsequential in practice.
Removed the dependency on
stsci.imagemanip
package. [#227] - Removed the dependency on
stsci.ndimage
(usingscipy
routines instead). [#225] - Added
'Advanced Pipeline Products'
alignment code todrizzlepac
package. Enhancerunastrodriz
to compute and apply absolute astrometric corrections to GAIA (or related) frame to images where possible. [#200, #213, #216, #223, #234, #235, #244, #248, #249, #250, #251, #259, #260, #268, #271, #283, #294, #302] - Add computation and reporting of the fit's Root-Mean-Square Error (RMSE) and Mean Absolute Error (MAE). [#210]
- Replaced the use of
WCS._naxis1
andWCS._naxis2
withWCS.pixel_shape
[#207] - Removed support for Python 2. Only versions >= 3.5 are supported. [#207]
- Use a more numerically stable
numpy.linalg.inv
instead of own matrix inversion. [#205] - The intermediate fit match catalog, with the name
_catalog_fit.match
generated bytweakreg
now has correct RA and DEC values for the sources after applying the fit. [#200, #202] - Simplify logic for determining the chip ID for each source. [#200]
- Fix a bug that results in
tweakreg
crashing when no sources are found with user-specified source-finding parameters and whentweakreg
then attempts to find sources using default parameters. [#181] - Updated unit_tests to use original inputs, rather than updated inputs used by nightly regression tests.
- Fix
numpy
"floating" deprecation warnings. [#175] - Fix incorrect units in CR-cleaned images created by
astrodrizzle
. Now CR-cleaned images should have the same units as input images. [#190]
- Changed the color scheme of the
hist2d
plots toviridis
. [#167] - Refactored test suite
sdist
now packages C extension source code
- Replace
pyregion
withstregion
- Updated links in the documentation to point to latest
drizzlepac
website and online API documentation. - Code cleanup.
- Updated C code to be more compatible with latest numpy releases in order to reduce numerous compile warnings.
- Updated documentation to eliminate (at this moment) all sphinx documentation generation warnings.
- Moved
'release_notes.rst'
to'CHANGELOG.rst'
in the top-level directory. - Improved setup to allow documentation build. See drizzlepac PR #142 and Issue #129 for more details.
- Fixed a bug in a print statement in the create median step due to which background values for input images used in this step were not printed.
- Fixed a bug due to which
TweakReg
may have effectively ignoredverbose
setting. - Fixed a bug in
drizzlepac.util.WithLogging
due to whichastrodrizzle
would throw an error trying when to raise another error. See Issue #157 for more details.
- Fixed a bug in
TweakReg
introduced inv2.2.0
due to which, whenTweakReg
is run from the interpreter, the code may crash when trying to interpret input files.
- Fixed problems with processing WFPC2 data provided by the archive. User will
need to make sure they run
updatewcs
on all input WFPC2 data before combining them withastrodrizzle
.
- Implemented a major refactor of the project directory structure. Building no
longer requires
d2to1
orstsci.distutils
. Drizzlepac's release information (i.e. version, build date, etc) is now handled byrelic
. See https://github.com/spacetelescope/relic - Added basic support for compiling Drizzlepac's C extensions under Windows.
- Documentation is now generated during the build process. This ensures the
end-user always has access to documentation that applies to the version of
drizzlepac
being used. - Swapped the effect of setting
configobj
to None or'defaults'
inAstroDrizzle
andTweakReg
. When calling one of these tasks withconfigobj
parameter set to None, values for the not-explicitly-specified parameters should be set to the default values for the task. Whenconfigobj
is set to'defaults'
not-explicitly-specified parameters will be loaded from the~/.teal/astrodrizzle.cfg
or~/.teal/tweakreg.cfg
files that store latest used settings (or from matching configuration files in the current directory). See spacetelescope#115 for more details.
- Changed the definition of Megabyte used to describe the size of the buffer
for create median step (
combine_bufsize
). Previously a mixed (base-2 and base-10) definition was used with 1MB = 1000x1024B = 1024000B. Now 1MB is defined in base-2 (MiB) as 1MB = 1024x1024B = 1048576B. - Redesigned the logic in
createMedian
step used to split largesingle_sci
images into smaller chunks: new logic is more straightforward and fixes errors in the old algorithm that resulted in crashes or unnecessarily small chunk sizes that slowed downcreateMedian
step. - Due to the above mentioned redesign in the logic for splitting large images
into smaller chunks, now
overlap
can be set to 0 if so desired in theminmed
combine type. Also, it is automatically ignored (set to 0) for all non-minmed
combine types. This will result in additional speed-up in the Create Median step. - Both
AstroDrizzle()
andTweakReg()
now can be called withconfigobj
parameter set to'defaults'
in order to indicate that values for the not-explicitly-specified parameters should be set to the default values for the task instead of being loaded from the~/.teal/astrodrizzle.cfg
or~/.teal/tweakreg.cfg
files that store latest used settings. - Updated documentation.
- Restore recording of correct
EXPTIME
value in the headers of single drizzled ("single_sci") images. See spacetelescope#93 for more details. - Fixed a bug in
drizzlepac
due to which user providedcombine_lthresh
orcombine_hthresh
in theCREATE MEDIAN IMAGE
step were not converted correctly to electrons (processing unit). This bug affected processing of WFPC2, STIS, NICMOS, and WFC3 data. See spacetelescope#94 for more details. - Modified print format so that scales, skew and rotations are printed with 10 significant digits while shifts are printed with 4 digits after the decimal point.
- Fixed a bug in expanding reference catalog in
TweakReg
that would result in the code crashing. See spacetelescope#87 for more details. - Fixed a bug due to which user catalog fluxes would be interpreted as
magnitudes when
fluxunits
was set to'cps'
. See spacetelescope#88 for more details. - Fixed a bug due to which user-supplied flux limits were ignored for the reference catalog. See spacetelescope#89 for more details.
- Fixed a bug in computing optimal order of expanding reference catalog that resulted in code crashes. See spacetelescope#86 for more details.
- Fixed
astrodrizzle
lowers the case of the path of output images issue. See spacetelescope#79 for more details. - Fixed
tweakreg
ignores user-specified units of image catalogs (provided through therefcat
parameter) issue. See spacetelescope#81 for more details. - Corrected a message printed by tweakreg about used WCS for alignment. Also
improved documentation for the
refimage
parameter.
drizzlepac.adrizzle
updated to work with numpy >=1.12 when they implemented more strict array conversion rules for math. Any input which still has INT format will be converted to a float before any operations are performed, explicitly implementing what was an automatic operation prior to numpy 1.12.
- Fixed a bug introduced in release v2.1.15 in the logic for merging WCS due to which custom WCS scale was being ignored.
fits.io
operations will no longer use memory mapping in order to reduce the number of file handles used when running eitherastrodrizzle
ortweakreg
. See issue #39 for more details.- Fixed bugs and improved the logic for merging WCS that is used to define
astrodrizzle
's output WCS. - Added
crpix1
andcrpix2
parameters to custom WCS.
- Supressed info messages related inconsistent WCS - see issue #60 and stwcs issue #25 for more details.
- Fixed a bug due to which sky background was subtracted by
astrodrizzle
from the images even thoughskysub
was set to False whenMDRIZSKY
was already present in input images' headers.
astrodrizzle
now will runupdatewcs()
on newly created images when necessary, e.g., after converting WAVERED FITS to MEF format (*c0f.fits
to*_c0h.fits
) or after unpacking multi-imset STIS_flt
files. See PR #56 for more details.- Fixed a bug that was preventing processing STIS image data.
- Fixed a bug in reading user input (see issue #51).
Bug fix release (a bug was introduced in v2.1.10).
Some of the changes introduced in release v2.1.9 were not backward compatible. This release makes those changes backward compatible.
Compatibility improvements with Python 3 and other STScI software packages.
- Drizzlepac code will no longer attempt to delete "original" (WCS key 'O') resulting in a decreased number of warnings (see issue #35 ).
- Negative values are now zeroed in the 'minmed' step before attempting to estimate Poisson errors (see issue #22).
- Fixed a bug in
tweakreg
due to incorrect matrix inversion. - Improved compatibility with astropy.io.fits ('clobber' parameter) and numpy which has reduced the number of deprecation warnings).
- Existing static masks in the working directory are now overwritten and not simply re-used (see issue #23).
- Corrected formula for \sigma computation in the "create median" step to convert background to electrons before computations. This bug was producing incorrect \sigma for instruments whose gain was different from one.
- Improved
astrodrizzle
documentation forcombine_type
parameter which now also documents the formula for \sigma computation whencombine_type
parameter is set to'minmed'
.
Package maintenance release.
Technical re-release of v2.1.4
.
The following bug fixes have been implemented:
tweakreg
crashes when run with a single input image and a reference catalog.- Fixes an issue due to which
tweakreg
, when updating image headers, would not add '-SIP' suffix to CTYPE
- Improved ASN input file handling.
astrodrizzle
does not deleted2imfile
anylonger allowing multiple runs ofupdatewcs
on the same WFPC2 image, see Ticket 1244 for more details.- Allow exclusion regions in
tweakreg
to be in a different directory and allow relative path in exclusion region file name. - Improved handling of empty input image lists.
tweakreg
bug fix: use absolute value of polygon area.
runastrodriz
moved todrizzlepac
fromacstools
andwfc3tools
packages.- Improved logic for duplicate input detection.
- Improved logic for handling custom WCS parameters in
astrodrizzle
. - Compatibility improvements with Python 3.
Available under SSBX/IRAFX starting: Nov 17, 2015
This release includes the following bug fixes:
- Resolved order of operation problems when processing WFPC2 data with DGEOFILEs.
- The conversion of the WFPC2
DGEOFILE
intoD2IMFILE
is now incorporated intoSTWCS
v1.2.3 (r47112, r47113, r47114) rather than a part ofastrodrizzle
. This requires users to run updatewcs first, thenastrodrizzle
/tweakreg
will work with that WFPC2 data seamlessly (as if they were ACS or WFC3 data). - Compatibility improvements with Python 3.
Available under SSBX/IRAFX starting: Nov 2, 2015
This version builds upon the major set of changes implemented in v2.0.0 by not only fixing some bugs, but also cleaning up/changing/revising some APIs and docstrings. The complete list of changes includes:
- [API Change] The 'updatewcs' parameter was removed from both the
astrodrizzle
andtweakreg
interactive TEAL interfaces. The 'updatewcs' parameter can still be used with the Python interface for both theastrodrizzle
.astrodrizzle``() and ``tweakreg
. Call thestwcs.updatewcs.updatewcs()
function separately before runningastrodrizzle
ortweakreg
. - [API Change] The stand-alone interface for the blot routine
(
ablot.blot()
) has been revised to work seamlessly with astrodrizzle-generated products while being more obvious how to call it correctly. The help file for this task was also heavily revised to document all the input parameters and to provide an example of how to use the task. - [API Change] Coordinate transformation task
(
pixtopix
/pixtosky
/skytopix
) interfaces changed to be more consistent, yet remain backward-compatible for now. - Both
astrodrizzle
andtweakreg
now return an output CD matrix which has identical cross-terms indicating the same scale and orientation in each axis (an orthogonal CD matrix). This relies on a revision to thestwcs.distortion.utils.output_wcs()
function. - The user interfaces to all 3 coordinate transformation tasks now use 'coordfile' as the input file of coordinates to transform. The use of 'coords' has been deprecated, but still can be used if needed. However, use of 'coordfile' will always override any input provided simultaneously with 'coords' parameter. Help files have been updated to document this as clearly as possible for users.
- User-provided list of input catalogs no longer needs to be matched exactly
with input files. As long as all input images are included in input catalog
list in any order,
tweakreg
will apply the correct catalog to the correct file. tweakreg
has been updated to correctly and fully apply source selection criteria for both input source catalogs and reference source catalogs based onfluxmin
,fluxmax
andnbright
for each.- All use of keyword deletion has been updated in
drizzlepac
(andfitsblender
) to avoid warnings from astropy. - All 3 coordinate transformation tasks rely on the input of valid WCS information for the calculations. These tasks now warn the user when it could not find a valid WCS and instead defaulted to using a unity WCS, so that the user can understand what input needs to be checked/revised to get the correct results.
- Exclusion/inclusion region files that can be used with
tweakreg
can now be specified in image coordinates and sky coordinates and will only support files written out using DS9-compatible format. - The filename for 'final_refimage' in
astrodrizzle
and 'refimage' intweakreg
can now be specified with OR without an extension, such as '[sci,1]' or '[0]'. If no extension is specified, it will automatically look for the first extension with a valid HSTWCS and use that. This makes the use of this parameter in both place consistent and more general than before. - The reported fit as written out to a file has been slightly modified to report more appropriate numbers of significant digits for the results.
- Use of astrolib.coords was removed from
drizzlepac
and replaced by use of astropy functions instead. This eliminated one more obsolete dependency in our software. - Code was revised to rely entirely on
astropy.wcs
instead of stand-alone pywcs. - Code was revised to rely entirely on
astropy.io.fits
instead of stand-alone pyfits. - Added
photeq
task to account for inverse sensitivity variations across detector chips and/or epochs. - WFPC2 data from the archive with
DGEOFILE
reference files will now need to be processed usingstwcs.updatewcs
before running them throughastrodrizzle
ortweakreg
. This update converts the obsolete, unsupportedDGEOFILE
correction for the WFPC2 data into aD2IMFILE
specific for each WFPC2 observation, then uses that to convert the WCS based on the new conventions used for ACS and WFC3.
This set of changes represents the last major development effort for
DrizzlePac
in support of HST. Support of this code will continue
throughout the lifetime of HST, but will be limited primarily to bug fixes
to keep the code viable as Python libraries used by DrizzlePac
continue
to develop and evolve with the language.
** Available under SSBX/IRAFX starting:** Aug 4, 2014
This version encompasses a large number of updates and revisions to the
DrizzlePac
code, including the addition of new tasks and several parameter
name changes. The scope of these changes indicates the level of effort that
went into improving the DrizzlePac
code to make it easier and more
productive for users. The most significant updates to the DrizzlePac
code include:
- The Python code has been updated to work identically (without change) under both Python 2.7 and Python 3.x.
- Implementing sky matching, a new algorithm for matching the sky across a set
of images being combined by
astrodrizzle
. - Updating
tweakreg
to now align full mosaics where some images may not overlap others in the mosaic. - Added the option to write out single drizzle step images as compressed images (to save disk space for large mosaics, and I/O time for single drizzle step).
- Improved
tweakreg
residual plots visually while allowing them to be written out automatically whentweakreg
gets run in non-interactive mode. - Renamed parameters in
tweakreg
and imagefind to eliminate name clashes. - Added option to select sources based on sharpness/roundness when
tweakreg
searches for sources. - Added support for exclusion and inclusion regions arbitrary shape/size when
tweakreg
searches for sources. - Added a full set of source detection parameters for reference image to
support multi-instrument alignment in
tweakreg
. - Added support for new (simpler, more robust) ACS calibration of time-dependent distortion.
- A full 6-parameter general linear fit can now be performed using
tweakreg
, in addition to shift and rscale. - Cleaned up logic for sky-subtraction: user can now turn off sky-subtraction
with skysub=no, and still specify a user-defined sky value as the skyuser
keyword. This will reduce(eliminate?) the need to manually set
MDRIZSKY=0
.
In addition to these major updates/changes, numerous smaller bugs were fixed and other revisions were implemented which affected a small portion of the use cases, such as:
- headerlet code now accepts lists of files to be updated.
- source sky positions (RA and Dec) now included in match file.
- DQ flags can now be taken into account when performing source finding in
tweakreg
. - all intermediate files generated by
astrodrizzle
will now be removed when using 'clean'='yes'. - a problem was fixed that caused
createMedian
to crash where there were no good pixels in one of the images (when they did not overlap). - interpretation of shiftfile now improved to handle arbitrarily-long filenames, rather than being limited to 24 character filenames.
- documentation has been updated, sometimes with a lot more extensive descriptions.
This version of DrizzlePac
also requires use of the latest release version
of astropy primarily for WCS and FITS I/O support.
Publicly Released through PyPI: Mar 27, 2014
Available under SSBX/IRAFX starting: Mar 13, 2014
- Support for WFPC2 GEIS input images improved to correctly find the associated DQ images.
- Static mask files created for all chips in an image now get deleted when using the 'group' parameter to only drizzle a single chip or subset of chips.
- Fixed problem caused by changes to
stsci.tools
code so thatdrizzlepac
will reference the correct extensions in input images.
Publicly Released through PyPI: Jan 14, 2014
Available under SSBX/IRAFX starting: Jan 6, 2014
- Files created or updated by
drizzlepac
,fitsblender
, orSTWCS
tasks, e.g.tweakreg
orapply_headerlet
, will now ensure that theNEXTEND
keyword value correctly reflects the number of extensions in the FITS file upon completion.
Installed in OPUS: Dec 11, 2013
Available starting: Oct 28, 2013
- DQ arrays in input images now get updated with cosmic-ray masks
computed by
astrodrizzle
when run with the parameterin_memory=True
. This restored the cosmic-ray masks detected during pipeline processing.
available starting: Oct 21, 2013
tweakreg
can now be run in 'batch' mode. This allows the user to generate plots and have them saved to disk automatically without stopping processing and requiring any user input.
available starting: Sept 9, 2013
This version fixed a couple of bugs in astrodrizzle
; namely,
- Logic was updated to support pixfrac = 0.0 without crashing. Ths code will now automatically reset the kernel to 'point' in that case.
astrodrizzle
now forcibly removes all OPUS WCS keywords from drizzle product headers.- Default rules for generating drizzle product headers (as used in the archive) were modified to add definitions for 'float_one', 'int_one', 'zero' that generate output values of 1.0, 1, and 0 (zero) respectively for use as keyword values. This allows the LTM* rules to replace 'first' with 'float_one' so that the physical and image coordinates for drizzle products are consistent.
Additionally, changes were made to STWCS
for reprocessing use:
- Problems with using
apply_headerlet_as_primary()
from theSTWCS
package on WFPC2 data have been corrected in this revision.
Available starting: July 15, 2013
- AstroDrizzle now can process all STIS data without crashing.
available starting: May 6, 2013
- The output drizzle image header no longer contains references to D2IM arrays.
This allows
tweakreg
to work with drizzled images as input where 2-D D2IM corrections were needed. - Deprecated references to PyFITS .has_key() methods were also removed from the entire package, making it compatible with PyFITS 3.2.x and later.
available starting: Feb 11, 2013
- Fixed a bug in
astrodrizzle
which caused blot to raise an exception when using 'sinc' interpolation. - Cleaned up the logic for writing out the results from the pixtopix, pixtosky, and skytopix tasks to avoid an Exception when a list of inputs are provided and no output file is specified.
- A new parameter was added to the tweakback task to allow a user to specify
the value of
WCSNAME
when updating the FLT images with a new solution from a DRZ image header. - Code in tweakback for updating the header with a new WCS will now
automatically generate a unique
WCSNAME
if the there is a WCS solution in the FLT headers with the default or user-defined value ofWCSNAME
.
available starting: Feb 4, 2013
- Updated astrodrizzle to work with input images which do not have
WCSNAME
defined. This should make it easier to support non-HST input images in the future. - cleared up confusion between flux parameters in imagefindpars and catalog
inputs in
tweakreg
. - turned of use of fluxes for trimming input source catalogs when no flux column can be found in input source catalogs.
available starting: Dec 10, 2012
- Update
tweakreg
2d histogram building mode to correctly find the peak when all the inputs match with the same offset (no spurious sources in either source catalog). - Fixed a bug so that Ctrl-C does not cause an exception when used while
tweakreg
is running. - revised the source finding logic to ignore sources near the image edge, a change from how daofind works (daofind expands the image with blanks then fits anyway).
- created a new function to apply the nsigma separation criteria to (try to) eliminate duplicate entries for the same source from the source list. It turns out daofind does have problems with reporting some duplicate sources as well. This function does not work perfectly, but works to remove nearly all (if not all) duplicates in most cases.
available starting: Jan 14, 2013
- Bug fixed in updatehdr module to allow shiftfiles without RMS columns to work as inputs to manually apply shifts to headers of input images.
- Revised
astrodrizzle
to update WCS of all input images BEFORE checking whether or not they are valid. This ensures that all files provided as input toastrodrizzle
in the pipeline have the headers updated with the distortion model and new WCS. - Images with NGOODPIX=0 now identified for WFC3 and WFPC2 inputs, so they
can be ignored during
astrodrizzle
processing. - Replaced 2d histogram building code originally written in Python with a C function that run about 4x faster.
available starting: Dec 10, 2012
tweakreg
v1.1.0 source finding algorithm now runs many times faster (no algorithmic changes). No changes have been made yet to speed up the 2d histogram source matching code.- The 'pixtopix' task was updated to make the 'outimage' parameter optional by using the input image as the default. This required no API changes, but the help files were updated.
- Very minor update to guard against MDRIZTAB being specified without any explicit path.
- Update
astrodrizzle
to correctly report the exposure time, exposure start, and exposure end for the single drizzle products, in addition to insuring the final drizzle values remain correct. astrodrizzle
also includes initial changes to safeguard the C code from getting improperly cast values from the configObj(TEAL) input.
available starting: Oct 29, 2012
- Scaling of sky array for WFC3/IR IVM generation now correct.
- template mask files for WFPC2 no longer generated so that WFPC2 data can now be processed using num_cores > 1 (parallel processing).
- interpretation of the 'group' parameter fixed to support a single integer, a comma-separated list of integers or a single 'sci,<n>' value. The values correspond to the FITS extension number of the extensions that should be combined. This fix may also speed up the initialization step as more direct use of pyfits was implemented for the interpretation of the 'group' parameter.
available starting: Sept 26, 2012
The HST Archive and operational calibration pipeline started using this version on Sept 26, 2012.
available starting: Sept 24, 2012
- Bug fixed to allow use of final_wht_type=IVM for processing WFPC2 data.
- Revised Initialization processing to speed it up by using more up-to-date, direct pyfits calls.
available starting: Sept 17, 2012
- Fixed the logic so that crclean images always get created regardless of the value of the 'clean' parameter.
available starting: Sept 10, 2012
- Remove the restriction of only being able to process images which have
WCSNAME
keyword as imposed by r15631. The removal of this restriction will now allow for processing of non-updated input files withupdatewcs=False
for cases where no distortion model exists for the data (as required by CADC). - Added log statements reporting what sky value was actually used in the drizzle and blot steps
available starting: Sept 3, 2012
- Major revision to
astrodrizzle
allowing the option to process without writing out any intermediate products to disk. The intermediate products remain in memory requiring significantly more memory than usual. This improves the overall processing time by eliminating as much disk activity as possible as long as the OS does not start disk swapping due to lack of RAM. - revised to turn off 'updatewcs' when coeffs=False(no) so that exposures with filter combinations not found in the IDCTAB will not cause an error.
available starting: Aug 27, 2012
- Fixes problems with missing single_sci images.
- Static mask step revised to skip updates to static mask if all pixel data
falls within a single histogram bin. This avoids problems with masking out
entire images, which happens if low S/N SBC data is processed with
static_mask=yes
.
available starting: Aug 20, 2012
Use of IVM for final_wht now correct, as previous code used wrong inputs when
IVM weighting was automatically generated by astrodrizzle
.
available starting: Aug 13, 2012
- Completely removed the use of the TIME arrays for weighting IR drizzle products so that the photometry for saturated sources in drizzled products now comes out correct.
- Corrected a problem with
astrodrizzle
which affected processing of WFPC2 data where CRPIX2 was not found when creating the output single sci image.
available starting: Aug 3, 2012
The complete version of stsci_python can be downloaded from our download page
Used in archive/pipeline starting: July 10, 2012
Pipeline and archive started processing ACS data with this version.
Used in archive/pipeline starting: June 6, 2012
Pipeline and archive first started using astrodrizzle
by processing WFC3
images.