LSST Applications g00d0e8bbd7+edbf708997,g03191d30f7+6b31559d11,g118115db7c+ac820e85d2,g199a45376c+5137f08352,g1fd858c14a+90100aa1a7,g262e1987ae+64df5f6984,g29ae962dfc+1eb4aece83,g2cef7863aa+73c82f25e4,g3541666cd7+1e37cdad5c,g35bb328faa+edbf708997,g3fd5ace14f+fb4e2866cc,g47891489e3+19fcc35de2,g53246c7159+edbf708997,g5b326b94bb+d622351b67,g64539dfbff+dfe1dff262,g67b6fd64d1+19fcc35de2,g74acd417e5+cfdc02aca8,g786e29fd12+af89c03590,g7aefaa3e3d+dc1a598170,g87389fa792+a4172ec7da,g88cb488625+60ba2c3075,g89139ef638+19fcc35de2,g8d4809ba88+dfe1dff262,g8d7436a09f+db94b797be,g8ea07a8fe4+79658f16ab,g90f42f885a+6577634e1f,g9722cb1a7f+d8f85438e7,g98df359435+7fdd888faa,ga2180abaac+edbf708997,ga9e74d7ce9+128cc68277,gbf99507273+edbf708997,gca7fc764a6+19fcc35de2,gd7ef33dd92+19fcc35de2,gdab6d2f7ff+cfdc02aca8,gdbb4c4dda9+dfe1dff262,ge410e46f29+19fcc35de2,ge41e95a9f2+dfe1dff262,geaed405ab2+062dfc8cdc,w.2025.46
LSST Data Management Base Package
Loading...
Searching...
No Matches
lsst.pipe.tasks.diffractionSpikeMask Namespace Reference

Classes

class  DiffractionSpikeMaskConfig
 
class  DiffractionSpikeMaskTask
 

Functions

 getRegion (exposure, margin=None)
 
 boxSeparation (bbox, x, y)
 

Function Documentation

◆ boxSeparation()

lsst.pipe.tasks.diffractionSpikeMask.boxSeparation ( bbox,
x,
y )
Return the minimum horizontal or vertical distance from a point to the
outside edge of a bounding box.

Parameters
----------
bbox : `lsst.geom.Box2I`
    The bounding box to check.
x, y : `float`
    Coordinates of the point.

Returns
-------
distance : `float`
    The distance in pixels by which the point is outside the box, or 0 if
    it is inside.

Definition at line 468 of file diffractionSpikeMask.py.

468def boxSeparation(bbox, x, y):
469 """Return the minimum horizontal or vertical distance from a point to the
470 outside edge of a bounding box.
471
472 Parameters
473 ----------
474 bbox : `lsst.geom.Box2I`
475 The bounding box to check.
476 x, y : `float`
477 Coordinates of the point.
478
479 Returns
480 -------
481 distance : `float`
482 The distance in pixels by which the point is outside the box, or 0 if
483 it is inside.
484 """
485
486 x0, y0 = bbox.getBegin()
487 x1, y1 = bbox.getEnd()
488 dx = 0 if x0 <= x <= x1 else min(abs(x0 - x), abs(x - x1))
489 dy = 0 if y0 <= y <= y1 else min(abs(y0 - y), abs(y - y1))
490 return max(dx, dy)

◆ getRegion()

lsst.pipe.tasks.diffractionSpikeMask.getRegion ( exposure,
margin = None )
Calculate an enveloping region for an exposure.

Parameters
----------
exposure : `lsst.afw.image.Exposure`
    Exposure object with calibrated WCS.
margin : `lsst.sphgeom.Angle`, optional
    Grow the surrounding region of the exposure by this amount, in order to
    mask the diffraction spikes of stars off the image.

Returns
-------
region : `lsst.sphgeom.Region`
    Region enveloping an exposure.

Definition at line 433 of file diffractionSpikeMask.py.

433def getRegion(exposure, margin=None):
434 """Calculate an enveloping region for an exposure.
435
436 Parameters
437 ----------
438 exposure : `lsst.afw.image.Exposure`
439 Exposure object with calibrated WCS.
440 margin : `lsst.sphgeom.Angle`, optional
441 Grow the surrounding region of the exposure by this amount, in order to
442 mask the diffraction spikes of stars off the image.
443
444 Returns
445 -------
446 region : `lsst.sphgeom.Region`
447 Region enveloping an exposure.
448 """
449 # Bounding box needs to be a `Box2D` not a `Box2I` for `wcs.pixelToSky()`
450 bbox = lsst.geom.Box2D(exposure.getBBox())
451 wcs = exposure.getWcs()
452
453 region = lsst.sphgeom.ConvexPolygon([pp.getVector() for pp in wcs.pixelToSky(bbox.getCorners())])
454 if margin is not None:
455 # This is an ad-hoc, approximate implementation. It should be good
456 # enough for catalog loading, but is not a general-purpose solution.
457 center = lsst.geom.SpherePoint(region.getCentroid())
458 corners = [lsst.geom.SpherePoint(c) for c in region.getVertices()]
459 # Approximate the region as a Euclidian square
460 # geom.Angle(sphgeom.Angle) converter not pybind-wrapped???
461 diagonal_margin = lsst.geom.Angle(margin.asRadians() * math.sqrt(2.0))
462 padded = [c.offset(center.bearingTo(c), diagonal_margin) for c in corners]
463 return lsst.sphgeom.ConvexPolygon.convexHull([c.getVector() for c in padded])
464
465 return region
466
467
A class representing an angle.
Definition Angle.h:128
A floating-point coordinate rectangle geometry.
Definition Box.h:413
Point in an unspecified spherical coordinate system.
Definition SpherePoint.h:57
ConvexPolygon is a closed convex polygon on the unit sphere.
static ConvexPolygon convexHull(std::vector< UnitVector3d > const &points)
convexHull returns the convex hull of the given set of points if it exists and throws an exception ot...