Averaging daily values from annual data

Hi there,
I have a 2 column matrix of Date (dd:mm:yyyy ss:mm:hh) and wave height for 8372 records over a year, one record per hour.
What would be the best way to find a mean wave height for each day and plot this? Some days have more records than others.
I am fairly new to Matlab and understand that I need to convert using datenum first. Please help!
Alternatively, how would I run a moving average over the data for a specified number of records?
Thank you.

1 comentario

per isakson
per isakson el 31 de Jul. de 2015
"8372" &nbsp that is not a full year of hourly data. Which hours are missing?

Iniciar sesión para comentar.

Respuestas (1)

Andrei Bobrov
Andrei Bobrov el 31 de Jul. de 2015
f = fopen('data.txt');
c = textscan(f,'%s %s %f');
fclose(f);
[y m d] = datevec(datenum(strcat(c{1:2}),'dd:mm:yyyySS:MM:HH'));
[a,~,c1] = unique([y m d],'rows');
out = [a, accumarray(c1,c{3},[],@mean);

Categorías

Preguntada:

JH
el 31 de Jul. de 2015

Respondida:

el 31 de Jul. de 2015

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by