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

gleitende Varianz/moving variance

 

RainbowBrite
Forum-Anfänger

Forum-Anfänger


Beiträge: 13
Anmeldedatum: 13.05.09
Wohnort: Bremen
Version: R2007a
     Beitrag Verfasst am: 18.08.2009, 14:54     Titel: gleitende Varianz/moving variance
  Antworten mit Zitat      
Hallo,
ich habe ein kleines script geschrieben um die gleitende varianz zu berechnen. Allerdings dauert die Berechnung ziemlich lang. Das liegt vielleicht auch an den 45300 Daten. Von jeweils 300 Daten soll die Varianz berechnet werden.
Weiß jemand von euch eine Möglichkeit um das ganze schneller zu machen?
Danke.
Viele Grüße

Code:

a=300; % the length you need to define to calculate an average --> window size
u=u3; % time series

for k=1:45000 % n is l-a+1, l is the number of lines of one vector
    for i=k:(k+a-1)
    uav(k,1)=mean(u(k:(k+a-1),1));% µ1
    udiftp=u(k:(k+a-1),1)-uav(k,1);% x1-µ1
    prdtuvdiftp=udiftp.^2;% (x1-µ1)^2
    u3_mvvar(k,1)=sum(prdtuvdiftp(1:300,1))/a;
    end
end
 
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: 18.08.2009, 16:04     Titel:
  Antworten mit Zitat      
Hi,

dein Code haut nicht wirklich hin, erstmal kannst du die innere Schleife komplett weglassen, die hat keine Wirkung. Die Berechnung von u3_mvvar ist auch falsch. Du berechnest dort immer nur die Summe von den ersten 300 frames. Die Lösung ist einfacher als du dir das vielleicht denkst:

Code:

number = fix((length(u))/a);
u = u(1:a.*number);
new1 = var(reshape(u,a,number));
 


Das wars schon sollte u nicht durch a teilbar sein, wird hinten abgeschnitten. Da könnte man auch noch das letzte Feld nehmen je nachdem ob es Sinn macht oder nicht.

Viele Grüße,

der Oli
Private Nachricht senden Benutzer-Profile anzeigen
 
RainbowBrite
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 13
Anmeldedatum: 13.05.09
Wohnort: Bremen
Version: R2007a
     Beitrag Verfasst am: 18.08.2009, 16:50     Titel:
  Antworten mit Zitat      
Hallo Oli,
danke für die Antwort. Dein Code funktioniert auch soweit, allerdings wollte ich hinterher nen Vektor haben, der die gleiche Länge hat wie die Zeitserie. Also die ersten 300 Werte vom ersten Wert ausgehend, dann vom zweiten Wert ausgehen die nächsten 300 Werte. Und davon dann immer die Varianz. Ist das verständlich?
Mein Code funktioniert auch eigentlich, nur dauert das eben schon sehr lange.
Private Nachricht senden Benutzer-Profile anzeigen
 
steve
Ehrenmitglied

Ehrenmitglied



Beiträge: 2.022
Anmeldedatum: 03.09.07
Wohnort: Wien
Version: R2023b
     Beitrag Verfasst am: 20.08.2009, 09:19     Titel:
  Antworten mit Zitat      
Moin,

wenn du eh nur die Varianz suchst, dann mach es doch einfach so:
Code:
a=300; % the length you need to define to calculate an average --> window size
u=u3; % time series
varianz = zeros(u3)
for k=1:length(u)-a
    varianz(k) = var(u(k:k+a));
end


Sollte zumindest klappen...

Gruß
Alex
_________________

>> I told me to.

____________________________________
Matlab Cheat Sheet
goMatlab-Knigge - dran gehalten?!
Schon in den FAQ gesucht?
Ist vielleicht bei den Skripten oder den Tutorials was für dich dabei?
Private Nachricht senden Benutzer-Profile anzeigen
 
RainbowBrite
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 13
Anmeldedatum: 13.05.09
Wohnort: Bremen
Version: R2007a
     Beitrag Verfasst am: 20.08.2009, 09:55     Titel:
  Antworten mit Zitat      
Oh, vielen Dank. Das sieht viel einfacher aus und geht viel schneller! Und die Ergebnisse sind auch fast gleich. Danke!
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.