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);
676 value = defaultvalue;
679 return queryarr(name.c_str(),value);
695 value = defaultvalue;
698 return queryarr(name.c_str(),value);
707 int queryarr_default( std::string name, std::vector<double> & value, std::vector<double> defaultvalue)
713 addarr(name.c_str(),defaultvalue);
715 return queryarr(name.c_str(),value);
724 int queryarr_default( std::string name, std::vector<double> & value, std::vector<std::string> defaultvalue,
Unit unit)
730 addarr(name.c_str(),defaultvalue);
742 template <
typename T>
752 std::string name = a_name;
755 for (
int n = 0; n < number; n++)
758 this->queryclass<T>(name, tmp);
759 value.push_back(tmp);
772 std::string name0 = a_name + std::to_string(0);
773 std::string name1 = a_name + std::to_string(1);
779 else if (this->
contains(name1.c_str()))
793 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
798 this->queryclass<T>(name, tmp);
799 value.push_back(tmp);
801 name = a_name + std::to_string(cntr+1);
808 template <
typename T>
818 std::string name = a_name;
821 for (
int n = 0; n < number; n++)
825 value.push_back(tmp);
838 std::string name0 = a_name + std::to_string(0);
839 std::string name1 = a_name + std::to_string(1);
845 else if (this->
contains(name1.c_str()))
859 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
865 value.push_back(tmp);
867 name = a_name + std::to_string(cntr+1);
878 for (
auto li = m_table->begin(), End = m_table->end(); li != End; ++li)
880 if (!li->second.m_count)
884 if (li->first.rfind(
getPrefix()+
".",0) != std::string::npos)
902 std::vector<std::string> ret;
903 for (
auto li = m_table->begin(), End = m_table->end(); li != End; ++li)
905 if (!li->second.m_count && li->first.rfind(
getPrefix()+
".",0) != std::string::npos)
907 ret.push_back(li->first);
917 for (
auto li = pp.m_table->begin(), End = pp.m_table->end(); li != End; ++li)
919 if (!li->second.m_count)
931 std::string
full (std::string name)
942 auto old_prefix = m_prefix;
945 if (old_prefix.empty()) m_prefix = name;
946 else m_prefix.append(
".").append(name);
947 T::Parse(*value, *
this);
949 if (unused_inputs.size())
951 std::stringstream ss;
952 for (
unsigned int i=0; i < unused_inputs.size(); i++)
953 ss <<
"\n\t" << unused_inputs[i];
959 m_prefix = old_prefix;
962 m_prefix = old_prefix;
967 auto old_prefix = m_prefix;
970 if (old_prefix.empty()) m_prefix = name;
971 else m_prefix.append(
".").append(name);
972 T::Parse(value, *
this);
974 if (unused_inputs.size())
976 std::stringstream ss;
977 for (
unsigned int i=0; i < unused_inputs.size(); i++)
978 ss <<
"\n\t" << unused_inputs[i];
982 catch (std::runtime_error &e)
988 m_prefix = old_prefix;
991 m_prefix = old_prefix;
999 T::Parse(*value, *
this);
1001 catch (std::runtime_error &e)
1015 T::Parse(value, *
this);
1017 catch (std::runtime_error &e)
1035 template<
typename...
IC,
typename... Args,
typename PTRTYPE>
1036 void select (std::string name, PTRTYPE *& ic_eta, Args&&... args)
1042 if constexpr (
sizeof...(IC) == 0)
1044 using first_IC = std::tuple_element_t<0, std::tuple<
IC...>>;
1045 ic_eta =
new first_IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(first_IC::name));
1050 std::string type =
"";
1052 bool matched = (( type == IC::name
1053 ? (ic_eta =
new IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(IC::name))),
1060 catch (std::runtime_error &e)
1074 template<
typename FirstIC,
typename...
IC,
typename... Args,
typename PTRTYPE>
1077 std::string type =
"";
1082 (( type == FirstIC::name
1083 ? (ic_eta =
new FirstIC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(FirstIC::name))),
1087 ? (ic_eta =
new IC(std::forward<Args>(args)..., (*
this), name +
"." + std::string(IC::name))),
1088 true :
false) || ...);
1098 template<
typename...
IC,
typename... Args,
typename PTRTYPE>
1108 std::string name = a_name;
1112 this->
select<
IC...>(a_name, tmp, args...);
1113 value.push_back(tmp);
1125 std::string name0 = a_name + std::to_string(0);
1126 std::string name1 = a_name + std::to_string(1);
1132 else if (this->
contains(name1.c_str()))
1146 for (
int cntr = start; this->
contains(name.c_str()); cntr++)
1151 this->
select<
IC...>(name, tmp, args...);
1152 value.push_back(tmp);
1154 name = a_name + std::to_string(cntr+1);
1163 template<
typename... INTEGRATOR,
typename... Args,
typename PTRTYPE>
1166 std::string type =
"";
1170 bool matched = ((type == INTEGRATOR::name
1171 ? (ic_eta =
new INTEGRATOR(std::forward<Args>(args)..., (*
this))),
1184 template<
typename INTEGRATOR,
typename Args,
typename PTRTYPE>
1187 ic_eta =
new INTEGRATOR(std::forward<Args>(args), (*
this));
1190 template<
typename INTEGRATOR,
typename PTRTYPE>
1193 ic_eta =
new INTEGRATOR((*
this));
1202 template <
typename... OBJ,
typename CLASS>
1221 template <
typename CLASS,
int N,
typename... OBJ>
1224 if constexpr (N == 0)
1229 for (
unsigned int i = 0; i <
sizeof...(OBJ); i++)
1230 if (type == value.names[i])
1233 if (value.selected < 0)
1236 ", invalid type " + type);
1242 if constexpr (N <
sizeof...(OBJ))
1244 if (value.selected == N)
1246 std::get<N>(value.obj).Parse(std::get<N>(value.obj), *
this);
1259 void query_exactly( std::vector<std::string> names, std::pair<std::string, Set::Scalar> values[N],
1260 std::vector<Unit> units = std::vector<Unit>())
1265 "# of units must be 0, 1, or ", names.size(),
" but got ", units.size());
1268 std::vector<std::string> read;
1269 for (
unsigned int n = 0; n < names.size(); n++)
1271 if (amrex::ParmParse::contains(names[n].c_str()))
1273 read.push_back(names[n]);
1278 " Incorrect number of values specified: only ", N,
1279 " values are allowed, but received ",
1284 for (
unsigned int n = 0; n < names.size(); n++)
1286 if (amrex::ParmParse::contains(names[n].c_str()))
1288 values[cnt].first = names[n];
1290 if (units.size() == 0)
1292 else if (units.size() == 1)
1302 std::string names_str =
"[";
1303 for (
unsigned int i = 0; i < names.size(); i++)
1305 names_str +=
full(names[i]);
1306 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 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="_")
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