Schnittkurve
Unter einer Schnittkurve versteht man in der Geometrie im einfachsten Fall die Schnittgerade zweier nicht paralleler Ebenen des Anschauungsraumes. Im Allgemeinen besteht die Schnittkurve zweier Flächen aus den gemeinsamen Punkten, in denen sich die Flächen transversal schneiden. Transversal bedeutet, dass in jedem gemeinsamen Punkt die Flächennormalen nicht auf einer Gerade liegen. Mit dieser Einschränkung schließt man aus, dass die Flächen sich berühren oder sogar ganze Flächenstücke gemeinsam haben.
Die Bestimmung der Schnittkurve zweier Flächen ist nur in einfachen Fällen analytisch möglich. Zum Beispiel: a) Schnittgerade zweier Ebenen, b) Schnitt einer Ebene mit einer Quadrik (Kugel, Kegel, Hyperboloid, …), c) Schnitt zweier Quadriken in besonderen Lagen (z. B. Rotationsquadriken mit derselben Rotationsachse). Für allgemeinere Fälle werden in der Literatur Algorithmen bereitgestellt, mit denen man Polygone mit Punkten auf der Schnittkurve zweier Flächen berechnen kann[1]. Die darstellende Geometrie bietet für in der Technik häufig vorkommende Fälle (Schnitt Zylinder-Kugel, Zylinder-Kegel, …) Methoden, mit denen man einzelne Punkte einer Schnittkurve (Durchdringungskurve) zeichnerisch bestimmen kann. Siehe: Hilfsebenenverfahren, Pendelebenenverfahren, Mantellinienverfahren und Hilfskugelverfahren.
Schnittgerade zweier Ebenen
Gegeben: Zwei Ebenen linear unabhängig, d. h., die Ebenen sind nicht parallel.
Gesucht: Eine Parameterdarstellung der Schnittgerade.
Die Richtung der Schnittgerade ergibt sich aus dem Kreuzprodukt der Normalenvektoren: . Einen Punkt der Schnittgerade erhält man, indem man die Ebenen mit der zu und senkrechten Ebene schneidet. und findet man durch Einsetzen in die Gleichungen der Ebenen und .
Beispiel:
Die Normalenvektoren sind und der Richtungsvektor der Schnittgerade . Für den Punkt ergibt sich nach obiger Formel Also ist
eine Parameterdarstellung der Schnittgerade beider Ebenen.
Bemerkung:
- Man kann bei konkret vorgegebenen Ebenengleichungen auch den Gauß-Algorithmus zur Bestimmung einer Parameterdarstellung der Schnittgerade verwenden. Der obige Weg ist als programmierbare Formel für den allgemeinen Fall geeigneter.
- Falls eine Ebene (oder beide) in Parameterdarstellung gegeben ist, so erhält man durch einen Normalenvektor und die Gleichung der Ebene: .
Schnittkurve einer Ebene mit einer Quadrik
Die Schnittkurve einer Ebene mit einer Quadrik (Kugel, Kegel, Zylinder, …) ist immer ein Kegelschnitt. Für die analytische Bestimmung der ebenen Schnitte eines senkrechten Kreiskegels: siehe Kegelschnitt. Die ebenen Schnitte anderer Quadriken z. B. die ebenen Schnitte einer Kugel, eines Zylinders, eines Paraboloids, eines Hyperboloids findet man hier: [2].
Eine wichtige Anwendung finden ebene Schnitte von Quadriken bei der Bestimmung von Umrisskurven. Denn sowohl bei Parallelprojektion als auch bei Zentralprojektion sind die Umrisse von Quadriken ebene Schnitte. Bei allgemeineren Flächen sind Umrisskurven meistens keine ebene Schnitte mehr. Siehe hierzu: Umrisskonstruktion.
Schnittkurve eines Zylinders/Kegels mit einer Quadrik
Da die Bestimmung des Schnittpunktes einer Gerade mit einer Quadrik in impliziter Form (z. B. Kugel ) nur das Lösen einer quadratischen Gleichung erfordert, lassen sich beliebig viele Schnittpunkte der Schnittkurve eines Zylinders oder Kegels (beide werden von Geraden erzeugt) mit einer Quadrik berechnen und durch einen Polygonzug visualisieren (s. Bilder).
Die Bilder zeigen die Möglichkeiten, die beim Schnitt eines Zylinders mit einer Kugel auftreten können:
- Im ersten Bild gibt es eine zusammenhängende Schnittkurve.
- Im zweiten Bild zerfällt die Schnittkurve in zwei getrennte Kurven.
- Im dritten Bild berühren sich Zylinder und Kugel in einem Punkt (singulärer Punkt). Hier haben die Flächennormalen dieselbe Richtung. Die Schnittkurve durchdringt sich selbst im Berührpunkt.
- Haben Zylinder und Kugel denselben Radius und der Mittelpunkt der Kugel liegt auf der Zylinderachse, so berühren sich Kugel und Zylinder in einem Kreis. Der Schnitt der beiden besteht ausschließlich aus singulären Punkten.
- Schnittkurve Kugel mit einem Zylinder: 1-teilig
- Schnittkurve Kugel mit einem Zylinder: 2-teilig
- Schnittkurve einer Kugel mit einem Zylinder: Kurve mit 1 Singularität
- Schnittkurve Kugel mit einem Zylinder: berührend
Allgemeiner Fall: Verfolgungsalgorithmus
Bei allgemeineren Flächen kann man keine Besonderheiten wie oben ausnutzen. Eine Möglichkeit, ein Polygon aus Punkten der gesuchten Schnittkurve zu erzeugen, bietet der Verfolgungsalgorithmus (s. Abschnitt Literatur). Er besteht aus zwei wesentlichen Teilen:
- Ein von der Darstellung der beteiligten Flächen abhängiger Kurvenpunkt-Algorithmus, der zu einem Punkt in der Nähe beider Flächen einen Punkt der Schnittkurve bestimmt. Für implizit gegebene Flächen gibt es einen relativ einfachen und schnellen Algorithmus, da die Funktionen der beiden Flächen auch in der Nähe der Flächen ausgewertet werden können und die Gradienten der Funktionen den Weg auf die beteiligten Flächen angeben. Für parametrisierte Flächen fehlen solche Informationen. Hier verwendet man u. a. Algorithmen, die Lotfußpunkte auf Flächen bestimmen.
- Der zweite Teil des Verfolgungsalgorithmus geht von einem bekannten Punkt der Schnittkurve aus und bestimmt mit Hilfe der Flächennormalen über deren Kreuzprodukt eine Tangente an die Schnittkurve. Vom ersten Punkt geht man dann um eine fest vorgegebene Schrittweite in Tangentenrichtung, um einen neuen Startpunkt für den Kurvenpunkt-Algorithmus zu erhalten. Der Kurvenpunkt-Algorithmus liefert den 2. Kurvenpunkt (s. Bild).
Zu Details des Verfolgungsalgorithmus: siehe[3].
Der Verfolgungsalgorithmus läuft immer entlang einer zusammenhängenden Schnittkurve. Falls mehrere Schnittkurven existieren, muss der Algorithmus mehrmals mit geeigneten Startpunkten durchlaufen werden. Der Algorithmus zeigt sich in der Praxis relativ robust. Selbst über einzelne Singularitäten läuft er ohne große Probleme, da es sehr unwahrscheinlich ist, dass man zufällig einen singulären Punkt erwischt (siehe Bild mit Zylinder und Fläche ).
- Schnittkurve der Fläche mit Zylinder: zweiteilig
- Schnittkurve der Fläche mit Zylinder: einteilig
- Schnittkurve der Fläche mit Zylinder: einteilig mit sing. Punkt
Anwendung: Umrisskurve
Ein Punkt des Umrisses einer impliziten Fläche mit der Gleichung muss bei einer Parallelprojektion in Richtung der Bedingung genügen. D. h. ein Umrisspunkt ist ein Punkt der Schnittkurve der beiden impliziten Flächen
- .
Bei Quadriken ist immer eine lineare Funktion und damit die Umrisskurve ein ebener Schnitt.
Der Umriss der Fläche (s. Bild) wurde mit dem Verfolgungsalgorithmus bestimmt und gezeichnet.
Bemerkung: Die Bestimmung eines Umrisspolygons einer parametrisierten Fläche erfordert ein Polygon auf einer impliziten Kurve in der Parameterebene zu bestimmen( siehe[4]) :
- Umrissbedingung: .
Schnittkurven zwischen Polyedern
Die Schnittkurve zwischen zwei Polyedern ist ein Polygon (s. Schnitt dreier Häuser). Da insbesondere parametrisierte Flächen oft durch 4-Eck-Netze dargestellt werden und die 4-Ecke in der Regel fast eben sind, ergibt sich die Schnittkurve als Schnittpolygon der einzelnen Facetten der Flächen. Einen geeigneten Algorithmus zur Bestimmung des Schnittpolygons zweier Polyeder findet man hier: [5].
Siehe auch
Einzelnachweise
- CDKG: Computerunterstützte Darstellende und Konstruktive Geometrie (TU Darmstadt) (PDF; 3,4 MB), S. 149
- CDKG: Computerunterstützte Darstellende und Konstruktive Geometrie (TU Darmstadt) (PDF; 3,4 MB), S. 87–124
- CDKG: Computerunterstützte Darstellende und Konstruktive Geometrie (TU Darmstadt) (PDF; 3,4 MB), S. 153, 158
- CDKG: Computerunterstützte Darstellende und Konstruktive Geometrie (TU Darmstadt) (PDF; 3,4 MB), S. 158
- CDKG: Computerunterstützte Darstellende und Konstruktive Geometrie (TU Darmstadt) (PDF; 3,4 MB), S. 179
Literatur
- C:L: Bajaj, C.M. Hoffmann, R.E. Lynch: Tracing surface intersections, Comp. Aided Geom. Design 5 (1988), S. 285–307.
- R.E. Barnhill, S.N. Kersey: AMarching method for parametric surface/surface intersection, Comp. Aided Geom. Design 7 (1990), S. 257–280.
- R. Barnhill, G. Farin, M. Jordan, B. Piper: Surface/Surface intersection, Computer Aided Geometric Design 4 (1987), S. 3–16.