1024手机基地看电影,午夜福利视频导航,国产精品福利在线一区,亚洲欧美日韩另类成人,在线观看午夜日本理论片,成年超爽免费网站,国产精品成人免费,精品动作一级毛片,成人免费观看网站,97精品伊人久久大香蕉

標題: 基于51單片機ULN2003a驅動的步進電機控制實驗(含代碼,接線圖,代碼詳解) [打印本頁]

作者: 夜雨聲    時間: 2019-12-31 23:03
標題: 基于51單片機ULN2003a驅動的步進電機控制實驗(含代碼,接線圖,代碼詳解)
實驗的仿真題圖


步進電機是那個寶買的28BYJ-48 驅動模塊的ULN2003a也那個寶買的
接線圖如下


也可以按照自己的代碼來接線,我是按自己代碼的串口設置接的線。
話不多說先上代碼:
首先電機轉動的代碼
uchar phasecw[8] ={0x08,0x0c,0x04,0x06,0x02,0x03,0x01,0x09};//正轉 電機導通相序 D-C-B-A
uchar phaseccw[8]={0x01,0x03,0x02,0x06,0x04,0x0c,0x08,0x09};//反轉 電機導通相序 A-B-C-D

//順時針轉動
  1. void MotorCW(void)
  2. {
  3. uchar i;
  4. for(i=0;i<8;i++)
  5.   {
  6.    MotorData=phasecw[i];
  7.    Delay_ms(speed);//轉速調節
  8.   }
  9.         i=0;
  10. }
  11. //逆時針轉動
  12. void MotorCCW(void)
  13. {
  14. uchar i;
  15. for(i=0;i<8;i++)
  16.   {
  17.    MotorData=phaseccw[i];
  18.    Delay_ms(speed);//轉速調節
  19.   }
  20. }
