16#ifndef dealii_composition_manifold_h
17#define dealii_composition_manifold_h
86 virtual std::unique_ptr<Manifold<dim, spacedim>>
87 clone()
const override;
143 :
ChartManifold<dim, spacedim, chartdim>(F.get_periodicity())
149 Assert(
G.get_periodicity().norm() == 0.0,
150 ExcMessage(
"The second manifold cannot be periodic."));
160std::unique_ptr<Manifold<dim, spacedim>>
164 return std::make_unique<
195 return G->push_forward(F->push_forward(
chart_point));
214 G->push_forward_gradient(F->push_forward(
chart_point));
218 for (
unsigned int d = 0; d < spacedim; ++d)
219 for (
unsigned int c = 0; c < chartdim; ++c)
virtual Point< chartdim > pull_back(const Point< spacedim > &space_point) const
virtual Point< spacedim > push_forward(const Point< chartdim > &chart_point) const
CompositionManifold(const ChartManifold< dim1, intermediate_dim, chartdim > &F, const ChartManifold< dim2, spacedim, intermediate_dim > &G)
virtual std::unique_ptr< Manifold< dim, spacedim > > clone() const override
virtual DerivativeForm< 1, chartdim, spacedim > push_forward_gradient(const Point< chartdim > &chart_point) const
SmartPointer< const ChartManifold< dim2, spacedim, intermediate_dim >, CompositionManifold< dim, spacedim, chartdim, dim1, dim2, intermediate_dim > > G
SmartPointer< const ChartManifold< dim1, intermediate_dim, chartdim >, CompositionManifold< dim, spacedim, chartdim, dim1, dim2, intermediate_dim > > F
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define Assert(cond, exc)
static ::ExceptionBase & ExcMessage(std::string arg1)