Custom evaluation function, specified as a function handle. The train
function
calls evalFcn
after evalPeriod
episodes.
Your evaluation function must have three inputs and three outputs, as illustrated by
the following signature.
Given an agent, its environment, and training episode information, the custom
evaluation function runs a number of evaluation episodes and returns a corresponding
summarizing statistic, a vector of episode scores, and any additional data that might be
needed for logging.
The required input arguments (passed to evalFcn
from
train
) are:
agent
— Agent to evaluate, specified as a reinforcement
learning agent object. For multiagent environments, this is a cell array of agent
objects.
environment
— Environments within which the agents are
evaluated, specified as a reinforcement environment object.
trainingInfo
— A structure containing the following fields.
episodeIndex
— Current episode index, specified as a
positive integer
episodeInfo
— A structure containing the fields
CumulativeReward
, StepsTaken
, and
InitialObservation
, which contain, respectively, the
cumulative reward, the number of steps taken, and the initial observations of
the current training episode
The output arguments (passed from evalFcn
to
train
) are:
statistic
— A statistic computed from a group of consecutive
evaluation episodes. Common statistics are the mean, medium, maximum, and minimum.
At the end of the training, this value is returned by train
as
the element of the EvaluationStatistics
vector corresponding to the last training
episode.
scores
— A vector of episode scores from each evaluation
episode. You can use a logger object to store this argument during training.
data
— Any additional data from evaluation that you might
find useful, for example for logging purposes. You can use a logger object to store
this argument during training.
To use additional input arguments beyond the allowed two, define your additional
arguments in the MATLAB workspace, then specify stepFcn
as an anonymous
function that in turn calls your custom function with the additional arguments defined
in the workspace, as shown in the example Create Custom Environment Using Step and Reset Functions.
Example: evalFcn=@myEvalFcn