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

Throw an error when truncating outside of support #1723

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

ararslan
Copy link
Member

Fixes #843 using option 2 as described here. The implementation checks for 0 probability within the truncated region but continues to allow coincident truncation bounds if they're within the support. That avoids breaking cases like that shown in #1712.

Copy link
Member

@devmotion devmotion left a comment

Choose a reason for hiding this comment

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

I think for AD backends such as Zygote we should allow to disable (and skip automatically) the check by uaing the @check_args macro - in other distributions standard checks (without @check_args) impacted performance severely.

src/truncate.jl Outdated Show resolved Hide resolved
@ararslan
Copy link
Member Author

Looks like this approach doesn't quite do it, as evidenced by the large number of test failures 🙃

@devmotion
Copy link
Member

Some of them at least are due to tests that have to be fixed/removed: https://github.com/JuliaStats/Distributions.jl/actions/runs/5017513840/jobs/8995725428?pr=1723#step:6:67

Some others seem to indicate that logtp = -Inf currently for normal distributions truncated far away from the mean. Even though some of their traits (e.g., mean and variance) are tested they are basically useless:

julia> d = truncated(Normal(0, 1), 100, 115)
Truncated(Normal{Float64}=0.0, σ=1.0); lower=100.0, upper=115.0)

julia> mean(d)
100.00999800099926

julia> var(d)
9.994005086296622e-5

julia> pdf(d, 101)
NaN

julia> logpdf(d, 101)
Inf

julia> d.logtp
-Inf

julia> d.tp
0.0

I think we might be able to fix these existing numerical issues for normal distributions (at least) by improving the numerical accuracy in the calculation of logtp. IMO this should be possible since

julia> SpecialFunctions.logerf(100/sqrt(2), 115/sqrt(2)) - log(2)
-5005.5242086942035

It seems one part could consist of improving logdiffcdf for normal distributions as currently

julia> logdiffcdf(Normal(0, 1), 115, 100)
-Inf

And then maybe logdiffcdf could be used in truncated?

@devmotion
Copy link
Member

I opened #1728 to address the logdiffcdf issue for normal distributions.

@ararslan ararslan force-pushed the aa/error-no-support branch from 4b19063 to 9c3bf42 Compare May 26, 2023 15:52
src/truncate.jl Outdated Show resolved Hide resolved
@quildtide
Copy link
Contributor

quildtide commented Aug 1, 2024

Something @devmotion wrote in #1721 reminds me that there's actually 2 separate issues that are closely related, but might require different solutions.

I think we would want to catch this case earlier in truncated: A distribution with zero mass is by definition not a distribution. See #843.

I would argue that something like truncated(Normal(0,1), 0, 0) is actually a degenerate distribution with infinite mass at a single point. On the other hand, truncated(Uniform(0,0), -2, -1) is indeed not a distribution.

Now the question is, should we handle these cases differently?

It seems to me like this pull request would error out on randf(Normal(0,1), 0, 0) since:

julia> logdiffcdf(Normal(0,1), 0, 0)
-Inf

Note that this currently works "as proper", in my opinion.

julia> t = truncated(Normal(0,1), 0, 0)
Truncated(Normal{Float64}=0.0, σ=1.0); lower=0.0, upper=0.0)

julia> rand(t)
0.0

julia> t = truncated(Normal(0,1), 1, 1)
Truncated(Normal{Float64}=0.0, σ=1.0); lower=1.0, upper=1.0)

julia> rand(t)
1.0

@ararslan
Copy link
Member Author

ararslan commented Aug 2, 2024

You're right, the truncated(Normal(0, 1), 0, 0) case is unintentionally broken by the change in 94d2817.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Truncated should catch truncations outside the support
3 participants