How to calculate mean wind direction

조회 수: 42 (최근 30일)
Jenna Marie
Jenna Marie 2014년 5월 5일
댓글: Soeren Bilges 2023년 2월 10일
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
José-Luis
José-Luis 2014년 5월 5일
Instead of 0, you mean?
Jenna Marie
Jenna Marie 2014년 5월 5일
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....

댓글을 달려면 로그인하십시오.

채택된 답변

José-Luis
José-Luis 2014년 5월 5일
average = mod(sum(data),360)./numel(data)
Please accept an answer if it helped you.
  댓글 수: 12
Naseef Muhammed
Naseef Muhammed 2022년 9월 12일
@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

댓글을 달려면 로그인하십시오.

추가 답변 (3개)

Jenna Marie
Jenna Marie 2014년 5월 5일
Thank you so much for your response!
What does numel mean?
  댓글 수: 1
José-Luis
José-Luis 2014년 5월 5일
No worries.
doc numel
Counts the number of elements in the matrix.

댓글을 달려면 로그인하십시오.


Walter Roberson
Walter Roberson 2017년 7월 9일
See unwrap() but you will need to convert to radians

Robert Daly
Robert Daly 2021년 6월 16일
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
  댓글 수: 1
Soeren Bilges
Soeren Bilges 2023년 2월 10일
Preferred and robust solution, thanks.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Logical에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by