Метод Гаусса

Материал из testwiki
Перейти к навигации Перейти к поиску

Шаблон:Другие значения Ме́тод Га́усса — классический метод решения системы линейных алгебраических уравнений (СЛАУ). Назван в честь немецкого математика Карла Фридриха Гаусса. Это метод последовательного исключения переменных, когда с помощью элементарных преобразований система уравнений приводится к равносильной системе верхнего правого или нижнего левого треугольного вида, из которой последовательно, начиная с последних или c первых (по номеру), находятся все переменные системы[1][2].

История

Хотя в настоящее время данный метод повсеместно называется методом Гаусса, он был известен и до К. Ф. Гаусса. Первое известное описание данного метода — в китайском трактате «Математика в девяти книгах».

Описание метода

Пусть исходная система выглядит следующим образом:

{a11x1++a1nxn=b1am1x1++amnxn=bm

Её можно записать в матричном виде:

Ax=b,

где

A=(a11a1nam1amn),x=(x1xn),b=(b1bm).(1)

Матрица A называется основной матрицей системы, b — столбцом свободных членов.

Тогда, согласно свойству элементарных преобразований над строками, основную матрицу этой системы можно привести к ступенчатому виду (эти же преобразования нужно применять к столбцу свободных членов):

{α1j1xj1+α1j2xj2++α1jrxjr++α1jnxjn=β1α2j2xj2++α2jrxjr++α2jnxjn=β2αrjrxjr++αrjnxjn=βr0=βr+10=βm,

где α1j1,,αrjr0.

При этом будем считать, что базисный минор (ненулевой минор максимального порядка) основной матрицы находится в верхнем левом углу, то есть в него входят только коэффициенты при переменных xj1,,xjr[3].

Тогда переменные xj1,,xjr называются главными переменными. Все остальные называются свободными.

Если хотя бы одно число βi0, где i>r, то рассматриваемая система несовместна, т. е. у неё нет ни одного решения.

Пусть βi=0 для любых i>r.

Перенесём свободные переменные за знаки равенств и поделим каждое из уравнений системы на свой коэффициент при самом левом x (αiji,i=1,,r, где i — номер строки):

{xj1+α^1j2xj2++α^1jrxjr=β^1α^1jr+1xjr+1α^1jnxjnxj2++α^2jrxjr=β^2α^2jr+1xjr+1α^2jnxjnxjr=β^rα^rjr+1xjr+1α^rjnxjn,β^i=βiαiji,α^ijk=αijkαiji(2),

где i=1,,r,k=i+1,,n.

Если свободным переменным системы (2) придавать все возможные значения и решать новую систему относительно главных неизвестных снизу вверх (то есть от нижнего уравнения к верхнему), то мы получим все решения этой СЛАУ. Так как эта система получена путём элементарных преобразований над исходной системой (1), то по теореме об эквивалентности при элементарных преобразованиях системы (1) и (2) эквивалентны, то есть множества их решений совпадают.

Шаблон:Message box

Критерий совместности

Упомянутое выше условие βi=0 для всех i>r может быть сформулировано в качестве необходимого и достаточного условия совместности:

Напомним, что рангом совместной системы называется ранг её основной матрицы (либо расширенной, так как они равны).

Шаблон:Message box

Алгоритм

Блок-схема представлена на рисунке. Данный рисунок — адаптированный для написания программы на языке C/C++, где a — расширенная матрица, последний столбец в которой — столбец свободных членов. Количество строк — n.

Алгоритм Гаусса для решения СЛАУ

Описание

Алгоритм решения СЛАУ методом Гаусса подразделяется на два этапа.

  • На первом этапе осуществляется так называемый прямой ход, когда путём элементарных преобразований над строками систему приводят к ступенчатой или треугольной форме, либо устанавливают, что система несовместна. Для этого среди элементов первого столбца матрицы выбирают ненулевой, перемещают содержащую его строку в крайнее верхнее положение, делая эту строку первой. Далее ненулевые элементы первого столбца всех нижележащих строк обнуляются путём вычитания из каждой строки первой строки, домноженной на отношение первого элемента этих строк к первому элементу первой строки. После того, как указанные преобразования были совершены, первую строку и первый столбец мысленно вычёркивают и продолжают, пока не останется матрица нулевого размера. Если на какой-то из итераций среди элементов первого столбца не нашёлся ненулевой, то переходят к следующему столбцу и проделывают аналогичную операцию.
  • На втором этапе осуществляется так называемый обратный ход, суть которого заключается в том, чтобы выразить все получившиеся базисные переменные через небазисные и построить фундаментальную систему решений, либо, если все переменные являются базисными, то выразить в численном виде единственное решение системы линейных уравнений. Эта процедура начинается с последнего уравнения, из которого выражают соответствующую базисную переменную (а она там всего одна) и подставляют в предыдущие уравнения, и так далее, поднимаясь по «ступенькам» наверх. Каждой строчке соответствует ровно одна базисная переменная, поэтому на каждом шаге, кроме последнего (самого верхнего), ситуация в точности повторяет случай последней строки.

Метод Гаусса требует O(n3) арифметических операций.

Этот метод опирается на: Шаблон:Message box

Простейший случай

В простейшем случае алгоритм выглядит так:

{a11x1+a12x2++a1nxn=b1(1)a21x1+a22x2++a2nxn=b2(2)am1x1+am2x2++amnxn=bm(m)
  • Прямой ход:
(2)(2)(1)(a21a11):a22x2+a23x3++a2nxn=b2(3)(3)(1)(a31a11):a32x2+a33x3++a3nxn=b3(m)(m)(1)(am1a11):am2x2+am3x3++amnxn=bn(3)(3)(2)(a32a22):a33x3++a3nxn=b3(m)(m)(m1)(am,n1(m2)am1,n1(m2)):amm(m1)xm++amn(m1)xn=bm(m1)
  • Обратный ход. Из последнего ненулевого уравнения выражаем базисную переменную через небазисные и подставляем в предыдущие уравнения. Повторяя эту процедуру для всех базисных переменных, получаем фундаментальное решение.

Пример

Покажем, как методом Гаусса можно решить следующую систему:

{2x+yz=83xy+2z=112x+y+2z=3

Обнулим коэффициенты при x во второй и третьей строчках. Для этого прибавим к ним первую строчку, умноженную на 32 и 1, соответственно:

{2x+yz=812y+12z=12y+z=5

Теперь обнулим коэффициент при y в третьей строке, вычтя из неё вторую строку, умноженную на 4:

{2x+yz=812y+12z=1z=1

В результате мы привели исходную систему к треугольному виду, тем самым закончив первый этап алгоритма.

На втором этапе разрешим полученные уравнения в обратном порядке. Имеем:

z=1 из третьего;
y=3 из второго, подставив полученное z
x=2 из первого, подставив полученные z и y.

Таким образом, исходная система решена.

В случае, если число уравнений в совместной системе получилось меньше числа неизвестных, ответ будет записываться в виде фундаментальной системы решений.

Реализация алгоритма на языке программирования C#

namespace Gauss_Method
{
    class Maths
    {
        /// <summary>
        /// Метод Гаусса (Решение СЛАУ)
        /// </summary>
        /// <param name="Matrix">Начальная матрица</param>
        /// <returns></returns>
        public static double[] Gauss(double[,] Matrix)
        {
            int n = Matrix.GetLength(0); //Размерность начальной матрицы (строки)
            double[,] Matrix_Clone = new double[n, n + 1]; //Матрица-дублер
            for (int i = 0; i < n; i++)
                for (int j = 0; j < n + 1; j++)
                    Matrix_Clone[i, j] = Matrix[i, j];

            // Прямой ход (Зануление нижнего левого угла)
            for (int k = 0; k < n; k++) //k-номер строки
            {
                for (int i = 0; i < n + 1; i++) //i-номер столбца
                    Matrix_Clone[k, i] = Matrix_Clone[k, i] / Matrix[k, k]; //Деление k-строки на первый член !=0 для преобразования его в единицу
                for (int i = k + 1; i < n; i++) //i-номер следующей строки после k
                {
                    double K = Matrix_Clone[i, k] / Matrix_Clone[k, k]; //Коэффициент
                    for (int j = 0; j < n + 1; j++) //j-номер столбца следующей строки после k
                        Matrix_Clone[i, j] = Matrix_Clone[i, j] - Matrix_Clone[k, j] * K; //Зануление элементов матрицы ниже первого члена, преобразованного в единицу
                }
                for (int i = 0; i < n; i++) //Обновление, внесение изменений в начальную матрицу
                    for (int j = 0; j < n + 1; j++)
                        Matrix[i, j] = Matrix_Clone[i, j];
            }

            // Обратный ход (Зануление верхнего правого угла)
            for (int k = n - 1; k > -1; k--) //k-номер строки
            {
                for (int i = n; i > -1; i--) //i-номер столбца
                    Matrix_Clone[k, i] = Matrix_Clone[k, i] / Matrix[k, k];
                for (int i = k - 1; i > -1; i--) //i-номер следующей строки после k
                {
                    double K = Matrix_Clone[i, k] / Matrix_Clone[k, k];
                    for (int j = n; j > -1; j--) //j-номер столбца следующей строки после k
                        Matrix_Clone[i, j] = Matrix_Clone[i, j] - Matrix_Clone[k, j] * K;
                }
            }

            // Отделяем от общей матрицы ответы
            double[] Answer = new double[n];
            for (int i = 0; i < n; i++)
                Answer[i] = Matrix_Clone[i, n];

            return Answer;
        }
    }
}

Реализация алгоритма на языке программирования Borland Turbo Basic

С приведением матрицы коэффициентов к верхнему правому треугольному виду и вычислением корней в обратном порядке, от X[N] до X[1][4]:

CLS
COLOR 10

DATA 3
DATA 4.00,  0.24, -0.08,   8
DATA 0.09,  3.00, -0.15,   9
DATA 0.04, -0.08,  4.00,  20
'X[1]=1.909198, X[2]=3.194954, X[3]=5.044807

05 PRINT "Reshenie sistemy iz N lineynyh uravneniy metodom Gaussa"
10 'INPUT "Chislo uravneniy N=";N
   READ N
20 DIM A[N,N],B[N],X[N]

'1. Vvod
30 FOR I=1 TO N
     'PRINT USING "## Vvod koef. uravneniya ";I
40   FOR J=1 TO N
       'INPUT A[I,J]
       READ A[I,J]
       PRINT USING "##.##  ";A[I,J],
50   NEXT J
     'INPUT B[I]
     READ B[I]
     PRINT USING "##.##";B[I]
   NEXT I

'2. Pryamoy hod
60 FOR I=1 TO N-1
     FOR J=I+1 TO N
70     A[J,I]=-A[J,I]/A[I,I]
       FOR K=I+1 TO N
80       A[J,K]=A[J,K]+A[J,I]*A[I,K]
       NEXT K
90     B[J]=B[J]+A[J,I]*B[I]
     NEXT J
   NEXT I
100 X[N]=B[N]/A[N,N]

'3. Obratnyi hod
110 FOR I=N-1 TO 1 STEP -1
      H=B[I]
120   FOR J=I+1 TO N
        H=H-X[J]*A[I,J]
      NEXT J
130   X[I]=H/A[I,I]
    NEXT I

'4. Vyvod
140 PRINT "Korni sistemy uravneniy"
150 FOR I=1 TO N
      PRINT USING "X[##]=##.######";I,X[I]
160 NEXT I
    END

С приведением матрицы коэффициентов к нижнему левому треугольному виду и вычислением корней в прямом порядке, от X[1] до X[N][2]:

CLS
COLOR 10

DATA 3
DATA 3,  2, -1,  4
DATA 2, -1,  5, 23
DATA 1,  7, -1,  5
'X[1]=2.0, X[2]=1.0, X[3]=4.0

PRINT "Reshenie sistemy iz N lineynyh uravneniy prosteishim metodom Gaussa"
PRINT "s nigney levoy treugolxnoy matricey"

READ N 'Chislo uravneniy
DIM A[N,N+1],X[N]
PRINT

'1. Vvod -------------------------
PRINT "Koefficienty sistemy uravneniy"
FOR I=1 TO N
  FOR J=1 TO N+1
    READ A[I,J]
    PRINT USING "###.##  ";A[I,J],
  NEXT J
  PRINT
NEXT I
PRINT

'2. Pryamoy hod i vyvod X[1]
FOR L=0 TO N-2
  FOR I=1 TO N-1-L
    K=A[I,N-L]/A[N-L,N-L]
    FOR J=1 TO N+1
      A[I,J]=A[I,J]-A[N-L,J]*K
    NEXT J,I,L
PRINT "Nignyaya levaya treugolxnaya matrica"
GOSUB MATVYV
PRINT
PRINT "Korny sistemy uravneniy"
X[1]=A[1,N+1]/A[1,1]
PRINT USING "X[ 1]=###.######";X[1]

'3. Obratnyi hod i vyvod X[I], I>1
FOR I=2 TO N
  H=A[I,N+1]
  FOR J=1 TO I-1
    H=H-A[I,J]*X[J]
  NEXT J
  X[I]=H/A[I,I]
  PRINT USING "X[##]=###.######";I,X[I]
NEXT I
END

MATVYV:
FOR I=1 TO N
  FOR J=1 TO N+1
    PRINT USING "###.######  ";A[I,J];
  NEXT J
  PRINT
NEXT I
RETURN

Применение и модификации

Помимо аналитического решения СЛАУ, метод Гаусса также применяется для:

  • нахождения матрицы, обратной к данной (к матрице справа приписывается единичная такого же размера, что и исходная: [A|E], после чего A приводится к виду единичной матрицы методом Гаусса—Жордана; в результате на месте изначальной единичной матрицы справа оказывается обратная к исходной матрица: [E|A1]);
  • определения ранга матрицы (согласно следствию из теоремы Кронекера — Капелли ранг матрицы равен числу её главных переменных);
  • численного решения СЛАУ в технических приложениях (для уменьшения погрешности вычислений используется Метод Гаусса с выделением главного элемента, суть которого заключена в том, чтобы на каждом шаге в качестве главной переменной выбирать ту, при которой среди оставшихся после вычёркивания очередных строк и столбцов стоит максимальный по модулю коэффициент).

Достоинства метода

  • Для матриц ограниченного размера — менее трудоёмкий по сравнению с другими методами.
  • Позволяет однозначно установить, совместна система или нет, и если совместна, найти её решение.
  • Позволяет найти максимальное число линейно независимых уравнений — ранг матрицы системы[5].

Устойчивость метода Гаусса

Метод Гаусса для плохо обусловленных матриц коэффициентов является вычислительно неустойчивым. Например, для матриц Гильберта метод приводит к очень большим ошибкам даже при небольшой размерности этих матриц. Уменьшить вычислительную ошибку можно с помощью метода Гаусса с выделением главного элемента, который является условно устойчивым[6]. Широкое применение метода Гаусса связано с тем, что плохо обусловленные матрицы встречаются на практике относительно редко.

Неоптимальность метода Гаусса

В 1969 году Штрассен доказал, что большие матрицы можно перемножить за время O(nlog27)O(n2,81)Шаблон:Source-ref. Отсюда вытекает, что обращение матриц и решение СЛАУ можно осуществлять алгоритмами асимптотически более быстрыми по порядку, чем метод Гаусса. Таким образом, для больших СЛАУ метод Гаусса не оптимален по скорости.

См. также

Примечания

Шаблон:Примечания

Литература

Ссылки

Шаблон:ВС Шаблон:Методы решения СЛАУ

  1. Н. Ш. Кремер, 2.3. «Метод Гаусса», стр. 44
  2. 2,0 2,1 Усовершенствование решения СЛАУ простейшим методом Гаусса. Куликов А. С.
  3. Такого расположения минора можно добиться перестановкой столбцов основной матрицы и соответствующей перенумерацией переменных.
  4. Решение систем линейных уравнений простейшим методом Гаусса. Куликов А. С.
  5. Н. Ш. Кремер, 2.4. «Система m линейных уравнений с n переменными», стр. 49
  6. УСТОЙЧИВОСТЬ И ТОЧНОСТЬ ПРЯМЫХ МЕТОДОВШаблон:Недоступная ссылка