NEWS
[Skript] Absolute Feuchte berechnen
-
Kannst du irgendwie dein VIS View davon auch zur Verfügung stellen und ggf. auch noch die passenden Skripte dazu damit man sieht woher/wie du diese Informationen alle extrahierst. `
Das sind zig kleine Skripte. Ich kann gerne hier ein paar Beispiele ablegen.
Z.B. erzeugt ein lokales Skript auf dem Ubuntu Server mit der mySQL Datenbank Abfragen auf dem Server, die wiederum dort lokal gespeichert werden. Der ioBroker Server (ein 2. Ubuntu Server) hat dann den entsprechenden Pfad gemountet. Diese Ergebnisdateien werden mit excec() cat ausgelesen und ausgewertet. Lokal werden direkt die Abfragen gestartet.
Ein paar Beispiele:
Abfrage im Web, welche CCU2 Software aktuell verfügbar ist:
! ````
request = require('request');
! var url ="http://update.homematic.com/firmware/download?cmd=js_check_version&version=12345&product=HM-CCU2&serial=12345";
var timeout = 10000;
! var pfad = "Systeminfos.CCU" + "."; // Pfad Systeminfos zur CCU
var cronStr = "*/45 * * * *";
! var idActVersion = pfad + 'Version_aktuell';
! createState(idActVersion, "", {
name: 'CCU SW Version aktuell verfügbar',
desc: 'CCU SW Version aktuell verfügbar',
type: 'string',
unit: '',
role: 'value'
});
! var options = {
url: url= url,
timeout: timeout,
headers: {
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.1'
}
};
! function readWeb(url) {
try {
request(options, function (error, response, body) {
if (!error && ('' + response.statusCode).match(/^2\d\d$/)) { // kein Fehler (2xx), Inhalt in body
log(response.statusCode);
if (body !== null) {
var actVersion = body.match(/\d+.\d+.\d+/);//log(body); //log(actVersion);
! if (actVersion !== null) setState(idActVersion ,actVersion.toString());
}} else { // Fehler bei der Abfrage der CUxD Webseite //log("StatusCode="+response.statusCode); if (error.code !== null) { log("ERROR CODE: " + error.code + " ################"); // EHOSTUNREACH, ETIMEDOUT if (!error) { log("response.statusCode: " + response.statusCode); } else { // } log(error,'error'); setState(idActVersion,"Fehler"); } else { log ("#### ERROR CODE = null ####",error); } /* setTimeout(function(l) { // bei Fehler jede Stunde abfragen readWeb(url); },3600000); */ } }); } catch (error) { log('Fehler (try) leseWebseite: ' + error, 'error'); }
}
! // regelmässige Wiederholungen
// -----------------------------------------------------------------------------
schedule(cronStr, function () {
readWeb(url);
});
! // main
// -----------------------------------------------------------------------------
function main() {
readWeb(url);
}
! // Start Skript:
// -----------------------------------------------------------------------------
setTimeout(main, 500);
! ````Daten der CCU2 über CuxD abfragen (aktuelle Firmware, Auslastung, usw.):
! ````
! // Skriptname und Instanz nicht ändern!
// javascript.1.scriptEnabled.Daten.Read_CUxD
//
// scriptEnabled wird von anderen Skripten verwendet:
// script.js.Steuerung.Reaktion_auf_Ping
! request = require('request');
! var ccuIp ="172.16.199.99";
var timeout = 3000;
! var pfad = "Systeminfos.CCU" + "."; // Pfad Systeminfos zur CCU
var pfad2 = "Systeminfos.CUxD" + "."; // Pfad Systeminfos zu CUxD
var cronStr = "*/10 * * * ";
! var idCcuUptime = pfad + 'uptime';
var idCcuVersion = pfad + 'Version';
! var idCcuLa01 = pfad + 'Load_Average.load_average_01_min';
var idCcuLa05 = pfad + 'Load_Average.load_average_05_min';
var idCcuLa15 = pfad + 'Load_Average.load_average_15_min';
! var idCpuLoad = pfad + '10s_CPU_Load';
! var idCuxdUptime = pfad2 + 'uptime';
var idCuxdVersion = pfad2 + 'Version';
var idCuxdStatus = pfad2 + 'Status_http';
var idCuxdStatusBool= pfad2 + 'Status_http_bool';
var idCuxdError = pfad2 + 'http_error';
! createState(idCcuUptime, 0, {
name: 'CCU Uptime',
desc: 'CCU Uptime',
type: 'number',
unit: 'Tag(e)',
role: 'value'
});
! createState(idCcuVersion, "", {
name: 'CCU SW Version',
desc: 'CCU SW Version',
type: 'string',
unit: '',
role: 'value'
});
! createState(idCuxdUptime, 0, {
name: 'CUxD Uptime',
desc: 'CUxD Uptime',
type: 'number',
unit: 'Tag(e)',
role: 'value'
});
! createState(idCuxdVersion, "", {
name: 'CUxD SW Version',
desc: 'CUxD SW Version',
type: 'string',
unit: '',
role: 'value'
});
! createState(idCuxdStatus, 0, {
name: 'Status Webseite CUxD',
desc: 'Status Webseite CUxD',
type: 'number',
unit: '',
role: 'value'
});
! createState(idCuxdStatusBool, false, {
name: 'Status Webseite CUxD bool',
desc: 'Status Webseite CUxD bool',
type: 'boolean',
unit: '',
role: 'value'
});
! createState(idCuxdError, "", {
name: 'letzte Meldung Webseite CUxD',
desc: 'letzte Meldung Webseite CUxD',
type: 'string',
unit: '',
role: 'value'
});
! createState(idCcuLa01, 0, {
name: 'mittlere Systemauslastung in der letzten Minute',
desc: 'mittlere Systemauslastung in der letzten Minute',
type: 'number',
unit: '',
role: 'value'
});
! createState(idCcuLa05, 0, {
name: 'mittlere Systemauslastung in der letzten 5 Minuten',
desc: 'mittlere Systemauslastung in der letzten 5 Minuten',
type: 'number',
unit: '',
role: 'value'
});
! createState(idCcuLa15, 0, {
name: 'mittlere Systemauslastung in der letzten 15 Minuten',
desc: 'mittlere Systemauslastung in der letzten 15 Minuten',
type: 'number',
unit: '',
role: 'value'
});
! createState(idCpuLoad, 0, {
name: '10 Sekunden CPU Load',
desc: '10 Sekunden CPU Load',
type: 'number',
unit: '%',
role: 'value'
});
! var options = {
url: url= "http://" + ccuIp + "/addons/cuxd/index.ccc?m=15",
timeout: timeout,
headers: {
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.1'
}
};
! function readCUxD(url) {
try {
request(options, function (error, response, body) {
if (!error && ('' + response.statusCode).match(/^2\d\d$/)) { // kein Fehler (2xx), Inhalt in body
//log(response.statusCode);
var cuxdUptimeStr = body.match(/CUxD-Uptime(.+)/i);
var ccuUptimeStr = body.match(/CCU-Uptime(.+)/i);
var speicher = body.match(/Speicher:(.+)/i);
var filesystem = body.match(/Filesystem: / (.+)/i);
var filesystemSD = body.match(/Filesystem: /media/sd(.+)/i);
var loadAverage = body.match(/load-average: (.)+/i);
var cpuLoad = loadAverage;
! var cuxdVersion = cuxdUptimeStr.toString().match(/((\d+.){1,2}\d+)/i);
var cuxdUptime = cuxdUptimeStr.toString().replace(/ Tag.+/i,"");
cuxdUptime = parseInt(cuxdUptime.replace(/(.?)): /,""));var ccuVersion = ccuUptimeStr.toString().match(/((\d+\.){1,2}\d+)/i); var ccuUptime = ccuUptimeStr.toString().replace(/ Tag.+/i,""); ccuUptime = parseInt(ccuUptime.replace(/(.*?)\): /,""));
! loadAverage = loadAverage.toString().replace(/load-average: /, "");
loadAverage = loadAverage.match(/.{14}/);
loadAverage = loadAverage.toString().replace(/,/g,".");
loadAverage = loadAverage.split(" ");
! cpuLoad = cpuLoad.toString().replace(/.+cpu-load: /, "");
cpuLoad = cpuLoad.toString().replace("%", "");! //log("-------------------------------------");
//log(cuxdUptimeStr);
//log(ccuUptimeStr);
//log(speicher);
log("Filesystem: "+filesystem);
log("FilesystemSD: "+filesystemSD);
//log("CUxD Version : "+ cuxdVersion[0]);
//log("CUxD Uptime: " + cuxdUptime + " Tag(e)");
//log("ccu Version : "+ ccuVersion[0]);
//log("ccu Uptime: " + ccuUptime + " Tag(e)");
//log(body);
! setState(idCcuLa01 ,parseFloat(loadAverage[0]));
setState(idCcuLa05 ,parseFloat(loadAverage[1]));
setState(idCcuLa15 ,parseFloat(loadAverage[2]));
! setState(idCpuLoad ,parseFloat(cpuLoad));
!
setState(idCuxdStatus ,response.statusCode);
setState(idCuxdStatusBool ,true);
! setState(idCuxdError ,"OK (" + response.statusCode+")");
! setState(idCcuUptime ,ccuUptime);
setState(idCcuVersion ,ccuVersion[0]);
! setState(idCuxdUptime ,cuxdUptime);
setState(idCuxdVersion ,cuxdVersion[0]);} else { // Fehler bei der Abfrage der CUxD Webseite //log("StatusCode="+response.statusCode); log("ERROR CODE: " + error.code + " ################"); // EHOSTUNREACH, ETIMEDOUT if (!error) { setState(idCuxdStatus ,response.statusCode); } else { setState(idCuxdStatus ,-1); } setState(idCuxdStatusBool ,false); setState(idCuxdError ,formatDate(new Date(), "YYYY-MM-DD,hh:mm " + error));
! // Uptime negieren, wenn Webseite nicht erreichbar
if (getState(idCuxdUptime).val > 0) setState(idCuxdUptime,getState(idCuxdUptime).val * -1);
if (getState(idCcuUptime).val > 0) setState(idCcuUptime,getState(idCcuUptime).val * -1);
log(error,'error');setTimeout(function(l) { // bei Fehler jede Minute abfragen readCUxD(url); },60000); } }); } catch (error) { log('Fehler (try) leseWebseite: ' + error, 'error'); }
}
! // regelmässige Wiederholungen
// -----------------------------------------------------------------------------
schedule(cronStr, function () {
readCUxD(url);
});
! // main
// -----------------------------------------------------------------------------
function main() {
readCUxD(url);
}
! // Start Skript:
// -----------------------------------------------------------------------------
setTimeout(main, 500);
! ````Vergleich der Firmware im Internet und der auf der CCU2:
!
var pfad = "Systeminfos.CCU" + "."; // Pfad Systeminfos zur CCU ! var idFWnow = "javascript.1.Systeminfos.CCU.Version"/*CCU SW Version*/; var idFWact = "javascript.1.Systeminfos.CCU.Version_aktuell"/*CCU SW Version aktuell verfügbar*/; ! var idFWneu = pfad + 'neue_FW_verfügbar'; var idFWerror = "javascript." + instance + "." + pfad + 'letzte_FW_Abfrage_Fehler'; ! createState(idFWneu, false, { name: 'neue CCU2 Firmware verfügbar', desc: 'neue CCU2 Firmware verfügbar', type: 'boolean', unit: '', role: 'value' }); ! createState(idFWerror, false, { name: 'letzte FW Abfrage war ein Fehler', desc: 'letzte FW Abfrage war ein Fehler', type: 'boolean', unit: '', role: 'value' }); ! // bestehende Firmware hat sich geändert on({id:idFWnow,change:'ne'}, function (obj) { vergleichFW(); }); ! // verfügbare Firmware hat sich geändert on({id:idFWact,change:'ne'}, function (obj) { vergleichFW(); }); ! function vergleichFW() { var fwAct = getState(idFWact).val; var fwNow = getState(idFWnow).val; var fWError = getState(idFWerror).val; log("CCU2 Firmware im Internet : " + fwAct); log("CCU2 Firmware auf der CCU2: " + fwNow); if (fwAct != "Fehler") { if(!fWError) { // nur wenn die letzte Internetabfrage fehlerfrei war if (fwAct != fwNow) { setState(idFWneu,true); // neue Firmware verfügbar log("CCU2: FW ist: " + fwNow + ", neue Firmware verfügbar: " + fwAct); sayit("Für die CCU2 ist eine neue Firmware verfügbar",50); sendTo("pushover" ,"neue CCU2 Firmeware: " + fwAct); sendTo('telegram.1' ,"neue CCU2 Firmeware: " + fwAct); ! } else { setState(idFWneu,false); // keine neue Firmware verfügbar log("CCU2: FW ist aktuell ("+ fwNow+")"); sayit("CCU2 Firmware ist aktuell.",50); } setState(idFWerror,false); // wenn die letzte Internetabfrage einen Fehler hatte, nun auf fehlerfrei setzten und nächstes Mal prüfen } } else { setState(idFWerror,true); // FW Abfrage im Internet = Fehler -> Flag Fehler auf true } } ! // main // ----------------------------------------------------------------------------- function main() { vergleichFW(); } ! // Start Skript: // ----------------------------------------------------------------------------- setTimeout(main, 500); !
Abfrage der node.js Version auf dem ioBroker Server:
! ````
var pfad = "Systeminfos.ioBroker" + ".";
var cronStr = "*/30 * * * *";
! var abfrage = "nodejs -v";
! var idNodejsVersion = pfad + 'node_js_Version';
! createState(idNodejsVersion, "", {
name: 'node.js Version',
desc: 'node.js Version (abgefragt mit nodejs -v)',
type: 'string',
unit: '',
role: 'value'
});! function abfrageVersion() {
exec(abfrage, function(err, stdout, stderr) {
if (err) {
log(err,"error");
return;
}
//log(stdout);
setStateDelayed(idNodejsVersion,stdout,100);
});
}
! function abfragen() {
abfrageVersion();
}
! // regelmässige Wiederholungen
// -----------------------------------------------------------------------------
schedule(cronStr, abfragen);
! // main
// -----------------------------------------------------------------------------
function main() {
abfragen();
}
! // Start Skript:
// -----------------------------------------------------------------------------
! setTimeout(main, 500);
! ````Abfrage der Festplattenauslastung auf dem ioBroker Server:
! ````
// ermittelt auf Linuxrechner den Festplattenplatz für ioBroker
// mit dem Linux Befehl: du
! var pfad = "Systeminfos.ioBroker" + ".";
var cronStr = "*/30 * * * *";
! var abfrageGesamt ="du /opt/iobroker -s -m";
var abfrageData ="du /opt/iobroker/iobroker-data -s -m";
var abfrageObjects ="du /opt/iobroker/iobroker-data/objects.json -s -k";
var abfrageStates ="du /opt/iobroker/iobroker-data/states.json -s -k";
var abfrageLog ="du /opt/iobroker/log -s -k";
! var idHdGesamt = pfad + 'HD_gesamt';
var idHdData = pfad + 'HD_iobroker_data';
var idHdObjects = pfad + 'HD_objects_json';
var idHdStates = pfad + 'HD_states_json';
var idHdLog = pfad + 'HD_log';
! createState(idHdGesamt, 0, {
name: 'Festplattenplatz ioBroker gesamt',
desc: 'Festplattenplatz ioBroker gesamt',
type: 'number',
unit: 'MByte',
role: 'value'
});createState(idHdData, 0, {
name: 'Festplattenplatz ioBroker-data',
desc: 'Festplattenplatz ioBroker-data',
type: 'number',
unit: 'MByte',
role: 'value'
});! createState(idHdStates, 0, {
name: 'Festplattenplatz states.json',
desc: 'Festplattenplatz states.json',
type: 'number',
unit: 'kByte',
role: 'value'
});
! createState(idHdObjects, 0, {
name: 'Festplattenplatz objects.json',
desc: 'Festplattenplatz objects.json',
type: 'number',
unit: 'kByte',
role: 'value'
});
! createState(idHdLog, 0, {
name: 'Festplattenplatz ioBroker Log-Files',
desc: 'Festplattenplatz ioBroker Log-Files',
type: 'number',
unit: 'kByte',
role: 'value'
});
! // Belegung Festplattenplatz für ioBroker mit "du" auslesen
function abfrageHD(abfrage,dp) {
exec(abfrage, function(err, stdout, stderr) {
if (err) {
log(err,"error");
return;
}
stdout = stdout.replace(/[\D]+/, ""); // alle nicht-Ziffern entfernen
setState(dp,parseInt(stdout));
});
}
! function abfragen() {
abfrageHD(abfrageGesamt,idHdGesamt);
abfrageHD(abfrageData,idHdData);
abfrageHD(abfrageObjects,idHdObjects);
abfrageHD(abfrageStates,idHdStates);
abfrageHD(abfrageLog,idHdLog);
}
! // regelmässige Wiederholungen
// -----------------------------------------------------------------------------
schedule(cronStr, abfragen);
! // main
// -----------------------------------------------------------------------------
function main() {
abfragen();
}
! // Start Skript:
// -----------------------------------------------------------------------------
! setTimeout(main, 500);
! ````Abfrage der Speicherauslastung auf dem ioBroker Server:
!
// ermittelt auf Linuxrechner den Speicherverbrauch // mit dem Linux Befehl: free // // Beduetung der Werte: // http://www.selflinux.org/selflinux/html/information_basic02.html ! // getestet unter Ubuntu 16.04 mit deutscher Ausgabe von "free -m" ! // free -m auf der Kosole muss folgende Tabelle ausgeben: ! //# free -m // gesamt benutzt frei gemns. Puffer/Cache verfügbar //Speicher: 7966 1238 5916 10 812 6624 //Auslagerungsspeicher: 8187 0 8187 ! var pfad = "Systeminfos.host.Speicher" + "."; var cronStr = "*/1 * * * *"; ! var forceCreation = false; ! var datenpunkte = { 'Speicher_1_gesamt': { "init":0, "common": { name: 'Speicher gesamt, der für das System verfügbar ist', desc: 'Speicher gesamt, der für das System verfügbar ist (ohne Kernel)', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_2_benutzt': { "init":0, "common": { name: 'Speicher benutzt', desc: 'Speicher benutzt', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_3_frei': { "init":0, "common": { name: 'Speicher frei', desc: 'Speicher frei', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_4_gemeinsam': { "init":0, "common": { name: 'gemeinsamer Speicher für Prozesse', desc: 'gemeinsamer Speicher für Prozesse', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_5_Buffer_Cache': { "init":0, "common": { name: 'Speicher als Cache', desc: 'Speicher als Cache', type: 'number', unit: 'MByte', role: 'value' } }, 'Speicher_6_verfügbar': { "init":0, "common": { name: 'verfügbarer Speicher', desc: 'verfügbarer Speicher', type: 'number', unit: 'MByte', role: 'value' } }, 'Auslagerungsspeicher_1_gesamt': { "init":0, "common": { name: 'Auslagerungsspeicher gesamt', desc: 'Auslagerungsspeicher gesamt', type: 'number', unit: 'MByte', role: 'value' } }, 'Auslagerungsspeicher_2_benutzt': { "init":0, "common": { name: 'Auslagerungsspeicher benutzt', desc: 'Auslagerungsspeicher benutzt', type: 'number', unit: 'MByte', role: 'value' } }, 'Auslagerungsspeicher_3_frei': { "init":0, "common": { name: 'Auslagerungsspeicher frei', desc: 'Auslagerungsspeicher frei', type: 'number', unit: 'MByte', role: 'value' } } }; ! function createDp() { var name; var init; var common; for (var dp in datenpunkte) { name = pfad + dp; init = datenpunkte[dp].init; common = datenpunkte[dp].common; createState(name, init , forceCreation, common); } } ! function writeDp(arr) { var i = 0; for (var dp in datenpunkte) { var wert = parseInt(arr[i++]); setState(pfad + dp,wert); //log(dp+": "+ wert + " #" + typeof(wert)); } } ! // Speicher mit "free -m" auslesen function freeMem() { exec('free -m', function(err, stdout, stderr) { if (err) { log(err); return; } stdout = stdout.replace(/[\D]+/, ""); // alle Zeichen vor der ersten Ziffer entfernen stdout = stdout.split(/[\D]+/g); // alle nicht-Ziffern als Trennzeichen für das Array verwenden (im Block) //log(stdout); writeDp(stdout); }); } ! // regelmässige Wiederholungen // ----------------------------------------------------------------------------- schedule(cronStr, freeMem); ! // main // ----------------------------------------------------------------------------- function main() { freeMem(); } ! // Start Skript: // ----------------------------------------------------------------------------- ! createDp(); setTimeout(main, 500); !
usw. usw.
Das sind recht viele und individuelle Abfragen.
Wenn Du aus der Übersicht was gebrauchen kannst, dann kann ich das gezielt posten.
Alles wäre etwas viel…
-
[…]
usw. usw.
Das sind recht viele und individuelle Abfragen.
Wenn Du aus der Übersicht was gebrauchen kannst, dann kann ich das gezielt posten.
Alles wäre etwas viel… `
Danke schonmal dafür. Schau ich mir gleich im Anschluss mal an und geb bescheid wenn mich noch was interessiert von deiner Systemübersicht. An was ich aber gerade sitze ist nochmal dein Schwellwertskript und das passende VIS widget dazu. Das läuft prinzipiell hier schon sehr gut, aber in dem VIS gadget sind z.B. Referenz auf sowas wie '{javascript.0.Visualisierung.Fenster.Farbe_Fenster_Bad}'. Wie genau generierst du die?
-
Das läuft prinzipiell hier schon sehr gut, aber in dem VIS gadget sind z.B. Referenz auf sowas wie '{javascript.0.Visualisierung.Fenster.Farbe_Fenster_Bad}'. Wie genau generierst du die? `
Das sind die Bindings, beschrieben unter:
https://github.com/iobroker/iobroker.vi … of-objects
Du kannst die Felder in VIS direkt mit Datenpunkten verknüpfen.
Du musst Dir nur die benötigte Objekt ID raussuchen und in den geschweiften Klammern eintragen, wo Du sie benötigst.
Entweder unter den Objekten:
Oder im VIS Editor bei einem Widget mit ID (unter ID raussuchen) und dann ausschneiden/einfügen, wo Du es hinhaben willst.
-
Oh… habe die eigentliche Frage falsch gelesen.
Habe mich schon gewundert
-
Oh… habe die eigentliche Frage falsch gelesen.
Habe mich schon gewundert `
In der Tat. Mir ist natürlich das mit den Bindings bekannt, allerdings weiss ich nicht wie du diese "javascript.0.Visualisierung…." Datenpunkte generierst. Darum geht es mir.
-
Das läuft prinzipiell hier schon sehr gut, aber in dem VIS gadget sind z.B. Referenz auf sowas wie '{javascript.0.Visualisierung.Fenster.Farbe_Fenster_Bad}'. Wie genau generierst du die? `
So, nun mit der richtigen Antwort :roll:
Das ist ein ""Logik-Skript".
Das muss ich allerdings mal viel eleganter machen.
Hatte angefangen, ist gewachsen und ist nun extrem fehleranfällig, wenn man was neues hinzufügt.
Das kann man besser machen
! ````
var debug = false;
! var dpPfad = "Visualisierung.Fenster" + "."; // In welchem Pfad sollen die Datenpunkte angelegt werden. String mit "." am Ende.
var instanz = "javascript." + instance + ".";
! var farbeInit = "background:rgb(204, 204, 204);";
var farbeNichtOk = "background:yellow;";
var farbeOk = "background:lime;";
! var idFarbeBadFenster = dpPfad + 'Farbe_Fenster_Bad';
var idFarbeBadLueften = dpPfad + 'Farbe_Lueften_Bad';
var idLueftenBad = "javascript.0.Raumklima.Raum.Bad.Lüftungsempfehlung";
var idFensterOffenBad = "hm-rpc.0.KEQ099999.1.STATE"/Fenster Bad.STATE/;
var idHystereseBad = "javascript.0.Raumklima.Raum.Bad.DETAILS_Lüftungsempfehlung.Lüften_Hysterese"/Logik im Bereich der Hysterese. Keine Änderung der bestehenden Lüftungsempfehlung./;
! var idFarbeSchlafzimmerFenster = dpPfad + 'Farbe_Fenster_Schlafzimmer';
var idFarbeSchlafzimmerLueften = dpPfad + 'Farbe_Lueften_Schlafzimmer';
var idLueftenSchlafzimmer = "javascript.0.Raumklima.Raum.Schlafzimmer.Lüftungsempfehlung"/Lüftungsempfehlung/;
var idFensterOffenSchlafzimmer = "hm-rpc.0.LEQ199999.1.STATE"/Fenster Schlafzimmer.STATE/;
var idHystereseSchlafzimmer = "javascript.0.Raumklima.Raum.Schlafzimmer.DETAILS_Lüftungsempfehlung.Lüften_Hysterese";
! var idFarbeGaestebadTuer = dpPfad + 'Farbe_Tür_Gästebad';
var idFarbeGaestebadLueften = dpPfad + 'Farbe_Lueften_Gästebad';
var idLueftenGaestebad = "javascript.0.Raumklima.Raum.Gästebad.Lüftungsempfehlung"/Lüftungsempfehlung/;
var idTuerOffenGaestebad = "hm-rpc.0.KEQ099999.1.STATE"/Tür Gästebad.STATE/;
var idHystereseGaestebad = "javascript.0.Raumklima.Raum.Gästebad.DETAILS_Lüftungsempfehlung.Lüften_Hysterese"/Logik im Bereich der Hysterese. Keine Änderung der bestehenden Lüftungsempfehlung./;
! var idFarbeKatharinaFenster = dpPfad + 'Farbe_Fenster_Katharina';
var idFarbeKatharinaLueften = dpPfad + 'Farbe_Lueften_Katharina';
var idLueftenKatharina = "javascript.0.Raumklima.Raum.Katharina.Lüftungsempfehlung"/Lüftungsempfehlung/;
var idFensterKatharina = "hm-rpc.0.MEQ199999.1.STATE"/Fenster Katharina/;
var idHystereseKatharina = "javascript.0.Raumklima.Raum.Katharina.DETAILS_Lüftungsempfehlung.Lüften_Hysterese"/Logik im Bereich der Hysterese. Keine Änderung der bestehenden Lüftungsempfehlung./;
! // =============================================================================
// Datenpunkte anlegen
// =============================================================================
function dpAnlegen() {
! // einfach angelegte Datenpunkte
// -----------------------------
//createState(dpPfad + 'datenpunktName',"Test");
! // ausführlich beschriebene Datenpunkte
// ------------------------------------
! createState(idFarbeBadFenster, farbeInit, {
name: 'Farbe Fenster Bad',
desc: 'Farbliche Darstellung Badezimmerfenster in Abhängigkeit der Lüftungslogik',
type: 'string',
unit: ''
});
! createState(idFarbeSchlafzimmerFenster, farbeInit, {
name: 'Farbe Fenster Schlafzimmer',
desc: 'Farbliche Darstellung Schlafzimmerzimmerfenster in Abhängigkeit der Lüftungslogik',
type: 'string',
unit: ''
});
! createState(idFarbeGaestebadTuer, farbeInit, {
name: 'Farbe Tür Gästebad',
desc: 'Farbliche Darstellung Gästebadtür in Abhängigkeit der Lüftungslogik',
type: 'string',
unit: ''
});
! createState(idFarbeKatharinaFenster, farbeInit, {
name: 'Farbe Fenster Katharina',
desc: 'Farbliche Darstellung Fenster Katharina in Abhängigkeit der Lüftungslogik',
type: 'string',
unit: ''
});
! createState(idFarbeSchlafzimmerLueften, farbeInit, {
name: 'Farbe Lüften Schlafzimmer',
desc: 'Farbliche Darstellung Lüftungsempfehlung im Schlafzimmer in Abhängigkeit der Lüftungslogik und Fensterstellung',
type: 'string',
unit: ''
});
! createState(idFarbeBadLueften, farbeInit, {
name: 'Farbe Lüften Bad',
desc: 'Farbliche Darstellung Lüftungsempfehlung im Bad in Abhängigkeit der Lüftungslogik und Fensterstellung',
type: 'string',
unit: ''
});
! createState(idFarbeGaestebadLueften, farbeInit, {
name: 'Farbe Lüften Gästebad',
desc: 'Farbliche Darstellung Lüftungsempfehlung im Gästebad in Abhängigkeit der Lüftungslogik und Fensterstellung',
type: 'string',
unit: ''
});
! createState(idFarbeKatharinaLueften, farbeInit, {
name: 'Farbe Lüften Katharina',
desc: 'Farbliche Darstellung Lüftungsempfehlung im Katharina in Abhängigkeit der Lüftungslogik und Fensterstellung',
type: 'string',
unit: ''
});}
! // -----------------------------------------------------------------------------
// Funktionen Funktionen
// -----------------------------------------------------------------------------
! function setFarbe(idLueften,idOffen,idFarbeFenster,idHysterese,idFarbeLueften) {
var lueften = getState(idLueften).val;
var offen = getState(idOffen).val;
var farbe = farbeNichtOk;var logikOK = ((lueften && offen) || (!lueften && !offen ) ? true : false); // true: optimaler Zustand
! if(idHysterese) {
var hysterese = getState(idHysterese).val;
if (hysterese) {
logikOK = true;
}
}
! if(logikOK) farbe = farbeOk;
setState(idFarbeFenster,farbe); // Farbformatioerung schreiben
if(idFarbeLueften) {
setState(idFarbeLueften,farbe); // Farbformatioerung schreiben
}
if(debug) log("idLueften: " + idLueften);
if(debug) log("Lüften: " + lueften + " - offen: " + offen + " - farbe: " + farbe + " - logikOK: " + logikOK);
if(debug) log("--------------");
return logikOK; // falls benötigt, Ergebnis der Prüfung
}
! // -----------------------------------------------------------------------------
// Schedule Schedule
// -----------------------------------------------------------------------------
function onAnlegen() {
! /*
// wird um 00:00 ausgeführt
schedule({hour: 0, minute: 0}, function (){
// was soll passieren
});
*/
! // -----------------------------------------------------------------------------
// ON ON
// -----------------------------------------------------------------------------
! // Fenster Bad
on({id: idLueftenBad,change:'ne'}, function (obj) {
setFarbe(idLueftenBad,idFensterOffenBad,idFarbeBadFenster,idHystereseBad,idFarbeBadLueften);
});
! on({id: idFensterOffenBad ,change:'ne'}, function (obj) {
setFarbe(idLueftenBad,idFensterOffenBad,idFarbeBadFenster,idHystereseBad,idFarbeBadLueften);
});
! on({id: idHystereseBad ,change:'ne'}, function (obj) {
setFarbe(idLueftenBad,idFensterOffenBad,idFarbeBadFenster,idHystereseBad,idFarbeBadLueften);
});
! // Fenster Schlafzimmer
on({id: idLueftenSchlafzimmer,change:'ne'}, function (obj) {
setFarbe(idLueftenSchlafzimmer,idFensterOffenSchlafzimmer,idFarbeSchlafzimmerFenster,idHystereseSchlafzimmer,idFarbeSchlafzimmerLueften);
});
! on({id: idFensterOffenSchlafzimmer ,change:'ne'}, function (obj) {
setFarbe(idLueftenSchlafzimmer,idFensterOffenSchlafzimmer,idFarbeSchlafzimmerFenster,idHystereseSchlafzimmer,idFarbeSchlafzimmerLueften);
});
! on({id: idHystereseSchlafzimmer ,change:'ne'}, function (obj) {
setFarbe(idLueftenSchlafzimmer,idFensterOffenSchlafzimmer,idFarbeSchlafzimmerFenster,idHystereseSchlafzimmer,idFarbeSchlafzimmerLueften);
});
! // Tür Gästebad
on({id: idLueftenGaestebad,change:'ne'}, function (obj) {
setFarbe(idLueftenGaestebad,idTuerOffenGaestebad,idFarbeGaestebadTuer,idHystereseGaestebad,idFarbeGaestebadLueften);
});
! on({id: idTuerOffenGaestebad ,change:'ne'}, function (obj) {
setFarbe(idLueftenGaestebad,idTuerOffenGaestebad,idFarbeGaestebadTuer,idHystereseGaestebad,idFarbeGaestebadLueften);
});
! on({id: idHystereseGaestebad ,change:'ne'}, function (obj) {
setFarbe(idLueftenGaestebad,idTuerOffenGaestebad,idFarbeGaestebadTuer,idHystereseGaestebad,idFarbeGaestebadLueften);
});
! // Fenster Katharina
on({id: idLueftenKatharina,change:'ne'}, function (obj) {
setFarbe(idLueftenKatharina,idFensterKatharina,idFarbeKatharinaFenster,idHystereseKatharina,idFarbeKatharinaLueften);
});
! on({id: idFensterKatharina ,change:'ne'}, function (obj) {
setFarbe(idLueftenKatharina,idFensterKatharina,idFarbeKatharinaFenster,idHystereseKatharina,idFarbeKatharinaLueften);
});
! on({id: idHystereseKatharina ,change:'ne'}, function (obj) {
setFarbe(idLueftenKatharina,idFensterKatharina,idFarbeKatharinaFenster,idHystereseKatharina,idFarbeKatharinaLueften);
});
! }
! // =============================================================================
// main - Hauptprogramm (wird beim Scriptstart ausgeführt) main
// =============================================================================
function main() {
! // Hauptprogramm nach Timeout (z.B. damit neu angelegte Datenpunkte vorhanden sind)
// Im Hauptprogramm weiter:
setFarbe(idLueftenBad ,idFensterOffenBad,idFarbeBadFenster,idHystereseBad,idFarbeBadLueften);
setFarbe(idLueftenSchlafzimmer,idFensterOffenSchlafzimmer,idFarbeSchlafzimmerFenster,idHystereseSchlafzimmer,idFarbeSchlafzimmerLueften);
setFarbe(idLueftenGaestebad,idTuerOffenGaestebad,idFarbeGaestebadTuer,idHystereseGaestebad,idFarbeGaestebadLueften);
setFarbe(idLueftenKatharina,idFensterKatharina,idFarbeKatharinaFenster,idHystereseKatharina,idFarbeKatharinaLueften);
! }
dpAnlegen(); // erst die notwendigen Datenpunkte anlegen
setTimeout(onAnlegen, 500); // dann die Subscriptions setzen
setTimeout(main, 1000); // dann das Hauptprogramm starten
! ```` -
Das sind zig kleine Skripte. Ich kann gerne hier ein paar Beispiele ablegen.
[…]
usw. usw.
Das sind recht viele und individuelle Abfragen.
Wenn Du aus der Übersicht was gebrauchen kannst, dann kann ich das gezielt posten.
Alles wäre etwas viel… `
Nun hab ich mir die Skripte die du hier gepostet hattest mal zu Gemüte geführt und diese auch alle übernommen. In der Tat würde mich aber noch folgende Skripte interessieren:
1. Abfrageskript um die Prozessor+RAM Auslastung des Hosts zu ermitteln inkl. Anzahl der Linux Updates, etc. (ist in der Box "ubuntu1604server" zu sehen.
2. Skript zur Ermittlung der Anzahl der Servicemeldungen, Alarme, UNRECH, LOWBAT Meldungen der CCU2
3. Skript zur Ermittlung des Status der hue Bridge usw.
4. Skript zur Ermittlung des Status deiner Diskstation DS1512+ (hab das gleiche Teil
5. Skript zur Ermittlung des Status des WIFFI-wz
Und zu guter letzt wäre es noch schön du könntest den gesamten VIS-View deiner Systeminfos mal exportieren und hier zur Verfügung stellen damit ich mir die Darstellung des selben etwas besser abkupfern kann
Vielen Dank natürlich schon einmal im Voraus!
-
Hallo, Jens. Bekommst Du. Wird allerdings Sonntag werden. Vorab:
1. am Sonntag
2. findest Du auch hier im Forum (nicht von mir). Ansonsten Sonntag
3. kommt Sonntag, inkl. dem Part, der die aktuell im Internet verfügbare Version abfragt und mit dem Ist-Stand vergleicht
4. ist ein Skript auf der DS. Auch hier aus dem Forum. Den Part in ioBroker muss ich neu machen. Will da mehr Infos visualisieren. Im VIS View siehst Du, dass auch gerade die wenigen Infos leer bleiben, da ich da schon angefangen hatte.
5. findest Du auch hier imForum. Ansonsten auch am Sonntag
Viel Arbeit. Habe aber viel dabei gelernt und man macht es nur einmal.
Wir scheinen ja fast die identische Ausstattung zu haben. Bei der CCU habe ich von Kassel im Kopf, dass Du aktiv bei einer Softwarelösung mitarbeitest. Das wäre auch mal ein Thema für mich von der CCU2 wegzukommen;-)
Gesendet von iPhone mit Tapatalk
-
Hallo, Jens. Bekommst Du. Wird allerdings Sonntag werden. `
OK, dann warte ich mal auf Sonntag. Allerdings war ich selbst auch nicht ganz untätig und hab mal kurzerhand dein Skript zur Generierung dieser "javascript.0.Visualisierung…" Datenpunkte umgeschrieben damit man dort am Anfang einfach nur eine Tabelle aller Räume angeben muss. Des Weiteren kann man jetzt mehr als nur ein Fenster bzw. beliebig viele Verschlüsse angeben:
! ````
var debug = false;
! var dpPfad = "Visualisierung.Fenster" + "."; // In welchem Pfad sollen die Datenpunkte angelegt werden. String mit "." am Ende.
var instanz = "javascript." + instance + ".";
! var farbeInit = "background:rgb(204, 204, 204);";
var farbeNichtOk = "background:yellow;";
var farbeOk = "background:lime;";
! var raumliste = {
"Badezimmer" : {
"verschluss1": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-BZ.STATE/
},
"Kinderzimmer" : {
"verschluss1": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-KZ-Links.STATE/,
"verschluss2": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-KZ-Rechts.STATE/
},
"Schlafzimmer" : {
"verschluss1": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-SZ-Links.STATE/,
"verschluss2": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-SZ-Rechts.STATE/
},
"Gästezimmer" : {
"verschluss1": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-GZ-Links.STATE/,
"verschluss2": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-GZ-Rechts.STATE/
},
"Wohnzimmer" : {
"verschluss1": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-WZ-Links.STATE/,
"verschluss2": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-WZ-Rechts.STATE/,
"verschluss3": "hm-rpc.0.LEQXXXXXX.1.STATE"/Terassentür-WZ.STATE/,
"verschluss4": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-AZ.STATE/
},
"Küche" : {
"verschluss1": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-Kü.STATE/,
"verschluss2": "hm-rpc.0.LEQXXXXXX.1.STATE"/Terassentür-Kü.STATE/
},
"WC-EG" : {
"verschluss1": "hm-rpc.0.MEQXXXXXX.1.STATE"/Fenster-WC-EG.STATE/
},
"HWR" : {
"verschluss1": "hm-rpc.0.MEQXXXXXXX.1.STATE"/Fenster-HWR.STATE/
}
};
! // =============================================================================
// Datenpunkte anlegen
// =============================================================================
function dpAnlegen() {
! // Datenpunkte anhand der Raumliste anlegen lassen
for (var raum in raumliste) {
createState(dpPfad + 'Farbe_Fenster_' + raum, farbeInit, {
name: 'Farbe Fenster ' + raum,
desc: 'Farbliche Darstellung ' + raum + '-Fenster in Abhängigkeit der Lüftungslogik',
type: 'string',
unit: ''
});
createState(dpPfad + 'Farbe_Lueften_' + raum, farbeInit, {
name: 'Farbe Lüften ' + raum,
desc: 'Farbliche Darstellung Lüftungsempfehlung im ' + raum + ' in Abhängigkeit der Lüftungslogik und Fensterstellung',
type: 'string',
unit: ''
});
}
}
! // -----------------------------------------------------------------------------
// Funktionen Funktionen
// -----------------------------------------------------------------------------
! function setFarbe(raumName) {var raum = raumliste[raumName]; var lueften = getState("javascript.0.Raumklima.Raum." + raumName + ".Lüftungsempfehlung").val; var offen; var farbe = farbeNichtOk; // kontrollieren ob ein Fenster offen ist var i=1; var verschluss; while((verschluss = raum['verschluss' + i])) { if(getState(verschluss).val) { offen = true; break; } i++; } var logikOK = ((lueften && offen) || (!lueften && !offen ) ? true : false); // true: optimaler Zustand
! var hysterese = getState("javascript.0.Raumklima.Raum." + raumName + ".DETAILS_Lüftungsempfehlung.Lüften_Hysterese").val;
if (hysterese) {
logikOK = true;
}
! if(logikOK) farbe = farbeOk;// Farbformatierung schreiben setState(dpPfad + 'Farbe_Fenster_' + raumName, farbe); setState(dpPfad + 'Farbe_Lueften_' + raumName, farbe); if(debug) log("idLueften: " + "javascript.0.Raumklima.Raum." + raumName + ".Lüftungsempfehlung"); if(debug) log("Lüften: " + lueften + " - offen: " + offen + " - farbe: " + farbe + " - logikOK: " + logikOK); if(debug) log("--------------"); // falls benötigt, Ergebnis der Prüfung return logikOK;
}
! // -----------------------------------------------------------------------------
// Schedule Schedule
// -----------------------------------------------------------------------------
function onAnlegen() {
! // Subscriptions anlegen
for (var raum in raumliste) {// subscription für Lüftungsempfehlung-Änderungen anlegen on({id: "javascript.0.Raumklima.Raum." + raum + ".Lüftungsempfehlung", change:'ne'}, function (obj) { setFarbe(raum); });
! // subscription für Hysterese-Änderungen anlegen
on({id: "javascript.0.Raumklima.Raum." + raum + ".DETAILS_Lüftungsempfehlung.Lüften_Hysterese", change:'ne'}, function (obj) {
setFarbe(raum);
});// eine subscription für jedes fenster anlegen var i=1; var idVerschluss; while((idVerschluss = raum['verschluss' + i])) { on({id: idVerschluss, change:'ne'}, function (obj) { setFarbe(raum); }); i++; } }
! log("Subscriptions angelegt");
}
! // =============================================================================
// main - Hauptprogramm (wird beim Scriptstart ausgeführt) main
// =============================================================================
function main() {
! // Hauptprogramm nach Timeout (z.B. damit neu angelegte Datenpunkte vorhanden sind)
// Im Hauptprogramm weiter:
for (var raum in raumliste) {
setFarbe(raum);
}
}
dpAnlegen(); // erst die notwendigen Datenpunkte anlegen
onAnlegen(); // dann die Subscriptions setzen
setTimeout(main, 1000); // dann das Hauptprogramm starten
! ````Vielleicht ist diese leichte Verbesserung ja auch für dich nützlich und du willst sie übernehmen. So ist der Skript auf jedenfall viel besser wattbar, finde ich.
-
Super!
das werde ich morgen direkt übernehmen:-)
danke!
Gesendet von iPhone mit Tapatalk
-
Super!
das werde ich morgen direkt übernehmen:-)
danke! `
Und? Script übernommen? Und wie sieht es mit den Dingen aus die du mir "bis Sonntag" noch posten wolltest hier?
-
Schande über mein Haupt.
Beides noch nicht
Multihost hatte sich dazwischen geschoben [emoji12]
hab dann was für spät Abends zu tun;-)
Gesendet von iPhone mit Tapatalk
-
Und wie sieht es mit den Dingen aus die du mir "bis Sonntag" noch posten wolltest hier? `
Hehe [emoji57] da ist einer sehr ungeduldig! [emoji23][emoji12] aber ich bin froh das du ruhr70 danach gefragt hast, ich habe mich nicht getraut!
Auch ich konnte paar interessante Sachen mopsen [emoji12][emoji6][emoji23]
Vielen Dank euch beiden!!!
Gesendet von iPhone mit Tapatalk
-
Schande über mein Haupt.
Beides noch nicht
Multihost hatte sich dazwischen geschoben [emoji12]
hab dann was für spät Abends zu tun;-) `
Ok, kein Stress Wollte nur nochmal etwas daran erinnern
Inzwischen hab ich meinen abgekupferten View mit der Raumklima Tabelle wie du fast fertig. Allerdings erschliessen sich mir die Werte darin nicht alle wirklich komplett. Vielleicht könntest du da nochmal bitte etwas aufklären dazu? Siehe hier:
Was mich da vor allem interessieren würde ist die Deutung des Rechten Bereiches:
1. Warum werden die geschlossenen Fenster bis auf das im Gästezimmer mit gelbem Hintergrund dargestellt? Ich verstehe das so, das das Fenster zwar geschlossen ist, aber ich es besser öffnen sollte?
2. Warum ist das "Lüften" hier mit gelben Hintergrund dargestellt? Hatte das auch mal mit grünem Hintergrund.
3. Die Begriffe "En", "Kü" und "Au" sind mir zwar bekannt allerdings ist der Blick auf die Tabelle nicht ganz intuitiv wie ich denke, oder? Weil z.B. nur im Gästezimmer momentan "Au" aus ist und das bedeutet ja "Auskühlschutz". Irgendwie kann ich da nicht richtig deuten was mir die drei werte Sagen sollen? Wenn "En" leuchtet, soll ich dann lüften zum entfeuchten? Und bei Kü zum kühlen? oder wie muss ich die werte genau interpretieren?
Wäre schön wenn du (der sich das ausgedacht hat) hier etwas detaillierter gerade auf die Interpretation der Tabelle eingehen könntest (gerade was den rechten Teil angeht).
-
Hier nun die gleiche Tabelle einige Minuten später nachdem die Frau nachhause gekommen ist und nun die Heizung sich wieder eingeschalten hat und damit dann auch die TEMP_Minimum werte entsprechend angepasst wurden für die Berechnung des Raumklimas:
Was ich hier z.B. im Vergleich zu vorherigen Tabelle nicht verstehe ist:
1. Warum wird jetzt "Lüften" in grün beim Gästezimmer angezeigt obwohl sich nichts verändert hat zum alten Status (auch TEMP_Minimum) ist für das Gästezimmer gleich geblieben?!?
2. Da die SOLL Temperatur z.B. für das Badezimmer jetzt von 17Grad auf 22 Grad hochgeregelt wurde (und damit auch TEMP_Minimum der Raumklimaberechnung) wird jetzt verständlicherweise nicht mehr "Lüften" in gelb angezeigt sondern ist ganz verschwunden. Allerdings auch das "Au" flag das nach meinem Verständnis doch sagen sollte das der Auskühlschutz deaktiviert ist. Aber es sollte doch das Gegenteil der fall sein? Und warum ist "geschlossen" immer noch gelb und nicht grün?
Fragen über Fragen
-
Was mich da vor allem interessieren würde ist die Deutung des Rechten Bereiches: `
Meine Grundüberlegung ist, dass möglichst alles grün sein sollte.
Wird alles grün angezeigt, ist alles im grünen Bereich
1. Warum werden die geschlossenen Fenster bis auf das im Gästezimmer mit gelbem Hintergrund dargestellt? Ich verstehe das so, das das Fenster zwar geschlossen ist, aber ich es besser öffnen sollte? `
Die Spalte "Lüften":
leer = keine Lüftungsempfehlung
Lüften = Lüftungsempfehlung
grün = alles OK, entsprechend der Lüftungsempfehlung
gelb = Empfehlung ist nicht erfüllt
Deine Interpretation passt. Fenster ist trotz Lüftungsempfehlung geschlossen.
Daher wird
"Lüften" gelb dargestellt -> Lüftungsempfehlung, aber nicht erfüllt
"geschlossen" gelb dargestellt -> Fenster sollte zum lüften auf sein
2. Warum ist das "Lüften" hier mit gelben Hintergrund dargestellt? Hatte das auch mal mit grünem Hintergrund. `
gelb, da trotz Empfehlung nciht gelüftet wird.
Wenn Du nun das Fenster öffnest, dann sollte "Lüften" grün dargestellt werden und die Anzeige des Fensters vom gelben "geschlossen" auf ein grünes "geöffnet" wechseln.
3. Die Begriffe "En", "Kü" und "Au" sind mir zwar bekannt allerdings ist der Blick auf die Tabelle nicht ganz intuitiv wie ich denke, oder? Weil z.B. nur im Gästezimmer momentan "Au" aus ist und das bedeutet ja "Auskühlschutz". Irgendwie kann ich da nicht richtig deuten was mir die drei werte Sagen sollen? Wenn "En" leuchtet, soll ich dann lüften zum entfeuchten? Und bei Kü zum kühlen? oder wie muss ich die werte genau interpretieren?
Wäre schön wenn du (der sich das ausgedacht hat) hier etwas detaillierter gerade auf die Interpretation der Tabelle eingehen könntest (gerade was den rechten Teil angeht). `
Die Spalten werden nicht benötigt.
Die eigentliche Lüftungslogik kommt vom Paul53 und ist von ihm sehr gut im Laufe des Trheads erklärt.
Eine Lüftungsempfehlung wird gegeben, wenn alle drei Bedingungen erfüllt werden (logisch und):
En -> es kann enlüftet werden
Kü -> die Raumtemperatur kann mit lüften abgekühlt werden
Au -> Die untere Temperatur (Auskühlschutz) ist noch nciht erreicht
Ich habe sie nur für mich in den Spalten visualisiert, um die Logik zu überprüfen.
Jetzt im Winter überlege ich, ob ich das für mich nicht noch mit der relativen Luftfeuchtigkeit ergänze.
Wenn ein Reum "trocken" ist, muss ich ihn nicht entfeuchten. Eher im Gegenteil. Irgendwo dafür sorgen, dass zusätzliche Luftfeuchtigkeit rein kommt.
Werde das noch im Winter angehen.
In den heissen Tagen haben die Empfehlungen sehr gut gepasst.
Dann werde ich noch einen weiteren Faktor, CO2 mit reinbringen. Also lüften der Luftqualität willen (CO2 und ggf. noch VOC).
Hier nun die gleiche Tabelle einige Minuten später nachdem die Frau nachhause gekommen ist und nun die Heizung sich wieder eingeschalten hat und damit dann auch die TEMP_Minimum werte entsprechend angepasst wurden für die Berechnung des Raumklimas:
screenshot_112.png
Was ich hier z.B. im Vergleich zu vorherigen Tabelle nicht verstehe ist:
1. Warum wird jetzt "Lüften" in grün beim Gästezimmer angezeigt obwohl sich nichts verändert hat zum alten Status (auch TEMP_Minimum) ist für das Gästezimmer gleich geblieben?!? `
Sagte ja, dass es eine Fleissarbeit ist.
Sieht für mich nach einem Fehler in der Datenpunktauswahl im VIS (Datenpunkt oder Bindings) oder in einem der Skripte (Datenpunktzuordnung) aus.
In Deinem optimierten Skript für die Visualisierung hattest Du atlw. uch mehrere Fenster pro Raum. Ggf. liegt hier noch ein Logikproblem vor. Ich habe noch nicht nachgesehen.
Kurz, ich würde auf einen falschen Eintrag tippen.
Es müsste wie folgt sein:
En && Kü && Au gegeben -> Lüftungsempfehlung
Fenster geschlossen: Lüftungsempfehlung und geschlossen müssten gelb dargestellt werden.
Wobei mir es mir etwas seltsam vorkommt, dass bei 17,3 Grad der Auskühlschutz noch gegeben sein soll.
Entweder hast Du die unterste Temperatur für den Raum sehr niedrig eingestellt oder das Skript muss überprüft werden, warum der Auskühlschutz gegeben ist oder es wird der falsche Datenpunkt visualisiert
2. Da die SOLL Temperatur z.B. für das Badezimmer jetzt von 17Grad auf 22 Grad hochgeregelt wurde (und damit auch TEMP_Minimum der Raumklimaberechnung) wird jetzt verständlicherweise nicht mehr "Lüften" in gelb angezeigt sondern ist ganz verschwunden. Allerdings auch das "Au" flag das nach meinem Verständnis doch sagen sollte das der Auskühlschutz deaktiviert ist. Aber es sollte doch das Gegenteil der fall sein? Und warum ist "geschlossen" immer noch gelb und nicht grün?
Fragen über Fragen `
An welcher Stelle veränderst Du denn die SOLL Temperaturen?
Bei mir sind die einmal star eingestellt. Dynamisch macht zumindestens im Winter / Sommer durchaus Sinn.
Zum Badezimmer:
"Au" fehlt, also keine Lüftungsempfehlung, da nicht alle drei Bedingungen erfüllt sind.
ACHTUNG: es ist noch eine Hysterese-Funktion eingebaut. SO dass im "Grenzbereich" die alte Empfehlung stehen bleibt und nicht wild hin und her springt.
Lüftungsempfehlung sollte leer bleiben, da keine Empfehlung > OK
Es wird nicht empfohlen zu lüften, also sollte ein geschlossenes Fenster grün angezeigt werden.
Hier vermute ich wieder einen Fehler bei der "Fleissarbeit"
Oder die Kurzform:
-
grün, alles OK
-
andere Farbe, Handlungsbedarf
-
einmalig viel Fleissarbeit und Fehleranfällig
Ich hatte aber davor gewarnt
Für die anderen Themen (Überwachung der Komponenten, Softwarestände, usw.) mache ich einen neuen Thread auf. Das war hier schon argh offtopic.
-
-
Hallo in die Runde,
ich versuche das Skript aus Seite 13 in Version 0.6.4 in meinem Javascript Adapter zum Laufen zu bringen. Das scheitert leider schon beim reinkopieren. Wenn ich ein neues Skript anlege und dort den Code aus dem Spoiler reinkopiere und speichern möchte bricht der Adapter mit der Log-Meldung "invalid chars" ab und speichert das ganze nicht. Am Charset kann das irgendwie nicht liegen, da hab ich schon alles ausprobiert.
Any Ideas?
Danke für jeden Hinweis.
jsc
-
Moin,
kannst Du bitte mal einen Screenshot der Fehlersituation posten?
Ggf. ist dann eine mögliche Ursache zu sehen.
Gruß,
Eric
Mit Tapatalk getippert.
-
Hier eine der Fehlermeldungen. Hier meckert er über die auskommentierten "================", bei einem ersten Einfügen und speichern meckert er nur mit "cannot decode" und wegen "invalid characters"
1789_unbenannt.png -
Zeig bitte mal einen Screenshot des Script-Fensters (inkl. des unteren Log-Bereichs ) aus iobroker mit dem eingefügten Code und der dann ggf. gezeigten Fehlermeldung.
Gruß,
Eric
Mit Tapatalk getippert.