• 第三阶段学习beiqi3


    滑行回馈力矩给定修改力矩

    1. if(1 == Vehicle_cmd.cmdmode.data.slip_feedback_flag)//滑行回馈
    2. {
    3. motor_regen_power = EV_MCU_Para.field.Motor_regen_power_slip_level;//滑行固定功率在 10kw *****11.22 这里除去2 5kw
    4. motor_regen_trq_lmt = _IQmpyI32(motor_regen_power, 9550) / 3000;//IQ10 10kw恒功率下的3000转速的 力矩31
    5. motor_regen_trq_lmt = _IQ10mpy(motor_regen_trq_lmt, SysBase.invtorque);//IQ24 乘以系数后的 最大力矩限制 31
    6. motor_regen_trq_throad = _IQmpyI32(10, SysBase.invtorque);//IQ24 10N的力矩系数
    7. if (motor_regen_trq_lmt > motor_regen_trq_throad)
    8. {
    9. motor_regen_trq_deta = motor_regen_trq_lmt - motor_regen_trq_throad;//IQ24 大概 21
    10. motor_regen_trq_start = motor_regen_trq_throad;//IQ24 大概 10
    11. }
    12. else
    13. {
    14. motor_regen_trq_deta = 0;//IQ24
    15. motor_regen_trq_start = motor_regen_trq_lmt;
    16. }
    17. if (speed >= 3000)//恒功率回馈
    18. {
    19. trq = _IQmpyI32(motor_regen_power, 9550) / speed;//IQ10 //此处可以调小功率,以致调小回馈
    20. sysCfgPara.TrqCmd_NEW = 0 - _IQ10mpy(trq, SysBase.invtorque);//IQ24
    21. }
    22. else if (speed >= 1500)//XN.m--->10N.m
    23. {/* 如下可以列出数学式子 最终得到 trq* (speed-1500)/ 1500 = k_tmp
    24. 大概是速度超出1500的余量 占据1500的比例 用这个比例获得trq力矩 */
    25. trq = motor_regen_trq_deta; //21的力矩 这里除去 5 减少滑行力矩 滑行回馈电流***************************************
    26. k_tmp = _IQdiv(trq, _IQmpyI32(1500, SysBase.invspeed));
    27. k_tmp = _IQmpy(_IQmpyI32((speed - 1500), SysBase.invspeed), k_tmp);
    28. trq = motor_regen_trq_start + k_tmp;//最终力矩 10+k_tmp
    29. sysCfgPara.TrqCmd_NEW = 0 - trq;
    30. }
    31. else if (speed >= 500)//10N.m--->0N.m
    32. {
    33. trq = motor_regen_trq_start;
    34. k_tmp = _IQdiv(trq, _IQmpyI32(1000, SysBase.invspeed));
    35. k_tmp = _IQmpy(_IQmpyI32((speed - 500), SysBase.invspeed), k_tmp);
    36. sysCfgPara.TrqCmd_NEW = 0 - k_tmp;
    37. }
    38. else
    39. {
    40. sysCfgPara.TrqCmd_NEW = 0;
    41. }
    42. if(sysCfgPara.TrqCmd_NEW < -trqLoopPara.Max_TorqueGen)//力矩下限保护
    43. {
    44. sysCfgPara.TrqCmd_NEW = -trqLoopPara.Max_TorqueGen;
    45. }
    46. }
    在1500判断中的大概分解

    令 SysBase.invspeed为s

    第一个 k_tmp=trq/(1500s)

    第一个 k_tmp=( trq/(1500s))* ((speed -1500)*s)消除有k_tmp= trq*(speed-1500)/1500

    所以k_tmp=trq*(speed-1500)/1500

    T =10+   T*(1500-speed)/1500   大概意思是   T增加 多余的速度占1500的比 的T力矩 

  • 相关阅读:
    内网离线安装Nginx并配置SSL
    A-Level经济真题(6)
    CSP-J/S第一轮测试知识点全覆盖
    ​开发者上架ios系统iphone苹果xcode签名的封装应用ipa文件用于四个分类怎么选择打包方式?
    CSS书写位置和基础选择器
    移动端适配解决方案
    django建站过程(2)创建第一个应用程序页面
    【算法自由之路】算法复杂度、对数器、基本排序、异或与位运算技巧
    数据结构之直接插入排序(白话解析核心代码)
    vue中父组件给子组件传递了参数后,什么时候确保子组件中收到的参数更新了
  • 原文地址:https://blog.csdn.net/qq_36658033/article/details/134562261