9 #ifndef Tempus_TimeStepControlStrategyComposite_hpp 10 #define Tempus_TimeStepControlStrategyComposite_hpp 12 #include "Tempus_config.hpp" 17 #include "Tempus_SolutionHistory.hpp" 41 template<
class Scalar>
61 Status & integratorStatus)
override 64 s->setNextTimeStep(tsc, sh, integratorStatus);
70 {
return "Tempus::TimeStepControlComposite"; }
73 const Teuchos::EVerbosityLevel verbLevel)
const override 75 auto l_out = Teuchos::fancyOStream( out.getOStream() );
76 Teuchos::OSTab ostab(*l_out, 2, this->
description());
77 l_out->setOutputToRootOnly(0);
79 *l_out <<
"\n--- " << this->
description() <<
" ---" << std::endl;
81 if (Teuchos::as<int>(verbLevel) >= Teuchos::as<int>(Teuchos::VERB_MEDIUM)) {
83 <<
" Step Type = " << this->
getStepType()<< std::endl;
85 std::stringstream sList;
86 for(std::size_t i = 0; i <
strategies_.size(); ++i) {
90 *l_out <<
" Strategy List = " << sList.str() << std::endl;
93 s->describe(*l_out, verbLevel);
95 *l_out << std::string(this->
description().length()+8,
'-') <<std::endl;
104 if (Teuchos::nonnull(strategy)) {
107 TEUCHOS_TEST_FOR_EXCEPTION(this->
getStepType() != strategy->getStepType(),
109 "Error - Cannot mix 'Constant' and 'Variable' step types.\n" 110 "strategies in composite! Need at least one.\n");
120 virtual std::vector<Teuchos::RCP<TimeStepControlStrategy<Scalar>>>
128 TEUCHOS_TEST_FOR_EXCEPTION(
strategies_.size() == 0, std::logic_error,
129 "Error - No strategies in composite! Need at least one.\n");
136 TEUCHOS_TEST_FOR_EXCEPTION(s->isInitialized() ==
false, std::logic_error,
137 "Error - Composite strategy, "<< s->getName() <<
" is not initialized!\n");
139 if (strategy0->getStepType() != s->getStepType()) {
140 std::ostringstream msg;
141 msg <<
"Error - All the Strategy Step Types must match.\n";
142 for(std::size_t i = 0; i <
strategies_.size(); ++i) {
143 msg <<
" Strategy[" << i <<
"] = " 147 TEUCHOS_TEST_FOR_EXCEPTION(
true, std::logic_error, msg.str());
157 Teuchos::RCP<Teuchos::ParameterList> pl =
158 Teuchos::parameterList(
"Time Step Control Strategy");
160 pl->set<std::string>(
"Strategy Type", this->
getStrategyType(),
"Composite");
162 std::stringstream sList;
163 for(std::size_t i = 0; i <
strategies_.size(); ++i) {
167 pl->set<std::string>(
"Strategy List", sList.str());
170 pl->set(s->getName(), *s->getValidParameters());
177 std::vector<Teuchos::RCP<TimeStepControlStrategy<Scalar > > >
strategies_;
184 template <
class Scalar>
185 Teuchos::RCP<TimeStepControlStrategyComposite<Scalar> >
187 Teuchos::RCP<Teuchos::ParameterList>
const& pList,
188 std::string name =
"Composite")
191 using Teuchos::ParameterList;
193 std::vector<std::string> tscsList;
195 TEUCHOS_TEST_FOR_EXCEPTION(
196 pList->get<std::string>(
"Strategy Type",
"Composite") !=
197 "Composite", std::logic_error,
198 "Error - Strategy Type != 'Composite'. (='" 199 +pList->get<std::string>(
"Strategy Type")+
"')\n");
203 std::string str = pList->get<std::string>(
"Strategy List");
204 std::string delimiters(
",");
205 const char* WhiteSpace =
" \t\v\r\n";
207 std::string::size_type lastPos = str.find_first_not_of(delimiters, 0);
209 std::string::size_type pos = str.find_first_of(delimiters, lastPos);
210 while ((pos != std::string::npos) || (lastPos != std::string::npos)) {
212 std::string token = str.substr(lastPos,pos-lastPos);
214 std::size_t start = token.find_first_not_of(WhiteSpace);
215 std::size_t end = token.find_last_not_of(WhiteSpace);
216 token = (start == end ? std::string() : token.substr(start, end-start+1));
218 tscsList.push_back(token);
219 if(pos==std::string::npos)
break;
221 lastPos = str.find_first_not_of(delimiters, pos);
222 pos = str.find_first_of(delimiters, lastPos);
228 for (
auto tscsName: tscsList) {
229 RCP<ParameterList> pl =
230 Teuchos::rcp(
new ParameterList(pList->sublist(tscsName)));
232 auto strategyType = pl->get<std::string>(
"Strategy Type",
"Unknown");
233 if (strategyType ==
"Constant") {
235 createTimeStepControlStrategyConstant<Scalar>(pl, tscsName));
236 }
else if (strategyType ==
"Basic VS") {
238 createTimeStepControlStrategyBasicVS<Scalar>(pl, tscsName));
239 }
else if (strategyType ==
"Integral Controller") {
241 createTimeStepControlStrategyIntegralController<Scalar>(pl, tscsName));
242 }
else if (strategyType ==
"Composite") {
244 createTimeStepControlStrategyComposite<Scalar>(pl, tscsName));
246 RCP<Teuchos::FancyOStream> out =
247 Teuchos::fancyOStream(Teuchos::rcpFromRef(std::cout));
248 out->setOutputToRootOnly(0);
249 Teuchos::OSTab ostab(out,1,
"createTimeStepControlStrategyComposite()");
250 *out <<
"Warning -- Unknown strategy type!\n" 251 <<
"'Strategy Type' = '" << strategyType <<
"'\n" 252 <<
"Should call addStrategy() with this\n" 253 <<
"(app-specific?) strategy, and initialize().\n" << std::endl;
258 tscsc->setName(name);
260 if (tscsc->size() == 0) {
261 RCP<Teuchos::FancyOStream> out =
262 Teuchos::fancyOStream(Teuchos::rcpFromRef(std::cout));
263 out->setOutputToRootOnly(0);
264 Teuchos::OSTab ostab(out,1,
"createTimeStepControlStrategyComposite()");
265 *out <<
"Warning -- Did not find a Tempus strategy to create!\n" 266 <<
"Should call addStrategy() with (app-specific?) strategy(ies),\n" 267 <<
"and initialize().\n" << std::endl;
278 template<
class Scalar>
283 t->addStrategy(tscs);
284 return Teuchos::rcp_const_cast<Teuchos::ParameterList> (t->getValidParameters());
289 #endif // Tempus_TimeStepControlStrategy_hpp virtual std::string getStrategyType() const
virtual Teuchos::RCP< const Teuchos::ParameterList > getValidParameters() const override
Return ParameterList with current values.
virtual int size() const
Size of composite list.
virtual std::vector< Teuchos::RCP< TimeStepControlStrategy< Scalar > > > getStrategies() const
Return composite list.
std::vector< Teuchos::RCP< TimeStepControlStrategy< Scalar > > > strategies_
void clearStrategies()
Clear the composite list.
void describe(Teuchos::FancyOStream &out, const Teuchos::EVerbosityLevel verbLevel) const override
Teuchos::RCP< TimeStepControlStrategyComposite< Scalar > > createTimeStepControlStrategyComposite(Teuchos::RCP< Teuchos::ParameterList > const &pList, std::string name="Composite")
std::string description() const override
Status
Status for the Integrator, the Stepper and the SolutionState.
virtual void setStepType(std::string s)
bool isInitialized_
Bool if strategy is initialized.
TimeStepControl manages the time step size. There several mechanisms that effect the time step size a...
SolutionHistory is basically a container of SolutionStates. SolutionHistory maintains a collection of...
virtual void setNextTimeStep(const TimeStepControl< Scalar > &tsc, Teuchos::RCP< SolutionHistory< Scalar > > sh, Status &integratorStatus) override
Determine the time step size.
StepControlStrategy class for TimeStepControl.
virtual ~TimeStepControlStrategyComposite()
Destructor.
TimeStepControlStrategyComposite loops over a vector of TimeStepControlStrategies.
virtual void initialize() const override
void addStrategy(const Teuchos::RCP< TimeStepControlStrategy< Scalar > > &strategy)
Append strategy to the composite list.
TimeStepControlStrategyComposite()
Constructor.
virtual void setStrategyType(std::string s)
virtual std::string getStepType() const
TimeStepControlStrategy class for TimeStepControl.
Teuchos::RCP< Teuchos::ParameterList > getTimeStepControlStrategyCompositePL()
Nonmember function to return ParameterList with default values.