/* 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 . */ #ifndef ECLIPSESTATE_H #define ECLIPSESTATE_H #include #include #include #include #include #include #include #include #include #include #include namespace Opm { class EclipseState { public: EclipseState(DeckConstPtr deck, bool beStrict = false); ScheduleConstPtr getSchedule() const; EclipseGridConstPtr getEclipseGrid() const; EclipseGridPtr getEclipseGridCopy() const; bool hasPhase(enum Phase::PhaseEnum phase) const; std::string getTitle() const; bool supportsGridProperty(const std::string& keyword) const; std::shared_ptr > getIntGridProperty( const std::string& keyword ) const; std::shared_ptr > getDoubleGridProperty( const std::string& keyword ) const; bool hasIntGridProperty(const std::string& keyword) const; bool hasDoubleGridProperty(const std::string& keyword) const; void loadGridPropertyFromDeckKeyword(std::shared_ptr inputBox , DeckKeywordConstPtr deckKeyword); std::shared_ptr getFaults() const; std::shared_ptr getTransMult() const; private: void initSchedule(DeckConstPtr deck); void initEclipseGrid(DeckConstPtr deck); void initPhases(DeckConstPtr deck); void initTitle(DeckConstPtr deck); void initProperties(DeckConstPtr deck); void initTransMult(); void initFaults(DeckConstPtr deck); void setMULTFLT(std::shared_ptr section) const; double getSIScaling(const std::string &dimensionString) const; void scanSection(std::shared_ptr section , BoxManager& boxManager); void handleADDKeyword(DeckKeywordConstPtr deckKeyword , BoxManager& boxManager); void handleBOXKeyword(DeckKeywordConstPtr deckKeyword , BoxManager& boxManager); void handleCOPYKeyword(DeckKeywordConstPtr deckKeyword , BoxManager& boxManager); void handleENDBOXKeyword(BoxManager& boxManager); void handleEQUALSKeyword(DeckKeywordConstPtr deckKeyword , BoxManager& boxManager); void handleMULTIPLYKeyword(DeckKeywordConstPtr deckKeyword , BoxManager& boxManager); void setKeywordBox(DeckRecordConstPtr deckRecord , BoxManager& boxManager); void copyIntKeyword(const std::string& srcField , const std::string& targetField , std::shared_ptr inputBox); void copyDoubleKeyword(const std::string& srcField , const std::string& targetField , std::shared_ptr inputBox); EclipseGridConstPtr m_eclipseGrid; ScheduleConstPtr schedule; std::set phases; std::string m_title; std::shared_ptr m_unitSystem; std::shared_ptr > m_intGridProperties; std::shared_ptr > m_doubleGridProperties; std::shared_ptr m_transMult; std::shared_ptr m_faults; }; typedef std::shared_ptr EclipseStatePtr; typedef std::shared_ptr EclipseStateConstPtr; } #endif