Classification loss for observations not used for training
L = kfoldLoss(obj)
L = kfoldLoss(obj,Name,Value)
L = kfoldLoss(obj) returns loss obtained by cross-validated classification model obj. For every fold, this method computes classification loss for in-fold observations using a model trained on out-of-fold observations.
L = kfoldLoss(obj,Name,Value) calculates loss with additional options specified by one or more Name,Value pair arguments. You can specify several name-value pair arguments in any order as Name1,Value1,…,NameN,ValueN.
Object of class ClassificationPartitionedModel.
Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and Value is the corresponding value. Name must appear inside single quotes (' '). You can specify several name and value pair arguments in any order as Name1,Value1,...,NameN,ValueN.
Indices of folds ranging from 1 to obj.KFold. Use only these folds for predictions.
Function handle or string representing a loss function. Built-in loss functions:
You can write your own loss function in the syntax described in Loss Functions.
A string for determining the output of kfoldLoss:
Loss, by default the fraction of misclassified data. L can be a vector, and can mean different things, depending on the name-value pair settings.
The default classification error is the fraction of the data X that obj misclassifies, where Y are the true classifications.
Weighted classification error is the sum of weight i times the Boolean value that is 1 when obj misclassifies the ith row of X, divided by the sum of the weights.
The built-in loss functions are:
'binodeviance' — For binary classification, assume the classes yn are -1 and 1. With weight vector w normalized to have sum 1, and predictions of row n of data X as f(Xn), the binomial deviance is
'exponential' — With the same definitions as for 'binodeviance', the exponential loss is
'classiferror' — Predict the label with the largest posterior probability. The loss is then the fraction of misclassified observations.
'hinge' — Classification error measure that has the form
wj is weight j.
For binary classification, yj = 1 for the positive class and -1 for the negative class. For problems where the number of classes K > 3, yj is a vector of 0s, but with a 1 in the position corresponding to the true class, e.g., if the second observation is in the third class and K = 4, then y2 = [0 0 1 0]′.
is, for binary classification, the posterior probability or, for K > 3, a vector of posterior probabilities for each class given observation j.
'mincost' — Predict the label with the smallest expected misclassification cost, with expectation taken over the posterior probability, and cost as given by the Cost property of the classifier (a matrix). The loss is then the true misclassification cost averaged over the observations.
To write your own loss function, create a function file in this form:
function loss = lossfun(C,S,W,COST)
N is the number of rows of X.
K is the number of classes in the classifier, represented in the ClassNames property.
C is an N-by-K logical matrix, with one true per row for the true class. The index for each class is its position in the ClassNames property.
S is an N-by-K numeric matrix. S is a matrix of posterior probabilities for classes with one row per observation, similar to the posterior output from predict.
W is a numeric vector with N elements, the observation weights. If you pass W, the elements are normalized to sum to the prior probabilities in the respective classes.
COST is a K-by-K numeric matrix of misclassification costs. For example, you can use COST = ones(K) - eye(K), which means a cost of 0 for correct classification, and 1 for misclassification.
The output loss should be a scalar.
Pass the function handle @lossfun as the value of the LossFun name-value pair.
Find the average cross-validated classification error for a model of the ionosphere data:
load ionosphere tree = fitctree(X,Y); cvtree = crossval(tree); L = kfoldLoss(cvtree) L = 0.1197