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 in verschiedene Vektoren aufteilen

 

code88
Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 91
Anmeldedatum: 06.02.08
Wohnort: Meinisberg
Version: MATLAB Version 7.8.0.347 (R2009a)
     Beitrag Verfasst am: 14.12.2010, 19:37     Titel: Vektor in verschiedene Vektoren aufteilen
  Antworten mit Zitat      
Ich habe ein Vektor, der Winkelwerte enthält:

Code:
v=(1,2,3,4,90,94,95,99,100,180,200,250,270,300,333,350,360,361)


Nun möchte ich den Vektor so aufteilen, dass ich alle 90° in eine andere Spalte aufteile und dann nach 360° wieder bei der ersten beginne. Oder einfach 4mal 90° in eine andere Spalte und dann bei der ersten wieder beginnen.

Mit
Code:
Ende=max(v)

Ende=Ende/90

for i=1:Ende
Suche(i)=1;
Suche(i+1)=find(v>=90*i,1);

end

finde ich die Positionen im Vektor, die ich aufteilen möchte.
Nun kann ich mit

Code:
for i=1:size(Suche,2)-1

ZSpeicher=[];

ZSpeicher=v(Suche(i):Suche(i+1));
end
 

die Werte für den ersten Spaltenvektor herausnehmen.
Nun müsste ich ja das ganze 4 mal in einen anderen Spaltenvektor machen z.B. Ergebnis(1,1), Ergebnis(1,2), Ergebnis(1,3) Ergebnis(1,4) und dann wieder bei Ergebnis(1,1) beginnen, ohne natürlich die bereits vorhandenen Daten zu überschreiben.
Wie ist das machbar?
Private Nachricht senden Benutzer-Profile anzeigen


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.501
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 14.12.2010, 21:40     Titel:
  Antworten mit Zitat      
Hallo,

mir ist der Ansatz nicht ganz klar. Wenn die Daten jeweils in Spalten geschrieben werden sollen, gibt es Probleme, falls es in den einzelnen Bereichen unterschiedlich viele Werte gibt.
Ich würde es so angehen:
Code:
gruppe = ceil( mod(v, 360) / 90);


Damit ist zu jedem Element bekannt, zu welcher Gruppe es gehört; z.B.
Code:
gruppe1 = v(gruppe == 1);


Grüße,
Harald
Private Nachricht senden Benutzer-Profile anzeigen
 
code88
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 91
Anmeldedatum: 06.02.08
Wohnort: Meinisberg
Version: MATLAB Version 7.8.0.347 (R2009a)
     Beitrag Verfasst am: 14.12.2010, 21:59     Titel:
  Antworten mit Zitat      
Das ist natürlich richtig. Bei unterschiedlichen Anzahl Werten kann es zu einem Konflikt kommen. Nur ich möchte ja nach 4 Gruppen keine weitere erstellen sondern die Werte den 4 Gruppen anfügen.

Also
Gruppe 1 0°-90°
Gruppe 2 90°-180°
Gruppe 3 180°-270°
Gruppe 4 270°-360°

dann in
Gruppe 1 360°-450° anfügen
Gruppe 2 450°-540° anfügen etc.

Also wären dann in Gruppe 1 0°-90° und 360°-450° etc.
und in Gruppe 2 90°-180° und 450°-540° etc.
Private Nachricht senden Benutzer-Profile anzeigen
 
Sco
Forum-Meister

Forum-Meister


Beiträge: 699
Anmeldedatum: 15.08.10
Wohnort: Dundee
Version: 2008a, 2010a
     Beitrag Verfasst am: 15.12.2010, 01:45     Titel:
  Antworten mit Zitat      
Hallo,

deine Gruppierung ist ein wenig komisch, da die Winkel 90,180,360... in mehreren Gruppen vorkommen sollen und damit redundant sind. Ist dies wirklich so gewünscht?

Ansonsten habe ich ein ein Beispiel erstellt, welches die Winkel folgendermassen gruppiert:

G1: 0-89 ; 360-449
G2: 90-179; 450-539
G3: 180-269; 540-629
G4: 270:359 ; 630-719

usw.

Ich habe wirklich eine Weile dran getüftelt, bin mit dem Ergebnis jedoch nicht wirklich zufrieden und hoffe auf diesen Weg, dass dir noch jemand einem besseren Vorschlag macht. Jedoch poste ich den Code trotzdem, da eine Lösung nunmal besser ist als nix:
Code:

v = [1,2,90,94,95,99,100,180,200,250,269,270,300,333,350,360,361,380,450,500,555,900,901,988,1070];
v = sort(v); % in case angles are not in order
m = max(v);
if m < 360
   m = 270;
end

dif = histc(v,0:90:m+90);
idx = cumsum(dif);
offset = 3;
v_new(1:dif(1),1) = v(1,1:dif(1));

for k = 1:size(idx,2)-1
    if k > 3
        if ~isempty(k(~rem(k,4))) && k~=4
            offset = offset+4;
        end
        temp = nnz(v_new(:,k-offset));
        v_new(temp+1:temp+dif(k+1),k-offset) = v(1,(idx(k)+1):(idx(k+1)));
    else
        v_new(1:dif(k+1),k+1) = v(1,(idx(k)+1):(idx(k+1)));
    end
end
 


P.S. Ich habe die ganze Sache als Array und nicht als Cell gelöst, so dass kürzere Spalten automatisch mit Nullen befüllt werden. Also muesstest du die angehängten Nullen ignorieren oder dir den Code als Cell umbasteln.

Edit: sehe gerade die Lösung von Harald (hab die wohl echt übersehen). Ja so einfach kann es natürlich auch gelöst werden und ich sitz hier seit ... naja wie auch immer.

MFG

Sco
Private Nachricht senden Benutzer-Profile anzeigen
 
code88
Themenstarter

Forum-Fortgeschrittener

Forum-Fortgeschrittener


Beiträge: 91
Anmeldedatum: 06.02.08
Wohnort: Meinisberg
Version: MATLAB Version 7.8.0.347 (R2009a)
     Beitrag Verfasst am: 15.12.2010, 09:59     Titel:
  Antworten mit Zitat      
Vielen Dank für den grossen Einsatz.
Jetzt habe ich es ausprobiert.

Code:
gruppe = ceil( mod(v, 360) / 90);



Winkelgruppe1 = v(gruppe == 1);
Winkelgruppe2 = v(gruppe == 2);
Winkelgruppe3 = v(gruppe == 3);
Winkelgruppe4 = v(gruppe == 4);

So scheint es wirklich zu funktionieren.
Super!
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 - 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.