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

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 2162|回復(fù): 2
打印 上一主題 下一主題
收起左側(cè)

stm32風(fēng)力擺源碼 dmp解算姿態(tài)

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:382827 發(fā)表于 2018-11-16 15:04 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
暑假做的風(fēng)力擺,有需要的拿走,基于原子的dmp解算的姿態(tài)

單片機(jī)源程序如下:
  1. #include "mpuiic.h"
  2. #include "delay.h"

  3. //MPU IIC 延時(shí)函數(shù)
  4. void MPU_IIC_Delay(void)
  5. {
  6.         delay_us(2);
  7. }

  8. //初始化IIC
  9. void MPU_IIC_Init(void)
  10. {                                             
  11.   GPIO_InitTypeDef  GPIO_InitStructure;
  12.        
  13.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);//先使能外設(shè)IO PORTB時(shí)鐘
  14.                
  15.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10|GPIO_Pin_11;         // 端口配置
  16.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                  //推挽輸出
  17.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;                 //IO口速度為50MHz
  18.   GPIO_Init(GPIOB, &GPIO_InitStructure);                                         //根據(jù)設(shè)定參數(shù)初始化GPIO
  19.        
  20.   GPIO_SetBits(GPIOB,GPIO_Pin_10|GPIO_Pin_11);                                                 //PB10,PB11 輸出高       

  21. }
  22. //產(chǎn)生IIC起始信號(hào)
  23. void MPU_IIC_Start(void)
  24. {
  25.         MPU_SDA_OUT();     //sda線輸出
  26.         MPU_IIC_SDA=1;                    
  27.         MPU_IIC_SCL=1;
  28.         MPU_IIC_Delay();
  29.         MPU_IIC_SDA=0;//START:when CLK is high,DATA change form high to low
  30.         MPU_IIC_Delay();
  31.         MPU_IIC_SCL=0;//鉗住I2C總線,準(zhǔn)備發(fā)送或接收數(shù)據(jù)
  32. }          
  33. //產(chǎn)生IIC停止信號(hào)
  34. void MPU_IIC_Stop(void)
  35. {
  36.         MPU_SDA_OUT();//sda線輸出
  37.         MPU_IIC_SCL=0;
  38.         MPU_IIC_SDA=0;//STOP:when CLK is high DATA change form low to high
  39.         MPU_IIC_Delay();
  40.         MPU_IIC_SCL=1;
  41.         MPU_IIC_SDA=1;//發(fā)送I2C總線結(jié)束信號(hào)
  42.         MPU_IIC_Delay();                                                                  
  43. }
  44. //等待應(yīng)答信號(hào)到來(lái)
  45. //返回值:1,接收應(yīng)答失敗
  46. //        0,接收應(yīng)答成功
  47. u8 MPU_IIC_Wait_Ack(void)
  48. {
  49.         u8 ucErrTime=0;
  50.         MPU_SDA_IN();      //SDA設(shè)置為輸入  
  51.         MPU_IIC_SDA=1;MPU_IIC_Delay();          
  52.         MPU_IIC_SCL=1;MPU_IIC_Delay();         
  53.         while(MPU_READ_SDA)
  54.         {
  55.                 ucErrTime++;
  56.                 if(ucErrTime>250)
  57.                 {
  58.                         MPU_IIC_Stop();
  59.                         return 1;
  60.                 }
  61.         }
  62.         MPU_IIC_SCL=0;//時(shí)鐘輸出0           
  63.         return 0;  
  64. }
  65. //產(chǎn)生ACK應(yīng)答
  66. void MPU_IIC_Ack(void)
  67. {
  68.         MPU_IIC_SCL=0;
  69.         MPU_SDA_OUT();
  70.         MPU_IIC_SDA=0;
  71.         MPU_IIC_Delay();
  72.         MPU_IIC_SCL=1;
  73.         MPU_IIC_Delay();
  74.         MPU_IIC_SCL=0;
  75. }
  76. //不產(chǎn)生ACK應(yīng)答                    
  77. void MPU_IIC_NAck(void)
  78. {
  79.         MPU_IIC_SCL=0;
  80.         MPU_SDA_OUT();
  81.         MPU_IIC_SDA=1;
  82.         MPU_IIC_Delay();
  83.         MPU_IIC_SCL=1;
  84.         MPU_IIC_Delay();
  85.         MPU_IIC_SCL=0;
  86. }                                                                              
  87. //IIC發(fā)送一個(gè)字節(jié)
  88. //返回從機(jī)有無(wú)應(yīng)答
  89. //1,有應(yīng)答
  90. //0,無(wú)應(yīng)答                          
  91. void MPU_IIC_Send_Byte(u8 txd)
  92. {                        
  93.     u8 t;   
  94.         MPU_SDA_OUT();             
  95.     MPU_IIC_SCL=0;//拉低時(shí)鐘開(kāi)始數(shù)據(jù)傳輸
  96.     for(t=0;t<8;t++)
  97.     {              
  98.         MPU_IIC_SDA=(txd&0x80)>>7;
  99.         txd<<=1;           
  100.                     MPU_IIC_SCL=1;
  101.                     MPU_IIC_Delay();
  102.                     MPU_IIC_SCL=0;       
  103.                     MPU_IIC_Delay();
  104.     }         
  105. }             
  106. //讀1個(gè)字節(jié),ack=1時(shí),發(fā)送ACK,ack=0,發(fā)送nACK   
  107. u8 MPU_IIC_Read_Byte(unsigned char ack)
  108. {
  109.         unsigned char i,receive=0;
  110.         MPU_SDA_IN();//SDA設(shè)置為輸入
  111.     for(i=0;i<8;i++ )
  112.         {
  113.         MPU_IIC_SCL=0;
  114.         MPU_IIC_Delay();
  115.                 MPU_IIC_SCL=1;
  116.         receive<<=1;
  117.         if(MPU_READ_SDA)receive++;   
  118.                 MPU_IIC_Delay();
  119.     }                                         
  120.     if (!ack)
  121.         MPU_IIC_NAck();//發(fā)送nACK
  122.     else
  123.         MPU_IIC_Ack(); //發(fā)送ACK   
  124.     return receive;
  125. }
