找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3055|回复: 0
收起左侧

STM32增量式PID电机pwm调速代码

[复制链接]
ID:253361 发表于 2021-10-6 15:45 | 显示全部楼层 |阅读模式
可使用外部中断设置当前转速

单片机源程序如下:
  1. #include "sys.h"  
  2. #include "delay.h"
  3. #include "stdio.h"
  4. #include "usart.h"       

  5. double Enconde_left ;

  6. double m;


  7. int main(void)
  8. {       
  9.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
  10.         uart_init (115200);
  11.         delay_init();
  12.         OLED_Init ();
  13.         OLED_Clear();
  14.         Encoder_TIM2_Init();
  15.         TIM1_PWM_Init(7199,0);//pwm输出
  16.         TIMER_Init(999,7199);//定时器中断
  17.         KEY_EXTI_Init();
  18.        
  19.         My_MOTOR_Init();
  20.         OLED_ShowString(0,0,"ENC:",12);
  21.         OLED_ShowString(0,3,"SET:",12);
  22.         OLED_ShowString(0,5,"OUT:",12);
  23.         while(1)
  24.         {               
  25. //        Load(-2000);
  26. //               
  27. //                Enconde_left = Read_Speed(2);
  28. //                OLED_ShowNumber(50,5,Enconde_left,5,16);
  29.                

  30.                 OLED_Float(0,50,Enconde_left,3);
  31.                 OLED_Float(3,50,Set_val1,3);
  32.                 OLED_ShowNumber(50,5,PWM_TEST,5,12);
  33. //                Test_Send_User(Enconde_left,Set_val1,0,0,0,0, 0,0,0,0);
  34.                
  35.         }
  36. }
复制代码
  1. #include "control.h"


  2. float PID_Calc(int Set_Val,double Now_Val);


  3. CTRL PID;
  4. double PWM_TEST;
  5. int PWM_OUT = 500;
  6. int Set_val1 = -350;
  7. void PID_Val(void)
  8. {
  9.         PID.Kp = 18;
  10.         PID.Ki = 0.3;
  11.         PID.Kd = 5;
  12. }



  13. void TIM3_IRQHandler(void)   //TIM3中断
  14. {
  15.         if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET)  //检查TIM3更新中断发生与否
  16.                 {
  17.                 TIM_ClearITPendingBit(TIM3, TIM_IT_Update);  //清除TIMx更新中断标志
  18.                 Enconde_left = Read_Speed(2);
  19. //                PWM_OUT += PID_Calc(Set_val1,Enconde_left);

  20. //                Limt_Duty(&PWM_OUT);
  21. //                Load(PWM_OUT);
  22.                 PWM_TEST += PID_Calc(Set_val1,Enconde_left);

  23.                 Limt_Duty_1(&PWM_TEST);
  24.                 Load(PWM_TEST);

  25.                 }
  26. }


  27. float PID_Calc(int Set_Val,double Now_Val)
  28. {
  29.         PID_Val();       
  30.         float PID_Inc = 30; //增量
  31.        
  32.         PID.Ek = Set_Val - Now_Val;//本次误差
  33.        
  34.         PID_Inc = PID.Kp * (PID.Ek - PID.Ek1) + PID.Ki * PID.Ek + PID.Kd * (PID.Ek - 2 * PID.Ek1 + PID.Ek2 );
  35.        
  36.         PID.Ek2 = PID.Ek1 ;
  37.        
  38.         PID.Ek1 = PID.Ek ;

  39.         return PID_Inc;
  40. }

  41. void EXTI3_IRQHandler(void)
  42. {
  43.         Set_val1 -= 50;
  44.        
  45.         EXTI_ClearITPendingBit(EXTI_Line3);
  46. }

  47. void EXTI4_IRQHandler(void)
  48. {
  49.         Set_val1 += 50;
  50.        
  51.         EXTI_ClearITPendingBit(EXTI_Line4);
  52. }

  53. void EXTI9_5_IRQHandler(void)
  54. {
  55.         static u8 temp = 0;
  56.        
  57.         if(!temp)
  58.         {
  59.                 Set_val1 = 300;
  60.                 temp = 1;
  61.         }
  62.         else
  63.         {
  64.                 Set_val1 = -300;
  65.                 temp = 0;
  66.         }
  67.        
  68.         EXTI_ClearITPendingBit(EXTI_Line5);
  69. }


复制代码


所有代码51hei附件下载:
外部中断设置转速.7z (238.62 KB, 下载次数: 102)

评分

参与人数 1黑币 +30 收起 理由
admin + 30 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

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

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表