NEMoSys
0.63.0
A modular, extensible resource with robust automated mesh generation, mesh quality analysis, adaptive mesh refinement, and data transfer between arbitrary meshes.
GradSizeField.H
Go to the documentation of this file.
1
/*******************************************************************************
2
* Promesh *
3
* Copyright (C) 2022, IllinoisRocstar LLC. All rights reserved. *
4
* *
5
* Promesh is the property of IllinoisRocstar LLC. *
6
* *
7
* IllinoisRocstar LLC *
8
* Champaign, IL *
9
* www.illinoisrocstar.com *
10
* promesh@illinoisrocstar.com *
11
*******************************************************************************/
12
/*******************************************************************************
13
* This file is part of Promesh *
14
* *
15
* This version of Promesh is free software: you can redistribute it and/or *
16
* modify it under the terms of the GNU Lesser General Public License as *
17
* published by the Free Software Foundation, either version 3 of the License, *
18
* or (at your option) any later version. *
19
* *
20
* Promesh is distributed in the hope that it will be useful, but WITHOUT ANY *
21
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS *
22
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more *
23
* details. *
24
* *
25
* You should have received a copy of the GNU Lesser General Public License *
26
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
27
* *
28
*******************************************************************************/
29
#ifndef NEMOSYS_GRADSIZEFIELD_H_
30
#define NEMOSYS_GRADSIZEFIELD_H_
31
32
#include "nemosys_export.h"
33
#include "
SizeFieldGeneration/SizeFieldGen.H
"
34
35
namespace
NEM
{
36
namespace
ADP {
37
38
class
NEMOSYS_EXPORT
GradSizeField
:
public
SizeFieldBase
{
39
// constructors and destructors
40
public
:
41
GradSizeField
(vtkDataSet *_ds,
int
arrayID,
double
_dev_mult,
bool
_maxIsmin);
42
43
~GradSizeField
()
override
{
44
std::cout <<
"GradSizeField destroyed"
<< std::endl;
45
}
46
47
// methods
48
public
:
49
// computes the gradient of point data at a cell using
50
// derivatives of shape interpolation functions
51
static
std::vector<double> computeGradAtCell(vtkCell *cell, vtkDataArray *da);
52
// compute L2 norm of gradient of point data at each cell
53
static
std::vector<double> computeL2GradAtAllCells(vtkDataSet *ds,
54
vtkDataArray *da);
55
// compute size field and insert as cell data into mesh's dataSet
56
void
computeSizeField(vtkDataArray *da)
override
;
57
};
58
59
}
// namespace ADP
60
}
// namespace NEM
61
62
#endif // NEMOSYS_GRADSIZEFIELD_H_
NEM::ADP::GradSizeField
Definition:
GradSizeField.H:38
SizeFieldGen.H
NEM
Definition:
AutoVerificationDriver.C:38
NEM::ADP::GradSizeField::~GradSizeField
~GradSizeField() override
Definition:
GradSizeField.H:43
NEM::ADP::SizeFieldBase
Definition:
SizeFieldGen.H:41
include
SizeFieldGeneration
GradSizeField.H
Generated on Wed Jan 26 2022 16:40:01 for NEMoSys by
1.8.13