16 #include <deal.II/base/memory_consumption.h> 18 #include <deal.II/grid/magic_numbers.h> 19 #include <deal.II/grid/persistent_tria.h> 23 DEAL_II_NAMESPACE_OPEN
26 template <
int dim,
int spacedim>
29 template <
int dim,
int spacedim>
33 template <
int dim,
int spacedim>
36 : coarse_grid(&coarse_grid, typeid(*this).name())
41 template <
int dim,
int spacedim>
57 template <
int dim,
int spacedim>
76 template <
int dim,
int spacedim>
82 for (
unsigned int i = 0; i <
refine_flags.size() + 1; ++i)
88 template <
int dim,
int spacedim>
114 template <
int dim,
int spacedim>
123 template <
int dim,
int spacedim>
136 template <
int dim,
int spacedim>
148 template <
int dim,
int spacedim>
160 template <
int dim,
int spacedim>
168 out << mn_persistent_tria_flags_begin <<
' ' << n_flag_levels << std::endl;
170 for (
unsigned int i = 0; i < n_flag_levels; ++i)
174 mn_tria_refine_flags_end,
178 mn_tria_coarsen_flags_end,
182 out << mn_persistent_tria_flags_end << std::endl;
189 template <
int dim,
int spacedim>
197 unsigned int magic_number;
199 AssertThrow(magic_number == mn_persistent_tria_flags_begin,
202 unsigned int n_flag_levels;
204 for (
unsigned int i = 0; i < n_flag_levels; ++i)
210 mn_tria_refine_flags_end,
214 mn_tria_coarsen_flags_end,
219 AssertThrow(magic_number == mn_persistent_tria_flags_end,
227 template <
int dim,
int spacedim>
237 template <
int dim,
int spacedim>
255 DEAL_II_NAMESPACE_CLOSE
virtual void copy_triangulation(const Triangulation< dim, spacedim > &other_tria)
unsigned int n_refinement_steps() const
static::ExceptionBase & ExcIO()
virtual void write_flags(std::ostream &out) const
static void read_bool_vector(const unsigned int magic_number1, std::vector< bool > &v, const unsigned int magic_number2, std::istream &in)
virtual void clear_flags()
virtual void create_triangulation(const std::vector< Point< spacedim >> &vertices, const std::vector< CellData< dim >> &cells, const SubCellData &subcelldata) override
#define AssertThrow(cond, exc)
static void write_bool_vector(const unsigned int magic_number1, const std::vector< bool > &v, const unsigned int magic_number2, std::ostream &out)
virtual void execute_coarsening_and_refinement() override
static::ExceptionBase & ExcFlagsNotCleared()
SmartPointer< const Triangulation< dim, spacedim >, PersistentTriangulation< dim, spacedim > > coarse_grid
unsigned int n_levels() const
virtual std::size_t memory_consumption() const override
void load_coarsen_flags(std::istream &out)
std::vector< std::vector< bool > > refine_flags
virtual void execute_coarsening_and_refinement()
void save_coarsen_flags(std::ostream &out) const
static::ExceptionBase & ExcImpossibleInDim(int arg1)
#define Assert(cond, exc)
static::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
virtual void copy_triangulation(const Triangulation< dim, spacedim > &tria) override
virtual void create_triangulation_compatibility(const std::vector< Point< spacedim >> &vertices, const std::vector< CellData< dim >> &cells, const SubCellData &subcelldata) override
void save_refine_flags(std::ostream &out) const
PersistentTriangulation(const Triangulation< dim, spacedim > &coarse_grid)
static::ExceptionBase & ExcTriaNotEmpty()
virtual void read_flags(std::istream &in)
std::vector< std::vector< bool > > coarsen_flags
std::enable_if< std::is_fundamental< T >::value, std::size_t >::type memory_consumption(const T &t)
void load_refine_flags(std::istream &in)