PcgRandom 1.2.0

dotnet add package PcgRandom --version 1.2.0                
NuGet\Install-Package PcgRandom -Version 1.2.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="PcgRandom" Version="1.2.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PcgRandom --version 1.2.0                
#r "nuget: PcgRandom, 1.2.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install PcgRandom as a Cake Addin
#addin nuget:?package=PcgRandom&version=1.2.0

// Install PcgRandom as a Cake Tool
#tool nuget:?package=PcgRandom&version=1.2.0                

About

PcgRandom provides an implementation of Random that generates pseudorandom numbers using the PCG family of random number generators. It is a .NET port (written entirely in C#) of the C library by Melissa O'Neill. You can use a PcgRandom instance anywhere you would use a Random instance.

Basic Usage

using Pcg;

// create a new random number generator based on the current time
Random random = new PcgRandom();

// or with a seed (to generate the same sequence of numbers)
// random = new PcgRandom(1);

// generate a random non-negative 32-bit integer
Console.WriteLine(random.Next());

// generate a random non-negative 64-bit integer
Console.WriteLine(random.NextInt64());

// generate a random number in a range, e.g., a dice roll; note that
// the upper bound is exclusive, so this generates numbers from 1 to 6
Console.WriteLine(random.Next(1, 7));

// generate a random Boolean
Console.WriteLine(random.Next(2) == 1);

// fill an array with random bytes
var bytes = new byte[16];
random.NextBytes(bytes);
Console.WriteLine(Convert.ToHexString(bytes));

// generate a random floating-point number
Console.WriteLine(random.NextDouble());

// generate a random floating point number from 5 to 15
Console.WriteLine(5.0 + random.NextDouble() * 10);

The above code will produce output similar to the following:

359607667
2470866491422793932
5
True
F0F1E514E052C05868664FA43BA9285D
0.3241723496466875
14.117484646849334

Low-Level API

PcgRandom also provides a low-level API that is roughly equivalent to the the PCG C High-Level API.

The Pcg32 class is equivalent to the C pcg32_random_t type:

// create a random Pcg32 instance, specifying a seed and a sequence identifier
var pcg32 = new Pcg32((ulong) random.NextInt64(), (ulong) random.NextInt64());

// generate a random unsigned 32-bit integer
Console.WriteLine(pcg32.GenerateNext());

// skip over 300 numbers in the sequence (without generating them), then generate the next random number
pcg32.Advance(300);
Console.WriteLine(pcg32.GenerateNext());

// advance the state all the way around so that the same number is generated
pcg32.Advance(ulong.MaxValue);
Console.WriteLine(pcg32.GenerateNext());

The the Pcg32Single class is equivalent to the C pcg32s_random_t type:

// Pcg32Single takes just a seed; there is only one sequence
var pcg32Single = new Pcg32Single((ulong) random.NextInt64());

// the API is the same as Pcg32
Console.WriteLine(pcg32Single.GenerateNext());
Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp1.0 was computed.  netcoreapp1.1 was computed.  netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard1.0 is compatible.  netstandard1.1 was computed.  netstandard1.2 was computed.  netstandard1.3 was computed.  netstandard1.4 was computed.  netstandard1.5 was computed.  netstandard1.6 was computed.  netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net45 was computed.  net451 was computed.  net452 was computed.  net46 was computed.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen30 was computed.  tizen40 was computed.  tizen60 was computed. 
Universal Windows Platform uap was computed.  uap10.0 was computed. 
Windows Phone wp8 was computed.  wp81 was computed.  wpa81 was computed. 
Windows Store netcore was computed.  netcore45 was computed.  netcore451 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 1.0

  • .NETStandard 2.0

    • No dependencies.
  • net6.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.2.0 4,084 4/14/2023
1.1.0 70,072 9/5/2017
1.0.0 1,433 6/28/2016
0.9.0-rc1 1,129 4/12/2016
0.4.0 1,377 12/22/2015
0.3.0 1,342 12/4/2015
0.2.0 1,623 12/4/2015