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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 16686|回復: 16
打印 上一主題 下一主題
收起左側

基于51單片機的pwm直流電機調速proteus仿真文件與源碼

  [復制鏈接]
跳轉到指定樓層
樓主
ID:257901 發表于 2017-12-5 21:04 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
讀者可用proteus仿真,學習pwm對直流電機調速控制。
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. #include <reg52.h>
  2. /*********************************************
  3. * 定時器初值
  4. *********************************************/
  5. #define T0HIGH        0xec
  6. #define T0LOWW        0x8a

  7. /*********************************************
  8. *
  9. *********************************************/
  10. typedef unsigned char        u8;
  11. typedef unsigned int        u16;
  12. typedef unsigned long        u32;
  13. typedef bit                                BOOL;

  14. /*********************************************
  15. * 單片機管腳定義
  16. *********************************************/
  17. sbit KEY_ON_PIN = P2^0;
  18. sbit KEY_INC_PIN = P2^1;
  19. sbit KEY_DEC_PIN = P2^2;

  20. sbit MOTO_LEFT = P3^6;
  21. sbit MOTO_RIGHT = P3^7;

  22. /*********************************************
  23. * 按鍵定義
  24. *********************************************/
  25. #define KEY_NULL                0xff
  26. #define KEY_LONG_PERIOD        25
  27. #define KEY_CONTINUE_PERIOD        20

  28. #define KEY_DOWN                0x80
  29. #define KEY_CONTINUE        0x40
  30. #define KEY_UP                        0x20

  31. #define KEY_STATE_INIT                0
  32. #define KEY_STATE_WOBBLE        1
  33. #define KEY_STATE_PRESS                2
  34. #define KEY_STATE_LONG                3
  35. #define KEY_STATE_CONTINUE        4
  36. #define KEY_STATE_RELEASE        5

  37. #define KEY_ON_VALUE                1
  38. #define KEY_INC_VALUE                2
  39. #define KEY_DEC_VALUE                3

  40. #define KEY_ON                (KEY_ON_VALUE | KEY_DOWN)
  41. #define KEY_INC                (KEY_INC_VALUE | KEY_DOWN)
  42. #define KEY_INC_CON        (KEY_INC_VALUE | KEY_CONTINUE)
  43. #define KEY_DEC                (KEY_DEC_VALUE | KEY_DOWN)
  44. #define KEY_DEC_CON        (KEY_DEC_VALUE | KEY_CONTINUE)
  45. /*********************************************
  46. * 常量定義
  47. *********************************************/
  48. #define true        1
  49. #define false        0

  50. #define MOTO_ON                MOTO_LEFT = false;\
  51.                                         MOTO_RIGHT = true
  52. #define MOTO_OFF        MOTO_LEFT = true;\
  53.                                         MOTO_RIGHT = true
  54. /*********************************************
  55. * 全局變量定義
  56. *********************************************/
  57. code u8 DisCode[] = {0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8, 0x80, 0x90, 0xff};

  58. u8 PWMpercent = 0;
  59. u8 DisNum[4] = {0x0a, 0x0a, 0x0a, 0x00};
  60. u8 DisPosition = 0;
  61. u8 SecCount = 0;
  62. u8 u10msNum = 0;

  63. BOOL b10msEvent = false;
  64. BOOL b100msEvent = false;
  65. BOOL b1secEvent = false;
  66. BOOL MotoStart = false;
  67. BOOL MotoRun = false;

  68. void Key_Prosess(void);
  69. void Dynamic_Display(void);
  70. void Speed_Display(void);

  71. /*********************************************
  72. * 主函數
  73. *********************************************/
  74. main()
  75. {
  76.         TMOD = 0x01;
  77.         TH0 = T0HIGH;
  78.         TL0 = T0LOWW;
  79.         TR0 = 1;
  80.         ET0 = 1;
  81.         EA = 1;
  82.         P1 = 0x00;

  83.         while(1)
  84.         {
  85.                 if(true == b10msEvent)        //10毫秒定時標志
  86.                 {
  87.                         b10msEvent = false;
  88.                         Key_Prosess();                //按鍵掃描
  89.                         Dynamic_Display();                //動態顯示

  90.                         if(true == MotoStart)        //如果電機啟動
  91.                         {
  92.                                 if(true == MotoRun)
  93.                                 {
  94.                                         if(--u10msNum == 0)                //如果電機轉動時間到,停止電機
  95.                                         {
  96.                                                 MotoRun = false;
  97.                                                 MOTO_OFF;
  98.                                         }
  99.                                 }
  100.                                 if(true == b1secEvent)                //PWM周期為1秒,1秒鐘時間到,開始下一個周期
  101.                                 {
  102.                                         b1secEvent = false;
  103.                                         MotoRun = true;
  104.                                         MOTO_ON;
  105.                                         u10msNum = PWMpercent;
  106.                                 }
  107.                         }
  108.                 }
  109.         }
  110. }
  111. /*********************************************
  112. * 清顯示
  113. *********************************************/
  114. void Num_Clear(void)
  115. {
  116.         u8 i;
  117.         for(i=0; i<3; i++)
  118.         {
  119.                 DisNum[i] = 0x0a;
  120.         }
  121.         DisNum[3] = 0x00;
  122. }
  123. /*********************************************
  124. * 讀鍵值
  125. *********************************************/
  126. u8 Key_Scan(void)
  127. {
  128.         if(KEY_ON_PIN == false)
  129.                 return KEY_ON_VALUE;
  130.         if(KEY_INC_PIN == false)
  131.                 return KEY_INC_VALUE;
  132.         if(KEY_DEC_PIN == false)
  133.                 return KEY_DEC_VALUE;
  134.         return KEY_NULL;
  135. }
  136. /*********************************************
  137. * 按鍵狀態掃描
  138. *********************************************/
  139. u8 GetKey(void)
  140. {
  141.         static u8 KeyState = KEY_STATE_INIT;
  142.         static u8 KeyTimeCount = 0;
  143.         static u8 LastKey = KEY_NULL;        //保存按鍵釋放時候的鍵值
  144.         u8 KeyTemp = KEY_NULL ;

  145.         KeyTemp = Key_Scan();

  146.         switch(KeyState)
  147.         {
  148.                 case KEY_STATE_INIT:        //初始狀態
  149.                         if(KEY_NULL != KeyTemp)        //有鍵按下
  150.                         {
  151.                                 KeyState = KEY_STATE_WOBBLE;        //進入消抖
  152.                         }
  153.                         break;

  154.                 case KEY_STATE_WOBBLE:        //消抖
  155.                         KeyState = KEY_STATE_PRESS;
  156.                         break;

  157.                 case KEY_STATE_PRESS:
  158.                         if(KEY_NULL != KeyTemp)
  159.                         {
  160.                                 LastKey = KeyTemp;        //保存鍵值,以便在釋放按鍵狀態返回鍵值
  161.                                 KeyTemp |= KEY_DOWN;        //按鍵按下
  162.                                 KeyState = KEY_STATE_LONG;
  163.                         }
  164.                         else
  165.                         {
  166.                                 KeyState = KEY_STATE_INIT;
  167.                         }
  168.                         break;

  169.                 case KEY_STATE_LONG:
  170.                         if(KEY_NULL != KeyTemp)
  171.                         {
  172.                                 if(++KeyTimeCount >= KEY_LONG_PERIOD)
  173.                                 {
  174.                                         KeyTimeCount = 0;
  175.                                         KeyState = KEY_STATE_CONTINUE;
  176.                                 }
  177.                         }
  178.                         else
  179.                         {
  180.                                 KeyState = KEY_STATE_RELEASE;
  181.                         }
  182.                         break;

  183.                 case KEY_STATE_CONTINUE:
  184.                         if(KEY_NULL != (KeyTemp))
  185.                         {
  186.                                 if(++KeyTimeCount >= KEY_CONTINUE_PERIOD)
  187.                                 {
  188.                                         KeyTimeCount = 0;
  189.                                         KeyTemp |= KEY_CONTINUE;  //連擊按鍵事件發生
  190.                                 }
  191.                         }
  192.                         else
  193.                         {
  194.                                 KeyState = KEY_STATE_RELEASE;
  195.                         }
  196.                         break;

  197.                 case KEY_STATE_RELEASE:
  198.                         LastKey |= KEY_UP;        //按鍵釋放
  199.                         KeyTemp = LastKey;
  200.                         KeyState = KEY_STATE_INIT;
  201.                         break;

  202.                 default:
  203.                         break;
  204.         }
  205.         return KeyTemp;
  206. }
  207. /*********************************************
  208. * 按鍵功能處理
  209. *********************************************/
  210. void Key_Prosess(void)
  211. {
  212.         u8 KeyData;

  213.         KeyData = GetKey();

  214.         switch(KeyData)
  215.         {
  216.                 case KEY_ON:        //開關電機
  217.                         if(true == MotoStart)
  218.                         {
  219.                                 MotoStart = false;
  220.                                 Num_Clear();
  221.                                 MOTO_OFF;
  222.                                 MotoRun = false;
  223.                                 PWMpercent= 0;
  224.                         }
  225.                         else
  226.                         {
  227.                                 MotoStart = true;
  228.                                 MOTO_ON;
  229.                                 MotoStart = true;
  230.                                 MotoRun = true;
  231.                                 u10msNum = PWMpercent = 1;
  232.                         }
  233.                         break;

  234.                 case KEY_INC:        //單步增加
  235.                 case KEY_INC_CON:        //連續增加
  236.                         if((PWMpercent < 100) && MotoStart)                //PWM從1%~100%
  237.                                 PWMpercent++;
  238.                         break;

  239.                 case KEY_DEC:        //單步減小
  240.                 case KEY_DEC_CON:        //連續減小
  241.                         if((PWMpercent > 1) && MotoStart)                //PWM從1%~100%
  242.                                 PWMpercent--;
  243.                         break;

  244.                 default:
  245.                         break;
  246.         }
  247.         Speed_Display();
  248. }
  249. /*********************************************
  250. * 速度轉換成十進制數
  251. *********************************************/
  252. void Speed_Display(void)
  253. {
  254.         u8 i;

  255.         DisNum[1] = PWMpercent / 100;
  256.         DisNum[2] = PWMpercent % 100 / 10;
  257.         DisNum[3] = PWMpercent % 10;
  258.         for(i=1; i<3; i++)
  259.         {
  260.                 if(DisNum[i] != 0)
  261.                         break;
  262.                 DisNum[i] = 0x0a;
  263. ……………………

  264. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

所有資料51hei提供下載:
pwm直流電機調速.rar (68.74 KB, 下載次數: 660)


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

使用道具 舉報

沙發
ID:213280 發表于 2017-12-6 23:18 | 只看該作者
很好的程序,很棒 Proteus7.5仿真成功了

51hei.png (29.56 KB, 下載次數: 64)

51hei.png
回復

使用道具 舉報

板凳
ID:299790 發表于 2018-5-11 21:25 | 只看該作者
不錯
好資料,51黑有你更精彩!!!
回復

使用道具 舉報

地板
ID:228452 發表于 2018-5-16 05:24 | 只看該作者
1. What is PWM frequency ?
2 Add option to change frequency depending of motor type
3. Thanks for listing
回復

使用道具 舉報

5#
ID:342294 發表于 2018-8-17 13:15 | 只看該作者
下載下來的程序和你展示的程序不是一個程序    因為下載下來的程序里面沒有開定時器中斷   試想一下51這種沒有PWM功能的單片機  想要有PWM波 必須開定時器中斷得到一個PWM 變量數  這樣你的電機才能實現調速    不知道你是不是故意這么做的  還是你弄錯了  
回復

使用道具 舉報

6#
ID:387272 發表于 2018-8-23 10:50 | 只看該作者
還需要重新對程序進行編譯,生成HEX文件才行,下載的程序是不一致的

評分

參與人數 1黑幣 +20 收起 理由
admin + 20 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

7#
ID:388738 發表于 2018-8-23 11:47 | 只看該作者
程序有完整的按鍵單擊、連擊處理,pwm調速正在學習中,謝謝分享
回復

使用道具 舉報

8#
ID:488624 發表于 2019-3-11 16:17 | 只看該作者
很好用啊,謝謝
回復

使用道具 舉報

9#
ID:43121 發表于 2019-3-18 08:54 | 只看該作者
謝謝,很棒的應用,非常適合教學
回復

使用道具 舉報

10#
ID:505364 發表于 2019-4-6 10:31 | 只看該作者
lany 發表于 2018-8-23 11:47
程序有完整的按鍵單擊、連擊處理,pwm調速正在學習中,謝謝分享

你好  這個文件應該怎么打開?
回復

使用道具 舉報

11#
ID:27031 發表于 2019-6-3 22:19 | 只看該作者
謝謝分享基于51單片機的pwm直流電機調速proteus仿真文件與源碼
回復

使用道具 舉報

12#
ID:70035 發表于 2019-8-29 08:44 | 只看該作者
仿真了,不錯。
回復

使用道具 舉報

13#
ID:69408 發表于 2019-8-29 09:07 | 只看該作者
下載學習學習,謝謝樓主分享!!
回復

使用道具 舉報

14#
ID:660312 發表于 2019-12-10 10:19 | 只看該作者
很棒的一個程序,希望可以一直保留
回復

使用道具 舉報

15#
ID:706694 發表于 2020-6-15 19:20 | 只看該作者
學習一下 正好有需求
回復

使用道具 舉報

16#
ID:817551 發表于 2020-9-10 12:29 | 只看該作者

RE: 基于51單片機的pwm直流電機調速proteus仿真文件與源碼


我的沒有,需要改代碼嗎
回復

使用道具 舉報

17#
ID:897014 發表于 2021-3-28 15:23 | 只看該作者
這個是雙閉環的嗎???
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 在线一区二区三区 | 日本一区二区三区免费观看 | 国产专区免费 | 中文字幕av第一页 | 亚洲情侣视频 | 久久久久久国产精品免费免费狐狸 | 一级二级三级在线观看 | 亚洲精品9999 | 美女高潮网站 | 国产精品一区二区在线 | 国产精品日本一区二区在线播放 | 黄色一级视频 | 天天干视频网 | 久久手机在线视频 | 欧美99| 国产欧美日韩二区 | 久久综合九色综合欧美狠狠 | 天天爽夜夜骑 | 久久久久久久国产 | 久久国产精品久久久久久久久久 | 久草网站 | 精品一区二区免费视频 | 99r在线| 一级片网站视频 | 91精品国产乱码久久久久久 | 国产高清视频在线观看 | 91精品国产91久久久久久吃药 | 国产色 | 国产高清精品网站 | 国产精品观看 | a级片在线观看 | 亚洲午夜av| 91最新入口 | 亚洲国产一区在线 | 精品久久久久久久久久 | 欧美一级欧美三级在线观看 | 在线观看中文字幕一区二区 | 天天操天天操 | 伊人色综合久久天天五月婷 | 国产成人精品免费视频大全最热 | 51ⅴ精品国产91久久久久久 |