2012-05-18 02:45:23 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2011-2012 Statoil ASA, Ceetron AS
|
|
|
|
//
|
|
|
|
// 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 <http://www.gnu.org/licenses/gpl.html>
|
|
|
|
// for more details.
|
|
|
|
//
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#include "RigReservoirBuilderMock.h"
|
2013-03-22 10:58:44 -05:00
|
|
|
#include "RigCaseData.h"
|
2013-03-21 04:31:58 -05:00
|
|
|
#include "RigActiveCellInfo.h"
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
/* rand example: guess the number */
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <time.h>
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RigReservoirBuilderMock::RigReservoirBuilderMock()
|
|
|
|
{
|
|
|
|
m_resultCount = 0;
|
|
|
|
m_timeStepCount = 0;
|
|
|
|
m_gridPointDimensions = cvf::Vec3st::ZERO;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigReservoirBuilderMock::setGridPointDimensions(const cvf::Vec3st& gridPointDimensions)
|
|
|
|
{
|
|
|
|
m_gridPointDimensions = gridPointDimensions;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigReservoirBuilderMock::setResultInfo(size_t resultCount, size_t timeStepCount)
|
|
|
|
{
|
|
|
|
m_resultCount = resultCount;
|
|
|
|
m_timeStepCount = timeStepCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigReservoirBuilderMock::appendNodes(const cvf::Vec3d& min, const cvf::Vec3d& max, const cvf::Vec3st& cubeDimension, std::vector<cvf::Vec3d>& nodes)
|
|
|
|
{
|
|
|
|
double dx = (max.x() - min.x()) / static_cast<double>(cubeDimension.x());
|
|
|
|
double dy = (max.y() - min.y()) / static_cast<double>(cubeDimension.y());
|
|
|
|
double dz = (max.z() - min.z()) / static_cast<double>(cubeDimension.z());
|
|
|
|
|
|
|
|
double zPos = min.z();
|
|
|
|
|
|
|
|
size_t k;
|
|
|
|
for (k = 0; k < cubeDimension.z(); k++)
|
|
|
|
{
|
|
|
|
double yPos = min.y();
|
|
|
|
|
|
|
|
size_t j;
|
|
|
|
for (j = 0; j < cubeDimension.y(); j++)
|
|
|
|
{
|
|
|
|
double xPos = min.x();
|
|
|
|
|
|
|
|
size_t i;
|
|
|
|
for (i = 0; i < cubeDimension.x(); i++)
|
|
|
|
{
|
|
|
|
cvf::Vec3d min(xPos, yPos, zPos);
|
|
|
|
cvf::Vec3d max(xPos + dx, yPos + dy, zPos + dz);
|
|
|
|
|
|
|
|
appendCubeNodes(min, max, nodes);
|
|
|
|
|
|
|
|
xPos += dx;
|
|
|
|
}
|
|
|
|
|
|
|
|
yPos += dy;
|
|
|
|
}
|
|
|
|
|
|
|
|
zPos += dz;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigReservoirBuilderMock::appendCubeNodes(const cvf::Vec3d& min, const cvf::Vec3d& max, std::vector<cvf::Vec3d>& nodes)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
// 7---------6 Faces:
|
|
|
|
// /| /| |k 0 bottom 0, 3, 2, 1
|
|
|
|
// / | / | | /j 1 top 4, 5, 6, 7
|
|
|
|
// 4---------5 | |/ 2 front 0, 1, 5, 4
|
|
|
|
// | 3------|--2 *---i 3 right 1, 2, 6, 5
|
|
|
|
// | / | / 4 back 3, 7, 6, 2
|
|
|
|
// |/ |/ 5 left 0, 4, 7, 3
|
|
|
|
// 0---------1
|
|
|
|
|
|
|
|
cvf::Vec3d v0(min.x(), min.y(), min.z());
|
|
|
|
cvf::Vec3d v1(max.x(), min.y(), min.z());
|
|
|
|
cvf::Vec3d v2(max.x(), max.y(), min.z());
|
|
|
|
cvf::Vec3d v3(min.x(), max.y(), min.z());
|
|
|
|
|
|
|
|
cvf::Vec3d v4(min.x(), min.y(), max.z());
|
|
|
|
cvf::Vec3d v5(max.x(), min.y(), max.z());
|
|
|
|
cvf::Vec3d v6(max.x(), max.y(), max.z());
|
|
|
|
cvf::Vec3d v7(min.x(), max.y(), max.z());
|
|
|
|
|
|
|
|
nodes.push_back(v0);
|
|
|
|
nodes.push_back(v1);
|
|
|
|
nodes.push_back(v2);
|
|
|
|
nodes.push_back(v3);
|
|
|
|
nodes.push_back(v4);
|
|
|
|
nodes.push_back(v5);
|
|
|
|
nodes.push_back(v6);
|
|
|
|
nodes.push_back(v7);
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigReservoirBuilderMock::appendCells(size_t nodeStartIndex, size_t cellCount, RigGridBase* hostGrid, std::vector<RigCell>& cells)
|
|
|
|
{
|
2013-01-30 02:30:48 -06:00
|
|
|
size_t activeCellIndex = 0;
|
2012-05-18 02:45:23 -05:00
|
|
|
size_t i;
|
|
|
|
for (i = 0; i < cellCount; i++)
|
|
|
|
{
|
|
|
|
RigCell riCell;
|
|
|
|
|
|
|
|
riCell.setHostGrid(hostGrid);
|
|
|
|
riCell.setCellIndex(i);
|
|
|
|
|
|
|
|
riCell.cornerIndices()[0] = nodeStartIndex + i * 8 + 0;
|
|
|
|
riCell.cornerIndices()[1] = nodeStartIndex + i * 8 + 1;
|
|
|
|
riCell.cornerIndices()[2] = nodeStartIndex + i * 8 + 2;
|
|
|
|
riCell.cornerIndices()[3] = nodeStartIndex + i * 8 + 3;
|
|
|
|
riCell.cornerIndices()[4] = nodeStartIndex + i * 8 + 4;
|
|
|
|
riCell.cornerIndices()[5] = nodeStartIndex + i * 8 + 5;
|
|
|
|
riCell.cornerIndices()[6] = nodeStartIndex + i * 8 + 6;
|
|
|
|
riCell.cornerIndices()[7] = nodeStartIndex + i * 8 + 7;
|
|
|
|
|
|
|
|
riCell.setParentCellIndex(0);
|
2013-01-30 02:30:48 -06:00
|
|
|
|
2013-02-25 07:07:59 -06:00
|
|
|
//TODO: Rewrite active cell info in mock models
|
|
|
|
/*
|
2013-01-30 02:30:48 -06:00
|
|
|
if (!(i % 5))
|
|
|
|
{
|
2013-01-30 07:13:50 -06:00
|
|
|
riCell.setActiveIndexInMatrixModel(cvf::UNDEFINED_SIZE_T);
|
2013-01-30 02:30:48 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2013-01-30 07:13:50 -06:00
|
|
|
riCell.setActiveIndexInMatrixModel(activeCellIndex++);
|
2013-01-30 02:30:48 -06:00
|
|
|
}
|
2013-02-25 07:07:59 -06:00
|
|
|
*/
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
cells.push_back(riCell);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigReservoirBuilderMock::populateReservoir(RigCaseData* eclipseCase)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2013-02-13 06:24:39 -06:00
|
|
|
std::vector<cvf::Vec3d>& mainGridNodes = eclipseCase->mainGrid()->nodes();
|
2012-05-18 02:45:23 -05:00
|
|
|
appendNodes(m_minWorldCoordinate, m_maxWorldCoordinate, cellDimension(), mainGridNodes);
|
|
|
|
size_t mainGridNodeCount = mainGridNodes.size();
|
|
|
|
size_t mainGridCellCount = mainGridNodeCount / 8;
|
|
|
|
|
|
|
|
// Must create cells in main grid here, as this information is used when creating LGRs
|
2013-02-13 06:24:39 -06:00
|
|
|
appendCells(0, mainGridCellCount, eclipseCase->mainGrid(), eclipseCase->mainGrid()->cells());
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
size_t totalCellCount = mainGridCellCount;
|
|
|
|
|
|
|
|
size_t lgrIdx;
|
|
|
|
for (lgrIdx = 0; lgrIdx < m_localGridRefinements.size(); lgrIdx++)
|
|
|
|
{
|
|
|
|
LocalGridRefinement& lgr = m_localGridRefinements[lgrIdx];
|
|
|
|
|
|
|
|
// Compute all global cell indices to be replaced by local grid refinement
|
|
|
|
std::vector<size_t> mainGridIndicesWithSubGrid;
|
|
|
|
{
|
|
|
|
size_t i;
|
|
|
|
for (i = lgr.m_mainGridMinCellPosition.x(); i <= lgr.m_mainGridMaxCellPosition.x(); i++)
|
|
|
|
{
|
|
|
|
size_t j;
|
|
|
|
for (j = lgr.m_mainGridMinCellPosition.y(); j <= lgr.m_mainGridMaxCellPosition.y(); j++)
|
|
|
|
{
|
|
|
|
size_t k;
|
|
|
|
for (k = lgr.m_mainGridMinCellPosition.z(); k <= lgr.m_mainGridMaxCellPosition.z(); k++)
|
|
|
|
{
|
|
|
|
mainGridIndicesWithSubGrid.push_back(cellIndexFromIJK(i, j, k));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create local grid and set local grid dimensions
|
2013-02-13 06:24:39 -06:00
|
|
|
RigLocalGrid* localGrid = new RigLocalGrid(eclipseCase->mainGrid());
|
|
|
|
eclipseCase->mainGrid()->addLocalGrid(localGrid);
|
|
|
|
localGrid->setParentGrid(eclipseCase->mainGrid());
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
localGrid->setIndexToStartOfCells(mainGridNodes.size() / 8);
|
|
|
|
cvf::Vec3st gridPointDimensions(
|
|
|
|
lgr.m_singleCellRefinementFactors.x() * (lgr.m_mainGridMaxCellPosition.x() - lgr.m_mainGridMinCellPosition.x() + 1) + 1,
|
|
|
|
lgr.m_singleCellRefinementFactors.y() * (lgr.m_mainGridMaxCellPosition.y() - lgr.m_mainGridMinCellPosition.y() + 1) + 1,
|
|
|
|
lgr.m_singleCellRefinementFactors.z() * (lgr.m_mainGridMaxCellPosition.z() - lgr.m_mainGridMinCellPosition.z() + 1) + 1);
|
|
|
|
localGrid->setGridPointDimensions(gridPointDimensions);
|
|
|
|
|
|
|
|
cvf::BoundingBox bb;
|
|
|
|
size_t cellIdx;
|
|
|
|
for (cellIdx = 0; cellIdx < mainGridIndicesWithSubGrid.size(); cellIdx++)
|
|
|
|
{
|
2013-02-13 06:24:39 -06:00
|
|
|
RigCell& cell = eclipseCase->mainGrid()->cells()[mainGridIndicesWithSubGrid[cellIdx]];
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
caf::SizeTArray8& indices = cell.cornerIndices();
|
|
|
|
int nodeIdx;
|
|
|
|
for (nodeIdx = 0; nodeIdx < 8; nodeIdx++)
|
|
|
|
{
|
2013-02-13 06:24:39 -06:00
|
|
|
bb.add(eclipseCase->mainGrid()->nodes()[indices[nodeIdx]]);
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
// Deactivate cell in main grid
|
|
|
|
cell.setSubGrid(localGrid);
|
|
|
|
}
|
|
|
|
|
|
|
|
cvf::Vec3st lgrCellDimensions = gridPointDimensions - cvf::Vec3st(1, 1, 1);
|
|
|
|
appendNodes(bb.min(), bb.max(), lgrCellDimensions, mainGridNodes);
|
|
|
|
|
|
|
|
size_t subGridCellCount = (mainGridNodes.size() / 8) - totalCellCount;
|
2013-02-13 06:24:39 -06:00
|
|
|
appendCells(totalCellCount*8, subGridCellCount, localGrid, eclipseCase->mainGrid()->cells());
|
2012-05-18 02:45:23 -05:00
|
|
|
totalCellCount += subGridCellCount;
|
|
|
|
}
|
|
|
|
|
2013-02-13 06:24:39 -06:00
|
|
|
eclipseCase->mainGrid()->setGridPointDimensions(m_gridPointDimensions);
|
2012-05-18 02:45:23 -05:00
|
|
|
|
2013-02-13 06:24:39 -06:00
|
|
|
addWellData(eclipseCase, eclipseCase->mainGrid());
|
2013-02-25 07:07:59 -06:00
|
|
|
|
|
|
|
// Set all cells active
|
2013-03-13 05:50:31 -05:00
|
|
|
RigActiveCellInfo* activeCellInfo = eclipseCase->activeCellInfo(RifReaderInterface::MATRIX_RESULTS);
|
2013-02-25 07:07:59 -06:00
|
|
|
activeCellInfo->setGlobalCellCount(eclipseCase->mainGrid()->cells().size());
|
|
|
|
for (size_t i = 0; i < eclipseCase->mainGrid()->cells().size(); i++)
|
|
|
|
{
|
2013-03-22 03:32:42 -05:00
|
|
|
activeCellInfo->setCellResultIndex(i, i);
|
2013-02-25 07:07:59 -06:00
|
|
|
}
|
2013-05-21 14:03:05 -05:00
|
|
|
|
2013-05-24 02:54:00 -05:00
|
|
|
activeCellInfo->setGridCount(1);
|
|
|
|
activeCellInfo->setGridActiveCellCounts(0, eclipseCase->mainGrid()->cells().size());
|
|
|
|
activeCellInfo->computeDerivedData();
|
|
|
|
|
2013-05-21 14:03:05 -05:00
|
|
|
// Add grid coarsening for main grid
|
2013-05-22 01:11:39 -05:00
|
|
|
if (cellDimension().x() > 4 &&
|
|
|
|
cellDimension().y() > 5 &&
|
|
|
|
cellDimension().z() > 6)
|
|
|
|
{
|
|
|
|
eclipseCase->mainGrid()->addCoarseningBox(1, 2, 1, 3, 1, 4);
|
|
|
|
eclipseCase->mainGrid()->addCoarseningBox(3, 4, 4, 5, 5, 6);
|
|
|
|
}
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigReservoirBuilderMock::addLocalGridRefinement(const cvf::Vec3st& mainGridStart, const cvf::Vec3st& mainGridEnd, const cvf::Vec3st& refinementFactors)
|
|
|
|
{
|
|
|
|
m_localGridRefinements.push_back(LocalGridRefinement(mainGridStart, mainGridEnd, refinementFactors));
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigReservoirBuilderMock::setWorldCoordinates(cvf::Vec3d minWorldCoordinate, cvf::Vec3d maxWorldCoordinate)
|
|
|
|
{
|
|
|
|
m_minWorldCoordinate = minWorldCoordinate;
|
|
|
|
m_maxWorldCoordinate = maxWorldCoordinate;
|
|
|
|
}
|
|
|
|
|
2012-06-26 09:10:41 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
bool RigReservoirBuilderMock::inputProperty(RigCaseData* eclipseCase, const QString& propertyName, std::vector<double>* values)
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
size_t k;
|
|
|
|
|
|
|
|
/* initialize random seed: */
|
|
|
|
srand ( time(NULL) );
|
|
|
|
|
|
|
|
/* generate secret number: */
|
|
|
|
int iSecret = rand() % 20 + 1;
|
|
|
|
|
2013-02-13 06:24:39 -06:00
|
|
|
for (k = 0; k < eclipseCase->mainGrid()->cells().size(); k++)
|
2012-06-26 09:10:41 -05:00
|
|
|
{
|
|
|
|
values->push_back(k * iSecret);
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
bool RigReservoirBuilderMock::staticResult(RigCaseData* eclipseCase, const QString& result, std::vector<double>* values)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
size_t k;
|
|
|
|
|
2013-02-13 06:24:39 -06:00
|
|
|
for (k = 0; k < eclipseCase->mainGrid()->cells().size(); k++)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
{
|
2013-02-25 07:07:59 -06:00
|
|
|
values->push_back((k * 2) % eclipseCase->mainGrid()->cells().size());
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
bool RigReservoirBuilderMock::dynamicResult(RigCaseData* eclipseCase, const QString& result, size_t stepIndex, std::vector<double>* values)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
|
|
|
int resultIndex = 1;
|
|
|
|
|
|
|
|
QRegExp rx("[0-9]{1,2}"); // Find number 0-99
|
|
|
|
int digitPos = rx.indexIn(result);
|
|
|
|
if (digitPos > -1)
|
|
|
|
{
|
|
|
|
resultIndex = rx.cap(0).toInt() + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
double scaleValue = 1.0 + resultIndex * 0.1;
|
|
|
|
double offsetValue = 100 * resultIndex;
|
|
|
|
|
|
|
|
size_t k;
|
2013-02-13 06:24:39 -06:00
|
|
|
for (k = 0; k < eclipseCase->mainGrid()->cells().size(); k++)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2013-02-13 06:24:39 -06:00
|
|
|
RigCell& cell = eclipseCase->mainGrid()->cells()[k];
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2013-02-25 07:07:59 -06:00
|
|
|
double val = offsetValue + scaleValue * ( (stepIndex * 1000 + k) % eclipseCase->mainGrid()->cells().size() );
|
|
|
|
values->push_back(val);
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-08-31 12:12:47 -05:00
|
|
|
// Set result size to zero for some timesteps
|
|
|
|
if ((stepIndex + 1) % 3 == 0)
|
|
|
|
{
|
|
|
|
values->clear();
|
|
|
|
}
|
|
|
|
|
2012-05-18 02:45:23 -05:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2013-03-22 09:43:42 -05:00
|
|
|
void RigReservoirBuilderMock::addWellData(RigCaseData* eclipseCase, RigGridBase* grid)
|
2012-05-18 02:45:23 -05:00
|
|
|
{
|
2013-02-13 06:24:39 -06:00
|
|
|
CVF_ASSERT(eclipseCase);
|
2012-05-18 02:45:23 -05:00
|
|
|
CVF_ASSERT(grid);
|
|
|
|
|
|
|
|
cvf::Vec3st dim = grid->gridPointDimensions();
|
|
|
|
|
2013-03-22 09:43:42 -05:00
|
|
|
cvf::Collection<RigSingleWellResultsData> wells;
|
2012-05-18 02:45:23 -05:00
|
|
|
|
|
|
|
int wellIdx;
|
|
|
|
for (wellIdx = 0; wellIdx < 1; wellIdx++)
|
|
|
|
{
|
2013-03-22 09:43:42 -05:00
|
|
|
cvf::ref<RigSingleWellResultsData> wellCellsTimeHistory = new RigSingleWellResultsData;
|
2012-05-18 02:45:23 -05:00
|
|
|
wellCellsTimeHistory->m_wellName = QString("Well %1").arg(wellIdx);
|
|
|
|
|
|
|
|
wellCellsTimeHistory->m_wellCellsTimeSteps.resize(m_timeStepCount);
|
|
|
|
|
|
|
|
size_t timeIdx;
|
|
|
|
for (timeIdx = 0; timeIdx < m_timeStepCount; timeIdx++)
|
|
|
|
{
|
|
|
|
RigWellResultFrame& wellCells = wellCellsTimeHistory->m_wellCellsTimeSteps[timeIdx];
|
|
|
|
|
|
|
|
wellCells.m_productionType = RigWellResultFrame::PRODUCER;
|
|
|
|
wellCells.m_isOpen = true;
|
|
|
|
|
|
|
|
wellCells.m_wellHead.m_gridIndex = 0;
|
|
|
|
wellCells.m_wellHead.m_gridCellIndex = grid->cellIndexFromIJK(1, 0, 0);
|
|
|
|
|
|
|
|
// Connections
|
|
|
|
// int connectionCount = CVF_MIN(dim.x(), CVF_MIN(dim.y(), dim.z())) - 2;
|
|
|
|
size_t connectionCount = dim.z() - 2;
|
|
|
|
if (connectionCount > 0)
|
|
|
|
{
|
|
|
|
// Only main grid supported by now. Must be taken care of when LGRs are supported
|
|
|
|
wellCells.m_wellResultBranches.resize(1);
|
|
|
|
RigWellResultBranch& wellSegment = wellCells.m_wellResultBranches[0];
|
|
|
|
|
|
|
|
size_t connIdx;
|
|
|
|
for (connIdx = 0; connIdx < connectionCount; connIdx++)
|
|
|
|
{
|
|
|
|
if (connIdx == (size_t)(connectionCount/4)) continue;
|
|
|
|
|
|
|
|
RigWellResultCell data;
|
|
|
|
data.m_gridIndex = 0;
|
|
|
|
|
|
|
|
if (connIdx < dim.y()-2)
|
|
|
|
data.m_gridCellIndex = grid->cellIndexFromIJK(1 , 1 + connIdx , 1 + connIdx);
|
|
|
|
else
|
|
|
|
data.m_gridCellIndex = grid->cellIndexFromIJK(1 , dim.y()-2 , 1 + connIdx);
|
|
|
|
|
|
|
|
|
|
|
|
if (connIdx < connectionCount / 2)
|
|
|
|
{
|
|
|
|
data.m_isOpen = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
data.m_isOpen = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (wellSegment.m_wellCells.size() == 0 || wellSegment.m_wellCells.back().m_gridCellIndex != data.m_gridCellIndex)
|
|
|
|
{
|
|
|
|
wellSegment.m_wellCells.push_back(data);
|
|
|
|
|
|
|
|
if (connIdx == connectionCount / 2 )
|
|
|
|
{
|
|
|
|
RigWellResultCell deadEndData = data;
|
|
|
|
deadEndData.m_gridCellIndex = data.m_gridCellIndex + 1;
|
|
|
|
deadEndData.m_isOpen = true;
|
|
|
|
|
|
|
|
RigWellResultCell deadEndData1 = data;
|
|
|
|
deadEndData1.m_gridCellIndex = data.m_gridCellIndex + 2;
|
|
|
|
deadEndData.m_isOpen = false;
|
|
|
|
|
|
|
|
wellSegment.m_wellCells.push_back(deadEndData);
|
|
|
|
wellSegment.m_wellCells.push_back(deadEndData1);
|
|
|
|
|
|
|
|
deadEndData.m_isOpen = true;
|
|
|
|
wellSegment.m_wellCells.push_back(deadEndData);
|
|
|
|
|
|
|
|
data.m_isOpen = true;
|
|
|
|
wellSegment.m_wellCells.push_back(data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (connIdx < dim.y()-2)
|
|
|
|
{
|
|
|
|
data.m_gridCellIndex = grid->cellIndexFromIJK(1 , 1 + connIdx , 2 + connIdx);
|
|
|
|
|
|
|
|
if (wellSegment.m_wellCells.size() == 0 || wellSegment.m_wellCells.back().m_gridCellIndex != data.m_gridCellIndex)
|
|
|
|
{
|
|
|
|
wellSegment.m_wellCells.push_back(data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create a mapping from result timestep indices to well timestep indices.
|
|
|
|
// Use one-to-one mapping for easy use
|
|
|
|
std::vector<size_t> map;
|
|
|
|
for (timeIdx = 0; timeIdx < m_timeStepCount; timeIdx++)
|
|
|
|
{
|
|
|
|
map.push_back(timeIdx);
|
|
|
|
}
|
|
|
|
wellCellsTimeHistory->m_resultTimeStepIndexToWellTimeStepIndex = map;
|
|
|
|
|
|
|
|
wells.push_back(wellCellsTimeHistory.p());
|
|
|
|
}
|
|
|
|
|
2013-02-13 06:24:39 -06:00
|
|
|
eclipseCase->setWellResults(wells);
|
2012-05-18 02:45:23 -05:00
|
|
|
}
|
|
|
|
|