PowTrees.LINQPad
0.0.45
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.0.45
NuGet\Install-Package PowTrees.LINQPad -Version 0.0.45
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.0.45" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PowTrees.LINQPad --version 0.0.45
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: PowTrees.LINQPad, 0.0.45"
#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.0.45 // Install PowTrees.LINQPad as a Cake Tool #tool nuget:?package=PowTrees.LINQPad&version=0.0.45
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
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 | net7.0-windows7.0 is compatible. net8.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net7.0-windows7.0
- PowTrees (>= 0.0.45)
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 | 130 | 6/30/2024 |
0.1.1 | 116 | 6/30/2024 |
0.1.0 | 117 | 6/30/2024 |
0.0.48 | 168 | 9/15/2023 |
0.0.47 | 132 | 9/3/2023 |
0.0.46 | 151 | 8/23/2023 |
0.0.45 | 133 | 8/22/2023 |
0.0.44 | 186 | 8/5/2023 |
0.0.43 | 159 | 7/30/2023 |
0.0.42 | 156 | 7/18/2023 |
0.0.41 | 159 | 7/15/2023 |
0.0.40 | 156 | 7/15/2023 |
0.0.39 | 157 | 7/12/2023 |
0.0.38 | 160 | 7/12/2023 |
0.0.37 | 176 | 7/11/2023 |
0.0.36 | 158 | 7/10/2023 |
0.0.35 | 153 | 7/10/2023 |
0.0.34 | 154 | 7/9/2023 |
0.0.33 | 150 | 7/8/2023 |
0.0.32 | 151 | 7/5/2023 |
0.0.31 | 156 | 7/5/2023 |
0.0.30 | 165 | 7/5/2023 |
0.0.29 | 154 | 7/4/2023 |
0.0.28 | 157 | 7/2/2023 |
0.0.27 | 143 | 6/21/2023 |
0.0.26 | 141 | 6/20/2023 |
0.0.25 | 140 | 6/20/2023 |
0.0.24 | 147 | 6/15/2023 |
0.0.23 | 146 | 6/15/2023 |
0.0.22 | 141 | 6/15/2023 |
0.0.21 | 147 | 6/12/2023 |
0.0.20 | 146 | 6/12/2023 |
0.0.19 | 151 | 6/5/2023 |
0.0.18 | 134 | 6/3/2023 |
0.0.17 | 141 | 6/3/2023 |
0.0.16 | 135 | 6/1/2023 |
0.0.15 | 141 | 5/31/2023 |
0.0.14 | 135 | 5/28/2023 |
0.0.13 | 138 | 5/28/2023 |
0.0.12 | 135 | 5/12/2023 |
0.0.10 | 152 | 4/24/2023 |
0.0.9 | 157 | 4/24/2023 |
0.0.8 | 315 | 12/4/2022 |
0.0.7 | 320 | 11/26/2022 |
0.0.6 | 315 | 11/26/2022 |