12 #include "../quadinterpolator.hpp"
22 namespace quadrature_interpolator
28 void TensorValues<QVectorLayout::byVDIM>(
const int NE,
30 const DofToQuad &maps,
34 if (NE == 0) {
return; }
35 const int dim = maps.FE->GetDim();
36 const int D1D = maps.ndof;
37 const int Q1D = maps.nqpt;
38 const double *B = maps.B.Read();
39 const double *X = e_vec.Read();
40 double *Y = q_val.Write();
44 const int id = (vdim<<8) | (D1D<<4) | Q1D;
49 <<
" are not supported!");
50 MFEM_VERIFY(Q1D <=
MAX_Q1D,
"Quadrature rules with more than "
51 <<
MAX_Q1D <<
" 1D points are not supported!");
52 Values1D<L>(NE, B, X, Y, vdim, D1D, Q1D);
59 case 0x124:
return Values2D<L,1,2,4,8>(NE,B,X,Y);
60 case 0x136:
return Values2D<L,1,3,6,4>(NE,B,X,Y);
61 case 0x148:
return Values2D<L,1,4,8,2>(NE,B,X,Y);
63 case 0x224:
return Values2D<L,2,2,4,8>(NE,B,X,Y);
64 case 0x234:
return Values2D<L,2,3,4,8>(NE,B,X,Y);
65 case 0x236:
return Values2D<L,2,3,6,4>(NE,B,X,Y);
66 case 0x248:
return Values2D<L,2,4,8,2>(NE,B,X,Y);
72 MFEM_VERIFY(D1D <= MD,
"Orders higher than " << MD-1
73 <<
" are not supported!");
74 MFEM_VERIFY(Q1D <= MQ,
"Quadrature rules with more than "
75 << MQ <<
" 1D points are not supported!");
76 Values2D<L,0,0,0,0,MD,MQ>(NE,B,X,Y,vdim,D1D,Q1D);
85 case 0x124:
return Values3D<L,1,2,4>(NE,B,X,Y);
86 case 0x136:
return Values3D<L,1,3,6>(NE,B,X,Y);
87 case 0x148:
return Values3D<L,1,4,8>(NE,B,X,Y);
89 case 0x324:
return Values3D<L,3,2,4>(NE,B,X,Y);
90 case 0x336:
return Values3D<L,3,3,6>(NE,B,X,Y);
91 case 0x348:
return Values3D<L,3,4,8>(NE,B,X,Y);
94 case 0x322:
return Values3D<L,3,2,2>(NE,B,X,Y);
95 case 0x333:
return Values3D<L,3,3,3>(NE,B,X,Y);
96 case 0x344:
return Values3D<L,3,4,4>(NE,B,X,Y);
97 case 0x355:
return Values3D<L,3,5,5>(NE,B,X,Y);
98 case 0x366:
return Values3D<L,3,6,6>(NE,B,X,Y);
99 case 0x377:
return Values3D<L,3,7,7>(NE,B,X,Y);
100 case 0x388:
return Values3D<L,3,8,8>(NE,B,X,Y);
101 case 0x399:
return Values3D<L,3,9,9>(NE,B,X,Y);
105 constexpr
int MD = 8;
106 constexpr
int MQ = 8;
107 MFEM_VERIFY(D1D <= MD,
"Orders higher than " << MD-1
108 <<
" are not supported!");
109 MFEM_VERIFY(Q1D <= MQ,
"Quadrature rules with more than "
110 << MQ <<
" 1D points are not supported!");
111 Values3D<L,0,0,0,MD,MQ>(NE,B,X,Y,vdim,D1D,Q1D);
116 mfem::out <<
"Unknown kernel 0x" << std::hex <<
id << std::endl;
117 MFEM_ABORT(
"Kernel not supported yet");
QVectorLayout
Type describing possible layouts for Q-vectors.
OutStream out(std::cout)
Global stream used by the library for standard output. Initially it uses the same std::streambuf as s...
VDIM x NQPT x NE (values) / VDIM x DIM x NQPT x NE (grads)