|
|
Werte einer Liste durch deren Rang ersetzen |
|
StefanGast |
Gast
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 09:49
Titel: Werte einer Liste durch deren Rang ersetzen
|
 |
Hallo,
ich habe eine Excel-Liste in Matlab geladen, die im Prinzip etwa folgendermaßen aussieht:
2 12 3 51
33 45 1 7
Wahrscheinlich ist es für euch ein Klacks, aber ich kriege es nicht hin, den Zahlenwerten ihren relativen Rang zu den anderen Werten der jeweiligen Zeile zuzuordnen, der dann den absoluten Wert ersetzen soll. Das heißt, die neue Ordnung sollte so aussehen:
1 3 2 4
3 4 1 2
Könnt ihr mir helfen?
Schönen Gruß und danke im Voraus.
Ich sitze hier noch eine Weile und werde bei eine Antwort umgehen zurückposten.
Stefan
|
|
|
|
|
Schrank |

Forum-Century
|
 |
Beiträge: 203
|
 |
|
 |
Anmeldedatum: 10.07.08
|
 |
|
 |
Wohnort: Berlin
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:15
Titel:
|
 |
Hallo Stefan,
müsste das gewünschte liefern.
Gruß Schrank
|
|
|
nschlange |

Ehrenmitglied
|
 |
Beiträge: 1.320
|
 |
|
 |
Anmeldedatum: 06.09.07
|
 |
|
 |
Wohnort: NRW
|
 |
|
 |
Version: R2007b
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:20
Titel:
|
 |
Hi,
etwas an das Beispiel angepasst:
_________________
Viele Grüße
nschlange
"Chuck Norris ejakuliert fluessigen Stahl!"
|
|
|
Gast |
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:23
Titel:
|
 |
Hallo Schrank,
danke für die schnelle Antwort. Leider spuckt mir Matlab "Unexpected MATLAB expression" aus. Da das Problem nicht bei "sort" liegen kann, müsste es bei dem Ausdruck in der eckigen Klammer liegen, oder?
|
|
|
nschlange |

Ehrenmitglied
|
 |
Beiträge: 1.320
|
 |
|
 |
Anmeldedatum: 06.09.07
|
 |
|
 |
Wohnort: NRW
|
 |
|
 |
Version: R2007b
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:25
Titel:
|
 |
Hi,
dazwischen fehlt wohl ein =.
_________________
Viele Grüße
nschlange
"Chuck Norris ejakuliert fluessigen Stahl!"
|
|
|
steffi |

Forum-Century
|
 |
Beiträge: 149
|
 |
|
 |
Anmeldedatum: 07.03.08
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:26
Titel:
|
 |
Welche MATLAB Version hast du? Könnte auch an der Version liegen...
_________________
Wenn ich bei der Arbeit mit Computern eins gelernt habe dann das ich einem Computer nur soweit traue wie ich ihn werfen kann.
|
|
|
Gast |
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:31
Titel:
|
 |
Hallo,
es ist die Version 7.4.0. Mit dem Code von nschlange hat es aber funktioniert. Vielen Dank an alle!
Wenn ich den Code jetzt bei einer 60x40-Matrix als auch an einer weiteren 30x20-Matrix anwenden möchte, muss ich da etwas ändern?
|
|
|
nschlange |

Ehrenmitglied
|
 |
Beiträge: 1.320
|
 |
|
 |
Anmeldedatum: 06.09.07
|
 |
|
 |
Wohnort: NRW
|
 |
|
 |
Version: R2007b
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:34
Titel:
|
 |
Hi,
den Code kannst Du so übernehmen.
_________________
Viele Grüße
nschlange
"Chuck Norris ejakuliert fluessigen Stahl!"
|
|
|
Schrank |

Forum-Century
|
 |
Beiträge: 203
|
 |
|
 |
Anmeldedatum: 10.07.08
|
 |
|
 |
Wohnort: Berlin
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:39
Titel:
|
 |
Hallo,
irgendwie sollte ich mir abgewöhnen Code nach dem testen neu zu tippen... ich mach jedes mal nen Tippfehler rein.
Gruß Schrank
|
|
|
Gast |
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 10:39
Titel:
|
 |
