xref: /libCEED/tests/t410-qfunction.c (revision 4fee36f0a30516a0b5ad51bf7eb3b32d83efd623)
1288c0443SJeremy L Thompson /// @file
2d1d35e2fSjeremylt /// Test creation, evaluation, and destruction for QFunction by name
3d1d35e2fSjeremylt /// \test Test creation, evaluation, and destruction for QFunction by name
4288c0443SJeremy L Thompson #include <ceed.h>
5288c0443SJeremy L Thompson 
6288c0443SJeremy L Thompson int main(int argc, char **argv) {
7288c0443SJeremy L Thompson   Ceed          ceed;
8288c0443SJeremy L Thompson   CeedVector    in[16], out[16];
9*4fee36f0SJeremy L Thompson   CeedVector    q_data, dx, w, u, v;
10288c0443SJeremy L Thompson   CeedQFunction qf_setup, qf_mass;
11*4fee36f0SJeremy L Thompson   CeedInt       q = 8;
12*4fee36f0SJeremy L Thompson   CeedScalar    v_true[q];
13288c0443SJeremy L Thompson 
14288c0443SJeremy L Thompson   CeedInit(argv[1], &ceed);
15288c0443SJeremy L Thompson 
16*4fee36f0SJeremy L Thompson   CeedVectorCreate(ceed, q, &dx);
17*4fee36f0SJeremy L Thompson   CeedVectorCreate(ceed, q, &w);
18*4fee36f0SJeremy L Thompson   CeedVectorCreate(ceed, q, &u);
19*4fee36f0SJeremy L Thompson   {
20*4fee36f0SJeremy L Thompson     CeedScalar dx_array[q], w_array[q], u_array[q];
21*4fee36f0SJeremy L Thompson 
22*4fee36f0SJeremy L Thompson     for (CeedInt i = 0; i < q; i++) {
23*4fee36f0SJeremy L Thompson       CeedScalar x = 2. * i / (q - 1) - 1;
24*4fee36f0SJeremy L Thompson       dx_array[i]  = 1;
25*4fee36f0SJeremy L Thompson       w_array[i]   = 1 - x * x;
26*4fee36f0SJeremy L Thompson       u_array[i]   = 2 + 3 * x + 5 * x * x;
27*4fee36f0SJeremy L Thompson       v_true[i]    = w_array[i] * u_array[i];
28*4fee36f0SJeremy L Thompson     }
29*4fee36f0SJeremy L Thompson     CeedVectorSetArray(dx, CEED_MEM_HOST, CEED_COPY_VALUES, dx_array);
30*4fee36f0SJeremy L Thompson     CeedVectorSetArray(w, CEED_MEM_HOST, CEED_COPY_VALUES, w_array);
31*4fee36f0SJeremy L Thompson     CeedVectorSetArray(u, CEED_MEM_HOST, CEED_COPY_VALUES, u_array);
32*4fee36f0SJeremy L Thompson   }
33*4fee36f0SJeremy L Thompson   CeedVectorCreate(ceed, q, &v);
34*4fee36f0SJeremy L Thompson   CeedVectorSetValue(v, 0);
35*4fee36f0SJeremy L Thompson   CeedVectorCreate(ceed, q, &q_data);
36*4fee36f0SJeremy L Thompson   CeedVectorSetValue(q_data, 0);
37*4fee36f0SJeremy L Thompson 
38288c0443SJeremy L Thompson   CeedQFunctionCreateInteriorByName(ceed, "Mass1DBuild", &qf_setup);
39*4fee36f0SJeremy L Thompson   {
40*4fee36f0SJeremy L Thompson     in[0]  = dx;
41*4fee36f0SJeremy L Thompson     in[1]  = w;
42*4fee36f0SJeremy L Thompson     out[0] = q_data;
43*4fee36f0SJeremy L Thompson     CeedQFunctionApply(qf_setup, q, in, out);
44*4fee36f0SJeremy L Thompson   }
45*4fee36f0SJeremy L Thompson 
46288c0443SJeremy L Thompson   CeedQFunctionCreateInteriorByName(ceed, "MassApply", &qf_mass);
47288c0443SJeremy L Thompson   {
48*4fee36f0SJeremy L Thompson     in[0]  = w;
49*4fee36f0SJeremy L Thompson     in[1]  = u;
50*4fee36f0SJeremy L Thompson     out[0] = v;
51*4fee36f0SJeremy L Thompson     CeedQFunctionApply(qf_mass, q, in, out);
52288c0443SJeremy L Thompson   }
53*4fee36f0SJeremy L Thompson 
54*4fee36f0SJeremy L Thompson   // Verify results
55288c0443SJeremy L Thompson   {
56*4fee36f0SJeremy L Thompson     const CeedScalar *v_array;
57*4fee36f0SJeremy L Thompson 
58*4fee36f0SJeremy L Thompson     CeedVectorGetArrayRead(v, CEED_MEM_HOST, &v_array);
59*4fee36f0SJeremy L Thompson     for (CeedInt i = 0; i < q; i++) {
60*4fee36f0SJeremy L Thompson       if (v_true[i] != v_array[i]) printf("[%" CeedInt_FMT "] v_true %f != v %f\n", i, v_true[i], v_array[i]);
61*4fee36f0SJeremy L Thompson     }
62*4fee36f0SJeremy L Thompson     CeedVectorRestoreArrayRead(v, &v_array);
63288c0443SJeremy L Thompson   }
64288c0443SJeremy L Thompson 
65*4fee36f0SJeremy L Thompson   CeedVectorDestroy(&dx);
66*4fee36f0SJeremy L Thompson   CeedVectorDestroy(&w);
67*4fee36f0SJeremy L Thompson   CeedVectorDestroy(&u);
68*4fee36f0SJeremy L Thompson   CeedVectorDestroy(&v);
69*4fee36f0SJeremy L Thompson   CeedVectorDestroy(&q_data);
70288c0443SJeremy L Thompson   CeedQFunctionDestroy(&qf_setup);
71288c0443SJeremy L Thompson   CeedQFunctionDestroy(&qf_mass);
72288c0443SJeremy L Thompson   CeedDestroy(&ceed);
73288c0443SJeremy L Thompson   return 0;
74288c0443SJeremy L Thompson }
75