31 #include <boost/serialization/map.hpp> 32 #include <boost/serialization/split_member.hpp> 33 #include <boost/serialization/unique_ptr.hpp> 34 #include <boost/serialization/vector.hpp> 35 #include <boost/signals2.hpp> 50 template <
int dim,
int spacedim>
66 template <
typename CellIterator>
67 struct PeriodicFacePair;
70 template <
int,
int,
int>
72 template <
int spacedim>
74 template <
int,
int,
int>
79 namespace TriangulationImplementation
94 struct Implementation;
97 namespace TriaAccessorImplementation
99 struct Implementation;
105 template <
int dim,
int spacedim>
120 namespace TriangulationImplementation
196 template <
class Archive>
198 serialize(Archive &ar,
const unsigned int version);
255 template <
class Archive>
257 serialize(Archive &ar,
const unsigned int version);
315 template <
class Archive>
317 serialize(Archive &ar,
const unsigned int version);
1108 template <
int dim,
int spacedim = dim>
1174 limit_level_difference_at_vertices = 0x1,
1195 eliminate_unrefined_islands = 0x2,
1211 patch_level_1 = 0x4,
1235 coarsest_level_1 = 0x8,
1260 allow_anisotropic_smoothing = 0x10,
1293 eliminate_refined_inner_islands = 0x100,
1298 eliminate_refined_boundary_islands = 0x200,
1304 do_not_produce_unrefined_islands = 0x400,
1310 smoothing_on_refinement =
1311 (limit_level_difference_at_vertices | eliminate_unrefined_islands),
1316 smoothing_on_coarsening =
1317 (eliminate_refined_inner_islands | eliminate_refined_boundary_islands |
1318 do_not_produce_unrefined_islands),
1325 maximum_smoothing = 0xffff ^ allow_anisotropic_smoothing
1517 std::list<typename Triangulation<dim, spacedim>::cell_iterator>
1524 static const unsigned int dimension = dim;
1529 static const unsigned int space_dimension = spacedim;
1546 const bool check_for_distorted_cells =
false);
1605 get_mesh_smoothing()
const;
1660 reset_all_manifolds();
1721 virtual std::vector<types::boundary_id>
1722 get_boundary_ids()
const;
1736 virtual std::vector<types::manifold_id>
1737 get_manifold_ids()
const;
1830 &construction_data);
1841 create_triangulation_compatibility(
1853 flip_all_direction_flags();
1867 set_all_refine_flags();
1884 refine_global(
const unsigned int times = 1);
1918 execute_coarsening_and_refinement();
1950 prepare_coarsening_and_refinement();
1995 template <
typename T>
2000 template <
typename InputIterator>
2004 return std::accumulate(first, last,
T());
2068 boost::signals2::signal<void(
2078 boost::signals2::signal<void(
2088 boost::signals2::signal<void(
2238 save_refine_flags(std::ostream &out)
const;
2244 save_refine_flags(std::vector<bool> &v)
const;
2250 load_refine_flags(std::istream &in);
2256 load_refine_flags(
const std::vector<bool> &v);
2262 save_coarsen_flags(std::ostream &out)
const;
2268 save_coarsen_flags(std::vector<bool> &v)
const;
2274 load_coarsen_flags(std::istream &out);
2280 load_coarsen_flags(
const std::vector<bool> &v);
2287 get_anisotropic_refinement_flag()
const;
2311 save_user_flags(std::ostream &out)
const;
2319 save_user_flags(std::vector<bool> &v)
const;
2326 load_user_flags(std::istream &in);
2333 load_user_flags(
const std::vector<bool> &v);
2340 clear_user_flags_line();
2347 save_user_flags_line(std::ostream &out)
const;
2355 save_user_flags_line(std::vector<bool> &v)
const;
2362 load_user_flags_line(std::istream &in);
2369 load_user_flags_line(
const std::vector<bool> &v);
2376 clear_user_flags_quad();
2383 save_user_flags_quad(std::ostream &out)
const;
2391 save_user_flags_quad(std::vector<bool> &v)
const;
2398 load_user_flags_quad(std::istream &in);
2405 load_user_flags_quad(
const std::vector<bool> &v);
2413 clear_user_flags_hex();
2420 save_user_flags_hex(std::ostream &out)
const;
2428 save_user_flags_hex(std::vector<bool> &v)
const;
2435 load_user_flags_hex(std::istream &in);
2442 load_user_flags_hex(
const std::vector<bool> &v);
2458 save_user_indices(std::vector<unsigned int> &v)
const;
2465 load_user_indices(
const std::vector<unsigned int> &v);
2473 save_user_pointers(std::vector<void *> &v)
const;
2480 load_user_pointers(
const std::vector<void *> &v);
2488 save_user_indices_line(std::vector<unsigned int> &v)
const;
2495 load_user_indices_line(
const std::vector<unsigned int> &v);
2503 save_user_indices_quad(std::vector<unsigned int> &v)
const;
2510 load_user_indices_quad(
const std::vector<unsigned int> &v);
2518 save_user_indices_hex(std::vector<unsigned int> &v)
const;
2525 load_user_indices_hex(
const std::vector<unsigned int> &v);
2532 save_user_pointers_line(std::vector<void *> &v)
const;
2539 load_user_pointers_line(
const std::vector<void *> &v);
2547 save_user_pointers_quad(std::vector<void *> &v)
const;
2554 load_user_pointers_quad(
const std::vector<void *> &v);
2562 save_user_pointers_hex(std::vector<void *> &v)
const;
2569 load_user_pointers_hex(
const std::vector<void *> &v);
2631 begin_active(
const unsigned int level = 0)
const;
2659 end(
const unsigned int level)
const;
2681 end_active(
const unsigned int level)
const;
2694 last_active()
const;
2711 cell_iterators()
const;
2749 active_cell_iterators()
const;
2767 cell_iterators_on_level(
const unsigned int level)
const;
2785 active_cell_iterators_on_level(
const unsigned int level)
const;
2808 begin_active_face()
const;
2836 active_face_iterators()
const;
2854 begin_vertex()
const;
2862 begin_active_vertex()
const;
2900 n_lines(
const unsigned int level)
const;
2906 n_active_lines()
const;
2912 n_active_lines(
const unsigned int level)
const;
2924 n_quads(
const unsigned int level)
const;
2930 n_active_quads()
const;
2936 n_active_quads(
const unsigned int level)
const;
2949 n_hexs(
const unsigned int level)
const;
2955 n_active_hexs()
const;
2962 n_active_hexs(
const unsigned int level)
const;
2993 n_global_active_cells()
const;
3017 n_active_faces()
const;
3045 virtual unsigned int 3046 n_global_levels()
const;
3058 has_hanging_nodes()
const;
3078 const std::vector<Point<spacedim>> &
3079 get_vertices()
const;
3086 n_used_vertices()
const;
3092 vertex_used(
const unsigned int index)
const;
3098 const std::vector<bool> &
3099 get_used_vertices()
const;
3113 max_adjacent_cells()
const;
3122 locally_owned_subdomain()
const;
3134 get_triangulation();
3141 get_triangulation()
const;
3163 n_raw_lines()
const;
3175 n_raw_lines(
const unsigned int level)
const;
3187 n_raw_quads()
const;
3199 n_raw_quads(
const unsigned int level)
const;
3211 n_raw_hexs(
const unsigned int level)
const;
3223 n_raw_cells(
const unsigned int level)
const;
3237 n_raw_faces()
const;
3262 template <
class Archive>
3264 save(Archive &ar,
const unsigned int version)
const;
3281 template <
class Archive>
3283 load(Archive &ar,
const unsigned int version);
3309 std::pair<cell_iterator, unsigned int>,
3310 std::pair<std::pair<cell_iterator, unsigned int>, std::bitset<3>>> &
3311 get_periodic_face_map()
const;
3318 template <
class Archive>
3320 serialize(Archive &archive,
const unsigned int version);
3324 BOOST_SERIALIZATION_SPLIT_MEMBER()
3340 <<
"You are requesting information from refinement level " 3342 <<
" of a triangulation, but this triangulation only has " 3343 << arg2 <<
" refinement levels. The given level " << arg1
3344 <<
" must be *less* than " << arg2 <<
".");
3352 ExcTriangulationNotEmpty,
3355 <<
"You are trying to perform an operation on a triangulation " 3356 <<
"that is only allowed if the triangulation is currently empty. " 3357 <<
"However, it currently stores " << arg1 <<
" vertices and has " 3358 <<
"cells on " << arg2 <<
" levels.");
3377 <<
"You tried to do something on level " << arg1
3378 <<
", but this level is empty.");
3395 <<
"The given boundary_id " << arg1
3396 <<
" is not defined in this Triangulation!");
3404 ExcInconsistentCoarseningFlags,
3405 "A cell is flagged for coarsening, but either not all of its siblings " 3406 "are active or flagged for coarsening as well. Please clean up all " 3407 "coarsen flags on your triangulation via " 3408 "Triangulation::prepare_coarsening_and_refinement() beforehand!");
3435 write_bool_vector(
const unsigned int magic_number1,
3436 const std::vector<bool> &v,
3437 const unsigned int magic_number2,
3438 std::ostream & out);
3445 read_bool_vector(
const unsigned int magic_number1,
3446 std::vector<bool> &v,
3447 const unsigned int magic_number2,
3455 update_periodic_face_map();
3465 std::vector<GridTools::PeriodicFacePair<cell_iterator>>
3472 std::map<std::pair<cell_iterator, unsigned int>,
3473 std::pair<std::pair<cell_iterator, unsigned int>, std::bitset<3>>>
3503 begin_raw(
const unsigned int level = 0)
const;
3510 end_raw(
const unsigned int level)
const;
3528 begin_raw_line(
const unsigned int level = 0)
const;
3548 begin_line(
const unsigned int level = 0)
const;
3568 begin_active_line(
const unsigned int level = 0)
const;
3606 begin_raw_quad(
const unsigned int level = 0)
const;
3626 begin_quad(
const unsigned int level = 0)
const;
3646 begin_active_quad(
const unsigned int level = 0)
const;
3683 begin_raw_hex(
const unsigned int level = 0)
const;
3703 begin_hex(
const unsigned int level = 0)
const;
3723 begin_active_hex(
const unsigned int level = 0)
const;
3751 clear_despite_subscriptions();
3760 reset_active_cell_indices();
3776 execute_refinement();
3785 execute_coarsening();
3792 fix_coarsen_flags();
3807 virtual unsigned int 3808 coarse_cell_id_to_coarse_cell_index(
3825 coarse_cell_index_to_coarse_cell_id(
3826 const unsigned int coarse_cell_index)
const;
3832 std::vector<std::unique_ptr<
3841 std::unique_ptr<::internal::TriangulationImplementation::TriaFaces<dim>>
3859 std::map<types::manifold_id, std::unique_ptr<const Manifold<dim, spacedim>>>
3899 std::unique_ptr<std::map<unsigned int, types::boundary_id>>
3922 std::unique_ptr<std::map<unsigned int, types::manifold_id>>
3926 template <
int,
int,
int>
3928 template <
int,
int,
int>
3934 friend struct ::internal::TriaAccessorImplementation::Implementation;
3938 friend struct ::internal::TriangulationImplementation::Implementation;
3941 friend class ::internal::TriangulationImplementation::TriaObjects;
3947 #ifndef DEAL_II_MSVC 3948 static_assert(dim <= spacedim,
3949 "The dimension <dim> of a Triangulation must be less than or " 3950 "equal to the space dimension <spacedim> in which it lives.");
3961 namespace TriangulationImplementation
3963 template <
class Archive>
3965 NumberCache<1>::serialize(Archive &ar,
const unsigned int)
3968 ar &n_lines &n_lines_level;
3969 ar &n_active_lines &n_active_lines_level;
3973 template <
class Archive>
3975 NumberCache<2>::serialize(Archive &ar,
const unsigned int version)
3977 this->NumberCache<1>::serialize(ar, version);
3979 ar &n_quads &n_quads_level;
3980 ar &n_active_quads &n_active_quads_level;
3984 template <
class Archive>
3986 NumberCache<3>::serialize(Archive &ar,
const unsigned int version)
3988 this->NumberCache<2>::serialize(ar, version);
3990 ar &n_hexes &n_hexes_level;
3991 ar &n_active_hexes &n_active_hexes_level;
3998 template <
int dim,
int spacedim>
4003 return vertices_used[index];
4008 template <
int dim,
int spacedim>
4012 return number_cache.n_levels;
4015 template <
int dim,
int spacedim>
4019 return number_cache.n_levels;
4023 template <
int dim,
int spacedim>
4032 template <
int dim,
int spacedim>
4033 inline const std::vector<Point<spacedim>> &
4040 template <
int dim,
int spacedim>
4041 template <
class Archive>
4049 unsigned int n_levels = levels.size();
4051 for (
unsigned int i = 0; i < levels.size(); ++i)
4057 bool faces_is_nullptr = (faces.get() ==
nullptr);
4058 ar & faces_is_nullptr;
4059 if (!faces_is_nullptr)
4065 ar &anisotropic_refinement;
4068 ar &check_for_distorted_cells;
4072 ar &vertex_to_boundary_id_map_1d;
4073 ar &vertex_to_manifold_id_map_1d;
4079 template <
int dim,
int spacedim>
4080 template <
class Archive>
4093 levels.resize(size);
4094 for (
unsigned int i = 0; i < levels.size(); ++i)
4096 std::unique_ptr<internal::TriangulationImplementation::TriaLevel<dim>>
4099 levels[i] = std::move(level);
4103 bool faces_is_nullptr =
true;
4104 ar & faces_is_nullptr;
4105 if (!faces_is_nullptr)
4111 ar &anisotropic_refinement;
4118 for (
unsigned int l = 0;
l < levels.size(); ++
l)
4119 levels[
l]->active_cell_indices.resize(levels[
l]->refine_flags.size());
4120 reset_active_cell_indices();
4124 bool my_check_for_distorted_cells;
4125 ar & my_check_for_distorted_cells;
4127 Assert(my_check_for_distorted_cells == check_for_distorted_cells,
4128 ExcMessage(
"The triangulation loaded into here must have the " 4129 "same setting with regard to reporting distorted " 4130 "cell as the one previously stored."));
4134 ar &vertex_to_boundary_id_map_1d;
4135 ar &vertex_to_manifold_id_map_1d;
4146 template <
int dim,
int spacedim>
4156 template <
int dim,
int spacedim>
4159 const unsigned int coarse_cell_index)
const 4161 return coarse_cell_index;
boost::signals2::signal< void(const Triangulation< dim, spacedim > &destination_tria)> copy
::internal::TriangulationImplementation::NumberCache< dim > number_cache
virtual unsigned int coarse_cell_id_to_coarse_cell_index(const types::coarse_cell_id coarse_cell_id) const
boost::signals2::signal< void()> post_refinement
unsigned int n_vertices() const
std::vector< unsigned int > n_quads_level
boost::signals2::signal< void(const typename Triangulation< dim, spacedim >::cell_iterator &cell)> pre_coarsening_on_cell
#define DeclException2(Exception2, type1, type2, outsequence)
boost::signals2::signal< void()> post_distributed_repartition
typename IteratorSelector::line_iterator line_iterator
T operator()(InputIterator first, InputIterator last) const
unsigned int n_active_lines
std::vector< GridTools::PeriodicFacePair< cell_iterator > > periodic_face_pairs_level_0
typename IteratorSelector::raw_line_iterator raw_line_iterator
std::vector< Point< spacedim > > vertices
std::map< types::manifold_id, std::unique_ptr< const Manifold< dim, spacedim > > > manifold
typename IteratorSelector::hex_iterator hex_iterator
typename IteratorSelector::active_line_iterator active_line_iterator
boost::signals2::signal< void()> pre_distributed_refinement
bool anisotropic_refinement
#define AssertIndexRange(index, range)
static ::ExceptionBase & ExcFacesHaveNoLevel()
unsigned int n_levels() const
void create_triangulation(Triangulation< dim, dim > &tria, const AdditionalData &additional_data=AdditionalData())
std::unique_ptr<::internal::TriangulationImplementation::TriaFaces< dim > > faces
unsigned int n_active_quads
static ::ExceptionBase & ExcMessage(std::string arg1)
boost::signals2::signal< void()> pre_refinement
const bool check_for_distorted_cells
#define DeclException1(Exception1, type1, outsequence)
unsigned int n_active_hexes
unsigned int n_raw_quads() const
#define Assert(cond, exc)
boost::signals2::signal< void()> clear
unsigned int n_raw_hexs(const unsigned int level) const
unsigned int max_adjacent_cells() const
void load(Archive &ar, const unsigned int version)
std::list< typename Triangulation< dim, spacedim >::cell_iterator > distorted_cells
unsigned int n_quads() const
#define DeclExceptionMsg(Exception, defaulttext)
std::unique_ptr< std::map< unsigned int, types::manifold_id > > vertex_to_manifold_id_map_1d
std::vector< bool > vertices_used
#define DeclException0(Exception0)
virtual types::coarse_cell_id coarse_cell_index_to_coarse_cell_id(const unsigned int coarse_cell_index) const
boost::signals2::signal< void(const typename Triangulation< dim, spacedim >::cell_iterator &cell)> post_refinement_on_cell
typename IteratorSelector::active_quad_iterator active_quad_iterator
const std::vector< Point< spacedim > > & get_vertices() const
#define DEAL_II_NAMESPACE_CLOSE
boost::signals2::signal< void()> mesh_movement
typename IteratorSelector::raw_quad_iterator raw_quad_iterator
VectorType::value_type * end(VectorType &V)
unsigned int n_raw_lines() const
boost::signals2::signal< void()> pre_distributed_save
std::map< std::pair< cell_iterator, unsigned int >, std::pair< std::pair< cell_iterator, unsigned int >, std::bitset< 3 > > > periodic_face_map
void save(Archive &ar, const unsigned int version) const
unsigned int n_active_cells(const internal::TriangulationImplementation::NumberCache< 1 > &c)
typename IteratorSelector::quad_iterator quad_iterator
TriangulationBase< dim, spacedim > Triangulation
boost::signals2::signal< void()> create
std::unique_ptr< std::map< unsigned int, types::boundary_id > > vertex_to_boundary_id_map_1d
std::vector< std::unique_ptr< ::internal::TriangulationImplementation::TriaLevel< dim > > > levels
unsigned int n_active_quads() const
unsigned int n_cells(const internal::TriangulationImplementation::NumberCache< 1 > &c)
std::vector< unsigned int > n_lines_level
boost::signals2::signal< void()> pre_partition
typename IteratorSelector::active_hex_iterator active_hex_iterator
boost::signals2::signal< void()> post_distributed_save
std::vector< unsigned int > n_active_hexes_level
#define DEAL_II_NAMESPACE_OPEN
virtual unsigned int n_global_levels() const
VectorType::value_type * begin(VectorType &V)
typename IteratorSelector::raw_hex_iterator raw_hex_iterator
MeshSmoothing smooth_grid
boost::signals2::signal< unsigned int(const cell_iterator &, const CellStatus), CellWeightSum< unsigned int > > cell_weight
boost::signals2::signal< void()> pre_distributed_load
std::vector< unsigned int > n_active_lines_level
std::vector< unsigned int > n_active_quads_level
boost::signals2::signal< void()> post_distributed_load
global_cell_index coarse_cell_id
std::vector< unsigned int > n_hexes_level
boost::signals2::signal< void()> pre_distributed_repartition
bool vertex_used(const unsigned int index) const
boost::signals2::signal< void()> any_change
std::enable_if< std::is_fundamental< T >::value, std::size_t >::type memory_consumption(const T &t)
Tensor< 2, dim, Number > l(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
boost::signals2::signal< void()> post_distributed_refinement