线性代数在工程中的应用实例.doc
《线性代数在工程中的应用实例.doc》由会员分享,可在线阅读,更多相关《线性代数在工程中的应用实例.doc(20页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
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矩阵。其物理意义为
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 线性代数 工程 中的 应用 实例
限制150内