///////////////////////////////////////////////////////////////////////////////// // // 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 "RicCreateSaturationPressurePlotsFeature.h" #include "RicSaturationPressureUi.h" #include "RiaApplication.h" #include "RiaLogging.h" #include "RiaPorosityModel.h" #include "RigCaseCellResultsData.h" #include "RigEclipseCaseData.h" #include "RigEclipseResultAddress.h" #include "RigEquil.h" #include "RimEclipseResultCase.h" #include "RimMainPlotCollection.h" #include "RimProject.h" #include "RimSaturationPressurePlot.h" #include "RimSaturationPressurePlotCollection.h" #include "RiuPlotMainWindow.h" #include "RiuPlotMainWindowTools.h" #include "cafPdmUiPropertyViewDialog.h" #include "cafSelectionManager.h" #include #include CAF_CMD_SOURCE_INIT(RicCreateSaturationPressurePlotsFeature, "RicCreateSaturationPressurePlotsFeature"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicCreateSaturationPressurePlotsFeature::isCommandEnabled() { return true; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicCreateSaturationPressurePlotsFeature::onActionTriggered(bool isChecked) { RimProject* project = RiaApplication::instance()->project(); bool launchedFromPlotCollection = true; RimSaturationPressurePlotCollection* collection = caf::SelectionManager::instance()->selectedItemAncestorOfType(); if (!collection) { collection = project->mainPlotCollection()->saturationPressurePlotCollection(); launchedFromPlotCollection = false; } std::vector eclipseCases; { RiaApplication* app = RiaApplication::instance(); std::vector cases; app->project()->allCases(cases); for (auto* rimCase : cases) { auto erc = dynamic_cast(rimCase); if (erc) { eclipseCases.push_back(erc); } } } RimEclipseResultCase* eclipseResultCase = nullptr; if (!eclipseCases.empty()) { if (eclipseCases.size() == 1) { eclipseResultCase = eclipseCases[0]; } else { RicSaturationPressureUi saturationPressureUi; saturationPressureUi.setSelectedCase(eclipseCases[0]); RiuPlotMainWindow* plotwindow = RiaApplication::instance()->mainPlotWindow(); caf::PdmUiPropertyViewDialog propertyDialog( plotwindow, &saturationPressureUi, "Select Case to create Pressure Saturation plots", ""); if (propertyDialog.exec() == QDialog::Accepted) { eclipseResultCase = dynamic_cast(saturationPressureUi.selectedCase()); } } } caf::PdmObject* objectToSelect = nullptr; if (eclipseResultCase) { eclipseResultCase->ensureReservoirCaseIsOpen(); bool requiredInputDataPresent = false; if (!eclipseResultCase->eclipseCaseData()->equilData().empty()) { if (eclipseResultCase->eclipseCaseData() && eclipseResultCase->eclipseCaseData()->results(RiaDefines::MATRIX_MODEL)) { RigCaseCellResultsData* resultData = eclipseResultCase->eclipseCaseData()->results(RiaDefines::MATRIX_MODEL); if (resultData->hasResultEntry(RigEclipseResultAddress(RiaDefines::DYNAMIC_NATIVE, "PRESSURE")) && resultData->hasResultEntry(RigEclipseResultAddress(RiaDefines::DYNAMIC_NATIVE, "PDEW")) && resultData->hasResultEntry(RigEclipseResultAddress(RiaDefines::DYNAMIC_NATIVE, "PBUB"))) { requiredInputDataPresent = true; } } } std::vector plots; if (requiredInputDataPresent) { plots = collection->createSaturationPressurePlots(eclipseResultCase); for (auto plot : plots) { plot->loadDataAndUpdate(); plot->zoomAll(); plot->updateConnectedEditors(); } } if (plots.empty()) { QString text = "No plots generated.\n\n"; text += "Data required to generate saturation/pressure plots:\n"; text += " - EQLNUM property defining at least one region\n"; text += " - Dynamic properties PRESSURE, PBUB and PDEW\n\n"; text += "Make sure to add 'PBPD' to the RPTRST keyword in the SOLUTION selection. "; text += "If this is a two phase run (Oil/water or Gas/Water) or if both VAPOIL "; text += "and DISGAS are disabled, saturation pressure are not valid."; QMessageBox::warning(nullptr, "Saturation Pressure Plots", text); RiaLogging::warning(text); } else { objectToSelect = plots.front(); } } collection->updateAllRequiredEditors(); RiaApplication::instance()->getOrCreateAndShowMainPlotWindow(); if (objectToSelect) { RiuPlotMainWindowTools::selectAsCurrentItem(objectToSelect); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicCreateSaturationPressurePlotsFeature::setupActionLook(QAction* actionToSetup) { RimSaturationPressurePlotCollection* collection = caf::SelectionManager::instance()->selectedItemAncestorOfType(); if (!collection) { actionToSetup->setText("New Grid Cross Plot from 3d View"); } else { actionToSetup->setText("Create Saturation Pressure Plots"); } actionToSetup->setIcon(QIcon(":/SummaryXPlotsLight16x16.png")); }