Skip to content

Commit

Permalink
Try #1489:
Browse files Browse the repository at this point in the history
  • Loading branch information
bors[bot] authored Oct 9, 2023
2 parents 2706600 + 9437aa5 commit 5ba71b3
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 9 deletions.
6 changes: 6 additions & 0 deletions .buildkite/pipeline.yml
Original file line number Diff line number Diff line change
Expand Up @@ -435,6 +435,12 @@ steps:
key: unit_hyb_ops_3d
command: "julia --color=yes --check-bounds=yes --project=test test/Operators/hybrid/3d.jl"

- label: "Unit: hyb ops 3d CUDA"
key: unit_hyb_ops_3d_cuda
command: "julia --color=yes --check-bounds=yes --project=test test/Operators/hybrid/3d.jl"
agents:
slurm_gpus: 1

- label: "Unit: remapping"
key: unit_remapping
command: "julia --color=yes --check-bounds=yes --project=test test/Operators/remapping.jl"
Expand Down
16 changes: 15 additions & 1 deletion src/Operators/finitedifference.jl
Original file line number Diff line number Diff line change
Expand Up @@ -240,11 +240,16 @@ StencilBroadcasted{Style}(

Adapt.adapt_structure(to, sbc::StencilBroadcasted{Style}) where {Style} =
StencilBroadcasted{Style}(
sbc.op,
Adapt.adapt(to, sbc.op),
Adapt.adapt(to, sbc.args),
Adapt.adapt(to, sbc.axes),
)

function Adapt.adapt_structure(to, op::FiniteDifferenceOperator)
op
end



function Base.Broadcast.instantiate(sbc::StencilBroadcasted)
op = sbc.op
Expand Down Expand Up @@ -2690,6 +2695,15 @@ Base.@propagate_inbounds function stencil_right_boundary(
stencil_interior(op, loc, space, idx - 1, hidx, arg)
end

function Adapt.adapt_structure(to, op::DivergenceF2C)
DivergenceF2C(map(bc -> Adapt.adapt_structure(to, bc), op.bcs))
end

function Adapt.adapt_structure(to, bc::SetValue)
SetValue(Adapt.adapt_structure(to, bc.val))
end


"""
D = DivergenceC2F(;boundaryname=boundarycondition...)
D.(v)
Expand Down
32 changes: 24 additions & 8 deletions test/Operators/hybrid/3d.jl
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ import ClimaCore.Geometry: WVector
import ClimaCore.Utilities: half
import ClimaCore.DataLayouts: level

device = ClimaComms.device()

@testset "sphere divergence" begin
FT = Float64
vertdomain = Domains.IntervalDomain(
Expand All @@ -26,12 +28,16 @@ import ClimaCore.DataLayouts: level
boundary_tags = (:bottom, :top),
)
vertmesh = Meshes.IntervalMesh(vertdomain, nelems = 10)
vert_center_space = Spaces.CenterFiniteDifferenceSpace(vertmesh)
verttopology = Topologies.IntervalTopology(
ClimaComms.SingletonCommsContext(device),
vertmesh,
)
vert_center_space = Spaces.CenterFiniteDifferenceSpace(verttopology)

horzdomain = Domains.SphereDomain(30.0)
horzmesh = Meshes.EquiangularCubedSphere(horzdomain, 4)
horztopology = Topologies.Topology2D(
ClimaComms.SingletonCommsContext(ClimaComms.CPUSingleThreaded()),
ClimaComms.SingletonCommsContext(device),
horzmesh,
)
quad = Spaces.Quadratures.GLL{3 + 1}()
Expand All @@ -53,7 +59,8 @@ function hvspace_3D(
xelem = 4,
yelem = 4,
zelem = 16,
npoly = 7,
npoly = 7;
device = ClimaComms.device(),
)
FT = Float64
vertdomain = Domains.IntervalDomain(
Expand All @@ -62,7 +69,11 @@ function hvspace_3D(
boundary_tags = (:bottom, :top),
)
vertmesh = Meshes.IntervalMesh(vertdomain, nelems = zelem)
vert_center_space = Spaces.CenterFiniteDifferenceSpace(vertmesh)
verttopology = Topologies.IntervalTopology(
ClimaComms.SingletonCommsContext(device),
vertmesh,
)
vert_center_space = Spaces.CenterFiniteDifferenceSpace(verttopology)

horzdomain = Domains.RectangleDomain(
Geometry.XPoint{FT}(xlim[1]) .. Geometry.XPoint{FT}(xlim[2]),
Expand All @@ -72,7 +83,7 @@ function hvspace_3D(
)
horzmesh = Meshes.RectilinearMesh(horzdomain, xelem, yelem)
horztopology = Topologies.Topology2D(
ClimaComms.SingletonCommsContext(ClimaComms.CPUSingleThreaded()),
ClimaComms.SingletonCommsContext(device),
horzmesh,
)

Expand Down Expand Up @@ -105,7 +116,8 @@ end

@testset "2D SE, 1D FV Extruded Domain ∇ ODE Solve vertical" begin

hv_center_space, hv_face_space = hvspace_3D()
hv_center_space, hv_face_space =
hvspace_3D(; device = ClimaComms.CPUSingleThreaded())
V =
Geometry.UVWVector.(
zeros(Float64, hv_face_space),
Expand Down Expand Up @@ -181,8 +193,12 @@ end
#
# NOTE: the equation setup is only correct for Cartesian domains!

hv_center_space, hv_face_space =
hvspace_3D((-1.0, 1.0), (-1.0, 1.0), (-1.0, 1.0))
hv_center_space, hv_face_space = hvspace_3D(
(-1.0, 1.0),
(-1.0, 1.0),
(-1.0, 1.0);
device = ClimaComms.CPUSingleThreaded(),
)

abstract type BCtag end
struct ZeroFlux <: BCtag end
Expand Down

0 comments on commit 5ba71b3

Please sign in to comment.