Линейная алгебра

Содержание

Слайд 3

Матричные операции

Пусть матрица А(МхN) умножается на матрицу B(NxK).
Результат – матрица С

Матричные операции Пусть матрица А(МхN) умножается на матрицу B(NxK). Результат – матрица

В покомпонентной записи:

Для того, чтобы умножить матрицу А на матрицу В необходимо, чтобы число столбцов матрицы А равнялось числу строк матрицы В.

Слайд 4

Специальные операции

На Матлабе это выглядит как:

Здесь X и Y – вектор-столбцы

Аналогично выглядят

Специальные операции На Матлабе это выглядит как: Здесь X и Y – вектор-столбцы Аналогично выглядят операции:
операции:

Слайд 5

Задание

Дана покомпонентная запись. Записать в формате
Матлаба:

А – матрица, х и

Задание Дана покомпонентная запись. Записать в формате Матлаба: А – матрица, х
y– вектор-столбцы.
Записать в покомпонентной форме:

Какова размерность матрицы и векторов? Что собой представляет результат?

Записать в формате Матлаба: (j – мнимая единица)

Слайд 6

Логическая индексация массивов

Логические вектора, построенные с помощью логических выражений могут служить индексами

Логическая индексация массивов Логические вектора, построенные с помощью логических выражений могут служить
при доступе к массивам.
Пусть
>>x=[1,2,3,4,5,6,7,8];
>>y=x(x>3)
Y= 4 5 6 7 8

Слайд 7

Пусть функция задается разными выражениями при разных значениях аргумента:

>> y=@(x)[0*x((x<-5)),sin(x(a1)),x(a2).^2-3,log(x(a3))]
>>x=-10:0.1:10;
>>plot(x,y(x))
Обратите внимание как

