55 "Lowest order BDM element are degree 1, but you asked for degree 0"));
84 for (
unsigned int i = 0; i < GeometryInfo<dim>::max_children_per_face; ++i)
89 unsigned int target_row = 0;
90 for (
unsigned int d = 0; d < GeometryInfo<dim>::max_children_per_face; ++
d)
91 for (
unsigned int i = 0; i < face_embeddings[
d].
m(); ++i)
93 for (
unsigned int j = 0; j < face_embeddings[
d].
n(); ++j)
116 std::ostringstream namebuf;
117 namebuf <<
"FE_BDM<" << dim <<
">(" << this->
degree - 1 <<
")";
119 return namebuf.str();
124 std::unique_ptr<FiniteElement<dim, dim>>
127 return std_cxx14::make_unique<FE_BDM<dim>>(*this);
136 std::vector<double> & nodal_values)
const 149 unsigned int dbase = 0;
151 unsigned int pbase = 0;
159 nodal_values[dbase + i] =
160 support_point_values[pbase + i]
174 nodal_values[dbase + i] = s;
204 nodal_values[dbase + i] = s;
214 std::vector<unsigned int>
227 std::vector<unsigned int> dpo(dim + 1, 0u);
244 return std::vector<bool>();
259 std::vector<bool> ret_val(dofs_per_cell,
false);
282 initialize_test_values(std::vector<std::vector<double>> &test_values,
284 const unsigned int deg)
287 std::vector<Tensor<1, dim>> dummy1;
288 std::vector<Tensor<2, dim>> dummy2;
289 std::vector<Tensor<3, dim>> dummy3;
290 std::vector<Tensor<4, dim>> dummy4;
292 test_values.resize(quadrature.
size());
294 for (
unsigned int k = 0; k < quadrature.
size(); ++k)
296 test_values[k].resize(poly.n());
297 poly.evaluate(quadrature.
point(k),
303 for (
unsigned int i = 0; i < poly.n(); ++i)
305 test_values[k][i] *= quadrature.
weight(k);
315 initialize_test_values(std::vector<std::vector<double>> &,
333 QGauss<dim - 1> face_points(deg + 1);
337 for (
unsigned int k = 0; k < face_points.size(); ++k)
347 const unsigned int npoints =
353 for (
unsigned int k = 0;
358 0,
true,
false,
false, this->dofs_per_face));
372 const unsigned int ibase =
374 for (
unsigned int k = 0; k < cell_points.
size(); ++k)
390 #include "fe_bdm.inst" virtual void convert_generalized_support_point_values_to_dof_values(const std::vector< Vector< double >> &support_point_values, std::vector< double > &nodal_values) const override
std::vector< std::vector< double > > test_values_cell
void reinit(MatrixBlock< MatrixType > &v, const BlockSparsityPattern &p)
void initialize_support_points(const unsigned int bdm_degree)
#define AssertDimension(dim1, dim2)
std::vector< Point< dim > > generalized_support_points
FullMatrix< double > interface_constraints
static unsigned int n_polynomials(const unsigned int degree)
const unsigned int degree
const Point< dim > & point(const unsigned int i) const
void invert(const FullMatrix< number2 > &M)
FullMatrix< double > inverse_node_matrix
std::vector< Point< dim - 1 > > generalized_face_support_points
static std::vector< bool > get_ria_vector(const unsigned int degree)
FE_BDM(const unsigned int p)
static ::ExceptionBase & ExcMessage(std::string arg1)
static ::ExceptionBase & ExcImpossibleInDim(int arg1)
std::vector< std::vector< FullMatrix< double > > > prolongation
void reinit(const TableIndices< N > &new_size, const bool omit_default_initialization=false)
#define Assert(cond, exc)
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
virtual std::string get_name() const override
#define DEAL_II_NAMESPACE_CLOSE
static unsigned int n_polynomials(const unsigned int n)
SymmetricTensor< 2, dim, Number > d(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
unsigned int size() const
const unsigned int dofs_per_cell
static Quadrature< dim > project_to_all_faces(const SubQuadrature &quadrature)
virtual std::unique_ptr< FiniteElement< dim, dim > > clone() const override
#define DEAL_II_NAMESPACE_OPEN
std::vector< std::vector< double > > test_values_face
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
const unsigned int dofs_per_face
void reinit_restriction_and_prolongation_matrices(const bool isotropic_restriction_only=false, const bool isotropic_prolongation_only=false)
double weight(const unsigned int i) const
static ::ExceptionBase & ExcInternalError()
std::vector< MappingKind > mapping_kind