mirror of
https://github.com/OPM/opm-simulators.git
synced 2025-01-11 17:01:55 -06:00
Merge pull request #4520 from bska/load-aquflux-rst-info
Add Support for Initialising Constant Flux Aquifers from Restart
This commit is contained in:
commit
84cb77a870
@ -91,12 +91,18 @@ public:
|
|||||||
aquifer_data_ = aquifer;
|
aquifer_data_ = aquifer;
|
||||||
}
|
}
|
||||||
|
|
||||||
void initFromRestart(const data::Aquifers& /* aquiferSoln */) override {
|
void initFromRestart(const data::Aquifers& aquiferSoln) override
|
||||||
}
|
{
|
||||||
|
auto xaqPos = aquiferSoln.find(this->aquiferID());
|
||||||
void initialSolutionApplied() override {
|
if (xaqPos == aquiferSoln.end()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this->cumulative_flux_ = this->area_fraction_ * xaqPos->second.volume;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void initialSolutionApplied() override
|
||||||
|
{}
|
||||||
|
|
||||||
void beginTimeStep() override
|
void beginTimeStep() override
|
||||||
{}
|
{}
|
||||||
|
@ -134,6 +134,9 @@ private:
|
|||||||
void createDynamicAquifers(const int episode_index);
|
void createDynamicAquifers(const int episode_index);
|
||||||
|
|
||||||
void initializeStaticAquifers();
|
void initializeStaticAquifers();
|
||||||
|
void initializeRestartDynamicAquifers();
|
||||||
|
|
||||||
|
bool needRestartDynamicAquifers() const;
|
||||||
|
|
||||||
template <typename AquiferType, typename AquiferData>
|
template <typename AquiferType, typename AquiferData>
|
||||||
std::unique_ptr<AquiferType>
|
std::unique_ptr<AquiferType>
|
||||||
|
@ -165,6 +165,9 @@ void BlackoilAquiferModel<TypeTag>::init()
|
|||||||
this->initializeStaticAquifers();
|
this->initializeStaticAquifers();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (this->needRestartDynamicAquifers()) {
|
||||||
|
this->initializeRestartDynamicAquifers();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename TypeTag>
|
template<typename TypeTag>
|
||||||
@ -202,6 +205,15 @@ serializeOp(Serializer& serializer)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename TypeTag>
|
||||||
|
void BlackoilAquiferModel<TypeTag>::initializeRestartDynamicAquifers()
|
||||||
|
{
|
||||||
|
const auto rstStep = this->simulator_.vanguard().eclState()
|
||||||
|
.getInitConfig().getRestartStep() - 1;
|
||||||
|
|
||||||
|
this->createDynamicAquifers(rstStep);
|
||||||
|
}
|
||||||
|
|
||||||
template <typename TypeTag>
|
template <typename TypeTag>
|
||||||
void BlackoilAquiferModel<TypeTag>::initializeStaticAquifers()
|
void BlackoilAquiferModel<TypeTag>::initializeStaticAquifers()
|
||||||
{
|
{
|
||||||
@ -248,6 +260,20 @@ void BlackoilAquiferModel<TypeTag>::initializeStaticAquifers()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename TypeTag>
|
||||||
|
bool BlackoilAquiferModel<TypeTag>::needRestartDynamicAquifers() const
|
||||||
|
{
|
||||||
|
const auto& initconfig =
|
||||||
|
this->simulator_.vanguard().eclState().getInitConfig();
|
||||||
|
|
||||||
|
if (! initconfig.restartRequested()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return this->simulator_.vanguard()
|
||||||
|
.schedule()[initconfig.getRestartStep() - 1].hasAnalyticalAquifers();
|
||||||
|
}
|
||||||
|
|
||||||
template <typename TypeTag>
|
template <typename TypeTag>
|
||||||
template <typename AquiferType, typename AquiferData>
|
template <typename AquiferType, typename AquiferData>
|
||||||
std::unique_ptr<AquiferType>
|
std::unique_ptr<AquiferType>
|
||||||
|
@ -44,6 +44,24 @@ add_test_compare_parallel_restarted_simulation(CASENAME numerical_aquifer_3d_1aq
|
|||||||
DIR aquifer-num
|
DIR aquifer-num
|
||||||
TEST_ARGS --enable-tuning=true --tolerance-cnv=0.00003 --time-step-control=pid --linear-solver=cpr_trueimpes)
|
TEST_ARGS --enable-tuning=true --tolerance-cnv=0.00003 --time-step-control=pid --linear-solver=cpr_trueimpes)
|
||||||
|
|
||||||
|
add_test_compare_parallel_restarted_simulation(CASENAME aquflux_01
|
||||||
|
FILENAME AQUFLUX-01
|
||||||
|
SIMULATOR flow
|
||||||
|
ABS_TOL ${abs_tol_restart}
|
||||||
|
REL_TOL 5.0e-2
|
||||||
|
RESTART_STEP 3
|
||||||
|
DIR aquifers
|
||||||
|
TEST_ARGS --solver-max-time-step-in-days=1)
|
||||||
|
|
||||||
|
add_test_compare_parallel_restarted_simulation(CASENAME aquflux_02
|
||||||
|
FILENAME AQUFLUX-02
|
||||||
|
SIMULATOR flow
|
||||||
|
ABS_TOL ${abs_tol_restart}
|
||||||
|
REL_TOL 5.0e-2
|
||||||
|
RESTART_STEP 50
|
||||||
|
DIR aquifers
|
||||||
|
TEST_ARGS --solver-max-time-step-in-days=1)
|
||||||
|
|
||||||
# Serialized restart tests
|
# Serialized restart tests
|
||||||
if(HDF5_FOUND)
|
if(HDF5_FOUND)
|
||||||
opm_set_test_driver(${PROJECT_SOURCE_DIR}/tests/run-serialization-regressionTest.sh "")
|
opm_set_test_driver(${PROJECT_SOURCE_DIR}/tests/run-serialization-regressionTest.sh "")
|
||||||
|
@ -141,6 +141,14 @@ add_test_compare_parallel_simulation(CASENAME aquflux_01
|
|||||||
DIR aquifers
|
DIR aquifers
|
||||||
TEST_ARGS --enable-tuning=true)
|
TEST_ARGS --enable-tuning=true)
|
||||||
|
|
||||||
|
add_test_compare_parallel_simulation(CASENAME aquflux_02
|
||||||
|
FILENAME AQUFLUX-02
|
||||||
|
SIMULATOR flow
|
||||||
|
ABS_TOL ${abs_tol}
|
||||||
|
REL_TOL ${coarse_rel_tol_parallel}
|
||||||
|
DIR aquifers
|
||||||
|
TEST_ARGS --enable-tuning=true)
|
||||||
|
|
||||||
add_test_compare_parallel_simulation(CASENAME network_balance_01
|
add_test_compare_parallel_simulation(CASENAME network_balance_01
|
||||||
FILENAME NETWORK-01
|
FILENAME NETWORK-01
|
||||||
SIMULATOR flow
|
SIMULATOR flow
|
||||||
|
@ -199,7 +199,14 @@ add_test_compareECLFiles(CASENAME aquflux_01
|
|||||||
SIMULATOR flow
|
SIMULATOR flow
|
||||||
ABS_TOL ${abs_tol}
|
ABS_TOL ${abs_tol}
|
||||||
REL_TOL ${rel_tol}
|
REL_TOL ${rel_tol}
|
||||||
DIR aquifers)
|
DIR aquifers --solver-max-time-step-in-days=1)
|
||||||
|
|
||||||
|
add_test_compareECLFiles(CASENAME aquflux_02
|
||||||
|
FILENAME AQUFLUX-02
|
||||||
|
SIMULATOR flow
|
||||||
|
ABS_TOL ${abs_tol}
|
||||||
|
REL_TOL ${rel_tol}
|
||||||
|
DIR aquifers --solver-max-time-step-in-days=1)
|
||||||
|
|
||||||
add_test_compareECLFiles(CASENAME spe3
|
add_test_compareECLFiles(CASENAME spe3
|
||||||
FILENAME SPE3CASE1
|
FILENAME SPE3CASE1
|
||||||
|
@ -56,6 +56,24 @@ add_test_compare_restarted_simulation(CASENAME numerical_aquifer_3d_2aqu
|
|||||||
DIR aquifer-num
|
DIR aquifer-num
|
||||||
TEST_ARGS --sched-restart=true --enable-tuning=true)
|
TEST_ARGS --sched-restart=true --enable-tuning=true)
|
||||||
|
|
||||||
|
add_test_compare_restarted_simulation(CASENAME aquflux_01
|
||||||
|
FILENAME AQUFLUX-01
|
||||||
|
SIMULATOR flow
|
||||||
|
ABS_TOL ${abs_tol_restart}
|
||||||
|
REL_TOL 3.0e-3
|
||||||
|
RESTART_STEP 3
|
||||||
|
DIR aquifers
|
||||||
|
TEST_ARGS --enable-tuning=true)
|
||||||
|
|
||||||
|
add_test_compare_restarted_simulation(CASENAME aquflux_02
|
||||||
|
FILENAME AQUFLUX-02
|
||||||
|
SIMULATOR flow
|
||||||
|
ABS_TOL ${abs_tol_restart}
|
||||||
|
REL_TOL ${rel_tol_restart}
|
||||||
|
RESTART_STEP 50
|
||||||
|
DIR aquifers
|
||||||
|
TEST_ARGS --enable-tuning=true)
|
||||||
|
|
||||||
# The dynamic MSW data is not written to /read from the restart file
|
# The dynamic MSW data is not written to /read from the restart file
|
||||||
# We therefore accept significant deviation in the results.
|
# We therefore accept significant deviation in the results.
|
||||||
# Note also that we use --sched-restart=true since some necessary
|
# Note also that we use --sched-restart=true since some necessary
|
||||||
|
@ -85,6 +85,7 @@ tests[fetkovich_2d]="flow aquifer-fetkovich 2D_FETKOVICHAQUIFER"
|
|||||||
tests[numerical_aquifer_3d_1aqu]="flow aquifer-num 3D_1AQU_3CELLS"
|
tests[numerical_aquifer_3d_1aqu]="flow aquifer-num 3D_1AQU_3CELLS"
|
||||||
tests[numerical_aquifer_3d_2aqu]="flow aquifer-num 3D_2AQU_NUM"
|
tests[numerical_aquifer_3d_2aqu]="flow aquifer-num 3D_2AQU_NUM"
|
||||||
tests[aquflux_01]="flow aquifers AQUFLUX-01"
|
tests[aquflux_01]="flow aquifers AQUFLUX-01"
|
||||||
|
tests[aquflux_02]="flow aquifers AQUFLUX-02"
|
||||||
tests[msw_2d_h]="flow msw_2d_h 2D_H__"
|
tests[msw_2d_h]="flow msw_2d_h 2D_H__"
|
||||||
tests[msw_3d_hfa]="flow msw_3d_hfa 3D_MSW"
|
tests[msw_3d_hfa]="flow msw_3d_hfa 3D_MSW"
|
||||||
tests[polymer_oilwater]="flow polymer_oilwater 2D_OILWATER_POLYMER"
|
tests[polymer_oilwater]="flow polymer_oilwater 2D_OILWATER_POLYMER"
|
||||||
|
Loading…
Reference in New Issue
Block a user