Пусть функция задается разными выражениями при разных значениях аргумента: >> y=@(x)[0*x((x >>x=-10:0.1:10;
записывается функция, равная нулю на некотором интервале. Как формируется функция из отрезков.
Постройте график этой функции.

Слайд 8

Создание матриц
с заданными свойствами

eye(n) – возвращает единичную матрицу размера nxn; eye(m,n) –

Создание матриц с заданными свойствами eye(n) – возвращает единичную матрицу размера nxn;
размера mxn.
eye(size(A)) – возвращает единичную матрицу того же размера, что и A.
ones(n), ones(m,n), ones(size(A)) – возвращает матрицу, все элементы которой единицы.
zeros(n), zeros(m,n), zeros(size(A)) – нулевые матрицы.

Слайд 9

Функция linspace формирует линейный массив равноотстоящих узлов. Это подобно оператору :, но

Функция linspace формирует линейный массив равноотстоящих узлов. Это подобно оператору :, но
дает прямой контроль над числом точек. Применяется в следующих формах:
• linspace(a,b) – возвращает линейный массив из 100 точек, равномерно распределенных между a и b;
• linspace(a,b,n) – генерирует n точек, равномерно распределенных в интервале от a до b.

Слайд 10

>> linspace(1,10,5)
ans =
1.0000 3.2500 5.5000 7.7500 10.0000
logspace(a,b) – возвращает вектор-строку из

>> linspace(1,10,5) ans = 1.0000 3.2500 5.5000 7.7500 10.0000 logspace(a,b) – возвращает
50 равноотстоящих в логарифмическом масштабе точек между декадами 10^а и 10^b;
logspace(a,b,n) – возвращает n точек между декадами 10^а и 10^b;

Слайд 11

>> logspace(1,10,5)
ans =
Columns 1 through 4:
10.00000 1778.27941 316227.76602 56234132.51903
Column

>> logspace(1,10,5) ans = Columns 1 through 4: 10.00000 1778.27941 316227.76602 56234132.51903
5:
10000000000.00000
Функция rand генерирует массивы случайных чисел, значения элементов которых равномерно распределены в промежутке (0,1)

Слайд 12

Функция randn генерирует массив со случайными элементами, распределенными по нормальному закону с

Функция randn генерирует массив со случайными элементами, распределенными по нормальному закону с
нулевым математическим ожиданием и средним
квадратическим отклонением, равным 1.
randn(n), randn(m,n), randn(size(A))
rand(n), rand(m,n), rand(size(A))

Слайд 13

Проверить распределение случайных чисел можно, построив гистограмму распределения большого количества чисел.
>> Y=rand(10000,1);

Проверить распределение случайных чисел можно, построив гистограмму распределения большого количества чисел. >>
hist(Y,100)
>> Y=randn(10000,1); hist(Y,100)

Слайд 16

Конкатенация матриц

C = cat(dim,A,B) – объединяет массивы А и B в соответствии

Конкатенация матриц C = cat(dim,A,B) – объединяет массивы А и B в
со спецификацией размерности dim и возвращает объединенный массив;
dim=1 – горизонтальная конкатенация;
dim=2 – вертикальная конкатенация;
dim=3 – многомерный массив размерности 3 и т.д.

Слайд 17

X = diag(v,k) – для вектора v, состоящего из n компонентов, возвращает
квадратную

X = diag(v,k) – для вектора v, состоящего из n компонентов, возвращает
матрицу Х порядка n+abs(k) с элементами v на kой диагонали, при k=0 это главная диагональ (из левого верхнего угла матрицы в правый нижний угол), при k>0 – одна из диагоналей выше главнойдиагонали, при k<0 – одна из нижних диагоналей. Остальные элементы матрицы – нули;
v = diag(X,k) – возвращает вектор-столбец, k-ю диагональ матрицы Х;

Слайд 18

• prod(A) – возвращает произведение элементов массива, если А – вектор,
или вектор-строку,

• prod(A) – возвращает произведение элементов массива, если А – вектор, или
содержащую произведения элементов каждого столбца, если А – матрица;
• prod(A,dim) – возвращает вектор (строку или столбец) с произве-
дением элементов массива A по столбцам (dim=1), по строкам(dim=2).

Слайд 19

Пример:
>> A=[1 2 3 4; 2 4 5 7; 6 8 3

Пример: >> A=[1 2 3 4; 2 4 5 7; 6 8
4]
A =
1 2 3 4
2 4 5 7
6 8 3 4
>> B=prod(A)
B = 12 64 45 112
>> B=prod(A,2)
B = 24
280
576

Слайд 20

• sum(A) – возвращает сумму элементов массива, если А – вектор, или

• sum(A) – возвращает сумму элементов массива, если А – вектор, или
вектор-строку, содержащую сумму элементов каждого столбца, если А – матрица;
• sum(A,dim) – возвращает сумму элементов массива по столбцам (dim=1),
строкам (dim=2) или иным размерностям, в зависимости от значения скаляра dim.

Слайд 21

>> X=[1 2;3 4]
X =
1 2
3 4
>> sum(X)
ans =
4

>> X=[1 2;3 4] X = 1 2 3 4 >> sum(X) ans = 4 6
6

Слайд 22

Возможно создание пустых матриц, например:
>> M=[]
M = [](0x0)
>> M=[M [1,2;3,4]]
M =
1

Возможно создание пустых матриц, например: >> M=[] M = [](0x0) >> M=[M
2
3 4

Слайд 23

Матричные функции

expm(X) – возвращает еxp(X) от квадратной матрицы Х.
sqrtm(X),logm(X) –

Матричные функции expm(X) – возвращает еxp(X) от квадратной матрицы Х. sqrtm(X),logm(X) –
квадратный корень и логарифм от матрицы X.
Комплексный результат получается, если Х имеет неположительные собственные значения. Пусть X=[1,2;3,4];
Найти: exp(X); expm(X); sqrt(X);sqrtm(X);
Объяснить отличия.

Слайд 24

>> S=[1,0,3;1,3,1;4,0,0]
>> a=expm(S)
a =
31.22028 0.00000 23.37787
38.96594 20.08554 30.05928
31.17049 0.00000

>> S=[1,0,3;1,3,1;4,0,0] >> a=expm(S) a = 31.22028 0.00000 23.37787 38.96594 20.08554 30.05928
23.42766
>> b=logm(a)
b =
1.00000 0.00000 3.00000
1.00000 3.00000 1.00000
4.00000 0.00000 -0.00000

Слайд 25

Умножение матриц

Умножение матриц

Слайд 26

Вычисление нормы и чисел
обусловленности матрицы

Норма вектора X (или, точнее,
его p-норма) задается выражением
и

Вычисление нормы и чисел обусловленности матрицы Норма вектора X (или, точнее, его
вычисляется функцией norm(x,p).
Заметим, что norm(x,2)=sqrt(x’*x)

Слайд 27

Пусть А – матрица. Тогда n=norm(A) эквивалентно n=norm(A,2) и возвращает вторую норму,

Пусть А – матрица. Тогда n=norm(A) эквивалентно n=norm(A,2) и возвращает вторую норму,
то есть самое большое сингулярное число матрицы А.
n=norm(A,1)=
n=norm(A,inf)=
В общем случае p - норма матрицы A вычисляется как

Слайд 28

>> A=[2,3,1;1,9,4;2,6,7]
A =
2 3 1
1 9 4 Проверьте!
2 6 7
>>

>> A=[2,3,1;1,9,4;2,6,7] A = 2 3 1 1 9 4 Проверьте! 2
norm(A)
ans = 13.735
>> norm(A,1)
ans = 18
>> norm(A,Inf)
ans = 15

Слайд 29

Число обусловленности матрицы определяет чувствительность решения системы линейных уравнений к погрешностям исходных

Число обусловленности матрицы определяет чувствительность решения системы линейных уравнений к погрешностям исходных
данных. Следующая функция позволяет найти число обусловленности матриц:
cond(X) – возвращает число обусловленности, основанное на второй норме.

Слайд 30

>> A=hilb(4)
A =
1.00000 0.50000 0.33333 0.25000
0.50000 0.33333 0.25000 0.20000
0.33333

>> A=hilb(4) A = 1.00000 0.50000 0.33333 0.25000 0.50000 0.33333 0.25000 0.20000
0.25000 0.20000 0.16667
0.25000 0.20000 0.16667 0.14286
>> cond(A)
ans = 15513.73874

Слайд 31

Для нахождения определителя (детерминанта) и ранга матриц в MATLAB имеются следующие функции:

Для нахождения определителя (детерминанта) и ранга матриц в MATLAB имеются следующие функции:
det(X) – возвращает определитель квадратной матрицы X. Если X содержит только целые элементы, то результат – тоже целое число. Использование det(X)=0 как теста на вырожденность матрицы действительно только
для матрицы малого порядка с целыми элементами.

Слайд 32

Ранг матрицы определяется количеством сингулярных чисел, превышающих порог tol.
Для вычисления ранга используется

Ранг матрицы определяется количеством сингулярных чисел, превышающих порог tol. Для вычисления ранга
функция rank:
rank(A) – возвращает количество сингулярных чисел, которые являются
большими, чем заданный по умолчанию допуск;
rank(A,tol) – возвращает количество сингулярных чисел, которые превышают tol.

Слайд 33

>> A=hilb(11);
>> rank(A)
ans = 10
>> cond(A)
ans = 5.2237e+14

>> A=hilb(11); >> rank(A) ans = 10 >> cond(A) ans = 5.2237e+14

Слайд 34

Вычисление ортонормированного базиса матрицы обеспечивают следующие функции:
• B = orth(A) – возвращает

Вычисление ортонормированного базиса матрицы обеспечивают следующие функции: • B = orth(A) –
ортонормированный базис матрицы A. Столбцы B определяют то же пространство, что и столбцы матрицы A, но столбцы B ортогональны, то есть B'*B=eye(rank(A)). Количество столбцов матрицы B равно рангу матрицы A.
(Ортогонализация Грама-Шмитда).

Слайд 35

Собственные значения и собственные векторы квадратной матрицы

Задача на собственные значения для квадратной

Собственные значения и собственные векторы квадратной матрицы Задача на собственные значения для
матрицы имеет вид:

Или в покомпонентной записи:

Слайд 36

Совокупность всех собственных векторов, относящихся к одному и тому же собственному значению,

Совокупность всех собственных векторов, относящихся к одному и тому же собственному значению,
вместе с нулевым вектором, образует линейное подпространство.
Если вектора Х1 ,Х2 ,…,Хn являются собственными и относятся к разным собственным значениям, то векторы Х1 ,Х2, …,Хn – линейно независимы.

Слайд 37

Матрица А приводима к диагональному виду тогда и только тогда, когда существует

Матрица А приводима к диагональному виду тогда и только тогда, когда существует
базис в n-мерном пространстве, состоящий из собственных векторов

- Матричное представление уравнения на собственные значения.
Λ – диагональная матрица, состоящая из собственных значений;
Ψ – матрица собственных векторов.

Факторизация матрицы

Слайд 38

Матрица А называется неотрицательно определенной, если:

Для любого вектора Х

Матрица А называется

Матрица А называется неотрицательно определенной, если: Для любого вектора Х Матрица А
симметрической, если: Ан =А (н – символ эрмитова транспонирования, т.е. транспонирования и комплексного сопряжения. В Матлабе символ ‘).
Для симметрической и неотрицательно определенной матрицы собственные вектора – ортонормированные.

Слайд 39

[V, lambda] = eig (A) – вычисление матрицы собственных векторов (V) и

[V, lambda] = eig (A) – вычисление матрицы собственных векторов (V) и
диагональной матрицы собственных значений (lambda) от матрицы А

A2 =
1 2 3
4 5 6
7 8 9

>> [V,D]=eig(A2)
V =
-0.231971 -0.785830 0.408248
-0.525322 -0.086751 -0.816497
-0.818673 0.612328 0.408248

>> diag(D)‘ Каков ранг этой матрицы?
ans =
1.6117e+01 -1.1168e+00 -1.3037e-15

Слайд 40

>> V'*V
ans =
1.0000e+00 -2.7343e-01 5.5511e-17
-2.7343e-01 1.0000e+00 -9.9920e-16
5.5511e-17 -9.9920e-16 1.0000e+00
Матрица

>> V'*V ans = 1.0000e+00 -2.7343e-01 5.5511e-17 -2.7343e-01 1.0000e+00 -9.9920e-16 5.5511e-17 -9.9920e-16
А2 – не симметрическая и не является неотрицательно определенной, поэтому собственные вектора не ортонормированные

Слайд 41

Теплицева матрица

На всех диагоналях одинаковые значения

Теплицева матрица На всех диагоналях одинаковые значения

Слайд 42

toeplitz (c)
toeplitz (c, r)
Возвращает матрицу Теплица созданную из вектора c (в первом

toeplitz (c) toeplitz (c, r) Возвращает матрицу Теплица созданную из вектора c
случае).
Во втором случае верхняя треугольная из вектора с, а нижняя треугольная из вектора r.

Слайд 43

Создадим матрицу

>> r=0.9;
>> n=5;a=(0:n-1).^2;
>> c=r.^a;
>> K=toeplitz (c)
K =
1.00000 0.90000 0.65610

Создадим матрицу >> r=0.9; >> n=5;a=(0:n-1).^2; >> c=r.^a; >> K=toeplitz (c) K
0.38742 0.18530
0.90000 1.00000 0.90000 0.65610 0.38742
0.65610 0.90000 1.00000 0.90000 0.65610
0.38742 0.65610 0.90000 1.00000 0.90000
0.18530 0.38742 0.65610 0.90000 1.00000

Слайд 44

Найдем собственные вектора и собственные значения этой матрицы

>> [V,D]=eig(K);
V =
-1.6166e-01 3.8166e-01

Найдем собственные вектора и собственные значения этой матрицы >> [V,D]=eig(K); V =
5.7288e-01 -5.9526e-01 3.8168e-01
4.9416e-01 -5.9526e-01 -1.7637e-01 -3.8166e-01 4.7402e-01
-6.7775e-01 7.8822e-16 -5.3048e-01 1.9868e-17 5.0916e-01
4.9416e-01 5.9526e-01 -1.7637e-01 3.8166e-01 4.7402e-01
-1.6166e-01 -3.8166e-01 5.7288e-01 5.9526e-01 3.8168e-01

>> diag(D)'
ans =
0.00057261 0.01525073 0.18139281 1.14334725 3.65943661

Слайд 45

>> V'*V
ans =
1.0000e+00 1.1102e-16 6.9389e-17 -4.1633e-17 -9.0206e-17
1.1102e-16 1.0000e+00 -1.6653e-16 5.5511e-17

>> V'*V ans = 1.0000e+00 1.1102e-16 6.9389e-17 -4.1633e-17 -9.0206e-17 1.1102e-16 1.0000e+00 -1.6653e-16
5.5511e-17
6.9389e-17 -1.6653e-16 1.0000e+00 -1.1102e-16 5.5511e-17
-4.1633e-17 5.5511e-17 -1.1102e-16 1.0000e+00 -2.2204e-16
-5.5511e-17 5.5511e-17 2.7756e-17 -2.2204e-16 1.0000e+00

Так как эта теплицева матрица симметрическая и неотрицательно определенная, то собственные векторы ортогональны.

Слайд 46

Скорость выполнения

Файл test1 Файл test2
A=rand(1000,1000); A=rand(1000,1000);
B=rand(1000,1000); B=rand(1000,1000);
for i=1:1000 A=A.^B;
for j=1:1000
A(i,j)=A(i,j).^B(i,j);
end
end

Скорость выполнения Файл test1 Файл test2 A=rand(1000,1000); A=rand(1000,1000); B=rand(1000,1000); B=rand(1000,1000); for i=1:1000

Слайд 47

A=rand(1000,1000);
B=rand(1000,1000);
for i=1:1000
for j=1:1000
A(i,j)=A(i,j).^B(i,j);
end
end
---------------------------------
>> clear
>> tic,test1,toc
Elapsed time is

A=rand(1000,1000); B=rand(1000,1000); for i=1:1000 for j=1:1000 A(i,j)=A(i,j).^B(i,j); end end --------------------------------- >> clear
25.106 seconds.

A=rand(1000,1000);
B=rand(1000,1000);
A=A.^B;
---------------------------
>> clear
>> tic,test2,toc
Elapsed time is 0.224 seconds.

Выигрыш во времени выполнения 100 раз!

Слайд 48

>> clear
>> tic,test1,toc
Elapsed time is 0.340472 seconds.
>> clear
>> tic,test2,toc
Elapsed time is 0.254457

>> clear >> tic,test1,toc Elapsed time is 0.340472 seconds. >> clear >>
seconds.
В Матлабе интерпретатор оптимизирован лучше, чем в Octave.

Тест в MatLab 7.5.0

Имя файла: Линейная-алгебра.pptx
Количество просмотров: 35
Количество скачиваний: 0