2、3 向量与矩阵运算
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
矩阵操作
矩阵的旋转
fliplr(A) 左右旋转 flipud(A) 上下旋转
rot90(A) 逆时针旋转 90 度; rot90(A,k) 逆时针旋转 k×90 度 >> B=fliplr(A) >> C=flipud(A) >> D=rot90(A), E=rot90(A,-1)
例:>> A=[1 2 3;4 5 6]
若 A 可逆方阵,则 B/A <==> A 的逆右乘 B <==> B*inv(A) A\B <==> A 的逆左乘 B <==> inv(A)*B 通常,矩阵除法可以理解为 X=A\B <==> A*X=B X=B/A <==> X*A=B 当 A 和 B 行数相等时即可进行左除 当 A 和 B 列数相等时即可进行右除
数组运算:对应元素进行运算
数组运算包括:加、减、点乘、点除、点幂 相应的数组运算符为: “+” , “-” , “.* ” , “./ ” , “.\ ” ,“ .^ ” 点与算术运算符之间不能有空格! 没有“Βιβλιοθήκη Baidu+” 和 “.-”运算
例:>> A=[1 2 3; 4 5 6]; B=[3 2 1; 6 5 4];
则
a ^ d1 0 a^ D 0
0 a^ d2 0
0 a^ dn 0
若 a 是标量,A 是方阵,且 [V,D] = eig(A),则 a^A = V*(a^D)/V 若 A, P 均是矩阵,则 A^P 无定义
矩阵的超越函数
Matlab 提供了三种矩阵函数:expm、sqrtm、logm
详情参见联机帮助(help expm / sqrtm / logm )
更一般的矩阵函数: funm
funm(A,@fun)
参数 fun 的可以是 exp,,log,cos,sin,cosh,sinh
矩阵的数组运算
矩阵操作
查看矩阵的大小:size
size(A) 列出矩阵 A 的行数和列数 size(A,1) 返回矩阵 A 的行数 size(A,2) 返回矩阵 A 的列数
例:>> A=[1 2 3; 4 5 6]
>> size(A) >> size(A,1) >> size(A,2) length(x) length(A)
例:>> A=[1 2 3; 4 5 6]; B=[2 1; 3 4];
>> C=A*B
矩阵的 Kronecker 乘积
矩阵 Kronecker 乘积的定义
设A是n×m矩阵,B是p×q矩阵,则A与B的kronecker乘积为:
a11 B a B 21 C A B an1 B a12 B a 22 B an2 B a1 m B a2m B a nm B
Kronecker 乘积的性质
A B
是 np×mq 矩阵;通常 A B B A
任何两个矩阵都有 Kronecker 乘积 Matlab 中实现两个矩阵 Kronecker 相乘的函数为 kron(A,B) Kronecker乘积有时也称张量积
矩阵基本运算
矩阵的除法:/、\ 右除和左除
返回向量 X 的长度 等价于 max(size(A))
矩阵基本运算
矩阵的加减:对应分量进行运算
要求参与加减运算的矩阵具有 相同的维数
例:>> A=[1 2 3; 4 5 6]; B=[3 2 1; 6 5 4]
>> C=A+B; D=A-B;
矩阵的普通乘法
要求参与运算的矩阵满足线性代数中矩阵相乘的原则
常见矩阵生成函数
zeros(m,n) ones(m,n) eye(m,n) diag(X) tril(A) triu(A) rand(m,n) randn(m,n) 生成一个 m 行 n 列的零矩阵,m=n 时可简写为 zeros(n) 生成一个 m 行 n 列的元素全为 1 的矩阵, m=n 时可写为 ones(n) 生成一个主对角线全为 1 的 m 行 n 列矩阵, m=n 时可简写为 eye(n),即为 n 维单位矩阵 若 X 是矩阵,则 diag(X) 为 X 的主对角线向量 若 X 是向量,diag(X) 产生以 X 为主对角线的对角矩阵 提取一个矩阵的下三角部分 提取一个矩阵的上三角部分 产生 0~1 间均匀分布的随机矩阵 m=n 时简写为 rand(n) 产生均值为0,方差为1的标准正态分布随机矩阵 m=n 时简写为 randn(n)
矩阵操作
矩阵的转置与共轭转置
’ 共轭转置 .’ 转置,矩阵元素不取共轭 点与单引号之间不能有空格!
例:>> A=[1 2;2i 3i]
>> B=A’ >> C=A.’
矩阵操作
改变矩阵的形状:reshape
reshape(A,m,n): 将矩阵元素按 列方向 进行重组 重组后得到的新矩阵的元素个数 必须与原矩阵元素个数相等!
例:>> x=[0:pi/4:pi]; A=[1 2 3; 4 5 6];
>> y1=sin(x); y2=exp(A); y3=sqrt(A);
怎样计算 eA ?
数与数组的点幂
例:x=[1 2 3]; y=[4 5 6];
x.^y =[1^4,2^5,3^6]=[1,32,729]
x.^2 =[1^2,2^2,3^2]=[1,4,9] 2 .^x = ? 2 .^[x;y]= ?
向量与矩阵运算
向量与矩阵的生成(续)
矩阵的生成 直接输入: A=[1, 2, 3; 4, 5, 6; 7, 8, 9] 由向量生成 通过编写m文件生成 由函数生成 矩阵的拼接 例:>> x=[1,2,3];y=[2,3,4]; >> A=[x,y], B=[x;y]
例:>> C=magic(3)
矩阵操作
提取矩阵的部分元素: 冒号运算符
A(:) 将 A拉成列向量 A(:,:) 二维矩阵A的所有元素 A(:,k) A的第 k 列, A(k,:) A的第 k 行
A(k:m) A的第 k 到第 m 个元素 A(:,k:m) A的第 k 到第 m 列组成的子矩阵
自己动手
A(:) 与 A(:,:) 的区别 ? 如何获得由 A 的第一、三行和第一、二列组成的子矩阵?
f 作用在 x 的每个分量上
若 A 是矩阵,则 f(A) 是一个与 A 同形状的矩阵
函数取值
例:
exp( a 11 ) exp( a 21 ) exp( A ) exp( a ) m1 exp( a 12 ) exp( a 22 ) exp( a m 2 ) exp( a 1 n ) exp( a 2 n ) exp( a mn )
.^ 前面留个空格
Matlab中的所有 标点符号必须在 英文状态下输入
Matlab中常见数学函数
sin、cos、tan、cot、sec、csc、…
asin、acos、atan、acot、asec、acsc、… exp、log、log2、log10、sqrt
abs、conj、real、imag、sign fix、floor、ceil、round、mod、rem max、min、sum、mean、sort、fft norm、rank、det、inv、eig、lu、qr、svd …… ① log 是自然对数,即以 e 为底数 ② mod(x,y) 结果与 y 同号,rem(x,y) 则与 x 同号 ③ max 等函数的参数是矩阵时,是作用在矩阵各列上
数学实验
向量与矩阵运算
向量与矩阵运算
向量与矩阵的生成
向量的生成 直接输入: a=[1,2,3,4] 冒号运算符 从矩阵中抽取行或列
例:a=[1:4] ==> a=[1, 2, 3, 4]
b=[0:pi/3:pi] ==> b=[0, 1.0472, 2.0944, 3.1416] c=[6:-2:0] ==> c = [6, 4, 2, 0]
上机作业
1. 试分别生成 5 阶的单位阵、8 阶均匀分布的随机矩阵及其 下三角矩阵 2. 生产列向量 x=[1, 3, 5, 7, 9, … , 29] 3. 生成以 x 的元素为对角线的矩阵 A,并输出 A 的行数 4. 生成一个与 A 同阶的正态分布的随机矩阵 B 5. 输出 A 与 B 的 kronecker 乘积矩阵 C 6. 生成由 A 与 B 点乘得到的矩阵 D 7. 生成一个由 D 的第 8、4、10、13 行和第 7、1、6、9、2 列组成的子矩阵 E 8. 求出矩阵 E 的最大元素 9. 教材第53页,1(1),(3),(4)、2、3、4、5
>> C=A.*B; D=A./B; E=A.\B; F=A.^B; 参与运算的对象必须具有相同的形状!
函数取值
函数作用在矩阵上的取值
设 x 是变量, f 是一个函数
当 x = a 是标量时,f(x) = f(a)也是一个标量
当 x = [a, b, … , c] 是向量时,f(x)= [f(a), f(b), … , f(c)]
矩阵的乘方
A 是方阵,p 是正整数 A^p 表示 A 的 p 次幂,即 p 个 A 相乘。
若 A 是方阵,p 不是正整数 A^p 的计算涉及到 A 的特征值分解,即若 A = V*D*V-1 则 A^p=V*(D.^p)/V
矩阵的乘方
若 a 是标量,
d1 0 D 0 0 d2 0 0 0 dn