- 12V Akku mit 280 Ah bauen         
Seite 1 von 2 12 LetzteLetzte
Ergebnis 1 bis 10 von 17

Thema: Probleme mit PID-Regelung (Drehzahl)

  1. #1
    Benutzer Stammmitglied
    Registriert seit
    08.03.2010
    Beiträge
    66

    Probleme mit PID-Regelung (Drehzahl)

    Anzeige

    E-Bike
    Hallo,

    ich benötige noch mal Hilfe.
    Ich versuche gerade einen bürstenlosen Außenläufer mit Steller mittels einem Arduino zu regeln.
    Ziel ist es zunächst, das eine Drehzahl gehalten wird.

    Die Hardware ist ein Robbe Roxxy 2824-34. Steller ist ein BL-control 918.

    Die Drehzahl wird mit einem Hallsensor gemessen.
    Zum Regeln verwende ich die Lib "PID_v1".

    Die Erfassung der Drehzahl erfolgt entweder alle 2 Sekunden oder alle 2 Ticks vom Hallsensor.

    Die Neukalkulierung und setzen eines neuen Vorgabewertes erfolgt etwa zwei mal pro Sekunde.

    Ich komme mit der Einstellerei nicht weiter.
    Die Werte für I und D habe ich erst mal auf 0 gelassen.

    Anbei vier Messwerte:

    Werte von P,I und D
    Solldrehzal->von der Regelung erreichte Drehzahl


    Kp=0.01, Ki=0.00, Kd=0.00;
    2200->2100
    6000->3280
    8000->4090


    Kp=0.02, Ki=0.00, Kd=0.00;
    2200->2100
    6000->3840
    8000->4950


    Mit schwingen im anlauf, danach ruhig
    Kp=0.03, Ki=0.00, Kd=0.00;
    2200->2110
    6000->4340
    8000->5590


    Mit ständigen schwingen
    Kp=0.04, Ki=0.00, Kd=0.00;
    2200->2125
    6000->4600 (dann schwingen)
    8000-> Werte zwischen 3600-7800 (erhebliches schwingen)


    Warum bekomme ich es nicht hin das wenigstens die soll-Drehzahl erreicht wird?


    Gruß, Andreas

  2. #2
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    27.08.2013
    Ort
    Region Basel
    Alter
    66
    Beiträge
    2.435
    Hallo Andreas,
    Zitat Zitat von MechMac Beitrag anzeigen
    Warum bekomme ich es nicht hin das wenigstens die soll-Drehzahl erreicht wird?
    Das ist das Grundlegende Problem des P-Reglers!
    Die Stellgrösse des einfachen P-Reglers ist:
    = Kp * (soll - Ist)
    Deshalb hängt der P-Regler immer hinter dem Sollwert hinterher. Wird (Soll - Ist) gleich 0, dann wird auch die Stellgrösse 0.
    Eine verbesserte Variante benutzt:
    = (Kp * (Soll - Ist)) + (Kp2 * Soll)

    Das Schwingen hängt von den Zeitkonstanten der Regelstrecke ab. Unbekannt ist noch wie sich die BL-control 918 zeitlich verhält.
    Zudem spielt die Abtastrate des Istwerts auch noch mit rein.

    Jetzt hast du das Problem, dass aus (Soll - Ist) die neue Stellgrösse berechnet wird. Bis zur nächsten Messung ist dann der Motor viel zu schnell geworden, also wird die Stellgrösse wieder verkleinert.
    Möglicherweise musst du noch die Abtastrate erhöhen, der Motor reagiert recht schnell.

    Praktisch muss du jetzt den D-Anteil erhöhen, bis die Geschichte nicht mehr schwingt. Dann kannst du den P-Anteil weiter erhöhen.
    Dieses Spiel machst du, bis der Istwert eine minimale Abweichung hat und alles Stabil bleibt.

    Dann kannst du mit dem I-Anteil die restliche Abweichung noch verkleinern.


    MfG Peter(TOO)
    Manchmal frage ich mich, wieso meine Generation Geräte ohne Simulation entwickeln konnte?

  3. #3
    HaWe
    Gast
    ja, das Tunen und Fine-Tunen ist ein echter PITA.
    Ich hatte seinerzeit refresh-Intervalle von ca. 10ms für meine PID_v1-Regler. PID_v1 hat übrigens auch ein autotuning-Modul, das habe ich aber zugegebenermaßen selber nie verstanden.
    Der Weg, den Peter-too aufgezeigt hat, ist aber schon richtig:
    erst I und D auf Null und dann P optimal tunen,
    dann I schrittweise erhöhen, bis das System anfängt sich einzuschwingen,
    dann D schrittweise erhöhen, ohne dass es anfängt zu zittern oder zu schütteln, ggf. nochmal I und/oder P nachjustieren.

    Es gibt fürs PID tuning mehrere Schemata im Netz (öfters erwähnt: Ziegler-Nichols), aber keines ist so richtig optimal für alle erdenklichen Anwendungszwecke.
    Geändert von HaWe (26.08.2017 um 10:41 Uhr)

  4. #4
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    27.08.2013
    Ort
    Region Basel
    Alter
    66
    Beiträge
    2.435
    Hallo,
    Zitat Zitat von HaWe Beitrag anzeigen
    Es gibt fürs PID tuning mehrere Schemata im Netz (öfters erwähnt: Ziegler-Nichols), aber keines ist so richtig optimal für alle erdenklichen Anwendungszwecke.
    Man kann die Sprungantwort der Regelstrecke messen und dann eine Menge rechnen.

    Aber auch dann muss man von Hand nachtrimmen, da alle Konstanten variabel sind.
    Ich habe es in 40 Berufsjahren nie erlebt, dass berechnete Parameter wirklich gepasst haben, egal wer nach welcher Theorie gerechnet hat.
    Manchmal frage ich mich, wieso meine Generation Geräte ohne Simulation entwickeln konnte?

  5. #5
    Neuer Benutzer Öfters hier
    Registriert seit
    21.11.2010
    Ort
    Germany
    Beiträge
    17
    Die Werte für I und D habe ich erst mal auf 0 gelassen.
    Das wird dann aber schwingen. Der D-Anteil sollte nun erhöht werden bis es nicht mehr schwingt. Der I-Anteil ist für die Minimierung der Regelabweichung notwendig.
    Ohne I-Anteil wird die Solldrehzahl niemals erreicht & Ohne D-Anteil wirds Schwingen.

  6. #6
    Benutzer Stammmitglied
    Registriert seit
    08.03.2010
    Beiträge
    66
    Vielen Dank für die Infos!
    Ich werde heute Abend dazu kommen das mal auszuprobieren.

    Den Arduino zum Regeln, also der mit dem Hallsensor werde ich im folgetext ArduinoRH nennen.

    Das Problem ist, das der Motor an einem Servocontroller hängt. Dieser ist via UART an dem Hauptcontroller angeschlossen. Und der ArduinoRH dann via I2C an dem Hauptcontroller.
    Also ein laaaanger Weg.
    Ich freunde mich schonmal mit dem Gedanken an, den Motor direkt an den ArduinoRH anschließen. Aber ich befürchte, das es trotzdem Timing probleme gibt.

    Es macht doch keinen Sinn den PID-Algo alle 10ms aufzurufen, wenn es deutlich länger dauert eine Drehzahl zu ermitteln, oder?
    Die I2C Versorgung auf dem ArduinoRH benötige ich in jedem Fall.
    Nur wenn ich sende und empfange, kann ich in der Zeit keine Drehzahl messen.
    Aufschieben kann ich die Antwort auch nicht, da der Request vom Hauptcontroller sofort beantwortet werden muss.

  7. #7
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    27.08.2013
    Ort
    Region Basel
    Alter
    66
    Beiträge
    2.435
    Hallo MechMac,
    Zitat Zitat von MechMac Beitrag anzeigen
    Es macht doch keinen Sinn den PID-Algo alle 10ms aufzurufen, wenn es deutlich länger dauert eine Drehzahl zu ermitteln, oder?
    Richtig erkannt!
    Die kürzeste Zeit muss gleich der Abtastrate der Drehzahl sein. Alles was schneller ist bringt nichts, bzw. bringt den I-Anteil ins schleudern.

    Ein wichtiger Faktor sind dann aber auch die Zeit-Schwankungen bei der Abtastung, diese sollten möglichst klein sein.

    Sagen wir mal du hast alle 2 Sekunden eine neue Drehzahl und rufst aber alle 100 ms den Regler auf.
    Dann hat sich bei 19 Aufrufen am Ist-Wert nichts geändert. Der Regler stellt aber bei jedem Aufruf fest, dass sich nichts an der Differenz (Soll - Ist) geändert hat und erhöht jedes mal den Stellwert.....
    Das kann nichts werden!

    Oft macht es aber auch noch Sinn zuerst mehrere Abtastwerte zu erfassen um dann den Mittelwert zu bilden. Damit kann man einen Teil der Störungen verringern.

    Du solltest das Ganze so gestalten, dass du höchstens nach jeder Drehzahlmessung den Regler einmal aufrufst.
    Ein Problem dabei ist, dass die Abtastrate direkt als Zeit-Parameter in die Formel eingeht.
    Du hast dann eine Variable Konstante und das kann nicht stabil sein.

    Die Grundsätzliche Frage ist noch, wie schnell die Regelung sein muss?
    Also wie schnell muss eine bestimmte Drehzahl erreicht werden und wie schnell müssen Lastwechsel ausgeglichen werden?
    Hier stellt sich auch noch die Frage, wie gross und schnell die Lastwechsel überhaupt sind?
    Über die Anwendung wissen wir bis jetzt noch gar nichts, also was da am Motor hängt?

    Ich hatte viel mit Motor- und Heizreglern zu tun. Wenn du 4 m3 Wasser hast, macht es keinen Sinn da jede Sekunde zu messen, das System ist viel zu träge.

    Bei Motoren spielen die Schwungmasse und die Belastung eine grosse Rolle. Die Schwungmasse verändert vor allem den D-Anteil und die Belastung ändert die Zeitkonstante bei der Sprungantwort.
    Du hast dann eine weitere variable Konstante, weshalb die Berechnungen für einen PID-Regler eben nie stimmen....

    MfG Peter(TOO)
    Manchmal frage ich mich, wieso meine Generation Geräte ohne Simulation entwickeln konnte?

  8. #8
    HaWe
    Gast
    Zitat Zitat von Peter(TOO) Beitrag anzeigen
    Hallo MechMac,


    Richtig erkannt!
    Die kürzeste Zeit muss gleich der Abtastrate der Drehzahl sein. Alles was schneller ist bringt nichts, bzw. bringt den I-Anteil ins schleudern.

    Ein wichtiger Faktor sind dann aber auch die Zeit-Schwankungen bei der Abtastung, diese sollten möglichst klein sein.

    Sagen wir mal du hast alle 2 Sekunden eine neue Drehzahl und rufst aber alle 100 ms den Regler auf.
    Dann hat sich bei 19 Aufrufen am Ist-Wert nichts geändert. Der Regler stellt aber bei jedem Aufruf fest, dass sich nichts an der Differenz (Soll - Ist) geändert hat und erhöht jedes mal den Stellwert.....
    Das kann nichts werden!

    MfG Peter(TOO)
    Ich habe tatsächlich die Frequenz von nur 2x/s überlesen, ich selber habe seinerzeit alle 200µs die Encoder ausgelesen, und eine deutlich langsamere Abtastung als 10 oder 100ms reicht dann bei dir natürlich auch aus.

  9. #9
    Benutzer Stammmitglied
    Registriert seit
    08.03.2010
    Beiträge
    66
    So, die tests werde ich in Kürze an dem "echten" Motor durchführen.
    An dem Testmotor, den ich hier auch beschrieben hatte, bin ich zu folgendem Ergebnis gekommen:

    Wenn ich I etwas erhöhe wird es besser. Aber D darf ich nicht größer als 0 machen. Dann dreht das Teil völlig am Rad und fängt wie wild an zu schwingen.
    Ich hatte folgende Werte
    P=0.03 I=0.04 D=0.00

    Kann D eigentlich auch negativ sein?


    Naja, der "echte" Motor ist viel größer und dreht deutlich langsamer. Da kann ich dann auch mal den Test unter Last machen.

    Also irgendwie kommen mir die Werte so "klein" vor.

    Aber nochwas:
    Output, also das was von der PID-Regelung kommt, ist ein double. Ich übergebe dem Steller aber nur integer. Im Grunde fehlen mir die beiden nachkommastellen, die ja auch "feine" Korrekturen beinhalten.
    Als nicht-Mathematik-Mensch fällt mir da nur ein: Den Wert nicht begrenzen von 1500.00-1800.00, sondern von 15.00-18.00 und dann das Ergebnis*100.
    Macht das Sinn?
    Muss ich mal drüber nächtigen....

  10. #10
    Erfahrener Benutzer Robotik Einstein
    Registriert seit
    27.08.2013
    Ort
    Region Basel
    Alter
    66
    Beiträge
    2.435
    Zitat Zitat von MechMac Beitrag anzeigen
    Naja, der "echte" Motor ist viel größer und dreht deutlich langsamer. Da kann ich dann auch mal den Test unter Last machen.

    Also irgendwie kommen mir die Werte so "klein" vor.
    Meine Frage ist immer noch die Abtastrate des Istwertes und die Aufrufrate des Reglers?

    Wenn du den Regler öfters aufrufst, als gemessen wird, bekommt er zwischen den Messungen immer den selben Wert gefüttert.

    Der berechnete P-Anteil bleibt also konstant, weil (Ist-Soll) auch konstant bleibt.

    Der D-Anteil rechnet mit (IstALT - IstNEU) und kämpft gegen das Schwingen und zu schnelle Änderungen des Stellwerts. Wird er mit einem neuen Its-Wert aufgerufen rechnet er eine Gegenmassnahme. Bei den weiteren Aufrufen, wird sein Anteil dann 0.

    Der I-Anteil integriert den Wert (Soll - Ist) Da diese Differenz zwischen den Abtastungen konstant bleibt, erhöht der P-teil bei jedem Aufruf die Stellgrösse, ohne zu bemerken, was die letzte Änderung des Stellwerts ausgerichtet hat.

    Wenn du den Ist-Wert alle 2s abtastetest und den Regler alle 100ms aufrufst, hats du für 100ms einen vernünftigen Stellwert. Die nächsten 19 sind dann Schüsse in Blaue.
    Das Doofe ist aber, dass der Motor sofort auf eine Änderung des Stellwertes reagiert .....

    Die Abtastrate des Ist-Wertes muss also mindestens gleich gross, oder grösser, als die Aufrufzeit des Reglers sein.

    Ein Problem ist noch die Konstanz der Abtastrate des Istwerts.
    Etwas vereinfacht berechnet der Regler welche Drehzahlveränderung eine Stellwert-Veränderung um z.B. 10% in der Zeit tA bewirkt.
    ist nun aber die Abtastzeit einmal 2s und einmal 1s ändert sich dieser Wert um den Faktor 2!
    Alleine dies führt schon zum Schwingen.

    Man muss also die Abtastzeit möglichst Konstanz halten oder die reale Zeit zwischen den Abtastungen mit erfassen und im Regler mit verarbeiten. Dadurch wird allerdings die Rechnerei im Regler um einiges aufwändiger.



    Zitat Zitat von MechMac Beitrag anzeigen
    Aber nochwas:
    Output, also das was von der PID-Regelung kommt, ist ein double. Ich übergebe dem Steller aber nur integer. Im Grunde fehlen mir die beiden nachkommastellen, die ja auch "feine" Korrekturen beinhalten.
    Als nicht-Mathematik-Mensch fällt mir da nur ein: Den Wert nicht begrenzen von 1500.00-1800.00, sondern von 15.00-18.00 und dann das Ergebnis*100.
    Du solltest natürlich schon die maximale Auflösung aus den Stellglied heraus holen!

    Wenn dein Stellglied eine Auflösung von 1'000 hat und du skalierst das Ganze auf den Bereich von 0..10 (Integer), kann sich die Stellgrösse nur in 100er-Schritten ändern.
    Skalierst du auf 0...1'000 kann sich der Ausgang in 1er-Schritten verstellen.

    MfG Peter(TOO)
    Geändert von Peter(TOO) (29.08.2017 um 12:56 Uhr) Grund: Typo: P-Anteil --> I-Anteil
    Manchmal frage ich mich, wieso meine Generation Geräte ohne Simulation entwickeln konnte?

Seite 1 von 2 12 LetzteLetzte

Ähnliche Themen

  1. 10A Mikroschrittkarte - Probleme mit Strom-Regelung
    Von Kaiser-F im Forum Elektronik
    Antworten: 84
    Letzter Beitrag: 07.12.2010, 19:39
  2. Regelung mit PIC
    Von Shunth im Forum PIC Controller
    Antworten: 4
    Letzter Beitrag: 25.06.2010, 21:49
  3. Antworten: 4
    Letzter Beitrag: 04.11.2008, 18:39
  4. PWM-Regelung
    Von eis im Forum Elektronik
    Antworten: 0
    Letzter Beitrag: 20.05.2007, 12:03
  5. Antworten: 13
    Letzter Beitrag: 17.09.2004, 21:09

Berechtigungen

  • Neue Themen erstellen: Nein
  • Themen beantworten: Nein
  • Anhänge hochladen: Nein
  • Beiträge bearbeiten: Nein
  •  

LiFePO4 Speicher Test