PowTrees.LINQPad
0.1.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package PowTrees.LINQPad --version 0.1.0
NuGet\Install-Package PowTrees.LINQPad -Version 0.1.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="PowTrees.LINQPad" Version="0.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PowTrees.LINQPad --version 0.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: PowTrees.LINQPad, 0.1.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 PowTrees.LINQPad as a Cake Addin #addin nuget:?package=PowTrees.LINQPad&version=0.1.0 // Install PowTrees.LINQPad as a Cake Tool #tool nuget:?package=PowTrees.LINQPad&version=0.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
PowTrees
Table of content
Introduction
Tree structure with algorithms
Usage
JSON Serialization
TNod<T> root;
var jsonOpt = new JsonSerializerOptions();
jsonOpt.Converters.Add(NodConverterFactory.Instance);
var str = JsonSerializer.Serialize(root, jsonOpt);
var rootOut = JsonSerializer.Deserialize<TNod<T>>(str, jsonOpt)!;
FoldL
Map a tree recursively. For each node, we use the node and the mapped parent as input
Signature:
static TNod<U> FoldL<T, U>(
this TNod<T> root,
Func<TNod<T>, U, U> fun,
U seed
);
Example:
record Rec(int Val, int Ofs); // where Ofs is an offset we want to apply to Val
// root =
// ┌►(30,0)
// │
// (10,0)──►(20,3)─┤ ┌►(50,0)
// └►(40,6)─┤
// └►(60,1)
// 1. Apply Ofs on the node and its descendents:
// ---------------------------------------------
root.FoldL((nod, acc) => acc + nod.V.Ofs, 0)
┌►3
│
0──►3─┤ ┌►9
└►9─┤
└►10
// 2. Apply Ofs on the node descendents only:
// ------------------------------------------
root.FoldL((nod, acc) => acc + nod.ParentOr(e => e.Ofs, 0), 0)
┌►3
│
0──►0─┤ ┌►9
└►3─┤
└►9
// 3. Create a dictionary from the nodes to their accumulators
// -----------------------------------------------------------
root.Zip(root.FoldL(fun))
.ToDictionary(
e => e.First.V,
e => e.Second.V
);
As these cases are quite common, there are some utility functions to implement them easily:
static TNod<U> FoldL_Parent<T, U>(
this TNod<T> root,
Func<T, U> get,
Func<U, U, U> fun,
U seed
);
static IReadOnlyDictionary<T, U> FoldL_Dict<T, U>(
this TNod<T> root,
Func<T, U, U> fun,
U seed
) where T : notnull;
static IReadOnlyDictionary<T, U> FoldL_Parent_Dict<T, U>(
this TNod<T> root,
Func<T, U> get,
Func<U, U, U> fun,
U seed
) where T : notnull;
Build a node lookup map
If you transform a tree (A) into tree (B) without changing its shape (just changing the node content, not children). Very often, you then need to map the nodes of B back to A. For this use:
static IReadOnlyDictionary<TNod<T>, TNod<U>> BuildNodeLookup<T, U>(TNod<T> rootSrc, TNod<U> rootDst);
var lookupMap = TreeUtils.BuildNodeLookup(B, A);
License
MIT
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0-windows7.0 is compatible. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0-windows7.0
- PowTrees (>= 0.1.0)
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 |
---|---|---|
0.1.2 | 114 | 6/30/2024 |
0.1.1 | 105 | 6/30/2024 |
0.1.0 | 106 | 6/30/2024 |
0.0.48 | 162 | 9/15/2023 |
0.0.47 | 126 | 9/3/2023 |
0.0.46 | 145 | 8/23/2023 |
0.0.45 | 125 | 8/22/2023 |
0.0.44 | 180 | 8/5/2023 |
0.0.43 | 153 | 7/30/2023 |
0.0.42 | 150 | 7/18/2023 |
0.0.41 | 153 | 7/15/2023 |
0.0.40 | 150 | 7/15/2023 |
0.0.39 | 151 | 7/12/2023 |
0.0.38 | 154 | 7/12/2023 |
0.0.37 | 170 | 7/11/2023 |
0.0.36 | 152 | 7/10/2023 |
0.0.35 | 147 | 7/10/2023 |
0.0.34 | 148 | 7/9/2023 |
0.0.33 | 144 | 7/8/2023 |
0.0.32 | 145 | 7/5/2023 |
0.0.31 | 148 | 7/5/2023 |
0.0.30 | 159 | 7/5/2023 |
0.0.29 | 148 | 7/4/2023 |
0.0.28 | 151 | 7/2/2023 |
0.0.27 | 137 | 6/21/2023 |
0.0.26 | 135 | 6/20/2023 |
0.0.25 | 134 | 6/20/2023 |
0.0.24 | 141 | 6/15/2023 |
0.0.23 | 140 | 6/15/2023 |
0.0.22 | 135 | 6/15/2023 |
0.0.21 | 141 | 6/12/2023 |
0.0.20 | 140 | 6/12/2023 |
0.0.19 | 145 | 6/5/2023 |
0.0.18 | 128 | 6/3/2023 |
0.0.17 | 135 | 6/3/2023 |
0.0.16 | 129 | 6/1/2023 |
0.0.15 | 135 | 5/31/2023 |
0.0.14 | 127 | 5/28/2023 |
0.0.13 | 132 | 5/28/2023 |
0.0.12 | 129 | 5/12/2023 |
0.0.10 | 146 | 4/24/2023 |
0.0.9 | 151 | 4/24/2023 |
0.0.8 | 307 | 12/4/2022 |
0.0.7 | 310 | 11/26/2022 |
0.0.6 | 307 | 11/26/2022 |