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"}
74 #ifdef HAVE_ZOLTAN2_PULP 81 {
"error_check_level",
"basic_assertions",
"invalid_assertion_request"},
82 {
"debug_level",
"basic_status",
"invalid_status"},
83 {
"timer_type",
"no_timers",
"invalid_timers"},
84 {
"debug_output_stream",
"cout",
"invalid_stream"},
85 {
"timer_output_stream",
"/dev/null",
"invalid_stream"},
86 {
"memory_output_stream",
"cerr",
"invalid_stream"},
87 {
"debug_procs",
"all",
"not_a_valid_list_of_any_type"},
88 {
"mj_parts",
"2,3,4",
"not_a_valid_list_of_any_type"},
89 {
"memory_procs",
"2-10",
"not_a_valid_list_of_any_type"},
90 {
"order_method",
"rcm",
"invalid_method"},
91 {
"order_method_type",
"local",
"invalid_method_type"},
92 {
"order_package",
"amd",
"invalid_package"},
93 {
"partitioning_objective",
"balance_object_weight",
"invalid_objective"},
94 {
"partitioning_approach",
"repartition",
"invalid_approach"},
95 {
"objects_to_partition",
"graph_vertices",
"invalid_objects"},
96 {
"model",
"graph",
"invalid_model"},
97 {
"algorithm",
"rcb",
"invalid_algorithm"},
98 {
"symmetrize_input",
"transpose",
"invalid_option"},
99 {
"symmetrize_input",
"transpose",
"invalid_option"},
100 {
"mj_concurrent_part_count",
"0",
"invalid_value"},
101 {
"mj_recursion_depth",
"0",
"invalid_value"},
102 {
"mapping_type",
"0",
"invalid_value"},
103 {
"imbalance_tolerance",
"1.1",
"invalid_option"},
104 {
"mj_minimum_migration_imbalance",
"1.1",
"invalid_option"},
105 #ifdef HAVE_ZOLTAN2_PULP 106 {
"pulp_vert_imbalance",
"1.1",
"invalid_option"},
107 {
"pulp_edge_imbalance",
"1.1",
"invalid_option"},
108 #endif // HAVE_ZOLTAN2_PULP 109 {
"scotch_imbalance_ratio",
"1.1",
"invalid_option"},
110 {
"compute_metrics",
"false",
"invalid_bool_setting"},
111 {
"rectilinear",
"false",
"invalid_bool_setting"},
112 {
"subset_graph",
"false",
"invalid_bool_setting"},
113 {
"mj_enable_rcb",
"true",
"invalid_bool_setting"},
114 {
"mj_keep_part_boxes",
"true",
"invalid_bool_setting"},
115 {
"num_global_parts",
"1",
"invalid_value"},
116 {
"num_local_parts",
"0",
"invalid_value"},
117 {
"mj_migration_option",
"2",
"invalid_value"},
120 template <
typename T>
124 Teuchos::ParameterList validParameters;
125 pl.set(paramName, badValue);
127 cout << paramName <<
" = " << badValue << endl;
132 pl.validateParametersAndSetDefaults(validParameters);
134 catch(std::exception &e){
135 cout <<
"Correctly generated an error:" << endl;
136 cout << e.what() << endl;
141 cerr <<
"Bad parameter value was not detected in parameter list." << endl;
154 Teuchos::ParameterList valid(
"valid parameter list");
157 typedef Teuchos::AnyNumberParameterEntryValidator validator_t;
158 Teuchos::RCP<const validator_t> anyNumVal = Teuchos::rcp(
new validator_t);
163 std::cout <<
"set good default value" << std::endl;
165 std::string parameterName(
"parameterName");
167 valid.set(parameterName, 5.0,
"parameterDoc", anyNumVal);
169 catch (std::exception &e) {
170 std::cout <<
"FAIL error setting good default value " 171 << e.what() << std::endl;
175 double dd = valid.getEntry(parameterName).getValue<
double>(&dd);
176 std::cout <<
"good default value <double> = " << dd << std::endl;
180 Teuchos::ParameterList user(
"user");
183 std::cout <<
"test good user value" << std::endl;
184 user.set(parameterName,
"0.123");
186 user.validateParametersAndSetDefaults(valid);
188 catch (std::exception &e) {
189 std::cout <<
"FAIL " << e.what() << std::endl;
193 dd = user.getEntry(parameterName).getValue<
double>(&dd);
194 std::cout <<
"good user value <double> = " << dd << std::endl;
197 std::cout <<
"test bogus user value" << std::endl;
203 user.set(parameterName,
"bogus");
205 catch(std::exception &e) {
207 std::cout <<
"Parameter list correctly rejected bogus user value." 213 std::cout <<
"FAIL parameter list accepted a bogus user value" 220 std::cout <<
"set bogus default value" << std::endl;
222 std::string parameterNameToo(
"parameterNameToo");
225 valid.set(parameterNameToo,
"bogus",
"parameterDoc", anyNumVal);
227 catch (std::exception &e) {
229 std::cout <<
"Parameter list correctly rejected bogus default value." 235 std::cout <<
"FAIL parameter list accepted a bogus default value" 240 std::cout <<
"PASS" << std::endl;
246 int main(
int argc,
char *argv[])
248 Teuchos::GlobalMPISession session(&argc, &argv);
249 Teuchos::RCP<const Teuchos::Comm<int> > comm =
250 Teuchos::DefaultComm<int>::getComm();
252 int rank = comm->getRank();
261 if( tempTest != 0 ) {
267 Teuchos::ParameterList validParameters;
268 Teuchos::ParameterList myParams(
"testParameterList");
270 for (
int i=0; i <
NUMSTR; i++){
274 for (
int i=0; i <
NUMFN; i++){
278 Teuchos::ParameterList origParams(myParams);
285 myParams.validateParametersAndSetDefaults(validParameters);
288 catch(std::exception &e){
289 std::cerr <<
"Validate parameters generated an error:" << endl;
290 std::cerr << e.what() << endl;
291 std::cerr <<
"FAIL" << endl;
296 cout <<
"Parameters after validation: " << endl;
297 cout << myParams << endl;
300 for (
int i=0; i <
NUMSTR; i++){
301 Teuchos::ParameterList badParams(origParams);
303 testInvalidValue<string>(badParams,
strParams[i][0], strParams[i][2]);
305 cout <<
"FAIL" << endl;
310 for (
int i=0; i <
NUMFN; i++){
311 Teuchos::ParameterList badParams(origParams);
316 testInvalidValue<double>(badParams,
fnParams[i][0], badVal);
318 cout <<
"FAIL" << endl;
327 cout <<
"Parameter documentation:" << endl;
330 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]