Filter löschen
Filter löschen

How to calculate mean wind direction

30 Ansichten (letzte 30 Tage)
Jenna Marie
Jenna Marie am 5 Mai 2014
Kommentiert: Soeren Bilges am 10 Feb. 2023
Hello!
I need help figuring out how to calculate mean wind direction when my data is in degrees (0-360). I just realized my current program does not take into account that the data is circular, and the mean of 355 and 5 will be 180, instead of 0. Any help is greatly appreciated! I am a beginner when it comes to MATLAB programming
  2 Kommentare
José-Luis
José-Luis am 5 Mai 2014
Instead of 0, you mean?
Jenna Marie
Jenna Marie am 5 Mai 2014
Ah yes thank you for catching that! Accidentally mixed up 360 degrees in a circle with 365 days in a year. It's been a long day....

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

José-Luis
José-Luis am 5 Mai 2014
average = mod(sum(data),360)./numel(data)
Please accept an answer if it helped you.
  12 Kommentare
Naseef Muhammed
Naseef Muhammed am 12 Sep. 2022
@Walter Roberson I'm refering to the function 'windir_avg' you provided above. In that function, if we given 2 anlges from third or fourth, it will give a wrong answer. for example, if we put 345 and 355 the answer will be 190. similarly, 240 and 250 will result in 295. I hope it can be resolved if we edit your script as below:
function [windir_avged] = windir_avg(windir)
windir_avged=180/pi*angle(sum(exp(1i.*windir.*pi/180))/numel(windir));
if windir_avged < 0
windir_avged=windir_avged+360;
end

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (3)

Jenna Marie
Jenna Marie am 5 Mai 2014
Thank you so much for your response!
What does numel mean?
  1 Kommentar
José-Luis
José-Luis am 5 Mai 2014
No worries.
doc numel
Counts the number of elements in the matrix.

Melden Sie sich an, um zu kommentieren.


Walter Roberson
Walter Roberson am 9 Jul. 2017
See unwrap() but you will need to convert to radians

Robert Daly
Robert Daly am 16 Jun. 2021
I needed a solution that would ignore NAN values in the data.
Converts the direction data into X & Y vector components, averages those, then converts back to direction.
function [windir_avged] = windir_avg(windir)
[x,y] = pol2cart(deg2rad(windir),ones(size(windir)));
x=mean(x,'omitnan');
y=mean(y,'omitnan');
[windir_avged,~]=cart2pol(x,y);
windir_avged = rad2deg(windir_avged);
end

Kategorien

Mehr zu Dates and Time finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by