Решите неквадратную линейную систему с Math.net - PullRequest
0 голосов
/ 16 января 2020

Я пытаюсь решить неквадратную линейную систему с помощью математики. 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} ). Как я могу решить такую ​​систему с математикой. Net?

1 Ответ

2 голосов
/ 21 января 2020

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

        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;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...