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

Binomial::sample panics with extreme parameters #1378

Closed
TheIronBorn opened this issue Jan 31, 2024 · 6 comments
Closed

Binomial::sample panics with extreme parameters #1378

TheIronBorn opened this issue Jan 31, 2024 · 6 comments
Labels
A-degenerate Algorithm fails on some input X-bug Type: bug report

Comments

@TheIronBorn
Copy link
Contributor

let distr = Binomial::new(1 << 31, f64::MIN_POSITIVE).unwrap();
let x = thread_rng().sample(distr);
println!("{}", x);

panics with Uniform::new called with low >= high at:

let gen_u = Uniform::new(0., p4).unwrap();

@dhardy
Copy link
Member

dhardy commented Feb 8, 2024

A panic in sample is definitely a bug. Would you mind improving the constructor to check for this?

@TheIronBorn
Copy link
Contributor Author

Working on it now

@TheIronBorn
Copy link
Contributor Author

I can't find an easy relationship between n and p to make an easy check. Bounds on n * p produce false positives.

So we can:

  • use large bounds on n * p and report false positives
  • perform the whole BINV setup in new and then test

@TheIronBorn
Copy link
Contributor Author

I also found some panics in f64_to_i64 so there are multiple dimensions to consider

@dhardy
Copy link
Member

dhardy commented Mar 25, 2024

Sorry for the delay — there's no obvious best approach here. With that said, I suggest:

  • Binomial::new is conservative and uses the bounds on n*p despite false positives, assuming these have a low impact on real use-cases.
  • We could possibly add a new constructor like new_unchecked or new_permissive, warning that panic-on-sample is possible.

This is all assuming that it is possible to find reasonable bounds on inputs with a low impact on real usage.

@dhardy dhardy added X-bug Type: bug report A-degenerate Algorithm fails on some input labels Jul 26, 2024
@dhardy dhardy mentioned this issue Jul 28, 2024
1 task
@benjamin-lieser
Copy link
Collaborator

One problem is that we enter the BTPE even when np < 10. This happens when n > i32::MAX

I don't know if there are more issues than this, but this could be prevented by rejecting this condition.
Maybe we can also fix BINV for n > i32::MAX

BTPE needs this condition, otherwise you get a negative radius in p1

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-degenerate Algorithm fails on some input X-bug Type: bug report
Projects
None yet
Development

No branches or pull requests

3 participants