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

Full support for ghosted/unghosted distributed triangulations #100

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
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
1 change: 1 addition & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Added

- Added support for distributed level-set geometries. Since PR[#99](https://github.com/gridap/GridapEmbedded.jl/pull/99).
- Refactored the distributed code to allow for ghosted/unghosted geometries and triangulations. Since PR[#100](https://github.com/gridap/GridapEmbedded.jl/pull/100).

## [0.9.5] - 2024-10-18

Expand Down
17 changes: 8 additions & 9 deletions src/Distributed/Distributed.jl
Original file line number Diff line number Diff line change
Expand Up @@ -26,19 +26,16 @@ using GridapEmbedded.Interfaces: AbstractEmbeddedDiscretization
using GridapEmbedded.AgFEM: _touch_aggregated_cells!
using GridapEmbedded.AgFEM: AggregateCutCellsByThreshold
using GridapEmbedded.MomentFittedQuadratures: MomentFitted
using Gridap.Geometry: AppendedTriangulation
using Gridap.Geometry: AppendedTriangulation, TriangulationView
using Gridap.Geometry: get_face_to_parent_face
using Gridap.Arrays: find_inverse_index_map, testitem, return_type
using Gridap.FESpaces: FESpaceWithLinearConstraints
using Gridap.FESpaces: _dof_to_DOF, _DOF_to_dof
using GridapDistributed: DistributedDiscreteModel
using GridapDistributed: DistributedTriangulation
using GridapDistributed: DistributedFESpace
using GridapDistributed: DistributedSingleFieldFESpace
using GridapDistributed: DistributedMeasure
using GridapDistributed: add_ghost_cells
using GridapDistributed: generate_gids
using GridapDistributed: generate_cell_gids

using GridapDistributed: DistributedDiscreteModel, DistributedTriangulation, DistributedMeasure
using GridapDistributed: DistributedFESpace, DistributedSingleFieldFESpace
using GridapDistributed: NoGhost, WithGhost, filter_cells_when_needed, add_ghost_cells
using GridapDistributed: generate_gids, generate_cell_gids
using GridapDistributed: _find_vector_type

import GridapEmbedded.AgFEM: aggregate
Expand All @@ -61,6 +58,8 @@ include("DistributedDiscretizations.jl")

include("DistributedDiscreteGeometries.jl")

include("DistributedSubFacetTriangulations.jl")

include("DistributedAgFEM.jl")

include("DistributedQuadratures.jl")
Expand Down
122 changes: 102 additions & 20 deletions src/Distributed/DistributedAgFEM.jl
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@ function AgFEMSpace(
bgmodel::DistributedDiscreteModel,
f::DistributedFESpace,
bgcell_to_bgcellin::AbstractArray{<:AbstractVector},
g::DistributedFESpace=f)

g::DistributedFESpace=f
)
bgmodel_gids = get_cell_gids(bgmodel)
spaces = map(
local_views(f),
Expand All @@ -13,9 +13,7 @@ function AgFEMSpace(
local_views(bgmodel_gids)) do f,bgcell_to_bgcellin,g,gids
AgFEMSpace(f,bgcell_to_bgcellin,g,local_to_global(gids))
end
trians = map(get_triangulation,local_views(f))
trian = DistributedTriangulation(trians,bgmodel)
trian = add_ghost_cells(trian)
trian = add_ghost_cells(get_triangulation(f))
trian_gids = generate_cell_gids(trian)
cell_to_cellin = _active_aggregates(bgcell_to_bgcellin)
cell_to_ldofs = cell_ldof_to_mdof(spaces,cell_to_cellin)
Expand All @@ -26,7 +24,7 @@ function AgFEMSpace(
end

function aggregate(strategy,cutgeo::DistributedEmbeddedDiscretization,args...)
aggregates,aggregate_owner = distributed_aggregate(strategy,cutgeo,args...)
aggregates, aggregate_owner = distributed_aggregate(strategy,cutgeo,args...)
bgmodel = get_background_model(cutgeo)
if has_remote_aggregation(bgmodel,aggregates)
bgmodel = add_remote_aggregates(bgmodel,aggregates,aggregate_owner)
Expand All @@ -40,8 +38,8 @@ end
function distributed_aggregate(
strategy::AggregateCutCellsByThreshold,
cut::DistributedEmbeddedDiscretization,
in_or_out=IN)

in_or_out=IN
)
geo = get_geometry(cut)
distributed_aggregate(strategy,cut,geo,in_or_out)
end
Expand All @@ -50,14 +48,13 @@ function distributed_aggregate(
strategy::AggregateCutCellsByThreshold,
cut::DistributedEmbeddedDiscretization,
geo::CSG.Geometry,
in_or_out=IN)

in_or_out=IN
)
bgmodel = get_background_model(cut)
facet_to_inoutcut = compute_bgfacet_to_inoutcut(bgmodel,geo)
_distributed_aggregate_by_threshold(strategy.threshold,cut,geo,in_or_out,facet_to_inoutcut)
end


function _distributed_aggregate_by_threshold(threshold,cutgeo,geo,loc,facet_to_inoutcut)
@assert loc in (IN,OUT)

Expand All @@ -82,15 +79,14 @@ function _distributed_aggregate_by_threshold(threshold,cutgeo,geo,loc,facet_to_i

_distributed_aggregate_by_threshold_barrier(
threshold,cell_to_unit_cut_meas,facet_to_inoutcut,cell_to_inoutcut,
loc,cell_to_coords,cell_to_faces,face_to_cells,gids)
loc,cell_to_coords,cell_to_faces,face_to_cells,gids
)
end


function _distributed_aggregate_by_threshold_barrier(
threshold,cell_to_unit_cut_meas,facet_to_inoutcut,cell_to_inoutcut,
loc,cell_to_coords,cell_to_faces,face_to_cells,gids)


loc,cell_to_coords,cell_to_faces,face_to_cells,gids
)
ocell_to_touched = map(cell_to_unit_cut_meas) do c_to_m
map(≥,c_to_m,Fill(threshold,length(c_to_m)))
end
Expand All @@ -111,7 +107,6 @@ function _distributed_aggregate_by_threshold_barrier(
end

cell_to_neig = map(n->zeros(Int32,n),n_cells)

cell_to_root_part = map(collect,local_to_owner(gids))

c1 = map(array_cache,cell_to_faces)
Expand All @@ -129,7 +124,8 @@ function _distributed_aggregate_by_threshold_barrier(
cell_to_faces,
face_to_cells,
facet_to_inoutcut,
loc)
loc
)

