[−][src]Struct rand::distributions::uniform::UniformFloat
The back-end implementing UniformSampler for floating-point types.
Unless you are implementing UniformSampler for your own type, this type
should not be used directly, use Uniform instead.
Implementation notes
Instead of generating a float in the [0, 1) range using Standard, the
UniformFloat implementation converts the output of an PRNG itself. This
way one or two steps can be optimized out.
The floats are first converted to a value in the [1, 2) interval using a
transmute-based method, and then mapped to the expected range with a
multiply and addition. Values produced this way have what equals 23 bits of
random digits for an f32, and 52 for an f64.
Trait Implementations
impl<X: Clone> Clone for UniformFloat<X>[src][+]
impl<X: Copy> Copy for UniformFloat<X>[src]
impl<X: Debug> Debug for UniformFloat<X>[src][+]
impl UniformSampler for UniformFloat<f32>[src][+]
impl UniformSampler for UniformFloat<f64>[src][+]
Auto Trait Implementations
impl<X> RefUnwindSafe for UniformFloat<X> where
X: RefUnwindSafe,
X: RefUnwindSafe,
impl<X> Send for UniformFloat<X> where
X: Send,
X: Send,
impl<X> Sync for UniformFloat<X> where
X: Sync,
X: Sync,
impl<X> Unpin for UniformFloat<X> where
X: Unpin,
X: Unpin,
impl<X> UnwindSafe for UniformFloat<X> where
X: UnwindSafe,
X: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized, [src][+]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized, [src][+]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized, [src][+]
T: ?Sized,
impl<T> From<T> for T[src][+]
impl<T, U> Into<U> for T where
U: From<T>, [src][+]
U: From<T>,
impl<T> ToOwned for T where
T: Clone, [src][+]
T: Clone,
impl<T, U> TryFrom<U> for T where
U: Into<T>, [src][+]
U: Into<T>,
impl<T, U> TryInto<U> for T where
U: TryFrom<T>, [src][+]
U: TryFrom<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>, [src][+]
V: MultiLane<T>,