Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

power uses Float64 exponents for integers #53967

Merged
merged 25 commits into from
Apr 22, 2024
Merged
Changes from 1 commit
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
81a0813
power uses Float64 exponents for integers
KlausC Apr 5, 2024
5c60c57
use_pbs - better runtime prediction
KlausC Apr 6, 2024
c861bb0
fixed lead_zeros bug introduced previously
KlausC Apr 6, 2024
4ab7026
fixed corner cases and added tests
KlausC Apr 10, 2024
bb7633c
use_pbs threshold
KlausC Apr 10, 2024
fed55b7
fixed effects in `^`
KlausC Apr 11, 2024
fd7fc04
fix tests for pow
KlausC Apr 12, 2024
bfbd7d3
Merge branch 'master' into krc/pow-float-path
KlausC Apr 12, 2024
9f8e198
lest @assume_effects
KlausC Apr 12, 2024
703c047
Merge branch 'master' into krc/pow-float-path
KlausC Apr 13, 2024
ffe1c25
simplified `use_power_by_squaring`
KlausC Apr 13, 2024
df1091d
Merge branch 'krc/pow-float-path' of https://github.com/KlausC/julia …
KlausC Apr 13, 2024
e9b33a2
adjusted nmin, nmax
KlausC Apr 13, 2024
06d0a7c
use `clamp`
KlausC Apr 13, 2024
7212b2d
Merge branch 'master' into krc/pow-float-path
KlausC Apr 13, 2024
09658fc
Merge branch 'master' into krc/pow-float-path
KlausC Apr 14, 2024
0964a16
Merge branch 'master' into krc/pow-float-path
KlausC Apr 15, 2024
e43797d
Merge branch 'master' into krc/pow-float-path
KlausC Apr 16, 2024
d40a3c8
Merge branch 'master' into krc/pow-float-path
KlausC Apr 17, 2024
9f6d39d
try to inline `Base.Math.exp_impl`
KlausC Apr 18, 2024
f6c24e1
Merge branch 'master' into krc/pow-float-path
KlausC Apr 18, 2024
2d6fdf5
noinline pow_body, other compiler test
KlausC Apr 18, 2024
249c53f
Merge branch 'master' into krc/pow-float-path
KlausC Apr 19, 2024
2260a80
Merge branch 'master' into krc/pow-float-path
KlausC Apr 20, 2024
4c7f788
removed redundant code, mitigate test case
KlausC Apr 21, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions base/math.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1292,7 +1292,7 @@ end
return copysign(pow_body(abs(x), y), s)
oscardssmith marked this conversation as resolved.
Show resolved Hide resolved
end

@assume_effects :foldable @noinline function pow_body(x::Float64, y::Float64)
@assume_effects :foldable @inline function pow_body(x::Float64, y::Float64)
oscardssmith marked this conversation as resolved.
Show resolved Hide resolved
xu = reinterpret(UInt64, x)
if xu < (UInt64(1)<<52) # x is subnormal
xu = reinterpret(UInt64, x * 0x1p52) # normalize x
Expand All @@ -1303,7 +1303,7 @@ end
xyhi, xylo = two_mul(logxhi,y)
xylo = muladd(logxlo, y, xylo)
hi = xyhi+xylo
return Base.Math.exp_impl(hi, xylo-(hi-xyhi), Val(:ℯ))
return @inline Base.Math.exp_impl(hi, xylo-(hi-xyhi), Val(:ℯ))
end

@constprop :aggressive function ^(x::T, y::T) where T <: Union{Float16, Float32}
Expand Down