MathNet.Numerics.Signed 2.5.0

Math.NET Numerics, signed and thus with a strong name. We strongly discourage using this package and recommend using MathNet.Numerics instead, which is unsigned and weakly named.

There is a newer version of this package available.
See the version list below for details.
Install-Package MathNet.Numerics.Signed -Version 2.5.0
dotnet add package MathNet.Numerics.Signed --version 2.5.0
<PackageReference Include="MathNet.Numerics.Signed" Version="2.5.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MathNet.Numerics.Signed --version 2.5.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.

Release Notes

### Potentially Breaking Changes:

Despite semver this release contains two changes that may break code but without triggering a major version number change. The changes fix semantic bugs and a major usability issue without changing the formal API itself. Most users are not expected to be affected negatively. Nevertheless, this is an exceptional case and we try hard to avoid such changes in the future.

- Statistics: Empty statistics now return NaN instead of either 0 or throwing an exception. *This may break code in case you relied upon the previous unusual and inconsistent behavior.*

- Linear Algebra: More reasonable ToString behavior for matrices and vectors. *This may break code if you relied upon ToString to export your full data to text form intended to be parsed again later. Note that the classes in the MathNet.Numerics.IO library are more appropriate for storing and loading data.*

### Statistics:

- More consistent behavior for empty and single-element data sets: Min, Max, Mean, Variance, Standard Deviation etc. no longer throw exceptions if the data set is empty but instead return NaN. Variance and Standard Deviation will also return NaN if the set contains only a single entry. Population Variance and Population Standard Deviation will return 0 in this case.
- Reworked order statistics (Quantile, Quartile, Percentile, IQR, Fivenum, etc.), now much easier to use and supporting compatibility with all 9 R-types, Excel and Mathematica. The obsolete Percentile class now leverages the new order statistics, fixing a range check bug as side effect.
- New Hybrid Monte Carlo sampler for multivariate distributions.
- New financial statistics: absolute risk and return measures.
- Explicit statistics for sorted arrays, unsorted arrays and sequences/streams. Faster algorithms on sorted data, also avoids multiple enumerations.
- Some statistics like Quantile or empirical inverse CDF can optionally return a parametric function when multiple evaluations are needed, like for plotting.

### Linear Algebra:

- More reasonable ToString behavior for matrices and vectors: `ToString` methods no longer render the whole structure to a string for large data, among others because they used to wreak havoc in debugging and interactive scenarios like F# FSI. Instead, ToString now only renders an excerpt of the data, together with a line about dimension, type and in case of sparse data a sparseness indicator. The intention is to give a good idea about the data in a visually useful way. How much data is shown can be adjusted in the Control class. See also ToTypeString and ToVector/MatrixString.
- Performance: reworked and tuned common parallelization. Some operations are up to 3 magnitudes faster in some extreme cases. Replaced copy loops with native routines. More algorithms are storage-aware (and should thus perform better especially on sparse data).
- Fixed range checks in the Thin-QR decomposition.
- Fixed bug in Gram Schmidt for solving tall matrices.
- Vectors now implement the BCL IList interfaces (fixed-length) for better integration with existing .Net code.
- Matrix/Vector parsing has been updated to be able to parse the new visual format as well (see ToMatrixString).
- DebuggerDisplay attributes for matrices and vectors.
- Map/IndexedMap combinators with storage-aware and partially parallelized implementations for both dense and sparse data.
- Reworked Matrix/Vector construction from arrays, enumerables, indexed enumerables, nested enumerables or by providing an init function/lambda. Non-obsolete constructors now always use the raw data array directly without copying, while static functions always return a matrix/vector independent of the provided data source.
- F#: Improved extensions for matrix and vector construction: create, zeroCreate, randomCreate, init, ofArray2, ofRows/ofRowsList, ofColumns/ofSolumnsList, ofSeqi/Listi (indexed). Storage-aware for performance.
- F#: Updated map/mapi and other combinators to leverage core implementation, added -nz variants where zero-values may be skipped (relevant mostly for sparse matrices).
- F#: Idiomatic slice setters for sub-matrices and sub-vectors
- F#: More examples for matrix/vector creation and linear regression in the F# Sample-package.

### Misc:

- Control: Simpler usage with new static ConfigureAuto and ConfigureSingleThread methods. Resolved misleading configuration logic and naming around disabling parallelization.
- Control: New settings for linear algebra ToString behavior.
- Fixed range check in the Xor-shift pseudo-RNG.
- Parallelization: Reworked our common logic to avoid expensive lambda calls in inner loops. Tunable.
- F#: Examples (and thus the NuGet Sample package) are now F# scripts prepared for experimenting interactively in FSI, instead of normal F# files. Tries to get the assembly references right for most users, both within the Math.NET Numerics solution and the NuGet package.
- Various minor improvements on consistency, performance, tests, xml docs, obsolete attributes, redundant code, argument checks, resources, cleanup, nuget, etc.


