My Project
Loading...
Searching...
No Matches
GTNode.hpp
1/*
2 Copyright 2019 Equinor ASA.
3
4 This file is part of the Open Porous Media project (OPM).
5
6 OPM is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
10
11 OPM is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with OPM. If not, see <http://www.gnu.org/licenses/>.
18*/
19
20#ifndef GROUPTREE2
21#define GROUPTREE2
22
23#include <opm/input/eclipse/Schedule/Group/Group.hpp>
24#include <opm/input/eclipse/Schedule/Well/Well.hpp>
25
26#include <cstddef>
27#include <optional>
28#include <string>
29#include <vector>
30
31namespace Opm {
32
33class GTNode
34{
35public:
36 GTNode(const Group& group, std::size_t level, const std::optional<std::string>& parent_name);
37
38 void add_group(const GTNode& child_group);
39 void add_well(const Well& well);
40
41 const std::vector<Well>& wells() const;
42 const std::vector<GTNode>& groups() const;
43 const std::string& name() const;
44 const std::string& parent_name() const;
45
46 const Group& group() const;
47 std::size_t level() const;
48 std::vector<const GTNode*> all_nodes() const;
49
50private:
51 Group m_group;
52 std::size_t m_level{};
53 std::optional<std::string> m_parent_name {std::nullopt};
54
55 // Class T with a stl container <T> - supposedly undefined behavior
56 // before C++17 - but it compiles without warnings.
57 std::vector<GTNode> m_child_groups{};
58 std::vector<Well> m_wells{};
59};
60
61} // namespace Opm
62
63#endif // GROUPTREE2
Definition GTNode.hpp:34
Definition Group.hpp:47
Definition Well.hpp:78
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition Exceptions.hpp:30