LSST Applications g00d0e8bbd7+edbf708997,g03191d30f7+9ce8016dbd,g1955dfad08+0bd186d245,g199a45376c+5137f08352,g1fd858c14a+a888a50aa2,g262e1987ae+45f9aba685,g29ae962dfc+1c7d47a24f,g2cef7863aa+73c82f25e4,g35bb328faa+edbf708997,g3fd5ace14f+eed17d2c67,g47891489e3+6dc8069a4c,g53246c7159+edbf708997,g64539dfbff+c4107e45b5,g67b6fd64d1+6dc8069a4c,g74acd417e5+f452e9c21a,g786e29fd12+af89c03590,g7ae74a0b1c+a25e60b391,g7aefaa3e3d+2025e9ce17,g7cc15d900a+2d158402f9,g87389fa792+a4172ec7da,g89139ef638+6dc8069a4c,g8d4809ba88+c4107e45b5,g8d7436a09f+e96c132b44,g8ea07a8fe4+db21c37724,g98df359435+aae6d409c1,ga2180abaac+edbf708997,gac66b60396+966efe6077,gb632fb1845+88945a90f8,gbaa8f7a6c5+38b34f4976,gbf99507273+edbf708997,gca7fc764a6+6dc8069a4c,gd7ef33dd92+6dc8069a4c,gda68eeecaf+7d1e613a8d,gdab6d2f7ff+f452e9c21a,gdbb4c4dda9+c4107e45b5,ge410e46f29+6dc8069a4c,ge41e95a9f2+c4107e45b5,geaed405ab2+e194be0d2b,w.2025.47
LSST Data Management Base Package
Loading...
Searching...
No Matches
_fitsIoWithOptions.py
Go to the documentation of this file.
1# This file is part of afw.
2#
3# Developed for the LSST Data Management System.
4# This product includes software developed by the LSST Project
5# (https://www.lsst.org).
6# See the COPYRIGHT file at the top-level directory of this distribution
7# for details of code ownership.
8#
9# This program is free software: you can redistribute it and/or modify
10# it under the terms of the GNU General Public License as published by
11# the Free Software Foundation, either version 3 of the License, or
12# (at your option) any later version.
13#
14# This program is distributed in the hope that it will be useful,
15# but WITHOUT ANY WARRANTY; without even the implied warranty of
16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17# GNU General Public License for more details.
18#
19# You should have received a copy of the GNU General Public License
20# along with this program. If not, see <https://www.gnu.org/licenses/>.
21
22__all__ = ["imageReadFitsWithOptions",]
23
24import logging
25import lsst.geom
26from lsst.afw.fits import CompressionOptions
27from ._imageLib import ImageOrigin
28
29_LOG = logging.getLogger("lsst.afw.image")
30
31
32# This must be added to a class as a *classmethod*, for example:
33#
34# @continueclass
35# class MaskX:
36# readFitsWithOptions = classmethod(imageReadFitsWithOptions)
37def imageReadFitsWithOptions(cls, source, options):
38 """Read an Image, Mask, MaskedImage or Exposure from a FITS file,
39 with options.
40
41 Parameters
42 ----------
43 source : `str`
44 Fits file path from which to read image, mask, masked image
45 or exposure.
46 options : `lsst.daf.base.PropertySet` or `dict`
47 Read options:
48
49 - llcX: bbox minimum x (int)
50 - llcY: bbox minimum y (int, must be present if llcX is present)
51 - width: bbox width (int, must be present if llcX is present)
52 - height: bbox height (int, must be present if llcX is present)
53 - imageOrigin: one of "LOCAL" or "PARENT" (has no effect unless
54 a bbox is specified by llcX, etc.)
55
56 Alternatively, a bounding box () can be passed on with the
57 ``"bbox"'' (`lsst.geom.Box2I`) key.
58
59 Raises
60 ------
61 RuntimeError
62 If options contains an unknown value for "imageOrigin"
63 lsst.pex.exceptions.NotFoundError
64 If options contains "llcX" and is missing any of
65 "llcY", "width", or "height".
66 """
67 origin = ImageOrigin.PARENT
68 bbox = lsst.geom.Box2I()
69 if "bbox" in options:
70 bbox = options["bbox"]
71 elif "llcX" in options:
72 llcX = int(options["llcX"])
73 llcY = int(options["llcY"])
74 width = int(options["width"])
75 height = int(options["height"])
76 bbox = lsst.geom.Box2I(lsst.geom.Point2I(llcX, llcY), lsst.geom.Extent2I(width, height))
77 if "imageOrigin" in options:
78 originStr = str(options["imageOrigin"])
79 if (originStr == "LOCAL"):
80 origin = ImageOrigin.LOCAL
81 elif (originStr == "PARENT"):
82 origin = ImageOrigin.PARENT
83 else:
84 raise RuntimeError("Unknown ImageOrigin type {}".format(originStr))
85
86 return cls(source, bbox=bbox, origin=origin)
87
88
89def imageWriteFitsWithOptions(self, dest, options, item="image"):
90 """Write an Image or Mask to FITS, with options
91
92 Parameters
93 ----------
94 dest : `str`
95 Fits file path to which to write the image or mask.
96 options : `~collections.abc.Mapping`
97 Write options. The item ``item`` is accessed (which defaults to
98 "image"). It must contain a mapping with data for
99 `lsst.afw.fits.CompressionOptions.from_mapping`, or `None` for no
100 compression.
101 item : `str`, optional
102 Item to read from the ``options`` parameter.
103 """
104 if options is not None:
105 writeOptions = CompressionOptions.from_mapping(options[item])
106 self.writeFits(dest, writeOptions)
107 else:
108 self.writeFits(dest)
109
110
111def exposureWriteFitsWithOptions(self, dest, options):
112 """Write an Exposure or MaskedImage to FITS, with options
113
114 Parameters
115 ----------
116 dest : `str`
117 Fits file path to which to write the exposure or masked image.
118 options : `~collections.abc.Mapping`
119 Write options. The items "image", "mask" and "variance" are read.
120 Each must contain a mapping with data for
121 `lsst.afw.fits.CompressionOptions.from_mapping`, or `None` for no
122 compression.
123 """
124 if options is not None:
125 writeOptionDict = {name + "Options": CompressionOptions.from_mapping(plane_options)
126 for name in ("image", "mask", "variance")
127 if (plane_options := options[name]) is not None}
128 self.writeFits(dest, **writeOptionDict)
129 else:
130 self.writeFits(dest)
An integer coordinate rectangle.
Definition Box.h:55
imageWriteFitsWithOptions(self, dest, options, item="image")