How to make datenum more efficient for large arrays?

조회 수: 3 (최근 30일)
Marian
Marian 2013년 10월 29일
댓글: Cedric 2013년 10월 30일
I am using textscan() to create an matrix that is 3,081,680 rows long. The very first column, A{1}, is the timestamp column, and it's elements look like this:
"2011-01-23 18:38:30"
I have tried using datenum() to convert this, but it is either taking too long or not working at all (longer than ten minutes). Is there a way I can make this more efficient?
Thanks!

채택된 답변

Cedric
Cedric 2013년 10월 29일
편집: Cedric 2013년 10월 29일
What is the purpose ultimately? Do you need an accurate time stamp which accounts for the date and time? If you were computing daily averages for 2011 only, for example, we could find a way to generate month/day IDs probably faster than DATENUM.
Otherwise, there are FEX contributions, e.g. this one by Jan Simon: http://www.mathworks.com/matlabcentral/fileexchange/28093-datestr2num
as well as a few relevant threads, among which: http://undocumentedmatlab.com/blog/datenum-performance/
  댓글 수: 5
Marian
Marian 2013년 10월 30일
Ah, datevec! I have been teaching myself MATLAB and did not know of this function, but I believe that I needed datevec to read arrays, as datenum or datestr2num would not work for type "cell". Thanks so much!
Cedric
Cedric 2013년 10월 30일
You're welcome. Let me know if you go for an ACCUMARRAY approach for binning and need help with that.

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

추가 답변 (1개)

Kelly Kearney
Kelly Kearney 2013년 10월 29일
Are you specifying the date format? Particularly for large arrays,
datenum(A{1}, 'yyyy-mm-dd HH:MM:SS')
will be much faster than
datenum(A{1})
  댓글 수: 3
Marian
Marian 2013년 10월 30일
Error using datenum (line 179) DATENUM failed.
Error in onemin (line 9) time=datenum(A{1}, 'yyyy-mm-dd HH:MM:SS');
Caused by: Error using dtstr2dtnummx Failed on converting date string to date number.
This is the error I get using that, and I believe it is because of the double quotations around it.
Cedric
Cedric 2013년 10월 30일
Use the following format: '"yyyy-mm-dd HH:MM:SS"'

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

카테고리

Help CenterFile Exchange에서 Dates and Time에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by