Skip to content

Commit

Permalink
Merge pull request #57 from JuliaMath/large_arg
Browse files Browse the repository at this point in the history
Fix very large argument expansion in besselj0 and friends
  • Loading branch information
heltonmc authored Oct 17, 2022
2 parents 3bd0109 + 863a20c commit b4bf95d
Show file tree
Hide file tree
Showing 4 changed files with 39 additions and 1 deletion.
14 changes: 14 additions & 0 deletions src/besselj.jl
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,13 @@ function _besselj0(x::Float64)
q2 = (-1/8, 25/384, -1073/5120, 375733/229376)
p = evalpoly(x2, p2)
q = evalpoly(x2, q2)
if x > 1e15
a = SQ2OPI(T) * sqrt(xinv) * p
xn = muladd(xinv, q, -PIO4(T))
s_x, c_x = sincos(x)
s_xn, c_xn = sincos(xn)
return a * (c_x * c_xn - s_x * s_xn)
end
end

a = SQ2OPI(T) * sqrt(xinv) * p
Expand Down Expand Up @@ -126,6 +133,13 @@ function _besselj1(x::Float64)
q2 = (3/8, -21/128, 1899/5120, -543483/229376)
p = evalpoly(x2, p2)
q = evalpoly(x2, q2)
if x > 1e15
a = SQ2OPI(T) * sqrt(xinv) * p
xn = muladd(xinv, q, -3 * PIO4(T))
s_x, c_x = sincos(x)
s_xn, c_xn = sincos(xn)
return s * a * (c_x * c_xn - s_x * s_xn)
end
end

a = SQ2OPI(T) * sqrt(xinv) * p
Expand Down
16 changes: 15 additions & 1 deletion src/bessely.jl
Original file line number Diff line number Diff line change
Expand Up @@ -79,10 +79,17 @@ function _bessely0_compute(x::Float64)
q2 = (-1/8, 25/384, -1073/5120, 375733/229376)
p = evalpoly(x2, p2)
q = evalpoly(x2, q2)
if x > 1e15
a = SQ2OPI(T) * sqrt(xinv) * p
xn = muladd(xinv, q, -PIO4(T))
s_x, c_x = sincos(x)
s_xn, c_xn = sincos(xn)
return a * (s_x * c_xn + c_x * s_xn)
end
end

a = SQ2OPI(T) * sqrt(xinv) * p
xn = muladd(xinv, q, - PIO4(T))
xn = muladd(xinv, q, -PIO4(T))

# the following computes b = sin(x + xn) more accurately
# see src/misc.jl
Expand Down Expand Up @@ -159,6 +166,13 @@ function _bessely1_compute(x::Float64)
q2 = (3/8, -21/128, 1899/5120, -543483/229376)
p = evalpoly(x2, p2)
q = evalpoly(x2, q2)
if x > 1e15
a = SQ2OPI(T) * sqrt(xinv) * p
xn = muladd(xinv, q, - 3 * PIO4(T))
s_x, c_x = sincos(x)
s_xn, c_xn = sincos(xn)
return a * (s_x * c_xn + c_x * s_xn)
end
end

a = SQ2OPI(T) * sqrt(xinv) * p
Expand Down
5 changes: 5 additions & 0 deletions test/besselj_test.jl
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,11 @@ j1_32 = besselj1.(Float32.(x))
@test besselj1(-80.0f0) SpecialFunctions.besselj1(-80.0f0)
@test besselj1(-80.0) SpecialFunctions.besselj1(-80.0)

# tests for very large inputs
x = [1e12, 5e12, 1e13, 5e13, 1e14, 5e14, 1e15, 5e15, 1e16, 5e16, 1e17, 5e17, 1e18, 5e18, 1e19, 5e19, 1e20, 1e22, 1e25, 1e30, 1e40]
@test besselj0.(x) SpecialFunctions.besselj0.(x)
@test besselj1.(x) SpecialFunctions.besselj1.(x)

## Tests for besselj

#=
Expand Down
5 changes: 5 additions & 0 deletions test/bessely_test.jl
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,11 @@ y1_32 = bessely1.(Float32.(x))
@test bessely1(Inf32) == zero(Float32)
@test bessely1(Inf64) == zero(Float64)

# tests for very large inputs
x = [1e12, 5e12, 1e13, 5e13, 1e14, 5e14, 1e15, 5e15, 1e16, 5e16, 1e17, 5e17, 1e18, 5e18, 1e19, 5e19, 1e20, 1e22, 1e25, 1e30, 1e40]
@test bessely0.(x) SpecialFunctions.bessely0.(x)
@test bessely1.(x) SpecialFunctions.bessely1.(x)

## Tests for bessely

## test all numbers and orders for 0<nu<100
Expand Down

0 comments on commit b4bf95d

Please sign in to comment.