2014-12-15 03:22:49 -06:00
|
|
|
// Copyright 2013-2014 The Rust Project Developers. See the COPYRIGHT
|
2012-12-03 18:48:01 -06:00
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
//! Interface to random number generators in Rust.
|
|
|
|
//!
|
|
|
|
//! This is an experimental library which lives underneath the standard library
|
|
|
|
//! in its dependency chain. This library is intended to define the interface
|
|
|
|
//! for random number generation and also provide utilities around doing so. It
|
|
|
|
//! is not recommended to use this library directly, but rather the official
|
|
|
|
//! interface through `std::rand`.
|
2013-04-24 07:29:19 -05:00
|
|
|
|
2014-07-01 09:12:04 -05:00
|
|
|
#![crate_name = "rand"]
|
2014-03-21 20:05:05 -05:00
|
|
|
#![crate_type = "rlib"]
|
|
|
|
#![doc(html_logo_url = "http://www.rust-lang.org/logos/rust-logo-128x128-blk.png",
|
|
|
|
html_favicon_url = "http://www.rust-lang.org/favicon.ico",
|
2014-10-09 12:47:22 -05:00
|
|
|
html_root_url = "http://doc.rust-lang.org/nightly/",
|
2014-06-06 11:12:18 -05:00
|
|
|
html_playground_url = "http://play.rust-lang.org/")]
|
2015-01-30 14:26:44 -06:00
|
|
|
#![feature(int_uint)]
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
#![no_std]
|
2015-01-22 20:22:03 -06:00
|
|
|
#![unstable(feature = "rand")]
|
2015-01-21 20:21:14 -06:00
|
|
|
#![feature(staged_api)]
|
Preliminary feature staging
This partially implements the feature staging described in the
[release channel RFC][rc]. It does not yet fully conform to the RFC as
written, but does accomplish its goals sufficiently for the 1.0 alpha
release.
It has three primary user-visible effects:
* On the nightly channel, use of unstable APIs generates a warning.
* On the beta channel, use of unstable APIs generates a warning.
* On the beta channel, use of feature gates generates a warning.
Code that does not trigger these warnings is considered 'stable',
modulo pre-1.0 bugs.
Disabling the warnings for unstable APIs continues to be done in the
existing (i.e. old) style, via `#[allow(...)]`, not that specified in
the RFC. I deem this marginally acceptable since any code that must do
this is not using the stable dialect of Rust.
Use of feature gates is itself gated with the new 'unstable_features'
lint, on nightly set to 'allow', and on beta 'warn'.
The attribute scheme used here corresponds to an older version of the
RFC, with the `#[staged_api]` crate attribute toggling the staging
behavior of the stability attributes, but the user impact is only
in-tree so I'm not concerned about having to make design changes later
(and I may ultimately prefer the scheme here after all, with the
`#[staged_api]` crate attribute).
Since the Rust codebase itself makes use of unstable features the
compiler and build system to a midly elaborate dance to allow it to
bootstrap while disobeying these lints (which would otherwise be
errors because Rust builds with `-D warnings`).
This patch includes one significant hack that causes a
regression. Because the `format_args!` macro emits calls to unstable
APIs it would trigger the lint. I added a hack to the lint to make it
not trigger, but this in turn causes arguments to `println!` not to be
checked for feature gates. I don't presently understand macro
expansion well enough to fix. This is bug #20661.
Closes #16678
[rc]: https://github.com/rust-lang/rfcs/blob/master/text/0507-release-channels.md
2015-01-06 08:26:08 -06:00
|
|
|
#![staged_api]
|
2015-01-22 20:22:03 -06:00
|
|
|
#![feature(core)]
|
2015-02-03 03:11:38 -06:00
|
|
|
#![deprecated(reason = "use the crates.io `rand` library instead",
|
|
|
|
since = "1.0.0-alpha")]
|
|
|
|
|
|
|
|
#![allow(deprecated)]
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
|
2014-12-31 22:43:46 -06:00
|
|
|
#[macro_use]
|
|
|
|
extern crate core;
|
|
|
|
|
2015-01-06 11:24:46 -06:00
|
|
|
#[cfg(test)] #[macro_use] extern crate std;
|
|
|
|
#[cfg(test)] #[macro_use] extern crate log;
|
2014-03-13 01:34:31 -05:00
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
use core::prelude::*;
|
2013-09-21 06:32:57 -05:00
|
|
|
|
2014-03-01 18:23:04 -06:00
|
|
|
pub use isaac::{IsaacRng, Isaac64Rng};
|
2014-09-19 00:33:52 -05:00
|
|
|
pub use chacha::ChaChaRng;
|
2014-03-01 18:23:04 -06:00
|
|
|
|
2015-01-03 22:43:24 -06:00
|
|
|
use distributions::{Range, IndependentSample};
|
2014-03-01 18:23:04 -06:00
|
|
|
use distributions::range::SampleRange;
|
2013-10-10 04:18:07 -05:00
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
#[cfg(test)]
|
|
|
|
static RAND_BENCH_N: u64 = 100;
|
|
|
|
|
2013-04-28 09:18:53 -05:00
|
|
|
pub mod distributions;
|
2013-09-21 06:32:57 -05:00
|
|
|
pub mod isaac;
|
2014-09-19 00:33:52 -05:00
|
|
|
pub mod chacha;
|
2013-09-29 01:49:11 -05:00
|
|
|
pub mod reseeding;
|
2013-10-01 12:16:22 -05:00
|
|
|
mod rand_impls;
|
2013-04-28 09:18:53 -05:00
|
|
|
|
2013-12-26 06:43:23 -06:00
|
|
|
/// A type that can be randomly generated using an `Rng`.
|
2014-12-18 14:27:41 -06:00
|
|
|
pub trait Rand : Sized {
|
2013-05-28 16:35:52 -05:00
|
|
|
/// Generates a random instance of this type using the specified source of
|
2013-12-26 06:43:23 -06:00
|
|
|
/// randomness.
|
2013-05-03 01:09:50 -05:00
|
|
|
fn rand<R: Rng>(rng: &mut R) -> Self;
|
2013-02-05 06:56:40 -06:00
|
|
|
}
|
|
|
|
|
2013-12-26 06:43:23 -06:00
|
|
|
/// A random number generator.
|
2014-12-18 14:27:41 -06:00
|
|
|
pub trait Rng : Sized {
|
2013-12-26 06:43:23 -06:00
|
|
|
/// Return the next random u32.
|
2013-09-21 07:06:50 -05:00
|
|
|
///
|
2013-12-26 06:43:23 -06:00
|
|
|
/// This rarely needs to be called directly, prefer `r.gen()` to
|
|
|
|
/// `r.next_u32()`.
|
2013-10-08 17:56:57 -05:00
|
|
|
// FIXME #7771: Should be implemented in terms of next_u64
|
|
|
|
fn next_u32(&mut self) -> u32;
|
2013-09-21 07:06:50 -05:00
|
|
|
|
2013-12-26 06:43:23 -06:00
|
|
|
/// Return the next random u64.
|
2013-09-21 07:06:50 -05:00
|
|
|
///
|
|
|
|
/// By default this is implemented in terms of `next_u32`. An
|
|
|
|
/// implementation of this trait must provide at least one of
|
2013-12-26 06:43:23 -06:00
|
|
|
/// these two methods. Similarly to `next_u32`, this rarely needs
|
|
|
|
/// to be called directly, prefer `r.gen()` to `r.next_u64()`.
|
2013-09-21 07:06:50 -05:00
|
|
|
fn next_u64(&mut self) -> u64 {
|
2014-12-22 18:13:49 -06:00
|
|
|
((self.next_u32() as u64) << 32) | (self.next_u32() as u64)
|
2013-09-21 07:06:50 -05:00
|
|
|
}
|
2013-08-13 06:44:16 -05:00
|
|
|
|
2014-11-02 05:47:19 -06:00
|
|
|
/// Return the next random f32 selected from the half-open
|
|
|
|
/// interval `[0, 1)`.
|
|
|
|
///
|
|
|
|
/// By default this is implemented in terms of `next_u32`, but a
|
|
|
|
/// random number generator which can generate numbers satisfying
|
|
|
|
/// the requirements directly can overload this for performance.
|
|
|
|
/// It is required that the return value lies in `[0, 1)`.
|
|
|
|
///
|
|
|
|
/// See `Closed01` for the closed interval `[0,1]`, and
|
|
|
|
/// `Open01` for the open interval `(0,1)`.
|
|
|
|
fn next_f32(&mut self) -> f32 {
|
|
|
|
const MANTISSA_BITS: uint = 24;
|
|
|
|
const IGNORED_BITS: uint = 8;
|
|
|
|
const SCALE: f32 = (1u64 << MANTISSA_BITS) as f32;
|
|
|
|
|
|
|
|
// using any more than `MANTISSA_BITS` bits will
|
|
|
|
// cause (e.g.) 0xffff_ffff to correspond to 1
|
|
|
|
// exactly, so we need to drop some (8 for f32, 11
|
|
|
|
// for f64) to guarantee the open end.
|
|
|
|
(self.next_u32() >> IGNORED_BITS) as f32 / SCALE
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Return the next random f64 selected from the half-open
|
|
|
|
/// interval `[0, 1)`.
|
|
|
|
///
|
|
|
|
/// By default this is implemented in terms of `next_u64`, but a
|
|
|
|
/// random number generator which can generate numbers satisfying
|
|
|
|
/// the requirements directly can overload this for performance.
|
|
|
|
/// It is required that the return value lies in `[0, 1)`.
|
|
|
|
///
|
|
|
|
/// See `Closed01` for the closed interval `[0,1]`, and
|
|
|
|
/// `Open01` for the open interval `(0,1)`.
|
|
|
|
fn next_f64(&mut self) -> f64 {
|
|
|
|
const MANTISSA_BITS: uint = 53;
|
|
|
|
const IGNORED_BITS: uint = 11;
|
|
|
|
const SCALE: f64 = (1u64 << MANTISSA_BITS) as f64;
|
|
|
|
|
|
|
|
(self.next_u64() >> IGNORED_BITS) as f64 / SCALE
|
|
|
|
}
|
|
|
|
|
2013-09-22 05:51:57 -05:00
|
|
|
/// Fill `dest` with random data.
|
|
|
|
///
|
|
|
|
/// This has a default implementation in terms of `next_u64` and
|
2013-12-14 23:26:09 -06:00
|
|
|
/// `next_u32`, but should be overridden by implementations that
|
2013-09-22 05:51:57 -05:00
|
|
|
/// offer a more efficient solution than just calling those
|
|
|
|
/// methods repeatedly.
|
|
|
|
///
|
|
|
|
/// This method does *not* have a requirement to bear any fixed
|
|
|
|
/// relationship to the other methods, for example, it does *not*
|
|
|
|
/// have to result in the same output as progressively filling
|
|
|
|
/// `dest` with `self.gen::<u8>()`, and any such behaviour should
|
|
|
|
/// not be relied upon.
|
|
|
|
///
|
|
|
|
/// This method should guarantee that `dest` is entirely filled
|
2014-10-09 14:17:22 -05:00
|
|
|
/// with new data, and may panic if this is impossible
|
2013-09-22 05:51:57 -05:00
|
|
|
/// (e.g. reading past the end of a file that is being used as the
|
|
|
|
/// source of randomness).
|
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
2013-09-30 10:32:12 -05:00
|
|
|
/// ```rust
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-09-22 05:51:57 -05:00
|
|
|
///
|
2014-12-31 22:40:24 -06:00
|
|
|
/// let mut v = [0u8; 13579];
|
2014-12-27 18:20:47 -06:00
|
|
|
/// thread_rng().fill_bytes(&mut v);
|
2015-01-06 18:16:35 -06:00
|
|
|
/// println!("{:?}", v.as_slice());
|
2013-09-30 10:32:12 -05:00
|
|
|
/// ```
|
2013-10-14 23:37:32 -05:00
|
|
|
fn fill_bytes(&mut self, dest: &mut [u8]) {
|
2013-10-22 02:28:49 -05:00
|
|
|
// this could, in theory, be done by transmuting dest to a
|
|
|
|
// [u64], but this is (1) likely to be undefined behaviour for
|
|
|
|
// LLVM, (2) has to be very careful about alignment concerns,
|
|
|
|
// (3) adds more `unsafe` that needs to be checked, (4)
|
|
|
|
// probably doesn't give much performance gain if
|
|
|
|
// optimisations are on.
|
2015-01-25 15:05:03 -06:00
|
|
|
let mut count = 0;
|
2013-10-22 02:28:49 -05:00
|
|
|
let mut num = 0;
|
2014-09-14 22:27:36 -05:00
|
|
|
for byte in dest.iter_mut() {
|
2013-10-22 02:28:49 -05:00
|
|
|
if count == 0 {
|
|
|
|
// we could micro-optimise here by generating a u32 if
|
|
|
|
// we only need a few more bytes to fill the vector
|
|
|
|
// (i.e. at most 4).
|
|
|
|
num = self.next_u64();
|
|
|
|
count = 8;
|
2013-09-22 05:51:57 -05:00
|
|
|
}
|
2013-10-22 02:28:49 -05:00
|
|
|
|
|
|
|
*byte = (num & 0xff) as u8;
|
|
|
|
num >>= 8;
|
|
|
|
count -= 1;
|
2013-09-22 05:51:57 -05:00
|
|
|
}
|
|
|
|
}
|
2013-03-12 15:00:50 -05:00
|
|
|
|
2013-12-26 06:43:23 -06:00
|
|
|
/// Return a random value of a `Rand` type.
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```rust
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-12-26 06:43:23 -06:00
|
|
|
///
|
2014-12-27 18:20:47 -06:00
|
|
|
/// let mut rng = thread_rng();
|
2013-12-26 06:43:23 -06:00
|
|
|
/// let x: uint = rng.gen();
|
|
|
|
/// println!("{}", x);
|
2015-01-06 18:16:35 -06:00
|
|
|
/// println!("{:?}", rng.gen::<(f64, bool)>());
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```
|
2013-09-20 06:47:05 -05:00
|
|
|
#[inline(always)]
|
2013-05-03 01:09:50 -05:00
|
|
|
fn gen<T: Rand>(&mut self) -> T {
|
2013-04-23 09:00:43 -05:00
|
|
|
Rand::rand(self)
|
2013-02-05 06:56:40 -06:00
|
|
|
}
|
2011-10-26 18:24:31 -05:00
|
|
|
|
2014-12-15 03:22:49 -06:00
|
|
|
/// Return an iterator that will yield an infinite number of randomly
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// generated items.
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// ```
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-12-26 06:43:23 -06:00
|
|
|
///
|
2014-12-27 18:20:47 -06:00
|
|
|
/// let mut rng = thread_rng();
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// let x = rng.gen_iter::<uint>().take(10).collect::<Vec<uint>>();
|
2015-01-07 20:53:58 -06:00
|
|
|
/// println!("{:?}", x);
|
2015-01-06 18:16:35 -06:00
|
|
|
/// println!("{:?}", rng.gen_iter::<(f64, bool)>().take(5)
|
|
|
|
/// .collect::<Vec<(f64, bool)>>());
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
fn gen_iter<'a, T: Rand>(&'a mut self) -> Generator<'a, T, Self> {
|
|
|
|
Generator { rng: self }
|
2013-09-20 06:47:05 -05:00
|
|
|
}
|
|
|
|
|
2014-11-08 09:47:51 -06:00
|
|
|
/// Generate a random value in the range [`low`, `high`).
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
2013-10-10 04:18:07 -05:00
|
|
|
/// This is a convenience wrapper around
|
|
|
|
/// `distributions::Range`. If this function will be called
|
|
|
|
/// repeatedly with the same arguments, one should use `Range`, as
|
|
|
|
/// that will amortize the computations that allow for perfect
|
|
|
|
/// uniformity, as they only happen on initialization.
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
2014-11-08 09:47:51 -06:00
|
|
|
/// # Panics
|
|
|
|
///
|
|
|
|
/// Panics if `low >= high`.
|
|
|
|
///
|
2013-09-20 06:47:05 -05:00
|
|
|
/// # Example
|
|
|
|
///
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```rust
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-12-26 06:43:23 -06:00
|
|
|
///
|
2014-12-27 18:20:47 -06:00
|
|
|
/// let mut rng = thread_rng();
|
2013-12-26 06:43:23 -06:00
|
|
|
/// let n: uint = rng.gen_range(0u, 10);
|
|
|
|
/// println!("{}", n);
|
2014-04-21 16:58:52 -05:00
|
|
|
/// let m: f64 = rng.gen_range(-40.0f64, 1.3e5f64);
|
2013-12-26 06:43:23 -06:00
|
|
|
/// println!("{}", m);
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```
|
2014-05-29 19:45:07 -05:00
|
|
|
fn gen_range<T: PartialOrd + SampleRange>(&mut self, low: T, high: T) -> T {
|
2013-10-10 04:18:07 -05:00
|
|
|
assert!(low < high, "Rng.gen_range called with low >= high");
|
2015-01-03 22:43:24 -06:00
|
|
|
Range::new(low, high).ind_sample(self)
|
2012-05-19 13:25:45 -05:00
|
|
|
}
|
|
|
|
|
2013-09-20 06:47:05 -05:00
|
|
|
/// Return a bool with a 1 in n chance of true
|
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```rust
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
2014-12-27 18:20:47 -06:00
|
|
|
/// let mut rng = thread_rng();
|
2014-11-17 13:29:38 -06:00
|
|
|
/// println!("{}", rng.gen_weighted_bool(3));
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```
|
2013-09-20 06:47:05 -05:00
|
|
|
fn gen_weighted_bool(&mut self, n: uint) -> bool {
|
2015-01-04 06:58:08 -06:00
|
|
|
n <= 1 || self.gen_range(0, n) == 0
|
2013-09-20 06:47:05 -05:00
|
|
|
}
|
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// Return an iterator of random characters from the set A-Z,a-z,0-9.
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```rust
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
2014-12-27 18:20:47 -06:00
|
|
|
/// let s: String = thread_rng().gen_ascii_chars().take(10).collect();
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// println!("{}", s);
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
fn gen_ascii_chars<'a>(&'a mut self) -> AsciiGenerator<'a, Self> {
|
|
|
|
AsciiGenerator { rng: self }
|
2012-05-17 13:52:49 -05:00
|
|
|
}
|
2011-12-26 21:31:25 -06:00
|
|
|
|
2014-05-20 22:44:45 -05:00
|
|
|
/// Return a random element from `values`.
|
|
|
|
///
|
|
|
|
/// Return `None` if `values` is empty.
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
2014-05-20 22:44:45 -05:00
|
|
|
/// ```
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-12-26 06:43:23 -06:00
|
|
|
///
|
2015-01-25 15:05:03 -06:00
|
|
|
/// let choices = [1, 2, 4, 8, 16, 32];
|
2014-12-27 18:20:47 -06:00
|
|
|
/// let mut rng = thread_rng();
|
2015-01-06 18:16:35 -06:00
|
|
|
/// println!("{:?}", rng.choose(&choices));
|
2015-01-12 15:59:18 -06:00
|
|
|
/// assert_eq!(rng.choose(&choices[..0]), None);
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```
|
2014-05-20 22:44:45 -05:00
|
|
|
fn choose<'a, T>(&mut self, values: &'a [T]) -> Option<&'a T> {
|
2012-05-19 13:25:45 -05:00
|
|
|
if values.is_empty() {
|
2012-08-20 14:23:37 -05:00
|
|
|
None
|
2012-05-19 13:25:45 -05:00
|
|
|
} else {
|
2013-10-10 04:18:07 -05:00
|
|
|
Some(&values[self.gen_range(0u, values.len())])
|
2012-05-19 13:25:45 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-27 07:01:41 -05:00
|
|
|
/// Shuffle a mutable slice in place.
|
2013-09-20 06:47:05 -05:00
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```rust
|
2014-12-27 18:20:47 -06:00
|
|
|
/// use std::rand::{thread_rng, Rng};
|
2013-12-26 06:43:23 -06:00
|
|
|
///
|
2014-12-27 18:20:47 -06:00
|
|
|
/// let mut rng = thread_rng();
|
2015-01-25 15:05:03 -06:00
|
|
|
/// let mut y = [1, 2, 3];
|
2014-11-17 02:39:01 -06:00
|
|
|
/// rng.shuffle(&mut y);
|
2015-01-07 20:53:58 -06:00
|
|
|
/// println!("{:?}", y.as_slice());
|
2014-11-17 02:39:01 -06:00
|
|
|
/// rng.shuffle(&mut y);
|
2015-01-07 20:53:58 -06:00
|
|
|
/// println!("{:?}", y.as_slice());
|
2013-09-23 19:20:36 -05:00
|
|
|
/// ```
|
2014-03-27 07:01:41 -05:00
|
|
|
fn shuffle<T>(&mut self, values: &mut [T]) {
|
2012-05-19 13:25:45 -05:00
|
|
|
let mut i = values.len();
|
|
|
|
while i >= 2u {
|
|
|
|
// invariant: elements with index >= i have been locked in place.
|
|
|
|
i -= 1u;
|
|
|
|
// lock element i in place.
|
2013-10-10 04:18:07 -05:00
|
|
|
values.swap(i, self.gen_range(0u, i + 1u));
|
2012-05-19 13:25:45 -05:00
|
|
|
}
|
|
|
|
}
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
}
|
2013-08-13 06:44:16 -05:00
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// Iterator which will generate a stream of random items.
|
|
|
|
///
|
|
|
|
/// This iterator is created via the `gen_iter` method on `Rng`.
|
2014-08-27 20:46:52 -05:00
|
|
|
pub struct Generator<'a, T, R:'a> {
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
rng: &'a mut R,
|
|
|
|
}
|
2013-08-13 06:44:16 -05:00
|
|
|
|
2015-01-01 22:16:49 -06:00
|
|
|
impl<'a, T: Rand, R: Rng> Iterator for Generator<'a, T, R> {
|
|
|
|
type Item = T;
|
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
fn next(&mut self) -> Option<T> {
|
|
|
|
Some(self.rng.gen())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Iterator which will continuously generate random ascii characters.
|
|
|
|
///
|
|
|
|
/// This iterator is created via the `gen_ascii_chars` method on `Rng`.
|
2014-08-27 20:46:52 -05:00
|
|
|
pub struct AsciiGenerator<'a, R:'a> {
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
rng: &'a mut R,
|
|
|
|
}
|
|
|
|
|
2015-01-01 22:16:49 -06:00
|
|
|
impl<'a, R: Rng> Iterator for AsciiGenerator<'a, R> {
|
|
|
|
type Item = char;
|
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
fn next(&mut self) -> Option<char> {
|
|
|
|
static GEN_ASCII_STR_CHARSET: &'static [u8] =
|
2014-06-18 13:25:36 -05:00
|
|
|
b"ABCDEFGHIJKLMNOPQRSTUVWXYZ\
|
|
|
|
abcdefghijklmnopqrstuvwxyz\
|
|
|
|
0123456789";
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
Some(*self.rng.choose(GEN_ASCII_STR_CHARSET).unwrap() as char)
|
2013-08-13 06:44:16 -05:00
|
|
|
}
|
2013-04-23 09:00:43 -05:00
|
|
|
}
|
2012-05-19 13:25:45 -05:00
|
|
|
|
2013-09-29 10:29:28 -05:00
|
|
|
/// A random number generator that can be explicitly seeded to produce
|
|
|
|
/// the same stream of randomness multiple times.
|
|
|
|
pub trait SeedableRng<Seed>: Rng {
|
|
|
|
/// Reseed an RNG with the given seed.
|
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
|
|
|
/// ```rust
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// use std::rand::{Rng, SeedableRng, StdRng};
|
2013-09-29 10:29:28 -05:00
|
|
|
///
|
2014-08-04 07:19:02 -05:00
|
|
|
/// let seed: &[_] = &[1, 2, 3, 4];
|
|
|
|
/// let mut rng: StdRng = SeedableRng::from_seed(seed);
|
2013-12-26 06:43:23 -06:00
|
|
|
/// println!("{}", rng.gen::<f64>());
|
2014-11-17 02:39:01 -06:00
|
|
|
/// rng.reseed(&[5, 6, 7, 8]);
|
2013-12-26 06:43:23 -06:00
|
|
|
/// println!("{}", rng.gen::<f64>());
|
2013-09-29 10:29:28 -05:00
|
|
|
/// ```
|
|
|
|
fn reseed(&mut self, Seed);
|
|
|
|
|
|
|
|
/// Create a new RNG with the given seed.
|
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
///
|
|
|
|
/// ```rust
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// use std::rand::{Rng, SeedableRng, StdRng};
|
2013-09-29 10:29:28 -05:00
|
|
|
///
|
2014-08-04 07:19:02 -05:00
|
|
|
/// let seed: &[_] = &[1, 2, 3, 4];
|
|
|
|
/// let mut rng: StdRng = SeedableRng::from_seed(seed);
|
2013-12-26 06:43:23 -06:00
|
|
|
/// println!("{}", rng.gen::<f64>());
|
2013-09-29 10:29:28 -05:00
|
|
|
/// ```
|
|
|
|
fn from_seed(seed: Seed) -> Self;
|
|
|
|
}
|
|
|
|
|
2013-10-11 01:25:40 -05:00
|
|
|
/// An Xorshift[1] random number
|
|
|
|
/// generator.
|
2013-08-06 15:13:26 -05:00
|
|
|
///
|
|
|
|
/// The Xorshift algorithm is not suitable for cryptographic purposes
|
|
|
|
/// but is very fast. If you do not know for sure that it fits your
|
2014-05-29 23:37:31 -05:00
|
|
|
/// requirements, use a more secure one such as `IsaacRng` or `OsRng`.
|
2013-10-11 01:25:40 -05:00
|
|
|
///
|
|
|
|
/// [1]: Marsaglia, George (July 2003). ["Xorshift
|
|
|
|
/// RNGs"](http://www.jstatsoft.org/v08/i14/paper). *Journal of
|
|
|
|
/// Statistical Software*. Vol. 8 (Issue 14).
|
librustc: Make `Copy` opt-in.
This change makes the compiler no longer infer whether types (structures
and enumerations) implement the `Copy` trait (and thus are implicitly
copyable). Rather, you must implement `Copy` yourself via `impl Copy for
MyType {}`.
A new warning has been added, `missing_copy_implementations`, to warn
you if a non-generic public type has been added that could have
implemented `Copy` but didn't.
For convenience, you may *temporarily* opt out of this behavior by using
`#![feature(opt_out_copy)]`. Note though that this feature gate will never be
accepted and will be removed by the time that 1.0 is released, so you should
transition your code away from using it.
This breaks code like:
#[deriving(Show)]
struct Point2D {
x: int,
y: int,
}
fn main() {
let mypoint = Point2D {
x: 1,
y: 1,
};
let otherpoint = mypoint;
println!("{}{}", mypoint, otherpoint);
}
Change this code to:
#[deriving(Show)]
struct Point2D {
x: int,
y: int,
}
impl Copy for Point2D {}
fn main() {
let mypoint = Point2D {
x: 1,
y: 1,
};
let otherpoint = mypoint;
println!("{}{}", mypoint, otherpoint);
}
This is the backwards-incompatible part of #13231.
Part of RFC #3.
[breaking-change]
2014-12-05 19:01:33 -06:00
|
|
|
#[allow(missing_copy_implementations)]
|
2015-01-05 21:13:38 -06:00
|
|
|
#[derive(Clone)]
|
2013-04-26 08:23:49 -05:00
|
|
|
pub struct XorShiftRng {
|
2014-03-27 17:10:38 -05:00
|
|
|
x: u32,
|
|
|
|
y: u32,
|
|
|
|
z: u32,
|
|
|
|
w: u32,
|
2013-01-22 10:12:52 -06:00
|
|
|
}
|
2012-05-30 18:31:16 -05:00
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
impl XorShiftRng {
|
|
|
|
/// Creates a new XorShiftRng instance which is not seeded.
|
|
|
|
///
|
|
|
|
/// The initial values of this RNG are constants, so all generators created
|
|
|
|
/// by this function will yield the same stream of random numbers. It is
|
|
|
|
/// highly recommended that this is created through `SeedableRng` instead of
|
|
|
|
/// this function
|
|
|
|
pub fn new_unseeded() -> XorShiftRng {
|
|
|
|
XorShiftRng {
|
|
|
|
x: 0x193a6754,
|
|
|
|
y: 0xa8a7d469,
|
|
|
|
z: 0x97830e05,
|
|
|
|
w: 0x113ba7bb,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-04-23 09:00:43 -05:00
|
|
|
impl Rng for XorShiftRng {
|
2013-04-26 08:53:29 -05:00
|
|
|
#[inline]
|
2013-09-21 07:06:50 -05:00
|
|
|
fn next_u32(&mut self) -> u32 {
|
2012-05-30 18:31:16 -05:00
|
|
|
let x = self.x;
|
2013-04-12 00:10:01 -05:00
|
|
|
let t = x ^ (x << 11);
|
2012-05-30 18:31:16 -05:00
|
|
|
self.x = self.y;
|
|
|
|
self.y = self.z;
|
|
|
|
self.z = self.w;
|
|
|
|
let w = self.w;
|
|
|
|
self.w = w ^ (w >> 19) ^ (t ^ (t >> 8));
|
|
|
|
self.w
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-12-31 22:40:24 -06:00
|
|
|
impl SeedableRng<[u32; 4]> for XorShiftRng {
|
2014-10-09 14:17:22 -05:00
|
|
|
/// Reseed an XorShiftRng. This will panic if `seed` is entirely 0.
|
2014-12-31 22:40:24 -06:00
|
|
|
fn reseed(&mut self, seed: [u32; 4]) {
|
2013-09-29 10:29:28 -05:00
|
|
|
assert!(!seed.iter().all(|&x| x == 0),
|
|
|
|
"XorShiftRng.reseed called with an all zero seed.");
|
|
|
|
|
|
|
|
self.x = seed[0];
|
|
|
|
self.y = seed[1];
|
|
|
|
self.z = seed[2];
|
|
|
|
self.w = seed[3];
|
|
|
|
}
|
|
|
|
|
2014-10-09 14:17:22 -05:00
|
|
|
/// Create a new XorShiftRng. This will panic if `seed` is entirely 0.
|
2014-12-31 22:40:24 -06:00
|
|
|
fn from_seed(seed: [u32; 4]) -> XorShiftRng {
|
2013-09-29 10:29:28 -05:00
|
|
|
assert!(!seed.iter().all(|&x| x == 0),
|
|
|
|
"XorShiftRng::from_seed called with an all zero seed.");
|
|
|
|
|
|
|
|
XorShiftRng {
|
|
|
|
x: seed[0],
|
|
|
|
y: seed[1],
|
|
|
|
z: seed[2],
|
|
|
|
w: seed[3]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
impl Rand for XorShiftRng {
|
|
|
|
fn rand<R: Rng>(rng: &mut R) -> XorShiftRng {
|
|
|
|
let mut tuple: (u32, u32, u32, u32) = rng.gen();
|
|
|
|
while tuple == (0, 0, 0, 0) {
|
|
|
|
tuple = rng.gen();
|
2014-03-25 00:13:11 -05:00
|
|
|
}
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
let (x, y, z, w) = tuple;
|
|
|
|
XorShiftRng { x: x, y: y, z: z, w: w }
|
2013-09-30 10:32:12 -05:00
|
|
|
}
|
|
|
|
}
|
2012-10-02 16:15:14 -05:00
|
|
|
|
2013-11-18 05:27:48 -06:00
|
|
|
/// A wrapper for generating floating point numbers uniformly in the
|
|
|
|
/// open interval `(0,1)` (not including either endpoint).
|
|
|
|
///
|
|
|
|
/// Use `Closed01` for the closed interval `[0,1]`, and the default
|
|
|
|
/// `Rand` implementation for `f32` and `f64` for the half-open
|
|
|
|
/// `[0,1)`.
|
|
|
|
///
|
|
|
|
/// # Example
|
2014-03-01 18:23:04 -06:00
|
|
|
/// ```rust
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// use std::rand::{random, Open01};
|
2013-11-18 05:27:48 -06:00
|
|
|
///
|
2013-11-01 20:06:31 -05:00
|
|
|
/// let Open01(val) = random::<Open01<f32>>();
|
|
|
|
/// println!("f32 from (0,1): {}", val);
|
2013-11-18 05:27:48 -06:00
|
|
|
/// ```
|
2014-03-31 21:01:01 -05:00
|
|
|
pub struct Open01<F>(pub F);
|
2013-11-18 05:27:48 -06:00
|
|
|
|
|
|
|
/// A wrapper for generating floating point numbers uniformly in the
|
|
|
|
/// closed interval `[0,1]` (including both endpoints).
|
|
|
|
///
|
|
|
|
/// Use `Open01` for the closed interval `(0,1)`, and the default
|
|
|
|
/// `Rand` implementation of `f32` and `f64` for the half-open
|
|
|
|
/// `[0,1)`.
|
|
|
|
///
|
|
|
|
/// # Example
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
///
|
2014-03-01 18:23:04 -06:00
|
|
|
/// ```rust
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
/// use std::rand::{random, Closed01};
|
2013-11-18 05:27:48 -06:00
|
|
|
///
|
2013-11-01 20:06:31 -05:00
|
|
|
/// let Closed01(val) = random::<Closed01<f32>>();
|
|
|
|
/// println!("f32 from [0,1]: {}", val);
|
2013-11-18 05:27:48 -06:00
|
|
|
/// ```
|
2014-03-31 21:01:01 -05:00
|
|
|
pub struct Closed01<F>(pub F);
|
2013-11-18 05:27:48 -06:00
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
#[cfg(not(test))]
|
|
|
|
mod std {
|
2014-10-09 14:17:22 -05:00
|
|
|
pub use core::{option, fmt}; // panic!()
|
2014-12-23 05:55:12 -06:00
|
|
|
pub use core::clone; // derive Clone
|
2015-01-06 16:33:42 -06:00
|
|
|
pub use core::marker;
|
2015-01-10 20:50:07 -06:00
|
|
|
// for-loops
|
|
|
|
pub use core::iter;
|
2012-01-17 21:05:07 -06:00
|
|
|
}
|
2013-07-22 13:43:12 -05:00
|
|
|
|
2013-12-08 01:55:28 -06:00
|
|
|
#[cfg(test)]
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
mod test {
|
|
|
|
use std::rand;
|
2013-07-22 13:43:12 -05:00
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
pub struct MyRng<R> { inner: R }
|
2013-07-22 13:43:12 -05:00
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
impl<R: rand::Rng> ::Rng for MyRng<R> {
|
|
|
|
fn next_u32(&mut self) -> u32 {
|
|
|
|
fn next<T: rand::Rng>(t: &mut T) -> u32 {
|
|
|
|
use std::rand::Rng;
|
|
|
|
t.next_u32()
|
2013-10-11 06:09:06 -05:00
|
|
|
}
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
next(&mut self.inner)
|
|
|
|
}
|
2013-09-21 07:06:50 -05:00
|
|
|
}
|
|
|
|
|
2014-12-27 18:20:47 -06:00
|
|
|
pub fn rng() -> MyRng<rand::ThreadRng> {
|
|
|
|
MyRng { inner: rand::thread_rng() }
|
2013-09-26 04:08:44 -05:00
|
|
|
}
|
|
|
|
|
std: Recreate a `rand` module
This commit shuffles around some of the `rand` code, along with some
reorganization. The new state of the world is as follows:
* The librand crate now only depends on libcore. This interface is experimental.
* The standard library has a new module, `std::rand`. This interface will
eventually become stable.
Unfortunately, this entailed more of a breaking change than just shuffling some
names around. The following breaking changes were made to the rand library:
* Rng::gen_vec() was removed. This has been replaced with Rng::gen_iter() which
will return an infinite stream of random values. Previous behavior can be
regained with `rng.gen_iter().take(n).collect()`
* Rng::gen_ascii_str() was removed. This has been replaced with
Rng::gen_ascii_chars() which will return an infinite stream of random ascii
characters. Similarly to gen_iter(), previous behavior can be emulated with
`rng.gen_ascii_chars().take(n).collect()`
* {IsaacRng, Isaac64Rng, XorShiftRng}::new() have all been removed. These all
relied on being able to use an OSRng for seeding, but this is no longer
available in librand (where these types are defined). To retain the same
functionality, these types now implement the `Rand` trait so they can be
generated with a random seed from another random number generator. This allows
the stdlib to use an OSRng to create seeded instances of these RNGs.
* Rand implementations for `Box<T>` and `@T` were removed. These seemed to be
pretty rare in the codebase, and it allows for librand to not depend on
liballoc. Additionally, other pointer types like Rc<T> and Arc<T> were not
supported. If this is undesirable, librand can depend on liballoc and regain
these implementations.
* The WeightedChoice structure is no longer built with a `Vec<Weighted<T>>`,
but rather a `&mut [Weighted<T>]`. This means that the WeightedChoice
structure now has a lifetime associated with it.
* The `sample` method on `Rng` has been moved to a top-level function in the
`rand` module due to its dependence on `Vec`.
cc #13851
[breaking-change]
2014-05-25 03:39:37 -05:00
|
|
|
pub fn weak_rng() -> MyRng<rand::XorShiftRng> {
|
|
|
|
MyRng { inner: rand::weak_rng() }
|
2013-07-22 13:43:12 -05:00
|
|
|
}
|
2013-08-01 02:16:42 -05:00
|
|
|
}
|