21int main(
int argc,
char *argv[]) {
26 typedef std::vector<RealT> vec;
29 ROL::GlobalMPISession mpiSession(&argc, &argv);
31 int iprint = argc - 1;
32 ROL::Ptr<std::ostream> outStream;
35 outStream = ROL::makePtrFromRef(std::cout);
37 outStream = ROL::makePtrFromRef(bhs);
46 ROL::Ptr<vec> xopt_ptr = ROL::makePtr<vec>(xopt_dim,1.0);
48 ROL::Ptr<vec> li_ptr = ROL::makePtr<vec>(ci_dim,0.0);
50 ROL::PtrV xopt = ROL::makePtr<SV>(xopt_ptr);
51 ROL::PtrV li = ROL::makePtr<SV>(li_ptr);
57 auto obj_hs29 = ROL::makePtr<Objective_HS29<RealT>>();
58 auto incon_hs29 = ROL::makePtr<InequalityConstraint_HS29<RealT>>();
61 std::string stepname =
"Interior Point";
67 parlist->sublist(
"General").set(
"Print Verbosity",1);
69 parlist->sublist(
"Step").sublist(
"Interior Point").set(
"Initial Barrier Penalty",mu);
70 parlist->sublist(
"Step").sublist(
"Interior Point").set(
"Minimium Barrier Penalty",1e-8);
71 parlist->sublist(
"Step").sublist(
"Interior Point").set(
"Barrier Penalty Reduction Factor",factor);
72 parlist->sublist(
"Step").sublist(
"Interior Point").set(
"Subproblem Iteration Limit",30);
74 parlist->sublist(
"Step").sublist(
"Composite Step").sublist(
"Optimality System Solver").set(
"Nominal Relative Tolerance",1.e-4);
75 parlist->sublist(
"Step").sublist(
"Composite Step").sublist(
"Optimality System Solver").set(
"Fix Tolerance",
true);
76 parlist->sublist(
"Step").sublist(
"Composite Step").sublist(
"Tangential Subproblem Solver").set(
"Iteration Limit",20);
77 parlist->sublist(
"Step").sublist(
"Composite Step").sublist(
"Tangential Subproblem Solver").set(
"Relative Tolerance",1e-2);
78 parlist->sublist(
"Step").sublist(
"Composite Step").set(
"Output Level",0);
80 parlist->sublist(
"Status Test").set(
"Gradient Tolerance",1.e-12);
81 parlist->sublist(
"Status Test").set(
"Constraint Tolerance",1.e-8);
82 parlist->sublist(
"Status Test").set(
"Step Tolerance",1.e-8);
83 parlist->sublist(
"Status Test").set(
"Iteration Limit",100);
88 ROL::Ptr<ROL::Algorithm<RealT> > algo;
89 algo = ROL::makePtr<ROL::Algorithm<RealT>>(stepname,*parlist);
91 algo->run(problem,
true,*outStream);
95 *outStream << std::endl << std::setw(20) <<
"Computed Minimizer" << std::endl;
96 for(
int i=0;i<xopt_dim;++i ) {
97 *outStream << std::setw(20) << (*xopt_ptr)[i] << std::endl;
100 *outStream <<
"Exact minimizers: x* = (a,b,c), (a,-b,-c), (-a,b,-c), (-a,-b,c)" << std::endl;
101 *outStream <<
"Where a=4, b=" << 2*std::sqrt(2) <<
", and c=2" << std::endl;
104 catch (std::logic_error& err) {
105 *outStream << err.what() <<
"\n";
110 std::cout <<
"End Result: TEST FAILED\n";
112 std::cout <<
"End Result: TEST PASSED\n";