Auf Asynchron umgebaut

This commit is contained in:
2025-01-22 08:40:12 +01:00
parent 75eef3411d
commit c2c0b34bad
7 changed files with 143 additions and 49 deletions

View File

@@ -21,7 +21,11 @@ class Batterie extends IPSModule
$this->RegisterVariableString("PowerSteps", "PowerSteps"); $this->RegisterVariableString("PowerSteps", "PowerSteps");
$this->RegisterVariableBoolean("Idle", "Idle", "", 0); $this->RegisterVariableBoolean("Idle", "Idle", "", 0);
$this->RegisterVariableInteger("Sperre_Prio", "Sperre_Prio"); $this->RegisterVariableInteger("Sperre_Prio", "Sperre_Prio");
$this->RegisterVariableInteger("PV_Prio", "PV_Prio"); $this->RegisterVariableInteger("PV_Prio", "PV_Prio");
$this->RegisterVariableInteger("Power", "Power");
$this->RegisterVariableBoolean("Is_Peak_Shaving", "Is_Peak_Shaving");
$this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0); $this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0);
// Hilfsvariabeln für Idle zustand // Hilfsvariabeln für Idle zustand
@@ -31,6 +35,10 @@ class Batterie extends IPSModule
// Initialisiere Idle // Initialisiere Idle
$this->SetValue("Idle", true); $this->SetValue("Idle", true);
$this->RegisterTimer("Timer_Do_UserCalc",5000,"IPS_RequestAction(" .$this->InstanceID .', "Do_UserCalc", "");');
} }
public function ApplyChanges() public function ApplyChanges()
@@ -56,19 +64,28 @@ class Batterie extends IPSModule
public function RequestAction($Ident, $Value) public function RequestAction($Ident, $Value)
{ {
switch ($Ident) {
switch ($Ident) {
case "SetAktuelle_Leistung": case "SetAktuelle_Leistung":
$this->SetAktuelle_Leistung($Value); SetValue("Power", $Value);
break; break;
case "GetCurrentData":
return $this->GetCurrentData($Value); case "GetCurrentData":
default: SetValue("Is_Peak_Shaving", $Value);
throw new Exception("Invalid Ident"); break;
}
case "Do_UserCalc":
$this->SetAktuelle_Leistung(GetValue("Power"));
$this->GetCurrentData(GetValue("Is_Peak_Shaving"));
break;
default:
throw new Exception("Invalid Ident");
} }
}
public function SetAktuelle_Leistung(int $power) public function SetAktuelle_Leistung(int $power)
{ {

View File

@@ -15,15 +15,15 @@ class Boiler_2_Stufig_Mit_Fueler extends IPSModule
$this->RegisterPropertyInteger("Kontakt_Volllast", 0); $this->RegisterPropertyInteger("Kontakt_Volllast", 0);
$this->RegisterPropertyBoolean("Boilertemperatur_glätten", false); $this->RegisterPropertyBoolean("Boilertemperatur_glätten", false);
// Boiler spezifische Variablen // Boiler spezifische Variablen
$this->RegisterVariableInteger("Mindesttemperatur","Mindesttemperatur","",45); $this->RegisterVariableInteger("Mindesttemperatur","Mindesttemperatur","",45);
$this->RegisterVariableInteger("Maximaltemperatur","Maximaltemperatur","",60); $this->RegisterVariableInteger("Maximaltemperatur","Maximaltemperatur","",60);
$this->RegisterVariableInteger("Legionellentemperatur","Legionellentemperatur","",65); $this->RegisterVariableInteger("Legionellentemperatur","Legionellentemperatur","",65);
$this->RegisterVariableInteger("LegioCounter", "LegioCounter", "", 0); $this->RegisterVariableInteger("LegioCounter", "LegioCounter", "", 0);
//$this->RegisterVariableInteger("Boilertemperatur", "Boilertemperatur", "", 0);
$this->RegisterVariableInteger("Boilertemperatur", "Boilertemperatur", "", 0); $this->RegisterVariableInteger("Boilertemperatur", "Boilertemperatur", "", 0);
// Variabeln für Kommunkation mit Manager // Variabeln für Kommunkation mit Manager
$this->RegisterVariableInteger("Sperre_Prio", "Sperre_Prio"); $this->RegisterVariableInteger("Sperre_Prio", "Sperre_Prio");
@@ -32,6 +32,8 @@ class Boiler_2_Stufig_Mit_Fueler extends IPSModule
$this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0); $this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0);
$this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0); $this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0);
$this->RegisterVariableString("PowerSteps", "PowerSteps"); $this->RegisterVariableString("PowerSteps", "PowerSteps");
$this->RegisterVariableInteger("Power", "Power");
$this->RegisterVariableBoolean("Is_Peak_Shaving", "Is_Peak_Shaving");
// Hilfsvariabeln für Idle zustand // Hilfsvariabeln für Idle zustand
$this->RegisterPropertyInteger("IdleCounterMax", 2); $this->RegisterPropertyInteger("IdleCounterMax", 2);
@@ -40,30 +42,37 @@ class Boiler_2_Stufig_Mit_Fueler extends IPSModule
// Initialisiere Idle // Initialisiere Idle
$this->SetValue("Idle", true); $this->SetValue("Idle", true);
$this->RegisterTimer("Timer_Do_UserCalc",5000,"IPS_RequestAction(" .$this->InstanceID .', "Do_UserCalc", "");');
} }
public function ApplyChanges() public function ApplyChanges()
{ {
parent::ApplyChanges(); parent::ApplyChanges();
} }
public function RequestAction($Ident, $Value) public function RequestAction($Ident, $Value)
{ {
switch ($Ident) { switch ($Ident) {
case "SetAktuelle_Leistung": case "SetAktuelle_Leistung":
SetValue("Power", $Value);
$this->SetAktuelle_Leistung($Value);
break; break;
case "GetCurrentData": case "GetCurrentData":
SetValue("Is_Peak_Shaving", $Value);
$result = $this->GetCurrentData($Value); break;
return $result;
case "Do_UserCalc":
$this->SetAktuelle_Leistung(GetValue("Power"));
$this->GetCurrentData(GetValue("Is_Peak_Shaving"));
break;
default: default:
throw new Exception("Invalid Ident"); throw new Exception("Invalid Ident");
} }
@@ -112,27 +121,46 @@ class Boiler_2_Stufig_Mit_Fueler extends IPSModule
$boilertemperatur_glätten = $this->ReadPropertyBoolean("Boilertemperatur_glätten"); $boilertemperatur_glätten = $this->ReadPropertyBoolean("Boilertemperatur_glätten");
if ($boilertemperatur_glätten) { if ($boilertemperatur_glätten) {
// Wenn Glättung aktiviert ist, führe das Glätten durch
$boilerFuehlerPT1ID = $this->ReadPropertyInteger("Boilerfuehler_PT1"); $boilerFuehlerPT1ID = $this->ReadPropertyInteger("Boilerfuehler_PT1");
$boilerPT1 = IPS_VariableExists($boilerFuehlerPT1ID) ? GetValue($boilerFuehlerPT1ID) : 0.0;
$boilerTemp_test = $this->GetValue("Boilertemperatur"); if (IPS_VariableExists($boilerFuehlerPT1ID)) {
$boilerPT1 = GetValue($boilerFuehlerPT1ID);
} else {
$boilerPT1 = 0.0; // Standardwert
}
$time_constant = $this->ReadPropertyInteger("ZeitKonstante"); $boilerTempID = $this->GetIDForIdent("Boilertemperatur");
$delta_t = 30; if (IPS_VariableExists($boilerTempID)) {
$boilerTemp = $this->GetValue("Boilertemperatur");
} else {
$boilerTemp = 0.0; // Standardwert
}
// PT
$time_constant= $this->ReadPropertyInteger("ZeitKonstante");
$delta_t = 30; // Zeitdifferenz zwischen den Messungen (30 Sekunden)
$alpha = $delta_t / ($time_constant + $delta_t); $alpha = $delta_t / ($time_constant + $delta_t);
$newBoilerTemp = $boilerTemp + $alpha * ($boilerPT1 - $boilerTemp);
$newBoilerTemp = $boilerTemp_test + $alpha * ($boilerPT1 - $boilerTemp_test);
$this->SetValue("Boilertemperatur", $newBoilerTemp); $this->SetValue("Boilertemperatur", $newBoilerTemp);
} else { } else {
// Wenn Glättung nicht aktiviert ist, setze die Boilertemperatur direkt auf den Wert des Boilerfühlers
$boilerFuehlerPT1ID = $this->ReadPropertyInteger("Boilerfuehler_PT1"); $boilerFuehlerPT1ID = $this->ReadPropertyInteger("Boilerfuehler_PT1");
$boilerPT1 = IPS_VariableExists($boilerFuehlerPT1ID) ? GetValue($boilerFuehlerPT1ID) : 0.0;
if (IPS_VariableExists($boilerFuehlerPT1ID)) {
$boilerPT1 = GetValue($boilerFuehlerPT1ID);
} else {
$boilerPT1 = 0.0; // Standardwert
}
// Setze Boilertemperatur direkt auf den Wert des Boilerfühlers
$this->SetValue("Boilertemperatur", $boilerPT1); $this->SetValue("Boilertemperatur", $boilerPT1);
} }
$boilerTemp = $this->GetValue("Boilertemperatur");
$minTemp = $this->GetValue("Mindesttemperatur"); $minTemp = $this->GetValue("Mindesttemperatur");
$maxTemp = $this->GetValue("Maximaltemperatur"); $maxTemp = $this->GetValue("Maximaltemperatur");
$LegioTemp = $this->GetValue("Legionellentemperatur"); $LegioTemp = $this->GetValue("Legionellentemperatur");

View File

@@ -36,6 +36,8 @@ class Ladestation_Universal extends IPSModule
$this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0); $this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0);
$this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0); $this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0);
$this->RegisterVariableString("PowerSteps", "PowerSteps"); $this->RegisterVariableString("PowerSteps", "PowerSteps");
$this->RegisterVariableInteger("Power", "Power");
$this->RegisterVariableBoolean("Is_Peak_Shaving", "Is_Peak_Shaving");
// Hilfsvariabeln für Idle zustand // Hilfsvariabeln für Idle zustand
$this->RegisterPropertyInteger("IdleCounterMax", 2); $this->RegisterPropertyInteger("IdleCounterMax", 2);
@@ -44,6 +46,9 @@ class Ladestation_Universal extends IPSModule
// Initialisiere Idle // Initialisiere Idle
$this->SetValue("Idle", true); $this->SetValue("Idle", true);
$this->RegisterTimer("Timer_Do_UserCalc",5000,"IPS_RequestAction(" .$this->InstanceID .', "Do_UserCalc", "");');
} }
public function ApplyChanges() public function ApplyChanges()
@@ -52,16 +57,24 @@ class Ladestation_Universal extends IPSModule
// Zusätzliche Anpassungen nach Bedarf // Zusätzliche Anpassungen nach Bedarf
} }
// Aktionen verarbeiten
public function RequestAction($Ident, $Value) public function RequestAction($Ident, $Value)
{ {
switch ($Ident) { switch ($Ident) {
case "SetAktuelle_Leistung": case "SetAktuelle_Leistung":
$this->SetAktuelle_Leistung($Value); SetValue("Power", $Value);
break; break;
case "GetCurrentData": case "GetCurrentData":
$powerSteps = $this->GetCurrentData($Value); SetValue("Is_Peak_Shaving", $Value);
return $powerSteps; break;
case "Do_UserCalc":
$this->SetAktuelle_Leistung(GetValue("Power"));
$this->GetCurrentData(GetValue("Is_Peak_Shaving"));
break;
default: default:
throw new Exception("Invalid Ident"); throw new Exception("Invalid Ident");
} }

View File

@@ -64,13 +64,7 @@ class Manager extends IPSModule
} }
// Frage alle Energieverbraucher ab, was sie für Leistungen benötigen könnten // Frage alle Energieverbraucher ab, was sie für Leistungen benötigen könnten
foreach ($Verbraucher_Liste as $user) {
if (IPS_InstanceExists($user["Verbraucher"])) {
IPS_RequestAction($user["Verbraucher"],"GetCurrentData", $Is_Peak_Shaving);
IPS_LogMessage("Manager", "aufgerufen getcurrentdata");
}
}
$filteredVerbraucher = []; // Array das später mit allen Verbrauchsdaten der Energieverbraucher gefüllt wird $filteredVerbraucher = []; // Array das später mit allen Verbrauchsdaten der Energieverbraucher gefüllt wird
$allIdle = true; // Variable zur Überprüfung, ob alle Benutzer Idle = true sind $allIdle = true; // Variable zur Überprüfung, ob alle Benutzer Idle = true sind
@@ -254,6 +248,18 @@ class Manager extends IPSModule
} }
} }
} }
// Frage alle Energieverbraucher ab, was sie für Leistungen benötigen könnten
foreach ($Verbraucher_Liste as $user) {
if (IPS_InstanceExists($user["Verbraucher"])) {
IPS_RequestAction($user["Verbraucher"],"GetCurrentData", $Is_Peak_Shaving);
IPS_LogMessage("Manager", "aufgerufen getcurrentdata");
}
}
} }
} }
?> ?>

