Matt.Math.Linear.Solving 1.0.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Matt.Math.Linear.Solving --version 1.0.0                
NuGet\Install-Package Matt.Math.Linear.Solving -Version 1.0.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="Matt.Math.Linear.Solving" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Matt.Math.Linear.Solving --version 1.0.0                
#r "nuget: Matt.Math.Linear.Solving, 1.0.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 Matt.Math.Linear.Solving as a Cake Addin
#addin nuget:?package=Matt.Math.Linear.Solving&version=1.0.0

// Install Matt.Math.Linear.Solving as a Cake Tool
#tool nuget:?package=Matt.Math.Linear.Solving&version=1.0.0                

GaussianElimination

C# implementation of Gaussian Elimination for systems of XOR equations.

Build status

Nuget

Run this command to install the package:

Install-Package Matt.Math.Linear.Solving

Usage

var coefficients = new List<bool[]>();
var solutions = new List<byte[]>();

var solver = new GuassianElimination(coefficients, solutions);

var solution = solver.Solve(); // This modifies the "coefficients" and "solutions" lists
if (solution != null)
    // "solution" is a clone of the first rows of "solutions"
else
    // Not enough systems of equations are represented in "coefficients" and "solutions"

For example, these equations:

  • a XOR b = [0x01, 0x02, 0x03]
  • b XOR c = [0x02, 0x03, 0x04]
  • a XOR b XOR c = [0x03, 0x04, 0x05]

...can be solved with this code:

var coefficients = new List<bool[]>(
	new [] {true, true, false},
	new [] {false, true, true},
	new [] {true, true, true}
);
var solutions = new List<byte[]>(
	new [] {0x01, 0x02, 0x03},
	new [] {0x02, 0x03, 0x04},
	new [] {0x03, 0x04, 0x05}
);

var solver = new GuassianElimination(coefficients, solutions);

var solution = solver.Solve();

Note that solutions are given in reduced row echelon form.

Invoking .Solve() mutates the lists passed into the constructor; row operations are performed on them to change them as much as possible into reduced row echelon form.

Therefore, as they become available, new equations can be added to the coefficients and solutions lists between invocations of .Solve().

Thread safety

This code is not thread-safe.

Use cases

This was originally designed for this rateless forward error-correction project. It should be useful for other implementations of fountain codes.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework 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 tizen40 was computed.  tizen60 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 2.0

    • No dependencies.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Matt.Math.Linear.Solving:

Package Downloads
Matt.Encoding.Fountain

Tools for fountain codes.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.0.2 1,306 12/22/2017
3.0.1 1,049 12/22/2017
3.0.0 1,033 12/22/2017
2.0.0 1,382 12/22/2017
1.0.6 1,673 12/15/2017
1.0.5 1,102 12/15/2017
1.0.4 1,144 12/15/2017
1.0.3 1,518 12/14/2017
1.0.2 1,103 12/12/2017
1.0.1 957 12/12/2017
1.0.0 1,154 12/12/2017
1.0.0-alpha 923 12/12/2017