void buildResultInfoString(RigReservoir* reservoir, RifReaderInterface::PorosityModelResultType porosityModel, RimDefines::ResultCatType resultType) { RigCaseCellResultsData* matrixResults = reservoir->results(porosityModel); { 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(); } }
//-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RigFlowDiagVisibleCellsStatCalc::mobileVolumeWeightedMean(size_t timeStepIndex, double &result) { RimEclipseResultCase* eclCase = nullptr; m_resultsData->flowDiagSolution()->firstAncestorOrThisOfType(eclCase); if (!eclCase) return; RigCaseCellResultsData* caseCellResultsData = eclCase->results(RiaDefines::MATRIX_MODEL); size_t mobPVResultIndex = caseCellResultsData->findOrLoadScalarResult(RiaDefines::ResultCatType::STATIC_NATIVE, RiaDefines::mobilePoreVolumeName()); const std::vector<double>& weights = caseCellResultsData->cellScalarResults(mobPVResultIndex, 0); const std::vector<double>* values = m_resultsData->resultValues(m_resVarAddr, timeStepIndex); const RigActiveCellInfo* actCellInfo = m_resultsData->activeCellInfo(m_resVarAddr); RigWeightedMeanCalc::weightedMeanOverCells(&weights, values, m_cellVisibilities.p(), true, actCellInfo, true, &result); }