$extrastylesheet
00001 // The libMesh Finite Element Library. 00002 // Copyright (C) 2002-2014 Benjamin S. Kirk, John W. Peterson, Roy H. Stogner 00003 00004 // This library is free software; you can redistribute it and/or 00005 // modify it under the terms of the GNU Lesser General Public 00006 // License as published by the Free Software Foundation; either 00007 // version 2.1 of the License, or (at your option) any later version. 00008 00009 // This library is distributed in the hope that it will be useful, 00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00012 // Lesser General Public License for more details. 00013 00014 // You should have received a copy of the GNU Lesser General Public 00015 // License along with this library; if not, write to the Free Software 00016 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00017 00018 00019 00020 #ifndef LIBMESH_QUADRATURE_JACOBI_H 00021 #define LIBMESH_QUADRATURE_JACOBI_H 00022 00023 // Local includes 00024 #include "libmesh/quadrature.h" 00025 00026 // C++ includes 00027 00028 namespace libMesh 00029 { 00030 00031 00032 // ------------------------------------------------------------ 00033 // QJacobi class definition 00034 00035 00052 class QJacobi : public QBase 00053 { 00054 public: 00055 00059 QJacobi (const unsigned int _dim, 00060 const Order _order=INVALID_ORDER, 00061 const unsigned int a=1, 00062 const unsigned int b=0); 00063 00067 ~QJacobi() {} 00068 00073 QuadratureType type() const; 00074 00075 00076 private: 00077 const unsigned int _alpha; 00078 const unsigned int _beta; 00079 00080 void init_1D (const ElemType _type=INVALID_ELEM, 00081 unsigned int p_level=0); 00082 00083 }; 00084 00085 00086 00087 00088 // ------------------------------------------------------------ 00089 // QJacobi class members 00090 inline 00091 QJacobi::QJacobi(const unsigned int d, 00092 const Order o, 00093 const unsigned int a, 00094 const unsigned int b) : QBase(d,o), _alpha(a), _beta(b) 00095 { 00096 if (_dim == 1) 00097 init(EDGE2); 00098 } 00099 00100 00101 00102 inline 00103 QuadratureType QJacobi::type() const 00104 { 00105 if ((_alpha == 1) && (_beta == 0)) 00106 return QJACOBI_1_0; 00107 00108 else if ((_alpha == 2) && (_beta == 0)) 00109 return QJACOBI_2_0; 00110 00111 else 00112 libmesh_error_msg("Invalid Jacobi quadrature rule: alpha = " << _alpha << ", beta = " << _beta); 00113 } 00114 00115 00116 } // namespace libMesh 00117 00118 00119 #endif // LIBMESH_QUADRATURE_JACOBI_H