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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

HMC5883 GY-271三軸電子指南針加速度各平臺源碼與中文資料下載

[復制鏈接]
跳轉到指定樓層
樓主


SMT后檢測判定標準建議:
可用下列方式來判斷芯片是否正常。判斷標準在空曠的環境下兩次讀數據寄存器的值, 其結果表現狀況:絕對值大致相同, 符號相反。  

1.    0x20 = 40,  0x21=1,  0x0B=1,   0x09=1D
2.    Wait 10ms
3.    0x09=1C    ( enter standby mode)
4.    0x0B=0      (turn off set/reset)
5.    0x09=12    (self-test mode,  do set)
6.    Wait 10ms and check whether 0x09=10 (wait until selftest done)
7.    0x09=1D
8.    Read x/y/z data  ( data A )
9.    0x09=13     (self-test mode,  do reset)
10.    Wait 10ms  and check whether 0x09=10 (wait until selftest done)
11.    0x09=1D
12.    Read x/y/z data  ( data B )

濾波代碼
  1. //8個數據窗口均值濾波:
  2.          AccsumX = 0;
  3.          AccsumY = 0;
  4.          AccsumZ = 0;
  5.          for( i=0;i<FILTERNUM-1;i++)
  6.          {
  7.                    fAccX[i] = fAccX[i+1];
  8.                    fAccY[i] = fAccY[i+1];
  9.                    fAccZ[i] = fAccZ[i+1];
  10.          }

  11.          fAccX[FILTERNUM-1] = acc->data[0];
  12.          fAccY[FILTERNUM-1] = acc->data[1];
  13.          fAccZ[FILTERNUM-1] = acc->data[2];

  14.          for( i=0;i<FILTERNUM;i++)
  15.          {
  16.                    AccsumX += fAccX[i];
  17.                    AccsumY += fAccY[i];
  18.                    AccsumZ += fAccZ[i];
  19.          }
  20.          acc->data[0] = AccsumX / FILTERNUM;
  21.          acc->data[1] = AccsumY / FILTERNUM;
  22.          acc->data[2] = AccsumZ / FILTERNUM;
復制代碼

