Skip to content

dokkum/maskfill

Repository files navigation

maskfill

GitHub Latest Release) PyPI version Documentation Status

Fill in masked values in an image. The method description can be found in van Dokkum & Pasha (2024) (PASP).

Documentation at maskfill.readthedocs.io

Installation

The maskfill code can be installed from PyPI via

pip install maskfill

or the latest version from github can be retrieved via

git clone https://github.com/dokkum/maskfill.git
cd maskfill 
pip install . # or pip install -e .

Its dependencies are only numpy, scipy, astropy (for fits handling), and Python>=3.6 for type annotation an f-fstrings. If you wish, you can create a minimal working environment for this code via conda or mamba, e.g.,

mamba create -n maskfill python=3.10 numpy scipy astropy
mamba activate maskfill

Legacy

If you have a version of Python<3.6, we have tested maskfill as far back as Python 2.7 and it appears to work for the current version. To install a Python 2.7 - Python 3.5.9 compatible version (the only difference is type annotations and print statement formatting), checkout the branch:

git clone --branch python<3.6 --single-branch https://github.com/dokkum/maskfill.git
cd maskfill 
pip install . # or pip install -e .

(assuming you have the three dependencies in a working configuration).

Usage

Maskfill can be used either from the command line via a command line interface (CLI), or imported in Python as a function.

CLI

When you install maskfill it will create a maskfill executable callable from the shell. You can print the usage via

maskfill -h

The simplest call is something like

maskfill im.fits mask.fits out.fits

or

maskfill im mask out #file extension assumed to be .fits

in which you provide the input image, mask image, and name of the output file (if the .fits is omitted, maskfill will add it, though if your files have alternate extensions like .fit you should specify the full name). There are also several optional arguments and flags.

  • -e X or --extension X: if the image and mask are not in the 0th fits extension, specify it here
  • -s X or --size X: if you want a larger window kernel than the minimum 3x3, specify it here (faster, but less accurate results)
  • -o median or --operator median: either 'median' or 'mean', defines how masked pixels are filled in based on their neighbors
  • -n or --nosmooth: disable a final-step boxcar smoothing of the filled in mask pixels
  • -w or --writesteps: write _iter_N fits files after each iteration of the algorithm (default is False)
  • -v or --verbose: verbose output (shows the progress of iterations and number of remaining masked pixels).

The output is saved in the fits file with the provided output name. By default, after infilling, a smoothing step (using the same window, but a mean filter) is used to reduce sharp edges introduced by the iterative infilling. When enabled, the output fits file will contain the smoothed output image in the 0th extension, and the unsmoothed version post infilling in the 1st extension. If nosmooth is flagged, the 0th extension will contain the unsmoothed output. Information about which type of output is in which extension is added to the header.

Python Function

In python, import the maskfill function via

from maskfill import maskfill

The function supports all the same features as the CLI. We can provide either file paths or arrays directly, e.g.,

from astropy.io import fits 

im = fits.getdata('/path/to/im.fits')
mask = fits.getdata('/path/to/mask.fits')

result = maskfill(im,mask)
# or, equivalently, 
result = maskfill('/path/to/im.fits','/path/to/mask.fits')

When providing filepaths, the ext argument allows non 0th extensions to be queried. Like the CLI, all other arguments are optional, but unlike the CLI, the output_file argument is also optional --- maskfill returns the filled image(s) as arrays directly, but a `fits`` file can be written if desired by providing a filename (same goes for the intermediate steps).

Thus, a "maximally verbose" run might look like

result = maskfill('im.fits','mask.fits',writesteps=True,output_file='res.fits',verbose=True)

which would not only print to screen the iteration progress but write both intermediate and final fits files to disk.

The results output by the function are a tuple containing either:

  1. (output_smoothed,output) if the smoothing step is enabled, or
  2. (output, None) if the smoothing step is disabled.

Thus to access or plot the smoothed image from a default run, we would either run results[0], or run with

results,_ = maskfill(im,mask)

Citing Maskfill

If you find maskfill useful in your research or image handlings, please cite the code:

@ARTICLE{vanDokkum:2024,
       author = {{van Dokkum}, Pieter and {Pasha}, Imad},
        title = "{A Robust and Simple Method for Filling in Masked Data in Astronomical Images}",
      journal = {\pasp},
     keywords = {Direct imaging, Astronomical techniques, Astronomy data reduction, Astronomy data analysis, 387, 1684, 1861, 1858, Astrophysics - Instrumentation and Methods for Astrophysics, Astrophysics - Astrophysics of Galaxies},
         year = 2024,
        month = mar,
       volume = {136},
       number = {3},
          eid = {034503},
        pages = {034503},
          doi = {10.1088/1538-3873/ad2866},
archivePrefix = {arXiv},
       eprint = {2312.03064},
 primaryClass = {astro-ph.IM},
       adsurl = {https://ui.adsabs.harvard.edu/abs/2024PASP..136c4503V},
      adsnote = {Provided by the SAO/NASA Astrophysics Data System}
}