Revision 911b54edbd517a4f19fd83b75a940d1c58a78584 authored by Julian Heinze on 13 June 2023, 14:28:53 UTC, committed by Dmitri Naumov on 13 June 2023, 16:34:52 UTC
1 parent 2bfe60b
CellRule.cpp
/**
* \file
* \copyright
* Copyright (c) 2012-2023, OpenGeoSys Community (http://www.opengeosys.org)
* Distributed under a Modified BSD License.
* See accompanying file LICENSE.txt or
* http://www.opengeosys.org/project/license
*
*/
#include "CellRule.h"
#include "Element.h"
#include "FaceRule.h"
#include "MeshLib/Node.h"
namespace MeshLib
{
bool CellRule::testElementNodeOrder(Element const& e)
{
auto const cc = getCenterOfGravity(e).asEigenVector3d();
const unsigned nFaces(e.getNumberOfFaces());
for (unsigned j = 0; j < nFaces; ++j)
{
MeshLib::Element const* const face(e.getFace(j));
// Node 1 is checked below because that way all nodes are used for the
// test at some point, while for node 0 at least one node in every
// element type would be used for checking twice and one wouldn't be
// checked at all. (based on the definition of the _face_nodes variable)
auto const& x = face->getNode(1)->asEigenVector3d();
Eigen::Vector3d const cx = x - cc;
const double s = FaceRule::getSurfaceNormal(*face).dot(cx);
delete face;
if (s >= 0)
{
return false;
}
}
return true;
}
} // namespace MeshLib
Computing file changes ...