1e0ed867bSAlp Dener #include <../src/tao/bound/impls/bqnk/bqnk.h> 2e0ed867bSAlp Dener 33850be85SAlp Dener /*MC 43850be85SAlp Dener TAOBQNKLS - Bounded Quasi-Newton-Krylov Line Search method for nonlinear minimization with 53850be85SAlp Dener bound constraints. This method approximates the Hessian-vector product using a 63850be85SAlp Dener limited-memory quasi-Newton formula, and iteratively inverts the Hessian with a 73850be85SAlp Dener Krylov solver. The quasi-Newton matrix and its settings can be accessed via the 83850be85SAlp Dener prefix `-tao_bqnk_` 93850be85SAlp Dener 103850be85SAlp Dener Options Database Keys: 113850be85SAlp Dener + -tao_bqnk_max_cg_its - maximum number of bounded conjugate-gradient iterations taken in each Newton loop 123850be85SAlp Dener . -tao_bqnk_init_type - trust radius initialization method ("constant", "direction", "interpolation") 133850be85SAlp Dener . -tao_bqnk_update_type - trust radius update method ("step", "direction", "interpolation") 143850be85SAlp Dener - -tao_bqnk_as_type - active-set estimation method ("none", "bertsekas") 153850be85SAlp Dener 163850be85SAlp Dener Level: beginner 173850be85SAlp Dener M*/ 18e0ed867bSAlp Dener PETSC_EXTERN PetscErrorCode TaoCreate_BQNKLS(Tao tao) 19e0ed867bSAlp Dener { 20e0ed867bSAlp Dener TAO_BNK *bnk; 21*414d97d3SAlp Dener TAO_BQNK *bqnk; 22e0ed867bSAlp Dener PetscErrorCode ierr; 23e0ed867bSAlp Dener 24e0ed867bSAlp Dener PetscFunctionBegin; 25e0ed867bSAlp Dener ierr = TaoCreate_BQNK(tao);CHKERRQ(ierr); 26e0ed867bSAlp Dener bnk = (TAO_BNK*)tao->data; 27e0ed867bSAlp Dener bnk->update_type = BNK_UPDATE_STEP; 28*414d97d3SAlp Dener bqnk = (TAO_BQNK*)bnk->ctx; 29*414d97d3SAlp Dener bqnk->solve = TaoSolve_BNLS; 30e0ed867bSAlp Dener PetscFunctionReturn(0); 31e0ed867bSAlp Dener } 32