///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2022- Equinor ASA // // 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 "cvfObject.h" #include "cvfVector3.h" #include "cafAssert.h" #include #include #include #include "Token.hpp" class RigEclipseCaseData; class RigMainGrid; namespace roff { class Reader; } //================================================================================================== // // Class for access to Roff grids. // //================================================================================================== class RifRoffFileTools : public cvf::Object { public: RifRoffFileTools(); ~RifRoffFileTools() override; static bool openGridFile( const QString& fileName, RigEclipseCaseData* eclipseCase, QString* errorMessages ); static std::pair> createInputProperties( const QString& fileName, RigEclipseCaseData* eclipseCase ); private: static void interpretSplitenzData( int nz, float zoffset, float zscale, const std::vector& splitenz, const std::vector& zdata, std::vector& zcornsv ); static size_t computeActiveCellMatrixIndex( std::vector& activeCells ); static cvf::Vec3d getCorner( const RigMainGrid& grid, const std::vector& cornerLines, const std::vector& zcorn, size_t cellIdx, int cornerIdx, const cvf::Vec3d& offset, const cvf::Vec3d& scale ); static double interpolate( const cvf::Vec3d& top, const cvf::Vec3d& bottom, double z, int idx ); static std::vector readAndConvertToDouble( int nx, int ny, int nz, const std::string& keyword, roff::Token::Kind kind, roff::Reader& reader ); static bool appendNewInputPropertyResult( RigEclipseCaseData* caseData, const QString& resultName, const std::string& keyword, roff::Token::Kind token, roff::Reader& reader ); template static void convertToReservoirIndexOrder( int nx, int ny, int nz, const std::vector& in, std::vector& out ) { CAF_ASSERT( static_cast( nx ) * ny * nz == in.size() ); out.resize( in.size(), -1 ); int outIdx = 0; for ( int k = 0; k < nz; k++ ) { for ( int j = 0; j < ny; j++ ) { for ( int i = 0; i < nx; i++ ) { int inIdx = i * ny * nz + j * nz + ( nz - k - 1 ); out[outIdx] = static_cast( in[inIdx] ); outIdx++; } } } } };