2015-05-26 01:57:53 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2015- Statoil ASA
|
|
|
|
// Copyright (C) 2015- Ceetron Solutions 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 "RigFemPartGrid.h"
|
|
|
|
|
|
|
|
|
|
|
|
#include "RigFemPart.h"
|
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RigFemPartGrid::RigFemPartGrid(RigFemPart* femPart)
|
|
|
|
{
|
|
|
|
m_femPart = femPart;
|
|
|
|
generateStructGridData();
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RigFemPartGrid::~RigFemPartGrid()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-05-27 08:35:14 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
cvf::StructGridInterface::FaceType RigFemPartGrid::findGridFace(cvf::Vec3d faceNormal )
|
|
|
|
{
|
|
|
|
FaceType bestFace = cvf::StructGridInterface::POS_I;
|
|
|
|
|
|
|
|
double maxComponent = fabs(faceNormal[0]);
|
|
|
|
bestFace = (faceNormal[0] < 0) ? cvf::StructGridInterface::NEG_I: cvf::StructGridInterface::POS_I;
|
|
|
|
|
|
|
|
double absComp = fabs(faceNormal[1]);
|
|
|
|
if ( absComp > maxComponent)
|
|
|
|
{
|
|
|
|
maxComponent = absComp;
|
|
|
|
bestFace = (faceNormal[1] < 0) ? cvf::StructGridInterface::NEG_J: cvf::StructGridInterface::POS_J;
|
|
|
|
}
|
|
|
|
|
|
|
|
absComp = fabs(faceNormal[2]);
|
|
|
|
if ( absComp > maxComponent)
|
|
|
|
{
|
|
|
|
bestFace = (faceNormal[2] < 0) ? cvf::StructGridInterface::NEG_K: cvf::StructGridInterface::POS_K;
|
|
|
|
}
|
|
|
|
|
|
|
|
return bestFace;
|
|
|
|
}
|
|
|
|
|
2015-05-26 01:57:53 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigFemPartGrid::generateStructGridData()
|
|
|
|
{
|
|
|
|
// 1. Calculate neighbors for each element
|
|
|
|
// record the ones with 3 or fewer neighbors as possible grid corners
|
|
|
|
// 2. Loop over the possible corner cells,
|
|
|
|
// find the one that corresponds to IJK = 000
|
|
|
|
// by Determining what surfs correspond to NEG IJK surfaces in that element,
|
|
|
|
// and that none of those faces have a neighbor
|
|
|
|
// 4. Assign IJK = 000 to that element
|
|
|
|
// Store IJK in elm idx array
|
|
|
|
// 5. Loop along POS I surfaces increment I for each element and assign IJK
|
|
|
|
// when at end, go to POS J neighbor, increment J, repeat above.
|
|
|
|
// etc for POS Z
|
|
|
|
// Find max IJK as you go,
|
|
|
|
// also assert that there are no NEG I/NEG J/NEG Z neighbors when starting on a new row
|
|
|
|
// (Need to find min, and offset IJK values if there exists such)
|
|
|
|
// 6. If IJK to elm idx is needed, allocate "grid" with maxI,maxJ,maxZ values
|
|
|
|
// Loop over elms, assign elmIdx to IJK address in grid
|
|
|
|
|
2015-05-27 08:35:14 -05:00
|
|
|
const std::vector<int>& possibleGridCorners = m_femPart->possibleGridCornerElements();
|
|
|
|
size_t possibleCornerCount = possibleGridCorners.size();
|
|
|
|
const std::vector<cvf::Vec3f>& nodeCoordinates = m_femPart->nodes().coordinates;
|
2015-05-26 01:57:53 -05:00
|
|
|
|
2015-05-27 08:35:14 -05:00
|
|
|
// Find corner cell closest to origo
|
|
|
|
size_t gridCornerClosestToOrigo = cvf::UNDEFINED_SIZE_T;
|
|
|
|
double minDistance = HUGE_VAL;
|
|
|
|
for (size_t pcIdx = 0; pcIdx < possibleCornerCount; ++pcIdx)
|
|
|
|
{
|
|
|
|
int elmIdx = possibleGridCorners[pcIdx];
|
2015-05-26 01:57:53 -05:00
|
|
|
|
2015-05-27 08:35:14 -05:00
|
|
|
const int* elmNodeIndices = m_femPart->connectivities(elmIdx);
|
|
|
|
cvf::Vec3f firstNodePos = nodeCoordinates[elmNodeIndices[0]];
|
|
|
|
float distSq = firstNodePos.lengthSquared();
|
|
|
|
if (distSq < minDistance)
|
|
|
|
{
|
|
|
|
minDistance = distSq;
|
|
|
|
gridCornerClosestToOrigo = pcIdx;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
2015-05-26 01:57:53 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
size_t RigFemPartGrid::gridPointCountI() const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::UNDEFINED_SIZE_T;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
size_t RigFemPartGrid::gridPointCountJ() const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::UNDEFINED_SIZE_T;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
size_t RigFemPartGrid::gridPointCountK() const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::UNDEFINED_SIZE_T;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RigFemPartGrid::isCellValid(size_t i, size_t j, size_t k) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
cvf::Vec3d RigFemPartGrid::minCoordinate() const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::Vec3d::ZERO;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
cvf::Vec3d RigFemPartGrid::maxCoordinate() const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::Vec3d::ZERO;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RigFemPartGrid::cellIJKNeighbor(size_t i, size_t j, size_t k, FaceType face, size_t* neighborCellIndex) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
size_t RigFemPartGrid::cellIndexFromIJK(size_t i, size_t j, size_t k) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::UNDEFINED_SIZE_T;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RigFemPartGrid::ijkFromCellIndex(size_t cellIndex, size_t* i, size_t* j, size_t* k) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RigFemPartGrid::cellIJKFromCoordinate(const cvf::Vec3d& coord, size_t* i, size_t* j, size_t* k) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigFemPartGrid::cellCornerVertices(size_t cellIndex, cvf::Vec3d vertices[8]) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
cvf::Vec3d RigFemPartGrid::cellCentroid(size_t cellIndex) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::Vec3d::ZERO;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RigFemPartGrid::cellMinMaxCordinates(size_t cellIndex, cvf::Vec3d* minCoordinate, cvf::Vec3d* maxCoordinate) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
size_t RigFemPartGrid::gridPointIndexFromIJK(size_t i, size_t j, size_t k) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::UNDEFINED_SIZE_T;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
cvf::Vec3d RigFemPartGrid::gridPointCoordinate(size_t i, size_t j, size_t k) const
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return cvf::Vec3d::ZERO;
|
|
|
|
}
|
|
|
|
|
|
|
|
|