2012-05-18 02:45:23 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2014-09-23 08:04:57 -05:00
|
|
|
// Copyright (C) 2011- Statoil ASA
|
|
|
|
// Copyright (C) 2013- Ceetron Solutions AS
|
|
|
|
// Copyright (C) 2011-2012 Ceetron AS
|
2012-05-18 02:45:23 -05:00
|
|
|
//
|
|
|
|
// 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 <http://www.gnu.org/licenses/gpl.html>
|
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2017-01-10 02:51:39 -06:00
|
|
|
#include "RigEclipseCaseData.h"
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2016-05-26 08:17:49 -05:00
|
|
|
#include <ert/ecl/ecl_file.h>
|
2017-11-10 02:43:51 -06:00
|
|
|
#include "ert/ecl/ecl_kw_magic.h"
|
2016-05-26 08:17:49 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
#include "RiaStringEncodingTools.h"
|
|
|
|
#include "RiaTestDataDirectory.h"
|
2012-06-26 09:10:41 -05:00
|
|
|
#include "RifReaderEclipseOutput.h"
|
2013-02-05 03:51:32 -06:00
|
|
|
#include "RifEclipseOutputFileTools.h"
|
2019-03-18 06:52:01 -05:00
|
|
|
#include "RigEclipseCaseData.h"
|
2013-03-22 10:58:44 -05:00
|
|
|
#include "RigCaseCellResultsData.h"
|
2014-07-25 02:10:45 -05:00
|
|
|
#include "RifEclipseUnifiedRestartFileAccess.h"
|
2014-07-30 02:14:54 -05:00
|
|
|
#include "RifReaderSettings.h"
|
2019-03-18 06:52:01 -05:00
|
|
|
#include "RimEclipseResultCase.h"
|
2013-02-05 03:51:32 -06:00
|
|
|
|
2016-07-14 06:35:32 -05:00
|
|
|
#include <QDebug>
|
2019-03-18 06:52:01 -05:00
|
|
|
#include <QDir>
|
|
|
|
|
|
|
|
#include <memory>
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
using namespace RiaDefines;
|
2016-07-14 06:35:32 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-03-18 06:52:01 -05:00
|
|
|
TEST(RigReservoirTest, BasicTest10k)
|
|
|
|
{
|
|
|
|
QDir baseFolder(TEST_MODEL_DIR);
|
|
|
|
bool subFolderExists = baseFolder.cd("TEST10K_FLT_LGR_NNC");
|
|
|
|
EXPECT_TRUE(subFolderExists);
|
|
|
|
QString filename("TEST10K_FLT_LGR_NNC.EGRID");
|
|
|
|
QString filePath = baseFolder.absoluteFilePath(filename);
|
|
|
|
EXPECT_TRUE(QFile::exists(filePath));
|
|
|
|
|
|
|
|
std::unique_ptr<RimEclipseResultCase> resultCase(new RimEclipseResultCase);
|
|
|
|
cvf::ref<RigEclipseCaseData> reservoir = new RigEclipseCaseData(resultCase.get());
|
|
|
|
|
|
|
|
{
|
|
|
|
RigCaseCellResultsData* cellData = reservoir->results(MATRIX_MODEL);
|
|
|
|
|
|
|
|
QStringList staticResults = cellData->resultNames(STATIC_NATIVE);
|
|
|
|
EXPECT_EQ(0, staticResults.size());
|
|
|
|
//qDebug() << "Static results\n" << staticResults;
|
|
|
|
|
|
|
|
QStringList dynamicResults = cellData->resultNames(DYNAMIC_NATIVE);
|
|
|
|
EXPECT_EQ(0, dynamicResults.size());
|
|
|
|
//qDebug() << "Dynamic results\n" << dynamicResults;
|
|
|
|
|
|
|
|
int numTimeSteps = static_cast<int>(cellData->maxTimeStepCount());
|
|
|
|
EXPECT_EQ(0, numTimeSteps);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
cvf::ref<RifReaderEclipseOutput> readerInterfaceEcl = new RifReaderEclipseOutput;
|
|
|
|
bool result = readerInterfaceEcl->open(filePath, reservoir.p());
|
|
|
|
EXPECT_TRUE(result);
|
|
|
|
int numTimeSteps = static_cast<int>(readerInterfaceEcl->allTimeSteps().size());
|
|
|
|
EXPECT_EQ(9, numTimeSteps);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
RigCaseCellResultsData* cellData = reservoir->results(MATRIX_MODEL);
|
|
|
|
|
|
|
|
QStringList staticResults = cellData->resultNames(STATIC_NATIVE);
|
|
|
|
EXPECT_EQ(44, staticResults.size());
|
|
|
|
//qDebug() << "Static results\n" << staticResults;
|
|
|
|
|
|
|
|
QStringList dynamicResults = cellData->resultNames(DYNAMIC_NATIVE);
|
|
|
|
EXPECT_EQ(23, dynamicResults.size());
|
|
|
|
//qDebug() << "Dynamic results\n" << dynamicResults;
|
|
|
|
|
|
|
|
int numTimeSteps = static_cast<int>(cellData->maxTimeStepCount());
|
|
|
|
EXPECT_EQ(9, numTimeSteps);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(RigReservoirTest, BasicTest10kRestart)
|
2016-07-14 06:35:32 -05:00
|
|
|
{
|
|
|
|
RifEclipseUnifiedRestartFileAccess unrstAccess;
|
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
QDir baseFolder(TEST_MODEL_DIR);
|
|
|
|
bool subFolderExists = baseFolder.cd("TEST10K_FLT_LGR_NNC");
|
|
|
|
EXPECT_TRUE(subFolderExists);
|
|
|
|
QString filename("TEST10K_FLT_LGR_NNC.UNRST");
|
|
|
|
QString filePath = baseFolder.absoluteFilePath(filename);
|
|
|
|
EXPECT_TRUE(QFile::exists(filePath));
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
QStringList filenames;
|
|
|
|
filenames << filePath;
|
2016-07-14 06:35:32 -05:00
|
|
|
unrstAccess.setRestartFiles(filenames);
|
|
|
|
|
|
|
|
|
|
|
|
QStringList resultNames;
|
|
|
|
std::vector<size_t> dataItemCount;
|
|
|
|
|
|
|
|
unrstAccess.resultNames(&resultNames, &dataItemCount);
|
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
EXPECT_EQ(resultNames.size(), dataItemCount.size());
|
|
|
|
EXPECT_EQ(83, resultNames.size());
|
|
|
|
|
|
|
|
/* for (int i = 0; i < resultNames.size(); i++)
|
2016-07-14 06:35:32 -05:00
|
|
|
{
|
|
|
|
qDebug() << resultNames[i] << "\t" << dataItemCount[i];
|
2019-03-18 06:52:01 -05:00
|
|
|
} */
|
2016-07-14 06:35:32 -05:00
|
|
|
|
|
|
|
auto reportNums = unrstAccess.reportNumbers();
|
2019-03-18 06:52:01 -05:00
|
|
|
EXPECT_EQ((size_t) 9, reportNums.size());
|
|
|
|
|
|
|
|
/* for (auto reportNum : reportNums)
|
2016-07-14 06:35:32 -05:00
|
|
|
{
|
|
|
|
qDebug() << reportNum;
|
2019-03-18 06:52:01 -05:00
|
|
|
} */
|
|
|
|
}
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
TEST(RigReservoirTest, BasicTest10k_NativeECL)
|
|
|
|
{
|
|
|
|
QDir baseFolder(TEST_MODEL_DIR);
|
|
|
|
bool subFolderExists = baseFolder.cd("TEST10K_FLT_LGR_NNC");
|
|
|
|
EXPECT_TRUE(subFolderExists);
|
2016-07-14 06:35:32 -05:00
|
|
|
QString filename("TEST10K_FLT_LGR_NNC.EGRID");
|
2019-03-18 06:52:01 -05:00
|
|
|
QString filePath = baseFolder.absoluteFilePath(filename);
|
|
|
|
EXPECT_TRUE(QFile::exists(filePath));
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
ecl_grid_type* grid = ecl_grid_alloc(RiaStringEncodingTools::toNativeEncoded(filePath).data());
|
|
|
|
EXPECT_TRUE(grid);
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
QString subDir("RifReaderEclipseOutput");
|
|
|
|
QDir dataDir(TEST_DATA_DIR);
|
|
|
|
dataDir.mkdir(subDir);
|
|
|
|
dataDir.cd(subDir);
|
|
|
|
QString outFilePath = dataDir.absoluteFilePath("TEST10K_FLT_LGR_NNC_OUT.GRDECL");
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
#ifdef _MSC_VER
|
|
|
|
#pragma warning (push)
|
|
|
|
#pragma warning(disable : 4996)
|
|
|
|
#endif
|
|
|
|
FILE* filePtr = fopen(RiaStringEncodingTools::toNativeEncoded(outFilePath).data(), "w");
|
|
|
|
EXPECT_TRUE(filePtr != nullptr);
|
|
|
|
ecl_grid_fprintf_grdecl(grid, filePtr);
|
|
|
|
fclose(filePtr);
|
|
|
|
EXPECT_TRUE(QFile::exists(outFilePath));
|
|
|
|
|
|
|
|
QString expectedMd5("\xE9\x93\xB8Q@V\x8F\x13\xF4\xC3\x84\x96\x04p\n\x0F");
|
|
|
|
QByteArray generatedMd5 = RifEclipseOutputFileTools::md5sum(outFilePath);
|
|
|
|
EXPECT_TRUE(generatedMd5 == expectedMd5);
|
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
#pragma warning(pop)
|
|
|
|
#endif
|
|
|
|
}
|
2016-07-14 06:35:32 -05:00
|
|
|
|
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
TEST(RigReservoirTest, Test10k_ReadThenWriteToECL)
|
|
|
|
{
|
|
|
|
QDir baseFolder(TEST_MODEL_DIR);
|
|
|
|
bool subFolderExists = baseFolder.cd("TEST10K_FLT_LGR_NNC");
|
|
|
|
EXPECT_TRUE(subFolderExists);
|
|
|
|
QString filename("TEST10K_FLT_LGR_NNC.EGRID");
|
|
|
|
QString filePath = baseFolder.absoluteFilePath(filename);
|
|
|
|
EXPECT_TRUE(QFile::exists(filePath));
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
std::unique_ptr<RimEclipseResultCase> resultCase(new RimEclipseResultCase);
|
|
|
|
resultCase->setGridFileName(filePath);
|
|
|
|
resultCase->importGridAndResultMetaData(false);
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
QString subDir("RifReaderEclipseOutput");
|
|
|
|
QDir dataDir(TEST_DATA_DIR);
|
|
|
|
dataDir.mkdir(subDir);
|
|
|
|
dataDir.cd(subDir);
|
|
|
|
QString outFilePath = dataDir.absoluteFilePath("TEST10K_FLT_LGR_NNC_OUT_FROM_RES.GRDECL");
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
bool worked = RifReaderEclipseOutput::saveEclipseGrid(outFilePath, resultCase->eclipseCaseData());
|
|
|
|
EXPECT_TRUE(worked);
|
|
|
|
EXPECT_TRUE(QFile::exists(outFilePath));
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
QString dataFilePath = dataDir.absoluteFilePath("TEST10K_FLT_LGR_NNC_OUT_FROM_RES.VARS");
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
QStringList allStaticResults = resultCase->eclipseCaseData()->results(MATRIX_MODEL)->resultNames(RiaDefines::STATIC_NATIVE);
|
2016-07-14 06:35:32 -05:00
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
std::vector<QString> keywords;
|
|
|
|
for (QString keyword : allStaticResults)
|
|
|
|
{
|
|
|
|
keywords.push_back(keyword);
|
2016-07-14 06:35:32 -05:00
|
|
|
}
|
|
|
|
|
2019-03-18 06:52:01 -05:00
|
|
|
worked = RifReaderEclipseOutput::saveEclipseResults(dataFilePath, resultCase->eclipseCaseData(), keywords);
|
|
|
|
EXPECT_TRUE(worked);
|
|
|
|
EXPECT_TRUE(QFile::exists(dataFilePath));
|
2016-07-14 06:35:32 -05:00
|
|
|
}
|
2014-07-30 02:14:54 -05:00
|
|
|
#if 0
|
2013-02-05 03:51:32 -06:00
|
|
|
|
|
|
|
|
|
|
|
|
2014-07-30 02:14:54 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
TEST(RigReservoirTest, DISABLED_BasicTest)
|
|
|
|
{
|
|
|
|
|
|
|
|
cvf::ref<RifReaderEclipseOutput> readerInterfaceEcl = new RifReaderEclipseOutput;
|
|
|
|
cvf::ref<RigCaseData> reservoir = new RigCaseData;
|
|
|
|
|
|
|
|
QString filename("d:/Models/Statoil/troll_MSW/T07-4A-W2012-16-F3.EGRID");
|
|
|
|
|
|
|
|
RifReaderSettings readerSettings;
|
|
|
|
readerInterfaceEcl->setReaderSetting(&readerSettings);
|
|
|
|
|
|
|
|
bool result = readerInterfaceEcl->open(filename, reservoir.p());
|
|
|
|
EXPECT_TRUE(result);
|
|
|
|
|
|
|
|
{
|
|
|
|
// QStringList staticResults = readerInterfaceEcl->staticResults();
|
|
|
|
// EXPECT_EQ(42, staticResults.size());
|
|
|
|
// qDebug() << "Static results\n" << staticResults;
|
|
|
|
//
|
|
|
|
// QStringList dynamicResults = readerInterfaceEcl->dynamicResults();
|
|
|
|
// EXPECT_EQ(23, dynamicResults.size());
|
|
|
|
// qDebug() << "Dynamic results\n" << dynamicResults;
|
|
|
|
//
|
|
|
|
// int numTimeSteps = static_cast<int>(readerInterfaceEcl->numTimeSteps());
|
|
|
|
// EXPECT_EQ(9, numTimeSteps);
|
|
|
|
//
|
|
|
|
// QStringList timeStepText = readerInterfaceEcl->timeStepText();
|
|
|
|
// EXPECT_EQ(numTimeSteps, timeStepText.size());
|
|
|
|
// qDebug() << "Time step texts\n" << timeStepText;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
readerInterfaceEcl->close();
|
|
|
|
|
|
|
|
{
|
|
|
|
// QStringList staticResults = readerInterfaceEcl->staticResults();
|
|
|
|
// EXPECT_EQ(0, staticResults.size());
|
|
|
|
//
|
|
|
|
// QStringList dynamicResults = readerInterfaceEcl->dynamicResults();
|
|
|
|
// EXPECT_EQ(0, dynamicResults.size());
|
|
|
|
//
|
|
|
|
// int numTimeSteps = static_cast<int>(readerInterfaceEcl->numTimeSteps());
|
|
|
|
// EXPECT_EQ(0, numTimeSteps);
|
|
|
|
//
|
|
|
|
// QStringList timeStepText = readerInterfaceEcl->timeStepText();
|
|
|
|
// EXPECT_EQ(numTimeSteps, timeStepText.size());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2013-02-05 03:51:32 -06:00
|
|
|
|
2014-07-25 02:10:45 -05:00
|
|
|
|
2014-07-30 02:14:54 -05:00
|
|
|
|
|
|
|
TEST(RigReservoirTest, DISABLED_FileOutputToolsTest)
|
2013-02-05 03:51:32 -06:00
|
|
|
{
|
2014-07-30 02:14:54 -05:00
|
|
|
cvf::DebugTimer timer("test");
|
|
|
|
|
|
|
|
|
2013-02-05 03:51:32 -06:00
|
|
|
// QString filename("d:/Models/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.EGRID");
|
2014-07-25 02:10:45 -05:00
|
|
|
// QString filename("d:/Models/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.UNRST");
|
2014-07-30 02:14:54 -05:00
|
|
|
// QString filename("d:/Models/Statoil/troll_MSW/T07-4A-W2012-16-F3.UNRST");
|
|
|
|
QString filename("c:/tmp/troll_MSW/T07-4A-W2012-16-F3.UNRST");
|
|
|
|
|
2013-02-05 03:51:32 -06:00
|
|
|
|
2014-07-25 02:10:45 -05:00
|
|
|
ecl_file_type* ertFile = ecl_file_open(filename.toAscii().data(), ECL_FILE_CLOSE_STREAM);
|
2013-02-05 03:51:32 -06:00
|
|
|
EXPECT_TRUE(ertFile);
|
|
|
|
|
|
|
|
|
|
|
|
QStringList keywords;
|
|
|
|
std::vector<size_t> keywordDataItemCounts;
|
|
|
|
RifEclipseOutputFileTools::findKeywordsAndDataItemCounts(ertFile, &keywords, &keywordDataItemCounts);
|
|
|
|
|
|
|
|
EXPECT_TRUE(keywords.size() == keywordDataItemCounts.size());
|
|
|
|
|
|
|
|
qDebug() << "Keyword - Number of data items";
|
|
|
|
for (int i = 0; i < keywords.size(); i++)
|
|
|
|
{
|
|
|
|
QString paddedKeyword = QString("%1").arg(keywords[i], 8);
|
|
|
|
qDebug() << paddedKeyword << " - " << keywordDataItemCounts[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
ecl_file_close(ertFile);
|
2018-10-10 03:17:07 -05:00
|
|
|
ertFile = nullptr;
|
2014-07-30 02:14:54 -05:00
|
|
|
|
|
|
|
timer.reportTime();
|
|
|
|
//qDebug() << timer.lapt;
|
2013-02-05 03:51:32 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-07-25 02:10:45 -05:00
|
|
|
TEST(RigReservoirTest, UnifiedTestFile)
|
|
|
|
{
|
2014-07-30 02:14:54 -05:00
|
|
|
//QString filename("d:/Models/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.UNRST");
|
|
|
|
QString filename("d:/Models/Statoil/troll_MSW/T07-4A-W2012-16-F3.UNRST");
|
2014-07-25 02:10:45 -05:00
|
|
|
|
|
|
|
{
|
|
|
|
cvf::ref<RifEclipseUnifiedRestartFileAccess> restartFile = new RifEclipseUnifiedRestartFileAccess();
|
|
|
|
|
|
|
|
QStringList fileNameList;
|
|
|
|
fileNameList << filename;
|
|
|
|
restartFile->setRestartFiles(fileNameList);
|
|
|
|
restartFile->open();
|
|
|
|
|
|
|
|
QStringList resultNames;
|
|
|
|
std::vector<size_t> resultDataItemCounts;
|
|
|
|
restartFile->resultNames(&resultNames, &resultDataItemCounts);
|
|
|
|
|
2014-07-30 02:14:54 -05:00
|
|
|
qDebug() << "Result names\n";
|
2014-07-25 02:10:45 -05:00
|
|
|
for (int i = 0; i < resultNames.size(); i++)
|
|
|
|
{
|
2014-07-30 02:14:54 -05:00
|
|
|
qDebug() << resultNames[i] << "\t" << resultDataItemCounts[i];
|
2014-07-25 02:10:45 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
std::vector<QDateTime> tsteps = restartFile->timeSteps();
|
|
|
|
|
|
|
|
qDebug() << "Time step texts\n";
|
|
|
|
for (int i = 0; i < tsteps.size(); i++)
|
|
|
|
{
|
|
|
|
qDebug() << tsteps[i].toString();
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
std::vector<double> resultValues;
|
|
|
|
size_t timeStep = 0;
|
|
|
|
restartFile->results(resultNames[0], timeStep, &resultValues);
|
|
|
|
|
|
|
|
size_t i;
|
|
|
|
for (i = 0; i < 500; i++)
|
|
|
|
{
|
|
|
|
qDebug() << resultValues[i];
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-08-11 07:05:59 -05:00
|
|
|
void buildResultInfoString(RigReservoir* reservoir, RiaDefines::PorosityModelType porosityModel, RiaDefines::ResultCatType resultType)
|
2013-02-05 03:51:32 -06:00
|
|
|
{
|
2013-03-22 10:58:44 -05:00
|
|
|
RigCaseCellResultsData* matrixResults = reservoir->results(porosityModel);
|
2013-02-05 03:51:32 -06:00
|
|
|
{
|
|
|
|
QStringList resultNames = matrixResults->resultNames(resultType);
|
|
|
|
|
|
|
|
for (size_t i = 0 ; i < resultNames.size(); i++)
|
|
|
|
{
|
|
|
|
std::vector<double> values;
|
|
|
|
size_t scalarResultIndex = matrixResults->findOrLoadScalarResult(resultType, resultNames[i]);
|
|
|
|
EXPECT_TRUE(scalarResultIndex != cvf::UNDEFINED_SIZE_T);
|
|
|
|
|
|
|
|
QString resultText = QString("%1").arg(resultNames[i], 8);
|
|
|
|
std::vector< std::vector<double> > & resultValues = matrixResults->cellScalarResults(scalarResultIndex);
|
|
|
|
for (size_t timeStepIdx = 0; timeStepIdx < matrixResults->timeStepCount(scalarResultIndex); timeStepIdx++)
|
|
|
|
{
|
|
|
|
size_t resultValueCount = resultValues[timeStepIdx].size();
|
|
|
|
resultText += QString(" %1").arg(resultValueCount);
|
|
|
|
}
|
|
|
|
|
|
|
|
qDebug() << resultText;
|
|
|
|
}
|
|
|
|
qDebug() << "Number of items : " << resultNames.size();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(RigReservoirTest, DualPorosityTest)
|
|
|
|
{
|
|
|
|
cvf::ref<RifReaderEclipseOutput> readerInterfaceEcl = new RifReaderEclipseOutput;
|
|
|
|
cvf::ref<RigReservoir> reservoir = new RigReservoir;
|
|
|
|
|
|
|
|
QString filename("d:/Models/Statoil/DualProperty/DUALPORO.EGRID");
|
|
|
|
//QString filename("d:/Models/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.EGRID");
|
|
|
|
|
|
|
|
|
|
|
|
bool result = readerInterfaceEcl->open(filename, reservoir.p());
|
|
|
|
EXPECT_TRUE(result);
|
|
|
|
|
|
|
|
|
|
|
|
qDebug() << "\n\n" <<
|
|
|
|
"Matrix porosities, DYNAMIC results" <<
|
|
|
|
"----------------------------------";
|
2017-08-11 07:05:59 -05:00
|
|
|
buildResultInfoString(reservoir.p(), RiaDefines::MATRIX_MODEL, RiaDefines::DYNAMIC_NATIVE);
|
2013-02-05 03:51:32 -06:00
|
|
|
|
|
|
|
qDebug() << "\n\n" <<
|
|
|
|
"Matrix porosities, STATIC results" <<
|
|
|
|
"----------------------------------";
|
2017-08-11 07:05:59 -05:00
|
|
|
buildResultInfoString(reservoir.p(), RiaDefines::MATRIX_MODEL, RiaDefines::STATIC_NATIVE);
|
2013-02-05 03:51:32 -06:00
|
|
|
|
|
|
|
qDebug() << "\n\n" <<
|
|
|
|
"Fracture porosities, DYNAMIC results" <<
|
|
|
|
"----------------------------------";
|
2017-08-11 07:05:59 -05:00
|
|
|
buildResultInfoString(reservoir.p(), RiaDefines::FRACTURE_MODEL, RiaDefines::DYNAMIC_NATIVE);
|
2013-02-05 03:51:32 -06:00
|
|
|
|
|
|
|
qDebug() << "\n\n" <<
|
|
|
|
"Fracture porosities, STATIC results" <<
|
|
|
|
"----------------------------------";
|
2017-08-11 07:05:59 -05:00
|
|
|
buildResultInfoString(reservoir.p(), RiaDefines::FRACTURE_MODEL, RiaDefines::STATIC_NATIVE);
|
2013-02-05 03:51:32 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
//#include "RifEclipseUnifiedRestartFileAccess.h"
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
/*
|
|
|
|
TEST(RigReservoirTest, UnifiedTestFile)
|
|
|
|
{
|
|
|
|
|
|
|
|
// Location of test dataset received from Håkon Høgstøl in July 2011 with 10k active cells
|
|
|
|
#ifdef WIN32
|
|
|
|
QString filename("d:/Models/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.UNRST");
|
|
|
|
#else
|
|
|
|
QString filename("/mnt/hgfs/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.UNRST");
|
|
|
|
#endif
|
|
|
|
|
|
|
|
size_t numActiveCells = 11125;
|
|
|
|
size_t numGrids = 2;
|
|
|
|
|
|
|
|
{
|
|
|
|
cvf::ref<RifEclipseUnifiedRestartFileAccess> restartFile = new RifEclipseUnifiedRestartFileAccess(numGrids, numActiveCells);
|
|
|
|
|
|
|
|
QStringList fileNameList;
|
|
|
|
fileNameList << filename;
|
|
|
|
restartFile->open(fileNameList);
|
|
|
|
|
|
|
|
QStringList resultNames = restartFile->resultNames();
|
|
|
|
qDebug() << "Result names\n" << resultNames;
|
|
|
|
|
|
|
|
QStringList timeStepText = restartFile->timeStepsText();
|
|
|
|
qDebug() << "Time step texts\n" << timeStepText;
|
|
|
|
|
|
|
|
std::vector<double> resultValues;
|
|
|
|
size_t timeStep = 0;
|
|
|
|
restartFile->results(resultNames[0], timeStep, &resultValues);
|
|
|
|
|
|
|
|
size_t i;
|
|
|
|
for (i = 0; i < 500; i++)
|
|
|
|
{
|
|
|
|
qDebug() << resultValues[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
TEST(RigReservoirTest, BasicTest)
|
|
|
|
{
|
2012-06-26 09:10:41 -05:00
|
|
|
cvf::ref<RifReaderEclipseOutput> readerInterfaceEcl = new RifReaderEclipseOutput;
|
2012-05-18 02:45:23 -05:00
|
|
|
cvf::ref<RigReservoir> reservoir = new RigReservoir;
|
|
|
|
|
|
|
|
// Location of test dataset received from Håkon Høgstøl in July 2011 with 10k active cells
|
2012-06-26 09:10:41 -05:00
|
|
|
#ifdef WIN32
|
|
|
|
QString filename("TEST10K_FLT_LGR_NNC.EGRID");
|
|
|
|
#else
|
2012-05-18 02:45:23 -05:00
|
|
|
QString filename("/mnt/hgfs/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.EGRID");
|
2012-06-26 09:10:41 -05:00
|
|
|
#endif
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
bool result = readerInterfaceEcl->open(filename, reservoir.p());
|
|
|
|
EXPECT_TRUE(result);
|
|
|
|
|
|
|
|
{
|
|
|
|
QStringList staticResults = readerInterfaceEcl->staticResults();
|
|
|
|
EXPECT_EQ(42, staticResults.size());
|
|
|
|
qDebug() << "Static results\n" << staticResults;
|
|
|
|
|
|
|
|
QStringList dynamicResults = readerInterfaceEcl->dynamicResults();
|
|
|
|
EXPECT_EQ(23, dynamicResults.size());
|
|
|
|
qDebug() << "Dynamic results\n" << dynamicResults;
|
|
|
|
|
|
|
|
int numTimeSteps = static_cast<int>(readerInterfaceEcl->numTimeSteps());
|
|
|
|
EXPECT_EQ(9, numTimeSteps);
|
|
|
|
|
|
|
|
QStringList timeStepText = readerInterfaceEcl->timeStepText();
|
|
|
|
EXPECT_EQ(numTimeSteps, timeStepText.size());
|
|
|
|
qDebug() << "Time step texts\n" << timeStepText;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
readerInterfaceEcl->close();
|
|
|
|
|
|
|
|
{
|
|
|
|
QStringList staticResults = readerInterfaceEcl->staticResults();
|
|
|
|
EXPECT_EQ(0, staticResults.size());
|
|
|
|
|
|
|
|
QStringList dynamicResults = readerInterfaceEcl->dynamicResults();
|
|
|
|
EXPECT_EQ(0, dynamicResults.size());
|
|
|
|
|
|
|
|
int numTimeSteps = static_cast<int>(readerInterfaceEcl->numTimeSteps());
|
|
|
|
EXPECT_EQ(0, numTimeSteps);
|
|
|
|
|
|
|
|
QStringList timeStepText = readerInterfaceEcl->timeStepText();
|
|
|
|
EXPECT_EQ(numTimeSteps, timeStepText.size());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
TEST(RigReservoirTest, WellTest)
|
|
|
|
{
|
2012-06-26 09:10:41 -05:00
|
|
|
cvf::ref<RifReaderEclipseOutput> readerInterfaceEcl = new RifReaderEclipseOutput;
|
2017-01-10 02:51:39 -06:00
|
|
|
cvf::ref<RigEclipseCaseData> reservoir = new RigEclipseCaseData;
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
// Location of test dataset received from Håkon Høgstøl in July 2011 with 10k active cells
|
2012-06-26 09:10:41 -05:00
|
|
|
#ifdef WIN32
|
|
|
|
QString filename("TEST10K_FLT_LGR_NNC.EGRID");
|
|
|
|
#else
|
2012-05-18 02:45:23 -05:00
|
|
|
QString filename("/mnt/hgfs/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.EGRID");
|
2012-06-26 09:10:41 -05:00
|
|
|
#endif
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
bool result = readerInterfaceEcl->open(filename, reservoir.p());
|
|
|
|
EXPECT_TRUE(result);
|
|
|
|
|
|
|
|
cvf::UByteArray* mainGridWellCells = reservoir->wellCellsInGrid(0);
|
|
|
|
EXPECT_TRUE(mainGridWellCells->size() == reservoir->mainGrid()->cellCount());
|
|
|
|
}
|
2012-06-26 09:10:41 -05:00
|
|
|
|
2013-02-05 03:51:32 -06:00
|
|
|
|
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
#endif
|
2013-02-05 03:51:32 -06:00
|
|
|
|
2017-03-23 01:00:00 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2017-08-17 07:40:47 -05:00
|
|
|
TEST(DISABLED_RigReservoirTest, WellTest)
|
2017-03-23 01:00:00 -05:00
|
|
|
{
|
|
|
|
cvf::ref<RifReaderEclipseOutput> readerInterfaceEcl = new RifReaderEclipseOutput;
|
2017-09-08 07:43:28 -05:00
|
|
|
cvf::ref<RigEclipseCaseData> reservoir = new RigEclipseCaseData(nullptr);
|
2017-03-23 01:00:00 -05:00
|
|
|
|
|
|
|
// Location of test dataset received from Håkon Høgstøl in July 2011 with 10k active cells
|
|
|
|
#ifdef WIN32
|
|
|
|
QString filename("d:/Models/Statoil/soursim/PKMUNK_NOV_TEST_SS.GRID");
|
2017-03-24 05:17:12 -05:00
|
|
|
QString sourSim("d:/Models/Statoil/soursim/result.sourres.00001");
|
2017-03-23 01:00:00 -05:00
|
|
|
#else
|
|
|
|
QString filename("/mnt/hgfs/Statoil/testcase_juli_2011/data/TEST10K_FLT_LGR_NNC.EGRID");
|
|
|
|
QString sourSim("d:/Models/Statoil/soursim/result.sourres");
|
|
|
|
#endif
|
|
|
|
|
|
|
|
bool result = readerInterfaceEcl->open(filename, reservoir.p());
|
|
|
|
EXPECT_TRUE(result);
|
|
|
|
|
|
|
|
readerInterfaceEcl->setHdf5FileName(sourSim);
|
2017-03-24 05:17:12 -05:00
|
|
|
}
|
2017-11-10 02:43:51 -06:00
|
|
|
|