求教大神

作者在 2013-01-04 23:29:34 发布以下内容
#include <stdio.h>
void main() 
{
   int i,j,k,m,B;
   double ua0,nT=0.85,r=0.367;
   double ig[4]={6.09,3.09,1.71,1.0};   /*四档传动比数组定义并初始化*/
   double i0[7]={5.0,5.17,5.43,5.83,6.17,6.33,6.50}; /*主减速器传动比数组定义并初始化*/
   double n[4],T[4],Ft[4];
   double Fw[4],CDA=2.77;
   double D[4],t=0.0;
   double If=0.218,Iw1=1.798,Iw2=3.598,Iw;
   double deta[4];
   double g=9.80,f=0.013;
   double _a[4];
   double ua11,ua12,ua21,ua22,ua31,ua32,ua41,ua42;
   double n1=600,n2=4000,ig1=6.09,ig2=3.09,ig3=1.71,ig4=1.00;
   printf("请输入汽车总质量:\n");
   scanf("%d",&m); 
   for(k=0;k<=6;k++)                       
  {
  printf("主减速器传动比i0=%f\n",i0[k]); 
  ua11=(0.377*r*n1)/(ig1*i0[k]);
  ua12=(0.377*r*n2)/(ig1*i0[k]);
  ua21=(0.377*r*n1)/(ig2*i0[k]);
  ua22=(0.377*r*n2)/(ig2*i0[k]);
  ua31=(0.377*r*n1)/(ig3*i0[k]);
  ua32=(0.377*r*n2)/(ig3*i0[k]);
  ua41=(0.377*r*n1)/(ig4*i0[k]);
  ua42=(0.377*r*n2)/(ig4*i0[k]);
  B=0;                /*B变量用于控制交点数计算结果的输出,并且保证只记录并输出两档之间的第一个交点,便于后续计算*/ 
  for(j=3;j<=80;j++) /*以车速为条件循环,每次增加1km/h.计算i0下加速度倒数的交点情况*/
   {
    ua0=j;                                     
    for(i=0;i<=3;i++) /*以各个档位传动比为循环条件计算各档位加速度倒数交点情况*/
     {
      n[i]=(ua0*ig[i]*i0[k])/(0.377*r);     
  T[i]=-19.313+295.27*(n[i]/1000)-165.44*(n[i]/1000)*(n[i]/1000)+40.874*(n[i]/1000)*(n[i]/1000)*(n[i]/1000)-3.8445*(n[i]/1000)*(n[i]/1000)*(n[i]/1000)*(n[i]/1000);           /*????*/

      Ft[i]=(T[i]*ig[i]*i0[k]*nT)/r;    
      Fw[i]=(CDA*(ua0*ua0))/21.15;          
      D[i]=(Ft[i]-Fw[i])/(m*g);              
      Iw=Iw1+Iw2;
      deta[i]=1+Iw/(m*r*r)+(If*ig[i]*ig[i]*i0[k]*i0[k]*nT)/(m*r*r);  
      _a[i]=deta[i]/(g*(D[i]-f));            
      }
  
   if((_a[1]-_a[0]<0.01)&&(ua0>ua11)&&(ua0<ua12)&&(ua0>ua21)&&(ua0<ua22)&&(B<=0))  /*判断各自档位车速范围内是否有交点,精度0.01*/
    {printf("一二档加速度倒数曲线有交点(取第一个):_a1=_a2=%f,ua0=%f\n",_a[0],ua0);
     B=1;ua12=ua0;}

    if((_a[2]-_a[1]<0.01)&&(ua0>ua21)&&(ua0<ua22)&&(ua0>ua31)&&(ua0<ua32)&&(B<=0))
    {printf("二三档加速度倒数曲线有交点(取第一个):_a2=_a3=%f,ua0=%f\n",_a[1],ua0);
	B=1;ua22=ua0;}

    if((_a[3]-_a[2]<0.01)&&(ua0>ua31)&&(ua0<ua32)&&(ua0>ua41)&&(ua0<ua42)&&(B<=0))
    {printf("三四档加速度倒数曲线有交点(取第一个):_a3=_a4=%f,ua0=%f\n",_a[2],ua0);
	B=1;ua32=ua0;}
   }
 if(B<=0)
     printf("        各个挡位之间加速度倒数曲线均无交点\n");

 ua0=ua11;                                           /*以下部分程序用于计算加速时间*/
	t=0;
   for(j=0;j<10000000;j++)                /*设定最大循环次数,与车速自加的精度有关*/
   {
     for(i=0;i<=3;i++)                    /*各参数计算*/
     {
      n[i]=(ua0*ig[i]*i0[k])/(0.377*r);  
   T[i]=-19.313+295.27*(n[i]/1000)-165.44*(n[i]/1000)*(n[i]/1000)+40.874*(n[i]/1000)*(n[i]/1000)*(n[i]/1000)-3.8445*(n[i]/1000)*(n[i]/1000)*(n[i]/1000)*(n[i]/1000);      

      Ft[i]=(T[i]*ig[i]*i0[k]*nT)/r;          
      Fw[i]=(CDA*ua0*ua0)/21.15;      
      D[i]=(Ft[i]-Fw[i])/(m*g);            /*各挡动力因数计算*/
      Iw=Iw1+Iw2;
     deta[i]=1+Iw/(m*r*r)+(If*ig[i]*ig[i]*i0[k]*i0[k]*nT)/(m*r*r); 
      _a[i]=deta[i]/(g*(D[i]-f));                            
      }

   if((ua0>=3.0)&&(ua0<=ua12)) t=t+0.0001*_a[0];    /*判断ua0所属范围并计算加速时间*/
   else if((ua0>ua12)&&(ua0<=ua22)) t=t+0.0001*_a[1];
   else if((ua0>ua22)&&(ua0<=ua32)) t=t+0.0001*_a[2];
   else if((ua0>ua32)&&(ua0<=80.0)) t=t+0.0001*_a[3];
   ua0=ua0+0.0001;
   if(ua0>80) break;
  }

   printf("   3km/h至80km/h加速时间 t=%f",t/3.6);    /*3.6是速度单位换算的值*/           
   printf("\n");
 }
}
2.绘制加速度倒数曲线、加速时间曲线
function main(m,k)
global G yitaT r f CdA If Iw1  g
n=600:10:4000;
Tq=-19.313+295.27*(n/1000)-165.44*(n/1000).^2+40.874*(n/1000).^3-3.8445*(n/1000).^4;
g=9.8;G=m*g;yitaT=0.85;r=0.367;f=0.013;
CdA=2.77;If=0.218;Iw1=1.798;global Iw2Iw2=3.598;global L
L=3.2;global a
a=1.947;global hg
hg=0.9;
global  ig
ig=[6.09 3.09 1.71 1.00];
global Ff
Ff=G*f;
global Ft1 Ft2 Ft3 Ft4 ua1 ua2 ua3 ua4
Ft1=Tq*ig(1)*k*yitaT/r;
Ft2=Tq*ig(2)*k*yitaT/r;
Ft3=Tq*ig(3)*k*yitaT/r;
Ft4=Tq*ig(4)*k*yitaT/r;
ua1=0.377*r*n/ig(1)/k;
ua2=0.377*r*n/ig(2)/k;
ua3=0.377*r*n/ig(3)/k;
ua4=0.377*r*n/ig(4)/k;
subplot(2,2,1)
force()
subplot(2,2,2)
acc(m,k)
subplot(2,2,3)
ret(m,k)
subplot(2,2,4)
time(m,k)
%*驱动力-行驶阻力平衡图
function force()
ua=0:5:120;global Ff CdA Ft1 Ft2 Ft3 Ft4 ua1 ua2 ua3 ua4
Fw=CdA*ua.^2/21.15;
Fz=Ff+Fw;
plot(ua1,Ft1,ua2,Ft2,ua3,Ft3,ua4,Ft4,ua,Fz)
title('驱动力-行驶阻力平衡图')
xlabel('ua-km/h')
ylabel('F-N')
gtext('Ft1'),gtext('Ft2'),gtext('Ft3'),gtext('Ft4'),gtext('Ff+Fw')
%一档最大爬坡度%
%Ftt=Ft1-Fz;
%imax=tan(asin(max(Ftt/G)));
%imax;
%行驶加速度曲线,加速度倒数曲线图%
function acc(m,k)
global yitaT r CdA If Iw1 Iw2  ig Ft1 Ft2 Ft3 Ft4 ua1 ua2 ua3 ua4  Ff
deta1=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(1))^2*k^2*yitaT)/(m*r^2);
deta2=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(2))^2*k^2*yitaT)/(m*r^2);
deta3=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(3))^2*k^2*yitaT)/(m*r^2);
deta4=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(4))^2*k^2*yitaT)/(m*r^2);
Fw1=CdA*ua1.^2/21.15;
Fw2=CdA*ua2.^2/21.15;
Fw3=CdA*ua3.^2/21.15;
Fw4=CdA*ua4.^2/21.15;
a1=(Ft1-Ff-Fw1)/(deta1*m);
a2=(Ft2-Ff-Fw2)/(deta2*m);
a3=(Ft3-Ff-Fw3)/(deta3*m);
a4=(Ft4-Ff-Fw4)/(deta4*m);
plot(ua1,a1,ua2,a2,ua3,a3,ua4,a4)
axis([0 99 0 2.5])
title('汽车的行驶加速度曲线')
xlabel('ua-km/h')
ylabel('a-m/s^2')
gtext('Ⅰ'),
gtext('Ⅱ'),
gtext('Ⅲ'),
gtext('Ⅳ'),
function ret(m,k)
global yitaT r CdA If Iw1 Iw2  ig Ft1 Ft2 Ft3 Ft4 ua1 ua2 ua3 ua4  Ff
deta1=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(1))^2*k^2*yitaT)/(m*r^2);
deta2=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(2))^2*k^2*yitaT)/(m*r^2);
deta3=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(3))^2*k^2*yitaT)/(m*r^2);
deta4=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(4))^2*k^2*yitaT)/(m*r^2);
Fw1=CdA*ua1.^2/21.15;
Fw2=CdA*ua2.^2/21.15;
Fw3=CdA*ua3.^2/21.15;
Fw4=CdA*ua4.^2/21.15;
a1=(Ft1-Ff-Fw1)/(deta1*m);inv_a1=1./a1;
a2=(Ft2-Ff-Fw2)/(deta2*m);inv_a2=1./a2;
a3=(Ft3-Ff-Fw3)/(deta3*m);inv_a3=1./a3;
a4=(Ft4-Ff-Fw4)/(deta4*m);inv_a4=1./a4;
plot(ua1,inv_a1,ua2,inv_a2,ua3,inv_a3,ua4,inv_a4)
axis([0 99 0 10])
title('汽车的行驶加速度倒数曲线')
xlabel('ua-km/h')
gtext('Ⅰ'),
gtext('Ⅱ'),
gtext('Ⅲ'),
gtext('Ⅳ'),
%加速时间曲线图%
function time(m,k)
global  g G yitaT r f CdA i0 If Iw1 Iw2 L a hg ig
nmin=600;nmax=4000;
u1=0.377*r*nmin./ig/k;
u2=0.377*r*nmax./ig/k;
deta=0*ig;
for i=1:4
    deta(i)=1+(Iw1+Iw2)/(m*r^2)+(If*(ig(i))^2*k^2*yitaT)/(m*r^2);
