Купить Matlab  |  Mathematica  |  Mathcad  |  Maple  |  Statistica  |  Другие пакеты Поиск по сайту
Internet-класс  |  Примеры  |  Методики  |  Форум  |  Download
https://hub.exponenta.ru/


Справочник по Matlab
  • Массивы, матрицы и операции с ними
  • Математические функции
  • Линейная алгебра
  • Анализ и обработка данных
  • Работа с разреженными матрицами
  • Графические команды и функции
  •  

    \, /

    Решатели систем линейных уравнений

    Синтаксис:

                  X = B \ A
                  X = B / A

    Описание:

    Функция X = B \ A находит решение системы уравнений вида AX = B, где A - прямоугольная матрица размера m х n и B - матрица размера n х k.

    Функция X = B / A находит решение системы уравнений вида XA = B, где A - прямоугольная матрица размера n х m и B - матрица размера m х k.

    Алгоритм:

    Решение систем линейных уравнений вида X = A \ B и X = B / A реализовано в MATLAB с помощью специального монитора, который использует разные алгоритмы решения в зависимости от структуры матрицы A.

    • Если A - треугольная матрица с точностью до перестановки ее строк или столбцов, то решение таких систем уравнений может быть эффективно вычислено методом обратной подстановки. Проверка матрицы, является ли она верхней треугольной, осуществляется для полных матриц проверкой на нуль всех элементов, лежащих ниже диагонали; для разреженных матриц - определением структуры ее элементов. Большинство матриц нетреугольной структуры выявляются почти мгновенно, так что такая проверка требует очень малого времени.
    • Если матрица A - симметрическая или эрмитова с положительными диагональными элементами, то применяется разложение Холецкого (функция chol). Если A - разреженная матрица, применяется алгоритм упорядочения по разреженности (функции symmmd и spparms). Если при этом матрица A положительно определенна, то алгоритм Холецкого позволяет эффективно найти решение. Матрицы, не являющиеся положительно определенными, выявляются почти мгновенно. Разложение Холецкого имеет вид:
                 A = L * LT,
      где LT - верхняя треугольная матрица. После этого решение Х можно получить решая последовательно две треугольные системы
                 X = LT \ (L \ B).
    • Если A - произвольная квадратная матрица, то треугольное разложение вычисляется методом исключения Гаусса с частичным выбором главного элемента (функция lu). Если A - разреженная матрица, применяется алгоритм упорядочения по разреженности столбцов (функции colmmd и spparms). В результате имеем следующее разложение:
                 A = L * U,
      где L - нижняя, а U - верхняя треугольные матрицы. После этого решение Х можно получить решая последовательно две треугольные системы
                 X = U \ (L \ B).
    • Если A - прямоугольная полная матрица, то применяется QR-разложение на основе преобразований Хаусхолдера следующего вида
                 A * P = Q * R,
      где P - матрица преобразований, Q - ортогональная и R - верхняя треугольная (функция qr) матрицы. Решение, соответствующее минимуму квадрата ошибки, находится согласно следующему соотношению
                 X = P * (R \ (QT * B)).
    • Если A - прямоугольная разреженная матрица, то формируется вспомогательная расширенная матрица следующего вида:
                 S = [c*I A; AT 0].
      Это реализуется с помощью функции spaugment. По умолчанию значение коэффициента масштабирования невязки c равно max(max(abs(A)))/1000 (функция spparms). Решение X в соответствии с методом наименьших квадратов и матрица невязок R = B - A * X вычисляются путем решения следующей системы:
                 S * [R / c; X] = [B; 0]
      с использованием алгоритмов упорядочения по разреженности и исключения Гаусса с выбором главного элемента.
      Различные алгоритмы разложения матриц реализованы в системе MATLAB на основе ZGECO, ZGEFA и ZGESL для квадратных и процедур ZQRDC и ZQRSL для прямоугольных матриц из пакета LINPACK [1].

    Диагностические сообщения:

    При решении систем линейных уравнений:
    если A - квадратная вырожденная матрица, выдается сообщение Matrix is singular to working precision.

    Для выбранной точности матрица вырожденна.

    При поэлементном делении:
    если массив-делитель имеет нулевые элементы, выдается сообщение

               Divide by zero.
               Деление на нуль.

    На ЭВМ, где не реализован стандарт IEEE-арифметики, например на ЭВМ VAX, обе вышеприведенные операции будут выдавать сообщения об ошибке. На ЭВМ, где реализован стандарт IEEE-арифметики, например на РС, будут генерироваться только предупреждения. При этом при решении систем будут возвращаться матрицы, часть элементов которых будет иметь значение Inf; при поэлементном делении результатом могут быть как значения Inf, так и значение NaN.

    Если результат обращения матрицы не является надежным, выдается сообщение

                Warning: Matrix is close to singular or badly scaled.
                Results may be inaccurate. RCOND = xxx
                Предупреждение: Матрица близка к вырожденной или плохо масштабирована.
                Результаты могут быть неточными. Число обусловленности RCOND = xxx

    При решении систем линейных уравнений:
    если прямоугольная матрица А имеет неполный столбцовый ранг, выдается сообщение

                Warning: Rank deficient, rank = xxx tol = xxx
                Предупреждение: Неполный ранг, ранг rank = xxx точность tol = xxx

    Сопутствующие функции: INV, QR, DET, LU, RCOND, ORTH, RREF.

    Ссылки:

    1. Dongarra J. J., Bunch J. R., Moler C. B., Stewart G. W. LINPACK User’s Guide. Philadelphia, 1979.

    В начало страницы К предыдущему разделуК следующему разделу

    | На первую страницу | Поиск | Купить Matlab

    Исправляем ошибки: Нашли опечатку? Выделите ее мышкой и нажмите Ctrl+Enter


    Copyright © 1993-2024. Компания Softline. Все права защищены.

    Дата последнего обновления информации на сайте: 04.03.17
    Сайт начал работу 01.09.00