久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 34376|回復(fù): 70
打印 上一主題 下一主題
收起左側(cè)

STM32步進(jìn)電機(jī)S加減速程序源碼與詳細(xì)分析

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
基于STM32步進(jìn)電機(jī)s型加減速控制


一個(gè)物體從起點(diǎn)運(yùn)動(dòng)到終點(diǎn),要經(jīng)歷加速,勻速,減速的過程,把整個(gè)過程中速度隨時(shí)間變化關(guān)系畫出來,就是速度曲線.
S型加減速就是指速度曲線中加減速階段的曲線呈現(xiàn)一個(gè)英文字母'S'型.
S型加減速相對(duì)于梯形加減速更加平穩(wěn),對(duì)電機(jī)和傳動(dòng)系統(tǒng)的沖擊更小.
S型加減速的曲線并沒有限定是什么曲線,所以可以是指數(shù)曲線,可以是正弦曲線.這里分析的S型加減速是基于加速度勻速變化的曲線.
S型加減速的優(yōu)點(diǎn)就是啟動(dòng)和停止都很平滑,不會(huì)有很大的沖擊,但缺點(diǎn)就是啟動(dòng)和停止的時(shí)間比較長.
具體的加減速的速度曲線看背景圖….

右圖就是S型加速曲線和對(duì)應(yīng)的加速度曲線示意圖
在加速過程中,前半部分由于加速度是勻速遞增的,
這段曲線我們稱為加加速段曲線(后面稱它為IncAccel),后半部分是加速度勻速遞減的,稱為減加速段(DeAccel).
加加速段是加速度關(guān)于時(shí)間的斜率為正的直線,減
加速則是加速度關(guān)于時(shí)間的斜率為負(fù)的直線.
加速度從0開始變化,到了最大值開始減小,最后為0,
由于加速度的斜率是相同的,所以加加速度和減加速度
所用的時(shí)間是一樣.這兩段曲線是關(guān)于加速度最大值的對(duì)應(yīng)的速度中心對(duì)稱的.





