123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- #include <test_common.h>
- #include <igl/intrinsic_delaunay_triangulation.h>
- #include <igl/edge_lengths.h>
- #include <igl/triangulated_grid.h>
- #include <igl/is_delaunay.h>
- #include <igl/is_intrinsic_delaunay.h>
- #include <igl/is_edge_manifold.h>
- #include <igl/unique_simplices.h>
- #include <igl/get_seconds.h>
- #include <igl/matlab_format.h>
- TEST_CASE("intrinsic_delaunay_triangulation: two_triangles", "[igl]")
- {
- const Eigen::MatrixXd V =
- (Eigen::MatrixXd(4,2)<<
- 0,12,
- 1,0,
- 1,20,
- 2,9).finished();
- const Eigen::MatrixXi FN =
- (Eigen::MatrixXi(2,3)<<
- 0,1,2,
- 2,1,3).finished();
- Eigen::MatrixXd lN;
- igl::edge_lengths(V,FN,lN);
- Eigen::MatrixXd l;
- Eigen::MatrixXi F;
- igl::intrinsic_delaunay_triangulation( lN, FN, l, F);
- Eigen::MatrixXd lext;
- igl::edge_lengths(V,F,lext);
- test_common::assert_near(l,lext,1e-10);
- }
- TEST_CASE("intrinsic_delaunay_triangulation: skewed_grid", "[igl]")
- {
- Eigen::MatrixXd V;
- Eigen::MatrixXi F_in;
- igl::triangulated_grid(4,4,V,F_in);
- // Skew against diagonal direction
- V.col(0) -= 1.5*V.col(1);
- Eigen::MatrixXd l_in;
- igl::edge_lengths(V,F_in,l_in);
- Eigen::MatrixXd l;
- Eigen::MatrixXi F;
- igl::intrinsic_delaunay_triangulation( l_in, F_in, l, F);
- Eigen::MatrixXd lext;
- igl::edge_lengths(V,F,lext);
- test_common::assert_near(l,lext,1e-10);
- Eigen::Matrix<bool,Eigen::Dynamic,3> D;
- igl::is_delaunay(V,F,D);
- const Eigen::Matrix<bool,Eigen::Dynamic,3> Dtrue =
- Eigen::Matrix<bool,Eigen::Dynamic,3>::Constant(F.rows(),F.cols(),true);
- test_common::assert_eq(D,Dtrue);
- }
- TEST_CASE("intrinsic_delaunay_triangulation: peaks", "[igl]")
- {
- Eigen::MatrixXd V2;
- Eigen::MatrixXi F_in;
- igl::triangulated_grid(20,20,V2,F_in);
- Eigen::MatrixXd V(V2.rows(),3);
- for(int v=0;v<V.rows();v++)
- {
- const auto x = (V2(v,0)-0.5)*6.0;
- const auto y = (V2(v,1)-0.5)*6.0;
- // peaks.m
- const auto z = 3.*(1.-x)*(1.-x)*std::exp(-(x*x) - (y+1.)*(y+1.)) +
- - 10.*(x/5. - x*x*x - y*y*y*y*y)*std::exp(-x*x-y*y) +
- - 1./3.*std::exp(-(x+1.)*(x+1.) - y*y);
- V(v,0) = x;
- V(v,1) = y;
- V(v,2) = z;
- }
- Eigen::MatrixXd l_in;
- igl::edge_lengths(V,F_in,l_in);
- Eigen::MatrixXd l;
- Eigen::MatrixXi F;
- Eigen::MatrixXi E,uE;
- Eigen::VectorXi EMAP;
- std::vector<std::vector<int> > uE2E;
- igl::intrinsic_delaunay_triangulation(l_in,F_in,l,F,E,uE,EMAP,uE2E);
- Eigen::Matrix<bool,Eigen::Dynamic,3> D;
- const Eigen::Matrix<bool,Eigen::Dynamic,3> D_gt =
- Eigen::Matrix<bool,Eigen::Dynamic,3>::Constant(F.rows(),F.cols(),true);
- igl::is_intrinsic_delaunay(l,F,uE2E,D);
- test_common::assert_eq(D,D_gt);
- }
- TEST_CASE("intrinsic_delaunay_triangulation: tet", "[igl]")
- {
- const Eigen::MatrixXd V = (Eigen::MatrixXd(4,3)<<
- 10, 4,7,
- 5, 9,0,
- 8, 8,8,
- 1,10,9).finished();
- const Eigen::MatrixXi F_in = (Eigen::MatrixXi(4,3)<<
- 0,1,2,
- 0,2,3,
- 0,3,1,
- 1,3,2).finished();
- const Eigen::Matrix<bool,Eigen::Dynamic,3> D_before =
- (Eigen::Matrix<bool,Eigen::Dynamic,3>(4,3)<<
- 1,1,1,
- 1,0,1,
- 1,1,0,
- 1,1,1).finished();
- Eigen::Matrix<bool,Eigen::Dynamic,3> D;
- Eigen::MatrixXd l_in;
- igl::edge_lengths(V,F_in,l_in);
- igl::is_intrinsic_delaunay(l_in,F_in,D);
- test_common::assert_eq(D,D_before);
- Eigen::MatrixXd l;
- Eigen::MatrixXi F;
- Eigen::MatrixXi E,uE;
- Eigen::VectorXi EMAP;
- std::vector<std::vector<int> > uE2E;
- igl::intrinsic_delaunay_triangulation(l_in,F_in,l,F,E,uE,EMAP,uE2E);
- const Eigen::Matrix<bool,Eigen::Dynamic,3> D_after =
- Eigen::Matrix<bool,Eigen::Dynamic,3>::Constant(F.rows(),F.cols(),true);
- igl::is_intrinsic_delaunay(l,F,uE2E,D);
- test_common::assert_eq(D,D_after);
- }
|