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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 10822|回復: 2
收起左側

MLX90614 GY-906紅外測距單片機與ARDUINO源碼和資料下載

[復制鏈接]
ID:341332 發表于 2018-5-30 13:55 | 顯示全部樓層 |閱讀模式
內含ARDUINO與51單片機CODE.
GY-906紅外測距電路原理圖如下:
0.png

MLX90614系列紅外測溫模塊的原理及應用
南京航空航天大學  曾德志
摘要:  MLX90614 系列模塊是一組通用的紅外測溫模塊。在出廠前該模塊已進行校驗及線性化,具有非接觸、體積小、精度高,成本低等優點。被測目標溫度和環境溫度能通過單通道輸出,并有兩種輸出接口,適合于汽車空調、室內暖氣、家用電器、手持設備以及醫療設備應用等。本文以MLX90614AAA為例介紹其原理和應用。

1 引言
一般來說,測溫方式可分為接觸式和非接觸式,接觸式測溫只能測量被測物體與測溫傳感器達到熱平衡后的溫度,所以響應時間長,且極易受環境溫度的影響;而紅外測溫是根據被測物體的紅外輻射能量來確定物體的溫度,不與被測物體接觸,具有影響動被測物體溫度分布場,溫度分辨率高、響應速度快、測溫范圍廣、不受測溫上限的限制、穩定性好等特點,近年來在家庭自動化、汽車電子、航空和軍事上得到越來越廣泛的應用。

2  測溫原理概述
物體紅外輻射能量的大小和波長的分布與其表面溫度關系密切。因此,通過對物體自身紅外輻射的測量,能準確地確定其表面溫度,紅外測溫就是利用這一原理測量溫度的。紅外測溫器由光學系統、光電探測器、信號放大器和信號處理及輸出等部分組成。光學系統匯聚其視場內的目標紅外輻射能量,視場的大小由測溫儀的光學零件及其位置確定。紅外能量聚焦在光電探測器上并轉變為相應的電信號。該信號經過放大器和信號處理電路,并按照儀器內的算法和目標發射率校正后轉變為被測目標的溫度值。 PWM 的全稱是 Pulse Width Modulation(脈沖寬度調制)即通過調節脈沖的周期、寬度,以達到變壓、變頻的目的,數字式脈寬調制方式中,數字是控制信號,通過改變高低電平數的比值達到改變占空比的目的,PWM 控制電路在開關穩壓電源、不間斷電源(UPS)以及直流電機調速,交流電機變頻調速等控制電路中有著廣泛應用。
   SMBus (System Management Bus,)是 1995 年由intel 公司提出的一種高效同步串行總線,SMBus 只有兩根信號線:雙向數據線和時鐘信號線,容許 CPU 與各種外圍接口器件以串行方式進行通信、交換信息,即可以提高傳輸速度也可以減小器件的資源占用,另外即使在沒有SMBus 接口的單片機上也可利用軟件進行模擬。
Melexis 公司生產的 MLX90614 系列測溫模塊是應用非常方便的紅外測溫裝置,其所有的模塊都在出廠前進行了校驗,并且可以直接輸出線性或準線性信號,具有很好的互換性,免去了復雜的校正過程。
     該模塊以 81101 熱電元件作為紅外感應部分。輸出是被測物體溫度(TO)與傳感器自身溫度(Ta)共同作用的結果,理想情況下熱電元件的輸出電壓為:

其中溫度單位均為 Kelvin,A為元件的靈敏度常數。
目標溫度和環境溫度由 81101 內置的熱電偶測定測量,從 81101 中輸出的兩路溫度信號分別經內部 MLX90302 器件上高性能、低噪聲的斬波穩態放大器放大再經一個 17-bit 的模數轉換器(ADC)和強大的數字信號處理(DSP)單元后輸出。  
該系列模塊的溫度解析度可達 0.01°C,體積小巧,被測目標和環境溫度能通過單通道(由 MLX90302 內的狀態機控制)輸出,有兩種輸出方式:PWM 輸出、可編程 SMBus 輸出,適于多種應用環境,下面以 MLX90614 為例,重點介紹其特性和使用方法。

