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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

2015年電賽練習風力擺代碼 STM32F4 + jy61姿態傳感器 四路pwm 四個空心杯電機 PID

[復制鏈接]
跳轉到指定樓層
樓主
2015年全國電子設計競賽練習風力擺代碼  STM32F4 + jy61姿態傳感器 四路pwm控制 四個空心杯電機 PID控制風力擺畫圓,直線等等

制作出來的實物圖如下:


單片機源程序如下:
  1. #include "sys.h"
  2. #include "delay.h"
  3. #include "usart.h"
  4. #include "led.h"
  5. #include "lcd.h"
  6. #include "remote.h"
  7. #include "pwm.h"
  8. #include "motor.h"
  9. #include "math.h"
  10. #include "timer.h"
  11. //void Get_Angle();//獲取角度
  12. //void Get_Accelerate();//獲取角度
  13. //void Get_Palstance();//獲取角度
  14. void LCD_display(void);
  15. extern u8 Re_buf[11],counter;
  16. extern u8 jiasudu[6],jiaosudu[6],jiaodu[6];
  17. extern float Angle[3],Accelerate[3],Palstance[3],Temperature;
  18. float Err_X,Err_Y,Err_X_Last,Err_Y_Last;
  19. float X,Y;
  20. float Aim_X,Aim_Y;
  21. float Kp,Ki,Kd;
  22. u32 pwm1 = 0,pwm2 = 0,pwm3 = 0,pwm4 = 0;

  23. int main(void)
  24. {
  25.         u8 key;
  26.         u8 *str=0;
  27.         Kp = 100;
  28.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置系統中斷優先級分組2
  29.         delay_init(168);  //初始化延時函數
  30.         uart_init(115200);                //初始化串口波特率為115200
  31.         USART2_Init(115200);  //串口2初始化
  32.         delay_ms(1000);
  33.        
  34.         TIM12_PWM_Init(10000-1,21-1);//PWM1
  35.         TIM13_PWM_Init(10000-1,21-1);//PWM2
  36.         TIM14_PWM_Init(10000,21-1);//PWM3
  37.         TIM5_PWM_Init(10000-1,21-1);//PWM4

  38.         TIM3_Init(200-1,8400-1);    //定時器3初始化
  39.         Motor_Init();  //四路空心杯電機初始化
  40.         //LED_Init();                                        //初始化LED
  41.         LCD_Init();
  42.         Remote_Init();                                //紅外接收初始化                        
  43.        
  44.         POINT_COLOR=RED;//設置字體為紅色             
  45.         LCD_ShowString(30,130,200,16,16,"PWM1:");       
  46.   LCD_ShowString(30,150,200,16,16,"PWM2:");       
  47.   LCD_ShowString(30,170,200,16,16,"PWM3:");                
  48.   LCD_ShowString(30,190,200,16,16,"PWM4:");               
  49.         LCD_ShowString(30,210,200,16,16,"X_Angle:");
  50.         LCD_ShowString(30,230,200,16,16,"Y_Angle:");
  51.         LCD_ShowString(30,250,200,16,16,"Z_Angle:");
  52.        
  53.         Motor_Stop();  //電機置1高電平
  54.        
  55.         //Motor_Stop1();
  56.        
  57.         while(1)
  58.         {       
  59.                 LCD_display();
  60.         }
  61. }


  62. void TIM3_IRQHandler(void)//20ms進入一次中斷
  63. {
  64.     if(TIM_GetITStatus(TIM3,TIM_IT_Update)==SET) //溢出中斷
  65.                 {
  66.                
  67.                                 Aim_X = 12.0;
  68.                                 Aim_Y = 0;
  69.                                
  70.                                 X = Angle[0];
  71.                                 Y = Angle[1];
  72.                                
  73.                                 Err_X = X - Aim_X;
  74.                                 Err_Y = Y - Aim_Y;
  75.                                
  76.                                
  77.                                 if(Err_X <= 0)
  78.                                 {
  79.                                          Motor_Drive(2,1); //電機2正轉
  80.                                          Motor_Drive(4,0); //電機4反轉
  81.                                          pwm2 += Kp*(fabs(Err_X))*0.02;
  82.                                          pwm4 += Kp*(fabs(Err_X))*0.02;
  83.                                 }
  84.                                 else
  85.                                 {
  86.                                          Motor_Drive(2,1);  //電機2反轉
  87.                                          Motor_Drive(4,0);  //電機4正轉
  88.                                          pwm2 -= Kp*Err_X*0.02;
  89.                                          pwm4 -= Kp*Err_X*0.02;
  90.                                 }
  91.                                
  92.                                 if(Err_Y <= 0)
  93.                                 {
  94.                                          Motor_Drive(1,1); //電機1正轉
  95.                                          Motor_Drive(3,0); //電機3反轉
  96.                                          pwm1 += Kp*(fabs(Err_Y))*0.02;
  97.                                          pwm3 += Kp*(fabs(Err_Y))*0.02;
  98.                                 }
  99.                                 else
  100.                                 {
  101.                                          Motor_Drive(1,0);  //電機1反轉
  102.                                          Motor_Drive(3,1);  //電機3正轉
  103.                                          pwm1 += Kp*Err_Y*0.02;
  104.                                          pwm3 += Kp*Err_Y*0.02;
  105.                                 }
  106.                                
  107.                                 //限幅
  108.                                 if(pwm1 >= 9000) pwm1 = 9000;
  109.                                 if(pwm2 >= 9000) pwm2 = 9000;
  110.                                 if(pwm3 >= 9000) pwm3 = 9000;
  111.                                 if(pwm4 >= 9000) pwm4 = 9000;
  112.                                
  113.                                 TIM_SetCompare1(TIM13,pwm1);
  114.                                 TIM_SetCompare1(TIM14,pwm2);
  115.                                 TIM_SetCompare1(TIM12,pwm3);
  116.                                 TIM_SetCompare1(TIM5,pwm4);
  117.                        
  118.                 }
  119.                 TIM_ClearITPendingBit(TIM3,TIM_IT_Update);  //清除中斷標志位
  120. }



  121. void LCD_display()
  122. {
  123.        
  124.          LCD_ShowNum(86,130,pwm1,5,16);
  125.          LCD_ShowNum(86,150,pwm2,5,16);
  126.          LCD_ShowNum(86,170,pwm3,5,16);
  127.          LCD_ShowNum(86,190,pwm4,5,16);
  128.        
  129.    if(Angle[0] >= 0)
  130.                  {
  131.                          LCD_ShowChar(128,210,' ',16,0);
  132.                          LCD_Showfloat(144,210,Angle[0],4,16);               
  133.                  }
  134.                  else
  135.                  {
  136.                     LCD_ShowChar(128,210,'-',16,0);
  137.                           LCD_Showfloat(144,210,fabs(Angle[0]),4,16);               
  138.                  }
  139.                  
  140.                  if(Angle[1] >= 0)
  141.                  {
  142.                          LCD_ShowString(128,230,200,16,16," ");
  143.                          LCD_Showfloat(144,230,Angle[1],4,16);               
  144.                  }
  145.                  else
  146.                  {
  147.                     LCD_ShowString(128,230,200,16,16,"-");
  148.                           LCD_Showfloat(144,230,fabs(Angle[1]),4,16);               
  149.                  }
  150.                  
  151.                  if(Angle[2] >= 0)
  152.                  {
  153.                          LCD_ShowString(128,250,200,16,16," ");
  154.                    LCD_Showfloat(144,250,Angle[2],4,16);                //顯示鍵值                       
  155.                  }
  156.                  else
  157.                  {
  158.                     LCD_ShowString(128,250,200,16,16,"-");
  159.                           LCD_Showfloat(144,250,fabs(Angle[2]),4,16);                //顯示鍵值               
  160.                  }
  161.                  LCD_Fill(86,170,116+8*8,170+16,WHITE);        //清楚之前的顯示
  162.                  
  163. }

  164. /*
  165. void Get_Angle()//獲取角度
  166. {
  167.    Angle[0] = ((short)((jiaodu[1]<<8)|jiaodu[0]))/32768.0*180;//x軸角度
  168.    Angle[1] = ((short)((jiaodu[3]<<8)|jiaodu[2]))/32768.0*180;//Y軸角度
  169.          Angle[2] = ((short)((jiaodu[5]<<8)|jiaodu[4]))/32768.0*180;//Z軸角度
  170.          printf("x軸角度:%.3f,Y軸角度:%.3f,Z軸角度:%.3f\r\n",Angle[0],Angle[1],Angle[2]);
  171.          //delay_ms(1);
  172. }

  173. void Get_Accelerate()//獲取加速度
  174. {
  175.    Accelerate[0] = ((short)((jiasudu[1]<<8)|jiasudu[0]))/32768.0*16;//X軸加速度
  176.          Accelerate[1] = ((short)((jiasudu[3]<<8)|jiasudu[2]))/32768.0*16;//Y軸加速度
  177.          Accelerate[2] = ((short)((jiasudu[5]<<8)|jiasudu[4]))/32768.0*16;//Z軸加速度
  178.          printf("x軸加速度:%.3f,Y軸加速度:%.3f,Z軸加速度:%.3f\r\n",Accelerate[0],Accelerate[1],Accelerate[2]);
  179.          delay_ms(10);
  180. }
  181. void Get_Palstance()//獲取角速度
  182. {
  183.    Palstance[0] = ((short)((jiaosudu[1]<<8)|jiaosudu[0]))/32768.0*2000;//X軸角速度
  184.          Palstance[1] = ((short)((jiaosudu[3]<<8)|jiaosudu[2]))/32768.0*2000;//Y軸角速度
  185.          Palstance[2] = ((short)((jiaosudu[5]<<8)|jiaosudu[4]))/32768.0*2000;//Z軸角速度
  186.          printf("x軸角速度:%.2f,Y軸角速度:%.2f,Z軸角速度:%.2f\r\n",Palstance[0],Palstance[1],Palstance[2]);
  187.          delay_ms(10);
  188. }

  189. */

  190.         /*
  191.     key=Remote_Scan();       
  192.                 if(key)
  193.                 {                
  194.       LCD_ShowNum(86,130,pwm1,5,16);                //顯示鍵值                       
  195.                         LCD_ShowNum(86,150,pwm2,5,16);                //顯示鍵值                       
  196.                         LCD_ShowNum(86,170,pwm3,5,16);                //顯示鍵值                       
  197.                         LCD_ShowNum(86,190,pwm4,5,16);                //顯示鍵值                       
  198.                         switch(key)
  199.                         {
  200.                                
  201. ……………………

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

所有資料51hei提供下載:
風力擺.7z (346.31 KB, 下載次數: 94)

評分

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

查看全部評分

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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: av手机免费在线观看 | 亚洲精品在线观看视频 | 盗摄精品av一区二区三区 | 观看av | 国产亚洲人成a在线v网站 | 亚洲精彩免费视频 | 91精品国产一区二区三区 | 国产精品二区三区 | japanhd美女动 | 亚洲国产精品第一区二区 | 成人av电影在线 | 亚洲视频在线观看免费 | 天天影视亚洲综合网 | 国产精品欧美日韩 | 国产无人区一区二区三区 | 国产色在线 | 91精品国产91久久综合桃花 | 国产精品 欧美精品 | 亚洲第一网站 | 色综合国产 | 国内自拍视频在线观看 | 91国在线 | 日韩成人 | 视频一区在线 | 国产欧美一区二区三区在线看 | 国产成人av一区二区三区 | 久久一区二区视频 | 久草免费电影 | 亚洲性视频网站 | 武道仙尊动漫在线观看 | 精品一区二区电影 | 日韩精品久久久 | 日韩视频免费在线 | 国产一级片精品 | 日日草天天干 | 亚洲伊人精品酒店 | 欧美精品在线播放 | 天天夜碰日日摸日日澡 | 91精品国产综合久久香蕉麻豆 | 亚洲中字在线 | 欧美乱操 |