Skip to content

Commit

Permalink
#7 Refactor checking if vertex is Steiner vertex, fix a bug
Browse files Browse the repository at this point in the history
  • Loading branch information
artem-ogre committed Oct 16, 2023
1 parent dae9e82 commit 5b16feb
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 17 deletions.
10 changes: 7 additions & 3 deletions CDT/include/Triangulation.h
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,6 @@ class CDT_EXPORT Triangulation
public:
typedef std::vector<V2d<T> > V2dVec; ///< Vertices vector
V2dVec vertices; ///< triangulation's vertices
std::vector<bool> isSteinerVertex; ///< triangulation's vertices Steiner point flag
TriangleVec triangles; ///< triangulation's triangles
EdgeUSet fixedEdges; ///< triangulation's constraints (fixed edges)

Expand Down Expand Up @@ -529,11 +528,16 @@ class CDT_EXPORT Triangulation
TriIndVec resolveEncroachedEdges(
EdgeQue encroachedEdges,
VertInd& newVertBudget,
const V2d<T>* const circumcenterOrNull = NULL,
VertInd steinerVerticesOffset,
const V2d<T>* circumcenterOrNull = NULL,
RefinementCriterion::Enum refinementCriterion =
RefinementCriterion::SmallestAngle,
T badTriangleThreshold = T(0));
VertInd splitEncroachedEdge(Edge e, TriInd iT, TriInd iTopo);
VertInd splitEncroachedEdge(
Edge e,
TriInd iT,
TriInd iTopo,
VertInd steinerVerticesOffset);
void changeNeighbor(TriInd iT, TriInd oldNeighbor, TriInd newNeighbor);
void changeNeighbor(
TriInd iT,
Expand Down
38 changes: 24 additions & 14 deletions CDT/include/Triangulation.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -994,7 +994,6 @@ void Triangulation<T, TNearPointLocator>::addNewVertex(
const bool isSteiner)
{
vertices.push_back(pos);
isSteinerVertex.push_back(isSteiner);
m_vertTris.push_back(iT);
}

Expand Down Expand Up @@ -1252,6 +1251,7 @@ TriInd Triangulation<T, TNearPointLocator>::edgeTriangle(const Edge edge) const
}
currTri = t.next(edge.v1()).first;
} while(currTri != start);
assert(iT != invalidIndex);
return iT;
}

Expand All @@ -1275,12 +1275,12 @@ bool Triangulation<T, TNearPointLocator>::isRefinementNeeded(
return false;
}

/// Search in all fixed edges to find encroached edges, each fixed edge is
/// checked against its opposite vertices
/// Returns queue of encroached edges
template <typename T, typename TNearPointLocator>
EdgeQue Triangulation<T, TNearPointLocator>::detectEncroachedEdges()
{
// Search in all fixed edges to find encroached edges, each fixed edge is
// checked against its opposite vertices
// Returns queue of encroached edges
EdgeQue encroachedEdges;
for(EdgeUSet::const_iterator cit = fixedEdges.begin();
cit != fixedEdges.end();
Expand All @@ -1304,13 +1304,13 @@ EdgeQue Triangulation<T, TNearPointLocator>::detectEncroachedEdges()
return encroachedEdges;
}

/// Search in all fixed edges to find encroached edges, each fixed edge is
/// checked against its opposite vertices and vertex v
/// Returns queue of encroached edges
template <typename T, typename TNearPointLocator>
EdgeQue
Triangulation<T, TNearPointLocator>::detectEncroachedEdges(const V2d<T>& v)
{
// Search in all fixed edges to find encroached edges, each fixed edge is
// checked against its opposite vertices and vertex v
// Returns queue of encroached edges
EdgeQue encroachedEdges;
for(EdgeUSet::const_iterator cit = fixedEdges.begin();
cit != fixedEdges.end();
Expand All @@ -1329,6 +1329,7 @@ template <typename T, typename TNearPointLocator>
TriIndVec Triangulation<T, TNearPointLocator>::resolveEncroachedEdges(
EdgeQue encroachedEdges,
VertInd& newVertBudget,
const VertInd steinerVerticesOffset,
const V2d<T>* const circumcenterOrNull,
const RefinementCriterion::Enum refinementCriterion,
const T badTriangleThreshold)
Expand All @@ -1347,7 +1348,10 @@ TriIndVec Triangulation<T, TNearPointLocator>::resolveEncroachedEdges(
TriInd iT = edgeTriangle(edge);
const Triangle& t = triangles[iT];
VertInd i = splitEncroachedEdge(
edge, iT, edgeNeighbor(triangles[iT], edge.v1(), edge.v2()));
edge,
iT,
edgeNeighbor(triangles[iT], edge.v1(), edge.v2()),
steinerVerticesOffset);
--newVertBudget;

TriInd start = m_vertTris[i];
Expand Down Expand Up @@ -1392,13 +1396,16 @@ template <typename T, typename TNearPointLocator>
VertInd Triangulation<T, TNearPointLocator>::splitEncroachedEdge(
const Edge splitEdge,
const TriInd iT,
const TriInd iTopo)
const TriInd iTopo,
const VertInd steinerVerticesOffset)
{
const VertInd iMid = static_cast<VertInd>(vertices.size());
const V2d<T>& start = vertices[splitEdge.v1()];
const V2d<T>& end = vertices[splitEdge.v2()];
T split = T(0.5);
if(isSteinerVertex[splitEdge.v1()] || isSteinerVertex[splitEdge.v1()])
// check if any of the split edge vertices are Steiner vertices
if(splitEdge.v1() >= steinerVerticesOffset ||
splitEdge.v2() >= steinerVerticesOffset)
{
// In Ruppert's paper, he used D(0.01) factor to divide edge length, but
// that introduces FP rounding erros, so it's avoided.
Expand All @@ -1416,7 +1423,7 @@ VertInd Triangulation<T, TNearPointLocator>::splitEncroachedEdge(
}
assert(abs(nearestPowerOfTwo - pow(2, round(log(d) / log(2.0)))) < 1e6);
split = nearestPowerOfTwo / len;
if(isSteinerVertex[splitEdge.v1()])
if(splitEdge.v1() >= steinerVerticesOffset)
split = T(1) - split;
}
V2d<T> mid = V2d<T>::make(
Expand Down Expand Up @@ -2260,7 +2267,9 @@ void Triangulation<T, TNearPointLocator>::refineTriangles(
tryInitNearestPointLocator();

VertInd newVertBudget = maxVerticesToInsert;
resolveEncroachedEdges(detectEncroachedEdges(), newVertBudget);
const VertInd steinerVerticesOffset = vertices.size();
resolveEncroachedEdges(
detectEncroachedEdges(), newVertBudget, steinerVerticesOffset);

std::queue<TriInd> badTriangles;
for(TriInd iT(0), n = triangles.size(); iT < n; ++iT)
Expand Down Expand Up @@ -2303,13 +2312,14 @@ void Triangulation<T, TNearPointLocator>::refineTriangles(
{
continue;
}
TriIndVec badTris = resolveEncroachedEdges(

const TriIndVec badTris = resolveEncroachedEdges(
detectEncroachedEdges(vert),
newVertBudget,
steinerVerticesOffset,
&vert,
refinementCriterion,
refinementThreshold);

for(IndexSizeType i(0); i < TriInd(badTris.size()); ++i)
{
badTriangles.push(badTris[i]);
Expand Down

0 comments on commit 5b16feb

Please sign in to comment.