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=\"false\"/>"
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: use spread lumping\" type=\"bool\" value=\"false\"/>"
292  "<Parameter name=\"filtered matrix: spread lumping diag dom growth factor\" type=\"double\" value=\"1.1\"/>"
293  "<Parameter name=\"filtered matrix: spread lumping diag dom cap\" type=\"double\" value=\"2.0\"/>"
294  "<Parameter name=\"filtered matrix: use root stencil\" type=\"bool\" value=\"false\"/>"
295  "<Parameter name=\"filtered matrix: Dirichlet threshold\" type=\"double\" value=\"-1.0\"/>"
296  "<Parameter name=\"filtered matrix: reuse eigenvalue\" type=\"bool\" value=\"true\"/>"
297  "<Parameter name=\"filtered matrix: reuse graph\" type=\"bool\" value=\"true\"/>"
298  "<Parameter name=\"matrix: compute analysis\" type=\"bool\" value=\"false\"/>"
299  "<Parameter name=\"emin: iterative method\" type=\"string\" value=\"cg\"/>"
300  "<Parameter name=\"emin: num iterations\" type=\"int\" value=\"2\"/>"
301  "<Parameter name=\"emin: num reuse iterations\" type=\"int\" value=\"1\"/>"
302  "<Parameter name=\"emin: pattern\" type=\"string\" value=\"AkPtent\"/>"
303  "<Parameter name=\"emin: pattern order\" type=\"int\" value=\"1\"/>"
304  "<Parameter name=\"emin: use filtered matrix\" type=\"bool\" value=\"true\"/>"
305  "<Parameter name=\"tentative: calculate qr\" type=\"bool\" value=\"true\"/>"
306  "<Parameter name=\"tentative: constant column sums\" type=\"bool\" value=\"false\"/>"
307  "<Parameter name=\"tentative: build coarse coordinates\" type=\"bool\" value=\"true\"/>"
308  "<Parameter name=\"repartition: enable\" type=\"bool\" value=\"false\"/>"
309  "<Parameter name=\"repartition: partitioner\" type=\"string\" value=\"zoltan2\"/>"
310  "<ParameterList name=\"repartition: params\"/>"
311  "<Parameter name=\"repartition: start level\" type=\"int\" value=\"2\"/>"
312  "<Parameter name=\"repartition: use map\" type=\"bool\" value=\"false\"/>"
313  "<Parameter name=\"repartition: use subcommunicators in place\" type=\"bool\" value=\"false\"/>"
314  "<Parameter name=\"repartition: node repartition level\" type=\"int\" value=\"-1\"/>"
315  "<Parameter name=\"repartition: node id\" type=\"int\" value=\"-1\"/>"
316  "<Parameter name=\"repartition: min rows per proc\" type=\"int\" value=\"800\"/>"
317  "<Parameter name=\"repartition: target rows per proc\" type=\"int\" value=\"0\"/>"
318  "<Parameter name=\"repartition: min rows per thread\" type=\"int\" value=\"0\"/>"
319  "<Parameter name=\"repartition: target rows per thread\" type=\"int\" value=\"0\"/>"
320  "<Parameter name=\"repartition: max imbalance\" type=\"double\" value=\"1.2\"/>"
321  "<Parameter name=\"repartition: remap parts\" type=\"bool\" value=\"true\"/>"
322  "<Parameter name=\"repartition: remap num values\" type=\"int\" value=\"4\"/>"
323  "<Parameter name=\"repartition: remap accept partition\" type=\"bool\" value=\"true\"/>"
324  "<Parameter name=\"repartition: print partition distribution\" type=\"bool\" value=\"false\"/>"
325  "<Parameter name=\"repartition: rebalance P and R\" type=\"bool\" value=\"false\"/>"
326  "<Parameter name=\"repartition: explicit via new copy rebalance P and R\" type=\"bool\" value=\"false\"/>"
327  "<Parameter name=\"repartition: rebalance Nullspace\" type=\"bool\" value=\"true\"/>"
328  "<Parameter name=\"repartition: use subcommunicators\" type=\"bool\" value=\"true\"/>"
329  "<Parameter name=\"repartition: save importer\" type=\"bool\" value=\"false\"/>"
330  "<Parameter name=\"repartition: put on single proc\" type=\"int\" value=\"0\"/>"
331  "<Parameter name=\"repartition: send type\" type=\"string\" value=\"\"/>"
332  "<Parameter name=\"rap: relative diagonal floor\" type=\"Array(double)\" value=\"{}\"/>"
333  "<Parameter name=\"rap: fix zero diagonals\" type=\"bool\" value=\"false\"/>"
334  "<Parameter name=\"rap: fix zero diagonals threshold\" type=\"double\" value=\"0.\"/>"
335  "<Parameter name=\"rap: fix zero diagonals replacement\" type=\"double\" value=\"1.\"/>"
336  "<Parameter name=\"rap: shift\" type=\"double\" value=\"0.0\"/>"
337  "<Parameter name=\"rap: shift diagonal M\" type=\"bool\" value=\"false\"/>"
338  "<Parameter name=\"rap: shift low storage\" type=\"bool\" value=\"false\"/>"
339  "<Parameter name=\"rap: shift array\" type=\"Array(double)\" value=\"{}\"/>"
340  "<Parameter name=\"rap: cfl array\" type=\"Array(double)\" value=\"{}\"/>"
341  "<Parameter name=\"rap: algorithm\" type=\"string\" value=\"galerkin\"/>"
342  "<ParameterList name=\"matrixmatrix: kernel params\"/>"
343  "<Parameter name=\"matrixmatrix: kernel params:MM_TAFC_OptimizationCoreCount \" type=\"int\" value=\"3000 \"/>"
344  "<Parameter name=\"isMatrixMatrix_TransferAndFillComplete \" type=\"bool\" value=\"false\"/>"
345  "<Parameter name=\"reuse: type\" type=\"string\" value=\"none\"/>"
346  "<Parameter name=\"use external multigrid package\" type=\"string\" value=\"none\"/>"
347  "<ParameterList name=\"amgx:params\"/>"
348  "<ParameterList name=\"kokkos tuning: muelu parameter mapping\"/>"
349  "<Parameter name=\"debug: graph level\" type=\"int\" value=\"-2\"/>"
350  "<Parameter name=\"maxwell1: mode\" type=\"string\" value=\"standard\"/>"
351  "<ParameterList name=\"maxwell1: 11list\"/>"
352  "<ParameterList name=\"maxwell1: 22list\"/>"
353  "<Parameter name=\"maxwell1: dump matrices\" type=\"bool\" value=\"false\"/>"
354  "<Parameter name=\"maxwell1: nodal smoother fix zero diagonal threshold\" type=\"double\" value=\"1e-10\"/>"
355  "<Parameter name=\"refmaxwell: mode\" type=\"string\" value=\"additive\"/>"
356  "<Parameter name=\"refmaxwell: disable addon\" type=\"bool\" value=\"true\"/>"
357  "<ParameterList name=\"refmaxwell: 11list\"/>"
358  "<ParameterList name=\"refmaxwell: 22list\"/>"
359  "<Parameter name=\"refmaxwell: use as preconditioner\" type=\"bool\" value=\"false\"/>"
360  "<Parameter name=\"refmaxwell: dump matrices\" type=\"bool\" value=\"false\"/>"
361  "<Parameter name=\"refmaxwell: subsolves on subcommunicators\" type=\"bool\" value=\"false\"/>"
362  "<Parameter name=\"refmaxwell: enable reuse\" type=\"bool\" value=\"false\"/>"
363  "<Parameter name=\"refmaxwell: skip first (1,1) level\" type=\"bool\" value=\"true\"/>"
364  "<Parameter name=\"refmaxwell: normalize nullspace\" type=\"bool\" value=\"false\"/>"
365 "</ParameterList>"
366 ;
368 ("Poisson-2D",
369 
370  "<ParameterList name=\"MueLu\">"
371 
372  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
373 
374  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
375 
376  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
377 
378  "</ParameterList>"
379  )
380 ("Poisson-2D-complex",
381 
382  "<ParameterList name=\"MueLu\">"
383 
384  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
385 
386  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
387 
388  "<ParameterList name=\"smoother: params\">"
389 
390  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
391 
392  "</ParameterList>"
393 
394  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
395 
396  "</ParameterList>"
397  )
398 ("Poisson-3D",
399 
400  "<ParameterList name=\"MueLu\">"
401 
402  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
403 
404  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
405 
406  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
407 
408  "</ParameterList>"
409  )
410 ("Poisson-3D-complex",
411 
412  "<ParameterList name=\"MueLu\">"
413 
414  "<Parameter name=\"number of equations\" type=\"int\" value=\"1\"/>"
415 
416  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
417 
418  "<ParameterList name=\"smoother: params\">"
419 
420  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
421 
422  "</ParameterList>"
423 
424  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
425 
426  "</ParameterList>"
427  )
428 ("Elasticity-2D",
429 
430  "<ParameterList name=\"MueLu\">"
431 
432  "<Parameter name=\"number of equations\" type=\"int\" value=\"2\"/>"
433 
434  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
435 
436  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
437 
438  "</ParameterList>"
439  )
440 ("Elasticity-2D-complex",
441 
442  "<ParameterList name=\"MueLu\">"
443 
444  "<Parameter name=\"number of equations\" type=\"int\" value=\"2\"/>"
445 
446  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
447 
448  "<ParameterList name=\"smoother: params\">"
449 
450  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
451 
452  "</ParameterList>"
453 
454  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
455 
456  "</ParameterList>"
457  )
458 ("Elasticity-3D",
459 
460  "<ParameterList name=\"MueLu\">"
461 
462  "<Parameter name=\"number of equations\" type=\"int\" value=\"3\"/>"
463 
464  "<Parameter name=\"smoother: type\" type=\"string\" value=\"CHEBYSHEV\"/>"
465 
466  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
467 
468  "</ParameterList>"
469  )
470 ("Elasticity-3D-complex",
471 
472  "<ParameterList name=\"MueLu\">"
473 
474  "<Parameter name=\"number of equations\" type=\"int\" value=\"3\"/>"
475 
476  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
477 
478  "<ParameterList name=\"smoother: params\">"
479 
480  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Symmetric Gauss-Seidel\"/>"
481 
482  "</ParameterList>"
483 
484  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"sa\"/>"
485 
486  "</ParameterList>"
487  )
488 ("MHD",
489 
490  "<ParameterList name=\"MueLu\">"
491 
492  "<Parameter name=\"smoother: type\" type=\"string\" value=\"SCHWARZ\"/>"
493 
494  "<ParameterList name=\"smoother: params\">"
495 
496  "<Parameter name=\"schwarz: overlap level\" type=\"int\" value=\"1\"/>"
497 
498  "<Parameter name=\"schwarz: combine mode\" type=\"string\" value=\"Zero\"/>"
499 
500  "<Parameter name=\"schwarz: use reordering\" type=\"bool\" value=\"false\"/>"
501 
502  "<Parameter name=\"subdomain solver name\" type=\"string\" value=\"RILUK\"/>"
503 
504  "<ParameterList name=\"subdomain solver parameters\">"
505 
506  "<Parameter name=\"fact: iluk level-of-fill\" type=\"int\" value=\"0\"/>"
507 
508  "<Parameter name=\"fact: absolute threshold\" type=\"double\" value=\"0.\"/>"
509 
510  "<Parameter name=\"fact: relative threshold\" type=\"double\" value=\"1.\"/>"
511 
512  "<Parameter name=\"fact: relax value\" type=\"double\" value=\"0.\"/>"
513 
514  "</ParameterList>"
515 
516  "</ParameterList>"
517 
518  "<Parameter name=\"transpose: use implicit\" type=\"bool\" value=\"true\"/>"
519 
520  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"unsmoothed\"/>"
521 
522  "</ParameterList>"
523  )
524 ("ConvectionDiffusion",
525 
526  "<ParameterList name=\"MueLu\">"
527 
528  "<Parameter name=\"problem: symmetric\" type=\"bool\" value=\"false\"/>"
529 
530  "<Parameter name=\"smoother: type\" type=\"string\" value=\"RELAXATION\"/>"
531 
532  "<ParameterList name=\"smoother: params\">"
533 
534  "<Parameter name=\"relaxation: type\" type=\"string\" value=\"Gauss-Seidel\"/>"
535 
536  "</ParameterList>"
537 
538  "<Parameter name=\"multigrid algorithm\" type=\"string\" value=\"pg\"/>"
539 
540  "<Parameter name=\"sa: use filtered matrix\" type=\"bool\" value=\"true\"/>"
541 
542  "<Parameter name=\"emin: use filtered matrix\" type=\"bool\" value=\"true\"/>"
543 
544  "</ParameterList>"
545  )
546 ;
548 
549  ("default values","problem: type")
550 
551  ("ML output","verbosity")
552 
553  ("output filename","output filename")
554 
555  ("PDE equations","number of equations")
556 
557  ("max levels","max levels")
558 
559  ("prec type","cycle type")
560 
561  ("W cycle start level","W cycle start level")
562 
563  ("coarse grid correction scaling factor","coarse grid correction scaling factor")
564 
565  ("fuse prolongation and update","fuse prolongation and update")
566 
567  ("number of vectors","number of vectors")
568 
569  ("problem: symmetric","problem: symmetric")
570 
571  ("xml parameter file","xml parameter file")
572 
573  ("parameterlist: syntax","parameterlist: syntax")
574 
575  ("ML label","hierarchy label")
576 
577  ("matvec params","matvec params")
578 
579  ("half precision","half precision")
580 
581  ("smoother: pre or post","smoother: pre or post")
582 
583  ("smoother: type","smoother: type")
584 
585  ("smoother: pre type","smoother: pre type")
586 
587  ("smoother: post type","smoother: post type")
588 
589  ("smoother: params","smoother: params")
590 
591  ("smoother: pre params","smoother: pre params")
592 
593  ("smoother: post params","smoother: post params")
594 
595  ("smoother: overlap","smoother: overlap")
596 
597  ("smoother: pre overlap","smoother: pre overlap")
598 
599  ("smoother: post overlap","smoother: post overlap")
600 
601  ("max size","coarse: max size")
602 
603  ("coarse: type","coarse: type")
604 
605  ("coarse: params","coarse: params")
606 
607  ("coarse: overlap","coarse: overlap")
608 
609  ("aggregation: backend","aggregation: backend")
610 
611  ("aggregation: type","aggregation: type")
612 
613  ("aggregation: mode","aggregation: mode")
614 
615  ("aggregation: ordering","aggregation: ordering")
616 
617  ("aggregation: phase 1 algorithm","aggregation: phase 1 algorithm")
618 
619  ("aggregation: symmetrize graph after dropping","aggregation: symmetrize graph after dropping")
620 
621  ("aggregation: use blocking","aggregation: use blocking")
622 
623  ("aggregation: drop scheme","aggregation: drop scheme")
624 
625  ("aggregation: strength-of-connection: matrix","aggregation: strength-of-connection: matrix")
626 
627  ("aggregation: strength-of-connection: measure","aggregation: strength-of-connection: measure")
628 
629  ("aggregation: classical scheme","aggregation: classical scheme")
630 
631  ("aggregation: row sum drop tol","aggregation: row sum drop tol")
632 
633  ("aggregation: block diagonal: interleaved blocksize","aggregation: block diagonal: interleaved blocksize")
634 
635  ("aggregation: number of random vectors","aggregation: number of random vectors")
636 
637  ("aggregation: number of times to pre or post smooth","aggregation: number of times to pre or post smooth")
638 
639  ("aggregation: penalty parameters","aggregation: penalty parameters")
640 
641  ("aggregation: distance laplacian directional weights","aggregation: distance laplacian directional weights")
642 
643  ("aggregation: distance laplacian algo","aggregation: distance laplacian algo")
644 
645  ("aggregation: distance laplacian metric","aggregation: distance laplacian metric")
646 
647  ("aggregation: classical algo","aggregation: classical algo")
648 
649  ("aggregation: threshold","aggregation: drop tol")
650 
651  ("aggregation: use ml scaling of drop tol","aggregation: use ml scaling of drop tol")
652 
653  ("aggregation: min agg size","aggregation: min agg size")
654 
655  ("aggregation: max agg size","aggregation: max agg size")
656 
657  ("aggregation: compute aggregate qualities","aggregation: compute aggregate qualities")
658 
659  ("aggregation: brick x size","aggregation: brick x size")
660 
661  ("aggregation: brick y size","aggregation: brick y size")
662 
663  ("aggregation: brick z size","aggregation: brick z size")
664 
665  ("aggregation: brick x Dirichlet","aggregation: brick x Dirichlet")
666 
667  ("aggregation: brick y Dirichlet","aggregation: brick y Dirichlet")
668 
669  ("aggregation: brick z Dirichlet","aggregation: brick z Dirichlet")
670 
671  ("aggregation: max selected neighbors","aggregation: max selected neighbors")
672 
673  ("aggregation: Dirichlet threshold","aggregation: Dirichlet threshold")
674 
675  ("aggregation: greedy Dirichlet","aggregation: greedy Dirichlet")
676 
677  ("aggregation: deterministic","aggregation: deterministic")
678 
679  ("aggregation: coloring algorithm","aggregation: coloring algorithm")
680 
681  ("aggregation: coloring: use color graph","aggregation: coloring: use color graph")
682 
683  ("aggregation: coloring: localize color graph","aggregation: coloring: localize color graph")
684 
685  ("aggregation: enable phase 1","aggregation: enable phase 1")
686 
687  ("aggregation: enable phase 2a","aggregation: enable phase 2a")
688 
689  ("aggregation: enable phase 2b","aggregation: enable phase 2b")
690 
691  ("aggregation: enable phase 3","aggregation: enable phase 3")
692 
693  ("aggregation: match ML phase1","aggregation: match ML phase1")
694 
695  ("aggregation: match ML phase2a","aggregation: match ML phase2a")
696 
697  ("aggregation: match ML phase2b","aggregation: match ML phase2b")
698 
699  ("aggregation: phase2a agg factor","aggregation: phase2a agg factor")
700 
701  ("aggregation: error on nodes with no on-rank neighbors","aggregation: error on nodes with no on-rank neighbors")
702 
703  ("aggregation: phase3 avoid singletons","aggregation: phase3 avoid singletons")
704 
705  ("aggregation: allow empty prolongator columns","aggregation: allow empty prolongator columns")
706 
707  ("aggregation: preserve Dirichlet points","aggregation: preserve Dirichlet points")
708 
709  ("aggregation: dropping may create Dirichlet","aggregation: dropping may create Dirichlet")
710 
711  ("aggregation: allow user-specified singletons","aggregation: allow user-specified singletons")
712 
713  ("aggregation: use interface aggregation","aggregation: use interface aggregation")
714 
715  ("aggregation: export visualization data","aggregation: export visualization data")
716 
717  ("aggregation: output filename","aggregation: output filename")
718 
719  ("aggregation: output file: time step","aggregation: output file: time step")
720 
721  ("aggregation: output file: iter","aggregation: output file: iter")
722 
723  ("aggregation: output file: agg style","aggregation: output file: agg style")
724 
725  ("aggregation: output file: fine graph edges","aggregation: output file: fine graph edges")
726 
727  ("aggregation: output file: coarse graph edges","aggregation: output file: coarse graph edges")
728 
729  ("aggregation: output file: build colormap","aggregation: output file: build colormap")
730 
731  ("aggregation: output file: aggregate qualities","aggregation: output file: aggregate qualities")
732 
733  ("aggregation: output file: material","aggregation: output file: material")
734 
735  ("aggregation: params","aggregation: params")
736 
737  ("strength-of-connection: params","strength-of-connection: params")
738 
739  ("aggregation: mesh layout","aggregation: mesh layout")
740 
741  ("aggregation: output type","aggregation: output type")
742 
743  ("aggregation: coarsening rate","aggregation: coarsening rate")
744 
745  ("aggregation: number of spatial dimensions","aggregation: number of spatial dimensions")
746 
747  ("aggregation: coarsening order","aggregation: coarsening order")
748 
749  ("aggregation: pairwise: size","aggregation: pairwise: size")
750 
751  ("aggregation: pairwise: tie threshold","aggregation: pairwise: tie threshold")
752 
753  ("aggregate qualities: check symmetry","aggregate qualities: check symmetry")
754 
755  ("aggregate qualities: good aggregate threshold","aggregate qualities: good aggregate threshold")
756 
757  ("aggregate qualities: file output","aggregate qualities: file output")
758 
759  ("aggregate qualities: file base","aggregate qualities: file base")
760 
761  ("aggregate qualities: algorithm","aggregate qualities: algorithm")
762 
763  ("aggregate qualities: zero threshold","aggregate qualities: zero threshold")
764 
765  ("aggregate qualities: percentiles","aggregate qualities: percentiles")
766 
767  ("aggregate qualities: mode","aggregate qualities: mode")
768 
769  ("export data","export data")
770 
771  ("keep data","keep data")
772 
773  ("ML print initial list","print initial parameters")
774 
775  ("print unused","print unused parameters")
776 
777  ("transpose: use implicit","transpose: use implicit")
778 
779  ("transfers: half precision","transfers: half precision")
780 
781  ("nullspace: calculate rotations","nullspace: calculate rotations")
782 
783  ("nullspace: suppress dimension check","nullspace: suppress dimension check")
784 
785  ("restriction: scale nullspace","restriction: scale nullspace")
786 
787  ("use kokkos refactor","use kokkos refactor")
788 
789  ("synchronize factory timers","synchronize factory timers")
790 
791  ("rap: triple product","rap: triple product")
792 
793  ("energy minimization: enable","multigrid algorithm")
794 
795  ("toggle: mode","toggle: mode")
796 
797  ("semicoarsen: coarsen rate","semicoarsen: coarsen rate")
798 
799  ("semicoarsen: piecewise constant","semicoarsen: piecewise constant")
800 
801  ("semicoarsen: piecewise linear","semicoarsen: piecewise linear")
802 
803  ("semicoarsen: calculate nonsym restriction","semicoarsen: calculate nonsym restriction")
804 
805  ("semicoarsen: number of levels","semicoarsen: number of levels")
806 
807  ("linedetection: orientation","linedetection: orientation")
808 
809  ("linedetection: num layers","linedetection: num layers")
810 
811  ("aggregation: damping factor","sa: damping factor")
812 
813  ("aggregation aux: enable","sa: use filtered matrix")
814 
815  ("sa: calculate eigenvalue estimate","sa: calculate eigenvalue estimate")
816 
817  ("sa: eigen-analysis type","sa: eigen-analysis type")
818 
819  ("eigen-analysis: iterations","sa: eigenvalue estimate num iterations")
820 
821  ("not supported by ML","sa: use rowsumabs diagonal scaling")
822 
823  ("not supported by ML","sa: enforce constraints")
824 
825  ("not supported by ML","sa: max eigenvalue")
826 
827  ("not supported by ML","sa: rowsumabs diagonal replacement tolerance")
828 
829  ("not supported by ML","sa: rowsumabs use automatic diagonal tolerance")
830 
831  ("not supported by ML","sa: rowsumabs diagonal replacement value")
832 
833  ("not supported by ML","sa: rowsumabs replace single entry row with zero")
834 
835  ("not supported by ML","replicate: npdes")
836 
837  ("not supported by ML","combine: numBlks")
838 
839  ("interp: build coarse coordinates","interp: build coarse coordinates")
840 
841  ("transfer: params","transfer: params")
842 
843  ("pcoarsen: element","pcoarsen: element")
844 
845  ("pcoarsen: schedule","pcoarsen: schedule")
846 
847  ("pcoarsen: hi basis","pcoarsen: hi basis")
848 
849  ("pcoarsen: lo basis","pcoarsen: lo basis")
850 
851  ("smoother: neighborhood type","smoother: neighborhood type")
852 
853  ("filtered matrix: use lumping","filtered matrix: use lumping")
854 
855  ("filtered matrix: use spread lumping","filtered matrix: use spread lumping")
856 
857  ("filtered matrix: spread lumping diag dom growth factor","filtered matrix: spread lumping diag dom growth factor")
858 
859  ("filtered matrix: spread lumping diag dom cap","filtered matrix: spread lumping diag dom cap")
860 
861  ("filtered matrix: use root stencil","filtered matrix: use root stencil")
862 
863  ("filtered matrix: Dirichlet threshold","filtered matrix: Dirichlet threshold")
864 
865  ("filtered matrix: reuse eigenvalue","filtered matrix: reuse eigenvalue")
866 
867  ("filtered matrix: reuse graph","filtered matrix: reuse graph")
868 
869  ("matrix: compute analysis","matrix: compute analysis")
870 
871  ("emin: iterative method","emin: iterative method")
872 
873  ("emin: num iterations","emin: num iterations")
874 
875  ("emin: num reuse iterations","emin: num reuse iterations")
876 
877  ("emin: pattern","emin: pattern")
878 
879  ("emin: pattern order","emin: pattern order")
880 
881  ("emin: use filtered matrix","emin: use filtered matrix")
882 
883  ("tentative: calculate qr","tentative: calculate qr")
884 
885  ("tentative: constant column sums","tentative: constant column sums")
886 
887  ("tentative: build coarse coordinates","tentative: build coarse coordinates")
888 
889  ("repartition: enable","repartition: enable")
890 
891  ("repartition: partitioner","repartition: partitioner")
892 
893  ("repartition: params","repartition: params")
894 
895  ("repartition: start level","repartition: start level")
896 
897  ("repartition: use map","repartition: use map")
898 
899  ("repartition: use subcommunicators in place","repartition: use subcommunicators in place")
900 
901  ("repartition: node repartition level","repartition: node repartition level")
902 
903  ("repartition: node id","repartition: node id")
904 
905  ("repartition: min per proc","repartition: min rows per proc")
906 
907  ("repartition: target rows per proc","repartition: target rows per proc")
908 
909  ("repartition: min rows per thread","repartition: min rows per thread")
910 
911  ("repartition: target rows per thread","repartition: target rows per thread")
912 
913  ("repartition: max min ratio","repartition: max imbalance")
914 
915  ("repartition: remap parts","repartition: remap parts")
916 
917  ("repartition: remap num values","repartition: remap num values")
918 
919  ("repartition: remap accept partition","repartition: remap accept partition")
920 
921  ("repartition: print partition distribution","repartition: print partition distribution")
922 
923  ("repartition: rebalance P and R","repartition: rebalance P and R")
924 
925  ("repartition: explicit via new copy rebalance P and R","repartition: explicit via new copy rebalance P and R")
926 
927  ("repartition: rebalance Nullspace","repartition: rebalance Nullspace")
928 
929  ("repartition: use subcommunicators","repartition: use subcommunicators")
930 
931  ("repartition: save importer","repartition: save importer")
932 
933  ("repartition: put on single proc","repartition: put on single proc")
934 
935  ("repartition: send type","repartition: send type")
936 
937  ("rap: relative diagonal floor","rap: relative diagonal floor")
938 
939  ("rap: fix zero diagonals","rap: fix zero diagonals")
940 
941  ("rap: fix zero diagonals threshold","rap: fix zero diagonals threshold")
942 
943  ("rap: fix zero diagonals replacement","rap: fix zero diagonals replacement")
944 
945  ("rap: shift","rap: shift")
946 
947  ("rap: shift diagonal M","rap: shift diagonal M")
948 
949  ("rap: shift low storage","rap: shift low storage")
950 
951  ("rap: shift array","rap: shift array")
952 
953  ("rap: cfl array","rap: cfl array")
954 
955  ("rap: algorithm","rap: algorithm")
956 
957  ("matrixmatrix: kernel params","matrixmatrix: kernel params")
958 
959  ("matrixmatrix: kernel params:MM_TAFC_OptimizationCoreCount ","matrixmatrix: kernel params:MM_TAFC_OptimizationCoreCount ")
960 
961  ("isMatrixMatrix_TransferAndFillComplete ","isMatrixMatrix_TransferAndFillComplete ")
962 
963  ("reuse: type","reuse: type")
964 
965  ("use external multigrid package","use external multigrid package")
966 
967  ("amgx:params","amgx:params")
968 
969  ("kokkos tuning: muelu parameter mapping","kokkos tuning: muelu parameter mapping")
970 
971  ("debug: graph level","debug: graph level")
972 
973  ("maxwell1: mode","maxwell1: mode")
974 
975  ("maxwell1: 11list","maxwell1: 11list")
976 
977  ("maxwell1: 22list","maxwell1: 22list")
978 
979  ("maxwell1: dump matrices","maxwell1: dump matrices")
980 
981  ("maxwell1: nodal smoother fix zero diagonal threshold","maxwell1: nodal smoother fix zero diagonal threshold")
982 
983  ("refmaxwell: mode","refmaxwell: mode")
984 
985  ("refmaxwell: disable addon","refmaxwell: disable addon")
986 
987  ("refmaxwell: 11list","refmaxwell: 11list")
988 
989  ("refmaxwell: 22list","refmaxwell: 22list")
990 
991  ("zero starting solution","refmaxwell: use as preconditioner")
992 
993  ("refmaxwell: dump matrices","refmaxwell: dump matrices")
994 
995  ("refmaxwell: subsolves on subcommunicators","refmaxwell: subsolves on subcommunicators")
996 
997  ("refmaxwell: enable reuse","refmaxwell: enable reuse")
998 
999  ("refmaxwell: skip first (1,1) level","refmaxwell: skip first (1,1) level")
1000 
1001  ("refmaxwell: normalize nullspace","refmaxwell: normalize nullspace")
1002  ;
1003 
1004 }
1005 
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