Files
opm-common/opm/parser/eclipse/EclipseState/Schedule/Connection.hpp

98 lines
2.7 KiB
C++
Raw Normal View History

/*
Copyright 2013 Statoil ASA.
This file is part of the Open Porous Media project (OPM).
OPM is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
OPM is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with OPM. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef COMPLETION_HPP_
#define COMPLETION_HPP_
2018-06-28 14:45:30 +02:00
#include <array>
#include <map>
#include <memory>
#include <string>
#include <vector>
#include <opm/parser/eclipse/Parser/ParseContext.hpp>
#include <opm/parser/eclipse/EclipseState/Schedule/ScheduleEnums.hpp>
#include <opm/parser/eclipse/EclipseState/Util/Value.hpp>
namespace Opm {
class DeckKeyword;
class DeckRecord;
2018-06-08 16:23:03 +02:00
class Connection {
public:
2018-06-08 16:23:03 +02:00
Connection(int i, int j , int k ,
int complnum,
double depth,
WellCompletion::StateEnum state,
double CF,
double Kh,
double rw,
2017-02-16 08:36:41 +01:00
const int satTableId,
const WellCompletion::DirectionEnum direction);
2015-01-14 11:40:28 +01:00
bool attachedToSegment() const;
bool sameCoordinate(const int i, const int j, const int k) const;
int getI() const;
int getJ() const;
int getK() const;
WellCompletion::StateEnum state() const;
WellCompletion::DirectionEnum dir() const;
double depth() const;
int satTableId() const;
int complnum() const;
int segment() const;
double CF() const;
double Kh() const;
double rw() const;
double wellPi() const;
void setState(WellCompletion::StateEnum state);
void setComplnum(int compnum);
void scaleWellPi(double wellPi);
void updateSegment(int segment_number, double center_depth);
2018-06-08 16:23:03 +02:00
bool operator==( const Connection& ) const;
bool operator!=( const Connection& ) const;
private:
WellCompletion::DirectionEnum direction;
2018-06-26 09:45:50 +02:00
double center_depth;
WellCompletion::StateEnum open_state;
2018-06-26 10:08:44 +02:00
int sat_tableId;
int m_complnum;
double m_CF;
double m_Kh;
double m_rw;
2018-06-26 10:23:42 +02:00
std::array<int,3> ijk;
// related segment number
// -1 means the completion is not related to segment
int segment_number = -1;
double wPi = 1.0;
};
}
#endif /* COMPLETION_HPP_ */