From 2a2b105e1c15a233eebfcb9be6462a07920b5e61 Mon Sep 17 00:00:00 2001 From: Charlie Vanaret Date: Mon, 9 Dec 2024 15:28:18 +0100 Subject: [PATCH] Replaced WarmstartInformation.problem_structure_changed with two flags: hessian_sparsity_changed and jacobian_sparsity_changed. This should allow a finer control in the subproblem solvers. --- .../SymmetricIndefiniteLinearSystem.hpp | 4 ++-- uno/optimization/WarmstartInformation.cpp | 20 +++++++++++-------- uno/optimization/WarmstartInformation.hpp | 4 +++- uno/solvers/BQPD/BQPDSolver.cpp | 2 +- 4 files changed, 18 insertions(+), 12 deletions(-) diff --git a/uno/linear_algebra/SymmetricIndefiniteLinearSystem.hpp b/uno/linear_algebra/SymmetricIndefiniteLinearSystem.hpp index 273eed9d..6e8f2953 100644 --- a/uno/linear_algebra/SymmetricIndefiniteLinearSystem.hpp +++ b/uno/linear_algebra/SymmetricIndefiniteLinearSystem.hpp @@ -92,10 +92,10 @@ namespace uno { template void SymmetricIndefiniteLinearSystem::factorize_matrix(DirectSymmetricIndefiniteLinearSolver& linear_solver, WarmstartInformation& warmstart_information) { - if (warmstart_information.problem_structure_changed) { + if (warmstart_information.hessian_sparsity_changed || warmstart_information.jacobian_sparsity_changed) { DEBUG << "Performing symbolic analysis of the indefinite system\n"; linear_solver.do_symbolic_analysis(this->matrix); - warmstart_information.problem_structure_changed = false; + warmstart_information.hessian_sparsity_changed = warmstart_information.jacobian_sparsity_changed = false; } DEBUG << "Performing numerical factorization of the indefinite system\n"; linear_solver.do_numerical_factorization(this->matrix); diff --git a/uno/optimization/WarmstartInformation.cpp b/uno/optimization/WarmstartInformation.cpp index 1cefbb5a..cdf5dcf3 100644 --- a/uno/optimization/WarmstartInformation.cpp +++ b/uno/optimization/WarmstartInformation.cpp @@ -6,11 +6,12 @@ namespace uno { void WarmstartInformation::display() const { - std::cout << "Objective: " << std::boolalpha << this->objective_changed << '\n'; - std::cout << "Constraints: " << std::boolalpha << this->constraints_changed << '\n'; - std::cout << "Constraint bounds: " << std::boolalpha << this->constraint_bounds_changed << '\n'; - std::cout << "Variable bounds: " << std::boolalpha << this->variable_bounds_changed << '\n'; - std::cout << "Problem structure: " << std::boolalpha << this->problem_structure_changed << '\n'; + std::cout << "Objective changed: " << std::boolalpha << this->objective_changed << '\n'; + std::cout << "Constraints changed: " << std::boolalpha << this->constraints_changed << '\n'; + std::cout << "Constraint bounds changed: " << std::boolalpha << this->constraint_bounds_changed << '\n'; + std::cout << "Variable bounds changed: " << std::boolalpha << this->variable_bounds_changed << '\n'; + std::cout << "Hessian sparsity changed: " << std::boolalpha << this->hessian_sparsity_changed << '\n'; + std::cout << "Jacobian sparsity changed: " << std::boolalpha << this->jacobian_sparsity_changed << '\n'; } void WarmstartInformation::no_changes() { @@ -18,7 +19,8 @@ namespace uno { this->constraints_changed = false; this->constraint_bounds_changed = false; this->variable_bounds_changed = false; - this->problem_structure_changed = false; + this->hessian_sparsity_changed = false; + this->jacobian_sparsity_changed = false; } void WarmstartInformation::iterate_changed() { @@ -33,7 +35,8 @@ namespace uno { this->constraints_changed = true; this->constraint_bounds_changed = true; this->variable_bounds_changed = true; - this->problem_structure_changed = true; + this->hessian_sparsity_changed = true; + this->jacobian_sparsity_changed = true; } void WarmstartInformation::only_objective_changed() { @@ -41,6 +44,7 @@ namespace uno { this->constraints_changed = false; this->constraint_bounds_changed = false; this->variable_bounds_changed = false; - this->problem_structure_changed = false; + this->hessian_sparsity_changed = false; + this->jacobian_sparsity_changed = false; } } // namespace \ No newline at end of file diff --git a/uno/optimization/WarmstartInformation.hpp b/uno/optimization/WarmstartInformation.hpp index 0cb5fba1..48c30ac0 100644 --- a/uno/optimization/WarmstartInformation.hpp +++ b/uno/optimization/WarmstartInformation.hpp @@ -10,7 +10,9 @@ namespace uno { bool constraints_changed{true}; bool constraint_bounds_changed{true}; bool variable_bounds_changed{true}; - bool problem_structure_changed{true}; + // bool problem_structure_changed{true}; + bool hessian_sparsity_changed{true}; + bool jacobian_sparsity_changed{true}; void display() const; void no_changes(); diff --git a/uno/solvers/BQPD/BQPDSolver.cpp b/uno/solvers/BQPD/BQPDSolver.cpp index 92eaf087..678780ea 100644 --- a/uno/solvers/BQPD/BQPDSolver.cpp +++ b/uno/solvers/BQPD/BQPDSolver.cpp @@ -166,7 +166,7 @@ namespace uno { BQPDMode BQPDSolver::determine_mode(const WarmstartInformation& warmstart_information) const { BQPDMode mode = (this->number_calls == 0) ? BQPDMode::ACTIVE_SET_EQUALITIES : BQPDMode::USER_DEFINED; // if problem structure changed, use cold start - if (warmstart_information.problem_structure_changed) { + if (warmstart_information.hessian_sparsity_changed || warmstart_information.jacobian_sparsity_changed) { mode = BQPDMode::ACTIVE_SET_EQUALITIES; } // if only the variable bounds changed, reuse the active set estimate and the Jacobian information