SVG: Unterschied zwischen den Versionen
(Kurze Hinweise, v.a. zur Nutzung von plotReplace eingefügt) |
K (Syntaxhighlight - Aufrufe korrigiert) |
||
Zeile 11: | Zeile 11: | ||
== Definition == | == Definition == | ||
Die Definition <syntaxhighlight> | Die Definition <syntaxhighlight lang="perl"> | ||
define <name> SVG <logDevice>:<gplotfile>:<logfile> | define <name> SVG <logDevice>:<gplotfile>:<logfile> | ||
</syntaxhighlight>besteht lediglich in der Angabe einer Datenquelle, einer .gplot-File und der Angabe von entweder ''CURRENT'' (für LogFile-Quellen) bzw. ''HISTORY'' (für Datenbanken). | </syntaxhighlight>besteht lediglich in der Angabe einer Datenquelle, einer .gplot-File und der Angabe von entweder ''CURRENT'' (für LogFile-Quellen) bzw. ''HISTORY'' (für Datenbanken). | ||
Zeile 36: | Zeile 36: | ||
* Inhalt der Datei '''SVG_PlugX.gplot''' | * Inhalt der Datei '''SVG_PlugX.gplot''' | ||
{{Randnotiz|RNTyp=g|RNText=Gegebenenfalls sind die Feldnamen anzupassen}}< | {{Randnotiz|RNTyp=g|RNText=Gegebenenfalls sind die Feldnamen anzupassen}} | ||
<syntaxhighlight lang="Gnuplot"> | |||
# Leistungsdaten einer Steckdose (FileLog) | # Leistungsdaten einer Steckdose (FileLog) | ||
# | # | ||
Zeile 69: | Zeile 70: | ||
"<IN>" using 1:2 axes x1y2 title 'Strom' ls l1fill_stripe lw 1 with steps,\ | "<IN>" using 1:2 axes x1y2 title 'Strom' ls l1fill_stripe lw 1 with steps,\ | ||
"<IN>" using 1:2 axes x1y1 title 'Schaltzustand' ls l3 lw 1 with steps | "<IN>" using 1:2 axes x1y1 title 'Schaltzustand' ls l3 lw 1 with steps | ||
</ | </syntaxhighlight> | ||
* Definition von SVG-Device '''SVG_Test''' | * Definition von SVG-Device '''SVG_Test''' | ||
{{Randnotiz|RNTyp=g|RNText=Alle Vorkommen von ...Data-Device... und ...FileLog-Device... sind zu ersetzen}} | {{Randnotiz|RNTyp=g|RNText=Alle Vorkommen von ...Data-Device... und ...FileLog-Device... sind zu ersetzen}} | ||
< | <syntaxhighlight lang="perl"> | ||
defmod SVG_Test SVG ...FileLog-Device...:SVG_PlugX:CURRENT | defmod SVG_Test SVG ...FileLog-Device...:SVG_PlugX:CURRENT | ||
attr SVG_Test captionPos auto | attr SVG_Test captionPos auto | ||
attr SVG_Test plotReplace DataDevice="...Data-Device..." FileLogDevice="...FileLog-Device..." stateOFFvalue="20" stateONvalue="30" stateUNKNOWNvalue="10" yrange="[0:75]" y2range="[0:300]" title={"Steckdose(Testgerät) --- W: $data{min1}...$data{max1} / $data{currval1} --- mA: $data{min2}...$data{max2} / $data{currval2}"} | attr SVG_Test plotReplace DataDevice="...Data-Device..." FileLogDevice="...FileLog-Device..." stateOFFvalue="20" stateONvalue="30" stateUNKNOWNvalue="10" yrange="[0:75]" y2range="[0:300]" title={"Steckdose(Testgerät) --- W: $data{min1}...$data{max1} / $data{currval1} --- mA: $data{min2}...$data{max2} / $data{currval2}"} | ||
</ | </syntaxhighlight> | ||
* So sieht das resultierende Diagramm aus | * So sieht das resultierende Diagramm aus | ||
Zeile 92: | Zeile 93: | ||
[[Datei:PlotReplace Example DBLog.png|thumb|right|300px]] | [[Datei:PlotReplace Example DBLog.png|thumb|right|300px]] | ||
< | <syntaxhighlight lang="Gnuplot"> | ||
# Created by FHEM/98_SVG.pm, 2020-01-06 | |||
# to replace variables, use plotReplace like | # to replace variables, use plotReplace like | ||
# plotReplace-Parameter: SPEC1=Thermostat (von diesem Gerät stammen die Thermostat-Daten) | # plotReplace-Parameter: SPEC1=Thermostat (von diesem Gerät stammen die Thermostat-Daten) | ||
Zeile 133: | Zeile 135: | ||
"<IN>" using 1:2 axes x1y1 y2title '%WINDOW1%' ls l4fill lw 0.5 with steps,\ | "<IN>" using 1:2 axes x1y1 y2title '%WINDOW1%' ls l4fill lw 0.5 with steps,\ | ||
"<IN>" using 1:2 axes x1y1 y2title '%WINDOW2%' ls l5fill lw 0.5 with steps | "<IN>" using 1:2 axes x1y1 y2title '%WINDOW2%' ls l5fill lw 0.5 with steps | ||
</ | </syntaxhighlight> | ||
== Hinweise == | == Hinweise == | ||
* Plot-Abrisse vermeiden | * Plot-Abrisse vermeiden | ||
Zeile 141: | Zeile 143: | ||
* [[Plots erzeugen]] | * [[Plots erzeugen]] | ||
* [[Creating Plots]] | * [[Creating Plots]] | ||
<references /> | <references /> | ||
[[Kategorie:Logging]] | [[Kategorie:Logging]] |
Version vom 27. Januar 2020, 11:28 Uhr
SVG | |
---|---|
Zweck / Funktion | |
Erstellung von Diagrammen aus Logdaten | |
Allgemein | |
Typ | Hilfsmodul |
Details | |
Dokumentation | EN / DE |
Support (Forum) | Frontends |
Modulname | 98_SVG.pm |
Ersteller | rudolfkoenig (Forum / Wiki) |
Wichtig: sofern vorhanden, gilt im Zweifel immer die (englische) Beschreibung in der commandref! |
Das Modul SVG generiert Diagramme aus Logdateien oder -datenbanken.
Die Eigenschaften des zu erstellenden Diagrams werden in einer .gplot-Datei festgelegt.
Definition
Die Definition
define <name> SVG <logDevice>:<gplotfile>:<logfile>
besteht lediglich in der Angabe einer Datenquelle, einer .gplot-File und der Angabe von entweder CURRENT (für LogFile-Quellen) bzw. HISTORY (für Datenbanken).
Details zur Definition sind in der commandref/SVGlinkdefine dargestellt.
Attribute
Das wichtigste spezifische Attribut ist plotReplace, das einige andere, ältere Attribute ersetzen kann. Durch dieses können Angaben in den .gplot-Dateien dynamisch ersetzt werden, wodurch es auf einfache Weise möglich ist, dieselbe .gplot-Datei zur Erstellung von mehreren Plots zu nutzen, die dann auch in einem Plot unterschiedliche Datenquellen verwenden können. Dabei ist zu beachten, dass die in plotReplace angegebenen Parameter-Wert-Paare in zwei Stufen ersetzt werden:
Wird in der .gplot-Datei die Schreibweise %key% verwendet, wird der Parameter bereits ersetzt, bevor die Datenquelle ausgewertet wurde, in der Schreibweise <key> erfolgt die Auswertung erst danach. Dies ermöglicht es z.B. auch, Informationen aus unterschiedlichen FileLog-Dateien zu visualisieren, ohne die betreffende Datenquelle hart in der .gplot-Datei zu verankern.
Weiter ist es über diesen Mechanismus möglich, auch angepaßten Perl-Code zur Datenauswertung und -formatierung zu verwenden.
Siehe dazu insbesondere auch die nachfolgenden beiden Beispiele "Leistungsdaten einer Steckdose (FileLog)" und "Temperatur- und Heizungsdaten eines Zimmers" (DBLog).
Weitere Details in der commandref/SVGattr.
Funktionen
Details in der commandref/plotfunction.
Beispiele
Leistungsdaten einer Steckdose (FileLog)
- Inhalt der Datei SVG_PlugX.gplot
# Leistungsdaten einer Steckdose (FileLog)
#
# plotReplace-Parameter: DataDevice (von diesem Gerät stammen die Daten)
# FileLogDevice (in diesem Gerät werden die Daten geloggt)
# stateOFFvalue (y-Wert zur Darstellung von ausgeschaltetem Zustand)
# stateONvalue (y-Wert zur Darstellung von eingeschaltetem Zustand)
# stateUNKNOWNvalue (y-Wert zur Darstellung von unbekanntem Zustand)
# title (in der Regel ein perl-Ausdruck zur Darstellung von Eckwerten in der Titelzeile)
# yrange (Wertebereich für Darstellung in W vorgeben)
# y2range (Wertebereich für Darstellung in mA vorgeben)
set terminal png transparent size <SIZE> crop
set output '<OUT>.png'
set xdata time
set timefmt "%Y-%m-%d_%H:%M:%S"
set xlabel " "
set title '<title>'
set ytics
set y2tics
set grid ytics y2tics
set ylabel "Leistung (W)"
set y2label "Strom (mA)"
set yrange %yrange%
set y2range %y2range%
#%FileLogDevice% 4:%DataDevice%.power\x3a:0:
#%FileLogDevice% 4:%DataDevice%.current\x3a:"":($fld[3]*1000)
#%FileLogDevice% 4:%DataDevice%.userRead_socket_state\x3a:"":($fld[3]=~"off"?%stateOFFvalue%:($fld[3]=~"on"?%stateONvalue%:%stateUNKNOWNvalue%))
plot "<IN>" using 1:2 axes x1y1 title 'Leistung' ls l0 lw 1 with steps,\
"<IN>" using 1:2 axes x1y2 title 'Strom' ls l1fill_stripe lw 1 with steps,\
"<IN>" using 1:2 axes x1y1 title 'Schaltzustand' ls l3 lw 1 with steps
- Definition von SVG-Device SVG_Test
defmod SVG_Test SVG ...FileLog-Device...:SVG_PlugX:CURRENT
attr SVG_Test captionPos auto
attr SVG_Test plotReplace DataDevice="...Data-Device..." FileLogDevice="...FileLog-Device..." stateOFFvalue="20" stateONvalue="30" stateUNKNOWNvalue="10" yrange="[0:75]" y2range="[0:300]" title={"Steckdose(Testgerät) --- W: $data{min1}...$data{max1} / $data{currval1} --- mA: $data{min2}...$data{max2} / $data{currval2}"}
- So sieht das resultierende Diagramm aus
Temperatur- und Heizungsdaten eines Zimmers
Quelle: Beitrag (Datenquelle ist ein DBLog-Device namens LogDB):
# Created by FHEM/98_SVG.pm, 2020-01-06
# to replace variables, use plotReplace like
# plotReplace-Parameter: SPEC1=Thermostat (von diesem Gerät stammen die Thermostat-Daten)
# DBLogDevice (in diesem Gerät werden die Daten geloggt)
# Die übrigen plotReplace-Parameter sind selbsterklärend, Beispiel:
# attr SVG_Thermostat plotReplace DBLogDevice=DBLog SPEC1=Thermostat TL="My example thermostat" EXTERNALTEMPDEVICE=MYSENSOR_97 EXTERNALTEMPREADING=temperature2 \
# ROOMHUMIDITYDEVICE=HUEDevice3 EXTERNALHUMIDITYREADING=humidity ROOMTEMPDEVICE=HUEDevice4 ROOMTEMPREADING=temperature WINDOW1=Window1_MyRoom WINDOW2=Window2_MyRoom
set terminal png transparent size <SIZE> crop
set output '<OUT>.png'
set xdata time
set timefmt "%Y-%m-%d_%H:%M:%S"
set xlabel " "
set title '<TL>'
set ytics
set y2tics
set grid
set ylabel "Valve/Window"
set y2label "Temperature"
set yrange [-5:105]
set y2range [-15:35]
set isosample 20
#%DBLogDevice% %SPEC1%:desired-temp::
#%DBLogDevice% %SPEC1%:measured-temp:0:
#%DBLogDevice% %EXTERNALTEMPDEVICE%:%EXTERNALTEMPREADING%::
#%DBLogDevice% %SPEC1%:actuator:0:int
#%DBLogDevice% %ROOMHUMIDITYDEVICE%:%EXTERNALHUMIDITYREADING%:0:
#%DBLogDevice% %ROOMTEMPDEVICE%:%ROOMTEMPREADING%:0:
#%DBLogDevice% %WINDOW1%:state:::$val=~s/(open|closed|tilted)(\d*).*/$1eq"open"?60:$1eq"tilted"?45:0/eg
#%DBLogDevice% %WINDOW2%:state:::$val=~s/(open|closed|tilted)(\d*).*/$1eq"open"?60:$1eq"tilted"?45:0/eg
plot "<IN>" using 1:2 axes x1y2 title 'Desired' ls l0 lw 1 with lines,\
"<IN>" using 2:2 axes x1y2 title 'Measured actuator' ls l7 lw 1 with lines,\
"<IN>" using 1:2 axes x1y2 title 'Aussen' ls l1 lw 1 with lines,\
"<IN>" using 1:2 axes x1y1 y2title 'Valve' ls l5 lw 1 with steps,\
"<IN>" using 1:2 axes x1y1 title 'Humidity' ls l2 lw 1 with lines,\
"<IN>" using 1:2 axes x1y2 title 'Measured roomsensor' ls l3 lw 1 with lines,\
"<IN>" using 1:2 axes x1y1 y2title '%WINDOW1%' ls l4fill lw 0.5 with steps,\
"<IN>" using 1:2 axes x1y1 y2title '%WINDOW2%' ls l5fill lw 0.5 with steps
Hinweise
- Plot-Abrisse vermeiden
Sind in den Quelldaten nicht genügend Datenpunkte vorhanden, kann es zu Lücken in der Darstellung kommen. Abhilfe kann man mit LogProxy schaffen oder, indem man zusätzliche Datenpunkte in den Datenquellen generiert, z.B. durch das Setzen von addLog-Attributen an FileLog bzw. DBLog-Geräten. Weitere Hinweise sind in Plot-Abriss vermeiden zu finden.
Links