From bdd33218a94fe416e075045edefaabb3a06634b1 Mon Sep 17 00:00:00 2001 From: Alec Jacobson Date: Tue, 16 Feb 2021 11:09:33 -0500 Subject: [PATCH] fix re:jdumas' comments on PR --- include/igl/copyleft/quadprog.cpp | 1 - include/igl/decimate.cpp | 4 ---- include/igl/dual_contouring.cpp | 12 ++++++------ include/igl/min_quad_with_fixed.cpp | 18 ------------------ include/igl/per_corner_normals.cpp | 2 +- include/igl/polygon_corners.h | 4 ++-- include/igl/quadprog.cpp | 27 +++++++++++++++++---------- 7 files changed, 26 insertions(+), 42 deletions(-) diff --git a/include/igl/copyleft/quadprog.cpp b/include/igl/copyleft/quadprog.cpp index 2d0ffa74a3..7ee417e818 100644 --- a/include/igl/copyleft/quadprog.cpp +++ b/include/igl/copyleft/quadprog.cpp @@ -1,4 +1,3 @@ -//#define TRACE_SOLVER #include "quadprog.h" #include "../matlab_format.h" #include diff --git a/include/igl/decimate.cpp b/include/igl/decimate.cpp index f68887a167..c5c6cf7f6b 100644 --- a/include/igl/decimate.cpp +++ b/include/igl/decimate.cpp @@ -186,11 +186,7 @@ IGL_INLINE bool igl::decimate( C.row(e) = p; costs(e) = cost; }, -#ifndef NDEBUG - SIZE_MAX -#else 10000 -#endif ); for(int e = 0;e RowVector3S; - typedef Eigen::Matrix RowVector4S; - typedef Eigen::Matrix Matrix4S; - typedef Eigen::Matrix Matrix3S; - typedef Eigen::Matrix Vector3S; - typedef std::tuple KeyTriplet; + using RowVector3S = Eigen::Matrix; + using RowVector4S = Eigen::Matrix; + using Matrix4S = Eigen::Matrix; + using Matrix3S = Eigen::Matrix; + using Vector3S = Eigen::Matrix; + using KeyTriplet = std::tuple; // helper function public: // Working variables diff --git a/include/igl/min_quad_with_fixed.cpp b/include/igl/min_quad_with_fixed.cpp index 89d11ca372..715c7b75de 100644 --- a/include/igl/min_quad_with_fixed.cpp +++ b/include/igl/min_quad_with_fixed.cpp @@ -593,13 +593,6 @@ IGL_INLINE Eigen::Matrix igl::min_quad_with_fixed( const Eigen::Matrix & A, const Eigen::Matrix & b) { - //printf("igl::min_quad_with_fixed\n"); - //std::cout< igl::min_quad_with_fixed( const Eigen::Matrix bcbc = make_bcbc(); const Eigen::Matrix xx = min_quad_with_fixed(HH,ff,kk,bcbc); - //std::cout< igl::min_quad_with_fixed( const Eigen::Array & k, const Eigen::Matrix & bc) { - //printf("igl::min_quad_with_fixed\n"); - //std::cout< igl::min_quad_with_fixed( // Everything fixed if(kcount == (Eigen::Dynamic?H.rows():n)) { - //std::cout< igl::min_quad_with_fixed( typedef typename std::conditional,Eigen::CompleteOrthogonalDecomposition>::type Solver; - //std::cout< igl::min_quad_with_fixed( x(u) = -f(u); for(int i=0;i igl::min_quad_with_fixed( const Eigen::Array & k, const Eigen::Matrix & bc) { - //printf("igl::min_quad_with_fixed\n"); // 0 and n should be handle outside this function static_assert(kcount==Eigen::Dynamic || kcount>0 ,""); static_assert(kcount==Eigen::Dynamic || kcount igl::min_quad_with_fixed( } } } - //std::cout< IGL_INLINE void igl::per_corner_normals( @@ -102,7 +103,6 @@ IGL_INLINE void igl::per_corner_normals( } } -#include "doublearea.h" template < typename DerivedV, diff --git a/include/igl/polygon_corners.h b/include/igl/polygon_corners.h index afdcdd6203..6766d1f6db 100644 --- a/include/igl/polygon_corners.h +++ b/include/igl/polygon_corners.h @@ -36,8 +36,8 @@ namespace igl // and sizes // // Inputs: - // Q #Q by k list of k-gon indices (Q(i,j) = -1 means that face i is a - // j-gon) + // Q #Q by k list of polygon indices (ith row is a k-gon, unless Q(i,j) = + // -1 then it's a j-gon) template < typename DerivedQ, typename DerivedI, diff --git a/include/igl/quadprog.cpp b/include/igl/quadprog.cpp index ac19f75218..717b04661b 100644 --- a/include/igl/quadprog.cpp +++ b/include/igl/quadprog.cpp @@ -12,6 +12,23 @@ IGL_INLINE Eigen::Matrix igl::quadprog( const Eigen::Matrix & lb, const Eigen::Matrix & ub) { + // Alec 16/2/2021: + // igl::quadprog implements a very simple primal active set method. The new + // igl::min_quad_with_fixed is very fast for small dense problems so the + // iterations of igl::quadprog become very fast. Even if it ends up doing many + // more iterations than igl::copyleft::quadprog it would be much faster (in + // reality it doesn't do that many more iterations). It's a healthy 10-100x + // faster than igl::copyleft::quadprog for specific cases of QPs. + // + // Unfortunately, that set is limited. igl::quadprog is really good at tiny + // box-constrained QPs with a positive definite objective (like the kind that show + // up in dual contouring). igl::copyleft::quadprog handles more general problems + // (and also starts to beat igl::quadprog when the number of variables gets over + // ~20). I tried extending igl::quadprog so that we could use it for + // igl::copyleft::progressive_hulls and drop igl::copyleft::quadprog but it was + // trickier than I thought. Something like qpmad or the non GPL version of + // quadrog++ would be good future PR. + // typedef Eigen::Matrix VectorSn; typedef Eigen::Array Arraybn; assert( (lb.array() < ub.array() ).all() ); @@ -27,7 +44,6 @@ IGL_INLINE Eigen::Matrix igl::quadprog( // Optimize for this common case. // Windows needs template arguments spelled out x = min_quad_with_fixed(H,f,k,bc,A,b); - //std::cout< igl::quadprog( { const Scalar sign = bc(i)==ub(i)?1:-1; const Scalar lambda_i = sign * (H.row(i)*x+f(i)); - //printf(" considering k(%d) (λ = %g)\n",i,lambda_i); if(lambda_i > worst_lambda) { - //printf(" removing k(%d) (λ = %g)\n",i,lambda_i); best_remove = i; worst_lambda = lambda_i; } @@ -69,27 +83,20 @@ IGL_INLINE Eigen::Matrix igl::quadprog( { const auto i = best_add; assert(!k(i)); - //add_lower ? printf(" adding lb(%d)\n",i) : printf(" adding lb(%d)\n",i); bc(i) = add_lower ? lb(i) : ub(i); k(i) = true; }else if(best_remove >= 0) { const auto i = best_remove; assert(k(i)); - //printf(" removing k(%d) (λ = %g)\n",i,worst_lambda); k(i) = false; }else /*if(best_add < 0 && best_remove < 0)*/ { - std::cout<