PVector(cell_to_touched,partition(gids)) |> consistent! |> wait
PVector(cell_to_neig,partition(gids)) |> consistent! |> wait
Expand Down Expand Up @@ -248,8 +244,8 @@ function _find_best_neighbor_from_centroid_distance(
cell_to_touched,
cell_to_root_centroid,
facet_to_inoutcut,
loc)

loc
)
faces = getindex!(c1,cell_to_faces,cell)
dmin = Inf
T = eltype(eltype(face_to_cells))
Expand Down Expand Up @@ -559,6 +555,8 @@ function _local_aggregates(cell_to_gcellin,gcell_to_cell)
end
end

# change_bgmodel

function change_bgmodel(cell_to_gcellin,gids::PRange)
map(change_bgmodel,cell_to_gcellin,local_to_global(gids))
end
Expand All @@ -571,3 +569,87 @@ function change_bgmodel(cell_to_gcellin,ncell_to_gcell)
end
ncell_to_gcellin
end

function change_bgmodel(
cutgeo::DistributedEmbeddedDiscretization,
model::DistributedDiscreteModel
)
cuts = map(change_bgmodel,local_views(cutgeo),local_views(model))
DistributedEmbeddedDiscretization(cuts,model)
end

function change_bgmodel(
cutgeo::DistributedEmbeddedDiscretization,
model::DistributedDiscreteModel,
cell_to_new_cell
)
cuts = map(change_bgmodel,local_views(cutgeo),local_views(model),cell_to_new_cell)
DistributedEmbeddedDiscretization(cuts,model)
end

function change_bgmodel(
cut::EmbeddedDiscretization,
newmodel::DiscreteModel,
cell_to_newcell=1:num_cells(get_background_model(cut))
)
ls_to_bgc_to_ioc = map(cut.ls_to_bgcell_to_inoutcut) do bgc_to_ioc
new_bgc_to_ioc = Vector{Int8}(undef,num_cells(newmodel))
new_bgc_to_ioc[cell_to_newcell] = bgc_to_ioc
new_bgc_to_ioc
end
subcells = change_bgmodel(cut.subcells,cell_to_newcell)
subfacets = change_bgmodel(cut.subfacets,cell_to_newcell)
EmbeddedDiscretization(
newmodel,
ls_to_bgc_to_ioc,
subcells,
cut.ls_to_subcell_to_inout,
subfacets,
cut.ls_to_subfacet_to_inout,
cut.oid_to_ls,
cut.geo
)
end

function change_bgmodel(
cut::EmbeddedFacetDiscretization,
newmodel::DiscreteModel,
facet_to_newfacet=1:num_facets(get_background_model(cut))
)
nfacets = num_facets(newmodel)
ls_to_bgf_to_ioc = map(cut.ls_to_facet_to_inoutcut) do bgf_to_ioc
new_bgf_to_ioc = Vector{Int8}(undef,nfacets)
new_bgf_to_ioc[facet_to_newfacet] = bgf_to_ioc
new_bgf_to_ioc
end
subfacets = change_bgmodel(cut.subfacets,facet_to_newfacet)
EmbeddedFacetDiscretization(
newmodel,
ls_to_bgf_to_ioc,
subfacets,
cut.ls_to_subfacet_to_inout,
cut.oid_to_ls,
cut.geo
)
end

function change_bgmodel(cells::SubCellData,cell_to_newcell)
cell_to_bgcell = lazy_map(Reindex(cell_to_newcell),cells.cell_to_bgcell)
SubCellData(
cells.cell_to_points,
collect(Int32,cell_to_bgcell),
cells.point_to_coords,
cells.point_to_rcoords
)
end

function change_bgmodel(facets::SubFacetData,cell_to_newcell)
facet_to_bgcell = lazy_map(Reindex(cell_to_newcell),facets.facet_to_bgcell)
SubFacetData(
facets.facet_to_points,
facets.facet_to_normal,
collect(Int32,facet_to_bgcell),
facets.point_to_coords,
facets.point_to_rcoords
)
end
Loading
Loading