mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-02-25 18:55:30 -06:00
Add support for miscible solvent runs
- initialization only via Ecl Deck - adds modification of relperms and cap-pressures for miscible runs - adds TL mixing model for effective viscosity and density calculations Tested on SPE1CASE2_SOLVENT_MISC_TL, SPE9_CP_CO2_MISC_TL, SPE5CASE1-3 and SPE3CASE1_SOLVENT_MISC
This commit is contained in:
parent
64feefaf05
commit
f14ea0e3af
@ -778,6 +778,26 @@ public:
|
||||
return satnum_[elemIdx];
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Returns the index of the relevant region for thermodynmic properties
|
||||
*/
|
||||
template <class Context>
|
||||
unsigned miscnumRegionIndex(const Context& context, unsigned spaceIdx, unsigned timeIdx) const
|
||||
{ return miscnumRegionIndex(context.globalSpaceIndex(spaceIdx, timeIdx)); }
|
||||
|
||||
/*!
|
||||
* \brief Returns the index the relevant MISC region given a cell index
|
||||
*/
|
||||
unsigned miscnumRegionIndex(unsigned elemIdx) const
|
||||
{
|
||||
if (miscnum_.empty())
|
||||
return 0;
|
||||
|
||||
return miscnum_[elemIdx];
|
||||
}
|
||||
|
||||
|
||||
|
||||
/*!
|
||||
* \copydoc FvBaseProblem::name
|
||||
*/
|
||||
@ -1404,6 +1424,25 @@ private:
|
||||
}
|
||||
}
|
||||
|
||||
void updateMiscnum_()
|
||||
{
|
||||
const auto& eclState = this->simulator().gridManager().eclState();
|
||||
const auto& eclProps = eclState.get3DProperties();
|
||||
|
||||
if (!eclProps.hasDeckIntGridProperty("MISCNUM"))
|
||||
return;
|
||||
|
||||
const auto& miscnumData = eclProps.getIntGridProperty("MISCNUM").getData();
|
||||
const auto& gridManager = this->simulator().gridManager();
|
||||
|
||||
unsigned numElems = gridManager.gridView().size(/*codim=*/0);
|
||||
miscnum_.resize(numElems);
|
||||
for (unsigned elemIdx = 0; elemIdx < numElems; ++elemIdx) {
|
||||
unsigned cartElemIdx = gridManager.cartesianIndex(elemIdx);
|
||||
miscnum_[elemIdx] = miscnumData[cartElemIdx] - 1;
|
||||
}
|
||||
}
|
||||
|
||||
struct PffDofData_
|
||||
{
|
||||
Scalar transmissibility;
|
||||
@ -1449,6 +1488,7 @@ private:
|
||||
|
||||
std::vector<unsigned short> pvtnum_;
|
||||
std::vector<unsigned short> satnum_;
|
||||
std::vector<unsigned short> miscnum_;
|
||||
std::vector<unsigned short> rockTableIdx_;
|
||||
std::vector<RockParams> rockParams_;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user