2.2 Метод Гаусса для решения систем линейных уравнений
Пусть дана квадратная матрица A размером NxN. Требуется вычислить её определитель.
Воспользуемся идеями метода Гаусса решения систем линейных уравнений.
Дана система:
a11 x1 + a12 x2 + ... + a1n xn = b1
a21 x1 + a22 x2 + ... + a2n xn = b2
...
an1 x1 + an2 x2 + ... + ann xn = bn
Выполним следующий алгоритм.
На первом шаге найдём в первом столбце наибольший по модулю элемент, поставим уравнение с этим элементом на первую строчку (обменяв две соответствующие строки матрицы A и два соответствующих элемента вектора B), а затем будем отнимать это уравнение от всех остальных, чтобы в первом столбце все элементы (кроме первого) обратились в ноль. Например, при прибавлении ко второй строке будем домножать первую строку на -a21/a11, при добавлении к третьей - на -a31/a11, и т.д.
На втором шаге найдём во втором столбце, начиная со второго элемента, наибольший по модулю элемент, поставим уравнение с этим элементом на вторую строчку, и будем отнимать это уравнение от всех остальных (в том числе и от первого), чтобы во втором столбце все элементы (кроме второго) обратились в ноль. Понятно, что эта операция никак не изменит первый столбец - ведь от каждой строки мы будем отнимать вторую строку, домноженную на некоторый коэффициент, а во второй строке в первом столбце стоит ноль.
Т.е. на i-ом шаге найдём в i-ом столбце, начиная с i-го элемента, наибольший по модулю элемент, поставим уравнение с этим элементом на i-ю строчку, и будем отнимать это уравнение от всех остальных. Понятно, что это никак не повлияет на все предыдущие столбцы (с первого по (i-1)-ый).
В конце концов, мы приведём систему к так называемому диагональному виду:
c11 x1 = d1
c22 x2 = d2
...
cnn xn = dn
Т.е. мы нашли решение системы.
Замечание 1. На каждой итерации найдётся хотя бы один ненулевой элемент, иначе система бы имела нулевой определитель, что противоречит условию.
Замечание 2. Требование, что на каждом шаге мы выбираем наибольший по модулю элемент, очень важно в смысле численной устойчивости метода. Если выбирать произвольный ненулевой элемент, то это может привести к гигантской погрешности, когда получившееся решение будет отличаться в разы от правильного.
2.3 Метод Гаусса для вычисления определителя
Будем выполнять те же самые действия, что и при решении системы линейных уравнений, исключив только деление текущей строки на a[i][i] (точнее, само деление можно выполнять, но подразумевая, что число выносится за знак определителя). Тогда все операции, которые мы будем производить с матрицей, не будут изменять величину определителя матрицы, за исключением, быть может, знака (мы только обмениваем местами две строки, что меняет знак на противоположный, или прибавляем одну строку к другой, что не меняет величину определителя).
Но матрица, к которой мы приходим после выполнения алгоритма Гаусса, является диагональной, и определитель её равен произведению элементов, стоящих на диагонали. Знак, как уже говорилось, будет определяться количеством обменов строк (если их нечётное, то знак определителя следует изменить на противоположный). Таким образом, мы можем с помощью алгоритма Гаусса вычислять определитель матрицы за O(N3).
Осталось только заметить, что если в какой-то момент мы не найдём в текущем столбце ненулевого элемента, то алгоритм следует остановить и вернуть 0.
3. Функциональные модели и блок-схемы решения задачи
Блок-схема решения задачи представлена на рисунке 1.
Рисунок 1 – Блок-схема решения задачи для функции DETERMINATE
4 Программная реализация решения задачи
;ФУНКЦИЯ, ВЫЧИСЛЯЮЩАЯ ОПРЕДЕЛИТЕЛЬ
(DEFUN DETERMINANT (MATRIX SIZE)
;ОБЪЯВЛЕНИЕ ПЕРЕМЕННЫХ
;ОПРЕДЕЛИТЕЛЬ
(DECLARE (SPECIAL DET))
;ВСПОМОГАТЕЛЬНЫЕ МАССИВЫ И ПЕРЕМЕННЫЕ
(DECLARE (SPECIAL PAR))
(DECLARE (SPECIAL R))
(DECLARE (SPECIAL T_))
(DECLARE (SPECIAL I))
(DECLARE (SPECIAL II))
;*********************
(SETQ R (MAKE-ARRAY SIZE :ELEMENT-TYPE 'FLOAT :INITIAL-ELEMENT 0))
(SETQ T_ 1)
(SETQ DET 1)
(DO
((J 0))
((>= J (- SIZE 1)))
;ИСКЛЮЧАЕМ ДЕЛЕНИЕ НА 0
(IF (= (AREF MATRIX J J) 0)
(PROGN
(SETQ II (+ J 1))
;ИЩЕМ СТРОКУ В КОТОРОЙ J-Й ЭЛЕМЕНТ НЕ 0
(DO
(())
((OR (/= (AREF MATRIX II J) 0) (= II (- SIZE 1))))
(SETQ II (+ II 1))
)
;ЕСЛИ НЕТ ТАКОЙ СТРОКИ ОПРЕДЕЛИТЕЛЬ РАВЕН 0
(IF (AND (= (AREF MATRIX II J) 0) (= II (- SIZE 1))) (SETQ T_ 0))
;МЕНЯЕМ J СТРОКУ И НАЙДЕННУЮ
(DO
((K 0))
((>= K SIZE))
(SETF (AREF R K) (AREF MATRIX J K))
(SETF (AREF MATRIX J K) (AREF MATRIX II K))
(SETF (AREF II K) (AREF R K))
(SETQ K (+ K 1))
)
)
)
;ПРЯМОЙ ХОД
;ПРИВЕДЕНИЕ К ТРЕУГОЛЬНОМУ ТИПУ
(DO
((I (+ J 1)))
((>= I SIZE))
;ЕСЛИ (AREF MATR I J)=0 ДЕЛАТЬ НИЧЕГО НЕ НАДО
(IF (/= (AREF MATRIX I J) 0)
(PROGN
(SETQ PAR (/ (AREF MATRIX I J) (AREF MATRIX J J)))
(DO
((JJ J))
((>= JJ SIZE))
(SETF (AREF MATRIX J JJ) (* (AREF MATRIX J JJ) PAR))
(SETF (AREF MATRIX I JJ) (- (AREF MATRIX I JJ) (AREF MATRIX J JJ)))
(SETF (AREF MATRIX J JJ) (/ (AREF MATRIX J JJ) PAR))
(SETQ JJ (+ JJ 1))
)
)
)
(SETQ I (+ I 1))
)
(SETQ J (+ J 1))
)
(IF (/= T_ 0)
(PROGN
(DO
((I 0))
((>= I SIZE))
(SETQ DET (* DET (AREF MATRIX I I)))
(SETQ I (+ I 1))
)
)
;ИНАЧЕ
(SETQ DET 0)
)
;ВОЗВРАЩАЕМ ОПРЕДЕЛИТЕЛЬ
DET
)
(SETQ N 0)
(SETQ INPUT_STREAM (OPEN " D:\MATRIX.TXT" :DIRECTION :INPUT))
;РАЗМЕР МАТРИЦЫ
(SETF N (READ INPUT_STREAM))
(SETQ MATR (MAKE-ARRAY (LIST N N) :ELEMENT-TYPE 'FLOAT :INITIAL-ELEMENT 0))
(SETF MATR (READ INPUT_STREAM))
(CLOSE INPUT_STREAM)
(SETQ DETERM (DETERMINANT MATR N))
;РЕЗУЛЬТАТ
(SETQ OUTPUT_STREAM (OPEN " D:\DETERMINANT.TXT" :DIRECTION :OUTPUT))
;ЗАПИСЫВАЕМ ОПРЕДЕЛИТЕЛЬ
(PRINT 'DETERMINANT OUTPUT_STREAM)
(PRINT DETERM OUTPUT_STREAM)
;ЗАКРЫВАЕМ ФАЙЛ
(TERPRI OUTPUT_STREAM)
(CLOSE OUTPUT_STREAM)
5 Пример выполнения программы
Пример 1.
Рисунок 2 – Входные данные
Рисунок 3 – Выходные данные
Пример 2.
Рисунок 4 – Входные данные
Рисунок 5 – Выходные данные
Пример 3.
Рисунок 6 – Входные данные
Рисунок 7 – Выходные данные
Заключение
Проблема повышения качества вычислений, как несоответствие между желаемым и действительным, существует и будет существовать в дальнейшем. Ее решению будет содействовать развитие информационных технологий, которое заключается как в совершенствовании методов организации информационных процессов, так и их реализации с помощью конкретных инструментов – сред и языков программирования.
Итогом работы можно считать созданную функциональную модель для вычисления определителя методом исключения Гаусса. Созданная функциональная модель и ее программная реализация могут служить органической частью решения более сложных задач.
Список использованных источников и литературы
1. Бронштейн, И.Н. Справочник по математике для инженеров и учащихся втузов [Текст] / И.Н. Бронштейн, К.А. Семендяев. – М.: Наука, 2007. – 708 с.
2. Васильев, Ф.П. Численные методы решения экстремальных задач. [Текст] / Ф.П. Васильев – М.: Наука, 2002. C. 415.
3. Калиткин, Н.Н. Численные методы. [Электронный ресурс] / Н.Н. Калиткин. – М.: Питер, 2001. С. 504.
4. Кнут, Д.Э. Искусство программирования. Основные алгоритмы [Текст] / Д.Э. Кнут. – М.: Вильямс, 2007. Т.1. – 712 с.
5. Метод Гаусса [Электронный ресурс] – Режим доступа: http://www.wikipedia.org/wiki/Метод_Гаусса.
6. Степанов, П.А. Функциональное программирование на языке Lisp. [Электронный ресурс] / П.А.Степанов, А.В. Бржезовский. – М.: ГУАП, 2003. С. 79.
7. Симанков, В.С. Основы функционального программирования [Текст] / В.С. Симанков, Т.Т. Зангиев, И.В. Зайцев. – Краснодар: КубГТУ, 2002. – 160 с.
8. Хювенен Э. Мир Лиспа [Текст] / Э. Хювенен, Й. Сеппянен. – М.: Мир, 1990. – 460 с.
... так и ВּА, существует, так как матрицы согласованны: ·==·==; ·==·== = = АּВ=ВּА, т. е. данные матрицы коммутирующие. ЛЕКЦИЯ 2. ОПРЕДЕЛИТЕЛИ План 1. Определители квадратной матрицы и их свойства. 2. Теоремы Лапласа и аннулирования. Ключевые понятия Алгебраическое дополнение элемента определителя. Минор элемента определителя. ...
... его за прямые скобки. Оставшиеся коэффициенты упорядочены, как в матрице . Теперь для представления исходной системы уравнений в виде несложно определить векторно-матричную операцию , результатом которой является вектор с i-той компонентой, равной . Аксиоматическое построение линейной (векторной) алгебры с рассмотренными базовыми операциями позволило установить важные и полезные свойства, как ...
... – матрица проводимостей, обратная матрице сопротивлений ветвей. Если в функции fk и jk входят производные токов и напряжений, то процессы в этой линейной или нелинейной электрической цепи будут характеризоваться системой, соответственно, линейных или нелинейных дифференциальных уравнений. При отсутствии производных в функциях fk и jk процессы в этой линейной или нелинейной электрической цепи ...
... и методом Крамера на примере следующей системы В этом случае матрица коэффициентов А и вектор свободных членов b имеют вид Введём матрицу A и вектор b в рабочий лист MS Excel (см. рис. 21) Рисунок 21 В нашем случае матрица А находится в ячейках B1:Е4, а вектор b -G1:G4. Сначала решать систему будем методом обратной матрицы. Поэтому необходимо вычислить матрицу, обратную A. Для ...
0 комментариев