WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Vektor-Indizierung

 

Alpha23
Forum-Anfänger

Forum-Anfänger


Beiträge: 35
Anmeldedatum: 11.09.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 08.04.2009, 11:16     Titel: Vektor-Indizierung
  Antworten mit Zitat      
Hallo!

Ich möchte aus einem Vektor, der viele gleiche Werte hat, die alle nacheinander stehen einen Index herausziehen. In dem soll Anfangs- und Endzeile von jedem einzelnen Wert stehen. Die aufeinanderfolgenden Werte sollen auch ausgegeben werden.
Bsp.:

Code:
>> A=[1,1,1,1,1,2,2,1,1,5,5,5,5,3,3,2];
>> INDEX(A)
ans =

    1 2 1  5  3  2
    1 6 8 10 14 16
    5 7 9 13 15 16
 


Momentan mache ich das umständlich über eine Schleife, aber das geht doch sicherlich auch schneller oder? INDEX sollte im Endeffekt auch cell arrays erkennen (z.B. für die Indizierung einer Excel-Matrix, die aus einer Pivot-Tabelle herauskopiert wurde).
Danke für eure Vorschläge!

Gruß Timo
Private Nachricht senden Benutzer-Profile anzeigen


derOli
Forum-Meister

Forum-Meister


Beiträge: 579
Anmeldedatum: 19.03.08
Wohnort: Leipzig
Version: 2010a
     Beitrag Verfasst am: 08.04.2009, 11:37     Titel:
  Antworten mit Zitat      
Hi,

musste ziemlich tricksen aber so geht es. Verbesserungsvorschläge sind erwünscht:

Code:

A=[1,1,1,1,1,2,2,1,1,5,5,5,5,3,3,2];
A(end+1)=A(end)+1;

d=find(diff(A)~=0)
Out(3,1:length(d))=d;
Out(1,:)=A(d);
e=d+1;
Out(2,1)=1;
Out(2,2:end)=e(1:end-1)


A(end)=[];

clear e d
 
Private Nachricht senden Benutzer-Profile anzeigen
 
Alpha23
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 35
Anmeldedatum: 11.09.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 08.04.2009, 12:01     Titel:
  Antworten mit Zitat      
Hi!

Super, vielen Dank für die schnelle Antwort! Very Happy Very Happy Very Happy
Bei cell arrays wird das Ganze dann aber schon komplizierter, da geht's wahrscheinlich wieder nur über Schleife...
So ungefähr sollte das aussehen:

Code:
>> A=[ {'1'},{'1'},{'1'},{'1'},{'1'},{'e'},{'e'},{'pht'},{'pht'},{'5'},{'5'},{'5'},{'5'},{'xy'},{'xy'},{'2'}] ;
>> INDEX(A)
ans =

    [1] 'e' 'pht' [5] 'xy' [2]

ans =
    1 6 8 10 14 16
    5 7 9 13 15 16


A sieht wegen xlsread und Nachbearbeitung so aus. Das mit den zwei Ausgaben geht ja dann über nargout und nem if-case.

Danke schonmal im Voraus! Smile

Gruß Timo
Private Nachricht senden Benutzer-Profile anzeigen
 
spawnferkel
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 53
Anmeldedatum: 11.03.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 08.04.2009, 12:18     Titel:
  Antworten mit Zitat      
Kommt es auf Sortierung an?
Guck dir mal den Befehl
Code:
an.
Private Nachricht senden Benutzer-Profile anzeigen
 
derOli
Forum-Meister

Forum-Meister


Beiträge: 579
Anmeldedatum: 19.03.08
Wohnort: Leipzig
Version: 2010a
     Beitrag Verfasst am: 08.04.2009, 12:22     Titel:
  Antworten mit Zitat      
Ja tut mir Leid, da weiß ich jetzt auch erstmal keine bessere Lösung für cell arrays.

Grüße,

der Oli
Private Nachricht senden Benutzer-Profile anzeigen
 
Alpha23
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 35
Anmeldedatum: 11.09.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 08.04.2009, 12:40     Titel:
  Antworten mit Zitat      
derOli hat Folgendes geschrieben:
Ja tut mir Leid, da weiß ich jetzt auch erstmal keine bessere Lösung für cell arrays.

Grüße,

der Oli


Alles klar, kein Problem. Für den Fall kann ich ja auf meine Schleifenstruktur zurückgreifen. Danke nochmal für die obige Lösung! Smile
Private Nachricht senden Benutzer-Profile anzeigen
 
Alpha23
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 35
Anmeldedatum: 11.09.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 08.04.2009, 12:43     Titel:
  Antworten mit Zitat      
