亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? shtxx(c51).c

?? 基于C51的SHTXX溫濕度傳感器的驅動程序
?? C
字號:
/*********************************************************************************** 
Project:          SHTxx demo program (V2.1) 
Filename:         SHTxx_Sample_Code.c     

Prozessor:        80C51 family 
Compiler:         Keil Version 6.14 

Autor:            MST 
Copyrigth:        (c) Sensirion AG       
***********************************************************************************/ 

#include <AT89s53.h> //Microcontroller specific library, e.g. port definitions 
#include <intrins.h> //Keil library (is used for _nop()_ operation)   
#include <math.h>    //Keil library   
#include <stdio.h>   //Keil library 

typedef union  
{ unsigned int i; 
  float f; 
} value; 

//---------------------------------------------------------------------------------- 
// modul-var 
//---------------------------------------------------------------------------------- 
enum {TEMP,HUMI}; 

#define        DATA           P1_1 
#define        SCK           P1_0 

#define noACK 0 
#define ACK   1 
                            //adr  command  r/w 
#define STATUS_REG_W 0x06   //000   0011    0 
#define STATUS_REG_R 0x07   //000   0011    1 
#define MEASURE_TEMP 0x03   //000   0001    1 
#define MEASURE_HUMI 0x05   //000   0010    1 
#define RESET        0x1e   //000   1111    0 

//---------------------------------------------------------------------------------- 
char s_write_byte(unsigned char value) 
//---------------------------------------------------------------------------------- 
// writes a byte on the Sensibus and checks the acknowledge  
{  
  unsigned char i,error=0;   
  for (i=0x80;i>0;i/=2)             //shift bit for masking 
  { if (i & value) DATA=1;          //masking value with i , write to SENSI-BUS 
    else DATA=0;                         
    SCK=1;                          //clk for SENSI-BUS 
    _nop_();_nop_();_nop_();        //pulswith approx. 5 us           
    SCK=0; 
  } 
  DATA=1;                           //release DATA-line 
  SCK=1;                            //clk #9 for ack  
  error=DATA;                       //check ack (DATA will be pulled down by SHT11) 
  SCK=0;         
  return error;                     //error=1 in case of no acknowledge 
} 

//---------------------------------------------------------------------------------- 
char s_read_byte(unsigned char ack) 
//---------------------------------------------------------------------------------- 
// reads a byte form the Sensibus and gives an acknowledge in case of "ack=1"  
{  
  unsigned char i,val=0; 
  DATA=1;                           //release DATA-line 
  for (i=0x80;i>0;i/=2)             //shift bit for masking 
  { SCK=1;                          //clk for SENSI-BUS 
    if (DATA) val=(val | i);        //read bit   
    SCK=0;                                            
  } 
  DATA=!ack;                        //in case of "ack==1" pull down DATA-Line 
  SCK=1;                            //clk #9 for ack 
  _nop_();_nop_();_nop_();          //pulswith approx. 5 us  
  SCK=0;                                                     
  DATA=1;                           //release DATA-line 
  return val; 
} 

//---------------------------------------------------------------------------------- 
void s_transstart(void) 
//---------------------------------------------------------------------------------- 
// generates a transmission start  
//       _____         ________ 
// DATA:      |_______| 
//           ___     ___ 
// SCK : ___|   |___|   |______ 
{   
   DATA=1; SCK=0;                   //Initial state 
   _nop_(); 
   SCK=1; 
   _nop_(); 
   DATA=0; 
   _nop_(); 
   SCK=0;   
   _nop_();_nop_();_nop_(); 
   SCK=1; 
   _nop_(); 
   DATA=1;                    
   _nop_(); 
   SCK=0;                    
} 

//---------------------------------------------------------------------------------- 
void s_connectionreset(void) 
//---------------------------------------------------------------------------------- 
// communication reset: DATA-line=1 and at least 9 SCK cycles followed by transstart 
//       _____________________________________________________         ________ 
// DATA:                                                      |_______| 
//          _    _    _    _    _    _    _    _    _        ___     ___ 
// SCK : __| |__| |__| |__| |__| |__| |__| |__| |__| |______|   |___|   |______ 
{   
  unsigned char i;  
  DATA=1; SCK=0;                    //Initial state 
  for(i=0;i<9;i++)                  //9 SCK cycles 
  { SCK=1; 
    SCK=0; 
  } 
  s_transstart();                   //transmission start 
} 

