[其他产品] MicroChip中关于启动斜坡加速参数的计算

[复制链接]
 楼主| v26g7l 发表于 2022-11-26 18:28 | 显示全部楼层 |阅读模式
无传感器控制
一般情况下,无传感器控制采用状态观测器的方式,常见的无感FOC状态观测器有滑模观测器、龙伯格观测器、卡尔曼观测器,在众多的观测器中,滑模观测器应用是比较广泛的,MicroChip提供的无感FOC方案就是采用的滑模观测器。在无感FOC控制中,启动是一个关键问题,本文着重分析MicroChip的Sensorless中关于启动模块的实现.
无传感器启动过程
在MicroChip无传感器控制中,启动过程分为三个阶段,锁定–>斜坡加速–>速度闭环,首先来看一下MicroChip的代码:
  1. if(uGF.bit.OpenLoop)       
  2.         {
  3.                 if (Startup_Lock < MotorParm.LockTime)
  4.                         Startup_Lock += 1;        // This variable is incremented until
  5.                                                                 // lock time expires, them the open loop
  6.                                                                 // ramp begins
  7.                 else if (Startup_Ramp < MotorParm.EndSpeed)
  8.                         // Ramp starts, and increases linearly until EndSpeed is reached.
  9.                         // After ramp, estimated theta is used to commutate motor.
  10.                         Startup_Ramp += DELTA_STARTUP_RAMP;
  11.                 else
  12.                 {
  13.                         // This section enables closed loop, right after open loop ramp.
  14.             uGF.bit.ChangeMode = 1;
  15.             uGF.bit.OpenLoop = 0;
  16.                         Theta_error = ParkParm.qAngle - smc1.Theta;
  17.                 }
  18.                 ParkParm.qAngle += (int)(Startup_Ramp >> 16);
  19.         }
  20.         else
  21.         {
  22.                 ParkParm.qAngle = smc1.Theta + Theta_error;
  23.                 if( (_Q15abs(Theta_error) > _0_05DEG)&&(trans_counter == 0))
  24.                 {
  25.                         if (Theta_error < 0)
  26.                                 Theta_error += _0_05DEG;
  27.                         else
  28.                                 Theta_error -= _0_05DEG;
  29.                 }
  30.         }
主要参数分析
我们主要来分析一下程序中MotorParm.EndSpeed变量和宏定义DELTA_STARTUP_RAMP是怎样计算的。首先,找到有关代码如下:

  1. #define DELTA_STARTUP_RAMP        (unsigned int)(MINSPEEDINRPM*POLEPAIRS*LOOPTIMEINSEC*LOOPTIMEINSEC*65536*65536/(60*OPENLOOPTIMEINSEC))

  2. MotorParm.EndSpeed = ENDSPEEDOPENLOOP * POLEPAIRS * LOOPTIMEINSEC * 65536 * 65536 / 60.0;
其中,MINSPEEDINRPM和ENDSPEEDOPENLOOP均是指切入速度闭环的最小机械转速(单位:RPM),默认为500r/min,LOOPTIMEINSEC是开关周期(开关频率的倒数),POLEPAIRS是电机极对数,OPENLOOPTIMEINSEC是斜坡加速的时间(单位:秒)。
现在已知的是,我们要到的最终转速是N=500RPM,需要在斜坡加速时间Tramp达到这个速度,要计算每个PWM角度的增加量的增加量。假设电机极对数为P,开关频率为Fpwm,于是我们可以这样计算:
  1.      DELTA_STARTUP_RAMP=(N*P/60)*65536/Fpwm/(Fpwm*Tramp)
(NP/60)是每秒电气速度,除以Fpwm表示最终每个pwm的电气速度,要在(FpwmTramp)个PWM时增加到这个电气速度,就可以得到DELTA_STARTUP_RAMP,DELTA_STARTUP_RAMP类似于加速度的概念,可以解释为每个PWM角度增加量的增加量

您需要登录后才可以回帖 登录 | 注册

本版积分规则

28

主题

229

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部