44#ifndef ROL_TYPEB_ALGORITHMFACTORY_H
45#define ROL_TYPEB_ALGORITHMFACTORY_H
85 std::string retString;
94 default: retString =
"INVALID EAlgorithmB";
145template<
typename Real>
152 = parlist.sublist(
"Step").sublist(
"Line Search").sublist(
"Descent Method").get(
"Type",
"Newton-Krylov");
153 if (desc==
"Newton-Krylov" || desc==
"Newton")
154 return makePtr<NewtonKrylovAlgorithm<Real>>(parlist);
155 else if (desc==
"Quasi-Newton Method") {
157 = parlist.sublist(
"Step").sublist(
"Line Search").sublist(
"Quasi-Newton").get(
"Method",
"L-Secant-B");
158 if (method ==
"L-Secant-B")
159 return makePtr<LSecantBAlgorithm<Real>>(parlist);
161 return makePtr<QuasiNewtonAlgorithm<Real>>(parlist);
164 return makePtr<GradientAlgorithm<Real>>(parlist);
170 = parlist.sublist(
"Step").sublist(
"Trust Region").get(
"Subproblem Model",
"Lin-More");
171 if (trmod==
"Kelley-Sachs")
172 return makePtr<KelleySachsAlgorithm<Real>>(parlist);
173 else if (trmod==
"SPG")
174 return makePtr<TrustRegionSPGAlgorithm<Real>>(parlist);
175 else if (trmod==
"Coleman-Li")
176 return makePtr<ColemanLiAlgorithm<Real>>(parlist);
178 return makePtr<LinMoreAlgorithm<Real>>(parlist);
184 default:
return nullPtr;
Contains definitions of custom data types in ROL.
EAlgorithmB StringToEAlgorithmB(std::string s)
EAlgorithmB & operator--(EAlgorithmB &type)
Ptr< Algorithm< Real > > AlgorithmFactory(ParameterList &parlist)
EAlgorithmB & operator++(EAlgorithmB &type)
std::string EAlgorithmBToString(EAlgorithmB alg)
@ ALGORITHM_B_PRIMALDUALACTIVESET
@ ALGORITHM_B_MOREAUYOSIDA
@ ALGORITHM_B_SPECTRALGRADIENT
@ ALGORITHM_B_INTERIORPOINT
@ ALGORITHM_B_TRUSTREGION
int isValidAlgorithmB(EAlgorithmB alg)
Verifies validity of a AlgorithmB enum.
std::string removeStringFormat(std::string s)