34 const unsigned int select,
35 const bool integrate_to_one,
36 const double unitary_integral_value)
41 , integrate_to_one(integrate_to_one)
42 , unitary_integral_value(unitary_integral_value)
43 , rescaling(integrate_to_one ? 1. / (unitary_integral_value *
95 1. / (unitary_integral_value * Utilities::fixed_power<dim>(radius));
115 return integrate_to_one;
125 const unsigned int select,
126 const bool integrate_to_one)
142 for (
unsigned int i = 0; i < dim; ++i)
154 for (
unsigned int i = 0; i < dim; ++i)
164 const unsigned int component)
const 168 for (
unsigned int i = 0; i < dim; ++i)
178 const unsigned int component)
const 182 for (
unsigned int i = 0; i < dim; ++i)
194 const double integral_Linfty[] = {2.0,
195 3.14159265358979323846264338328,
196 4.18879020478639098461685784437};
200 const double integral_W1[] = {1.0,
201 1.04719755119659774615421446109,
202 1.04719755119659774615421446109};
206 const double integral_Cinfty[] = {1.20690032243787617533623799633,
207 1.26811216112759608094632335664,
208 1.1990039070192139033798473858};
212 const double integral_C1[] = {1.0,
213 0.93417655442731527615578663815,
214 0.821155557658032806157358815206};
223 const unsigned int select,
230 integral_Linfty[dim - 1])
237 const unsigned int component)
const 249 std::vector<double> & values,
250 const unsigned int component)
const 252 Assert(values.size() == points.size(),
259 for (
unsigned int k = 0; k < values.size(); ++k)
264 std::fill(values.begin(), values.end(), 0.);
274 Assert(values.size() == points.size(),
277 for (
unsigned int k = 0; k < values.size(); ++k)
296 const unsigned int select,
303 integral_W1[dim - 1])
310 const unsigned int component)
const 316 return ((d < this->
radius) ?
317 (this->radius - d) / this->radius * this->
rescaling :
327 std::vector<double> & values,
328 const unsigned int component)
const 330 Assert(values.size() == points.size(),
335 for (
unsigned int i = 0; i < values.size(); ++i)
338 values[i] = ((d < this->
radius) ?
343 std::fill(values.begin(), values.end(), 0.);
354 Assert(values.size() == points.size(),
357 for (
unsigned int k = 0; k < values.size(); ++k)
380 const unsigned int select,
387 integral_Cinfty[dim - 1])
394 const unsigned int component)
const 400 const double r = this->
radius;
403 const double e = -r * r / (r * r - d *
d);
413 std::vector<double> & values,
414 const unsigned int component)
const 416 Assert(values.size() == points.size(),
419 const double r = this->
radius;
423 for (
unsigned int i = 0; i < values.size(); ++i)
432 const double e = -r * r / (r * r - d *
d);
438 std::fill(values.begin(), values.end(), 0.);
448 Assert(values.size() == points.size(),
451 for (
unsigned int k = 0; k < values.size(); ++k)
454 const double r = this->
radius;
458 const double e = -r * r / (r * r - d *
d);
478 const unsigned int)
const 481 const double r = this->
radius;
484 const double e = -d * d / (r -
d) / (r + d);
487 (-2.0 * r * r / std::pow(-r * r + d * d, 2.0) * d *
498 const unsigned int select,
505 integral_C1[dim - 1])
512 const unsigned int component)
const 518 const double r = this->
radius;
530 std::vector<double> & values,
531 const unsigned int component)
const 533 Assert(values.size() == points.size(),
536 const double r = this->
radius;
540 for (
unsigned int i = 0; i < values.size(); ++i)
554 std::fill(values.begin(), values.end(), 0.);
564 Assert(values.size() == points.size(),
567 for (
unsigned int k = 0; k < values.size(); ++k)
570 const double r = this->
radius;
594 const double r = this->
radius;
virtual void vector_value_list(const std::vector< Point< dim >> &points, std::vector< Vector< double >> &values) const override
virtual void value_list(const std::vector< Point< dim >> &points, std::vector< double > &values, const unsigned int component=0) const override
virtual void value_list(const std::vector< Point< dim >> &points, std::vector< double > &values, const unsigned int component=0) const override
const unsigned int n_components
virtual Tensor< 1, dim > gradient(const Point< dim > &p, const unsigned int component=0) const override
SymmetricTensor< 2, dim, Number > e(const Tensor< 2, dim, Number > &F)
CutOffFunctionW1(const double radius=1., const Point< dim >=Point< dim >(), const unsigned int n_components=1, const unsigned int select=CutOffFunctionBase< dim >::no_component, const bool integrate_to_one=false)
CutOffFunctionC1(const double radius=1., const Point< dim >=Point< dim >(), const unsigned int n_components=1, const unsigned int select=CutOffFunctionBase< dim >::no_component, bool integrate_to_one=false)
#define AssertIndexRange(index, range)
virtual void set_center(const Point< dim > ¢er) override
static ::ExceptionBase & ExcNotInitialized()
std::array< std::unique_ptr< CutOffFunctionBase< 1 > >, dim > base
virtual void set_center(const Point< dim > &p)
virtual double value(const Point< dim > &p, const unsigned int component=0) const override
CutOffFunctionBase(const double radius=1., const Point< dim > center=Point< dim >(), const unsigned int n_components=1, const unsigned int select=CutOffFunctionBase< dim >::no_component, const bool integrate_to_one=false, const double unitary_integral_value=1.0)
static constexpr double E
static ::ExceptionBase & ExcMessage(std::string arg1)
virtual void set_radius(const double radius) override
#define Assert(cond, exc)
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
CutOffFunctionLinfty(const double radius=1., const Point< dim >=Point< dim >(), const unsigned int n_components=1, const unsigned int select=CutOffFunctionBase< dim >::no_component, const bool integrate_to_one=false)
virtual Tensor< 1, dim > gradient(const Point< dim > &p, const unsigned int component=0) const override
#define DEAL_II_NAMESPACE_CLOSE
virtual void vector_value_list(const std::vector< Point< dim >> &points, std::vector< Vector< double >> &values) const override
virtual double value(const Point< dim > &p, const unsigned int component=0) const override
virtual double value(const Point< dim > &p, const unsigned int component=0) const override
SymmetricTensor< 2, dim, Number > d(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
numbers::NumberTraits< Number >::real_type distance(const Point< dim, Number > &p) const
virtual void vector_value_list(const std::vector< Point< dim >> &points, std::vector< Vector< double >> &values) const override
const unsigned int selected
virtual void value_list(const std::vector< Point< dim >> &points, std::vector< double > &values, const unsigned int component=0) const override
virtual double value(const Point< dim > &p, const unsigned int component=0) const override
static constexpr double PI
virtual Tensor< 1, dim > gradient(const Point< dim > &p, const unsigned int component=0) const override
#define DEAL_II_NAMESPACE_OPEN
CutOffFunctionCinfty(const double radius=1., const Point< dim >=Point< dim >(), const unsigned int n_components=1, const unsigned int select=CutOffFunctionBase< dim >::no_component, bool integrate_to_one=false)
virtual void vector_value_list(const std::vector< Point< dim >> &points, std::vector< Vector< double >> &values) const override
virtual void value_list(const std::vector< Point< dim >> &points, std::vector< double > &values, const unsigned int component=0) const override
virtual double value(const Point< dim > &p, const unsigned int component=0) const override
virtual void set_radius(const double r)