⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rotunbal.m

📁 利用matalab编制的转子动力学计算软件。其中模型利用有限元建模
💻 M
字号:
function [U,Wv]=rotunbal(Rot,W,N)
%[U,Wv]=rotunbal(Rot,W,N)
%
%  Compute the response to unbalance at a range of speeds
%
% The co-ordinates for which Rot.RESP_DOF 
%        (see Rot.RNodeDir in themodel file) is selected
% The unbalance is defined in Rot.UNBALANCE
%
% Input:
%  Rot:  a model file or a Rot structure 
%  W  : optional, speed range in RPM W=Wmax, W=[W1 W2]
%  N:   number of speeds between 0-Wm or W1-W2
%
% By:
%  I.Bucher 24-10-98
 
 if isstr(Rot), Rot=rotfe(Rot); end  % template to Rot
 
  nM=size(Rot.M,1); z=sparse(nM,nM);
  
  nr=length(  Rot.RESP_DOF );
  
  % construct Speed vector
  if nargin<3, N=100; end
  if nargin<2, W=10000; end
     
    
  if length(W)>1, W1=W(1)*2*pi/60; W2=W(2)*2*pi/60;
   else, W1=0; W2=W(1)*2*pi/60; end
   Wv=linspace(W1,W2,N);
    U=zeros(N, nr);
    for q=1:N,
       w=Wv(q);
       a= ( -w^2*Rot.M+i*w*(w*Rot.G+Rot.D)+Rot.K);
       b=w^2*(Rot.Fu_cos-i*Rot.Fu_sin);
       if isfield(Rot,'Reduct')
          if Rot.Reduct.flag, c=Rot.T*(a\b); else, c=a\b;end
          else, c=a\b;
       end
       U(q,:)=c( Rot.RESP_DOF ).';
     end
    
   
 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -