#include #include #include #include #include #include #include #include #include #include TEST(PeelOuterHullLayers, TwoCubes) { Eigen::MatrixXd V; Eigen::MatrixXi F; test_common::load_mesh("two-boxes-bad-self-union.ply", V, F); ASSERT_EQ(486, V.rows()); ASSERT_EQ(708, F.rows()); typedef CGAL::Exact_predicates_exact_constructions_kernel K; typedef K::FT Scalar; typedef Eigen::Matrix MatrixXe; MatrixXe Vs; Eigen::MatrixXi Fs, IF; Eigen::VectorXi J, IM; igl::cgal::RemeshSelfIntersectionsParam param; igl::cgal::remesh_self_intersections(V, F, param, Vs, Fs, IF, J, IM); std::for_each(Fs.data(),Fs.data()+Fs.size(), [&IM](int & a){ a=IM(a); }); MatrixXe Vt; Eigen::MatrixXi Ft; igl::remove_unreferenced(Vs,Fs,Vt,Ft,IM); const size_t num_faces = Ft.rows(); Eigen::VectorXi I, flipped; size_t num_peels = igl::cgal::peel_outer_hull_layers(Vt, Ft, I, flipped); Eigen::MatrixXd vertices(Vt.rows(), Vt.cols()); std::transform(Vt.data(), Vt.data() + Vt.rows() * Vt.cols(), vertices.data(), [](Scalar v) { return CGAL::to_double(v); }); igl::writeOBJ("debug.obj", vertices, Ft); ASSERT_EQ(num_faces, I.rows()); ASSERT_EQ(0, I.minCoeff()); ASSERT_EQ(1, I.maxCoeff()); }