《线性代数在工程中的应用实例.doc》由会员分享,可在线阅读,更多相关《线性代数在工程中的应用实例.doc(20页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、_ 19_第7章 在科技及工程中的应用实例7.1 由拉压杆组成的桁架结构图7-1 由拉压杆件组成的桁架结构由13根拉压杆件组成的桁架结构,如图7-1所示,13个平衡方程已给出,它们来自6个中间节点,每个节点有x,y两个方向的平衡方程,还有一个整体结构的y方向平衡方程。现求其各杆所受的力。解:按照题给方程组改写成矩阵形式,令列方程时假设各杆的受力均为拉力,其相应的方程组及化为矩阵后的形式为:将它看作A*F=B,编成的程序为pla701,核心语句为给A,B赋值,再求F=AB,结果为:F= -7236; 5117; 2000; -6969; 2812; 5117; -4883; -3167; 188
2、3; 6969; -6906; 4383; 4883 图7-2 三阶格型梯形滤波器的结构图其中负号表示杆受的是压力。7.2 格型梯形滤波器系统函数的推导使用计算机解题后,用矩阵模型几乎是最简便的数学方法了。这将给后续课的建模和计算带来革命性的好处。例如要求出图7-2所示的滤波器的系统函数: 先列出方程,令q=z-1,得到x1= u- k3x4; x2=x1; x3=k3x2+x4; x4=qx7; x5= x2- k2x8; x6=x5;x7=k2x6+x8; x8=qx11; x9= x6- k1x12; x10=x9; x11=k1x10+x12; x12=qx10; x13=y= C0x
3、12+ C1x11+ C2x7+ C3x3这是一组含有13个变量的13个联立方程,用过去的手工方法一个一个消元,理论上是可行的,但它运算极其繁琐,可以预期,95%以上的师生恐怕一个小时也解不出来,而且做对的概率极低。用矩阵的思路和方法来解就完全不同,它不是通过消元来减少变量,而是想办法补上所有的零元素,把方程扩充为完整的矩阵形式: 看似把模型搞复杂了,其实计算却非常容易。程序pla703先对P,Q矩阵赋值,键入,马上就得出了系统函数。编程时要注意,本例虽然是数值计算,但计算的内容中带有z变换算子q=z-1,所以P,Q矩阵仍然必须用符号属性,对P,Q赋值时第一个元素必须取含q的算式。熟练后不必列
4、出Q和P的矩阵形式,可以按其下标规律直接进行元素赋值。用以下参数:k0=1, k1=1/4, k2=1/2, k3=1/3, C0=-0.2, C1=0.8, C2=1.5, C3=1,编成了程序pla703。运行此程序就得到:用矩阵模型解信号流图的最大优点是一步到位,依靠计算机,既快速,又极易查错。7.3 计算频谱用的DFT矩阵有限长序列x(n)(0nN-1)有N个样本值。它的傅里叶变换在频率区间(02)的N个等间隔分布的点k=2k/N(0kN-1)上也有N个样本值。这两组有限长的序列之间可以用简单的关系联系起来: 其中是一个相角为的单位向量,也称为旋转因子。X(k)就称为x(n)的离散傅里
5、叶变换(DFT),也就是x(n)的频谱。用矩阵来表示,可写成:所以信号频谱的计算,可以简单地用一个矩阵乘法来完成。信号是N1维数组,矩阵W称为DFT矩阵,它是NN维的复数阵。把矩阵乘法看作一个变换,我们就可以把频谱计算看作信号从时域到频域的线性变换。这个矩阵运算可用下列几条MATLAB语句来实现,程序名为pla704。xn=input(xn=(长度为N的数组) ), N=length(xn); % 输入数据n = 0:1:N-1; k = 0:1:N-1; % 设定n和k的行向量WN = exp(-j*2*pi/N); % 设定Wn因子nk = n*k; % 产生一个含nk值的N乘N维的整数矩
6、阵WNnk = WN . nk; % 求出W矩阵Xk = xn * WNnk% 求出离散傅里叶级数系数plot(k,Xk) % 画出幅频特性前两条语句无须解释。第三条语句把n转为列向量n,再与行向量k做矩阵乘,它产生的是一个整数矩阵: 图7-3 序列x(n)及其频谱这个整数方阵恰好是算式中W矩阵的指数部分。第四条语句就产生了W矩阵,而最后一条语句就完成了DFS的全部运算。由于实际上离散傅里叶级数并不太用到。它已被下节将介绍的离散傅里叶变换取代,而且两者的计算程序是完全相同的。所以如果写成MATLAB子程序,它可以命名为DFT。在这5行DFT子程序前面,加上输入语句:xn=input(xn= )
7、; N=length(xn);在子程序后面,加上绘图语句:subplot(2,1,1),stem(xn,.); subplot(2,1,2),stem(abs(Xk),.)就得到本题的程序pla604。运行pla604,并按提示输入xn,即可在子图1上得到xn序列的波形,并在子图2上得到此信号的幅频特性。例如输入序列为xn=ones(1,64),zeros(1,192),则得到的时域波形及其频谱图如图7-3。计算每一个DFT分量X(i),需要做N次复数乘法和N-1次复数加法。而要完成整个DFT,求出X,则需要做NN次复数乘法和N(N-1)次复数加法。另外,它占的数据存储量为NN。在频谱计算中,
8、N的典型值是1024。所以参与运算的数据达百万,需要的存储量超过16M, 乘法运算的次数超过数百万。因此,在低档的微机上,当N较大时,MATLAB会拒绝执行这个程序,并警告内存不足。实际上,MATLAB内置的是加快计算并节省内存快速傅里叶变换(FFT)程序。从这里也可以看出,矩阵给我们提供了一个组织海量数据进行运算的最好方法,对上百万数据进行赋值、运算和绘图,只用了几行程序。线性代数的重要性之所以在近20年来可与微积分相妣美,这是一个重要原因。如果学线性代数而不涉及工程计算实践,那就无法真正体会线性代数的精髓所在。7.4 显示器色彩制式转换问题彩色显示器使用红(R)、绿(G)和蓝(B)光的叠成
9、效应生成颜色。 显示器屏幕的内表面由微粒象素组成, 每个微粒包括三个荧光点: 红、绿、蓝。 电子枪位于屏幕的后方, 向屏幕上每个点发射电子束。计算机从图形应用程序或扫描仪发出数字信号到电子枪, 这些信号控制电子枪设置的电压强度. 不同 RGB 的强度组合将产生不同的颜色. 电子枪由偏转电磁场帮助瞄准以确保快速精确地屏幕刷新。 图7-4 彩色显示器的工作原理颜色模型规定一些属性或原色, 将颜色分解成不同属性的数字化组合. 这就是色彩制式的转换问题。观察者在屏幕上实际看到的色彩要受色彩制式和屏幕上荧光点数量的影响。. 因此每家计算机屏幕制造商都必须在(R, G, B)数据和国际通行的CIE色彩标准
10、之间进行转换, CIE标准使用三原色, 分别称为X, Y和Z。 针对短余辉荧光点的一类典型转换是=.计算机程序把用CIE数据(X, Y, Z)表示的色彩信息流发送到屏幕,求屏幕上的电子枪将这些数据转换成(R, G, B)数据的方程。现在要根据CIE数据(X, Y, Z)计算对应的(R, G, B)数据, 就是等式Aa = b 中A和b 已知, 求a。如果A是可逆矩阵, 则由Aa = b可得a = A-1b. 解:在Matlab命令窗口输入以下命令A = 0.61,0.29,0.15;0.35,0.59,0.063;0.04,0.12,0.787; % B = inv(A), 程序执行的结果为:
11、B = 2.2586 -1.0395 -0.3473 -1.3495 2.3441 0.0696 0.0910 -0.3046 1.2777 可见将CIE数据(X, Y, Z)转换成(R, G, B)数据的方程为a =Bb 在彩色电视技术中,还有许多地方会用到线性变换.比如民用电视信号的发送并不直接采用(R, G, B)数据,而是使用向量(Y, I, Q)来描述每种颜色.其中Y称为亮度信号,I和Q为色差信号,这样的制式可以达到彩色和黑白的兼容.如果屏幕是黑白的, 则只用到了Y,这比CIE数据能提供更好的单色图象。YIQ与“标准”RGB色彩之间的对应如下=它的逆变换矩阵留给读者自行计算。7.5
12、人员流动问题某试验性生产线每年一月份进行熟练工与非熟练工的人数统计, 然后将熟练工支援其他生产部门, 其缺额由招收新的非熟练工补齐。新、老非熟练工经过培训及实践至年终考核有成为熟练工,假设第一年一月份统计的熟练工和非熟练工各占一半,求以后每年一月份统计的熟练工和非熟练工所占百分比。设第n年一月份统计的熟练工和非熟练工所占百分比分别为xn和yn, 记成向量. 因为第一年统计的熟练工和非熟练工各占一半, 所以=。为了求以后每年的熟练工和非熟练工所占百分比, 先求与的关系式。根据已知条件可得: xn+1 = (1-)xn +(xn + yn) =xn +yn,yn+1 = (1-)(xn + yn)
13、 =xn +yn,即= A= A2= = An. 将A对角化成为可得到简明易算的结果:= 。键入命令P,D = eig(A),得,于是便有:,当n不断增加时,分别趋向于0.8和0.2。7.6 二氧化碳分子结构的振动频率二氧化碳分子可看成中间一个碳原子,左右分别以弹簧(化学键)联接两个氧原子,构成一个三质量振动系统(见图7-5)。其方程为:图7-5 CO2分子振动结构设三个原子沿轴向的振动具有同样的频率,则代入上式后得到:写成矩阵形式为:振动的频率的平方就决定于这个系数矩阵的特征值,因为有三个特征值,要取其中的最大值。由此写出计算程序pla706,核心语句为: k=14.2e2, mo=16*1
14、.6605e-27, mc=12*1.6605e-27,A=k/mo,-k/mo,0;-k/mc,2*k/mc,-k/mc;0,-k/mo,k/mo,x,y=eig(A), omega=sqrt(y)lamda=2*pi*3*108./max(max(omega)其运行结果如下。答案为:omega = 1.0e+014 图7-8 两自由度机械振动模型及lamda = 4.257951e-006 m 4.3m7.7 二自由度机械振动图7-9表示了一个由两个质量、两个弹簧和两个阻尼器构成的二自由度振动系统,今要求在给定初始位置和初始速度下的运动。解:设x1和x2分别表示两个质量关于它们平衡位置的偏
15、移,则此二自由度振动系统的一般方程为: (7.10.1)可写成矩阵形式:(7.10.2)其中(7.10.4)这是一个四阶的常系数齐次微分方程组,给定其初始位置X0和初始速度Xd0:(7.10.4)引进符号xd是为了在MATLAB编程中给导数以变量名的需要。用解析法求这个方程的解非常麻烦,只有当C=0,即无阻尼时,系统可解耦为两种独立的振动模态,通常书上只给出解耦简化后的解。有了MATLAB工具,根本无需设C0,也无需解耦,就可以用很简洁的程序求出其数值解。其基本思路是把原始非常化成典型的四个一阶方程构成的状态方程组:(7.10.5)这个方程在初始条件Y=Y0下的解为。用MATLAB表示为Y=Y
16、0*expm(A*t)。其中expm表示把(A*t)看成矩阵来求其指数。已经知道标量x求指数的方法,求矩阵指数虽然要麻烦一些,但概念是相仿的。我们不必都弄清细节。MATLAB提供了expm, expm1, 等多种函数供用户调用。所以我们只要把Y,Y0和A找到就行。先把方程(2)写成两个一阶矩阵方程:(7.10.6)于是(7.10.7)对于本题的二自由度系统,所以Y和Y0都是41的单列变量;由于A中的四个元素都是22方阵,A是44方阵。对于更多自由度的系统,公式(7)都是正确的。下面给出二自由度系统的一个数值例,设m1=1; m2=9; k1 = 4; k2=2; c1和c2可由用户输入。求在初
17、始条件x0 = 1;0和 xd0 = 0;-1下,系统的输出x1,x2曲线。根据上面的模型可以写出程序pla710,运行此程序,输入c1=0.2,c2=0.5所得的结果见图7-9。从中可清楚地看到振动的两种模态。特别是x1的运动反映了两种模态的迭合。给出不同的初始条件,各模态的幅度也会变化。输入c1=0,c2=0所得的结果见图7-10,这时两种振动模态是可图7-10 二自由度振动波形c1=c2=0图7-10 振动的输出波形(c1=c2=0)解耦的。可以看出,用计算机解题时,问题和数据的复杂性对解题的过程并无根本影响。通常我们选择比较简单,且有解析解的数据作为检验程序之用。一旦确定程序正确,它就
18、可用在很复杂的情况。例如作者就曾把b本例题的核心语句用在一个五自由度的系统上,解一个十阶的线性方程组,同样得出满意的结果。7.8 FIR数字滤波器最优化设计12设给定滤波器的预期幅频特性D()在=i(i=1,2,K)的K个频点上的值,若实际滤波器的脉冲响应的长度为N=2L+1,则其幅特性与预期特性相拟合的方程为:(i=1, 2, , K)这K个方程联立。由于是L+1个谐波的线性组合,这方程组中的待定参数d(n)有L+1个。如果K=L+1,即方程数与未知数的数目相等,则这个线性方程组是适定的,恰好可以解了这些系数。如果KL+1,即方程数比未知数的数目多,形成了所谓超定方程组。那就不可能找到精确满
19、足这些方程组的系数d(n),只能找到最近似地满足这些方程的最小二乘解。如果KL+1,则形成了不定方程组,那会有无穷个解,工程上是没有意义的。所以只考虑KL+1的情况。e=D-Pd其中:e为单列K元误差向量,D为预期幅特性在样本点列上的K元单列向量,d为L+1元待定系数单列向量,而P则是由cos(ni)组成的K(L+1)的系数矩阵。前面已经得到它的最小二乘解的公式:用MATLAB计算此式特别方便,可以表示为d=inv(P*P)*P*D,也可以更简便地用左除运算d=PD来完成。例7.8 举一个数字例,要求设计长度为N=9( 有5个待定系数)的FIR滤波器,要使它在0之间的八个频点上逼近预期的低通幅
20、特性D:=0, 0.33, 0.67, 1, 1.5, 2, 2.5, 3.14; D=1,1,1,1,0,0,0,0;解:列出方程组的完整形式:看来系数矩阵P的赋值比较麻烦,其实,回想求离散傅里叶变换时的做法,可以利用列矩阵w=w1; w2; ; w8乘行矩阵0:4形成一个85矩阵,然后求余弦得到P。这可以用MATLAB语句P=cos(w*0:4)轻而易举地列出。因此用下列几行MATLAB程序ag1010就可以方便地完成最小二乘最优滤波器的设计。N=9; L=floor(N-1)/2);% 列出待求系数序数w=0,0.33,0.67,1,1.5,2,2.5,3.14; % 列出频率向量D=1
21、,1,1,1,0,0,0,0;% 列出预期幅特性向量P=cos(w*0:L);% 列出P矩阵d=inv(P*P)*P*D% 求出待求系数图7-11 设计出的最优化滤波器的频率特性程序运行的结果为d = 0.3981 0.6039 0.2137 -0.1205 -0.1506知道d(n)以后,就可以计算滤波器的频率特性进行校核。得到的幅频特性见图7-11。因为L=4,最高的谐波次数为4,在0之间幅特性摆动最多两个周期,达到峰值的次数应为四次,这从图上也看得很清楚。7.9 弹性梁的柔度矩阵设简支梁如图7-12所示,在梁的三个位置分别施加力f1,f2和f3后,在该处产生的综合变形为图示的y1,y2和
22、y3,通常称为挠度。根据虎克定律,在材料未失去弹性的范围内,力与它引起的变形呈线性关系,可以写出完全的矩阵形式为:不难从这个矩阵乘法关系中得知矩阵D的物理意义。假如只施加一个力f1,其余两个力f2和f3为零,则引起的挠度为:y1=d11*f1,y2=d21*f1,y3=d31*f1,如果加的力为一个单位,则在1,2,3三个位置引起的挠度分别为d11,d21和d31。可以用同样的方法来理解其他的d,利用这个概念,可以用实测的方法来得到矩阵D中的各个元素。这些挠度元素愈大,表明这个梁愈柔软,所以矩阵D被称作柔度矩阵。柔度矩阵的逆就是刚度矩阵K,K=D -1,在本例中它也是一个33矩阵。其物理意义为
23、造成单位挠度所需要的力。这些力愈大,表明这个梁愈刚劲。在图7-3所示的情况下,柔度矩阵的9个元素中,没有一个为零。这说明它们之间相互耦合。在位置1施加力不但会引起该处的变形,同时也必然引起位置2和3处的变形;在其他位置加力亦然。如果矩阵变为对角矩阵,那也就意味着互相独立。位置1加的力只引起位置1处的挠度,常识告诉我们,在图7-3所示的简支梁上是不可能出现这种情况的。现在举一个数字的例子,设柔度矩阵,单位为【公分/牛顿】。(1)设在位置1,2,3处施加的力为30,50和20【牛顿】,试求出其挠度。(2)设要在位置3处产生0.4【公分】的挠度,其他两处挠度为零,试求应施加的力。解:列出解此题的Ma
24、tlab程序pla712D=0.001*5,2,1;2,4,3;1,3,6 % 输入柔度矩阵f=30;50;20, y=D*f% 解题(1),给定力求挠度y1=0;0;0.4 % 解题(2)给定挠度K=inv(D), f1=K*y1% 求刚度矩阵,求力程序运行的结果如下:题(1)的三个挠度为刚度矩阵为题(2)的三个力为最后的力中有负数是合理的,因为题目要求有两个位置上的挠度为零,如果三个力都同向,造成的变形也同向,那就没有一处的挠度会等于零,必须有反向加的力才行。可以看到,在刚度矩阵中也出现了负值元素,这是什么原因呢?可从其物理意义去想。对照柔度矩阵的物理意义,刚度矩阵中的第一列元素应该是:使
25、挠度y1达到一个单位,而y2和y3都等于零时,在三个位置上应施加的力。即同时在位置1施加k11的力,在位置2施加k21的力,而在位置3施加k31的力。正如上面的分析,要使两个位置上的挠度为零,这三个力必须有正有负。所以表现为刚度矩阵中每列元素中必定有负值元素。只在一个位置加力(意味着其他两个力为零),在三个位置引起挠度是非常直观,符合常识的,所以读者容易接受柔度矩阵的物理概念;只在一个位置加“挠度”(意味着其他两个挠度为零),在三个位置需要加多大力却需要想像,在常识中大概很少有人经历这种状况,所以刚度矩阵的物理概念就要难理解一些。7.10 用二次样条函数插值5个点x811151822y5910
26、87设给出以下五点坐标数据:(a) 求通过这些点的二次样条函数;(b) 求在x=12.7处的y的插值值;(c) 画出插值多项式和这些数据点解:由于有5个点(n=5),需要4个样条函数(i=1,.,4)。样条函数的方程为:四个多项式,每个多项式有三个系数,待求的总共为12个系数。按二次样条函数的规定,设,其余11个系数由11个线性方程组成的方程组决定。其中8个方程由各区段的多项式通过数据点决定,即3个方程由相邻多项式在共同节点处的斜率相等的条件决定。即 把11个联立方程写成矩阵形式,有:可以用MATLAB解出这11个系数如右,由此写出这几段多项式方程为:图7-13 二次样条函数插值结果(b) 在
27、x=12.7处的y值为:(c) 曲线也要分段画, 画出的曲线如右图,可以看出其第一段是一根直线,对应于。7.11 飞行器三维空间运动的矩阵描述图7-14 飞行器姿态角演示这里主要举例说明线性代数在刚体空间运动学中的应用。机械手、飞行器和机器人都是在空间运动的刚体或多刚体组。对它的运动的描述非常复杂,因为一个刚体要由三个转动和三个平移,即用6个自由度才能定量地决定它的位置。飞行器在空中可以围绕三个轴旋转。假如它在向北飞行时,机头正对北方,则它围绕铅垂轴的旋转角称为偏航角(Yaw),它描述了飞机左右的偏转,用u表示;围绕翼展轴的旋转角称为倾斜角(Pitch),它描述了飞机俯仰姿态,用v表示;围绕机
28、身轴的旋转角称为滚动角(Roll),用w表示;u,v和w三个变量统称为欧拉角,它们完全描述了飞机的姿态。MATLAB中有一个演示程序quatdemo.m,专门演示这几个姿态角所造成的飞机状态。键入:quatdemo屏幕上将出现如图6-7所示的画面。左方为飞行器在三维空间中的模型,其中红色的是飞行器;右上方为三个姿态角u,v,w的设定标尺和显示窗,右下方为在地面坐标系中的另外三个姿态角: 方位角、俯仰角和倾侧角。左下方还有【静态】和【动态】两个复选钮,我们只介绍【静态】,读者可自行试用【动态】进行演示。用键入参数或移动标尺的方法分别给u,v,w赋值并回车后,就可以得出相应的飞行器姿态,同时出现一
29、根蓝色的线表示合成旋转的转轴。图7-15 用G画出的飞行器本例用数值来讨论这个程序的实现方法。先把飞行器的三维图像用N个顶点的三维坐标描述,写成一个3N的数据矩阵G。其顶点次序要适当安排,使得用plot3命令时按顶点连线能绘制出飞行器的外观。例如,以下的程序(pla607前半部分)即可画出一个最简单的飞行器立体图,如图6-8所示。Gw=-4,-3,0;4,-3,0;0,7,0;-4,-3,0; % 主翼的顶点坐标Gt=0,-3,0;0,-3,3;0,2,0;0,-3,0; 尾翼的顶点坐标G=Gw,Gt % 整个飞行器外形的数据集plot3(Gw(1,:),Gw(2,:),Gw(3,:),r),
30、hold onplot3(Gt(1,:),Gt(2,:),Gt(3,:),g),axis equal运行此程序得出整个飞行器外形的数据集为 (7.14.1)飞行器围绕各个轴旋转的结果,表现为各个顶点坐标发生变化,也就是G的变化。只要把三种姿态的变换矩阵Y, P和R乘以图形数据矩阵G即可。其中 ,(7.14.2)如果三个姿态角都变化,转动的次序为: 先滚动R,再倾斜P,最后偏航Y,则最后的图像数据成为Gf = Y G2 = Y P G1 = YP RG = QG。最后变换矩阵成为 (7.14.3)由于矩阵乘法不服从交换律,转动次序不同时结果也不同。这个过程可以用手工计算,也可以用MATLAB程序
31、来实现。程序pla714半部分如下:syms u w vY=cos(u),sin(u),0;sin(u), cos(u),0;0,0,1)R=1,0,0;0,cos(w),sin(w);0,sin(w),cos(w)P=cos(v),0,sin(v);0,1,0;sin(v),0,cos(v)Q=Y*P*R这里采用了符号运算工具箱以得到普遍的公式。当设定了u,v,w的具体数值后,例如,u = p/4, v = 0, w = p/3,要求出Q矩阵的数字结果时,要用subs(代换)命令:A=subs(Q,u,v,w,pi/4,0,pi/3)运行结果为我们知道,二维变换矩阵的行列式代表的是两个向量组
32、成的平行四边形的面积,三维变换矩阵的行列式代表的是三个向量组成的平行六面体的体积。不难算出,det(Y) = 1,det(R) = 1,det(P) = 1,det(Q) = 1。当然也有det(A) = 1。说明这几个变换都不会改变图形对象的体积。这是描述刚体运动的一个必须遵守的原则。不仅不允许改变体积,而且不允许改变形状,后者要求其变换的特征值必须等于1。飞行器在空中的运动应该由六个自由度表征,其中三个是转动,三个是平移,要完整地描述这些运动,三维空间和33的变换矩阵是肯定不够的。所以就需要研究三维以上的线性空间和线性变换问题。就本题来看,研究的对象不是整个飞行器,而是飞行器外形上的N个顶
33、点。这些顶点可用三维空间中的三个坐标来描述,也就是3N数据集G3。考虑了平移运动后,如同二维情况那样,也必须要用齐次坐标系,即把三维空间扩展一维,在四维空间来建立数据组和44变换矩阵。即数据集G4成为4N矩阵,其最下面一行元素的取值都为1。 (7.14.4)而平移变换矩阵M和旋转变换矩阵Y, R, P成为 (7.14.5) (7.14.6)其中c1,c2,c3为在三个轴x1,x2,x3方向上的平移距离。这种方法也适用于机器人运动学的研究。7.12 金融公司支付基金的流动金融机构为保证现金充分支付, 设立一笔总额5400万的基金, 分开放置在位于A城和B城的两家公司, 基金在平时可以使用, 但每
34、周末结算时必须确保总额仍然为5400万. 经过相当长的一段时期的现金流动, 发现每过一周, A城公司有10%支付基金流动到B城公司, B城公司则有12%支付基金流动到A城公司. 起初A城公司基金为2600万, B城公司基金为2800万. 按此规律, 两公司支付基金数额变化趋势如何? 如果金融专家认为每个公司的支付基金不能少于2200万, 那么是否需要在必要时调动基金? 设第k+1周末结算时, A城公司B城公司的支付基金数分别为ak+1, bk+1 (单位:万元), 则有=2600, =2800, . 原问题转化为:(1) 把ak+1, bk+1表示成k的函数, 并确定ak和bk . (2) 看
35、ak和bk 是否小于2200. 解:令由此可得:为了计算Ak+1,固然可以用矩阵乘法硬算,但不是高明的办法。较好的方法是将A对角化。输入MATLAB命令:P,D = eig(0.9,0.12;0.1,0.88),得到因此= 键入以下语句即可完成这一计算:Xkp1=P*D(1,1)k,0;0,D(2,2)k*inv(P)*X0得到: =,可见ak单调递增, bk 单调递减, 且ak =,bk =. 两者都大于2200, 所以不需要调动基金。 7.13 质谱图实验结果分析峰点物质的CijCH4C2H4C2H6C3H6C3H810.20.20.30.20.22281000.1318122.41641
36、0015102618某一样本的质谱图给出了一系列的尖峰,它们表示了样本中所含的各种离子成分的质量。各尖峰的高度Ij取决于不同成分的质量。其中,Cij是物质i的离子对尖峰j所作贡献,nj是物质j的离子总数,每个尖峰的系数Cij如右表。设某样本产生的质谱图的尖峰为:I1=3.4, I2=20.5, I3=170, I4=49, I5=39.8, I6=96.3, 试求出样本中各种物质的含量。解:设五种物质的含量分别为x1,x2,x3,x4,x5,则可列出下列方程组:0.2*x1+0.2*x2+0.3*x3+0.2*x4+0.2*x5=3.428*x1+x2+0.1*x5=20.518*x2+12*
37、x3+2.4*x4+16*x5=17010*x3+x5=4910*x4+2*x5=39.818*x5=96.3这里有六个方程和五个未知数,是一个超定问题,可用左除求解。写成矩阵形式为:解题的程序pla702如下:A=0.2,0.2,0.3,0.2,0.2;28,1,0,0,0.1;0,18,12,2.4,16;0,0,10,0,1;0,0,0,10,2;0,0,0,0,18B=3.4;20.5;170;49;39.8;96.3, X=AB解得X的五个分量为:。7.14 用特征方程解Fibonacci数列问题Fibonacci数列于公元1200年左右被发现,在现代物理、准晶体结构、化学等领域都有
38、直接的应用,它把0和1作为初始项F0和F1,以后的每一项为其前两项的和,于是得到数列1,1,2,3,5,8,13,21,。数列递推的输入是两项,输出是一项,所以需要用两维矩阵建模。为了求出k无限增大时的Fk,相当于研究稳态的趋势,就需要应用特征值和特征向量。这是一个研究矩阵和特征值应用的极好例子。解的过程如下。一、建立矩阵模型:先把Fibonacci规则写成联立方程,设变量为两维向量,可写成矩阵方程:其中,初始条件。如果要求出第k项的Fibonacci数,就可以用矩阵连乘的方法,而写成矩阵连乘运算也很麻烦,注意A是对称实矩阵,把它对角化,可以大大简化计算。令,则上式可写成,因为对角矩阵乘方就等
39、于主对角线各元素自行乘方:,以此类推,所以其计算就方便得多。二、将系数矩阵对角化 建立特征方程并求根。为了将A对角化,首先求A的特征方程和特征值:令用二项式定理,得到两个特征根为 求特征向量,将代入特征矩阵的系数,进行消元,得出行最简型(注意)这是秩r=1,n=2的欠定方程,它的一个基础解即特征向量为。同理得对应于的特征向量为因而,其逆,P没有规范化并不要紧,因为P-1中的系数可以补偿。于是得出矩阵形式公式: (a)也可把矩阵展开,取其第二行,得出标量公式(b)三、程序编写及验证用下列程序pla614可以很快求出任意k阶的Fibonacci数。A=1,1;1,0, p,lamda=eig(A)
40、for k=1,3,5,10,20,50,100F=p*lamdak*inv(p)*1;0;% 用矩阵公式(a)计算% 下一语句是用标量公式(b)计算F1=(lamda(1,1)k-lamda(2,2)k)/(lamda(1,1)-lamda(2,2); k,F(2,:),F1 % 显示计算结果 end算出的结果见下表,F(1,:)和F1当然是一样的。k35102050100F25556765125862690253.542248481792631e+020k=73以上时,的有效位数已超过了MATLAB的精度(15位),靠MATLAB已经无法算得精确到整数位的Fibonacci数了。有趣的是:
41、这样一个完全是的数列,通项公式却是用来表达的。 而且当k趋向于无穷大时,后一项与前一项的比值越来越逼近1.618(其倒数是0.618).。因为2小于1,当k无限增大时,公式(b)中的后一项趋于零,Fk的变化趋势仅取决于1。Fk+1/Fk的值随k=3到9变化如下:1.5,1.667,1.6,1.625,1.6154,1.6190,1.6176,愈来愈趋近1.618。7.15 简单线性规划问题线性规划是一门研究如何使用最少的人力、物力和财力去最优地完成科学研究、工业设计、经济管理中实际问题的专门学科.主要在以下两类问题中得到 应用:一是在人力、物力、财务等资源一定的条件下,如何使用它们来完成最多的
42、任务;二是给一项任务,如何合理安排和规划,能以最少的人力、物力、资金等资源来完成该项任务。它比线性代数多了两个概念:第一、在欠定方程组的基础上,又引进了不等式(包括解必须大于零),从而建立了解的可行域的概念;第二、在可行区内求极大值的概念。最简单的线性规划问题在中学数学中就介绍了。 某工厂用A、B两种配件生产甲、乙两种产品,每生产一件甲产品使用4个A配件并耗100工时,每生产一件乙产品使用4个B配件并耗时200工时,该厂每天最多可从配件厂获得16个A配件和12个B配件,按每天工作800工时计算,该厂所有可能的日生产安排是什么?若生产一件甲产品获利2万元,生产一件乙产品获利3万元,采用哪种生产安
43、排获得的图6-11 例6.15的可行域绘制和目标函数的最大化利润最大?解:设甲、乙两种产品的日生产分别为x,y件时,工厂获得的利润为z万元,则要求最大化目标函数 而x,y应满足约束条件为,在线性规划的问题中,约束条件通常由一组欠定线性方程组和一些不等式构成。在本例中,第一个方程如果取等式,它就是r=1,n=2的二元欠定方程(组),其解集就是一根斜线。由于是不等式,其解集(即可行域)是该斜线左下方的半平面。其他三个不等式的约束条件比较简单,作出约束条件所表示的可行域,如图6-11所示。设目标函数为任意常数c,其等值线是一系列斜率为-2/3的平行线。当此直线平移经过可行域时,在点M(4,2)处达到
44、的最大值.。即每天安排生产4件甲产品,2件乙产品时,工厂获利最大为14万元。规模较大的线性规划问题就需要用到线性代数的理论。它的一般数学模型如下max(min) z表示使目标函数极大(极小)化,s.t.(subject to受约束于)。可以看出,约束条件的主体部分就是一个线性方程组,去掉其中的不等式,余下的线性方程组必定是欠定的,这样它才会有无穷多个解并组成一个子空间。加上其中的不等式以后,可行域就会向半平面扩大,所以在学线性代数时需要弄清欠定线性方程组的解的特性。约束条件中最后的,则是对自变量取值的限制,通常是默认的。MATLAB中有解线性规划问题的专用子程序LINPROG(f,A,B),它用来解决如下的问题: 最小化 z=f*x 约束条件: Ax = b (x的所有分量为正的条件是默认的,不必列入)对于例6.14,如果要套用这个函数,就要做一些修改。首先是把求极大改为求极小,那只要把z的系数f号的正负号反转即可。约束条件应写成一个完全的矩阵,要把大于改成小于,也可用改变系数符号的方法:于是相应的MATLAB程序pla613n核心语句可写成:f=-2,-3, A=100,200;4,0;0,4, B=800;16;12,X=linprog(f,A,B), zmax= -f*X程序运行的结果为: