1*b7c563b6SJeremy L Thompson #ifndef libceed_petsc_examples_sphere_problem_data_h 2*b7c563b6SJeremy L Thompson #define libceed_petsc_examples_sphere_problem_data_h 3e83e87a5Sjeremylt 4e83e87a5Sjeremylt #include <ceed.h> 5e83e87a5Sjeremylt #include <petsc.h> 6e83e87a5Sjeremylt #include "../include/structs.h" 7e83e87a5Sjeremylt #include "../qfunctions/bps/bp1sphere.h" 8e83e87a5Sjeremylt #include "../qfunctions/bps/bp2sphere.h" 9e83e87a5Sjeremylt #include "../qfunctions/bps/bp3sphere.h" 10e83e87a5Sjeremylt #include "../qfunctions/bps/bp4sphere.h" 11e83e87a5Sjeremylt #include "../qfunctions/bps/common.h" 12e83e87a5Sjeremylt 13e83e87a5Sjeremylt // ----------------------------------------------------------------------------- 14e83e87a5Sjeremylt // BP Option Data 15e83e87a5Sjeremylt // ----------------------------------------------------------------------------- 16e83e87a5Sjeremylt 17e83e87a5Sjeremylt // BP options 18e83e87a5Sjeremylt typedef enum { 19e83e87a5Sjeremylt CEED_BP1 = 0, CEED_BP2 = 1, CEED_BP3 = 2, 20e83e87a5Sjeremylt CEED_BP4 = 3, CEED_BP5 = 4, CEED_BP6 = 5 219b072555Sjeremylt } BPType; 22e83e87a5Sjeremylt 239b072555Sjeremylt static BPData bp_options[6] = { 24e83e87a5Sjeremylt [CEED_BP1] = { 259b072555Sjeremylt .num_comp_u = 1, 269b072555Sjeremylt .num_comp_x = 3, 279b072555Sjeremylt .topo_dim = 3, 289b072555Sjeremylt .q_data_size = 1, 299b072555Sjeremylt .q_extra = 1, 309b072555Sjeremylt .setup_geo = SetupMassGeo, 319b072555Sjeremylt .setup_rhs = SetupMassRhs, 32e83e87a5Sjeremylt .apply = Mass, 33e83e87a5Sjeremylt .error = Error, 349b072555Sjeremylt .setup_geo_loc = SetupMassGeo_loc, 359b072555Sjeremylt .setup_rhs_loc = SetupMassRhs_loc, 369b072555Sjeremylt .apply_loc = Mass_loc, 379b072555Sjeremylt .error_loc = Error_loc, 389b072555Sjeremylt .in_mode = CEED_EVAL_INTERP, 399b072555Sjeremylt .out_mode = CEED_EVAL_INTERP, 409b072555Sjeremylt .q_mode = CEED_GAUSS 41e83e87a5Sjeremylt }, 42e83e87a5Sjeremylt [CEED_BP2] = { 439b072555Sjeremylt .num_comp_u = 3, 449b072555Sjeremylt .num_comp_x = 3, 459b072555Sjeremylt .topo_dim = 3, 469b072555Sjeremylt .q_data_size = 1, 479b072555Sjeremylt .q_extra = 1, 489b072555Sjeremylt .setup_geo = SetupMassGeo, 499b072555Sjeremylt .setup_rhs = SetupMassRhs3, 50e83e87a5Sjeremylt .apply = Mass3, 51e83e87a5Sjeremylt .error = Error3, 529b072555Sjeremylt .setup_geo_loc = SetupMassGeo_loc, 539b072555Sjeremylt .setup_rhs_loc = SetupMassRhs3_loc, 549b072555Sjeremylt .apply_loc = Mass3_loc, 559b072555Sjeremylt .error_loc = Error3_loc, 569b072555Sjeremylt .in_mode = CEED_EVAL_INTERP, 579b072555Sjeremylt .out_mode = CEED_EVAL_INTERP, 589b072555Sjeremylt .q_mode = CEED_GAUSS 59e83e87a5Sjeremylt }, 60e83e87a5Sjeremylt [CEED_BP3] = { 619b072555Sjeremylt .num_comp_u = 1, 629b072555Sjeremylt .num_comp_x = 3, 639b072555Sjeremylt .topo_dim = 3, 649b072555Sjeremylt .q_data_size = 4, 659b072555Sjeremylt .q_extra = 1, 669b072555Sjeremylt .setup_geo = SetupDiffGeo, 679b072555Sjeremylt .setup_rhs = SetupDiffRhs, 68e83e87a5Sjeremylt .apply = Diff, 69e83e87a5Sjeremylt .error = Error, 709b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 719b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs_loc, 729b072555Sjeremylt .apply_loc = Diff_loc, 739b072555Sjeremylt .error_loc = Error_loc, 749b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 759b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 769b072555Sjeremylt .q_mode = CEED_GAUSS 77e83e87a5Sjeremylt }, 78e83e87a5Sjeremylt [CEED_BP4] = { 799b072555Sjeremylt .num_comp_u = 3, 809b072555Sjeremylt .num_comp_x = 3, 819b072555Sjeremylt .topo_dim = 3, 829b072555Sjeremylt .q_data_size = 4, 839b072555Sjeremylt .q_extra = 1, 849b072555Sjeremylt .setup_geo = SetupDiffGeo, 859b072555Sjeremylt .setup_rhs = SetupDiffRhs3, 86e83e87a5Sjeremylt .apply = Diff3, 87e83e87a5Sjeremylt .error = Error3, 889b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 899b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs3_loc, 909b072555Sjeremylt .apply_loc = Diff_loc, 919b072555Sjeremylt .error_loc = Error3_loc, 929b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 939b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 949b072555Sjeremylt .q_mode = CEED_GAUSS 95e83e87a5Sjeremylt }, 96e83e87a5Sjeremylt [CEED_BP5] = { 979b072555Sjeremylt .num_comp_u = 1, 989b072555Sjeremylt .num_comp_x = 3, 999b072555Sjeremylt .topo_dim = 3, 1009b072555Sjeremylt .q_data_size = 4, 1019b072555Sjeremylt .q_extra = 0, 1029b072555Sjeremylt .setup_geo = SetupDiffGeo, 1039b072555Sjeremylt .setup_rhs = SetupDiffRhs, 104e83e87a5Sjeremylt .apply = Diff, 105e83e87a5Sjeremylt .error = Error, 1069b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 1079b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs_loc, 1089b072555Sjeremylt .apply_loc = Diff_loc, 1099b072555Sjeremylt .error_loc = Error_loc, 1109b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 1119b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 1129b072555Sjeremylt .q_mode = CEED_GAUSS_LOBATTO 113e83e87a5Sjeremylt }, 114e83e87a5Sjeremylt [CEED_BP6] = { 1159b072555Sjeremylt .num_comp_u = 3, 1169b072555Sjeremylt .num_comp_x = 3, 1179b072555Sjeremylt .topo_dim = 3, 1189b072555Sjeremylt .q_data_size = 4, 1199b072555Sjeremylt .q_extra = 0, 1209b072555Sjeremylt .setup_geo = SetupDiffGeo, 1219b072555Sjeremylt .setup_rhs = SetupDiffRhs3, 122e83e87a5Sjeremylt .apply = Diff3, 123e83e87a5Sjeremylt .error = Error3, 1249b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 1259b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs3_loc, 1269b072555Sjeremylt .apply_loc = Diff_loc, 1279b072555Sjeremylt .error_loc = Error3_loc, 1289b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 1299b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 1309b072555Sjeremylt .q_mode = CEED_GAUSS_LOBATTO 131e83e87a5Sjeremylt } 132e83e87a5Sjeremylt }; 133e83e87a5Sjeremylt 134*b7c563b6SJeremy L Thompson #endif // libceed_petsc_examples_sphere_problem_data_h 135