單片機(jī)源程序如下:
  1. #include "Speed.h"
  2. //函數(shù)名稱: CalculateSpeedTab
  3. //函數(shù)功能:計(jì)算加減速表
  4. //參數(shù)參數(shù):Speed 速度結(jié)構(gòu)體
  5. //             V0;                //初速度,單位:step/s
  6. //             Vt;                //末速度,單位:step/s
  7. //             S;                 //路程,單位:step
  8. //             t;                 //加速時(shí)間,單位:s
  9. //             time;              //加速次數(shù)    單位:次
  10. //             *SpeedTab;         //加速速度表,速度單位:step/s
  11. //             SecSpeedPoint;     //減速點(diǎn) 單位:step
  12. //返回輸出:速度結(jié)構(gòu)體
  13. static Speed_t CalculateSpeedTab(Speed_t Speed)
  14. {
  15.     int i;                        
  16.     double aa;                    //加加速
  17.     int DeltaV;                   //速度變化量
  18.     int tempVt;
  19.     //如果速度記錄表的指針為空,說明沒有分配內(nèi)存
  20.     RT_ASSERT(Speed->SpeedTab != RT_NULL);
  21.     //各參數(shù)是否超范圍
  22.     RT_ASSERT(IS_SPEED(Speed->V0, Speed->Vt));
  23.     RT_ASSERT(IS_SPACE(Speed->S));
  24.     RT_ASSERT(IS_ADDTIMING(Speed->t));
  25.     RT_ASSERT(IS_ADDTIME(Speed->time));
  26.     //根據(jù)加速法則計(jì)算末速度
  27.     tempVt = LASTVELOCITY(Speed->S / SPEEDPRINCIPLE, Speed->V0, Speed->t);
  28.     Speed->Vt = (tempVt > Speed->Vt) ? Speed->Vt : tempVt;                                                   
  29.     Speed->SecSpeedPoint = ACCELERATESPACE(Speed->V0, Speed->Vt, Speed->t);        //計(jì)算減速點(diǎn)位置,剩余路程為該值時(shí)開始減速
  30.     aa = (double)((Speed->Vt - Speed->V0) / 2)      //加速度變化拐點(diǎn)時(shí)的速度值                           a|   /|\            
  31.         * 2                                         //知道直角三角形面積,逆推三角型高度時(shí)將面積*2        |  / | \面積為DeltaV
  32.         / (Speed->time / 2)                         //除以底邊                                            | /  |  \            
  33.         / (Speed->time / 2);                        //再除以底邊,得到斜率,即加加速                      |/___|___\__time   
  34.     //開始速度計(jì)算
  35.     for(i = 0; i < ((Speed->time / 2) + 1); i++)
  36.     {
  37.         DeltaV = (aa * i * i) / 2;                                     //V = V0 + a * t / 2;  a = aa * t;
  38.         *(Speed->SpeedTab + i) = Speed->V0 + DeltaV;                   //當(dāng)前點(diǎn)的速度
  39.         *(Speed->SpeedTab + Speed->time - i) = Speed->Vt - DeltaV;     //對(duì)稱點(diǎn)的速度
  40.     }
  41.     return Speed;
  42. }
  43. //函數(shù)名稱:TestSpeed
  44. //函數(shù)功能:測試速度表計(jì)算函數(shù)
  45. //函數(shù)參數(shù):V0      初速度,單位:轉(zhuǎn)/min
  46. //          Vt      末速度,單位:轉(zhuǎn)/min
  47. //          S       路程,單位:mm
  48. //          time    加速次數(shù)
  49. //函數(shù)返回:無
  50. void TestSpeed(int V0, int Vt, int S, int time)
  51. {
  52.     int i;
  53.     Speed_t Speed = (Speed_t)rt_malloc(sizeof(struct SPEED));
  54.     Speed->V0 = STEPSPEED(V0);    //起速
  55.     Speed->Vt = STEPSPEED(Vt);    //末速
  56.     Speed->S = TOTALSTEP(S);      //路程
  57.     Speed->t = 0.2;               //加速時(shí)間設(shè)為0.2秒
  58.     Speed->time = time;           //加速次數(shù)
  59.     Speed->SpeedTab = (int *)rt_malloc(sizeof(int) * (Speed->time + 1)); //根據(jù)加速次數(shù)申請(qǐng)表格內(nèi)存,加1,以防用的時(shí)候超界
  60.     CalculateSpeedTab(Speed);       //開始計(jì)算
  61.     for(i = 0; i < Speed->time; i++)
  62.     {
  63.         rt_kprintf("SpeedTab[%d] = %d, Acceleration = %d\n"
  64.                   , i
  65.                   , *(Speed->SpeedTab + i)
  66.                   , *(Speed->SpeedTab + i + 1) - *(Speed->SpeedTab + i));
  67.     }
  68.     rt_kprintf("SpeedTab[%d] = %d\n", i, *(Speed->SpeedTab + i));
  69.     rt_free(Speed->SpeedTab);              
  70.     rt_free(Speed);                    
  71. }

  72. FINSH_FUNCTION_EXPORT(TestSpeed, Test Speed table calculate);

復(fù)制代碼

