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 <optional>
24#include <vector>
25
26#include <opm/input/eclipse/Schedule/Group/Group.hpp>
27#include <opm/input/eclipse/Schedule/Well/Well.hpp>
28
29namespace Opm {
30
31class GTNode {
32public:
33 GTNode(const Group& group, std::size_t level, const std::optional<std::string>& parent_name);
34
35 void add_group(const GTNode& child_group);
36 void add_well(const Well& well);
37
38 const std::vector<Well>& wells() const;
39 const std::vector<GTNode>& groups() const;
40 const std::string& name() const;
41 const std::string& parent_name() const;
42
43 const Group& group() const;
44 std::size_t level() const;
45 std::vector<const GTNode*> all_nodes() const;
46private:
47 const Group m_group;
48 std::size_t m_level;
49 std::optional<std::string> m_parent_name;
50 /*
51 Class T with a stl container <T> - supposedly undefined behavior before
52 C++17 - but it compiles without warnings.
53 */
54 std::vector<GTNode> m_child_groups;
55 std::vector<Well> m_wells;
56};
57
58}
59#endif
Definition GTNode.hpp:31
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