11#ifndef QUGAR_IMPL_UNFITTED_DOMAIN_HPP
12#define QUGAR_IMPL_UNFITTED_DOMAIN_HPP
43 using FacetsStatus = std::array<ImmersedFacetStatus, static_cast<std::size_t>(dim) * 2>;
44 using GridPtr = std::shared_ptr<const CartGridTP<dim>>;
45 using FuncPtr = std::shared_ptr<const ImplicitFunc<dim>>;
47 using KDTreePtr = std::shared_ptr<UnfittedBinarySpacePart<dim>>;
60 const std::optional<std::vector<std::int64_t>> &target_cells);
Definition of Cartesian bounding box class.
Definition of Cartesian grid class.
Class representing a dim-dimensional Cartesian product bounding box.
Definition bbox.hpp:38
Definition unfitted_domain_binary_part.hpp:42
Definition unfitted_domain.hpp:51
Definition impl_unfitted_domain.hpp:40
void create_decomposition(KDTree &tree, const std::function< FuncSign(const BoundBox< dim > &)> &func_sign, const std::optional< std::vector< std::int64_t > > &target_cells)
std::array< ImmersedFacetStatus, static_cast< std::size_t >(dim) *2 > FacetsStatus
Definition impl_unfitted_domain.hpp:43
FuncPtr get_impl_func() const
std::shared_ptr< const ImplicitFunc< dim > > FuncPtr
Definition impl_unfitted_domain.hpp:45
void classify_undetermined_sign_cell(KDTree &tree)
std::shared_ptr< const CartGridTP< dim > > GridPtr
Definition impl_unfitted_domain.hpp:44
UnfittedImplDomain(const FuncPtr phi, GridPtr grid, const std::vector< std::int64_t > &cells)
FuncPtr phi_
Definition impl_unfitted_domain.hpp:56
UnfittedImplDomain(const FuncPtr phi, GridPtr grid)
std::shared_ptr< UnfittedBinarySpacePart< dim > > KDTreePtr
Definition impl_unfitted_domain.hpp:47
qugar::impl::FuncSign FuncSign
Definition impl_unfitted_domain.hpp:42
Declaration of a few implicit functions template class ready to be consumed by Algoim.
Definition affine_transf.hpp:28
FuncSign
Definition domain_function.hpp:33
Declaration of of UnfittedDomain class.
Declaration of of UnfittedDomain class.