/* Copyright 2017 TNO - Heat Transfer & Fluid Dynamics, Modelling & Optimization of the Subsurface Copyright 2017 Statoil ASA. 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 . */ #include namespace Opm { template BlackoilAquiferModel::BlackoilAquiferModel(Simulator& simulator) : simulator_(simulator) { init(); } template void BlackoilAquiferModel::initialSolutionApplied() { if (aquiferCarterTracyActive()) { for (auto& aquifer : aquifers_CarterTracy) { aquifer.initialSolutionApplied(); } } if (aquiferFetkovichActive()) { for (auto& aquifer : aquifers_Fetkovich) { aquifer.initialSolutionApplied(); } } } template void BlackoilAquiferModel::initFromRestart(const std::vector& aquiferSoln) { if (aquiferCarterTracyActive()) { for (auto& aquifer : aquifers_CarterTracy) { aquifer.initFromRestart(aquiferSoln); } } if (aquiferFetkovichActive()) { for (auto& aquifer : aquifers_Fetkovich) { aquifer.initFromRestart(aquiferSoln); } } } template void BlackoilAquiferModel::beginEpisode() { } template void BlackoilAquiferModel::beginIteration() { } template void BlackoilAquiferModel::beginTimeStep() { if (aquiferCarterTracyActive()) { for (auto& aquifer : aquifers_CarterTracy) { aquifer.beginTimeStep(); } } if (aquiferFetkovichActive()) { for (auto& aquifer : aquifers_Fetkovich) { aquifer.beginTimeStep(); } } } template template void BlackoilAquiferModel::addToSource(RateVector& rates, const Context& context, unsigned spaceIdx, unsigned timeIdx) const { if (aquiferCarterTracyActive()) { for (auto& aquifer : aquifers_CarterTracy) { aquifer.addToSource(rates, context, spaceIdx, timeIdx); } } if (aquiferFetkovichActive()) { for (auto& aquifer : aquifers_Fetkovich) { aquifer.addToSource(rates, context, spaceIdx, timeIdx); } } } template void BlackoilAquiferModel::endIteration() { } template void BlackoilAquiferModel::endTimeStep() { if (aquiferCarterTracyActive()) { for (auto& aquifer : aquifers_CarterTracy) { aquifer.endTimeStep(); } } if (aquiferFetkovichActive()) { for (auto& aquifer : aquifers_Fetkovich) { aquifer.endTimeStep(); } } } template void BlackoilAquiferModel::endEpisode() { } template template void BlackoilAquiferModel::serialize(Restarter& /* res */) { // TODO (?) throw std::logic_error("BlackoilAquiferModel::serialize() is not yet implemented"); } template template void BlackoilAquiferModel::deserialize(Restarter& /* res */) { // TODO (?) throw std::logic_error("BlackoilAquiferModel::deserialize() is not yet implemented"); } // Initialize the aquifers in the deck template void BlackoilAquiferModel::init() { const auto& aquifer = this->simulator_.vanguard().eclState().aquifer(); if (!aquifer.active()) { return; } const auto& comm = this->simulator_.vanguard().gridView().comm(); if (comm.size() > 1) throw std::runtime_error("Aquifers currently do not work in parallel."); // Get all the carter tracy aquifer properties data and put it in aquifers vector const auto& ugrid = simulator_.vanguard().grid(); const int number_of_cells = simulator_.gridView().size(0); cartesian_to_compressed_ = cartesianToCompressed(number_of_cells, Opm::UgGridHelpers::globalCell(ugrid)); const auto& connections = aquifer.connections(); for (const auto& aq : aquifer.ct()) { aquifers_CarterTracy.emplace_back(connections[aq.aquiferID], cartesian_to_compressed_, this->simulator_, aq); } for (const auto& aq : aquifer.fetp()) { aquifers_Fetkovich.emplace_back(connections[aq.aquiferID], cartesian_to_compressed_, this->simulator_, aq); } } template bool BlackoilAquiferModel::aquiferActive() const { return (aquiferCarterTracyActive() || aquiferFetkovichActive()); } template bool BlackoilAquiferModel::aquiferCarterTracyActive() const { return !aquifers_CarterTracy.empty(); } template bool BlackoilAquiferModel::aquiferFetkovichActive() const { return !aquifers_Fetkovich.empty(); } } // namespace Opm