Skip to content

Commit

Permalink
Merge commit '385e88ee90166642d221d89625bc0378e6492d7e' into topology
Browse files Browse the repository at this point in the history
* commit '385e88ee90166642d221d89625bc0378e6492d7e':
  Add local test plot of ideal age (coarsened)
  • Loading branch information
briochemc committed Oct 10, 2024
2 parents 1a581e6 + 385e88e commit 18879ba
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 16 deletions.
3 changes: 2 additions & 1 deletion Project.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ DataFrames = "a93c6f00-e57d-5684-b7b6-d8193f3e46c0"
GLMakie = "e9467ef8-e4e7-5192-8a1a-b1aee30e663a"
LinearAlgebra = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e"
Makie = "ee78f7c6-11fb-53f2-987a-cfe4a2b5a57a"
NaNStatistics = "b946abbf-3ea7-4610-9019-9858bfdeaf2d"
NetCDF = "30363a11-5582-574a-97bb-aa9a979735b9"
Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40"
TestItemRunner = "f8b46487-2199-4994-9208-9a1283c18c0a"
Expand All @@ -29,4 +30,4 @@ YAXArrays = "c21b50f5-aa40-41ea-b809-c0f5e47bfa5c"
Zarr = "0a941bbe-ad1d-11e8-39d9-ab76183a1d99"

[targets]
test = ["GLMakie", "LinearAlgebra", "Makie", "NetCDF", "Test", "TestItemRunner", "TestItems", "Unitful", "YAXArrays", "CSV", "DataFrames", "Zarr"]
test = ["GLMakie", "LinearAlgebra", "Makie", "NaNStatistics", "NetCDF", "Test", "TestItemRunner", "TestItems", "Unitful", "YAXArrays", "CSV", "DataFrames", "Zarr"]
47 changes: 32 additions & 15 deletions test/localbuild.jl
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,9 @@
using LinearAlgebra

# My local directory for input files
inputdir = "/Users/benoitpasquier/Data/TMIP/data/ACCESS-ESM1-5/historical/r1i1p1f1/Jan1990-Dec1999"
model = "ACCESS-ESM1-5"
member = "r1i1p1f1"
inputdir = "/Users/benoitpasquier/Data/TMIP/data/$model/historical/$member/Jan1990-Dec1999"

# Load datasets
umo_ds = open_dataset(joinpath(inputdir, "umo.nc"))
Expand Down Expand Up @@ -232,21 +234,21 @@ end
using LinearAlgebra
using Unitful
using Unitful: s, yr
using NaNStatistics
using GLMakie

(; modelgrid, indices, T, model, member, outputdir) = LocalBuiltMatrix

# unpack model grid
(; v3D,) = LocalBuiltMatrix.modelgrid
(; v3D, lat, zt) = modelgrid
# unpack indices
(; wet3D, N) = LocalBuiltMatrix.indices
(; wet3D, N) = indices

v = v3D[wet3D]

@info "coarsening grid"
LUMP, SPRAY, wet3D_c, v_c = OceanTransportMatrixBuilder.lump_and_spray(wet3D, v; di=2, dj=2, dk=1)

# unpack transport matrices
(; T) = LocalBuiltMatrix

# surface mask
issrf3D = copy(wet3D)
issrf3D[:,:,2:end] .= false
Expand All @@ -264,7 +266,22 @@ end
Γ = SPRAY * Γ_c
Γyr = ustrip.(yr, Γ .* s)
Γ3D = OceanTransportMatrixBuilder.as3D(Γyr, wet3D)

begin # plot zonal average
Γ2D = dropdims(nansum(Γ3D .* v3D, dims = 1) ./ nansum(v3D, dims = 1), dims = 1)
fig = Figure()
ax = Axis(fig[1,1], xlabel = "latitude (°)", ylabel = "depth (m)")
levels = 0:100:2000
colormap = :viridis
co = contourf!(ax, dropdims(maximum(lat |> Array, dims=1), dims=1), zt |> Array, Γ2D; levels, colormap)
cb = Colorbar(fig[1, 2], co; label = "Ideal mean age (yr)", tellheight = false)
cb.height = Relative(2/3)
ylims!(ax, (6000, 0))
Label(fig[0,1], text = "$model $member ideal mean age", tellwidth = false)
fig
end
outputfile = joinpath(outputdir, "ideal_age_$model.png")
@info "Saving ideal age as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)
@test 0 < (v' * Γyr) / sum(v) < 2000

end
Expand Down Expand Up @@ -455,7 +472,7 @@ end
cb.height = Relative(0.8)
fig
outputfile = joinpath(outputdir, "distances_check_$model.png")
@info "Saving distances check as image file:\n $(outputfile)"
@info "Saving distances check as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)


Expand All @@ -476,7 +493,7 @@ end
Label(fig[0,1], text = "Vertices check $model model", tellwidth = false, fontsize = 20)
fig
outputfile = joinpath(outputdir, "vertices_check_local_$model.png")
@info "Saving vertices check as image file:\n $(outputfile)"
@info "Saving vertices check as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)

# Check that the correct vertex order was applied to all cells
Expand Down Expand Up @@ -541,7 +558,7 @@ end
Label(fig[0,1], text = "Grid cell centers check $model model", tellwidth = false, fontsize = 20)
fig
outputfile = joinpath(outputdir, "grid_cell_centers_check_local_$model.png")
@info "Saving lon/lat check as image file:\n $(outputfile)"
@info "Saving lon/lat check as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)


Expand All @@ -554,7 +571,7 @@ end
Label(fig[0,1], text = "Area grid check $model model", tellwidth = false, fontsize = 20)
fig
outputfile = joinpath(outputdir, "area_check_local_$model.png")
@info "Saving area check as image file:\n $(outputfile)"
@info "Saving area check as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)


Expand All @@ -578,7 +595,7 @@ end
Label(fig[0,1:2], text = "Volume grid check $model model", tellwidth = false, fontsize = 20)
fig
outputfile = joinpath(outputdir, "volume_check_local_$model.png")
@info "Saving volume check as image file:\n $(outputfile)"
@info "Saving volume check as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)


Expand All @@ -601,7 +618,7 @@ end
Label(fig[0,1:2], text = "Cell thickness grid check $model model", tellwidth = false, fontsize = 20)
fig
outputfile = joinpath(outputdir, "cell_thickness_check_local_$model.png")
@info "Saving cell thickness check as image file:\n $(outputfile)"
@info "Saving cell thickness check as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)


Expand All @@ -616,7 +633,7 @@ end
ax = Axis(fig[1,2], xlabel = rich("$model0 cell volumes (", km3, ")"), ylabel = "relative error (%)")
scatter!(ax, X, 100 * abs.(Y .- X) ./ X, markersize = 0.5)
outputfile = joinpath(outputdir, "volume_comparison_$(model0)_vs_$(model).png")
@info "Saving volume comparison as image file:\n $(outputfile)"
@info "Saving volume comparison as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)


Expand All @@ -634,7 +651,7 @@ end
Label(fig[0,1], text = "$model mixed-layer depth", tellwidth = false, fontsize = 20)
fig
outputfile = joinpath(outputdir, "MLD_check_local_$model.png")
@info "Saving MLD check as image file:\n $(outputfile)"
@info "Saving MLD check as image file:\n $(joinpath("test", outputfile))"
save(outputfile, fig)

end
Expand Down

0 comments on commit 18879ba

Please sign in to comment.