1*98285ab4SZach Atkins // Copyright (c) 2017-2022, Lawrence Livermore National Security, LLC and other CEED contributors. 2*98285ab4SZach Atkins // All Rights Reserved. See the top-level LICENSE and NOTICE files for details. 3*98285ab4SZach Atkins // 4*98285ab4SZach Atkins // SPDX-License-Identifier: BSD-2-Clause 5*98285ab4SZach Atkins // 6*98285ab4SZach Atkins // This file is part of CEED: http://github.com/ceed 7*98285ab4SZach Atkins 8*98285ab4SZach Atkins /// @file 9*98285ab4SZach Atkins /// Problem data for BPS sphere examples 10*98285ab4SZach Atkins 11b7c563b6SJeremy L Thompson #ifndef libceed_petsc_examples_sphere_problem_data_h 12b7c563b6SJeremy L Thompson #define libceed_petsc_examples_sphere_problem_data_h 13e83e87a5Sjeremylt 14e83e87a5Sjeremylt #include <ceed.h> 15e83e87a5Sjeremylt #include <petsc.h> 162b730f8bSJeremy L Thompson 17e83e87a5Sjeremylt #include "../include/structs.h" 18e83e87a5Sjeremylt #include "../qfunctions/bps/bp1sphere.h" 19e83e87a5Sjeremylt #include "../qfunctions/bps/bp2sphere.h" 20e83e87a5Sjeremylt #include "../qfunctions/bps/bp3sphere.h" 21e83e87a5Sjeremylt #include "../qfunctions/bps/bp4sphere.h" 22e83e87a5Sjeremylt #include "../qfunctions/bps/common.h" 23e83e87a5Sjeremylt 24e83e87a5Sjeremylt // ----------------------------------------------------------------------------- 25e83e87a5Sjeremylt // BP Option Data 26e83e87a5Sjeremylt // ----------------------------------------------------------------------------- 27e83e87a5Sjeremylt 289b072555Sjeremylt static BPData bp_options[6] = { 292b730f8bSJeremy L Thompson [CEED_BP1] = {.num_comp_u = 1, 309b072555Sjeremylt .num_comp_x = 3, 319b072555Sjeremylt .topo_dim = 3, 329b072555Sjeremylt .q_data_size = 1, 339b072555Sjeremylt .q_extra = 1, 349b072555Sjeremylt .setup_geo = SetupMassGeo, 359b072555Sjeremylt .setup_rhs = SetupMassRhs, 36e83e87a5Sjeremylt .apply = Mass, 37e83e87a5Sjeremylt .error = Error, 389b072555Sjeremylt .setup_geo_loc = SetupMassGeo_loc, 399b072555Sjeremylt .setup_rhs_loc = SetupMassRhs_loc, 409b072555Sjeremylt .apply_loc = Mass_loc, 419b072555Sjeremylt .error_loc = Error_loc, 429b072555Sjeremylt .in_mode = CEED_EVAL_INTERP, 439b072555Sjeremylt .out_mode = CEED_EVAL_INTERP, 442b730f8bSJeremy L Thompson .q_mode = CEED_GAUSS }, 452b730f8bSJeremy L Thompson [CEED_BP2] = {.num_comp_u = 3, 469b072555Sjeremylt .num_comp_x = 3, 479b072555Sjeremylt .topo_dim = 3, 489b072555Sjeremylt .q_data_size = 1, 49d4d45553Srezgarshakeri .q_extra = 1, 509b072555Sjeremylt .setup_geo = SetupMassGeo, 519b072555Sjeremylt .setup_rhs = SetupMassRhs3, 52e83e87a5Sjeremylt .apply = Mass3, 53e83e87a5Sjeremylt .error = Error3, 549b072555Sjeremylt .setup_geo_loc = SetupMassGeo_loc, 559b072555Sjeremylt .setup_rhs_loc = SetupMassRhs3_loc, 569b072555Sjeremylt .apply_loc = Mass3_loc, 579b072555Sjeremylt .error_loc = Error3_loc, 589b072555Sjeremylt .in_mode = CEED_EVAL_INTERP, 599b072555Sjeremylt .out_mode = CEED_EVAL_INTERP, 602b730f8bSJeremy L Thompson .q_mode = CEED_GAUSS }, 612b730f8bSJeremy L Thompson [CEED_BP3] = {.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, 762b730f8bSJeremy L Thompson .q_mode = CEED_GAUSS }, 772b730f8bSJeremy L Thompson [CEED_BP4] = {.num_comp_u = 3, 789b072555Sjeremylt .num_comp_x = 3, 799b072555Sjeremylt .topo_dim = 3, 809b072555Sjeremylt .q_data_size = 4, 819b072555Sjeremylt .q_extra = 1, 829b072555Sjeremylt .setup_geo = SetupDiffGeo, 839b072555Sjeremylt .setup_rhs = SetupDiffRhs3, 84e83e87a5Sjeremylt .apply = Diff3, 85e83e87a5Sjeremylt .error = Error3, 869b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 879b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs3_loc, 889b072555Sjeremylt .apply_loc = Diff_loc, 899b072555Sjeremylt .error_loc = Error3_loc, 909b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 919b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 922b730f8bSJeremy L Thompson .q_mode = CEED_GAUSS }, 932b730f8bSJeremy L Thompson [CEED_BP5] = {.num_comp_u = 1, 949b072555Sjeremylt .num_comp_x = 3, 959b072555Sjeremylt .topo_dim = 3, 969b072555Sjeremylt .q_data_size = 4, 979b072555Sjeremylt .q_extra = 0, 989b072555Sjeremylt .setup_geo = SetupDiffGeo, 999b072555Sjeremylt .setup_rhs = SetupDiffRhs, 100e83e87a5Sjeremylt .apply = Diff, 101e83e87a5Sjeremylt .error = Error, 1029b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 1039b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs_loc, 1049b072555Sjeremylt .apply_loc = Diff_loc, 1059b072555Sjeremylt .error_loc = Error_loc, 1069b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 1079b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 1082b730f8bSJeremy L Thompson .q_mode = CEED_GAUSS_LOBATTO}, 1092b730f8bSJeremy L Thompson [CEED_BP6] = {.num_comp_u = 3, 1109b072555Sjeremylt .num_comp_x = 3, 1119b072555Sjeremylt .topo_dim = 3, 1129b072555Sjeremylt .q_data_size = 4, 1139b072555Sjeremylt .q_extra = 0, 1149b072555Sjeremylt .setup_geo = SetupDiffGeo, 1159b072555Sjeremylt .setup_rhs = SetupDiffRhs3, 116e83e87a5Sjeremylt .apply = Diff3, 117e83e87a5Sjeremylt .error = Error3, 1189b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 1199b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs3_loc, 1209b072555Sjeremylt .apply_loc = Diff_loc, 1219b072555Sjeremylt .error_loc = Error3_loc, 1229b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 1239b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 1242b730f8bSJeremy L Thompson .q_mode = CEED_GAUSS_LOBATTO} 125e83e87a5Sjeremylt }; 126e83e87a5Sjeremylt 127b7c563b6SJeremy L Thompson #endif // libceed_petsc_examples_sphere_problem_data_h 128