IBAMR  IBAMR version 0.19.
Classes | Namespaces | Functions
LevelSetUtilities.h File Reference
#include <ibamr/config.h>
#include "ibamr/AdvDiffHierarchyIntegrator.h"
#include "ibamr/LSInitStrategy.h"
#include "CellVariable.h"
#include "tbox/DescribedClass.h"
#include "tbox/Pointer.h"
#include "tbox/Serializable.h"
#include <limits>
#include <string>

Classes

class  IBAMR::LevelSetUtilities::LevelSetContainer
 A lightweight class to hold the level set variable and the associated hierarchy integrator (AdvDiffHierarchyIntegrator). More...
 
class  IBAMR::LevelSetUtilities::TagLSRefinementCells
 A lightweight class to tag grid cells containing the level set variable for grid refinement. More...
 
class  IBAMR::LevelSetUtilities::LevelSetMassLossFixer
 A lightweight class that stores the current value of the Lagrange multiplier for the level set variable. More...
 
class  IBAMR::LevelSetUtilities::SetLSProperties
 Class SetLSProperties is a utility class which sets (or resets after reinitialization) level set values on the patch hierarchy. More...
 

Namespaces

 IBTK
 
 IBAMR
 
 IBAMR::LevelSetUtilities
 Class LevelSetUtilities provides implementation of some helper functions to enforce mass/volume conservation of phases.
 

Functions

void IBAMR::LevelSetUtilities::tagLSCells (SAMRAI::tbox::Pointer< SAMRAI::hier::BasePatchHierarchy< NDIM > > hierarchy, const int level_number, const double error_data_time, const int tag_index, const bool initial_time, const bool uses_richardson_extrapolation_too, void *ctx)
 Preprocessing call back function to be hooked into IBAMR::HierarchyIntegrator class to tag the cells for grid refinement based on the given tagging criteria. More...
 
void IBAMR::LevelSetUtilities::fixMassLoss2PhaseFlows (double current_time, double new_time, bool skip_synchronize_new_state_data, int num_cycles, void *ctx)
 Compute the value of the Lagrange multiplier \( q \) and use that to adjust the flow level set variable \( \tilde{\phi} \) to satisfy the constraint: \( f(q) = \int_{\Omega} H(\tilde{\phi} + q) \text{d}\Omega - V^0 = 0 \). where, \( \tilde{\phi} \) is the level set field obtained from the reinitialization procedure, \( V^0 \) is the volume of the fluid at \( t = 0 \) s which needs to be conserved. Here, \( q \) is computed using the Newton's method till required tolerance. In practice the level set mass loss would be fixed during the postprocess integrate hierarchy stage. Hence the application time would be the new time and the variable context would be the new context. More...
 
void IBAMR::LevelSetUtilities::fixMassLoss3PhaseFlows (double current_time, double new_time, bool skip_synchronize_new_state_data, int num_cycles, void *ctx)
 Compute the value of the Lagrange multiplier \( q \) and use that to adjust the flow level set \( \tilde{\phi \) when there is a solid phase in the domain with level set \( \psi < 0 \). Satisfies the constraint: \( f(q) = \int_{\Omega} H(\tilde{\phi} + q) H(\psi) \text{d}\Omega - V^0 = 0 \). where, \( \tilde{\phi} \) is the level set field obtained from the reinitialization procedure, \( V^0 \) is the volume of the fluid at \( t = 0 \) s which needs to be conserved. Here, \( q \) is computed using the Newton's method till required tolerance. In practice the level set mass loss would be fixed during the postprocess integrate hierarchy stage. Hence the application time would be the new time and the variable context would be the new context. More...
 
std::vector< doubleIBAMR::LevelSetUtilities::computeHeavisideIntegrals2PhaseFlows (const LevelSetContainer &lsc)
 
std::vector< doubleIBAMR::LevelSetUtilities::computeHeavisideIntegrals3PhaseFlows (const LevelSetContainer &lsc)
 
void IBAMR::LevelSetUtilities::setLSDataPatchHierarchy (int ls_idx, SAMRAI::tbox::Pointer< IBTK::HierarchyMathOps > hier_math_ops, const int integrator_step, const double current_time, const bool initial_time, const bool regrid_time, void *ctx)
 A function that sets or resets the level set data on the patch hierarchy. More...