矩阵运算与Matlab命令
1.1 知识要点与背景:日常矩阵及其运算
【????? A=[4 2 3;1 3 2;1 3 3;3 2 2],???????? % 表1-1、表1-2的数据分别写成矩阵形式
? B=[35 20 60 45;10 15 50 40;20 12 45 20]???????? 】
【?????? C=A*B????????? %矩阵乘法,求各订单所对应的原材料和劳动力 。???? 】??
【?? whos?????????? % 查看Matlab工作空间中变量及其规模? 】????
1.2实验与观察:矩阵和Matlab语言
1.2.1 向量的生成和运算
? 【????? x=linspace(0,4*pi,100);?? %将[0,4π]区间100等分,产生了一个100维向量
?? y=sin(x);?????????????? %计算函数值,产生了一个与x同维的100维函数向量y
?? y1=sin(x).^2;???????? %计算函数向量,注意元素群运算
??? y2=exp(-x).*sin(x);???????????????
?? %以x为横坐标,y为纵坐标画函数的图用不同的线型将函数曲线绘制在一个图上
??? plot(x,y,'-',x,y1,'-',x,y2,'.-')??????????? 】
1. 向量的创建
???????????? ◆直接输入向量。
【x1=[1 2 4],x2=[1,2,1],x3=x1' 】
????? ◆冒号创建向量 。
【???? x1=3.4:6.7
?x2=3.4:2:6.7
?x3=2.6:-0.8:0?? 】
?????? ◆生成线性等分向量。
【???? x=linspace(0,1,5)?? 】
2. 向量的运算
?【?? y=sin(x)??? 】
???????? 【? y1=sin(x).^2;?? y2=exp(-x).*sin(x);?? 】????
1.2.2.矩阵创建和运算
1.创建矩阵
(1)数值矩阵的创建
??????? ◆直接输入法创建简单矩阵。
【?? A=[1 2 3 4; 5 6 7 8; 9 10 11 12] 】
【?? B=[-1.3,sqrt(3);(1+2)*4/5,sin(5);exp(2),6] 】
(2)符号矩阵的创建
?????? ◆
【?? syms a11 a12 a13 a14 a21 a22 a23 a24 a31 a32 a33 a34 …
??????? b11 b12 b13 b14 b21 b22 b23 b24 b31 b32 b33 b34
A1=[a11 a12 a13 a14 ;a21 a22 a23 a24; a31 a32 a33 a34],
B1=[b11 b12 b13 b14 ;b21 b22 b23 b24; b31 b32 b33 b34]????????? 】?
2.矩阵的运算
????????
【?? C=A1+B1,D=A1-B1? 】
???????
【???? syms c
? cA=c*A1? 】
???????
【?? C=A1*B1?? 】
{??? ??? Error using ==> sym/mtimes,? Inner matrix dimensions must agree.??? }
???????
【???? A2=A1(:,1:3), B1? 】
【? G=A2*B1??????? 】
【?? g11=A2(1,:)*B1(:,1)? 】
??????? 【??? A,?? A_trans=A'?? 】
???????
【?? H=[1 2 3 ; 2 1 0 ; 1 2 3 ], K=[1 2 3 ; 2 1 0 ; 2 3 1]
h_det=det(H), k_det=det(K),H_inv=inv(H),K_inv=K^-1?????????????? 】
????
【????? A=[3 0 1; 1 1 0;0 1 4];
?? B=inv(A-2*eye(3))*A, B=(A-2*eye(3))\A??? 】
3.分块矩阵:矩阵的裁剪、分割、修改与抽取
(1)
【??? A=[1 0 1 1 2;0 1 -1 2 3;3 0 5 1 0;2 3 1 2 1], vr=[1,3];vc=[1,3];
A1=A(vr,vc)?????? %取出A的1、3行和1、3列的交叉处元素构成新矩阵A1 】
???? ◆将上面的矩阵A分为四块,并把它们赋值到矩阵B中,观察运行后的结果。
【?? A11=A(1:2,1:2),A12=A(1:2,3:5),A21=A(3:4,1:2),A22=A(3:4,3:5)
B=[A11 A12;A21 A22]?????????? 】
(2)矩阵的修改和提取
??????? ◆? 【?? A=[1 0 1 1 2;0 1 -1 2 3;3 0 5 1 0;2 3 1 2 1]
? A(1,:)=[0 0 0 0 0];?????? A????????????????? 】
?????? ◆ 观察:
【??? B(:,[2,4])=[ ]???? %删除矩阵B的第2、4列?? 】
(3)矩阵元素的抽取
4.生成特殊矩阵
?????? 。
??????? ◆
【?? y1=rand(1,5), y2=rand(1,5),
rand('seed',3), x1=rand(1,5),? rand('seed',3), x2=rand(1,5)? 】
5. 常用矩阵函数
6. 数据的简单分析
??????? ◆
【????? rand('seed',1);A=rand(3,6),
?Asort=sort(A), Amax=max(A), Asum=sum(A)? 】
1.2.3? Matlab工作环境和编程
2.Matlab的基本设计
1.3应用、思考与练习
1.3.1? 关系矩阵
1.3.2 投入产出
1.3.3 循环比赛的名次
? 【??? A=[0 1 1 0; 0 0 1 1; 0 0 0 1; 1 0 0 0],
???? e=ones(4,1); c=A*e;??
????? s=c'????????????????????????????? 】
★ 画矩阵结构图的gplot指令。
?????? ◆(3)????????
【????? clf, A=[0 1 1 0;0 0 1 1;0 0 0 1;1 0 0 0];? xy=[0 1;0 0;-1 –0.5;1 –0.5];
?? graphy_plot(A,xy,1,0.5),? % gplot(A,xy)?? 】
1.3.4? 参考程序
graphy_plot.m
?【? function y=graphy_plot(A,xy,l,p)
?????? %画矩阵的有向结构图。 A为邻接矩阵,xy为顶点坐标,l控制参数,l=0,画无向图;????
?????? %l~=0,画有向图。p为控制箭头大小的参数。
a=-max(abs(xy(:,1)))*1.1;b=max(abs(xy(:,1)))*1.1;
c=-max(abs(xy(:,2)))*1.1;d=max(abs(xy(:,2)))*1.1;
if l=0
?? gplot(A,xy),axis([a b c d]),hold on,
elseif l~=0
?? U=[];V=[];X=[];Y=[];
?? n=length(A(:,1)) ;
?? for i=1:n
????? k=find(A(i,:)~=0);
????? m=length(k);
????? if(m~=0)
???????? for j=1:m
??????????? u(1)=(xy(k(j),1)-xy(i,1)); v(1)=(xy(k(j),2)-xy(i,2));
??????????? u(2)=eps;???? v(2)=eps;???? U=[u;U];V=[v;V];
??????????? X=[[xy(i,1) xy(k(j),1)];X]; Y=[[xy(i,2) xy(k(j),2)];Y];
????????? end
????? text(xy(i,1),xy(i,2),['\bullet\leftarrow\fontsize{16}\it{V}',…
????? um2str(i)]);??? hold on,
?????? end
????????? end
?? gplot(A,xy),axis([a b c d]),hold on,
?? h=quiver(X,Y,U,V,p);set(h,'color','red');hold on,
?? plot(xy(:,1),xy(:,2),'k.','markersize',12),hold on,
end? , hold off?????????????? 】
评论