PID: Unterschied zwischen den Versionen
John (Diskussion | Beiträge) |
John (Diskussion | Beiträge) |
||
Zeile 71: | Zeile 71: | ||
== Hintergrund-Informationen == | == Hintergrund-Informationen == | ||
=== list <pid-name> === | |||
<code> | |||
Internals: | |||
DEF DG.BAD.TF PID.Actor:state | |||
NAME PID.PID | |||
NR 616 | |||
NTFY_ORDER 50-PID.PID | |||
STATE processing | |||
TYPE PID | |||
Readings: | |||
2013-10-20 17:13:41 actuation 97 | |||
2013-10-20 17:21:42 actuationCalc 97.2079999999999 | |||
2013-10-20 17:21:42 delta 0.199999999999999 | |||
2013-10-20 17:13:41 desired 22 | |||
2013-10-20 17:13:41 measured 21.8 | |||
2013-10-20 17:21:42 p_d 0 | |||
2013-10-20 17:21:42 p_i 92.2079999999999 | |||
2013-10-20 17:21:42 p_p 4.99999999999998 | |||
2013-10-20 17:21:42 state processing | |||
Helper: | |||
actor PID.Actor | |||
actorCommand state | |||
actorErrorAction freeze | |||
actorErrorPos 0 | |||
actorInterval 300 | |||
actorKeepAlive 1800 | |||
actorLimitLower 0 | |||
actorLimitUpper 100 | |||
actorThreshold 4 | |||
actorTimestamp 2013-10-20 17:13:41 | |||
actorValueDecPlaces 0 | |||
calcInterval 60 | |||
deltaGradient 0 | |||
deltaOld 0.199999999999999 | |||
deltaOldTS 2013-10-20 17:18:07 | |||
deltaTreshold 0 | |||
desiredName desired | |||
disable 0 | |||
factor_D 0 | |||
factor_I 0.25 | |||
factor_P 25 | |||
isWindUP 0 | |||
measuredName measured | |||
reading temperature | |||
regexp ([\d\.]*) | |||
reverseAction 0 | |||
sensor DG.BAD.TF | |||
sensorTimeout 3600 | |||
updateInterval 600 | |||
Attributes: | |||
pidActorInterval 300 | |||
pidActorTreshold 4 | |||
pidActorValueDecPlaces 0 | |||
room PID | |||
verbose 4 | |||
Save config | |||
DG.BAD | |||
DG.JAKOB | |||
DG.JOHN | |||
DG.LAURA | |||
DG.MICHI | |||
DG.WC | |||
EG.HW | |||
EG.WC | |||
EG.WOZI | |||
HT.ALL | |||
KE.HEIZUNG | |||
PID | |||
PVA | |||
Presence | |||
System | |||
Unsorted | |||
Wetter | |||
icoEverything Everything | |||
Logfile | |||
Commandref | |||
Remote doc | |||
Edit files | |||
Select style | |||
Event monitor | |||
</code> | |||
=== Anti-WindUp-Strategie === | === Anti-WindUp-Strategie === | ||
Der integrale Anteil des PID-Reglers wird ohne Gegenmassnahmen auch dann weiter integriert, | Der integrale Anteil des PID-Reglers wird ohne Gegenmassnahmen auch dann weiter integriert, |
Version vom 20. Oktober 2013, 16:29 Uhr
PID ist ein Modul, das nach dem P-I-D Algorithmus einen Regler realisiert.
Projekt-Status
Das neue Modul befindet sich in der Evaluations-Phase und ist noch nicht für produktiven Einsatz freigegeben. Die nachfolgenden Ausführungen dienen zur Spezifizierung derneuen geplanten Funktionalitäten.
Features
- einstellbarer Bewertungs-/Berechungszyklus
- Überwachung des Istwert-Gebers über dessen Zeitstempel (Sensorausfall)
- Skalierbarkeit der Ausgabehäufigkeit an das Stellglied über Zeit und Mindeständerung
- Zwangsausgabe an das Stellglied nach Ablauf eines einstellbaren Zeitintervalls
- Notstellung des Stellgliedes, falls Istwert-Geber ausgefallen ist
- Begrenzung des Stellbereiches nach oben und unten
- Festlegung der Nachkommastellen (0..5) des Ausgabewertes zum Stellglied
- Festlegen einer minimalen Regelabweichung, ab der der Regler aktiv wird
- Festlegen des Reading-Namens für den Sollwert
- Festlegen des Reading-Namens für den Istwert
- Invertierung des Reglerwirksinnes
- Festlegen der minimalen Aktualisierungsrate der Readings
- Festlegen der Proportionalitätskonstanten P,I,D
Attribute
Parameter | Wertebereich | Default | Beschreibung |
---|---|---|---|
pidActorValueDecPlaces | [0..5] | 0 | Anzahl der Nachkommstellen für Ausgabewert zu Aktor |
pidActorInterval | uint | 180 | minimale Wartezeit in Sekunden, bis eine neue Ausgabe an das Stellglied erfolgen kann |
pidActorThreshold | uint | 1 | Notwendige minimale Änderung zum Altwert der Stellgliedausgabe, damit diese erneut erfolgt |
pidActorErrorAction | [freeze, errorPos] | freeze | legt das Verhalten der Ausgabe zum Stellglied fest, wenn der Istwert nicht innerhalb von <pidSensorTimeout> aktualisiert wurde (Sensor-Ausfall) freeze: Position des Stellgliedes beibehalten |
pidActorErrorPos | int | 0 | Diese Position ist einzunehmen, wenn pidActorErrorAction auf errorPos steht und der Istwert-Geber ausgefallen ist. |
pidActorKeepAlive | uint | 1800 | Spätestens nach dieser Zeit erfolgt eine Zwangsausgabe an das Stellglied
(wenn PID nicht disabled und nicht stopped) |
pidActorLimitLower | float | 0 | untere Begrenzung für das Stellglied |
pidActorLimitUpper | float | 100 | obere Begrenzung für das Stellglied |
pidCalcInterval | uint | 60 | Berechnungszyklus in Sekunden, nach dem die PID-Berechnung durchgeführt wird. |
pidDeltaTreshold | uint | 0 | wenn die Regeldifferenz(delta) kleiner al pidDeltaThreshold,, dann wird der Regler eingefroren (state= idle) |
pidDesiredName | string | desired | Name für das Reading, das den Sollwert für den Regler aufnehmen soll |
pidMeasuredName | string | measured | Name für das Reading, das den Istwert für den Regler aufnehmen soll |
pidSensorTimeout | uint | 3600 | Zeitlimit in Sekunden, nach dessen Überschreitung der Ausfall des Istwert-Gebers anzunehmen ist |
pidReverseAction | [0,1] | 0 | Umgekehrter Wirksinn des Reglers |
pidUpdateInterval | uint | 300 | Zeitlimit in Sekunden, nach der ein Zwangsupdate der Readings erfolgen muss (Kurvendarstellung). |
pidFactor_P | pos. float | 25 | Proportionalitätskonstante für P-Anteil |
pidFactor_I | pos. float | 0,25 | Proportionalitätskonstante für I-Anteil |
pidFactor_D | pos. float | 0 | Proportionalitätskonstante für D-Anteil |
disable | [0,1] | 0 | Freigabe/Sperren des Reglers |
Hintergrund-Informationen
list <pid-name>
Internals:
DEF DG.BAD.TF PID.Actor:state
NAME PID.PID
NR 616
NTFY_ORDER 50-PID.PID
STATE processing
TYPE PID
Readings:
2013-10-20 17:13:41 actuation 97
2013-10-20 17:21:42 actuationCalc 97.2079999999999
2013-10-20 17:21:42 delta 0.199999999999999
2013-10-20 17:13:41 desired 22
2013-10-20 17:13:41 measured 21.8
2013-10-20 17:21:42 p_d 0
2013-10-20 17:21:42 p_i 92.2079999999999
2013-10-20 17:21:42 p_p 4.99999999999998
2013-10-20 17:21:42 state processing
Helper:
actor PID.Actor
actorCommand state
actorErrorAction freeze
actorErrorPos 0
actorInterval 300
actorKeepAlive 1800
actorLimitLower 0
actorLimitUpper 100
actorThreshold 4
actorTimestamp 2013-10-20 17:13:41
actorValueDecPlaces 0
calcInterval 60
deltaGradient 0
deltaOld 0.199999999999999
deltaOldTS 2013-10-20 17:18:07
deltaTreshold 0
desiredName desired
disable 0
factor_D 0
factor_I 0.25
factor_P 25
isWindUP 0
measuredName measured
reading temperature
regexp ([\d\.]*)
reverseAction 0
sensor DG.BAD.TF
sensorTimeout 3600
updateInterval 600
Attributes:
pidActorInterval 300
pidActorTreshold 4
pidActorValueDecPlaces 0
room PID
verbose 4
Save config
DG.BAD
DG.JAKOB
DG.JOHN
DG.LAURA
DG.MICHI
DG.WC
EG.HW
EG.WC
EG.WOZI
HT.ALL
KE.HEIZUNG
PID
PVA
Presence
System
Unsorted
Wetter
icoEverything Everything
Logfile
Commandref
Remote doc
Edit files
Select style
Event monitor
Anti-WindUp-Strategie
Der integrale Anteil des PID-Reglers wird ohne Gegenmassnahmen auch dann weiter integriert, wenn das Stellglied bereits an seine Grenzen gestossen ist. Dies hat den Nachteil, dass nach einer Reduzierung der Regeldifferenz lange Wartezeiten entstehen können, bis das Stellglied reagiert. Dies nennt man den WindUP-Effekt. Hierzu wurde die folgende Strategie entwickelt:
Sobald das rechnerische Stellsignal (Ventilstellung Calc) die obere Grenze des Stellgliedes überschreitet (pidActorLimitUpper) oder die untere Grenze unterschreitet (pidActorLimitLower), wird die Integration des I-Anteils eingefroren.
Am Beispiel:
An Position L1 überschreitet der rechnerische Ausgabewert des Stellgliedes die obere Grenze (100%). Der I-Anteil verändert sich nicht mehr bis zur Position L2. Hier unterschreitet der Augabewert die obere Grenze, der I-Anteil kann wieder verändert werden.