My Project
Loading...
Searching...
No Matches
ExtNetwork.hpp
1/*
2 Copyright 2020 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
21#ifndef EXT_NETWORK_HPP
22#define EXT_NETWORK_HPP
23
24#include <map>
25#include <optional>
26#include <string>
27#include <vector>
28#include <functional>
29
30#include <opm/input/eclipse/Schedule/Network/Branch.hpp>
31#include <opm/input/eclipse/Schedule/Network/Node.hpp>
32
33namespace Opm {
34namespace Network {
35
36
38public:
39 ExtNetwork() = default;
40 bool active() const;
41 bool is_standard_network() const;
42 void set_standard_network(bool is_standard_network);
43 void add_branch(Branch branch);
44 void add_or_replace_branch(Branch branch);
45 void drop_branch(const std::string& uptree_node, const std::string& downtree_node);
46 bool has_node(const std::string& name) const;
47 void update_node(Node node);
48 const Node& node(const std::string& name) const;
49 std::vector<std::reference_wrapper<const Node>> roots() const;
50 std::vector<Branch> downtree_branches(const std::string& node) const;
51 std::vector<const Branch*> branches() const;
52 std::optional<Branch> uptree_branch(const std::string& node) const;
53 std::vector<std::string> node_names() const;
54 int NoOfBranches() const;
55
56 bool operator==(const ExtNetwork& other) const;
57 static ExtNetwork serializationTestObject();
58
59 template<class Serializer>
60 void serializeOp(Serializer& serializer)
61 {
62 serializer(m_branches);
63 serializer(insert_indexed_node_names);
64 serializer(m_nodes);
65 serializer(m_is_standard_network);
66 }
67
68private:
69 std::vector<Branch> m_branches;
70 std::vector<std::string> insert_indexed_node_names;
71 std::map<std::string, Node> m_nodes;
72 bool m_is_standard_network{false};
73 bool has_indexed_node_name(const std::string& name) const;
74 void add_indexed_node_name(std::string name);
75};
76
77}
78}
79#endif
Definition Branch.hpp:30
Definition ExtNetwork.hpp:37
Definition Node.hpp:30
Class for (de-)serializing.
Definition Serializer.hpp:84
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition Exceptions.hpp:30