PID

Aus FHEMWiki

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
ErrorPos: Position anfahren, die unter Attribut <pidActorErrorPos> angegeben ist."

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

Readings

13 10 20 Pid readings.png

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:

WindUP

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.

Weblinks