復制代碼
根據步進電機的原理:依次給4相高電平就可以驅動步進電機轉動而A,B,C,D四相 分別對應P1.0,P1.1,P1.2,P1.3口所以只有讓P1口依次為0x01,0x02,0x04,0x08就行了,如果要反轉就把它倒過來依次為0x08,0x04,0x02,0x01.一圈4步,所以叫四相四拍。但是我不推薦使用這種,它的一步角度較大電機會有較大抖動。所以采用了四相八拍0x01,0x03,0x02,0x06,0x04,0x0c,0x08,0x09這樣電機轉動也相對平穩不易出事。
為了實現電機的不停頓轉動我將轉動函數放在了死循環里,但是在死循環里我們無法控制電機了怎么辦了就在死循環里加入一個按鍵函數這樣死循環不停掃描按鍵我們就可以在k1 里面通過sem控制電機的正反轉了。
死循環:while(sem&&sam)
                {                        
                MotorCW();
          Delay_ms(speed);//轉速調節
          keypros();
                }   
    while(!sem&&sam)
                {
                MotorCCW();
          Delay_ms(speed);//轉速調節
按鍵控制:

if(k1==0)                  //檢測按鍵K1是否按下
        {        
                Delay_ms(10);   //消除抖動 一般大約10ms
                if(k1==0)         //再次判斷按鍵是否按下
                {
                        sam=1;
                        sem=!sem;
          }
                while(!k1);         //檢測按鍵是否松開
        }        
為什么要用一個鍵控制正反轉了?不僅僅是因為按鍵不夠,更重要的是能消除鍵位沖突,鍵位沖突是指同時按下不同的鍵產生的沖突。消除鍵位沖突也是每次實驗應該考慮的事情。但是這樣也產生了新的問題就是當我們用兩個鍵控制正反轉時,單片機上電后電機不會轉動。而用上述方法的話上電電機就進入死循環開始轉動,所以引入sam控制電機的開始于停止。當sam為0與上sem可以使sem失去控制能力,也就是電機不轉了。這樣也就解決此問題還能控制電機停止        
if(k2==0)                  //檢測按鍵K1是否按下
        {        
                Delay_ms(10);   //消除抖動 一般大約10ms
                if(k2==0)         //再次判斷按鍵是否按下
                {               
                sam=0;
                }        
         while(!k2);         //檢測按鍵是否松開
        }
我們由步進電機原理可知電機是一步一步的走的,如果我們控制了它每一步的間隔時間就可以達到控制電機的速度的目的。但是對于我買的步進電機來說速度變換的一定程度就不明顯了所以我設置了限位這樣就減少代碼的bug,所以寫出按鍵控制速度代碼如下
if(k3==0)                  //檢測按鍵K1是否按下
        {        
                Delay_ms(10);   //消除抖動 一般大約10ms
                if(k3==0)         //再次判斷按鍵是否按下
         {
                        speed++;
                 if(speed>6)
                {
                        speed=6;
                }
               
         }
                while(!k3);         //檢測按鍵是否松開
        }        
if(k4==0)                  //檢測按鍵K1是否按下
        {        
                Delay_ms(10);   //消除抖動 一般大約10ms
                if(k4==0)         //再次判斷按鍵是否按下
         {
                        speed--;
                        if(speed<1)
                {
                        speed=1;
                }
        
         }
                while(!k3);         //檢測按鍵是否松開
        }        
}
理解了這些代碼的原理就可以寫出總代碼了
  1. #include<reg52.h>
  2. #define uchar unsigned char
  3. #define uint unsigned int
  4. #define MotorData P1                    //步進電機控制接口定義
  5. uchar phasecw[8] ={0x08,0x0c,0x04,0x06,0x02,0x03,0x01,0x09};//正轉 電機導通相序 D-C-B-A
  6. uchar phaseccw[8]={0x01,0x03,0x02,0x06,0x04,0x0c,0x08,0x09};//反轉 電機導通相序 A-B-C-D
  7. uint  sem=0,sam=0,speed=3;//信號量,sem控制正反轉,sam設置電機是否轉動,1轉動,0不轉動
  8. sbit k1=P3^1;
  9. sbit k2=P3^0;
  10. sbit k3=P3^2;
  11. sbit k4=P3^3;
  12. //ms延時函數
  13. void Delay_ms(uint x)
  14. {
  15. uint i,j;
  16. for(i=0;i<x;i++)
  17.   for(j=0;j<112;j++);
  18. }
  19. //順時針轉動
  20. void MotorCW(void)
  21. {
  22. uchar i;
  23. for(i=0;i<8;i++)
  24.   {
  25.    MotorData=phasecw[i];
  26.    Delay_ms(speed);//轉速調節
  27.   }
  28.         i=0;
  29. }
  30. //逆時針轉動
  31. void MotorCCW(void)
  32. {
  33. uchar i;
  34. for(i=0;i<8;i++)
  35.   {
  36.    MotorData=phaseccw[i];
  37.    Delay_ms(speed);//轉速調節
  38.   }
  39. }

  40. //按鍵函數
  41. void keypros()
  42. {

  43.         if(k1==0)                  //檢測按鍵K1是否按下
  44.         {        
  45.                 Delay_ms(10);   //消除抖動 一般大約10ms
  46.                 if(k1==0)         //再次判斷按鍵是否按下
  47.                 {
  48.                         sam=1;
  49.                         sem=!sem;
  50.           }
  51.                 while(!k1);         //檢測按鍵是否松開
  52.         }               
  53.         if(k2==0)                  //檢測按鍵K1是否按下
  54.         {        
  55.                 Delay_ms(10);   //消除抖動 一般大約10ms
  56.                 if(k2==0)         //再次判斷按鍵是否按下
  57.                 {               
  58.                 sam=0;
  59.                 }        
  60.          while(!k2);         //檢測按鍵是否松開
  61.         }
  62.         if(k3==0)                  //檢測按鍵K1是否按下
  63.         {        
  64.                 Delay_ms(10);   //消除抖動 一般大約10ms
  65.                 if(k3==0)         //再次判斷按鍵是否按下
  66.          {
  67.                         speed++;
  68.                  if(speed>6)
  69.                 {
  70.                         speed=6;
  71.                 }
  72.                
  73.          }
  74.                 while(!k3);         //檢測按鍵是否松開
  75.         }        
  76. if(k4==0)                  //檢測按鍵K1是否按下
  77.         {        
  78.                 Delay_ms(10);   //消除抖動 一般大約10ms
  79.                 if(k4==0)         //再次判斷按鍵是否按下
  80.          {
  81.                         speed--;
  82.                         if(speed<1)
  83.                 {
  84.                         speed=1;
  85.                 }
  86.         
  87.          }
  88.                 while(!k3);         //檢測按鍵是否松開
  89.         }        
  90. }
  91. //主函數
  92. void main(void)
  93. {

  94. while(1)
  95. {
  96.                  MotorData=0x00;  //設初值
  97.           keypros();
  98.     while(sem&&sam)
  99.                 {                        
  100.                 MotorCW();
  101.           Delay_ms(speed);//轉速調節
  102.           keypros();
  103.                 }   
  104.     while(!sem&&sam)
  105.                 {
  106.                 MotorCCW();
  107.           Delay_ms(speed);//轉速調節
  108.           keypros();
  109.                 }               
  110. }

  111. }
