48 #include <Zoltan2_config.h> 50 #include <Teuchos_ParameterList.hpp> 51 #include <Teuchos_DefaultComm.hpp> 68 {
"debug_output_file",
"temp.txt",
"5"},
69 {
"timer_output_file",
"timerInfo.txt",
"10.3"},
70 {
"memory_output_file",
"memory.txt",
"3.33"}
76 {
"error_check_level",
"basic_assertions",
"invalid_assertion_request"},
77 {
"debug_level",
"basic_status",
"invalid_status"},
78 {
"timer_type",
"no_timers",
"invalid_timers"},
79 {
"debug_output_stream",
"cout",
"invalid_stream"},
80 {
"timer_output_stream",
"/dev/null",
"invalid_stream"},
81 {
"memory_output_stream",
"cerr",
"invalid_stream"},
82 {
"debug_procs",
"all",
"not_a_valid_list_of_any_type"},
83 {
"mj_parts",
"2,3,4",
"not_a_valid_list_of_any_type"},
84 {
"memory_procs",
"2-10",
"not_a_valid_list_of_any_type"},
85 {
"order_method",
"rcm",
"invalid_method"},
86 {
"order_package",
"amd",
"invalid_package"},
87 {
"partitioning_objective",
"balance_object_weight",
"invalid_objective"},
88 {
"partitioning_approach",
"repartition",
"invalid_approach"},
89 {
"objects_to_partition",
"graph_vertices",
"invalid_objects"},
90 {
"model",
"graph",
"invalid_model"},
91 {
"algorithm",
"rcb",
"invalid_algorithm"},
92 {
"symmetrize_input",
"transpose",
"invalid_option"},
93 {
"symmetrize_input",
"transpose",
"invalid_option"},
94 {
"mj_concurrent_part_count",
"0",
"invalid_value"},
95 {
"mj_recursion_depth",
"0",
"invalid_value"},
96 {
"mapping_type",
"0",
"invalid_value"},
97 {
"imbalance_tolerance",
"1.1",
"invalid_option"},
98 {
"mj_minimum_migration_imbalance",
"1.1",
"invalid_option"},
99 {
"pulp_vert_imbalance",
"1.1",
"invalid_option"},
100 {
"pulp_edge_imbalance",
"1.1",
"invalid_option"},
101 {
"scotch_imbalance_ratio",
"1.1",
"invalid_option"},
102 {
"compute_metrics",
"false",
"invalid_bool_setting"},
103 {
"rectilinear",
"false",
"invalid_bool_setting"},
104 {
"subset_graph",
"false",
"invalid_bool_setting"},
105 {
"mj_enable_rcb",
"true",
"invalid_bool_setting"},
106 {
"mj_keep_part_boxes",
"true",
"invalid_bool_setting"},
107 {
"num_global_parts",
"1",
"invalid_value"},
108 {
"num_local_parts",
"0",
"invalid_value"},
109 {
"mj_migration_option",
"2",
"invalid_value"},
112 template <
typename T>
116 Teuchos::ParameterList validParameters;
119 cout <<
paramName <<
" = " << badValue << endl;
124 pl.validateParametersAndSetDefaults(validParameters);
126 catch(std::exception &e){
127 cout <<
"Correctly generated an error:" << endl;
128 cout << e.what() << endl;
133 cerr <<
"Bad parameter value was not detected in parameter list." << endl;
146 Teuchos::ParameterList valid(
"valid parameter list");
149 typedef Teuchos::AnyNumberParameterEntryValidator validator_t;
150 Teuchos::RCP<const validator_t> anyNumVal = Teuchos::rcp(
new validator_t);
155 std::cout <<
"set good default value" << std::endl;
157 std::string parameterName(
"parameterName");
159 valid.set(parameterName, 5.0,
"parameterDoc", anyNumVal);
161 catch (std::exception &e) {
162 std::cout <<
"FAIL error setting good default value " 163 << e.what() << std::endl;
167 double dd = valid.getEntry(parameterName).getValue<
double>(&dd);
168 std::cout <<
"good default value <double> = " << dd << std::endl;
172 Teuchos::ParameterList user(
"user");
175 std::cout <<
"test good user value" << std::endl;
176 user.set(parameterName,
"0.123");
178 user.validateParametersAndSetDefaults(valid);
180 catch (std::exception &e) {
181 std::cout <<
"FAIL " << e.what() << std::endl;
185 dd = user.getEntry(parameterName).getValue<
double>(&dd);
186 std::cout <<
"good user value <double> = " << dd << std::endl;
189 std::cout <<
"test bogus user value" << std::endl;
195 user.set(parameterName,
"bogus");
197 catch(std::exception &e) {
199 std::cout <<
"Parameter list correctly rejected bogus user value." 205 std::cout <<
"FAIL parameter list accepted a bogus user value" 212 std::cout <<
"set bogus default value" << std::endl;
214 std::string parameterNameToo(
"parameterNameToo");
217 valid.set(parameterNameToo,
"bogus",
"parameterDoc", anyNumVal);
219 catch (std::exception &e) {
221 std::cout <<
"Parameter list correctly rejected bogus default value." 227 std::cout <<
"FAIL parameter list accepted a bogus default value" 232 std::cout <<
"PASS" << std::endl;
238 int main(
int argc,
char *argv[])
240 Teuchos::GlobalMPISession session(&argc, &argv);
241 Teuchos::RCP<const Teuchos::Comm<int> > comm =
242 Teuchos::DefaultComm<int>::getComm();
244 int rank = comm->getRank();
253 if( tempTest != 0 ) {
259 Teuchos::ParameterList validParameters;
260 Teuchos::ParameterList myParams(
"testParameterList");
262 for (
int i=0; i <
NUMSTR; i++){
266 for (
int i=0; i <
NUMFN; i++){
270 Teuchos::ParameterList origParams(myParams);
277 myParams.validateParametersAndSetDefaults(validParameters);
280 catch(std::exception &e){
281 std::cerr <<
"Validate parameters generated an error:" << endl;
282 std::cerr << e.what() << endl;
283 std::cerr <<
"FAIL" << endl;
288 cout <<
"Parameters after validation: " << endl;
289 cout << myParams << endl;
292 for (
int i=0; i <
NUMSTR; i++){
293 Teuchos::ParameterList badParams(origParams);
297 cout <<
"FAIL" << endl;
302 for (
int i=0; i <
NUMFN; i++){
303 Teuchos::ParameterList badParams(origParams);
308 testInvalidValue<double>(badParams,
fnParams[i][0], badVal);
310 cout <<
"FAIL" << endl;
319 cout <<
"Parameter documentation:" << endl;
322 cout <<
"PASS" << endl;
void createValidatorList(const Teuchos::ParameterList &plIn, Teuchos::ParameterList &plOut)
Create a list by adding validators to the users parameter list.
static void convertStringToInt(Teuchos::ParameterList ¶ms)
Convert parameters of type Teuchos::StringToIntegralParameterEntryValidator<int> to integer...
void printListDocumentation(const Teuchos::ParameterList &pl, std::ostream &os, std::string listNames)
static string fnParams[NUMFN][3]
int main(int argc, char *argv[])
static const std::string fail
Defines the Environment class.
int testInvalidValue(Teuchos::ParameterList &pl, string paramName, T badValue)
static string strParams[NUMSTR][3]