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_HCURL_FE_TRANSFORMATION_H 19 : #define LIBMESH_HCURL_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 HCurl 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 Paul T. Bauman 33 : * \date 2012 34 : */ 35 : template<typename OutputShape> 36 : class HCurlFETransformation : public FETransformationBase<OutputShape> 37 : { 38 : public: 39 : 40 97360 : HCurlFETransformation() 41 97360 : : FETransformationBase<OutputShape>() {} 42 : 43 104650 : virtual ~HCurlFETransformation() = 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(curl) 62 : * \f$ conforming elements. In this case \f$ \phi = (dx/d\xi)^{-T} 63 : * \hat{\phi} \f$, where \f$ (dx/d\xi)^{-T} \f$ is the 64 : * inverse-transpose of the Jacobian matrix of the element map. 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(curl) \f$ conforming elements. 78 : */ 79 73874 : 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 HCurl elements are not currently being computed!"); 89 73874 : } 90 : 91 : #ifdef LIBMESH_ENABLE_SECOND_DERIVATIVES 92 : /** 93 : * Evaluates shape function Hessians in physical coordinates based 94 : * on \f$ H(curl) \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 HCurl 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 based on \f$ H(curl) \f$ conforming 113 : * finite element transformation. 114 : * In 2-D, the transformation is \f$ \nabla \times \phi = J^{-1} * \nabla \times \hat{\phi} \f$ where 115 : * \f$ J = \det( dx/d\xi ) \f$ 116 : * In 3-D, the transformation is \f$ \nabla \times \phi = J^{-1} dx/d\xi \nabla \times \hat{\phi} \f$ 117 : */ 118 : virtual void map_curl(const unsigned int dim, 119 : const Elem * const elem, 120 : const std::vector<Point> & qp, 121 : const FEGenericBase<OutputShape> & fe, 122 : std::vector<std::vector<OutputShape>> & curl_phi) const override; 123 : 124 : /** 125 : * Evaluates the shape function divergence in physical coordinates 126 : * based on \f$ H(curl) \f$ conforming finite element transformation. 127 : */ 128 73874 : virtual void map_div(const unsigned int /*dim*/, 129 : const Elem * const /*elem*/, 130 : const std::vector<Point> & /*qp*/, 131 : const FEGenericBase<OutputShape> & /*fe*/, 132 : std::vector<std::vector<typename FEGenericBase<OutputShape>::OutputDivergence>> & /*div_phi*/) const override 133 : { 134 : libmesh_warning("WARNING: Shape function divergences for HCurl elements are not currently being computed!"); 135 73874 : } 136 : 137 : }; // class HCurlFETransformation 138 : 139 : } 140 : 141 : #endif // LIBMESH_HCURL_FE_TRANSFORMATION_H