#include <AMR.H>
This class is a framework for Berger-Oliger timestepping for adaptive mesh refinement of time-dependent problems. It is applicable to both hyperbolic and parabolic problems. It represents a hierarchy of levels of refinement as a collection of AMRLevel objects.
The usage pattern is this:
Public Member Functions | |
AMR () | |
~AMR () | |
void | define (int a_max_level, const Vector< int > &a_ref_ratios, const Box &a_prob_domain, const AMRLevelFactory *const a_amrLevelFact) |
void | define (int a_max_level, const Vector< int > &a_ref_ratios, const ProblemDomain &a_prob_domain, const AMRLevelFactory *const a_amrLevelFact) |
bool | isDefined () const |
bool | isSetUp () const |
void | setupForNewAMRRun () |
void | setupForFixedHierarchyRun (const Vector< Vector< Box > > &a_amr_grids, int a_proper_nest=1) |
void | conclude () const |
void | run (Real a_max_time, int a_max_step) |
void | plotPrefix (const std::string &a_plotfile_prefix) |
void | checkpointPrefix (const std::string &a_checkpointfile_prefix) |
void | plotInterval (int a_plot_interval) |
void | checkpointInterval (int a_checkpoint_interval) |
void | maxGridSize (int a_max_grid_size) |
void | maxBaseGridSize (int a_max_base_grid_size) |
void | dtToleranceFactor (Real a_dt_tolerance_factor) |
void | fillRatio (Real a_fillRat) |
void | blockFactor (int a_blockFactor) |
void | gridBufferSize (int a_grid_buffer_size) |
int | maxGridSize () const |
int | maxBaseGridSize () const |
void | verbosity (int a_verbosity) |
void | regridIntervals (const Vector< int > &a_regridIntervals) |
int | verbosity () const |
void | maxDtGrow (Real a_dtGrowFactor) |
void | timeEps (Real a_timeEps) |
Real | maxDtGrow () const |
Real | timeEps () const |
void | fixedDt (Real a_dt) |
Real | fixedDt () const |
Vector< AMRLevel * > | getAMRLevels () |
void | initialTime (Real a_initialTime) |
Real | getCurrentTime () const |
void | useSubcyclingInTime (bool a_useSubcycling) |
Protected Member Functions | |
int | timeStep (int a_level, int a_stepsLeft, bool a_coarseTimeBoundary) |
void | clearMemory () |
void | regrid (int a_base_level) |
void | initialGrid () |
void | writePlotFile () const |
void | writeCheckpointFile () const |
void | assignDt () |
bool | needToRegrid (int a_level, int a_numStepsLeft) const |
void | makeBaseLevelMesh (Vector< Box > &a_grids) const |
void | setDefaultValues () |
Protected Attributes | |
bool | m_useSubcycling |
int | m_blockFactor |
Real | m_fillRatio |
int | m_max_level |
int | m_finest_level_old |
int | m_finest_level |
int | m_checkpoint_interval |
int | m_plot_interval |
int | m_max_grid_size |
int | m_max_base_grid_size |
Real | m_dt_tolerance_factor |
Real | m_fixedDt |
bool | m_isDefined |
bool | m_isSetUp |
Vector< AMRLevel * > | m_amrlevels |
Vector< int > | m_ref_ratios |
Vector< int > | m_reduction_factor |
Vector< int > | m_regrid_intervals |
Real | m_dt_base |
Vector< Real > | m_dt_new |
Vector< Real > | m_dt_cur |
Real | m_maxDtGrow |
Real | m_time_eps |
BRMeshRefine | m_mesh_refine |
bool | m_use_meshrefine |
Vector< Vector< Box > > | m_amr_grids |
int | m_cur_step |
int | m_restart_step |
int | m_lastcheck_step |
Real | m_cur_time |
Vector< int > | m_steps_since_regrid |
Vector< long long > | m_cell_updates |
std::string | m_plotfile_prefix |
std::string | m_checkpointfile_prefix |
int | m_verbosity |
AMR::AMR | ( | ) |
Default constructor. Use must subsequently call a define() function and a setUp function.
AMR::~AMR | ( | ) |
Destructor.
void AMR::define | ( | int | a_max_level, | |
const Vector< int > & | a_ref_ratios, | |||
const Box & | a_prob_domain, | |||
const AMRLevelFactory *const | a_amrLevelFact | |||
) |
Defines this object. User must call a setup function before running. Arguments:
void AMR::define | ( | int | a_max_level, | |
const Vector< int > & | a_ref_ratios, | |||
const ProblemDomain & | a_prob_domain, | |||
const AMRLevelFactory *const | a_amrLevelFact | |||
) |
Defines this object. User must call a setup function before running. Arguments:
bool AMR::isDefined | ( | ) | const |
Has a define function been called? Lots of these functions will assert fail if not.
bool AMR::isSetUp | ( | ) | const |
Has a setUp function been called? If not, you can't call run
void AMR::setupForNewAMRRun | ( | ) |
Sets up this object for cold start. User must have previously called define(). Need to call this or setupForRestart or setupforFixedHierarchyRun before you run.
void AMR::setupForFixedHierarchyRun | ( | const Vector< Vector< Box > > & | a_amr_grids, | |
int | a_proper_nest = 1 | |||
) |
This sets the hierarchy and sets regrid_intervals to -1 (turns off regridding). If you want to keep regridding on, reset regridIntervals after this call;
void AMR::conclude | ( | ) | const |
You should call this last. It writes the last checkpoint file and tells you how many cells you updated and all that.
void AMR::run | ( | Real | a_max_time, | |
int | a_max_step | |||
) |
Runs the calculation. User must have previously called both the define function and a setup function.
void AMR::plotPrefix | ( | const std::string & | a_plotfile_prefix | ) |
Sets the plot file prefix. Should be called after define and before setup.
void AMR::checkpointPrefix | ( | const std::string & | a_checkpointfile_prefix | ) |
Sets the checkpoint file prefix. Should be called after define and before setup.
void AMR::plotInterval | ( | int | a_plot_interval | ) |
Sets the interval to write plot files, in terms of the base level time step.
void AMR::checkpointInterval | ( | int | a_checkpoint_interval | ) |
Sets the interval to write checkpoint files, in terms of the base level time step.
void AMR::maxGridSize | ( | int | a_max_grid_size | ) |
Set the maximum grid size. Should be called after define and before setup.
void AMR::maxBaseGridSize | ( | int | a_max_base_grid_size | ) |
Set the maximum grid size for level 0 grids. Defaults to maxGridSize, so should be called after maxGridSize and before setup
void AMR::dtToleranceFactor | ( | Real | a_dt_tolerance_factor | ) |
Set the factor by which the current dt must exceed the new (max) dt for time subcycling to occur (i.e., reduction of the current dt by powers of 2).
void AMR::fillRatio | ( | Real | a_fillRat | ) |
Set the fill ratio for meshrefinement. Should be called after define and before setup.
void AMR::blockFactor | ( | int | a_blockFactor | ) |
Set the blocking factor for meshrefinement. Should be called after define and before setup.
void AMR::gridBufferSize | ( | int | a_grid_buffer_size | ) |
Set the buffering for the meshrefinement. Should be called after define and before setup.
int AMR::maxGridSize | ( | ) | const |
Returns the maximum grid size.
int AMR::maxBaseGridSize | ( | ) | const |
Returns the maximum grid size for level 0 grids.
void AMR::verbosity | ( | int | a_verbosity | ) |
Sets verbosity level to a_verbosity.
-inf to 0: print nothing.
1: prints a message every coarse time step.
2: also prints a message when regridding and writing files.
3: also prints function trace, and some more inf during file I/O.
4 to inf: also prints list of boxes and processor maps during regrid.
This should be OK to call any time after define and before run.
void AMR::regridIntervals | ( | const Vector< int > & | a_regridIntervals | ) |
Sets the regridding intervals. This should be OK to call any time after define and before run.
int AMR::verbosity | ( | ) | const |
Returns current verbosity level.
-inf to 0: print nothing.
1: prints a message every coarse time step.
2: also prints a message when regridding and writing files.
3: also prints function trace, and some more inf during file I/O.
4 to inf: also prints list of boxes and processor maps during regrid.
void AMR::maxDtGrow | ( | Real | a_dtGrowFactor | ) |
Set maximum factor by which a timestep can grow.
void AMR::timeEps | ( | Real | a_timeEps | ) |
Set amount by which two times may differ and still be considered equal (used to determine whether we've reached stop time yet) In practice, this is multiplied by the current base-level timestep, so we consider ourselves finished if (stopTime - time) < timeEps*dt0
Real AMR::maxDtGrow | ( | ) | const |
Returns current maximum factor by which a timestep can grow.
Real AMR::timeEps | ( | ) | const |
Returns amount by which two times may differ and still be considered equal (used to determine whether we've reached stop time yet)
void AMR::fixedDt | ( | Real | a_dt | ) |
Set a fixed timestep.
Real AMR::fixedDt | ( | ) | const |
Returns the fixed timestep.
void AMR::initialTime | ( | Real | a_initialTime | ) |
Sets the initial time before starting compututation; this must be called before calling setupForFixedHierarchyRun or setupForNewAMRRun. Note that this will be over-ridden by the checkpointfile value if restarting using setupForRestart.
Real AMR::getCurrentTime | ( | ) | const |
Returns the current time
void AMR::useSubcyclingInTime | ( | bool | a_useSubcycling | ) |
Turn subcycling in time off or on. Default is true (use cyclingling).
int AMR::timeStep | ( | int | a_level, | |
int | a_stepsLeft, | |||
bool | a_coarseTimeBoundary | |||
) | [protected] |
void AMR::clearMemory | ( | ) | [protected] |
void AMR::regrid | ( | int | a_base_level | ) | [protected] |
void AMR::initialGrid | ( | ) | [protected] |
void AMR::writePlotFile | ( | ) | const [protected] |
void AMR::writeCheckpointFile | ( | ) | const [protected] |
void AMR::assignDt | ( | ) | [protected] |
bool AMR::needToRegrid | ( | int | a_level, | |
int | a_numStepsLeft | |||
) | const [protected] |
void AMR::setDefaultValues | ( | ) | [protected] |
bool AMR::m_useSubcycling [protected] |
int AMR::m_blockFactor [protected] |
Real AMR::m_fillRatio [protected] |
int AMR::m_max_level [protected] |
int AMR::m_finest_level_old [protected] |
int AMR::m_finest_level [protected] |
int AMR::m_checkpoint_interval [protected] |
int AMR::m_plot_interval [protected] |
int AMR::m_max_grid_size [protected] |
int AMR::m_max_base_grid_size [protected] |
Real AMR::m_dt_tolerance_factor [protected] |
Real AMR::m_fixedDt [protected] |
bool AMR::m_isDefined [protected] |
bool AMR::m_isSetUp [protected] |
Vector<AMRLevel*> AMR::m_amrlevels [protected] |
Vector<int> AMR::m_ref_ratios [protected] |
Vector<int> AMR::m_reduction_factor [protected] |
Vector<int> AMR::m_regrid_intervals [protected] |
Real AMR::m_dt_base [protected] |
Vector<Real> AMR::m_dt_new [protected] |
Vector<Real> AMR::m_dt_cur [protected] |
Real AMR::m_maxDtGrow [protected] |
Real AMR::m_time_eps [protected] |
BRMeshRefine AMR::m_mesh_refine [protected] |
bool AMR::m_use_meshrefine [protected] |
Vector<Vector<Box> > AMR::m_amr_grids [protected] |
int AMR::m_cur_step [protected] |
int AMR::m_restart_step [protected] |
int AMR::m_lastcheck_step [protected] |
Real AMR::m_cur_time [protected] |
Vector<int> AMR::m_steps_since_regrid [protected] |
Vector<long long> AMR::m_cell_updates [protected] |
std::string AMR::m_plotfile_prefix [protected] |
std::string AMR::m_checkpointfile_prefix [protected] |
int AMR::m_verbosity [protected] |