復制代碼
本文大體就是這樣,如果有什么疑問可以在評論區留言,我會盡量回答。
最后附上代碼包: 步進電機實驗.zip (20.67 KB, 下載次數: 561)


作者: xingfengyym    時間: 2020-4-10 15:36
您好,我想再讓電機轉快點可以嗎,我的電機時28byj的。還有就是我想把轉速顯示到lcd上怎么弄
作者: 阿飛7812    時間: 2020-4-10 20:50
謝謝分享收下了
作者: zzzz1999    時間: 2020-4-24 10:12
2相步進電機可以用ULN2003A來控制嗎
作者: ^-^    時間: 2020-4-24 10:37
zzzz1999 發表于 2020-4-24 10:12
2相步進電機可以用ULN2003A來控制嗎

可以的
作者: ^-^    時間: 2020-4-24 10:42
xingfengyym 發表于 2020-4-10 15:36
您好,我想再讓電機轉快點可以嗎,我的電機時28byj的。還有就是我想把轉速顯示到lcd上怎么弄

把延遲減小就可以提速了(注意物理限制,這個步進電機轉不快),轉速是自己算出來的(根據延遲以及相數),當然也可以增加測試傳感器進行測量
作者: zzzz1999    時間: 2020-4-24 12:46
^-^ 發表于 2020-4-24 10:37
可以的

2相的步進電機在控制系統設計上還是和4相的原理圖一樣嗎
作者: aktuan007    時間: 2020-4-24 21:28
講解詳細,我喜歡,適合我這樣的新手
作者: xcc225    時間: 2020-4-28 17:01
請問這個步進電機和uln2003驅動板可以實現每次轉動想要的角度嗎?  
作者: Liu....    時間: 2020-4-29 16:25
我想用交流電動機 怎么改控制電路能實現?
作者: 599177809    時間: 2020-5-24 14:57
你好,直接用開發板上上的步進電機模塊的5個引腳可以控制嗎?
作者: zy尋找    時間: 2020-5-26 11:21
按鍵K4檢測最后寫錯了吧?不應該是while(!K3)........
作者: kkhg    時間: 2020-5-27 13:32
阿飛7812 發表于 2020-4-10 20:50
謝謝分享收下了

