Mittelwert < Matlab < Mathe-Software < Mathe < Vorhilfe
|
Status: |
(Frage) beantwortet | Datum: | 09:58 Di 16.01.2007 | Autor: | makabeli |
Ich habe diese Frage in keinem Forum auf anderen Internetseiten gestellt.
Hallo,
ich habe 2 Datensätze, sagen wir einmal 500 Werte. Im zweiten Datensatz stehen 500 strings, jeweils das Datum zum ersten Datensatz.
...
24 01.01.1988
23 01.05.1988
23 01.12.1988
22 01.01.1989
12 01.05.1989
...
und so weiter.
Ich habe die Datum strings in Zahlen umgewandelt.
Jetzt möchte ich für jedes Jahr den Mittelwert berechnen.
Mir fällt einfach keine optimale for-schleife oder if-anweisung ein.
Kann mir vielleicht jemand helfen?
Danke schonmal im voraus.
|
|
|
|
Hallo,
erzeuge doch einen Zahlenwert für den 1.1. eines jeden Jahres. Dann kannst du in einer for-Schleife alle dazwischen liegenden einträge ausfindig machen per:
Jahresdurchschnitt = mean(Spalte_mit_Werten(Anfang_akt_Jahr <= Spalte_mit_Jahren & Spalte_mit_Jahre <= Anfang_naechst_Jahr));
So ungefähr müsste es gehen.
Gruß
Martin
|
|
|
|
|
Status: |
(Frage) beantwortet | Datum: | 13:44 Mi 17.01.2007 | Autor: | makabeli |
Ja die Idee hatte ich auch schon, aber das Problem ist halt für jeden 1.1. jeden Jahres einen Zahlenwert zu bestimmen.
Meine Daten sind nicht fest, sie ändern sich je nach dem welchen Zeitraum man betrachtet. Das können 30 Jahre, aber auch nur 2 Jahre sein. Und in jedem Jahr wurden Messungen durchgeführt, mal mehr mal weniger. Und der Vektor mit dem Datum, das sind ja strings, und ich weiß nicht wie ich die Abfrage dann machen soll.
Ich habe die strings mit datenum in Zahlen umgewandelt.
Damit wollte ich dann auch den 1.1. bestimmen.
Zeitraum: zum Beispiel a=1977; b=1987
For i=a:b
Datum=Datenum(01-01-i)
Weißt du wie ich meine. Ich kann zwar schauen welche Jahre vorkommen und dann für jeden einzelnen den 1.1. bestimmen
Grenze=Datenum(01-01-1977)
Und so weiter, aber dadurch das mein Programm nicht fest ist, und sich ständig ändert, brauche ich für die Bestimmung des 1.1. irgendeine Schleife.
Gruß
|
|
|
|
|
Hallo,
ich bin mir nicht ganz sicher, ob es das ist, was du brauchst, aber schau dir mal Folgendes an:
Der Vektor mit den Werten heiße werte.
Die Matrix, in deren Zeilen die Daten stehen, heiße daten.
%zuerst Koversion des Datumsformats in das englische
dates = [daten(:,4:5) repmat('/',length(daten),1) daten(:,1:2) repmat('/',length(daten),1) daten(:,7:10)];
%dann Extraktion aller vorkommender Jahre und Bestimmung von min und max
jahre = unique(daten(:,end-3:end),'rows');
minJahr=str2num(jahre(1,:));
maxJahr=str2num(jahre(end,:));
%Bestimmung des Mittelwertes für jedes Jahr und Speicherung in schnitt
for i=minJahr:maxJahr,
schnitt(i) = mean(val(find(datenum(dates) >= datenum(i,1,1) & datenum(dates) < datenum(i+1,1,1))));
end;
Bei diesem Code wird der Schnitt in Jahren ganz ohne Messungen zu NaN (not a number) bestimmt. Evtl. könnte man da eine Abfrage einfügen, also: Falls keine Messung in diesem Jahr, dann Schnitt = 0 oder -1 o.ä.
Gruß
Martin
|
|
|
|