Nektar++
MetricL2.cpp
Go to the documentation of this file.
1///////////////////////////////////////////////////////////////////////////////
2//
3// File: MetricL2.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 L2 metric.
32//
33///////////////////////////////////////////////////////////////////////////////
34
35#include <MetricL2.h>
36
37namespace Nektar
38{
39std::string MetricL2::type =
41
42// Guess default tolerance for generation routine.
43std::string MetricL2::defaultTolerance = "1e-12";
44
45MetricL2::MetricL2(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 = "^L 2 error\\s*(?:\\(variable "
52 "(\\w+)\\))?\\s*:\\s*([+-]?\\d.+\\d|-?\\d|[+-]?nan|[+-]?inf).*";
53
54 // Find the L2 error to match against.
55 TiXmlElement *value = metric->FirstChildElement("value");
56 ASSERTL0(value || m_generate, "Missing value tag for L2 metric!");
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 L2 error.
62 ASSERTL0(value->Attribute("tolerance"),
63 "Missing tolerance in L2 metric");
64 ASSERTL0(!EmptyString(value->GetText()), "Missing value in L2 metric.");
65
67 if (value->Attribute("variable"))
68 {
69 var.m_value = value->Attribute("variable");
70 }
71
73 val.m_value = value->GetText();
74 val.m_useTolerance = true;
75 val.m_tolerance = atof(value->Attribute("tolerance"));
76
77 if (!m_generate)
78 {
79 std::vector<MetricRegexFieldValue> tmp(2);
80 tmp[0] = var;
81 tmp[1] = val;
82 m_matches.push_back(tmp);
83 }
84 else
85 {
86 m_varTolerance[var.m_value] = value->Attribute("tolerance");
87 }
88
89 value = value->NextSiblingElement("value");
90 }
91}
92
93void MetricL2::v_Generate(std::istream &pStdout, std::istream &pStderr)
94{
95 // Run MetricRegex to generate matches.
96 MetricRegex::v_Generate(pStdout, pStderr);
97
98 // First remove all existing values.
99 m_metric->Clear();
100
101 // Now create new values.
102 for (int i = 0; i < m_matches.size(); ++i)
103 {
104 ASSERTL0(m_matches[i].size() == 2,
105 "Wrong number of matches for regular expression.");
106
107 bool tolSet = false;
108 std::string tol = MetricL2::defaultTolerance;
109 TiXmlElement *value = new TiXmlElement("value");
110
111 // See if there is a tolerance found already for this variable
112 // (including empty variables).
113 std::map<std::string, std::string>::iterator it =
114 m_varTolerance.find(m_matches[i][0].m_value);
115
116 if (it != m_varTolerance.end())
117 {
118 tol = it->second;
119 tolSet = true;
120 }
121
122 if (m_matches[i][0].m_value.size() > 0)
123 {
124 value->SetAttribute("variable", m_matches[i][0].m_value);
125
126 if (m_matches[i][0].m_value == "p" && !tolSet)
127 {
128 // Set lower tolerance for pressure fields automatically if
129 // we haven't already got a tolerance from the existing
130 // file.
131 tol = "1e-8";
132 }
133 }
134
135 value->SetAttribute("tolerance", tol);
136 value->LinkEndChild(new TiXmlText(m_matches[i][1].m_value));
137 m_metric->LinkEndChild(value);
138 }
139}
140} // 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
static std::string type
Definition: MetricL2.h:51
void v_Generate(std::istream &pStdout, std::istream &pStderr) override
Virtual function to generate the metric. Should be redefined in derived classes.
Definition: MetricL2.cpp:93
static MetricSharedPtr create(TiXmlElement *metric, bool generate)
Definition: MetricL2.h:46
MetricL2(TiXmlElement *metric, bool generate)
Definition: MetricL2.cpp:45
std::map< std::string, std::string > m_varTolerance
Definition: MetricL2.h:57
static std::string defaultTolerance
Definition: MetricL2.h:52
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