ECL output: use the same units as the input deck for ECL output

this makes it possible to compare ECL restart and summary files
produced by ebos directly with the ones stemming from Eclips. (But be
aware that VTK output files from ebos are still all-SI!)
This commit is contained in:
Andreas Lauser 2015-01-25 17:27:08 +01:00
parent c651c2f4ce
commit e09b026551
2 changed files with 31 additions and 4 deletions

View File

@ -211,27 +211,44 @@ public:
if (!dynamic_cast<EclWriter*>(&writer)) if (!dynamic_cast<EclWriter*>(&writer))
return; // this module only consideres ecl writers... return; // this module only consideres ecl writers...
typedef EclDeckUnits<TypeTag> DeckUnits;
const auto& deckUnits = this->simulator_.problem().deckUnits();
typename ParentType::BufferType bufferType = ParentType::ElementBuffer; typename ParentType::BufferType bufferType = ParentType::ElementBuffer;
if (pressuresOutput_()) { if (pressuresOutput_()) {
for (int phaseIdx = 0; phaseIdx < numPhases; ++ phaseIdx)
deckUnits.siToDeck(pressure_[phaseIdx], DeckUnits::pressure);
this->commitScalarBuffer_(writer, "PRESSURE", pressure_[oilPhaseIdx], bufferType); this->commitScalarBuffer_(writer, "PRESSURE", pressure_[oilPhaseIdx], bufferType);
this->commitScalarBuffer_(writer, "PGAS", pressure_[gasPhaseIdx], bufferType); this->commitScalarBuffer_(writer, "PGAS", pressure_[gasPhaseIdx], bufferType);
this->commitScalarBuffer_(writer, "PWAT", pressure_[waterPhaseIdx], bufferType); this->commitScalarBuffer_(writer, "PWAT", pressure_[waterPhaseIdx], bufferType);
} }
if (saturationsOutput_()) { if (saturationsOutput_()) {
for (int phaseIdx = 0; phaseIdx < numPhases; ++ phaseIdx)
deckUnits.siToDeck(saturation_[phaseIdx], DeckUnits::saturation);
this->commitScalarBuffer_(writer, "SWAT", saturation_[waterPhaseIdx], bufferType); this->commitScalarBuffer_(writer, "SWAT", saturation_[waterPhaseIdx], bufferType);
this->commitScalarBuffer_(writer, "SGAS", saturation_[gasPhaseIdx], bufferType); this->commitScalarBuffer_(writer, "SGAS", saturation_[gasPhaseIdx], bufferType);
// the oil saturation is _NOT_ written to disk. Instead, it is calculated by // the oil saturation is _NOT_ written to disk. Instead, it is calculated by
// the visualization tool. Wondering why is probably a waste of time... // the visualization tool. Wondering why is probably a waste of time...
} }
if (gasDissolutionFactorOutput_()) if (gasDissolutionFactorOutput_()) {
deckUnits.siToDeck(gasDissolutionFactor_, DeckUnits::gasDissolutionFactor);
this->commitScalarBuffer_(writer, "RS", gasDissolutionFactor_, bufferType); this->commitScalarBuffer_(writer, "RS", gasDissolutionFactor_, bufferType);
if (gasFormationVolumeFactorOutput_()) }
if (gasFormationVolumeFactorOutput_()) {
// no unit conversion required
this->commitScalarBuffer_(writer, "BG", gasFormationVolumeFactor_, bufferType); this->commitScalarBuffer_(writer, "BG", gasFormationVolumeFactor_, bufferType);
if (saturatedOilFormationVolumeFactorOutput_()) }
if (saturatedOilFormationVolumeFactorOutput_()) {
// no unit conversion required
this->commitScalarBuffer_(writer, "BOSAT", saturatedOilFormationVolumeFactor_, bufferType); this->commitScalarBuffer_(writer, "BOSAT", saturatedOilFormationVolumeFactor_, bufferType);
if (oilSaturationPressureOutput_()) }
if (oilSaturationPressureOutput_()) {
deckUnits.siToDeck(oilSaturationPressure_, DeckUnits::pressure);
this->commitScalarBuffer_(writer, "PSAT", oilSaturationPressure_); this->commitScalarBuffer_(writer, "PSAT", oilSaturationPressure_);
} }
}
private: private:
static bool saturationsOutput_() static bool saturationsOutput_()

View File

@ -32,6 +32,7 @@
#include "ecltransmissibility.hh" #include "ecltransmissibility.hh"
#include "ecldummygradientcalculator.hh" #include "ecldummygradientcalculator.hh"
#include "eclfluxmodule.hh" #include "eclfluxmodule.hh"
#include "ecldeckunits.hh"
#include <ewoms/models/blackoil/blackoilmodel.hh> #include <ewoms/models/blackoil/blackoilmodel.hh>
#include <ewoms/disc/ecfv/ecfvdiscretization.hh> #include <ewoms/disc/ecfv/ecfvdiscretization.hh>
@ -241,6 +242,7 @@ public:
: ParentType(simulator) : ParentType(simulator)
, transmissibilities_(simulator) , transmissibilities_(simulator)
, wellManager_(simulator) , wellManager_(simulator)
, deckUnits_(simulator)
, eclWriter_(simulator) , eclWriter_(simulator)
, summaryWriter_(simulator) , summaryWriter_(simulator)
{ {
@ -419,6 +421,12 @@ public:
} }
} }
/*!
* \brief Returns the object which converts between SI and deck units.
*/
const EclDeckUnits<TypeTag>& deckUnits() const
{ return deckUnits_; }
/*! /*!
* \copydoc FvBaseMultiPhaseProblem::intrinsicPermeability * \copydoc FvBaseMultiPhaseProblem::intrinsicPermeability
*/ */
@ -992,6 +1000,8 @@ private:
EclWellManager<TypeTag> wellManager_; EclWellManager<TypeTag> wellManager_;
EclDeckUnits<TypeTag> deckUnits_;
EclWriter<TypeTag> eclWriter_; EclWriter<TypeTag> eclWriter_;
EclSummaryWriter summaryWriter_; EclSummaryWriter summaryWriter_;
}; };