This package has no dependencies.

NuGet packages (15)

Showing the top 5 NuGet packages that depend on MathNet.Numerics.Signed:

Package Downloads
Spreads top level library.
F# Modules for Math.NET Numerics, the numerical foundation of the Math.NET project, aiming to provide methods and algorithms for numerical computations in science, engineering and every day use. Supports .Net Framework 4.5 or higher and .Net Standard 1.6 or higher, on Windows, Linux and Mac. This package contains strong-named assemblies for legacy use cases (not recommended).
Math.NET Spatial, providing methods and algorithms for geometry computations in science, engineering and every day use. Supports .Net Framework 4.6.1 or higher and .Net Standard 2.0 or higher on Windows, Linux and Mac. This package contains strong-named assemblies for legacy use cases (not recommended).
NCDK is C# implementation of the Chemistry Development Kit (CDK), which is an open-source library of algorithms for structural cheminformatics and bioinformatics.
Support functions for SNS, LightMapper, Live Electrochem, BioLED controller etc

GitHub repositories (3)

Showing the top 3 popular GitHub repositories that depend on MathNet.Numerics.Signed:

Repository Stars
Platform for Situated Intelligence
C#/.NET Binding for FoundationDB Client API
SolidWorks to URDF Exporter

Version History

Version Downloads Last updated
4.15.0 283 1/7/2021
4.14.0 227 1/1/2021
4.13.0 37 12/30/2020
4.12.0 8,062 8/2/2020
4.11.0 3,950 5/24/2020
4.10.0 121 5/24/2020
4.9.1 4,612 4/12/2020
4.9.0 28,794 10/13/2019
4.8.1 33,653 6/11/2019
4.8.0 1,109 6/2/2019
4.8.0-beta02 236 5/30/2019
4.8.0-beta01 268 4/28/2019
4.7.0 189,297 11/11/2018
4.6.0 6,349 10/19/2018
4.5.0 60,047 5/22/2018
4.4.1 2,458 5/6/2018
3.20.2 11,787 1/22/2018
3.20.1 963 1/13/2018
3.20.0 13,235 7/15/2017
3.20.0-beta01 461 5/31/2017
3.19.0 10,578 4/29/2017
3.18.0 1,958 4/9/2017
3.17.0 5,562 1/15/2017
3.16.0 686 1/3/2017
3.15.0 502 12/27/2016
3.14.0-beta03 496 11/20/2016
3.14.0-beta02 494 11/15/2016
3.14.0-beta01 506 10/30/2016
3.13.1 16,101 9/6/2016
3.13.0 921 8/18/2016
3.12.0 3,219 7/3/2016
3.11.1 14,584 4/24/2016
3.11.0 13,402 2/13/2016
3.10.0 1,555 12/30/2015
3.9.0 1,756 11/25/2015
3.8.0 3,341 9/26/2015
3.7.1 731 9/21/2015
3.7.0 8,080 5/9/2015
3.6.0 2,247 3/22/2015
3.5.0 2,023 1/10/2015
3.4.0 609 1/4/2015
3.3.0 773 11/26/2014
3.3.0-beta2 592 10/25/2014
3.3.0-beta1 546 9/28/2014
3.2.3 2,056 9/6/2014
3.2.2 573 9/5/2014
3.2.1 921 8/5/2014
3.2.0 3,041 8/5/2014
3.1.0 3,189 7/20/2014
3.0.2 731 6/26/2014
3.0.1 606 6/24/2014
3.0.0 889 6/21/2014
3.0.0-beta05 617 6/20/2014
3.0.0-beta04 527 6/15/2014
3.0.0-beta03 599 6/5/2014
3.0.0-beta02 560 5/29/2014
3.0.0-beta01 637 4/14/2014
3.0.0-alpha9 604 3/29/2014
3.0.0-alpha8 568 2/26/2014
3.0.0-alpha7 612 12/30/2013
3.0.0-alpha6 628 12/2/2013
3.0.0-alpha5 592 10/2/2013
2.6.1 2,344 8/13/2013
2.6.0 659 7/26/2013
2.5.0 1,220 4/14/2013
2.4.0 789 2/3/2013
2.3.0 795 11/25/2012
2.2.1 1,143 8/29/2012
Show less