Opbouw Zwembad Control Unit pt 3-1 (DS18b20)

De uitlezing van de ds18b20 gebeurt door het lezen van adressen, data en dergelijke, maar dat vond ik te veel informatie voor mijn zwembad. Ik heb niet meer nodig dan de temperatuur van de sensoren

Ik heb de sketch driftig aangepast en gesloopt. En voor mij werkt deze zoals hij nu is

Enkele wijzigingen in de sketch die ik hiervoor heb geplaatst:

 

#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(2); // on pin 2 (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;
int buiten, zwembad, dak;

if ( !ds.search(addr)) {
Serial.println();
Serial.println(“——————“);
ds.reset_search();
delay(250);
return;
}

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

ds.reset();
ds.select(addr);
ds.write(0x44); // start conversion, use ds.write(0x44,1) 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

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;
switch (addr[1]) {
case 30:
Serial.print(“Zwembad: “);
zwembad=celsius;
Serial.println(zwembad);
break;
case 25:
Serial.print(“Dak: “);
dak=celsius;
Serial.println(dak);
break;
case 245:
Serial.print(“buiten: “);
buiten = celsius;
Serial.println(buiten);
break;

}
}

Ik hoop dat je er wat mee kunt

 

Geef een reactie

Je e-mailadres wordt niet gepubliceerd. Vereiste velden zijn gemarkeerd met *

Deze site gebruikt Akismet om spam te verminderen. Bekijk hoe je reactie-gegevens worden verwerkt.