12345678910111213141516171819202122232425262728293031323334353637 |
- #include <test_common.h>
- #include <igl/tet_tet_adjacency.h>
- #include <igl/readMESH.h>
- #include <iostream>
- TEST_CASE("tet_tet_adjacency: dot", "[igl]")
- {
- const auto test_case = [](const std::string ¶m)
- {
- Eigen::MatrixXd V;
- Eigen::MatrixXi F, T, TT,TTi;
- // Load example mesh: GetParam() will be name of mesh file
- igl::readMESH(test_common::data_path(param), V, T, F);
- igl::tet_tet_adjacency(T, TT, TTi);
- REQUIRE (TT.rows() == T.rows());
- REQUIRE (TTi.rows() == T.rows());
- REQUIRE (TT.cols() == T.cols());
- REQUIRE (TTi.cols() == T.cols());
- for(int t = 0;t<T.rows();t++)
- {
- for(int c = 0; c<4 ;c++)
- {
- if(TT(t, c) >= 0)
- {
- REQUIRE (T.rows() > TT(t, c));
- REQUIRE (0 <= TTi(t, c));
- REQUIRE (4 > TTi(t, c));
- REQUIRE (t == TT(TT(t, c), TTi(t,c)));
- }
- }
- }
- };
- test_common::run_test_cases(test_common::tet_meshes(), test_case);
- }
|