mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-26 16:26:48 -06:00
212 lines
7.8 KiB
C++
212 lines
7.8 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (C) Statoil 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 <http://www.gnu.org/licenses/gpl.html>
|
|
// for more details.
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "RifEclipseSummaryTools.h"
|
|
|
|
#include "RifReaderEclipseSummary.h"
|
|
|
|
#include "ert/ecl/ecl_util.h"
|
|
|
|
#include <iostream>
|
|
#include "cafAppEnum.h"
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RifEclipseSummaryTools::findSummaryHeaderFile(const std::string& inputFile, std::string* headerFile, bool* isFormatted)
|
|
{
|
|
findSummaryHeaderFileInfo(inputFile, headerFile, NULL, NULL, isFormatted);
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RifEclipseSummaryTools::findSummaryFiles(const std::string& inputFile,
|
|
std::string* headerFile,
|
|
std::vector<std::string>* dataFiles)
|
|
{
|
|
dataFiles->clear();
|
|
headerFile->clear();
|
|
|
|
char* myPath = NULL;
|
|
char* myBase = NULL;
|
|
char* myExtention = NULL;
|
|
|
|
util_alloc_file_components(inputFile.data(), &myPath, &myBase, &myExtention);
|
|
|
|
std::string path; if(myPath) path = myPath;
|
|
std::string base; if(myBase) base = myBase;
|
|
std::string extention; if(myExtention) extention = myExtention;
|
|
|
|
if(path.empty() || base.empty()) return ;
|
|
|
|
char* myHeaderFile = NULL;
|
|
stringlist_type* summary_file_list = stringlist_alloc_new();
|
|
|
|
ecl_util_alloc_summary_files(path.data(), base.data(), extention.data(), &myHeaderFile, summary_file_list);
|
|
if(myHeaderFile)
|
|
{
|
|
(*headerFile) = myHeaderFile;
|
|
util_safe_free(myHeaderFile);
|
|
}
|
|
|
|
if(stringlist_get_size(summary_file_list) > 0)
|
|
{
|
|
for(int i = 0; i < stringlist_get_size(summary_file_list); i++)
|
|
{
|
|
dataFiles->push_back(stringlist_iget(summary_file_list,i));
|
|
}
|
|
}
|
|
stringlist_free(summary_file_list);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
bool RifEclipseSummaryTools::hasSummaryFiles(const std::string& gridFileName)
|
|
{
|
|
std::string headerFileName;
|
|
std::vector<std::string> dataFileNames;
|
|
RifEclipseSummaryTools::findSummaryFiles(gridFileName, &headerFileName, &dataFileNames);
|
|
if (!headerFileName.empty() && dataFileNames.size()) return true;
|
|
|
|
return false;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
std::vector<std::string> RifEclipseSummaryTools::findSummaryDataFiles(const std::string& caseFile)
|
|
{
|
|
std::vector<std::string> fileNames;
|
|
|
|
std::string path;
|
|
std::string base;
|
|
|
|
findSummaryHeaderFileInfo(caseFile, NULL, &path, &base, NULL);
|
|
if (path.empty() || base.empty()) return fileNames;
|
|
|
|
char* header_file = NULL;
|
|
stringlist_type* summary_file_list = stringlist_alloc_new();
|
|
|
|
ecl_util_alloc_summary_files(path.data(), base.data(), NULL, &header_file, summary_file_list);
|
|
if (stringlist_get_size( summary_file_list ) > 0)
|
|
{
|
|
for (int i = 0; i < stringlist_get_size(summary_file_list); i++)
|
|
{
|
|
fileNames.push_back(stringlist_iget(summary_file_list, i));
|
|
}
|
|
}
|
|
|
|
util_safe_free(header_file);
|
|
stringlist_free(summary_file_list);
|
|
|
|
return fileNames;
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RifEclipseSummaryTools::dumpMetaData(RifReaderEclipseSummary* readerEclipseSummary)
|
|
{
|
|
std::vector<RifEclipseSummaryAddress> addresses = readerEclipseSummary->allResultAddresses();
|
|
|
|
for (int category = 0; category < RifEclipseSummaryAddress::SUMMARY_BLOCK_LGR; category++)
|
|
{
|
|
RifEclipseSummaryAddress::SummaryVarCategory categoryEnum = RifEclipseSummaryAddress::SummaryVarCategory(category);
|
|
|
|
std::vector<RifEclipseSummaryAddress> catAddresses = addressesForCategory(addresses, categoryEnum);
|
|
|
|
if (catAddresses.size() > 0)
|
|
{
|
|
std::cout << caf::AppEnum<RifEclipseSummaryAddress::SummaryVarCategory>::uiText(categoryEnum).toStdString() << " count : " << catAddresses.size() << std::endl;
|
|
|
|
for (size_t i = 0; i < catAddresses.size(); i++)
|
|
{
|
|
std::cout << catAddresses[i].quantityName() << " "
|
|
<< catAddresses[i].regionNumber() << " "
|
|
<< catAddresses[i].regionNumber2() << " "
|
|
<< catAddresses[i].wellGroupName() << " "
|
|
<< catAddresses[i].wellName() << " "
|
|
<< catAddresses[i].wellSegmentNumber() << " "
|
|
<< catAddresses[i].lgrName() << " "
|
|
<< catAddresses[i].cellI() << " "
|
|
<< catAddresses[i].cellJ() << " "
|
|
<< catAddresses[i].cellK() << std::endl;
|
|
}
|
|
|
|
std::cout << std::endl;
|
|
}
|
|
}
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
void RifEclipseSummaryTools::findSummaryHeaderFileInfo(const std::string& inputFile, std::string* headerFile, std::string* path, std::string* base, bool* isFormatted)
|
|
{
|
|
char* myPath = NULL;
|
|
char* myBase = NULL;
|
|
bool formattedFile = true;
|
|
|
|
util_alloc_file_components(inputFile.data(), &myPath, &myBase, NULL);
|
|
|
|
char* myHeaderFile = ecl_util_alloc_exfilename(myPath, myBase, ECL_SUMMARY_HEADER_FILE, true, -1);
|
|
if (!myHeaderFile)
|
|
{
|
|
myHeaderFile = ecl_util_alloc_exfilename(myPath, myBase, ECL_SUMMARY_HEADER_FILE, false, -1);
|
|
if (myHeaderFile)
|
|
{
|
|
formattedFile = false;
|
|
}
|
|
}
|
|
|
|
if (myHeaderFile && headerFile) *headerFile = myHeaderFile;
|
|
if (myPath && path) *path = myPath;
|
|
if (myBase && base) *base = myBase;
|
|
if (isFormatted) *isFormatted = formattedFile;
|
|
|
|
util_safe_free(myHeaderFile);
|
|
util_safe_free(myBase);
|
|
util_safe_free(myPath);
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
std::vector<RifEclipseSummaryAddress> RifEclipseSummaryTools::addressesForCategory(const std::vector<RifEclipseSummaryAddress>& addresses, RifEclipseSummaryAddress::SummaryVarCategory category)
|
|
{
|
|
std::vector<RifEclipseSummaryAddress> filteredAddresses;
|
|
|
|
for (size_t i = 0; i < addresses.size(); i++)
|
|
{
|
|
if (addresses[i].category() == category)
|
|
{
|
|
filteredAddresses.push_back(addresses[i]);
|
|
}
|
|
}
|
|
|
|
return filteredAddresses;
|
|
}
|