Close

DS18B20

Úvodní stránka Fórum Hardware Senzory DS18B20

Označeno štítky: 

  • Toto téma obsahuje celkem 8 odpovědí. Do diskuze (3 diskutující) se naposledy zapojil uživatel posjirka a poslední změna proběhla před 8 roky a 8 měsíci.
Aktuálně je na stránce zobrazeno 9 příspěvků - 1. až 9. (celkem z 9)
  • Autor
    Příspěvky
  • #6001
    Jindra413
    Účastník

    Zdravím,
    potřeboval bych poradit s tímto senzorem. Zapojil jsem, vše mi fungovalo. Teplota se vypisovala na LCD displej. Poté jsem odpojil prostřední vodič (ten který předává informace) a od té doby ukazuje displej pouze teplotu 0.00. Dřív, když jsem zkoušel odpojit celý DS18B20, tak vždy LCD ukázal ERROR (mám to tak napsané v programu), a teď i když odpojím senzor, tak se stále zobrazuje nula. S programem jsem vůbec nehýbal, tak nevím kde je problém. Když použiju vypisování teploty na Sériový monitor, tak vše normálně funguje.
    Můžete mi prosím poradit?

    #6002
    Zbyšek Voda
    Správce

    Dobrý den, zkuste nám prosím pro jistotu poslat kód 🙂

    #6003
    Jindra413
    Účastník

    Ten kód je převzatý, malinko upravený. Pokud to bude fungovat, měl by to být termostat, který bude zapínat či vypínat podle nastavené teploty.

    // This Arduino sketch reads DS18B20 „1-Wire“ digital
    // temperature sensors.
    // Tutorial:
    // http://www.hacktronics.com/Tutorials/arduino-1-wire-tutorial.html

    #include <OneWire.h>
    #include <DallasTemperature.h>
    #include <LiquidCrystal.h>

    LiquidCrystal lcd(12, 11, 5, 4, 3, 2);

    // Data wire is plugged into pin 8 on the Arduino
    #define ONE_WIRE_BUS 8

    // Setup a oneWire instance to communicate with any OneWire devices
    OneWire oneWire(ONE_WIRE_BUS);

    // Pass our oneWire reference to Dallas Temperature.
    DallasTemperature sensors(&oneWire);

    // Assign the addresses of your 1-Wire temp sensors.
    // See the tutorial on how to obtain these addresses:
    // http://www.hacktronics.com/Tutorials/arduino-1-wire-address-finder.html

    DeviceAddress Thermometer = { 0x28, 0xFF, 0xC9, 0x09, 0xA5, 0x15, 0x01, 0x84 };

    void setup(void)
    {
    // Start up the library
    sensors.begin();
    // set the resolution to 10 bit (good enough?)
    sensors.setResolution(Thermometer, 10);

    lcd.begin(16,2); // columns, rows. use 16,2 for a 16×2 LCD, etc.
    lcd.clear(); // start with a blank screen

    }

    void printTemperature(DeviceAddress deviceAddress)
    {
    float tempC = sensors.getTempC(deviceAddress);
    if (tempC == -127.00) {
    lcd.print(„Error“);
    } else {
    lcd.print(tempC);

    }
    }

    void loop(void)
    {

    sensors.requestTemperatures();
    lcd.setCursor(0,0);
    lcd.print(„Teplota: „);
    printTemperature(Thermometer);
    lcd.print(“ C“);

    int teplota = 23.00;

    if (sensors.getTempC(Thermometer)>= teplota)
    { digitalWrite(13, HIGH);
    }
    else
    { digitalWrite(13, LOW);
    }
    delay(5000);
    }

    #6004
    Jindra413
    Účastník
    Attachments:
    #6006
    Zbyšek Voda
    Správce

    A když pod
    lcd.print(tempC);
    přidáte
    Serial.println(tempC);

    Co se Vám po sériové lince vypíše?

    #6007
    Jindra413
    Účastník

    Nic se mi na sériovou linku nevypíše.

    Pro vypisování na sériovou linku jsem používal toto:

    #include <OneWire.h>

    // OneWire DS18S20, DS18B20, DS1822 Temperature Example
    //
    // http://www.pjrc.com/teensy/td_libs_OneWire.html
    //
    // The DallasTemperature library can do all this work for you!
    // http://milesburton.com/Dallas_Temperature_Control_Library

    OneWire ds(10); // on pin 10 (a 4.7K resistor is necessary)

    void setup(void) {
    Serial.begin(9600);
    }

    void loop(void) {
    byte i;
    byte present = 0;
    byte type_s;
    byte data[12];
    byte addr[8];
    float celsius, fahrenheit;

    if ( !ds.search(addr)) {
    Serial.println(„No more addresses.“);
    Serial.println();
    ds.reset_search();
    delay(250);
    return;
    }

    Serial.print(„ROM =“);
    for( i = 0; i < 8; i++) {
    Serial.write(‚ ‚);
    Serial.print(addr[i], HEX);
    }

    if (OneWire::crc8(addr, 7) != addr[7]) {
    Serial.println(„CRC is not valid!“);
    return;
    }
    Serial.println();

    // the first ROM byte indicates which chip
    switch (addr[0]) {
    case 0x10:
    Serial.println(“ Chip = DS18S20″); // or old DS1820
    type_s = 1;
    break;
    case 0x28:
    Serial.println(“ Chip = DS18B20″);
    type_s = 0;
    break;
    case 0x22:
    Serial.println(“ Chip = DS1822″);
    type_s = 0;
    break;
    default:
    Serial.println(„Device is not a DS18x20 family device.“);
    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(“ Data = „);
    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();

    // Convert the data to actual temperature
    // because the result is a 16 bit signed integer, it should
    // be stored to an „int16_t“ type, which is always 16 bits
    // even when compiled on a 32 bit processor.
    int16_t raw = (data[1] << 8) | data[0];
    if (type_s) {
    raw = raw << 3; // 9 bit resolution default
    if (data[7] == 0x10) {
    // „count remain“ gives full 12 bit resolution
    raw = (raw & 0xFFF0) + 12 – data[6];
    }
    } else {
    byte cfg = (data[4] & 0x60);
    // at lower res, the low bits are undefined, so let’s zero them
    if (cfg == 0x00) raw = raw & ~7; // 9 bit resolution, 93.75 ms
    else if (cfg == 0x20) raw = raw & ~3; // 10 bit res, 187.5 ms
    else if (cfg == 0x40) raw = raw & ~1; // 11 bit res, 375 ms
    //// default is 12 bit resolution, 750 ms conversion time
    }
    celsius = (float)raw / 16.0;
    fahrenheit = celsius * 1.8 + 32.0;
    Serial.print(“ Temperature = „);
    Serial.print(celsius);
    Serial.print(“ Celsius, „);
    Serial.print(fahrenheit);
    Serial.println(“ Fahrenheit“);
    }

    #6010
    posjirka
    Účastník

    chlape obávám se , že tvuj popis nené až tak úplný. Ty jsi totoiž neodpojil pin z DS18B20, ale opojil si zároveň i Pull-up odpor že? To ti totiž udělá přesně to co popisuješ. Celá věda s vyhodonocením chyby na DS18B20 je ta že, když odpojiž pin Arduina od všeho vypíše ti 0,00 st.C. je to proto, že mu nepřijde ani 1 bit log.1.
    kaž připojíš čidlo správně máš tam pemanentně log.1 a čidlo přes otevřený kolektor přizemńuje celou linku (log.0) počet log.0/log.1 ti vlastně dává výslednou teplotu. To je vpříkald kladných teplot. Záporné teploty fungují tak, že čidlo zvládne max. 126 st.C a cokoliv je nad je vlastně záporná teplota. Takže data 130 st.C = skutečně -4st.C. To vše končí v -127stC což je úplně mimo roszah čidla (max. -50st.C) a to je vlastně ona hláška „Error“. Když necháš pull-up odpor připojený bez čidla, dostane arduino samé log.1 takže b11111111 což v překladu do dec.soustavy = 255 a při převodu do zápodných hodnot = -127st.C.

    To jsem se rozepsal. No ve výsledku: odpoji čidlo ale pull-up odpor tam nech a vše bude v pořádku.

    #6011
    Jindra413
    Účastník

    Omlouvám se za dezinformaci. Udělal jsem to přesně jak píšeš. Ale když to chci opět zprovoznit, tak to stále píše nuly. Ikdyž odpojím čidlo a odpor nechám zapojený.

    #6012
    posjirka
    Účastník

    omlouvat se nemusíš, jsme jen lidi. Na nefunkčnost můžeme zkusit tradiční postup:
    1, překotroluj zapojení, případně rozeber a znovu postav (studeňáky, vypadlý drát,..)
    2, vyzkoušej jednoduchý program, který ti LED diodou bude signalizovat jaký je stav na tom pinu

    // kontrola stavu pinu
    // by JP 2016
    // na vystup s LED diodou zapisuje stav z kontrolovaného pinu
     
    int kontrolovanyPin = 8; // sem dej 49slo pinu, ktery potřebuješ ověřit 
    int LED = 13; // pin s LED diodou - pou6ij tu na desce
    
    void setup() {
    pinMode(kontrolovanyPin, INPUT); // nastaven9 pinu najako vstup
      pinMode(LED, OUTPUT); // nasteven9 pinu 13 na vystup - LED dioda na desce 
    }
    
    void loop() {
      digitalWrite(LED, digitalRead(kontrolovanyPin)); // zapis na pins S LED diodaou stav kontrolovaneho vstupu
    }

    3, zlus jiné čidlo nebo jiný pin (jedno je možná špatné)

Aktuálně je na stránce zobrazeno 9 příspěvků - 1. až 9. (celkem z 9)
  • Pro reakci na toto téma se musíte přihlásit.