FluentRandomPicker 1.1.1

Additional Details

Version 1 and 2 are no longer maintained. Please update to version 3...

There is a newer version of this package available.
See the version list below for details.
dotnet add package FluentRandomPicker --version 1.1.1
                    
NuGet\Install-Package FluentRandomPicker -Version 1.1.1
                    
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="FluentRandomPicker" Version="1.1.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="FluentRandomPicker" Version="1.1.1" />
                    
Directory.Packages.props
<PackageReference Include="FluentRandomPicker" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add FluentRandomPicker --version 1.1.1
                    
#r "nuget: FluentRandomPicker, 1.1.1"
                    
#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.
#:package FluentRandomPicker@1.1.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=FluentRandomPicker&version=1.1.1
                    
Install as a Cake Addin
#tool nuget:?package=FluentRandomPicker&version=1.1.1
                    
Install as a Cake Tool

Fluent Random Picker

This library offers a nice, fluent way to pick random values. Probabilities can be specified, values can be weighted.

Getting started

Install the nuget package (https://www.nuget.org/packages/FluentRandomPicker/)

Add the using directive:

using Fluent_Random_Picker;

Begin with Out.Of() (see the examples).

Out.Of()...

Examples

var randomNumber = Out.Of().Values(5, 6).PickOne();
// randomNumber is 5 or 6 with equal probability.
var randomChar = Out.Of()
                  .Value('a').WithPercentage(70)
                  .AndValue('b').WithPercentage(30)
                  .PickOne();
// or
var randomChar = Out.Of().Values('a', 'b')
                  .WithPercentages(70, 30)
                  .PickOne();
// or
var randomChar = Out.Of().Values(new List<char> { 'a', 'b' })
                  .WithPercentages(new List<int> { 70, 30 })
                  .PickOne();
// randomChar is 'a' with a probability of 70 % and 'b' with a probability of 30 %.
var randomString = Out.Of()
                  .Value("hello").WithWeight(2)
                  .AndValue("world").WithWeight(3)
                  .PickOne();
// or
var randomChar = Out.Of().Values("hello", "world")
                  .WithWeights(2, 3)
                  .PickOne();
// or
var randomChar = Out.Of().Values(new HashSet<string> { "hello", "world" })
                  .WithWeights(new List<int> { 2, 3 })
                  .PickOne();
// randomString is "hello" or "world", but the probability for "world" is 1.5 times as high.
var randomInts = Out.Of()
                  .Value(1).WithPercentage(80)
                  .AndValue(10).WithPercentage(10)
                  .AndValue(100).WithPercentage(5)
                  .AndValue(1000).WithPercentage(5)
                  .Pick(5);
// randomInts can be [1, 1, 1, 1, 1] with a higher probability or [1, 1, 100, 10, 1]
// or even [1000, 1000, 1000, 1000, 1000] with a very small probability.
var randomInts = Out.Of()
                  .Values(1, 10, 100, 1000)
                  .WithPercentages(70, 15, 10, 5)
                  .PickDistinct(2);
// randomInts can be [1, 10], [1, 100], [1, 1000] ... but not [1, 1], [10, 10], ...
var operation = Out.Of<Func<long, long>>()
                .Value(i => i + 2)
                .AndValue(i => i * 2)
                .AndValue(i => (long)Math.Pow(i, 2))
                .AndValue(i => (long)Math.Pow(i, i))
                .PickOne();

var result = operation(10);
// result equals 10 + 2 or 10 * 2 or 10^2 or 10^10. 
Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 was computed.  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.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net5.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on FluentRandomPicker:

Repository Stars
SapiensAnatis/Dawnshard
Server emulator for Dragalia Lost
Version Downloads Last Updated
3.6.0 129 10/11/2025
3.5.1 60,604 3/16/2024
3.5.0 13,819 11/11/2023
3.4.0 7,957 12/19/2022
3.3.0 1,454 7/2/2022
3.2.0 633 4/28/2022
3.1.0 4,505 11/27/2021
3.0.2 453 11/13/2021
3.0.1 495 8/7/2021
3.0.0 514 7/28/2021
2.1.0 620 7/10/2021 2.1.0 is deprecated.
2.0.1 473 6/28/2021 2.0.1 is deprecated.
2.0.0 592 6/26/2021 2.0.0 is deprecated.
1.2.0 621 5/22/2021 1.2.0 is deprecated.
1.1.1 465 5/15/2021 1.1.1 is deprecated.
1.1.0 503 4/24/2021 1.1.0 is deprecated.
1.0.4 464 4/17/2021 1.0.4 is deprecated.
1.0.3 483 4/16/2021 1.0.3 is deprecated.
1.0.2 521 4/15/2021 1.0.2 is deprecated.
1.0.1 470 4/15/2021 1.0.1 is deprecated.
1.0.0 528 4/15/2021 1.0.0 is deprecated.