Skip to content

Commit

Permalink
Merge pull request #146 from gridap/cell_field_evaluation_at_arbitrar…
Browse files Browse the repository at this point in the history
…y_points

Cell field evaluation at arbitrary points
  • Loading branch information
JordiManyer authored May 17, 2024
2 parents 81bcf23 + 6e694f2 commit 0bb7457
Show file tree
Hide file tree
Showing 3 changed files with 91 additions and 1 deletion.
72 changes: 71 additions & 1 deletion src/CellData.jl
Original file line number Diff line number Diff line change
Expand Up @@ -352,4 +352,74 @@ function Gridap.Arrays.evaluate!(cache, ::DistributedCellField, ::DistributedCel
Did you mean evaluate(f,s) instead of evaluate(s,f), i.e.
f(s) instead of s(f)?
"""
end
end

# Interpolation at arbitrary points (returns -Inf if the point is not found)
Arrays.evaluate!(cache,f::DistributedCellField,x::Point) = evaluate!(cache,Interpolable(f),x)
Arrays.evaluate!(cache,f::DistributedCellField,x::AbstractVector{<:Point}) = evaluate!(cache,Interpolable(f),x)

struct DistributedInterpolable{A} <: Function
interps::A
end
local_views(a::DistributedInterpolable) = a.interps

function Interpolable(f::DistributedCellField;kwargs...)
interps = map(local_views(f)) do fun
Interpolable(fun,kwargs...)
end
DistributedInterpolable(interps)
end

(a::DistributedInterpolable)(x) = evaluate(a,x)

function Gridap.Arrays.return_cache(I::DistributedInterpolable,x::Point)
caches = map(local_views(I)) do fi
trian = get_triangulation(fi.uh)
y=mean(testitem(get_cell_coordinates(trian)))
@check typeof(testitem(x)) == typeof(y) "Can only evaluate DistributedInterpolable at physical points of the same dimension of the underlying triangulation"
return_cache(fi,y)
end
caches
end
Gridap.Arrays.return_cache(f::DistributedInterpolable,x::AbstractVector{<:Point}) = Gridap.Arrays.return_cache(f,testitem(x))

function Gridap.Arrays.evaluate!(caches,I::DistributedInterpolable,x::Point)
y=map(local_views(I),local_views(caches)) do fi,cache
try
evaluate!(cache,fi,x)
catch
-Inf
end
end
# reduce(max,y)
z=gather(y)
map_main(local_views(z)) do zi
reduce(max,zi)
end
end

function Gridap.Arrays.evaluate!(caches,I::DistributedInterpolable,v::AbstractVector{<:Point})
n=length(local_views(I))
m=length(v)
y=map(local_views(I),local_views(caches)) do fi,cache
w=Vector{Float64}(undef,m)
for (i,x) in enumerate(v)
try
w[i]=evaluate!(cache,fi,x)
catch
w[i]=-Inf
end
end
return w
end
# z=gather(y,destination=:all)
z=gather(y)
map_main(local_views(z)) do zi
w=Vector{Float64}(undef,m)
for i=0:m-1
w[i+1]=reduce(max,zi.data[zi.ptrs[1:n].+i])
end
return w
end
# reduce((v,w)->broadcast(max,v,w),y)
end
1 change: 1 addition & 0 deletions src/GridapDistributed.jl
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ import Gridap.TensorValues: inner, outer, double_contraction, symmetric_part
import LinearAlgebra: det, tr, cross, dot, , diag
import Base: inv, abs, abs2, *, +, -, /, adjoint, transpose, real, imag, conj, getproperty, propertynames
import Gridap.Fields: grad2curl
import Gridap.CellData: Interpolable

export FullyAssembledRows
export SubAssembledRows
Expand Down
19 changes: 19 additions & 0 deletions test/CellDataTests.jl
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,25 @@ function main(distribute,parts)
u3 = CellField(2.0,Ω)
u = _my_op(u1,u2,u3)

order = 1
reffe = ReferenceFE(lagrangian,Float64,order)
V = TestFESpace(model,reffe)
uh = interpolate_everywhere(x->x[1]+x[2],V)
x1 = Point(0.1,0.1)
x2 = Point(0.1,0.9)
x3 = Point(0.9,0.9)
v = [x1,x2,x3]

u1 = uh(x1)
u2 = uh(x2)
uv = uh(v)

map_main(u1,u2,uv) do u1,u2,v
@test u1 == 0.2
@test u2 == 1.0
@test v ==[0.2,1.0,1.8]
end

end

end # module

0 comments on commit 0bb7457

Please sign in to comment.