//---------------------------------------------------------------------------------- 
char s_softreset(void) 
//---------------------------------------------------------------------------------- 
// resets the sensor by a softreset  
{  
  unsigned char error=0;   
  s_connectionreset();              //reset communication 
  error+=s_write_byte(RESET);       //send RESET-command to sensor 
  return error;                     //error=1 in case of no response form the sensor 
} 

//---------------------------------------------------------------------------------- 
char s_read_statusreg(unsigned char *p_value, unsigned char *p_checksum) 
//---------------------------------------------------------------------------------- 
// reads the status register with checksum (8-bit) 
{  
  unsigned char error=0; 
  s_transstart();                   //transmission start 
  error=s_write_byte(STATUS_REG_R); //send command to sensor 
  *p_value=s_read_byte(ACK);        //read status register (8-bit) 
  *p_checksum=s_read_byte(noACK);   //read checksum (8-bit)   
  return error;                     //error=1 in case of no response form the sensor 
} 

//---------------------------------------------------------------------------------- 
char s_write_statusreg(unsigned char *p_value) 
//---------------------------------------------------------------------------------- 
// writes the status register with checksum (8-bit) 
{  
  unsigned char error=0; 
  s_transstart();                   //transmission start 
  error+=s_write_byte(STATUS_REG_W);//send command to sensor 
  error+=s_write_byte(*p_value);    //send value of status register 
  return error;                     //error>=1 in case of no response form the sensor 
} 
                                                             
//---------------------------------------------------------------------------------- 
char s_measure(unsigned char *p_value, unsigned char *p_checksum, unsigned char mode) 
//---------------------------------------------------------------------------------- 
// makes a measurement (humidity/temperature) with checksum 
{  
  unsigned error=0; 
  unsigned int i; 

  s_transstart();                   //transmission start 
  switch(mode){                     //send command to sensor 
    case TEMP        : error+=s_write_byte(MEASURE_TEMP); break; 
    case HUMI        : error+=s_write_byte(MEASURE_HUMI); break; 
    default     : break;          
  } 
  for (i=0;i<65535;i++) if(DATA==0) break; //wait until sensor has finished the measurement 
  if(DATA) error+=1;                // or timeout (~2 sec.) is reached 
  *(p_value)  =s_read_byte(ACK);    //read the first byte (MSB) 
  *(p_value+1)=s_read_byte(ACK);    //read the second byte (LSB) 
  *p_checksum =s_read_byte(noACK);  //read checksum 
  return error; 
} 

//---------------------------------------------------------------------------------- 
void init_uart() 
//---------------------------------------------------------------------------------- 
//9600 bps @ 11.059 MHz  
{SCON  = 0x52;     
 TMOD  = 0x20;     
 TCON  = 0x69;           
 TH1   = 0xfd;     
} 

//---------------------------------------------------------------------------------------- 
void calc_sth11(float *p_humidity ,float *p_temperature) 
//---------------------------------------------------------------------------------------- 
// calculates temperature [癈] and humidity [%RH]  
// input :  humi [Ticks] (12 bit)  
//          temp [Ticks] (14 bit) 
// output:  humi [%RH] 
//          temp [癈] 
{ const float C1=-4.0;              // for 12 Bit 
  const float C2=+0.0405;           // for 12 Bit 
  const float C3=-0.0000028;        // for 12 Bit 
  const float T1=+0.01;             // for 14 Bit @ 5V 
  const float T2=+0.00008;           // for 14 Bit @ 5V         

  float rh=*p_humidity;             // rh:      Humidity [Ticks] 12 Bit  
  float t=*p_temperature;           // t:       Temperature [Ticks] 14 Bit 
  float rh_lin;                     // rh_lin:  Humidity linear 
  float rh_true;                    // rh_true: Temperature compensated humidity 
  float t_C;                        // t_C   :  Temperature [癈] 

  t_C=t*0.01 - 40;                  //calc. temperature from ticks to [癈] 
  rh_lin=C3*rh*rh + C2*rh + C1;     //calc. humidity from ticks to [%RH] 
  rh_true=(t_C-25)*(T1+T2*rh)+rh_lin;   //calc. temperature compensated humidity [%RH] 
  if(rh_true>100)rh_true=100;       //cut if the value is outside of 
  if(rh_true<0.1)rh_true=0.1;       //the physical possible range 

  *p_temperature=t_C;               //return temperature [癈] 
  *p_humidity=rh_true;              //return humidity[%RH] 
} 

