MueLu  Version of the Day
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
MueLu_MasterList.cpp
Go to the documentation of this file.
1 // @HEADER
2 // *****************************************************************************
3 // MueLu: A package for multigrid based preconditioning
4 //
5 // Copyright 2012 NTESS and the MueLu contributors.
6 // SPDX-License-Identifier: BSD-3-Clause
7 // *****************************************************************************
8 // @HEADER
9 
10 // clang-format off
12 
13 #include "MueLu_Exceptions.hpp"
14 #include "MueLu_MasterList.hpp"
15 
16 namespace MueLu {
17 
19  if (masterList_.is_null()) {
20  masterList_ = Teuchos::getParametersFromXmlString(stringList_);
21  }
22 
23  return masterList_;
24  }
25 
27 
28  if ( (problemType != problemType_) || problemSpecificList_.is_null() ) {
29  if (DefaultProblemTypeLists_.find(problemType) != DefaultProblemTypeLists_.end()) {
30  problemType_ = problemType;
31  problemSpecificList_ = Teuchos::getParametersFromXmlString(DefaultProblemTypeLists_[problemType]);
32  } else {
33  //TODO provide valid problem types
34  TEUCHOS_TEST_FOR_EXCEPTION(true, MueLu::Exceptions::RuntimeError, "Invalid problem type " << problemType << ".");
35  }
36  }
37  return problemSpecificList_;
38  }
39 
40  std::string MasterList::interpretParameterName(const std::string& name, const std::string& value) {
41 
42  // used to concatenate the return string
43  std::stringstream ss;
44 
45  // put in short cuts here!
46 
47  if (name == "verbosity") {
48  std::string verb = "none";
49  if (value == "\"0\"") verb = "none";
50  if (value == "\"1\"" || value == "\"2\"" || value == "\"3\"") verb = "low";
51  if (value == "\"4\"" || value == "\"5\"" || value == "\"6\"") verb = "medium";
52  if (value == "\"7\"" || value == "\"8\"") verb = "high";
53  if (value == "\"9\"") verb = "extreme";
54  if (value == "\"10\"") verb = "test";
55  verb = "\"" + verb + "\"";
56  ss << "<Parameter name=\"verbosity\" type=\"string\" value=" << verb << "/>";
57  return ss.str();
58  }
59 
60  if (name == "cycle type") {
61  std::stringstream temp1; temp1 << "\"" << "MGV" << "\"";
62  std::stringstream temp2; temp2 << "\"" << "MGV" << "\"";
63  if (value == temp1.str() ) { ss << "<Parameter name=\"cycle type\" type=\"string\" value=\"V\"/>"; }
64  else if (value == temp2.str()) { ss << "<Parameter name=\"cycle type\" type=\"string\" value=\"W\"/>"; }
65  else TEUCHOS_TEST_FOR_EXCEPTION(true, MueLu::Exceptions::RuntimeError, "MasterList::interpretParameterName, Line " << __LINE__ << ". "
66  << "The parameter " << value << " is not supported by MueLu.");
67  return ss.str();
68  }
69 
70  // energy minimization is enabled
71  if (name == "multigrid algorithm") {
72  std::stringstream temp; temp << "\"" << "1" << "\"";
73  if (value == temp.str() ) { ss << "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"pg\"/>"; return ss.str(); }
74  }
75 
76  // put in auto-generated code here
77 
78 
79  if (name == "output filename") { ss << "<Parameter name=\"output filename\" type=\"string\" value=" << value << "/>"; return ss.str(); }
80  if (name == "number of equations") { ss << "<Parameter name=\"number of equations\" type=\"int\" value=" << value << "/>"; return ss.str(); }
81  if (name == "max levels") { ss << "<Parameter name=\"max levels\" type=\"int\" value=" << value << "/>"; return ss.str(); }
82  if (name == "W cycle start level") { ss << "<Parameter name=\"W cycle start level\" type=\"int\" value=" << value << "/>"; return ss.str(); }
83  if (name == "coarse grid correction scaling factor") { ss << "<Parameter name=\"coarse grid correction scaling factor\" type=\"double\" value=" << value << "/>"; return ss.str(); }
84  if (name == "fuse prolongation and update") { ss << "<Parameter name=\"fuse prolongation and update\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
85  if (name == "number of vectors") { ss << "<Parameter name=\"number of vectors\" type=\"int\" value=" << value << "/>"; return ss.str(); }
86  if (name == "problem: symmetric") { ss << "<Parameter name=\"problem: symmetric\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
87  if (name == "hierarchy label") { ss << "<Parameter name=\"hierarchy label\" type=\"string\" value=" << value << "/>"; return ss.str(); }
88  if (name == "aggregation: drop tol") { ss << "<Parameter name=\"aggregation: drop tol\" type=\"double\" value=" << value << "/>"; return ss.str(); }
89  if (name == "print initial parameters") { ss << "<Parameter name=\"print initial parameters\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
90  if (name == "print unused parameters") { ss << "<Parameter name=\"print unused parameters\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
91  if (name == "sa: damping factor") { ss << "<Parameter name=\"sa: damping factor\" type=\"double\" value=" << value << "/>"; return ss.str(); }
92  if (name == "sa: use filtered matrix") { ss << "<Parameter name=\"sa: use filtered matrix\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
93  if (name == "sa: eigen-analysis type") { ss << "<Parameter name=\"sa: eigen-analysis type\" type=\"string\" value=" << value << "/>"; return ss.str(); }
94  if (name == "sa: eigenvalue estimate num iterations") { ss << "<Parameter name=\"sa: eigenvalue estimate num iterations\" type=\"int\" value=" << value << "/>"; return ss.str(); }
95  if (name == "sa: use rowsumabs diagonal scaling") { ss << "<Parameter name=\"sa: use rowsumabs diagonal scaling\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
96  if (name == "sa: enforce constraints") { ss << "<Parameter name=\"sa: enforce constraints\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
97  if (name == "sa: max eigenvalue") { ss << "<Parameter name=\"sa: max eigenvalue\" type=\"double\" value=" << value << "/>"; return ss.str(); }
98  if (name == "sa: rowsumabs diagonal replacement tolerance") { ss << "<Parameter name=\"sa: rowsumabs diagonal replacement tolerance\" type=\"double\" value=" << value << "/>"; return ss.str(); }
99  if (name == "sa: rowsumabs use automatic diagonal tolerance") { ss << "<Parameter name=\"sa: rowsumabs use automatic diagonal tolerance\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
100  if (name == "sa: rowsumabs diagonal replacement value") { ss << "<Parameter name=\"sa: rowsumabs diagonal replacement value\" type=\"double\" value=" << value << "/>"; return ss.str(); }
101  if (name == "sa: rowsumabs replace single entry row with zero") { ss << "<Parameter name=\"sa: rowsumabs replace single entry row with zero\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
102  if (name == "replicate: npdes") { ss << "<Parameter name=\"replicate: npdes\" type=\"int\" value=" << value << "/>"; return ss.str(); }
103  if (name == "combine: numBlks") { ss << "<Parameter name=\"combine: numBlks\" type=\"int\" value=" << value << "/>"; return ss.str(); }
104  if (name == "pcoarsen: element") { ss << "<Parameter name=\"pcoarsen: element\" type=\"string\" value=" << value << "/>"; return ss.str(); }
105  if (name == "pcoarsen: schedule") { ss << "<Parameter name=\"pcoarsen: schedule\" type=\"string\" value=" << value << "/>"; return ss.str(); }
106  if (name == "pcoarsen: hi basis") { ss << "<Parameter name=\"pcoarsen: hi basis\" type=\"string\" value=" << value << "/>"; return ss.str(); }
107  if (name == "pcoarsen: lo basis") { ss << "<Parameter name=\"pcoarsen: lo basis\" type=\"string\" value=" << value << "/>"; return ss.str(); }
108  if (name == "smoother: neighborhood type") { ss << "<Parameter name=\"smoother: neighborhood type\" type=\"string\" value=" << value << "/>"; return ss.str(); }
109  if (name == "tentative: calculate qr") { ss << "<Parameter name=\"tentative: calculate qr\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
110  if (name == "tentative: constant column sums") { ss << "<Parameter name=\"tentative: constant column sums\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
111  if (name == "repartition: enable") { ss << "<Parameter name=\"repartition: enable\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
112  if (name == "repartition: start level") { ss << "<Parameter name=\"repartition: start level\" type=\"int\" value=" << value << "/>"; return ss.str(); }
113  if (name == "repartition: use map") { ss << "<Parameter name=\"repartition: use map\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
114  if (name == "repartition: use subcommunicators in place") { ss << "<Parameter name=\"repartition: use subcommunicators in place\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
115  if (name == "repartition: node repartition level") { ss << "<Parameter name=\"repartition: node repartition level\" type=\"int\" value=" << value << "/>"; return ss.str(); }
116  if (name == "repartition: node id") { ss << "<Parameter name=\"repartition: node id\" type=\"int\" value=" << value << "/>"; return ss.str(); }
117  if (name == "repartition: min rows per proc") { ss << "<Parameter name=\"repartition: min rows per proc\" type=\"int\" value=" << value << "/>"; return ss.str(); }
118  if (name == "repartition: max imbalance") { ss << "<Parameter name=\"repartition: max imbalance\" type=\"double\" value=" << value << "/>"; return ss.str(); }
119  if (name == "repartition: put on single proc") { ss << "<Parameter name=\"repartition: put on single proc\" type=\"int\" value=" << value << "/>"; return ss.str(); }
120  if (name == "use external multigrid package") { ss << "<Parameter name=\"use external multigrid package\" type=\"string\" value=" << value << "/>"; return ss.str(); }
121  if (name == "maxwell1: dump matrices") { ss << "<Parameter name=\"maxwell1: dump matrices\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
122  if (name == "refmaxwell: mode") { ss << "<Parameter name=\"refmaxwell: mode\" type=\"string\" value=" << value << "/>"; return ss.str(); }
123  if (name == "refmaxwell: disable addon") { ss << "<Parameter name=\"refmaxwell: disable addon\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
124  if (name == "refmaxwell: use as preconditioner") { ss << "<Parameter name=\"refmaxwell: use as preconditioner\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
125  if (name == "refmaxwell: dump matrices") { ss << "<Parameter name=\"refmaxwell: dump matrices\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
126  if (name == "refmaxwell: subsolves on subcommunicators") { ss << "<Parameter name=\"refmaxwell: subsolves on subcommunicators\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
127  if (name == "refmaxwell: enable reuse") { ss << "<Parameter name=\"refmaxwell: enable reuse\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
128  if (name == "refmaxwell: skip first (1,1) level") { ss << "<Parameter name=\"refmaxwell: skip first (1,1) level\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
129  if (name == "refmaxwell: normalize nullspace") { ss << "<Parameter name=\"refmaxwell: normalize nullspace\" type=\"bool\" value=" << value << "/>"; return ss.str(); }
130  return "";
131  }
132 
135  std::string MasterList::problemType_ = "unknown";
136  const std::string MasterList::stringList_ =
137 "<ParameterList name=\"MueLu\">"
138  "<Parameter name=\"problem: type\" type=\"string\" value=\"unknown\"/>"
139  "<Parameter name=\"verbosity\" type=\"string\" value=\"high\"/>"
140  "<Parameter name=\"output filename\" type=\"string\" value=\"\"/>"
141  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
142  "<Parameter name=\"max levels\" type=\"int\" value=\"10\"/>"
143  "<Parameter name=\"cycle type\" type=\"string\" value=\"V\"/>"
144  "<Parameter name=\"W cycle start level\" type=\"int\" value=\"0\"/>"
145  "<Parameter name=\"coarse grid correction scaling factor\" type=\"double\" value=\"1.0\"/>"
146  "<Parameter name=\"fuse prolongation and update\" type=\"bool\" value=\"true\"/>"
147  "<Parameter name=\"number of vectors\" type=\"int\" value=\"1\"/>"
148  "<Parameter name=\"problem: symmetric\" type=\"bool\" value=\"true\"/>"
149  "<Parameter name=\"xml parameter file\" type=\"string\" value=\"\"/>"
150  "<Parameter name=\"parameterlist: syntax\" type=\"string\" value=\"muelu\"/>"
151  "<Parameter name=\"hierarchy label\" type=\"string\" value=\"\"/>"
152  "<ParameterList name=\"matvec params\"/>"
153  "<Parameter name=\"half precision\" type=\"bool\" value=\"false\"/>"
154  "<Parameter name=\"smoother: pre or post\" type=\"string\" value=\"both\"/>"
155  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
156  "<Parameter name=\"smoother: pre type\" type=\"string\" value=\"RELAXATION\"/>"
157  "<Parameter name=\"smoother: post type\" type=\"string\" value=\"RELAXATION\"/>"
158  "<ParameterList name=\"smoother: params\"/>"
159  "<ParameterList name=\"smoother: pre params\"/>"
160  "<ParameterList name=\"smoother: post params\"/>"
161  "<Parameter name=\"smoother: overlap\" type=\"int\" value=\"0\"/>"
162  "<Parameter name=\"smoother: pre overlap\" type=\"int\" value=\"0\"/>"
163  "<Parameter name=\"smoother: post overlap\" type=\"int\" value=\"0\"/>"
164  "<Parameter name=\"coarse: max size\" type=\"int\" value=\"2000\"/>"
165  "<Parameter name=\"coarse: type\" type=\"string\" value=\"KLU\"/>"
166  "<ParameterList name=\"coarse: params\"/>"
167  "<Parameter name=\"coarse: overlap\" type=\"int\" value=\"0\"/>"
168  "<Parameter name=\"aggregation: backend\" type=\"string\" value=\"default\"/>"
169  "<Parameter name=\"aggregation: type\" type=\"string\" value=\"uncoupled\"/>"
170  "<Parameter name=\"aggregation: mode\" type=\"string\" value=\"uncoupled\"/>"
171  "<Parameter name=\"aggregation: ordering\" type=\"string\" value=\"natural\"/>"
172  "<Parameter name=\"aggregation: phase 1 algorithm\" type=\"string\" value=\"Distance2\"/>"
173  "<Parameter name=\"aggregation: symmetrize graph after dropping\" type=\"bool\" value=\"false\"/>"
174  "<Parameter name=\"aggregation: use blocking\" type=\"bool\" value=\"false\"/>"
175  "<Parameter name=\"aggregation: drop scheme\" type=\"string\" value=\"classical\"/>"
176  "<Parameter name=\"aggregation: strength-of-connection: matrix\" type=\"string\" value=\"A\"/>"
177  "<Parameter name=\"aggregation: strength-of-connection: measure\" type=\"string\" value=\"smoothed aggregation\"/>"
178  "<Parameter name=\"aggregation: classical scheme\" type=\"string\" value=\"direct\"/>"
179  "<Parameter name=\"aggregation: row sum drop tol\" type=\"double\" value=\"-1.0\"/>"
180  "<Parameter name=\"aggregation: block diagonal: interleaved blocksize\" type=\"int\" value=\"3\"/>"
181  "<Parameter name=\"aggregation: number of random vectors\" type=\"int\" value=\"10\"/>"
182  "<Parameter name=\"aggregation: number of times to pre or post smooth\" type=\"int\" value=\"10\"/>"
183  "<Parameter name=\"aggregation: penalty parameters\" type=\"Array(double)\" value=\"{12.,-.2,0,0,0} \"/>"
184  "<Parameter name=\"aggregation: distance laplacian directional weights\" type=\"Array(double)\" value=\"{1,1,1}\"/>"
185  "<Parameter name=\"aggregation: distance laplacian algo\" type=\"string\" value=\"default\"/>"
186  "<Parameter name=\"aggregation: distance laplacian metric\" type=\"string\" value=\"unweighted\"/>"
187  "<Parameter name=\"aggregation: classical algo\" type=\"string\" value=\"default\"/>"
188  "<Parameter name=\"aggregation: drop tol\" type=\"double\" value=\"0.0\"/>"
189  "<Parameter name=\"aggregation: use ml scaling of drop tol\" type=\"bool\" value=\"false\"/>"
190  "<Parameter name=\"aggregation: min agg size\" type=\"int\" value=\"2\"/>"
191  "<Parameter name=\"aggregation: max agg size\" type=\"int\" value=\"-1\"/>"
192  "<Parameter name=\"aggregation: compute aggregate qualities\" type=\"bool\" value=\"false\"/>"
193  "<Parameter name=\"aggregation: brick x size\" type=\"int\" value=\"2\"/>"
194  "<Parameter name=\"aggregation: brick y size\" type=\"int\" value=\"2\"/>"
195  "<Parameter name=\"aggregation: brick z size\" type=\"int\" value=\"2\"/>"
196  "<Parameter name=\"aggregation: brick x Dirichlet\" type=\"bool\" value=\"false\"/>"
197  "<Parameter name=\"aggregation: brick y Dirichlet\" type=\"bool\" value=\"false\"/>"
198  "<Parameter name=\"aggregation: brick z Dirichlet\" type=\"bool\" value=\"false\"/>"
199  "<Parameter name=\"aggregation: max selected neighbors\" type=\"int\" value=\"0\"/>"
200  "<Parameter name=\"aggregation: Dirichlet threshold\" type=\"double\" value=\"0.0\"/>"
201  "<Parameter name=\"aggregation: greedy Dirichlet\" type=\"bool\" value=\"false\"/>"
202  "<Parameter name=\"aggregation: deterministic\" type=\"bool\" value=\"false\"/>"
203  "<Parameter name=\"aggregation: coloring algorithm\" type=\"string\" value=\"serial\"/>"
204  "<Parameter name=\"aggregation: coloring: use color graph\" type=\"bool\" value=\"false\"/>"
205  "<Parameter name=\"aggregation: coloring: localize color graph\" type=\"bool\" value=\"true\"/>"
206  "<Parameter name=\"aggregation: enable phase 1\" type=\"bool\" value=\"true\"/>"
207  "<Parameter name=\"aggregation: enable phase 2a\" type=\"bool\" value=\"true\"/>"
208  "<Parameter name=\"aggregation: enable phase 2b\" type=\"bool\" value=\"true\"/>"
209  "<Parameter name=\"aggregation: enable phase 3\" type=\"bool\" value=\"true\"/>"
210  "<Parameter name=\"aggregation: match ML phase1\" type=\"bool\" value=\"false\"/>"
211  "<Parameter name=\"aggregation: match ML phase2a\" type=\"bool\" value=\"false\"/>"
212  "<Parameter name=\"aggregation: match ML phase2b\" type=\"bool\" value=\"false\"/>"
213  "<Parameter name=\"aggregation: phase2a agg factor\" type=\"double\" value=\"0.5\"/>"
214  "<Parameter name=\"aggregation: error on nodes with no on-rank neighbors\" type=\"bool\" value=\"false\"/>"
215  "<Parameter name=\"aggregation: phase3 avoid singletons\" type=\"bool\" value=\"false\"/>"
216  "<Parameter name=\"aggregation: allow empty prolongator columns\" type=\"bool\" value=\"false\"/>"
217  "<Parameter name=\"aggregation: preserve Dirichlet points\" type=\"bool\" value=\"false\"/>"
218  "<Parameter name=\"aggregation: dropping may create Dirichlet\" type=\"bool\" value=\"true\"/>"
219  "<Parameter name=\"aggregation: allow user-specified singletons\" type=\"bool\" value=\"false\"/>"
220  "<Parameter name=\"aggregation: use interface aggregation\" type=\"bool\" value=\"false\"/>"
221  "<Parameter name=\"aggregation: export visualization data\" type=\"bool\" value=\"false\"/>"
222  "<Parameter name=\"aggregation: output filename\" type=\"string\" value=\"\"/>"
223  "<Parameter name=\"aggregation: output file: time step\" type=\"int\" value=\"0\"/>"
224  "<Parameter name=\"aggregation: output file: iter\" type=\"int\" value=\"0\"/>"
225  "<Parameter name=\"aggregation: output file: agg style\" type=\"string\" value=\"Point Cloud\"/>"
226  "<Parameter name=\"aggregation: output file: fine graph edges\" type=\"bool\" value=\"false\"/>"
227  "<Parameter name=\"aggregation: output file: coarse graph edges\" type=\"bool\" value=\"false\"/>"
228  "<Parameter name=\"aggregation: output file: build colormap\" type=\"bool\" value=\"false\"/>"
229  "<Parameter name=\"aggregation: output file: aggregate qualities\" type=\"bool\" value=\"false\"/>"
230  "<Parameter name=\"aggregation: output file: material\" type=\"bool\" value=\"false\"/>"
231  "<ParameterList name=\"aggregation: params\"/>"
232  "<ParameterList name=\"strength-of-connection: params\"/>"
233  "<Parameter name=\"aggregation: mesh layout\" type=\"string\" value=\"Global Lexicographic\"/>"
234  "<Parameter name=\"aggregation: output type\" type=\"string\" value=\"Aggregates\"/>"
235  "<Parameter name=\"aggregation: coarsening rate\" type=\"string\" value=\"{3}\"/>"
236  "<Parameter name=\"aggregation: number of spatial dimensions\" type=\"int\" value=\"3\"/>"
237  "<Parameter name=\"aggregation: coarsening order\" type=\"int\" value=\"0\"/>"
238  "<Parameter name=\"aggregation: pairwise: size\" type=\"int\" value=\"8\"/>"
239  "<Parameter name=\"aggregation: pairwise: tie threshold\" type=\"double\" value=\"1e-6\"/>"
240  "<Parameter name=\"aggregate qualities: check symmetry\" type=\"bool\" value=\"false\"/>"
241  "<Parameter name=\"aggregate qualities: good aggregate threshold\" type=\"double\" value=\"100.0\"/>"
242  "<Parameter name=\"aggregate qualities: file output\" type=\"bool\" value=\"false\"/>"
243  "<Parameter name=\"aggregate qualities: file base\" type=\"string\" value=\"agg_qualities\"/>"
244  "<Parameter name=\"aggregate qualities: algorithm\" type=\"string\" value=\"forward\"/>"
245  "<Parameter name=\"aggregate qualities: zero threshold\" type=\"double\" value=\"1e-12\"/>"
246  "<Parameter name=\"aggregate qualities: percentiles\" type=\"Array(double)\" value=\"{}\"/>"
247  "<Parameter name=\"aggregate qualities: mode\" type=\"string\" value=\"eigenvalue\"/>"
248  "<ParameterList name=\"export data\"/>"
249  "<Parameter name=\"keep data\" type=\"string\" value=\"{}\"/>"
250  "<Parameter name=\"print initial parameters\" type=\"bool\" value=\"true\"/>"
251  "<Parameter name=\"print unused parameters\" type=\"bool\" value=\"true\"/>"
252  "<Parameter name=\"transpose: use implicit\" type=\"bool\" value=\"false\"/>"
253  "<Parameter name=\"transfers: half precision\" type=\"bool\" value=\"false\"/>"
254  "<Parameter name=\"nullspace: calculate rotations\" type=\"bool\" value=\"false\"/>"
255  "<Parameter name=\"nullspace: suppress dimension check\" type=\"bool\" value=\"false\"/>"
256  "<Parameter name=\"restriction: scale nullspace\" type=\"bool\" value=\"false\"/>"
257  "<Parameter name=\"use kokkos refactor\" type=\"bool\" value=\"false\"/>"
258  "<Parameter name=\"synchronize factory timers\" type=\"bool\" value=\"false\"/>"
259  "<Parameter name=\"rap: triple product\" type=\"bool\" value=\"false\"/>"
260  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
261  "<Parameter name=\"toggle: mode\" type=\"string\" value=\"semicoarsen\"/>"
262  "<Parameter name=\"semicoarsen: coarsen rate\" type=\"int\" value=\"3\"/>"
263  "<Parameter name=\"semicoarsen: piecewise constant\" type=\"bool\" value=\"false\"/>"
264  "<Parameter name=\"semicoarsen: piecewise linear\" type=\"bool\" value=\"false\"/>"
265  "<Parameter name=\"semicoarsen: calculate nonsym restriction\" type=\"bool\" value=\"false\"/>"
266  "<Parameter name=\"semicoarsen: number of levels\" type=\"int\" value=\"3\"/>"
267  "<Parameter name=\"linedetection: orientation\" type=\"string\" value=\"vertical\"/>"
268  "<Parameter name=\"linedetection: num layers\" type=\"int\" value=\"-1\"/>"
269  "<Parameter name=\"sa: damping factor\" type=\"double\" value=\"1.33\"/>"
270  "<Parameter name=\"sa: use filtered matrix\" type=\"bool\" value=\"true\"/>"
271  "<Parameter name=\"sa: calculate eigenvalue estimate\" type=\"bool\" value=\"false\"/>"
272  "<Parameter name=\"sa: eigen-analysis type\" type=\"string\" value=\"power-method\"/>"
273  "<Parameter name=\"sa: eigenvalue estimate num iterations\" type=\"int\" value=\"10\"/>"
274  "<Parameter name=\"sa: use rowsumabs diagonal scaling\" type=\"bool\" value=\"false\"/>"
275  "<Parameter name=\"sa: enforce constraints\" type=\"bool\" value=\"false\"/>"
276  "<Parameter name=\"sa: max eigenvalue\" type=\"double\" value=\"-1.0\"/>"
277  "<Parameter name=\"sa: rowsumabs diagonal replacement tolerance\" type=\"double\" value=\"-1.0\"/>"
278  "<Parameter name=\"sa: rowsumabs use automatic diagonal tolerance\" type=\"bool\" value=\"false\"/>"
279  "<Parameter name=\"sa: rowsumabs diagonal replacement value\" type=\"double\" value=\"0.0\"/>"
280  "<Parameter name=\"sa: rowsumabs replace single entry row with zero\" type=\"bool\" value=\"true\"/>"
281  "<Parameter name=\"replicate: npdes\" type=\"int\" value=\"1\"/>"
282  "<Parameter name=\"combine: numBlks\" type=\"int\" value=\"1\"/>"
283  "<Parameter name=\"interp: build coarse coordinates\" type=\"bool\" value=\"true\"/>"
284  "<ParameterList name=\"transfer: params\"/>"
285  "<Parameter name=\"pcoarsen: element\" type=\"string\" value=\"\"/>"
286  "<Parameter name=\"pcoarsen: schedule\" type=\"string\" value=\"\"/>"
287  "<Parameter name=\"pcoarsen: hi basis\" type=\"string\" value=\"\"/>"
288  "<Parameter name=\"pcoarsen: lo basis\" type=\"string\" value=\"\"/>"
289  "<Parameter name=\"smoother: neighborhood type\" type=\"string\" value=\"\"/>"
290  "<Parameter name=\"filtered matrix: use lumping\" type=\"bool\" value=\"true\"/>"
291  "<Parameter name=\"filtered matrix: lumping choice\" type=\"string\" value=\"diag lumping\"/>"
292  "<Parameter name=\"filtered matrix: use spread lumping\" type=\"bool\" value=\"false\"/>"
293  "<Parameter name=\"filtered matrix: spread lumping diag dom growth factor\" type=\"double\" value=\"1.1\"/>"
294  "<Parameter name=\"filtered matrix: spread lumping diag dom cap\" type=\"double\" value=\"2.0\"/>"
295  "<Parameter name=\"filtered matrix: use root stencil\" type=\"bool\" value=\"false\"/>"
296  "<Parameter name=\"filtered matrix: Dirichlet threshold\" type=\"double\" value=\"-1.0\"/>"
297  "<Parameter name=\"filtered matrix: reuse eigenvalue\" type=\"bool\" value=\"true\"/>"
298  "<Parameter name=\"filtered matrix: reuse graph\" type=\"bool\" value=\"true\"/>"
299  "<Parameter name=\"matrix: compute analysis\" type=\"bool\" value=\"false\"/>"
300  "<Parameter name=\"emin: iterative method\" type=\"string\" value=\"cg\"/>"
301  "<Parameter name=\"emin: num iterations\" type=\"int\" value=\"2\"/>"
302  "<Parameter name=\"emin: num reuse iterations\" type=\"int\" value=\"1\"/>"
303  "<Parameter name=\"emin: pattern\" type=\"string\" value=\"AkPtent\"/>"
304  "<Parameter name=\"emin: pattern order\" type=\"int\" value=\"1\"/>"
305  "<Parameter name=\"emin: use filtered matrix\" type=\"bool\" value=\"true\"/>"
306  "<Parameter name=\"tentative: calculate qr\" type=\"bool\" value=\"true\"/>"
307  "<Parameter name=\"tentative: constant column sums\" type=\"bool\" value=\"false\"/>"
308  "<Parameter name=\"tentative: build coarse coordinates\" type=\"bool\" value=\"true\"/>"
309  "<Parameter name=\"repartition: enable\" type=\"bool\" value=\"false\"/>"
310  "<Parameter name=\"repartition: partitioner\" type=\"string\" value=\"zoltan2\"/>"
311  "<ParameterList name=\"repartition: params\"/>"
312  "<Parameter name=\"repartition: start level\" type=\"int\" value=\"2\"/>"
313  "<Parameter name=\"repartition: use map\" type=\"bool\" value=\"false\"/>"
314  "<Parameter name=\"repartition: use subcommunicators in place\" type=\"bool\" value=\"false\"/>"
315  "<Parameter name=\"repartition: node repartition level\" type=\"int\" value=\"-1\"/>"
316  "<Parameter name=\"repartition: node id\" type=\"int\" value=\"-1\"/>"
317  "<Parameter name=\"repartition: min rows per proc\" type=\"int\" value=\"800\"/>"
318  "<Parameter name=\"repartition: target rows per proc\" type=\"int\" value=\"0\"/>"
319  "<Parameter name=\"repartition: min rows per thread\" type=\"int\" value=\"0\"/>"
320  "<Parameter name=\"repartition: target rows per thread\" type=\"int\" value=\"0\"/>"
321  "<Parameter name=\"repartition: max imbalance\" type=\"double\" value=\"1.2\"/>"
322  "<Parameter name=\"repartition: remap parts\" type=\"bool\" value=\"true\"/>"
323  "<Parameter name=\"repartition: remap num values\" type=\"int\" value=\"4\"/>"
324  "<Parameter name=\"repartition: remap accept partition\" type=\"bool\" value=\"true\"/>"
325  "<Parameter name=\"repartition: print partition distribution\" type=\"bool\" value=\"false\"/>"
326  "<Parameter name=\"repartition: rebalance P and R\" type=\"bool\" value=\"false\"/>"
327  "<Parameter name=\"repartition: explicit via new copy rebalance P and R\" type=\"bool\" value=\"false\"/>"
328  "<Parameter name=\"repartition: rebalance Nullspace\" type=\"bool\" value=\"true\"/>"
329  "<Parameter name=\"repartition: use subcommunicators\" type=\"bool\" value=\"true\"/>"
330  "<Parameter name=\"repartition: save importer\" type=\"bool\" value=\"false\"/>"
331  "<Parameter name=\"repartition: put on single proc\" type=\"int\" value=\"0\"/>"
332  "<Parameter name=\"repartition: send type\" type=\"string\" value=\"\"/>"
333  "<Parameter name=\"rap: relative diagonal floor\" type=\"Array(double)\" value=\"{}\"/>"
334  "<Parameter name=\"rap: fix zero diagonals\" type=\"bool\" value=\"false\"/>"
335  "<Parameter name=\"rap: fix zero diagonals threshold\" type=\"double\" value=\"0.\"/>"
336  "<Parameter name=\"rap: fix zero diagonals replacement\" type=\"double\" value=\"1.\"/>"
337  "<Parameter name=\"rap: shift\" type=\"double\" value=\"0.0\"/>"
338  "<Parameter name=\"rap: shift diagonal M\" type=\"bool\" value=\"false\"/>"
339  "<Parameter name=\"rap: shift low storage\" type=\"bool\" value=\"false\"/>"
340  "<Parameter name=\"rap: shift array\" type=\"Array(double)\" value=\"{}\"/>"
341  "<Parameter name=\"rap: cfl array\" type=\"Array(double)\" value=\"{}\"/>"
342  "<Parameter name=\"rap: algorithm\" type=\"string\" value=\"galerkin\"/>"
343  "<ParameterList name=\"matrixmatrix: kernel params\"/>"
344  "<Parameter name=\"matrixmatrix: kernel params:MM_TAFC_OptimizationCoreCount \" type=\"int\" value=\"3000 \"/>"
345  "<Parameter name=\"isMatrixMatrix_TransferAndFillComplete \" type=\"bool\" value=\"false\"/>"
346  "<Parameter name=\"reuse: type\" type=\"string\" value=\"none\"/>"
347  "<Parameter name=\"use external multigrid package\" type=\"string\" value=\"none\"/>"
348  "<ParameterList name=\"amgx:params\"/>"
349  "<ParameterList name=\"kokkos tuning: muelu parameter mapping\"/>"
350  "<Parameter name=\"debug: graph level\" type=\"int\" value=\"-2\"/>"
351  "<Parameter name=\"maxwell1: mode\" type=\"string\" value=\"standard\"/>"
352  "<ParameterList name=\"maxwell1: 11list\"/>"
353  "<ParameterList name=\"maxwell1: 22list\"/>"
354  "<Parameter name=\"maxwell1: dump matrices\" type=\"bool\" value=\"false\"/>"
355  "<Parameter name=\"maxwell1: nodal smoother fix zero diagonal threshold\" type=\"double\" value=\"1e-10\"/>"
356  "<Parameter name=\"refmaxwell: mode\" type=\"string\" value=\"additive\"/>"
357  "<Parameter name=\"refmaxwell: disable addon\" type=\"bool\" value=\"true\"/>"
358  "<ParameterList name=\"refmaxwell: 11list\"/>"
359  "<ParameterList name=\"refmaxwell: 22list\"/>"
360  "<Parameter name=\"refmaxwell: use as preconditioner\" type=\"bool\" value=\"false\"/>"
361  "<Parameter name=\"refmaxwell: dump matrices\" type=\"bool\" value=\"false\"/>"
362  "<Parameter name=\"refmaxwell: subsolves on subcommunicators\" type=\"bool\" value=\"false\"/>"
363  "<Parameter name=\"refmaxwell: enable reuse\" type=\"bool\" value=\"false\"/>"
364  "<Parameter name=\"refmaxwell: skip first (1,1) level\" type=\"bool\" value=\"true\"/>"
365  "<Parameter name=\"refmaxwell: normalize nullspace\" type=\"bool\" value=\"false\"/>"
366 "</ParameterList>"
367 ;
369 ("Poisson-2D",
370 
371  "<ParameterList name=\"MueLu\">"
372 
373  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
374 
375  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
376 
377  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
378 
379  "</ParameterList>"
380  )
381 ("Poisson-2D-complex",
382 
383  "<ParameterList name=\"MueLu\">"
384 
385  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
386 
387  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
388 
389  "<ParameterList name=\"smoother: params\">"
390 
391  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
392 
393  "</ParameterList>"
394 
395  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
396 
397  "</ParameterList>"
398  )
399 ("Poisson-3D",
400 
401  "<ParameterList name=\"MueLu\">"
402 
403  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
404 
405  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
406 
407  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
408 
409  "</ParameterList>"
410  )
411 ("Poisson-3D-complex",
412 
413  "<ParameterList name=\"MueLu\">"
414 
415  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
416 
417  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
418 
419  "<ParameterList name=\"smoother: params\">"
420 
421  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
422 
423  "</ParameterList>"
424 
425  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
426 
427  "</ParameterList>"
428  )
429 ("Elasticity-2D",
430 
431  "<ParameterList name=\"MueLu\">"
432 
433  "<Parameter name=\"number of equations\" type=\"int\" value=\"2\"/>"
434 
435  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
436 
437  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
438 
439  "</ParameterList>"
440  )
441 ("Elasticity-2D-complex",
442 
443  "<ParameterList name=\"MueLu\">"
444 
445  "<Parameter name=\"number of equations\" type=\"int\" value=\"2\"/>"
446 
447  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
448 
449  "<ParameterList name=\"smoother: params\">"
450 
451  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
452 
453  "</ParameterList>"
454 
455  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
456 
457  "</ParameterList>"
458  )
459 ("Elasticity-3D",
460 
461  "<ParameterList name=\"MueLu\">"
462 
463  "<Parameter name=\"number of equations\" type=\"int\" value=\"3\"/>"
464 
465  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
466 
467  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
468 
469  "</ParameterList>"
470  )
471 ("Elasticity-3D-complex",
472 
473  "<ParameterList name=\"MueLu\">"
474 
475  "<Parameter name=\"number of equations\" type=\"int\" value=\"3\"/>"
476 
477  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
478 
479  "<ParameterList name=\"smoother: params\">"
480 
481  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
482 
483  "</ParameterList>"
484 
485  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
486 
487  "</ParameterList>"
488  )
489 ("MHD",
490 
491  "<ParameterList name=\"MueLu\">"
492 
493  "<Parameter name=\"smoother: type\" type=\"string\" value=\"SCHWARZ\"/>"
494 
495  "<ParameterList name=\"smoother: params\">"
496 
497  "<Parameter name=\"schwarz: overlap level\" type=\"int\" value=\"1\"/>"
498 
499  "<Parameter name=\"schwarz: combine mode\" type=\"string\" value=\"Zero\"/>"
500 
501  "<Parameter name=\"schwarz: use reordering\" type=\"bool\" value=\"false\"/>"
502 
503  "<Parameter name=\"subdomain solver name\" type=\"string\" value=\"RILUK\"/>"
504 
505  "<ParameterList name=\"subdomain solver parameters\">"
506 
507  "<Parameter name=\"fact: iluk level-of-fill\" type=\"int\" value=\"0\"/>"
508 
509  "<Parameter name=\"fact: absolute threshold\" type=\"double\" value=\"0.\"/>"
510 
511  "<Parameter name=\"fact: relative threshold\" type=\"double\" value=\"1.\"/>"
512 
513  "<Parameter name=\"fact: relax value\" type=\"double\" value=\"0.\"/>"
514 
515  "</ParameterList>"
516 
517  "</ParameterList>"
518 
519  "<Parameter name=\"transpose: use implicit\" type=\"bool\" value=\"true\"/>"
520 
521  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"unsmoothed\"/>"
522 
523  "</ParameterList>"
524  )
525 ("ConvectionDiffusion",
526 
527  "<ParameterList name=\"MueLu\">"
528 
529  "<Parameter name=\"problem: symmetric\" type=\"bool\" value=\"false\"/>"
530 
531  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
532 
533  "<ParameterList name=\"smoother: params\">"
534 
535  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Gauss-Seidel\"/>"
536 
537  "</ParameterList>"
538 
539  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"pg\"/>"
540 
541  "<Parameter name=\"sa: use filtered matrix\" type=\"bool\" value=\"true\"/>"
542 
543  "<Parameter name=\"emin: use filtered matrix\" type=\"bool\" value=\"true\"/>"
544 
545  "</ParameterList>"
546  )
547 ;
549 
550  ("default values","problem: type")
551 
552  ("ML output","verbosity")
553 
554  ("output filename","output filename")
555 
556  ("PDE equations","number of equations")
557 
558  ("max levels","max levels")
559 
560  ("prec type","cycle type")
561 
562  ("W cycle start level","W cycle start level")
563 
564  ("coarse grid correction scaling factor","coarse grid correction scaling factor")
565 
566  ("fuse prolongation and update","fuse prolongation and update")
567 
568  ("number of vectors","number of vectors")
569 
570  ("problem: symmetric","problem: symmetric")
571 
572  ("xml parameter file","xml parameter file")
573 
574  ("parameterlist: syntax","parameterlist: syntax")
575 
576  ("ML label","hierarchy label")
577 
578  ("matvec params","matvec params")
579 
580  ("half precision","half precision")
581 
582  ("smoother: pre or post","smoother: pre or post")
583 
584  ("smoother: type","smoother: type")
585 
586  ("smoother: pre type","smoother: pre type")
587 
588  ("smoother: post type","smoother: post type")
589 
590  ("smoother: params","smoother: params")
591 
592  ("smoother: pre params","smoother: pre params")
593 
594  ("smoother: post params","smoother: post params")
595 
596  ("smoother: overlap","smoother: overlap")
597 
598  ("smoother: pre overlap","smoother: pre overlap")
599 
600  ("smoother: post overlap","smoother: post overlap")
601 
602  ("max size","coarse: max size")
603 
604  ("coarse: type","coarse: type")
605 
606  ("coarse: params","coarse: params")
607 
608  ("coarse: overlap","coarse: overlap")
609 
610  ("aggregation: backend","aggregation: backend")
611 
612  ("aggregation: type","aggregation: type")
613 
614  ("aggregation: mode","aggregation: mode")
615 
616  ("aggregation: ordering","aggregation: ordering")
617 
618  ("aggregation: phase 1 algorithm","aggregation: phase 1 algorithm")
619 
620  ("aggregation: symmetrize graph after dropping","aggregation: symmetrize graph after dropping")
621 
622  ("aggregation: use blocking","aggregation: use blocking")
623 
624  ("aggregation: drop scheme","aggregation: drop scheme")
625 
626  ("aggregation: strength-of-connection: matrix","aggregation: strength-of-connection: matrix")
627 
628  ("aggregation: strength-of-connection: measure","aggregation: strength-of-connection: measure")
629 
630  ("aggregation: classical scheme","aggregation: classical scheme")
631 
632  ("aggregation: row sum drop tol","aggregation: row sum drop tol")
633 
634  ("aggregation: block diagonal: interleaved blocksize","aggregation: block diagonal: interleaved blocksize")
635 
636  ("aggregation: number of random vectors","aggregation: number of random vectors")
637 
638  ("aggregation: number of times to pre or post smooth","aggregation: number of times to pre or post smooth")
639 
640  ("aggregation: penalty parameters","aggregation: penalty parameters")
641 
642  ("aggregation: distance laplacian directional weights","aggregation: distance laplacian directional weights")
643 
644  ("aggregation: distance laplacian algo","aggregation: distance laplacian algo")
645 
646  ("aggregation: distance laplacian metric","aggregation: distance laplacian metric")
647 
648  ("aggregation: classical algo","aggregation: classical algo")
649 
650  ("aggregation: threshold","aggregation: drop tol")
651 
652  ("aggregation: use ml scaling of drop tol","aggregation: use ml scaling of drop tol")
653 
654  ("aggregation: min agg size","aggregation: min agg size")
655 
656  ("aggregation: max agg size","aggregation: max agg size")
657 
658  ("aggregation: compute aggregate qualities","aggregation: compute aggregate qualities")
659 
660  ("aggregation: brick x size","aggregation: brick x size")
661 
662  ("aggregation: brick y size","aggregation: brick y size")
663 
664  ("aggregation: brick z size","aggregation: brick z size")
665 
666  ("aggregation: brick x Dirichlet","aggregation: brick x Dirichlet")
667 
668  ("aggregation: brick y Dirichlet","aggregation: brick y Dirichlet")
669 
670  ("aggregation: brick z Dirichlet","aggregation: brick z Dirichlet")
671 
672  ("aggregation: max selected neighbors","aggregation: max selected neighbors")
673 
674  ("aggregation: Dirichlet threshold","aggregation: Dirichlet threshold")
675 
676  ("aggregation: greedy Dirichlet","aggregation: greedy Dirichlet")
677 
678  ("aggregation: deterministic","aggregation: deterministic")
679 
680  ("aggregation: coloring algorithm","aggregation: coloring algorithm")
681 
682  ("aggregation: coloring: use color graph","aggregation: coloring: use color graph")
683 
684  ("aggregation: coloring: localize color graph","aggregation: coloring: localize color graph")
685 
686  ("aggregation: enable phase 1","aggregation: enable phase 1")
687 
688  ("aggregation: enable phase 2a","aggregation: enable phase 2a")
689 
690  ("aggregation: enable phase 2b","aggregation: enable phase 2b")
691 
692  ("aggregation: enable phase 3","aggregation: enable phase 3")
693 
694  ("aggregation: match ML phase1","aggregation: match ML phase1")
695 
696  ("aggregation: match ML phase2a","aggregation: match ML phase2a")
697 
698  ("aggregation: match ML phase2b","aggregation: match ML phase2b")
699 
700  ("aggregation: phase2a agg factor","aggregation: phase2a agg factor")
701 
702  ("aggregation: error on nodes with no on-rank neighbors","aggregation: error on nodes with no on-rank neighbors")
703 
704  ("aggregation: phase3 avoid singletons","aggregation: phase3 avoid singletons")
705 
706  ("aggregation: allow empty prolongator columns","aggregation: allow empty prolongator columns")
707 
708  ("aggregation: preserve Dirichlet points","aggregation: preserve Dirichlet points")
709 
710  ("aggregation: dropping may create Dirichlet","aggregation: dropping may create Dirichlet")
711 
712  ("aggregation: allow user-specified singletons","aggregation: allow user-specified singletons")
713 
714  ("aggregation: use interface aggregation","aggregation: use interface aggregation")
715 
716  ("aggregation: export visualization data","aggregation: export visualization data")
717 
718  ("aggregation: output filename","aggregation: output filename")
719 
720  ("aggregation: output file: time step","aggregation: output file: time step")
721 
722  ("aggregation: output file: iter","aggregation: output file: iter")
723 
724  ("aggregation: output file: agg style","aggregation: output file: agg style")
725 
726  ("aggregation: output file: fine graph edges","aggregation: output file: fine graph edges")
727 
728  ("aggregation: output file: coarse graph edges","aggregation: output file: coarse graph edges")
729 
730  ("aggregation: output file: build colormap","aggregation: output file: build colormap")
731 
732  ("aggregation: output file: aggregate qualities","aggregation: output file: aggregate qualities")
733 
734  ("aggregation: output file: material","aggregation: output file: material")
735 
736  ("aggregation: params","aggregation: params")
737 
738  ("strength-of-connection: params","strength-of-connection: params")
739 
740  ("aggregation: mesh layout","aggregation: mesh layout")
741 
742  ("aggregation: output type","aggregation: output type")
743 
744  ("aggregation: coarsening rate","aggregation: coarsening rate")
745 
746  ("aggregation: number of spatial dimensions","aggregation: number of spatial dimensions")
747 
748  ("aggregation: coarsening order","aggregation: coarsening order")
749 
750  ("aggregation: pairwise: size","aggregation: pairwise: size")
751 
752  ("aggregation: pairwise: tie threshold","aggregation: pairwise: tie threshold")
753 
754  ("aggregate qualities: check symmetry","aggregate qualities: check symmetry")
755 
756  ("aggregate qualities: good aggregate threshold","aggregate qualities: good aggregate threshold")
757 
758  ("aggregate qualities: file output","aggregate qualities: file output")
759 
760  ("aggregate qualities: file base","aggregate qualities: file base")
761 
762  ("aggregate qualities: algorithm","aggregate qualities: algorithm")
763 
764  ("aggregate qualities: zero threshold","aggregate qualities: zero threshold")
765 
766  ("aggregate qualities: percentiles","aggregate qualities: percentiles")
767 
768  ("aggregate qualities: mode","aggregate qualities: mode")
769 
770  ("export data","export data")
771 
772  ("keep data","keep data")
773 
774  ("ML print initial list","print initial parameters")
775 
776  ("print unused","print unused parameters")
777 
778  ("transpose: use implicit","transpose: use implicit")
779 
780  ("transfers: half precision","transfers: half precision")
781 
782  ("nullspace: calculate rotations","nullspace: calculate rotations")
783 
784  ("nullspace: suppress dimension check","nullspace: suppress dimension check")
785 
786  ("restriction: scale nullspace","restriction: scale nullspace")
787 
788  ("use kokkos refactor","use kokkos refactor")
789 
790  ("synchronize factory timers","synchronize factory timers")
791 
792  ("rap: triple product","rap: triple product")
793 
794  ("energy minimization: enable","multigrid algorithm")
795 
796  ("toggle: mode","toggle: mode")
797 
798  ("semicoarsen: coarsen rate","semicoarsen: coarsen rate")
799 
800  ("semicoarsen: piecewise constant","semicoarsen: piecewise constant")
801 
802  ("semicoarsen: piecewise linear","semicoarsen: piecewise linear")
803 
804  ("semicoarsen: calculate nonsym restriction","semicoarsen: calculate nonsym restriction")
805 
806  ("semicoarsen: number of levels","semicoarsen: number of levels")
807 
808  ("linedetection: orientation","linedetection: orientation")
809 
810  ("linedetection: num layers","linedetection: num layers")
811 
812  ("aggregation: damping factor","sa: damping factor")
813 
814  ("aggregation aux: enable","sa: use filtered matrix")
815 
816  ("sa: calculate eigenvalue estimate","sa: calculate eigenvalue estimate")
817 
818  ("sa: eigen-analysis type","sa: eigen-analysis type")
819 
820  ("eigen-analysis: iterations","sa: eigenvalue estimate num iterations")
821 
822  ("not supported by ML","sa: use rowsumabs diagonal scaling")
823 
824  ("not supported by ML","sa: enforce constraints")
825 
826  ("not supported by ML","sa: max eigenvalue")
827 
828  ("not supported by ML","sa: rowsumabs diagonal replacement tolerance")
829 
830  ("not supported by ML","sa: rowsumabs use automatic diagonal tolerance")
831 
832  ("not supported by ML","sa: rowsumabs diagonal replacement value")
833 
834  ("not supported by ML","sa: rowsumabs replace single entry row with zero")
835 
836  ("not supported by ML","replicate: npdes")
837 
838  ("not supported by ML","combine: numBlks")
839 
840  ("interp: build coarse coordinates","interp: build coarse coordinates")
841 
842  ("transfer: params","transfer: params")
843 
844  ("pcoarsen: element","pcoarsen: element")
845 
846  ("pcoarsen: schedule","pcoarsen: schedule")
847 
848  ("pcoarsen: hi basis","pcoarsen: hi basis")
849 
850  ("pcoarsen: lo basis","pcoarsen: lo basis")
851 
852  ("smoother: neighborhood type","smoother: neighborhood type")
853 
854  ("filtered matrix: use lumping","filtered matrix: use lumping")
855 
856  ("filtered matrix: lumping choice","filtered matrix: lumping choice")
857 
858  ("filtered matrix: use spread lumping","filtered matrix: use spread lumping")
859 
860  ("filtered matrix: spread lumping diag dom growth factor","filtered matrix: spread lumping diag dom growth factor")
861 
862  ("filtered matrix: spread lumping diag dom cap","filtered matrix: spread lumping diag dom cap")
863 
864  ("filtered matrix: use root stencil","filtered matrix: use root stencil")
865 
866  ("filtered matrix: Dirichlet threshold","filtered matrix: Dirichlet threshold")
867 
868  ("filtered matrix: reuse eigenvalue","filtered matrix: reuse eigenvalue")
869 
870  ("filtered matrix: reuse graph","filtered matrix: reuse graph")
871 
872  ("matrix: compute analysis","matrix: compute analysis")
873 
874  ("emin: iterative method","emin: iterative method")
875 
876  ("emin: num iterations","emin: num iterations")
877 
878  ("emin: num reuse iterations","emin: num reuse iterations")
879 
880  ("emin: pattern","emin: pattern")
881 
882  ("emin: pattern order","emin: pattern order")
883 
884  ("emin: use filtered matrix","emin: use filtered matrix")
885 
886  ("tentative: calculate qr","tentative: calculate qr")
887 
888  ("tentative: constant column sums","tentative: constant column sums")
889 
890  ("tentative: build coarse coordinates","tentative: build coarse coordinates")
891 
892  ("repartition: enable","repartition: enable")
893 
894  ("repartition: partitioner","repartition: partitioner")
895 
896  ("repartition: params","repartition: params")
897 
898  ("repartition: start level","repartition: start level")
899 
900  ("repartition: use map","repartition: use map")
901 
902  ("repartition: use subcommunicators in place","repartition: use subcommunicators in place")
903 
904  ("repartition: node repartition level","repartition: node repartition level")
905 
906  ("repartition: node id","repartition: node id")
907 
908  ("repartition: min per proc","repartition: min rows per proc")
909 
910  ("repartition: target rows per proc","repartition: target rows per proc")
911 
912  ("repartition: min rows per thread","repartition: min rows per thread")
913 
914  ("repartition: target rows per thread","repartition: target rows per thread")
915 
916  ("repartition: max min ratio","repartition: max imbalance")
917 
918  ("repartition: remap parts","repartition: remap parts")
919 
920  ("repartition: remap num values","repartition: remap num values")
921 
922  ("repartition: remap accept partition","repartition: remap accept partition")
923 
924  ("repartition: print partition distribution","repartition: print partition distribution")
925 
926  ("repartition: rebalance P and R","repartition: rebalance P and R")
927 
928  ("repartition: explicit via new copy rebalance P and R","repartition: explicit via new copy rebalance P and R")
929 
930  ("repartition: rebalance Nullspace","repartition: rebalance Nullspace")
931 
932  ("repartition: use subcommunicators","repartition: use subcommunicators")
933 
934  ("repartition: save importer","repartition: save importer")
935 
936  ("repartition: put on single proc","repartition: put on single proc")
937 
938  ("repartition: send type","repartition: send type")
939 
940  ("rap: relative diagonal floor","rap: relative diagonal floor")
941 
942  ("rap: fix zero diagonals","rap: fix zero diagonals")
943 
944  ("rap: fix zero diagonals threshold","rap: fix zero diagonals threshold")
945 
946  ("rap: fix zero diagonals replacement","rap: fix zero diagonals replacement")
947 
948  ("rap: shift","rap: shift")
949 
950  ("rap: shift diagonal M","rap: shift diagonal M")
951 
952  ("rap: shift low storage","rap: shift low storage")
953 
954  ("rap: shift array","rap: shift array")
955 
956  ("rap: cfl array","rap: cfl array")
957 
958  ("rap: algorithm","rap: algorithm")
959 
960  ("matrixmatrix: kernel params","matrixmatrix: kernel params")
961 
962  ("matrixmatrix: kernel params:MM_TAFC_OptimizationCoreCount ","matrixmatrix: kernel params:MM_TAFC_OptimizationCoreCount ")
963 
964  ("isMatrixMatrix_TransferAndFillComplete ","isMatrixMatrix_TransferAndFillComplete ")
965 
966  ("reuse: type","reuse: type")
967 
968  ("use external multigrid package","use external multigrid package")
969 
970  ("amgx:params","amgx:params")
971 
972  ("kokkos tuning: muelu parameter mapping","kokkos tuning: muelu parameter mapping")
973 
974  ("debug: graph level","debug: graph level")
975 
976  ("maxwell1: mode","maxwell1: mode")
977 
978  ("maxwell1: 11list","maxwell1: 11list")
979 
980  ("maxwell1: 22list","maxwell1: 22list")
981 
982  ("maxwell1: dump matrices","maxwell1: dump matrices")
983 
984  ("maxwell1: nodal smoother fix zero diagonal threshold","maxwell1: nodal smoother fix zero diagonal threshold")
985 
986  ("refmaxwell: mode","refmaxwell: mode")
987 
988  ("refmaxwell: disable addon","refmaxwell: disable addon")
989 
990  ("refmaxwell: 11list","refmaxwell: 11list")
991 
992  ("refmaxwell: 22list","refmaxwell: 22list")
993 
994  ("zero starting solution","refmaxwell: use as preconditioner")
995 
996  ("refmaxwell: dump matrices","refmaxwell: dump matrices")
997 
998  ("refmaxwell: subsolves on subcommunicators","refmaxwell: subsolves on subcommunicators")
999 
1000  ("refmaxwell: enable reuse","refmaxwell: enable reuse")
1001 
1002  ("refmaxwell: skip first (1,1) level","refmaxwell: skip first (1,1) level")
1003 
1004  ("refmaxwell: normalize nullspace","refmaxwell: normalize nullspace")
1005  ;
1006 
1007 }
1008 
static std::map< std::string, std::string > ML2MueLuLists_
Map of ML parameter strings to corresponding MueLu parametes.
static const std::string stringList_
String equivalent of the masterList_.
static Teuchos::RCP< Teuchos::ParameterList > problemSpecificList_
A ParameterList that holds all valid parameters and their default values for a particular problem typ...
static std::string interpretParameterName(const std::string &name, const std::string &value)
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
static Teuchos::RCP< Teuchos::ParameterList > masterList_
A ParameterList that holds all valid parameters and their default values.
static Teuchos::RCP< Teuchos::ParameterList > GetProblemSpecificList(std::string const &problemType)
Return default parameter settings for the specified problem type.
Exception throws to report errors in the internal logical of the program.
static Teuchos::RCP< const Teuchos::ParameterList > List()
Return a &quot;master&quot; list of all valid parameters and their default values.
Helper class to initialize DefaultProblemTypeLists_ in class MasterList.
static std::map< std::string, std::string > DefaultProblemTypeLists_
Map of string equivalents of the problemSpecificList_. The first entry is the problem type...
static std::string problemType_
The problem type associated with the current problem-specific ParameterList.
bool is_null() const