單片機源程序如下:
  1. //***************************************
  2. // HMC5883 51串口測試程序
  3. // 使用單片機STC89C51
  4. // 晶振:11.0592M
  5. // 顯示:PC串口
  6. // 編譯環境 Keil uVision2
  7. // 參考宏晶網站24c04通信程序
  8. // 時間:2011年3月1日
  9. //****************************************
  10. #include  <REG51.H>       
  11. #include  <math.h>    //Keil library  
  12. #include  <stdio.h>   //Keil library       
  13. #include  <INTRINS.H>
  14. #define   uchar unsigned char
  15. #define   uint  unsigned int       
  16. //使用的端口,請按照以下接線
  17. #define DataPort P0        //LCD1602數據端口
  18. sbit        SCL=P1^0;      //IIC時鐘引腳定義
  19. sbit        SDA=P1^1;      //IIC數據引腳定義


  20. #define        SlaveAddress   0x3C          //定義器件5883在IIC總線中的從地址
  21. typedef unsigned char BYTE;
  22. typedef unsigned short WORD;

  23. BYTE BUF[8];                         //接收數據緩存區             
  24. uchar ge,shi,bai,qian,wan;           //顯示變量
  25. int  dis_data;                       //變量
  26. //************

  27. //************
  28. void delay(unsigned int k);
  29. void Init_HMC5883(void);            //初始化5883
  30. void conversion(uint temp_data);

  31. void  Single_Write_HMC5883(uchar REG_Address,uchar REG_data);   //單個寫入數據
  32. //uchar Single_Read_HMC5883(uchar REG_Address);                   //單個讀取內部寄存器數據
  33. void  Multiple_Read_HMC5883();                                  //連續的讀取內部寄存器數據
  34. //以下是模擬iic使用函數-------------
  35. void Delay5us();
  36. void Delay5ms();
  37. void HMC5883_Start();
  38. void HMC5883_Stop();
  39. void HMC5883_SendACK(bit ack);
  40. bit  HMC5883_RecvACK();
  41. void HMC5883_SendByte(BYTE dat);
  42. BYTE HMC5883_RecvByte();
  43. void HMC5883_ReadPage();
  44. void HMC5883_WritePage();
  45. //-----------------------------------

  46. //*********************************************
  47. //串口初始化
  48. //9600 bps @ 11.059 MHz
  49. void init_uart()
  50. {
  51.         TMOD=0x21;                               
  52.         TH1=0xfd;                               
  53.         TL1=0xfd;                               
  54.         SCON=0x50;
  55.         PS=1;      //串口中斷設為高優先級別
  56.         TR0=1;           //啟動定時器                       
  57.         TR1=1;
  58.         ET0=1;     //打開定時器0中斷                       
  59.         ES=1;       
  60. }

  61. //*********串口數據發送******************
  62. void  SeriPushSend(uchar send_data)
  63. {
  64.     SBUF=send_data;  
  65.         while(!TI);TI=0;          
  66. }
  67. //*********************************************************
  68. void conversion(uint temp_data)  
  69. {  
  70.     wan=temp_data/10000+0x30 ;
  71.     temp_data=temp_data%10000;   //取余運算
  72.         qian=temp_data/1000+0x30 ;
  73.     temp_data=temp_data%1000;    //取余運算
  74.     bai=temp_data/100+0x30   ;
  75.     temp_data=temp_data%100;     //取余運算
  76.     shi=temp_data/10+0x30    ;
  77.     temp_data=temp_data%10;      //取余運算
  78.     ge=temp_data+0x30;        
  79. }

  80. /*******************************/
  81. void delay(unsigned int k)       
  82. {                                               
  83. unsigned int i,j;                               
  84. for(i=0;i<k;i++)
  85. {                       
  86. for(j=0;j<121;j++)                       
  87. {;}}                                               
  88. }
  89.        

  90. /**************************************
  91. 延時5微秒(STC90C52RC@12M)
  92. 不同的工作環境,需要調整此函數,注意時鐘過快時需要修改
  93. 當改用1T的MCU時,請調整此延時函數
  94. **************************************/
  95. void Delay5us()
  96. {
  97.     _nop_();_nop_();_nop_();_nop_();
  98.     _nop_();_nop_();_nop_();_nop_();
  99.         _nop_();_nop_();_nop_();_nop_();
  100.         _nop_();_nop_();_nop_();_nop_();
  101.     _nop_();_nop_();_nop_();_nop_();
  102. }

  103. /**************************************
  104. 延時5毫秒(STC90C52RC@12M)
  105. 不同的工作環境,需要調整此函數
  106. 當改用1T的MCU時,請調整此延時函數
  107. **************************************/
  108. void Delay5ms()
  109. {
  110.     WORD n = 560;

  111.     while (n--);
  112. }

  113. /**************************************
  114. 起始信號
  115. **************************************/
  116. void HMC5883_Start()
  117. {
  118.     SDA = 1;                    //拉高數據線
  119.     SCL = 1;                    //拉高時鐘線
  120.     Delay5us();                 //延時
  121.     SDA = 0;                    //產生下降沿
  122.     Delay5us();                 //延時
  123.     SCL = 0;                    //拉低時鐘線
  124. }

  125. /**************************************
  126. 停止信號
  127. **************************************/
  128. void HMC5883_Stop()
  129. {
  130.     SDA = 0;                    //拉低數據線
  131.     SCL = 1;                    //拉高時鐘線
  132.     Delay5us();                 //延時
  133.     SDA = 1;                    //產生上升沿
  134.     Delay5us();                 //延時
  135. }

  136. /**************************************
  137. 發送應答信號
  138. 入口參數:ack (0:ACK 1:NAK)
  139. **************************************/
  140. void HMC5883_SendACK(bit ack)
  141. {
  142.     SDA = ack;                  //寫應答信號
  143.     SCL = 1;                    //拉高時鐘線
  144.     Delay5us();                 //延時
  145.     SCL = 0;                    //拉低時鐘線
  146.     Delay5us();                 //延時
  147. }

  148. /**************************************
  149. 接收應答信號
  150. **************************************/
  151. bit HMC5883_RecvACK()
  152. {
  153.     SCL = 1;                    //拉高時鐘線
  154.     Delay5us();                 //延時
  155.     CY = SDA;                   //讀應答信號
  156.     SCL = 0;                    //拉低時鐘線
  157.     Delay5us();                 //延時

  158.     return CY;
  159. }

  160. /**************************************
  161. 向IIC總線發送一個字節數據
  162. **************************************/
  163. void HMC5883_SendByte(BYTE dat)
  164. {
  165.     BYTE i;

  166.     for (i=0; i<8; i++)         //8位計數器
  167.     {
  168.         dat <<= 1;              //移出數據的最高位
  169.         SDA = CY;               //送數據口
  170.         SCL = 1;                //拉高時鐘線
  171.         Delay5us();             //延時
  172.         SCL = 0;                //拉低時鐘線
  173.         Delay5us();             //延時
  174.     }
  175.     HMC5883_RecvACK();
  176. }

  177. /**************************************
  178. 從IIC總線接收一個字節數據
  179. **************************************/
  180. BYTE HMC5883_RecvByte()
  181. {
  182.     BYTE i;
  183.     BYTE dat = 0;

  184.     SDA = 1;                    //使能內部上拉,準備讀取數據,
  185.     for (i=0; i<8; i++)         //8位計數器
  186.     {
  187.         dat <<= 1;
  188.         SCL = 1;                //拉高時鐘線
  189.         Delay5us();             //延時
  190.         dat |= SDA;             //讀數據               
  191.         SCL = 0;                //拉低時鐘線
  192.         Delay5us();             //延時
  193.     }
  194.     return dat;
  195. }

  196. //***************************************************

  197. void Single_Write_HMC5883(uchar REG_Address,uchar REG_data)
  198. {
  199.     HMC5883_Start();                  //起始信號
  200.     HMC5883_SendByte(SlaveAddress);   //發送設備地址+寫信號
  201.     HMC5883_SendByte(REG_Address);    //內部寄存器地址,請參考中文pdf
  202.     HMC5883_SendByte(REG_data);       //內部寄存器數據,請參考中文pdf
  203.     HMC5883_Stop();                   //發送停止信號
  204. }
  205. /*
  206. //********單字節讀取內部寄存器*************************
  207. uchar Single_Read_HMC5883(uchar REG_Address)
  208. {  uchar REG_data;
  209.     HMC5883_Start();                          //起始信號
  210.     HMC5883_SendByte(SlaveAddress);           //發送設備地址+寫信號
  211.     HMC5883_SendByte(REG_Address);                   //發送存儲單元地址,從0開始       
  212.     HMC5883_Start();                          //起始信號
  213.     HMC5883_SendByte(SlaveAddress+1);         //發送設備地址+讀信號
  214.     REG_data=HMC5883_RecvByte();              //讀出寄存器數據
  215.         HMC5883_SendACK(1);   
  216.         HMC5883_Stop();                           //停止信號
  217.     return REG_data;
  218. }
  219. */
  220. //******************************************************
  221. //
  222. //連續讀出HMC5883內部角度數據,地址范圍0x3~0x5
  223. //
  224. //******************************************************
  225. void Multiple_read_HMC5883(void)
  226. {   uchar i;
  227.     HMC5883_Start();                          //起始信號
  228.     HMC5883_SendByte(SlaveAddress);           //發送設備地址+寫信號
  229.     HMC5883_SendByte(0x03);                   //發送存儲單元地址,從0x3開始       
  230.     HMC5883_Start();                          //起始信號
  231.     HMC5883_SendByte(SlaveAddress+1);         //發送設備地址+讀信號
  232.          for (i=0; i<7; i++)                      //連續讀取6個地址數據,存儲中BUF
  233.     {
  234.         BUF[i] = HMC5883_RecvByte();          //BUF[0]存儲0x32地址中的數據
  235.         if (i == 6)
  236.         {
  237.            HMC5883_SendACK(1);                //最后一個數據需要回NOACK
  238.         }
  239.         else
  240.         {
  241.           HMC5883_SendACK(0);                //回應ACK
  242.        }
  243.    }
  244.     HMC5883_Stop();                          //停止信號
  245.     Delay5ms();
  246. }

  247. //初始化HMC5883,根據需要請參考pdf進行修改****
  248. void Init_HMC5883()
  249. {
  250.      Single_Write_HMC5883(0x02,0x00);  //
  251.          Single_Write_HMC5883(0x01,0xE0);  //
  252. }
  253. //*********************************************************
  254. //主程序********
  255. //*********************************************************
  256. ……………………

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