//-------------------------------------------------------------------- 
float calc_dewpoint(float h,float t) 
//-------------------------------------------------------------------- 
// calculates dew point 
// input:   humidity [%RH], temperature [癈] 
// output:  dew point [癈] 
{ float logEx,dew_point; 
  logEx=0.66077+7.5*t/(237.3+t)+(log10(h)-2); 
  dew_point = (logEx - 0.66077)*237.3/(0.66077+7.5-logEx); 
  return dew_point; 
} 

//---------------------------------------------------------------------------------- 
void main() 
//---------------------------------------------------------------------------------- 
// sample program that shows how to use SHT11 functions 
// 1. connection reset  
// 2. measure humidity [ticks](12 bit) and temperature [ticks](14 bit) 
// 3. calculate humidity [%RH] and temperature [癈] 
// 4. calculate dew point [癈] 
// 5. print temperature, humidity, dew point   

{  
  value humi_val,temp_val; 
  float dew_point; 
  unsigned char error,checksum; 
  unsigned int i; 

  init_uart(); 
  s_connectionreset(); 
  while(1) 
  { 
    error=0; 
    error+=s_measure((unsigned char*) &humi_val.i,&checksum,HUMI);  //measure humidity 
    error+=s_measure((unsigned char*) &temp_val.i,&checksum,TEMP);  //measure temperature 
    if(error!=0) s_connectionreset();                 //in case of an error: connection reset 
    else 
    { 
      humi_val.f=(float)humi_val.i;                   //converts integer to float 
      temp_val.f=(float)temp_val.i;                   //converts integer to float 
      calc_sth11(&humi_val.f,&temp_val.f);            //calculate humidity, temperature 
      dew_point=calc_dewpoint(humi_val.f,temp_val.f); //calculate dew point 
      printf("temp:%5.1fC humi:%5.1f%% dew point:%5.1fC 
",temp_val.f,humi_val.f,dew_point); 
    } 
    //----------wait approx. 0.8s to avoid heating up SHTxx------------------------------       
    for (i=0;i<40000;i++);     //(be sure that the compiler doesn't eliminate this line!) 
    //-----------------------------------------------------------------------------------                        
  } 
}  

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
777亚洲妇女| 欧美日韩三级一区二区| 91精品国产综合久久福利| 日韩一区精品字幕| 精品国产百合女同互慰| 成人av在线播放网址| 亚洲国产视频一区| 26uuu精品一区二区在线观看| 成人精品视频一区二区三区尤物| 亚洲欧美日韩系列| 日韩一区二区三区av| 成人av在线电影| 国产成人精品免费网站| 三级在线观看一区二区 | 亚洲一区二区四区蜜桃| 欧美一区二区三区视频在线 | 欧美日韩国产影片| 九九热在线视频观看这里只有精品 | 狠狠色丁香九九婷婷综合五月| 中文字幕制服丝袜一区二区三区| 欧美精品视频www在线观看| 成人免费视频app| 99国产欧美另类久久久精品| 久久91精品久久久久久秒播| 狠狠色狠狠色综合日日91app| 国产一区二区三区在线观看精品| 午夜视频一区在线观看| 亚洲日本韩国一区| 国产精品污www在线观看| 欧美一二三区精品| 久久综合成人精品亚洲另类欧美 | 久久久久久久久久看片| 91精品国产综合久久精品app| 91精品在线一区二区| 精品乱人伦小说| 日韩一区二区三免费高清| 久久女同互慰一区二区三区| 亚洲视频一区在线| 青青草原综合久久大伊人精品 | 7799精品视频| 国产视频一区二区在线观看| 精品少妇一区二区三区免费观看| 久久综合久久久久88| 亚洲国产欧美在线| 日韩免费一区二区| 欧美三级中文字幕在线观看| 亚洲精选视频免费看| 欧美一级黄色片| 欧美精品久久久久久久多人混战| 久久蜜桃一区二区| 亚洲国产综合色| 国产精品1区二区.| 成人av动漫网站| 欧美一区二区三区在线观看| 中文幕一区二区三区久久蜜桃| 午夜精品久久久久久久久| 成人一级片在线观看| 欧美一卡二卡三卡四卡| 亚洲另类在线一区| 国产成+人+日韩+欧美+亚洲| 成人三级在线视频| 欧美电影免费观看高清完整版在线 | 精品一区二区在线观看| 色婷婷综合久久久久中文| 99精品一区二区三区| 日韩精品一区二区在线观看| 一二三区精品视频| 日本美女一区二区三区| 九九视频精品免费| 9191成人精品久久| 亚洲卡通动漫在线| 国产成人一级电影| 欧美v日韩v国产v| 日韩电影在线看| 在线精品亚洲一区二区不卡| 91精品在线一区二区| 亚洲成人av电影| 国产在线一区二区| 欧美大肚乱孕交hd孕妇| 视频一区中文字幕| 在线不卡免费欧美| 日韩激情一区二区| 7878成人国产在线观看| 五月天亚洲婷婷| 欧美理论片在线| 无吗不卡中文字幕| 3d动漫精品啪啪一区二区竹菊| 夜夜精品视频一区二区 | 亚洲欧美另类在线| 91在线精品一区二区三区| 亚洲欧洲无码一区二区三区| 日本女优在线视频一区二区| 91精品国产综合久久小美女| 麻豆91在线看| 欧美日韩和欧美的一区二区| 亚洲二区在线观看| 自拍偷在线精品自拍偷无码专区| 国产一区二区三区在线看麻豆| 精品国产电影一区二区| 国产99久久精品| 国产精品久久看| 欧美影片第一页| 中文字幕一区二区三| 9i看片成人免费高清| 久久午夜色播影院免费高清| 丰满少妇在线播放bd日韩电影| 国产精品久久毛片av大全日韩| 91成人免费在线视频| 国产精品久久久久久久午夜片| av网站一区二区三区| 亚洲成人免费av| 精品少妇一区二区三区在线视频| 成人一区二区在线观看| 亚洲自拍偷拍av| 精品免费视频一区二区| 成人精品国产福利| 天天射综合影视| 日本一区二区动态图| 精品一区二区三区在线播放| 中文一区在线播放| 3d动漫精品啪啪1区2区免费| 成人激情免费网站| 人妖欧美一区二区| 日本一二三不卡| 欧美久久免费观看| 国产91丝袜在线播放0| 日一区二区三区| 中文字幕一区二区三区色视频| 91精品视频网| 91亚洲男人天堂| 一区视频在线播放| 欧美精品一区二区三区蜜桃 | 亚洲一区二区三区四区在线| www国产精品av| 欧美群妇大交群的观看方式| 99久久亚洲一区二区三区青草| 日本成人在线不卡视频| 亚洲视频一区在线| 国产人伦精品一区二区| 国产大陆亚洲精品国产| 日本美女视频一区二区| 大白屁股一区二区视频| 日欧美一区二区| 亚洲一区二区三区中文字幕在线| 国产精品久久久久aaaa樱花| 久久久久久99久久久精品网站| 这里只有精品99re| 欧美日韩一区久久| 一本色道久久综合亚洲91| 成人一二三区视频| 国产成人免费在线视频| 国产一区二区三区精品视频| 六月婷婷色综合| 国产精品三级av| 久久久www成人免费无遮挡大片| 欧美一区二区三区日韩| 91精品午夜视频| 日韩免费观看高清完整版在线观看| 在线观看亚洲专区| 欧美图片一区二区三区| 在线视频欧美区| 欧美日韩一卡二卡| 欧美色电影在线| 欧美精品在线视频| 欧美一区二区三区免费在线看| 91精品国产手机| 日韩免费观看高清完整版在线观看| 日韩网站在线看片你懂的| 精品久久久久久久人人人人传媒 | 国产91对白在线观看九色| 国产一区二区在线影院| 韩国成人福利片在线播放| 国产美女视频91| 成人av动漫网站| 欧美性猛片xxxx免费看久爱| 91麻豆精品91久久久久同性| 欧美精品一区二区三区高清aⅴ| 久久久精品国产免大香伊| 国产精品久久久久久久久免费桃花| 中文字幕一区二区三区四区不卡 | 欧美自拍丝袜亚洲| 欧美日韩国产另类不卡| 日韩三级中文字幕| 日本一区二区三区电影| 蜜臀av性久久久久av蜜臀妖精| 美日韩一区二区| 国产 欧美在线| 91成人国产精品| 欧美一区二区在线播放| 国产日韩欧美不卡在线| 亚洲最快最全在线视频| 国产精品第五页| 99久久精品免费看国产| 欧美在线影院一区二区| 精品国产污网站| 亚洲六月丁香色婷婷综合久久| 蜜桃av噜噜一区二区三区小说| 成人午夜短视频| 777久久久精品| 国产精品视频在线看|