Inverse Kinematik

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen

Die inverse Kinematik, Inverskinematik oder Rückwärtstransformation ist ein Begriff aus der Computeranimation und Robotik. Sie ermöglicht bei einem Roboter die Bestimmung der Gelenkwinkel der Armelemente anhand der Pose (Position und Orientierung) des Endeffektors. Sie spielt damit eine wichtige Rolle bei der Bewegung von Industrierobotern und bei der Computeranimation von Charakteren. Sie ist das logische Gegenstück zur direkten Kinematik.

Bei der inversen Kinematik wird das letzte Glied der kinematischen Kette, der Endeffektor, bewegt und in die gewünschte Lage gebracht. Die übrigen Glieder der Kette müssen dann entsprechend den Freiheitsgraden ihrer Gelenke passende Lagen einnehmen.

Vergleichen lässt sich dies mit dem menschlichen Arm, der mit seinen Gelenken auch eine solche kinematische Kette darstellt: Bringt man beispielsweise die Hand in eine bestimmte Lage, so nehmen Handgelenk, Ellenbogen und Schulter automatisch ebenfalls bestimmte Stellungen ein. Genau diese Gelenkwinkel-Stellungen müssen über die inverse Kinematik bestimmt werden.

Die Zusammenhänge verdeutlicht folgende Abbildung: Roboterkinematik.png

Kinematik erreicht selben Punkt über verschiedene Konfigurationen.

Schwierigkeiten[Bearbeiten | Quelltext bearbeiten]

Bei der Berechnung der inversen Kinematik treten folgende Schwierigkeiten auf:

  1. Die Lage der einzelnen Glieder bzw. Armelemente muss nicht eindeutig sein. Es kann und wird im Allgemeinen mehrere Konfigurationen geben, die zur gewünschten Lage des Endeffektors führen. Man stelle sich eine einfache Kinematik vor, die aus zwei Gliedern besteht. Das erste Glied ist über ein Drehgelenk an der Umgebung befestigt, das zweite Glied ist über ein Drehgelenk am ersten Glied befestigt. Ein Punkt im Arbeitsraum kann nun auf zwei Weisen erreicht werden: "rechts rum" und "links rum". Diese beiden Möglichkeiten nennt man Konfigurationen.
  2. Es können unzulässige Konfigurationen entstehen. Diese sind mathematisch zwar vielleicht korrekt, können von den Gelenken aber nicht erfüllt bzw. eingenommen werden oder führen zu nicht erreichbaren Ziellagen.
  3. Die Anzahl der Parameter ist nicht identisch. Beispielsweise können bei einem 7-Achser die Gelenke nur bis auf einen Freiheitsgrad festgelegt werden.

Lösungsmöglichkeiten[Bearbeiten | Quelltext bearbeiten]

Zur Lösung des inversen kinematischen Problems gibt es kein allgemein anwendbares Verfahren. Da die Berechnung der Gelenkwinkel sehr schnell erfolgen muss, sind in der Praxis üblicherweise Lösungen zu finden, die auf den speziellen Roboter optimiert und angepasst sind.

Es existieren folgende grundlegende Methoden:

Algebraische Methoden[Bearbeiten | Quelltext bearbeiten]

Durch sukzessive Invertierung der Denavit-Hartenberg-Transformationsmatrizen und damit Lösung des folgenden Gleichungssystems können nach und nach die einzelnen Gelenkwinkelvektorkomponenten berechnet werden:

Wobei eine homogene Matrix ist, die die Position und Orientierung des Endeffektors beschreibt.

Geometrische Methoden[Bearbeiten | Quelltext bearbeiten]

Aufgrund des Wissens über die Geometrie des Roboters wird versucht, zum Beispiel mit Hilfe von Kosinussatz oder Sinussatz den Gelenkwinkelvektor zu berechnen.

Numerische Methoden[Bearbeiten | Quelltext bearbeiten]

Mit numerischen Methoden wird iterativ versucht, eine Lösung für den Gelenkwinkelvektor zu finden. Lokale Minima oder die Bestimmung eines geeigneten Startwerts sind hier jedoch problematisch.

Gleichungen[Bearbeiten | Quelltext bearbeiten]

Die inverse Kinematik ist der Vorwärtskinematik genau entgegengesetzt. Es bezieht sich auf den Prozess des Erhaltens von Gelenkwinkeln aus bekannten Koordinaten des Endeffektors. Wenn beispielsweise kartesische Handgelenk- oder Faustkoordinaten bekannt sind, besteht das Ziel darin, die Winkel der Schulter- und Ellbogengelenke für den Arm in der Sagittalebene zu entschlüsseln. Wenn die Freiheitsgrade Eingabe und Ausgabe nicht übereinstimmen, ist die inverse Kinematik möglicherweise zwecklos, da es entweder unendlich viele oder keine Lösungen gibt.

Gesucht ist eine Koordinatentransformation

Es ist zu beachten, dass es selbst in unserem Fall mit gut abgestimmten Freiheitsgraden möglicherweise keine Lösung, eine einzelne Lösung oder zwei Lösungen für die inverse Kinematik gibt, die keinem Schnittpunkt zwischen Kreisen entsprechen, die beim ersten Gelenk und Endeffektor zentriert sind, und bei gleichen Radien zu den entsprechenden Längen der Verbindungen berühren sich zwei Kreise, die die einzelne Position vom zweiten Gelenk definieren, und zwei Schnittpunkte, die zwei mögliche Lösungen für das zweite Gelenk definieren.

Diese Schnittpunkte können bestimmt werden, indem Gleichungen für zwei Kreise gesetzt und nach aufgelöst werden:

Wenn eine Lösung für existiert, kann man nach auflösen.

Ein anderer Ansatz ist, den Kosinussatz zu verwenden und den Winkel zu bestimmen:

Daraus ergibt sich

Ebenso erhält man mithilfe des Kosinussatz

und schließlich[1]

Siehe auch[Bearbeiten | Quelltext bearbeiten]

Literatur[Bearbeiten | Quelltext bearbeiten]

Weblinks[Bearbeiten | Quelltext bearbeiten]

Einzelnachweise[Bearbeiten | Quelltext bearbeiten]

  1. Marko B. Popovic, Matthew P. Bowers, in Biomechatronics, 2019, ScienceDirect: Inverse Kinematics