// This file is part of libigl, a simple c++ geometry processing library. // // Copyright (C) 2013 Alec Jacobson // // This Source Code Form is subject to the terms of the Mozilla Public License // v. 2.0. If a copy of the MPL was not distributed with this file, You can // obtain one at http://mozilla.org/MPL/2.0/. #ifndef IGL_COPYLEFT_TETGEN_TETRAHEDRALIZE_H #define IGL_COPYLEFT_TETGEN_TETRAHEDRALIZE_H #include "../../igl_inline.h" #include #include #include #ifndef TETLIBRARY #define TETLIBRARY #endif #include "tetgen.h" // Defined REAL namespace igl { namespace copyleft { namespace tetgen { // Mesh the interior of a surface mesh (V,F) using tetgen // // Inputs: // V #V by 3 vertex position list // F #F list of polygon face indices into V (0-indexed) // switches string of tetgen options (See tetgen documentation) e.g. // "pq1.414a0.01" tries to mesh the interior of a given surface with // quality and area constraints // "" will mesh the convex hull constrained to pass through V (ignores F) // Outputs: // TV #V by 3 vertex position list // TT #T by 4 list of tet face indices // TF #F by 3 list of triangle face indices // Returns status: // 0 success // 1 tetgen threw exception // 2 tetgen did not crash but could not create any tets (probably there are // holes, duplicate faces etc.) // -1 other error IGL_INLINE int tetrahedralize( const std::vector > & V, const std::vector > & F, const std::string switches, std::vector > & TV, std::vector > & TT, std::vector > & TF); // Wrapper with Eigen types // Templates: // DerivedV real-value: i.e. from MatrixXd // DerivedF integer-value: i.e. from MatrixXi template < typename DerivedV, typename DerivedF, typename DerivedTV, typename DerivedTT, typename DerivedTF> IGL_INLINE int tetrahedralize( const Eigen::PlainObjectBase& V, const Eigen::PlainObjectBase& F, const std::string switches, Eigen::PlainObjectBase& TV, Eigen::PlainObjectBase& TT, Eigen::PlainObjectBase& TF); // Mesh the interior of a surface mesh (V,F) using tetgen // // Inputs: // V #V by 3 vertex position list // F #F list of polygon face indices into V (0-indexed) // M #V list of markers for vertices // switches string of tetgen options (See tetgen documentation) e.g. // "pq1.414a0.01" tries to mesh the interior of a given surface with // quality and area constraints // "" will mesh the convex hull constrained to pass through V (ignores F) // Outputs: // TV #V by 3 vertex position list // TT #T by 4 list of tet face indices // TF #F by 3 list of triangle face indices // TM #V list of markers for vertices // Returns status: // 0 success // 1 tetgen threw exception // 2 tetgen did not crash but could not create any tets (probably there are // holes, duplicate faces etc.) // -1 other error IGL_INLINE int tetrahedralize( const std::vector > & V, const std::vector > & F, const std::vector & VM, const std::vector & FM, const std::string switches, std::vector > & TV, std::vector > & TT, std::vector > & TF, std::vector & TM); // Wrapper with Eigen types // Templates: // DerivedV real-value: i.e. from MatrixXd // DerivedF integer-value: i.e. from MatrixXi template < typename DerivedV, typename DerivedF, typename DerivedVM, typename DerivedFM, typename DerivedTV, typename DerivedTT, typename DerivedTF, typename DerivedTM> IGL_INLINE int tetrahedralize( const Eigen::PlainObjectBase& V, const Eigen::PlainObjectBase& F, const Eigen::PlainObjectBase& VM, const Eigen::PlainObjectBase& FM, const std::string switches, Eigen::PlainObjectBase& TV, Eigen::PlainObjectBase& TT, Eigen::PlainObjectBase& TF, Eigen::PlainObjectBase& TM); } } } #ifndef IGL_STATIC_LIBRARY # include "tetrahedralize.cpp" #endif #endif