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

komplexe Vektoren in Matrizen fügen und neu sortieren

 

SaraNadine
Forum-Newbie

Forum-Newbie


Beiträge: 8
Anmeldedatum: 18.11.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 18.11.2015, 12:11     Titel: komplexe Vektoren in Matrizen fügen und neu sortieren
  Antworten mit Zitat      
Hallo zusammen,

ich bin noch ein Matlab-Neuling und ich habe ein Problem, das ich nicht gelöst bekomme.

Also ich habe 2 Tabellen in Matlab die eine heißt "Versuchsplan" die andere "Ergebnisse". Die Tabelle Versuchsplan besteht aus 7 Spalten mit je 112.914 Zeilen. Da in der Tabelle nur reelle Werte stehen, macht die keine Probleme. Dazu muss ich sagen, dass jede Spalte in eine Variable gewandelt wird.

ABER in der Tabelle "Ergebnisse" stehen 11 Spalten mit ebenfalls 112.914 Zeilen. Aber in den Zellen dieser Tabelle stehen 4x3, 3x3 und 3x1 Matrizen.

Ich speichere die Spalten mit:
Code:
A=cell2mat(Tabellenname.Spaltenname(x,:);
 

Dabei schreibt Matlab die Matrizen in einer Spalte alle untereinander, sodass Variablen mit 451.656 Zeilen entstehen.

Ich muss aber die Variablen später durchsuchen können und dazu dann den passenden Eintrag in den anderen Variablen finden. Das geht ja nur, wenn die Zeilennummern gleich bleiben.

Deswegen habe ich mir überlegt, dass ich alle Werte der Matrizen in eine Zeile schreiben will. Dann haben wieder alle Variablen 112.914 Zeilen und ich kann es herrlich filtern und sortieren.
Dazu habe ich folgenden Code geschrieben, der auch funktionier aber EWIG brauch. Ich spreche hier von ~5Minuten pro Variabel und ich habe 8 davon... ´Vor allem bin ich mir gar nicht sicher ob Matlab rechnet oder sich aufgehangen hat.... ich hab extra ein "disp('fertig') ans Ende geschrieben, damit ich sehe wenn die Berechnung fertig ist. Das dauert alles zu lange.

Code:
for x=1:112914;
A=cell2mat(Tabellenname.Spaltenname(x,:);
A(1,2)=A(2,1); A(1,3)=A(3,1); A(3,:)=[]; A(2,:)=[];
if x==1;
Var1=A;
elseif x>1;
Var1=vertcat(Var1,A);
end
end


Vor allem habe ich auch die Warnung, dass Var1 die Größe ändert und eine Preallocating Zeit sparen würde.
Aber mit (Vor der for Schleife)
Code:
Var1=zeros(112914,3)

oder auch "cell" lässt sich das Problem nicht lösen. Die Warnung bleibt bestehen.

Jetzt habe ich gesehen, dass es die "reshape" Funktion gibt. Aber in allen Beispielen dazu werden die Werte in einer Spalte nach einer festgelegten Anzahl von Werten getrennt. Das geht ei mir nicht.

Ich brauche die Anweisung "lasse die Werte der ersten Zeile, wo sie sind, füge alle Werte der zweiten Zeile in eine neue Spalten am Ende der ersten Zeile ein und lösch die zweite Zeile, mache das gleiche mit der dritten Zeile; lasse dann die ursprünglich 4.Zeile (die durch das Löschen der 2. und 3. Zeile jetzt die 2. Zeile ist) unangetastet und verfahre mit den ursprünglichen Zeilen 5 und 6 wie mit den Zeilen 2 und 3. und so weiter bis man bei 112914 ankommt und das nach Möglichkeit in einer angemessenen Zeit.

Ach ja zu allem Überfluss sind die Werte in den Matrizen auch noch komplex.

Versteht mich jemand und kann mir auch noch helfen?
Private Nachricht senden Benutzer-Profile anzeigen


Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 19.11.2015, 16:53     Titel: Re: komplexe Vektoren in Matrizen fügen und neu sortieren
  Antworten mit Zitat      
Hallo SaraNadine,

Ein Minimal-Beispiel des Inhalts Deiner Tabelle würde helfen, das Problem zu verstehen und einen Vorschlag zur Lösung zu machen.

Zitat:
ABER in der Tabelle "Ergebnisse" stehen 11 Spalten mit ebenfalls 112.914 Zeilen. Aber in den Zellen dieser Tabelle stehen 4x3, 3x3 und 3x1 Matrizen.

Der Code sieht so aus, als würdest Du aber nur die erste Spalte dieser Matrizen berücksichtigen und sie als Zeile eintragen. Stimmt das?

Code:
Result = zeros(112914, 3);
for index = 1:112914;
  A = Tabellenname.Spaltenname{index,:};
  Result(index, :) = A(:, 1).';
end

Erzeugt dies das richtige Ergebnis?

Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
 
SaraNadine
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 8
Anmeldedatum: 18.11.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 23.11.2015, 09:58     Titel: komplexe Vektoren in Matrizen fügen und neu sortieren
  Antworten mit Zitat      
Das Beispiel war für die 3x1 Matrix. Deswegen ist da nur die erste Spalte berücksichtigt. In den anderen Matrizen beachte ich schon alle Spalten.

Ich habe das so wie ich es hatte mit "vertcat" durchlaufen lassen. Hat fast 2 Stunden gedauert. Aber ich habe mir einen Weg überlegt wie ich das nur ein Mal machen musste und dann habe ich das eben rechnen lassen und solange was anderes gemacht. Rolling Eyes Sicherlich nicht der klügste Weg, aber der für mich akzeptabelste.

Danke für deine Hilfe. Smile Smile Smile
Private Nachricht senden Benutzer-Profile anzeigen
 
Jan S
Moderator

Moderator


Beiträge: 11.057
Anmeldedatum: 08.07.10
Wohnort: Heidelberg
Version: 2009a, 2016b
     Beitrag Verfasst am: 23.11.2015, 12:50     Titel: Re: komplexe Vektoren in Matrizen fügen und neu sortieren
  Antworten mit Zitat      
Hallo SaraNadine,

Die Methode vergeudet Resourcen, und damit Energie und infolgedessen wird die Welt mit mehr CO2 verseucht als nötig. Think global, act local. :-)

Mit vertcat tritt das Problem auf, dass das Array in jeder Iteration vergrößert wird. Dafür wird ein neues Array im Speicher alloziert und die Werte des alten kopiert. Wenn man das für z.B. 1000 doubles macht, hat man zum Schluss nicht 1000*8B = 8kB alloziert, sondern sum(1:1000)*8b = 2MB . Bei 112.914 Zeilen geht es schon um Größenordnungen von 3.187 TerraByte mal die Anzahl der Bytes pro Zeile. Dass das Stunden dauert, ist nicht verwunderlich.

Es gibt aber eine triviale Abhilfe: Pre-Allocation. Man reserviert die benötigte Anzahl von Elemente vor der Schleife und kopiert die Variablen nur hinein, anstatt sie anzuhängen. Und schon läuft das eher in Sekundenbruchteilenm denn die Größenordnung 100'000 ist kein nennenswertes Problem für moderne Rechner.

Gruß, Jan
Private Nachricht senden Benutzer-Profile anzeigen
 
SaraNadine
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 8
Anmeldedatum: 18.11.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 23.11.2015, 12:57     Titel: komplexe Vektoren in Matrizen fügen und neu sortieren
  Antworten mit Zitat      
Danke für den tollen Tip... Confused

Wie ich zu allererst geschrieben habe, nimmt er die Preallocation dabei aber nicht an...

Vielen Dank für eure Hilfe. Das Thema ist für mich aber abgeschlossen. Es muss weiter gehen in meiner Arbeit. Wink
Private Nachricht senden Benutzer-Profile anzeigen
 
SaraNadine
Themenstarter

Forum-Newbie

Forum-Newbie


Beiträge: 8
Anmeldedatum: 18.11.15
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 02.12.2015, 14:49     Titel: Re: komplexe Vektoren in Matrizen fügen und neu sortieren
  Antworten mit Zitat      
Hallo,
falls noch mal jemand so ein Problem hat, ich habe eine Lösung gefunden, die in meinem Fall extrem viel Zeit gespart hat:

Code:

Matrix=zeros(188190,3)
for x=1:188190;
        A=cell2mat(Datenquelle(x,:));
        A(1,2)=A(2,1); A(1,3)=A(3,1) ;
        A(3,:)=[]; A(2,:)=[];
        Matrix(x,:)=A(1,:);
end
 


das erspart die komplette if-Schleife aus meinem ersten Text und geht super schnell. Very Happy
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.