1*d275d636SJeremy L Thompson // Copyright (c) 2017-2025, Lawrence Livermore National Security, LLC and other CEED contributors. 298285ab4SZach Atkins // All Rights Reserved. See the top-level LICENSE and NOTICE files for details. 398285ab4SZach Atkins // 498285ab4SZach Atkins // SPDX-License-Identifier: BSD-2-Clause 598285ab4SZach Atkins // 698285ab4SZach Atkins // This file is part of CEED: http://github.com/ceed 798285ab4SZach Atkins 898285ab4SZach Atkins /// @file 998285ab4SZach Atkins /// Problem data for BPs 1024a65d3dSJeremy L Thompson #pragma once 11e83e87a5Sjeremylt 12e83e87a5Sjeremylt #include <ceed.h> 13e83e87a5Sjeremylt #include <petsc.h> 142b730f8bSJeremy L Thompson 15e83e87a5Sjeremylt #include "../include/structs.h" 16e83e87a5Sjeremylt #include "../qfunctions/bps/bp1.h" 17e83e87a5Sjeremylt #include "../qfunctions/bps/bp2.h" 18e83e87a5Sjeremylt #include "../qfunctions/bps/bp3.h" 19e83e87a5Sjeremylt #include "../qfunctions/bps/bp4.h" 20e83e87a5Sjeremylt #include "../qfunctions/bps/common.h" 21e83e87a5Sjeremylt 22e83e87a5Sjeremylt // ----------------------------------------------------------------------------- 23e83e87a5Sjeremylt // BP Option Data 24e83e87a5Sjeremylt // ----------------------------------------------------------------------------- 25e83e87a5Sjeremylt 269b072555Sjeremylt BPData bp_options[6] = { 272b730f8bSJeremy L Thompson [CEED_BP1] = {.num_comp_u = 1, 289b072555Sjeremylt .num_comp_x = 3, 299b072555Sjeremylt .topo_dim = 3, 309b072555Sjeremylt .q_data_size = 1, 319b072555Sjeremylt .q_extra = 1, 329b072555Sjeremylt .setup_geo = SetupMassGeo, 339b072555Sjeremylt .setup_rhs = SetupMassRhs, 34e83e87a5Sjeremylt .apply = Mass, 35e83e87a5Sjeremylt .error = Error, 369b072555Sjeremylt .setup_geo_loc = SetupMassGeo_loc, 379b072555Sjeremylt .setup_rhs_loc = SetupMassRhs_loc, 389b072555Sjeremylt .apply_loc = Mass_loc, 399b072555Sjeremylt .error_loc = Error_loc, 409b072555Sjeremylt .in_mode = CEED_EVAL_INTERP, 419b072555Sjeremylt .out_mode = CEED_EVAL_INTERP, 429b072555Sjeremylt .q_mode = CEED_GAUSS, 432b730f8bSJeremy L Thompson .enforce_bc = PETSC_FALSE}, 442b730f8bSJeremy L Thompson [CEED_BP2] = {.num_comp_u = 3, 459b072555Sjeremylt .num_comp_x = 3, 469b072555Sjeremylt .topo_dim = 3, 479b072555Sjeremylt .q_data_size = 1, 489b072555Sjeremylt .q_extra = 1, 499b072555Sjeremylt .setup_geo = SetupMassGeo, 509b072555Sjeremylt .setup_rhs = SetupMassRhs3, 51e83e87a5Sjeremylt .apply = Mass3, 52e83e87a5Sjeremylt .error = Error3, 539b072555Sjeremylt .setup_geo_loc = SetupMassGeo_loc, 549b072555Sjeremylt .setup_rhs_loc = SetupMassRhs3_loc, 559b072555Sjeremylt .apply_loc = Mass3_loc, 569b072555Sjeremylt .error_loc = Error3_loc, 579b072555Sjeremylt .in_mode = CEED_EVAL_INTERP, 589b072555Sjeremylt .out_mode = CEED_EVAL_INTERP, 599b072555Sjeremylt .q_mode = CEED_GAUSS, 602b730f8bSJeremy L Thompson .enforce_bc = PETSC_FALSE}, 612b730f8bSJeremy L Thompson [CEED_BP3] = {.num_comp_u = 1, 629b072555Sjeremylt .num_comp_x = 3, 639b072555Sjeremylt .topo_dim = 3, 649b072555Sjeremylt .q_data_size = 7, 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, 772b730f8bSJeremy L Thompson .enforce_bc = PETSC_TRUE }, 782b730f8bSJeremy L Thompson [CEED_BP4] = {.num_comp_u = 3, 799b072555Sjeremylt .num_comp_x = 3, 809b072555Sjeremylt .topo_dim = 3, 819b072555Sjeremylt .q_data_size = 7, 829b072555Sjeremylt .q_extra = 1, 839b072555Sjeremylt .setup_geo = SetupDiffGeo, 849b072555Sjeremylt .setup_rhs = SetupDiffRhs3, 85e83e87a5Sjeremylt .apply = Diff3, 86e83e87a5Sjeremylt .error = Error3, 879b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 889b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs3_loc, 899b072555Sjeremylt .apply_loc = Diff3_loc, 909b072555Sjeremylt .error_loc = Error3_loc, 919b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 929b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 939b072555Sjeremylt .q_mode = CEED_GAUSS, 942b730f8bSJeremy L Thompson .enforce_bc = PETSC_TRUE }, 952b730f8bSJeremy L Thompson [CEED_BP5] = {.num_comp_u = 1, 969b072555Sjeremylt .num_comp_x = 3, 979b072555Sjeremylt .topo_dim = 3, 989b072555Sjeremylt .q_data_size = 7, 999b072555Sjeremylt .q_extra = 0, 1009b072555Sjeremylt .setup_geo = SetupDiffGeo, 1019b072555Sjeremylt .setup_rhs = SetupDiffRhs, 102e83e87a5Sjeremylt .apply = Diff, 103e83e87a5Sjeremylt .error = Error, 1049b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 1059b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs_loc, 1069b072555Sjeremylt .apply_loc = Diff_loc, 1079b072555Sjeremylt .error_loc = Error_loc, 1089b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 1099b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 1109b072555Sjeremylt .q_mode = CEED_GAUSS_LOBATTO, 1112b730f8bSJeremy L Thompson .enforce_bc = PETSC_TRUE }, 1122b730f8bSJeremy L Thompson [CEED_BP6] = {.num_comp_u = 3, 1139b072555Sjeremylt .num_comp_x = 3, 1149b072555Sjeremylt .topo_dim = 3, 1159b072555Sjeremylt .q_data_size = 7, 1169b072555Sjeremylt .q_extra = 0, 1179b072555Sjeremylt .setup_geo = SetupDiffGeo, 1189b072555Sjeremylt .setup_rhs = SetupDiffRhs3, 119e83e87a5Sjeremylt .apply = Diff3, 120e83e87a5Sjeremylt .error = Error3, 1219b072555Sjeremylt .setup_geo_loc = SetupDiffGeo_loc, 1229b072555Sjeremylt .setup_rhs_loc = SetupDiffRhs3_loc, 1239b072555Sjeremylt .apply_loc = Diff3_loc, 1249b072555Sjeremylt .error_loc = Error3_loc, 1259b072555Sjeremylt .in_mode = CEED_EVAL_GRAD, 1269b072555Sjeremylt .out_mode = CEED_EVAL_GRAD, 1279b072555Sjeremylt .q_mode = CEED_GAUSS_LOBATTO, 1282b730f8bSJeremy L Thompson .enforce_bc = PETSC_TRUE } 129e83e87a5Sjeremylt }; 130