/** * * \copyright * Copyright (c) 2012-2016, 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 "GeometricBasics.h" #include "Point3d.h" #include "Vector3.h" namespace MathLib { double calcTetrahedronVolume(MathLib::Point3d const& a, MathLib::Point3d const& b, MathLib::Point3d const& c, MathLib::Point3d const& d) { const MathLib::Vector3 ab(a, b); const MathLib::Vector3 ac(a, c); const MathLib::Vector3 ad(a, d); return std::abs(MathLib::scalarTriple(ac, ad, ab)) / 6.0; } } // end namespace MathLib