mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
Add Memory Report dialog
Compute how much memory is used for result/case/total. Show as text in dialog.
This commit is contained in:
@@ -216,6 +216,24 @@ void RigCaseCellResultsData::mobileVolumeWeightedMean( const RigEclipseResultAdd
|
||||
statistics( resVarAddr )->mobileVolumeWeightedMean( timeStepIndex, meanValue );
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
std::map<std::string, size_t> RigCaseCellResultsData::resultValueCount() const
|
||||
{
|
||||
std::map<std::string, size_t> memoryUse;
|
||||
|
||||
for ( size_t i = 0; i < m_cellScalarResults.size(); i++ )
|
||||
{
|
||||
if ( allocatedValueCount( i ) > 0 )
|
||||
{
|
||||
memoryUse[m_resultInfos[i].resultName().toStdString()] = allocatedValueCount( i );
|
||||
}
|
||||
}
|
||||
|
||||
return memoryUse;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
@@ -2838,22 +2856,25 @@ RigAllanDiagramData* RigCaseCellResultsData::allanDiagramData()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
bool RigCaseCellResultsData::isDataPresent( size_t scalarResultIndex ) const
|
||||
{
|
||||
if ( scalarResultIndex >= resultCount() )
|
||||
return allocatedValueCount( scalarResultIndex ) > 0;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
size_t RigCaseCellResultsData::allocatedValueCount( size_t scalarResultIndex ) const
|
||||
{
|
||||
if ( scalarResultIndex >= resultCount() ) return 0;
|
||||
|
||||
const std::vector<std::vector<double>>& valuesAllTimeSteps = m_cellScalarResults[scalarResultIndex];
|
||||
|
||||
size_t valueCount = 0;
|
||||
for ( const auto& values : valuesAllTimeSteps )
|
||||
{
|
||||
return false;
|
||||
valueCount += values.size();
|
||||
}
|
||||
|
||||
const std::vector<std::vector<double>>& data = m_cellScalarResults[scalarResultIndex];
|
||||
|
||||
for ( size_t tsIdx = 0; tsIdx < data.size(); ++tsIdx )
|
||||
{
|
||||
if ( !data[tsIdx].empty() )
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
return valueCount;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
|
||||
Reference in New Issue
Block a user