array/cellfun vs. for loop

24 vues (au cours des 30 derniers jours)
David Goldsmith
David Goldsmith le 28 Juin 2012
Commenté : Rik le 20 Août 2018
Are arrayfun and cellfun always faster than functionally equivalent for loops? If so, why? (E.g., is it a difference in the library functions they call for implementation?) Finally, is it possible to give a general "order function" by which they're faster (e.g., O(N), O(NlogN), etc.)?

Réponse acceptée

Walter Roberson
Walter Roberson le 28 Juin 2012
For loops are usually faster than arrayfun or cellfun, as the for loop does not need to invoke the function handle each time. The for loop also has opportunities for optimizations between statements that the arrayfun or cellfun would not have.
arrayfun() or cellfun() can be faster to write the code for, as they are a higher level concept. Not always, though: some of the twists one has to go through to create the behaviour as an anonymous function can be messy.
  8 commentaires
Walter Roberson
Walter Roberson le 20 Août 2018
I do find the blog article at the link indicated.
Rik
Rik le 20 Août 2018
Strange. Maybe it was offline temporarily, or my own connection had a hiccup. Anyway, here is a permalink for future reference.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Loops and Conditional Statements dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by