diff --git a/base/math.jl b/base/math.jl index 681cd07453def..1f194f73ca7f9 100644 --- a/base/math.jl +++ b/base/math.jl @@ -1131,7 +1131,7 @@ julia> rem2pi(7pi/4, RoundDown) """ function rem2pi end function rem2pi(x::Float64, ::RoundingMode{:Nearest}) - isnan(x) && return NaN + isfinite(x) || return NaN abs(x) < pi && return x @@ -1156,7 +1156,7 @@ function rem2pi(x::Float64, ::RoundingMode{:Nearest}) end end function rem2pi(x::Float64, ::RoundingMode{:ToZero}) - isnan(x) && return NaN + isfinite(x) || return NaN ax = abs(x) ax <= 2*Float64(pi,RoundDown) && return x @@ -1183,7 +1183,7 @@ function rem2pi(x::Float64, ::RoundingMode{:ToZero}) copysign(z,x) end function rem2pi(x::Float64, ::RoundingMode{:Down}) - isnan(x) && return NaN + isfinite(x) || return NaN if x < pi4o2_h if x >= 0 @@ -1214,7 +1214,7 @@ function rem2pi(x::Float64, ::RoundingMode{:Down}) end end function rem2pi(x::Float64, ::RoundingMode{:Up}) - isnan(x) && return NaN + isfinite(x) || return NaN if x > -pi4o2_h if x <= 0 diff --git a/test/numbers.jl b/test/numbers.jl index 7520fbf3a2b2f..55729ca3d3b30 100644 --- a/test/numbers.jl +++ b/test/numbers.jl @@ -2612,10 +2612,12 @@ end end @testset "PR #36420 $T" for T in (Float16, Float32, Float64) - @test rem2pi(T(NaN), RoundToZero) === T(NaN) - @test rem2pi(T(NaN), RoundNearest) === T(NaN) - @test rem2pi(T(NaN), RoundDown) === T(NaN) - @test rem2pi(T(NaN), RoundUp) === T(NaN) + for r in (RoundToZero, RoundNearest, RoundDown, RoundUp) + for x in (Inf, -Inf, NaN, -NaN) + @test isnan(rem2pi(T(x), r)) + @test rem2pi(T(x), r) isa T + end + end end import Base.^