2023-03-02 04:35:26 -06:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2023- 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 <http://www.gnu.org/licenses/gpl.html>
|
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include "RifRevealCsvSectionSummaryReader.h"
|
|
|
|
|
|
|
|
#include "RiaDateStringParser.h"
|
|
|
|
#include "RiaLogging.h"
|
|
|
|
#include "RiaQDateTimeTools.h"
|
|
|
|
|
|
|
|
#include "RifCsvUserDataParser.h"
|
2023-06-14 03:32:14 -05:00
|
|
|
#include "RifEclipseSummaryAddress.h"
|
2023-03-02 04:35:26 -06:00
|
|
|
#include "RifEclipseUserDataKeywordTools.h"
|
|
|
|
#include "RifEclipseUserDataParserTools.h"
|
|
|
|
|
|
|
|
#include "SummaryPlotCommands/RicPasteAsciiDataToSummaryPlotFeatureUi.h"
|
|
|
|
|
|
|
|
#include "cafUtils.h"
|
|
|
|
|
|
|
|
#include <QDateTime>
|
|
|
|
#include <QFile>
|
|
|
|
#include <QTextStream>
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RifRevealCsvSectionSummaryReader::RifRevealCsvSectionSummaryReader()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RifRevealCsvSectionSummaryReader::~RifRevealCsvSectionSummaryReader()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2023-09-18 02:29:37 -05:00
|
|
|
bool RifRevealCsvSectionSummaryReader::parse( const QString& text,
|
2023-09-18 02:28:29 -05:00
|
|
|
RifEclipseSummaryAddressDefines::SummaryCategory defaultCategory,
|
2023-09-18 02:29:37 -05:00
|
|
|
QString* errorText )
|
2023-03-02 04:35:26 -06:00
|
|
|
{
|
|
|
|
m_allResultAddresses.clear();
|
|
|
|
m_mapFromAddressToResultIndex.clear();
|
|
|
|
|
|
|
|
AsciiDataParseOptions parseOptions;
|
|
|
|
parseOptions.useCustomDateTimeFormat = true;
|
|
|
|
parseOptions.dateTimeFormat = "dd.MM.yyyy hh:mm:ss";
|
|
|
|
parseOptions.fallbackDateTimeFormat = "dd.MM.yyyy";
|
|
|
|
parseOptions.cellSeparator = ",";
|
|
|
|
parseOptions.decimalSeparator = ".";
|
|
|
|
parseOptions.timeSeriesColumnName = "Date";
|
|
|
|
parseOptions.defaultCategory = defaultCategory;
|
|
|
|
|
|
|
|
m_parser = std::unique_ptr<RifCsvUserDataPastedTextParser>( new RifCsvUserDataPastedTextParser( text, errorText ) );
|
2023-04-24 04:28:38 -05:00
|
|
|
std::map<QString, std::pair<QString, double>> unitMapping = { { "Sm3", { "SM3", 1.0 } },
|
|
|
|
{ "Sm3/day", { "SM3/DAY", 1.0 } },
|
|
|
|
{ "Sm3/day/bar", { "SM3/DAY/BAR", 1.0 } },
|
|
|
|
{ "Sm3/Sm3", { "SM3/SM3", 1.0 } },
|
|
|
|
{ "rm3", { "RM3", 1.0 } },
|
|
|
|
{ "rm3/day", { "RM3/DAY", 1.0 } },
|
|
|
|
{ "rm3/day/bar", { "RM3/DAY/BAR", 1.0 } },
|
|
|
|
{ "Rm3/day/bar", { "RM3/DAY/BAR", 1.0 } },
|
|
|
|
{ "BARa", { "BARSA", 1.0 } },
|
|
|
|
{ "fraction", { "", 1.0 } },
|
|
|
|
{ "1000Sm3/d", { "SM3/DAY", 1000.0 } },
|
|
|
|
{ "MSm3", { "SM3", 1000000.0 } } };
|
|
|
|
|
2023-09-18 02:28:29 -05:00
|
|
|
QString prefix = defaultCategory == RifEclipseSummaryAddressDefines::SummaryCategory::SUMMARY_FIELD ? "F" : "W";
|
2023-06-14 03:32:14 -05:00
|
|
|
|
|
|
|
std::map<QString, QString> nameMapping = { { "WaterCut", prefix + "WCT" }, { "GOR", prefix + "GOR" },
|
|
|
|
{ "BottomHolePressure", prefix + "BHP" }, { "CumLiquidInjected", prefix + "LIT" },
|
|
|
|
{ "CumWaterInjected", prefix + "WIT" }, { "CumGasInjected", prefix + "GIT" },
|
|
|
|
{ "CumOilInjected", prefix + "OIT" }, { "CumLiquidProduced", prefix + "LPT" },
|
|
|
|
{ "CumWaterProduced", prefix + "WPT" }, { "CumGasProduced", prefix + "GPT" },
|
|
|
|
{ "CumOilProduced", prefix + "OPT" }, { "LiquidProduced", prefix + "LPR" },
|
|
|
|
{ "WaterProduced", prefix + "WPR" }, { "GasProduced", prefix + "GPR" },
|
|
|
|
{ "OilProduced", prefix + "OPR" }, { "LiquidInjected", prefix + "LIR" },
|
|
|
|
{ "WaterInjected", prefix + "WIR" }, { "GasInjected", prefix + "GIR" },
|
|
|
|
{ "OilInjected", prefix + "OIR" }, { "WaterGasRatio", prefix + "WGR" },
|
|
|
|
{ "GasLiftRate", prefix + "GLIR" } };
|
|
|
|
|
|
|
|
if ( !m_parser->parse( parseOptions, nameMapping, unitMapping ) )
|
2023-03-02 04:35:26 -06:00
|
|
|
{
|
|
|
|
RiaLogging::error( QString( "Failed to parse file" ) );
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
buildTimeStepsAndMappings();
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|