頭文件:
  1. #ifndef __SPEED_H__
  2. #define __SPEED_H__
  3. #include "rtthread.h"
  4. #include "finsh.h"
  5. /*  三分之一加減速法則:
  6. 加速路程不超過三分之一總路程,
  7. 這樣做的目的是給減速留有足夠的時(shí)間去檢測減速點(diǎn),
  8. 進(jìn)而實(shí)現(xiàn)平穩(wěn)的將速度減到初速度,
  9. 如果在處理速度夠快的情況下,
  10. 可以選擇二分之一加減速
  11. */
  12. //加減速法則,2分之一法則或3分之一法則
  13. #define SPEEDPRINCIPLE              3
  14. //電機(jī)最大轉(zhuǎn)速,單位轉(zhuǎn)/min
  15. #define MOTOMAXSPEED                1500   
  16. //電機(jī)每轉(zhuǎn)對(duì)應(yīng)的傳動(dòng)距離,單位:mm
  17. #define MOTOROUNDLENGTH             36
  18. //電機(jī)最大初速度,初速度超過該值會(huì)對(duì)電機(jī)造成傷害,單位轉(zhuǎn)/min
  19. #define MOTOMAXSTART                200
  20. //驅(qū)動(dòng)器細(xì)分?jǐn)?shù)
  21. #define DRIVERSFRACTION             1
  22. //電機(jī)細(xì)分?jǐn)?shù)
  23. #define MOTOFRACTION                200
  24. //根據(jù)初速度,末速度,以及時(shí)間,計(jì)算加速路程
  25. #define ACCELERATESPACE(V0,Vt,t)    (((V0) + (Vt)) * (t) / 2)
  26. //根據(jù)加速路程,初速度,以及時(shí)間,計(jì)算末速度
  27. #define LASTVELOCITY(S,V0,t)        (2 * (S) / (t) - (V0))
  28. //根據(jù)電機(jī)轉(zhuǎn)速(轉(zhuǎn)/min),計(jì)算電機(jī)步速度(step/s)
  29. #define STEPSPEED(RV)               ((RV) * MOTOFRACTION * DRIVERSFRACTION / 60)
  30. //根據(jù)長度計(jì)算電機(jī)所需走的步數(shù),S的單位為mm
  31. #define TOTALSTEP(S)                S * MOTOFRACTION * DRIVERSFRACTION / MOTOROUNDLENGTH
  32. struct SPEED
  33. {
  34.     int         V0;                 //初速度,單位:step/s
  35.     int         Vt;                 //末速度,單位:step/s
  36.     long long   S;                  //路程,單位:step
  37.     double      t;                  //加速時(shí)間,單位:s
  38.     int         time;               //加速次數(shù)    單位:次
  39.     int         *SpeedTab;          //加速速度表,速度單位:step/s
  40.     int         SecSpeedPoint;      //減速點(diǎn) 單位:step(在電機(jī)運(yùn)動(dòng)過程中,如果剩余路程小于等于該值,那么電機(jī)開始減速)
  41. };
  42. typedef struct SPEED * Speed_t;


  43. //各參數(shù)范圍值,可以在此設(shè)置參數(shù)范圍
  44. //初速度大于0小于電機(jī)最高起速,末速度大于初速度,小于電機(jī)最高轉(zhuǎn)速
  45. #define IS_SPEED(V0,Vt)     (((V0) >= 0) && ((V0) <= STEPSPEED(MOTOMAXSTART))  \
  46.                             && ((Vt) >= (V0)) && ((Vt) <= STEPSPEED(MOTOMAXSPEED)))                           
  47. #define IS_SPACE(S)         ((S) > 0)
  48. #define IS_ADDTIMING(t)     ((t) > 0)            
  49. #define IS_ADDTIME(time)     ((time) >= 32)        //讓加速次數(shù)必須大于等于32,否則計(jì)算表格就沒什么意義

  50. #endif
復(fù)制代碼


所有資料51hei提供下載:
S型加減速分析.rar (2.64 MB, 下載次數(shù): 1151)



S型加減速.png (121.42 KB, 下載次數(shù): 178)

S型加減速.png

S型加減速和梯形加減速.png (127.74 KB, 下載次數(shù): 180)

S型加減速和梯形加減速.png

加速度曲線圖.png (113.87 KB, 下載次數(shù): 162)

加速度曲線圖.png

實(shí)際計(jì)算得到的S型曲線圖.png (112.19 KB, 下載次數(shù): 161)

實(shí)際計(jì)算得到的S型曲線圖.png

評(píng)分

參與人數(shù) 2黑幣 +13 收起 理由
AnthonyYMH + 5 共享資料的黑幣獎(jiǎng)勵(lì)!
supermcu8 + 8 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏33 分享淘帖 頂5 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:389278 發(fā)表于 2018-8-24 11:23 | 只看該作者
正在學(xué)這個(gè) 真是運(yùn)氣呀
謝謝
回復(fù)

使用道具 舉報(bào)

板凳
ID:146544 發(fā)表于 2018-9-14 09:35 | 只看該作者
學(xué)習(xí)了,很受用。請(qǐng)問樓主。rtthread.h在STM32里報(bào)錯(cuò)什么原因?
回復(fù)

使用道具 舉報(bào)

