標(biāo)題: STM32F103C8T6單片機(jī)PID控制程序 [打印本頁(yè)]

作者: lmalma    時(shí)間: 2023-3-12 21:43
標(biāo)題: STM32F103C8T6單片機(jī)PID控制程序
適合于  STM32 單片機(jī)   型號(hào)   F103C8T6    PID控制程序

單片機(jī)源程序如下:
  1. #include "delay.h"
  2. #include "sys.h"
  3. #include "usart.h"
  4. #include "PWM.h"
  5. #include "stm32f10x_tim.h"
  6. #include "key.h"
  7. #include "pid.h"

  8. //捕獲TIM4通道二PB7的頻率和占空比
  9. //PA8輸出PWM驅(qū)動(dòng)脈沖
  10. //按鍵一設(shè)置初始轉(zhuǎn)速為3000;按鍵二 增加1000轉(zhuǎn)速 按鍵3 降低1000轉(zhuǎn)速
  11. extern void TIM3_PWM_Init(u16 arr,u16 psc);
  12. extern void TIM4_PWMINPUT_INIT(u16 arr,u16 psc);
  13. extern u16 PWM0_TEMP;
  14. extern u16 period;
  15. extern u16 duty ;
  16. extern u8 CollectFlag ;
  17. float SetSpeed;            //定義設(shè)定值
  18. float ActualSpeed;        //定義實(shí)際值
  19. float err;                //定義偏差值
  20. float err_next;            //定義上一個(gè)偏差值
  21. float err_last;            //定義最上前的偏差值
  22. float incrementSpeed;
  23. float Kp,Ki,Kd;
  24. unsigned int rpm_set;

  25. int main(void)
  26. {
  27.          u8 b,c;       
  28.          NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);       

  29.          PID_init();
  30.         KEY_Init();
  31.         SystemInit();
  32.         delay_init();                             //延時(shí)初始化
  33.         NVIC_Configuration();          //中斷配置
  34.         uart_init(9600);                                //串口初始化
  35.         DIR_Init();
  36.         TIM4_PWMINPUT_INIT(0xffff,72-1);   //pwm輸入初始化以1M的頻率捕捉
  37.   TIM1_PWM_Init(1000-1,20);             //pwm頻率調(diào)節(jié)
  38.   //TIM_SetCompare1(TIM1,2000);            //初始轉(zhuǎn)速設(shè)定
  39.          delay_ms(300);
  40.          delay_ms(1000);
  41.          rpm_set=3000;                             //設(shè)轉(zhuǎn)速給定
  42.    TIM3_Int_Init(50000,72-1);               //pid運(yùn)算進(jìn)中斷速率設(shè)置
  43. //TIM_SetCompare1(TIM1,800);                  
  44.                 while(1)
  45.         {   
  46.                 b=KEY_Scan(0);
  47.                         delay_ms(100);
  48.                   if(1)
  49.                         { //USART_SendData(USART1,'a');
  50.                                 //USART_SendData(USART1,(u8)err);
  51. //                                printf("duty          = %d%% \r\n",duty*100/period);                                //打印占空比
  52. //                                printf("s         = %dr/min\r\n",3750000/period);//打印周期另一種叫法
  53.                        
  54.                                 if(period<1.0)
  55.                                         printf("#%f",0.0);
  56.                           else printf("n=%d\n",3750000/period);    //打印速度值
  57.                        
  58.                         }
  59.             if(b==1) rpm_set=3000;                  //設(shè)轉(zhuǎn)速
  60.                        
  61.                         if(b==2) rpm_set=rpm_set+1000;
  62.                         if(b==3) rpm_set=rpm_set-1000;
  63.                         if(rpm_set>=9000) rpm_set=9000;
  64.                         if(rpm_set<=1000) rpm_set=1000;
  65.    
  66.         }         
  67. }
復(fù)制代碼

Keil代碼下載:
STM32F103C8T6PID控制程序.7z (198.01 KB, 下載次數(shù): 67)







歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1