|
|
PID Regler - Was läuft hier falsch? |
|
eey |
Forum-Fortgeschrittener
|
|
Beiträge: 86
|
|
|
|
Anmeldedatum: 31.03.12
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 02.07.2014, 15:24
Titel: PID Regler - Was läuft hier falsch?
|
|
Hallo,
ich versuche mich seit einiger Zeit den PID-Regel Algorithmus für ein simples PT1 Glied iterativ zu implementieren (also ohne die Verwendung irgendwelcher Toolboxen oder fertiger Funktionen).
Mein Code sieht momentan so aus:
Leider kommt dabei ein komplett falsches Ergebnis raus... dies kann leicht verifiziert werden wenn man statt der iterativen Lösung das Closed-Loop System mittels der Funktionen "feedback" und "tf" bzw. "pid" aufbaut und mittels "lsim" berechnen lässt.
Die Formeln sollten aber so stimmen, hab die auch schon mehrmals nachgerechnet...
Wo könnte hier der Fehler liegen?
|
|
|
|
|
vega1013 |
Forum-Century
|
|
Beiträge: 162
|
|
|
|
Anmeldedatum: 26.02.08
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 03.07.2014, 08:43
Titel:
|
|
Hallo eey,
auf die schnelle würde ich hier den Fehler in der im PT1 Glied vermuten. Was ist mit der Verstärkung und des Zeitkonstanten? Hast du die zu eins gesetzt und die Formel umgestellt? Vielleicht kannst du mal den Link angeben wo du diese Formel her hast bzw. wenn du sie umgestellt hast dann wie?
Auch der Code zum prüfen wäre hilfreich, dann könnte man selber mal experimentieren...
VG
Vega
|
|
|
eey |
Themenstarter
Forum-Fortgeschrittener
|
|
Beiträge: 86
|
|
|
|
Anmeldedatum: 31.03.12
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 03.07.2014, 09:18
Titel:
|
|
Hallo,
also das wäre der Code zum überprüfen:
wenn man das macht sieht man eben dass mein y != y_correct, also irgendwo was nicht stimmen kann.
Die Formel für das PT1 Glied habe ich von hier (müsste so stimmen), die Formel für den PID Regler ist ja (denke ich) allgemein bekannt.
Aber irgendwas muss hier trotzdem noch falsch sein...
|
|
|
AKNOT |
Forum-Century
|
|
Beiträge: 129
|
|
|
|
Anmeldedatum: 12.10.11
|
|
|
|
Wohnort: Bochum
|
|
|
|
Version: R2018a
|
|
|
|
|
|
Verfasst am: 03.07.2014, 11:17
Titel:
|
|
Nimmst du 0.1 statt 1 als Reglerparameter, dann läuft es, ansonsten ist es instabil.
Die Formel für PT1 scheint mir nicht ganz korrekt...schau nochmal bei Wiki. Allerdings fällt es nicht ins Gewicht, da die fragwürdigen Teile auch bei dir alle 1 sind.
|
|
|
vega1013 |
Forum-Century
|
|
Beiträge: 162
|
|
|
|
Anmeldedatum: 26.02.08
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 03.07.2014, 11:27
Titel:
|
|
Die Formel ist m.M.n. richtig umgesetzt und umgestellt, also für T=K=1.
Und das sollte dann auch das Problem sein, dass deine Abtastzeit gleich der Zeitkonstanten ist...versuch mal diese zu reduzieren
|
|
|
eey |
Themenstarter
Forum-Fortgeschrittener
|
|
Beiträge: 86
|
|
|
|
Anmeldedatum: 31.03.12
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 03.07.2014, 18:30
Titel:
|
|
AKNOT hat Folgendes geschrieben: |
Nimmst du 0.1 statt 1 als Reglerparameter, dann läuft es, ansonsten ist es instabil.
Die Formel für PT1 scheint mir nicht ganz korrekt...schau nochmal bei Wiki. Allerdings fällt es nicht ins Gewicht, da die fragwürdigen Teile auch bei dir alle 1 sind. |
Also die Formel müsste schon richtig sein (Habs extra nochmal überprüft). Ist halt der Spezialfall dass K=T=1, für Testzwecke, aber das müsste ja irrelevant sein.
vega1013 hat Folgendes geschrieben: |
Die Formel ist m.M.n. richtig umgesetzt und umgestellt, also für T=K=1.
Und das sollte dann auch das Problem sein, dass deine Abtastzeit gleich der Zeitkonstanten ist...versuch mal diese zu reduzieren |
Hab ich schon probiert, aber auch bei einer Abtastzeit von 0.0001 mittels t = linspace(0, 500, 5000000); ist es falsch und instabil.
|
|
|
vega1013 |
Forum-Century
|
|
Beiträge: 162
|
|
|
|
Anmeldedatum: 26.02.08
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 03.07.2014, 22:38
Titel:
|
|
Zitat: |
Hab ich schon probiert, aber auch bei einer Abtastzeit von 0.0001 mittels t = linspace(0, 500, 5000000); ist es falsch und instabil. |
Wenn du die Abtastzeit auf 0.1 setzt sieht der Verlauf schon mal tendenziell richtig aus. Jetzt spuckt dir nur noch der D-Anteil in die Suppe. Setze den auf 0.1 und es funzt...
|
|
|
eey |
Themenstarter
Forum-Fortgeschrittener
|
|
Beiträge: 86
|
|
|
|
Anmeldedatum: 31.03.12
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 03.07.2014, 22:41
Titel:
|
|
vega1013 hat Folgendes geschrieben: |
Wenn du die Abtastzeit auf 0.1 setzt sieht der Verlauf schon mal tendenziell richtig aus. Jetzt spuckt dir nur noch der D-Anteil in die Suppe. Setze den auf 0.1 und es funzt... |
Ja schon, aber das sollte doch nicht so sein oder? Denn mit der lsim Variante funktioniert es ja auch mit einem D-Anteil von 1, also sollte es doch so auch klappen?
Mir gehts hier auch weniger darum es irgendwie zum laufen zu bringen als vielmehr zu verstehen was da eigentlich schief läuft.
|
|
|
AKNOT |
Forum-Century
|
|
Beiträge: 129
|
|
|
|
Anmeldedatum: 12.10.11
|
|
|
|
Wohnort: Bochum
|
|
|
|
Version: R2018a
|
|
|
|
|
|
Verfasst am: 04.07.2014, 07:56
Titel:
|
|
Dann sind die in lsim verwendeten Methoden zur Integration/Differentiation vermutlich einfach robuster. Gefiltert wird der D-Anteil ja in beiden Fällen nicht, da könnte eine kleine Zeitkonstante vielleicht noch Abhilfe schaffen.
|
|
|
eey |
Themenstarter
Forum-Fortgeschrittener
|
|
Beiträge: 86
|
|
|
|
Anmeldedatum: 31.03.12
|
|
|
|
Wohnort: ---
|
|
|
|
Version: ---
|
|
|
|
|
|
Verfasst am: 07.07.2014, 18:30
Titel:
|
|
AKNOT hat Folgendes geschrieben: |
Dann sind die in lsim verwendeten Methoden zur Integration/Differentiation vermutlich einfach robuster. Gefiltert wird der D-Anteil ja in beiden Fällen nicht, da könnte eine kleine Zeitkonstante vielleicht noch Abhilfe schaffen. |
Hm ok... Aber das sind ja die Standard Formeln zur Berechnung des PID-Outputs die man überall findet... Diese sind dann ja quasi relativ schlecht??
Oder anders gefragt: Warum verwendet jeder diese (sehr schlechte) Approximation des PID-Reglers wenn es doch mit Funktionen wie lsim viel bessere und genauere Ergebnisse gibt? Macht dies in der Praxis keinen Sinn? Oder versteh ich jetzt was falsch?
|
|
|
AKNOT |
Forum-Century
|
|
Beiträge: 129
|
|
|
|
Anmeldedatum: 12.10.11
|
|
|
|
Wohnort: Bochum
|
|
|
|
Version: R2018a
|
|
|
|
|
|
Verfasst am: 08.07.2014, 08:28
Titel:
|
|
Das kann schon einfach an einer anderen Diskretisierungsmethode liegen (Vorwärts- oder Rückwärts-Euler oder Trapezoidal...), dein PID-Algorithmus dürfte komplett Vorwärts-Euler (expliziter Euler) sein, der instabiler und empfindlicher bzgl. der Abtastzeit ist als der implizite (Rückwärts), dafür aber einfacher zu implementieren.
Wenn du den Simulink PID-Block her nimmst, kannst du die Methoden auswählen und wirst genau solche Stabilitätsunterschiede feststellen. In der Hilfe ist das bestimmt auch dokumentiert, sodass du es selbst implementieren kannst...ansonsten weiß Google bestimmt noch mehr Details
|
|
|
|
|
Einstellungen und Berechtigungen
|
|
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
|
|
Impressum
| Nutzungsbedingungen
| Datenschutz
| FAQ
| RSS
Hosted by:
Copyright © 2007 - 2025
goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.
|
|