98#include "AMReX_ParmParse.H"
101#define pp_query_required(...) pp.query_required(__VA_ARGS__)
102#define pp_query_default(...) pp.query_default(__VA_ARGS__)
103#define pp_query_validate(...) pp.query_validate(__VA_ARGS__)
104#define pp_query_file(...) pp.query_file(__VA_ARGS__)
105#define pp_queryarr(...) pp.queryarr(__VA_ARGS__)
106#define pp_queryarr_required(...) pp.queryarr_required(__VA_ARGS__)
107#define pp_queryarr_default(...) pp.queryarr_default(__VA_ARGS__)
108#define pp_query(...) pp.query(__VA_ARGS__)
109#define pp_queryclass(...) pp.queryclass(__VA_ARGS__)
110#define pp_forbid(...) pp.forbid(__VA_ARGS__)
122 std::string inputfile =
"";
123 while (this->querykth(
"input",k,inputfile))
126 this->addfile(inputfile);
139 (void)amrex::ParmParse::contains(name.c_str());
144 if (m_prefix.length())
145 m_prefix = m_prefix +
"." +
prefix;
152 size_t pos = m_prefix.rfind(
'.');
153 if (pos == std::string::npos)
156 m_prefix = m_prefix.substr(0, pos);
160 void forbid(std::string name, std::string explanation)
162 if (amrex::ParmParse::contains(
full(name).c_str()))
166 std::set<std::string> subs = amrex::ParmParse::getEntries(
full(name));
175 if (amrex::ParmParse::contains(name.c_str()))
177 if (amrex::ParmParse::contains(
full(name).c_str()))
180 std::set<std::string> subs = amrex::ParmParse::getEntries(name.c_str());
185 std::set<std::string> subs = amrex::ParmParse::getEntries(
full(name).c_str());
196 std::string strvalue;
197 int retval = amrex::ParmParse::query(name.c_str(),strvalue);
202 catch (std::runtime_error & e)
241 catch (std::runtime_error &e)
257 return query(name.c_str(),value);
259 catch (std::runtime_error & e)
279 return queryunit(name.c_str(), value, type);
281 catch (std::runtime_error & e)
299 add(name.c_str(),defaultvalue);
301 return query(name.c_str(),value);
303 catch (std::runtime_error & e)
321 add(name.c_str(),defaultvalue);
323 return queryunit(name.c_str(),value,type);
325 catch (std::runtime_error & e)
336 int query_validate( std::string name,
int & value, std::vector<int> possibleintvals)
345 add(name.c_str(), possibleintvals[0]);
349 int retval = query(name.c_str(),value);
353 for (
unsigned int i = 0; i < possibleintvals.size(); i++)
355 if (value == possibleintvals[i]) ok =
true;
358 if (ok)
return retval;
360 std::stringstream ss;
361 ss << possibleintvals[0];
362 for (
unsigned int i = 1; i < possibleintvals.size(); i++)
363 ss <<
"," << possibleintvals[i];
367 catch (std::runtime_error & e)
379 int query_validate( std::string name, std::string & value, std::vector<const char *> possiblecharvals,
bool firstbydefault)
386 if (!amrex::ParmParse::contains(name.c_str()))
393 if (!amrex::ParmParse::contains(name.c_str()))
395 add(name.c_str(), std::string(possiblecharvals[0]));
399 int retval = amrex::ParmParse::query(name.c_str(),value);
403 for (
unsigned int i = 0; i < possiblecharvals.size(); i++)
405 if (value == std::string(possiblecharvals[i])) ok =
true;
408 if (ok)
return retval;
410 std::stringstream ss;
411 ss << possiblecharvals[0];
412 for (
unsigned int i = 1; i < possiblecharvals.size(); i++)
413 ss <<
"," << possiblecharvals[i];
417 catch (std::runtime_error & e)
429 int query_validate( std::string name, std::string & value, std::vector<const char *> possiblecharvals)
435 catch (std::runtime_error & e)
448 int query_default( std::string name, std::string & value,
const char *defaultvalue)
452 return query_default(name, value, std::string(defaultvalue));
454 catch (std::runtime_error & e)
470 if (defaultvalue) defaultint = 1;
473 catch (std::runtime_error & e)
486 int query_file( std::string name, std::string & value,
bool copyfile,
bool checkfile)
495 int retval = query(name.c_str(),value);
497 if (amrex::ParallelDescriptor::IOProcessor())
499 if ( checkfile && ! std::filesystem::exists(value))
503 if ( checkfile && !std::filesystem::is_regular_file(value))
514 catch (std::runtime_error & e)
524 int query_file( std::string name, std::string & value,
bool copyfile)
535 int queryarr( std::string name, std::vector<T> & value)
539 return amrex::ParmParse::queryarr(name.c_str(),value);
553 return amrex::ParmParse::queryarr(name.c_str(),value);
558 std::vector<std::string> valstrings;
559 int retval = amrex::ParmParse::queryarr(name.c_str(), valstrings);
560 for (
unsigned int i = 0; i < valstrings.size(); i++)
574 catch (std::runtime_error &e)
588 std::vector<Set::Scalar> vals;
590 if (vals.size() < AMREX_SPACEDIM)
593 " requires at least ", AMREX_SPACEDIM,
594 " arguments, got ",vals.size());
596 for (
int i = 0; i < AMREX_SPACEDIM; i++) value(i) = vals[i];
607 std::vector<Set::Scalar> vals;
609 if (vals.size() == 9)
612 Util::Warning(
INFO,
"Reading a 3D matrix (",
full(name),
")into a 2D code - some values will be ignored.");
613 value(0,0) = vals[0]; value(0,1)= vals[1];
614 value(1,0) = vals[3]; value(1,1)= vals[4];
617 value(0,0) = vals[0]; value(0,1)= vals[1]; value(0,2)= vals[2];
618 value(1,0) = vals[3]; value(1,1)= vals[4]; value(1,2)= vals[5];
619 value(2,0) = vals[6]; value(2,1)= vals[7]; value(2,2)= vals[8];
622 else if (vals.size() == 4)
625 value(0,0) = vals[0]; value(0,1)= vals[1];
626 value(1,0) = vals[2]; value(1,1)= vals[3];
629 Util::Warning(
INFO,
"Reading a 2D matrix (",
full(name),
")into a 3D code - remaining values will be set to zero.");
630 value(0,0) = vals[0]; value(0,1)= vals[1]; value(0,2)= 0.0;
631 value(1,0) = vals[2]; value(1,1)= vals[3]; value(1,2)= 0.0;
632 value(2,0) = 0.0; value(2,1)= 0.0; value(2,2)= 0.0;
649 return queryarr<T>(name,value);
660 int queryarr_default( std::string name, std::vector<std::string> & value, std::vector<std::string> defaultvalue)
664 addarr(name.c_str(),defaultvalue);
666 return amrex::ParmParse::queryarr(name.c_str(),value);
677 return queryarr(name.c_str(),value,unit);
679 catch (std::runtime_error &e)
696 value = defaultvalue;
699 return queryarr(name.c_str(),value);
715 value = defaultvalue;
718 return queryarr(name.c_str(),value);
727 int queryarr_default( std::string name, std::vector<double> & value, std::vector<double> defaultvalue)
733 addarr(name.c_str(),defaultvalue);
735 return queryarr(name.c_str(),value);
744 int queryarr_default( std::string name, std::vector<double> & value, std::vector<std::string> defaultvalue,
Unit unit)
750 addarr(name.c_str(),defaultvalue);
762 template <
typename T>
772 std::string name = a_name;
775 for (
int n = 0; n < number; n++)
778 this->queryclass<T>(name, tmp);
779 value.push_back(tmp);
792 std::string name0 = a_name + std::to_string(0);
793 std::string name1 = a_name + std::to_string(1);
799 else if (this->
contains(name1.c_str()))
813 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
818 this->queryclass<T>(name, tmp);
819 value.push_back(tmp);
821 name = a_name + std::to_string(cntr+1);
828 template <
typename T>
838 std::string name = a_name;
841 for (
int n = 0; n < number; n++)
845 value.push_back(tmp);
858 std::string name0 = a_name + std::to_string(0);
859 std::string name1 = a_name + std::to_string(1);
865 else if (this->
contains(name1.c_str()))
879 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
885 value.push_back(tmp);
887 name = a_name + std::to_string(cntr+1);
898 for (
auto li = m_table->begin(), End = m_table->end(); li != End; ++li)
900 if (!li->second.m_count)
904 if (li->first.rfind(
getPrefix()+
".",0) != std::string::npos)
922 std::vector<std::string> ret;
923 for (
auto li = m_table->begin(), End = m_table->end(); li != End; ++li)
925 if (!li->second.m_count && li->first.rfind(
getPrefix()+
".",0) != std::string::npos)
927 ret.push_back(li->first);
937 for (
auto li = pp.m_table->begin(), End = pp.m_table->end(); li != End; ++li)
939 if (!li->second.m_count)
951 std::string
full (std::string name)
962 auto old_prefix = m_prefix;
965 if (old_prefix.empty()) m_prefix = name;
966 else m_prefix.append(
".").append(name);
967 T::Parse(*value, *
this);
969 if (unused_inputs.size())
971 std::stringstream ss;
972 for (
unsigned int i=0; i < unused_inputs.size(); i++)
973 ss <<
"\n\t" << unused_inputs[i];
979 m_prefix = old_prefix;
982 m_prefix = old_prefix;
987 auto old_prefix = m_prefix;
990 if (old_prefix.empty()) m_prefix = name;
991 else m_prefix.append(
".").append(name);
992 T::Parse(value, *
this);
994 if (unused_inputs.size())
996 std::stringstream ss;
997 for (
unsigned int i=0; i < unused_inputs.size(); i++)
998 ss <<
"\n\t" << unused_inputs[i];
1002 catch (std::runtime_error &e)
1008 m_prefix = old_prefix;
1011 m_prefix = old_prefix;
1019 T::Parse(*value, *
this);
1021 catch (std::runtime_error &e)
1035 T::Parse(value, *
this);
1037 catch (std::runtime_error &e)
1055 template<
typename...
IC,
typename... Args,
typename PTRTYPE>
1056 void select (std::string name, PTRTYPE *& ic_eta, Args&&... args)
1062 if constexpr (
sizeof...(IC) == 0)
1064 using first_IC = std::tuple_element_t<0, std::tuple<
IC...>>;
1065 ic_eta =
new first_IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(first_IC::name));
1070 std::string type =
"";
1072 bool matched = (( type == IC::name
1073 ? (ic_eta =
new IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(IC::name))),
1080 catch (std::runtime_error &e)
1094 template<
typename FirstIC,
typename...
IC,
typename... Args,
typename PTRTYPE>
1097 std::string type =
"";
1102 (( type == FirstIC::name
1103 ? (ic_eta =
new FirstIC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(FirstIC::name))),
1107 ? (ic_eta =
new IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(IC::name))),
1108 true :
false) || ...);
1118 template<
typename...
IC,
typename... Args,
typename PTRTYPE>
1128 std::string name = a_name;
1132 this->
select<
IC...>(a_name, tmp, args...);
1133 value.push_back(tmp);
1145 std::string name0 = a_name + std::to_string(0);
1146 std::string name1 = a_name + std::to_string(1);
1152 else if (this->
contains(name1.c_str()))
1166 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
1171 this->
select<
IC...>(name, tmp, args...);
1172 value.push_back(tmp);
1174 name = a_name + std::to_string(cntr+1);
1183 template<
typename... INTEGRATOR,
typename... Args,
typename PTRTYPE>
1186 std::string type =
"";
1190 bool matched = ((type == INTEGRATOR::name
1191 ? (ic_eta =
new INTEGRATOR(std::forward<Args>(args)..., (*
this))),
1204 template<
typename INTEGRATOR,
typename Args,
typename PTRTYPE>
1207 ic_eta =
new INTEGRATOR(std::forward<Args>(args), (*
this));
1210 template<
typename INTEGRATOR,
typename PTRTYPE>
1213 ic_eta =
new INTEGRATOR((*
this));
1222 template <
typename... OBJ,
typename CLASS>
1241 template <
typename CLASS,
int N,
typename... OBJ>
1244 if constexpr (N == 0)
1249 for (
unsigned int i = 0; i <
sizeof...(OBJ); i++)
1250 if (type == value.names[i])
1253 if (value.selected < 0)
1256 ", invalid type " + type);
1262 if constexpr (N <
sizeof...(OBJ))
1264 if (value.selected == N)
1266 std::get<N>(value.obj).Parse(std::get<N>(value.obj), *
this);
1279 void query_exactly( std::vector<std::string> names, std::pair<std::string, Set::Scalar> values[N],
1280 std::vector<Unit> units = std::vector<Unit>())
1285 "# of units must be 0, 1, or ", names.size(),
" but got ", units.size());
1288 std::vector<std::string> read;
1289 for (
unsigned int n = 0; n < names.size(); n++)
1291 if (amrex::ParmParse::contains(names[n].c_str()))
1293 read.push_back(names[n]);
1298 " Incorrect number of values specified: only ", N,
1299 " values are allowed, but received ",
1304 for (
unsigned int n = 0; n < names.size(); n++)
1306 if (amrex::ParmParse::contains(names[n].c_str()))
1308 values[cnt].first = names[n];
1310 if (units.size() == 0)
1312 else if (units.size() == 1)
1322 std::string names_str =
"[";
1323 for (
unsigned int i = 0; i < names.size(); i++)
1325 names_str +=
full(names[i]);
1326 if (i < names.size()-1) names_str +=
", ";
int queryarr_default(std::string name, std::vector< double > &value, std::vector< std::string > defaultvalue, Unit unit)
bool contains(std::string name)
int queryunit(std::string name, Unit &value)
int queryarr_default(std::string name, std::vector< std::string > &value, std::vector< std::string > defaultvalue)
int queryarr_required(std::string name, std::vector< Set::Scalar > &value, Unit unit=Unit::Less())
int queryarr(std::string name, std::vector< T > &value)
void forbid(std::string name, std::string explanation)
void select(std::string name, CLASS &value)
int query_enumerate(std::string a_name, std::vector< T > &value, int number=1)
int queryarr(std::string name, std::vector< Set::Scalar > &value, Unit unit=Unit::Less())
void pushPrefix(const std::string prefix)
int query_validate(std::string name, std::string &value, std::vector< const char * > possiblecharvals, bool firstbydefault)
int query_file(std::string name, std::string &value)
int queryarr(std::string name, Set::Vector &value, Unit unit=Unit::Less())
int queryarr_default(std::string name, Set::Vector &value, std::string defaultvalue, Unit unit)
int query_file(std::string name, std::string &value, bool copyfile, bool checkfile)
int AnyUnusedInputs(bool inscopeonly=true, bool verbose=false)
int queryarr(std::string name, Set::Matrix &value, Unit unit=Unit::Less())
std::vector< std::string > GetUnusedInputs()
void queryclass(std::string name, T &value)
std::string getPrefix() const
static bool checked_for_input_files
void select(std::string name, PTRTYPE *&ic_eta, Args &&... args)
void queryclass(std::string name, T *value)
int queryclass_enumerate(std::string a_name, std::vector< T > &value, int number=1)
int query_required(std::string name, T &value)
int queryarr_default(std::string name, Set::Matrix &value, Set::Matrix defaultvalue)
int query_default(std::string name, T &value, std::string defaultvalue, const Unit type)
void select_default(std::string name, PTRTYPE *&ic_eta, Args &&... args)
int queryarr_default(std::string name, Set::Vector &value, Set::Vector defaultvalue)
int queryunit(std::string name, Unit &value, const Unit type)
int query_default(std::string name, int &value, bool defaultvalue)
int query_file(std::string name, std::string &value, bool copyfile)
void select_enumerate(std::string a_name, std::vector< PTRTYPE * > &value, Args &&... args)
void queryclass(T &value)
static int AllUnusedInputs()
int query_validate(std::string name, std::string &value, std::vector< const char * > possiblecharvals)
void queryclass(T *value)
int queryarr_required(std::string name, std::vector< T > &value)
int query_required(std::string name, T &value, const Unit type)
void static_polymorphism_parser(CLASS &value)
void select_only(PTRTYPE *&ic_eta, Args &&args)
void select_main(PTRTYPE *&ic_eta, Args &&... args)
int queryunit(std::string name, Set::Scalar &value, const Unit type)
int query_default(std::string name, T &value, T defaultvalue)
void select_only(PTRTYPE *&ic_eta)
void ignore(std::string name)
std::string full(std::string name)
int query_validate(std::string name, int &value, std::vector< int > possibleintvals)
int queryarr_default(std::string name, std::vector< double > &value, std::vector< double > defaultvalue)
void query_exactly(std::vector< std::string > names, std::pair< std::string, Set::Scalar > values[N], std::vector< Unit > units=std::vector< Unit >())
int query_default(std::string name, std::string &value, const char *defaultvalue)
ParmParse(std::string arg)
Initialize a spherical inclusion.
Eigen::Matrix< amrex::Real, AMREX_SPACEDIM, 1 > Vector
Eigen::Matrix< amrex::Real, AMREX_SPACEDIM, AMREX_SPACEDIM > Matrix
AMREX_FORCE_INLINE std::string Join(const std::vector< std::string > &vec, std::string separator="_")
AMREX_FORCE_INLINE std::vector< std::string > Split(std::string &str, const char delim=' ')
void DebugMessage(std::string, std::string, int, Args const &...)
AMREX_FORCE_INLINE void AssertException(std::string file, std::string func, int line, std::string smt, bool pass, Args const &... args)
void Abort(const char *msg)
void CopyFileToOutputDir(std::string a_path, bool fullpath, std::string prefix)
void Warning(std::string file, std::string func, int line, Args const &... args)
void Message(std::string file, std::string func, int line, Args const &... args)
void ParmParseException(std::string file, std::string func, int line, std::string fullname, Args const &... args)
void Exception(std::string file, std::string func, int line, Args const &... args)
bool isType(const Unit &test) const
std::string normalized_unitstring() const
static Unit Parse(double val, std::string unitstring, bool verbose=false)
double normalized_value() const