vtb4_3.m
来自「在MATLAB中开发震动相关仿真时需要用到的」· M 代码 · 共 28 行
M
28 行
function [v,w,zeta]=VTB4_3(m,d,k)%VTB4_3 VTB4_3(m,d,k)% [v,w,zeta]=VTB4_3(m,d,k)% function VTB4_3 finds the mode shapes and natural frequencies of% a linear second order matrix equation. % [v,w]=VTB4_3(m,k) finds the mode shapes and natural frequencies % for the undamped case.if nargin==2 k=d; [v,w]=eig(m\k); w=sqrt(w);endif nargin==3 if norm(d/m*k-k/m*d) < 1e-8*norm(k/m*d) disp('Damping is proportional, eigenvectors are real.') [v,w]=eig(m\k); w=sqrt(w); zeta=(v'*m*v)\(v'*d*v)/2/w; else disp('Damping is non-proportional, eigenvectors are complex.') a=[0*k eye(length(k));-m\k -m\d]; [v,w1]=eig(a); w=abs(w1); zeta=-real(w1)/w; endendw=diag(w);zeta=diag(zeta);
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?