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

nested for-Schleife vektorisieren

 

Lloyd Blankfein
Forum-Century

Forum-Century



Beiträge: 149
Anmeldedatum: 23.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 26.04.2012, 18:05     Titel: nested for-Schleife vektorisieren
  Antworten mit Zitat      
Hallo,

ich habe ein Performanceproblem welches ich mit dem Profiler lokalisiert habe.

Code:

            for j=1:size(obj.mAVG_Indicator,1)
               if obj.mAVG_Indicator(j,1)==0
                   x=libpointer('doublePtr',obj.Performance(:,obj.mAVG_Indicator(j,2)));
               else
                   x=libpointer('doublePtr',obj.ts(:,obj.mAVG_Indicator(j,2)));
               end
               obj.mAVG=[obj.mAVG,zeros(size(x.value,1),1)];%Expand the matrix
               for i=1:size(x.value,1)-obj.mAVG_Indicator(j,3)+1-TSDelay(j)
                    for k=1:obj.mAVG_Indicator(j,3)
                        obj.mAVG(i,j+1)=obj.mAVG(i,j+1)+x.value(i+k-1);
                    end
               end
               obj.mAVG(:,j+1)=obj.mAVG(:,j+1)/obj.mAVG_Indicator(j,3);
               for i=i+1:size(x.value,1)
                   obj.mAVG(i,j+1)=NaN;
               end
            end
 


Ich möchte obige for-Schleifen (i- und k-Iterationen) vektorisieren. Kann man nested fors vektorisieren?
Wie würde das aussehen?

Vielen Dank für eure Hilfe,
Lloyd
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: 26.04.2012, 20:21     Titel: Re: nested for-Schleife vektorisieren
  Antworten mit Zitat      
Hallo Lloyd Blankfein,

Code:

               for i=1:size(x.value,1)-obj.mAVG_Indicator(j,3)+1-TSDelay(j)
                    for k=1:obj.mAVG_Indicator(j,3)
                        obj.mAVG(i,j+1)=obj.mAVG(i,j+1)+x.value(i+k-1);
                    end
               end
 

Hier wird "obj.mAVG(i,j+1)" "obj.mAVG_Indicator(j,3)" mal überschrieben. Ist das sinnvoll?

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

Forum-Century

Forum-Century



Beiträge: 149
Anmeldedatum: 23.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 28.04.2012, 16:00     Titel:
  Antworten mit Zitat      
Hallo Jan,

danke für den Hinweis! An der Stelle werden rollierende Summen gebildet, welche mit sum wahrscheinlich schneller laufen werden.
Ich prüfe mal mit dem Profiler welchen Vorteil das bringt.

Gruß,
Lloyd
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: 28.04.2012, 23:02     Titel:
  Antworten mit Zitat      
Hallo Lloyd Blankfein,

Leider schaltet der Profiler die JIT-Beschleunigung aus. Dies ändert die Timings der Schleifen deutlich.
Ein paar TIC/TOCs wären besser geeignet.

Es gibt noch weiteres Verbesserungspotential. Ich möchte mich nur nicht in details stürzen, solange noch Bugs im code sind.

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

Forum-Century

Forum-Century



Beiträge: 149
Anmeldedatum: 23.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 29.04.2012, 14:53     Titel:
  Antworten mit Zitat      
Hallo Jan,

die TIC/TOCs setzte ich dann sinnvoller Weise am Anfang- bzw. Ende der i-Schleife, richtig?

Gruß,
Lloyd
Private Nachricht senden Benutzer-Profile anzeigen
 
Lloyd Blankfein
Themenstarter

Forum-Century

Forum-Century



Beiträge: 149
Anmeldedatum: 23.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 02.05.2012, 09:07     Titel:
  Antworten mit Zitat      
Hallo Jan,

Code:

for i=1:size(x.value,1)-obj.mAVG_Indicator(j,3)+1-TSDelay(j)
        obj.mAVG(i,j+1)=sum(x.value(i):x.value(i+obj.mAVG_Indicator(j,3)-1));
end
 


ich bilde nun die Summe anstatt k-mal zu iterieren. Der Code läuft um etwa den Faktor 8 schneller Very Happy

Zitat:
Es gibt noch weiteres Verbesserungspotential. Ich möchte mich nur nicht in details stürzen, solange noch Bugs im code sind.


Was ist dir noch aufgefallen?
Vielen Dank!

Gruß,
Lloyd
Private Nachricht senden Benutzer-Profile anzeigen
 
Lloyd Blankfein
Themenstarter

Forum-Century

Forum-Century



Beiträge: 149
Anmeldedatum: 23.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 02.05.2012, 09:21     Titel:
  Antworten mit Zitat      
Bei der Summe ist mir ein Fehler unterlaufen, es muss heißen:
Code:

obj.mAVG(i,j+1)=sum(x.value(i:i+obj.mAVG_Indicator(j,3)-1));
 
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: 03.05.2012, 12:21     Titel:
  Antworten mit Zitat      
Hallo Lloyd Blankfein,

Es ist schwierig und fehleranfällig, sich aus mehreren Postings die korrekte Funktion zusammen zu kopieren, um sie verbessern zu können. Dies schein ein Moving Average zu sein:
Code:
obj.mAVG(i,j+1)=sum(x.value(i:i+obj.mAVG_Indicator(j,3)-1));

Das wiederholte Berechnen der Summe enthält eine Menge redundanter Operationen, deshalb wäre FILTER() wahrscheinlich deutlich schneller.

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

Forum-Century

Forum-Century



Beiträge: 149
Anmeldedatum: 23.02.11
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 03.05.2012, 17:33     Titel:
  Antworten mit Zitat      
Hallo Jan,

DANKE, ich habe die Idee mit dem Filter umgesetzt:

Code:

        function CalcMovingAVG(obj)
            bCalcPerformanceYesNo=Boolean.No;
            TSDelay=zeros(size(obj.mAVG_Indicator,1),1);
            %Example: TS starts on 11/23/1990 -> Performace is available
            %from 11/26/1990 onwards. If Moving AVG is based on Performace
            %there will be a delay of 1 day -> TSDelay=1
            for j=1:size(obj.mAVG_Indicator,1)
                if obj.mAVG_Indicator(j,1)==0
                    bCalcPerformanceYesNo=Boolean.Yes;
                    TSDelay(j)=1;
                end
            end
            if bCalcPerformanceYesNo
                CalcPerformance(obj);
            end
            obj.mAVG=[obj.ts(:,1),NaN(size(obj.ts(:,1),1),size(obj.mAVG_Indicator,1))];
            for j=1:size(obj.mAVG_Indicator,1)
               b=ones(1,obj.mAVG_Indicator(j,3))/obj.mAVG_Indicator(j,3);
               if obj.mAVG_Indicator(j,1)==0
                   x=libpointer('doublePtr',obj.Performance(:,obj.mAVG_Indicator(j,2)));
               else
                   x=libpointer('doublePtr',obj.ts(:,obj.mAVG_Indicator(j,2)));
               end
               obj.mAVG(1:size(x.value,1)-TSDelay(j),j+1) = filter(b,1,flipud(x.value(1:size(x.value,1)-TSDelay(j))));
               obj.mAVG(1:size(x.value,1)-TSDelay(j),j+1)=flipud(obj.mAVG(1:size(x.value,1)-TSDelay(j),j+1));
               obj.mAVG(size(x.value,1)-obj.mAVG_Indicator(j,3)+2-TSDelay(j):size(x.value,1),j+1)=NaN;
            end
        end
 


Die Funktion ist nun um den Faktor 8 schneller Smile

Gruß,
Lloyd
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.