Skip to content

Commit

Permalink
Upgrade to Project file and to SpecialFunctions 0.8 (#77)
Browse files Browse the repository at this point in the history
* Upgrade to Project file and to SpecialFunctions 0.8

* Update .travis.yml and .appveyor.yml

* Update Project.toml

Co-Authored-By: Alex Arslan <[email protected]>
  • Loading branch information
andreasnoack and ararslan authored Nov 7, 2019
1 parent bca4582 commit 44154fe
Show file tree
Hide file tree
Showing 14 changed files with 41 additions and 25 deletions.
2 changes: 1 addition & 1 deletion .appveyor.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
environment:
matrix:
- julia_version: 0.7
- julia_version: 1
- julia_version: 1.2
- julia_version: nightly

platform:
Expand Down
2 changes: 1 addition & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@ os:
- linux
- osx
julia:
- 0.7
- 1.0
- 1.2
- nightly
notifications:
email: false
Expand Down
19 changes: 19 additions & 0 deletions Project.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
name = "StatsFuns"
uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c"
version = "0.9.0"

[deps]
Rmath = "79098fc4-a85e-5d69-aa6a-4863f24498fa"
SpecialFunctions = "276daf66-3868-5448-9aa4-cd146d93841b"

[compat]
Rmath = "0.4, 0.5"
SpecialFunctions = "0.8"
julia = "1"

[extras]
ForwardDiff = "f6369f11-7733-5829-9624-2563aa707210"
Test = "8dfed614-e22c-5e08-85e1-65c5234f0b40"

[targets]
test = ["ForwardDiff", "Test"]
3 changes: 0 additions & 3 deletions REQUIRE

This file was deleted.

2 changes: 1 addition & 1 deletion src/distrs/beta.jl
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,4 @@ import .RFunctions:
betapdf::Real, β::Real, x::Number) = x^- 1) * (1 - x)^- 1) / beta(α, β)

# logpdf for numbers with generic types
betalogpdf::Real, β::Real, x::Number) =- 1) * log(x) +- 1) * log1p(-x) - lbeta(α, β)
betalogpdf::Real, β::Real, x::Number) =- 1) * log(x) +- 1) * log1p(-x) - logbeta(α, β)
2 changes: 1 addition & 1 deletion src/distrs/binom.jl
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,4 @@ import .RFunctions:
binompdf(n::Real, p::Real, k::Real) = exp(binomlogpdf(n, p, k))

# logpdf for numbers with generic types
binomlogpdf(n::Real, p::Real, k::Real) = -log1p(n) - lbeta(n - k + 1, k + 1) + k * log(p) + (n - k) * log1p(-p)
binomlogpdf(n::Real, p::Real, k::Real) = -log1p(n) - logbeta(n - k + 1, k + 1) + k * log(p) + (n - k) * log1p(-p)
2 changes: 1 addition & 1 deletion src/distrs/chisq.jl
Original file line number Diff line number Diff line change
Expand Up @@ -21,5 +21,5 @@ end
# logpdf for numbers with generic types
function chisqlogpdf(k::Real, x::Number)
hk = k / 2 # half k
-hk * log(oftype(hk, 2)) - lgamma(hk) + (hk - 1) * log(x) - x / 2
-hk * log(oftype(hk, 2)) - loggamma(hk) + (hk - 1) * log(x) - x / 2
end
2 changes: 1 addition & 1 deletion src/distrs/fdist.jl
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,4 @@ import .RFunctions:
fdistpdf(ν1::Real, ν2::Real, x::Number) = sqrt((ν1 * x)^ν1 * ν2^ν2 / (ν1 * x + ν2)^(ν1 + ν2)) / (x * beta(ν1 / 2, ν2 / 2))

# logpdf for numbers with generic types
fdistlogpdf(ν1::Real, ν2::Real, x::Number) = (ν1 * log(ν1 * x) + ν2 * log(ν2) - (ν1 + ν2) * log(ν1 * x + ν2)) / 2 - log(x) - lbeta(ν1 / 2, ν2 / 2)
fdistlogpdf(ν1::Real, ν2::Real, x::Number) = (ν1 * log(ν1 * x) + ν2 * log(ν2) - (ν1 + ν2) * log(ν1 * x + ν2)) / 2 - log(x) - logbeta(ν1 / 2, ν2 / 2)
2 changes: 1 addition & 1 deletion src/distrs/gamma.jl
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,4 @@ import .RFunctions:
gammapdf(k::Real, θ::Real, x::Number) = 1 / (gamma(k) * θ^k) * x^(k - 1) * exp(-x / θ)

# logpdf for numbers with generic types
gammalogpdf(k::Real, θ::Real, x::Number) = -lgamma(k) - k * log(θ) + (k - 1) * log(x) - x / θ
gammalogpdf(k::Real, θ::Real, x::Number) = -loggamma(k) - k * log(θ) + (k - 1) * log(x) - x / θ
2 changes: 1 addition & 1 deletion src/distrs/pois.jl
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ import .RFunctions:
# generic versions
poispdf::Real, x::Real) = exp(poislogpdf(λ, x))

poislogpdf::T, x::T) where {T <: Real} = xlogy(x, λ) - λ - lgamma(x + 1)
poislogpdf::T, x::T) where {T <: Real} = xlogy(x, λ) - λ - loggamma(x + 1)

