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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
uid:582255 日志

步進電機控制實驗

已有 1036 次閱讀2021-2-3 21:30

電機轉動的代碼
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. }

  21. 根據步進電機的原理:依次給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這樣電機轉動也相對平穩不易出事。
    為了實現電機的不停頓轉動我將轉動函數放在了死循環里,但是在死循環里我們無法控制電機了怎么辦了就在死循環里加入一  步進電機實驗.zip (20.67 KB, 下載次數: 213) 個按鍵函數這樣死循環不停掃描按鍵我們就可以在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. }
    復制代碼
    本文大體就是這樣

路過

雞蛋

鮮花

握手

雷人

全部作者的其他最新日志

評論 (0 個評論)

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

Powered by 單片機教程網

返回頂部
主站蜘蛛池模板: 久草99 | 国产精品久久久久久吹潮 | 色888www视频在线观看 | 色综合视频 | 欧美日韩电影一区二区 | 久久com| 波多野结衣一区二区三区在线观看 | 国产高清在线 | 久久久精品一区二区三区 | 一区二区视频在线 | 婷婷丁香在线视频 | 成人在线免费 | 日日夜夜av | 亚洲色图网址 | 国产成人麻豆免费观看 | 国产精品国产三级国产aⅴ中文 | 精品国产乱码久久久久久闺蜜 | 日日摸日日碰夜夜爽亚洲精品蜜乳 | 亚洲精品一区二区三区免 | 综合久久综合久久 | 欧美视频二区 | 精品永久 | 日本精品久久久一区二区三区 | 精品久久亚洲 | 国产精品高清在线 | 日韩视频中文字幕 | 国产精品久久久久久久久免费樱桃 | 观看av| 日韩欧美理论片 | 亚洲网站在线观看 | 四虎最新视频 | 羞羞视频网站 | 一级特黄a大片 | 婷婷色在线播放 | 国产成人免费视频网站高清观看视频 | 538在线精品| 成人av免费 | 一本一道久久a久久精品综合 | 天天操 夜夜操 | 国产在线中文 | 日本成人中文字幕 |