可以分享 一下嗎?
作者: OK過嗎    時間: 2020-5-28 11:43
樓主,電機的正反轉不是很靈敏,時靈是不靈的,照程序的邏輯來說應該是按一次正反轉按鈕,轉動的方向就可以反轉了,但是實測后有時多次按下正反轉按鈕仍然沒有反轉,有時一按下正反轉按鈕就反轉,不是很穩定。
作者: 北江啊    時間: 2020-6-5 16:05
有驅動器了 還要考慮相序嗎
作者: 康德    時間: 2020-10-23 15:46
謝謝樓主分享,講解很仔細
作者: mule.。    時間: 2021-1-23 10:58
你好,您現在的轉速大概多少?
作者: 1322143244    時間: 2021-5-5 23:40
有程序框圖嘛
作者: wangwenhai8    時間: 2021-7-18 10:28
謝謝。學習。可以用。
作者: 3042974988    時間: 2021-7-27 09:35
speed是干嘛的啊
作者: 3042974988    時間: 2021-7-27 10:46
你是怎么調速的啊
作者: SGW2020    時間: 2021-8-16 15:38
仿真時  怎么不轉 按下K2 怎么不轉
作者: SGW2020    時間: 2021-8-17 10:59
你好,非常感謝你的分享,但是速度調節,我不知道你是怎么控制的?所以我改了一下,代碼,如附件,幫忙指點一下,謝謝!


  1. #include<reg52.h>
  2. #define uchar unsigned char
  3. #define uint unsigned int
  4. #define MotorData P1                    //步進電機控制接口定義
  5. uchar phasecw[8] ={0x02,0x06,0x04,0x0c,0x08,0x09,0x01,0x03};//正轉 電機導通相序 D-C-B-A
  6. uchar phaseccw[8] ={0x03,0x01,0x09,0x08,0x0c,0x04,0x06,0x02};//反轉 電機導通相序 A-B-C-D
  7. void key();
  8. void key1();
  9. uchar num,num1;  
  10. uint  speed=200;//速度調節
  11. sbit K1=P3^0;
  12. sbit K2=P3^1;
  13. sbit K3=P3^2;
  14. sbit K4=P3^3;


  15. //ms延時函數
  16. void Delay_ms(uint x)
  17. {
  18. uint i,j;
  19. for(i=0;i<x;i++)
  20.   for(j=0;j<112;j++);
  21. }
  22. //順時針轉動
  23. void MotorCW(void)
  24. {

  25.             if(!K1)
  26.             {
  27.              uchar i;
  28.              for(i=0;i<8;i++)
  29.               {
  30.                MotorData=phasecw[i];
  31.                Delay_ms(speed);//轉速調節
  32.                key1();
  33.               }  
  34.               
  35.           }
  36.                               
  37. }
  38. //逆時針轉動
  39. void MotorCCW(void)
  40. {
  41.         
  42.             if(!K2)
  43.             {
  44.              uchar i;
  45.              for(i=0;i<8;i++)
  46.               {
  47.                MotorData=phaseccw[i];
  48.                Delay_ms(speed);//轉速調節
  49.                 key1();
  50.               }      
  51.           }
  52.                     
  53. }

  54. void main(void)
  55. {

  56. while(1)
  57. {
  58.         key();
  59.    
  60. }
  61.          
  62. }



  63. void key()   
  64. {

  65.    if(K1==0)      //順時針 啟動
  66.         {
  67.                 Delay_ms(5);          
  68.                 if(K1==0)       
  69.                 {
  70.              
  71.                         while(!K1)
  72.             {
  73.                         MotorCW();
  74.                         }
  75.                  
  76.         }
  77.     }

  78.    
  79.    if(K2==0)     //逆時針 啟動
  80.         {
  81.                 Delay_ms(5);          
  82.                 if(K2==0)       
  83.                 {
  84.              
  85.                         while(!K2)
  86.             {
  87.                         MotorCCW();
  88.                         }
  89.                  
  90.         }
  91.     }     
  92.      
  93. }



  94. void key1()    //速度調節
  95. {

  96.    
  97.     if(K3==0)     //速度調節
  98.         {
  99.                 Delay_ms(5);          
  100.                 if(K3==0)       
  101.                 {
  102.                         num++;             
  103.                         while(!K3);               
  104.                         if(num==1)         
  105.                         {
  106.                         speed=100;
  107.                         }
  108.             
  109.             if(num==2)         
  110.                         {         
  111.                         speed=50;
  112.                         }
  113.            if(num==3)         
  114.                         {
  115.             num=0;
  116.                         speed=20;
  117.                         }
  118.                        
  119.         }
  120.     }
  121.    
  122.      
  123. }

  124. // 控制步進電機,K1 順時針  ,K2 逆時針 ,K3 速度調節



復制代碼

作者: 258095592    時間: 2022-1-22 17:25
為何按照你的線路圖和代碼,仿真就直接動到了135度,不再動了呢,
作者: 96311    時間: 2022-1-22 20:39
我是剛學51的,對我很有用,謝謝。
作者: 96311    時間: 2022-1-22 20:41
很好,請問這個芯片可以用來驅動24V的步進電機嗎、
作者: lgjmjx    時間: 2022-2-2 14:44
能下載嗎?只見扣黑幣,下哪里了??
作者: heicad    時間: 2022-2-3 07:03
lgjmjx 發表于 2022-2-2 14:44
能下載嗎?只見扣黑幣,下哪里了??

可以下載我剛下載成功了,你換一個瀏覽器試試
作者: ccczzzyy    時間: 2022-5-23 20:30

我是剛學51的,對我很有用,謝謝




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