Skip to content

Commit

Permalink
Update fenicsx-sf codes for latest DOLFINx
Browse files Browse the repository at this point in the history
  • Loading branch information
adeebkor committed Sep 10, 2024
1 parent c31280d commit 7f44245
Show file tree
Hide file tree
Showing 3 changed files with 102 additions and 56 deletions.
44 changes: 29 additions & 15 deletions cpp/fenicsx-sf/common/Linear.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,8 @@ void axpy(la::Vector<T>& r, T alpha, const la::Vector<T>& x, const la::Vector<T>
template <typename T, int P>
class LinearSpectral3D {
public:
LinearSpectral3D(std::shared_ptr<mesh::Mesh<T>> Mesh,
LinearSpectral3D(basix::FiniteElement<T> element,
std::shared_ptr<mesh::Mesh<T>> Mesh,
std::shared_ptr<mesh::MeshTags<std::int32_t>> FacetTags,
std::shared_ptr<fem::Function<T>> speedOfSound,
std::shared_ptr<fem::Function<T>> density,
Expand All @@ -79,7 +80,7 @@ class LinearSpectral3D {

// Define function space
V = std::make_shared<fem::FunctionSpace<T>>(
fem::create_functionspace(functionspace_form_forms_a, "u", mesh));
fem::create_functionspace(mesh, element));

// Define field functions
index_map = V->dofmap()->index_map;
Expand All @@ -98,19 +99,32 @@ class LinearSpectral3D {
std::fill(u_.begin(), u_.end(), 1.0);

// Compute exterior facets
std::map<fem::IntegralType,
std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>>> fd;
auto facet_domains = fem::compute_integration_domains(
fem::IntegralType::exterior_facet, *V->mesh()->topology_mutable(),
ft->indices(), mesh->topology()->dim() - 1, ft->values());
for (auto& facet : facet_domains) {
std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>> x;
x.emplace_back(facet.first, std::span(facet.second.data(), facet.second.size()));
fd.insert({fem::IntegralType::exterior_facet, std::move(x)});
}
std::vector<std::int32_t> ft_unique(ft->values().size());
std::copy(ft->values().begin(), ft->values().end(), ft_unique.begin());
std::sort(ft_unique.begin(), ft_unique.end());
auto it = std::unique(ft_unique.begin(), ft_unique.end());
ft_unique.erase(it, ft_unique.end());

std::map<fem::IntegralType, std::vector<std::pair<std::int32_t, std::vector<std::int32_t>>>> fd;
std::map<fem::IntegralType, std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>>> fd_view;

std::vector<std::int32_t> facet_domains;
for (auto& tag : ft_unique) {
facet_domains = fem::compute_integration_domains(
fem::IntegralType::exterior_facet, *V->mesh()->topology_mutable(),
ft->find(tag), mesh->topology()->dim()-1);
fd[fem::IntegralType::exterior_facet].push_back(
{tag, facet_domains});
}

for (auto const& [key, val] : fd) {
for (auto const& [tag, vec] : val) {
fd_view[key].push_back({tag, std::span(vec.data(), vec.size())});
}
}

// Define LHS form
a = std::make_shared<fem::Form<T, T>>(fem::create_form<T, T>(
a = std::make_shared<fem::Form<T>>(fem::create_form<T>(
*form_forms_a, {V}, {{"u", u}, {"c0", c0}, {"rho0", rho0}}, {}, {}));

m = std::make_shared<la::Vector<T>>(index_map, bs);
Expand All @@ -120,10 +134,10 @@ class LinearSpectral3D {
m->scatter_rev(std::plus<T>());

// Define RHS form
L = std::make_shared<fem::Form<T, T>>(fem::create_form<T, T>(
L = std::make_shared<fem::Form<T>>(fem::create_form<T>(
*form_forms_L, {V},
{{"g", g}, {"v_n", v_n}, {"c0", c0}, {"rho0", rho0}}, {},
fd));
fd_view, {}, {}));
b = std::make_shared<la::Vector<T>>(index_map, bs);
b_ = b->mutable_array();

Expand Down
58 changes: 37 additions & 21 deletions cpp/fenicsx-sf/common/Lossy.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,6 @@ void axpy(la::Vector<T>& r, T alpha, const la::Vector<T>& x, const la::Vector<T>

} // namespace kernels


/// Solver for the 3D second order linear wave equation with attenuation.
/// This solver uses GLL lattice and GLL quadrature such that it produces
/// a diagonal mass matrix.
Expand All @@ -54,14 +53,16 @@ void axpy(la::Vector<T>& r, T alpha, const la::Vector<T>& x, const la::Vector<T>
template <typename T, int P>
class LossySpectral3D {
public:
LossySpectral3D(std::shared_ptr<mesh::Mesh<T>> Mesh,
LossySpectral3D(basix::FiniteElement<T> element,
std::shared_ptr<mesh::Mesh<T>> Mesh,
std::shared_ptr<mesh::MeshTags<std::int32_t>> FacetTags,
std::shared_ptr<fem::Function<T>> speedOfSound,
std::shared_ptr<fem::Function<T>> density,
std::shared_ptr<fem::Function<T>> diffusivityOfSound,
const T& sourceFrequency,
const T& sourceAmplitude,
const T& sourceSpeed) {

// MPI
MPI_Comm_rank(MPI_COMM_WORLD, &mpi_rank);
MPI_Comm_size(MPI_COMM_WORLD, &mpi_size);
Expand All @@ -83,7 +84,7 @@ class LossySpectral3D {

// Define function space
V = std::make_shared<fem::FunctionSpace<T>>(
fem::create_functionspace(functionspace_form_forms_a, "u", mesh));
fem::create_functionspace(mesh, element));

// Define field functions
index_map = V->dofmap()->index_map;
Expand All @@ -104,21 +105,34 @@ class LossySpectral3D {
std::fill(u_.begin(), u_.end(), 1.0);

// Compute exterior facets
std::map<fem::IntegralType,
std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>>> fd;
auto facet_domains = fem::compute_integration_domains(
fem::IntegralType::exterior_facet, *V->mesh()->topology_mutable(),
ft->indices(), mesh->topology()->dim() - 1, ft->values());
for (auto& facet : facet_domains) {
std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>> x;
x.emplace_back(facet.first, std::span(facet.second.data(), facet.second.size()));
fd.insert({fem::IntegralType::exterior_facet, std::move(x)});
}
std::vector<std::int32_t> ft_unique(ft->values().size());
std::copy(ft->values().begin(), ft->values().end(), ft_unique.begin());
std::sort(ft_unique.begin(), ft_unique.end());
auto it = std::unique(ft_unique.begin(), ft_unique.end());
ft_unique.erase(it, ft_unique.end());

std::map<fem::IntegralType, std::vector<std::pair<std::int32_t, std::vector<std::int32_t>>>> fd;
std::map<fem::IntegralType, std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>>> fd_view;

std::vector<std::int32_t> facet_domains;
for (auto& tag : ft_unique) {
facet_domains = fem::compute_integration_domains(
fem::IntegralType::exterior_facet, *V->mesh()->topology_mutable(),
ft->find(tag), mesh->topology()->dim()-1);
fd[fem::IntegralType::exterior_facet].push_back(
{tag, facet_domains});
}

for (auto const& [key, val] : fd) {
for (auto const& [tag, vec] : val) {
fd_view[key].push_back({tag, std::span(vec.data(), vec.size())});
}
}

// Define LHS form
a = std::make_shared<fem::Form<T, T>>(fem::create_form<T, T>(
a = std::make_shared<fem::Form<T>>(fem::create_form<T>(
*form_forms_a, {V}, {{"u", u}, {"c0", c0}, {"rho0", rho0}, {"delta0", delta0}}, {},
fd));
fd_view, {}));

m = std::make_shared<la::Vector<T>>(index_map, bs);
m_ = m->mutable_array();
Expand All @@ -127,10 +141,10 @@ class LossySpectral3D {
m->scatter_rev(std::plus<T>());

// Define RHS form
L = std::make_shared<fem::Form<T, T>>(fem::create_form<T, T>(
L = std::make_shared<fem::Form<T>>(fem::create_form<T>(
*form_forms_L, {V},
{{"g", g}, {"dg", dg}, {"v_n", v_n}, {"c0", c0}, {"rho0", rho0}, {"delta0", delta0}}, {},
fd));
fd_view, {}, {}));
b = std::make_shared<la::Vector<T>>(index_map, bs);
b_ = b->mutable_array();

Expand Down Expand Up @@ -191,11 +205,13 @@ class LossySpectral3D {
dwindow = 0.0;
}

/*
// Update boundary condition (homogenous domain)
// std::fill(g_.begin(), g_.end(), window * p0 * w0 / s0 * cos(w0 * t));
// std::fill(dg_.begin(), dg_.end(),
// dwindow * p0 * w0 / s0 * cos(w0 * t)
// - window * p0 * w0 * w0 / s0 * sin(w0 * t));
std::fill(g_.begin(), g_.end(), window * p0 * w0 / s0 * cos(w0 * t));
std::fill(dg_.begin(), dg_.end(),
dwindow * p0 * w0 / s0 * cos(w0 * t)
- window * p0 * w0 * w0 / s0 * sin(w0 * t));
*/

// Update boundary condition (heterogenous domain)
std::fill(g_.begin(), g_.end(), window * 2.0 * p0 * w0 / s0 * cos(w0 * t));
Expand Down
56 changes: 36 additions & 20 deletions cpp/fenicsx-sf/common/Westervelt.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,8 @@ void axpy(la::Vector<T>& r, T alpha, const la::Vector<T>& x, const la::Vector<T>
template <typename T, int P>
class WesterveltSpectral3D {
public:
WesterveltSpectral3D(std::shared_ptr<mesh::Mesh<T>> Mesh,
WesterveltSpectral3D(basix::FiniteElement<T> element,
std::shared_ptr<mesh::Mesh<T>> Mesh,
std::shared_ptr<mesh::MeshTags<std::int32_t>> FacetTags,
std::shared_ptr<fem::Function<T>> speedOfSound,
std::shared_ptr<fem::Function<T>> density,
Expand Down Expand Up @@ -86,7 +87,7 @@ class WesterveltSpectral3D {

// Define function space
V = std::make_shared<fem::FunctionSpace<T>>(
fem::create_functionspace(functionspace_form_forms_a, "u", mesh));
fem::create_functionspace(mesh, element));

// Define field functions
index_map = V->dofmap()->index_map;
Expand All @@ -108,21 +109,34 @@ class WesterveltSpectral3D {
std::fill(u_.begin(), u_.end(), 1.0);

// Compute exterior facets
std::map<fem::IntegralType,
std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>>> fd;
auto facet_domains = fem::compute_integration_domains(
fem::IntegralType::exterior_facet, *V->mesh()->topology_mutable(),
ft->indices(), mesh->topology()->dim() - 1, ft->values());
for (auto& facet : facet_domains) {
std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>> x;
x.emplace_back(facet.first, std::span(facet.second.data(), facet.second.size()));
fd.insert({fem::IntegralType::exterior_facet, std::move(x)});
}
std::vector<std::int32_t> ft_unique(ft->values().size());
std::copy(ft->values().begin(), ft->values().end(), ft_unique.begin());
std::sort(ft_unique.begin(), ft_unique.end());
auto it = std::unique(ft_unique.begin(), ft_unique.end());
ft_unique.erase(it, ft_unique.end());

std::map<fem::IntegralType, std::vector<std::pair<std::int32_t, std::vector<std::int32_t>>>> fd;
std::map<fem::IntegralType, std::vector<std::pair<std::int32_t, std::span<const std::int32_t>>>> fd_view;

std::vector<std::int32_t> facet_domains;
for (auto& tag : ft_unique) {
facet_domains = fem::compute_integration_domains(
fem::IntegralType::exterior_facet, *V->mesh()->topology_mutable(),
ft->find(tag), mesh->topology()->dim()-1);
fd[fem::IntegralType::exterior_facet].push_back(
{tag, facet_domains});
}

for (auto const& [key, val] : fd) {
for (auto const& [tag, vec] : val) {
fd_view[key].push_back({tag, std::span(vec.data(), vec.size())});
}
}

// Define LHS form
a = std::make_shared<fem::Form<T, T>>(fem::create_form<T, T>(
a = std::make_shared<fem::Form<T>>(fem::create_form<T>(
*form_forms_a, {V}, {{"u", u}, {"c0", c0}, {"rho0", rho0}, {"delta0", delta0}}, {},
fd));
fd_view, {}));

m0 = std::make_shared<la::Vector<T>>(index_map, bs);
m0_ = m0->mutable_array();
Expand All @@ -133,10 +147,10 @@ class WesterveltSpectral3D {
m_ = m->mutable_array();

// Define RHS form
L = std::make_shared<fem::Form<T, T>>(fem::create_form<T, T>(
L = std::make_shared<fem::Form<T>>(fem::create_form<T>(
*form_forms_L, {V},
{{"g", g}, {"dg", dg}, {"v_n", v_n}, {"c0", c0}, {"rho0", rho0}, {"delta0", delta0}}, {},
fd));
fd_view, {}, {}));
b = std::make_shared<la::Vector<T>>(index_map, bs);
b_ = b->mutable_array();

Expand Down Expand Up @@ -211,11 +225,13 @@ class WesterveltSpectral3D {
dwindow = 0.0;
}

/*
// Update boundary condition (homogenous domain)
// std::fill(g_.begin(), g_.end(), window * p0 * w0 / s0 * cos(w0 * t));
// std::fill(dg_.begin(), dg_.end(),
// dwindow * p0 * w0 / s0 * cos(w0 * t)
// - window * p0 * w0 * w0 / s0 * sin(w0 * t));
std::fill(g_.begin(), g_.end(), window * p0 * w0 / s0 * cos(w0 * t));
std::fill(dg_.begin(), dg_.end(),
dwindow * p0 * w0 / s0 * cos(w0 * t)
- window * p0 * w0 * w0 / s0 * sin(w0 * t));
*/

// Update boundary condition (heterogenous domain)
std::fill(g_.begin(), g_.end(), window * 2.0 * p0 * w0 / s0 * cos(w0 * t));
Expand Down

0 comments on commit 7f44245

Please sign in to comment.