diff options
author | vrouvrea <vrouvrea@636b058d-ea47-450e-bf9e-a15bfbe3eedb> | 2018-11-21 09:18:27 +0000 |
---|---|---|
committer | vrouvrea <vrouvrea@636b058d-ea47-450e-bf9e-a15bfbe3eedb> | 2018-11-21 09:18:27 +0000 |
commit | 0c44486d50e114fb6831ad050ee28dafe218cb97 (patch) | |
tree | 9366865e82fe706e48458a59145d8850dcd6b909 /src/Alpha_complex/test/Alpha_complex_3d_unit_test.cpp | |
parent | eef89bb492169faeb57dfdc65222b6a0483cb7c8 (diff) |
Separate tests to parallelize compilation
git-svn-id: svn+ssh://scm.gforge.inria.fr/svnroot/gudhi/branches/alpha_complex_3d_module_vincent@4010 636b058d-ea47-450e-bf9e-a15bfbe3eedb
Former-commit-id: 33bd17816b7258d16e20943e2f54b5379d174b84
Diffstat (limited to 'src/Alpha_complex/test/Alpha_complex_3d_unit_test.cpp')
-rw-r--r-- | src/Alpha_complex/test/Alpha_complex_3d_unit_test.cpp | 447 |
1 files changed, 0 insertions, 447 deletions
diff --git a/src/Alpha_complex/test/Alpha_complex_3d_unit_test.cpp b/src/Alpha_complex/test/Alpha_complex_3d_unit_test.cpp index e4a45791..c408dc75 100644 --- a/src/Alpha_complex/test/Alpha_complex_3d_unit_test.cpp +++ b/src/Alpha_complex/test/Alpha_complex_3d_unit_test.cpp @@ -23,7 +23,6 @@ #define BOOST_TEST_DYN_LINK #define BOOST_TEST_MODULE "alpha_complex_3d" #include <boost/test/unit_test.hpp> -#include <boost/mpl/list.hpp> #include <cmath> // float comparison #include <limits> @@ -49,27 +48,6 @@ using Safe_alpha_complex_3d = using Exact_alpha_complex_3d = Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::EXACT, false, false>; -using Fast_weighted_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::FAST, true, false>; -using Safe_weighted_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::SAFE, true, false>; -using Exact_weighted_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::EXACT, true, false>; - -using Fast_periodic_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::FAST, false, true>; -using Safe_periodic_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::SAFE, false, true>; -using Exact_periodic_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::EXACT, false, true>; - -using Fast_weighted_periodic_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::FAST, true, true>; -using Safe_weighted_periodic_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::SAFE, true, true>; -using Exact_weighted_periodic_alpha_complex_3d = - Gudhi::alpha_complex::Alpha_complex_3d<Gudhi::alpha_complex::complexity::EXACT, true, true>; - BOOST_AUTO_TEST_CASE(Alpha_complex_3d_from_points) { // ----------------- // Fast version @@ -185,428 +163,3 @@ BOOST_AUTO_TEST_CASE(Alpha_complex_3d_from_points) { ++safe_sh; } } - -typedef boost::mpl::list<Fast_weighted_alpha_complex_3d, Safe_weighted_alpha_complex_3d, - Exact_weighted_alpha_complex_3d> - weighted_variants_type_list; - -#ifdef GUDHI_DEBUG -BOOST_AUTO_TEST_CASE_TEMPLATE(Alpha_complex_weighted_throw, Weighted_alpha_complex_3d, weighted_variants_type_list) { - using Point_3 = typename Weighted_alpha_complex_3d::Point_3; - std::vector<Point_3> w_points; - w_points.push_back(Point_3(0.0, 0.0, 0.0)); - w_points.push_back(Point_3(0.0, 0.0, 0.2)); - w_points.push_back(Point_3(0.2, 0.0, 0.2)); - // w_points.push_back(Point_3(0.6, 0.6, 0.0)); - // w_points.push_back(Point_3(0.8, 0.8, 0.2)); - // w_points.push_back(Point_3(0.2, 0.8, 0.6)); - - // weights size is different from w_points size to make weighted Alpha_complex_3d throw in debug mode - std::vector<double> weights = {0.01, 0.005, 0.006, 0.01, 0.009, 0.001}; - - std::cout << "Check exception throw in debug mode" << std::endl; - BOOST_CHECK_THROW(Weighted_alpha_complex_3d wac(w_points, weights), std::invalid_argument); -} -#endif - -BOOST_AUTO_TEST_CASE_TEMPLATE(Alpha_complex_weighted, Weighted_alpha_complex_3d, weighted_variants_type_list) { - std::cout << "Weighted alpha complex 3d from points and weights" << std::endl; - using Point_3 = typename Weighted_alpha_complex_3d::Point_3; - std::vector<Point_3> w_points; - w_points.push_back(Point_3(0.0, 0.0, 0.0)); - w_points.push_back(Point_3(0.0, 0.0, 0.2)); - w_points.push_back(Point_3(0.2, 0.0, 0.2)); - w_points.push_back(Point_3(0.6, 0.6, 0.0)); - w_points.push_back(Point_3(0.8, 0.8, 0.2)); - w_points.push_back(Point_3(0.2, 0.8, 0.6)); - - // weights size is different from w_points size to make weighted Alpha_complex_3d throw in debug mode - std::vector<double> weights = {0.01, 0.005, 0.006, 0.01, 0.009, 0.001}; - - Weighted_alpha_complex_3d alpha_complex_p_a_w(w_points, weights); - Gudhi::Simplex_tree<> stree; - alpha_complex_p_a_w.create_complex(stree); - - std::cout << "Weighted alpha complex 3d from weighted points" << std::endl; - using Weighted_point_3 = typename Weighted_alpha_complex_3d::Weighted_point_3; - - std::vector<Weighted_point_3> weighted_points; - - for (std::size_t i = 0; i < w_points.size(); i++) { - weighted_points.push_back(Weighted_point_3(w_points[i], weights[i])); - } - Weighted_alpha_complex_3d alpha_complex_w_p(weighted_points); - - Gudhi::Simplex_tree<> stree_bis; - alpha_complex_w_p.create_complex(stree_bis); - - // --------------------- - // Compare both versions - // --------------------- - std::cout << "Weighted alpha complex 3d is of dimension " << stree_bis.dimension() << " - versus " - << stree.dimension() << std::endl; - BOOST_CHECK(stree_bis.dimension() == stree.dimension()); - std::cout << "Weighted alpha complex 3d num_simplices " << stree_bis.num_simplices() << " - versus " - << stree.num_simplices() << std::endl; - BOOST_CHECK(stree_bis.num_simplices() == stree.num_simplices()); - std::cout << "Weighted alpha complex 3d num_vertices " << stree_bis.num_vertices() << " - versus " - << stree.num_vertices() << std::endl; - BOOST_CHECK(stree_bis.num_vertices() == stree.num_vertices()); - - auto sh = stree.filtration_simplex_range().begin(); - while (sh != stree.filtration_simplex_range().end()) { - std::vector<int> simplex; - std::vector<int> exact_simplex; -#ifdef DEBUG_TRACES - std::cout << " ( "; -#endif - for (auto vertex : stree.simplex_vertex_range(*sh)) { - simplex.push_back(vertex); -#ifdef DEBUG_TRACES - std::cout << vertex << " "; -#endif - } -#ifdef DEBUG_TRACES - std::cout << ") -> " - << "[" << stree.filtration(*sh) << "] "; - std::cout << std::endl; -#endif - - // Find it in the exact structure - auto sh_exact = stree_bis.find(simplex); - BOOST_CHECK(sh_exact != stree_bis.null_simplex()); - - // Exact and non-exact version is not exactly the same due to float comparison - GUDHI_TEST_FLOAT_EQUALITY_CHECK(stree_bis.filtration(sh_exact), stree.filtration(*sh)); - - ++sh; - } -} - -#ifdef GUDHI_DEBUG -typedef boost::mpl::list<Fast_periodic_alpha_complex_3d, Safe_periodic_alpha_complex_3d, - Exact_periodic_alpha_complex_3d> - periodic_variants_type_list; - -BOOST_AUTO_TEST_CASE_TEMPLATE(Alpha_complex_periodic_throw, Periodic_alpha_complex_3d, periodic_variants_type_list) { - std::cout << "Periodic alpha complex 3d exception throw" << std::endl; - using Point_3 = typename Periodic_alpha_complex_3d::Point_3; - std::vector<Point_3> p_points; - - // Not important, this is not what we want to check - p_points.push_back(Point_3(0.0, 0.0, 0.0)); - - std::cout << "Check exception throw in debug mode" << std::endl; - // Check it throws an exception when the cuboid is not iso - BOOST_CHECK_THROW(Periodic_alpha_complex_3d periodic_alpha_complex(p_points, 0., 0., 0., 0.9, 1., 1.), - std::invalid_argument); - BOOST_CHECK_THROW(Periodic_alpha_complex_3d periodic_alpha_complex(p_points, 0., 0., 0., 1., 0.9, 1.), - std::invalid_argument); - BOOST_CHECK_THROW(Periodic_alpha_complex_3d periodic_alpha_complex(p_points, 0., 0., 0., 1., 1., 0.9), - std::invalid_argument); - BOOST_CHECK_THROW(Periodic_alpha_complex_3d periodic_alpha_complex(p_points, 0., 0., 0., 1.1, 1., 1.), - std::invalid_argument); - BOOST_CHECK_THROW(Periodic_alpha_complex_3d periodic_alpha_complex(p_points, 0., 0., 0., 1., 1.1, 1.), - std::invalid_argument); - BOOST_CHECK_THROW(Periodic_alpha_complex_3d periodic_alpha_complex(p_points, 0., 0., 0., 1., 1., 1.1), - std::invalid_argument); -} -#endif - -BOOST_AUTO_TEST_CASE(Alpha_complex_periodic) { - // --------------------- - // Fast periodic version - // --------------------- - std::cout << "Fast periodic alpha complex 3d" << std::endl; - - using Creator = CGAL::Creator_uniform_3<double, Fast_periodic_alpha_complex_3d::Point_3>; - CGAL::Random random(7); - CGAL::Random_points_in_cube_3<Fast_periodic_alpha_complex_3d::Point_3, Creator> in_cube(1, random); - std::vector<Fast_periodic_alpha_complex_3d::Point_3> p_points; - - for (int i = 0; i < 50; i++) { - Fast_periodic_alpha_complex_3d::Point_3 p = *in_cube++; - p_points.push_back(p); - } - - Fast_periodic_alpha_complex_3d periodic_alpha_complex(p_points, -1., -1., -1., 1., 1., 1.); - - Gudhi::Simplex_tree<> stree; - periodic_alpha_complex.create_complex(stree); - - // ---------------------- - // Exact periodic version - // ---------------------- - std::cout << "Exact periodic alpha complex 3d" << std::endl; - - std::vector<Exact_periodic_alpha_complex_3d::Point_3> e_p_points; - - for (auto p : p_points) { - e_p_points.push_back(Exact_periodic_alpha_complex_3d::Point_3(p[0], p[1], p[2])); - } - - Exact_periodic_alpha_complex_3d exact_alpha_complex(e_p_points, -1., -1., -1., 1., 1., 1.); - - Gudhi::Simplex_tree<> exact_stree; - exact_alpha_complex.create_complex(exact_stree); - - // --------------------- - // Compare both versions - // --------------------- - std::cout << "Exact periodic alpha complex 3d is of dimension " << exact_stree.dimension() << " - Non exact is " - << stree.dimension() << std::endl; - BOOST_CHECK(exact_stree.dimension() == stree.dimension()); - std::cout << "Exact periodic alpha complex 3d num_simplices " << exact_stree.num_simplices() << " - Non exact is " - << stree.num_simplices() << std::endl; - BOOST_CHECK(exact_stree.num_simplices() == stree.num_simplices()); - std::cout << "Exact periodic alpha complex 3d num_vertices " << exact_stree.num_vertices() << " - Non exact is " - << stree.num_vertices() << std::endl; - BOOST_CHECK(exact_stree.num_vertices() == stree.num_vertices()); - - // We cannot compare as objects from dispatcher on the alpha shape is not deterministic. - // cf. https://github.com/CGAL/cgal/issues/3346 - auto sh = stree.filtration_simplex_range().begin(); - auto sh_exact = exact_stree.filtration_simplex_range().begin(); - - while (sh != stree.filtration_simplex_range().end() || sh_exact != exact_stree.filtration_simplex_range().end()) { - GUDHI_TEST_FLOAT_EQUALITY_CHECK(stree.filtration(*sh), exact_stree.filtration(*sh_exact), 1e-14); - - std::vector<int> vh(stree.simplex_vertex_range(*sh).begin(), stree.simplex_vertex_range(*sh).end()); - std::vector<int> exact_vh(exact_stree.simplex_vertex_range(*sh_exact).begin(), - exact_stree.simplex_vertex_range(*sh_exact).end()); - - BOOST_CHECK(vh.size() == exact_vh.size()); - ++sh; - ++sh_exact; - } - - BOOST_CHECK(sh == stree.filtration_simplex_range().end()); - BOOST_CHECK(sh_exact == exact_stree.filtration_simplex_range().end()); - - // ---------------------- - // Safe periodic version - // ---------------------- - std::cout << "Safe periodic alpha complex 3d" << std::endl; - - std::vector<Safe_periodic_alpha_complex_3d::Point_3> s_p_points; - - for (auto p : p_points) { - s_p_points.push_back(Safe_periodic_alpha_complex_3d::Point_3(p[0], p[1], p[2])); - } - - Safe_periodic_alpha_complex_3d safe_alpha_complex(s_p_points, -1., -1., -1., 1., 1., 1.); - - Gudhi::Simplex_tree<> safe_stree; - safe_alpha_complex.create_complex(safe_stree); - - // --------------------- - // Compare both versions - // --------------------- - // We cannot compare as objects from dispatcher on the alpha shape is not deterministic. - // cf. https://github.com/CGAL/cgal/issues/3346 - sh = stree.filtration_simplex_range().begin(); - auto sh_safe = safe_stree.filtration_simplex_range().begin(); - - while (sh != stree.filtration_simplex_range().end() || sh_safe != safe_stree.filtration_simplex_range().end()) { - GUDHI_TEST_FLOAT_EQUALITY_CHECK(stree.filtration(*sh), safe_stree.filtration(*sh_safe), 1e-14); - - std::vector<int> vh(stree.simplex_vertex_range(*sh).begin(), stree.simplex_vertex_range(*sh).end()); - std::vector<int> safe_vh(safe_stree.simplex_vertex_range(*sh_safe).begin(), - safe_stree.simplex_vertex_range(*sh_safe).end()); - - BOOST_CHECK(vh.size() == safe_vh.size()); - ++sh; - ++sh_safe; - } - - BOOST_CHECK(sh == stree.filtration_simplex_range().end()); - BOOST_CHECK(sh_safe == safe_stree.filtration_simplex_range().end()); -} - -typedef boost::mpl::list<Fast_weighted_periodic_alpha_complex_3d, Exact_weighted_periodic_alpha_complex_3d, - Safe_weighted_periodic_alpha_complex_3d> - wp_variants_type_list; - -#ifdef GUDHI_DEBUG -BOOST_AUTO_TEST_CASE_TEMPLATE(Alpha_complex_weighted_periodic_throw, Weighted_periodic_alpha_complex_3d, - wp_variants_type_list) { - std::cout << "Weighted periodic alpha complex 3d exception throw" << std::endl; - - using Creator = CGAL::Creator_uniform_3<double, typename Weighted_periodic_alpha_complex_3d::Point_3>; - CGAL::Random random(7); - CGAL::Random_points_in_cube_3<typename Weighted_periodic_alpha_complex_3d::Point_3, Creator> in_cube(1, random); - std::vector<typename Weighted_periodic_alpha_complex_3d::Point_3> wp_points; - - for (int i = 0; i < 50; i++) { - typename Weighted_periodic_alpha_complex_3d::Point_3 p = *in_cube++; - wp_points.push_back(p); - } - std::vector<double> p_weights; - // Weights must be in range ]0, 1/64 = 0.015625[ - for (std::size_t i = 0; i < wp_points.size(); ++i) { - p_weights.push_back(random.get_double(0., 0.01)); - } - - std::cout << "Cuboid is not iso exception" << std::endl; - // Check it throws an exception when the cuboid is not iso - BOOST_CHECK_THROW( - Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, -1., -1., -1., 0.9, 1., 1.), - std::invalid_argument); - BOOST_CHECK_THROW( - Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, -1., -1., -1., 1., 0.9, 1.), - std::invalid_argument); - BOOST_CHECK_THROW( - Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, -1., -1., -1., 1., 1., 0.9), - std::invalid_argument); - BOOST_CHECK_THROW( - Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, -1., -1., -1., 1.1, 1., 1.), - std::invalid_argument); - BOOST_CHECK_THROW( - Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, -1., -1., -1., 1., 1.1, 1.), - std::invalid_argument); - BOOST_CHECK_THROW( - Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, -1., -1., -1., 1., 1., 1.1), - std::invalid_argument); - - std::cout << "0 <= point.weight() < 1/64 * domain_size * domain_size exception" << std::endl; - // Weights must be in range ]0, 1/64 = 0.015625[ - double temp = p_weights[25]; - p_weights[25] = 1.0; - BOOST_CHECK_THROW(Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, 0., 0., 0., 1., 1., 1.), - std::invalid_argument); - // Weights must be in range ]0, 1/64 = 0.015625[ - p_weights[25] = temp; - temp = p_weights[14]; - p_weights[14] = -1e-10; - BOOST_CHECK_THROW(Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, 0., 0., 0., 1., 1., 1.), - std::invalid_argument); - p_weights[14] = temp; - - std::cout << "wp_points and p_weights size exception" << std::endl; - // Weights and points must have the same size - // + 1 - p_weights.push_back(1e-10); - BOOST_CHECK_THROW(Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, 0., 0., 0., 1., 1., 1.), - std::invalid_argument); - // - 1 - p_weights.pop_back(); - p_weights.pop_back(); - BOOST_CHECK_THROW(Weighted_periodic_alpha_complex_3d wp_alpha_complex(wp_points, p_weights, 0., 0., 0., 1., 1., 1.), - std::invalid_argument); -} -#endif - -BOOST_AUTO_TEST_CASE(Alpha_complex_weighted_periodic) { - // --------------------- - // Fast weighted periodic version - // --------------------- - std::cout << "Fast weighted periodic alpha complex 3d" << std::endl; - - using Creator = CGAL::Creator_uniform_3<double, Fast_weighted_periodic_alpha_complex_3d::Point_3>; - CGAL::Random random(7); - CGAL::Random_points_in_cube_3<Fast_weighted_periodic_alpha_complex_3d::Point_3, Creator> in_cube(1, random); - std::vector<Fast_weighted_periodic_alpha_complex_3d::Point_3> p_points; - - for (int i = 0; i < 50; i++) { - Fast_weighted_periodic_alpha_complex_3d::Point_3 p = *in_cube++; - p_points.push_back(p); - } - std::vector<double> p_weights; - // Weights must be in range ]0, 1/64 = 0.015625[ - for (std::size_t i = 0; i < p_points.size(); ++i) { - p_weights.push_back(random.get_double(0., 0.01)); - } - - Fast_weighted_periodic_alpha_complex_3d periodic_alpha_complex(p_points, p_weights, -1., -1., -1., 1., 1., 1.); - - Gudhi::Simplex_tree<> stree; - periodic_alpha_complex.create_complex(stree); - - // ---------------------- - // Exact weighted periodic version - // ---------------------- - std::cout << "Exact weighted periodic alpha complex 3d" << std::endl; - - std::vector<Exact_weighted_periodic_alpha_complex_3d::Point_3> e_p_points; - - for (auto p : p_points) { - e_p_points.push_back(Exact_weighted_periodic_alpha_complex_3d::Point_3(p[0], p[1], p[2])); - } - - Exact_weighted_periodic_alpha_complex_3d exact_alpha_complex(e_p_points, p_weights, -1., -1., -1., 1., 1., 1.); - - Gudhi::Simplex_tree<> exact_stree; - exact_alpha_complex.create_complex(exact_stree); - - // --------------------- - // Compare both versions - // --------------------- - std::cout << "Exact weighted periodic alpha complex 3d is of dimension " << exact_stree.dimension() - << " - Non exact is " << stree.dimension() << std::endl; - BOOST_CHECK(exact_stree.dimension() == stree.dimension()); - std::cout << "Exact weighted periodic alpha complex 3d num_simplices " << exact_stree.num_simplices() - << " - Non exact is " << stree.num_simplices() << std::endl; - BOOST_CHECK(exact_stree.num_simplices() == stree.num_simplices()); - std::cout << "Exact weighted periodic alpha complex 3d num_vertices " << exact_stree.num_vertices() - << " - Non exact is " << stree.num_vertices() << std::endl; - BOOST_CHECK(exact_stree.num_vertices() == stree.num_vertices()); - - // We cannot compare as objects from dispatcher on the alpha shape is not deterministic. - // cf. https://github.com/CGAL/cgal/issues/3346 - auto sh = stree.filtration_simplex_range().begin(); - auto sh_exact = exact_stree.filtration_simplex_range().begin(); - - while (sh != stree.filtration_simplex_range().end() || sh_exact != exact_stree.filtration_simplex_range().end()) { - GUDHI_TEST_FLOAT_EQUALITY_CHECK(stree.filtration(*sh), exact_stree.filtration(*sh_exact), 1e-14); - - std::vector<int> vh(stree.simplex_vertex_range(*sh).begin(), stree.simplex_vertex_range(*sh).end()); - std::vector<int> exact_vh(exact_stree.simplex_vertex_range(*sh_exact).begin(), - exact_stree.simplex_vertex_range(*sh_exact).end()); - - BOOST_CHECK(vh.size() == exact_vh.size()); - ++sh; - ++sh_exact; - } - - BOOST_CHECK(sh == stree.filtration_simplex_range().end()); - BOOST_CHECK(sh_exact == exact_stree.filtration_simplex_range().end()); - - // ---------------------- - // Safe weighted periodic version - // ---------------------- - std::cout << "Safe weighted periodic alpha complex 3d" << std::endl; - - std::vector<Safe_weighted_periodic_alpha_complex_3d::Point_3> s_p_points; - - for (auto p : p_points) { - s_p_points.push_back(Safe_weighted_periodic_alpha_complex_3d::Point_3(p[0], p[1], p[2])); - } - - Safe_weighted_periodic_alpha_complex_3d safe_alpha_complex(s_p_points, p_weights, -1., -1., -1., 1., 1., 1.); - - Gudhi::Simplex_tree<> safe_stree; - safe_alpha_complex.create_complex(safe_stree); - - // --------------------- - // Compare both versions - // --------------------- - // We cannot compare as objects from dispatcher on the alpha shape is not deterministic. - // cf. https://github.com/CGAL/cgal/issues/3346 - sh = stree.filtration_simplex_range().begin(); - auto sh_safe = safe_stree.filtration_simplex_range().begin(); - - while (sh != stree.filtration_simplex_range().end() || sh_safe != safe_stree.filtration_simplex_range().end()) { - GUDHI_TEST_FLOAT_EQUALITY_CHECK(stree.filtration(*sh), safe_stree.filtration(*sh_safe), 1e-14); - - std::vector<int> vh(stree.simplex_vertex_range(*sh).begin(), stree.simplex_vertex_range(*sh).end()); - std::vector<int> safe_vh(safe_stree.simplex_vertex_range(*sh_safe).begin(), - safe_stree.simplex_vertex_range(*sh_safe).end()); - - BOOST_CHECK(vh.size() == safe_vh.size()); - ++sh; - ++sh_safe; - } - - BOOST_CHECK(sh == stree.filtration_simplex_range().end()); - BOOST_CHECK(sh_safe == safe_stree.filtration_simplex_range().end()); -} |