|
|
spaltenweises Min bzgl der euklidischen Norm 2er Matrizen |
|
nullteilerin |
Gast
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.11.2012, 15:14
Titel: spaltenweises Min bzgl der euklidischen Norm 2er Matrizen
|
 |
Hallo Matlab-Freunde!
Angenommen, ich habe zwei Matrizen A,B gegeben, welche gemeinsame Zeilenanzahl, aber nicht zwangsläufig gleiche Spaltenanzahl haben.
Ich möchte nun das Minimum der euklidischen Norm von jeweils A(:,i)-B(:,j), für alle j, bekommen, dabei interessiert mich weniger der Wert des Minimums, als viel mehr der jeweilige Index der zwei Spalten, die dieses Minimum erzeugen.
matlab bietet die function min an, die mir mit [C,I]= min(...) auch mit I die Indizes der einzelnen Minimas geben soll. Nur scheint der mir dann auch nur einen Index anzugeben.
Wie kann man die verschiedenen Spaltenvektoren kombinieren?
Danke für eure Vorschläge.
|
|
|
|
|
Harald |

Forum-Meister
|
 |
Beiträge: 24.501
|
 |
|
 |
Anmeldedatum: 26.03.09
|
 |
|
 |
Wohnort: Nähe München
|
 |
|
 |
Version: ab 2017b
|
 |
|
|
 |
|
Verfasst am: 11.11.2012, 18:14
Titel:
|
 |
Hallo,
ich habe noch nicht ganz verstanden, worum es geht.
Willst du zu jeder Spalte der zweiten Matrix herausfinden, welche Spalte in der ersten Matrix ihr am nächsten kommt? Oder willst du herausfinden, welche Spalten der beiden Matrizen sich am ähnlichsten sind?
Grüße,
Harald
|
|
|
nullteilerin |
Gast
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 12.11.2012, 17:18
Titel: .
|
 |
Hallo Harald,
die Spalten der ersten Matrix A fungieren als Cluster-Mittelpunkte. Nun bekomme ich mehrere Vektoren in Form von Spalten einer Matrix B und möchte diese in die Cluster einsortieren.
Ddafür muss ich für jeden Vektor in A (also jede Spalte), den euklidischen Abstand zwischen diesem Vektor und der Spalte in B testen. Der minimale Abstand bestimmt dabei das zugehörige Cluster.
Ich möchte am Ende nur einen neuen Vektor der mir in jedem Index i zeigt, wie oft in B ein Vektor auftaucht, der zum Cluster i-te Spalte von A auftaucht.
zb.
A = 1 2
3 4
B = 3 2 1
1 2 2
Ausgabe: v = 1 1 1
Also alle Spalten von B haben die kleinste euklidische Distanz zu erster Spalte von A
Wie kann ich das effizient schreiben, ohne dass es bei großen Matrizen rechnerisch explodiert?
|
|
|
Harald |

Forum-Meister
|
 |
Beiträge: 24.501
|
 |
|
 |
Anmeldedatum: 26.03.09
|
 |
|
 |
Wohnort: Nähe München
|
 |
|
 |
Version: ab 2017b
|
 |
|
|
 |
|
Verfasst am: 12.11.2012, 17:29
Titel:
|
 |
Hallo,
eine Möglichkeit wäre, sich vorhandene Funktionalität zum Clustering in der Statistics Toolbox anzusehen (z.B. eine Iteration von KMEANS).
Ansonsten würde ich das mit bsxfun (für die Ermittlung der Differenz) händisch programmieren.
Grüße,
Harald
|
|
|
|
|
Einstellungen und Berechtigungen
|
|
Du kannst Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen. Du kannst Dateien in diesem Forum posten Du kannst Dateien in diesem Forum herunterladen
|
|
Impressum
| Nutzungsbedingungen
| Datenschutz
| FAQ
| RSS
Hosted by:
Copyright © 2007 - 2025
goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks
MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.
|
|