17 #ifndef dealii_mesh_worker_functional_h 18 #define dealii_mesh_worker_functional_h 49 template <
typename number =
double>
66 template <
class DOFINFO>
73 template <
class DOFINFO>
80 template <
class DOFINFO>
82 assemble(
const DOFINFO &info1,
const DOFINFO &info2);
107 template <
typename number =
double>
143 template <
class DOFINFO>
150 template <
class DOFINFO>
157 template <
class DOFINFO>
159 assemble(
const DOFINFO &info1,
const DOFINFO &info2);
173 template <
typename number>
182 template <
typename number>
183 template <
class DOFINFO>
187 info.initialize_numbers(
results.size());
191 template <
typename number>
192 template <
class DOFINFO>
196 for (
unsigned int i = 0; i <
results.size(); ++i)
201 template <
typename number>
202 template <
class DOFINFO>
206 for (
unsigned int i = 0; i <
results.size(); ++i)
214 template <
typename number>
224 template <
typename number>
226 : separate_faces(true)
231 template <
typename number>
247 template <
typename number>
248 template <
class DOFINFO>
252 info.initialize_numbers(
257 template <
typename number>
258 template <
class DOFINFO>
268 for (
unsigned int i = 0; i < info.n_values(); ++i)
269 v->
block(i)(info.cell->user_index()) += info.value(i);
273 template <
typename number>
274 template <
class DOFINFO>
278 for (
unsigned int i = 0; i < info1.n_values(); ++i)
283 const double J = info1.value(i) + info2.value(i);
284 v1->
block(i)(info1.face->user_index()) += J;
285 if (info2.face != info1.face)
286 v1->
block(i)(info2.face->user_index()) += J;
291 v0->
block(i)(info1.cell->user_index()) += .5 * info1.value(i);
292 v0->
block(i)(info2.cell->user_index()) += .5 * info2.value(i);
static const unsigned int invalid_unsigned_int
type entry(const std::string &name)
Access to stored data object by name.
#define AssertDimension(dim1, dim2)
void initialize(const unsigned int n)
#define AssertIndexRange(index, range)
void initialize(AnyData &results, bool separate_faces=true)
#define Assert(cond, exc)
void initialize_info(DOFINFO &info, bool face)
#define DEAL_II_NAMESPACE_CLOSE
std::enable_if< IsBlockVector< VectorType >::value, unsigned int >::type n_blocks(const VectorType &vector)
void initialize_info(DOFINFO &info, bool face) const
unsigned int n_blocks() const
#define DEAL_II_NAMESPACE_OPEN
void assemble(const DOFINFO &info)
std::vector< double > results
static ::ExceptionBase & ExcNameMismatch(int arg1, std::string arg2)
BlockType & block(const unsigned int i)
number operator()(const unsigned int i) const
const std::string & name(const unsigned int i) const
Name of object at index.
void assemble(const DOFINFO &info)