地板
ID:155719 發(fā)表于 2018-11-3 09:14 | 只看該作者
多謝樓主了,收藏 學(xué)習(xí),正需要
回復(fù)

使用道具 舉報(bào)

5#
ID:461071 發(fā)表于 2019-1-3 16:11 | 只看該作者
感謝樓主!
回復(fù)

使用道具 舉報(bào)

6#
ID:463385 發(fā)表于 2019-1-6 23:42 | 只看該作者
正需要步進(jìn)電機(jī)的資料,謝謝
回復(fù)

使用道具 舉報(bào)

7#
ID:463496 發(fā)表于 2019-1-7 10:03 | 只看該作者
學(xué)習(xí)學(xué)習(xí)
回復(fù)

使用道具 舉報(bào)

8#
ID:337376 發(fā)表于 2019-1-13 21:16 | 只看該作者
很棒,很詳細(xì)
回復(fù)

使用道具 舉報(bào)

9#
ID:126254 發(fā)表于 2019-1-17 17:15 | 只看該作者
很受用,哈哈,謝謝樓主
回復(fù)

使用道具 舉報(bào)

10#
ID:471313 發(fā)表于 2019-1-25 08:12 | 只看該作者
謝謝樓主的分享
回復(fù)

使用道具 舉報(bào)

11#
ID:384489 發(fā)表于 2019-1-31 11:34 | 只看該作者
一直想學(xué)習(xí)S型算法,無奈原理性的注釋太少了,也是云里霧里的。看到樓主發(fā)的這個(gè)很欣慰,感謝分享。
回復(fù)

使用道具 舉報(bào)

12#
ID:311744 發(fā)表于 2019-3-2 16:52 | 只看該作者
學(xué)習(xí)學(xué)習(xí)
回復(fù)

使用道具 舉報(bào)

13#
ID:138247 發(fā)表于 2019-3-6 11:02 | 只看該作者

謝謝樓主分享。。。
回復(fù)

使用道具 舉報(bào)

14#
ID:445062 發(fā)表于 2019-3-6 13:43 | 只看該作者

感謝樓主!
回復(fù)

使用道具 舉報(bào)

15#
ID:445062 發(fā)表于 2019-3-6 13:44 | 只看該作者
謝謝樓主分享。。。
回復(fù)

使用道具 舉報(bào)

16#
ID:19303 發(fā)表于 2019-3-8 10:38 | 只看該作者
很好,學(xué)習(xí)中
回復(fù)

使用道具 舉報(bào)

17#
ID:519239 發(fā)表于 2019-4-23 08:37 | 只看該作者
非常感謝樓主的分享,對(duì)于新手來說,幫助很大,謝謝
回復(fù)

使用道具 舉報(bào)

18#
ID:519224 發(fā)表于 2019-4-23 09:19 | 只看該作者
希望樓主可以出更多更好的教程
回復(fù)

使用道具 舉報(bào)

19#
ID:62019 發(fā)表于 2019-5-15 22:34 | 只看該作者
好好學(xué)習(xí)下
回復(fù)

使用道具 舉報(bào)

20#
ID:540349 發(fā)表于 2019-5-16 23:39 | 只看該作者
樓主厲害
回復(fù)

使用道具 舉報(bào)

21#
ID:561398 發(fā)表于 2019-6-12 23:56 | 只看該作者
不錯(cuò),不錯(cuò)。。。
回復(fù)

使用道具 舉報(bào)

22#
ID:561398 發(fā)表于 2019-6-12 23:57 | 只看該作者
學(xué)習(xí)了,很受用。請(qǐng)問樓主。rtthread.h在STM32里報(bào)錯(cuò)什么原因?
回復(fù)

使用道具 舉報(bào)

23#
ID:511461 發(fā)表于 2019-6-13 10:06 | 只看該作者
很棒,謝謝分享
回復(fù)

使用道具 舉報(bào)

24#
ID:576733 發(fā)表于 2019-7-2 22:02 | 只看該作者
非常好的資料,非常感謝
回復(fù)

使用道具 舉報(bào)

25#
ID:290893 發(fā)表于 2019-7-4 09:54 | 只看該作者
不錯(cuò)。。。。。。。。。。。。。。。
回復(fù)

