From 6cc64e618cb63fb93f66765f69913ce3811d4b68 Mon Sep 17 00:00:00 2001 From: artem-ogre Date: Mon, 21 Aug 2023 11:40:44 +0200 Subject: [PATCH] #7 Refactor calculating triangle circumcenter --- CDT/include/CDTUtils.h | 12 ++++++++++++ CDT/include/CDTUtils.hpp | 34 ++++++++++++++++++++++++--------- CDT/include/Triangulation.h | 1 - CDT/include/Triangulation.hpp | 36 +++++++++-------------------------- 4 files changed, 46 insertions(+), 37 deletions(-) diff --git a/CDT/include/CDTUtils.h b/CDT/include/CDTUtils.h index 55d915b..bdacf6a 100644 --- a/CDT/include/CDTUtils.h +++ b/CDT/include/CDTUtils.h @@ -419,6 +419,14 @@ CDT_EXPORT bool isInCircumcircle( CDT_EXPORT CDT_INLINE_IF_HEADER_ONLY bool verticesShareEdge(const TriIndVec& aTris, const TriIndVec& bTris); +/// Vector's length +template +CDT_EXPORT T length(const V2d& v); + +/// Vector's squared length +template +CDT_EXPORT T lengthSquared(const V2d& v); + /// Distance between two 2D points template CDT_EXPORT T distance(const V2d& a, const V2d& b); @@ -437,6 +445,10 @@ CDT_EXPORT bool isEncroachingOnEdge( const V2d& edgeStart, const V2d& edgeEnd); +/// Position of ABC triangle circumcenter +template +CDT_EXPORT V2d circumcenter(V2d a, V2d b, const V2d& c); + } // namespace CDT #ifndef CDT_USE_AS_COMPILED_LIBRARY diff --git a/CDT/include/CDTUtils.hpp b/CDT/include/CDTUtils.hpp index e87341e..34c2de8 100644 --- a/CDT/include/CDTUtils.hpp +++ b/CDT/include/CDTUtils.hpp @@ -275,29 +275,33 @@ bool verticesShareEdge(const TriIndVec& aTris, const TriIndVec& bTris) } template -T distanceSquared(const T ax, const T ay, const T bx, const T by) +T lengthSquared(const T x, const T y) { - const T dx = bx - ax; - const T dy = by - ay; - return dx * dx + dy * dy; + return x * x + y * y; } template -T distance(const T ax, const T ay, const T bx, const T by) +T lengthSquared(const V2d& v) { - return std::sqrt(distanceSquared(ax, ay, bx, by)); + return lengthSquared(v.x, v.y); } template -T distance(const V2d& a, const V2d& b) +T length(const V2d& v) { - return distance(a.x, a.y, b.x, b.y); + return std::sqrt(lengthSquared(v)); } template T distanceSquared(const V2d& a, const V2d& b) { - return distanceSquared(a.x, a.y, b.x, b.y); + return lengthSquared(b.x - a.x, b.y - a.y); +} + +template +T distance(const V2d& a, const V2d& b) +{ + return std::sqrt(distanceSquared(a, b)); } bool touchesSuperTriangle(const Triangle& t) @@ -320,4 +324,16 @@ bool isEncroachingOnEdge( T(0); } +template +V2d circumcenter(V2d a, V2d b, const V2d& c) +{ + const T denom = 0.5 / orient2D(c, a, b); + a.x -= c.x, a.y -= c.y; + b.x -= c.x, b.y -= c.y; + const T aLenSq = lengthSquared(a), bLenSq = lengthSquared(b); + return V2d::make( + c.x + (b.y * aLenSq - a.y * bLenSq) * denom, + c.y + (a.x * bLenSq - b.x * aLenSq) * denom); +} + } // namespace CDT diff --git a/CDT/include/Triangulation.h b/CDT/include/Triangulation.h index 71aeaba..f9aae8b 100644 --- a/CDT/include/Triangulation.h +++ b/CDT/include/Triangulation.h @@ -519,7 +519,6 @@ class CDT_EXPORT Triangulation const Triangle& tri, RefineTriangles::Enum refinement, T threshold) const; - V2d circumcenter(const Triangle& tri) const; /// Search in all fixed edges to find encroached edges, each fixed edge is /// checked against its opposite vertices /// Returns queue of encroached edges diff --git a/CDT/include/Triangulation.hpp b/CDT/include/Triangulation.hpp index e5a617c..307bc6e 100644 --- a/CDT/include/Triangulation.hpp +++ b/CDT/include/Triangulation.hpp @@ -1299,30 +1299,6 @@ bool Triangulation::isBadTriangle( return ans; } -template -V2d -Triangulation::circumcenter(const Triangle& tri) const -{ - V2d a1 = vertices[tri.vertices[0]]; - V2d b1 = vertices[tri.vertices[1]]; - V2d a = vertices[tri.vertices[0]]; - V2d b = vertices[tri.vertices[1]]; - const V2d& c = vertices[tri.vertices[2]]; - const T denom = 0.5 / orient2D(c, a, b); - a.x -= c.x; - a.y -= c.y; - b.x -= c.x; - b.y -= c.y; - T oX = - c.x + - (b.y * (a.x * a.x + a.y * a.y) - a.y * (b.x * b.x + b.y * b.y)) * denom; - T oY = - c.y + - (a.x * (b.x * b.x + b.y * b.y) - b.x * (a.x * a.x + a.y * a.y)) * denom; - V2d v = V2d::make(oX, oY); - return v; -} - /// Search in all fixed edges to find encroached edges, each fixed edge is /// checked against its opposite vertices /// Returns queue of encroached edges @@ -1450,7 +1426,7 @@ VertInd Triangulation::splitEncroachedEdge( { // In Ruppert's paper, he used D(0.01) factor to divide edge length, but // that introduces FP rounding erros, so it's avoided. - const T len = distance(start.x, start.y, end.x, end.y); + const T len = distance(start, end); const T d = T(0.5) * len; // Find the splitting distance. T nearestPowerOfTwo = T(1); @@ -2317,7 +2293,10 @@ void Triangulation::refineTriangles( if(isBadTriangle(t, refinementConstrain, threshold)) { - const V2d vert = circumcenter(t); + const V2d vert = circumcenter( + vertices[t.vertices[0]], + vertices[t.vertices[1]], + vertices[t.vertices[2]]); if(locatePointTriangle( vert, vertices[0], vertices[1], vertices[2]) != PtTriLocation::Outside) @@ -2337,7 +2316,10 @@ void Triangulation::refineTriangles( { continue; } - const V2d vert = circumcenter(t); + const V2d vert = circumcenter( + vertices[t.vertices[0]], + vertices[t.vertices[1]], + vertices[t.vertices[2]]); if(locatePointTriangle(vert, vertices[0], vertices[1], vertices[2]) == PtTriLocation::Outside) {