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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機直流電機PWM調速仿真+源代碼

  [復制鏈接]
跳轉到指定樓層
樓主
分享一個自己做的直流電機PWM調速仿真帶源代碼,下面是功能介紹
ON/OFF: 電機轉/停
INC: 占空比1%~100%遞增,每步1%
DEC: 占空比100%~1%遞減,每步1%
三位數碼管顯示,從1~100,表示占空比1%~100%



源程序如下:
  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. }
  265. /*********************************************
  266. * 動態顯示速度百分比
  267. *********************************************/
  268. void Dynamic_Display(void)
  269. {
  270.         static u8 DisPinOn = 0x01;

  271.         DisPinOn <<= 1;
  272.         if(DisPinOn == 0x10)
  273.         {
  274.                 DisPosition = 0;
  275.                 DisPinOn = 0x01;
  276.         }
  277.         P0 = 0xff;
  278.         P1 = DisPinOn;
  279.         P0 = DisCode[DisNum[DisPosition++]];
  280. }
  281. /*********************************************
  282. * 定時器0中斷
  283. *********************************************/
  284. void timer0(void) interrupt 1
  285. {
  286.         TH0 = T0HIGH;
  287.         TL0 = T0LOWW;

  288.         b10msEvent = true;                //10毫秒中斷
  289.         if(++SecCount == 100)
  290.         {
  291.                 SecCount = 0;
  292.                 b1secEvent = true;                //1秒到時
  293.         }
  294. }
復制代碼

直流電機PWM調速仿真工程文件下載:
moto.rar (68.74 KB, 下載次數: 212)



評分

參與人數 1黑幣 +1 收起 理由
liqiang1996 + 1 很給力!

查看全部評分

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

使用道具 舉報

沙發
ID:75280 發表于 2016-9-6 09:13 | 只看該作者
O(∩_∩)O謝謝   樓主分享
回復

使用道具 舉報

板凳
ID:138707 發表于 2016-9-7 12:40 | 只看該作者
O(∩_∩)O謝謝  51黑有你更精彩!!!
回復

使用道具 舉報

地板
ID:159648 發表于 2017-1-3 16:17 | 只看該作者
謝謝分享。。
回復

使用道具 舉報

5#
ID:161244 發表于 2017-1-11 04:30 | 只看該作者
頂  謝謝分享哈
回復

使用道具 舉報

6#
ID:90156 發表于 2017-4-4 23:37 | 只看該作者
太感謝樓主啦
回復

使用道具 舉報

7#
ID:185687 發表于 2017-4-11 21:14 | 只看該作者
謝謝好貼分享
回復

使用道具 舉報

8#
ID:215143 發表于 2017-6-27 14:56 | 只看該作者
好貼啊
回復

使用道具 舉報

9#
ID:215165 發表于 2017-6-27 15:42 | 只看該作者
謝謝分享,學習了
回復

使用道具 舉報

10#
ID:308395 發表于 2018-5-3 10:37 | 只看該作者
不夠好,沒有實時讀速度
回復

使用道具 舉報

11#
ID:312908 發表于 2018-6-3 10:02 | 只看該作者
謝謝樓主分享
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 午夜精品视频在线观看 | 国产在线不卡 | 天天精品综合 | 中文字幕一区在线观看视频 | 国产免费一区二区三区 | 久久精品久久久 | 免费观看的av | 成人在线精品视频 | 特黄色一级毛片 | 亚洲在线免费观看 | 91精品国产色综合久久 | 国产精品毛片 | 一区二区国产精品 | 在线观看欧美日韩视频 | 中文字幕一区在线 | 91综合网| 亚洲福利av| 夜夜干夜夜操 | 久久精品免费观看 | 久艹av | 91香蕉视频在线观看 | 日本黄色一级视频 | 久久久高清 | 午夜免费成人 | 欧美中文字幕 | 亚洲成人免费视频在线观看 | 色五月激情五月 | 男女羞羞视频在线看 | 国产日产精品一区二区三区四区 | 精品久久久久久亚洲综合网 | 黄色大片毛片 | 99福利视频 | 成人免费福利视频 | 久久久久国产视频 | 亚洲成人一区 | 激情五月婷婷综合 | 99久久婷婷国产综合精品电影 | 一级片毛片| 久久久婷婷 | 福利一区二区在线 | 日韩一区二区在线播放 |