找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3113|回复: 5
打印 上一主题 下一主题
收起左侧

基于stm32f103zet6+MPU6050的风板控制系统源程序

[复制链接]
跳转到指定楼层
楼主
ID:324282 发表于 2019-7-28 15:06 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
系统采用stm32f103ZET6作为控制器,使用MPU6050作为角度反馈,通过位置式PID控制风板到任意角度。欢迎技术交流。联系1194735786.

单片机源程序如下:
  1. #include "led.h"
  2. #include "key.h"
  3. #include "timer.h"
  4. #include "contral.h"
  5. #include "oled.h"
  6. #include "mpu6050.h"
  7. #include "beep.h"
  8. #include "delay.h"
  9. #include "sys.h"
  10. #include "usart.h"
  11. #define PWM_INT 3000
  12. /************************************************
  13. 风机:左(PA6)  右(PA7)
  14. OLED   GND    电源地                                       
  15.                                 VCC  接5V或3.3v电源
  16.                                 D0   接PD6(SCL)                                KEY0: PEin(4)           //PE4
  17.                                 D1   接PD7(SDA)       KEY1: PEin(3)        //PE3
  18.                                 RES  接PD4              WK_UP: PAin(0)        //PA0  WK_UP
  19.                                 DC   接PD5                                                        BEEP: PBout(8)       
  20.                                 CS   接PD3
  21. 陀螺仪  TX:PA10                                                                LED0:PB5
  22.                                 RX:PA9                 LED1: PE5
  23. ************************************************/

  24. /***********全局变量**************/
  25. vu8 key=0;
  26. int fengji_zuo,fengji_you;
  27. u16 led0pwmval=0,ax;
  28. u8 dir=1;
  29. int pwm_left,pwm_right;
  30. int ek;

  31. void pid_ctrl(u16 kp,u16 kd,int experd)
  32. {
  33. //        int exp;
  34. //        if(experd<0)
  35. //                exp = experd -0;
  36. //        else if(experd <15)
  37. //                exp = experd -0;
  38. //        else
  39. //                exp = experd +0;
  40.         ek = experd - angle[0];
  41.         if(ek < 0)
  42.         {
  43.                 pwm_left = PWM_INT + kp*ek + kd*w[0];  
  44.                 pwm_right= PWM_INT - kp*ek - kd*w[0];  
  45.         }                                       
  46.         else                                    
  47.         {                                       
  48.                 pwm_left = PWM_INT + kp*ek + kd*w[0];  
  49.                 pwm_right= PWM_INT - kp*ek - kd*w[0];  
  50.         }
  51.         //low_data
  52.         if(pwm_left < 1500)
  53.                 pwm_left = 1500;
  54.         else
  55.                 pwm_left = pwm_left;
  56.         if(pwm_right < 1500)
  57.                 pwm_right = 1500;
  58.         else
  59.                 pwm_right = pwm_right;
  60.         //hight_data
  61.         if(pwm_left > 7200)
  62.                 pwm_left = 7200;
  63.         else
  64.                 pwm_left = pwm_left;
  65.         if(pwm_right > 7200)
  66.                 pwm_right = 7200;
  67.         else
  68.                 pwm_right = pwm_right;
  69. }

  70. int main(void)
  71. {               
  72.         delay_init();                     //延时函数初始化          
  73.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);          //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
  74.         uart_init(115200);         //串口初始化为115200
  75.         LED_Init();                             //LED端口初始化
  76.         OLED_Init();                                                                      //OLED???
  77.         OLED_Clear();                                                              //??
  78.         BEEP_Init();                 //初始化蜂鸣器端口
  79.         KEY_Init();                 //初始化与按键连接的硬件接口
  80.         TIM3_PWM_Init(7199,0);         //不分频。PWM频率=72000000/7200=10Khz
  81.          
  82.         OLED_ShowCHinese(00,0,1); //加
  83.         OLED_ShowCHinese(16,0,2); //速
  84.         OLED_ShowCHinese(32,0,3); //度
  85.          
  86.         OLED_ShowCHinese(00,2,0);  //角
  87.         OLED_ShowCHinese(16,2,2); //速
  88.         OLED_ShowCHinese(32,2,3); //度
  89.          
  90.         OLED_ShowCHinese(00,4,0);  //角
  91.         OLED_ShowCHinese(16,4,3);  //度
  92.          
  93.         while(1)
  94.         {
  95.                 mpu6050();
  96.                 key_tihao();

  97.     /*************PID********************/               
  98.                 pid_ctrl(400,5,exp_set);

  99.                
  100.                
  101.                 OLED_ShowNum(72,0,a[0],3,16);
  102.                 OLED_ShowNum(72,2,w[0],3,16);
  103.                 TIM_SetCompare1(TIM3,pwm_left );         // pwm_left 2100
  104.                 TIM_SetCompare2(TIM3,pwm_right);   // pwm_right
  105.                
  106.                
  107.                 if(w[0] < 0)
  108.                 {
  109.                         OLED_ShowChar(64,2,'-');
  110.                         OLED_ShowNum(72,2,-w[0],3,16);
  111.                 }
  112.                 else
  113.                 {
  114.                         OLED_ShowChar(64,2,' ');
  115.                         OLED_ShowNum(72,2,w[0],3,16);
  116.                 }
  117. /************角度显示******************/
  118.                 if(angle[0] < 0)
  119.                 {
  120.                         OLED_ShowChar(48,4,'-');
  121.                         ax = -angle[0];
  122.                         OLED_ShowNum(64,4,-angle[0],3,16);
  123.                 }
  124.                 else
  125.                 {
  126.                         OLED_ShowChar(48,4,' ');
  127.                         OLED_ShowNum(64,4,angle[0],3,16);
  128.                 }
  129.                
  130.                 if(exp_set < 0)
  131.                 {
  132.                         OLED_ShowChar(96,4,'-');
  133.                         OLED_ShowNum(102,4,-exp_set,3,16);
  134.                 }
  135.                 else
  136.                 {
  137.                         OLED_ShowChar(96,4,' ');
  138.                         OLED_ShowNum(102,4,exp_set,3,16);
  139.                 }
  140.                 OLED_ShowNum(0,6,pwm_left,4,16);
  141.                 OLED_ShowNum(72,6,pwm_right,4,16);
  142. /************************************/
  143. //                delay_ms(10);
  144. //               
  145. //                if(dir)led0pwmval++;
  146. //                else led0pwmval--;

  147. //                 if(led0pwmval>36000)dir=0;
  148. //                if(led0pwmval==0)dir=1;               
  149. //                TIM_SetCompare1(TIM3,led0pwmval);               
  150. //                TIM_SetCompare2(TIM3,led0pwmval);               

  151.                
  152. //                LED1=1;
  153. //                delay_ms(300);         //延时300ms
  154. //                LED1=0;
  155. //                delay_ms(300);        //延时300ms
  156.        
  157.         }
  158. }
复制代码

所有资料51hei提供下载:
风板控制.7z (202.54 KB, 下载次数: 91)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:421308 发表于 2019-7-28 19:15 | 只看该作者
谢谢分享
回复

使用道具 举报

板凳
ID:492627 发表于 2019-7-31 20:30 | 只看该作者
为什么没有定义IIC协议呢
回复

使用道具 举报

地板
ID:592195 发表于 2019-7-31 23:34 | 只看该作者
你的程序对吗?

回复

使用道具 举报

5#
ID:504404 发表于 2019-8-21 13:25 | 只看该作者
hjbhb 发表于 2019-7-31 20:30
为什么没有定义IIC协议呢

她用都rxtx
回复

使用道具 举报

6#
ID:403681 发表于 2019-8-22 08:55 | 只看该作者
感谢分享
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表