Hallo nschlange,
leider scheint da etwas schief zu laufen. Ich habe die Matrix nur leicht verändert, aber die Rangfolge haut nicht mehr hin:
A = [2 1 3 4 6;
33 45 1 7 2;
5 4 3 2 1];
[B,IX]=sort(A');
IX'
ans =
2 1 3 4 5
3 5 4 1 2
5 4 3 2 1
In der zweiten Reihe stimmt etwas nicht. In meiner 40x60-Matrix sind auch viele Fehler aufgetaucht. Hast du eine Idee, woran das liegen könnte?
|
|
|
Gast |
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 11:02
Titel:
|
 |
Nach langem auf-die-Daten-Starren, habe ich endlich erkannt, dass der Befehl "sort" nicht die Ränge ausspuckt, sondern mir nur sagt, in welcher Reihenfolge er die Werte aus dem Array ziehen würde. Bei
2 1 3 4 5
3 5 4 1 2
5 4 3 2 1
hieße das in der zweiten Spalte, dass zunächst der dritte Wert, dann der fünfte usw. gezogen würde. Ich werde also das gewonnene Array nochmals verarbeiten müssen. Ich werde mich melden, falls ich etwas finden sollte. Ansonsten bin ich immer noch offen für Hilfe, falls jemandem etwas einfallen sollte.
|
|
|
Gast |
|
 |
Beiträge: ---
|
 |
|
 |
Anmeldedatum: ---
|
 |
|
 |
Wohnort: ---
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 11:32
Titel:
|
 |
HAllo,
die Lösung besteht einfach darin, die Werte im gewonnenen Array nochmals zu sortieren. Vielen Dank für eure Hilfe! Wäre sonst nicht so "schnell" zu einem Ergebnis gekommen!
Gruß
Stefan
|
|
|
nschlange |

Ehrenmitglied
|
 |
Beiträge: 1.320
|
 |
|
 |
Anmeldedatum: 06.09.07
|
 |
|
 |
Wohnort: NRW
|
 |
|
 |
Version: R2007b
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 11:47
Titel:
|
 |
Anonymous hat Folgendes geschrieben: |
Nach langem auf-die-Daten-Starren, habe ich endlich erkannt, dass der Befehl "sort" nicht die Ränge ausspuckt, sondern mir nur sagt, in welcher Reihenfolge er die Werte aus dem Array ziehen würde. Bei
2 1 3 4 5
3 5 4 1 2
5 4 3 2 1
hieße das in der zweiten Spalte, dass zunächst der dritte Wert, dann der fünfte usw. gezogen würde. Ich werde also das gewonnene Array nochmals verarbeiten müssen. Ich werde mich melden, falls ich etwas finden sollte. Ansonsten bin ich immer noch offen für Hilfe, falls jemandem etwas einfallen sollte. |
Hi,
war das nicht das, was Du mit 'relativem Rang' gemeint hast?
Ich raff' es gerade nicht. Kannst Du mir einem Beispiel auf die Sprünge helfen? Also eine Matrix, einmal das Ergebnis von sort und dann was Du möchtest?
_________________
Viele Grüße
nschlange
"Chuck Norris ejakuliert fluessigen Stahl!"
|
|
|
Schrank |

Forum-Century
|
 |
Beiträge: 203
|
 |
|
 |
Anmeldedatum: 10.07.08
|
 |
|
 |
Wohnort: Berlin
|
 |
|
 |
Version: ---
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 12:10
Titel:
|
 |
Boah, was nen Krampf
In Häßlichkeit kaum zu übertreffen, aber ich musste auch erstmal verstehen was falsch ist...
Oben wird der Rank ausgerechnet, unten zum Vergleich das Ergebnis mit sort.
Gruß Schrank
|
|
|
nschlange |

Ehrenmitglied
|
 |
Beiträge: 1.320
|
 |
|
 |
Anmeldedatum: 06.09.07
|
 |
|
 |
Wohnort: NRW
|
 |
|
 |
Version: R2007b
|
 |
|
|
 |
|
Verfasst am: 11.09.2008, 12:35
Titel:
|
 |
Ah, ok. Jetzt seh' auch ich den Unterschied.
Dann halt zweimal sortieren:
Dumm, dass das bei dem ersten Beispiel nicht aufgefallen ist...
Edit: Die Idee hatte Stefan ja schon...
_________________
Viele Grüße
nschlange
"Chuck Norris ejakuliert fluessigen Stahl!"
Zuletzt bearbeitet von nschlange am 11.09.2008, 12:42, insgesamt einmal bearbeitet
|
|
|
|
Gehe zu Seite 1, 2 Weiter
|
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.
|
|