namespace Opm { template BlackoilAquiferModel:: BlackoilAquiferModel(Simulator& simulator) : simulator_(simulator) { init(); } template void BlackoilAquiferModel::initialSolutionApplied() { for (auto aquifer = aquifers_.begin(); aquifer != aquifers_.end(); ++aquifer) { aquifer->initialSolutionApplied(); } } template void BlackoilAquiferModel::beginEpisode() { } template void BlackoilAquiferModel::beginTimeStep() { for (auto aquifer = aquifers_.begin(); aquifer != aquifers_.end(); ++aquifer) { aquifer->beginTimeStep(); } } template void BlackoilAquiferModel::beginIteration() { } template template void BlackoilAquiferModel::addToSource(RateVector& rates, const Context& context, unsigned spaceIdx, unsigned timeIdx) const { for (auto& aquifer: aquifers_) { aquifer.addToSource(rates, context, spaceIdx, timeIdx); } } template void BlackoilAquiferModel::endIteration() { } template void BlackoilAquiferModel::endTimeStep() { for (auto aquifer = aquifers_.begin(); aquifer != aquifers_.end(); ++aquifer) { aquifer->endTimeStep(); } } template void BlackoilAquiferModel::endEpisode() { } // Initialize the aquifers in the deck template void BlackoilAquiferModel:: init() { const auto& deck = this->simulator_.vanguard().deck(); if ( !deck.hasKeyword("AQUCT") ) { return ; } //updateConnectionIntensiveQuantities(); const auto& eclState = this->simulator_.vanguard().eclState(); // Get all the carter tracy aquifer properties data and put it in aquifers vector const AquiferCT aquiferct = AquiferCT(eclState,deck); const Aquancon aquifer_connect = Aquancon(eclState.getInputGrid(), deck); std::vector aquifersData = aquiferct.getAquifers(); std::vector aquifer_connection = aquifer_connect.getAquOutput(); assert( aquifersData.size() == aquifer_connection.size() ); for (size_t i = 0; i < aquifersData.size(); ++i) { aquifers_.push_back( AquiferCarterTracy (aquifersData.at(i), aquifer_connection.at(i), this->simulator_) ); } } template bool BlackoilAquiferModel:: aquiferActive() const { return !aquifers_.empty(); } } // namespace Opm