Bewässerungssteuerung: Unterschied zwischen den Versionen
Keine Bearbeitungszusammenfassung |
Keine Bearbeitungszusammenfassung |
||
Zeile 1: | Zeile 1: | ||
Diese Seite beschreibt, wie man intelligent seine Bewässerung steuern kann wenn man zb. Bodenfeuchtesensoren installiert hat. | Diese Seite beschreibt, wie man intelligent seine Bewässerung steuern kann wenn man zb. Bodenfeuchtesensoren installiert hat. | ||
Es wird von folgenden Komponenten ausgegangen: | Es wird von folgenden Komponenten ausgegangen: | ||
* Gardena Magnetventile, angesprochen über einen FS20-Aktor (zb. S8M) | * Gardena Magnetventile, angesprochen über einen FS20-Aktor (zb. S8M) | ||
* | * Bodenfeuchtesensoren, zb. FS20 BF oder andere (zb. an einem [[AVR-NET-IO]]) | ||
==allgemeine Einstellungen== | |||
===Anlegen der Bodenfeuchtesensoren=== | |||
Für einen FS20 Sensor: FS20BF | |||
define Bodenfeuchtesensor FS20 34f2 00 | |||
attr Bodenfeuchtesensor room Bewässerung | |||
Für eine 1wire Version: einen analogen Sensor (zb. Vegetronix), angeschlossen an einen 4fach A/D Converter DS2450 | |||
attr | define Bodenfeuchte OWAD DS2450 50310C000000 60 | ||
attr | attr Bodenfeuchte AFunction VA*33.9 | ||
attr Bodenfeuchte AUnit percent|% | |||
attr Bodenfeuchte BFunction VB*33.9 | |||
attr Bodenfeuchte BUnit percent|% | |||
attr Bodenfeuchte CFunction VC*33.9 | |||
attr Bodenfeuchte CUnit percent|% | |||
attr Bodenfeuchte event-on-change-reading state | |||
attr Bodenfeuchte model DS2450 | |||
attr Bodenfeuchte room Bewässerung | |||
Alternativ auch andere, siehe [[AVR-NET-IO]] | Alternativ auch andere, siehe [[AVR-NET-IO]] | ||
===zentrale Schaltvariable=== | |||
Erstellung einer Schaltvariable um im Frontend die Bewässerung zentral zu steuern | |||
* Auto => Je nach Angabe des Bodenfeuchtesensors wird bewässert oder nicht | * Auto => Je nach Angabe des Bodenfeuchtesensors wird bewässert oder nicht | ||
* On => Es wird immer bewässert | * On => Es wird immer bewässert | ||
* Off => Es wird nicht bewässert | * Off => Es wird nicht bewässert | ||
define Bewaesserung_Active dummy | |||
attr Bewaesserung_Active room Bewässerung | |||
attr Bewaesserung_Active setList Auto On Off | |||
attr Bewaesserung_Active webCmd Auto:On:Off | |||
==Steuerung mittels FS20/einzelner Devices== | |||
Falls für jedes Magnetventil ein eigenes Device existiert | |||
<nowiki>define BewNotify notify BewNotify { | ===1. Bewässerungsventile definieren=== | ||
my @@args | Als erstes werden die Bewässerungsventile in FHEM definiert, zb.: | ||
my $device | define Bewaesserung_Ventil1 FS20 2305 51 | ||
my $duration = "%EVTPART1"; | attr Bewaesserung_Ventil1 model fs20st | ||
my $sensor | attr Bewaesserung_Ventil1 room Bewässerung | ||
my $auto | |||
my $sensorstate = "on";; | ===Zuweisung eines Sensors einem oder mehrerer Bewässerungsventile=== | ||
Hier der Fall eines FS20BF Bodenfeuchtesensors. Dieser übermittelt nur im state ein "on" oder "off" | |||
if(($auto eq "Auto") || ($auto eq "On")) { | attr Bewaesserung_Ventil1 sensor Bodenfeuchtesensor | ||
Im Falle der 1wire Version wird das Ventil 1 mit dem Bodenfeuchtesensor "gepaired" der am Port A des Sensors "Bodenfeuchte" hängt. Dieser übermittelt einen echten Dezimalwert. | |||
attr Bewaesserung_Ventil1 sensor Bodenfeuchte:A | |||
===zentrale Prozedur zur Bewässerung=== | |||
Jetzt wird die zentrale Prozedur zur Steuerung angelegt: | |||
<nowiki>define BewNotify notify BewNotify { | |||
my @@args = split(" ",'%EVENT'); | |||
} | my $device = "%EVTPART0"; | ||
my $duration = "%EVTPART1"; | |||
my $sensor = AttrVal($device, "sensor", undef); | |||
my @@sArr = split(":", $sensor) if($sensor =~ m/:/); | |||
my $auto = ReadingsVal("Bewaesserung_Active", "state", "Off"); | |||
my $sensorstate = "on"; | |||
my $schwellwert = 0; | |||
if(($auto eq "Auto") || ($auto eq "On")) { | |||
if((defined ($sensor)) && ($auto eq "Auto")) { | |||
if (defined($sArr[0])) { | |||
$sensorstate = ReadingsVal($sArr[0], $sArr[1], undef); | |||
$schwellwert = AttrVal($sArr[0], "schwellwert", undef); | |||
$schwellwert = AttrVal($sArr[0], $sArr[1]."Low", 0) if (!defined($schwellwert)); | |||
} else { | |||
$schwellwert = AttrVal($sensor, "schwellwert", undef); | |||
$sensorstate = ReadingsVal($sensor, "state", undef) if (!defined($sensorstate)); | |||
$sensorstate = ReadingsVal($sensor, "status", undef) if (!defined($sensorstate)); | |||
} | |||
$sensorstate = "off" if (!defined($sensorstate)); | |||
} | |||
if($sensorstate eq "on") { | |||
fhem "set $device on-for-timer $duration"; | |||
} elsif ($sensorstate =~ m/^(\d+)/) { | |||
Log 5, "Sensorstate: $sensorstate"; | |||
Log 5, "Schwellwert: $schwellwert"; | |||
if ($schwellwert >= $sensorstate) { fhem "set $device on-for-timer $duration"; } | |||
} elsif (ReadingsVal($device, "state", "") ne "off" ) { | |||
fhem "set $device off"; | |||
} | |||
} | |||
} | } | ||
attr BewNotify comment Prozedur um aufgrund Umweltzustände die Bewässerung freizugeben oder nicht. Bsp: BewNotify {Device} {Dauer in sek} {Schaltvariable} | attr BewNotify comment Prozedur um aufgrund Umweltzustände die Bewässerung freizugeben oder nicht. Bsp: BewNotify {Device} {Dauer in sek} {Schaltvariable} | ||
attr BewNotify room Bewässerung</nowiki> | attr BewNotify room Bewässerung</nowiki> | ||
Das geübte Auge wird feststellen, das für die Bodenfeuchtesensoren sowohl das Reading "state" als auch das Reading "status" abgefragt wird. Das liegt daran, das die FS20 BF ein Reading "state" haben, die analogen Bodenfeuchtesensoren über die ECMDDevice classdef-Definition ein "status" Reading (Das Reading "state" ist intern verwendet und darf nicht doppelt vergeben werden). | Das geübte Auge wird feststellen, das für die Bodenfeuchtesensoren sowohl das Reading "state" als auch das Reading "status" abgefragt wird. Das liegt daran, das die FS20 BF ein Reading "state" haben, die analogen Bodenfeuchtesensoren über die ECMDDevice classdef-Definition ein "status" Reading (Das Reading "state" ist intern verwendet und darf nicht doppelt vergeben werden). | ||
===Zeitsteuerung=== | |||
6. Abschließend wird die Bewässerung in die Zeitsteuerung übergeben | 6. Abschließend wird die Bewässerung in die Zeitsteuerung übergeben | ||
Version vom 23. Mai 2013, 07:57 Uhr
Diese Seite beschreibt, wie man intelligent seine Bewässerung steuern kann wenn man zb. Bodenfeuchtesensoren installiert hat.
Es wird von folgenden Komponenten ausgegangen:
- Gardena Magnetventile, angesprochen über einen FS20-Aktor (zb. S8M)
- Bodenfeuchtesensoren, zb. FS20 BF oder andere (zb. an einem AVR-NET-IO)
allgemeine Einstellungen
Anlegen der Bodenfeuchtesensoren
Für einen FS20 Sensor: FS20BF
define Bodenfeuchtesensor FS20 34f2 00 attr Bodenfeuchtesensor room Bewässerung
Für eine 1wire Version: einen analogen Sensor (zb. Vegetronix), angeschlossen an einen 4fach A/D Converter DS2450
define Bodenfeuchte OWAD DS2450 50310C000000 60 attr Bodenfeuchte AFunction VA*33.9 attr Bodenfeuchte AUnit percent|% attr Bodenfeuchte BFunction VB*33.9 attr Bodenfeuchte BUnit percent|% attr Bodenfeuchte CFunction VC*33.9 attr Bodenfeuchte CUnit percent|% attr Bodenfeuchte event-on-change-reading state attr Bodenfeuchte model DS2450 attr Bodenfeuchte room Bewässerung
Alternativ auch andere, siehe AVR-NET-IO
zentrale Schaltvariable
Erstellung einer Schaltvariable um im Frontend die Bewässerung zentral zu steuern
- Auto => Je nach Angabe des Bodenfeuchtesensors wird bewässert oder nicht
- On => Es wird immer bewässert
- Off => Es wird nicht bewässert
define Bewaesserung_Active dummy attr Bewaesserung_Active room Bewässerung attr Bewaesserung_Active setList Auto On Off attr Bewaesserung_Active webCmd Auto:On:Off
Steuerung mittels FS20/einzelner Devices
Falls für jedes Magnetventil ein eigenes Device existiert
1. Bewässerungsventile definieren
Als erstes werden die Bewässerungsventile in FHEM definiert, zb.:
define Bewaesserung_Ventil1 FS20 2305 51 attr Bewaesserung_Ventil1 model fs20st attr Bewaesserung_Ventil1 room Bewässerung
Zuweisung eines Sensors einem oder mehrerer Bewässerungsventile
Hier der Fall eines FS20BF Bodenfeuchtesensors. Dieser übermittelt nur im state ein "on" oder "off"
attr Bewaesserung_Ventil1 sensor Bodenfeuchtesensor
Im Falle der 1wire Version wird das Ventil 1 mit dem Bodenfeuchtesensor "gepaired" der am Port A des Sensors "Bodenfeuchte" hängt. Dieser übermittelt einen echten Dezimalwert.
attr Bewaesserung_Ventil1 sensor Bodenfeuchte:A
zentrale Prozedur zur Bewässerung
Jetzt wird die zentrale Prozedur zur Steuerung angelegt:
define BewNotify notify BewNotify { my @@args = split(" ",'%EVENT'); my $device = "%EVTPART0"; my $duration = "%EVTPART1"; my $sensor = AttrVal($device, "sensor", undef); my @@sArr = split(":", $sensor) if($sensor =~ m/:/); my $auto = ReadingsVal("Bewaesserung_Active", "state", "Off"); my $sensorstate = "on"; my $schwellwert = 0; if(($auto eq "Auto") || ($auto eq "On")) { if((defined ($sensor)) && ($auto eq "Auto")) { if (defined($sArr[0])) { $sensorstate = ReadingsVal($sArr[0], $sArr[1], undef); $schwellwert = AttrVal($sArr[0], "schwellwert", undef); $schwellwert = AttrVal($sArr[0], $sArr[1]."Low", 0) if (!defined($schwellwert)); } else { $schwellwert = AttrVal($sensor, "schwellwert", undef); $sensorstate = ReadingsVal($sensor, "state", undef) if (!defined($sensorstate)); $sensorstate = ReadingsVal($sensor, "status", undef) if (!defined($sensorstate)); } $sensorstate = "off" if (!defined($sensorstate)); } if($sensorstate eq "on") { fhem "set $device on-for-timer $duration"; } elsif ($sensorstate =~ m/^(\d+)/) { Log 5, "Sensorstate: $sensorstate"; Log 5, "Schwellwert: $schwellwert"; if ($schwellwert >= $sensorstate) { fhem "set $device on-for-timer $duration"; } } elsif (ReadingsVal($device, "state", "") ne "off" ) { fhem "set $device off"; } } } attr BewNotify comment Prozedur um aufgrund Umweltzustände die Bewässerung freizugeben oder nicht. Bsp: BewNotify {Device} {Dauer in sek} {Schaltvariable} attr BewNotify room Bewässerung
Das geübte Auge wird feststellen, das für die Bodenfeuchtesensoren sowohl das Reading "state" als auch das Reading "status" abgefragt wird. Das liegt daran, das die FS20 BF ein Reading "state" haben, die analogen Bodenfeuchtesensoren über die ECMDDevice classdef-Definition ein "status" Reading (Das Reading "state" ist intern verwendet und darf nicht doppelt vergeben werden).
Zeitsteuerung
6. Abschließend wird die Bewässerung in die Zeitsteuerung übergeben
define Timer_Ventil1 at *00:00:00 trigger BewNotify Bewaesserung_Ventil1 1920 attr Timer_Ventil1 room Bewässerung
Hiermit wird täglich um 0Uhr die Bewässerungsprozedur aufgerufen bei dem Ventil1 für 30min geöffnet wird. Abhängig natürlich von der Einstellung [Auto|On|Off] der Schaltariable "Bewaesserung_Active"