spawnferkel hat Folgendes geschrieben:
Kommt es auf Sortierung an?
Guck dir mal den Befehl
Code:
an.


unique gibt nur die verschiedenen Einträge zurück, lässt aber Dopplungen weg.
z.B.
Code:
unique([1,1,1,2,2,2,1,1])
ans =
         1 2

 

Schau dir mal das allererste Beispiel genauer an, dann siehst du, warum's damit nicht geht.
Aber obiger Vorschlag funzt einwandfrei - hatte nicht an den diff-Befehl gedacht.
Private Nachricht senden Benutzer-Profile anzeigen
 
spawnferkel
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 53
Anmeldedatum: 11.03.09
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 08.04.2009, 12:48     Titel:
  Antworten mit Zitat      
Alpha23 hat Folgendes geschrieben:

Schau dir mal das allererste Beispiel genauer an, dann siehst du, warum's damit nicht geht.


Schau dir mal mehr als nur das allererste Beispiel an, dann siehst du, dass man es doch benutzen kann.
Private Nachricht senden Benutzer-Profile anzeigen
 
Alpha23
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 35
Anmeldedatum: 11.09.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 08.04.2009, 14:06     Titel:
  Antworten mit Zitat      
spawnferkel hat Folgendes geschrieben:
Alpha23 hat Folgendes geschrieben:

Schau dir mal das allererste Beispiel genauer an, dann siehst du, warum's damit nicht geht.


Schau dir mal mehr als nur das allererste Beispiel an, dann siehst du, dass man es doch benutzen kann.


Wenn du schon gackerst, solltest du auch ein Ei legen...
Private Nachricht senden Benutzer-Profile anzeigen
 
derOli
Forum-Meister

Forum-Meister


Beiträge: 579
Anmeldedatum: 19.03.08
Wohnort: Leipzig
Version: 2010a
     Beitrag Verfasst am: 08.04.2009, 14:48     Titel:
  Antworten mit Zitat      
Stimmt, mit unique gehts:

Code:

A = [ {'1'},{'1'},{'1'},{'1'},{'e'},{'e'},{'pht'},{'pht'},{'5'},{'5'},{'5'},{'5'},{'1'},{'xy'},{'xy'},{'2'}]

% 1 e pht 5 1 xy
% 1 5 7  9  13 14
% 4 6 8  12 13 15
[a,b,c]=unique(A)

A=c;
A(end+1)=A(end)+1;

d=find(diff(A)~=0)
Out(3,1:length(d))=d;
Out(1,:)=A(d);
e=d+1;
Out(2,1)=1;
Out(2,2:end)=e(1:end-1)

A(end)=[];

firstrow=a(Out(1,:))

 


Ist jetzt ein perfektes Beispiel für schlechtes, auf anderen Code aufbauendes Programmieren. Also bitte nochmal durchgucken und einen Code zusammenpacken, der für diese Aufgabe gemacht ist und auch wie der code oben funktioniert.

Viele Grüße,

der Oli
Private Nachricht senden Benutzer-Profile anzeigen
 
Alpha23
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 35
Anmeldedatum: 11.09.08
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 09.04.2009, 15:45     Titel:
  Antworten mit Zitat      
Shocked Jetzt wo du's schreibst... Wink

Ich hatte das vorher abgehakt, weil ich wieder den diff-Befehl vergessen hatte. Aber logisch, dass man's so machen kann!
Zusammengefasst und verschönert könnte das Ganze dann auch so aussehen:

Code:
A = [ {'1'},{'1'},{'1'},{'1'},{'e'},{'e'},{'pht'},{'pht'},{'5'},{'5'},{'5'},{'5'},{'1'},{'xy'},{'xy'},{'2'}];

[a,b,c]=unique(A);

IND(2,:)=find(diff([c,c(end)+1]));
IND(1,:)=[1,IND(2,1:end-1)+1];

DAT=A(IND(1,:));


Die erste Zeile von Out braucht man in dem Fall nicht mehr, da ist es sinnvoller, eine zweite Variable anzulegen würde ich sagen. Praktisch: Input kann jetzt Vektor oder Cell array sein, das macht keinen Unterschied mehr! Smile
Danke nochmal und schöne Ostern! Smile
Private Nachricht senden Benutzer-Profile anzeigen
 
derOli
Forum-Meister

Forum-Meister


Beiträge: 579
Anmeldedatum: 19.03.08
Wohnort: Leipzig
Version: 2010a
     Beitrag Verfasst am: 09.04.2009, 17:02     Titel:
  Antworten mit Zitat      
Jup sehr schön,

sieht gut aus. Das nenne ich mal gemeinschaftliches Programmieren.

Very Happy

Grüße,

der Oli
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

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 | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2024 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.