|
MoochoPack : Framework for Large-Scale Optimization Algorithms
Version of the Day
|
00001 #if 0 00002 00003 // @HEADER 00004 // *********************************************************************** 00005 // 00006 // Moocho: Multi-functional Object-Oriented arCHitecture for Optimization 00007 // Copyright (2003) Sandia Corporation 00008 // 00009 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive 00010 // license for use of this work by or on behalf of the U.S. Government. 00011 // 00012 // Redistribution and use in source and binary forms, with or without 00013 // modification, are permitted provided that the following conditions are 00014 // met: 00015 // 00016 // 1. Redistributions of source code must retain the above copyright 00017 // notice, this list of conditions and the following disclaimer. 00018 // 00019 // 2. Redistributions in binary form must reproduce the above copyright 00020 // notice, this list of conditions and the following disclaimer in the 00021 // documentation and/or other materials provided with the distribution. 00022 // 00023 // 3. Neither the name of the Corporation nor the names of the 00024 // contributors may be used to endorse or promote products derived from 00025 // this software without specific prior written permission. 00026 // 00027 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY 00028 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00029 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 00030 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE 00031 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00032 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00033 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00034 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00035 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00036 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00037 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00038 // 00039 // Questions? Contact Roscoe A. Bartlett (rabartl@sandia.gov) 00040 // 00041 // *********************************************************************** 00042 // @HEADER 00043 00044 #include <assert.h> 00045 #include <math.h> 00046 00047 #include "MoochoPack_LineSearch2ndOrderCorrect_StepSetOptions.hpp" 00048 #include "OptionsFromStreamPack_StringToBool.hpp" 00049 00050 // Define the options 00051 namespace { 00052 00053 const int local_num_options = 8; 00054 00055 enum local_EOptions { 00056 NEWTON_OLEVEL, 00057 CONSTR_NORM_THRESHOLD, 00058 CONSTR_INCR_RATIO, 00059 AFTER_K_ITER, 00060 FORCED_CONSTR_REDUCTION, 00061 FORCED_REDUCT_RATIO, 00062 MAX_STEP_RATIO, 00063 MAX_NEWTON_ITER 00064 }; 00065 00066 const char* local_SOptions[local_num_options] = { 00067 "newton_olevel", 00068 "constr_norm_threshold", 00069 "constr_incr_ratio", 00070 "after_k_iter", 00071 "forced_constr_reduction", 00072 "forced_reduct_ratio", 00073 "max_step_ratio", 00074 "max_newton_iter" 00075 }; 00076 00077 } 00078 00079 namespace MoochoPack { 00080 00081 LineSearch2ndOrderCorrect_StepSetOptions::LineSearch2ndOrderCorrect_StepSetOptions( 00082 LineSearch2ndOrderCorrect_Step* target 00083 , const char opt_grp_name[] ) 00084 : OptionsFromStreamPack::SetOptionsFromStreamNode( 00085 opt_grp_name, local_num_options, local_SOptions ) 00086 , OptionsFromStreamPack::SetOptionsToTargetBase< 00087 LineSearch2ndOrderCorrect_Step >( target ) 00088 {} 00089 00090 void LineSearch2ndOrderCorrect_StepSetOptions::setOption( 00091 int option_num, const std::string& option_value ) 00092 { 00093 typedef LineSearch2ndOrderCorrect_Step target_t; 00094 switch( (local_EOptions)option_num ) { 00095 case NEWTON_OLEVEL: 00096 { 00097 const std::string &option = option_value.c_str(); 00098 if( option == "PRINT_USE_DEFAULT" ) 00099 target().newton_olevel( target_t::PRINT_USE_DEFAULT ); 00100 else if( option == "PRINT_NOTHING" ) 00101 target().newton_olevel( target_t::PRINT_NEWTON_NOTHING ); 00102 else if( option == "PRINT_SUMMARY_INFO" ) 00103 target().newton_olevel( target_t::PRINT_NEWTON_SUMMARY_INFO ); 00104 else if( option == "PRINT_STEPS" ) 00105 target().newton_olevel( target_t::PRINT_NEWTON_STEPS ); 00106 else if( option == "PRINT_VECTORS" ) 00107 target().newton_olevel( target_t::PRINT_NEWTON_VECTORS ); 00108 else 00109 throw std::invalid_argument( "Error, incorrect value for " 00110 "\"newton_olevel\"." ); 00111 break; 00112 } 00113 case CONSTR_NORM_THRESHOLD: 00114 target().constr_norm_threshold(::fabs(::atof(option_value.c_str()))); 00115 break; 00116 case CONSTR_INCR_RATIO: 00117 target().constr_incr_ratio(::fabs(::atof(option_value.c_str()))); 00118 break; 00119 case AFTER_K_ITER: 00120 target().after_k_iter(::abs(::atoi(option_value.c_str()))); 00121 break; 00122 case FORCED_CONSTR_REDUCTION: 00123 { 00124 const std::string &option = option_value.c_str(); 00125 if( option == "LESS_X_D" ) 00126 target().forced_constr_reduction(target_t::CONSTR_LESS_X_D ); 00127 else if( option == "LESS_X" ) 00128 target().forced_constr_reduction( target_t::CONSTR_LESS_X ); 00129 else 00130 throw std::invalid_argument( "Error, incorrect value for " 00131 "\"forced_constr_reduction\"." ); 00132 break; 00133 } 00134 case FORCED_REDUCT_RATIO: 00135 target().forced_reduct_ratio(::fabs(::atof(option_value.c_str()))); 00136 break; 00137 case MAX_STEP_RATIO: 00138 target().max_step_ratio(::fabs(::atof(option_value.c_str()))); 00139 break; 00140 case MAX_NEWTON_ITER: 00141 target().max_newton_iter(::abs(::atoi(option_value.c_str()))); 00142 break; 00143 default: 00144 TEUCHOS_TEST_FOR_EXCEPT(true); // Local error only? 00145 } 00146 } 00147 00148 } // end namespace MoochoPack 00149 00150 #endif // 0
1.7.6.1