end
deta_u=0.5;
ua=3:deta_u:80;
N=length(ua);n=0;Tq=0;Ft=0;inv_a=0*ua;delta=0*ua;
Ff=G*f;
Fw=CdA*ua.^2/21.15;
for i= 1:N
    j=i;
   if ua(i)<=u2(1)
       n=ua(i)*(ig(1)*k/r)/0.377;
       Tq=-19.313+295.27*(n/1000)-165.44*(n/1000).^2+40.874*(n/1000).^3-3.8445*(n/1000).^4;
        Ft=Tq*ig(1)*k*yitaT/r;
        inv_a(i)=(deta(1)*m)/(Ft-Ff-Fw(i));
        delta(i)=deta_u*inv_a(i)/3.6;
   elseif ua(i)<=u2(2)
        n=ua(i)*(ig(2)*k/r)/0.377;
        Tq=-19.313+295.27*(n/1000)-165.44*(n/1000).^2+40.874*(n/1000).^3-3.8445*(n/1000).^4;
        Ft=Tq*ig(2)*k*yitaT/r;
        inv_a(i)=(deta(2)*m)/(Ft-Ff-Fw(i));
        delta(i)=deta_u*inv_a(i)/3.6;
        elseif ua(i)<=u2(3)
            n=ua(i)*(ig(3)*k/r)/0.377;
        Tq=-19.313+295.27*(n/1000)-165.44*(n/1000).^2+40.874*(n/1000).^3-3.8445*(n/1000).^4;
        Ft=Tq*ig(3)*k*yitaT/r;
        inv_a(i)=(deta(3)*m)/(Ft-Ff-Fw(i));
        delta(i)=deta_u*inv_a(i)/3.6;
        else 
             n=ua(i)*(ig(4)*k/r)/0.377;
        Tq=-19.313+295.27*(n/1000)-165.44*(n/1000).^2+40.874*(n/1000).^3-3.8445*(n/1000).^4;
        Ft=Tq*ig(4)*k*yitaT/r;
        inv_a(i)=(deta(4)*m)/(Ft-Ff-Fw(i));
        delta(i)=deta_u*inv_a(i)/3.6;
    end

        a=delta(1:j);
        t(i)=sum(a);
end
    T=t(N)
    plot(t,ua);grid;
    axis([0 60 0 100])
    title('汽车加速时间曲线')
    xlabel('t-s')
    ylabel('ua-km/h')


默认分类 | 阅读 378 次
文章评论,共0条
游客请输入验证码
文章分类
文章归档
最新评论