Численная линейная алгебра исследует то, как можно использовать матричные операции для создания компьютерных алгоритмов, которые эффективно дают приблизительные ответы на задачи непрерывной математики. Численная линейная алгебра является видом линейной алгебры и представляет собой область численного анализа. Компьютеры используют арифметику с плавающей запятой и не могут точно представлять иррациональные данные, поэтому, когда компьютерный алгоритм применяется к матрице данных, он иногда может увеличить разность[англ.] между числом, хранящимся в компьютере, и истинным числом, приближением которого оно является. Численная линейная алгебра использует свойства векторов и матриц для разработки эффективных алгоритмов, которые минимизируют ошибку, вносимую компьютером.
Основные задачи в численной линейной алгебре включают получение матричных разложений, таких как сингулярное разложение, QR-разложение, LU-разложение или собственное разложение, которые затем можно использовать для решения общих задач линейной алгебры, таких как решение систем линейных уравнений, определение местоположения собственных значений или оптимизация методом наименьших квадратов. Основная задача численной линейной алгебры — разработка алгоритмов, которые не вносят ошибок при применении к реальным данным на компьютере с конечной точностью, часто достигается с помощью итерационных методов[англ.].
Для многих задач прикладной линейной алгебры полезно рассматривать матрицу как объединённый набор векторов-столбцов. Например, при решении линейной системы , вместо нахождения как умножения и , лучше представить как вектор коэффициентов в линейном разложении в базисе, образованном столбцами [1]:8. Представление о матрицах как об объединённом наборе столбцов практично для целей матричных алгоритмов, в связи с тем, что матричные алгоритмы часто содержат два вложенных цикла: один по столбцам матрицы , а другой по строкам матрицы . Например, для матриц и векторов и , можно использовать разделение столбцов для вычисления как
Сингулярное разложение матрицы , где и унитарные матрицы, а диагональная. Элементы диагональной матрицы называются сингулярными числами матрицы . Так как сингулярные числа являются квадратными корнями из собственных значений матрицы , существует тесная связь между разложением по сингулярным значениям и разложениями по собственным значениям. Это означает, что большинство методов вычисления разложения по сингулярным числам аналогичны методам собственных значений[1]:36; возможно, самый распространенный метод включает преобразование Хаусхолдера[1]:253.
LU-разложение матрицы состоит из нижней треугольной матрицы и верхней треугольной матрицы такими, что . Матрица находится с помощью метода Гаусса, которая включает в себя умножения слева на набор матриц для формирования , откуда [1]:147[4]:96.
Спектральное разложение матрицы , где столбцы — собственные векторы матрицы , и представляет собой диагональную матрицу, диагональные элементы которой — соответствующие собственные значения матрицы [1]:33. Не существует прямого метода нахождения спектрального разложения произвольной матрицы: поскольку невозможно написать программу, которая находит точные корни произвольного многочлена за конечное время, любой алгоритм нахождения собственных значений обязательно должен быть итерационным[1]:192.
С точки зрения числовой линейной алгебры, метод Гаусса — это процедура разложения матрицы в LU-разложение, которую метод Гаусса выполняет путем умножения слева на последовательность матриц до тех пор, пока не станет верхней треугольной, а не станет нижней треугольной, где [1]:148. Наивные программы для метода Гаусса, как известно, очень
вычислительно неустойчивы и дают огромные ошибки при применении к матрицам со многими значащими цифрами[2]. Самое простое решение — ввести опорный элемент[англ.], что даёт модифицированный стабильный алгоритм метода Гаусса[1]:151.
Численная линейная алгебра обычно рассматривает матрицы как объединённый набор векторов-столбцов. Традиционный подход состоит в том, чтобы решить линейную систему , чтобы получить как произведение и . Вместо этого численная линейная алгебра интерпретирует как вектор коэффициентов линейного разложения в базисе, образованном столбцами [1]:8.
Для решения систем линейных уравнений могут применяться матричные уравнения. В зависимости от характеристик матрицы и векторов и , одни разложения могут быть проще, чем другие. можно использовать множество различных разложений, в зависимости от характеристик матрицы и векторов и , что может значительно упростить получение одного разложения по сравнению с другими. Если — QR-разложение матрицы , то [1]:54. Если — спектральное разложение матрицы , то мы стремимся найти такой, что , с и . Откуда получаем [1]:33. Наконец, если — LU-разложение матрицы , то можно решить с помощью треугольных матриц и [1]:147[4]:99.
Подход, связанный с матричными разложениями, предлагает ряд способов решения линейной системы , где мы стремимся минимизировать , как в модели линейной регрессии. QR-алгоритм решает эту проблему, сначала определяя , а затем вычисляя тонкое QR-разложенние и переходит к уравнению . Эта верхнетреугольная система может быть решена относительно . Аналогичный алгоритм для решения МНК можно получить при помощи SVD-разложения. Вычисляя тонкое SVD-разложение , а затем вычисляя вектор , мы сводим задачу наименьших квадратов к простой диагональной системе[1]:84. Тот факт, что решения методом наименьших квадратов могут быть получены с помощью QR-разложения и SVD-разложения, означает, что в дополнение к классическому методу нормальных уравнений[англ.] решения задач наименьших квадратов, эти задачи также могут быть решены методами, включающими алгоритм Грама-Шмидта и методы Хаусхолдера.
Обусловленность и вычислительная устойчивость
Рассмотрим функцию , где — нормированное векторное пространство данных и — нормированное векторное пространство решений. Для некоторой точки задача называется плохо обусловленной, если малое возмущение в приводит к большому изменению значения . Мы можем количественно определить это, определив число обусловленности, которое показывает, насколько хорошо обусловлена проблема. Определим его как
Неустойчивость — это склонность компьютерных алгоритмов, зависящих от арифметики с плавающей запятой, получать результаты, резко отличающееся от точного математического решения задачи. Когда матрица содержит реальные данные со многими значащими цифрами, многие алгоритмы для решения таких задач, как линейные системы уравнений или оптимизация методом наименьших квадратов, могут давать очень неточные результаты. Создание устойчивых алгоритмов для плохо обусловленных задач — центральная задача численной линейной алгебры. Одним из примеров: устойчивость метода отражения Хаусхолдера делает алгоритм надежным методом решения линейных систем, тогда как неустойчивость метода нормальных уравнений для решения задач наименьших квадратов является причиной для выбора методов матричного разложения, таких как использование SVD-разложения. Некоторые методы разложения матриц могут быть неустойчивыми, но имеют простые модификации, делающие их устойчивыми; например, нестабильный метод Грама-Шмидта, который может легко быть изменён для получения устойчивой модификации Грама-Шмидта[1]:140. Другая классическая задача числовой линейной алгебры заключается в том, что метод Гаусса нестабилен, но становится устойчивым с введением опорного элемента.
Есть две причины, по которым итерационные алгоритмы — важная часть численной линейной алгебры. Во-первых, многие численные задачи не имеют прямого решения; чтобы найти собственные значения и собственные векторы произвольной матрицы, мы можем использовать только итеративный подход. Во-вторых, безытерационные алгоритмы для произвольной матрицы требуют времени, что неожиданно долго, учитывая, что матрицы содержат только чисел. Итерационные подходы могут использовать некоторые особенности матриц, чтобы сократить это время. Например, когда матрица разреженная, итеративный алгоритм может пропустить многие шаги, которые обязательно последуют при прямом подходе, даже если они избыточны.
Ядро многих итерационных методов в численной линейной алгебре — это проекция матрицы на более низкое подпространство Крылова более низкой размерности, что позволяет аппроксимировать характеристики матрицы высокой размерности путем итеративного вычисления эквивалентных характеристик подобных матриц, начиная с пространства низкой размерности и последовательного перехода к более высоким измерениям. Когда симметрична, и мы хотим решить линейную задачу , классический итеративный подход — метод сопряжённых градиентов. Если не симметричная, то примерами итерационных решений линейной задачи являются обобщенный метод минимальных невязок (GMRES)[англ.] и метод сопряжённых градиентов для нормальных уравнений (CGN)[англ.] для нормальных уравнений. Если симметричная, то для нахождения собственных значений и собственных векторов мы можем использовать алгоритм Ланцоша[англ.], и если не симметричная, то используется итерация Арнольди.
Программное обеспечение для численного анализа
Некоторые языки программирования используют методы оптимизации численной линейной алгебры и предназначены для реализации её алгоритмов. Эти языки включают MATLAB, Analytica, Maple, и Mathematica. Другие языки программирования, которые явно не предназначены для численной линейной алгебры, имеют библиотеки, которые предоставляют процедуры и оптимизацию; в C и Fortran есть пакеты Basic Linear Algebra Subprograms и LAPACK, в python есть библиотека NumPy, и в Perl есть Perl Data Language. Многие команды численной линейной алгебры в R полагаются на фундаментальные библиотеки, такие как LAPACK[5].
↑ 123Golub, Gene H. Matrix Computations / Gene H. Golub, Charles F. Van Loan. — 3rd. — Baltimore : The Johns Hopkins University Press, 1996. — ISBN 0-8018-5413-X.
↑Rickert, JosephR and Linear Algebra (неопр.). R-bloggers (29 августа 2013). Дата обращения: 17 февраля 2019. Архивировано 18 февраля 2019 года.
Strategi Solo vs Squad di Free Fire: Cara Menang Mudah!