From 77d116f956bae3363ccf945edb7bd1166b03af41 Mon Sep 17 00:00:00 2001 From: Zhaoyi Shen <11598433+szy21@users.noreply.github.com> Date: Fri, 19 Jul 2024 11:01:45 -0700 Subject: [PATCH] clean up temperature tolerance --- src/relations.jl | 2 +- src/states.jl | 20 ++++++++++---------- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/relations.jl b/src/relations.jl index b87f5477..721bf11b 100644 --- a/src/relations.jl +++ b/src/relations.jl @@ -1925,7 +1925,7 @@ See also [`saturation_adjustment`](@ref). q_tot::FT, ::Type{phase_type}, maxiter::Int, - relative_temperature_tol::Real = sqrt(eps(FT)), + relative_temperature_tol::Real, T_guess::Union{FT, Nothing} = nothing, ) where {FT <: Real, sat_adjust_method, phase_type <: PhaseEquil} tol = RS.RelativeSolutionTolerance(relative_temperature_tol) diff --git a/src/states.jl b/src/states.jl index 52536751..35183864 100644 --- a/src/states.jl +++ b/src/states.jl @@ -305,9 +305,6 @@ end Base.convert(::Type{PhaseEquil{FT}}, ts::PhaseEquil) where {FT} = PhaseEquil{FT}(ts.ρ, ts.p, ts.e_int, ts.q_tot, ts.T) -@inline ifnothing(x, y) = x -@inline ifnothing(x::Nothing, y) = y - """ PhaseEquil_ρeq(param_set, ρ, e_int, q_tot[, maxiter, relative_temperature_tol, sat_adjust_method, T_guess]) @@ -333,8 +330,9 @@ and, optionally ::Type{sat_adjust_method} = RS.NewtonsMethod, T_guess::Union{FT, Nothing} = nothing, ) where {FT <: Real, sat_adjust_method, IT <: ITERTYPE, TT <: TOLTYPE} - maxiter = ifnothing(maxiter, 8) - relative_temperature_tol = ifnothing(relative_temperature_tol, FT(1e-4)) + maxiter === nothing && (maxiter = 8) + relative_temperature_tol === nothing && + (relative_temperature_tol = FT(1e-4)) phase_type = PhaseEquil{FT} q_tot_safe = clamp(q_tot, FT(0), FT(1)) T = saturation_adjustment( @@ -403,7 +401,7 @@ Constructs a [`PhaseEquil`](@ref) thermodynamic state from: ) where {FT <: Real, IT <: ITERTYPE, TT <: TOLTYPE} maxiter === nothing && (maxiter = 36) relative_temperature_tol === nothing && - (relative_temperature_tol = FT(1e-5)) + (relative_temperature_tol = FT(1e-4)) phase_type = PhaseEquil{FT} tol = RS.RelativeSolutionTolerance(relative_temperature_tol) T = saturation_adjustment_given_ρθq( @@ -590,12 +588,14 @@ TODO: change input argument order: perform_sat_adjust is p::FT, q_tot::FT, perform_sat_adjust = false, - maxiter::Int = 5, - relative_temperature_tol::Real = FT(sqrt(eps(FT))), + maxiter::IT = nothing, + relative_temperature_tol::TT = nothing, ::Type{sat_adjust_method} = RS.NewtonsMethodAD, T_guess::Union{FT, Nothing} = nothing, -) where {FT <: Real, sat_adjust_method} - +) where {FT <: Real, sat_adjust_method, IT <: ITERTYPE, TT <: TOLTYPE} + maxiter === nothing && (maxiter = 5) + relative_temperature_tol === nothing && + (relative_temperature_tol = FT(1e-4)) phase_type = PhaseEquil{FT} if perform_sat_adjust T = saturation_adjustment_ρpq(