![]() |
AW: 2D- in 3D-Koordinate umrechnen
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:
|
AW: 2D- in 3D-Koordinate umrechnen
Zitat:
Mit der Unit geht vieles einfacher und sie ist wirklich sehr gut und übersichtlich geschrieben und nimmt mir ne menge Arbeit ab, Respekt! :thumb: Zitat:
Vielen Dank schon mal, warst jetzt schon sehr hilfsbereit :) Freundliche Grüsse |
AW: 2D- in 3D-Koordinate umrechnen
Guck Dir auch die Unit Vectorgeometry.pas im GLScene-Projekt an. Da könnte einiges drin sein, was Dich weiter bringt.
|
AW: 2D- in 3D-Koordinate umrechnen
Zitat:
Ergebnis ist der Vektor X, der zum ursprünglichen Punkt x passt. x könnte bspw. der Punkt sein, wo der User hingeklickt hat, dann ist X der entsprechende 3D-Punkt. Zitat:
|
AW: 2D- in 3D-Koordinate umrechnen
Liste der Anhänge anzeigen (Anzahl: 1)
Hey,
Habe nun das Wochenende versucht mich ein wenig in das Thema hineinzulesen und bin nun halbwegs drinnen. Die erste Formel kriege ich nun sicher ohne Probleme hin, jedoch habe ich immer noch ein kleines Verständnisproblem bei der 2. :/ (Ich habe sie nochmals angehängt damit klar ist welche gemeint ist^^) Wieso genau steht dort 2 mal X=...? Klar, den Punkt könnte man ja auf verschiedene Arten berechnen jedoch komme ich bei A + u * B1 + u * B2 nicht auf ein mögliches Resultat und bei der unteren X Gleichung müsste ich ja einen 3D Vektor mit einem 2D Vektor (u,v ?) Multiplizieren oder nicht? Wie man vielleicht erkennen kann, ich tappe wieder im dunkeln und je mehr ich drüber nachdenke desto mehr unklarheiten enstehen :shock::pale: Ich glaube mein grösstes Problem sind eher die ganzen Gleichungen mit ihren Elementen und "Ausführungen", habe ich schön öfters bemerkt wenn man mal was auf Wikipedia o.ä. sucht :D Wäre wirklich dankbar für nochmalige hilfe, denn ich verdreh mir gleich alles im kopf und kapiere gar nichts mehr :stupid: Freundliche Grüsse |
AW: 2D- in 3D-Koordinate umrechnen
Liste der Anhänge anzeigen (Anzahl: 1)
Also das Bild hat ja drei Zeilen. die erste ist eine Definition. Die Basusvektoren B1 und B2 habe ich so definiert und die musstdu so ausrechnen.
Dann habe ich die zweite Gleichung aufgeschrieben (zweite Zeile) und vereinfacht/umgeformt (dritte Zeile). Das heißt, du brauchst nur eine davon. Welche dir liber ist. Die erste Form: \vec{X} = \vec{A} + u \vec{B_1} + v \vec{B_2} hier weißt du ja u und v aus der vorherigen Rechnung, Ich hoffe, für u und v gelten folgende Ungleichungen: u und v beide je zwischen 0 und 1, sowie u+v kleiner gleich 1. (Nur dann ist der Pukt nämlich im Dreieck!) Dann rechnest du für jede der drei Komponenten von X die Gleichung aus, also X_x = A_x + u * (B_x - A_x) + v * (C_x - A_x) Hier habe ich die Definition für B_1 und B_2 direkt eingesetzt, da sind also nur noch die x-Komponenten der 3D-Punkte drin und u, v. Für die anderen beiden Komponenten von X brauchst du das analog. (also _y und _z) Die zweite Form (dritte Zeile) macht daraus eine Matrixmultiplikation. Wenn du eine Bibliothek dafür hast, macht es das vll. einfacher. Die Matrix setzt sich einfach aus den beiden Basisvektoren zusammen. Ich habe das mal in Excel gemacht: Anhang 45312 Die Matrix habe ich mal fett umrahmt, das Ergebnis der Matrixmultiplikation ist grün und das Endergebnis (das große X) ist die Addition von dem grünen und A und steht oben rechts. Zu dem was du schon hast: Zitat:
Zitat:
Oder du "behältst" die Vektoren B_1 und B_2, dann steht da aber nur (Überraschung ^^) B_1*u + B_2 * v -- wie in der ersten Gleichung. |
AW: 2D- in 3D-Koordinate umrechnen
Danke, hab mir das zum Teil schon gedacht aber nun ist es mir Klar, hab nicht gedacht das man selbst eine 3x2 mit einer 2x1 Matrix multiplizieren kann, ist ja aber ganz logisch und es klappt wunderbar :D
Der Fehler tritt bei mir tatsächlich in der ersten Formel auf wo ich es mit der Matrixinversion probiere soll denn wenn ich die 2. Formel mit korrekten "Labordaten" (z.b die aus der excel tabelle) füttere erhalte ich korrekte Daten wie bei dir auch. Momentan mache ich das so um u und v auszurechnen das ich eine ![]()
Delphi-Quellcode:
Also eigentlich ne 3x3 Matrix weil das bei TMatrix der standard ist, die restlichen Felder habe ich als 0 deklariert. Danach habe ich die inversion (heisst das so?) Berechnet und den determinanten davon mit (xy - a) multipliziert, also genau so in pseudo code:
M=
[b_1_1, b_2_1, 0, b_1_2, b_2_2, 0, 0 , 0 , 0
Code:
Ich bin hier wieder fleissig am lesen und versuche das Thema zu verstehen und glaube gerade das ich mich mit dem determinanten vertan hab und glaube eher das ich die inversierte matrix mit dem vektor multiplizieren muss oder irre ich mich da wieder komplett? Wie sehe ich was eine Blockmatrix und was eine ganz normale Klammer ist? Wie gesagt hab die letzten tage vieles durch "try n' error" versucht und weiss mittlerweile gar nicht mehr wirklich was ging und was kläglich scheiterte :oops:
determinant(inversion(M)) * (xy - a)
Ich versuchs erstmal weiter, vielen vielen herzlichen dank für deine grossartige unterstützung, kann mir vorstellen wie mühesam es ist sowas mir beibzubringen :stupid::lol: trotzdem schön zu sehen das es Leute gibt die es versuchen :) Freundliche Grüsse |
AW: 2D- in 3D-Koordinate umrechnen
Ah ja da ist ja der Fehler :wink:
Ich habe zwar oben von "mit Nullen auffüllen" geschrieben, aber das war nicht ganz richtig - wie mir gerade aufgefallen ist. Das Element unten rechts müsste dennoch 1 sein. (Stell dir eine Einheitsmatrix vor, in die man die kleinere Matrix hineinkopiert) Zitat:
Zitat:
Du braucht die Determinante nicht, wenn du direkt die Inverse berechnest. (Du brauchst sie eventuell zur Berechnung der Inversen) Ich habe mal deine Punkte von oben durchgerechnet mit Zwischenergebnissen. Vielleicht wird dann klarer, wie die Formeln in Code aussehen. Grundlegendes zuer MATLAB-Syntax: Semikolon (;) macht eine neue Zeile, vertcat verkettet vertikal, horzcat horizontal. [1; 0; 0] ist also ein Spaltenvektor und gleichbedeutend mit vertcat(1, 0, 0)
Code:
Falls du mit 3x3 Matrizen rechnen musst, geht der letzte Teil so:
A = [20; 100; 0]
B = [20; 100; 20] C = [0; 100; 20] a = [0; 100] b = [50; 0] c = [100; 200] x = 50; y = 90; %% Ab hier sind Eingaben mit >> am Angang, der Rest ist das Ergebnis der vorigen Eingabe >> xy = vertcat(x, y) % Untereinander schreiben xy = 50 90 >> Basis2D = horzcat(b-a, c-a) % Nebeneinander schreiben Basis2D = 50 100 -100 100 >> inv(Basis2D) % Inverse ans = 0.0066667 -0.0066667 0.0066667 0.0033333 >> uv = inv(Basis2D) * ( xy - a ) uv = 0.4 0.3 >> Basis3D = horzcat(B-A, C-A) Basis3D = 0 -20 0 0 20 20 >> X = A + Basis3D * uv X = 14 100 14
Code:
>> xy = vertcat(x, y) % Untereinander schreiben
xy = 50 90 >> Basis2D = horzcat(b-a, c-a) % Nebeneinander schreiben Basis2D = 50 100 -100 100 >> Basis2D(3, 3) = 1 % Erweitern Basis2D = 50 100 0 -100 100 0 0 0 1 >> inv(Basis2D) % Inverse ans = 0.0066667 -0.0066667 0 0.0066667 0.0033333 0 0 0 1 >> uv = inv(Basis2D) * vertcat( xy - a, 0 ) uv = 0.4 0.3 0 >> Basis3D = horzcat(B-A, C-A, [0; 0; 0]) Basis3D = 0 -20 0 0 0 0 20 20 0 >> X = A + Basis3D * uv X = 14 100 14 |
AW: 2D- in 3D-Koordinate umrechnen
Unglaublich!
Vielen vielen vielen dank hab's endlich geschafft! Woooow, das war wohl das ekligste im Mathematik Bereich was ich bisher gemacht habe jedoch bin ich froh das du mir so gut unter die Arme gegriffen hast, hab es nun endlich verstanden das ich Vektoren und Skalare eigentlich als Matrizen betrachten und das man das so einfach untereinander oder nebeneinander schreiben kann. Ich hoffe deine Beiträge hier werden auch in Zukunft anderen helfen, so wie du das alles 10 mal verinfacht für mich erklären musstest wird bestimmt jeder Depp das verstehen :lol: Zitat:
Aber das meinst du doch nicht oder? xD Freundliche Grüsse und danke nochmal, bist ein Schatz :love: |
AW: 2D- in 3D-Koordinate umrechnen
Zitat:
Zitat:
Der Spruch "Die Determinante der Inversen ist gleich dem inversen der Determinante." klingt vielleicht erst mal verwirrend. Aber damit ist nur gemeint:
Code:
Die Determinante ist ja ein Skalar, und das inverse eines Skalars nennt man auch Kehrwert. EInsteigerfrundlicher könnte man also sagen:
M =
50 100 -100 100 >> det(M) ans = 15000 >> det(inv(M)) ans = 6.6667e-05 >> 1/ans ans = 15000 Zitat:
Wenn die Determinante gleich 0 ist, müsstest du beim invertieren der Matrix irgendwann durch 0 teilen. Eine solche Matrix ist nicht invertierbar. Das passiert beispielsweise, wenn man eine komplette Zeile mit Nullen füllt. ;-) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:35 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz