6. Kapitel
Bewegung auf Polygonen als Kollisionsproblem
Bewegung auf Polygonen
Fotorealistisch dargestellte Objekte werden zwecks mathematischer Behandlung oft als Polygonzug approximiert. Hier soll die Bewegung eines rollenden Balls auf einer Oberfläche untersucht werden, die als Polygon vorliegt.Auch wenn die Bewegung eines Balls auf einem Polygon auf den ersten Blick nichts mit Kollisionen zu tun hat, so sind es die Werkzeuge der Kollisionserkennung, die hier zu Einsatz kommen. Die einzelnen Polygonsegmente können als schiefe Ebene angesehen werden. Dort aber, wo diese schiefen Ebenen mit ungleichen Neigungswinkeln zusammen stoßen, gibt es eine Ecke an der die Bewegung des Balls von einer Ebene zur anderen übergeht. Dort sind Ort s und Geschwindigkeit vs auf die neuen Gegebenheiten Neigungswinkel β und daraus folgend die effektive Beschleunigung g_ einzustellen.
Ecken spielen dabei eine besondere Rolle, da es bei konkaven Ecken zwei Kontaktpunkte und bei konvexen Ecken eine Diskontinuität gibt, an der die Bewegung des Balls - zumindest zeitweise - in einen schrägen Wurf übergeht. Auch liegt, wie bei der Kollisionserkennung, das Problem in der Diskretisierung der Zeit. Es müssen Korrekturmaßnahmen gefunden werden, die das genaue Erkennen der Ecken ermöglichen. Andernfalls kommt es zu ruckhaften Bewegungsabläufen und zu Verletzungen der Energie- bzw. Impulserhaltungssätze.
Polygone mit ausschließlich konkaven Ecken
Beginnen wir mit dem weniger komplizierten Fall eines Polygons, das nur konkave Ecken aufweist. Solange sich der Ball weit genug von diesen Ecken entfernt bewegt, ist die Welt in Ordnung und die Bewegung erfolgt nach den Gesetzen der schiefen Ebene. Zweckmäßiger Weise wird wieder das s-Koordinatensystem angewendet, was die Berechnung der Bewegung vereinfacht, weil die Darstellung des bewegten Objektes mittels der Matrix-Befehle erfolgt.Die Probleme beginnen, wenn sich der Ball einer Ecke nähert und diese dann durchläuft. Wie in zu ersehen ist, kann der Ball nicht bis an das Ende der aktuellen Schräge mit der Länge lengthi rollen, da er bereits die nächste Schräge i+1 berührt. Bei konvexen Ecken gibt es immer zwei solche Berührungspunkte, die die betreffenden Schrägen um die Abstände limiter verkürzen. Mit anderen Worten, die Bewegung auf der Schrägen i endet an der um den Abstand limiter verminderten Segmentlänge lengthi und setzt sich auf der Schrägen i+1 am Punkt limiter beginnend fort (wenn Du Dir die Bewegung von links nach rechts ablaufend denkst).
Dies ist der erste Grund, weshalb über die Bewegung an den Ecken eines Polygons nachgedacht werden muss. Falsch wäre es, die Bewegung des Balles erst mit dem Erreichen der Segmentlänge auf dem aktuellen Segment zu beenden und bereits am Nullpunkt des anschließenden Segments fortzusetzen. Eine diskontinuierliche Bewegung wäre die Folge!
Abb. Ball in einer konkaven Ecke
Abb. Berechnung der Bewegungsgrenzen zwischen zwei Segmenten
()
zeigt die Abfolge der Bewegungsbereiche bei einer von links nach rechts ablaufenden Bewegung.
Der Ball startet seinen Weg s(t) auf dem Segment i bei einem beliebigen
Startwert s0 mit der aktuell geltenden effektiven Beschleunigung g',
dem Neigungswinkel β und der Anfangsgeschwindigkeit v0.
Dabei ist stets zu prüfen, ob der Wert
überschritten wird. Ist dies der Fall, muss das Segment i verlassen werden. Für die
Fortsetzung der Bewegung auf dem Segment i+1 sind nun die neuen Bewegungsparameter, wie
effektive Beschleunigung g', Neigungswinkel β zu verwenden.
Die Startgeschwindigkeit v0 im neuen Segment ist gleich der Geschwindigkeit
v(t) beim Verlassen des alten Segments. Und der Startort ist gleich dem Wert des aktuellen
Limiters s0 = limiteri+1.
Abb. Grenzen der Bewegung zwischen zwei Segmenten
- Berechnung der Zeitspanne bis zum exakten Erreichen des Limiter-Punktes auf dem Segment i:
()
-
Berechnung der Endgeschwindigkeit an diesem Punkt. D.h. Die Differentialgleichung für die Geschwindigkeit ist jetzt
mit dem verkürzten Zeitincrement Δright zu berechnen. Der Index
right in Δright bedeutet, dass das verbleibende
Zeitintervall rechts vom letzten regulären Zeitintervall steht, also nur für Bewegungen von links nach rechts gilt.
Die so berechnete Endgeschwindigkeit ist gleich der Startgeschwindigkeit v0 für die Bewegung auf dem Segment i+1.() -
Setzen des Startorts s0 auf dem neuen Segment. Dieser Ort geht zunächst vom
Limiter aus, muss aber noch durch die Bewegung des Balls im restlichen Zeitintervall erweitert werden:
()
Abb. a Eckenübergang bei Bewegung von links nach rechts
Abb. b Eckenübergang bei Bewegung von rechts nach links
()
()
Die Endgeschwindigkeit im aktuellen Segment ist gleich der Startgeschwindigkeit v0 für die Bewegung auf dem Segment i-1.
()
Abb. Flowchart der Bewegungsberechnungen
Die State-machine sieht für den vorliegenden Fall noch sehr einfach aus. Da die Kontur vereinbarungsgemäß nur aus Segmenten besteht, die an ihren Grenzen konkaven Ecken bilden, besteht die kritische Aufgabe nur in der genauen Feststellung eines Segmentwechsels. Während des Status "onGround" gelten die Gesetze der schiefen Ebene. Wegen der unterschiedlichen Steigungen der einzelnen Segmente herrschen unterschiedliche Hangabtriebskräfte vor, deren Werte aber vorab schon bekannt sind. Solange kein Segmentende (2) prognostiziert ist, bleibt der Status "onGround" (1) erhalten. Erst am Segmentende machen sich die Berechnungen von Startort und -geschwindigkeit für das neue Segment erforderlich. Dazu werden die oben beschriebenen Prognoseverfahren heran gezogen. Besondere Beachtung verdient hierbei die Richtungsinformation der Geschwindigkeit v, weil bei einer Bewegung nach rechts der Startort am Segmentanfang, andernfalls am Segmentende liegt.
Im Programmbeispiel wird der rollende Ball so plaziert, dass im Bereich der Bewegung nur konkave Ecken auftreten. Zur Demonstration
der Wirksamkeit der Korrekturmaßnahmen werden die Standardlösung und die Lösung mit Korrekturmaßnahmen gegenüber gestellt. Um die
Unterschiede deutlich zu machen, unterliegt die Bewegung keinerlei Reibungseinfluss.
Nach dem Aufruf und dem Start des Programmbeispiels wird die Bewegung des Balls ohne Korrekturmaßnahmen gezeigt. Der Button Korr/NoKorr erlaubt das Umschalten in den Korrekturmodus. Nach Umschaltung ist der Bewegungsablauf erneut zu starten. Weiterhin kann mit dem Button Shape zwischen zwei Konturen gewählt werden.
Um den Nachweis der energetischen Treue der verwendeten Algorithmen zu erbringen, wird hier der genauere Runge-Kutta-Solver zur Lösung der Bewegungsgleichungen eingesetzt. Zur Überprüfung der energetischen Treue wird die Gesamenergie Wges angezeigt. Zwecks detailierter Bewegungsstudien gibt es einen Debug-Modus, in dem die Bewegung Schritt weise abgearbeitet werden kann. Zur optischen Orientierung werden die Limiter als Marken auf dem Weg eingeblendet.
Nach dem Aufruf und dem Start des Programmbeispiels wird die Bewegung des Balls ohne Korrekturmaßnahmen gezeigt. Der Button Korr/NoKorr erlaubt das Umschalten in den Korrekturmodus. Nach Umschaltung ist der Bewegungsablauf erneut zu starten. Weiterhin kann mit dem Button Shape zwischen zwei Konturen gewählt werden.
Um den Nachweis der energetischen Treue der verwendeten Algorithmen zu erbringen, wird hier der genauere Runge-Kutta-Solver zur Lösung der Bewegungsgleichungen eingesetzt. Zur Überprüfung der energetischen Treue wird die Gesamenergie Wges angezeigt. Zwecks detailierter Bewegungsstudien gibt es einen Debug-Modus, in dem die Bewegung Schritt weise abgearbeitet werden kann. Zur optischen Orientierung werden die Limiter als Marken auf dem Weg eingeblendet.
Ergebnisdiskussion: Im Bewegungsmodus ohne Korrektur sind deutlich die Unstetigkeiten der Bewegung an den konkaven Ecken zu beobachten. Auch gibt es starke Schwankungen der Gesamtenergie Wges, obwohl insgesamt keine Änderungen außerhalb der Schwankungsbreite auftreten.
Anders im Korrektur-Modus. Hier verläuft die Bewegung im Übergang von einem Segment zum nächsten (oder vorhergehenden) flüssig und ruckelfrei. Auch die Schwankungen der Gesamtenergie Wges sind sehr klein. Allerdings akkumulieren sich die Energie-Fehlbeträge, so dass es zu einem fehlerhaften Energiezuwachs kommt. In der Praxis, unter dem Einfluss von Reibungseffekten, dürfte das aber keine Rolle spielen. Hier überwiegt der Nutzen einer gleichmäßigen Bewegung!
Noch eine Bemerkung zur Programm-Ökonomie: Alle geometrischen Vorgaben, die Konturelemente betreffend, sind feststehend. Deshalb ist es zweckmäßig, daraus abgeleitete Größen wie Neigungswinkel βi, Segmentlänge lengthi, gewichtete Gravitationskonstante g_i oder Limiter limiteri vorab in der setup()-Funktion zu berechnen. So stehen diese Werte in der draw()-Funktion unmittelbar und ohne Rechenaufwand zur Verfügung.
Allgemeine Polygone bei geringen Objektgeschwindigkeiten
Hier werden Bewegungen auf Polygonen mit konkaven und konvexen Ecken bei geringen Geschwindigkeiten untersucht. Die Beschränkung auf geringe Objektgeschwindigkeiten bedeutet, dass das Objekt an konvexen Ecken nicht abhebt, sondern über diese Ecke abrollt. Eine Testung auf eine Loslösung des Objektes vom Untergrund kann also entfallen!Die Bewegung auf Polygonen mit konvexen Ecken führt auf zwei unterschiedliche Bewegungsmodi:
- Bewegung des Balls auf den Segmenten einschließlich der konkaven Ecken. Dies ist eine beschleunigte Bewegung im s-Koordinatensystem der schiefen Ebene und
- bei geringen Geschwindigkeiten rollt der Ball über konvexen Ecken ohne den Boden zu verlassen. Dies ist eine beschleunigte rotatorische Bewegung im φ - r-Koordinatensystem in Polarkoordinaten.
Im Gegensatz zu einem Profil mit ausschließlich konkaven Ecken, wo nur Geradenstücke d.h. Segmente
aneinander gefügt werden, gibt es bei den konvexen Ecken einen Kreissektor zwischen den benachbarten Segmenten, der
durch eine rotatorische Bewegung um die betroffene Ecke ausgefüllt werden muss. Das Betreten dieses Bereiches ist
nicht mit einem Segmentwechsel verbunden. Trotzdem ist eine Parameterübergabe beim Betreten
und auch beim Verlassen dieses Kreissektors erforderlich.
Treten konvexe Ecken auf, endet bzw. beginnt die geradlinige Bewegung auf den Segmenten i bzw. i+1 direkt an den Segmentgrenzen. Assoziiert mit den Segmentgrenzen sind die Normalen (in rote, gestrichelte Linien), zwischen denen der eingeschlossene Kreissektor liegt. Auch hier sind die Normalenwinkel φlinks und φrechts bekannt, da sie wie die anderen Konturparameter in der Setup()-Funktion vorab berechnet werden können.
Wie schon erwähnt, handelt es sich bei der Bewegung des Balls auf der Ecke um eine Drehbewegung des Ballmittelpunktes centerBall um den Eckpunkt Pi. Beim Übergang von geradliniger Bewegung zur Drehbewegung wird die Geschwindigkeit vs in die der Winkelgeschwindigeit ω der Drehbewegung umgerechnet:
Treten konvexe Ecken auf, endet bzw. beginnt die geradlinige Bewegung auf den Segmenten i bzw. i+1 direkt an den Segmentgrenzen. Assoziiert mit den Segmentgrenzen sind die Normalen (in rote, gestrichelte Linien), zwischen denen der eingeschlossene Kreissektor liegt. Auch hier sind die Normalenwinkel φlinks und φrechts bekannt, da sie wie die anderen Konturparameter in der Setup()-Funktion vorab berechnet werden können.
Wie schon erwähnt, handelt es sich bei der Bewegung des Balls auf der Ecke um eine Drehbewegung des Ballmittelpunktes centerBall um den Eckpunkt Pi. Beim Übergang von geradliniger Bewegung zur Drehbewegung wird die Geschwindigkeit vs in die der Winkelgeschwindigeit ω der Drehbewegung umgerechnet:
()
Abb. Bewegung über eine konvexe Ecke
Innerhalb der Drehbewegung gilt die Differentialgleichung für die beschleunigte Drehbewegung (ohne Reibungseinfluss):
()
()
Soweit so gut, die eigentliche Schwierigkeit besteht aber darin, die Grenzen zwischen den einzelnen Zuständen sicher und möglichst genau zu erkennen. Denn, wie bereits im vorherigen Abschnitt (Polygone mit ausschließlich konkaven Ecken) ausgeführt, verhindert die zeitliche Diskretisierung eine genaue Bestimmung des Objektstandorts. Darum muss auch bei der Bewegung auf der Ecke mit einem Prognoseverfahren analog zu bis gearbeitet werden:
(a)
(b)
Die Geschwindigkeit zum Ende des begonnenen Intervalls beim Übergang von der Drehbewegung zur Bewegung auf dem nächsten Segment wird wieder mit Hilfe des einfachen EULER-CAUCHY-Algorithmus abgeschätzt:
(a)
(b)
Beim Übergang von der Drehbewegung zur Bewegung auf einem Segment muss die Winkelgeschwindigkeit ω in die der schiefen Ebene v umgerechnet werden. Das erfolgt analog zu . Schließlich ist noch der Startort auf dem aktuellen Segment zu bestimmen, dies erfolgt wieder analog zu bzw. .
Die vorliegende State-machine basiert natürlich auf der vom vorangegangenen Beispiel () bekannten Lösung. Da nunmehr auch konvexe Ecken zugelassen sind, muss der Flowchart um den Zweig 3 erweitert werden. Sofern eine konkave Ecke vorliegt, erfolgt die Berechnung der Parameterübergabe wie gehabt über den Zweig 2 und der Status bleibt unverändert "onGround". Anders, wenn eine konvexe Ecke vorliegt. Dann erfolgt die Parameterübergabe an die Bewegungsgleichungen für die rotatorische Bewegung auf der Ecke (4) und der Status wird in "onEdge" geändert. In diesem Zustand 5 verbleibt die State-machine, bis das Ende der Bewegung auf der Ecke prognostiziert wird. Dann erfolgt die Berechnung der an die schiefe Ebene zu übergebenden Bewegungs-Parameter und die Bewegung wird auf dem anschließenden Segment fortgesetzt.
Abb. Flowchart der Bewegungsberechnungen
Bewegungen auf Polygonen, die aus schiefen Ebene einschließlich der konkaven Ecken bestehen, wurde im Kapitel Polygone mit ausschließlich konkaven Ecken ausführlich behandelt. Mit dem Hinzutreten auch konvexer Ecken verkompliziert sich der Status-Baum ().
Konkave und konvexe Ecken wechseln sich ab oder folgen mehrfach aufeinander. Mit Hilfe des Buttons Game
können unterschiedliche Anfangsbedingungen und unterschiedliche Konturen gewählt werden. So können verschiedene
Bewegungsszenarien mit unterschiedlichen Anfangsbedingungen (Startort und -geschwindigkeit) überprüft werden.
Bewusst wird wieder auf die Anwendung irgendwelcher Reibungseinflüsse oder das Bouncing verzichtet, um die Korrektheit der Implementierung transparent machen zu können. Sollten Dir die vorgegebenen Konturen nicht genügen, kannst Du in dem inkludierten Programm contours.js weitere Konturen hinzufügen oder verändern. Allerdings sind Konturen mit senkrechten Segmenten Tabu!
Zum Feinstudium der Bewegungsabläufe gibt es noch den debug-Modus, in dem Du schrittweise die Bewegungen studieren kannst.
Bewusst wird wieder auf die Anwendung irgendwelcher Reibungseinflüsse oder das Bouncing verzichtet, um die Korrektheit der Implementierung transparent machen zu können. Sollten Dir die vorgegebenen Konturen nicht genügen, kannst Du in dem inkludierten Programm contours.js weitere Konturen hinzufügen oder verändern. Allerdings sind Konturen mit senkrechten Segmenten Tabu!
Zum Feinstudium der Bewegungsabläufe gibt es noch den debug-Modus, in dem Du schrittweise die Bewegungen studieren kannst.
Ergebnisdiskussion:
Auch bei dieser Lösung gibt es Unstimmigkeiten bei der energetischen Billanz über den gesamten Spielraum. Hauptursache hierfür sind fehlerhafte Parameterübergaben an den Ecken infolge der Zeitdiskretisierung. Solche Fehler dürften aber bei Berücksichtigung diverser Reibungsverluste kaum ins Gewicht fallen.
Zur Vollständigen Lösung einer Aufgabe dieses Problemkreises wäre die Einführung von Reibung und Bouncing sinnvoll.
Allgemeine Polygone
Hier werden wir das Projekt mit Bouncing und darum mit Reibungseinfluss entwickeln. Dies ermöglicht die umfassende und natürliche Bewegung auf beliebig gestalteten Untergründen.Die Bewegung auf Polygonen mit konvexen Ecken führt im Allgemeinen auf drei unterschiedliche Bewegungsmodi:
- Bewegung des Balls auf den Segmenten einschließlich der konkaven Ecken. Dies ist eine beschleunigte Bewegung im s-Koordinatensystem der schiefen Ebene,
- bei geringen Geschwindigkeiten rollt der Ball über konvexen Ecken ohne den Boden zu verlassen. Dies ist eine beschleunigte rotatorische Bewegung im φ - r-Koordinatensystem in Polarkoordinaten und
- bei größeren Geschwindigkeiten hebt der Ball an den konvexen Ecken ab. Damit beginnt eine Bewegung nach den Gesetzen des schrägen Wurfs im x - y-Koordinatensystem.
Gegenüber den bisher behandelten Fällen ist nunmehr eine Entscheidung über den Bewegungsmodus an konvexen Ecken
erforderlich. veranschaulicht die zwei möglichen Fälle:
- Der Ball rollt langsam auf die konvexe Ecke zu (dunkelblauer Geschwindigkeitsvektor und gestrichelte Bewegungspfad). Würde jetzt auf den Status "onFlight" geschaltet, beschriebe der Ball eine Flugbahn, bei der Ball unter das folgende Segment fallen würde. Also rollt der Ball in diesem Fall über die Ecke.
- Der Ball rollt hinreichend schnell auf die konvexe Ecke zu (hellblauer Geschwindigkeitsvektor und strich-gepunkteter
Bewegungspfad). Jetzt genügen die Geschwindigkeitskomponenten, die an der Segmentgrenze aus der Bewegung auf der schiefen Ebene übergeben worden
sind, um eine Flugbahn zu erzeugen, die außerhalb des Abrollkreises liegt. Damit ist der schräge Wurf möglich und der Ball
springt (fliegt) über die Ecke.
Der Abrollkreis ist die Bahn, der der Mittelpunkt des Balls beim Abrollen über die Ecke folgt.
Abb. Roll or Flight?
Für die Ausführung der flight-Phase steht uns der mathematische Apparat des schrägen Wurfs zur Verfügung. Und für die Landung des Balls auf dem Grund, egal, ob Segment oder Ecke, gibt es die oben beschriebene Kollisionserkennung mit nachträglicher Korrektur. Die dazu erforderlichen Includes findest Du im Ordner "p5_includes/pCollision_v3.0".
Wie bereits erwähnt werden alle Bewegungen unter Reibungseinfluss betrachtet. D.h. auch das Bouncing unterliegt einem Energie-Verlust. Dieser wird in x- bzw. y-Richtung unterschiedlich durch die Variablen bouncingLossX bzw. bouncingLossY berücksichtigt. Der damit verbundene stetige Energieabbau führt dazu, dass das Bouncing endlich ist und die Bewegung des Balls wieder in die Bewegung auf der schiefen Ebene übergehen kann.
Die in gezeigte state-machine stellt - unschwer zu erkennen - eine Erweiterung von dar. Hinzugekommen ist die Abfrage im Zustand 1 (rollOrFlight), die im Zustand 2 die Übergabe der Bewegungsparameter an die Flug-Phase und den Flug (3) selbst ausführt. Findet eine Bodenberührung statt, erfolgt eine Reflexion des Balls (Bouncing). Dabei wird geprüft, ob die Energie für ein weiteres Bouncing ausreicht (4). Ist das nicht der Fall, werden die Bewegungsparameter für eine Bewegung "onGround" bereitgestellt und die Bewegung auf der schiefen Ebene fortgesetzt.
Abb. Flowchart der Bewegungsberechnungen
Dieses Beispielprogramm zeigt die gesamte Palette der Aufgabenstellung. Konkave und konvexe Ecken wechseln sich ab und das Bouncing ist möglich.
Allerdings würde das Bouncing ohne Reibungseinfluss niemals aufhören. Darum wird nun auch der Reibungseinfluss berücksichtigt. Weil aber
die Rollreibung und auch die Aufprallverluste beim Bouncing größere Einflüsse haben als die Strömungsreibung, wird auf die Implementierung letzterer
verzichtet!
Mit Hilfe des Buttons shape
können unterschiedliche Untergründe gewählt werden. Sollten Dir die vorgegebenen Konturen nicht ausreichen, kannst Du in dem inkludierten
Programm contours.js weitere Konturen hinzufügen oder verändern. Allerdings sind Konturen mit senkrechten
Segmenten Tabu!
Zum Feinstudium der Bewegungsabläufe gibt es noch den debug-Modus, in dem Du schrittweise die Bewegungen studieren kannst.
Zum Feinstudium der Bewegungsabläufe gibt es noch den debug-Modus, in dem Du schrittweise die Bewegungen studieren kannst.
Ergebnisdiskussion:
Die vorliegende Lösung kommt den Erfordernissen eines natürlichen Bewegungsverlaufs sehr nahe. Die größten Schwierigkeiten bei der Implementierung sind auf die Folgen der Zeitdiskretisierung zurück zu führen. Allerdings fallen energetische Fehler wegen der Einführung von Reibungseffekten kaum ins Gewicht.
Bouncing gehört unbedingt zu einem natürlichen Bewegungsablauf und wird darum auch zugelassen.
- Kontur 0: allein von der Schwerkraft beschleunigt bewegt sich der Ball auf der Kontur abwärts.
- Kontur 1: der Ball startet mit einer so großen Anfangsgeschwindigkeit, dass an den konvexen Ecken ein Abheben erfolgt.
- Kontur 2: die Anfangsgeschwindigkeit erlaubt nur an der ersten konvexen Ecke ein Abheben. Infolge der Energieverluste kann der Ball an der zweiten Ecke nur noch abrollen.
- Kontur 3: die Geschwindigkeit des Balls wird so hoch, dass mehrere Segmente beim Bouncing übersprungen werden.