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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機控制實現PWM輸出經L298驅動芯片后驅動電機

[復制鏈接]
跳轉到指定樓層
樓主
使用proteus進行仿真:運用單片機(AT89C52、STM32、MSP430等)控制實現PWM輸出經驅動芯片后驅動電機,(驅動自選)
需實現以下功能:
1、pwm頻率為1KHz,初始占空比50%
2、PWM輸出占空比可調
3、可控制兩個電機同時正轉、反轉、一正一反;
(可實物,提供所需器材)

仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)



單片機源程序如下:
  1. #include<reg52.h>  // 引入STC89C52頭文件
  2. #define uint unsigned int  // 定義無符號整型變量
  3. #define uchar unsigned char  // 定義無符號字符型變量

  4. uchar time, count = 50, flag1 = 1, flag2 = 1;  // 定義變量

  5. uchar seg[] = {0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39};  // 數碼管顯示字符

  6. sbit PWM1 = P3^0;  // PWM 輸出引腳 1
  7. sbit PWM2 = P3^1;  // PWM 輸出引腳 2
  8. sbit PWM3 = P3^2;  // PWM 輸出引腳 3
  9. sbit PWM4 = P3^3;  // PWM 輸出引腳 4

  10. sbit key_add = P2^3;  // 增加按鍵
  11. sbit key_dec = P2^4;  // 減少按鍵
  12. sbit key_turn1 = P2^5;  // 旋轉按鍵 1
  13. sbit key_turn2 = P2^6;  // 旋轉按鍵 2

  14. sbit RS = P3^5;  // LCD 控制引腳 RS
  15. sbit RW = P3^6;  // LCD 控制引腳 RW
  16. sbit E = P3^7;  // LCD 控制引腳 E

  17. // 延時函數
  18. void delayxms(uint z);
  19. // 旋轉按鍵1的處理函數
  20. void Motor_turn1();
  21. // 旋轉按鍵2的處理函數
  22. void Motor_turn2();
  23. // 增加按鍵的處理函數
  24. void Motor_add();
  25. // 減少按鍵的處理函數
  26. void Motor_dec();
  27. // 定時器0的初始化函數
  28. void timer0_init();
  29. // 定時器1的初始化函數
  30. void timer1_init();
  31. // 向LCD發送命令
  32. void w_com(uchar j);
  33. // 向LCD發送數據
  34. void w_dat(uchar j);
  35. // 初始化LCD
  36. void lcd_init();

  37. void main()
  38. {
  39.     uint mm, nn;
  40.     lcd_init();
  41.     timer0_init();
  42.     timer1_init();
  43.     while (1)
  44.     {
  45.         Motor_turn1();
  46.         Motor_turn2();
  47.         Motor_add();
  48.         Motor_dec();

  49.         w_com(0x80);
  50.         w_dat('d');
  51.         w_dat('u');
  52.         w_dat('t');
  53.         w_dat('y');
  54.         w_dat(' ');
  55.         w_dat('r');
  56.         w_dat('a');
  57.         w_dat('t');
  58.         w_dat('i');
  59.         w_dat('o');
  60.         w_dat(':');
  61.         w_com(0xc7);

  62.         mm = seg[count/10];
  63.         nn = seg[count%10];
  64.         w_dat(mm);
  65.         w_dat(nn);
  66.         w_dat('%');
  67.     }
  68. }

  69. // 延時函數,延時z毫秒
  70. void delayxms(uint z)
  71. {
  72.     uint x, y;
  73.     for (y = z; y > 0; y--)
  74.         for (x = 110; x > 0; x--);
  75. }

  76. // 處理旋轉按鍵1
  77. void Motor_turn1()
  78. {
  79.     if (key_turn1 == 0)
  80.     {
  81.         delayxms(2);
  82.         if (key_turn1 == 0)
  83.         {
  84.             flag1 = ~flag1;
  85.         }
  86.         while (!key_turn1);
  87.     }
  88. }

  89. // 處理旋轉按鍵2
  90. void Motor_turn2()
  91. {
  92.     if (key_turn2 == 0)
  93.     {
  94.         delayxms(2);
  95.         if (key_turn2 == 0)
  96.         {
  97.             flag2 = ~flag2;
  98.         }
  99.         while (!key_turn2);
  100.     }
  101. }

  102. // 處理增加按鍵
  103. void Motor_add()
  104. {
  105.     if (key_add == 0)
  106.     {
  107.         delayxms(2);
  108.         if (key_add == 0)
  109.         {
  110.             count += 5;
  111.             if (count >= 100)
  112.             {
  113.                 count = 0;
  114.             }
  115.         }
  116.         while (!key_add);
  117.     }
  118. }

  119. // 處理減少按鍵
  120. void Motor_dec()
  121. {
  122.     if (key_dec == 0)
  123.     {
  124.         delayxms(2);
  125.         if (key_dec == 0)
  126.         {
  127.             count -= 5;
  128.             if (count >= 100)
  129.             {
  130.                 count = 0;
  131.             }
  132.         }
  133.         while (!key_dec);
  134.     }
  135. }

  136. // 定時器0初始化
  137. void timer0_init()
  138. {
  139.     TMOD = 0x01;
  140.     TH0 = (65536 - 10) / 256;
  141.     TL0 = (65536 - 10) % 256;
  142.     TR0 = 1;
  143.     ET0 = 1;
  144.     EA = 1;
  145. }

  146. // 定時器0中斷處理函數
  147. void timer0_int() interrupt 1
  148. {
  149.     TR0 = 0;
  150.     TH0 = (65536 - 10) / 256;
  151.     TL0 = (65536 - 10) % 256;
  152.     TR0 = 1;

  153.     if (flag1 == 1)
  154.     {
  155.         PWM1 = 0;
  156.         time++;
  157.         if (time < count)
  158.             PWM2 = 1;
  159.         else
  160.             PWM2 = 0;

  161.         if (time >= 100)
  162.             time = 0;
  163.     }
  164.     else
  165.     {
  166.         PWM2 = 0;
  167.         time++;
  168.         if (time < count)
  169.             PWM1 = 1;
  170.         else
  171.             PWM1 = 0;

  172.         if (time >= 100)
  173.             time = 0;
  174.     }
  175. }

  176. // 定時器1初始化
  177. void timer1_init()
  178. {
  179.     TMOD = 0x10;
  180.     TH1 = (65536 - 10) / 256;
  181.     TL1 = (65536 - 10) % 256;
  182.     TR1 = 1;
  183.     ET1 = 1;
  184.     EA = 1;
  185. }

  186. // 定時器1中斷處理函數
  187. void timer1_int() interrupt 3
  188. {
  189.     TR1 = 0;
  190.     TH1 = (65536 - 10) / 256;
  191.     TL1 = (65536 - 10) % 256;
  192.     TR1 = 1;

  193.     if (flag2 == 1)
  194.     {
  195.         PWM3 = 0;
  196.         time++;
  197.         if (time < count)
  198.             PWM4 = 1;
  199.         else
  200.             PWM4 = 0;

  201.         if (time >= 100)
  202.             time = 0;
  203.     }
  204.     else
  205.     {
  206.         PWM4 = 0;
  207.         time++;
  208.         if (time < count)
  209.             PWM3 = 1;
  210.         else
  211.             PWM3 = 0;

  212.         if (time >= 100)
  213.             time = 0;
  214.     }
  215. }

  216. // 向LCD發送命令
  217. void w_com(uchar j) {
  218.     RS = 0;
  219.     RW = 0;
  220.     E = 1;
  221.     P1 = j;
  222.     E = 0;
  223.     delayxms(3);
  224. }

  225. // 向LCD發送數據
  226. void w_dat(uchar j) {
  227.     RS = 1;
  228.     RW = 0;
  229.     E = 1;
  230.     P1 = j;
  231.     E = 0;
  232.     delayxms(2);
  233. }

  234. // 初始化LCD
  235. void lcd_init() {
  236.     delayxms(10);
  237.     w_com(0x38);
  238.     delayxms(10);
  239.     w_com(0x0c);
  240.     delayxms(10);
  241.     w_com(0x06);
  242.     delayxms(10);
  243.     w_com(0x01);
  244.     delayxms(10);
  245.     w_com(0x38);
  246.     delayxms(10);
  247. }
