Block-Structured AMR Software Framework
Loading...
Searching...
No Matches
AMReX_EBFabFactory.H
Go to the documentation of this file.
1#ifndef AMREX_EBFABFACTORY_H_
2#define AMREX_EBFABFACTORY_H_
3#include <AMReX_Config.H>
4
5#include <AMReX_FabFactory.H>
6
7#include <AMReX_EBData.H>
9#include <AMReX_Geometry.H>
10#include <AMReX_EBSupport.H>
11#include <AMReX_Array.H>
12#include <AMReX_MFIter.H>
13
20namespace amrex
21{
22
23namespace EB2 {
24 class Level;
25 class IndexSpace;
26}
27
31 : public FabFactory<FArrayBox>
32{
33public:
34
45 EBFArrayBoxFactory (const EB2::Level& a_level, const Geometry& a_geom,
46 const BoxArray& a_ba, const DistributionMapping& a_dm,
47 const Vector<int>& a_ngrow, EBSupport a_support);
48 ~EBFArrayBoxFactory () override = default;
49
51 EBFArrayBoxFactory (EBFArrayBoxFactory&&) noexcept = default;
52
53 EBFArrayBoxFactory () = delete;
54 EBFArrayBoxFactory& operator= (const EBFArrayBoxFactory&) = delete;
55 EBFArrayBoxFactory& operator= (EBFArrayBoxFactory&&) = delete;
56
59 FArrayBox* create (const Box& box, int ncomps, const FabInfo& info, int box_index) const final;
60
63 FArrayBox* create_alias (FArrayBox const& rhs, int scomp, int ncomp) const final;
64
66 void destroy (FArrayBox* fab) const final;
67
70 EBFArrayBoxFactory* clone () const final;
71
73 [[nodiscard]] const FabArray<EBCellFlagFab>& getMultiEBCellFlagFab () const noexcept
74 { return m_ebdc->getMultiEBCellFlagFab(); }
75
77 [[nodiscard]] const MultiFab& getLevelSet () const noexcept { return m_ebdc->getLevelSet(); }
78
80 [[nodiscard]] const MultiFab& getVolFrac () const noexcept { return m_ebdc->getVolFrac(); }
81
83 [[nodiscard]] const MultiCutFab& getCentroid () const noexcept { return m_ebdc->getCentroid(); }
84
86 [[nodiscard]] const MultiCutFab& getBndryCent () const noexcept { return m_ebdc->getBndryCent(); }
87
89 [[nodiscard]] const MultiCutFab& getBndryNormal () const noexcept { return m_ebdc->getBndryNormal(); }
90
92 [[nodiscard]] const MultiCutFab& getBndryArea () const noexcept { return m_ebdc->getBndryArea(); }
93
95 [[nodiscard]] Array<const MultiCutFab*,AMREX_SPACEDIM> getAreaFrac () const noexcept {
96 return m_ebdc->getAreaFrac();
97 }
98
102 return m_ebdc->getFaceCent();
103 }
104
107 return m_ebdc->getEdgeCent();
108 }
109
111 [[nodiscard]] bool isAllRegular () const noexcept;
112
114 [[nodiscard]] EB2::Level const* getEBLevel () const noexcept { return m_parent; }
116 [[nodiscard]] EB2::IndexSpace const* getEBIndexSpace () const noexcept;
118 [[nodiscard]] int maxCoarseningLevel () const noexcept;
119
121 [[nodiscard]] const DistributionMapping& DistributionMap () const noexcept;
123 [[nodiscard]] const BoxArray& boxArray () const noexcept;
125 [[nodiscard]] const Geometry& Geom () const noexcept { return m_geom; }
126
128 [[nodiscard]] bool hasEBInfo() const noexcept;
129
132 [[nodiscard]] iMultiFab const* getCutCellMask () const noexcept { return m_ebdc->getCutCellMask(); }
133
135 [[nodiscard]] EBData getEBData (MFIter const& mfi) const noexcept;
136
138 [[nodiscard]] EBDataArrays getEBDataArrays () const noexcept;
139
140private:
141
142 EBSupport m_support;
143 Geometry m_geom;
144 std::shared_ptr<EBDataCollection> m_ebdc;
145 EB2::Level const* m_parent = nullptr;
146 Gpu::DeviceVector<Array4<Real const>> m_eb_data;
147};
148
151std::unique_ptr<EBFArrayBoxFactory>
152makeEBFabFactory (const Geometry& a_geom,
153 const BoxArray& a_ba,
154 const DistributionMapping& a_dm,
155 const Vector<int>& a_ngrow, EBSupport a_support);
156
159std::unique_ptr<EBFArrayBoxFactory>
160makeEBFabFactory (const EB2::Level*,
161 const BoxArray& a_ba,
162 const DistributionMapping& a_dm,
163 const Vector<int>& a_ngrow, EBSupport a_support);
164
167std::unique_ptr<EBFArrayBoxFactory>
168makeEBFabFactory (const EB2::IndexSpace*, const Geometry& a_geom,
169 const BoxArray& a_ba,
170 const DistributionMapping& a_dm,
171 const Vector<int>& a_ngrow, EBSupport a_support);
172
173}
174
175#endif
#define AMREX_NODISCARD
Definition AMReX_Extension.H:252
A collection of Boxes stored in an Array.
Definition AMReX_BoxArray.H:568
Calculates the distribution of FABs to MPI processes.
Definition AMReX_DistributionMapping.H:43
Definition AMReX_EB2.H:28
Definition AMReX_EB2_Level.H:42
FAB storing EBCellFlag data per cell.
Definition AMReX_EBCellFlag.H:324
Aggregates the EB data required to build EB-aware MultiFabs/FabFactories.
Definition AMReX_EBDataCollection.H:27
Definition AMReX_EBFabFactory.H:32
const MultiCutFab & getBndryArea() const noexcept
Boundary area.
Definition AMReX_EBFabFactory.H:92
void destroy(FArrayBox *fab) const final
Destroy a FAB produced by this factory.
Definition AMReX_EBFabFactory.cpp:127
EBFArrayBoxFactory * clone() const final
Produce a deep copy of this factory (excluding EB level ownership).
Definition AMReX_EBFabFactory.cpp:142
EB2::IndexSpace const * getEBIndexSpace() const noexcept
Definition AMReX_EBFabFactory.cpp:154
EB2::Level const * getEBLevel() const noexcept
Definition AMReX_EBFabFactory.H:114
const MultiCutFab & getBndryNormal() const noexcept
Boundary normals.
Definition AMReX_EBFabFactory.H:89
const FabArray< EBCellFlagFab > & getMultiEBCellFlagFab() const noexcept
EB cell flags for all boxes.
Definition AMReX_EBFabFactory.H:73
bool isAllRegular() const noexcept
Definition AMReX_EBFabFactory.cpp:148
const BoxArray & boxArray() const noexcept
BoxArray describing the FAB layout.
Definition AMReX_EBFabFactory.cpp:177
EBData getEBData(MFIter const &mfi) const noexcept
Convenience wrapper returning EBData views for the FAB referenced by mfi.
Definition AMReX_EBFabFactory.cpp:189
iMultiFab const * getCutCellMask() const noexcept
Definition AMReX_EBFabFactory.H:132
int maxCoarseningLevel() const noexcept
Maximum coarse level supported by the EB hierarchy.
Definition AMReX_EBFabFactory.cpp:160
const DistributionMapping & DistributionMap() const noexcept
Distribution mapping describing the FABs this factory allocates.
Definition AMReX_EBFabFactory.cpp:171
FArrayBox * create_alias(FArrayBox const &rhs, int scomp, int ncomp) const final
Create an alias view into an existing EB-aware FAB.
Definition AMReX_EBFabFactory.cpp:113
const MultiCutFab & getCentroid() const noexcept
Cell centroid.
Definition AMReX_EBFabFactory.H:83
Array< const MultiCutFab *, 3 > getEdgeCent() const noexcept
Edge centroids.
Definition AMReX_EBFabFactory.H:106
const MultiCutFab & getBndryCent() const noexcept
Boundary centroid.
Definition AMReX_EBFabFactory.H:86
EBFArrayBoxFactory(EBFArrayBoxFactory &&) noexcept=default
Array< const MultiCutFab *, 3 > getAreaFrac() const noexcept
Area fractions along each axis.
Definition AMReX_EBFabFactory.H:95
Array< const MultiCutFab *, 3 > getFaceCent() const noexcept
Definition AMReX_EBFabFactory.H:101
bool hasEBInfo() const noexcept
True if EB geometric data beyond flags is available.
Definition AMReX_EBFabFactory.cpp:183
~EBFArrayBoxFactory() override=default
const MultiFab & getLevelSet() const noexcept
Level set field.
Definition AMReX_EBFabFactory.H:77
const MultiFab & getVolFrac() const noexcept
Volume fraction.
Definition AMReX_EBFabFactory.H:80
const Geometry & Geom() const noexcept
Geometry inherited from the EB level.
Definition AMReX_EBFabFactory.H:125
FArrayBox * create(const Box &box, int ncomps, const FabInfo &info, int box_index) const final
Allocate an EB-aware FAB for box with ncomps components.
Definition AMReX_EBFabFactory.cpp:97
EBDataArrays getEBDataArrays() const noexcept
Return GPU-accessible array views for all FABs owned by this factory.
Definition AMReX_EBFabFactory.cpp:202
EBFArrayBoxFactory(const EBFArrayBoxFactory &)=default
A Fortran Array of REALs.
Definition AMReX_FArrayBox.H:231
An Array of FortranArrayBox(FAB)-like Objects.
Definition AMReX_FabArray.H:350
Definition AMReX_FabFactory.H:50
Rectangular problem domain geometry.
Definition AMReX_Geometry.H:74
Iterator for looping ever tiles and boxes of amrex::FabArray based containers.
Definition AMReX_MFIter.H:88
FabArray façade that only allocates cut-cell Fabs (skipping regular cells).
Definition AMReX_MultiCutFab.H:87
A collection (stored as an array) of FArrayBox objects.
Definition AMReX_MultiFab.H:40
This class is a thin wrapper around std::vector. Unlike vector, Vector::operator[] provides bound che...
Definition AMReX_Vector.H:28
A Collection of IArrayBoxes.
Definition AMReX_iMultiFab.H:34
amrex_real Real
Floating Point Type for Fields.
Definition AMReX_REAL.H:79
std::unique_ptr< EBFArrayBoxFactory > makeEBFabFactory(const Geometry &a_geom, const BoxArray &a_ba, const DistributionMapping &a_dm, const Vector< int > &a_ngrow, EBSupport a_support)
Definition AMReX_EBFabFactory.cpp:215
std::array< T, N > Array
Definition AMReX_Array.H:26
Definition AMReX_Amr.cpp:49
EBSupport
Requested EB metadata level for factories and utilities.
Definition AMReX_EBSupport.H:14
A multidimensional array accessor.
Definition AMReX_Array4.H:283
Views aggregating EBData for multiple boxes.
Definition AMReX_EBData.H:207
Set of Array4 views to EB data for a single box (plus helpers).
Definition AMReX_EBData.H:34
Definition AMReX_FabFactory.H:27