How can I calculate formula using loop?
3 views (last 30 days)
Show older comments
Suat YAZICI
on 18 Aug 2018
Commented: Suat YAZICI
on 19 Aug 2018
Hello!
Excel file format as follows:
- A column: Year (from 1998 to 2018)
- B column: Day of the year
- C column: Hour
I'd like to convert the values of B and C column as year.
Doy= C/24+B
Formula is:
Time=A+(Doy/365) or Time=A+(Doy/366)
Dividing 365 or 366 is related to divide by 4. That's why I benefitted from modulo operation but I didn't do what I want.
data=xlsread('R.xlsx');
Doy=data(:,2)+(data(:,3)/24);
M = mod(data(:,1),4);
j=1;
for i=1:176784;
if M ==0
Time=data(:,1)+(Doy/366);
else M~=0
Time=data(:,1)+(Doy/365);
j=j+1;
end
0 Comments
Accepted Answer
Walter Roberson
on 18 Aug 2018
data = xlsread('R.xlsx');
Doy = data(:,2)+(data(:,3)/24);
yearlen = 365 + (eomday(data(:,1),2) == 29); %trick
Time = data(:,1) + Doy ./ yearlen;
3 Comments
Walter Roberson
on 19 Aug 2018
Very close. Centuries (years which end in 00) are not leap years unless they are also divisible by 400. So 1900 was not a leap year by 2000 was.
The eomday() routine knows about leap years, and will return 29 when asked for the last day of the month for February for any year which is a leap year. My code compares the response of eomday() to 29 to determine whether the year is a leap year; if it is not a leap year then the == returns 0, and if it is a leap year then the == returns 1. That 0 or 1 value is added to 365 to determine the length of the year, 365 for non leap years and 366 for leap years. The day of year is then divided by that amount.
More Answers (0)
See Also
Categories
Find more on Dates and Time in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!