17 #include <deal.II/base/std_cxx14/memory.h> 19 #include <deal.II/fe/fe_nothing.h> 21 DEAL_II_NAMESPACE_OPEN
24 template <
int dim,
int spacedim>
44 template <
int dim,
int spacedim>
45 std::unique_ptr<FiniteElement<dim, spacedim>>
48 return std_cxx14::make_unique<FE_Nothing<dim, spacedim>>(*this);
53 template <
int dim,
int spacedim>
57 std::ostringstream namebuf;
58 namebuf <<
"FE_Nothing<" << dim <<
">(";
63 namebuf <<
", dominating";
66 namebuf <<
"dominating";
73 template <
int dim,
int spacedim>
82 template <
int dim,
int spacedim>
93 template <
int dim,
int spacedim>
94 std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
106 return std_cxx14::make_unique<
112 template <
int dim,
int spacedim>
120 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
133 template <
int dim,
int spacedim>
141 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
154 template <
int dim,
int spacedim>
163 const ::internal::FEValuesImplementation::MappingRelatedData<dim,
176 template <
int dim,
int spacedim>
185 template <
int dim,
int spacedim>
199 return ((
dominate == f_nothing->dominate) &&
200 (this->components == f_nothing->components));
207 template <
int dim,
int spacedim>
230 template <
int dim,
int spacedim>
231 std::vector<std::pair<unsigned int, unsigned int>>
239 return std::vector<std::pair<unsigned int, unsigned int>>();
243 template <
int dim,
int spacedim>
244 std::vector<std::pair<unsigned int, unsigned int>>
252 return std::vector<std::pair<unsigned int, unsigned int>>();
256 template <
int dim,
int spacedim>
257 std::vector<std::pair<unsigned int, unsigned int>>
265 return std::vector<std::pair<unsigned int, unsigned int>>();
269 template <
int dim,
int spacedim>
278 template <
int dim,
int spacedim>
286 (void)interpolation_matrix;
288 Assert(interpolation_matrix.
m() == 0,
290 Assert(interpolation_matrix.
n() == 0,
296 template <
int dim,
int spacedim>
304 (void)interpolation_matrix;
306 Assert(interpolation_matrix.
m() == 0,
308 Assert(interpolation_matrix.
n() == 0,
313 template <
int dim,
int spacedim>
323 (void)interpolation_matrix;
324 Assert(interpolation_matrix.
m() == 0,
326 Assert(interpolation_matrix.
n() == 0,
333 #include "fe_nothing.inst" 336 DEAL_II_NAMESPACE_CLOSE
virtual double shape_value(const unsigned int i, const Point< dim > &p) const override
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim > &quadrature,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
bool is_dominating() const
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source_fe, FullMatrix< double > &interpolation_matrix) const override
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source_fe, FullMatrix< double > &interpolation_matrix) const override
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source_fe, const unsigned int index, FullMatrix< double > &interpolation_matrix) const override
static::ExceptionBase & ExcMessage(std::string arg1)
#define Assert(cond, exc)
static::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
virtual bool hp_constraints_are_implemented() const override
Abstract base class for mapping classes.
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
virtual std::string get_name() const override
unsigned int n_components() const
virtual bool operator==(const FiniteElement< dim, spacedim > &fe) const override
FE_Nothing(const unsigned int n_components=1, const bool dominate=false)
unsigned int n_components(const DoFHandler< dim, spacedim > &dh)