Решите неквадратную линейную систему с Math.net

Я пытаюсь решить неквадратную линейную систему с помощью Math.net. Но я получаю сообщение об ошибке Размеры матрицы должны совпадать: 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?

1 ответ

Решение

Вы не можете использовать функцию Matrix.Solve с неквадратной матрицей, потому что нет обратных и уникальных решений для прямоугольной матрицы. Погуглите "обратную прямоугольную матрицу", чтобы найти множество объяснений. Однако вы можете использовать псевдообратную форму, как показано ниже.

        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;
Другие вопросы по тегам