Nektar++
MetricEigenvalue.cpp
Go to the documentation of this file.
1///////////////////////////////////////////////////////////////////////////////
2//
3// File: MetricEigenvalue.cpp
4//
5// For more information, please see: http://www.nektar.info
6//
7// The MIT License
8//
9// Copyright (c) 2006 Division of Applied Mathematics, Brown University (USA),
10// Department of Aeronautics, Imperial College London (UK), and Scientific
11// Computing and Imaging Institute, University of Utah (USA).
12//
13// Permission is hereby granted, free of charge, to any person obtaining a
14// copy of this software and associated documentation files (the "Software"),
15// to deal in the Software without restriction, including without limitation
16// the rights to use, copy, modify, merge, publish, distribute, sublicense,
17// and/or sell copies of the Software, and to permit persons to whom the
18// Software is furnished to do so, subject to the following conditions:
19//
20// The above copyright notice and this permission notice shall be included
21// in all copies or substantial portions of the Software.
22//
23// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
24// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
26// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
28// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
29// DEALINGS IN THE SOFTWARE.
30//
31// Description: Implementation of the eigenvalue metric.
32//
33///////////////////////////////////////////////////////////////////////////////
34
35#include <boost/algorithm/string.hpp>
36
37#include <MetricEigenvalue.h>
38
39namespace Nektar
40{
42 "EIGENVALUE", MetricEigenvalue::create);
43
44// Guess default tolerance for generation routine.
45std::string MetricEigenvalue::defaultTolerance = "1e-03";
46
47MetricEigenvalue::MetricEigenvalue(TiXmlElement *metric, bool generate)
48 : MetricRegex(metric, generate)
49{
50 // We do not mind which order the converged eigenvalues are listed.
51 m_unordered = true;
52
53 // Regex for FP numbers of forms: 120, -23, 4.345, 2.4563e-01, -nan
54 std::string fp = R"(-?\d+\.?\d*(?:e[+-]\d+)?|-?nan)";
55
56 // Set up the regular expression. This matches lines beginning with EV:
57 // followed by an eigenvalue index and then at least 2 floating-point
58 // values comprising real and imaginary components of complex evals.
59 // Comparison is made only on the captured eigenvalue components.
60 m_regex = R"(^EV:\s+\d+\s+()" + fp + ")\\s+(" + fp + ").*";
61
62 // Find the number of iterations to match against.
63 TiXmlElement *value = metric->FirstChildElement("value");
64 ASSERTL0(value || m_generate, "Missing value tag for eigenvalue metric!");
65
66 while (value)
67 {
68 ASSERTL0(value->Attribute("tolerance"),
69 "Missing tolerance in eigenvalue metric");
70 ASSERTL0(!EmptyString(value->GetText()),
71 "Missing value in preconditioner metric.");
72
73 MetricRegexFieldValue mag, angle;
74
75 // Read valute as comma-separate mag,angle parts
76 std::string cmplx = value->GetText();
77 std::vector<std::string> cmpts;
78 boost::split(cmpts, cmplx, boost::is_any_of(","));
79 ASSERTL0(cmpts.size() == 2,
80 "Value should be magnitude and angle, separated by comma");
81
82 mag.m_value = cmpts[0];
83 mag.m_useTolerance = true;
84 mag.m_tolerance = atof(value->Attribute("tolerance"));
85
86 angle.m_value = cmpts[1];
87 angle.m_useTolerance = true;
88 angle.m_tolerance = atof(value->Attribute("tolerance"));
89
90 if (!m_generate)
91 {
92 std::vector<MetricRegexFieldValue> tmp(2);
93 tmp[0] = mag;
94 tmp[1] = angle;
95 m_matches.push_back(tmp);
96 }
97 else
98 {
99 m_varTolerance = value->Attribute("tolerance");
100 }
101
102 value = value->NextSiblingElement("value");
103 }
104}
105
106void MetricEigenvalue::v_Generate(std::istream &pStdout, std::istream &pStderr)
107{
108 // Run MetricRegex to generate matches.
109 MetricRegex::v_Generate(pStdout, pStderr);
110
111 // First remove all existing values.
112 m_metric->Clear();
113
114 // Now create new values.
115 for (int i = 0; i < m_matches.size(); ++i)
116 {
117 ASSERTL0(m_matches[i].size() == 3,
118 "Wrong number of matches for regular expression.");
119
120 std::string tol = MetricEigenvalue::defaultTolerance;
121 TiXmlElement *value = new TiXmlElement("value");
122
123 if (m_varTolerance != "")
124 {
125 tol = m_varTolerance;
126 }
127
128 value->SetAttribute("index", m_matches[i][0].m_value);
129 value->SetAttribute("tolerance", tol);
130 value->LinkEndChild(new TiXmlText(m_matches[i][1].m_value + "," +
131 m_matches[i][2].m_value));
132 m_metric->LinkEndChild(value);
133 }
134}
135} // namespace Nektar
#define ASSERTL0(condition, msg)
Definition: ErrorUtil.hpp:208
static MetricSharedPtr create(TiXmlElement *metric, bool generate)
static std::string defaultTolerance
MetricEigenvalue(TiXmlElement *metric, bool generate)
void v_Generate(std::istream &pStdout, std::istream &pStderr) override
Virtual function to generate the metric. Should be redefined in derived classes.
static std::string type
std::string RegisterCreatorFunction(std::string key, CreatorFunction func)
Definition: Metric.h:133
TiXmlElement * m_metric
Pointer to XML structure containing metric definition.
Definition: Metric.h:101
bool m_generate
Determines whether to generate this metric or not.
Definition: Metric.h:96
bool m_unordered
If true, regex matches may be in any order in output.
Definition: MetricRegex.h:86
void v_Generate(std::istream &pStdout, std::istream &pStderr) override
Test output against a regex expression and set of matches.
std::vector< std::vector< MetricRegexFieldValue > > m_matches
Stores the multiple matches defined in each <MATCH> tag.
Definition: MetricRegex.h:84
std::regex m_regex
Storage for the boost regex.
Definition: MetricRegex.h:82
bool EmptyString(const char *s)
Check to see whether the given string s is empty (or null).
Definition: Metric.h:50
MetricFactory & GetMetricFactory()
Definition: Metric.cpp:42
Data structure for a Regex value to match.
Definition: MetricRegex.h:49