output the cells which the simulator classes consider active
copying the EclipseGrid object is required as the final set of active cells requires knowledge of the grid used by the simulator which is not available in opm-parser. In turn, this requires to call EclipseGrid::resetACTNUM() which is non-const.
This commit is contained in:
parent
dc5fc64e98
commit
597735b7d0
@ -483,7 +483,18 @@ public:
|
|||||||
auto dataField = eclipseState->getDoubleGridProperty("PORO")->getData();
|
auto dataField = eclipseState->getDoubleGridProperty("PORO")->getData();
|
||||||
restrictToActiveCells(dataField, numCells, compressedToCartesianCellIdx);
|
restrictToActiveCells(dataField, numCells, compressedToCartesianCellIdx);
|
||||||
|
|
||||||
auto eclGrid = eclipseState->getEclipseGrid();
|
auto eclGrid = eclipseState->getEclipseGridCopy();
|
||||||
|
|
||||||
|
// update the ACTNUM array using the processed cornerpoint grid
|
||||||
|
std::vector<int> actnumData(eclGrid->getCartesianSize(), 1);
|
||||||
|
if (compressedToCartesianCellIdx) {
|
||||||
|
std::fill(actnumData.begin(), actnumData.end(), 0);
|
||||||
|
for (int cellIdx = 0; cellIdx < numCells; ++cellIdx) {
|
||||||
|
int cartesianCellIdx = compressedToCartesianCellIdx[cellIdx];
|
||||||
|
actnumData[cartesianCellIdx] = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
eclGrid->resetACTNUM(&actnumData[0]);
|
||||||
|
|
||||||
// finally, write the grid to disk
|
// finally, write the grid to disk
|
||||||
eclGrid->fwriteEGRID(egridFileName_.ertHandle());
|
eclGrid->fwriteEGRID(egridFileName_.ertHandle());
|
||||||
|
Loading…
Reference in New Issue
Block a user