16 #include <GeometryShop.H>
17 #include <GeometryService.H>
22 #include <CD_NamespaceHeader.H>
49 const int a_verbosity,
50 const Real a_finestDx,
51 const RealVect a_probLo,
52 const ProblemDomain a_finestDomain,
53 const ProblemDomain a_scanLevel,
54 const int a_ebGhost = 4,
55 const Real a_thrshdVoF = 1.0e-16);
78 DisjointBoxLayout& a_grids,
79 const int& a_maxGridSize,
80 const int& a_maxIrregGridSize)
override;
92 GeometryService::InOut
94 const ProblemDomain& a_domain,
95 const RealVect& a_probLo,
97 const DataIndex& a_dit)
const override;
112 fillGraph(BaseFab<int>& a_regIrregCovered,
113 Vector<IrregNode>& a_nodes,
114 const Box& a_validRegion,
115 const Box& a_ghostRegion,
116 const ProblemDomain& a_domain,
117 const RealVect& a_probLo,
119 const DataIndex& a_di)
const override;
186 Vector<RefCountedPtr<LayoutData<GeometryService::InOut>>>
m_boxMap;
202 const RealVect a_probLo,
203 const ProblemDomain a_finestDomain,
204 const ProblemDomain a_scanLevel);
231 isRegular(
const Box a_box,
const RealVect a_probLo,
const Real a_dx)
const;
240 isCovered(
const Box a_box,
const RealVect a_probLo,
const Real a_dx)
const;
246 inline std::vector<std::pair<Box, int>>
253 defineLevel(Vector<Box>& coveredBoxes, Vector<Box>& regularBoxes, Vector<Box>& cutCellBoxes,
const int a_level);
256 #include <CD_NamespaceFooter.H>
258 #include <CD_ScanShopImplem.H>
Declaration of an enum for identifying various ways of sorting grid patches.
BoxSorting
Enum for sorting boxes.
Definition: CD_BoxSorting.H:21
Implementation of CD_Timer.H.
Derived version of GeometryShop that load balances based on the cut cells themselves.
Definition: CD_ScanShop.H:30
void makeDomains(const Real a_dx, const RealVect a_probLo, const ProblemDomain a_finestDomain, const ProblemDomain a_scanLevel)
Create the problem domain and resolutions.
Definition: CD_ScanShop.cpp:90
bool isCovered(const Box a_box, const RealVect a_probLo, const Real a_dx) const
Check if every point in box is covered.
Definition: CD_ScanShopImplem.H:39
Vector< RefCountedPtr< LayoutData< GeometryService::InOut > > > m_boxMap
Box maps.
Definition: CD_ScanShop.H:186
Vector< Real > m_dx
Level resolutions. Note that index 0 is the finest level.
Definition: CD_ScanShop.H:170
void buildCoarseLevel(const int a_finerLevel, const int a_maxGridSize)
Build the "coarse level" where we initiate the recursion process.
Definition: CD_ScanShop.cpp:194
void buildFinerLevels(const int a_coarserLevel, const int a_maxGridSize)
Refine levels recursively down to the finest level.
Definition: CD_ScanShop.cpp:269
std::string m_fileName
Set output file name (if doing profiling)
Definition: CD_ScanShop.H:125
int m_scanLevel
Scan level where we first begin to break up boxes. This is relative the EBIS level.
Definition: CD_ScanShop.H:145
int m_ebGhost
Maximum number of ghost cells near the EB.
Definition: CD_ScanShop.H:150
BoxSorting m_boxSorting
For arranging boxes in space when we load balance.
Definition: CD_ScanShop.H:130
~ScanShop()
Destructor (does nothing)
Definition: CD_ScanShop.cpp:71
void makeGrids(const ProblemDomain &a_domain, DisjointBoxLayout &a_grids, const int &a_maxGridSize, const int &a_maxIrregGridSize) override
This grid generation method is called by EBISLevel when using distributed data.
Definition: CD_ScanShop.cpp:133
Vector< DisjointBoxLayout > m_grids
Grids on each level, used for generating the EBIS information.
Definition: CD_ScanShop.H:180
void setProfileFileName(const std::string a_fileName)
If doing profiling, set the output name.
Definition: CD_ScanShop.cpp:82
bool m_profile
Bool for run-time profiling of ScanShop.
Definition: CD_ScanShop.H:140
std::vector< std::pair< Box, int > > getSortedBoxesAndTypes(const Vector< Box > &a_boxes, const Vector< int > &a_types) const
Sort boxes lexicographically.
Definition: CD_ScanShopImplem.H:58
RealVect m_probLo
Lower-left corner of simulation domain.
Definition: CD_ScanShop.H:155
const BaseIF * m_baseIF
Implicit function used to generate geometrys.
Definition: CD_ScanShop.H:160
Timer m_timer
Timer for when we use run-time profiling.
Definition: CD_ScanShop.H:135
void defineLevel(Vector< Box > &coveredBoxes, Vector< Box > ®ularBoxes, Vector< Box > &cutCellBoxes, const int a_level)
Define the "box map" on a specified level.
Definition: CD_ScanShop.cpp:358
GeometryService::InOut InsideOutside(const Box &a_region, const ProblemDomain &a_domain, const RealVect &a_probLo, const Real &a_dx, const DataIndex &a_dit) const override
This method is called by EBSILevel when using distributed data.
Definition: CD_ScanShop.cpp:488
ScanShop()=delete
Disallowed default constructor.
std::vector< bool > m_hasThisLevel
Check if level has been scanned. 0 = false, != 0 implies true.
Definition: CD_ScanShop.H:191
bool isRegular(const Box a_box, const RealVect a_probLo, const Real a_dx) const
Check if every point in input box is regular.
Definition: CD_ScanShopImplem.H:20
bool m_hasScanLevel
Check if scan level has been built.
Definition: CD_ScanShop.H:165
Vector< ProblemDomain > m_domains
Level domains. Note that index 0 is the finest level.
Definition: CD_ScanShop.H:175
virtual void fillGraph(BaseFab< int > &a_regIrregCovered, Vector< IrregNode > &a_nodes, const Box &a_validRegion, const Box &a_ghostRegion, const ProblemDomain &a_domain, const RealVect &a_probLo, const Real &a_dx, const DataIndex &a_di) const override
Override of GeometryShop's fillGraph.
Definition: CD_ScanShop.cpp:531
Class which is used for run-time monitoring of events.
Definition: CD_Timer.H:31