16#include <GeometryShop.H>
17#include <GeometryService.H>
22#include <CD_NamespaceHeader.H>
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:93
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:197
void buildFinerLevels(const int a_coarserLevel, const int a_maxGridSize)
Refine levels recursively down to the finest level.
Definition CD_ScanShop.cpp:272
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:74
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:136
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:85
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:361
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:491
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:534
Class which is used for run-time monitoring of events.
Definition CD_Timer.H:31
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:37
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:25