用 Math.net 求解非平方线性系统

Solve non square linear system with Math.net

我正在尝试用 Math.net 求解非线性方程组。 但是我得到一个错误 Matrix dimensions must agree: 3x7.

下面是一些示例代码:

using MathNet.Numerics.LinearAlgebra;
var mBuilder = Matrix<double>.Build;
var vBuilder = Vector<double>.Build;
var A = mBuilder.DenseOfArray(new double[,]
{
    { 3, 2, 1, 5, -1, 0, 0 },
    { 2, 1, 1, 2, 0, -1, 0 },
    { 5, 1, 3, 4, 0, 0, -1 }
});
var b = vBuilder.DenseOfArray(new double[] { -3, -5, -2 });
Vector<double> x;
x = A.Solve(b);

显然系统有解决方案(例如 X = {0, 0, 0, 0, 3, 5, 2})。 如何用 Math.Net 解决这样的系统?

您不能对非方阵使用 Matrix.Solve 函数,因为矩形矩阵没有逆解和唯一解。 Google "inverse of rectangular matrix" 大量的解释。但是,您可以使用伪逆,如下所示。

        var mBuilder = Matrix<double>.Build;
        var A = mBuilder.DenseOfArray(new double[,]
      {
          { 3, 2, 1, 5, -1, 0, 0 },
          { 2, 1, 1, 2, 0, -1, 0 },
          { 5, 1, 3, 4, 0, 0, -1 }
      });

        Matrix<double> b = Matrix<double>.Build.Dense(3, 1);
        b[0, 0] = -3.0;
        b[1, 0] = -5.0;
        b[2, 0] = -2.0;

        var p = A.PseudoInverse();
        var x = p * b;

        // verify
        var o = A * x;