how to modify a structure?

Hello. I initialize (instantiate) a structure like this:
YourStruct = struct(...
'Date', {cell(2208,1)}, ...
'Hour', {zeros(2208,1)}, ...
'DryBulb', {zeros(2208,1)}, ...
'DewPnt', {zeros(2208,1)}, ...
'SYSLoad', {zeros(2208,1)}, ...
'NumDate', {zeros(2208,1)});
'Date' has 92 days, and 'Hour' has 24 hours, from 1 to 24. How can I express 'Date' and 'Hour' in serial date numbers and how do I present these serial date numbers in 'NumDate'? Thank you.

7 Commenti

Image Analyst
Image Analyst il 16 Set 2012
Please format properly (as Code).
UPT
UPT il 16 Set 2012
please Image Analyst,can you be more specific?(sorry but i'm a begginer in MATLAB).thanks
UPT
UPT il 16 Set 2012
thank for your suggestions Walter Robinson..:)
Walter Roberson
Walter Roberson il 16 Set 2012
Please go back and edit your original posting to mark-up the code there.
Note: there is no "i" in my username.
UPT
UPT il 16 Set 2012
Modificato: Oleg Komarov il 16 Set 2012
sorry again for my mistakes Walter Roberson: here is my new post:
data = struct('Date', {cell(2208,1)}, 'Hour', {zeros(2208,1)}, 'DryBulb', {zeros(2208,1)}, 'DewPnt', {zeros(2208,1)}, 'SYSLoad', {zeros(2208,1)}, 'NumDate', {zeros(2208,1)});
'Date' has 92 days and 'Hour' has 24 hours,from 1 to 24.how can i express 'Date' and 'Hour' in serial date numbers and to present these serial date numbers in 'NumDate'?
Walter Roberson
Walter Roberson il 16 Set 2012
Blank line before and after the code. Indent the code.

Accedi per commentare.

Risposte (1)

Walter Roberson
Walter Roberson il 16 Set 2012
NumDate = Data.Date + (Data.Hour - 1) / 24;

5 Commenti

Walter Roberson
Walter Roberson il 16 Set 2012
Wait -- what exactly does the Date cell contain?
UPT
UPT il 16 Set 2012
Date cell contains the dates from 1 July 2011-31 September 2011
Walter Roberson
Walter Roberson il 16 Set 2012
As strings? If so then use datenum() to convert them to serial date numbers and add (Hour-1)/24
UPT
UPT il 17 Set 2012
for each day i want to have 24 date serial numbers (a date serial number for each hour).could please you tell me how i can do that?...note:im a new user in matlab and i make some basic mistakes,so dont be upset if i dont understand all what you say..anyway,this is the fourth time you help me and im very grateful to you..:)
Your Hour field is the same length as your Date field, which suggests you want exactly 1 hour conversion for each Date converted, rather than wanting to create 24 hour conversions for each Date converted.
data.NumDate = datenum(Data.Date) + (Data.Hour - 1) / 24;
except that you might need to add an additional parameter to datenum() in order to indicate the date format.

Accedi per commentare.

Richiesto:

UPT
il 16 Set 2012

Community Treasure Hunt

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

Start Hunting!

Translated by