Line data Source code
1 : // The libMesh Finite Element Library. 2 : // Copyright (C) 2002-2025 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner 3 : 4 : // This library is free software; you can redistribute it and/or 5 : // modify it under the terms of the GNU Lesser General Public 6 : // License as published by the Free Software Foundation; either 7 : // version 2.1 of the License, or (at your option) any later version. 8 : 9 : // This library is distributed in the hope that it will be useful, 10 : // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 : // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 12 : // Lesser General Public License for more details. 13 : 14 : // You should have received a copy of the GNU Lesser General Public 15 : // License along with this library; if not, write to the Free Software 16 : // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 17 : 18 : #ifndef LIBMESH_HDIV_FE_TRANSFORMATION_H 19 : #define LIBMESH_HDIV_FE_TRANSFORMATION_H 20 : 21 : #include "libmesh/fe_transformation_base.h" 22 : 23 : namespace libMesh 24 : { 25 : 26 : /** 27 : * This class handles the computation of the shape functions in the 28 : * physical domain for HDiv conforming elements. This class assumes 29 : * the \p FEGenericBase object has been initialized in the reference 30 : * domain (i.e. \p init_shape_functions has been called). 31 : * 32 : * \author Nuno Nobre 33 : * \date 2023 34 : */ 35 : template<typename OutputShape> 36 : class HDivFETransformation : public FETransformationBase<OutputShape> 37 : { 38 : public: 39 : 40 476634 : HDivFETransformation() 41 476634 : : FETransformationBase<OutputShape>() {} 42 : 43 514373 : virtual ~HDivFETransformation() = default; 44 : 45 : /** 46 : * Pre-requests any necessary data from FEMap 47 : */ 48 : virtual void init_map_phi(const FEGenericBase<OutputShape> & fe) const override; 49 : 50 : /** 51 : * Pre-requests any necessary data from FEMap 52 : */ 53 : virtual void init_map_dphi(const FEGenericBase<OutputShape> & fe) const override; 54 : 55 : /** 56 : * Pre-requests any necessary data from FEMap 57 : */ 58 : virtual void init_map_d2phi(const FEGenericBase<OutputShape> & fe) const override; 59 : 60 : /** 61 : * Evaluates shape functions in physical coordinates for \f$ H(div) 62 : * \f$ conforming elements. In this case \f$ \phi = J^{-1} (dx/d\xi) 63 : * \hat{\phi} \f$, where \f$ (dx/d\xi) \f$ is the Jacobian matrix of the 64 : * element map and J = \det( dx/d\xi ). 65 : * 66 : * \note Here \f$ x, \xi \f$ are vectors. 67 : */ 68 : virtual void map_phi(const unsigned int dim, 69 : const Elem * const elem, 70 : const std::vector<Point> & qp, 71 : const FEGenericBase<OutputShape> & fe, 72 : std::vector<std::vector<OutputShape>> & phi, 73 : bool add_p_level = true) const override; 74 : 75 : /** 76 : * Evaluates shape function gradients in physical coordinates for 77 : * \f$ H(div) \f$ conforming elements. 78 : */ 79 424409 : virtual void map_dphi(const unsigned int /*dim*/, 80 : const Elem * const /*elem*/, 81 : const std::vector<Point> & /*qp*/, 82 : const FEGenericBase<OutputShape> & /*fe*/, 83 : std::vector<std::vector<typename FEGenericBase<OutputShape>::OutputGradient>> & /*dphi*/, 84 : std::vector<std::vector<OutputShape>> & /*dphidx*/, 85 : std::vector<std::vector<OutputShape>> & /*dphidy*/, 86 : std::vector<std::vector<OutputShape>> & /*dphidz*/) const override 87 : { 88 : libmesh_warning("WARNING: Shape function gradients for HDiv elements are not currently being computed!"); 89 424409 : } 90 : 91 : #ifdef LIBMESH_ENABLE_SECOND_DERIVATIVES 92 : /** 93 : * Evaluates shape function Hessians in physical coordinates based 94 : * on \f$ H(div) \f$ conforming finite element transformation. 95 : */ 96 0 : virtual void map_d2phi(const unsigned int /*dim*/, 97 : const std::vector<Point> & /*qp*/, 98 : const FEGenericBase<OutputShape> & /*fe*/, 99 : std::vector<std::vector<typename FEGenericBase<OutputShape>::OutputTensor>> & /*d2phi*/, 100 : std::vector<std::vector<OutputShape>> & /*d2phidx2*/, 101 : std::vector<std::vector<OutputShape>> & /*d2phidxdy*/, 102 : std::vector<std::vector<OutputShape>> & /*d2phidxdz*/, 103 : std::vector<std::vector<OutputShape>> & /*d2phidy2*/, 104 : std::vector<std::vector<OutputShape>> & /*d2phidydz*/, 105 : std::vector<std::vector<OutputShape>> & /*d2phidz2*/) const override 106 : { 107 : libmesh_warning("WARNING: Shape function Hessians for HDiv elements are not currently being computed!"); 108 0 : } 109 : #endif //LIBMESH_ENABLE_SECOND_DERIVATIVES 110 : 111 : /** 112 : * Evaluates the shape function curl in physical coordinates 113 : * based on \f$ H(div) \f$ conforming finite element transformation. 114 : */ 115 424409 : virtual void map_curl(const unsigned int /*dim*/, 116 : const Elem * const /*elem*/, 117 : const std::vector<Point> & /*qp*/, 118 : const FEGenericBase<OutputShape> & /*fe*/, 119 : std::vector<std::vector<OutputShape>> & /*curl_phi*/) const override 120 : { 121 : libmesh_warning("WARNING: Shape function curls for HDiv elements are not currently being computed!"); 122 424409 : } 123 : 124 : /** 125 : * Evaluates the shape function divergence in physical coordinates based on \f$ H(div) \f$ conforming 126 : * finite element transformation. 127 : * The transformation is \f$ \nabla \cdot \phi = J^{-1} \nabla \cdot \hat{\phi} \f$ where 128 : * \f$ J = \det( dx/d\xi ) \f$ 129 : */ 130 : virtual void map_div(const unsigned int dim, 131 : const Elem * const elem, 132 : const std::vector<Point> & qp, 133 : const FEGenericBase<OutputShape> & fe, 134 : std::vector<std::vector<typename FEGenericBase<OutputShape>::OutputDivergence>> & div_phi) const override; 135 : 136 : }; // class HDivFETransformation 137 : 138 : } 139 : 140 : #endif // LIBMESH_HDIV_FE_TRANSFORMATION_H