標題: 1602+DHT11+ARDUNIO MINI 溫濕度計 [打印本頁]

作者: a714756521    時間: 2017-12-20 22:05
標題: 1602+DHT11+ARDUNIO MINI 溫濕度計
  1. double Fahrenheit(double celsius)
  2. {
  3.         return 1.8 * celsius + 32;
  4. }    //攝氏溫度度轉化為華氏溫度

  5. double Kelvin(double celsius)
  6. {
  7.         return celsius + 273.15;
  8. }     //攝氏溫度轉化為開氏溫度

  9. // 露點(點在此溫度時,空氣飽和并產(chǎn)生露珠)
  10. // 參考: wahiduddin點net/calc/density_algorithms.htm
  11. double dewPoint(double celsius, double humidity)
  12. {
  13.         double A0= 373.15/(273.15 + celsius);
  14.         double SUM = -7.90298 * (A0-1);
  15.         SUM += 5.02808 * log10(A0);
  16.         SUM += -1.3816e-7 * (pow(10, (11.344*(1-1/A0)))-1) ;
  17.         SUM += 8.1328e-3 * (pow(10,(-3.49149*(A0-1)))-1) ;
  18.         SUM += log10(1013.246);
  19.         double VP = pow(10, SUM-3) * humidity;
  20.         double T = log(VP/0.61078);   // temp var
  21.         return (241.88 * T) / (17.558-T);
  22. }

  23. // 快速計算露點,速度是5倍dewPoint()
  24. // 參考: en點wikipedia點org/wiki/Dew_point
  25. double dewPointFast(double celsius, double humidity)
  26. {
  27.         double a = 17.271;
  28.         double b = 237.7;
  29.         double temp = (a * celsius) / (b + celsius) + log(humidity/100);
  30.         double Td = (b * temp) / (a - temp);
  31.         return Td;
  32. }

  33. #include <dht11.h>
  34. #include <Wire.h>
  35. #include <LiquidCrystal_I2C.h>

  36. LiquidCrystal_I2C lcd(0x27,16,2); // set the LCD address to 0x27 for a 16 chars and 2 line display

  37. dht11 DHT11;

  38. #define DHT11PIN 2

  39. void setup()
  40. {
  41.   lcd.init();                      // initialize the lcd
  42.   lcd.backlight();
  43.   lcd.print("Waiting...");
  44.   Serial.begin(9600);
  45. }
  46. void loop()
  47. {
  48.   int chk = DHT11.read(DHT11PIN);

  49.   switch (chk)
  50.   {
  51.     case DHTLIB_OK:
  52.                 lcd.setCursor(0, 0);
  53.                 lcd.print("Temp:");
  54.                 lcd.print((float)DHT11.temperature,2);
  55.                 lcd.write(0xDF);
  56.                 lcd.print("C");

  57.                 lcd.setCursor(0, 1);
  58.                 lcd.print("Humidity:");
  59.                 lcd.print((float)DHT11.humidity,2);
  60.                 lcd.print("%");

  61.                 break;
  62.     case DHTLIB_ERROR_CHECKSUM:
  63.                 lcd.clear();
  64.                 lcd.print("Checksum error");
  65.                 delay(1000);  
  66.                 lcd.clear();
  67.                 break;
  68.     case DHTLIB_ERROR_TIMEOUT:
  69.                 lcd.clear();
  70.                 lcd.print("Time out error");
  71.                 delay(1000);            
  72.                 lcd.clear();
  73.                 break;
  74.     default:
  75.                 lcd.clear();
  76.                 lcd.print("Unknown error");
  77.                 delay(1000);               
  78.                 lcd.clear();
  79.                 break;
  80.   }
  81.   delay(1000);
  82. }
復制代碼







歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1