Wy Rand Class
Represents a pseudo-random number generator based on the WyRand algorithm.
Definition
Namespace: Numerics.NET.Random
Assembly: Numerics.NET (in Numerics.NET.dll) Version: 10.3.0
C#
Assembly: Numerics.NET (in Numerics.NET.dll) Version: 10.3.0
public sealed class WyRand : RandomSource<ScalarGenerator64<WyRandEngine>>,
IRandomSourceFactory<WyRand>, IAdvanceable- Inheritance
- Object → RandomSource<ScalarGenerator64<WyRandEngine>> → WyRand
- Implements
- IAdvanceable, IRandomSourceFactory<WyRand>
Remarks
Use the WyRand class to represent a pseudo-random number generator that uses the WyRand algorithm by Wang Yi.
WyRand is an extremely fast hash-based random number generator with excellent statistical properties. It has a period of approximately 264 and passes all statistical tests including BigCrush and PractRand.
This generator is particularly suitable for simulations, games, and other applications where speed is critical. It is not cryptographically secure.
Reference: Wang Yi. "The fastest strong pseudo random number generator." https://github.com/wangyi-fudan/wyhash
Example
var rng = new WyRand(999);
int randomInt = rng.Next();
double randomDouble = rng.NextDouble();Constructors
| WyRand() | Initializes a new instance of the WyRand class using OS entropy. |
| WyRand( | Initializes a new instance of the WyRand class with the specified options. |
| WyRand( | Initializes a new instance of the WyRand class from saved state. |
| WyRand( | Initializes a new instance of the WyRand class with direct state initialization. |
| WyRand( | Initializes a new instance of the WyRand class with the specified seed. |
| WyRand( | Initializes a new instance of the WyRand class with the specified seed array. |
| WyRand( | Initializes a new instance of the WyRand class with the specified seed. |
| WyRand( | Initializes a new instance of the WyRand class with the specified seed array. |
Properties
| Bits |
Gets the number of bits per word in the generator's native output.
(Overrides RandomSource<TGenerator>.BitsPerWord) |
| Name |
Gets a human-readable name for this random number generator.
(Overrides RandomSource<TGenerator>.Name) |
| State |
Gets the number of bytes required to save/load this generator's state.
(Inherited from RandomSource<TGenerator>) |
| Uncached |
Gets an uncached facade for this random number generator.
(Inherited from RandomSource<TGenerator>) |
Methods
| Advance | Advances the RNG state by the specified number of outputs. |
| Copy | Returns a deep copy of this RNG. |
| Create | Creates a new WyRand instance from the specified options. |
| Create | Creates a hierarchical stream tree for generating independent RNG streams. |
| Equals | Determines whether the specified object is equal to the current object. (Inherited from Object) |
| Fill( |
Fills a span with random 32-bit unsigned integer values.
(Inherited from RandomSource<TGenerator>) |
| Fill( |
Fills a span with random 32-bit signed integers less than the specified maximum.
(Inherited from RandomSource<TGenerator>) |
| Fill( |
Fills a span with random 64-bit signed integers less than the specified maximum.
(Inherited from RandomSource<TGenerator>) |
| Fill( |
Fills a span with random 32-bit signed integers within a specified range.
(Inherited from RandomSource<TGenerator>) |
| Fill( |
Fills a span with random 64-bit signed integers within a specified range.
(Inherited from RandomSource<TGenerator>) |
| Get | Serves as the default hash function. (Inherited from Object) |
| Get |
Returns the current state of the generator as a byte array.
(Inherited from RandomSource<TGenerator>) |
| Get | Gets the Type of the current instance. (Inherited from Object) |
| Load |
Loads the generator's state from the source span in a stable little-endian format.
(Inherited from RandomSource<TGenerator>) |
| Next() |
Returns a non-negative random integer.
(Inherited from RandomSource<TGenerator>) |
| Next( |
Returns a non-negative random integer less than the specified maximum.
(Inherited from RandomSource<TGenerator>) |
| Next( |
Returns a random integer within a specified range.
(Inherited from RandomSource<TGenerator>) |
| Next |
Fills the elements of a specified array of bytes with random numbers.
(Inherited from RandomSource<TGenerator>) |
| Next |
Fills the elements of a specified span of bytes with random numbers.
(Inherited from RandomSource<TGenerator>) |
| Next |
Fills the elements of a specified span of bytes with random numbers.
(Inherited from RandomSource<TGenerator>) |
| Next |
Fills the elements of a specified span of bytes with random numbers.
(Inherited from RandomSource<TGenerator>) |
| Next |
Returns a random floating-point number in the range [0.0, 1.0).
(Inherited from RandomSource<TGenerator>) |
| Next |
Returns a non-negative random 64-bit integer.
(Inherited from RandomSource<TGenerator>) |
| Next |
Returns a non-negative random 64-bit integer less than the specified maximum.
(Inherited from RandomSource<TGenerator>) |
| Next |
Returns a random 64-bit integer within a specified range.
(Inherited from RandomSource<TGenerator>) |
| Next |
Returns a random single-precision floating-point number in the range [0.0, 1.0).
(Inherited from RandomSource<TGenerator>) |
| Next |
Returns a random 32-bit unsigned integer.
(Inherited from RandomSource<TGenerator>) |
| Next |
Returns a random 64-bit unsigned integer.
(Inherited from RandomSource<TGenerator>) |
| Reinitialize |
Reinitializes this random number generator using the specified initialization options.
(Inherited from RandomSource<TGenerator>) |
| Save |
Saves the generator's state to the destination span in a stable little-endian format.
(Inherited from RandomSource<TGenerator>) |
| ToString | Returns a string that represents the current object. (Inherited from Object) |