- Because inputParse is slow: code is faster with custom input checking.
- Because many toolbox functions call a compiled function to check the inputs, which is specialized for the family of functions that use it.
Why does MatLab has inputParse function but does not use it in its own functions
4 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Why does MatLab has inputParse function but does not use it in its own functions, for example, in interp1 which accepts arguments in name-value style?
3 Kommentare
Antworten (2)
Jan
am 5 Jun. 2018
Bearbeitet: Jan
am 5 Jun. 2018
The total time to solve a problem consists of:
T_total = T_design + T_programming + T_debugging + T_runtime
inputParser can reduce the programming time remarkably. It might waste many milliseconds, but if the function is called some hundred times only, this does not matter. Using an hour to write and test a variety of input arguments can be inefficient in comparison, even if the code consumes microseconds only. And if you have a bug in manual input parsing, which was not detected before delivering the software, the costs can be substantial.
The shorter the function and the more frequently it is called, the worse is the slowdown by inputParser. But even interp1 and polyfit need more time with checking the inputs than with the actual computations - without inputParser ...
0 Kommentare
Hilmar Lehnert
am 8 Aug. 2021
Because it's SLOW. For example, one undocumented sub function in pwelch() (psdfreqvec()) uses InputParser() and the darn thing chews up way more time than my entire data analysis which is a real problem for large data sets.
inputParser() is ok as an interface to a very high level function that gets called only a few times, but using it inside a library or utility function is a terrible idea.
0 Kommentare
Siehe auch
Kategorien
Mehr zu Get Started with MATLAB finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!