Nektar++
MetricPrecon.cpp
Go to the documentation of this file.
1///////////////////////////////////////////////////////////////////////////////
2//
3// File: MetricPrecon.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 preconditioner metric.
32//
33///////////////////////////////////////////////////////////////////////////////
34
35#include <MetricPrecon.h>
36
37namespace Nektar
38{
39std::string MetricPrecon::type =
41
42// Guess default tolerance for generation routine.
43std::string MetricPrecon::defaultTolerance = "2";
44
45MetricPrecon::MetricPrecon(TiXmlElement *metric, bool generate)
46 : MetricRegex(metric, generate)
47{
48 // Set up the regular expression. This (optionally) matches a variable
49 // name if it exists: first field is variable name, second field is L2
50 // error.
51 m_regex = "^CG iterations made = (\\d+) .*";
52
53 // Find the number of iterations to match against.
54 TiXmlElement *value = metric->FirstChildElement("value");
55 ASSERTL0(value || m_generate, "Missing value tag for precon metric!");
56
57 while (value)
58 {
59 // Set up a match with two fields which correspond with the
60 // subexpression above. The first is the variable name, second is
61 // the precon iteration count.
62 ASSERTL0(value->Attribute("tolerance"),
63 "Missing tolerance in preconditioner metric");
64 ASSERTL0(!EmptyString(value->GetText()),
65 "Missing value in preconditioner metric.");
66
68 val.m_value = value->GetText();
69 val.m_useIntTolerance = true;
70 val.m_intTolerance = atoi(value->Attribute("tolerance"));
71
72 if (!m_generate)
73 {
74 std::vector<MetricRegexFieldValue> tmp(1);
75 tmp[0] = val;
76 m_matches.push_back(tmp);
77 }
78 else
79 {
80 m_varTolerance = value->Attribute("tolerance");
81 }
82
83 value = value->NextSiblingElement("value");
84 }
85}
86
87void MetricPrecon::v_Generate(std::istream &pStdout, std::istream &pStderr)
88{
89 // Run MetricRegex to generate matches.
90 MetricRegex::v_Generate(pStdout, pStderr);
91
92 // First remove all existing values.
93 m_metric->Clear();
94
95 // Now create new values.
96 for (int i = 0; i < m_matches.size(); ++i)
97 {
98 ASSERTL0(m_matches[i].size() == 1,
99 "Wrong number of matches for regular expression.");
100
101 std::string tol = MetricPrecon::defaultTolerance;
102 TiXmlElement *value = new TiXmlElement("value");
103
104 if (m_varTolerance != "")
105 {
106 tol = m_varTolerance;
107 }
108
109 value->SetAttribute("tolerance", tol);
110 value->LinkEndChild(new TiXmlText(m_matches[i][0].m_value));
111 m_metric->LinkEndChild(value);
112 }
113}
114} // namespace Nektar
#define ASSERTL0(condition, msg)
Definition: ErrorUtil.hpp:208
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
void v_Generate(std::istream &pStdout, std::istream &pStderr) override
Virtual function to generate the metric. Should be redefined in derived classes.
std::string m_varTolerance
Definition: MetricPrecon.h:57
static std::string defaultTolerance
Definition: MetricPrecon.h:52
MetricPrecon(TiXmlElement *metric, bool generate)
static MetricSharedPtr create(TiXmlElement *metric, bool generate)
Definition: MetricPrecon.h:46
static std::string type
Definition: MetricPrecon.h:51
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