Constructor for function_handles

Creates evaluable function handles for any function, possibly outside the MATLAB search path
1K Downloads
Updated 2 May 2020

Editor's Note: This file was selected as MATLAB Central Pick of the Week

If you ever found yourself in a situation where you could not or didn't want to add a directory to the MATLAB search path, but still needed speedy access to a function in that directory, this file is for you.
In such cases, having to change directories to gain access to the function is not the best solution: you'd always have to take care to change the current path back to what it was (even on error). Moreover, performance in those cases can be poor if you have to call this function very often.

FUNCTION_HANDLE allows you to create function handles which can successfully be evaluated without loss of performance, even if the function the handle points to is not on the MATLAB search path.

While there often are better ways to accomplish this sort of task (package directories, symbolic links, etc.), there are a few niche cases where these solutions are simply more involved than using this FUNCTION_HANDLE constructor.

Note that FUNCTION_HANDLE overloads a function present in standard MATLAB. This 'native' function is nothing more than documentation (linked to in the help for this constructor) and an error message which says that you cannot use the function to construct handles. As this is exactly what FUNCTION_HANDLE implements, this shadowing is desirable.

Example session:

>> F = function_handle('./path/to/function/myFcn.m')
F =
@myFcn

>> A = function_handle(...
{@cos, '../dir/not/on/path/myFunction.m'})
A =
@cos @myFunction

>> A{1}(pi)
ans =
-1

>> functions(A{1})
ans =
function: 'min'
type: 'simple'
file: ''

>> functions(A{2})
ans =
function: 'myFunction'
type: 'simple'
file: '/fullpath/dir/not/on/path/myFunction.m'

Cite As

Rody Oldenhuis (2024). Constructor for function_handles (https://github.com/rodyo/FEX-function_handle/releases/tag/v1.3), GitHub. Retrieved .

MATLAB Release Compatibility
Created with R2010a
Compatible with any release
Platform Compatibility
Windows macOS Linux
Categories
Find more on Functions in Help Center and MATLAB Answers

Community Treasure Hunt

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

Start Hunting!

Versions that use the GitHub default branch cannot be downloaded

Version Published Release Notes
1.3

See release notes for this release on GitHub: https://github.com/rodyo/FEX-function_handle/releases/tag/v1.3

1.2.0.0

[linked to Github]

1.1.0.0

- small doc update; tags were messed up

1.0.0.0

To view or report issues in this GitHub add-on, visit the GitHub Repository.
To view or report issues in this GitHub add-on, visit the GitHub Repository.