22 #ifndef _aspect_geometry_model_spherical_shell_h 23 #define _aspect_geometry_model_spherical_shell_h 30 namespace GeometryModel
46 const double inner_radius,
47 const double outer_radius);
57 virtual std::unique_ptr<Manifold<dim, dim>>
58 clone()
const override;
84 const double w)
const override;
90 virtual Tensor<1, dim>
92 const Point<dim> &x2)
const override;
109 virtual Tensor<1, dim>
111 const typename Triangulation<dim, dim>::face_iterator &face,
112 const Point<dim> &p)
const override;
119 const typename Triangulation<dim, dim>::face_iterator &face,
120 typename Manifold<dim, dim>::FaceVertexNormals &face_vertex_normals)
139 get_new_points(
const ArrayView<
const Point<dim>> &surrounding_points,
140 const Table<2, double> &weights,
141 ArrayView<Point<dim>> new_points)
const override;
149 const ArrayView<const double> &weights)
const override;
203 void create_coarse_mesh (parallel::distributed::Triangulation<dim> &coarse_grid)
const override;
212 double length_scale ()
const override;
227 double depth(
const Point<dim> &position)
const override;
233 double height_above_reference_surface(
const Point<dim> &position)
const override;
238 Point<dim> representative_point(
const double depth)
const override;
243 double maximal_depth()
const override;
266 std::set<types::boundary_id>
267 get_used_boundary_indicators ()
const override;
274 std::map<std::string,types::boundary_id>
275 get_symbolic_boundary_names_map ()
const override;
281 std::set<std::pair<std::pair<types::boundary_id, types::boundary_id>,
unsigned int>>
282 get_periodic_boundary_pairs ()
const override;
291 adjust_positions_for_periodicity (Point<dim> &position,
292 const ArrayView<Point<dim>> &connected_positions = {},
293 const ArrayView<Tensor<1, dim>> &connected_velocities = {})
const override;
301 has_curved_elements()
const override;
309 point_is_in_domain(
const Point<dim> &point)
const override;
322 std::array<double,dim> cartesian_to_natural_coordinates(
const Point<dim> &position)
const override;
329 Point<dim> natural_to_cartesian_coordinates(
const std::array<double,dim> &position)
const override;
349 parse_parameters (ParameterHandler &prm)
override;
355 inner_radius ()
const;
361 outer_radius ()
const;
367 opening_angle ()
const;
374 make_periodicity_constraints(
const DoFHandler<dim> &dof_handler,
375 AffineConstraints<double> &constraints)
const override;
423 void set_manifold_ids (parallel::distributed::Triangulation<dim> &triangulation)
const;
441 std::unique_ptr<const internal::SphericalManifoldWithTopography<dim>>
manifold;
446 static constexpr types::manifold_id my_manifold_id = 99;
virtual Point< dim > get_new_point(const ArrayView< const Point< dim >> &vertices, const ArrayView< const double > &weights) const override
std::unique_ptr< const internal::SphericalManifoldWithTopography< dim > > manifold
const InitialTopographyModel::Interface< dim > * topo
virtual Point< dim > get_intermediate_point(const Point< dim > &p1, const Point< dim > &p2, const double w) const override
virtual std::unique_ptr< Manifold< dim, dim > > clone() const override
std::vector< double > R_values_list
void declare_parameters(ParameterHandler &prm)
Point< dim > push_forward_from_sphere(const Point< dim > &p) const
int n_cells_along_circumference
virtual void get_new_points(const ArrayView< const Point< dim >> &surrounding_points, const Table< 2, double > &weights, ArrayView< Point< dim >> new_points) const override
virtual void get_normals_at_vertices(const typename Triangulation< dim, dim >::face_iterator &face, typename Manifold< dim, dim >::FaceVertexNormals &face_vertex_normals) const override
CustomMeshRadialSubdivision
Point< dim > pull_back_to_sphere(const Point< dim > &p) const
SphericalManifoldWithTopography(const InitialTopographyModel::Interface< dim > &topography, const double inner_radius, const double outer_radius)
virtual Tensor< 1, dim > normal_vector(const typename Triangulation< dim, dim >::face_iterator &face, const Point< dim > &p) const override
double topography_for_point(const Point< dim > &x_y_z) const
unsigned int initial_lateral_refinement
virtual Tensor< 1, dim > get_tangent_vector(const Point< dim > &x1, const Point< dim > &x2) const override