2012-05-18 02:45:23 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// 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 <http://www.gnu.org/licenses/gpl.html>
|
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2013-03-22 10:58:44 -05:00
|
|
|
#include "RigCaseCellResultsData.h"
|
2012-06-26 09:10:41 -05:00
|
|
|
|
2014-08-18 05:03:21 -05:00
|
|
|
#include "RigMainGrid.h"
|
|
|
|
#include "RigStatisticsDataCache.h"
|
2013-04-05 03:49:39 -05:00
|
|
|
#include "RigStatisticsMath.h"
|
2014-08-18 05:03:21 -05:00
|
|
|
#include "RigStatisticsCalculator.h"
|
2013-04-05 03:49:39 -05:00
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
#include <QDateTime>
|
2013-02-13 07:59:30 -06:00
|
|
|
#include <math.h>
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
RigCaseCellResultsData::RigCaseCellResultsData(RigMainGrid* ownerGrid)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2012-06-26 09:10:41 -05:00
|
|
|
CVF_ASSERT(ownerGrid != NULL);
|
|
|
|
m_ownerMainGrid = ownerGrid;
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
|
2013-03-19 02:28:25 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigCaseCellResultsData::setMainGrid(RigMainGrid* ownerGrid)
|
2013-03-19 02:28:25 -05:00
|
|
|
{
|
|
|
|
m_ownerMainGrid = ownerGrid;
|
|
|
|
}
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2014-08-18 05:03:21 -05:00
|
|
|
void RigCaseCellResultsData::minMaxCellScalarValues(size_t scalarResultIndex, double& min, double& max)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2014-08-18 05:03:21 -05:00
|
|
|
m_statisticsDataCache[scalarResultIndex]->minMaxCellScalarValues(min, max);
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigCaseCellResultsData::minMaxCellScalarValues(size_t scalarResultIndex, size_t timeStepIndex, double& min, double& max)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2014-08-18 05:03:21 -05:00
|
|
|
m_statisticsDataCache[scalarResultIndex]->minMaxCellScalarValues(timeStepIndex, min, max);
|
|
|
|
}
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2014-08-18 05:03:21 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigCaseCellResultsData::posNegClosestToZero(size_t scalarResultIndex, double& pos, double& neg)
|
|
|
|
{
|
|
|
|
m_statisticsDataCache[scalarResultIndex]->posNegClosestToZero(pos, neg);
|
|
|
|
}
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2014-08-18 05:03:21 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigCaseCellResultsData::posNegClosestToZero(size_t scalarResultIndex, size_t timeStepIndex, double& pos, double& neg)
|
|
|
|
{
|
|
|
|
m_statisticsDataCache[scalarResultIndex]->posNegClosestToZero(timeStepIndex, pos, neg);
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
|
2012-09-11 02:22:36 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
const std::vector<size_t>& RigCaseCellResultsData::cellScalarValuesHistogram(size_t scalarResultIndex)
|
2012-09-11 02:22:36 -05:00
|
|
|
{
|
2014-08-18 05:03:21 -05:00
|
|
|
return m_statisticsDataCache[scalarResultIndex]->cellScalarValuesHistogram();
|
2012-09-11 02:22:36 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigCaseCellResultsData::p10p90CellScalarValues(size_t scalarResultIndex, double& p10, double& p90)
|
2012-09-11 02:22:36 -05:00
|
|
|
{
|
2014-08-18 05:03:21 -05:00
|
|
|
m_statisticsDataCache[scalarResultIndex]->p10p90CellScalarValues(p10, p90);
|
2012-09-11 02:22:36 -05:00
|
|
|
}
|
|
|
|
|
2012-10-23 05:08:46 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigCaseCellResultsData::meanCellScalarValues(size_t scalarResultIndex, double& meanValue)
|
2012-10-23 05:08:46 -05:00
|
|
|
{
|
2014-08-18 05:03:21 -05:00
|
|
|
m_statisticsDataCache[scalarResultIndex]->meanCellScalarValues(meanValue);
|
2012-10-23 05:08:46 -05:00
|
|
|
}
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
size_t RigCaseCellResultsData::resultCount() const
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
return m_cellScalarResults.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
size_t RigCaseCellResultsData::timeStepCount(size_t scalarResultIndex) const
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
CVF_TIGHT_ASSERT(scalarResultIndex < resultCount());
|
|
|
|
|
|
|
|
return m_cellScalarResults[scalarResultIndex].size();
|
|
|
|
}
|
|
|
|
|
2013-02-13 06:10:54 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
const std::vector< std::vector<double> > & RigCaseCellResultsData::cellScalarResults( size_t scalarResultIndex ) const
|
2013-02-13 06:10:54 -06:00
|
|
|
{
|
|
|
|
CVF_TIGHT_ASSERT(scalarResultIndex < resultCount());
|
|
|
|
|
|
|
|
return m_cellScalarResults[scalarResultIndex];
|
|
|
|
}
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
std::vector< std::vector<double> > & RigCaseCellResultsData::cellScalarResults( size_t scalarResultIndex )
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
CVF_TIGHT_ASSERT(scalarResultIndex < resultCount());
|
|
|
|
|
|
|
|
return m_cellScalarResults[scalarResultIndex];
|
|
|
|
}
|
|
|
|
|
2013-03-13 04:29:47 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
std::vector<double>& RigCaseCellResultsData::cellScalarResults(size_t scalarResultIndex, size_t timeStepIndex)
|
2013-03-13 04:29:47 -05:00
|
|
|
{
|
|
|
|
CVF_TIGHT_ASSERT(scalarResultIndex < resultCount());
|
|
|
|
CVF_TIGHT_ASSERT(timeStepIndex < m_cellScalarResults[scalarResultIndex].size());
|
|
|
|
|
|
|
|
return m_cellScalarResults[scalarResultIndex][timeStepIndex];
|
|
|
|
}
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
double RigCaseCellResultsData::cellScalarResult( size_t scalarResultIndex, size_t timeStepIndex, size_t resultValueIndex)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2012-08-31 12:12:47 -05:00
|
|
|
if (scalarResultIndex < resultCount() &&
|
|
|
|
timeStepIndex < m_cellScalarResults[scalarResultIndex].size() &&
|
|
|
|
resultValueIndex != cvf::UNDEFINED_SIZE_T &&
|
|
|
|
resultValueIndex < m_cellScalarResults[scalarResultIndex][timeStepIndex].size())
|
|
|
|
{
|
|
|
|
return m_cellScalarResults[scalarResultIndex][timeStepIndex][resultValueIndex];
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return HUGE_VAL;
|
|
|
|
}
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
|
2013-03-05 06:10:26 -06:00
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
size_t RigCaseCellResultsData::findScalarResultIndex(RimDefines::ResultCatType type, const QString& resultName) const
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2012-06-26 09:10:41 -05:00
|
|
|
std::vector<ResultInfo>::const_iterator it;
|
|
|
|
for (it = m_resultInfos.begin(); it != m_resultInfos.end(); it++)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
if (it->m_resultType == type && it->m_resultName == resultName)
|
|
|
|
{
|
|
|
|
return it->m_gridScalarResultIndex;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return cvf::UNDEFINED_SIZE_T;
|
|
|
|
}
|
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
size_t RigCaseCellResultsData::findScalarResultIndex(const QString& resultName) const
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
size_t scalarResultIndex = cvf::UNDEFINED_SIZE_T;
|
|
|
|
|
|
|
|
scalarResultIndex = this->findScalarResultIndex(RimDefines::STATIC_NATIVE, resultName);
|
|
|
|
|
|
|
|
if (scalarResultIndex == cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
|
|
|
scalarResultIndex = this->findScalarResultIndex(RimDefines::DYNAMIC_NATIVE, resultName);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (scalarResultIndex == cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
|
|
|
scalarResultIndex = this->findScalarResultIndex(RimDefines::GENERATED, resultName);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (scalarResultIndex == cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
|
|
|
scalarResultIndex = this->findScalarResultIndex(RimDefines::INPUT_PROPERTY, resultName);
|
|
|
|
}
|
|
|
|
|
|
|
|
return scalarResultIndex;
|
|
|
|
}
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
/// Adds an empty scalar set, and returns the scalarResultIndex to it.
|
2014-08-22 06:38:03 -05:00
|
|
|
/// if resultName already exists, it just returns the scalarResultIndex to the existing result.
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
size_t RigCaseCellResultsData::addEmptyScalarResult(RimDefines::ResultCatType type, const QString& resultName, bool needsToBeStored)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2014-08-22 06:38:03 -05:00
|
|
|
size_t scalarResultIndex = this->findScalarResultIndex(type, resultName);
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
// If the result exists, do nothing
|
|
|
|
|
|
|
|
if (scalarResultIndex != cvf::UNDEFINED_SIZE_T)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2014-08-22 06:38:03 -05:00
|
|
|
return scalarResultIndex;
|
|
|
|
}
|
2014-08-18 05:03:21 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
// Create the new empty result with metadata
|
2014-08-20 02:51:55 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
scalarResultIndex = this->resultCount();
|
|
|
|
m_cellScalarResults.push_back(std::vector<std::vector<double> >());
|
|
|
|
ResultInfo resInfo(type, needsToBeStored, false, resultName, scalarResultIndex);
|
|
|
|
m_resultInfos.push_back(resInfo);
|
2014-08-18 05:03:21 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
// Create statistics calculator and add statistics cache object
|
|
|
|
// Todo: Move to a "factory" method
|
2014-08-18 05:03:21 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
cvf::ref<RigStatisticsCalculator> statisticsCalculator;
|
2014-08-18 05:03:21 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
if (resultName == RimDefines::combinedTransmissibilityResultName())
|
|
|
|
{
|
|
|
|
cvf::ref<RigMultipleDatasetStatCalc> calc = new RigMultipleDatasetStatCalc();
|
|
|
|
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANX"));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANY"));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANZ"));
|
2014-08-20 02:51:55 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
statisticsCalculator = calc;
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
2014-08-22 06:38:03 -05:00
|
|
|
else if (resultName == RimDefines::combinedMultResultName())
|
|
|
|
{
|
|
|
|
cvf::ref<RigMultipleDatasetStatCalc> calc = new RigMultipleDatasetStatCalc();
|
|
|
|
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "MULTX"));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "MULTX-"));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "MULTY"));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "MULTY-"));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "MULTZ"));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, "MULTZ-"));
|
|
|
|
|
|
|
|
statisticsCalculator = calc;
|
|
|
|
}
|
2014-09-09 00:12:43 -05:00
|
|
|
else if (resultName == RimDefines::combinedRiTranResultName())
|
2014-08-22 06:38:03 -05:00
|
|
|
{
|
|
|
|
cvf::ref<RigMultipleDatasetStatCalc> calc = new RigMultipleDatasetStatCalc();
|
2014-09-09 00:12:43 -05:00
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riTranXResultName()));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riTranYResultName()));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riTranZResultName()));
|
2014-08-22 06:38:03 -05:00
|
|
|
statisticsCalculator = calc;
|
|
|
|
}
|
2014-08-26 08:32:19 -05:00
|
|
|
else if (resultName == RimDefines::combinedRiMultResultName())
|
|
|
|
{
|
|
|
|
cvf::ref<RigMultipleDatasetStatCalc> calc = new RigMultipleDatasetStatCalc();
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riMultXResultName()));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riMultYResultName()));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riMultZResultName()));
|
|
|
|
statisticsCalculator = calc;
|
|
|
|
}
|
2014-09-09 00:12:43 -05:00
|
|
|
else if (resultName == RimDefines::combinedRiAreaNormTranResultName())
|
2014-08-27 04:41:08 -05:00
|
|
|
{
|
|
|
|
cvf::ref<RigMultipleDatasetStatCalc> calc = new RigMultipleDatasetStatCalc();
|
2014-09-09 00:12:43 -05:00
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riAreaNormTranXResultName()));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riAreaNormTranYResultName()));
|
|
|
|
calc->addNativeStatisticsCalculator(this, findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riAreaNormTranZResultName()));
|
2014-08-27 04:41:08 -05:00
|
|
|
statisticsCalculator = calc;
|
|
|
|
}
|
2014-08-22 06:38:03 -05:00
|
|
|
else
|
|
|
|
{
|
|
|
|
statisticsCalculator = new RigNativeStatCalc(this, scalarResultIndex);
|
|
|
|
}
|
|
|
|
|
|
|
|
cvf::ref<RigStatisticsDataCache> dataCache = new RigStatisticsDataCache(statisticsCalculator.p());
|
|
|
|
m_statisticsDataCache.push_back(dataCache.p());
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
return scalarResultIndex;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
QStringList RigCaseCellResultsData::resultNames(RimDefines::ResultCatType resType) const
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
QStringList varList;
|
2012-06-26 09:10:41 -05:00
|
|
|
std::vector<ResultInfo>::const_iterator it;
|
|
|
|
for (it = m_resultInfos.begin(); it != m_resultInfos.end(); it++)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
if (it->m_resultType == resType )
|
|
|
|
{
|
|
|
|
varList.push_back(it->m_resultName);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return varList;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2014-08-18 05:03:21 -05:00
|
|
|
void RigCaseCellResultsData::recalculateStatistics(size_t scalarResultIndex)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2014-08-18 05:03:21 -05:00
|
|
|
m_statisticsDataCache[scalarResultIndex]->clearAllStatistics();
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
2012-06-26 09:10:41 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
/// Returns whether the result data in question is addressed by Active Cell Index
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
bool RigCaseCellResultsData::isUsingGlobalActiveIndex(size_t scalarResultIndex) const
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
CVF_TIGHT_ASSERT(scalarResultIndex < m_cellScalarResults.size());
|
|
|
|
|
|
|
|
if (!m_cellScalarResults[scalarResultIndex].size()) return true;
|
2013-02-06 03:02:50 -06:00
|
|
|
|
|
|
|
size_t firstTimeStepResultValueCount = m_cellScalarResults[scalarResultIndex][0].size();
|
|
|
|
if (firstTimeStepResultValueCount == m_ownerMainGrid->cells().size()) return false;
|
2012-06-26 09:10:41 -05:00
|
|
|
|
2013-02-12 04:50:23 -06:00
|
|
|
return true;
|
2012-06-26 09:10:41 -05:00
|
|
|
}
|
|
|
|
|
2012-09-11 02:22:36 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
QDateTime RigCaseCellResultsData::timeStepDate(size_t scalarResultIndex, size_t timeStepIndex) const
|
2012-09-11 02:22:36 -05:00
|
|
|
{
|
|
|
|
if (scalarResultIndex < m_resultInfos.size() && (size_t)(m_resultInfos[scalarResultIndex].m_timeStepDates.size()) > timeStepIndex)
|
2013-01-22 04:34:47 -06:00
|
|
|
return m_resultInfos[scalarResultIndex].m_timeStepDates[static_cast<int>(timeStepIndex)];
|
2012-09-11 02:22:36 -05:00
|
|
|
else
|
|
|
|
return QDateTime();
|
|
|
|
}
|
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
std::vector<QDateTime> RigCaseCellResultsData::timeStepDates(size_t scalarResultIndex) const
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
if (scalarResultIndex < m_resultInfos.size() )
|
|
|
|
return m_resultInfos[scalarResultIndex].m_timeStepDates;
|
|
|
|
else
|
2013-03-18 05:40:39 -05:00
|
|
|
return std::vector<QDateTime>();
|
2012-06-26 09:10:41 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigCaseCellResultsData::setTimeStepDates(size_t scalarResultIndex, const std::vector<QDateTime>& dates)
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
CVF_ASSERT(scalarResultIndex < m_resultInfos.size() );
|
|
|
|
|
|
|
|
m_resultInfos[scalarResultIndex].m_timeStepDates = dates;
|
2013-03-18 08:34:29 -05:00
|
|
|
|
2013-03-21 09:31:47 -05:00
|
|
|
std::vector< std::vector<double> >& dataValues = this->cellScalarResults(scalarResultIndex);
|
|
|
|
dataValues.resize(dates.size());
|
2012-06-26 09:10:41 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
size_t RigCaseCellResultsData::maxTimeStepCount(size_t* scalarResultIndexWithMostTimeSteps) const
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
2013-03-18 08:34:29 -05:00
|
|
|
size_t maxTsCount = 0;
|
2013-03-19 02:14:35 -05:00
|
|
|
size_t scalarResultIndexWithMaxTsCount = cvf::UNDEFINED_SIZE_T;
|
2013-03-05 06:10:26 -06:00
|
|
|
|
2013-03-19 02:14:35 -05:00
|
|
|
for (size_t i = 0; i < m_resultInfos.size(); i++)
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
2013-03-19 02:14:35 -05:00
|
|
|
if (m_resultInfos[i].m_timeStepDates.size() > maxTsCount)
|
|
|
|
{
|
|
|
|
maxTsCount = m_resultInfos[i].m_timeStepDates.size();
|
|
|
|
scalarResultIndexWithMaxTsCount = i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (scalarResultIndexWithMostTimeSteps)
|
|
|
|
{
|
|
|
|
*scalarResultIndexWithMostTimeSteps = scalarResultIndexWithMaxTsCount;
|
|
|
|
}
|
2013-03-05 06:10:26 -06:00
|
|
|
|
2013-03-19 02:14:35 -05:00
|
|
|
return maxTsCount;
|
2012-06-26 09:10:41 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
QString RigCaseCellResultsData::makeResultNameUnique(const QString& resultNameProposal) const
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
QString newResultName = resultNameProposal;
|
|
|
|
size_t resultIndex = cvf::UNDEFINED_SIZE_T;
|
|
|
|
int nameNum = 1;
|
|
|
|
int stringLength = newResultName.size();
|
|
|
|
while (true)
|
|
|
|
{
|
|
|
|
resultIndex = this->findScalarResultIndex(newResultName);
|
|
|
|
if (resultIndex == cvf::UNDEFINED_SIZE_T) break;
|
|
|
|
|
|
|
|
newResultName.truncate(stringLength);
|
|
|
|
newResultName += "_" + QString::number(nameNum);
|
|
|
|
++nameNum;
|
|
|
|
}
|
|
|
|
|
|
|
|
return newResultName;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigCaseCellResultsData::removeResult(const QString& resultName)
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
size_t resultIdx = findScalarResultIndex(resultName);
|
|
|
|
if (resultIdx == cvf::UNDEFINED_SIZE_T) return;
|
|
|
|
|
|
|
|
m_cellScalarResults[resultIdx].clear();
|
|
|
|
|
|
|
|
m_resultInfos[resultIdx].m_resultType = RimDefines::REMOVED;
|
|
|
|
}
|
2012-08-31 12:12:47 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigCaseCellResultsData::clearAllResults()
|
2012-08-31 12:12:47 -05:00
|
|
|
{
|
2013-03-21 04:31:58 -05:00
|
|
|
m_cellScalarResults.clear();
|
|
|
|
m_resultInfos.clear();
|
2012-08-31 12:12:47 -05:00
|
|
|
}
|
2012-10-24 03:52:44 -05:00
|
|
|
|
2013-06-26 16:34:03 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
/// Removes all the actual numbers put into this object, and frees up the memory.
|
|
|
|
/// Does not touch the metadata in any way
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigCaseCellResultsData::freeAllocatedResultsData()
|
|
|
|
{
|
|
|
|
for (size_t resultIdx = 0; resultIdx < m_cellScalarResults.size(); ++resultIdx)
|
|
|
|
{
|
|
|
|
for (size_t tsIdx = 0; tsIdx < m_cellScalarResults[resultIdx].size(); ++tsIdx)
|
|
|
|
{
|
|
|
|
// Using swap with an empty vector as that is the safest way to really get rid of the allocated data in a vector
|
|
|
|
std::vector<double> empty;
|
|
|
|
m_cellScalarResults[resultIdx][tsIdx].swap(empty);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-10-24 03:52:44 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2014-08-22 06:38:03 -05:00
|
|
|
/// Make sure we have a result with given type and name, and make sure one "timestep" result vector
|
|
|
|
// for the static result values are allocated
|
2012-10-24 03:52:44 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
size_t RigCaseCellResultsData::addStaticScalarResult(RimDefines::ResultCatType type, const QString& resultName, bool needsToBeStored, size_t resultValueCount)
|
2012-10-24 03:52:44 -05:00
|
|
|
{
|
2013-03-21 09:31:47 -05:00
|
|
|
size_t resultIdx = addEmptyScalarResult(type, resultName, needsToBeStored);
|
2012-10-24 03:52:44 -05:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
m_cellScalarResults[resultIdx].resize(1, std::vector<double>());
|
2012-10-24 03:52:44 -05:00
|
|
|
m_cellScalarResults[resultIdx][0].resize(resultValueCount, HUGE_VAL);
|
|
|
|
|
|
|
|
return resultIdx;
|
|
|
|
}
|
|
|
|
|
2013-02-01 07:39:32 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
RifReaderInterface::PorosityModelResultType RigCaseCellResultsData::convertFromProjectModelPorosityModel(RimDefines::PorosityModelType porosityModel)
|
2013-02-01 07:39:32 -06:00
|
|
|
{
|
|
|
|
if (porosityModel == RimDefines::MATRIX_MODEL) return RifReaderInterface::MATRIX_RESULTS;
|
|
|
|
|
|
|
|
return RifReaderInterface::FRACTURE_RESULTS;
|
|
|
|
}
|
|
|
|
|
2013-04-10 04:37:34 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RigCaseCellResultsData::mustBeCalculated(size_t scalarResultIndex) const
|
|
|
|
{
|
|
|
|
std::vector<ResultInfo>::const_iterator it;
|
|
|
|
for (it = m_resultInfos.begin(); it != m_resultInfos.end(); it++)
|
|
|
|
{
|
|
|
|
if (it->m_gridScalarResultIndex == scalarResultIndex)
|
|
|
|
{
|
|
|
|
return it->m_mustBeCalculated;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigCaseCellResultsData::setMustBeCalculated(size_t scalarResultIndex)
|
|
|
|
{
|
|
|
|
std::vector<ResultInfo>::iterator it;
|
|
|
|
for (it = m_resultInfos.begin(); it != m_resultInfos.end(); it++)
|
|
|
|
{
|
|
|
|
if (it->m_gridScalarResultIndex == scalarResultIndex)
|
|
|
|
{
|
|
|
|
it->m_mustBeCalculated = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-12-16 13:26:52 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2014-08-20 04:32:50 -05:00
|
|
|
void RigCaseCellResultsData::createPlaceholderResultEntries()
|
2013-12-16 13:26:52 -06:00
|
|
|
{
|
2014-08-22 06:38:03 -05:00
|
|
|
// SOIL
|
2014-08-21 01:39:19 -05:00
|
|
|
{
|
2014-08-28 03:35:05 -05:00
|
|
|
size_t soilIndex = findScalarResultIndex(RimDefines::DYNAMIC_NATIVE, "SOIL");
|
|
|
|
if (soilIndex == cvf::UNDEFINED_SIZE_T)
|
2014-08-22 06:38:03 -05:00
|
|
|
{
|
2014-08-28 03:35:05 -05:00
|
|
|
size_t swatIndex = findScalarResultIndex(RimDefines::DYNAMIC_NATIVE, "SWAT");
|
|
|
|
size_t sgasIndex = findScalarResultIndex(RimDefines::DYNAMIC_NATIVE, "SGAS");
|
|
|
|
|
|
|
|
if (swatIndex != cvf::UNDEFINED_SIZE_T || sgasIndex != cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
|
|
|
soilIndex = addEmptyScalarResult(RimDefines::DYNAMIC_NATIVE, "SOIL", false);
|
|
|
|
this->setMustBeCalculated(soilIndex);
|
|
|
|
}
|
2014-08-21 01:39:19 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
// TRANSXYZ
|
2014-08-19 06:20:44 -05:00
|
|
|
{
|
2014-08-22 06:38:03 -05:00
|
|
|
size_t tranX, tranY, tranZ;
|
|
|
|
if (findTransmissibilityResults(tranX, tranY, tranZ))
|
2014-08-19 06:20:44 -05:00
|
|
|
{
|
2014-08-22 06:38:03 -05:00
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::combinedTransmissibilityResultName(), false, 0);
|
2014-08-19 06:20:44 -05:00
|
|
|
}
|
|
|
|
}
|
2014-08-22 06:38:03 -05:00
|
|
|
// MULTXYZ
|
|
|
|
{
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::combinedMultResultName(), false, 0);
|
|
|
|
}
|
2013-12-16 13:26:52 -06:00
|
|
|
|
2014-08-22 06:38:03 -05:00
|
|
|
// riTRANSXYZ and X,Y,Z
|
2014-08-19 06:20:44 -05:00
|
|
|
{
|
2014-08-22 06:38:03 -05:00
|
|
|
size_t ntgResIdx = findScalarResultIndex(RimDefines::STATIC_NATIVE, "NTG");
|
|
|
|
if ( findScalarResultIndex(RimDefines::STATIC_NATIVE, "NTG") != cvf::UNDEFINED_SIZE_T
|
|
|
|
&& findScalarResultIndex(RimDefines::STATIC_NATIVE, "PERMX") != cvf::UNDEFINED_SIZE_T
|
|
|
|
&& findScalarResultIndex(RimDefines::STATIC_NATIVE, "PERMY") != cvf::UNDEFINED_SIZE_T
|
|
|
|
&& findScalarResultIndex(RimDefines::STATIC_NATIVE, "PERMZ") != cvf::UNDEFINED_SIZE_T)
|
2014-08-19 06:20:44 -05:00
|
|
|
{
|
2014-09-09 00:12:43 -05:00
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riTranXResultName(), false, 0);
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riTranYResultName(), false, 0);
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riTranZResultName(), false, 0);
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::combinedRiTranResultName(), false, 0);
|
2014-08-19 06:20:44 -05:00
|
|
|
}
|
|
|
|
}
|
2014-08-26 08:32:19 -05:00
|
|
|
|
|
|
|
// riMULTXYZ and X, Y, Z
|
|
|
|
{
|
|
|
|
size_t tranX, tranY, tranZ;
|
|
|
|
if (findTransmissibilityResults(tranX, tranY, tranZ)
|
2014-09-09 00:12:43 -05:00
|
|
|
&& findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riTranXResultName()) != cvf::UNDEFINED_SIZE_T
|
|
|
|
&& findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riTranYResultName()) != cvf::UNDEFINED_SIZE_T
|
|
|
|
&& findScalarResultIndex(RimDefines::STATIC_NATIVE, RimDefines::riTranZResultName()) != cvf::UNDEFINED_SIZE_T)
|
2014-08-26 08:32:19 -05:00
|
|
|
{
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riMultXResultName(), false, 0);
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riMultYResultName(), false, 0);
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riMultZResultName(), false, 0);
|
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::combinedRiMultResultName(), false, 0);
|
|
|
|
}
|
|
|
|
}
|
2014-08-27 04:41:08 -05:00
|
|
|
|
|
|
|
// riTRANSXYZbyArea and X, Y, Z
|
|
|
|
{
|
|
|
|
if (findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANX") != cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
2014-09-09 00:12:43 -05:00
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riAreaNormTranXResultName(), false, 0);
|
2014-08-27 04:41:08 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if (findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANY") != cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
2014-09-09 00:12:43 -05:00
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riAreaNormTranYResultName(), false, 0);
|
2014-08-27 04:41:08 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if (findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANZ") != cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
2014-09-09 00:12:43 -05:00
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::riAreaNormTranZResultName(), false, 0);
|
2014-08-27 04:41:08 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
size_t tranX, tranY, tranZ;
|
|
|
|
if (findTransmissibilityResults(tranX, tranY, tranZ))
|
|
|
|
{
|
2014-09-09 00:12:43 -05:00
|
|
|
addStaticScalarResult(RimDefines::STATIC_NATIVE, RimDefines::combinedRiAreaNormTranResultName(), false, 0);
|
2014-08-27 04:41:08 -05:00
|
|
|
}
|
|
|
|
}
|
2013-12-16 13:26:52 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RigCaseCellResultsData::findTransmissibilityResults(size_t& tranX, size_t& tranY, size_t& tranZ) const
|
|
|
|
{
|
|
|
|
tranX = findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANX");
|
|
|
|
tranY = findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANY");
|
|
|
|
tranZ = findScalarResultIndex(RimDefines::STATIC_NATIVE, "TRANZ");
|
|
|
|
|
|
|
|
if (tranX == cvf::UNDEFINED_SIZE_T ||
|
|
|
|
tranY == cvf::UNDEFINED_SIZE_T ||
|
|
|
|
tranZ == cvf::UNDEFINED_SIZE_T)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|