Skip to content

Commit

Permalink
Number format flexibility with set! (#634)
Browse files Browse the repository at this point in the history
* fix: a bug when using set!

* update changelog

* remove time stamp comments

* assert number format before fourier transform

* set_vordiv! with NF conversion for FFTW

---------

Co-authored-by: Lu Peng <[email protected]>
Co-authored-by: milankl <[email protected]>
  • Loading branch information
3 people authored Dec 14, 2024
1 parent f38f918 commit 0578a7a
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 7 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

## Unreleased

- Number format flexibility with set! [#634](https://github.com/SpeedyWeather/SpeedyWeather.jl/pull/634)
- Forcing/drag for primitive models [#635](https://github.com/SpeedyWeather/SpeedyWeather.jl/pull/635)
- RingGrids indexing with leading Colon should now always return another RingGrid instance [#637](https://github.com/SpeedyWeather/SpeedyWeather.jl/pull/637)
- Roll back GPUArrays upgrade to ensure CUDA compatibility [#636](https://github.com/SpeedyWeather/SpeedyWeather.jl/pull/636)
Expand Down
2 changes: 2 additions & 0 deletions src/SpeedyTransforms/fourier.jl
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ function _fourier_batched!( # GRID TO SPECTRAL
(; rfft_plans) = S # pre-planned transforms
nlayers = size(grids, 2) # number of vertical layers

@assert eltype(grids) == eltype(S) "Number format of grid $(eltype(grids)) and SpectralTransform $(eltype(S)) need too match."
@boundscheck ismatching(S, grids) || throw(DimensionMismatch(S, grids))
@boundscheck nlayers == S.nlayers || throw(DimensionMismatch(S, grids))
@boundscheck size(f_north) == size(f_south) == (S.nfreq_max, S.nlayers, nlat_half) || throw(DimensionMismatch(S, grids))
Expand Down Expand Up @@ -82,6 +83,7 @@ function _fourier_serial!( # GRID TO SPECTRAL
rfft_plans = S.rfft_plans_1D # pre-planned transforms
nlayers = size(grids, 2) # number of vertical layers

@assert eltype(grids) == eltype(S) "Number format of grid $(eltype(grids)) and SpectralTransform $(eltype(S)) need too match."
@boundscheck ismatching(S, grids) || throw(DimensionMismatch(S, grids))
@boundscheck nlayers <= S.nlayers || throw(DimensionMismatch(S, grids))
@boundscheck size(f_north) == size(f_south) == (S.nfreq_max, S.nlayers, nlat_half) || throw(DimensionMismatch(S, grids))
Expand Down
3 changes: 3 additions & 0 deletions src/SpeedyTransforms/spectral_transform.jl
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,9 @@ struct SpectralTransform{
eigenvalues⁻¹::VectorType # = -1/(l*(l+1))
end

# eltype of a transform is the number format used within
Base.eltype(S::SpectralTransform{NF}) where NF = NF

"""
$(TYPEDSIGNATURES)
Generator function for a SpectralTransform struct. With `NF` the number format,
Expand Down
22 changes: 15 additions & 7 deletions src/dynamics/prognostic_variables.jl
Original file line number Diff line number Diff line change
Expand Up @@ -296,7 +296,13 @@ function set!(
S::Union{Nothing, SpectralTransform}=nothing;
add::Bool=false,
)
specs = isnothing(S) ? transform(grids) : transform(grids, S)
if isnothing(S)
specs = transform(grids)
else
# convert to number format in S, needed for FFTW
grids = convert.(eltype(S), grids)
specs = transform(grids, S)
end
set!(var, specs; add)
end

Expand Down Expand Up @@ -440,15 +446,19 @@ function set_vordiv!(
u::AbstractGridArray,
v::AbstractGridArray,
geometry::Geometry,
S::Union{Nothing, SpectralTransform}=nothing;
S::SpectralTransform = SpectralTransform(geometry.spectral_grid);
add::Bool=false,
coslat_scaling_included::Bool=false,
)
u_ = coslat_scaling_included ? u : RingGrids.scale_coslat⁻¹(u)
v_ = coslat_scaling_included ? v : RingGrids.scale_coslat⁻¹(v)

u_spec = isnothing(S) ? transform(u_) : transform(u_, S)
v_spec = isnothing(S) ? transform(v_) : transform(v_, S)
# convert to number format of spectral transform, otherwise FFTW complains
u_ = eltype(S) == eltype(u_) ? u_ : convert.(eltype(S), u_)
v_ = eltype(S) == eltype(v_) ? v_ : convert.(eltype(S), v_)

u_spec = transform(u_, S)
v_spec = transform(v_, S)

set_vordiv!(vor, div, u_spec, v_spec, geometry, S; add, coslat_scaling_included=true)
end
Expand All @@ -460,12 +470,10 @@ function set_vordiv!(
u::LowerTriangularArray,
v::LowerTriangularArray,
geometry::Geometry,
S::Union{Nothing, SpectralTransform}=nothing;
S::SpectralTransform = SpectralTransform(geometry.spectral_grid);
add::Bool=false,
coslat_scaling_included::Bool=false,
)
S = isnothing(S) ? SpectralTransform(geometry.spectral_grid) : S

u_ = coslat_scaling_included ? u : transform(RingGrids.scale_coslat⁻¹(transform(u, S)), S)
v_ = coslat_scaling_included ? v : transform(RingGrids.scale_coslat⁻¹(transform(u, S)), S)

Expand Down

0 comments on commit 0578a7a

Please sign in to comment.