/*
Copyright 2016 Statoil ASA
2016 IRIS
This file is part of the Open Porous Media project (OPM).
OPM 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.
OPM 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 for more details.
You should have received a copy of the GNU General Public License
along with OPM. If not, see .
*/
#ifndef OPM_SIMULATORS_COMPAT_HPP
#define OPM_SIMULATORS_COMPAT_HPP
#include
#include
#include
#include
namespace Opm {
// Forward declarations
class SimulationDataContainer;
class WellStateFullyImplicitBlackoil;
class WellStateFullyImplicitBlackoilDense;
/// Extract single data vector from striped data.
/// \return u such that u[i] = v[offset + i*stride].
std::vector< double > destripe( const std::vector< double >& v,
size_t stride,
size_t offset );
/// Inject single data vector into striped data.
/// \return reference to dst input, that is changed so that
/// dst[offset + i*stride] = v[i]. This is done for
/// i = 0..(dst.size()/stride).
std::vector< double >& stripe( const std::vector< double >& v,
size_t stride,
size_t offset,
std::vector< double >& dst );
/// Returns Solution with the following fields:
/// PRESSURE, TEMP (unconditionally)
/// SWAT, SGAS, RS, RV, SSOL (if appropriate fields present in input)
/// If use_si_units is true, the fields will have the measure UnitSystem::measure::identity,
/// and therefore *not* be converted to customary units (depending on family) upon output.
data::Solution simToSolution( const SimulationDataContainer& reservoir,
const bool use_si_units,
PhaseUsage phases );
/// Copies the following fields from sol into state (all conditionally):
/// PRESSURE, TEMP, SWAT, SGAS, RS, RV, SSOL
/// Also handles extra data such as hysteresis parameters, SOMAX, etc.
void solutionToSim( const data::Solution& sol,
const std::map >& extra,
PhaseUsage phases,
SimulationDataContainer& state );
/// Copies the following fields from wells into state.
/// bhp, temperature, currentControls, wellRates, perfPress, perfRates, perfPhaseRates
void wellsToState( const data::Wells& wells,
PhaseUsage phases,
WellStateFullyImplicitBlackoil& state );
/// As the WellStateFullyImplicitBlackoil overload, but also sets
/// the wellSolution field from the values of the other fields.
void wellsToState( const data::Wells& wells,
PhaseUsage phases,
WellStateFullyImplicitBlackoilDense& state );
}
#endif //OPM_SIMULATORS_COMPAT_HPP