29 namespace IsotropicElementProperty3D {
39 virtual void operator() (
const libMesh::Point& p,
45 const libMesh::Point& p,
62 virtual void operator() (
const libMesh::Point& p,
67 const libMesh::Point& p,
85 virtual void operator() (
const libMesh::Point& p,
90 const libMesh::Point& p,
110 virtual void operator() (
const libMesh::Point& p,
116 const libMesh::Point& p,
138 virtual void operator() (
const libMesh::Point& p,
144 const libMesh::Point& p,
165 virtual void operator() (
const libMesh::Point& p,
171 const libMesh::Point& p,
187 return _material->depends_on(f) ||
216 const libMesh::Point& p,
229 _material_inertia(mat) {
250 const libMesh::Point& p,
264 _material_stiffness(mat_stiff),
265 _material_expansion(mat_expansion) {
292 const libMesh::Point& p,
304 _prestress(prestress){
327 const libMesh::Point& p,
338 _mat_cond(mat_cond) {
365 const libMesh::Point& p,
404 const libMesh::Point& p,
422 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
428 (_material->stiffness_matrix(3));
430 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
434 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
440 (_material->stiffness_matrix(3));
442 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
446 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
450 libmesh_assert(
false);
452 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
456 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
460 libmesh_assert(
false);
462 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
466 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
470 libmesh_assert(
false);
472 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
476 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
480 libmesh_assert(
false);
482 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
486 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
490 libmesh_assert(
false);
492 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
496 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
502 (_material->inertia_matrix(3));
504 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
508 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
514 (_material->inertia_matrix(3));
516 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
520 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
526 (_material->stiffness_matrix(3),
527 _material->thermal_expansion_matrix(3));
529 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
533 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
539 (_material->stiffness_matrix(3),
540 _material->thermal_expansion_matrix(3));
542 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
546 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
551 return this->thermal_expansion_A_matrix(e);
555 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
560 return this->thermal_expansion_A_matrix();
564 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
568 libmesh_assert(
false);
570 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
574 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
578 libmesh_assert(
false);
580 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
584 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
588 libmesh_assert(
false);
590 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(
nullptr);
594 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
600 (_material->conductance_matrix(3));
602 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
606 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
612 (_material->conductance_matrix(3));
614 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
618 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
624 (_material->capacitance_matrix(3));
626 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
630 std::unique_ptr<MAST::FieldFunction<RealMatrixX> >
636 (_material->capacitance_matrix(3));
638 return std::unique_ptr<MAST::FieldFunction<RealMatrixX> >(rval);
virtual void operator()(const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the function at the specified point, p, and time, t, and returns it in v...
virtual void operator()(const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the function at the specified point, p, and time, t, and returns it in v...
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > inertia_matrix() const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > stiffness_A_matrix() const
virtual void derivative(const MAST::FunctionBase &f, const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the derivative of function with respect to the function f at the specified po...
virtual ~ThermalExpansionMatrix()
ThermalConductanceMatrix(const MAST::FieldFunction< RealMatrixX > &mat_cond)
virtual ~PrestressAMatrix()
const MAST::FieldFunction< RealMatrixX > & _prestress
virtual ~ThermalConductanceMatrix()
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > prestress_B_matrix(MAST::ElementBase &e) const
InertiaMatrix(const MAST::FieldFunction< RealMatrixX > &mat)
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_conductance_matrix() const
virtual bool depends_on(const MAST::FunctionBase &f) const
returns true if the property card depends on the function f
std::set< const MAST::FunctionBase * > _functions
set of functions that this function depends on
const MAST::FieldFunction< RealMatrixX > & _material_stiffness
virtual void derivative(const MAST::FunctionBase &f, const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the derivative of function with respect to the function f at the specified po...
virtual void derivative(const MAST::FunctionBase &f, const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the derivative of function with respect to the function f at the specified po...
virtual void operator()(const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the function at the specified point, p, and time, t, and returns it in v...
const MAST::FieldFunction< RealMatrixX > & _mat_cap
virtual void derivative(const MAST::FunctionBase &f, ValType &v) const
calculates the value of the function derivative and returns it in v.
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_expansion_A_matrix() const
StiffnessMatrix(const MAST::FieldFunction< RealMatrixX > &mat)
virtual void derivative(const MAST::FunctionBase &f, const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the derivative of function with respect to the function f at the specified po...
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > damping_matrix(const MAST::ElementBase &e) const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_capacitance_matrix() const
ThermalCapacitanceMatrix(const MAST::FieldFunction< RealMatrixX > &mat_cond)
ThermalExpansionMatrix(const MAST::FieldFunction< RealMatrixX > &mat_stiff, const MAST::FieldFunction< RealMatrixX > &mat_expansion)
virtual void derivative(const MAST::FunctionBase &f, const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the derivative of function with respect to the function f at the specified po...
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > transverse_shear_stiffness_matrix(const MAST::ElementBase &e) const
PrestressAMatrix(const MAST::FieldFunction< RealMatrixX > &prestress)
Matrix< Real, Dynamic, Dynamic > RealMatrixX
const MAST::FieldFunction< RealMatrixX > & _material_inertia
This creates the base class for functions that have a saptial and temporal dependence, and provide sensitivity operations with respect to the functions and parameters.
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > stiffness_D_matrix() const
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > prestress_A_matrix(MAST::ElementBase &e) const
const MAST::FieldFunction< RealMatrixX > & _material_stiffness
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > stiffness_B_matrix() const
virtual ~StiffnessMatrix()
virtual std::unique_ptr< MAST::FieldFunction< RealMatrixX > > thermal_expansion_B_matrix() const
virtual void derivative(const MAST::FunctionBase &f, const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the derivative of function with respect to the function f at the specified po...
const MAST::FieldFunction< RealMatrixX > & _material_expansion
virtual void operator()(const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the function at the specified point, p, and time, t, and returns it in v...
virtual void operator()(const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the function at the specified point, p, and time, t, and returns it in v...
virtual void operator()(const libMesh::Point &p, const Real t, RealMatrixX &m) const
calculates the value of the function at the specified point, p, and time, t, and returns it in v...
const MAST::FieldFunction< RealMatrixX > & _mat_cond
virtual ~ThermalCapacitanceMatrix()
virtual bool depends_on(const MAST::FunctionBase &f) const
returns true if the property card depends on the function f
This is the base class for elements that implement calculation of finite element quantities over the ...