LSST Applications g0fba68d861+5616995c1c,g1ebb85f214+2420ccdea7,g1fd858c14a+44c57a1f81,g21d47ad084+8e51fce9ac,g262e1987ae+1a7d68eb3b,g2cef7863aa+3bd8df3d95,g35bb328faa+fcb1d3bbc8,g36ff55ed5b+2420ccdea7,g47891489e3+5c6313fe9a,g53246c7159+fcb1d3bbc8,g646c943bdb+dbb9921566,g67b6fd64d1+5c6313fe9a,g6bd32b75b5+2420ccdea7,g74acd417e5+37fc0c974d,g786e29fd12+cf7ec2a62a,g86c591e316+6e13bcb9e9,g87389fa792+1e0a283bba,g89139ef638+5c6313fe9a,g90f42f885a+fce05a46d3,g9125e01d80+fcb1d3bbc8,g93e38de9ac+5345a64125,g95a1e89356+47d08a1cc6,g97be763408+bba861c665,ga9e4eb89a6+85210110a1,gb0b61e0e8e+1f27f70249,gb58c049af0+f03b321e39,gb89ab40317+5c6313fe9a,gc4e39d7843+4e09c98c3d,gd16ba4ae74+5402bcf54a,gd8ff7fe66e+2420ccdea7,gd9a9a58781+fcb1d3bbc8,gdab6d2f7ff+37fc0c974d,gde280f09ee+604b327636,ge278dab8ac+50e2446c94,ge410e46f29+5c6313fe9a,gef3c2e6661+6b480e0fb7,gf67bdafdda+5c6313fe9a,gffca2db377+fcb1d3bbc8,v29.2.0.rc1
LSST Data Management Base Package
Loading...
Searching...
No Matches
_spanSetContinued.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#
19import numpy as np
20
21from . import SpanSet
22from lsst.utils import continueClass
23
24__all__ = []
25
26
27@continueClass
28class SpanSet: # noqa: F811
29 def asArray(self, shape=None, xy0=None):
30 """Convert a SpanSet into a numpy boolean array
31
32 Parameters
33 ----------
34 shape : `tuple` of `int`
35 The final shape of the output array.
36 If `shape` is `None` then the extent of the bounding box is used.
37 xy0 : `~lsst.geom.Box2I` or `tuple` of `int`
38 The lower-left corner of the array that will contain the spans.
39 If `xy0` is `None` then the origin of the bounding box is used.
40
41 Returns
42 -------
43 result : `numpy.ndarray`
44 The array with pixels contained in `spans` marked as `True`.
45 """
46 # prevent circular import
47 from lsst.afw.image import Mask
48
49 if shape is None and xy0 is None:
50 # It's slightly faster to set the array with the Mask instead of
51 # shifting the spans.
52 bbox = self.getBBox()
53 mask = Mask(bbox)
54 self.setMask(mask, 1)
55 result = mask.getArray().astype(bool)
56 else:
57 if shape is None:
58 # Use the shape of the full SpanSet
59 extent = self.getBBox().getDimensions()
60 shape = extent[1], extent[0]
61
62 if xy0 is None:
63 xy0 = self.getBBox().getMin()
64 offset = (-xy0[0], -xy0[1])
65
66 result = np.zeros(shape, dtype=bool)
67 yidx, xidx = self.shiftedBy(*offset).indices()
68 result[yidx, xidx] = 1
69 return result