27 #ifndef OPM_CPGRID_VANGUARD_HPP 28 #define OPM_CPGRID_VANGUARD_HPP 30 #include <opm/common/TimingMacros.hpp> 48 template <
class TypeTag>
56 using InheritsFrom = std::tuple<FlowBaseVanguard>;
61 template<
class TypeTag>
65 template<
class TypeTag>
67 using type = Dune::CpGrid;
69 template<
class TypeTag>
85 template <
class TypeTag>
88 GetPropType<TypeTag, Properties::GridView>,
89 GetPropType<TypeTag, Properties::Scalar>>
104 static constexpr
int dimensionworld = Grid::dimensionworld;
106 static constexpr
bool waterEnabled = Indices::waterEnabled;
107 static constexpr
bool gasEnabled = Indices::gasEnabled;
108 static constexpr
bool oilEnabled = Indices::oilEnabled;
110 using Element =
typename GridView::template Codim<0>::Entity;
117 this->callImplementationInit();
120 int compressedIndexForInteriorLGR(
const std::string& lgr_tag,
const Connection& conn)
const override 122 const std::array<int,3> lgr_ijk = {conn.getI(), conn.getJ(), conn.getK()};
123 const auto& lgr_level = this->
grid().getLgrNameToLevel().at(lgr_tag);
127 const auto& lgr_dim = this->
grid().currentData()[lgr_level]->logicalCartesianSize();
128 const auto lgr_cartesian_index = (lgr_ijk[2]*lgr_dim[0]*lgr_dim[1]) + (lgr_ijk[1]*lgr_dim[0]) + (lgr_ijk[0]);
136 const auto& runspec = this->
eclState().runspec();
137 const auto& config = this->
eclState().getSimulationConfig();
138 const auto& phases = runspec.phases();
141 if (config.isThermal()) {
142 if (getPropValue<TypeTag, Properties::EnergyModuleType>() != EnergyModules::FullyImplicitThermal) {
143 throw std::runtime_error(
"Input specifies energy while simulator has disabled it, try xxx_energy");
146 if (getPropValue<TypeTag, Properties::EnergyModuleType>() == EnergyModules::FullyImplicitThermal) {
147 throw std::runtime_error(
"Input specifies no energy while simulator has energy, try run without _energy");
151 if (config.isDiffusive()) {
152 if (getPropValue<TypeTag, Properties::EnableDiffusion>() ==
false) {
153 throw std::runtime_error(
"Input specifies diffusion while simulator has disabled it, try xxx_diffusion");
157 if (runspec.micp()) {
158 if (getPropValue<TypeTag, Properties::EnableBioeffects>() ==
false) {
159 throw std::runtime_error(
"Input specifies MICP while simulator has it disabled");
163 if (runspec.biof()) {
164 if (getPropValue<TypeTag, Properties::EnableBioeffects>() ==
false) {
165 throw std::runtime_error(
"Input specifies Biofilm while simulator has it disabled");
169 if (phases.active(Phase::BRINE)) {
170 if (getPropValue<TypeTag, Properties::EnableBrine>() ==
false) {
171 throw std::runtime_error(
"Input specifies Brine while simulator has it disabled");
175 if (phases.active(Phase::POLYMER)) {
176 if (getPropValue<TypeTag, Properties::EnablePolymer>() ==
false) {
177 throw std::runtime_error(
"Input specifies Polymer while simulator has it disabled");
182 if (phases.active(Phase::ZFRACTION)) {
183 if (getPropValue<TypeTag, Properties::EnableExtbo>() ==
false) {
184 throw std::runtime_error(
"Input specifies ExBo while simulator has it disabled");
187 if (phases.active(Phase::FOAM)) {
188 if (getPropValue<TypeTag, Properties::EnableFoam>() ==
false) {
189 throw std::runtime_error(
"Input specifies Foam while simulator has it disabled");
193 if (phases.active(Phase::SOLVENT)) {
194 if (getPropValue<TypeTag, Properties::EnableSolvent>() ==
false) {
195 throw std::runtime_error(
"Input specifies Solvent while simulator has it disabled");
198 if(phases.active(Phase::WATER)){
199 if(waterEnabled ==
false){
200 throw std::runtime_error(
"Input specifies water while simulator has it disabled");
203 if(phases.active(Phase::GAS)){
204 if(gasEnabled ==
false){
205 throw std::runtime_error(
"Input specifies gas while simulator has it disabled");
208 if(phases.active(Phase::OIL)){
209 if(oilEnabled ==
false){
210 throw std::runtime_error(
"Input specifies oil while simulator has it disabled");
223 globalTrans_.reset();
226 const TransmissibilityType& globalTransmissibility()
const 228 assert( globalTrans_ !=
nullptr );
229 return *globalTrans_;
240 if (
const auto& extPFile = this->externalPartitionFile();
241 !extPFile.empty() && (extPFile !=
"none"))
247 this->addCorners(), this->numOverlap(),
248 this->partitionMethod(), this->serialPartitioning(),
250 this->allow_splitting_inactive_wells_,
251 this->imbalanceTol(),
257 this->updateGridView_();
258 this->updateCartesianToCompressedMapping_();
259 this->updateCellDepths_();
260 this->updateCellThickness_();
263 this->distributeFieldProps_(this->
eclState());
274 if (
const auto& lgrs = this->
eclState().getLgrs(); lgrs.size() > 0) {
275 OpmLog::info(
"\nAdding LGRs to the grid and updating its leaf grid view");
276 this->addLgrsUpdateLeafView(lgrs, lgrs.size(), *this->grid_);
278 this->updateGridView_();
279 this->updateCellDepths_();
280 this->updateCellThickness_();
282 if (this->grid_->comm().size()>1) {
286 OpmLog::info(
"\nAdding LGRs to the global view and updating its leaf grid view");
287 this->grid_->switchToGlobalView();
288 this->addLgrsUpdateLeafView(lgrs, lgrs.size(), *this->grid_);
289 this->grid_->switchToDistributedView();
290 this->grid_->syncDistributedGlobalCellIds();
295 unsigned int gridEquilIdxToGridIdx(
unsigned int elemIndex)
const {
299 unsigned int gridIdxToEquilGridIdx(
unsigned int elemIndex)
const {
309 std::function<std::array<double,dimensionworld>(int)>
315 const std::vector<int>& globalCell()
317 return this->
grid().globalCell();
323 this->doCreateGrids_(this->edgeConformal(), this->
eclState());
326 void allocTrans()
override 328 OPM_TIMEBLOCK(allocateTrans);
329 globalTrans_.reset(
new TransmissibilityType(this->
eclState(),
334 getPropValue<TypeTag, Properties::EnergyModuleType>() == EnergyModules::FullyImplicitThermal ||
335 getPropValue<TypeTag, Properties::EnergyModuleType>() == EnergyModules::SequentialImplicitThermal,
336 getPropValue<TypeTag, Properties::EnableDiffusion>(),
337 getPropValue<TypeTag, Properties::EnableDispersion>()));
338 globalTrans_->update(
false, TransmissibilityType::TransUpdateQuantities::Trans);
341 double getTransmissibility(
unsigned I,
unsigned J)
const override 343 return globalTrans_->transmissibility(I,J);
347 const std::string& zoltanParams()
const override 349 return this->zoltanParams_;
352 double zoltanPhgEdgeSizeThreshold()
const override 354 return this->zoltanPhgEdgeSizeThreshold_;
357 const std::string& metisParams()
const override 359 return this->metisParams_;
367 std::unique_ptr<TransmissibilityType> globalTrans_;
372 #endif // OPM_CPGRID_VANGUARD_HPP const Schedule & schedule() const
Return a reference to the object that managages the ECL schedule.
Definition: FlowGenericVanguard.hpp:177
typename Properties::Detail::GetPropImpl< TypeTag, Property >::type::type GetPropType
get the type alias defined in the property (equivalent to old macro GET_PROP_TYPE(...))
Definition: propertysystem.hh:233
Dune::EdgeWeightMethod edgeWeightsMethod() const
Parameter deciding the edge-weight strategy of the load balancer.
Definition: FlowGenericVanguard.hpp:242
int numJacobiBlocks() const
Number of blocks in the Block-Jacobi preconditioner.
Definition: FlowGenericVanguard.hpp:248
const EclipseState & eclState() const
Return a reference to the internalized ECL deck.
Definition: FlowGenericVanguard.hpp:168
void checkConsistency()
Checking consistency of simulator.
Definition: CpGridVanguard.hpp:134
Definition: CpGridVanguard.hpp:55
Helper class for grid instantiation of ECL file-format using problems.
bool ownersFirst() const
Parameter that decide if cells owned by rank are ordered before ghost cells.
Definition: FlowGenericVanguard.hpp:260
const GridView & gridView() const
Returns a reference to the grid view to be used.
Definition: basevanguard.hh:70
std::optional< std::vector< std::unordered_map< std::size_t, std::size_t > > > lgrMappers_
Mapping between LGR cartesian and compressed cells.
Definition: FlowBaseVanguard.hpp:450
bool enableDistributedWells() const
Whether perforations of a well might be distributed.
Definition: FlowGenericVanguard.hpp:311
Defines the common properties required by the porous medium multi-phase models.
bool enableEclOutput() const
Whether or not to emit result files that are compatible with a commercial reservoir simulator...
Definition: FlowGenericVanguard.hpp:318
Dune::CpGrid & grid()
Return a reference to the simulation grid.
Definition: GenericCpGridVanguard.hpp:93
Definition: FlowBaseVanguard.hpp:70
Definition: GenericCpGridVanguard.hpp:79
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
std::function< std::array< double, dimensionworld >int)> cellCentroids() const
Get function to query cell centroids for a distributed grid.
Definition: CpGridVanguard.hpp:310
Declares the properties required by the black oil model.
void addLgrs()
Add LGRs and update Leaf Grid View in the simulation grid.
Definition: CpGridVanguard.hpp:270
Helper class for grid instantiation of ECL file-format using problems.
This file ensures that flow can be compiled in the presence of dune-fem.
void loadBalance()
Distribute the simulation grid over multiple processes.
Definition: CpGridVanguard.hpp:237
The type of the DUNE grid.
Definition: basicproperties.hh:104
Property which provides a Vanguard (manages grids)
Definition: basicproperties.hh:100
Helper class for grid instantiation of ECL file-format using problems.
Definition: FlowBaseVanguard.hpp:56
static void setExternalLoadBalancer(const std::function< std::vector< int >(const Dune::CpGrid &)> &loadBalancer)
Sets a function that returns external load balancing information when passed the grid.
Definition: GenericCpGridVanguard.hpp:125
const CartesianIndexMapper & cartesianIndexMapper() const
Returns the object which maps a global element index of the simulation grid to the corresponding elem...
Definition: GenericCpGridVanguard.cpp:613
Helper class for grid instantiation of ECL file-format using problems.
Definition: CpGridVanguard.hpp:49
Definition: Transmissibility.hpp:54
void releaseGlobalTransmissibilities()
Free the memory occupied by the global transmissibility object.
Definition: CpGridVanguard.hpp:221
ParallelWellStruct parallelWells_
Information about wells in parallel.
Definition: FlowGenericVanguard.hpp:431
Contains the classes required to extend the black-oil model by energy.
Definition: CollectDataOnIORank.hpp:49
Manages the initializing and running of time dependent problems.
Definition: simulator.hh:83
Definition: blackoilmodel.hh:80
std::function< std::array< double, dimensionworld >int)> cellCentroids_(const CartMapper &cartMapper, const bool &isCpGrid) const
Get function to query cell centroids for a distributed grid.
Definition: FlowBaseVanguard.hpp:305