min_quad_with_fixed.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. #include <test_common.h>
  2. #include <igl/min_quad_with_fixed.h>
  3. #include <igl/EPS.h>
  4. TEST_CASE("min_quad_with_fixed: dense", "[igl]" )
  5. {
  6. const Eigen::Matrix<double,3,3> H = (Eigen::Matrix<double,3,3>(3,3)<<62,43,76,43,69,62,76,62,101).finished();
  7. const Eigen::Matrix<double,3,1> f = (Eigen::Matrix<double,3,1>(3,1)<<9,8,5).finished();
  8. const Eigen::Matrix<double,1,3> A = (Eigen::Matrix<double,1,3>(1,3)<<1,1,1).finished();
  9. const Eigen::Matrix<double,1,1> b = (Eigen::Matrix<double,1,1>(1,1)<<2).finished();
  10. const Eigen::Array<bool,3,1> k = (Eigen::Array<bool,3,1>()<<true,false,false).finished();
  11. const Eigen::Matrix<double,3,1> bc = (Eigen::Matrix<double,3,1>(3,1)<<1,0,0).finished();
  12. // Windows needs template args spelled out
  13. const Eigen::Matrix<double,3,1> x = igl::min_quad_with_fixed<double,3,1>(H,f,k,bc,A,b);
  14. REQUIRE(abs(x(0)- 1.0)<igl::EPS<double>());
  15. REQUIRE(abs(x(1)- 1.5)<igl::EPS<double>());
  16. REQUIRE(abs(x(2)- -.5)<igl::EPS<double>());
  17. }
  18. TEST_CASE("min_quad_with_fixed: Aeq", "[igl]" )
  19. {
  20. Eigen::MatrixXd Q(4,4);
  21. Q<<
  22. 1,-1,0,0,
  23. -1,2,-1,0,
  24. 0,-1,2,-1,
  25. 0,0,-1,1;
  26. Eigen::VectorXd B = Eigen::VectorXd::Zero(4);
  27. Eigen::MatrixXd Aeq(1,4);
  28. Aeq<<-1,0,0,1;
  29. Eigen::VectorXd beq(1);
  30. beq<<3;
  31. Eigen::VectorXi b(1);
  32. b<<0;
  33. Eigen::VectorXd bc(1);
  34. bc<<0;
  35. Eigen::VectorXd Z;
  36. igl::min_quad_with_fixed(
  37. Eigen::SparseMatrix<double>(Q.sparseView()),B,b,bc,
  38. Eigen::SparseMatrix<double>(Aeq.sparseView()),beq,true,Z);
  39. Eigen::VectorXd Zgt(4);
  40. Zgt << 0,1,2,3;
  41. const double epsilon = 1e-15;
  42. test_common::assert_near(Z,Zgt,epsilon);
  43. }