KY-001 hőmérséklet-érzékelő modul

További képek

KY-001 hőmérséklet-érzékelő modul

Ter. állapot: Raktáron

Raktárkészlet: 1.00 db.


500 Ft (Ára)


Kód: ARD-KY001

Termék leírás

KY-001 hőmérséklet-érzékelő modul


Bővebb leírás

Infóért kattints a linkre:

KY-001 Temperature Sensor Module

Ismertető
A Maxim-Dallas 18B20 hőmérő-áramköre -55..+125 fok közt képes mérni. Azonban a hozzávezetések illetve a tokozása nem megoldott, így nedves, agresszív környezetben a hőmérő kábelezése könnyen korrodálódik. Erre kínál megoldást a vízmentesítéssel és védőtokkal ellátott kivitelű mérőszonda.
A hőmérőszenzor legjobb mérési pontossága: 1/16-od fok! Mivel minden hőmérő egyedi beégetett 64-bites azonosítóval ellátott, így egyetlen buszrendszerre rengeteg hőmérő felfűzhető. Az adatgyűjtő-rendszerek, nap- illetve sörkollektor-megvalósítások elengedhetetlen mérő-tartoztéka.
Az 1-wire eljáráskönyvtárt a fejlesztőrendszerek beépítve tartalmazzák.


Hőmérő-szolgáltatások

  • Univerzális 1-Wire buszrendszerre csatlakoztatható,
  • Egyetlen kontrollerkivezetést igényel a használata,
  • Zavartűrő, zavarérzékelten kialakítás,
  • CRC ellenőrzött kommunikáció,
  • Táplálható az adatvonalon át (3.0...5V),
  • Járulékos hardware-t nem igényel,
  • Széles hőmérsékleti méréstartomány –55..+125°C,
  • Szélsőséges esetben maximum ±0.5°C pontosság,
  • Beállítható mérési pontosság 9.. 12 bit (1/2..1/16°C),
  • Maximális mérési idő 750ms (max.),
  • Beállítható riasztási hőmérséklet.
 

Csatlakozás
Szenzorkivezetésként megvalósítva (3 pin):

  • 1 - GND,
  • 2 - Vcc,
  • 3 - Adatvonal (S)

Csomag

  • 1x DS18B20 szenzormodul

Példakód Arduino:

#include <OneWire.h>
 
// DS18S20 Temperature chip i/o
OneWire ds(10);  // on pin 10
 
void setup(void) {
  // initialize inputs/outputs
  // start serial port
  Serial.begin(9600);
}
 
void loop(void) {
 
  //For conversion of raw data to C
  int HighByte, LowByte, TReading, SignBit, Tc_100, Whole, Fract;
 
  byte i;
  byte present = 0;
  byte data[12];
  byte addr[8];
 
  if ( !ds.search(addr)) {
      Serial.print("No more addresses.n");
      ds.reset_search();
      return;
  }
 
  Serial.print("R=");
  for( i = 0; i < 8; i++) {
    Serial.print(addr[i], HEX);
    Serial.print(" ");
  }
 
  if ( OneWire::crc8( addr, 7) != addr[7]) {
      Serial.print("CRC is not valid!n");
      return;
  }
 
  if ( addr[0] == 0x10) {
      Serial.print("Device is a DS18S20 family device.n");
  }
  else if ( addr[0] == 0x28) {
      Serial.print("Device is a DS18B20 family device.n");
  }
  else {
      Serial.print("Device family is not recognized: 0x");
      Serial.println(addr[0],HEX);
      return;
  }
 
  ds.reset();
  ds.select(addr);
  ds.write(0x44,1);         // start conversion, with parasite power on at the end
 
  delay(1000);     // maybe 750ms is enough, maybe not
  // we might do a ds.depower() here, but the reset will take care of it.
 
  present = ds.reset();
  ds.select(addr);    
  ds.write(0xBE);         // Read Scratchpad
 
  Serial.print("P=");
  Serial.print(present,HEX);
  Serial.print(" ");
  for ( i = 0; i < 9; i++) {           // we need 9 bytes
    data[i] = ds.read();
    Serial.print(data[i], HEX);
    Serial.print(" ");
  }
  Serial.print(" CRC=");
  Serial.print( OneWire::crc8( data, 8), HEX);
  Serial.println();
 
  //Conversion of raw data to C
  LowByte = data[0];
  HighByte = data[1];
  TReading = (HighByte << 8) + LowByte;
  SignBit = TReading & 0x8000;  // test most sig bit
  if (SignBit) // negative
  {
    TReading = (TReading ^ 0xffff) + 1; // 2's comp
  }
  Tc_100 = (6 * TReading) + TReading / 4;    // multiply by (100 * 0.0625) or 6.25
 
  Whole = Tc_100 / 100;  // separate off the whole and fractional portions
  Fract = Tc_100 % 100;
 
 
  if (SignBit) // If its negative
  {
     Serial.print("-");
  }
  Serial.print(Whole);
  Serial.print(".");
  if (Fract < 10)
  {
     Serial.print("0");
  }
  Serial.print(Fract);
 
  Serial.print("n");
  //End conversion to C
}