afterEach
Run function after each function finishes running in the background
Description
runs the function B
= afterEach(A
,fcn
,n
)fcn
automatically after each element in the
Future
array A
finishes and returns a
Future
object B
.
MATLAB® runs the function fcn
using the outputs from each
element in Future
array A
. If
Future
array A
has M
elements, MATLAB runs the function M
times. When the scheduled
function fcn
finishes for the
M
th time, the
Future
object B
finishes.
For more information about using afterEach
to run functions
after they finish running on a parallel pool, see afterEach
(Parallel Computing Toolbox).
If the computations for any elements in A
result in an error,
by default, afterEach
does not run fcn
on the elements that failed.
Examples
Run Callback Function After Function Finishes Running in the Background
This example shows how to use afterEach
to schedule a callback function to run after a function finishes running in the background.
Use parfeval
to run the function rand(1)
and retrieve one output. Specify backgroundPool
as the first argument to run the function in the background. Repeat 10 times to create 10 Future
objects.
for i = 1:10 f(i) = parfeval(backgroundPool,@rand, 1, 1); end
After each Future
finishes, display the value using the disp
function. The input arguments for disp
are the output arguments from each Future
. Specify the third argument to the afterEach
function as 0
to return no outputs from the callback.
afterEach(f,@disp,0);
Handle Errors from Functions Running in the Background
This example shows how to use afterEach
to handle errors from a function that runs in the background.
When computations for Future
objects result in an error, by default, afterEach
does not evaluate its function on the elements that failed. If you want to handle any errors, for example, when you have a user interface that you want to update, you can use the PassFuture
argument. When you set PassFuture
to true
, MATLAB passes the Future
object to the callback function. You can call fetchOutputs
on it, process the outputs, and handle any possible errors.
Send a computation to the background using parfeval
. The computation results in an error. You can view the error message using the Error
property of the future.
errorFuture = parfeval(backgroundPool, ...
@(n,k) factorial(n)/(factorial(k)*factorial(n-k)),1,4,8);
wait(errorFuture);
errorFuture.Error
ans = ParallelException with properties: identifier: 'MATLAB:factorial:NNegativeInt' message: 'N must be an array of real non-negative integers.' cause: {} remotecause: {[1×1 MException]} stack: [2×1 struct] Correction: []
If you use afterEach
on a future that results in an error, the callback function is not evaluated. In the code below, MATLAB does not execute the displayResult
function because the future errors.
afterEach(errorFuture,@displayResult,0);
Write a callback function to handle futures that result in errors. If the error property of the future variable is empty, the handleError
helper function calls fetchOutputs
on the future variable, and process its outputs. If the error property of the future variable is not empty, the handleError
helper function displays an error dialog box.
function handleError(f) fig = uifigure(Position=[100 100 425 275]); if isempty(f.Error) output = fetchOutputs(f); message = strcat("Computation complete: Result = ",num2str(output)); uialert(fig,message,"Sucess",Icon="success") else message = "Computation failed!"; uialert(fig,message,"Error",Icon="error") end end
Call afterEach
with the handleError
function and set PassFuture
to true
.
afterEach(errorFuture,@handleError,0,PassFuture=true);
function displayResult(output) fig = uifigure(Position=[100 100 425 275]); message = strcat("Computation complete: Result = ",num2str(output)); uialert(fig,message,"Sucess",Icon="success") end
Update Wait Bar While Functions Run in the Background
This example shows how to use afterEach
to update a wait bar with the progress of functions running in the background.
Create a wait bar, w
.
w = waitbar(0,'Please wait ...');
Set the number of iterations for your for
-loop, N
. Store the current number of completed iterations, 0
, and the total number of iterations, N
, in the UserData
property of the wait bar.
N = 20;
w.UserData = [0 N];
Run a for
-loop with N
iterations. In each iteration, use parfeval
and backgroundPool
to run pause
in the background for a random number of seconds. Store each Future
object in an array.
for i = 1:N delay = rand; f(i) = parfeval(backgroundPool,@pause,0,delay); end
Use the helper function updateWaitbar
to update the waitbar after each Future
finishes.
afterEach(f,@(~)updateWaitbar(w),0);
Use delete
to close the wait bar after all the Future
objects finish.
afterAll(f,@(~)delete(w),0);
Define Helper Function
Define the helper function updateWaitbar
. The function increments the first element of the UserData
property, then uses the vector to calculate the progress.
function updateWaitbar(w) % Update a waitbar using the UserData property. % Check if the waitbar is a reference to a deleted object if isvalid(w) % Increment the number of completed iterations w.UserData(1) = w.UserData(1) + 1; % Calculate the progress progress = w.UserData(1) / w.UserData(2); % Update the waitbar waitbar(progress,w); end end
Input Arguments
A
— Input Future
parallel.Future
scalar | parallel.Future
array
Input Future
object, specified as a parallel.Future
scalar or array.
MATLAB runs the function fcn
after each element
in A
finishes.
By default
PassFuture
is false and MATLAB runsfcn(X1,...,Xm)
using the outputsX1,...,Xm
from eachFuture
element inA
as the elements finish.If any of the elements in
A
encounters an error, by default,afterEach
does not runfcn
on the elements that failed.If you specify
PassFuture
astrue
, MATLAB runsfcn(A(j))
after eachFuture
element inA
finishes.If any of the elements in
A
encounters an errorafterEach
runsfcn
on the elements that failed.
If the Future
array has M
elements,
MATLAB runs the function M
times. When the
scheduled function fcn
finishes, the
Future
object B
finishes.
Example: A =
parfeval(backgroundPool,@magic,1,3);
fcn
— Callback function to run
function handle
Callback function to run, specified as a function handle.
Example: fcn = @magic
n
— Number of output arguments
nonnegative integer scalar
Number of output arguments, specified as a nonnegative integer scalar.
By default
PassFuture
is false, andn
is the number of output arguments requested from runningfcn(X1,...,Xm)
using the outputsX1,...,Xm
from each element in theFuture
arrayA
.If you specify
PassFuture
astrue
,n
is the number of output arguments requested from runningfcn(A(j))
using each elementA(j)
in theFuture
arrayA
.
Data Types: single
| double
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
PassFuture
— Pass Future
elements in array A
to callback function
false
or 0
(default) | true
or 1
Pass the Future
elements in array A
to the callback function, specified as true
or
false
.
By default
PassFuture
is false and MATLAB runsfcn(X1,...,Xm)
using the outputsX1,...,Xm
from eachFuture
element inA
as the elements finish.If any of the elements in
A
encounters an error, by default,afterEach
does not runfcn
on the elements that failed.If you specify
PassFuture
astrue
, MATLAB runsfcn(A(j))
after eachFuture
element inA
finishes, instead of the outputs of theFuture
elements inA
.If any of the elements in
A
encounters an errorafterEach
runsfcn
on the elements that failed.
Data Types: logical
Output Arguments
B
— Output Future
parallel.Future
object
Output Future
object, returned as a
parallel.Future
object.
Use
fetchOutputs
to retrieve results fromB
.Use
afterEach
orafterAll
to run a function whenB
completes.
When you set PassFuture
, you change the
Error
property of B
if
afterEach
does not result in an error:
By default,
PassFuture
isfalse
and if any of the elements inA
encounters an error, theError
property ofB
is a cell array with the same number of elements asA
.If you set
PassFuture
totrue
, theError
property ofB
is an empty cell array, even if one or more elements inA
encounter an error.
If afterEach
results in an error, the
Error
property of B
is an
MException
object.
Version History
Introduced in R2018a
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: United States.
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
Asia Pacific
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)