12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- // This file is part of libigl, a simple c++ geometry processing library.
- //
- // Copyright (C) 2013 Alec Jacobson <alecjacobson@gmail.com>
- //
- // 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/.
- //
- // remove_unreferenced.h
- // Preview3D
- //
- // Created by Daniele Panozzo on 17/11/11.
- #ifndef IGL_REMOVE_UNREFERENCED_H
- #define IGL_REMOVE_UNREFERENCED_H
- #include "igl_inline.h"
- #include <Eigen/Core>
- namespace igl
- {
- // Remove unreferenced vertices from V, updating F accordingly
- //
- // Input:
- // V #V by dim list of mesh vertex positions
- // F #F by ss list of simplices (Values of -1 are quitely skipped)
- // Outputs:
- // NV #NV by dim list of mesh vertex positions
- // NF #NF by ss list of simplices
- // IM #V by 1 list of indices such that: NF = IM(F) and NT = IM(T)
- // and V(find(IM<=size(NV,1)),:) = NV
- //
- template <
- typename DerivedV,
- typename DerivedF,
- typename DerivedNV,
- typename DerivedNF,
- typename DerivedI>
- IGL_INLINE void remove_unreferenced(
- const Eigen::PlainObjectBase<DerivedV> &V,
- const Eigen::PlainObjectBase<DerivedF> &F,
- Eigen::PlainObjectBase<DerivedNV> &NV,
- Eigen::PlainObjectBase<DerivedNF> &NF,
- Eigen::PlainObjectBase<DerivedI> &I);
- template <
- typename DerivedV,
- typename DerivedF,
- typename DerivedNV,
- typename DerivedNF,
- typename DerivedI,
- typename DerivedJ>
- IGL_INLINE void remove_unreferenced(
- const Eigen::PlainObjectBase<DerivedV> &V,
- const Eigen::PlainObjectBase<DerivedF> &F,
- Eigen::PlainObjectBase<DerivedNV> &NV,
- Eigen::PlainObjectBase<DerivedNF> &NF,
- Eigen::PlainObjectBase<DerivedI> &I,
- Eigen::PlainObjectBase<DerivedJ> &J);
- // Inputs:
- // n number of vertices (possibly greater than F.maxCoeff()+1)
- // F #F by ss list of simplices
- // Outputs:
- // IM #V by 1 list of indices such that: NF = IM(F) and NT = IM(T)
- // and V(find(IM<=size(NV,1)),:) = NV
- // J #RV by 1 list, such that RV = V(J,:)
- //
- template <
- typename DerivedF,
- typename DerivedI,
- typename DerivedJ>
- IGL_INLINE void remove_unreferenced(
- const size_t n,
- const Eigen::PlainObjectBase<DerivedF> &F,
- Eigen::PlainObjectBase<DerivedI> &I,
- Eigen::PlainObjectBase<DerivedJ> &J);
- }
- #ifndef IGL_STATIC_LIBRARY
- # include "remove_unreferenced.cpp"
- #endif
- #endif
|