復制代碼

Keil代碼與Proteus仿真下載: 仿真程序.7z (65.19 KB, 下載次數: 19)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

沙發
ID:1086975 發表于 2023-7-9 14:09 | 只看該作者
因為51單片機性能不好,所以在液晶屏上顯示就是很不靈敏
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 天天操夜夜骑 | 国产精品久久久久久网站 | 欧美视频免费在线观看 | 美日韩中文字幕 | 福利视频大全 | 亚洲成人自拍 | 91av在线视频观看 | 色妞av| 成人精品一区亚洲午夜久久久 | 成人午夜精品 | 偷拍第一页 | 乳色吐息在线观看 | www.日韩在线| 中文字幕韩在线第一页 | 久久午夜国产精品www忘忧草 | 91色网站 | 一级做a爰片性色毛片16 | 欧美男人天堂 | 精品一区电影 | 欧美日韩精品在线免费观看 | 99视频| 欧美视频日韩 | 成人免费视频观看视频 | 国产精品久久久久久久久久久久久久 | 91porn国产成人福利 | 九九天堂网 | 欧美一区二区视频 | 日韩第一区 | 中文字幕第7页 | 青青草华人在线视频 | 久久国产欧美日韩精品 | 国产精品日韩欧美一区二区三区 | 99国产精品99久久久久久 | 国精产品一区一区三区免费完 | 亚洲一区久久 | 一级在线免费观看 | 欧美国产激情 | 欧美日高清视频 | 亚洲天堂av网 | 久久网一区二区 | 国产探花 |