MoochoPack : Framework for Large-Scale Optimization Algorithms  Version of the Day
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Groups Pages
MoochoPack_NLPAlgoConfigMamaJama.hpp
1 // @HEADER
2 // ***********************************************************************
3 //
4 // Moocho: Multi-functional Object-Oriented arCHitecture for Optimization
5 // Copyright (2003) Sandia Corporation
6 //
7 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
8 // license for use of this work by or on behalf of the U.S. Government.
9 //
10 // Redistribution and use in source and binary forms, with or without
11 // modification, are permitted provided that the following conditions are
12 // met:
13 //
14 // 1. Redistributions of source code must retain the above copyright
15 // notice, this list of conditions and the following disclaimer.
16 //
17 // 2. Redistributions in binary form must reproduce the above copyright
18 // notice, this list of conditions and the following disclaimer in the
19 // documentation and/or other materials provided with the distribution.
20 //
21 // 3. Neither the name of the Corporation nor the names of the
22 // contributors may be used to endorse or promote products derived from
23 // this software without specific prior written permission.
24 //
25 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
26 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
29 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36 //
37 // Questions? Contact Roscoe A. Bartlett (rabartl@sandia.gov)
38 //
39 // ***********************************************************************
40 // @HEADER
41 
42 #ifndef RSQP_ALGO_CONFIG_MAMA_JAMA_H
43 #define RSQP_ALGO_CONFIG_MAMA_JAMA_H
44 
45 #include "MoochoPack_NLPAlgoConfig.hpp"
46 #include "MoochoPack_NLPAlgo.hpp"
47 #include "MoochoPack_DecompositionSystemStateStepBuilderStd.hpp"
48 #include "OptionsFromStreamPack_OptionsFromStream.hpp"
49 
50 namespace MoochoPack {
51 
70 public:
71 
74 
77 
80 
91  void set_options( const options_ptr_t& options );
93  const options_ptr_t& get_options() const;
95  void config_algo_cntr(NLPAlgoContainer* algo_cntr, std::ostream* trase_out);
97  void init_algo(NLPAlgoInterface* algo);
98 
100 
101 public:
102 
105 
108  QN_AUTO, QN_BFGS, QN_PBFGS, QN_LBFGS, QN_LPBFGS };
111  INIT_HESS_AUTO, INIT_HESS_SERIALIZE, INIT_HESS_IDENTITY, INIT_HESS_FIN_DIFF_SCALE_IDENTITY
112  , INIT_HESS_FIN_DIFF_SCALE_DIAGONAL, INIT_HESS_FIN_DIFF_SCALE_DIAGONAL_ABS };
115  QP_AUTO, QP_QPSOL, QP_QPOPT, QP_QPKWIK, QP_QPSCHUR };
118  LINE_SEARCH_AUTO, LINE_SEARCH_NONE, LINE_SEARCH_DIRECT
119  , LINE_SEARCH_2ND_ORDER_CORRECT, LINE_SEARCH_WATCHDOG
120  , LINE_SEARCH_FILTER };
123  MERIT_FUNC_AUTO, MERIT_FUNC_L1, MERIT_FUNC_MOD_L1
124  , MERIT_FUNC_MOD_L1_INCR };
127  L1_PENALTY_PARAM_AUTO, L1_PENALTY_PARAM_WITH_MULT
128  , L1_PENALTY_PARAM_MULT_FREE };
129 
131 
134 
136  struct SOptionValues {
137  // Constructor (sets default values)
138  SOptionValues();
139  // Variable Reduction, Range/Null space decompositions
140  value_type max_basis_cond_change_frac_; // If < , don't change default
141  // Reduced Hessian Approximations
142  bool exact_reduced_hessian_;
143  EQuasiNewton quasi_newton_;
144  int num_lbfgs_updates_stored_; // If < 0, don't change default
145  bool lbfgs_auto_scaling_;
146  EHessianInitialization hessian_initialization_;
147  // QP subproblem solvers
148  EQPSolverType qp_solver_type_;
149  bool reinit_hessian_on_qp_fail_;
150  // Line search methods
151  ELineSearchMethod line_search_method_;
152  EMeritFunctionType merit_function_type_;
153  EL1PenaltyParamUpdate l1_penalty_param_update_;
154  int full_steps_after_k_; // If < 0, do not use this option at all.
155  value_type max_pz_norm_;
156  int num_pz_damp_iters_;
157  };
158 
160 
161 private:
162 
164  DecompositionSystemStateStepBuilderStd decomp_sys_step_builder_;
165 
167  options_ptr_t options_;
168 
170  SOptionValues uov_; // options set by user
171  SOptionValues cov_; // current option values actually used
172 
173  // ///////////////////////////////////////////////////////
174  // Private member functions
175 
177  static void readin_options(
179  , SOptionValues *option_values, std::ostream* trase_out );
180 
182  static void set_default_options(
183  const SOptionValues& user_option_values
184  , SOptionValues *current_option_values
185  , std::ostream* trase_out );
186 
187 }; // end class NLPAlgoConfigMamaJama
188 
198 } // end namespace MoochoPack
199 
200 #endif // RSQP_ALGO_CONFIG_MAMA_JAMA_H
Standard builder object for creating DecompositionSystem, EvalNewPoint Step and other objects and set...
Interface NLPAlgoContainer uses to access NLPAlgo.
This is a do all configuration class for NLPAlgo.
Implementation for NLPAlgo solver.
Interface for objects responsible for configuring an rSQP algorithm.
void config_algo_cntr(NLPAlgoContainer *algo_cntr, std::ostream *trase_out)
void set_options(const options_ptr_t &options)
Set the OptionsFromStream object that will be used for specifying the options.