Filter löschen
Filter löschen

Why is datenummx(clock) faster than now()?

3 Ansichten (letzte 30 Tage)
Dan Couture
Dan Couture am 2 Jan. 2013
Why is running datenummx(clock) 4x faster than the standard now() call? https://gist.github.com/4432190

Akzeptierte Antwort

per isakson
per isakson am 2 Jan. 2013
Bearbeitet: per isakson am 2 Jan. 2013
The function, now, has one executable line of code
t = datenum(clock);
the function, datenum, calls the function, datenummx, after having done error checking, etc.
That's why.
  2 Kommentare
Dan Couture
Dan Couture am 3 Jan. 2013
Thanks per isakson.
I did see the layers of function calls below now() which is where I dug out the datenummx(clock) code. My question was intended to focus on why does matlab have all those layers in between that just slow it down? My apologies for the vagueness of the originial question.
  • Why does Matlab not alias now() directly to datenummx(clock)?
  • There is no user input, so error checking should be minimal (if any)
and as a follow-up:
  • Is there something still below the datenummx call that would be even faster?
I am running a fairly complex simulation through object oriented m-files and need to reference the current system time quickly and continually.
per isakson
per isakson am 3 Jan. 2013
Bearbeitet: per isakson am 3 Jan. 2013
I often find it difficult to understand the rational behind various design decisions of The MathWorks (TMW). Since, TMW is successful in the money-making industry, I guess TMW knows what they are doing.
Regarding datenummx I guess it is possible to make a faster function (little error checking, one OS (Windows only), maybe "in-place".) Post a new question.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Holidays / Seasons 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