///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2019- 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 // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RimReloadCaseTools.h" #include "RiaFractureDefines.h" #include "RiaSummaryTools.h" #include "RigCaseCellResultsData.h" #include "RigEclipseCaseData.h" #include "Rim2dIntersectionView.h" #include "Rim2dIntersectionViewCollection.h" #include "RimEclipseCase.h" #include "RimEclipseCellColors.h" #include "RimEclipseContourMapProjection.h" #include "RimEclipseContourMapView.h" #include "RimEclipseContourMapViewCollection.h" #include "RimEclipseView.h" #include "RimGridCalculation.h" #include "RimGridCalculationCollection.h" #include "RimMainPlotCollection.h" #include "RimProject.h" #include "RimSummaryCaseMainCollection.h" //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimReloadCaseTools::reloadAllEclipseData( RimEclipseCase* eclipseCase ) { reloadAllEclipseData( eclipseCase, true ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimReloadCaseTools::reloadAllEclipseGridData( RimEclipseCase* eclipseCase ) { reloadAllEclipseData( eclipseCase, false ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimReloadCaseTools::reloadAllEclipseData( RimEclipseCase* eclipseCase, bool reloadSummaryData ) { CVF_ASSERT( eclipseCase ); RigEclipseCaseData* eclipseCaseData = eclipseCase->eclipseCaseData(); if ( !eclipseCaseData ) return; clearAllGridData( eclipseCaseData ); eclipseCase->reloadEclipseGridFile(); std::vector gridCalculations = RimProject::current()->gridCalculationCollection()->sortedGridCalculations(); for ( auto gridCalculation : gridCalculations ) { bool recalculate = false; for ( auto inputCase : gridCalculation->inputCases() ) { if ( inputCase == eclipseCase ) recalculate = true; } if ( recalculate ) gridCalculation->calculate(); } updateAll3dViews( eclipseCase ); if ( reloadSummaryData ) { RimSummaryCaseMainCollection* sumCaseColl = RiaSummaryTools::summaryCaseMainCollection(); if ( sumCaseColl ) { sumCaseColl->loadAllSummaryCaseData(); } } updateAllPlots(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimReloadCaseTools::clearAllGridData( RigEclipseCaseData* eclipseCaseData ) { if ( !eclipseCaseData ) return; RigCaseCellResultsData* matrixModelResults = eclipseCaseData->results( RiaDefines::PorosityModelType::MATRIX_MODEL ); if ( matrixModelResults ) { matrixModelResults->clearAllResults(); } RigCaseCellResultsData* stimPlanModelResults = eclipseCaseData->results( RiaDefines::PorosityModelType::FRACTURE_MODEL ); if ( stimPlanModelResults ) { stimPlanModelResults->clearAllResults(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimReloadCaseTools::updateAll3dViews( RimEclipseCase* eclipseCase ) { if ( !eclipseCase ) return; for ( RimEclipseView* reservoirView : eclipseCase->reservoirViews() ) { CVF_ASSERT( reservoirView ); reservoirView->setEclipseCase( eclipseCase ); reservoirView->loadDataAndUpdate(); reservoirView->updateGridBoxData(); reservoirView->updateAnnotationItems(); } for ( RimEclipseContourMapView* contourMap : eclipseCase->contourMapCollection()->views() ) { CVF_ASSERT( contourMap ); if ( contourMap->cellResult()->resultType() == RiaDefines::ResultCatType::GENERATED ) { // When a generated result is selected, the data might come from a calculation. Make sure that all // computations are updated based on new data. // See RimEclipseContourMapProjection::generateResults() contourMap->contourMapProjection()->clearGeometry(); contourMap->contourMapProjection()->clearGridMappingAndRedraw(); } contourMap->loadDataAndUpdate(); contourMap->updateGridBoxData(); contourMap->updateAnnotationItems(); } for ( Rim2dIntersectionView* view : eclipseCase->intersectionViewCollection()->views() ) { view->createDisplayModelAndRedraw(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimReloadCaseTools::updateAllPlots() { RimMainPlotCollection::current()->loadDataAndUpdateAllPlots(); }