diff options
| author | Daniel Mueller <deso@posteo.net> | 2020-04-04 14:39:19 -0700 | 
|---|---|---|
| committer | Daniel Mueller <deso@posteo.net> | 2020-04-04 14:39:19 -0700 | 
| commit | d0d9683df8398696147e7ee1fcffb2e4e957008c (patch) | |
| tree | 4baa76712a76f4d072ee3936c07956580b230820 /rand/rand_distr/src/pareto.rs | |
| parent | 203e691f46d591a2cc8acdfd850fa9f5b0fb8a98 (diff) | |
| download | nitrocli-d0d9683df8398696147e7ee1fcffb2e4e957008c.tar.gz nitrocli-d0d9683df8398696147e7ee1fcffb2e4e957008c.tar.bz2 | |
Remove vendored dependencies
While it appears that by now we actually can get successful builds
without Cargo insisting on Internet access by virtue of using the
--frozen flag, maintaining vendored dependencies is somewhat of a pain
point. This state will also get worse with upcoming changes that replace
argparse in favor of structopt and pull in a slew of new dependencies by
doing so. Then there is also the repository structure aspect, which is
non-standard due to the way we vendor dependencies and a potential
source of confusion.
In order to fix these problems, this change removes all the vendored
dependencies we have.
Delete subrepo argparse/:argparse
Delete subrepo base32/:base32
Delete subrepo cc/:cc
Delete subrepo cfg-if/:cfg-if
Delete subrepo getrandom/:getrandom
Delete subrepo lazy-static/:lazy-static
Delete subrepo libc/:libc
Delete subrepo nitrokey-sys/:nitrokey-sys
Delete subrepo nitrokey/:nitrokey
Delete subrepo rand/:rand
Diffstat (limited to 'rand/rand_distr/src/pareto.rs')
| -rw-r--r-- | rand/rand_distr/src/pareto.rs | 89 | 
1 files changed, 0 insertions, 89 deletions
| diff --git a/rand/rand_distr/src/pareto.rs b/rand/rand_distr/src/pareto.rs deleted file mode 100644 index 33ea382..0000000 --- a/rand/rand_distr/src/pareto.rs +++ /dev/null @@ -1,89 +0,0 @@ -// Copyright 2018 Developers of the Rand project. -// -// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or -// https://www.apache.org/licenses/LICENSE-2.0> or the MIT license -// <LICENSE-MIT or https://opensource.org/licenses/MIT>, at your -// option. This file may not be copied, modified, or distributed -// except according to those terms. - -//! The Pareto distribution. - -use rand::Rng; -use crate::{Distribution, OpenClosed01}; -use crate::utils::Float; - -/// Samples floating-point numbers according to the Pareto distribution -/// -/// # Example -/// ``` -/// use rand::prelude::*; -/// use rand_distr::Pareto; -/// -/// let val: f64 = thread_rng().sample(Pareto::new(1., 2.).unwrap()); -/// println!("{}", val); -/// ``` -#[derive(Clone, Copy, Debug)] -pub struct Pareto<N> { -    scale: N, -    inv_neg_shape: N, -} - -/// Error type returned from `Pareto::new`. -#[derive(Clone, Copy, Debug, PartialEq, Eq)] -pub enum Error { -    /// `scale <= 0` or `nan`. -    ScaleTooSmall, -    /// `shape <= 0` or `nan`. -    ShapeTooSmall, -} - -impl<N: Float> Pareto<N> -where OpenClosed01: Distribution<N> -{ -    /// Construct a new Pareto distribution with given `scale` and `shape`. -    /// -    /// In the literature, `scale` is commonly written as x<sub>m</sub> or k and -    /// `shape` is often written as α. -    pub fn new(scale: N, shape: N) -> Result<Pareto<N>, Error> { -        if !(scale > N::from(0.0)) { -            return Err(Error::ScaleTooSmall); -        } -        if !(shape > N::from(0.0)) { -            return Err(Error::ShapeTooSmall); -        } -        Ok(Pareto { scale, inv_neg_shape: N::from(-1.0) / shape }) -    } -} - -impl<N: Float> Distribution<N> for Pareto<N> -where OpenClosed01: Distribution<N> -{ -    fn sample<R: Rng + ?Sized>(&self, rng: &mut R) -> N { -        let u: N = OpenClosed01.sample(rng); -        self.scale * u.powf(self.inv_neg_shape) -    } -} - -#[cfg(test)] -mod tests { -    use crate::Distribution; -    use super::Pareto; - -    #[test] -    #[should_panic] -    fn invalid() { -        Pareto::new(0., 0.).unwrap(); -    } - -    #[test] -    fn sample() { -        let scale = 1.0; -        let shape = 2.0; -        let d = Pareto::new(scale, shape).unwrap(); -        let mut rng = crate::test::rng(1); -        for _ in 0..1000 { -            let r = d.sample(&mut rng); -            assert!(r >= scale); -        } -    } -} | 
