///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2011-2012 Statoil ASA, Ceetron AS // // ResInsight 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. // // ResInsight 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 at // for more details. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include #include "RigCell.h" #include "cvfVector3.h" #include "cvfAssert.h" #include "cvfObject.h" #include "RigMainGrid.h" #include "RigWellResults.h" #include "RigActiveCellInfo.h" class RigReservoirCellResults; class RigEclipseCase: public cvf::Object { public: RigEclipseCase(); ~RigEclipseCase(); RigMainGrid* mainGrid() { return m_mainGrid.p(); } const RigMainGrid* mainGrid() const { return m_mainGrid.p(); } void setMainGrid(RigMainGrid* mainGrid); void allGrids(std::vector* grids); void allGrids(std::vector* grids) const; const RigGridBase* grid(size_t index) const; RigReservoirCellResults* results(RifReaderInterface::PorosityModelResultType porosityModel); const RigReservoirCellResults* results(RifReaderInterface::PorosityModelResultType porosityModel) const; cvf::ref dataAccessObject(const RigGridBase* grid, RifReaderInterface::PorosityModelResultType porosityModel, size_t timeStepIndex, size_t scalarSetIndex) const; void computeCachedData(); void setWellResults(const cvf::Collection& data); const cvf::Collection& wellResults() { return m_wellResults; } cvf::UByteArray* wellCellsInGrid(size_t gridIndex); RigCell& cellFromWellResultCell(const RigWellResultCell& wellResultCell); bool findSharedSourceFace(cvf::StructGridInterface::FaceType& sharedSourceFace, const RigWellResultCell& sourceWellCellResult, const RigWellResultCell& otherWellCellResult) const; RigActiveCellInfo* activeCellInfo(); const RigActiveCellInfo* activeCellInfo() const; private: void computeActiveCellData(); void computeWellCellsPrGrid(); void computeActiveCellsGeometryBoundingBox(); private: RigActiveCellInfo m_activeCellInfo; cvf::ref m_mainGrid; cvf::ref m_matrixModelResults; cvf::ref m_fractureModelResults; cvf::Collection m_wellResults; cvf::Collection m_wellCellsInGrid; };