From 2fe98c550b6abb53adbb33880e57762a1baaaac9 Mon Sep 17 00:00:00 2001 From: csmemoe Date: Fri, 4 Mar 2022 14:44:24 -0700 Subject: [PATCH] Fix for issue 0013573: Interpolation tests are broken with changes to xmsextractor (TS_GREEN_BUILD_RETURN) The problem was that we were computing a simple arithmetic mean of the interpolation points but we needed to compute the actual polygon centroid instead. This was especially important for quadtree cells. --- xmsextractor/ugrid/XmUGridTriangles2d.cpp | 23 ++++++++++--------- .../ugrid/XmUGridTriangulatorBase.cpp | 2 +- 2 files changed, 13 insertions(+), 12 deletions(-) diff --git a/xmsextractor/ugrid/XmUGridTriangles2d.cpp b/xmsextractor/ugrid/XmUGridTriangles2d.cpp index b30998e..39059e1 100644 --- a/xmsextractor/ugrid/XmUGridTriangles2d.cpp +++ b/xmsextractor/ugrid/XmUGridTriangles2d.cpp @@ -303,11 +303,11 @@ void XmUGridTriangles2dUnitTests::testBuildCentroidTrianglesOnTriangle() // test building both cetroid and midpoints in triangle cell triangles.BuildTriangles(*ugrid, XmUGridTriangles2d::PO_CENTROIDS_AND_MIDPOINTS); - + double delta = 1.0e-6; VecPt3d triPointsOut = triangles.GetPoints(); VecPt3d triPointsExpected = {{0, 0, 0}, {1, 0, 0}, {0.5, 1, 0}, {0.5, 0, 0}, {0.75, 0.5, 0}, {0.25, 0.5, 0}, {0.5, 1 / 3.0, 0}}; - TS_ASSERT_EQUALS(triPointsExpected, triPointsOut); + TS_ASSERT_DELTA_VECPT3D(triPointsExpected, triPointsOut, delta); VecInt trianglesOut = triangles.GetTriangles(); VecInt trianglesExpected = {0, 3, 6, 3, 1, 6, 1, 4, 6, 4, 2, 6, 2, 5, 6, 5, 0, 6}; @@ -329,20 +329,20 @@ void XmUGridTriangles2dUnitTests::testBuildCentroidTrianglesOnTriangle() idxsExpected = {4, 2, 6}; TS_ASSERT_EQUALS(idxsExpected, idxs); weightsExpected = {0.0, 0.25, 0.75}; - TS_ASSERT_EQUALS(weightsExpected, weights); + TS_ASSERT_DELTA_VEC(weightsExpected, weights, delta); cellIdx = triangles.GetIntersectedCell(Pt3d(0.5, 0.25, 0), idxs, weights); TS_ASSERT_EQUALS(0, cellIdx); idxsExpected = {0, 3, 6}; TS_ASSERT_EQUALS(idxsExpected, idxs); weightsExpected = {0.0, 0.25, 0.75}; - TS_ASSERT_EQUALS(weightsExpected, weights); + TS_ASSERT_DELTA_VEC(weightsExpected, weights, delta); // test building cetroid in triangle cell triangles.BuildTriangles(*ugrid, XmUGridTriangles2d::PO_CENTROIDS_ONLY); triPointsOut = triangles.GetPoints(); triPointsExpected = {{0, 0, 0}, {1, 0, 0}, {0.5, 1, 0}, {0.5, 1 / 3.0, 0}}; - TS_ASSERT_EQUALS(triPointsExpected, triPointsOut); + TS_ASSERT_DELTA_VECPT3D(triPointsExpected, triPointsOut, delta); trianglesOut = triangles.GetTriangles(); trianglesExpected = {0, 1, 3, 1, 2, 3, 2, 0, 3}; @@ -356,19 +356,19 @@ void XmUGridTriangles2dUnitTests::testBuildCentroidTrianglesOnTriangle() idxsExpected = {2, 0, 3}; TS_ASSERT_EQUALS(idxsExpected, idxs); weightsExpected = {0.125, 0.5, 0.375}; - TS_ASSERT_EQUALS(weightsExpected, weights); + TS_ASSERT_DELTA_VEC(weightsExpected, weights, delta); cellIdx = triangles.GetIntersectedCell(Pt3d(0.75, 0.25, 0), idxs, weights); TS_ASSERT_EQUALS(0, cellIdx); idxsExpected = {1, 2, 3}; TS_ASSERT_EQUALS(idxsExpected, idxs); weightsExpected = {0.5, 0.125, 0.375}; - TS_ASSERT_EQUALS(weightsExpected, weights); + TS_ASSERT_DELTA_VEC(weightsExpected, weights, delta); cellIdx = triangles.GetIntersectedCell(Pt3d(0.5, 0.25, 0), idxs, weights); TS_ASSERT_EQUALS(0, cellIdx); idxsExpected = {0, 1, 3}; TS_ASSERT_EQUALS(idxsExpected, idxs); weightsExpected = {0.125, 0.125, 0.75}; - TS_ASSERT_EQUALS(weightsExpected, weights); + TS_ASSERT_DELTA_VEC(weightsExpected, weights, delta); // test without building centroid in triangle cell triangles.BuildTriangles(*ugrid, XmUGridTriangles2d::PO_NO_POINTS); @@ -387,7 +387,7 @@ void XmUGridTriangles2dUnitTests::testBuildCentroidTrianglesOnTriangle() idxsExpected = {0, 1, 2}; TS_ASSERT_EQUALS(idxsExpected, idxs); weightsExpected = {0.375, 0.375, 0.25}; - TS_ASSERT_EQUALS(weightsExpected, weights); + TS_ASSERT_DELTA_VEC(weightsExpected, weights, delta); } // XmUGridTriangles2dUnitTests::testBuildCentroidTrianglesOnTriangle //------------------------------------------------------------------------------ @@ -468,10 +468,11 @@ void XmUGridTriangles2dUnitTests::testBuildCentroidTriangles2dCellTypes() {5.0, 5.0, 0.0}, // 14 - quad centroid {15.0, 5.0, 0.0}, // 15 - pixel centroid {23.333333333333332, 3.3333333333333335, 0.0}, // 16 - triangle centroid - {33.333333333333336, 10.0, 0.0} // 17 - polygon centroid + {32.222222222222221, 10.0, 0.0} // 17 - polygon centroid }; // clang-format on - TS_ASSERT_EQUALS(triPointsExpected, triPointsOut); + double delta = 1.0e-6; + TS_ASSERT_DELTA_VECPT3D(triPointsExpected, triPointsOut, delta); VecInt trianglesOut = triangles.GetTriangles(); // clang-format off diff --git a/xmsextractor/ugrid/XmUGridTriangulatorBase.cpp b/xmsextractor/ugrid/XmUGridTriangulatorBase.cpp index 11fafda..b8bf492 100644 --- a/xmsextractor/ugrid/XmUGridTriangulatorBase.cpp +++ b/xmsextractor/ugrid/XmUGridTriangulatorBase.cpp @@ -314,7 +314,7 @@ bool XmUGridTriangulatorBase::GenerateCentroidTriangles(int a_cellIdx, for (size_t pointIdx = 0; pointIdx < numPoints; ++pointIdx) polygon.push_back(points[a_cellPointIdxs[pointIdx]]); - Pt3d centroid = gmComputeCentroid(polygon); + Pt3d centroid = gmComputePolygonCentroid(polygon); // make sure the centroid is located inside the cell if (gmPointInPolygon2D(polygon, centroid) != 1)