summaryrefslogtreecommitdiff
path: root/src/Persistent_cohomology/test/betti_numbers_unit_test.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/Persistent_cohomology/test/betti_numbers_unit_test.cpp')
-rw-r--r--src/Persistent_cohomology/test/betti_numbers_unit_test.cpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/src/Persistent_cohomology/test/betti_numbers_unit_test.cpp b/src/Persistent_cohomology/test/betti_numbers_unit_test.cpp
index 40221005..67dfcce4 100644
--- a/src/Persistent_cohomology/test/betti_numbers_unit_test.cpp
+++ b/src/Persistent_cohomology/test/betti_numbers_unit_test.cpp
@@ -84,6 +84,8 @@ BOOST_AUTO_TEST_CASE( plain_homology_betti_numbers )
// 2 1 0 inf
// means that in Z/2Z-homology, the Betti numbers are b0=2 and b1=1.
+ std::cout << "BETTI NUMBERS" << std::endl;
+
BOOST_CHECK(pcoh.betti_number(0) == 2);
BOOST_CHECK(pcoh.betti_number(1) == 1);
BOOST_CHECK(pcoh.betti_number(2) == 0);
@@ -93,6 +95,8 @@ BOOST_AUTO_TEST_CASE( plain_homology_betti_numbers )
BOOST_CHECK(bns[0] == 2);
BOOST_CHECK(bns[1] == 1);
BOOST_CHECK(bns[2] == 0);
+
+ std::cout << "GET PERSISTENT PAIRS" << std::endl;
// Custom sort and output persistence
cmp_intervals_by_dim_then_length<Mini_simplex_tree> cmp(&st);
@@ -115,6 +119,33 @@ BOOST_AUTO_TEST_CASE( plain_homology_betti_numbers )
BOOST_CHECK(st.dimension(get<0>(persistent_pairs[2])) == 0);
BOOST_CHECK(st.filtration(get<0>(persistent_pairs[2])) == 0);
BOOST_CHECK(get<1>(persistent_pairs[2]) == st.null_simplex());
+
+ std::cout << "PAIRS IN DIMENSION" << std::endl;
+
+ auto pairs_in_dimension_0 = pcoh.pairs_in_dimension(0);
+ std::cout << "pairs_in_dimension_0.size() = " << pairs_in_dimension_0.size() << std::endl;
+ for (int i = 0; i < pairs_in_dimension_0.size(); i++)
+ std::cout << "pairs_in_dimension_0[" << i << "] = [" << pairs_in_dimension_0[i].first << "," <<
+ pairs_in_dimension_0[i].second << "]" << std::endl;
+ BOOST_CHECK(pairs_in_dimension_0.size() == 2);
+ BOOST_CHECK(pairs_in_dimension_0[0].first == 0);
+ BOOST_CHECK(pairs_in_dimension_0[0].second == std::numeric_limits<Mini_simplex_tree::Filtration_value>::infinity());
+ BOOST_CHECK(pairs_in_dimension_0[1].first == 0);
+ BOOST_CHECK(pairs_in_dimension_0[1].second == std::numeric_limits<Mini_simplex_tree::Filtration_value>::infinity());
+
+
+ auto pairs_in_dimension_1 = pcoh.pairs_in_dimension(1);
+ std::cout << "pairs_in_dimension_1.size() = " << pairs_in_dimension_1.size() << std::endl;
+ for (int i = 0; i < pairs_in_dimension_1.size(); i++)
+ std::cout << "pairs_in_dimension_1[" << i << "] = [" << pairs_in_dimension_1[i].first << "," <<
+ pairs_in_dimension_1[i].second << "]" << std::endl;
+ BOOST_CHECK(pairs_in_dimension_1.size() == 1);
+ BOOST_CHECK(pairs_in_dimension_1[0].first == 0);
+ BOOST_CHECK(pairs_in_dimension_1[0].second == std::numeric_limits<Mini_simplex_tree::Filtration_value>::infinity());
+
+ auto pairs_in_dimension_2 = pcoh.pairs_in_dimension(2);
+ std::cout << "pairs_in_dimension_2.size() = " << pairs_in_dimension_2.size() << std::endl;
+ BOOST_CHECK(pairs_in_dimension_2.size() == 0);
}
using Simplex_tree = Gudhi::Simplex_tree<>;
@@ -231,4 +262,30 @@ BOOST_AUTO_TEST_CASE( betti_numbers )
BOOST_CHECK(st.dimension(get<0>(persistent_pairs[2])) == 0);
BOOST_CHECK(st.filtration(get<0>(persistent_pairs[2])) == 1);
BOOST_CHECK(get<1>(persistent_pairs[2]) == st.null_simplex());
+
+ std::cout << "PAIRS IN DIMENSION" << std::endl;
+
+ auto pairs_in_dimension_0 = pcoh.pairs_in_dimension(0);
+ std::cout << "pairs_in_dimension_0.size() = " << pairs_in_dimension_0.size() << std::endl;
+ for (int i = 0; i < pairs_in_dimension_0.size(); i++)
+ std::cout << "pairs_in_dimension_0[" << i << "] = [" << pairs_in_dimension_0[i].first << "," <<
+ pairs_in_dimension_0[i].second << "]" << std::endl;
+ BOOST_CHECK(pairs_in_dimension_0.size() == 2);
+ BOOST_CHECK(pairs_in_dimension_0[0].first == 2);
+ BOOST_CHECK(pairs_in_dimension_0[0].second == std::numeric_limits<Mini_simplex_tree::Filtration_value>::infinity());
+ BOOST_CHECK(pairs_in_dimension_0[1].first == 1);
+ BOOST_CHECK(pairs_in_dimension_0[1].second == std::numeric_limits<Mini_simplex_tree::Filtration_value>::infinity());
+
+ auto pairs_in_dimension_1 = pcoh.pairs_in_dimension(1);
+ std::cout << "pairs_in_dimension_1.size() = " << pairs_in_dimension_1.size() << std::endl;
+ for (int i = 0; i < pairs_in_dimension_1.size(); i++)
+ std::cout << "pairs_in_dimension_1[" << i << "] = [" << pairs_in_dimension_1[i].first << "," <<
+ pairs_in_dimension_1[i].second << "]" << std::endl;
+ BOOST_CHECK(pairs_in_dimension_1.size() == 1);
+ BOOST_CHECK(pairs_in_dimension_1[0].first == 4);
+ BOOST_CHECK(pairs_in_dimension_1[0].second == std::numeric_limits<Mini_simplex_tree::Filtration_value>::infinity());
+
+ auto pairs_in_dimension_2 = pcoh.pairs_in_dimension(2);
+ std::cout << "pairs_in_dimension_2.size() = " << pairs_in_dimension_2.size() << std::endl;
+ BOOST_CHECK(pairs_in_dimension_2.size() == 0);
}