From 3972dc1fec415a71110faf1f8b40fd8a5dbfe900 Mon Sep 17 00:00:00 2001 From: John Parejko Date: Fri, 17 May 2024 15:34:00 -0700 Subject: [PATCH] Rework error reporting for assertImagesAlmostEqual Just reporting the maximum absolute difference does not tell you where np.allclose() was failing, because it uses a relative+absolute comparison. --- python/lsst/afw/image/testUtils.py | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/python/lsst/afw/image/testUtils.py b/python/lsst/afw/image/testUtils.py index 2e4a9368d..9f7ac53b9 100755 --- a/python/lsst/afw/image/testUtils.py +++ b/python/lsst/afw/image/testUtils.py @@ -370,10 +370,23 @@ def imagesDiffer(image0, image1, skipMask=None, rtol=1.0e-05, atol=1e-08): if not np.allclose(valFilledArr1, valFilledArr2, rtol=rtol, atol=atol): errArr = np.abs(valFilledArr1 - valFilledArr2) maxErr = errArr.max() - maxPosInd = np.where(errArr == maxErr) - maxPosTuple = (maxPosInd[1][0], maxPosInd[0][0]) - errStr = f"maxDiff={maxErr} at position {maxPosTuple}; " \ - f"value={valFilledArr1[maxPosInd][0]} vs. {valFilledArr2[maxPosInd][0]}" + maxAbsInd = np.where(errArr == maxErr) + maxAbsTuple = (maxAbsInd[1][0], maxAbsInd[0][0]) + # NOTE: use the second image, because the numpy test is: + # (atol + rtol * absolute(b)) + allcloseLimit = rtol*np.abs(valFilledArr2) + atol + failing = np.where(errArr >= allcloseLimit) + # We want value of the largest absolute error. + maxFailing = errArr[failing].max() + maxFailingInd = np.where(errArr == maxFailing) + maxFailingTuple = (maxFailingInd[0][0], maxFailingInd[1][0]) + errStr = (f"{len(failing[0])} pixels failing np.allclose(), worst is: " + f"|{valFilledArr1[maxFailingTuple]} - {valFilledArr2[maxFailingTuple]}| = " + f"{maxFailing} > {allcloseLimit[maxFailingTuple]} " + f"(rtol*abs(image2)+atol with rtol={rtol}, atol={atol}) " + f"at position {maxFailingTuple}, and maximum absolute error: " + f"|{valFilledArr1[maxAbsInd][0]} - {valFilledArr2[maxAbsInd][0]}| = {maxErr} " + f"at position {maxAbsTuple}.") errStrList.insert(0, errStr) return "; ".join(errStrList)