poislogpdf::Number, x::Number) = poislogpdf(promote(float(λ), x)...)

Expand Down
2 changes: 1 addition & 1 deletion src/distrs/tdist.jl
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,4 @@ import .RFunctions:
tdistpdf::Real, x::Number) = gamma((ν + 1) / 2) / (sqrt* pi) * gamma/ 2)) * (1 + x^2 / ν)^(-+ 1) / 2)

# logpdf for numbers with generic types
tdistlogpdf::Real, x::Number) = lgamma((ν + 1) / 2) - log* pi) / 2 - lgamma/ 2) + (-+ 1) / 2) * log(1 + x^2 / ν)
tdistlogpdf::Real, x::Number) = loggamma((ν + 1) / 2) - log* pi) / 2 - loggamma/ 2) + (-+ 1) / 2) * log(1 + x^2 / ν)
8 changes: 4 additions & 4 deletions src/misc.jl
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ function logmvgamma(p::Int, a::Real)
# NOTE: one(a) factors are here to prevent unnecessary promotion of Float32
res = p * (p - 1) * log(pi * one(a)) / 4
for ii in 1:p
res += lgamma(a + (1 - ii) * one(a)/ 2)
res += loggamma(a + (1 - ii) * one(a) / 2)
end
return res
end
Expand All @@ -19,15 +19,15 @@ end
The remainder term after
[Stirling's approximation](https://en.wikipedia.org/wiki/Stirling%27s_approximation)
to [`lgamma`](@ref):
to [`loggamma`](@ref):
```math
\\log \\Gamma(x) \\approx x \\log(x) - x + \\log(2\\pi/x)/2 = \\log(x)*(x-1/2) + \\log(2\\pi)/2 - x
```
In Julia syntax, this means:
lstirling_asym(x) = lgamma(x) + x - (x-0.5)*log(x) - 0.5*log(2π)
lstirling_asym(x) = loggamma(x) + x - (x-0.5)*log(x) - 0.5*log(2π)
For sufficiently large `x`, this can be approximated using the asymptotic
_Stirling's series_ ([DLMF 5.11.1](https://dlmf.nist.gov/5.11.1)):
Expand All @@ -53,7 +53,7 @@ which is < 1/2 ulp for x >= 10.0, and total numeric error appears to be < 2 ulps
"""
function lstirling_asym end

lstirling_asym(x::BigFloat) = lgamma(x) + x - log(x)*(x - big(0.5)) - log2π/big(2)
lstirling_asym(x::BigFloat) = loggamma(x) + x - log(x)*(x - big(0.5)) - log2π/big(2)

lstirling_asym(x::Integer) = lstirling_asym(float(x))

Expand Down
1 change: 0 additions & 1 deletion test/REQUIRE

This file was deleted.

17 changes: 9 additions & 8 deletions test/misc.jl
Original file line number Diff line number Diff line change
Expand Up @@ -4,22 +4,23 @@ using SpecialFunctions, StatsFuns
@testset "type behavior" for eltya in (Float32, Float64)
p = rand(1:50)
a = rand(eltya)
@test typeof(logmvgamma(p, a)) == eltya
# add p since loggamma is only define for positive arguments
@test typeof(logmvgamma(p, a + p)) == eltya
end

@testset "consistent with lgamma" for eltya in (Float32, Float64)
@testset "consistent with loggamma" for eltya in (Float32, Float64)
# Γ₁(a) = Γ(a), Γ₂(a) = √π Γ(a) Γ(a - 0.5), etc
a = rand(eltya)
@test logmvgamma(1, a) lgamma(a)
@test logmvgamma(2, a) eltya(0.5logπ) + lgamma(a) + lgamma(a - eltya(0.5))
@test logmvgamma(3, a) eltya((3/2)*logπ) + lgamma(a) + lgamma(a - eltya(0.5)) + lgamma(a - one(a))
a = rand(eltya) + 1 # add one since loggamma is only define for positive arguments
@test logmvgamma(1, a) loggamma(a)
@test logmvgamma(2, a) eltya(0.5logπ) + loggamma(a) + loggamma(a - eltya(0.5))
@test logmvgamma(3, a) eltya((3/2)*logπ) + loggamma(a) + loggamma(a - eltya(0.5)) + loggamma(a - one(a))
end

@testset "consistent with itself" for eltya in (Float32, Float64)
# Γᵢ(a) = (π^{i-1/2}) Γ(a) Γᵢ₋₁(a - 0.5)
for p in 1:50
a = rand(eltya)
@test logmvgamma(p, a) eltya((p/2-1/2)*logπ) + lgamma(a) + logmvgamma(p - 1, a - eltya(0.5))
a = rand(eltya) + p # add p since loggamma is only define for positive arguments
@test logmvgamma(p, a) eltya((p/2-1/2)*logπ) + loggamma(a) + logmvgamma(p - 1, a - eltya(0.5))
end
end
end

2 comments on commit 44154fe

@andreasnoack
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@JuliaRegistrator
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Registration pull request created: JuliaRegistries/General/5180

After the above pull request is merged, it is recommended that a tag is created on this repository for the registered package version.

This will be done automatically if Julia TagBot is installed, or can be done manually through the github interface, or via:

git tag -a v0.9.0 -m "<description of version>" 44154fe5b52f0392d30d635519545fef9e8eb573
git push origin v0.9.0

Please sign in to comment.