找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

帖子
查看: 19564|回復: 22
打印 上一主題 下一主題
收起左側

STM32控制無刷直流電機BLDC速度環(huán)PID源碼

  [復制鏈接]
跳轉到指定樓層
樓主
ID:287661 發(fā)表于 2018-3-13 08:55 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
用的是timer1高級定時器控制無刷直流電機
此程序只有轉速PID 速度通過程序Set_Point調節(jié) 調節(jié)范圍在100到12000之間
KEY2控制無刷電機啟動
KEY3控制無刷電機停止

電路原理圖如下:


單片機源程序如下:
pid.c
  1. /*====================================================================================================
  2.                                                 增量式PID
  3. The PID (比例、積分、微分) function is used in mainly
  4. control applications. PIDCalc performs one iteration of the PID
  5. algorithm.
  6. While the PID function works, main is just a dummy program showing
  7. a typical usage.
  8. =====================================================================================================*/
  9. #define Set_Point        1000         //100 10000
  10. #define PWM_Max                1400
  11. #define PWM_Min     50  
  12. typedef struct PID
  13. {
  14.         int Target;     //設定目標 Desired Value
  15.         int Uk;                        //Uk
  16.         int Udk;                //Udk增量
  17.         int Uk_1;                 //Uk-1
  18.         double P;                 //比例常數(shù) Proportional Const
  19.         double I;                 //積分常數(shù) Integral Const
  20.         int    b;
  21.         double D;                 //微分常數(shù) Derivative Const
  22.         int ek_0;                //ek
  23.         int ek_1;                 //ek-1
  24.         int ek_2;                 //ek-2
  25. }PID;
  26. static PID Speed_PID;
  27. static PID *Speed_Point = &Speed_PID;
  28. /*====================================================================================================
  29. Initialize PID Structure PID參數(shù)初始化
  30. =====================================================================================================*/
  31. void Speed_PIDInit(void)
  32. {
  33.         Speed_Point->Target = Set_Point;
  34.         Speed_Point->Uk                = 0;
  35.         Speed_Point->Udk    = 0;
  36.         Speed_Point->Uk_1   = PWM_Min;
  37.         Speed_Point->ek_0         = 0;         //ek=0
  38.         Speed_Point->ek_1         = 0;         //ek-1=0
  39.         Speed_Point->ek_2         = 0;          //ek-2=0
  40.         Speed_Point->P                 = 4;  //比例常數(shù) Proportional Const
  41.         Speed_Point->I                 = 0.084;          //積分常數(shù)Integral Const
  42.         Speed_Point->b      = 1;
  43.         Speed_Point->D                 = 1.8;          //微分常數(shù) Derivative Const
  44. }
  45. /*====================================================================================================
  46. 增量式PID計算部分
  47. =====================================================================================================*/
  48. int Speed_PIDAdjust(int Next_Point)
  49. {
  50.         Speed_Point->ek_0= Speed_Point->Target - Next_Point;         //增量計算
  51.         /*遇限削弱積分即控制量Uk進入飽和區(qū),便停止進行增大的積分項運算,而只進行使積分減少的運算*/
  52.         if(((Speed_Point->Uk_1>=PWM_Max)&&(Speed_Point->ek_0>=0))||((Speed_Point->Uk_1<=PWM_Min)&&(Speed_Point->ek_0<=0)))
  53.         {
  54.             Speed_Point->b=0;
  55.         }
  56.         else
  57.         {
  58.                 Speed_Point->b=1;
  59.         }
  60.         Speed_Point->Udk=Speed_Point->P*(Speed_Point->ek_0-Speed_Point->ek_1) + Speed_Point->b*Speed_Point->I*Speed_Point->ek_0
  61.                 + Speed_Point->D*(Speed_Point->ek_0-2*Speed_Point->ek_1+Speed_Point->ek_2);
  62.     /* 存儲誤差,用于下次計算 */
  63.         Speed_Point->Uk = Speed_Point->Uk_1 + Speed_Point->Udk;

  64.         Speed_Point->ek_2 =        Speed_Point->ek_1;
  65.         Speed_Point->ek_1 = Speed_Point->ek_0;
  66.         Speed_Point->Uk_1 = Speed_Point->Uk;
  67.     if(Speed_Point->Uk >= PWM_Max)
  68.         {
  69.                 return PWM_Max;
  70.         }
  71.         else if(Speed_Point->Uk <= PWM_Min)
  72.         {
  73.                 return PWM_Min;
  74.         }
  75.         return(Speed_Point->Uk);
  76. }
