15 releases

new 0.5.0 Jan 27, 2025
0.5.0-beta.2 Nov 30, 2024
0.5.0-alpha.3 Jul 31, 2024
0.5.0-alpha.1 Mar 18, 2024
0.2.1 Jun 28, 2019

#1369 in Algorithms

Download history 467721/week @ 2024-10-08 477603/week @ 2024-10-15 485460/week @ 2024-10-22 451905/week @ 2024-10-29 464042/week @ 2024-11-05 468046/week @ 2024-11-12 446907/week @ 2024-11-19 331274/week @ 2024-11-26 412856/week @ 2024-12-03 472296/week @ 2024-12-10 365155/week @ 2024-12-17 153555/week @ 2024-12-24 258809/week @ 2024-12-31 460467/week @ 2025-01-07 458196/week @ 2025-01-14 344875/week @ 2025-01-21

1,554,928 downloads per month
Used in 2,717 crates (540 directly)

MIT/Apache

620KB
11K SLoC

rand_distr

Test Status Latest version Book API API

Implements a full suite of random number distribution sampling routines.

This crate is a superset of the rand::distr module, including support for sampling from Beta, Binomial, Cauchy, ChiSquared, Dirichlet, Exponential, FisherF, Gamma, Geometric, Hypergeometric, InverseGaussian, LogNormal, Normal, Pareto, PERT, Poisson, StudentT, Triangular and Weibull distributions. Sampling from the unit ball, unit circle, unit disc and unit sphere surfaces is also supported.

It is worth mentioning the statrs crate which provides similar functionality along with various support functions, including PDF and CDF computation. In contrast, this rand_distr crate focuses on sampling from distributions.

Portability and libm

The floating point functions from num_traits and libm are used to support no_std environments and ensure reproducibility. If the floating point functions from std are preferred, which may provide better accuracy and performance but may produce different random values, the std_math feature can be enabled. (Note that any other crate depending on num-traits with the std feature (default-enabled) will have the same effect.)

Crate features

  • std (enabled by default): rand_distr implements the Error trait for its error types. Implies alloc and rand/std.
  • alloc (enabled by default): required for some distributions when not using std (in particular, Dirichlet and WeightedAliasIndex).
  • std_math: see above on portability and libm
  • serde: implement (de)seriaialization using serde

License

rand_distr is distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE and LICENSE-MIT, and COPYRIGHT for details.

Dependencies

~1.4–6.5MB
~32K SLoC