Skip to content

Commit

Permalink
#7 Refactor calculating triangle circumcenter
Browse files Browse the repository at this point in the history
  • Loading branch information
artem-ogre committed Oct 6, 2023
1 parent 5380aff commit d2fb314
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 37 deletions.
12 changes: 12 additions & 0 deletions CDT/include/CDTUtils.h
Original file line number Diff line number Diff line change
Expand Up @@ -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 <typename T>
CDT_EXPORT T length(const V2d<T>& v);

/// Vector's squared length
template <typename T>
CDT_EXPORT T lengthSquared(const V2d<T>& v);

/// Distance between two 2D points
template <typename T>
CDT_EXPORT T distance(const V2d<T>& a, const V2d<T>& b);
Expand All @@ -437,6 +445,10 @@ CDT_EXPORT bool isEncroachingOnEdge(
const V2d<T>& edgeStart,
const V2d<T>& edgeEnd);

/// Position of ABC triangle circumcenter
template <typename T>
CDT_EXPORT V2d<T> circumcenter(V2d<T> a, V2d<T> b, const V2d<T>& c);

} // namespace CDT

#ifndef CDT_USE_AS_COMPILED_LIBRARY
Expand Down
34 changes: 25 additions & 9 deletions CDT/include/CDTUtils.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -275,29 +275,33 @@ bool verticesShareEdge(const TriIndVec& aTris, const TriIndVec& bTris)
}

template <typename T>
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 <typename T>
T distance(const T ax, const T ay, const T bx, const T by)
T lengthSquared(const V2d<T>& v)
{
return std::sqrt(distanceSquared(ax, ay, bx, by));
return lengthSquared(v.x, v.y);
}

template <typename T>
T distance(const V2d<T>& a, const V2d<T>& b)
T length(const V2d<T>& v)
{
return distance(a.x, a.y, b.x, b.y);
return std::sqrt(lengthSquared(v));
}

template <typename T>
T distanceSquared(const V2d<T>& a, const V2d<T>& b)
{
return distanceSquared(a.x, a.y, b.x, b.y);
return lengthSquared(b.x - a.x, b.y - a.y);
}

template <typename T>
T distance(const V2d<T>& a, const V2d<T>& b)
{
return std::sqrt(distanceSquared(a, b));
}

bool touchesSuperTriangle(const Triangle& t)
Expand All @@ -320,4 +324,16 @@ bool isEncroachingOnEdge(
T(0);
}

template <typename T>
V2d<T> circumcenter(V2d<T> a, V2d<T> b, const V2d<T>& 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<T>::make(
c.x + (b.y * aLenSq - a.y * bLenSq) * denom,
c.y + (a.x * bLenSq - b.x * aLenSq) * denom);
}

} // namespace CDT
1 change: 0 additions & 1 deletion CDT/include/Triangulation.h
Original file line number Diff line number Diff line change
Expand Up @@ -517,7 +517,6 @@ class CDT_EXPORT Triangulation
const Triangle& tri,
RefineTriangles::Enum refinement,
T threshold) const;
V2d<T> 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
Expand Down
36 changes: 9 additions & 27 deletions CDT/include/Triangulation.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -1294,30 +1294,6 @@ bool Triangulation<T, TNearPointLocator>::isBadTriangle(
return ans;
}

template <typename T, typename TNearPointLocator>
V2d<T>
Triangulation<T, TNearPointLocator>::circumcenter(const Triangle& tri) const
{
V2d<T> a1 = vertices[tri.vertices[0]];
V2d<T> b1 = vertices[tri.vertices[1]];
V2d<T> a = vertices[tri.vertices[0]];
V2d<T> b = vertices[tri.vertices[1]];
const V2d<T>& 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<T> v = V2d<T>::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
Expand Down Expand Up @@ -1445,7 +1421,7 @@ VertInd Triangulation<T, TNearPointLocator>::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);
Expand Down Expand Up @@ -2319,7 +2295,10 @@ void Triangulation<T, TNearPointLocator>::refineTriangles(

if(isBadTriangle(t, refinementConstrain, threshold))
{
const V2d<T> vert = circumcenter(t);
const V2d<T> 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)
Expand All @@ -2339,7 +2318,10 @@ void Triangulation<T, TNearPointLocator>::refineTriangles(
{
continue;
}
const V2d<T> vert = circumcenter(t);
const V2d<T> 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)
{
Expand Down

0 comments on commit d2fb314

Please sign in to comment.