Merge pull request #3317 from akva2/minpvmode_enum_class
MinpvMode: convert to enum class
This commit is contained in:
commit
c49f1fc354
@ -92,17 +92,18 @@ if(ENABLE_ECL_INPUT)
|
|||||||
src/opm/input/eclipse/EclipseState/EclipseConfig.cpp
|
src/opm/input/eclipse/EclipseState/EclipseConfig.cpp
|
||||||
src/opm/input/eclipse/EclipseState/EclipseState.cpp
|
src/opm/input/eclipse/EclipseState/EclipseState.cpp
|
||||||
src/opm/input/eclipse/EclipseState/EndpointScaling.cpp
|
src/opm/input/eclipse/EclipseState/EndpointScaling.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/FieldProps.cpp
|
|
||||||
src/opm/input/eclipse/EclipseState/Grid/FieldPropsManager.cpp
|
|
||||||
src/opm/input/eclipse/EclipseState/Grid/Box.cpp
|
src/opm/input/eclipse/EclipseState/Grid/Box.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/BoxManager.cpp
|
src/opm/input/eclipse/EclipseState/Grid/BoxManager.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/EclipseGrid.cpp
|
src/opm/input/eclipse/EclipseState/Grid/EclipseGrid.cpp
|
||||||
|
src/opm/input/eclipse/EclipseState/Grid/FieldProps.cpp
|
||||||
|
src/opm/input/eclipse/EclipseState/Grid/FieldPropsManager.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/FaceDir.cpp
|
src/opm/input/eclipse/EclipseState/Grid/FaceDir.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/FaultCollection.cpp
|
src/opm/input/eclipse/EclipseState/Grid/FaultCollection.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/Fault.cpp
|
src/opm/input/eclipse/EclipseState/Grid/Fault.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/FaultFace.cpp
|
src/opm/input/eclipse/EclipseState/Grid/FaultFace.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/GridDims.cpp
|
src/opm/input/eclipse/EclipseState/Grid/GridDims.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/MapAxes.cpp
|
src/opm/input/eclipse/EclipseState/Grid/MapAxes.cpp
|
||||||
|
src/opm/input/eclipse/EclipseState/Grid/MinpvMode.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/MULTREGTScanner.cpp
|
src/opm/input/eclipse/EclipseState/Grid/MULTREGTScanner.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/NNC.cpp
|
src/opm/input/eclipse/EclipseState/Grid/NNC.cpp
|
||||||
src/opm/input/eclipse/EclipseState/Grid/Operate.cpp
|
src/opm/input/eclipse/EclipseState/Grid/Operate.cpp
|
||||||
|
@ -115,7 +115,7 @@ namespace Opm {
|
|||||||
PinchMode::ModeEnum getMultzOption( ) const;
|
PinchMode::ModeEnum getMultzOption( ) const;
|
||||||
PinchMode::ModeEnum getPinchGapMode( ) const;
|
PinchMode::ModeEnum getPinchGapMode( ) const;
|
||||||
|
|
||||||
MinpvMode::ModeEnum getMinpvMode() const;
|
MinpvMode getMinpvMode() const;
|
||||||
const std::vector<double>& getMinpvVector( ) const;
|
const std::vector<double>& getMinpvVector( ) const;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -222,7 +222,7 @@ namespace Opm {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
std::vector<double> m_minpvVector;
|
std::vector<double> m_minpvVector;
|
||||||
MinpvMode::ModeEnum m_minpvMode;
|
MinpvMode m_minpvMode;
|
||||||
std::optional<double> m_pinch;
|
std::optional<double> m_pinch;
|
||||||
PinchMode::ModeEnum m_pinchoutMode;
|
PinchMode::ModeEnum m_pinchoutMode;
|
||||||
PinchMode::ModeEnum m_multzMode;
|
PinchMode::ModeEnum m_multzMode;
|
||||||
|
@ -20,14 +20,17 @@
|
|||||||
#ifndef OPM_MINPVMODE_HPP
|
#ifndef OPM_MINPVMODE_HPP
|
||||||
#define OPM_MINPVMODE_HPP
|
#define OPM_MINPVMODE_HPP
|
||||||
|
|
||||||
|
#include <iosfwd>
|
||||||
|
|
||||||
namespace Opm {
|
namespace Opm {
|
||||||
|
|
||||||
namespace MinpvMode {
|
enum class MinpvMode {
|
||||||
enum ModeEnum {
|
Inactive = 1,
|
||||||
Inactive = 1,
|
EclSTD = 2,
|
||||||
EclSTD = 2,
|
};
|
||||||
};
|
|
||||||
}
|
std::ostream& operator<<(std::ostream&, const MinpvMode&);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -96,7 +96,7 @@ EclipseGrid::EclipseGrid(const std::array<int, 3>& dims ,
|
|||||||
const std::vector<double>& zcorn ,
|
const std::vector<double>& zcorn ,
|
||||||
const int * actnum)
|
const int * actnum)
|
||||||
: GridDims(dims),
|
: GridDims(dims),
|
||||||
m_minpvMode(MinpvMode::ModeEnum::Inactive),
|
m_minpvMode(MinpvMode::Inactive),
|
||||||
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
||||||
m_multzMode(PinchMode::ModeEnum::TOP),
|
m_multzMode(PinchMode::ModeEnum::TOP),
|
||||||
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
||||||
@ -112,7 +112,7 @@ EclipseGrid::EclipseGrid(const std::array<int, 3>& dims ,
|
|||||||
|
|
||||||
EclipseGrid::EclipseGrid(const std::string& fileName )
|
EclipseGrid::EclipseGrid(const std::string& fileName )
|
||||||
: GridDims(),
|
: GridDims(),
|
||||||
m_minpvMode(MinpvMode::ModeEnum::Inactive),
|
m_minpvMode(MinpvMode::Inactive),
|
||||||
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
||||||
m_multzMode(PinchMode::ModeEnum::TOP),
|
m_multzMode(PinchMode::ModeEnum::TOP),
|
||||||
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
||||||
@ -126,7 +126,7 @@ EclipseGrid::EclipseGrid(const std::string& fileName )
|
|||||||
|
|
||||||
EclipseGrid::EclipseGrid(const GridDims& gd)
|
EclipseGrid::EclipseGrid(const GridDims& gd)
|
||||||
: GridDims(gd),
|
: GridDims(gd),
|
||||||
m_minpvMode(MinpvMode::ModeEnum::Inactive),
|
m_minpvMode(MinpvMode::Inactive),
|
||||||
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
||||||
m_multzMode(PinchMode::ModeEnum::TOP),
|
m_multzMode(PinchMode::ModeEnum::TOP),
|
||||||
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
||||||
@ -146,7 +146,7 @@ EclipseGrid::EclipseGrid(const GridDims& gd)
|
|||||||
EclipseGrid::EclipseGrid(size_t nx, size_t ny , size_t nz,
|
EclipseGrid::EclipseGrid(size_t nx, size_t ny , size_t nz,
|
||||||
double dx, double dy, double dz)
|
double dx, double dy, double dz)
|
||||||
: GridDims(nx, ny, nz),
|
: GridDims(nx, ny, nz),
|
||||||
m_minpvMode(MinpvMode::ModeEnum::Inactive),
|
m_minpvMode(MinpvMode::Inactive),
|
||||||
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
||||||
m_multzMode(PinchMode::ModeEnum::TOP),
|
m_multzMode(PinchMode::ModeEnum::TOP),
|
||||||
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
||||||
@ -254,7 +254,7 @@ EclipseGrid::EclipseGrid(const EclipseGrid& src, const std::vector<int>& actnum)
|
|||||||
|
|
||||||
EclipseGrid::EclipseGrid(const Deck& deck, const int * actnum)
|
EclipseGrid::EclipseGrid(const Deck& deck, const int * actnum)
|
||||||
: GridDims(deck),
|
: GridDims(deck),
|
||||||
m_minpvMode(MinpvMode::ModeEnum::Inactive),
|
m_minpvMode(MinpvMode::Inactive),
|
||||||
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
m_pinchoutMode(PinchMode::ModeEnum::TOPBOT),
|
||||||
m_multzMode(PinchMode::ModeEnum::TOP),
|
m_multzMode(PinchMode::ModeEnum::TOP),
|
||||||
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
m_pinchGapMode(PinchMode::ModeEnum::GAP)
|
||||||
@ -362,17 +362,17 @@ EclipseGrid::EclipseGrid(const Deck& deck, const int * actnum)
|
|||||||
const auto& record = deck.get<ParserKeywords::MINPV>( ).back().getRecord(0);
|
const auto& record = deck.get<ParserKeywords::MINPV>( ).back().getRecord(0);
|
||||||
const auto& item = record.getItem<ParserKeywords::MINPV::VALUE>( );
|
const auto& item = record.getItem<ParserKeywords::MINPV::VALUE>( );
|
||||||
std::fill(m_minpvVector.begin(), m_minpvVector.end(), item.getSIDouble(0));
|
std::fill(m_minpvVector.begin(), m_minpvVector.end(), item.getSIDouble(0));
|
||||||
m_minpvMode = MinpvMode::ModeEnum::EclSTD;
|
m_minpvMode = MinpvMode::EclSTD;
|
||||||
} else if (deck.hasKeyword<ParserKeywords::MINPORV>()) {
|
} else if (deck.hasKeyword<ParserKeywords::MINPORV>()) {
|
||||||
const auto& record = deck.get<ParserKeywords::MINPORV>( ).back().getRecord(0);
|
const auto& record = deck.get<ParserKeywords::MINPORV>( ).back().getRecord(0);
|
||||||
const auto& item = record.getItem<ParserKeywords::MINPORV::VALUE>( );
|
const auto& item = record.getItem<ParserKeywords::MINPORV::VALUE>( );
|
||||||
std::fill(m_minpvVector.begin(), m_minpvVector.end(), item.getSIDouble(0));
|
std::fill(m_minpvVector.begin(), m_minpvVector.end(), item.getSIDouble(0));
|
||||||
m_minpvMode = MinpvMode::ModeEnum::EclSTD;
|
m_minpvMode = MinpvMode::EclSTD;
|
||||||
} else if(deck.hasKeyword<ParserKeywords::MINPVV>()) {
|
} else if(deck.hasKeyword<ParserKeywords::MINPVV>()) {
|
||||||
// We should use the grid properties to support BOX, but then we need the eclipseState
|
// We should use the grid properties to support BOX, but then we need the eclipseState
|
||||||
const auto& record = deck.get<ParserKeywords::MINPVV>( ).back().getRecord(0);
|
const auto& record = deck.get<ParserKeywords::MINPVV>( ).back().getRecord(0);
|
||||||
m_minpvVector =record.getItem(0).getSIDoubleData();
|
m_minpvVector =record.getItem(0).getSIDoubleData();
|
||||||
m_minpvMode = MinpvMode::ModeEnum::EclSTD;
|
m_minpvMode = MinpvMode::EclSTD;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (actnum != nullptr) {
|
if (actnum != nullptr) {
|
||||||
@ -536,7 +536,7 @@ EclipseGrid::EclipseGrid(const Deck& deck, const int * actnum)
|
|||||||
return m_multzMode;
|
return m_multzMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
MinpvMode::ModeEnum EclipseGrid::getMinpvMode() const {
|
MinpvMode EclipseGrid::getMinpvMode() const {
|
||||||
return m_minpvMode;
|
return m_minpvMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1420,7 +1420,7 @@ std::vector<double> EclipseGrid::createDVector(const std::array<int,3>& dims, st
|
|||||||
|
|
||||||
bool status = ((m_pinch == other.m_pinch) && (m_minpvMode == other.getMinpvMode()));
|
bool status = ((m_pinch == other.m_pinch) && (m_minpvMode == other.getMinpvMode()));
|
||||||
|
|
||||||
if(m_minpvMode!=MinpvMode::ModeEnum::Inactive) {
|
if (m_minpvMode != MinpvMode::Inactive) {
|
||||||
status = status && (m_minpvVector == other.getMinpvVector());
|
status = status && (m_minpvVector == other.getMinpvVector());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
38
src/opm/input/eclipse/EclipseState/Grid/MinpvMode.cpp
Normal file
38
src/opm/input/eclipse/EclipseState/Grid/MinpvMode.cpp
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2015 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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
#include <opm/input/eclipse/EclipseState/Grid/MinpvMode.hpp>
|
||||||
|
|
||||||
|
#include <cassert>
|
||||||
|
#include <ostream>
|
||||||
|
|
||||||
|
namespace Opm {
|
||||||
|
|
||||||
|
std::ostream& operator<<(std::ostream& os, const MinpvMode& mm)
|
||||||
|
{
|
||||||
|
if (mm == MinpvMode::EclSTD)
|
||||||
|
return (os << "EclStd");
|
||||||
|
else if (mm == MinpvMode::Inactive)
|
||||||
|
return (os << "Inactive");
|
||||||
|
else
|
||||||
|
assert(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -850,8 +850,8 @@ BOOST_AUTO_TEST_CASE(ConstructorMINPV) {
|
|||||||
Opm::EclipseGrid grid3(deck3);
|
Opm::EclipseGrid grid3(deck3);
|
||||||
|
|
||||||
BOOST_CHECK(!grid1.equal( grid3 ));
|
BOOST_CHECK(!grid1.equal( grid3 ));
|
||||||
BOOST_CHECK_EQUAL(grid1.getMinpvMode(), Opm::MinpvMode::ModeEnum::Inactive);
|
BOOST_CHECK_EQUAL(grid1.getMinpvMode(), Opm::MinpvMode::Inactive);
|
||||||
BOOST_CHECK_EQUAL(grid3.getMinpvMode(), Opm::MinpvMode::ModeEnum::EclSTD);
|
BOOST_CHECK_EQUAL(grid3.getMinpvMode(), Opm::MinpvMode::EclSTD);
|
||||||
BOOST_CHECK_EQUAL(grid3.getMinpvVector()[0], 10.0);
|
BOOST_CHECK_EQUAL(grid3.getMinpvVector()[0], 10.0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user