View File

@@ -29,6 +29,8 @@ class Verbraucher_1_Stufig extends IPSModule
$this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0); $this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0);
$this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0); $this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0);
$this->RegisterVariableString("PowerSteps", "PowerSteps"); $this->RegisterVariableString("PowerSteps", "PowerSteps");
$this->RegisterVariableInteger("Power", "Power");
$this->RegisterVariableBoolean("Is_Peak_Shaving", "Is_Peak_Shaving");
// Hilfsvariabeln für Idle zustand // Hilfsvariabeln für Idle zustand
$this->RegisterPropertyInteger("IdleCounterMax", 2); $this->RegisterPropertyInteger("IdleCounterMax", 2);
@@ -37,6 +39,9 @@ class Verbraucher_1_Stufig extends IPSModule
// Initialisiere Idle // Initialisiere Idle
$this->SetValue("Idle", true); $this->SetValue("Idle", true);
$this->RegisterTimer("Timer_Do_UserCalc",5000,"IPS_RequestAction(" .$this->InstanceID .', "Do_UserCalc", "");');
} }
public function ApplyChanges() public function ApplyChanges()
@@ -44,24 +49,34 @@ class Verbraucher_1_Stufig extends IPSModule
parent::ApplyChanges(); parent::ApplyChanges();
} }
// Aktionen verarbeiten
public function RequestAction($Ident, $Value) public function RequestAction($Ident, $Value)
{ {
switch ($Ident) { switch ($Ident) {
case "SetAktuelle_Leistung": case "SetAktuelle_Leistung":
$this->SetAktuelle_Leistung($Value); SetValue("Power", $Value);
break; break;
case "GetCurrentData": case "GetCurrentData":
return $this->GetCurrentData($Value); SetValue("Is_Peak_Shaving", $Value);
break; break;
case "ResetPowerSteps": case "ResetPowerSteps":
$this->ResetPowerSteps($Value); $this->ResetPowerSteps($Value);
break; break;
case "Do_UserCalc":
$this->SetAktuelle_Leistung(GetValue("Power"));
$this->GetCurrentData(GetValue("Is_Peak_Shaving"));
break;
default: default:
throw new Exception("Invalid Ident"); throw new Exception("Invalid Ident");
} }
} }
// Methode zum Setzen der PowerSteps und Timer starten // Methode zum Setzen der PowerSteps und Timer starten
public function SetTimerOn() public function SetTimerOn()
{ {

View File

@@ -34,6 +34,8 @@ class WP_Steuerung extends IPSModule
$this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0); $this->RegisterVariableInteger("Aktuelle_Leistung", "Aktuelle_Leistung", "", 0);
$this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0); $this->RegisterVariableFloat("Bezogene_Energie", "Bezogene_Energie", "", 0);
$this->RegisterVariableString("PowerSteps", "PowerSteps"); $this->RegisterVariableString("PowerSteps", "PowerSteps");
$this->RegisterVariableInteger("Power", "Power");
$this->RegisterVariableBoolean("Is_Peak_Shaving", "Is_Peak_Shaving");
// Hilfsvariabeln für Idle zustand // Hilfsvariabeln für Idle zustand
$this->RegisterPropertyInteger("IdleCounterMax", 2); $this->RegisterPropertyInteger("IdleCounterMax", 2);
@@ -42,6 +44,9 @@ class WP_Steuerung extends IPSModule
// Initialisiere Idle // Initialisiere Idle
$this->SetValue("Idle", true); $this->SetValue("Idle", true);
$this->RegisterTimer("Timer_Do_UserCalc",5000,"IPS_RequestAction(" .$this->InstanceID .', "Do_UserCalc", "");');
} }
public function ApplyChanges() public function ApplyChanges()
@@ -49,24 +54,34 @@ class WP_Steuerung extends IPSModule
parent::ApplyChanges(); parent::ApplyChanges();
} }
// Aktionen verarbeiten
public function RequestAction($Ident, $Value) public function RequestAction($Ident, $Value)
{ {
switch ($Ident) { switch ($Ident) {
case "SetAktuelle_Leistung": case "SetAktuelle_Leistung":
$this->SetAktuelle_Leistung($Value); SetValue("Power", $Value);
break; break;
case "GetCurrentData": case "GetCurrentData":
return $this->GetCurrentData($Value); SetValue("Is_Peak_Shaving", $Value);
break; break;
case "ResetPowerSteps": case "ResetPowerSteps":
$this->ResetPowerSteps($Value); $this->ResetPowerSteps($Value);
break; break;
case "Do_UserCalc":
$this->SetAktuelle_Leistung(GetValue("Power"));
$this->GetCurrentData(GetValue("Is_Peak_Shaving"));
break;
default: default:
throw new Exception("Invalid Ident"); throw new Exception("Invalid Ident");
} }
} }
// Methode zum Setzen des aktuellen Stromverbrauchs // Methode zum Setzen des aktuellen Stromverbrauchs
public function SetAktuelle_Leistung(float $power) public function SetAktuelle_Leistung(float $power)
{ {

View File

@@ -6,7 +6,7 @@
"compatibility": { "compatibility": {
"version": "7.1" "version": "7.1"
}, },
"version": "0.282", "version": "0.283",
"build": 0, "build": 0,
"date": 0 "date": 0