使用道具 舉報(bào)

26#
ID:418638 發(fā)表于 2019-7-4 14:31 | 只看該作者
不錯(cuò)不錯(cuò)
回復(fù)

使用道具 舉報(bào)

27#
ID:479761 發(fā)表于 2019-7-12 15:22 | 只看該作者
請(qǐng)問這是用什么驅(qū)動(dòng)的
回復(fù)

使用道具 舉報(bào)

28#
ID:421308 發(fā)表于 2019-7-13 16:53 | 只看該作者
很有價(jià)值
回復(fù)

使用道具 舉報(bào)

29#
ID:511073 發(fā)表于 2019-7-14 12:48 | 只看該作者
謝謝分享
回復(fù)

使用道具 舉報(bào)

30#
ID:583912 發(fā)表于 2019-7-14 15:14 | 只看該作者

多謝樓主了,收藏 學(xué)習(xí),
回復(fù)

使用道具 舉報(bào)

31#
ID:152548 發(fā)表于 2019-7-28 11:39 | 只看該作者
這個(gè)不錯(cuò),可以使很多人入門。算法還有PIID的,需要用到高等數(shù)學(xué)了。
回復(fù)

使用道具 舉報(bào)

32#
ID:554080 發(fā)表于 2019-8-23 14:59 | 只看該作者
看起來挺詳細(xì)  看看
回復(fù)

使用道具 舉報(bào)

33#
ID:609995 發(fā)表于 2019-9-10 14:38 | 只看該作者
謝謝,正在研究這方面的內(nèi)容
回復(fù)

使用道具 舉報(bào)

34#
ID:610293 發(fā)表于 2019-9-11 10:01 | 只看該作者
感謝樓主的分享!
回復(fù)

使用道具 舉報(bào)

35#
ID:409322 發(fā)表于 2019-9-18 10:06 | 只看該作者
謝謝大佬分享!
回復(fù)

使用道具 舉報(bào)

36#
ID:409322 發(fā)表于 2019-9-18 10:07 | 只看該作者
謝謝大佬分享,正好能用到,拿來學(xué)習(xí)一下
回復(fù)

使用道具 舉報(bào)

37#
ID:477269 發(fā)表于 2019-10-17 17:07 | 只看該作者
正好需要呢,太感謝 了
回復(fù)

使用道具 舉報(bào)

38#
ID:637590 發(fā)表于 2019-11-7 17:25 | 只看該作者
寫的真好 你真棒寫的真好 你真棒寫的真好 你真棒
回復(fù)

使用道具 舉報(bào)

39#
ID:492919 發(fā)表于 2019-11-23 15:24 | 只看該作者
學(xué)習(xí)一下
感謝樓主
回復(fù)

使用道具 舉報(bào)

40#
ID:648200 發(fā)表于 2019-11-24 09:32 | 只看該作者
感謝樓主
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 黄色片在线看 | 国产午夜精品一区二区三区四区 | 精品欧美一区二区三区久久久 | 欧美视频二区 | 欧美片网站免费 | 国产伊人久久久 | 综合国产| 亚洲成人精 | 日韩精品一区二区三区在线观看 | 久久夜夜 | 久久久夜| 亚洲精品无| 国产天堂 | 色网站在线免费观看 | 国产成人精品一区二区 | 国产视频久久久 | 欧美人妖网站 | 亚洲成人久久久 | 久久精品一区 | 久久久久久亚洲精品 | 中文一区| 成人精品一区二区三区 | 国内精品久久久久久 | 中文日韩字幕 | 久久午夜国产精品www忘忧草 | 国产黑丝在线 | 成人影院免费视频 | 亚洲精品国产成人 | 天堂在线一区 | 免费午夜电影 | 中文字幕在线观看一区二区 | 91在线一区| 久久精品aaa | 免费观看一级特黄欧美大片 | 日韩三级电影在线看 | 成人在线视频免费观看 | 免费国产精品久久久久久 | 国产精品久久在线观看 | 中文字字幕一区二区三区四区五区 | 免费a网 | 欧美一区二区三区在线观看视频 |