/
BoundingBoxNodeSetGenerator.h
51 lines (39 loc) · 1.27 KB
/
BoundingBoxNodeSetGenerator.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//* This file is part of the MOOSE framework
//* https://www.mooseframework.org
//*
//* All rights reserved, see COPYRIGHT for full restrictions
//* https://github.com/idaholab/moose/blob/master/COPYRIGHT
//*
//* Licensed under LGPL 2.1, please see LICENSE for details
//* https://www.gnu.org/licenses/lgpl-2.1.html
#ifndef BOUNDINGBOXNODESETGENERATOR_H
#define BOUNDINGBOXNODESETGENERATOR_H
#include "MeshGenerator.h"
#include "MooseEnum.h"
#include "libmesh/bounding_box.h"
// Forward declarations
class BoundingBoxNodeSetGenerator;
namespace libMesh
{
class BoundingBox;
}
template <>
InputParameters validParams<BoundingBoxNodeSetGenerator>();
/**
* Selects a set of nodes and assigns a nodeset name to them based on
* the bounding box specified. Can select nodes "inside" or "outside"
* the bounding box.
*/
class BoundingBoxNodeSetGenerator : public MeshGenerator
{
public:
BoundingBoxNodeSetGenerator(const InputParameters & parameters);
std::unique_ptr<MeshBase> generate() override;
protected:
std::unique_ptr<MeshBase> & _input;
/// Select nodes on the 'inside' or the 'outside' of the bounding box
MooseEnum _location;
/// Bounding box for testing element centroids against. Note that
BoundingBox _bounding_box;
};
#endif // BOUNDINGBOXNODESETGENERATOR_H