Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add support for interior face integrals #1223

Merged
merged 73 commits into from
Dec 5, 2024
Merged
Show file tree
Hide file tree
Changes from 54 commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
f27a541
adding testing tool that generates all possible face orientations
samuelpmishLLNL Aug 23, 2024
26766aa
fix AddTet to AddHex
samuelpmishLLNL Aug 23, 2024
3a7c374
add InteriorFace fn, add some preliminary tests
samuelpmishLLNL Aug 23, 2024
bd2947b
fix linkage error in restriction helper function, setting up next tests
samuelpmishLLNL Aug 23, 2024
044162f
trying to figure out how to get node positions/directions from mfem
samuelpmishLLNL Aug 23, 2024
d3529fa
decode hcurl dof orientations for face elements
samuelpmishLLNL Aug 25, 2024
0e96c71
add exhaustive test suite of DG face dof agreement
samuelpmishLLNL Aug 25, 2024
f1de1c0
plumbing for the new integral type
samuelpmishLLNL Aug 26, 2024
dff154c
Merge branch 'develop' into mish2/dg_support
tupek2 Aug 28, 2024
53e88be
more plumbing for the new integral type
samuelpmishLLNL Aug 30, 2024
2e25351
Merge branch 'mish2/dg_support' of github-work.com:LLNL/serac into mi…
samuelpmishLLNL Aug 30, 2024
8f739f1
debugging segfault
samuelpmishLLNL Sep 6, 2024
4bcd5e2
Merge branch 'develop' into mish2/dg_support
samuelpmishLLNL Sep 6, 2024
c006522
add new ctor for restriction that takes a Domain, fix two small bugs …
samuelpmishLLNL Sep 11, 2024
51b9dae
add some tests for domain-based restriction operators
samuelpmishLLNL Sep 11, 2024
5082552
include some checks for element restrictions over domains with Hcurl,…
samuelpmishLLNL Sep 11, 2024
18af6c8
working on updating sparse matrix assembly
samuelpmishLLNL Sep 13, 2024
1945881
more work on new sparse matrix assembly routine
samuelpmishLLNL Sep 13, 2024
0bf2235
big changes to move ElementTestrictions into Domain classes
samuelpmishLLNL Oct 5, 2024
6270797
fix bug in geometric factor kernel macro, fix some warnings
samuelpmishLLNL Oct 10, 2024
e21d752
update some functional tests to use Domains
samuelpmishLLNL Oct 10, 2024
e909e10
suppress warnings and fix bug in fespace construction
samuelpmishLLNL Oct 23, 2024
5d4a093
fix the way the chain rule is computed internally in the interior fac…
samuelpmishLLNL Oct 25, 2024
9a5156e
debugging element matrix calculation
samuelpmishLLNL Nov 5, 2024
938f788
fix bug in element matrix calculation
samuelpmishLLNL Nov 5, 2024
a25b076
add interior face functions for triangle and placeholders for quad
samuelpmishLLNL Nov 12, 2024
2923c9e
debugging diff in quadrilateral stiffness matrix calculation
samuelpmishLLNL Nov 13, 2024
303625a
this one line change took me like 3 hours to find
samuelpmishLLNL Nov 14, 2024
0e94619
plumb new element restrictions through QoI specialization of serac::F…
samuelpmishLLNL Nov 15, 2024
cf72418
updating some tests to use Domains, (rather than meshes) in calls to …
samuelpmishLLNL Nov 18, 2024
1277916
Merge branch 'develop' into mish2/dg_support
samuelpmishLLNL Nov 18, 2024
c5032a5
fix #include order issues, updating more tests
samuelpmishLLNL Nov 18, 2024
726804d
updating more tests
samuelpmishLLNL Nov 18, 2024
686ea10
updating more tests
samuelpmishLLNL Nov 19, 2024
e615bed
guard against accessing retrictions that weren't needed by an integral
samuelpmishLLNL Nov 19, 2024
ce09966
update buckling and contact examples
samuelpmishLLNL Nov 19, 2024
e824db3
update more examples and tests, add convenience function for checking…
samuelpmishLLNL Nov 19, 2024
f78da84
updating heat_transfer module + tests, some other examples
samuelpmishLLNL Nov 19, 2024
9f828b7
update addCustomDomainIntegral in solid mechanics module
samuelpmishLLNL Nov 19, 2024
e3a87d1
fix const issue
samuelpmishLLNL Nov 19, 2024
9e43f72
more guarding against accesses to unnecessary restriction operators
samuelpmishLLNL Nov 19, 2024
b37b454
fix interpolate routines returning degenerate tensors, rather than `d…
samuelpmishLLNL Nov 19, 2024
a636054
fix mistakenly calling a function that wasn't defined
samuelpmishLLNL Nov 19, 2024
a20e7b9
simplify qfunction in dg test
samuelpmishLLNL Nov 19, 2024
af09e08
update more solid mechanics tests
samuelpmishLLNL Nov 19, 2024
db99e0e
add more tests
samuelpmishLLNL Nov 19, 2024
080e0d0
fix indexing bug in element stiffness calculation on interior faces, …
samuelpmishLLNL Nov 20, 2024
2bf54fb
add a lot of doxygen comments, trying to figure out how to add suppor…
samuelpmishLLNL Nov 21, 2024
7905f46
fix bug where face orientations were not be applied when they should …
samuelpmishLLNL Nov 21, 2024
88055d1
revert experimental change to ParGridfunctions in geometric factor ro…
samuelpmishLLNL Nov 21, 2024
a694fe1
fix bug where set operations on domains were not populating the mfem_…
samuelpmishLLNL Nov 21, 2024
3365ae3
add error message when trying to use an unsupported integral configur…
samuelpmishLLNL Nov 26, 2024
3234970
run dg test on one processor
samuelpmishLLNL Nov 26, 2024
e3a3fdd
Apply style updates
Nov 26, 2024
e5e4fa9
Merge branch 'develop' into mish2/dg_support
samuelpmishLLNL Dec 2, 2024
ada95fb
adjust some names, delete unused code
samuelpmishLLNL Dec 2, 2024
e868e9c
fix some integer conversion warnings on GCC
samuelpmishLLNL Dec 2, 2024
76d1890
address some doxygen warnings
samuelpmishLLNL Dec 2, 2024
11bed34
Apply style updates
Dec 2, 2024
22dc40b
explicitly add some headers to CMakeLists.txt
samuelpmishLLNL Dec 2, 2024
3c8b96e
(blind) attempt to fix benchmark compilation errors
samuelpmishLLNL Dec 2, 2024
8a65b76
Merge branch 'mish2/dg_support' of github-work.com:LLNL/serac into mi…
samuelpmishLLNL Dec 2, 2024
d1e255e
enable building benchmarks by directly specifying SERAC_ENABLE_BENCHM…
samuelpmishLLNL Dec 3, 2024
cae2d94
fix compilation error from missing namespace prefix in benchmarks
samuelpmishLLNL Dec 3, 2024
afb499a
Apply style updates
Dec 3, 2024
9c44026
temporarily disable lua integration tests
samuelpmishLLNL Dec 4, 2024
989bca6
delete print statements
samuelpmishLLNL Dec 4, 2024
f374a7a
respond to Mike's PR feedback
samuelpmishLLNL Dec 4, 2024
50d63c3
Merge branch 'mish2/dg_support' of github-work.com:LLNL/serac into mi…
samuelpmishLLNL Dec 4, 2024
9db8634
Apply style updates
Dec 5, 2024
c9219f3
respond to Brandon's feedback
samuelpmishLLNL Dec 5, 2024
fb01e66
Merge branch 'develop' into mish2/dg_support
samuelpmishLLNL Dec 5, 2024
7249be1
Apply style updates
Dec 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 4 additions & 5 deletions examples/buckling/cylinder.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -124,9 +124,8 @@ int main(int argc, char* argv[])

// Create and refine mesh
std::string filename = SERAC_REPO_DIR "/data/meshes/hollow-cylinder.mesh";
auto mesh = serac::buildMeshFromFile(filename);
auto pmesh = mesh::refineAndDistribute(std::move(mesh), serial_refinement, parallel_refinement);
serac::StateManager::setMesh(std::move(pmesh), mesh_tag);
auto mesh = mesh::refineAndDistribute(serac::buildMeshFromFile(filename), serial_refinement, parallel_refinement);
auto& pmesh = serac::StateManager::setMesh(std::move(mesh), mesh_tag);

// Surface attributes for boundary conditions
std::set<int> xneg{2};
Expand Down Expand Up @@ -160,8 +159,8 @@ int main(int argc, char* argv[])
auto lambda = 1.0;
auto G = 0.1;
solid_mechanics::NeoHookean mat{.density = 1.0, .K = (3 * lambda + 2 * G) / 3, .G = G};

solid_solver->setMaterial(mat);
Domain whole_mesh = EntireDomain(pmesh);
solid_solver->setMaterial(mat, whole_mesh);

// Set up essential boundary conditions
// Bottom of cylinder is fixed
Expand Down
9 changes: 5 additions & 4 deletions examples/contact/beam_bending.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,8 @@ int main(int argc, char* argv[])
// Construct the appropriate dimension mesh and give it to the data store
std::string filename = SERAC_REPO_DIR "/data/meshes/beam-hex-with-contact-block.mesh";

auto mesh = serac::mesh::refineAndDistribute(serac::buildMeshFromFile(filename), 2, 0);
serac::StateManager::setMesh(std::move(mesh), "beam_mesh");
auto mesh = serac::mesh::refineAndDistribute(serac::buildMeshFromFile(filename), 2, 0);
auto& pmesh = serac::StateManager::setMesh(std::move(mesh), "beam_mesh");

serac::LinearSolverOptions linear_options{.linear_solver = serac::LinearSolver::Strumpack, .print_level = 1};
#ifndef MFEM_USE_STRUMPACK
Expand Down Expand Up @@ -78,7 +78,8 @@ int main(int argc, char* argv[])
solid_solver.setParameter(1, G_field);

serac::solid_mechanics::ParameterizedNeoHookeanSolid mat{1.0, 0.0, 0.0};
solid_solver.setMaterial(serac::DependsOn<0, 1>{}, mat);
serac::Domain whole_mesh = serac::EntireDomain(pmesh);
solid_solver.setMaterial(serac::DependsOn<0, 1>{}, mat, whole_mesh);

// Pass the BC information to the solver object
solid_solver.setDisplacementBCs({1}, [](const mfem::Vector&, mfem::Vector& u) {
Expand Down Expand Up @@ -117,4 +118,4 @@ int main(int argc, char* argv[])
serac::exitGracefully();

return 0;
}
}
8 changes: 5 additions & 3 deletions examples/contact/ironing.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,11 @@ int main(int argc, char* argv[])
// Construct the appropriate dimension mesh and give it to the data store
std::string filename = SERAC_REPO_DIR "/data/meshes/ironing.mesh";

auto mesh = serac::mesh::refineAndDistribute(serac::buildMeshFromFile(filename), 2, 0);
serac::StateManager::setMesh(std::move(mesh), "ironing_mesh");
auto mesh = serac::mesh::refineAndDistribute(serac::buildMeshFromFile(filename), 2, 0);
auto& pmesh = serac::StateManager::setMesh(std::move(mesh), "ironing_mesh");

serac::LinearSolverOptions linear_options{.linear_solver = serac::LinearSolver::Strumpack, .print_level = 1};

#ifndef MFEM_USE_STRUMPACK
SLIC_INFO_ROOT("Contact requires MFEM built with strumpack.");
return 1;
Expand Down Expand Up @@ -78,7 +79,8 @@ int main(int argc, char* argv[])
solid_solver.setParameter(1, G_field);

serac::solid_mechanics::ParameterizedNeoHookeanSolid mat{1.0, 0.0, 0.0};
solid_solver.setMaterial(serac::DependsOn<0, 1>{}, mat);
serac::Domain whole_mesh = serac::EntireDomain(pmesh);
solid_solver.setMaterial(serac::DependsOn<0, 1>{}, mat, whole_mesh);

// Pass the BC information to the solver object
solid_solver.setDisplacementBCs({5}, [](const mfem::Vector&, mfem::Vector& u) {
Expand Down
9 changes: 5 additions & 4 deletions examples/contact/sphere.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,8 @@ int main(int argc, char* argv[])
cube_mesh.SetCurvature(p);

std::vector<mfem::Mesh*> mesh_ptrs{&ball_mesh, &cube_mesh};
auto mesh = serac::mesh::refineAndDistribute(mfem::Mesh(mesh_ptrs.data(), static_cast<int>(mesh_ptrs.size())), 0, 0);
serac::StateManager::setMesh(std::move(mesh), "sphere_mesh");
auto mesh = serac::mesh::refineAndDistribute(mfem::Mesh(mesh_ptrs.data(), static_cast<int>(mesh_ptrs.size())), 0, 0);
auto& pmesh = serac::StateManager::setMesh(std::move(mesh), "sphere_mesh");

serac::LinearSolverOptions linear_options{.linear_solver = serac::LinearSolver::Strumpack, .print_level = 1};
#ifndef MFEM_USE_STRUMPACK
Expand All @@ -75,7 +75,8 @@ int main(int argc, char* argv[])
nonlinear_options, linear_options, serac::solid_mechanics::default_quasistatic_options, name, "sphere_mesh");

serac::solid_mechanics::NeoHookean mat{1.0, 10.0, 0.25};
solid_solver.setMaterial(mat);
serac::Domain whole_mesh = serac::EntireDomain(pmesh);
solid_solver.setMaterial(mat, whole_mesh);

// Pass the BC information to the solver object
solid_solver.setDisplacementBCs({3}, [](const mfem::Vector&, mfem::Vector& u) {
Expand Down Expand Up @@ -122,4 +123,4 @@ int main(int argc, char* argv[])
serac::exitGracefully();

return 0;
}
}
9 changes: 5 additions & 4 deletions examples/contact/twist.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,8 @@ int main(int argc, char* argv[])
// Construct the appropriate dimension mesh and give it to the data store
std::string filename = SERAC_REPO_DIR "/data/meshes/twohex_for_contact.mesh";

auto mesh = serac::mesh::refineAndDistribute(serac::buildMeshFromFile(filename), 3, 0);
serac::StateManager::setMesh(std::move(mesh), "twist_mesh");
auto mesh = serac::mesh::refineAndDistribute(serac::buildMeshFromFile(filename), 3, 0);
auto& pmesh = serac::StateManager::setMesh(std::move(mesh), "twist_mesh");

serac::LinearSolverOptions linear_options{.linear_solver = serac::LinearSolver::Strumpack, .print_level = 1};
#ifndef MFEM_USE_STRUMPACK
Expand All @@ -61,7 +61,8 @@ int main(int argc, char* argv[])
nonlinear_options, linear_options, serac::solid_mechanics::default_quasistatic_options, name, "twist_mesh");

serac::solid_mechanics::NeoHookean mat{1.0, 10.0, 10.0};
solid_solver.setMaterial(mat);
serac::Domain whole_mesh = serac::EntireDomain(pmesh);
solid_solver.setMaterial(mat, whole_mesh);

// Pass the BC information to the solver object
solid_solver.setDisplacementBCs({3}, [](const mfem::Vector&, mfem::Vector& u) {
Expand Down Expand Up @@ -108,4 +109,4 @@ int main(int argc, char* argv[])
serac::exitGracefully();

return 0;
}
}
6 changes: 4 additions & 2 deletions examples/simple_conduction/without_input_file.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ int main(int argc, char* argv[])

std::string mesh_tag{"mesh"};

serac::StateManager::setMesh(std::move(mesh), mesh_tag);
auto& pmesh = serac::StateManager::setMesh(std::move(mesh), mesh_tag);
// _create_mesh_end

// _create_module_start
Expand All @@ -54,7 +54,9 @@ int main(int argc, char* argv[])
// _conductivity_start
constexpr double kappa = 0.5;
serac::heat_transfer::LinearIsotropicConductor mat(1.0, 1.0, kappa);
heat_transfer.setMaterial(mat);

serac::Domain whole_domain = serac::EntireDomain(pmesh);
heat_transfer.setMaterial(mat, whole_domain);

// _conductivity_end
// _bc_start
Expand Down
60 changes: 30 additions & 30 deletions src/drivers/CMakeLists.txt
Copy link
Contributor Author

@samuelpmishLLNL samuelpmishLLNL Nov 26, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've temporarily disabled these serac "drivers" since:

  • to my knowledge, no one uses them
  • we don't really have an input-file interface for a lot of things (Domain included)
  • it's caused confusion for new users (understandably, but incorrectly) thinking that this is the primary way to use serac

Keeping them enabled would add extra burden to this PR which I don't feel is justified in the near future.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is a user that is currently using it for testing the memory mapped file library.

Original file line number Diff line number Diff line change
Expand Up @@ -4,33 +4,33 @@
#
# SPDX-License-Identifier: (BSD-3-Clause)

blt_add_executable( NAME serac_driver
SOURCES serac.cpp
DEPENDS_ON serac_physics serac_mesh
OUTPUT_NAME serac
)

if (SERAC_ENABLE_TESTS)
set(input_files_dir ${CMAKE_CURRENT_SOURCE_DIR}/../../data/input_files/tests)

# Run basic test for the Serac driver
blt_add_test(NAME serac_driver_solid
COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac -o driver_solid -i ${input_files_dir}/solid/dyn_solve.lua
NUM_MPI_TASKS 1 )

blt_add_test(NAME serac_driver_heat_transfer
COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac -o driver_heat_transfer -i ${input_files_dir}/heat_transfer/static_solve.lua
NUM_MPI_TASKS 1 )

blt_add_test(NAME serac_driver_help
COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac --help
NUM_MPI_TASKS 1 )

blt_add_test(NAME serac_driver_docs
COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac -o docs -d -i ${input_files_dir}/solid/qs_linear.lua
NUM_MPI_TASKS 1 )
endif()

install( TARGETS serac_driver
RUNTIME DESTINATION bin
)
#blt_add_executable( NAME serac_driver
# SOURCES serac.cpp
# DEPENDS_ON serac_physics serac_mesh
# OUTPUT_NAME serac
# )
#
#if (SERAC_ENABLE_TESTS)
# set(input_files_dir ${CMAKE_CURRENT_SOURCE_DIR}/../../data/input_files/tests)
#
# # Run basic test for the Serac driver
# blt_add_test(NAME serac_driver_solid
# COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac -o driver_solid -i ${input_files_dir}/solid/dyn_solve.lua
# NUM_MPI_TASKS 1 )
#
# blt_add_test(NAME serac_driver_heat_transfer
# COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac -o driver_heat_transfer -i ${input_files_dir}/heat_transfer/static_solve.lua
# NUM_MPI_TASKS 1 )
#
# blt_add_test(NAME serac_driver_help
# COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac --help
# NUM_MPI_TASKS 1 )
#
# blt_add_test(NAME serac_driver_docs
# COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/serac -o docs -d -i ${input_files_dir}/solid/qs_linear.lua
# NUM_MPI_TASKS 1 )
#endif()
#
#install( TARGETS serac_driver
# RUNTIME DESTINATION bin
# )
7 changes: 7 additions & 0 deletions src/serac/infrastructure/accelerator.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,13 @@ void zero_out(axom::Array<T, dim, space>& arr)
{
std::memset(arr.data(), 0, static_cast<std::size_t>(arr.size()) * sizeof(T));
}

/// @brief set the contents of an array to zero, byte-wise
template <typename T, int dim>
void zero_out(axom::ArrayView<T, dim, axom::MemorySpace::Host>& arr)
{
std::memset(arr.data(), 0, static_cast<std::size_t>(arr.size()) * sizeof(T));
}
#ifdef __CUDACC__
/// @overload
template <typename T, int dim>
Expand Down
6 changes: 0 additions & 6 deletions src/serac/infrastructure/debug_print.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -61,12 +61,6 @@ std::ostream& operator<<(std::ostream& out, DoF dof)
return out;
}

std::ostream& operator<<(std::ostream& out, serac::SignedIndex i)
{
out << "{" << i.index_ << ", " << i.sign_ << "}";
return out;
}

/**
* @brief write a 2D array of values out to file, in a space-separated format
* @tparam T the type of each value in the array
Expand Down
1 change: 0 additions & 1 deletion src/serac/numerics/functional/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ set(functional_depends serac_mesh ${serac_device_depends})
set(functional_headers
differentiate_wrt.hpp
boundary_integral_kernels.hpp
dof_numbering.hpp
element_restriction.hpp
geometry.hpp
geometric_factors.hpp
Expand Down
29 changes: 14 additions & 15 deletions src/serac/numerics/functional/boundary_integral_kernels.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,7 @@ template <uint32_t differentiation_index, int Q, mfem::Geometry::Type geom, type
void evaluation_kernel_impl(trial_element_type trial_elements, test_element, double t,
const std::vector<const double*>& inputs, double* outputs, const double* positions,
const double* jacobians, lambda_type qf, [[maybe_unused]] derivative_type* qf_derivatives,
const int* elements, uint32_t num_elements, camp::int_seq<int, indices...>)
uint32_t num_elements, camp::int_seq<int, indices...>)
{
// mfem provides this information as opaque arrays of doubles,
// so we reinterpret the pointer with
Expand All @@ -185,7 +185,7 @@ void evaluation_kernel_impl(trial_element_type trial_elements, test_element, dou

// batch-calculate values / derivatives of each trial space, at each quadrature point
[[maybe_unused]] tuple qf_inputs = {promote_each_to_dual_when<indices == differentiation_index>(
get<indices>(trial_elements).interpolate(get<indices>(u)[elements[e]], rule))...};
get<indices>(trial_elements).interpolate(get<indices>(u)[e], rule))...};

// (batch) evalute the q-function at each quadrature point
auto qf_outputs = batch_apply_qf(qf, t, x_e, J_e, get<indices>(qf_inputs)...);
Expand All @@ -200,7 +200,7 @@ void evaluation_kernel_impl(trial_element_type trial_elements, test_element, dou
}

// (batch) integrate the material response against the test-space basis functions
test_element::integrate(get_value(qf_outputs), rule, &r[elements[e]]);
test_element::integrate(get_value(qf_outputs), rule, &r[e]);
}
}

Expand Down Expand Up @@ -250,8 +250,7 @@ SERAC_HOST_DEVICE auto batch_apply_chain_rule(derivative_type* qf_derivatives, c
* @param[in] num_elements The number of elements in the mesh
*/
template <int Q, mfem::Geometry::Type geom, typename test, typename trial, typename derivatives_type>
void action_of_gradient_kernel(const double* dU, double* dR, derivatives_type* qf_derivatives, const int* elements,
std::size_t num_elements)
void action_of_gradient_kernel(const double* dU, double* dR, derivatives_type* qf_derivatives, std::size_t num_elements)
{
using test_element = finite_element<geom, test>;
using trial_element = finite_element<geom, trial>;
Expand All @@ -266,13 +265,13 @@ void action_of_gradient_kernel(const double* dU, double* dR, derivatives_type* q
// for each element in the domain
for (uint32_t e = 0; e < num_elements; e++) {
// (batch) interpolate each quadrature point's value
auto qf_inputs = trial_element::interpolate(du[elements[e]], rule);
auto qf_inputs = trial_element::interpolate(du[e], rule);

// (batch) evalute the q-function at each quadrature point
auto qf_outputs = batch_apply_chain_rule(qf_derivatives + e * nqp, qf_inputs);

// (batch) integrate the material response against the test-space basis functions
test_element::integrate(qf_outputs, rule, &dr[elements[e]]);
test_element::integrate(qf_outputs, rule, &dr[e]);
}
}

Expand All @@ -299,7 +298,7 @@ void action_of_gradient_kernel(const double* dU, double* dR, derivatives_type* q
*/
template <mfem::Geometry::Type g, typename test, typename trial, int Q, typename derivatives_type>
void element_gradient_kernel(ExecArrayView<double, 3, ExecutionSpace::CPU> dK, derivatives_type* qf_derivatives,
const int* elements, std::size_t num_elements)
std::size_t num_elements)
{
using test_element = finite_element<g, test>;
using trial_element = finite_element<g, trial>;
Expand All @@ -310,7 +309,7 @@ void element_gradient_kernel(ExecArrayView<double, 3, ExecutionSpace::CPU> dK, d

// for each element in the domain
for (uint32_t e = 0; e < num_elements; e++) {
auto* output_ptr = reinterpret_cast<typename test_element::dof_type*>(&dK(elements[e], 0, 0));
auto* output_ptr = reinterpret_cast<typename test_element::dof_type*>(&dK(e, 0, 0));

tensor<derivatives_type, nquad> derivatives{};
for (int q = 0; q < nquad; q++) {
Expand All @@ -327,35 +326,35 @@ void element_gradient_kernel(ExecArrayView<double, 3, ExecutionSpace::CPU> dK, d
template <uint32_t wrt, int Q, mfem::Geometry::Type geom, typename signature, typename lambda_type,
typename derivative_type>
auto evaluation_kernel(signature s, lambda_type qf, const double* positions, const double* jacobians,
std::shared_ptr<derivative_type> qf_derivatives, const int* elements, uint32_t num_elements)
std::shared_ptr<derivative_type> qf_derivatives, uint32_t num_elements)
{
auto trial_elements = trial_elements_tuple<geom>(s);
auto test_element = get_test_element<geom>(s);
return [=](double time, const std::vector<const double*>& inputs, double* outputs, bool /* update state */) {
evaluation_kernel_impl<wrt, Q, geom>(trial_elements, test_element, time, inputs, outputs, positions, jacobians, qf,
qf_derivatives.get(), elements, num_elements, s.index_seq);
qf_derivatives.get(), num_elements, s.index_seq);
};
}

template <int wrt, int Q, mfem::Geometry::Type geom, typename signature, typename derivative_type>
std::function<void(const double*, double*)> jacobian_vector_product_kernel(
signature, std::shared_ptr<derivative_type> qf_derivatives, const int* elements, uint32_t num_elements)
signature, std::shared_ptr<derivative_type> qf_derivatives, uint32_t num_elements)
{
return [=](const double* du, double* dr) {
using test_space = typename signature::return_type;
using trial_space = typename std::tuple_element<wrt, typename signature::parameter_types>::type;
action_of_gradient_kernel<Q, geom, test_space, trial_space>(du, dr, qf_derivatives.get(), elements, num_elements);
action_of_gradient_kernel<Q, geom, test_space, trial_space>(du, dr, qf_derivatives.get(), num_elements);
};
}

template <int wrt, int Q, mfem::Geometry::Type geom, typename signature, typename derivative_type>
std::function<void(ExecArrayView<double, 3, ExecutionSpace::CPU>)> element_gradient_kernel(
signature, std::shared_ptr<derivative_type> qf_derivatives, const int* elements, uint32_t num_elements)
signature, std::shared_ptr<derivative_type> qf_derivatives, uint32_t num_elements)
{
return [=](ExecArrayView<double, 3, ExecutionSpace::CPU> K_elem) {
using test_space = typename signature::return_type;
using trial_space = typename std::tuple_element<wrt, typename signature::parameter_types>::type;
element_gradient_kernel<geom, test_space, trial_space, Q>(K_elem, qf_derivatives.get(), elements, num_elements);
element_gradient_kernel<geom, test_space, trial_space, Q>(K_elem, qf_derivatives.get(), num_elements);
};
}

Expand Down
10 changes: 5 additions & 5 deletions src/serac/numerics/functional/detail/hexahedron_H1.inl
Original file line number Diff line number Diff line change
Expand Up @@ -152,11 +152,11 @@ struct finite_element<mfem::Geometry::CUBE, H1<p, c> > {
tensor<double, dim> dphi_j_dxi = {G(qx, jx) * B(qy, jy) * B(qz, jz), B(qx, jx) * G(qy, jy) * B(qz, jz),
B(qx, jx) * B(qy, jy) * G(qz, jz)};

int Q = (qz * q + qy) * q + qx;
auto& d00 = get<0>(get<0>(input(Q)));
auto& d01 = get<1>(get<0>(input(Q)));
auto& d10 = get<0>(get<1>(input(Q)));
auto& d11 = get<1>(get<1>(input(Q)));
int Q = (qz * q + qy) * q + qx;
const auto& d00 = get<0>(get<0>(input(Q)));
const auto& d01 = get<1>(get<0>(input(Q)));
const auto& d10 = get<0>(get<1>(input(Q)));
const auto& d11 = get<1>(get<1>(input(Q)));

output[Q] = {d00 * phi_j + dot(d01, dphi_j_dxi), d10 * phi_j + dot(d11, dphi_j_dxi)};
}
Expand Down
10 changes: 5 additions & 5 deletions src/serac/numerics/functional/detail/hexahedron_Hcurl.inl
Original file line number Diff line number Diff line change
Expand Up @@ -318,11 +318,11 @@ struct finite_element<mfem::Geometry::CUBE, Hcurl<p>> {
break;
}

int Q = (qz * q + qy) * q + qx;
auto& d00 = get<0>(get<0>(input(Q)));
auto& d01 = get<1>(get<0>(input(Q)));
auto& d10 = get<0>(get<1>(input(Q)));
auto& d11 = get<1>(get<1>(input(Q)));
int Q = (qz * q + qy) * q + qx;
const auto& d00 = get<0>(get<0>(input(Q)));
const auto& d01 = get<1>(get<0>(input(Q)));
const auto& d10 = get<0>(get<1>(input(Q)));
const auto& d11 = get<1>(get<1>(input(Q)));

output[Q] = {dot(d00, phi_j) + dot(d01, curl_phi_j), dot(d10, phi_j) + dot(d11, curl_phi_j)};
}
Expand Down
Loading