From 73b9ad83c4004e1e7c9c01f7e568b14a7756f4f8 Mon Sep 17 00:00:00 2001 From: Charles Kawczynski Date: Mon, 11 Nov 2024 12:58:55 -0500 Subject: [PATCH] Define CommonSpaces module --- NEWS.md | 21 ++- docs/src/api.md | 12 ++ src/ClimaCore.jl | 1 + src/CommonSpaces/CommonSpaces.jl | 199 ++++++++++++++++++++++++ test/CommonSpaces/unit_common_spaces.jl | 137 ++++++++++++++++ 5 files changed, 363 insertions(+), 7 deletions(-) create mode 100644 src/CommonSpaces/CommonSpaces.jl create mode 100644 test/CommonSpaces/unit_common_spaces.jl diff --git a/NEWS.md b/NEWS.md index b4eb35a610..629987be79 100644 --- a/NEWS.md +++ b/NEWS.md @@ -4,16 +4,23 @@ ClimaCore.jl Release Notes main ------- + - We've added new convenience constructors for spaces PR [2082](https://github.com/CliMA/ClimaCore.jl/pull/2082). Here are links to the new constructors: + - [ExtrudedCubedSphereSpace]() + - [CubedSphereSpace]() + - [ColumnSpace]() + - [Box3DSpace]() + - [SliceXZSpace]() + - [RectangleXYSpace]() + v0.14.20 -------- - We've added new convenience constructors for grids PR [1848](https://github.com/CliMA/ClimaCore.jl/pull/1848). Here are links to the new constructors: - - [ExtrudedCubedSphereGrid]() - - [CubedSphereGrid]() - - [ColumnGrid]() - - [Box3DGrid]() - - [SliceXZGrid]() - - [RectangleXYGrid]() + - [ExtrudedCubedSphereGrid](https://github.com/CliMA/ClimaCore.jl/blob/cbb193042fac3b4bef33251fbc0f232427bfe506/src/CommonGrids/CommonGrids.jl#L85-L144) + - [CubedSphereGrid](https://github.com/CliMA/ClimaCore.jl/blob/cbb193042fac3b4bef33251fbc0f232427bfe506/src/CommonGrids/CommonGrids.jl#L200-L235) + - [ColumnGrid](https://github.com/CliMA/ClimaCore.jl/blob/cbb193042fac3b4bef33251fbc0f232427bfe506/src/CommonGrids/CommonGrids.jl#L259-L281) + - [Box3DGrid](https://github.com/CliMA/ClimaCore.jl/blob/cbb193042fac3b4bef33251fbc0f232427bfe506/src/CommonGrids/CommonGrids.jl#L303-L378) + - [SliceXZGrid](https://github.com/CliMA/ClimaCore.jl/blob/cbb193042fac3b4bef33251fbc0f232427bfe506/src/CommonGrids/CommonGrids.jl#L441-L498) + - [RectangleXYGrid](https://github.com/CliMA/ClimaCore.jl/blob/cbb193042fac3b4bef33251fbc0f232427bfe506/src/CommonGrids/CommonGrids.jl#L547-L602) - A `strict = true` keyword was added to `rcompare`, which checks that the types match. If `strict = false`, then `rcompare` will return `true` for `FieldVector`s and `NamedTuple`s with the same properties but permuted order. For example: - `rcompare((;a=1,b=2), (;b=2,a=1); strict = true)` will return `false` and diff --git a/docs/src/api.md b/docs/src/api.md index cfb9fd029b..5bea58e919 100644 --- a/docs/src/api.md +++ b/docs/src/api.md @@ -247,6 +247,18 @@ Spaces.SpectralElementSpaceSlab Spaces.node_horizontal_length_scale ``` +## CommonSpaces + +```@docs +CommonSpaces +CommonSpaces.ExtrudedCubedSphereSpace +CommonSpaces.CubedSphereSpace +CommonSpaces.ColumnSpace +CommonSpaces.Box3DSpace +CommonSpaces.SliceXZSpace +CommonSpaces.RectangleXYSpace +``` + ### Quadratures diff --git a/src/ClimaCore.jl b/src/ClimaCore.jl index cb908bf7f1..2ee050abb2 100644 --- a/src/ClimaCore.jl +++ b/src/ClimaCore.jl @@ -24,6 +24,7 @@ include("Limiters/Limiters.jl") include("InputOutput/InputOutput.jl") include("Remapping/Remapping.jl") include("CommonGrids/CommonGrids.jl") +include("CommonSpaces/CommonSpaces.jl") include("deprecated.jl") diff --git a/src/CommonSpaces/CommonSpaces.jl b/src/CommonSpaces/CommonSpaces.jl new file mode 100644 index 0000000000..411f394fce --- /dev/null +++ b/src/CommonSpaces/CommonSpaces.jl @@ -0,0 +1,199 @@ +""" + CommonSpaces + +CommonSpaces contains convenience constructors for common +spaces, which builds off of [`CommonGrids`](@ref) and +(when appropriate) requires an additional argument, +`staggering::Staggering` to construct the desired +space. +""" +module CommonSpaces + +export ExtrudedCubedSphereSpace, + CubedSphereSpace, ColumnSpace, Box3DSpace, SliceXZSpace, RectangleXYSpace + +export Grids +import ..Grids +import ..Grids: Staggering +import ..Spaces +import ..CommonGrids +import ..CommonGrids: + ExtrudedCubedSphereGrid, + CubedSphereGrid, + ColumnGrid, + Box3DGrid, + SliceXZGrid, + RectangleXYGrid + +""" + ExtrudedCubedSphereSpace(args...; staggering::Staggering, kwargs...) + +Calls [`CommonGrids.ExtrudedCubedSphereGrid`](@ref), +with the args, kwargs, plus an additional `staggering::Staggering` +keyword, to construct a cell center or cell face space. + +# Example usage + +```julia +using ClimaCore.CommonSpaces +space = ExtrudedCubedSphereSpace(; + z_elem = 10, + z_min = 0, + z_max = 1, + radius = 10, + h_elem = 10, + n_quad_points = 4, + staggering = Grids.CellCenter() +) +``` +""" +function ExtrudedCubedSphereSpace end + +ExtrudedCubedSphereSpace(; kwargs...) = + ExtrudedCubedSphereSpace(Float64; kwargs...) +ExtrudedCubedSphereSpace( + ::Type{FT}; + staggering::Staggering, + kwargs..., +) where {FT} = Spaces.ExtrudedFiniteDifferenceSpace( + ExtrudedCubedSphereGrid(FT; kwargs...), + staggering, +) + +""" + CubedSphereSpace(args...; kwargs...) + +Calls [`CommonGrids.CubedSphereGrid`](@ref), +with the args, kwargs. + +# Example usage + +```julia +using ClimaCore.CommonSpaces +space = CubedSphereSpace(; + radius = 10, + n_quad_points = 4, + h_elem = 10, +) +``` +""" +function CubedSphereSpace end +CubedSphereSpace(; kwargs...) = CubedSphereSpace(Float64; kwargs...) +CubedSphereSpace(::Type{FT}; kwargs...) where {FT} = + Spaces.SpectralElementSpace2D(CubedSphereGrid(FT; kwargs...)) + +""" + ColumnSpace(args...; kwargs...) + +Calls [`CommonGrids.ColumnGrid`](@ref), +with the args, kwargs, plus an additional `staggering::Staggering` +keyword, to construct a cell center or cell face space. + +# Example usage + +```julia +using ClimaCore.CommonSpaces +space = ColumnSpace(; + z_elem = 10, + z_min = 0, + z_max = 10, + staggering = Grids.CellCenter() +) +``` +""" +function ColumnSpace end +ColumnSpace(; kwargs...) = ColumnSpace(Float64; kwargs...) +ColumnSpace(::Type{FT}; staggering::Staggering, kwargs...) where {FT} = + Spaces.FiniteDifferenceSpace(ColumnGrid(FT; kwargs...), staggering) + +""" + Box3DSpace(args...; kwargs...) + +Calls [`CommonGrids.Box3DGrid`](@ref), +with the args, kwargs, plus an additional `staggering::Staggering` +keyword, to construct a cell center or cell face space. + +# Example usage + +```julia +using ClimaCore.CommonSpaces +space = Box3DSpace(; + z_elem = 10, + x_min = 0, + x_max = 1, + y_min = 0, + y_max = 1, + z_min = 0, + z_max = 10, + periodic_x = false, + periodic_y = false, + n_quad_points = 4, + x_elem = 3, + y_elem = 4, + staggering = Grids.CellCenter() +) +``` +""" +function Box3DSpace end +Box3DSpace(; kwargs...) = Box3DSpace(Float64; kwargs...) +Box3DSpace(::Type{FT}; staggering::Staggering, kwargs...) where {FT} = + Spaces.ExtrudedFiniteDifferenceSpace(Box3DGrid(FT; kwargs...), staggering) + +""" + SliceXZSpace(args...; kwargs...) + +Calls [`CommonGrids.SliceXZGrid`](@ref), +with the args, kwargs, plus an additional `staggering::Staggering` +keyword, to construct a cell center or cell face space. + +# Example usage + +```julia +using ClimaCore.CommonSpaces +space = SliceXZSpace(; + z_elem = 10, + x_min = 0, + x_max = 1, + z_min = 0, + z_max = 1, + periodic_x = false, + n_quad_points = 4, + x_elem = 4, + staggering = Grids.CellCenter() +) +``` +""" +function SliceXZSpace end +SliceXZSpace(; kwargs...) = SliceXZSpace(Float64; kwargs...) +SliceXZSpace(::Type{FT}; staggering::Staggering, kwargs...) where {FT} = + Spaces.ExtrudedFiniteDifferenceSpace(SliceXZGrid(FT; kwargs...), staggering) + +""" + RectangleXYSpace(args...; kwargs...) + +Calls [`CommonGrids.RectangleXYGrid`](@ref), +with the args, kwargs. + +# Example usage + +```julia +using ClimaCore.CommonSpaces +space = RectangleXYSpace(; + x_min = 0, + x_max = 1, + y_min = 0, + y_max = 1, + periodic_x = false, + periodic_y = false, + n_quad_points = 4, + x_elem = 3, + y_elem = 4, +) +``` +""" +function RectangleXYSpace end +RectangleXYSpace(; kwargs...) = RectangleXYSpace(Float64; kwargs...) +RectangleXYSpace(::Type{FT}; kwargs...) where {FT} = + Spaces.SpectralElementSpace2D(RectangleXYGrid(FT; kwargs...)) + +end # module diff --git a/test/CommonSpaces/unit_common_spaces.jl b/test/CommonSpaces/unit_common_spaces.jl new file mode 100644 index 0000000000..468ea9e69f --- /dev/null +++ b/test/CommonSpaces/unit_common_spaces.jl @@ -0,0 +1,137 @@ +#= +julia --project +using Revise; include(joinpath("test", "CommonSpaces", "unit_common_spaces.jl")) +=# +import ClimaComms +ClimaComms.@import_required_backends +using ClimaCore.CommonSpaces +using ClimaCore: + Geometry, + Hypsography, + Fields, + Spaces, + Grids, + Topologies, + Meshes, + DataLayouts +using Test + +@testset "Convenience constructors" begin + function warp_surface(coord) + # sin²(x) form ground elevation + x = Geometry.component(coord, 1) + FT = eltype(x) + hc = FT(500.0) + h = hc * FT(sin(π * x / 25000)^2) + return h + end + + space = ExtrudedCubedSphereSpace(; + z_elem = 10, + z_min = 0, + z_max = 1, + radius = 10, + h_elem = 10, + n_quad_points = 4, + horizontal_layout_type = DataLayouts.IJHF, + staggering = Grids.CellCenter(), + ) + grid = Spaces.grid(space) + @test grid isa Grids.ExtrudedFiniteDifferenceGrid + @test grid.horizontal_grid isa Grids.SpectralElementGrid2D + @test Grids.topology(grid.horizontal_grid).mesh isa + Meshes.EquiangularCubedSphere + + function hypsography_fun(h_grid, z_grid) + h_space = Spaces.SpectralElementSpace2D(h_grid) + cf = Fields.coordinate_field(h_space) + warp_fn = warp_surface # closure + z_surface = map(cf) do coord + Geometry.ZPoint(warp_fn(coord)) + end + Hypsography.LinearAdaption(z_surface) + end + + space = ExtrudedCubedSphereSpace(; + z_elem = 10, + z_min = 0, + z_max = 1, + radius = 10, + h_elem = 10, + n_quad_points = 4, + hypsography_fun, + staggering = Grids.CellCenter(), + ) + grid = Spaces.grid(space) + @test grid isa Grids.ExtrudedFiniteDifferenceGrid + @test grid.horizontal_grid isa Grids.SpectralElementGrid2D + @test Grids.topology(grid.horizontal_grid).mesh isa + Meshes.EquiangularCubedSphere + @test Grids.topology(grid.horizontal_grid).mesh isa + Meshes.EquiangularCubedSphere + + space = CubedSphereSpace(; radius = 10, n_quad_points = 4, h_elem = 10) + grid = Spaces.grid(space) + @test grid isa Grids.SpectralElementGrid2D + @test Grids.topology(grid).mesh isa Meshes.EquiangularCubedSphere + + space = ColumnSpace(; + z_elem = 10, + z_min = 0, + z_max = 1, + staggering = Grids.CellCenter(), + ) + grid = Spaces.grid(space) + @test grid isa Grids.FiniteDifferenceGrid + + space = Box3DSpace(; + z_elem = 10, + x_min = 0, + x_max = 1, + y_min = 0, + y_max = 1, + z_min = 0, + z_max = 10, + periodic_x = false, + periodic_y = false, + n_quad_points = 4, + x_elem = 3, + y_elem = 4, + staggering = Grids.CellCenter(), + ) + grid = Spaces.grid(space) + @test grid isa Grids.ExtrudedFiniteDifferenceGrid + @test grid.horizontal_grid isa Grids.SpectralElementGrid2D + @test Grids.topology(grid.horizontal_grid).mesh isa Meshes.RectilinearMesh + + space = SliceXZSpace(; + z_elem = 10, + x_min = 0, + x_max = 1, + z_min = 0, + z_max = 1, + periodic_x = false, + n_quad_points = 4, + x_elem = 4, + staggering = Grids.CellCenter(), + ) + grid = Spaces.grid(space) + @test grid isa Grids.ExtrudedFiniteDifferenceGrid + @test grid.horizontal_grid isa Grids.SpectralElementGrid1D + @test Grids.topology(grid.horizontal_grid).mesh isa Meshes.IntervalMesh + + space = RectangleXYSpace(; + x_min = 0, + x_max = 1, + y_min = 0, + y_max = 1, + periodic_x = false, + periodic_y = false, + n_quad_points = 4, + x_elem = 3, + y_elem = 4, + ) + grid = Spaces.grid(space) + @test grid isa Grids.SpectralElementGrid2D + @test Grids.topology(grid).mesh isa Meshes.RectilinearMesh +end