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

parfor, funktoren und Daten aus den Threads zurückschreiben

 

SimulantX

Gast


Beiträge: ---
Anmeldedatum: ---
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 19.02.2016, 16:43     Titel: parfor, funktoren und Daten aus den Threads zurückschreiben
  Antworten mit Zitat      
Hallo,

ich versuche meine Simulation für Parameter-Sweeps per "parfor" auf den Pool zu verteilen, was eigentlich auch gut funktioniert. Leider wollte ich dem parfor jetzt eine Vorbereitungs-Funktion und einen "collector" mitgeben, welcher die Ergebnisse weiterverwertet, filtert und schließlich abspeichert. Leider funktioniert es überhaupt nicht gut, wenn Matlab nicht sieht was dort geschieht.

Hier die einfache Sweep-Methode meiner Klasse:
Code:

        function run_sim_sweep( self, duration, omega_path, torque_path, prepare_func, collector, start_i, end_i )
               
            collector_slices = collector.make_slices( end_i - start_i + 1 );
           
            parfor i = start_i : end_i
                feval( prepare_func, self, i );
                local_result = self.run_sim( duration, omega_path, torque_path );
                collector_slices{i}.collect( self, i, local_result );
                collector_slices{i}.hack2 = i;
            end
           
            collector.fold_slices( collector_slices );
           
        end
 


Da Debugging mit parfor unmöglich ist, diese Hack-writes. Weil das mit dem einfachen "collector"-Objekt nicht funktioniert, zerlegt der sich nun vor dem Durchlauf in ein Feld von "slices", welche die Einzelergebnisse abspeichern und dann hinterher wieder zusammengesetzt werden.
Nun bekomme ich aber nur Grütze zurück. Das gesamte collector_slices-Array hat anschließen "hack2 = 1" und die collect-Methode speichert das übergebene i auch nochmal in einem "hack"-Feld, welches für alle Elemente nach dem parfor "hack=2" lautet.
Nun hab ich keinen Plan, was Matlab da treibt und kann nicht abschätzen, inwiefern bzw. wann mir da das vertiefte Studium der Dokumentation hilft.
Erkennt jemand auf einen Blick, warum das nicht funktionieren kann?


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.492
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 22.02.2016, 20:34     Titel:
  Antworten mit Zitat      
Hallo,

es ist schwierig zu durchblicken, was dein Code machen soll.

Ausgehend von einer for-Schleife sind in der Regel nur wenige Schritte zur Parallelisierung nötig.
Vielleicht helfen diese Videos weiter, insbesondere Teil 4
http://www.mathworks.com/videos/ser.....ting-tutorials-97719.html

Grüße,
Harald
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.