復(fù)制代碼

所有資料51hei提供下載:
風(fēng)力擺.rar (364.67 KB, 下載次數(shù): 23)


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

使用道具 舉報(bào)

沙發(fā)
ID:1 發(fā)表于 2018-11-16 17:27 | 只看該作者
補(bǔ)全原理圖或者詳細(xì)說(shuō)明一下電路連接即可獲得100+黑幣
回復(fù)

使用道具 舉報(bào)

板凳
ID:259503 發(fā)表于 2019-7-12 19:35 | 只看該作者
可以,很好的,謝謝l
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 成人国产精品一级毛片视频毛片 | 999久久久 | 青草久久免费视频 | 亚洲成年影院 | 一区二区在线不卡 | 亚洲成人精品国产 | 91免费在线看 | 色婷婷av一区二区三区软件 | 色综合一区二区 | 日韩成人性视频 | 欧美亚洲视频在线观看 | 成人av免费网站 | 免费在线观看一区二区 | a在线观看 | 欧美视频二区 | 91精品久久久久 | 国内精品成人 | а_天堂中文最新版地址 | 国产999精品久久久久久 | 国产在线一区二区 | 日本不卡一区二区三区 | 高清18麻豆 | 亚洲欧美视频 | 99热这里有精品 | 成年网站在线观看 | 国产精品久久久久久久久久久久 | 欧美一级欧美一级在线播放 | 欧美高清视频一区 | 欧美一区二区免费电影 | 91免费小视频 | 蜜臀久久| 亚洲视频一区在线观看 | 国产精久久久久久久妇剪断 | 久久久青草婷婷精品综合日韩 | 亚洲国产成人精品久久 | 精品一区电影 | 国产99热精品 | 日韩欧美国产一区二区 | 91色在线| 久久一及片 | 中文字幕不卡 |