通過 SMBus 編程可以更改模塊 EEPROM 內的預設值并按照應用要求進行配置,并可以讀出 EEPROM 內的配置信息;還可以讀出模塊 RAM 內溫度等數據。  
MLX90614有適用于 3伏和 5 伏電源操作的兩種類型。由于3 伏型其小于 2 毫安的電流消耗,它非常適用于手提裝置和電池動力裝置。為此,傳感器也具有一個節能“休眠”模式,此時電流消耗可低于 2 毫安。對于 12 伏汽車電池直接供電的情況,5 伏型包含的電子部件可與幾個外部元件一起在較高電壓下運行。
3 MLX90614簡介
3.1 MLX90614 管腳
0.png

單片機源程序如下:
  1. #include"at89x52.h"
  2. #include"intrins.h"
  3. //************************************
  4. #define  uint  unsigned int
  5. #define  uchar unsigned char
  6. #define  Nack_counter  10
  7. //************** 端口定義**************
  8. //LCD 控制線接口
  9. uchar flag1;
  10. sbit  RS=P0^7;
  11. sbit  RW=P0^6;
  12. sbit  LCDE=P0^5;
  13. //mlx90614 端口定義
  14. sbit  SCL=P1^6;// 時鐘線
  15. sbit  SDA=P1^7;// 數據線
  16. //************ 數據定義****************
  17. bdata uchar flag;//可位尋址數據
  18. sbit bit_out=flag^7;
  19. sbit bit_in=flag^0;
  20. uchar DataH,DataL,Pecreg;
  21. //************ 函數聲明*****************************************
  22. void   start_bit();                 //MLX90614 發起始位子程序
  23. void   stop_bit();                 //MLX90614發結束位子程序
  24. uchar  rx_byte(void);              //MLX90614 接收字節子程序
  25. void   send_bit(void);             //MLX90614發送位子程序
  26. void   tx_byte(uchar dat_byte);     //MLX90614 接收字節子程序
  27. void   receive_bit(void);           //MLX90614接收位子程序
  28. void   delay(uint N);              //延時程序
  29. uint   memread(void);             // 讀溫度數據
  30. void   init1602(void);        //LCD 初始化子程序
  31. void   chk_busy_flg(void);         //LCD 判斷忙子程序
  32. void   dis_cmd_wrt(uchar cmd);     //LCD 寫命令子程序
  33. void   dis_dat_wrt(uchar dat);       //LCD 寫數據子程序
  34. void   display(uint Tem);           // 顯示子程序
  35. //*************主函數*******************************************
  36. void main()
  37. {
  38. uint Tem;
  39. //函數部分
  40. SCL=1;SDA=1;_nop_();
  41. _nop_();_nop_();_nop_();
  42. SCL=0;
  43. delay(1000);
  44. SCL=1;
  45. init1602();
  46. while(1)
  47. {
  48.    Tem=memread();
  49.    display(Tem);
  50.    delay(20);
  51. }
  52. }
  53. //*********輸入轉換并顯示*********
  54. void display(uint Tem)
  55. {
  56. uint T,a,b;
  57. T=Tem*2;
  58.   dis_cmd_wrt(0x01);//清屏
  59. if(T>=27315)
  60. {
  61.    T=T-27315;
  62.    a=T/100;
  63.    b=T-a*100;
  64. //---------------------------
  65.    if(a>=100)
  66.    {
  67.     dis_dat_wrt(0x30+a/100);
  68.     a=a%100;
  69.     dis_dat_wrt(0x30+a/10);
  70.     a=a%10;
  71.     dis_dat_wrt(0x30+a);
  72.    }
  73.    else if(a>=10)
  74.    {
  75.     dis_dat_wrt(0x30+a/10);
  76.     a=a%10;
  77.     dis_dat_wrt(0x30+a);
  78.    }
  79.    else
  80.    {
  81.     dis_dat_wrt(0x30+a);
  82.    }
  83.    dis_dat_wrt(0x2e);// 顯示點
  84.    //---------------------------
  85.   if(b>=10)
  86.   {
  87.     dis_dat_wrt(0x30+b/10);
  88. //    b=b%10;
  89. //    dis_dat_wrt(0x30+b);
  90.   }
  91.   else
  92.   {
  93.     dis_dat_wrt(0x30);
  94. //    dis_dat_wrt(0x30+b);
  95.   }
  96. }
  97. //==========
  98. else
  99. {
  100.   T=27315-T;
  101.   a=T/100;
  102.     b=T-a*100;
  103.   dis_dat_wrt(0x2d);
  104. //--------------------------
  105.   if(a>=10)
  106.   {
  107.     dis_dat_wrt(0x30+a/10);
  108.     a=a%10;
  109.     dis_dat_wrt(0x30+a);
  110.   }
  111.   else
  112.   {
  113.     dis_dat_wrt(0x30+a);
  114.   }
  115.   dis_dat_wrt(0x2e);//顯示點
  116. //--------------------------
  117.   if(b>=10)
  118.   {
  119.     dis_dat_wrt(0x30+b/10);
  120.     b=b%10;
  121.     dis_dat_wrt(0x30+b);
  122.   }
  123.   else
  124.   {
  125.     dis_dat_wrt(0x30);
  126.     dis_dat_wrt(0x30+b);
  127.   }
  128. }
  129. }

  130. //************************************
  131. void   start_bit(void)
  132. {
  133.    SDA=1;
  134.    _nop_();_nop_();_nop_();_nop_();_nop_();
  135.    SCL=1;
  136.    _nop_();_nop_();_nop_();_nop_();_nop_();
  137.    SDA=0;
  138.    _nop_();_nop_();_nop_();_nop_();_nop_();
  139.    SCL=0;
  140.    _nop_();_nop_();_nop_();_nop_();_nop_();

  141. }
  142. //------------------------------
  143. void   stop_bit(void)
  144. {

  145.    SCL=0;
  146.    _nop_();_nop_();_nop_();_nop_();_nop_();
  147.    SDA=0;
  148.    _nop_();_nop_();_nop_();_nop_();_nop_();
  149.    SCL=1;
  150.    _nop_();_nop_();_nop_();_nop_();_nop_();
  151.    SDA=1;
  152. }
  153. //--------- 發送一個字節---------
  154. void  tx_byte(uchar dat_byte)
  155. {
  156.    char i,n,dat;
  157.    n=Nack_counter;
  158. TX_again:
  159.    dat=dat_byte;
  160.    for(i=0;i<8;i++)
  161.    {
  162.      if(dat&0x80)
  163.       bit_out=1;
  164.      else
  165.       bit_out=0;
  166.      send_bit();
  167.      dat=dat<<1;
  168.    }
  169.    
  170.       receive_bit();
  171.    if(bit_in==1)
  172.    {
  173.     stop_bit();
  174.     if(n!=0)
  175.     {n--;goto Repeat;}
  176.     else
  177.      goto exit;
  178.    }
  179.    else
  180.     goto exit;
  181. Repeat:
  182.     start_bit();
  183.     goto TX_again;
  184. exit: ;
  185. }
  186. //-----------發送一個位---------
  187. void  send_bit(void)
  188. {
  189.   if(bit_out==0)
  190.   
  191.        SDA=0;
  192.   else
  193.      SDA=1;
  194.   _nop_();
  195.   SCL=1;
  196.   _nop_();_nop_();_nop_();_nop_();
  197.   _nop_();_nop_();_nop_();_nop_();
  198.   SCL=0;
  199.   _nop_();_nop_();_nop_();_nop_();
  200.   _nop_();_nop_();_nop_();_nop_();
  201. }
  202. //---------- 接收一個字節--------
  203. uchar rx_byte(void)
  204. {
  205.   uchar i,dat;
  206.   dat=0;
  207.   for(i=0;i<8;i++)
  208.   {
  209.     dat=dat<<1;
  210.     receive_bit();
  211.     if(bit_in==1)
  212.      dat=dat+1;
  213.   }
  214.   send_bit();
  215.   return dat;
  216. }

  217. //---------- 接收一個位----------
  218. void receive_bit(void)
  219. {
  220.   SDA=1;bit_in=1;
  221.   SCL=1;
  222.   _nop_();_nop_();_nop_();_nop_();
  223.   _nop_();_nop_();_nop_();_nop_();
  224.   bit_in=SDA;
  225.   _nop_();
  226.   SCL=0;
  227.   _nop_();_nop_();_nop_();_nop_();
  228.   _nop_();_nop_();_nop_();_nop_();
  229. }
  230. //------------ 延時--------------
  231. void   delay(uint N)
  232. {
  233.   uint i;
  234.   for(i=0;i<N;i++)
  235.   
  236.      _nop_();
  237. }
  238. //------------------------------
  239. uint memread(void)
  240. {
  241.   start_bit();
  242.   tx_byte(0xB4);  //Send SlaveAddress ==============================
  243.   //tx_byte(0x00);
  244.   tx_byte(0x07);  //Send Command
  245.   //------------
  246.   start_bit();
  247.   tx_byte(0x01);
  248.   bit_out=0;
  249.   DataL=rx_byte();
  250.   bit_out=0;
  251.   DataH=rx_byte();
  252.   bit_out=1;
  253.   Pecreg=rx_byte();
  254.   stop_bit();
  255.   return(DataH*256+DataL);
  256. }
  257. //******************LCD 顯示子函數***********************
  258. void init1602(void)        // 初始化LCD
  259. {
  260.    dis_cmd_wrt(0x01);
  261.    dis_cmd_wrt(0x0c);
  262.    dis_cmd_wrt(0x06);
  263.    dis_cmd_wrt(0x38);
  264.    
  265.    }

  266. void chk_busy_flg(void) //LCD 忙標志判斷
  267. {
  268.    flag1=0x80;
  269.   while(flag1&0x80)
  270. {
  271.    P2=0xff;
  272.    RS=0;
  273.    RW=1;
  274.    LCDE=1;
  275. ……………………

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

0.png

所有資料51hei提供下載:

GY-906資料.rar (2.26 MB, 下載次數: 105)


回復

使用道具 舉報

ID:343923 發表于 2018-6-3 21:19 | 顯示全部樓層
你好!我想問一下這個GY906 和單個MLX90614的區別在哪里?使用還是要加上拉電阻還是怎樣呢?新人求解!
回復

使用道具 舉報

ID:212262 發表于 2018-11-25 22:00 | 顯示全部樓層
同樓上,想問GY906和MLX90614區別
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 九九看片 | 99这里只有精品 | 中文字幕在线免费观看 | 日本不卡在线视频 | 特黄级国产片 | 9久9久| 亚洲va国产日韩欧美精品色婷婷 | 国产精品久久久久久久久久久久冷 | 国产视频在线一区二区 | 欧美色影院 | 婷婷成人在线 | 狠狠爱免费视频 | 久久久久久亚洲 | 欧美激情久久久 | 一级片视频免费观看 | www.日日操| 久久久久国产一区二区三区 | 国产成人精品一区二 | 色视频网站| 国产精品欧美一区二区三区 | 欧美一级免费看 | 日日天天| 国产在线一区二 | 日本天天操| 天天人人精品 | 日本一区二区三区免费观看 | 日韩三 | 亚洲日本视频 | 在线观看av网站永久 | 婷婷国产一区二区三区 | 欧美激情国产精品 | 69精品久久久久久 | 91豆花视频 | 国产成人免费视频网站视频社区 | www.国产精品 | 在线视频亚洲 | 黄色一级免费看 | 欧美成人自拍 | 99精品视频一区二区三区 | 两性午夜视频 | av第一页|