python — Приведение матрицы к треугольному виду
Вопрос задан
Изменён 2 года назад
Просмотрен 1k раза
def Gauss(A): for k in range(len(A) - 1): At = A.copy() for i in range(len(A)): for j in range(len(A)): if(i <= k): A[i][j] = At[i][j] elif(i > k and j > k): A[i][j] = round(At[i][j] - (At[i][k] / At[k][k]) * At[k][j], 4) elif(i > k and j <= k): A[i][j] = 0 return A with open('matrix.txt') as f: matrix = [list(map(float, row.split())) for row in f.readlines()] M = Gauss(matrix) for i in range(len(M)): print(*M[i])
Не понимаю, почему никаких изменений в матрице не происходит на 7 строке, притом что если убрать строку 8, то изменения будут?
- python
- матрицы
1
Вот ваш код с отладочной печатью:
def Gauss(A): for k in range(len(A) - 1): At = A. copy() for i in range(len(A)): assert At[i] is A[i] for j in range(len(A)): if(i <= k): A[i][j] = At[i][j] elif(i > k and j > k): print('use', i, k) A[i][j] = round(At[i][j] - (At[i][k] / At[k][k]) * At[k][j], 4) elif(i > k and j <= k): print('clear', i, j) A[i][j] = 0 return A matrix = [[2, 1], [4, 1]] M = Gauss(matrix) for i in range(len(M)): print(*M[i])
Он печатает следущее:
clear 1 0 use 1 0 2 1 0 1.0
assert
показывает что копирование не удалось. Массивы A
и At
используют одни и те же строки.
Строка clear 1 0
показывает что стёрт элемент матрицы, а строка use 1 0
показывает что стёртое значение используется в вычислениях.
P.S. Гауссово исключение можно написать без изготовления копий матрицы, если делать это аккуратно.
0
Зарегистрируйтесь или войдите
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Отправить без регистрации
Почта
Необходима, но никому не показывается
Отправить без регистрации
Почта
Необходима, но никому не показывается
Нажимая на кнопку «Отправить ответ», вы соглашаетесь с нашими пользовательским соглашением, политикой конфиденциальности и политикой о куки
Какими бывают виды матриц.
Ступенчатый вид матрицы. Приведение матрицы к ступенчатому и треугольному видуМатрица — это особый объект в математике. Изображается в форме прямоугольной или квадратной таблицы, сложенной из определенного числа строк и столбцов. В математике имеется большое разнообразие видов матриц, различающихся по размерам или содержанию. Числа ее строк и столбцов именуются порядками. Эти объекты употребляются в математике для упорядочивания записи систем линейных уравнений и удобного поиска их результатов. Уравнения с использованием матрицы решаются посредством метода Карла Гаусса, Габриэля Крамера, миноров и алгебраических дополнений, а также многими другими способами. Базовым умением при работе с матрицами является приведение к стандартному виду. Однако для начала давайте разберемся, какие виды матриц выделяют математики.
Нулевой тип
Все компоненты этого вида матрицы — нули. Между тем, число ее строк и столбцов абсолютно различно.
Квадратный тип
Количество столбцов и строк этого вида матрицы совпадает. Иначе говоря, она представляет собой таблицу формы «квадрат». Число ее столбцов (или строк) именуются порядком. Частными случаями считается существование матрицы второго порядка (матрица 2×2), четвертого порядка (4×4), десятого (10×10), семнадцатого (17×17) и так далее.
Вектор-стобец
Это один из простейших видов матриц, содержащий только один столбец, который включает в себя три численных значения. Она представляет ряд свободных членов (чисел, независимых от переменных) в системах линейных уравнений.
Вектор-строка
Вид, аналогичный предыдущему. Состоит из трех численных элементов, в свою очередь организованных в одну строку.
Диагональный тип
Числовые значения в диагональном виде матрицы принимают только компоненты главной диагонали (выделена зеленым цветом). Основная диагональ начинается с элемента, находящегося в правом верхнем углу, а заканчивается числом в третьем столбце третьей строки. Остальные компоненты равны нулю. Диагональный тип представляет собой только квадратную матрицу какого-либо порядка. Среди матриц диагонального вида можно выделить скалярную. Все ее компоненты принимают одинаковые значения.
Единичная матрица
Подвид диагональной матрицы. Все ее числовые значения являются единицами. Используя единичный тип матричных таблиц, выполняют ее базовые преобразования или находят матрицу, обратную исходной.
Канонический тип
Канонический вид матрицы считается одним из основных; приведение к нему часто необходимо для работы. Число строк и столбцов в канонической матрице различно, она необязательно принадлежит к квадратному типу. Она несколько похожа на единичную матрицу, однако в ее случае не все компоненты основной диагонали принимают значение, равное единице. Главнодиагональных единиц может быть две, четыре (все зависит от длины и ширины матрицы). Или единицы могут не иметься вовсе (тогда она считается нулевой). Остальные компоненты канонического типа, как и элементы диагонального и единичного, равны нулю.
Треугольный тип
Один из важнейших видов матрицы, применяемый при поиске ее детерминанта и при выполнении простейших операций. Треугольный тип происходит от диагонального, поэтому матрица также является квадратной. Треугольный вид матрицы подразделяют на верхнетреугольный и нижнетреугольный.
В верхнетреугольной матрице (рис. 1) только элементы, которые находятся над главной диагональю, принимают значение, равное нулю. Компоненты же самой диагонали и части матрицы, располагающейся под ней, содержат числовые значения.
В нижнетреугольной (рис. 2), наоборот, элементы, располагающиеся в нижней части матрицы, равны нулю.
Ступенчатая матрица
Вид необходим для нахождения ранга матрицы, а также для элементарных действий над ними (наряду с треугольным типом). Ступенчатая матрица названа так, потому что в ней содержатся характерные «ступени» из нулей (как показано на рисунке). В ступенчатом типе образуется диагональ из нулей (необязательно главная), и все элементы под данной диагональю тоже имеют значения, равные нулю. Обязательным условием является следующее: если в ступенчатой матрице присутствует нулевая строка, то остальные строки, находящиеся ниже нее, также не содержат числовых значений.
Таким образом, мы рассмотрели важнейшие типы матриц, необходимые для работы с ними. Теперь разберемся с задачей преобразования матрицы в требуемую форму.
Приведение к треугольному виду
Как же привести матрицу к треугольному виду? Чаще всего в заданиях нужно преобразовать матрицу в треугольный вид, чтобы найти ее детерминант, по-другому называемый определителем. Выполняя данную процедуру, крайне важно «сохранить» главную диагональ матрицы, потому что детерминант треугольной матрицы равен именно произведению компонентов ее главной диагонали. Напомню также альтернативные методы нахождения определителя. Детерминант квадратного типа находится при помощи специальных формул. Например, можно воспользоваться методом треугольника. Для других матриц используют метод разложения по строке, столбцу или их элементам. Также можно применять метод миноров и алгебраических дополнений матрицы.
Подробно разберем процесс приведения матрицы к треугольному виду на примерах некоторых заданий.
Задание 1
Необходимо найти детерминант представленной матрицы, используя метод приведения его к треугольному виду.
Данная нам матрица представляет собой квадратную матрицу третьего порядка. Следовательно, для ее преобразования в треугольную форму нам понадобится обратить в нуль два компонента первого столбца и один компонент второго.
Чтобы привести ее к треугольному виду, начнем преобразование с левого нижнего угла матрицы — с числа 6. Чтобы обратить его в нуль, умножим первую строку на три и вычтем ее из последней строки.
Важно! Верхняя строка не изменяется, а остается такой же, как и в исходной матрице. Записывать строку, в четыре раза большую исходной, не нужно. Но значения строк, компоненты которых нужно обратить в нуль, постоянно меняются.
Далее займемся следующим значением — элементом второй строки первого столбца, числом 8. Умножим первую строку на четыре и вычтем ее из второй строки. Получим нуль.
Осталось только последнее значение — элемент третьей строки второго столбца. Это число (-1). Чтобы обратить его в нуль, из первой строки вычтем вторую.
Выполним проверку:
detA = 2 x (-1) x 11 = -22.
Значит, ответ к заданию: -22.
Задание 2
Нужно найти детерминант матрицы методом приведения его к треугольному виду.
Представленная матрица принадлежит к квадратному типу и является матрицей четвертого порядка. Значит, необходимо обратить в нуль три компонента первого столбца, два компонента второго столбца и один компонент третьего.
Начнем приведение ее с элемента, находящегося в нижнем углу слева, — с числа 4. Нам нужно обратить данное число в нуль. Удобнее всего сделать это, умножив на четыре верхнюю строку, а затем вычесть ее из четвертой. Запишем итог первого этапа преобразования.
Итак, компонент четвертой строки обращен в нуль. Перейдем к первому элементу третьей строки, к числу 3. Выполняем аналогичную операцию. Умножаем на три первую строку, вычитаем ее из третьей строки и записываем результат.
Далее видим число 2 во второй строке. Повторяем операцию: умножаем верхнюю строку на два и вычитаем ее из второй.
Нам удалось обратить в нуль все компоненты первого столбца данной квадратной матрицы, за исключением числа 1 — элемента главной диагонали, не требующего преобразования. Теперь важно сохранить полученные нули, поэтому будем выполнять преобразования со строками, а не со столбцами. Перейдем ко второму столбцу представленной матрицы.
Снова начнем с нижней части — с элемента второго столбца последней строки. Это число (-7). Однако в данном случае удобнее начать с числа (-1) — элемента второго столбца третьей строки. Чтобы обратить его в нуль, вычтем из третьей строки вторую. Затем умножим вторую строку на семь и вычтем ее из четвертой. Мы получили нуль вместо элемента, расположенного в четвертой строке второго столбца. Теперь перейдем к третьему столбцу.
В данном столбце нам нужно обратить в нуль только одно число — 4. Сделать это несложно: просто прибавляем к последней строке третью и видим необходимый нам нуль.
После всех произведенных преобразований мы привели предложенную матрицу к треугольному виду. Теперь, чтобы найти ее детерминант, нужно только произвести умножение получившихся элементов главной диагонали. Получаем: detA = 1 x (-1) x (-4) x 40 = 160. Следовательно, решением является число 160.
Итак, теперь вопрос приведения матрицы к треугольному виду вас не затруднит.
Приведение к ступенчатому виду
При элементарных операциях над матрицами ступенчатый вид является менее «востребованным», чем треугольный. Чаще всего он используется для нахождения ранга матрицы (т. е. количества ее ненулевых строк) или для определения линейно зависимых и независимых строк. Однако ступенчатый вид матрицы является более универсальным, так как подходит не только для квадратного типа, но и для всех остальных.
Чтобы привести матрицу к ступенчатому виду, сначала нужно найти ее детерминант. Для этого подойдут вышеназванные методы. Цель нахождения детерминанта такова: выяснить, можно ли преобразовать ее в ступенчатый вид матрицы. Если детерминант больше или меньше нуля, то можно спокойно приступать к заданию. Если же он равен нулю, выполнить приведение матрицы к ступенчатому виду не получится. В таком случае нужно проверить, нет ли ошибок в записи или в преобразованиях матрицы. Если подобных неточностей нет, задание решить невозможно.
Рассмотрим, как привести матрицу к ступенчатому виду на примерах нескольких заданий.
Задание 1. Найти ранг данной матричной таблицы.
Перед нами квадратная матрица третьего порядка (3×3). Мы знаем, что для нахождения ранга необходимо привести ее к ступенчатому виду. Поэтому сначала нам необходимо найти детерминант матрицы. Воспользуемся методом треугольника: detA = (1 x 5 x 0) + (2 x 1 x 2) + (6 x 3 x 4) — (1 x 1 x 4) — (2 x 3 x 0) — (6 x 5 x 2) = 12.
Детерминант = 12. Он больше нуля, значит, матрицу можно привести к ступенчатому виду. Приступим к ее преобразованиям.
Начнем его с элемента левого столбца третьей строки — числа 2. Умножаем верхнюю строку на два и вычитаем ее из третьей. Благодаря этой операции как нужный нам элемент, так и число 4 — элемент второго столбца третьей строки — обратились в нуль.
Далее обращаем в нуль элемент второй строки первого столбца — число 3. Для этого умножаем верхнюю строку на три и вычитаем ее из второй.
Мы видим, что в результате приведения образовалась треугольная матрица. В нашем случае продолжить преобразование нельзя, так как остальные компоненты не удастся обратить в нуль.
Значит, делаем вывод, что количество строк, содержащих числовые значения, в данной матрице (или ее ранг) — 3. Ответ к заданию: 3.
Задание 2. Определить количество линейно независимых строк данной матрицы.
Нам требуется найти такие строки, которые нельзя какими-либо преобразованиями обратить в нуль. Фактически нам нужно найти количество ненулевых строк, или ранг представленной матрицы. Для этого выполним ее упрощение.
Мы видим матрицу, не принадлежащую к квадратному типу. Она имеет размеры 3×4. Начнем приведение также с элемента левого нижнего угла — числа (-1).
Прибавляем первую строку к третьей. Далее вычитаем из нее вторую, чтобы обратить число 5 в нуль.
Дальнейшие ее преобразования невозможны. Значит, делаем вывод, что количество линейно независимых строк в ней и ответ к заданию — 3.
Теперь приведение матрицы к ступенчатому виду не является для вас невыполнимым заданием.
На примерах данных заданий мы разобрали приведение матрицы к треугольному виду и ступенчатому виду. Чтобы обратить в нуль нужные значения матричных таблиц, в отдельных случаях требуется проявить фантазию и правильно преобразовать их столбцы или строки. Успехов вам в математике и в работе с матрицами!
линейная алгебра — Преобразование матрицы к верхнему треугольному виду
спросил
Изменено 8 лет, 6 месяцев назад
Просмотрено 8к раз
$\begingroup$
Следующая задача из Апостола, Исчисление, Том II
(стр. 80).Вопрос требует вычислить определитель
$$ \begin{pmatrix} а & 1 & 0 & 0 & 0 \\ 4 & a & 2 & 0 & 0 \\ 0 и 3 и а и 3 и 0 \\ 0 и 0 и 2 и а и 4 \\ 0 и 0 и 0 и 1 и а \end{pmatrix}$$
путем преобразования его в верхнюю треугольную матрицу.
Есть ли эффективный способ преобразовать это в верхнюю треугольную матрицу? Я могу заняться сокращением строк, что в конечном итоге должно привести меня к этому (мои попытки сделать это привели к чрезвычайно долгим и утомительным вычислениям), но форма матрицы предполагает, что может быть более быстрый способ? Я не могу найти его. (Конечно, можно вычислить определитель, просто выполнив разложение, но меня больше интересует, есть ли быстрый способ добраться до верхней треугольной матрицы, которую требует задача.)
- линейная алгебра
- матрицы
$\endgroup$
5
$\begingroup$
Эта матрица называется трехдиагональной матрицей.
В этом случае вы должны быть в состоянии превратить эту матрицу в верхнюю треугольную матрицу всего за четыре элементарных операции со строками*, все сложения строк. Добавление строк не влияет на определитель, поэтому вам просто нужно перемножить элементы по диагонали полученной верхней треугольной матрицы и получить определитель результата. Стандартный метод декомпозиции LU, которому учат людей, делает то же самое… есть нечто, называемое методом Краута для декомпозиции LU, который легче вычислить, но, скорее всего, проще просто уменьшить его по строке.
*не похоже, что вам придется делать какие-либо повороты с первого взгляда. Поворот просто умножает определитель на -1.
$\endgroup$
1
Зарегистрируйтесь или войдите в систему
Зарегистрируйтесь с помощью Google
Зарегистрироваться через Facebook
Зарегистрируйтесь, используя адрес электронной почты и пароль
Опубликовать как гость
Электронная почта
Требуется, но никогда не отображается
Опубликовать как гость
Электронная почта
Требуется, но не отображается
Чтобы найти первый собственный вектор, мы используем собственное значение $\lambda = 2$ и решаем $(A-\lambda I)v1 = 0$, в результате чего получаем собственный вектор $v1 = \langle1, 1\rangle$.
Примечание : Я не уверен, что вы уже изучили или поняли алгебраическую и геометрическую множественность, поэтому я воздержусь от этой терминологии, но она очень важна! См. Геометрическая и алгебраическая кратность .
Далее нам нужно найти другой собственный вектор, но поскольку у нас есть повторяющееся собственное значение, его обычно называют обобщенным собственным вектором (если он существует из 9{-1}AP = \pmatrix{2&1 \\ 0&2}$.
Вы заметили что-нибудь особенное в матрице $J$?
Давайте проверим эти результаты, используя Wolfram Alpha .
Имеет ли это смысл, и вы следуете?
Дополнительный ответ
Как вы это делаете?
Не каждая матрица имеет достаточно линейно независимых собственных векторов, чтобы ее можно было диагонализовать. Однако с помощью преобразований подобия любую квадратную матрицу можно привести к жордановой канонической форме, которая почти диагональна.
См. эти замечательные примечания (особенно в 7.2.1 для примера 4×4, который показывает все возможности для 4×4, но прочитайте все это и просмотрите все примеры с алгебраической и геометрической множественностью), Jordan Canonical Form .
Общее условие — наличие нетривиальных блоков Джордана, см.
Также посмотрите этот интересный пост Количество канонических форм Жордана для матрицы nxn .
Есть еще примера , которые вы можете просмотреть здесь.
Кроме того, они могут оказаться полезными.
Как определить диагонализируемость этих двух матриц?
Когда геометрическая кратность собственного значения меньше его алгебраической кратности?
Может ли собственное значение ($n$ на $n$-матрицу A) с алгебраической кратностью $n$ иметь собственное пространство размерности менее $n$?
См.