LCOV - code coverage report
Current view: top level - src/quadrature - quadrature_gauss_lobatto_1D.C (source / functions) Hit Total Coverage
Test: libMesh/libmesh: #4229 (6a9aeb) with base 727f46 Lines: 640 642 99.7 %
Date: 2025-08-19 19:27:09 Functions: 1 1 100.0 %
Legend: Lines: hit not hit

          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             : 
      19             : 
      20             : // C++ includes
      21             : 
      22             : // Local includes
      23             : #include "libmesh/quadrature_gauss_lobatto.h"
      24             : 
      25             : namespace libMesh
      26             : {
      27             : 
      28        9230 : void QGaussLobatto::init_1D()
      29             : {
      30             :   //----------------------------------------------------------------------
      31             :   // 1D quadrature rules
      32        9490 :   switch(get_order())
      33             :     {
      34             :       // Since Gauss-Lobatto rules must include the endpoints of the
      35             :       // domain, there is no 1-point rule.  The two-point
      36             :       // Gauss-Lobatto rule is equivalent to the trapezoidal rule.
      37         355 :     case CONSTANT:
      38             :     case FIRST:
      39             :       {
      40         355 :         _points.resize (2);
      41         355 :         _weights.resize(2);
      42             : 
      43         355 :         _points[0](0) = -1;
      44         355 :         _points[1]    = -_points[0];
      45             : 
      46         355 :         _weights[0]   = 1.;
      47         355 :         _weights[1]   = _weights[0];
      48             : 
      49         355 :         return;
      50             :       }
      51             : 
      52             :       // The three-point Gauss-Lobatto rule is equivalent to Simpsons' rule.
      53             :       // It can integrate cubic polynomials exactly.
      54         710 :     case SECOND:
      55             :     case THIRD:
      56             :       {
      57         710 :         _points.resize (3);
      58         710 :         _weights.resize(3);
      59             : 
      60         710 :         _points[0](0) = -1;
      61         710 :         _points[1]    = 0;
      62         710 :         _points[2]    = -_points[0];
      63             : 
      64         710 :         _weights[0]   = Real(1)/3;
      65         710 :         _weights[1]   = Real(4)/3;
      66         710 :         _weights[2]   = _weights[0];
      67         710 :         return;
      68             :       }
      69             : 
      70             :       // The four-point Gauss-Lobatto rule can integrate 2*4-3 =
      71             :       // 5th-order polynomials exactly.
      72         710 :     case FOURTH:
      73             :     case FIFTH:
      74             :       {
      75         710 :         _points.resize (4);
      76         710 :         _weights.resize(4);
      77             : 
      78         710 :         _points[ 0](0) = -1;
      79         710 :         _points[ 1](0) = -std::sqrt(Real(1)/5); // ~ -0.4472135955
      80         710 :         _points[ 2]    = -_points[1];
      81         710 :         _points[ 3]    = -_points[0];
      82             : 
      83         710 :         _weights[ 0]   = Real(1)/6;
      84         710 :         _weights[ 1]   = Real(5)/6;
      85         710 :         _weights[ 2]   = _weights[1];
      86         710 :         _weights[ 3]   = _weights[0];
      87             : 
      88         710 :         return;
      89             :       }
      90             : 
      91             :       // The five-point Gauss-Lobatto rule can integrate 2*5-3 =
      92             :       // 7th-order polynomials exactly.
      93         710 :     case SIXTH:
      94             :     case SEVENTH:
      95             :       {
      96         710 :         _points.resize (5);
      97         710 :         _weights.resize(5);
      98             : 
      99         710 :         _points[ 0](0) = -1;
     100         710 :         _points[ 1](0) = -std::sqrt(Real(3)/7); // ~ -0.6546536707
     101         710 :         _points[ 2](0) = 0.;
     102         710 :         _points[ 3]    = -_points[1];
     103         710 :         _points[ 4]    = -_points[0];
     104             : 
     105         710 :         _weights[ 0]   = 1/Real(10);
     106         710 :         _weights[ 1]   = Real(49)/90;
     107         710 :         _weights[ 2]   = Real(32)/45;
     108         710 :         _weights[ 3]   = _weights[1];
     109         710 :         _weights[ 4]   = _weights[0];
     110             : 
     111         710 :         return;
     112             :       }
     113             : 
     114             :       // 2*6-3 = 9
     115         710 :     case EIGHTH:
     116             :     case NINTH:
     117             :       {
     118         710 :         _points.resize (6);
     119         710 :         _weights.resize(6);
     120             : 
     121         710 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     122         710 :         _points[ 1](0) = -7.6505532392946469285100297395934e-01_R;
     123         710 :         _points[ 2](0) = -2.8523151648064509631415099404088e-01_R;
     124         710 :         _points[ 3]    = -_points[2];
     125         710 :         _points[ 4]    = -_points[1];
     126         710 :         _points[ 5]    = -_points[0];
     127             : 
     128         710 :         _weights[ 0]   = 6.6666666666666666666666666666667e-02_R;
     129         710 :         _weights[ 1]   = 3.7847495629784698031661280821202e-01_R;
     130         710 :         _weights[ 2]   = 5.5485837703548635301672052512131e-01_R;
     131         710 :         _weights[ 3]   = _weights[2];
     132         710 :         _weights[ 4]   = _weights[1];
     133         710 :         _weights[ 5]   = _weights[0];
     134             : 
     135         710 :         return;
     136             :       }
     137             : 
     138             :       // 2*7-3 = 11
     139         355 :     case TENTH:
     140             :     case ELEVENTH:
     141             :       {
     142         355 :         _points.resize (7);
     143         355 :         _weights.resize(7);
     144             : 
     145         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     146         355 :         _points[ 1](0) = -8.3022389627856692987203221396747e-01_R;
     147         355 :         _points[ 2](0) = -4.6884879347071421380377188190877e-01_R;
     148         355 :         _points[ 3](0) = 0.;
     149         355 :         _points[ 4]    = -_points[2];
     150         355 :         _points[ 5]    = -_points[1];
     151         355 :         _points[ 6]    = -_points[0];
     152             : 
     153         355 :         _weights[ 0]   = 4.7619047619047619047619047619048e-02_R;
     154         355 :         _weights[ 1]   = 2.7682604736156594801070040629007e-01_R;
     155         355 :         _weights[ 2]   = 4.3174538120986262341787102228136e-01_R;
     156         355 :         _weights[ 3]   = 4.8761904761904761904761904761905e-01_R;
     157         355 :         _weights[ 4]   = _weights[2];
     158         355 :         _weights[ 5]   = _weights[1];
     159         355 :         _weights[ 6]   = _weights[0];
     160             : 
     161         355 :         return;
     162             :       }
     163             : 
     164             :       // 2*8-3 = 13
     165         355 :     case TWELFTH:
     166             :     case THIRTEENTH:
     167             :       {
     168         355 :         _points.resize (8);
     169         355 :         _weights.resize(8);
     170             : 
     171         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     172         355 :         _points[ 1](0) = -8.7174014850960661533744576122066e-01_R;
     173         355 :         _points[ 2](0) = -5.9170018143314230214451073139795e-01_R;
     174         355 :         _points[ 3](0) = -2.0929921790247886876865726034535e-01_R;
     175         355 :         _points[ 4]    = -_points[3];
     176         355 :         _points[ 5]    = -_points[2];
     177         355 :         _points[ 6]    = -_points[1];
     178         355 :         _points[ 7]    = -_points[0];
     179             : 
     180         355 :         _weights[ 0]   = 3.5714285714285714285714285714286e-02_R;
     181         355 :         _weights[ 1]   = 2.1070422714350603938299206577576e-01_R;
     182         355 :         _weights[ 2]   = 3.4112269248350436476424067710775e-01_R;
     183         355 :         _weights[ 3]   = 4.1245879465870388156705297140221e-01_R;
     184         355 :         _weights[ 4]   = _weights[3];
     185         355 :         _weights[ 5]   = _weights[2];
     186         355 :         _weights[ 6]   = _weights[1];
     187         355 :         _weights[ 7]   = _weights[0];
     188             : 
     189         355 :         return;
     190             :       }
     191             : 
     192             :       // 2*9-3 = 15
     193         355 :     case FOURTEENTH:
     194             :     case FIFTEENTH:
     195             :       {
     196         355 :         _points.resize (9);
     197         355 :         _weights.resize(9);
     198             : 
     199         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     200         355 :         _points[ 1](0) = -8.9975799541146015731234524441834e-01_R;
     201         355 :         _points[ 2](0) = -6.7718627951073775344588542709134e-01_R;
     202         355 :         _points[ 3](0) = -3.6311746382617815871075206870866e-01_R;
     203         355 :         _points[ 4](0) = 0.;
     204         355 :         _points[ 5]    = -_points[3];
     205         355 :         _points[ 6]    = -_points[2];
     206         355 :         _points[ 7]    = -_points[1];
     207         355 :         _points[ 8]    = -_points[0];
     208             : 
     209         355 :         _weights[ 0]   = 2.7777777777777777777777777777778e-02_R;
     210         355 :         _weights[ 1]   = 1.6549536156080552504633972002921e-01_R;
     211         355 :         _weights[ 2]   = 2.7453871250016173528070561857937e-01_R;
     212         355 :         _weights[ 3]   = 3.4642851097304634511513153213972e-01_R;
     213         355 :         _weights[ 4]   = 3.7151927437641723356009070294785e-01_R;
     214         355 :         _weights[ 5]   = _weights[3];
     215         355 :         _weights[ 6]   = _weights[2];
     216         355 :         _weights[ 7]   = _weights[1];
     217         355 :         _weights[ 8]   = _weights[0];
     218             : 
     219         355 :         return;
     220             :       }
     221             : 
     222             :       // 2*10-3 = 17
     223         355 :     case SIXTEENTH:
     224             :     case SEVENTEENTH:
     225             :       {
     226         355 :         _points.resize (10);
     227         355 :         _weights.resize(10);
     228             : 
     229         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     230         355 :         _points[ 1](0) = -9.1953390816645881382893266082234e-01_R;
     231         355 :         _points[ 2](0) = -7.3877386510550507500310617485983e-01_R;
     232         355 :         _points[ 3](0) = -4.7792494981044449566117509273126e-01_R;
     233         355 :         _points[ 4](0) = -1.6527895766638702462621976595817e-01_R;
     234         355 :         _points[ 5]    = -_points[4];
     235         355 :         _points[ 6]    = -_points[3];
     236         355 :         _points[ 7]    = -_points[2];
     237         355 :         _points[ 8]    = -_points[1];
     238         355 :         _points[ 9]    = -_points[0];
     239             : 
     240         355 :         _weights[ 0]   = 2.2222222222222222222222222222222e-02_R;
     241         355 :         _weights[ 1]   = 1.3330599085107011112622717075539e-01_R;
     242         355 :         _weights[ 2]   = 2.2488934206312645211945782173105e-01_R;
     243         355 :         _weights[ 3]   = 2.9204268367968375787558225737444e-01_R;
     244         355 :         _weights[ 4]   = 3.2753976118389745665651052791689e-01_R;
     245         355 :         _weights[ 5]   = _weights[4];
     246         355 :         _weights[ 6]   = _weights[3];
     247         355 :         _weights[ 7]   = _weights[2];
     248         355 :         _weights[ 8]   = _weights[1];
     249         355 :         _weights[ 9]   = _weights[0];
     250             : 
     251         355 :         return;
     252             :       }
     253             : 
     254             :       // 2*11-3 = 19
     255         355 :     case EIGHTTEENTH:
     256             :     case NINETEENTH:
     257             :       {
     258         355 :         _points.resize (11);
     259         355 :         _weights.resize(11);
     260             : 
     261         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     262         355 :         _points[ 1](0) = -9.3400143040805913433227413609938e-01_R;
     263         355 :         _points[ 2](0) = -7.8448347366314441862241781610846e-01_R;
     264         355 :         _points[ 3](0) = -5.6523532699620500647096396947775e-01_R;
     265         355 :         _points[ 4](0) = -2.9575813558693939143191151555906e-01_R;
     266         355 :         _points[ 5](0) = 0.;
     267         355 :         _points[ 6]    = -_points[4];
     268         355 :         _points[ 7]    = -_points[3];
     269         355 :         _points[ 8]    = -_points[2];
     270         355 :         _points[ 9]    = -_points[1];
     271         355 :         _points[10]    = -_points[0];
     272             : 
     273         355 :         _weights[ 0]   = 1.8181818181818181818181818181818e-02_R;
     274         355 :         _weights[ 1]   = 1.0961227326699486446140344958035e-01_R;
     275         355 :         _weights[ 2]   = 1.8716988178030520410814152189943e-01_R;
     276         355 :         _weights[ 3]   = 2.4804810426402831404008486642187e-01_R;
     277         355 :         _weights[ 4]   = 2.8687912477900808867922240333154e-01_R;
     278         355 :         _weights[ 5]   = 3.0021759545569069378593188116998e-01_R;
     279         355 :         _weights[ 6]   = _weights[4];
     280         355 :         _weights[ 7]   = _weights[3];
     281         355 :         _weights[ 8]   = _weights[2];
     282         355 :         _weights[ 9]   = _weights[1];
     283         355 :         _weights[10]   = _weights[0];
     284             : 
     285         355 :         return;
     286             :       }
     287             : 
     288             :       // 2*12-3 = 21
     289         355 :     case TWENTIETH:
     290             :     case TWENTYFIRST:
     291             :       {
     292         355 :         _points.resize (12);
     293         355 :         _weights.resize(12);
     294             : 
     295         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     296         355 :         _points[ 1](0) = -9.4489927222288222340758013830322e-01_R;
     297         355 :         _points[ 2](0) = -8.1927932164400667834864158171690e-01_R;
     298         355 :         _points[ 3](0) = -6.3287615303186067766240485444366e-01_R;
     299         355 :         _points[ 4](0) = -3.9953094096534893226434979156697e-01_R;
     300         355 :         _points[ 5](0) = -1.3655293285492755486406185573969e-01_R;
     301         355 :         _points[ 6]    = -_points[5];
     302         355 :         _points[ 7]    = -_points[4];
     303         355 :         _points[ 8]    = -_points[3];
     304         355 :         _points[ 9]    = -_points[2];
     305         355 :         _points[10]    = -_points[1];
     306         355 :         _points[11]    = -_points[0];
     307             : 
     308         355 :         _weights[ 0]   = 1.5151515151515151515151515151515e-02_R;
     309         355 :         _weights[ 1]   = 9.1684517413196130668342594134079e-02_R;
     310         355 :         _weights[ 2]   = 1.5797470556437011516467106270034e-01_R;
     311         355 :         _weights[ 3]   = 2.1250841776102114535830207736687e-01_R;
     312         355 :         _weights[ 4]   = 2.5127560319920128029324441214760e-01_R;
     313         355 :         _weights[ 5]   = 2.7140524091069617700028833849960e-01_R;
     314         355 :         _weights[ 6]   = _weights[5];
     315         355 :         _weights[ 7]   = _weights[4];
     316         355 :         _weights[ 8]   = _weights[3];
     317         355 :         _weights[ 9]   = _weights[2];
     318         355 :         _weights[10]   = _weights[1];
     319         355 :         _weights[11]   = _weights[0];
     320             : 
     321         355 :         return;
     322             :       }
     323             : 
     324             :       // 2*13-3 = 23
     325         355 :     case TWENTYSECOND:
     326             :     case TWENTYTHIRD:
     327             :       {
     328         355 :         _points.resize (13);
     329         355 :         _weights.resize(13);
     330             : 
     331         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     332         355 :         _points[ 1](0) = -9.5330984664216391189690546475545e-01_R;
     333         355 :         _points[ 2](0) = -8.4634756465187231686592560709875e-01_R;
     334         355 :         _points[ 3](0) = -6.8618846908175742607275903956636e-01_R;
     335         355 :         _points[ 4](0) = -4.8290982109133620174693723363693e-01_R;
     336         355 :         _points[ 5](0) = -2.4928693010623999256867370037423e-01_R;
     337         355 :         _points[ 6](0) = 0.;
     338         355 :         _points[ 7]    = -_points[5];
     339         355 :         _points[ 8]    = -_points[4];
     340         355 :         _points[ 9]    = -_points[3];
     341         355 :         _points[10]    = -_points[2];
     342         355 :         _points[11]    = -_points[1];
     343         355 :         _points[12]    = -_points[0];
     344             : 
     345         355 :         _weights[ 0]   = 1.2820512820512820512820512820513e-02_R;
     346         355 :         _weights[ 1]   = 7.7801686746818927793588988333134e-02_R;
     347         355 :         _weights[ 2]   = 1.3498192668960834911991476258937e-01_R;
     348         355 :         _weights[ 3]   = 1.8364686520355009200749425874681e-01_R;
     349         355 :         _weights[ 4]   = 2.2076779356611008608553400837940e-01_R;
     350         355 :         _weights[ 5]   = 2.4401579030667635645857814836016e-01_R;
     351         355 :         _weights[ 6]   = 2.5193084933344673604413864154124e-01_R;
     352         355 :         _weights[ 7]   = _weights[5];
     353         355 :         _weights[ 8]   = _weights[4];
     354         355 :         _weights[ 9]   = _weights[3];
     355         355 :         _weights[10]   = _weights[2];
     356         355 :         _weights[11]   = _weights[1];
     357         355 :         _weights[12]   = _weights[0];
     358             : 
     359         355 :         return;
     360             :       }
     361             : 
     362             :       // 2*14-3 = 25
     363         355 :     case TWENTYFOURTH:
     364             :     case TWENTYFIFTH:
     365             :       {
     366         355 :         _points.resize (14);
     367         355 :         _weights.resize(14);
     368             : 
     369         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     370         355 :         _points[ 1](0) = -9.5993504526726090135510016201542e-01_R;
     371         355 :         _points[ 2](0) = -8.6780105383034725100022020290826e-01_R;
     372         355 :         _points[ 3](0) = -7.2886859909132614058467240052088e-01_R;
     373         355 :         _points[ 4](0) = -5.5063940292864705531662270585908e-01_R;
     374         355 :         _points[ 5](0) = -3.4272401334271284504390340364167e-01_R;
     375         355 :         _points[ 6](0) = -1.1633186888370386765877670973616e-01_R;
     376         355 :         _points[ 7]    = -_points[6];
     377         355 :         _points[ 8]    = -_points[5];
     378         355 :         _points[ 9]    = -_points[4];
     379         355 :         _points[10]    = -_points[3];
     380         355 :         _points[11]    = -_points[2];
     381         355 :         _points[12]    = -_points[1];
     382         355 :         _points[13]    = -_points[0];
     383             : 
     384         355 :         _weights[ 0]   = 1.0989010989010989010989010989011e-02_R;
     385         355 :         _weights[ 1]   = 6.6837284497681284634070660746053e-02_R;
     386         355 :         _weights[ 2]   = 1.1658665589871165154099667065465e-01_R;
     387         355 :         _weights[ 3]   = 1.6002185176295214241282099798759e-01_R;
     388         355 :         _weights[ 4]   = 1.9482614937341611864033177837588e-01_R;
     389         355 :         _weights[ 5]   = 2.1912625300977075487116252395417e-01_R;
     390         355 :         _weights[ 6]   = 2.3161279446845705888962835729264e-01_R;
     391         355 :         _weights[ 7]   = _weights[6];
     392         355 :         _weights[ 8]   = _weights[5];
     393         355 :         _weights[ 9]   = _weights[4];
     394         355 :         _weights[10]   = _weights[3];
     395         355 :         _weights[11]   = _weights[2];
     396         355 :         _weights[12]   = _weights[1];
     397         355 :         _weights[13]   = _weights[0];
     398             : 
     399         355 :         return;
     400             :       }
     401             : 
     402             :       // 2*15-3 = 27
     403         355 :     case TWENTYSIXTH:
     404             :     case TWENTYSEVENTH:
     405             :       {
     406         355 :         _points.resize (15);
     407         355 :         _weights.resize(15);
     408             : 
     409         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     410         355 :         _points[ 1](0) = -9.6524592650383857279585139206960e-01_R;
     411         355 :         _points[ 2](0) = -8.8508204422297629882540163148223e-01_R;
     412         355 :         _points[ 3](0) = -7.6351968995181520070411847597629e-01_R;
     413         355 :         _points[ 4](0) = -6.0625320546984571112352993863673e-01_R;
     414         355 :         _points[ 5](0) = -4.2063805471367248092189693873858e-01_R;
     415         355 :         _points[ 6](0) = -2.1535395536379423822567944627292e-01_R;
     416         355 :         _points[ 7](0) = 0.;
     417         355 :         _points[ 8]    = -_points[6];
     418         355 :         _points[ 9]    = -_points[5];
     419         355 :         _points[10]    = -_points[4];
     420         355 :         _points[11]    = -_points[3];
     421         355 :         _points[12]    = -_points[2];
     422         355 :         _points[13]    = -_points[1];
     423         355 :         _points[14]    = -_points[0];
     424             : 
     425         355 :         _weights[ 0]   = 9.5238095238095238095238095238095e-03_R;
     426         355 :         _weights[ 1]   = 5.8029893028601249096880584025282e-02_R;
     427         355 :         _weights[ 2]   = 1.0166007032571806760366617078880e-01_R;
     428         355 :         _weights[ 3]   = 1.4051169980242810946044680564367e-01_R;
     429         355 :         _weights[ 4]   = 1.7278964725360094905207709940835e-01_R;
     430         355 :         _weights[ 5]   = 1.9698723596461335609250034650741e-01_R;
     431         355 :         _weights[ 6]   = 2.1197358592682092012743007697722e-01_R;
     432         355 :         _weights[ 7]   = 2.1704811634881564951495021425091e-01_R;
     433         355 :         _weights[ 8]   = _weights[6];
     434         355 :         _weights[ 9]   = _weights[5];
     435         355 :         _weights[10]   = _weights[4];
     436         355 :         _weights[11]   = _weights[3];
     437         355 :         _weights[12]   = _weights[2];
     438         355 :         _weights[13]   = _weights[1];
     439         355 :         _weights[14]   = _weights[0];
     440             : 
     441         355 :         return;
     442             :       }
     443             : 
     444             :       // 2*16-3 = 29
     445         355 :     case TWENTYEIGHTH:
     446             :     case TWENTYNINTH:
     447             :       {
     448         355 :         _points.resize (16);
     449         355 :         _weights.resize(16);
     450             : 
     451         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     452         355 :         _points[ 1](0) = -9.6956804627021793295224273836746e-01_R;
     453         355 :         _points[ 2](0) = -8.9920053309347209299462826151985e-01_R;
     454         355 :         _points[ 3](0) = -7.9200829186181506393108827096315e-01_R;
     455         355 :         _points[ 4](0) = -6.5238870288249308946788321964058e-01_R;
     456         355 :         _points[ 5](0) = -4.8605942188713761178189078584687e-01_R;
     457         355 :         _points[ 6](0) = -2.9983046890076320809835345472230e-01_R;
     458         355 :         _points[ 7](0) = -1.0132627352194944784303300504592e-01_R;
     459         355 :         _points[ 8]    = -_points[7];
     460         355 :         _points[ 9]    = -_points[6];
     461         355 :         _points[10]    = -_points[5];
     462         355 :         _points[11]    = -_points[4];
     463         355 :         _points[12]    = -_points[3];
     464         355 :         _points[13]    = -_points[2];
     465         355 :         _points[14]    = -_points[1];
     466         355 :         _points[15]    = -_points[0];
     467             : 
     468         355 :         _weights[ 0]   = 8.3333333333333333333333333333333e-03_R;
     469         355 :         _weights[ 1]   = 5.0850361005919905403244919565455e-02_R;
     470         355 :         _weights[ 2]   = 8.9393697325930800991052080166084e-02_R;
     471         355 :         _weights[ 3]   = 1.2425538213251409834953633265731e-01_R;
     472         355 :         _weights[ 4]   = 1.5402698080716428081564494048499e-01_R;
     473         355 :         _weights[ 5]   = 1.7749191339170412530107566952836e-01_R;
     474         355 :         _weights[ 6]   = 1.9369002382520358431691359885352e-01_R;
     475         355 :         _weights[ 7]   = 2.0195830817822987148919912541094e-01_R;
     476         355 :         _weights[ 8]   = _weights[7];
     477         355 :         _weights[ 9]   = _weights[6];
     478         355 :         _weights[10]   = _weights[5];
     479         355 :         _weights[11]   = _weights[4];
     480         355 :         _weights[12]   = _weights[3];
     481         355 :         _weights[13]   = _weights[2];
     482         355 :         _weights[14]   = _weights[1];
     483         355 :         _weights[15]   = _weights[0];
     484             : 
     485         355 :         return;
     486             :       }
     487             : 
     488             :       // 2*17-3 = 31
     489         355 :     case THIRTIETH:
     490             :     case THIRTYFIRST:
     491             :       {
     492         355 :         _points.resize (17);
     493         355 :         _weights.resize(17);
     494             : 
     495         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     496         355 :         _points[ 1](0) = -9.7313217663141831415697950187372e-01_R;
     497         355 :         _points[ 2](0) = -9.1087999591557359562380250639773e-01_R;
     498         355 :         _points[ 3](0) = -8.1569625122177030710675055323753e-01_R;
     499         355 :         _points[ 4](0) = -6.9102898062768470539491935737245e-01_R;
     500         355 :         _points[ 5](0) = -5.4138539933010153912373340750406e-01_R;
     501         355 :         _points[ 6](0) = -3.7217443356547704190723468073526e-01_R;
     502         355 :         _points[ 7](0) = -1.8951197351831738830426301475311e-01_R;
     503         355 :         _points[ 8](0) = 0.;
     504         355 :         _points[ 9]    = -_points[7];
     505         355 :         _points[10]    = -_points[6];
     506         355 :         _points[11]    = -_points[5];
     507         355 :         _points[12]    = -_points[4];
     508         355 :         _points[13]    = -_points[3];
     509         355 :         _points[14]    = -_points[2];
     510         355 :         _points[15]    = -_points[1];
     511         355 :         _points[16]    = -_points[0];
     512             : 
     513         355 :         _weights[ 0]   = 7.3529411764705882352941176470588e-03_R;
     514         355 :         _weights[ 1]   = 4.4921940543254209647400954623212e-02_R;
     515         355 :         _weights[ 2]   = 7.9198270503687119190264429952835e-02_R;
     516         355 :         _weights[ 3]   = 1.1059290900702816137577270522008e-01_R;
     517         355 :         _weights[ 4]   = 1.3798774620192655905620157495403e-01_R;
     518         355 :         _weights[ 5]   = 1.6039466199762153951632836586475e-01_R;
     519         355 :         _weights[ 6]   = 1.7700425351565787043694574536329e-01_R;
     520         355 :         _weights[ 7]   = 1.8721633967761923589208848286062e-01_R;
     521         355 :         _weights[ 8]   = 1.9066187475346943329940724702825e-01_R;
     522         355 :         _weights[ 9]   = _weights[7];
     523         355 :         _weights[10]   = _weights[6];
     524         355 :         _weights[11]   = _weights[5];
     525         355 :         _weights[12]   = _weights[4];
     526         355 :         _weights[13]   = _weights[3];
     527         355 :         _weights[14]   = _weights[2];
     528         355 :         _weights[15]   = _weights[1];
     529         355 :         _weights[16]   = _weights[0];
     530             : 
     531         355 :         return;
     532             :       }
     533             : 
     534             :       // 2*18-3 = 33
     535         355 :     case THIRTYSECOND:
     536             :     case THIRTYTHIRD:
     537             :       {
     538         355 :         _points.resize (18);
     539         355 :         _weights.resize(18);
     540             : 
     541         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     542         355 :         _points[ 1](0) = -9.7610555741219854286451892434170e-01_R;
     543         355 :         _points[ 2](0) = -9.2064918534753387383785462543128e-01_R;
     544         355 :         _points[ 3](0) = -8.3559353521809021371364636232794e-01_R;
     545         355 :         _points[ 4](0) = -7.2367932928324268130621036530207e-01_R;
     546         355 :         _points[ 5](0) = -5.8850483431866176117353589319356e-01_R;
     547         355 :         _points[ 6](0) = -4.3441503691212397534228713674067e-01_R;
     548         355 :         _points[ 7](0) = -2.6636265287828098416766533202560e-01_R;
     549         355 :         _points[ 8](0) = -8.9749093484652111022645010088562e-02_R;
     550         355 :         _points[ 9]    = -_points[8];
     551         355 :         _points[10]    = -_points[7];
     552         355 :         _points[11]    = -_points[6];
     553         355 :         _points[12]    = -_points[5];
     554         355 :         _points[13]    = -_points[4];
     555         355 :         _points[14]    = -_points[3];
     556         355 :         _points[15]    = -_points[2];
     557         355 :         _points[16]    = -_points[1];
     558         355 :         _points[17]    = -_points[0];
     559             : 
     560         355 :         _weights[ 0]   = 6.5359477124183006535947712418301e-03_R;
     561         355 :         _weights[ 1]   = 3.9970628810914066137599176410101e-02_R;
     562         355 :         _weights[ 2]   = 7.0637166885633664999222960167786e-02_R;
     563         355 :         _weights[ 3]   = 9.9016271717502802394423605318672e-02_R;
     564         355 :         _weights[ 4]   = 1.2421053313296710026339635889675e-01_R;
     565         355 :         _weights[ 5]   = 1.4541196157380226798300321049443e-01_R;
     566         355 :         _weights[ 6]   = 1.6193951723760248926432670670023e-01_R;
     567         355 :         _weights[ 7]   = 1.7326210948945622601061440382668e-01_R;
     568         355 :         _weights[ 8]   = 1.7901586343970308229381880694353e-01_R;
     569         355 :         _weights[ 9]   = _weights[8];
     570         355 :         _weights[10]   = _weights[7];
     571         355 :         _weights[11]   = _weights[6];
     572         355 :         _weights[12]   = _weights[5];
     573         355 :         _weights[13]   = _weights[4];
     574         355 :         _weights[14]   = _weights[3];
     575         355 :         _weights[15]   = _weights[2];
     576         355 :         _weights[16]   = _weights[1];
     577         355 :         _weights[17]   = _weights[0];
     578             : 
     579         355 :         return;
     580             :       }
     581             : 
     582             :       // 2*19-3 = 35
     583         355 :     case THIRTYFOURTH:
     584             :     case THIRTYFIFTH:
     585             :       {
     586         355 :         _points.resize (19);
     587         355 :         _weights.resize(19);
     588             : 
     589         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     590         355 :         _points[ 1](0) = -9.7861176622208009515263406311022e-01_R;
     591         355 :         _points[ 2](0) = -9.2890152815258624371794025879655e-01_R;
     592         355 :         _points[ 3](0) = -8.5246057779664609308595597004106e-01_R;
     593         355 :         _points[ 4](0) = -7.5149420255261301416363748963394e-01_R;
     594         355 :         _points[ 5](0) = -6.2890813726522049776683230622873e-01_R;
     595         355 :         _points[ 6](0) = -4.8822928568071350277790963762492e-01_R;
     596         355 :         _points[ 7](0) = -3.3350484782449861029850010384493e-01_R;
     597         355 :         _points[ 8](0) = -1.6918602340928157137515415344488e-01_R;
     598         355 :         _points[ 9](0) = 0.;
     599         355 :         _points[10]    = -_points[8];
     600         355 :         _points[11]    = -_points[7];
     601         355 :         _points[12]    = -_points[6];
     602         355 :         _points[13]    = -_points[5];
     603         355 :         _points[14]    = -_points[4];
     604         355 :         _points[15]    = -_points[3];
     605         355 :         _points[16]    = -_points[2];
     606         355 :         _points[17]    = -_points[1];
     607         355 :         _points[18]    = -_points[0];
     608             : 
     609         355 :         _weights[ 0]   = 5.8479532163742690058479532163743e-03_R;
     610         355 :         _weights[ 1]   = 3.5793365186176477115425569035122e-02_R;
     611         355 :         _weights[ 2]   = 6.3381891762629736851695690418317e-02_R;
     612         355 :         _weights[ 3]   = 8.9131757099207084448008790556153e-02_R;
     613         355 :         _weights[ 4]   = 1.1231534147730504407091001546378e-01_R;
     614         355 :         _weights[ 5]   = 1.3226728044875077692604673390973e-01_R;
     615         355 :         _weights[ 6]   = 1.4841394259593888500968064366841e-01_R;
     616         355 :         _weights[ 7]   = 1.6029092404406124197991096818359e-01_R;
     617         355 :         _weights[ 8]   = 1.6755658452714286727013727774026e-01_R;
     618         355 :         _weights[ 9]   = 1.7000191928482723464467271561652e-01_R;
     619         355 :         _weights[10]   = _weights[8];
     620         355 :         _weights[11]   = _weights[7];
     621         355 :         _weights[12]   = _weights[6];
     622         355 :         _weights[13]   = _weights[5];
     623         355 :         _weights[14]   = _weights[4];
     624         355 :         _weights[15]   = _weights[3];
     625         355 :         _weights[16]   = _weights[2];
     626         355 :         _weights[17]   = _weights[1];
     627         355 :         _weights[18]   = _weights[0];
     628             : 
     629         355 :         return;
     630             :       }
     631             : 
     632             :       // 2*20-3 = 37
     633         355 :     case THIRTYSIXTH:
     634             :     case THIRTYSEVENTH:
     635             :       {
     636         355 :         _points.resize (20);
     637         355 :         _weights.resize(20);
     638             : 
     639         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     640         355 :         _points[ 1](0) = -9.8074370489391417192544643858423e-01_R;
     641         355 :         _points[ 2](0) = -9.3593449881266543571618158493063e-01_R;
     642         355 :         _points[ 3](0) = -8.6687797808995014130984721461629e-01_R;
     643         355 :         _points[ 4](0) = -7.7536826095205587041431752759469e-01_R;
     644         355 :         _points[ 5](0) = -6.6377640229031128984640332297116e-01_R;
     645         355 :         _points[ 6](0) = -5.3499286403188626164813596182898e-01_R;
     646         355 :         _points[ 7](0) = -3.9235318371390929938647470381582e-01_R;
     647         355 :         _points[ 8](0) = -2.3955170592298649518240135692709e-01_R;
     648         355 :         _points[ 9](0) = -8.0545937238821837975944518159554e-02_R;
     649         355 :         _points[10]    = -_points[9];
     650         355 :         _points[11]    = -_points[8];
     651         355 :         _points[12]    = -_points[7];
     652         355 :         _points[13]    = -_points[6];
     653         355 :         _points[14]    = -_points[5];
     654         355 :         _points[15]    = -_points[4];
     655         355 :         _points[16]    = -_points[3];
     656         355 :         _points[17]    = -_points[2];
     657         355 :         _points[18]    = -_points[1];
     658         355 :         _points[19]    = -_points[0];
     659             : 
     660         355 :         _weights[ 0]   = 5.2631578947368421052631578947368e-03_R;
     661         355 :         _weights[ 1]   = 3.2237123188488941491605028117294e-02_R;
     662         355 :         _weights[ 2]   = 5.7181802127566826004753627173243e-02_R;
     663         355 :         _weights[ 3]   = 8.0631763996119603144776846113721e-02_R;
     664         355 :         _weights[ 4]   = 1.0199149969945081568378120573289e-01_R;
     665         355 :         _weights[ 5]   = 1.2070922762867472509942970500239e-01_R;
     666         355 :         _weights[ 6]   = 1.3630048235872418448978079298903e-01_R;
     667         355 :         _weights[ 7]   = 1.4836155407091682581471301373397e-01_R;
     668         355 :         _weights[ 8]   = 1.5658010264747548715816989679364e-01_R;
     669         355 :         _weights[ 9]   = 1.6074328638784574900772672644908e-01_R;
     670         355 :         _weights[10]   = _weights[9];
     671         355 :         _weights[11]   = _weights[8];
     672         355 :         _weights[12]   = _weights[7];
     673         355 :         _weights[13]   = _weights[6];
     674         355 :         _weights[14]   = _weights[5];
     675         355 :         _weights[15]   = _weights[4];
     676         355 :         _weights[16]   = _weights[3];
     677         355 :         _weights[17]   = _weights[2];
     678         355 :         _weights[18]   = _weights[1];
     679         355 :         _weights[19]   = _weights[0];
     680             : 
     681         355 :         return;
     682             :       }
     683             : 
     684             :       // 2*21-3 = 39
     685         355 :     case THIRTYEIGHTH:
     686             :     case THIRTYNINTH:
     687             :       {
     688         355 :         _points.resize (21);
     689         355 :         _weights.resize(21);
     690             : 
     691         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     692         355 :         _points[ 1](0) = -9.8257229660454802823448127655541e-01_R;
     693         355 :         _points[ 2](0) = -9.4197629695974553429610265066144e-01_R;
     694         355 :         _points[ 3](0) = -8.7929475532359046445115359630494e-01_R;
     695         355 :         _points[ 4](0) = -7.9600192607771240474431258966036e-01_R;
     696         355 :         _points[ 5](0) = -6.9405102606222323262731639319467e-01_R;
     697         355 :         _points[ 6](0) = -5.7583196026183068692702187033809e-01_R;
     698         355 :         _points[ 7](0) = -4.4411578327900210119451634960735e-01_R;
     699         355 :         _points[ 8](0) = -3.0198985650876488727535186785875e-01_R;
     700         355 :         _points[ 9](0) = -1.5278551580218546600635832848567e-01_R;
     701         355 :         _points[10](0) = 0.;
     702         355 :         _points[11]    = -_points[9];
     703         355 :         _points[12]    = -_points[8];
     704         355 :         _points[13]    = -_points[7];
     705         355 :         _points[14]    = -_points[6];
     706         355 :         _points[15]    = -_points[5];
     707         355 :         _points[16]    = -_points[4];
     708         355 :         _points[17]    = -_points[3];
     709         355 :         _points[18]    = -_points[2];
     710         355 :         _points[19]    = -_points[1];
     711         355 :         _points[20]    = -_points[0];
     712             : 
     713         355 :         _weights[ 0]   = 4.7619047619047619047619047619048e-03_R;
     714         355 :         _weights[ 1]   = 2.9184840098505458609458543613171e-02_R;
     715         355 :         _weights[ 2]   = 5.1843169000849625072722971852830e-02_R;
     716         355 :         _weights[ 3]   = 7.3273918185074144252547861041894e-02_R;
     717         355 :         _weights[ 4]   = 9.2985467957886065301137664149214e-02_R;
     718         355 :         _weights[ 5]   = 1.1051708321912333526700048678439e-01_R;
     719         355 :         _weights[ 6]   = 1.2545812119086894801515753570800e-01_R;
     720         355 :         _weights[ 7]   = 1.3745846286004134358089961741515e-01_R;
     721         355 :         _weights[ 8]   = 1.4623686244797745926727053063439e-01_R;
     722         355 :         _weights[ 9]   = 1.5158757511168138445325068150529e-01_R;
     723         355 :         _weights[10]   = 1.5338519033217494855158440506754e-01_R;
     724         355 :         _weights[11]   = _weights[9];
     725         355 :         _weights[12]   = _weights[8];
     726         355 :         _weights[13]   = _weights[7];
     727         355 :         _weights[14]   = _weights[6];
     728         355 :         _weights[15]   = _weights[5];
     729         355 :         _weights[16]   = _weights[4];
     730         355 :         _weights[17]   = _weights[3];
     731         355 :         _weights[18]   = _weights[2];
     732         355 :         _weights[19]   = _weights[1];
     733         355 :         _weights[20]   = _weights[0];
     734             : 
     735         355 :         return;
     736             :       }
     737             : 
     738             :       // 2*22-3 = 41
     739         355 :     case FORTIETH:
     740             :     case FORTYFIRST:
     741             :       {
     742         355 :         _points.resize (22);
     743         355 :         _weights.resize(22);
     744             : 
     745         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     746         355 :         _points[ 1](0) = -9.8415243845764617655228962221207e-01_R;
     747         355 :         _points[ 2](0) = -9.4720428399922868052421376661573e-01_R;
     748         355 :         _points[ 3](0) = -8.9006229019090447052965782577909e-01_R;
     749         355 :         _points[ 4](0) = -8.1394892761192113604544184805614e-01_R;
     750         355 :         _points[ 5](0) = -7.2048723996120215811988189639847e-01_R;
     751         355 :         _points[ 6](0) = -6.1166943828425897122621160586993e-01_R;
     752         355 :         _points[ 7](0) = -4.8981487518990234980875123568327e-01_R;
     753         355 :         _points[ 8](0) = -3.5752071013891953806095728024018e-01_R;
     754         355 :         _points[ 9](0) = -2.1760658515928504178795509346539e-01_R;
     755         355 :         _points[10](0) = -7.3054540010898334761088790464107e-02_R;
     756         355 :         _points[11]    = -_points[10];
     757         355 :         _points[12]    = -_points[9];
     758         355 :         _points[13]    = -_points[8];
     759         355 :         _points[14]    = -_points[7];
     760         355 :         _points[15]    = -_points[6];
     761         355 :         _points[16]    = -_points[5];
     762         355 :         _points[17]    = -_points[4];
     763         355 :         _points[18]    = -_points[3];
     764         355 :         _points[19]    = -_points[2];
     765         355 :         _points[20]    = -_points[1];
     766         355 :         _points[21]    = -_points[0];
     767             : 
     768         355 :         _weights[ 0]   = 4.3290043290043290043290043290043e-03_R;
     769         355 :         _weights[ 1]   = 2.6545747682501757911627904520543e-02_R;
     770         355 :         _weights[ 2]   = 4.7214465293740752123775734864792e-02_R;
     771         355 :         _weights[ 3]   = 6.6865605864553076012404194157097e-02_R;
     772         355 :         _weights[ 4]   = 8.5090060391838447815711236095748e-02_R;
     773         355 :         _weights[ 5]   = 1.0150057480164767437243730374960e-01_R;
     774         355 :         _weights[ 6]   = 1.1574764465393906659003636772146e-01_R;
     775         355 :         _weights[ 7]   = 1.2752769665343027553084445930883e-01_R;
     776         355 :         _weights[ 8]   = 1.3658968861374142668617736220617e-01_R;
     777         355 :         _weights[ 9]   = 1.4274049227136140033623599356679e-01_R;
     778         355 :         _weights[10]   = 1.4584901944424179361642043947997e-01_R;
     779         355 :         _weights[11]   = _weights[10];
     780         355 :         _weights[12]   = _weights[9];
     781         355 :         _weights[13]   = _weights[8];
     782         355 :         _weights[14]   = _weights[7];
     783         355 :         _weights[15]   = _weights[6];
     784         355 :         _weights[16]   = _weights[5];
     785         355 :         _weights[17]   = _weights[4];
     786         355 :         _weights[18]   = _weights[3];
     787         355 :         _weights[19]   = _weights[2];
     788         355 :         _weights[20]   = _weights[1];
     789         355 :         _weights[21]   = _weights[0];
     790             : 
     791         355 :         return;
     792             :       }
     793             : 
     794             :       // 2*23-3 = 43
     795         355 :     case FORTYSECOND:
     796             :     case FORTYTHIRD:
     797             :       {
     798         355 :         _points.resize (23);
     799         355 :         _weights.resize(23);
     800             : 
     801         355 :         _points[ 0](0) = -1.0000000000000000000000000000000e+00_R;
     802         355 :         _points[ 1](0) = -9.8552715587873257808146276673810e-01_R;
     803         355 :         _points[ 2](0) = -9.5175795571071020413563967985143e-01_R;
     804         355 :         _points[ 3](0) = -8.9945855804034501095016032034737e-01_R;
     805         355 :         _points[ 4](0) = -8.2965109665128588622320061929000e-01_R;
     806         355 :         _points[ 5](0) = -7.4369504117206068394516354306700e-01_R;
     807         355 :         _points[ 6](0) = -6.4326364446013620847614553360277e-01_R;
     808         355 :         _points[ 7](0) = -5.3031177113684416813011532015230e-01_R;
     809         355 :         _points[ 8](0) = -4.0703793791447482919595048821510e-01_R;
     810         355 :         _points[ 9](0) = -2.7584154894579306710687763267914e-01_R;
     811         355 :         _points[10](0) = -1.3927620404066839859186261298277e-01_R;
     812         355 :         _points[11](0) = 0.;
     813         355 :         _points[12]    = -_points[10];
     814         355 :         _points[13]    = -_points[9];
     815         355 :         _points[14]    = -_points[8];
     816         355 :         _points[15]    = -_points[7];
     817         355 :         _points[16]    = -_points[6];
     818         355 :         _points[17]    = -_points[5];
     819         355 :         _points[18]    = -_points[4];
     820         355 :         _points[19]    = -_points[3];
     821         355 :         _points[20]    = -_points[2];
     822         355 :         _points[21]    = -_points[1];
     823         355 :         _points[22]    = -_points[0];
     824             : 
     825         355 :         _weights[ 0]   = 3.9525691699604743083003952569170e-03_R;
     826         355 :         _weights[ 1]   = 2.4248600771531736517399658937097e-02_R;
     827         355 :         _weights[ 2]   = 4.3175871170241834748876465612042e-02_R;
     828         355 :         _weights[ 3]   = 6.1252477129554206381382847440355e-02_R;
     829         355 :         _weights[ 4]   = 7.8135449475569989741934255347965e-02_R;
     830         355 :         _weights[ 5]   = 9.3497246163512341833500706906697e-02_R;
     831         355 :         _weights[ 6]   = 1.0703910172433651153518362791547e-01_R;
     832         355 :         _weights[ 7]   = 1.1849751066274913130212600472426e-01_R;
     833         355 :         _weights[ 8]   = 1.2764947470175887663614855305567e-01_R;
     834         355 :         _weights[ 9]   = 1.3431687263860381990156489770071e-01_R;
     835         355 :         _weights[10]   = 1.3836993638580739452350273386294e-01_R;
     836         355 :         _weights[11]   = 1.3972978001274736514015970647975e-01_R;
     837         355 :         _weights[12]   = _weights[10];
     838         355 :         _weights[13]   = _weights[9];
     839         355 :         _weights[14]   = _weights[8];
     840         355 :         _weights[15]   = _weights[7];
     841         355 :         _weights[16]   = _weights[6];
     842         355 :         _weights[17]   = _weights[5];
     843         355 :         _weights[18]   = _weights[4];
     844         355 :         _weights[19]   = _weights[3];
     845         355 :         _weights[20]   = _weights[2];
     846         355 :         _weights[21]   = _weights[1];
     847         355 :         _weights[22]   = _weights[0];
     848             : 
     849         355 :         return;
     850             :       }
     851             : 
     852           0 :     default:
     853           0 :       libmesh_error_msg("Quadrature rule " << _order << " not supported!");
     854             :     }
     855             : }
     856             : 
     857             : } // namespace libMesh

Generated by: LCOV version 1.14