diff --git a/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.cpp b/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.cpp index d6fde4d171..3f0f904f30 100644 --- a/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.cpp +++ b/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.cpp @@ -194,7 +194,7 @@ void MMCellFlag::set(const int32_t cellLabels[8]) // Determine vertex type int32_t numFaceCrossings = 0; - m_NumJunctions = 0; + uint32_t numJunctions = 0; for(Face face = Face::LeftFace; face <= Face::TopFace; ++face) { if(faceCrossingType(face) != FaceCrossingType::NoFaceCrossing) @@ -202,18 +202,18 @@ void MMCellFlag::set(const int32_t cellLabels[8]) numFaceCrossings++; if(faceCrossingType(face) == FaceCrossingType::JunctionFaceCrossing) { - m_NumJunctions++; + numJunctions++; } } } if(numFaceCrossings != 0) { uint32_t vertexTypeBits = 0; - if(m_NumJunctions < 1) + if(numJunctions < 1) { vertexTypeBits = static_cast(VertexType::SurfaceVertex); } - else if(m_NumJunctions <= 2) + else if(numJunctions <= 2) { vertexTypeBits = static_cast(VertexType::EdgeVertex); } @@ -223,6 +223,8 @@ void MMCellFlag::set(const int32_t cellLabels[8]) } m_BitFlag |= (vertexTypeBits << k_VertexTypeShift); } + + m_BitFlag |= numJunctions << k_NumJunctionsBitShift; } MMCellFlag::VertexType MMCellFlag::vertexType() const diff --git a/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.h b/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.h index 50a6424bed..d7d9eaf9e6 100644 --- a/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.h +++ b/src/Plugins/SimplnxCore/src/SimplnxCore/SurfaceNets/MMCellFlag.h @@ -73,13 +73,16 @@ class MMCellFlag bool isEdgeCrossing(Edge edge) const; uint8_t numJunctions() const { - return m_NumJunctions; + return m_BitFlag >> k_NumJunctionsBitShift; } private: + static inline constexpr uint32_t k_NumJunctionsBitShift = 29; + // The bitflag + // The last 3 bits of the bitflag are the number of junctions + // numJunctions can at most be 6 uint32_t m_BitFlag = 0; - uint8_t m_NumJunctions = 0; }; // For iterating over cell faces