From a0aa106439d50c6b1d61e6ceb140c1939068ace6 Mon Sep 17 00:00:00 2001 From: Eli Rykoff Date: Tue, 7 May 2024 11:13:45 -0700 Subject: [PATCH 1/2] Remove debugging lines from tests. --- tests/test_coaddPsf.py | 7 ------- 1 file changed, 7 deletions(-) diff --git a/tests/test_coaddPsf.py b/tests/test_coaddPsf.py index d7d2d64d8..6a7e4499b 100755 --- a/tests/test_coaddPsf.py +++ b/tests/test_coaddPsf.py @@ -32,7 +32,6 @@ def getPsfMoments(psf, point): - # import os, pdb; print "PID =", os.getpid(); pdb.set_trace() image = psf.computeImage(point) array = image.getArray() sumx2 = 0.0 @@ -127,7 +126,6 @@ def tearDown(self): def testCreate(self): """Check that we can create a CoaddPsf with 9 elements.""" - print("CreatePsfTest") # also test that the weight field name is correctly observed schema = afwTable.ExposureTable.makeMinimalSchema() @@ -174,7 +172,6 @@ def testCreate(self): def testFractionalPixel(self): """Check that we can create a CoaddPsf with 10 elements.""" - print("FractionalPixelTest") cdMatrix = afwGeom.makeCdMatrix( scale=5.55555555e-05*lsst.geom.degrees, orientation=90*lsst.geom.degrees, @@ -202,7 +199,6 @@ def testFractionalPixel(self): def testRotatePsf(self): """Check that we can create a CoaddPsf with 10 elements.""" - print("RotatePsfTest") cdMatrix = afwGeom.makeCdMatrix( scale=5.55555555e-05*lsst.geom.degrees, orientation=90*lsst.geom.degrees, @@ -228,7 +224,6 @@ def testRotatePsf(self): def testDefaultSize(self): """Test of both default size and specified size.""" - print("DefaultSizeTest") sigma0 = 5 # set the peak of the outer guassian to 0 so this is really a single gaussian. @@ -255,7 +250,6 @@ def testDefaultSize(self): def testSimpleGaussian(self): """Check that we can measure a single Gaussian's attributes.""" - print("SimpleGaussianTest") sigma0 = 5 # set the peak of the outer guassian to 0 so this is really a single gaussian. @@ -296,7 +290,6 @@ def testSimpleGaussian(self): def testWeight(self): """Check that we can measure a single Gaussian's attributes.""" - print("WeightTest") sigma0 = 5 # set the peak of the outer guassian to 0 so this is really a single gaussian. From e93766cac4e16513d32cc8104825319cb988c0dd Mon Sep 17 00:00:00 2001 From: Eli Rykoff Date: Tue, 7 May 2024 11:15:09 -0700 Subject: [PATCH 2/2] Change so that bad coadd psfs raise InvalidPsfError --- src/CoaddPsf.cc | 5 +++-- tests/test_coaddPsf.py | 8 ++++++++ 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/src/CoaddPsf.cc b/src/CoaddPsf.cc index 38f3c41ce..b4b332163 100644 --- a/src/CoaddPsf.cc +++ b/src/CoaddPsf.cc @@ -36,6 +36,7 @@ #include "lsst/base.h" #include "lsst/pex/exceptions.h" #include "lsst/geom/Box.h" +#include "lsst/afw/detection/Psf.h" #include "lsst/afw/image/ImageUtils.h" #include "lsst/afw/math/Statistics.h" #include "lsst/meas/algorithms/CoaddPsf.h" @@ -229,7 +230,7 @@ geom::Box2I CoaddPsf::doComputeBBox(geom::Point2D const &ccdXY, afw::image::Colo afw::table::ExposureCatalog subcat = _catalog.subsetContaining(ccdXY, _coaddWcs, true); if (subcat.empty()) { throw LSST_EXCEPT( - pex::exceptions::InvalidParameterError, + lsst::afw::detection::InvalidPsfError, (boost::format("Cannot compute BBox at point %s; no input images at that point.") % ccdXY) .str()); } @@ -252,7 +253,7 @@ CoaddPsf::doComputeKernelImage(geom::Point2D const &ccdXY, afw::image::Color con afw::table::ExposureCatalog subcat = _catalog.subsetContaining(ccdXY, _coaddWcs, true); if (subcat.empty()) { throw LSST_EXCEPT( - pex::exceptions::InvalidParameterError, + lsst::afw::detection::InvalidPsfError, (boost::format("Cannot compute CoaddPsf at point %s; no input images at that point.") % ccdXY) .str()); } diff --git a/tests/test_coaddPsf.py b/tests/test_coaddPsf.py index 6a7e4499b..0e7cc84c5 100755 --- a/tests/test_coaddPsf.py +++ b/tests/test_coaddPsf.py @@ -29,6 +29,7 @@ import lsst.meas.algorithms as measAlg import lsst.pex.exceptions as pexExceptions import lsst.utils.tests +from lsst.afw.detection import InvalidPsfError def getPsfMoments(psf, point): @@ -358,6 +359,13 @@ def testTicket2872(self): naiveAvgPos = lsst.geom.Point2D(50, 50) with self.assertRaises(pexExceptions.InvalidParameterError): coaddPsf.computeKernelImage(naiveAvgPos) + with self.assertRaises(InvalidPsfError): + coaddPsf.computeKernelImage(naiveAvgPos) + with self.assertRaises(pexExceptions.InvalidParameterError): + coaddPsf.computeBBox(naiveAvgPos) + with self.assertRaises(InvalidPsfError): + coaddPsf.computeBBox(naiveAvgPos) + # important test is that this doesn't throw: coaddPsf.computeKernelImage(coaddPsf.getAveragePosition())