22 #ifndef _aspect_geometry_model_chunk_h 23 #define _aspect_geometry_model_chunk_h 29 #include <deal.II/grid/manifold.h> 30 #include <deal.II/base/function_lib.h> 31 #include <deal.II/grid/grid_out.h> 35 namespace GeometryModel
59 const double min_longitude,
60 const double min_radius,
74 pull_back(
const Point<dim> &space_point)
const override;
83 push_forward(
const Point<dim> &chart_point)
const override;
90 DerivativeForm<1, dim, dim>
111 virtual Tensor<1, dim>
113 const typename Triangulation<dim>::face_iterator &face,
114 const Point<dim> &p)
const override;
123 get_radius(
const Point<dim> &space_point)
const;
128 std::unique_ptr<Manifold<dim,dim>>
129 clone()
const override;
208 void create_coarse_mesh (parallel::distributed::Triangulation<dim> &coarse_grid)
const override;
221 std::set<types::boundary_id>
222 get_used_boundary_indicators ()
const override;
236 std::map<std::string,types::boundary_id>
237 get_symbolic_boundary_names_map ()
const override;
250 double length_scale ()
const override;
265 double depth(
const Point<dim> &position)
const override;
271 double height_above_reference_surface(
const Point<dim> &position)
const override;
276 Point<dim> representative_point(
const double depth)
const override;
283 double west_longitude()
const;
290 double east_longitude()
const;
296 double longitude_range()
const;
303 double south_latitude()
const;
310 double north_latitude()
const;
316 double latitude_range()
const;
322 double maximal_depth()
const override;
334 double outer_radius()
const;
343 has_curved_elements()
const override;
351 point_is_in_domain(
const Point<dim> &point)
const override;
364 std::array<double,dim> cartesian_to_natural_coordinates(
const Point<dim> &position)
const override;
371 Point<dim> natural_to_cartesian_coordinates(
const std::array<double,dim> &position)
const override;
384 parse_parameters (ParameterHandler &prm)
override;
415 std::unique_ptr<const internal::ChunkGeometry<dim>>
manifold;
420 static constexpr types::manifold_id my_manifold_id = 15;
DerivativeForm< 1, dim, dim > push_forward_gradient(const Point< dim > &chart_point) const override
std::array< unsigned int, dim > repetitions
const InitialTopographyModel::Interface< dim > * topo
virtual Point< dim > pull_back_topo(const Point< dim > &space_point) const
std::unique_ptr< const internal::ChunkGeometry< dim > > manifold
ChunkGeometry(const InitialTopographyModel::Interface< dim > &topography, const double min_longitude, const double min_radius, const double max_depth)
void declare_parameters(ParameterHandler &prm)
Point< dim > pull_back_sphere(const Point< dim > &space_point) const
double get_radius(const Point< dim > &space_point) const
Point< dim > pull_back(const Point< dim > &space_point) const override
virtual Point< dim > push_forward_topo(const Point< dim > &chart_point) const
virtual Tensor< 1, dim > normal_vector(const typename Triangulation< dim >::face_iterator &face, const Point< dim > &p) const override
Point< dim > push_forward_sphere(const Point< dim > &chart_point) const
std::unique_ptr< Manifold< dim, dim > > clone() const override
Point< dim > push_forward(const Point< dim > &chart_point) const override