mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
#3473 LGR Export. Support for exporting a single LGR for per well. Warning if completions intersect with existing LGR
This commit is contained in:
@@ -27,6 +27,7 @@
|
|||||||
#include "RifEclipseDataTableFormatter.h"
|
#include "RifEclipseDataTableFormatter.h"
|
||||||
|
|
||||||
#include "RigCaseCellResultsData.h"
|
#include "RigCaseCellResultsData.h"
|
||||||
|
#include "RigMainGrid.h"
|
||||||
#include "RigResultAccessor.h"
|
#include "RigResultAccessor.h"
|
||||||
#include "RigResultAccessorFactory.h"
|
#include "RigResultAccessorFactory.h"
|
||||||
#include "RigVirtualPerforationTransmissibilities.h"
|
#include "RigVirtualPerforationTransmissibilities.h"
|
||||||
@@ -46,6 +47,7 @@
|
|||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QTextStream>
|
#include <QTextStream>
|
||||||
|
#include <QMessageBox>
|
||||||
|
|
||||||
#include <cafPdmUiPropertyViewDialog.h>
|
#include <cafPdmUiPropertyViewDialog.h>
|
||||||
#include <cafSelectionManager.h>
|
#include <cafSelectionManager.h>
|
||||||
@@ -64,7 +66,7 @@ RicExportLgrUi* RicExportLgrFeature::openDialog()
|
|||||||
RiaApplication* app = RiaApplication::instance();
|
RiaApplication* app = RiaApplication::instance();
|
||||||
RimProject* proj = app->project();
|
RimProject* proj = app->project();
|
||||||
|
|
||||||
QString startPath = app->lastUsedDialogDirectory("CARFIN_DIR");
|
QString startPath = app->lastUsedDialogDirectory("LGR_EXPORT_DIR");
|
||||||
if (startPath.isEmpty())
|
if (startPath.isEmpty())
|
||||||
{
|
{
|
||||||
QFileInfo fi(proj->fileName());
|
QFileInfo fi(proj->fileName());
|
||||||
@@ -92,12 +94,12 @@ RicExportLgrUi* RicExportLgrFeature::openDialog()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
caf::PdmUiPropertyViewDialog propertyDialog(nullptr, featureUi, "Export Carfin", "", QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
|
caf::PdmUiPropertyViewDialog propertyDialog(nullptr, featureUi, "LGR Export", "", QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
|
||||||
propertyDialog.resize(QSize(600, 230));
|
propertyDialog.resize(QSize(600, 250));
|
||||||
|
|
||||||
if (propertyDialog.exec() == QDialog::Accepted && !featureUi->exportFolder().isEmpty())
|
if (propertyDialog.exec() == QDialog::Accepted && !featureUi->exportFolder().isEmpty())
|
||||||
{
|
{
|
||||||
app->setLastUsedDialogDirectory("CARFIN_DIR", featureUi->exportFolder());
|
app->setLastUsedDialogDirectory("LGR_EXPORT_DIR", featureUi->exportFolder());
|
||||||
return featureUi;
|
return featureUi;
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@@ -130,14 +132,12 @@ bool RicExportLgrFeature::openFileForExport(const QString& folderName, const QSt
|
|||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
void RicExportLgrFeature::exportLgr(QTextStream& stream, const std::map<RigCompletionDataGridCell, LgrInfo>& lgrInfos)
|
void RicExportLgrFeature::exportLgr(QTextStream& stream, const std::vector<LgrInfo>& lgrInfos)
|
||||||
{
|
{
|
||||||
int count = 0;
|
int count = 0;
|
||||||
for (auto lgr : lgrInfos)
|
for (auto lgrInfo : lgrInfos)
|
||||||
{
|
{
|
||||||
auto lgrName = QString("LGR_%1").arg(++count);
|
auto lgrName = QString("LGR_%1").arg(++count);
|
||||||
auto dataGridCell = lgr.first;
|
|
||||||
auto lgrInfo = lgr.second;
|
|
||||||
|
|
||||||
{
|
{
|
||||||
RifEclipseDataTableFormatter formatter(stream);
|
RifEclipseDataTableFormatter formatter(stream);
|
||||||
@@ -158,12 +158,12 @@ void RicExportLgrFeature::exportLgr(QTextStream& stream, const std::map<RigCompl
|
|||||||
);
|
);
|
||||||
|
|
||||||
formatter.add(lgrInfo.name);
|
formatter.add(lgrInfo.name);
|
||||||
formatter.addOneBasedCellIndex(dataGridCell.localCellIndexI());
|
formatter.addOneBasedCellIndex(lgrInfo.mainGridStartCell.i());
|
||||||
formatter.addOneBasedCellIndex(dataGridCell.localCellIndexI());
|
formatter.addOneBasedCellIndex(lgrInfo.mainGridEndCell.i());
|
||||||
formatter.addOneBasedCellIndex(dataGridCell.localCellIndexJ());
|
formatter.addOneBasedCellIndex(lgrInfo.mainGridStartCell.j());
|
||||||
formatter.addOneBasedCellIndex(dataGridCell.localCellIndexJ());
|
formatter.addOneBasedCellIndex(lgrInfo.mainGridEndCell.j());
|
||||||
formatter.addOneBasedCellIndex(dataGridCell.localCellIndexK());
|
formatter.addOneBasedCellIndex(lgrInfo.mainGridStartCell.k());
|
||||||
formatter.addOneBasedCellIndex(dataGridCell.localCellIndexK());
|
formatter.addOneBasedCellIndex(lgrInfo.mainGridEndCell.k());
|
||||||
formatter.add(lgrInfo.sizes.i());
|
formatter.add(lgrInfo.sizes.i());
|
||||||
formatter.add(lgrInfo.sizes.j());
|
formatter.add(lgrInfo.sizes.j());
|
||||||
formatter.add(lgrInfo.sizes.k());
|
formatter.add(lgrInfo.sizes.k());
|
||||||
@@ -171,7 +171,7 @@ void RicExportLgrFeature::exportLgr(QTextStream& stream, const std::map<RigCompl
|
|||||||
formatter.tableCompleted("", false);
|
formatter.tableCompleted("", false);
|
||||||
}
|
}
|
||||||
|
|
||||||
RifEclipseDataTableFormatter::addValueTable(stream, "PORO", lgrInfo.sizes.i(), lgrInfo.values);
|
RifEclipseDataTableFormatter::addValueTable(stream, "PORO", 8, lgrInfo.values);
|
||||||
|
|
||||||
{
|
{
|
||||||
RifEclipseDataTableFormatter formatter(stream);
|
RifEclipseDataTableFormatter formatter(stream);
|
||||||
@@ -181,6 +181,140 @@ void RicExportLgrFeature::exportLgr(QTextStream& stream, const std::map<RigCompl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
std::vector<LgrInfo> RicExportLgrFeature::buildOneLgrPerMainCell(RimEclipseCase* eclipseCase,
|
||||||
|
const std::vector<RigCompletionDataGridCell>& intersectingCells,
|
||||||
|
const caf::VecIjk& lgrSizes)
|
||||||
|
{
|
||||||
|
int lgrCount = 0;
|
||||||
|
std::vector<LgrInfo> lgrs;
|
||||||
|
|
||||||
|
eclipseCase->results(RiaDefines::MATRIX_MODEL)->findOrLoadScalarResult(RiaDefines::STATIC_NATIVE, "PORO");
|
||||||
|
cvf::ref<RigResultAccessor> poroAccessObject =
|
||||||
|
RigResultAccessorFactory::createFromUiResultName(eclipseCase->eclipseCaseData(), 0, RiaDefines::MATRIX_MODEL, 0, "PORO");
|
||||||
|
|
||||||
|
for (const auto& intersectingCell : intersectingCells)
|
||||||
|
{
|
||||||
|
size_t globCellIndex = intersectingCell.globalCellIndex();
|
||||||
|
double poro = poroAccessObject->cellScalarGlobIdx(globCellIndex);
|
||||||
|
|
||||||
|
std::vector<double> lgrValues;
|
||||||
|
|
||||||
|
for (size_t k = 0; k < lgrSizes.k(); k++)
|
||||||
|
{
|
||||||
|
for (size_t j = 0; j < lgrSizes.j(); j++)
|
||||||
|
{
|
||||||
|
for (size_t i = 0; i < lgrSizes.i(); i++)
|
||||||
|
{
|
||||||
|
lgrValues.push_back(poro);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
caf::VecIjk mainGridFirstCell(intersectingCell.localCellIndexI(),
|
||||||
|
intersectingCell.localCellIndexJ(),
|
||||||
|
intersectingCell.localCellIndexK());
|
||||||
|
caf::VecIjk mainGridEndCell(intersectingCell.localCellIndexI(),
|
||||||
|
intersectingCell.localCellIndexJ(),
|
||||||
|
intersectingCell.localCellIndexK());
|
||||||
|
|
||||||
|
LgrInfo lgrInfo(QString("LGR_%1").arg(++lgrCount), lgrSizes, mainGridFirstCell, mainGridEndCell);
|
||||||
|
lgrInfo.values = lgrValues;
|
||||||
|
lgrs.push_back(lgrInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
return lgrs;
|
||||||
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
std::vector<LgrInfo> RicExportLgrFeature::buildSingleLgr(RimEclipseCase* eclipseCase,
|
||||||
|
const std::vector<RigCompletionDataGridCell>& intersectingCells,
|
||||||
|
const caf::VecIjk& lgrSizes)
|
||||||
|
{
|
||||||
|
std::vector<LgrInfo> lgrs;
|
||||||
|
|
||||||
|
eclipseCase->results(RiaDefines::MATRIX_MODEL)->findOrLoadScalarResult(RiaDefines::STATIC_NATIVE, "PORO");
|
||||||
|
cvf::ref<RigResultAccessor> poroAccessObject =
|
||||||
|
RigResultAccessorFactory::createFromUiResultName(eclipseCase->eclipseCaseData(), 0, RiaDefines::MATRIX_MODEL, 0, "PORO");
|
||||||
|
|
||||||
|
// Find min and max IJK
|
||||||
|
auto iRange = initRange();
|
||||||
|
auto jRange = initRange();
|
||||||
|
auto kRange = initRange();
|
||||||
|
|
||||||
|
for (auto cell : intersectingCells)
|
||||||
|
{
|
||||||
|
iRange.first = std::min(cell.localCellIndexI(), iRange.first);
|
||||||
|
iRange.second = std::max(cell.localCellIndexI(), iRange.second);
|
||||||
|
jRange.first = std::min(cell.localCellIndexJ(), jRange.first);
|
||||||
|
jRange.second = std::max(cell.localCellIndexJ(), jRange.second);
|
||||||
|
kRange.first = std::min(cell.localCellIndexK(), kRange.first);
|
||||||
|
kRange.second = std::max(cell.localCellIndexK(), kRange.second);
|
||||||
|
}
|
||||||
|
|
||||||
|
auto mainGrid = eclipseCase->mainGrid();
|
||||||
|
std::vector<double> lgrValues;
|
||||||
|
for (size_t mainK = kRange.first; mainK <= kRange.second; mainK++)
|
||||||
|
{
|
||||||
|
for (size_t mainJ = jRange.first; mainJ <= jRange.second; mainJ++)
|
||||||
|
{
|
||||||
|
for (size_t mainI = iRange.first; mainI <= iRange.second; mainI++)
|
||||||
|
{
|
||||||
|
size_t globCellIndex = mainGrid->cellIndexFromIJK(mainI, mainJ, mainK);
|
||||||
|
|
||||||
|
double poro = poroAccessObject->cellScalarGlobIdx(globCellIndex);
|
||||||
|
|
||||||
|
for (size_t k = 0; k < lgrSizes.k(); k++)
|
||||||
|
{
|
||||||
|
for (size_t j = 0; j < lgrSizes.j(); j++)
|
||||||
|
{
|
||||||
|
for (size_t i = 0; i < lgrSizes.i(); i++)
|
||||||
|
{
|
||||||
|
lgrValues.push_back(poro);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
caf::VecIjk mainGridStartCell(iRange.first, jRange.first, kRange.first);
|
||||||
|
caf::VecIjk mainGridEndCell(iRange.second, jRange.second, kRange.second);
|
||||||
|
|
||||||
|
LgrInfo lgrInfo(QString("LGR_1"), lgrSizes, mainGridStartCell, mainGridEndCell);
|
||||||
|
lgrInfo.values = lgrValues;
|
||||||
|
lgrs.push_back(lgrInfo);
|
||||||
|
|
||||||
|
return lgrs;
|
||||||
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
std::vector<RigCompletionDataGridCell> RicExportLgrFeature::cellsIntersectingCompletions(RimEclipseCase* eclipseCase,
|
||||||
|
const RimWellPath* wellPath,
|
||||||
|
size_t timeStep)
|
||||||
|
{
|
||||||
|
std::vector<RigCompletionDataGridCell> cells;
|
||||||
|
|
||||||
|
auto completions = eclipseCase->computeAndGetVirtualPerforationTransmissibilities();
|
||||||
|
if (completions)
|
||||||
|
{
|
||||||
|
auto intCells = completions->multipleCompletionsPerEclipseCell(wellPath, timeStep);
|
||||||
|
|
||||||
|
for (auto intCell : intCells)
|
||||||
|
{
|
||||||
|
cells.push_back(intCell.first);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return cells;
|
||||||
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
///
|
///
|
||||||
//--------------------------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------------------------
|
||||||
@@ -205,62 +339,43 @@ void RicExportLgrFeature::onActionTriggered(bool isChecked)
|
|||||||
auto dialogData = openDialog();
|
auto dialogData = openDialog();
|
||||||
if (dialogData)
|
if (dialogData)
|
||||||
{
|
{
|
||||||
// Per cell LGR
|
|
||||||
std::map<RigCompletionDataGridCell, LgrInfo> lgrs;
|
|
||||||
|
|
||||||
auto activeView = dynamic_cast<RimEclipseView*>(RiaApplication::instance()->activeGridView());
|
auto activeView = dynamic_cast<RimEclipseView*>(RiaApplication::instance()->activeGridView());
|
||||||
if (!activeView) return;
|
if (!activeView) return;
|
||||||
|
|
||||||
auto eclipseCase = dialogData->caseToApply();
|
auto eclipseCase = dialogData->caseToApply();
|
||||||
|
|
||||||
eclipseCase->results(RiaDefines::MATRIX_MODEL)->findOrLoadScalarResult(RiaDefines::STATIC_NATIVE, "PORO");
|
|
||||||
cvf::ref<RigResultAccessor> poroAccessObject =
|
|
||||||
RigResultAccessorFactory::createFromUiResultName(eclipseCase->eclipseCaseData(), 0, RiaDefines::MATRIX_MODEL, 0, "PORO");
|
|
||||||
|
|
||||||
auto lgrCellCounts = dialogData->lgrCellCount();
|
auto lgrCellCounts = dialogData->lgrCellCount();
|
||||||
|
size_t timeStep = activeView->currentTimeStep();
|
||||||
|
|
||||||
auto completions = eclipseCase->computeAndGetVirtualPerforationTransmissibilities();
|
bool lgrIntersected = false;
|
||||||
if (completions)
|
for (const auto& wellPath : wellPaths)
|
||||||
{
|
{
|
||||||
size_t timeStep = activeView->currentTimeStep();
|
auto intersectingCells = cellsIntersectingCompletions(eclipseCase, wellPath, timeStep);
|
||||||
|
if (containsAnyNonMainGridCells(intersectingCells))
|
||||||
for (const auto& wellPath : wellPaths)
|
|
||||||
{
|
{
|
||||||
int lgrCount = 0;
|
lgrIntersected = true;
|
||||||
|
continue;
|
||||||
for (const auto& completionsForWell : completions->multipleCompletionsPerEclipseCell(wellPath, timeStep))
|
|
||||||
{
|
|
||||||
size_t globCellIndex = completionsForWell.first.globalCellIndex();
|
|
||||||
double poro = poroAccessObject->cellScalarGlobIdx(globCellIndex);
|
|
||||||
|
|
||||||
std::vector<double> lgrValues;
|
|
||||||
|
|
||||||
for (size_t k = 0; k < lgrCellCounts.k(); k++)
|
|
||||||
{
|
|
||||||
for (size_t j = 0; j < lgrCellCounts.j(); j++)
|
|
||||||
{
|
|
||||||
for (size_t i = 0; i < lgrCellCounts.i(); i++)
|
|
||||||
{
|
|
||||||
lgrValues.push_back(poro);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
LgrInfo lgrInfo(QString("LGR_%1").arg(++lgrCount), lgrCellCounts);
|
|
||||||
lgrInfo.values = lgrValues;
|
|
||||||
lgrs.insert(std::make_pair(completionsForWell.first, lgrInfo));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Export
|
|
||||||
QFile file;
|
|
||||||
QString fileName = caf::Utils::makeValidFileBasename(QString("LGR_%1.dat").arg(wellPath->name()));
|
|
||||||
openFileForExport(dialogData->exportFolder(), fileName, &file);
|
|
||||||
QTextStream stream(&file);
|
|
||||||
stream.setRealNumberNotation(QTextStream::FixedNotation);
|
|
||||||
stream.setRealNumberPrecision(2);
|
|
||||||
exportLgr(stream, lgrs);
|
|
||||||
file.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::vector<LgrInfo> lgrs;
|
||||||
|
if(dialogData->singleLgrSplit())
|
||||||
|
lgrs = buildSingleLgr(eclipseCase, intersectingCells, lgrCellCounts);
|
||||||
|
else
|
||||||
|
lgrs = buildOneLgrPerMainCell(eclipseCase, intersectingCells, lgrCellCounts);
|
||||||
|
|
||||||
|
// Export
|
||||||
|
QFile file;
|
||||||
|
QString fileName = caf::Utils::makeValidFileBasename(QString("LGR_%1").arg(wellPath->name())) + ".dat";
|
||||||
|
openFileForExport(dialogData->exportFolder(), fileName, &file);
|
||||||
|
QTextStream stream(&file);
|
||||||
|
stream.setRealNumberNotation(QTextStream::FixedNotation);
|
||||||
|
stream.setRealNumberPrecision(2);
|
||||||
|
exportLgr(stream, lgrs);
|
||||||
|
file.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (lgrIntersected)
|
||||||
|
{
|
||||||
|
QMessageBox::warning(nullptr, "LGR cells intersected", "At least one completion intersects with an LGR. No output for those completions produced");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -290,3 +405,14 @@ std::vector<RimWellPath*> RicExportLgrFeature::selectedWellPaths()
|
|||||||
}
|
}
|
||||||
return wellPaths;
|
return wellPaths;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
bool RicExportLgrFeature::containsAnyNonMainGridCells(const std::vector<RigCompletionDataGridCell>& cells)
|
||||||
|
{
|
||||||
|
return std::find_if(cells.begin(), cells.end(), [](const RigCompletionDataGridCell& cell)
|
||||||
|
{
|
||||||
|
return !cell.isMainGridCell();
|
||||||
|
}) != cells.end();
|
||||||
|
}
|
||||||
|
|||||||
@@ -22,7 +22,9 @@
|
|||||||
#include "cafCmdFeature.h"
|
#include "cafCmdFeature.h"
|
||||||
#include <cafVecIjk.h>
|
#include <cafVecIjk.h>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
#include <limits>
|
||||||
|
|
||||||
|
class RimEclipseCase;
|
||||||
class RimSimWellInView;
|
class RimSimWellInView;
|
||||||
class RimWellPath;
|
class RimWellPath;
|
||||||
class RicExportLgrUi;
|
class RicExportLgrUi;
|
||||||
@@ -36,13 +38,20 @@ class QTextStream;
|
|||||||
class LgrInfo
|
class LgrInfo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
LgrInfo(const QString&name, caf::VecIjk& sizes) : name(name), sizes(sizes)
|
LgrInfo(const QString&name,
|
||||||
|
const caf::VecIjk& sizes,
|
||||||
|
const caf::VecIjk& mainGridStartCell,
|
||||||
|
const caf::VecIjk& mainGridEndCell)
|
||||||
|
: name(name), sizes(sizes), mainGridStartCell(mainGridStartCell), mainGridEndCell(mainGridEndCell)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
QString name;
|
QString name;
|
||||||
caf::VecIjk sizes;
|
caf::VecIjk sizes;
|
||||||
std::vector<double> values;
|
std::vector<double> values;
|
||||||
|
|
||||||
|
caf::VecIjk mainGridStartCell;
|
||||||
|
caf::VecIjk mainGridEndCell;
|
||||||
};
|
};
|
||||||
|
|
||||||
//==================================================================================================
|
//==================================================================================================
|
||||||
@@ -52,9 +61,23 @@ class RicExportLgrFeature : public caf::CmdFeature
|
|||||||
{
|
{
|
||||||
CAF_CMD_HEADER_INIT;
|
CAF_CMD_HEADER_INIT;
|
||||||
|
|
||||||
|
typedef std::pair<size_t, size_t> Range;
|
||||||
|
static Range initRange() { return std::make_pair(std::numeric_limits<size_t>::max(), 0); }
|
||||||
|
|
||||||
static RicExportLgrUi* openDialog();
|
static RicExportLgrUi* openDialog();
|
||||||
static bool openFileForExport(const QString& folderName, const QString& fileName, QFile* exportFile);
|
static bool openFileForExport(const QString& folderName, const QString& fileName, QFile* exportFile);
|
||||||
static void exportLgr(QTextStream& stream, const std::map<RigCompletionDataGridCell, LgrInfo>& lgrInfos);
|
static void exportLgr(QTextStream& stream, const std::vector<LgrInfo>& lgrInfos);
|
||||||
|
|
||||||
|
static std::vector<LgrInfo> buildOneLgrPerMainCell(RimEclipseCase* eclipseCase,
|
||||||
|
const std::vector<RigCompletionDataGridCell>& intersectingCells,
|
||||||
|
const caf::VecIjk& lgrSizes);
|
||||||
|
static std::vector<LgrInfo> buildSingleLgr(RimEclipseCase* eclipseCase,
|
||||||
|
const std::vector<RigCompletionDataGridCell>& intersectingCells,
|
||||||
|
const caf::VecIjk& lgrSizes);
|
||||||
|
|
||||||
|
static std::vector<RigCompletionDataGridCell> cellsIntersectingCompletions(RimEclipseCase* eclipseCase,
|
||||||
|
const RimWellPath* wellPath,
|
||||||
|
size_t timeStep);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual bool isCommandEnabled() override;
|
virtual bool isCommandEnabled() override;
|
||||||
@@ -63,4 +86,5 @@ protected:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
static std::vector<RimWellPath*> selectedWellPaths();
|
static std::vector<RimWellPath*> selectedWellPaths();
|
||||||
|
static bool containsAnyNonMainGridCells(const std::vector<RigCompletionDataGridCell>& cells);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -131,3 +131,11 @@ QString RigCompletionDataGridCell::lgrName() const
|
|||||||
{
|
{
|
||||||
return m_lgrName;
|
return m_lgrName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
///
|
||||||
|
//--------------------------------------------------------------------------------------------------
|
||||||
|
bool RigCompletionDataGridCell::isMainGridCell() const
|
||||||
|
{
|
||||||
|
return m_lgrName.isEmpty();
|
||||||
|
}
|
||||||
|
|||||||
@@ -46,6 +46,8 @@ public:
|
|||||||
|
|
||||||
QString lgrName() const;
|
QString lgrName() const;
|
||||||
|
|
||||||
|
bool isMainGridCell() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
size_t m_globalCellIndex;
|
size_t m_globalCellIndex;
|
||||||
QString m_lgrName;
|
QString m_lgrName;
|
||||||
|
|||||||
Reference in New Issue
Block a user