所有資料51hei提供下載:
HW-127-246-通用資料-國產QMC5883-進口HMC5883-GY-271三軸電子指南針加速度資料.rar (3.12 MB, 下載次數: 53)



評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:587615 發表于 2019-7-23 21:17 | 只看該作者
有沒有32的
回復

使用道具 舉報

板凳
ID:1108858 發表于 2024-1-10 21:56 | 只看該作者
good,很好的資料
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产精品久久久久久吹潮 | 宅女噜噜66国产精品观看免费 | 天天久久 | 国产精品2区| 亚洲欧美日韩精品久久亚洲区 | 久久综合国产 | 日本一区二区高清不卡 | 久久成人在线视频 | 精品国产乱码久久久久久蜜臀 | 久久69精品久久久久久国产越南 | 在线三级电影 | 国产成人精品高清久久 | 免费在线一区二区三区 | 成人精品国产免费网站 | 欧美日韩在线视频一区 | 久久午夜国产精品www忘忧草 | 精品视频久久久久久 | 久久久久久久国产精品影院 | 色婷婷久久 | 九九看片 | 欧美国产日韩在线观看成人 | 极品电影院 | 欧美在线视频免费 | 一区二区高清在线观看 | 亚洲精品一区中文字幕乱码 | 99国产视频 | a级在线免费观看 | 一级电影免费看 | 日本免费一区二区三区视频 | 在线91| 亚洲精品一区久久久久久 | 国产成人一区 | av一区二区三区四区 | 男人久久天堂 | 久久99精品久久久 | 欧美精品一区二区在线观看 | 欧美成人精品在线观看 | 爱综合| 成人午夜激情 | 欧洲免费毛片 | 91精品国产综合久久久久久丝袜 |