復制代碼

  1. #include "includes.h"
  2. /********************CoOS變量**********************/
  3. #define TASK_STK_SIZE         128

  4. #define TASK0_PRIO        2
  5. #define TASK1_PRIO  3

  6. OS_STK STK_TASK0[TASK_STK_SIZE];
  7. OS_STK STK_TASK1[TASK_STK_SIZE];


  8. void TASK0(void *param);
  9. void TASK1(void *param);

  10. /*************************************************/

  11. /*********************一般變量********************/
  12. extern uint32_t Speed_count;
  13. uint8_t USART_Flag = 0;

  14. /*************************************************/
  15. int main(void)
  16. {
  17.         /* 片內(nèi)外設初始化 */        
  18.         Periph_Init();
  19.         
  20.         /* 操作系統(tǒng)初始化 */
  21.     CoInitOS();

  22.         CoCreateTask( TASK0, (void*)0, TASK0_PRIO, &STK_TASK0[TASK_STK_SIZE - 1], TASK_STK_SIZE);
  23.         CoCreateTask( TASK1, (void*)0, TASK1_PRIO, &STK_TASK1[TASK_STK_SIZE - 1], TASK_STK_SIZE);
  24.         CoStartOS();
  25.     while(1);
  26. }

  27. void TASK0(void *param)
  28. {
  29.   uint16_t data;
  30.   KEY_Init();
  31.   Speed_PIDInit();                        
  32.   for(;;)
  33.   {
  34.     if(KEY_Read(KEY1))
  35.         {
  36.                 CoTickDelay(5);
  37.                 if(KEY_Read(KEY1))
  38.                 {
  39.                    BLDC_Start();        
  40.                 }
  41.         }
  42.         if(KEY_Read(KEY2))
  43.         {
  44.                 CoTickDelay(5);
  45.                 if(KEY_Read(KEY2))
  46.                 {
  47.                    BLDC_Stop();
  48.                 }
  49.         }
  50.         if(USART_Flag)
  51.         {
  52.             data = 1000000/(6*Speed_count);
  53.                 USART_SendData( USART2, data);
  54.                 USART_Flag = 0;
  55.         }
  56.         CoTickDelay(5);
  57.   }                        
  58. }
  59. void TASK1(void *param)
  60. {        
  61.   for(;;)
  62.   {
  63.            LED_On();
  64.            CoTickDelay(200);
  65.            LED_Off();
  66.            CoTickDelay(200);
  67.   }
  68. }
復制代碼


所有資料51hei提供下載:
速度環(huán)PID.rar (390.88 KB, 下載次數(shù): 575)


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏26 分享淘帖 頂 踩
回復

使用道具 舉報

沙發(fā)
ID:316065 發(fā)表于 2018-5-25 13:43 | 只看該作者
代碼能不能用
回復

使用道具 舉報

板凳
ID:228452 發(fā)表于 2018-5-26 04:45 | 只看該作者
Thank you for code list
回復

使用道具 舉報

地板
ID:382987 發(fā)表于 2018-8-4 22:19 | 只看該作者
學習一下
回復

使用道具 舉報

5#
ID:229981 發(fā)表于 2018-8-7 14:07 | 只看該作者
嗯,看一看,硬件電路OK。留個記號,有時間仔細看看
回復

使用道具 舉報

6#
ID:407899 發(fā)表于 2018-10-13 14:41 | 只看該作者
先MARK一下,以備使用,謝謝樓主
回復

使用道具 舉報

7#
ID:340228 發(fā)表于 2018-11-5 09:37 | 只看該作者
看起來好像不錯,下載下來看看
回復

使用道具 舉報

8#
ID:427504 發(fā)表于 2018-11-17 10:27 | 只看該作者
樓主硬件上是怎么搭建的,可以傳授些經(jīng)驗嗎?
回復

使用道具 舉報

9#
ID:317479 發(fā)表于 2019-4-18 12:01 | 只看該作者
MARK看看
回復

使用道具 舉報

10#
ID:423385 發(fā)表于 2019-4-20 22:10 | 只看該作者
很好,很強大。
回復

使用道具 舉報

11#
ID:518540 發(fā)表于 2019-4-22 14:30 | 只看該作者
MARK,驅動電路學習了!
回復

使用道具 舉報

12#
ID:99570 發(fā)表于 2019-9-10 23:23 | 只看該作者
很好,學習一下看看怎么閉環(huán)。
回復

使用道具 舉報

13#
ID:324611 發(fā)表于 2019-9-18 14:31 | 只看該作者
學習高手。
回復

使用道具 舉報

14#
ID:99570 發(fā)表于 2019-9-21 17:29 | 只看該作者
不錯哦,學習中。
回復

使用道具 舉報

15#
ID:669414 發(fā)表于 2019-12-21 08:32 | 只看該作者
看起來好像不錯,下載下來看看
回復

使用道具 舉報

16#
ID:285946 發(fā)表于 2020-6-20 14:39 | 只看該作者
學習前輩的經(jīng)驗
回復

使用道具 舉報

17#
ID:135281 發(fā)表于 2020-8-25 17:22 | 只看該作者
電路保護是怎么處理的,采樣看不出來
回復

使用道具 舉報

18#
ID:323651 發(fā)表于 2020-9-28 09:28 | 只看該作者
不錯的代碼,學到了,謝謝
回復

使用道具 舉報

19#
ID:95059 發(fā)表于 2020-11-11 16:45 | 只看該作者
代碼能用,想知道τ 寶能買到實體嗎? 給個鏈接
回復

使用道具 舉報

20#
ID:884849 發(fā)表于 2021-3-17 23:37 | 只看該作者
非常好的教程
回復

使用道具 舉報

21#
ID:319585 發(fā)表于 2021-7-16 20:36 | 只看該作者
看了一下應該是單電阻采樣,如果能三電阻采樣就好了。
回復

使用道具 舉報

22#
ID:555044 發(fā)表于 2022-7-1 18:00 | 只看該作者
學習一下,對P、I、D三個參數(shù)的校定有好的方法不
回復

使用道具 舉報

23#
ID:137171 發(fā)表于 2022-7-26 10:52 | 只看該作者
這個應該是有霍爾傳感器的控制代碼吧,如果沒有霍爾的話,有沒有控制code
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表