Main Content

fitcnet

Train neural network classification model

Description

Use fitcnet to train a feedforward, fully connected neural network for classification. The first fully connected layer of the neural network has a connection from the network input (predictor data), and each subsequent layer has a connection from the previous layer. Each fully connected layer multiplies the input by a weight matrix and then adds a bias vector. An activation function follows each fully connected layer. The final fully connected layer and the subsequent softmax activation function produce the network's output, namely classification scores (posterior probabilities) and predicted labels. For more information, see Neural Network Structure.

example

Mdl = fitcnet(Tbl,ResponseVarName) returns a neural network classification model Mdl trained using the predictors in the table Tbl and the class labels in the ResponseVarName table variable.

Mdl = fitcnet(Tbl,formula) returns a neural network classification model trained using the sample data in the table Tbl. The input argument formula is an explanatory model of the response and a subset of the predictor variables in Tbl used to fit Mdl.

Mdl = fitcnet(Tbl,Y) returns a neural network classification model using the predictor variables in the table Tbl and the class labels in vector Y.

example

Mdl = fitcnet(X,Y) returns a neural network classification model trained using the predictors in the matrix X and the class labels in vector Y.

example

Mdl = fitcnet(___,Name,Value) specifies options using one or more name-value arguments in addition to any of the input argument combinations in previous syntaxes. For example, you can adjust the number of outputs and the activation functions for the fully connected layers by specifying the LayerSizes and Activations name-value arguments.

Examples

collapse all

Train a neural network classifier, and assess the performance of the classifier on a test set.

Read the sample file CreditRating_Historical.dat into a table. The predictor data consists of financial ratios and industry sector information for a list of corporate customers. The response variable consists of credit ratings assigned by a rating agency. Preview the first few rows of the data set.

creditrating = readtable("CreditRating_Historical.dat");
head(creditrating)
ans=8×8 table
     ID      WC_TA     RE_TA     EBIT_TA    MVE_BVTD    S_TA     Industry    Rating 
    _____    ______    ______    _______    ________    _____    ________    _______

    62394     0.013     0.104     0.036      0.447      0.142        3       {'BB' }
    48608     0.232     0.335     0.062      1.969      0.281        8       {'A'  }
    42444     0.311     0.367     0.074      1.935      0.366        1       {'A'  }
    48631     0.194     0.263     0.062      1.017      0.228        4       {'BBB'}
    43768     0.121     0.413     0.057      3.647      0.466       12       {'AAA'}
    39255    -0.117    -0.799      0.01      0.179      0.082        4       {'CCC'}
    62236     0.087     0.158     0.049      0.816      0.324        2       {'BBB'}
    39354     0.005     0.181     0.034      2.597      0.388        7       {'AA' }

Because each value in the ID variable is a unique customer ID, that is, length(unique(creditrating.ID)) is equal to the number of observations in creditrating, the ID variable is a poor predictor. Remove the ID variable from the table, and convert the Industry variable to a categorical variable.

creditrating = removevars(creditrating,"ID");
creditrating.Industry = categorical(creditrating.Industry);

Convert the Rating response variable to an ordinal categorical variable.

creditrating.Rating = categorical(creditrating.Rating, ...
    ["AAA","AA","A","BBB","BB","B","CCC"],"Ordinal",true);

Partition the data into training and test sets. Use approximately 80% of the observations to train a neural network model, and 20% of the observations to test the performance of the trained model on new data. Use cvpartition to partition the data.

rng("default") % For reproducibility of the partition
c = cvpartition(creditrating.Rating,"Holdout",0.20);
trainingIndices = training(c); % Indices for the training set
testIndices = test(c); % Indices for the test set
creditTrain = creditrating(trainingIndices,:);
creditTest = creditrating(testIndices,:);

Train a neural network classifier by passing the training data creditTrain to the fitcnet function.

Mdl = fitcnet(creditTrain,"Rating")
Mdl = 
  ClassificationNeuralNetwork
           PredictorNames: {'WC_TA'  'RE_TA'  'EBIT_TA'  'MVE_BVTD'  'S_TA'  'Industry'}
             ResponseName: 'Rating'
    CategoricalPredictors: 6
               ClassNames: [AAA    AA    A    BBB    BB    B    CCC]
           ScoreTransform: 'none'
          NumObservations: 3146
               LayerSizes: 10
              Activations: 'relu'
    OutputLayerActivation: 'softmax'
                   Solver: 'LBFGS'
          ConvergenceInfo: [1×1 struct]
          TrainingHistory: [1000×7 table]


  Properties, Methods

Mdl is a trained ClassificationNeuralNetwork classifier. You can use dot notation to access the properties of Mdl. For example, you can specify Mdl.TrainingHistory to get more information about the training history of the neural network model.

Evaluate the performance of the classifier on the test set by computing the test set classification error. Visualize the results by using a confusion matrix.

testAccuracy = 1 - loss(Mdl,creditTest,"Rating", ...
    "LossFun","classiferror")
testAccuracy = 0.8003
confusionchart(creditTest.Rating,predict(Mdl,creditTest))

Specify the structure of a neural network classifier, including the size of the fully connected layers.

Load the ionosphere data set, which includes radar signal data. X contains the predictor data, and Y is the response variable, whose values represent either good ("g") or bad ("b") radar signals.

load ionosphere

Separate the data into training data (XTrain and YTrain) and test data (XTest and YTest) by using a stratified holdout partition. Reserve approximately 30% of the observations for testing, and use the rest of the observations for training.

rng("default") % For reproducibility of the partition
cvp = cvpartition(Y,"Holdout",0.3);
XTrain = X(training(cvp),:);
YTrain = Y(training(cvp));
XTest = X(test(cvp),:);
YTest = Y(test(cvp));

Train a neural network classifier. Specify to have 35 outputs in the first fully connected layer and 20 outputs in the second fully connected layer. By default, both layers use a rectified linear unit (ReLU) activation function. You can change the activation functions for the fully connected layers by using the Activations name-value argument.

Mdl = fitcnet(XTrain,YTrain, ...
    "LayerSizes",[35 20])
Mdl = 
  ClassificationNeuralNetwork
             ResponseName: 'Y'
    CategoricalPredictors: []
               ClassNames: {'b'  'g'}
           ScoreTransform: 'none'
          NumObservations: 246
               LayerSizes: [35 20]
              Activations: 'relu'
    OutputLayerActivation: 'softmax'
                   Solver: 'LBFGS'
          ConvergenceInfo: [1×1 struct]
          TrainingHistory: [47×7 table]


  Properties, Methods

Access the weights and biases for the fully connected layers of the trained classifier by using the LayerWeights and LayerBiases properties of Mdl. The first two elements of each property correspond to the values for the first two fully connected layers, and the third element corresponds to the values for the final fully connected layer with a softmax activation function for classification. For example, display the weights and biases for the second fully connected layer.

Mdl.LayerWeights{2}
ans = 20×35

    0.0481    0.2501   -0.1535   -0.0934    0.0760   -0.0579   -0.2465    1.0411    0.3712   -1.2007    1.1162    0.4296    0.4045    0.5005    0.8839    0.4624   -0.3154    0.3454   -0.0487    0.2648    0.0732    0.5773    0.4286    0.0881    0.9468    0.2981    0.5534    1.0518   -0.0224    0.6894    0.5527    0.7045   -0.6124    0.2145   -0.0790
   -0.9489   -1.8343    0.5510   -0.5751   -0.8726    0.8815    0.0203   -1.6379    2.0315    1.7599   -1.4153   -1.4335   -1.1638   -0.1715    1.1439   -0.7661    1.1230   -1.1982   -0.5409   -0.5821   -0.0627   -0.7038   -0.0817   -1.5773   -1.4671    0.2053   -0.7931   -1.6201   -0.1737   -0.7762   -0.3063   -0.8771    1.5134   -0.4611   -0.0649
   -0.1910    0.0246   -0.3511    0.0097    0.3160   -0.0693    0.2270   -0.0783   -0.1626   -0.3478    0.2765    0.4179    0.0727   -0.0314   -0.1798   -0.0583    0.1375   -0.1876    0.2518    0.2137    0.1497    0.0395    0.2859   -0.0905    0.4325   -0.2012    0.0388   -0.1441   -0.1431   -0.0249   -0.2200    0.0860   -0.2076    0.0132    0.1737
   -0.0415   -0.0059   -0.0753   -0.1477   -0.1621   -0.1762    0.2164    0.1710   -0.0610   -0.1402    0.1452    0.2890    0.2872   -0.2616   -0.4204   -0.2831   -0.1901    0.0036    0.0781   -0.0826    0.1588   -0.2782    0.2510   -0.1069   -0.2692    0.2306    0.2521    0.0306    0.2524   -0.4218    0.2478    0.2343   -0.1031    0.1037    0.1598
    1.1848    1.6142   -0.1352    0.5774    0.5491    0.0103    0.0209    0.7219   -0.8643   -0.5578    1.3595    1.5385    1.0015    0.7416   -0.4342    0.2279    0.5667    1.1589    0.7100    0.1823    0.4171    0.7051    0.0794    1.3267    1.2659    0.3197    0.3947    0.3436   -0.1415    0.6607    1.0071    0.7726   -0.2840    0.8801    0.0848
    0.2486   -0.2920   -0.0004    0.2806    0.2987   -0.2709    0.1473   -0.2580   -0.0499   -0.0755    0.2000    0.1535   -0.0285   -0.0520   -0.2523   -0.2505   -0.0437   -0.2323    0.2023    0.2061   -0.1365    0.0744    0.0344   -0.2891    0.2341   -0.1556    0.1459    0.2533   -0.0583    0.0243   -0.2949   -0.1530    0.1546   -0.0340   -0.1562
   -0.0516    0.0640    0.1824   -0.0675   -0.2065   -0.0052   -0.1682   -0.1520    0.0060    0.0450    0.0813   -0.0234    0.0657    0.3219   -0.1871    0.0658   -0.2103    0.0060   -0.2831   -0.1811   -0.0988    0.2378   -0.0761    0.1714   -0.1596   -0.0011    0.0609    0.4003    0.3687   -0.2879    0.0910    0.0604   -0.2222   -0.2735   -0.1155
   -0.6192   -0.7804   -0.0506   -0.4205   -0.2584   -0.2020   -0.0008    0.0534    1.0185   -0.0307   -0.0539   -0.2020    0.0368   -0.1847    0.0886   -0.4086   -0.4648   -0.3785    0.1542   -0.5176   -0.3207    0.1893   -0.0313   -0.5297   -0.1261   -0.2749   -0.6152   -0.5914   -0.3089    0.2432   -0.3955   -0.1711    0.1710   -0.4477    0.0718
    0.5049   -0.1362   -0.2218    0.1637   -0.1282   -0.1008    0.1445    0.4527   -0.4887    0.0503    0.1453    0.1316   -0.3311   -0.1081   -0.7699    0.4062   -0.1105   -0.0855    0.0630   -0.1469   -0.2533    0.3976    0.0418    0.5294    0.3982    0.1027   -0.0973   -0.1282    0.2491    0.0425    0.0533    0.1578   -0.8403   -0.0535   -0.0048
    1.1109   -0.0466    0.4044    0.6366    0.1863    0.5660    0.2839    0.8793   -0.5497    0.0057    0.3468    0.0980    0.3364    0.4669    0.1466    0.7883   -0.1743    0.4444    0.4535    0.1521    0.7476    0.2246    0.4473    0.2829    0.8881    0.4666    0.6334    0.3105    0.9571    0.2808    0.6483    0.1180   -0.4558    1.2486    0.2453
      ⋮

Mdl.LayerBiases{2}
ans = 20×1

    0.6147
    0.1891
   -0.2767
   -0.2977
    1.3655
    0.0347
    0.1509
   -0.4839
   -0.3960
    0.9248
      ⋮

The final fully connected layer has two outputs, one for each class in the response variable. The number of layer outputs corresponds to the first dimension of the layer weights and layer biases.

size(Mdl.LayerWeights{end})
ans = 1×2

     2    20

size(Mdl.LayerBiases{end})
ans = 1×2

     2     1

To estimate the performance of the trained classifier, compute the test set classification error for Mdl.

testError = loss(Mdl,XTest,YTest, ...
    "LossFun","classiferror")
testError = 0.0774
accuracy = 1 - testError
accuracy = 0.9226

Mdl accurately classifies approximately 92% of the observations in the test set.

At each iteration of the training process, compute the validation loss of the neural network. Stop the training process early if the validation loss reaches a reasonable minimum.

Load the patients data set. Create a table from the data set. Each row corresponds to one patient, and each column corresponds to a diagnostic variable. Use the Smoker variable as the response variable, and the rest of the variables as predictors.

load patients
tbl = table(Diastolic,Systolic,Gender,Height,Weight,Age,Smoker);

Separate the data into a training set tblTrain and a validation set tblValidation by using a stratified holdout partition. The software reserves approximately 30% of the observations for the validation data set and uses the rest of the observations for the training data set.

rng("default") % For reproducibility of the partition
c = cvpartition(tbl.Smoker,"Holdout",0.30);
trainingIndices = training(c);
validationIndices = test(c);
tblTrain = tbl(trainingIndices,:);
tblValidation = tbl(validationIndices,:);

Train a neural network classifier by using the training set. Specify the Smoker column of tblTrain as the response variable. Evaluate the model at each iteration by using the validation set. Specify to display the training information at each iteration by using the Verbose name-value argument. By default, the training process ends early if the validation cross-entropy loss is greater than or equal to the minimum validation cross-entropy loss computed so far, six times in a row. To change the number of times the validation loss is allowed to be greater than or equal to the minimum, specify the ValidationPatience name-value argument.

Mdl = fitcnet(tblTrain,"Smoker", ...
    "ValidationData",tblValidation, ...
    "Verbose",1);
|==========================================================================================|
| Iteration  | Train Loss | Gradient   | Step       | Iteration  | Validation | Validation |
|            |            |            |            | Time (sec) | Loss       | Checks     |
|==========================================================================================|
|           1|    2.602935|   26.866935|    0.262009|    0.001800|    2.793048|           0|
|           2|    1.470816|   42.594723|    0.058323|    0.001460|    1.247046|           0|
|           3|    1.299292|   25.854432|    0.034910|    0.000456|    1.507857|           1|
|           4|    0.710465|   11.629107|    0.013616|    0.000617|    0.889157|           0|
|           5|    0.647783|    2.561740|    0.005753|    0.000957|    0.766728|           0|
|           6|    0.645541|    0.681579|    0.001000|    0.000706|    0.776072|           1|
|           7|    0.639611|    1.544692|    0.007013|    0.005517|    0.776320|           2|
|           8|    0.604189|    5.045676|    0.064190|    0.000534|    0.744919|           0|
|           9|    0.565364|    5.851552|    0.068845|    0.000504|    0.694226|           0|
|          10|    0.391994|    8.377717|    0.560480|    0.000370|    0.425466|           0|
|==========================================================================================|
| Iteration  | Train Loss | Gradient   | Step       | Iteration  | Validation | Validation |
|            |            |            |            | Time (sec) | Loss       | Checks     |
|==========================================================================================|
|          11|    0.383843|    0.630246|    0.110270|    0.000749|    0.428487|           1|
|          12|    0.369289|    2.404750|    0.084395|    0.000531|    0.405728|           0|
|          13|    0.357839|    6.220679|    0.199197|    0.000353|    0.378480|           0|
|          14|    0.344974|    2.752717|    0.029013|    0.000330|    0.367279|           0|
|          15|    0.333747|    0.711398|    0.074513|    0.000328|    0.348499|           0|
|          16|    0.327763|    0.804818|    0.122178|    0.000348|    0.330237|           0|
|          17|    0.327702|    0.778169|    0.009810|    0.000365|    0.329095|           0|
|          18|    0.327277|    0.020615|    0.004377|    0.000380|    0.329141|           1|
|          19|    0.327273|    0.010018|    0.003313|    0.000432|    0.328773|           0|
|          20|    0.327268|    0.019497|    0.000805|    0.000776|    0.328831|           1|
|==========================================================================================|
| Iteration  | Train Loss | Gradient   | Step       | Iteration  | Validation | Validation |
|            |            |            |            | Time (sec) | Loss       | Checks     |
|==========================================================================================|
|          21|    0.327228|    0.113983|    0.005397|    0.000509|    0.329085|           2|
|          22|    0.327138|    0.240166|    0.012159|    0.000333|    0.329406|           3|
|          23|    0.326865|    0.428912|    0.036841|    0.000381|    0.329952|           4|
|          24|    0.325797|    0.255227|    0.139585|    0.000339|    0.331246|           5|
|          25|    0.325181|    0.758050|    0.135868|    0.000890|    0.332035|           6|
|==========================================================================================|

Create a plot that compares the training cross-entropy loss and the validation cross-entropy loss at each iteration. By default, fitcnet stores the loss information inside the TrainingHistory property of the object Mdl. You can access this information by using dot notation.

iteration = Mdl.TrainingHistory.Iteration;
trainLosses = Mdl.TrainingHistory.TrainingLoss;
valLosses = Mdl.TrainingHistory.ValidationLoss;

plot(iteration,trainLosses,iteration,valLosses)
legend(["Training","Validation"])
xlabel("Iteration")
ylabel("Cross-Entropy Loss")

Check the iteration that corresponds to the minimum validation loss. The final returned model Mdl is the model trained at this iteration.

[~,minIdx] = min(valLosses);
iteration(minIdx)
ans = 19

Assess the cross-validation loss of neural network models with different regularization strengths, and choose the regularization strength corresponding to the best performing model.

Read the sample file CreditRating_Historical.dat into a table. The predictor data consists of financial ratios and industry sector information for a list of corporate customers. The response variable consists of credit ratings assigned by a rating agency. Preview the first few rows of the data set.

creditrating = readtable("CreditRating_Historical.dat");
head(creditrating)
ans=8×8 table
     ID      WC_TA     RE_TA     EBIT_TA    MVE_BVTD    S_TA     Industry    Rating 
    _____    ______    ______    _______    ________    _____    ________    _______

    62394     0.013     0.104     0.036      0.447      0.142        3       {'BB' }
    48608     0.232     0.335     0.062      1.969      0.281        8       {'A'  }
    42444     0.311     0.367     0.074      1.935      0.366        1       {'A'  }
    48631     0.194     0.263     0.062      1.017      0.228        4       {'BBB'}
    43768     0.121     0.413     0.057      3.647      0.466       12       {'AAA'}
    39255    -0.117    -0.799      0.01      0.179      0.082        4       {'CCC'}
    62236     0.087     0.158     0.049      0.816      0.324        2       {'BBB'}
    39354     0.005     0.181     0.034      2.597      0.388        7       {'AA' }

Because each value in the ID variable is a unique customer ID, that is, length(unique(creditrating.ID)) is equal to the number of observations in creditrating, the ID variable is a poor predictor. Remove the ID variable from the table, and convert the Industry variable to a categorical variable.

creditrating = removevars(creditrating,"ID");
creditrating.Industry = categorical(creditrating.Industry);

Convert the Rating response variable to an ordinal categorical variable.

creditrating.Rating = categorical(creditrating.Rating, ...
    ["AAA","AA","A","BBB","BB","B","CCC"],"Ordinal",true);

Create a cvpartition object for stratified 5-fold cross-validation. cvp partitions the data into five folds, where each fold has roughly the same proportions of different credit ratings. Set the random seed to the default value for reproducibility of the partition.

rng("default")
cvp = cvpartition(creditrating.Rating,"KFold",5);

Compute the cross-validation classification error for neural network classifiers with different regularization strengths. Try regularization strengths on the order of 1/n, where n is the number of observations. Specify to standardize the data before training the neural network models.

1/size(creditrating,1)
ans = 2.5432e-04
lambda = (0:0.5:5)*1e-4;
cvloss = zeros(length(lambda),1);

for i = 1:length(lambda)
    cvMdl = fitcnet(creditrating,"Rating","Lambda",lambda(i), ...
        "CVPartition",cvp,"Standardize",true);
    cvloss(i) = kfoldLoss(cvMdl,"LossFun","classiferror");
end

Plot the results. Find the regularization strength corresponding to the lowest cross-validation classification error.

plot(lambda,cvloss)
xlabel("Regularization Strength")
ylabel("Cross-Validation Loss")

[~,idx] = min(cvloss);
bestLambda = lambda(idx)
bestLambda = 5.0000e-05

Train a neural network classifier using the bestLambda regularization strength.

Mdl = fitcnet(creditrating,"Rating","Lambda",bestLambda, ...
    "Standardize",true)
Mdl = 
  ClassificationNeuralNetwork
           PredictorNames: {'WC_TA'  'RE_TA'  'EBIT_TA'  'MVE_BVTD'  'S_TA'  'Industry'}
             ResponseName: 'Rating'
    CategoricalPredictors: 6
               ClassNames: [AAA    AA    A    BBB    BB    B    CCC]
           ScoreTransform: 'none'
          NumObservations: 3932
               LayerSizes: 10
              Activations: 'relu'
    OutputLayerActivation: 'softmax'
                   Solver: 'LBFGS'
          ConvergenceInfo: [1×1 struct]
          TrainingHistory: [1000×7 table]


  Properties, Methods

Train a neural network classifier using the OptimizeHyperparameters argument to improve the resulting classifier. Using this argument causes fitcnet to minimize cross-validation loss over some problem hyperparameters using Bayesian optimization.

Read the sample file CreditRating_Historical.dat into a table. The predictor data consists of financial ratios and industry sector information for a list of corporate customers. The response variable consists of credit ratings assigned by a rating agency. Preview the first few rows of the data set.

creditrating = readtable("CreditRating_Historical.dat");
head(creditrating)
ans=8×8 table
     ID      WC_TA     RE_TA     EBIT_TA    MVE_BVTD    S_TA     Industry    Rating 
    _____    ______    ______    _______    ________    _____    ________    _______

    62394     0.013     0.104     0.036      0.447      0.142        3       {'BB' }
    48608     0.232     0.335     0.062      1.969      0.281        8       {'A'  }
    42444     0.311     0.367     0.074      1.935      0.366        1       {'A'  }
    48631     0.194     0.263     0.062      1.017      0.228        4       {'BBB'}
    43768     0.121     0.413     0.057      3.647      0.466       12       {'AAA'}
    39255    -0.117    -0.799      0.01      0.179      0.082        4       {'CCC'}
    62236     0.087     0.158     0.049      0.816      0.324        2       {'BBB'}
    39354     0.005     0.181     0.034      2.597      0.388        7       {'AA' }

Because each value in the ID variable is a unique customer ID, that is, length(unique(creditrating.ID)) is equal to the number of observations in creditrating, the ID variable is a poor predictor. Remove the ID variable from the table, and convert the Industry variable to a categorical variable.

creditrating = removevars(creditrating,"ID");
creditrating.Industry = categorical(creditrating.Industry);

Convert the Rating response variable to an ordinal categorical variable.

creditrating.Rating = categorical(creditrating.Rating, ...
    ["AAA","AA","A","BBB","BB","B","CCC"],"Ordinal",true);

Partition the data into training and test sets. Use approximately 80% of the observations to train a neural network model, and 20% of the observations to test the performance of the trained model on new data. Use cvpartition to partition the data.

rng("default") % For reproducibility of the partition
c = cvpartition(creditrating.Rating,"Holdout",0.20);
trainingIndices = training(c); % Indices for the training set
testIndices = test(c); % Indices for the test set
creditTrain = creditrating(trainingIndices,:);
creditTest = creditrating(testIndices,:);

Train a neural network classifier by passing the training data creditTrain to the fitcnet function, and include the OptimizeHyperparameters argument. For reproducibility, set the AcquisitionFunctionName to "expected-improvement-plus" in a HyperparameterOptimizationOptions structure. To attempt to get a better solution, set the number of optimization steps to 100 instead of the default 30. fitcnet performs Bayesian optimization by default. To use grid search or random search, set the Optimizer field in HyperparameterOptimizationOptions.

rng("default") % For reproducibility
Mdl = fitcnet(creditTrain,"Rating","OptimizeHyperparameters","auto", ...
    "HyperparameterOptimizationOptions", ...
    struct("AcquisitionFunctionName","expected-improvement-plus", ...
    "MaxObjectiveEvaluations",100))
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|    1 | Best   |     0.55944 |      4.4429 |     0.55944 |     0.55944 |         none |         true |      0.05834 |  3                    |
|    2 | Best   |     0.21329 |       18.59 |     0.21329 |     0.22705 |         relu |         true |   5.0811e-08 | [  1  25]             |
|    3 | Accept |     0.74189 |     0.82112 |     0.21329 |     0.21335 |      sigmoid |         true |      0.57986 |  126                  |
|    4 | Accept |      0.4501 |      1.0542 |     0.21329 |     0.21351 |         tanh |        false |     0.018683 |  10                   |
|    5 | Accept |     0.23045 |      63.554 |     0.21329 |     0.21579 |         relu |         true |   4.6536e-09 | [  1 229   3]         |
|    6 | Accept |     0.74189 |     0.78256 |     0.21329 |     0.21781 |         relu |         true |       6.1298 |  294                  |
|    7 | Accept |     0.74189 |      0.3333 |     0.21329 |     0.21338 |         relu |         true |       27.304 | [  1   3]             |
|    8 | Accept |      0.2651 |      16.999 |     0.21329 |     0.21358 |         relu |         true |   8.0246e-07 | [ 37   2]             |
|    9 | Accept |     0.22759 |      19.265 |     0.21329 |     0.21361 |         tanh |        false |   3.1805e-09 | [ 15   1]             |
|   10 | Accept |     0.23713 |      19.309 |     0.21329 |     0.21358 |         tanh |        false |   2.5491e-07 | [ 23   2]             |
|   11 | Accept |     0.21774 |       95.59 |     0.21329 |     0.21368 |         tanh |        false |   7.5659e-09 | [  3  20 285]         |
|   12 | Accept |     0.27813 |      40.925 |     0.21329 |     0.21365 |         relu |        false |   3.3558e-09 |  140                  |
|   13 | Accept |     0.21805 |      56.019 |     0.21329 |     0.21368 |         relu |        false |   0.00012665 | [  2 208  22]         |
|   14 | Accept |     0.74189 |     0.38445 |     0.21329 |     0.21346 |         relu |        false |      0.96119 | [ 39 119   4]         |
|   15 | Accept |     0.26414 |      15.215 |     0.21329 |     0.21339 |         relu |        false |    2.023e-06 | [ 26  17]             |
|   16 | Accept |     0.29593 |      47.519 |     0.21329 |     0.21339 |         tanh |         true |   3.3214e-09 | [300 127]             |
|   17 | Accept |     0.28798 |      84.109 |     0.21329 |     0.21339 |         tanh |         true |    3.101e-05 | [ 64 165]             |
|   18 | Accept |     0.74189 |     0.56853 |     0.21329 |     0.21338 |         tanh |         true |       1.2557 | [153  94]             |
|   19 | Accept |     0.22982 |      83.717 |     0.21329 |      0.2134 |         tanh |         true |    4.427e-07 | [  5   4 292]         |
|   20 | Accept |     0.22505 |       51.26 |     0.21329 |      0.2134 |      sigmoid |        false |    3.189e-09 | [  7 162]             |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   21 | Accept |     0.21456 |      60.938 |     0.21329 |     0.21341 |      sigmoid |        false |   2.5984e-06 | [  3 224]             |
|   22 | Accept |      0.7136 |     0.44787 |     0.21329 |     0.21337 |      sigmoid |        false |     0.015582 |  6                    |
|   23 | Accept |     0.27146 |       42.77 |     0.21329 |     0.21335 |      sigmoid |        false |   1.2532e-07 |  123                  |
|   24 | Accept |     0.22028 |      48.545 |     0.21329 |     0.21333 |         none |        false |   3.2499e-09 | [ 30 146]             |
|   25 | Accept |     0.21329 |       13.21 |     0.21329 |      0.2133 |         none |        false |   6.8052e-07 | [  8   2]             |
|   26 | Accept |     0.21424 |      13.527 |     0.21329 |     0.21328 |         none |        false |   0.00082724 | [  1   7 225]         |
|   27 | Accept |     0.74189 |     0.30095 |     0.21329 |     0.21328 |         none |        false |       2.7706 | [  2 201]             |
|   28 | Accept |     0.21551 |      24.077 |     0.21329 |     0.21331 |         none |        false |   4.2331e-05 | [  1  19  52]         |
|   29 | Accept |      0.2206 |      53.353 |     0.21329 |     0.21334 |         none |        false |   4.2518e-08 |  266                  |
|   30 | Accept |     0.21996 |      6.5484 |     0.21329 |     0.21334 |         none |         true |   3.3059e-09 |  13                   |
|   31 | Accept |     0.21551 |      17.833 |     0.21329 |     0.21334 |         none |         true |   2.6343e-07 | [  3  19   3]         |
|   32 | Accept |     0.28576 |      81.849 |     0.21329 |     0.21334 |      sigmoid |         true |   3.1878e-09 | [ 16 294]             |
|   33 | Accept |      0.2206 |      5.8928 |     0.21329 |     0.21334 |         none |         true |   3.3018e-08 |  28                   |
|   34 | Accept |     0.21488 |      71.221 |     0.21329 |     0.21334 |      sigmoid |         true |   7.9762e-07 | [  1   5 286]         |
|   35 | Accept |     0.31564 |      24.922 |     0.21329 |     0.21334 |      sigmoid |         true |   1.1735e-07 | [ 51   8]             |
|   36 | Accept |     0.21678 |       48.21 |     0.21329 |     0.21332 |         none |         true |   2.1257e-08 | [  4  27 210]         |
|   37 | Accept |     0.21742 |      59.952 |     0.21329 |     0.21332 |      sigmoid |         true |   1.8694e-05 | [  3 235]             |
|   38 | Accept |     0.22092 |      29.291 |     0.21329 |     0.21332 |         none |         true |   1.3405e-05 | [  7  77   8]         |
|   39 | Accept |     0.74189 |     0.31529 |     0.21329 |     0.21332 |         tanh |        false |       31.775 | [  4   8]             |
|   40 | Accept |     0.27082 |      149.94 |     0.21329 |     0.21332 |         tanh |        false |   3.6794e-05 | [219 240]             |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   41 | Accept |     0.21678 |      20.465 |     0.21329 |     0.21334 |      sigmoid |         true |     3.81e-06 | [  2  16  25]         |
|   42 | Accept |     0.22155 |      9.4112 |     0.21329 |     0.20714 |         none |        false |   0.00019388 |  285                  |
|   43 | Accept |     0.21742 |      25.778 |     0.21329 |     0.20712 |         none |         true |   2.1217e-06 | [ 87   3]             |
|   44 | Accept |     0.21488 |      60.391 |     0.21329 |     0.20711 |         relu |        false |   3.3101e-05 | [  1   5 257]         |
|   45 | Accept |     0.21488 |      13.197 |     0.21329 |     0.21329 |         none |        false |   4.5453e-06 | [  1   3]             |
|   46 | Accept |     0.21488 |      10.038 |     0.21329 |     0.20777 |         none |        false |   3.4008e-08 | [  1   5]             |
|   47 | Accept |     0.21488 |       12.93 |     0.21329 |     0.20775 |      sigmoid |        false |    1.006e-05 | [  1   3]             |
|   48 | Accept |     0.21996 |      6.8334 |     0.21329 |     0.21332 |      sigmoid |         true |    3.829e-06 |  2                    |
|   49 | Accept |     0.22155 |      126.94 |     0.21329 |     0.21332 |      sigmoid |         true |   0.00015279 | [133  92 283]         |
|   50 | Best   |     0.21202 |      48.253 |     0.21202 |     0.21206 |         relu |         true |   0.00020411 | [  1 158  39]         |
|   51 | Accept |     0.29053 |      140.77 |     0.21202 |      0.2122 |         relu |         true |   4.8947e-05 | [ 14 259 264]         |
|   52 | Accept |     0.24666 |      46.379 |     0.21202 |     0.21236 |         relu |         true |    0.0017423 | [ 96  60]             |
|   53 | Accept |      0.2314 |      132.63 |     0.21202 |     0.21238 |         relu |         true |    0.0004174 | [237 295]             |
|   54 | Accept |     0.36968 |      1.3587 |     0.21202 |     0.20862 |         relu |         true |   0.00058355 |  1                    |
|   55 | Accept |     0.22791 |      38.591 |     0.21202 |     0.21217 |      sigmoid |         true |    2.537e-05 | [ 63   1  23]         |
|   56 | Accept |     0.22314 |      50.941 |     0.21202 |     0.21218 |      sigmoid |        false |   1.9802e-06 | [ 10   1 174]         |
|   57 | Accept |     0.22505 |      10.489 |     0.21202 |     0.21384 |         tanh |         true |   4.2741e-07 |  5                    |
|   58 | Accept |     0.21488 |      135.54 |     0.21202 |     0.21234 |         none |        false |   2.1727e-07 | [234 300   1]         |
|   59 | Accept |     0.42912 |      35.118 |     0.21202 |      0.2116 |         relu |         true |    0.0010189 | [  2 271   4]         |
|   60 | Accept |     0.31818 |      59.012 |     0.21202 |     0.21147 |         relu |         true |    3.179e-09 |  281                  |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   61 | Accept |     0.21678 |      42.051 |     0.21202 |     0.21143 |      sigmoid |        false |   4.8212e-07 | [  1   2 110]         |
|   62 | Accept |     0.21583 |      53.945 |     0.21202 |     0.21134 |         none |        false |   2.0278e-05 | [298   2]             |
|   63 | Accept |      0.2136 |      8.4188 |     0.21202 |     0.20979 |         none |         true |   1.0782e-06 |  1                    |
|   64 | Accept |      0.2171 |      43.599 |     0.21202 |     0.21116 |         none |        false |   4.6304e-05 | [268   4]             |
|   65 | Accept |     0.21488 |      48.532 |     0.21202 |     0.21111 |         none |         true |    2.743e-07 | [297   2]             |
|   66 | Accept |     0.21901 |        6.22 |     0.21202 |     0.21064 |         none |        false |   8.4149e-05 | [  1  42]             |
|   67 | Accept |     0.32517 |      31.934 |     0.21202 |     0.21055 |      sigmoid |         true |   3.2658e-05 | [  1   1 131]         |
|   68 | Accept |     0.26891 |       63.64 |     0.21202 |      0.2105 |      sigmoid |         true |   5.5718e-06 |  287                  |
|   69 | Accept |     0.22664 |      65.645 |     0.21202 |     0.21063 |         tanh |        false |   2.4001e-08 | [276   2]             |
|   70 | Accept |     0.21488 |      17.145 |     0.21202 |     0.21209 |         none |         true |   2.6613e-07 | [  1  89   2]         |
|   71 | Accept |     0.31119 |      183.97 |     0.21202 |     0.21325 |      sigmoid |         true |   6.9584e-09 | [283 219 251]         |
|   72 | Accept |     0.26669 |      69.335 |     0.21202 |     0.21209 |         relu |        false |   4.3556e-05 | [296  56]             |
|   73 | Accept |     0.26478 |      41.246 |     0.21202 |     0.21239 |         relu |        false |   7.2907e-07 | [163  13  30]         |
|   74 | Accept |     0.21202 |      38.512 |     0.21202 |     0.21205 |         relu |         true |   9.7142e-06 | [  1 206]             |
|   75 | Accept |     0.21392 |      12.254 |     0.21202 |     0.21202 |      sigmoid |         true |   6.7548e-06 | [  1  18   4]         |
|   76 | Accept |     0.22123 |      70.416 |     0.21202 |     0.21311 |         none |        false |    9.381e-06 | [ 21 299  96]         |
|   77 | Accept |     0.21774 |      8.8834 |     0.21202 |     0.21268 |         none |        false |   3.2274e-09 |  3                    |
|   78 | Accept |     0.21488 |      26.186 |     0.21202 |     0.21358 |         none |         true |   4.9871e-07 | [  1 269]             |
|   79 | Accept |     0.22155 |       7.719 |     0.21202 |     0.21364 |      sigmoid |        false |   1.0684e-06 |  1                    |
|   80 | Accept |     0.28798 |      127.45 |     0.21202 |     0.21359 |         tanh |         true |    5.792e-07 | [298 179]             |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   81 | Accept |     0.21869 |      42.326 |     0.21202 |     0.21396 |         none |         true |   3.2482e-09 | [292   4  30]         |
|   82 | Accept |     0.21456 |      4.5781 |     0.21202 |     0.21398 |         none |        false |   1.0932e-07 |  1                    |
|   83 | Accept |     0.21456 |       56.88 |     0.21202 |     0.21401 |         tanh |        false |   4.2509e-08 | [  1 245]             |
|   84 | Accept |     0.21424 |      13.453 |     0.21202 |     0.21405 |      sigmoid |        false |   3.2874e-09 | [  1  26]             |
|   85 | Accept |     0.21678 |      10.635 |     0.21202 |     0.21404 |         tanh |         true |   4.1779e-08 | [  1   8]             |
|   86 | Accept |     0.22028 |      47.716 |     0.21202 |       0.212 |         none |         true |   1.1854e-06 | [295  32]             |
|   87 | Accept |     0.21742 |      33.925 |     0.21202 |       0.212 |         relu |        false |   3.9749e-08 | [  1 153]             |
|   88 | Accept |     0.21392 |      36.047 |     0.21202 |     0.21424 |         tanh |        false |   9.5415e-06 | [  1 103]             |
|   89 | Accept |     0.21233 |        16.3 |     0.21202 |     0.21423 |         tanh |        false |   1.0503e-06 | [  1  17   2]         |
|   90 | Accept |     0.23299 |      9.2509 |     0.21202 |     0.21427 |         relu |        false |   1.3237e-05 |  1                    |
|   91 | Accept |     0.21488 |      3.4455 |     0.21202 |       0.212 |         none |         true |    3.546e-09 | [  1 110]             |
|   92 | Accept |     0.21742 |      10.494 |     0.21202 |     0.21431 |         relu |         true |   5.6941e-05 | [  1  29]             |
|   93 | Accept |     0.21647 |      9.7543 |     0.21202 |     0.21431 |         tanh |         true |    1.895e-06 | [  1   4]             |
|   94 | Accept |     0.21456 |      33.436 |     0.21202 |     0.21431 |         relu |         true |   6.2404e-07 | [  1 160]             |
|   95 | Accept |     0.21901 |      2.8367 |     0.21202 |     0.21433 |         none |        false |   0.00013257 | [  1   1]             |
|   96 | Accept |     0.21424 |      35.446 |     0.21202 |     0.21182 |      sigmoid |        false |   2.1124e-08 | [  1 131]             |
|   97 | Accept |     0.21742 |      13.191 |     0.21202 |      0.2143 |         relu |         true |   1.0947e-05 | [  2  13  15]         |
|   98 | Best   |      0.2117 |      8.2787 |      0.2117 |     0.21427 |         tanh |         true |    3.183e-09 |  1                    |
|   99 | Accept |     0.54895 |      4.6185 |      0.2117 |     0.21009 |         relu |        false |   3.3662e-09 | [  1   4]             |
|  100 | Accept |     0.27972 |      49.201 |      0.2117 |      0.2128 |         relu |        false |   3.7247e-08 | [239  20]             |

__________________________________________________________
Optimization completed.
MaxObjectiveEvaluations of 100 reached.
Total function evaluations: 100
Total elapsed time: 3855.2145 seconds
Total objective function evaluation time: 3767.578

Best observed feasible point:
    Activations    Standardize     Lambda      LayerSizes
    ___________    ___________    _________    __________

       tanh           true        3.183e-09        1     

Observed objective function value = 0.2117
Estimated objective function value = 0.25267
Function evaluation time = 8.2787

Best estimated feasible point (according to models):
    Activations    Standardize      Lambda       LayerSizes  
    ___________    ___________    __________    _____________

       none           false       4.2331e-05    1    19    52

Estimated objective function value = 0.2128
Estimated function evaluation time = 23.627
Mdl = 
  ClassificationNeuralNetwork
                       PredictorNames: {'WC_TA'  'RE_TA'  'EBIT_TA'  'MVE_BVTD'  'S_TA'  'Industry'}
                         ResponseName: 'Rating'
                CategoricalPredictors: 6
                           ClassNames: [AAA    AA    A    BBB    BB    B    CCC]
                       ScoreTransform: 'none'
                      NumObservations: 3146
    HyperparameterOptimizationResults: [1×1 BayesianOptimization]
                           LayerSizes: [1 19 52]
                          Activations: 'none'
                OutputLayerActivation: 'softmax'
                               Solver: 'LBFGS'
                      ConvergenceInfo: [1×1 struct]
                      TrainingHistory: [753×7 table]


  Properties, Methods

Mdl is a trained ClassificationNeuralNetwork classifier. The model corresponds to the best estimated feasible point, as opposed to the best observed feasible point. (For details on this distinction, see bestPoint.) You can use dot notation to access the properties of Mdl. For example, you can specify Mdl.HyperparameterOptimizationResults to get more information about the optimization of the neural network model.

Find the classification accuracy of the model on the test data set. Visualize the results by using a confusion matrix.

modelAccuracy = 1 - loss(Mdl,creditTest,"Rating", ...
    "LossFun","classiferror")
modelAccuracy = 0.8053
confusionchart(creditTest.Rating,predict(Mdl,creditTest))

The model has all predicted classes within one unit of the true classes, meaning all predictions are off by no more than one rating.

Train a neural network classifier using the OptimizeHyperparameters argument to improve the resulting classification accuracy. Use the hyperparameters function to specify larger-than-default values for the number of layers used and the layer size range.

Read the sample file CreditRating_Historical.dat into a table. The predictor data consists of financial ratios and industry sector information for a list of corporate customers. The response variable consists of credit ratings assigned by a rating agency.

creditrating = readtable("CreditRating_Historical.dat");

Because each value in the ID variable is a unique customer ID, that is, length(unique(creditrating.ID)) is equal to the number of observations in creditrating, the ID variable is a poor predictor. Remove the ID variable from the table, and convert the Industry variable to a categorical variable.

creditrating = removevars(creditrating,"ID");
creditrating.Industry = categorical(creditrating.Industry);

Convert the Rating response variable to an ordinal categorical variable.

creditrating.Rating = categorical(creditrating.Rating, ...
    ["AAA","AA","A","BBB","BB","B","CCC"],"Ordinal",true);

Partition the data into training and test sets. Use approximately 80% of the observations to train a neural network model, and 20% of the observations to test the performance of the trained model on new data. Use cvpartition to partition the data.

rng("default") % For reproducibility of the partition
c = cvpartition(creditrating.Rating,"Holdout",0.20);
trainingIndices = training(c); % Indices for the training set
testIndices = test(c); % Indices for the test set
creditTrain = creditrating(trainingIndices,:);
creditTest = creditrating(testIndices,:);

List the hyperparameters available for this problem of fitting the Rating response.

params = hyperparameters("fitcnet",creditTrain,"Rating");
for ii = 1:length(params)
    disp(ii);disp(params(ii))
end
     1

  optimizableVariable with properties:

         Name: 'NumLayers'
        Range: [1 3]
         Type: 'integer'
    Transform: 'none'
     Optimize: 1

     2

  optimizableVariable with properties:

         Name: 'Activations'
        Range: {'relu'  'tanh'  'sigmoid'  'none'}
         Type: 'categorical'
    Transform: 'none'
     Optimize: 1

     3

  optimizableVariable with properties:

         Name: 'Standardize'
        Range: {'true'  'false'}
         Type: 'categorical'
    Transform: 'none'
     Optimize: 1

     4

  optimizableVariable with properties:

         Name: 'Lambda'
        Range: [3.1786e-09 31.7864]
         Type: 'real'
    Transform: 'log'
     Optimize: 1

     5

  optimizableVariable with properties:

         Name: 'LayerWeightsInitializer'
        Range: {'glorot'  'he'}
         Type: 'categorical'
    Transform: 'none'
     Optimize: 0

     6

  optimizableVariable with properties:

         Name: 'LayerBiasesInitializer'
        Range: {'zeros'  'ones'}
         Type: 'categorical'
    Transform: 'none'
     Optimize: 0

     7

  optimizableVariable with properties:

         Name: 'Layer_1_Size'
        Range: [1 300]
         Type: 'integer'
    Transform: 'log'
     Optimize: 1

     8

  optimizableVariable with properties:

         Name: 'Layer_2_Size'
        Range: [1 300]
         Type: 'integer'
    Transform: 'log'
     Optimize: 1

     9

  optimizableVariable with properties:

         Name: 'Layer_3_Size'
        Range: [1 300]
         Type: 'integer'
    Transform: 'log'
     Optimize: 1

    10

  optimizableVariable with properties:

         Name: 'Layer_4_Size'
        Range: [1 300]
         Type: 'integer'
    Transform: 'log'
     Optimize: 0

    11

  optimizableVariable with properties:

         Name: 'Layer_5_Size'
        Range: [1 300]
         Type: 'integer'
    Transform: 'log'
     Optimize: 0

To try more layers than the default of 1 through 3, set the range of NumLayers (optimizable variable 1) to its maximum allowable size, [1 5]. Also, set Layer_4_Size and Layer_5_Size (optimizable variables 10 and 11, respectively) to be optimized.

params(1).Range = [1 5];
params(10).Optimize = true;
params(11).Optimize = true;

Set the range of all layer sizes (optimizable variables 7 through 11) to [1 400] instead of the default [1 300].

for ii = 7:11
    params(ii).Range = [1 400];
end

Train a neural network classifier by passing the training data creditTrain to the fitcnet function, and include the OptimizeHyperparameters argument set to params. For reproducibility, set the AcquisitionFunctionName to "expected-improvement-plus" in a HyperparameterOptimizationOptions structure. To attempt to get a better solution, set the number of optimization steps to 100 instead of the default 30.

rng("default") % For reproducibility
Mdl = fitcnet(creditTrain,"Rating","OptimizeHyperparameters",params, ...
    "HyperparameterOptimizationOptions", ...
    struct("AcquisitionFunctionName","expected-improvement-plus", ...
    "MaxObjectiveEvaluations",100))
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|    1 | Best   |     0.74189 |      2.9388 |     0.74189 |     0.74189 |      sigmoid |         true |      0.68961 | [104   1   5   3   1] |
|    2 | Best   |      0.2225 |       91.12 |      0.2225 |     0.24316 |         relu |         true |   0.00058564 | [ 38 208 162]         |
|    3 | Accept |     0.64081 |      15.805 |      0.2225 |      0.2269 |      sigmoid |         true |   1.9768e-06 | [  1  25   1 287   7] |
|    4 | Best   |     0.21964 |      42.124 |     0.21964 |     0.22319 |         none |        false |   1.3353e-06 |  320                  |
|    5 | Accept |     0.74189 |     0.27365 |     0.21964 |     0.21968 |         relu |         true |       2.7056 | [  1   2   1]         |
|    6 | Accept |     0.29752 |      119.81 |     0.21964 |     0.21968 |         relu |         true |   1.0503e-06 | [301  31 400]         |
|    7 | Accept |     0.24285 |      49.214 |     0.21964 |     0.21968 |         relu |         true |   3.9171e-07 | [  3 142  56]         |
|    8 | Accept |     0.74189 |      0.5032 |     0.21964 |     0.21968 |         none |         true |      0.18455 |  338                  |
|    9 | Best   |     0.21551 |      10.569 |     0.21551 |     0.21553 |         none |        false |   1.8409e-07 | [ 16   3   7]         |
|   10 | Best   |     0.21456 |      58.812 |     0.21456 |     0.21712 |         none |        false |    3.335e-07 | [ 14   1 389  36]     |
|   11 | Accept |     0.21774 |      31.378 |     0.21456 |     0.21458 |         none |        false |    0.0015351 | [ 14  66  66 400]     |
|   12 | Accept |     0.21774 |      10.648 |     0.21456 |     0.21459 |         none |        false |   0.00089509 | [  8 399]             |
|   13 | Best   |     0.21424 |      30.123 |     0.21424 |     0.21427 |      sigmoid |        false |   1.4746e-06 | [  2  43   2  34  18] |
|   14 | Accept |     0.74189 |      11.099 |     0.21424 |     0.21427 |      sigmoid |        false |   0.00086753 | [  2 220  36 224 170] |
|   15 | Accept |     0.63636 |      12.882 |     0.21424 |      0.2143 |      sigmoid |        false |   8.1218e-06 | [  3  67  55   2  18] |
|   16 | Accept |     0.23363 |      57.487 |     0.21424 |     0.21431 |      sigmoid |        false |   8.5124e-08 | [171  21   1   7]     |
|   17 | Accept |     0.21964 |      55.479 |     0.21424 |     0.21438 |         none |        false |   4.7023e-05 | [ 26 250  10   8  66] |
|   18 | Accept |     0.22028 |      85.705 |     0.21424 |     0.21433 |         none |        false |   1.1411e-07 | [104 186  99]         |
|   19 | Accept |     0.21583 |      94.815 |     0.21424 |     0.21434 |         none |        false |     0.001281 | [153 320   2   2 238] |
|   20 | Accept |     0.74189 |      3.6128 |     0.21424 |     0.21445 |      sigmoid |        false |     0.080845 | [309   2 400]         |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   21 | Accept |     0.29053 |      129.97 |     0.21424 |     0.21444 |         relu |         true |   5.2378e-07 | [ 47  13 122 345  49] |
|   22 | Accept |     0.74189 |     0.56884 |     0.21424 |     0.21447 |      sigmoid |        false |        22.67 | [237  13   2]         |
|   23 | Accept |     0.74189 |     0.52117 |     0.21424 |     0.21443 |         none |        false |       26.916 | [354   1   7  29]     |
|   24 | Accept |     0.56008 |      14.031 |     0.21424 |     0.21436 |         relu |         true |   1.1199e-05 | [ 74  20   4   1]     |
|   25 | Accept |     0.21933 |      50.083 |     0.21424 |     0.21437 |         none |        false |   6.5138e-05 | [ 10  28 266]         |
|   26 | Accept |     0.21996 |       96.38 |     0.21424 |      0.2144 |         none |        false |    8.653e-06 | [ 28 140  91 254]     |
|   27 | Accept |     0.21647 |      21.086 |     0.21424 |     0.21439 |         none |        false |   7.8745e-05 | [ 87   1  21  14]     |
|   28 | Accept |     0.23109 |      36.618 |     0.21424 |     0.21446 |      sigmoid |        false |   2.9094e-06 | [111   4]             |
|   29 | Accept |     0.22028 |      60.117 |     0.21424 |     0.21446 |         none |        false |   3.4241e-09 | [ 87 183   2  21]     |
|   30 | Accept |     0.74189 |     0.76418 |     0.21424 |     0.21434 |         relu |         true |     0.096418 | [ 26  10 385]         |
|   31 | Accept |     0.30896 |       96.39 |     0.21424 |     0.21433 |         relu |         true |   1.4796e-08 | [356   7 185]         |
|   32 | Accept |     0.22568 |      16.277 |     0.21424 |     0.21442 |      sigmoid |        false |    5.385e-07 | [ 23   2]             |
|   33 | Accept |      0.2953 |      73.411 |     0.21424 |     0.21451 |         relu |         true |   6.7579e-05 | [237   2 167]         |
|   34 | Accept |     0.22092 |      142.27 |     0.21424 |     0.21452 |         none |        false |   3.2199e-09 | [ 13   8 386 231]     |
|   35 | Accept |     0.32804 |      59.882 |     0.21424 |     0.21425 |         relu |         true |   1.7207e-08 | [335   2]             |
|   36 | Accept |     0.26446 |      42.748 |     0.21424 |     0.21426 |      sigmoid |        false |   7.6024e-09 |  170                  |
|   37 | Accept |     0.25938 |      25.846 |     0.21424 |     0.21556 |      sigmoid |        false |   1.4964e-06 |  67                   |
|   38 | Accept |     0.23363 |       29.88 |     0.21424 |     0.21699 |      sigmoid |        false |   1.3302e-06 | [ 41  12   1  13   2] |
|   39 | Accept |     0.21488 |       18.38 |     0.21424 |     0.21429 |         none |        false |   3.3766e-09 | [325   1  26]         |
|   40 | Accept |     0.21488 |      4.6847 |     0.21424 |     0.21429 |         none |        false |   3.8762e-08 | [  1  13]             |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   41 | Accept |     0.21964 |      16.462 |     0.21424 |     0.21436 |         none |        false |   8.2526e-05 | [ 97  11]             |
|   42 | Accept |     0.22123 |      12.431 |     0.21424 |     0.21569 |         none |        false |   0.00049767 | [ 42  14  13   4   2] |
|   43 | Accept |     0.31691 |      59.148 |     0.21424 |       0.215 |         relu |         true |   0.00029442 | [  1  12 384   4  31] |
|   44 | Accept |      0.2225 |      82.411 |     0.21424 |       0.215 |         relu |         true |   3.2207e-09 | [  2 331  19  74  12] |
|   45 | Accept |     0.26478 |      55.779 |     0.21424 |     0.21501 |         relu |        false |   3.2107e-09 | [ 35 179  14   2]     |
|   46 | Accept |     0.29021 |      61.335 |     0.21424 |     0.21501 |         relu |        false |   5.7389e-06 | [ 42 318]             |
|   47 | Accept |     0.24348 |      129.66 |     0.21424 |     0.21501 |         relu |        false |   1.3815e-05 | [104 285 121   2  22] |
|   48 | Accept |     0.74189 |     0.25805 |     0.21424 |     0.21498 |         relu |        false |     0.060763 | [ 51   1  26]         |
|   49 | Accept |     0.25524 |      229.69 |     0.21424 |     0.21498 |         relu |        false |   1.0038e-07 | [ 11 379 336  33]     |
|   50 | Accept |     0.24062 |      86.121 |     0.21424 |     0.21499 |         relu |        false |   4.5255e-07 | [  8 207  24 285]     |
|   51 | Accept |     0.27622 |      36.186 |     0.21424 |     0.21499 |         relu |        false |   6.5926e-09 |  190                  |
|   52 | Accept |     0.21519 |      45.365 |     0.21424 |       0.215 |         tanh |        false |   3.2561e-09 | [  1 170]             |
|   53 | Accept |     0.22791 |      42.993 |     0.21424 |     0.21661 |         tanh |        false |    4.052e-09 | [  2  72  46]         |
|   54 | Accept |      0.2384 |      56.734 |     0.21424 |     0.21501 |         tanh |        false |   2.7916e-07 | [199   2   4]         |
|   55 | Accept |     0.29402 |      400.74 |     0.21424 |      0.2148 |         tanh |        false |   8.6815e-06 | [358 241 347 187]     |
|   56 | Accept |     0.21488 |      57.685 |     0.21424 |     0.21618 |      sigmoid |        false |   9.7045e-08 | [  1 343]             |
|   57 | Accept |     0.50731 |      14.593 |     0.21424 |      0.2206 |         tanh |        false |     0.014697 | [  1 325]             |
|   58 | Accept |     0.24507 |      105.57 |     0.21424 |     0.22011 |         tanh |        false |   1.2961e-08 | [ 53   7   6 364  20] |
|   59 | Accept |     0.25683 |      337.11 |     0.21424 |     0.21973 |         tanh |        false |   5.2292e-08 | [160 173 398 188   2] |
|   60 | Accept |     0.21424 |      52.362 |     0.21424 |     0.21365 |         none |        false |   1.9773e-08 | [265   3   8 144]     |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   61 | Accept |     0.21901 |      112.95 |     0.21424 |     0.21345 |         relu |         true |   3.8578e-05 | [  3 398 139   4]     |
|   62 | Accept |     0.21551 |      70.941 |     0.21424 |     0.21345 |         tanh |        false |   1.6012e-07 | [  1 347]             |
|   63 | Accept |     0.29561 |      179.56 |     0.21424 |     0.21345 |         tanh |        false |   5.0988e-07 | [ 52 395  29 179  90] |
|   64 | Accept |     0.28894 |      16.156 |     0.21424 |     0.21342 |         tanh |        false |   3.6595e-08 |  43                   |
|   65 | Accept |     0.23808 |      110.07 |     0.21424 |     0.21347 |         tanh |         true |   3.2378e-09 | [  3 376  75]         |
|   66 | Accept |     0.23522 |      37.116 |     0.21424 |     0.21346 |         tanh |         true |   1.1144e-07 | [  6 100   2]         |
|   67 | Accept |     0.30451 |      207.92 |     0.21424 |     0.21345 |         tanh |         true |   4.2187e-06 | [ 64 162  73 215 253] |
|   68 | Accept |     0.21519 |      64.314 |     0.21424 |     0.21344 |         tanh |         true |   3.2005e-09 | [  1   1   4  42 182] |
|   69 | Accept |     0.22823 |      18.554 |     0.21424 |     0.21343 |         tanh |         true |   3.0624e-08 | [  2   1  18   2]     |
|   70 | Accept |      0.4965 |     0.24191 |     0.21424 |     0.21341 |         tanh |         true |    0.0062297 |  1                    |
|   71 | Accept |     0.23872 |      59.935 |     0.21424 |      0.2134 |         tanh |         true |   3.3039e-09 | [  5 248   6]         |
|   72 | Accept |     0.24348 |      126.52 |     0.21424 |     0.21338 |         tanh |         true |   9.1602e-09 | [ 11   1 353 125  26] |
|   73 | Accept |     0.33058 |      15.405 |     0.21424 |     0.21333 |         tanh |         true |    5.149e-09 |  38                   |
|   74 | Accept |     0.22664 |      93.852 |     0.21424 |     0.21338 |         tanh |         true |   5.1801e-08 | [  3  22  13   2 390] |
|   75 | Accept |     0.21456 |      39.525 |     0.21424 |     0.21346 |         none |        false |   9.9076e-07 | [  8 321   1  14]     |
|   76 | Accept |     0.24094 |      144.33 |     0.21424 |     0.21341 |         tanh |        false |   4.8372e-09 | [146 376   4   4]     |
|   77 | Accept |     0.43134 |      61.629 |     0.21424 |     0.21356 |         relu |        false |    2.487e-06 | [203   1 325  33   8] |
|   78 | Accept |     0.22028 |      185.83 |     0.21424 |     0.21355 |         tanh |        false |   3.8579e-09 | [210   1 270 256   7] |
|   79 | Accept |     0.28894 |      88.793 |     0.21424 |     0.21353 |         relu |        false |   1.6973e-08 | [ 92 364]             |
|   80 | Accept |     0.21488 |      15.626 |     0.21424 |     0.21344 |         none |        false |   4.8495e-08 | [158   1  95   8]     |
|============================================================================================================================================|
| Iter | Eval   | Objective   | Objective   | BestSoFar   | BestSoFar   |  Activations |  Standardize |       Lambda |            LayerSizes |
|      | result |             | runtime     | (observed)  | (estim.)    |              |              |              |                       |
|============================================================================================================================================|
|   81 | Accept |     0.24634 |      25.257 |     0.21424 |     0.21345 |         tanh |         true |     3.86e-09 | [ 35   1  51]         |
|   82 | Accept |     0.21488 |      60.696 |     0.21424 |     0.21257 |      sigmoid |        false |   1.1764e-06 | [  1 379]             |
|   83 | Accept |     0.21964 |      90.211 |     0.21424 |     0.21255 |         none |        false |   3.2479e-09 | [ 24 341  70 161]     |
|   84 | Accept |     0.74189 |     0.87744 |     0.21424 |     0.21248 |         tanh |        false |       19.804 | [125   2 355]         |
|   85 | Accept |     0.21583 |      46.265 |     0.21424 |     0.21243 |         none |        false |   3.8097e-05 | [126   1 111  52]     |
|   86 | Accept |     0.21647 |      94.709 |     0.21424 |     0.21241 |         none |        false |   4.4626e-05 | [ 60 381   2 257   7] |
|   87 | Accept |     0.22409 |      91.623 |     0.21424 |     0.21309 |      sigmoid |        false |   3.2244e-09 | [ 74 122   6 141]     |
|   88 | Accept |     0.22982 |      82.493 |     0.21424 |     0.21233 |      sigmoid |        false |   6.6053e-08 | [ 37 299   3]         |
|   89 | Accept |     0.22028 |      45.673 |     0.21424 |      0.2123 |         none |        false |   0.00022752 | [  6 146  67  11  14] |
|   90 | Best   |     0.21392 |      104.36 |     0.21392 |     0.21218 |         none |         true |   4.7915e-09 | [351  52 361   2]     |
|   91 | Accept |     0.21996 |      22.493 |     0.21392 |     0.21209 |         none |         true |   3.4932e-09 | [ 17 186  18]         |
|   92 | Accept |     0.21488 |      4.1562 |     0.21392 |     0.21187 |         none |         true |   3.8203e-09 | [  3   1  91]         |
|   93 | Accept |      0.2206 |      91.939 |     0.21392 |     0.21199 |         none |         true |   2.6478e-07 | [128 226 140]         |
|   94 | Accept |     0.22028 |      32.482 |     0.21392 |      0.2119 |         none |         true |   1.0985e-08 | [ 32 266  81]         |
|   95 | Accept |     0.21996 |      8.1232 |     0.21392 |     0.21176 |         none |         true |   3.4762e-09 |  129                  |
|   96 | Accept |     0.21488 |      20.198 |     0.21392 |     0.21167 |         none |         true |   9.3788e-08 | [155   1 368   8 393] |
|   97 | Accept |     0.21488 |      7.8171 |     0.21392 |     0.21165 |         none |         true |   4.6151e-08 | [257   1   9]         |
|   98 | Accept |     0.21996 |       25.05 |     0.21392 |     0.21148 |         none |         true |   5.0115e-08 | [ 61 392]             |
|   99 | Accept |     0.21869 |      223.66 |     0.21392 |     0.21139 |         none |         true |   3.7372e-09 | [397 361   2  26]     |
|  100 | Accept |     0.74189 |     0.73109 |     0.21392 |     0.21136 |         tanh |         true |       29.506 | [ 11   9 398]         |

__________________________________________________________
Optimization completed.
MaxObjectiveEvaluations of 100 reached.
Total function evaluations: 100
Total elapsed time: 6645.9313 seconds
Total objective function evaluation time: 6315.0249

Best observed feasible point:
    Activations    Standardize      Lambda             LayerSizes       
    ___________    ___________    __________    ________________________

       none           true        4.7915e-09    351     52    361      2

Observed objective function value = 0.21392
Estimated objective function value = 0.21501
Function evaluation time = 104.357

Best estimated feasible point (according to models):
    Activations    Standardize      Lambda      LayerSizes
    ___________    ___________    __________    __________

      sigmoid         false       1.1764e-06     1    379 

Estimated objective function value = 0.21136
Estimated function evaluation time = 60.6733
Mdl = 
  ClassificationNeuralNetwork
                       PredictorNames: {'WC_TA'  'RE_TA'  'EBIT_TA'  'MVE_BVTD'  'S_TA'  'Industry'}
                         ResponseName: 'Rating'
                CategoricalPredictors: 6
                           ClassNames: [AAA    AA    A    BBB    BB    B    CCC]
                       ScoreTransform: 'none'
                      NumObservations: 3146
    HyperparameterOptimizationResults: [1×1 BayesianOptimization]
                           LayerSizes: [1 379]
                          Activations: 'sigmoid'
                OutputLayerActivation: 'softmax'
                               Solver: 'LBFGS'
                      ConvergenceInfo: [1×1 struct]
                      TrainingHistory: [1000×7 table]


  Properties, Methods

Find the classification accuracy of the model on the test data set. Visualize the results by using a confusion matrix.

testAccuracy = 1 - loss(Mdl,creditTest,"Rating", ...
    "LossFun","classiferror")
testAccuracy = 0.8053
confusionchart(creditTest.Rating,predict(Mdl,creditTest))

The model has all predicted classes within one unit of the true classes, meaning all predictions are off by no more than one rating.

Input Arguments

collapse all

Sample data used to train the model, specified as a table. Each row of Tbl corresponds to one observation, and each column corresponds to one predictor variable. Optionally, Tbl can contain one additional column for the response variable. Multicolumn variables and cell arrays other than cell arrays of character vectors are not allowed.

  • If Tbl contains the response variable, and you want to use all remaining variables in Tbl as predictors, then specify the response variable by using ResponseVarName.

  • If Tbl contains the response variable, and you want to use only a subset of the remaining variables in Tbl as predictors, then specify a formula by using formula.

  • If Tbl does not contain the response variable, then specify a response variable by using Y. The length of the response variable and the number of rows in Tbl must be equal.

Data Types: table

Response variable name, specified as the name of a variable in Tbl.

You must specify ResponseVarName as a character vector or string scalar. For example, if the response variable Y is stored as Tbl.Y, then specify it as "Y". Otherwise, the software treats all columns of Tbl, including Y, as predictors when training the model.

The response variable must be a categorical, character, or string array; a logical or numeric vector; or a cell array of character vectors. If Y is a character array, then each element of the response variable must correspond to one row of the array.

A good practice is to specify the order of the classes by using the ClassNames name-value argument.

Data Types: char | string

Explanatory model of the response variable and a subset of the predictor variables, specified as a character vector or string scalar in the form "Y~x1+x2+x3". In this form, Y represents the response variable, and x1, x2, and x3 represent the predictor variables.

To specify a subset of variables in Tbl as predictors for training the model, use a formula. If you specify a formula, then the software does not use any variables in Tbl that do not appear in formula.

The variable names in the formula must be both variable names in Tbl (Tbl.Properties.VariableNames) and valid MATLAB® identifiers. You can verify the variable names in Tbl by using the isvarname function. If the variable names are not valid, then you can convert them by using the matlab.lang.makeValidName function.

Data Types: char | string

Class labels used to train the model, specified as a numeric, categorical, or logical vector; a character or string array; or a cell array of character vectors.

  • If Y is a character array, then each element of the class labels must correspond to one row of the array.

  • The length of Y must be equal to the number of rows in Tbl or X.

  • A good practice is to specify the class order by using the ClassNames name-value argument.

Data Types: single | double | categorical | logical | char | string | cell

Predictor data used to train the model, specified as a numeric matrix.

By default, the software treats each row of X as one observation, and each column as one predictor.

The length of Y and the number of observations in X must be equal.

To specify the names of the predictors in the order of their appearance in X, use the PredictorNames name-value argument.

Note

If you orient your predictor matrix so that observations correspond to columns and specify 'ObservationsIn','columns', then you might experience a significant reduction in computation time.

Data Types: single | double

Note

The software treats NaN, empty character vector (''), empty string (""), <missing>, and <undefined> elements as missing values, and removes observations with any of these characteristics:

  • Missing value in the response variable (for example, Y or ValidationData{2})

  • At least one missing value in a predictor observation (for example, row in X or ValidationData{1})

  • NaN value or 0 weight (for example, value in Weights or ValidationData{3})

Name-Value Arguments

Specify optional comma-separated pairs of Name,Value arguments. Name is the argument name and Value is the corresponding value. Name must appear inside quotes. You can specify several name and value pair arguments in any order as Name1,Value1,...,NameN,ValueN.

Example: fitcnet(X,Y,'LayerSizes',[10 10],'Activations',["relu","tanh"]) specifies to create a neural network with two fully connected layers, each with 10 outputs. The first layer uses a rectified linear unit (ReLU) activation function, and the second uses a hyperbolic tangent activation function.
Neural Network Options

collapse all

Sizes of the fully connected layers in the neural network model, specified as a positive integer vector. The ith element of LayerSizes is the number of outputs in the ith fully connected layer of the neural network model.

LayerSizes does not include the size of the final fully connected layer that uses a softmax activation function. For more information, see Neural Network Structure.

Example: 'LayerSizes',[100 25 10]

Activation functions for the fully connected layers of the neural network model, specified as a character vector, string scalar, string array, or cell array of character vectors with values from this table.

ValueDescription
'relu'

Rectified linear unit (ReLU) function — Performs a threshold operation on each element of the input, where any value less than zero is set to zero, that is,

f(x)={x,x00,x<0

'tanh'

Hyperbolic tangent (tanh) function — Applies the tanh function to each input element

'sigmoid'

Sigmoid function — Performs the following operation on each input element:

f(x)=11+ex

'none'

Identity function — Returns each input element without performing any transformation, that is, f(x) = x

  • If you specify one activation function only, then Activations is the activation function for every fully connected layer of the neural network model, excluding the final fully connected layer. The activation function for the final fully connected layer is always softmax (see Neural Network Structure).

  • If you specify an array of activation functions, then the ith element of Activations is the activation function for the ith layer of the neural network model.

Example: 'Activations','sigmoid'

Function to initialize the fully connected layer weights, specified as 'glorot' or 'he'.

ValueDescription
'glorot'Initialize the weights with the Glorot initializer [1] (also known as the Xavier initializer). For each layer, the Glorot initializer independently samples from a uniform distribution with zero mean and variable 2/(I+O), where I is the input size and O is the output size for the layer.
'he'Initialize the weights with the He initializer [2]. For each layer, the He initializer samples from a normal distribution with zero mean and variance 2/I, where I is the input size for the layer.

Example: 'LayerWeightsFunction','he'

Type of initial fully connected layer biases, specified as 'zeros' or 'ones'.

  • If you specify the value 'zeros', then each fully connected layer has an initial bias of 0.

  • If you specify the value 'ones', then each fully connected layer has an initial bias of 1.

Example: 'LayerBiasesInitializer','ones'

Data Types: char | string

Predictor data observation dimension, specified as 'rows' or 'columns'.

Note

If you orient your predictor matrix so that observations correspond to columns and specify 'ObservationsIn','columns', then you might experience a significant reduction in computation time. You cannot specify 'ObservationsIn','columns' for predictor data in a table.

Example: 'ObservationsIn','columns'

Data Types: char | string

Regularization term strength, specified as a nonnegative scalar. The software composes the objective function for minimization from the cross-entropy loss function and the ridge (L2) penalty term.

Example: 'Lambda',1e-4

Data Types: single | double

Flag to standardize the predictor data, specified as a numeric or logical 0 (false) or 1 (true). If you set Standardize to true, then the software centers and scales each numeric predictor variable by the corresponding column mean and standard deviation. The software does not standardize the categorical predictors.

Example: 'Standardize',true

Data Types: single | double | logical

Convergence Control Options

collapse all

Verbosity level, specified as 0 or 1. The 'Verbose' name-value argument controls the amount of diagnostic information that fitcnet displays at the command line.

ValueDescription
0fitcnet does not display diagnostic information.
1fitcnet periodically displays diagnostic information.

By default, StoreHistory is set to true and fitcnet stores the diagnostic information inside of Mdl. Use Mdl.TrainingHistory to access the diagnostic information.

Example: 'Verbose',1

Data Types: single | double

Frequency of verbose printing, which is the number of iterations between printing to the command window, specified as a positive integer scalar. A value of 1 indicates to print diagnostic information at every iteration.

Note

To use this name-value argument, set Verbose to 1.

Example: 'VerboseFrequency',5

Data Types: single | double

Flag to store the training history, specified as a numeric or logical 0 (false) or 1 (true). If StoreHistory is set to true, then the software stores diagnostic information inside of Mdl, which you can access by using Mdl.TrainingHistory.

Example: 'StoreHistory',false

Data Types: single | double | logical

Maximum number of training iterations, specified as a positive integer scalar.

The software returns a trained model regardless of whether the training routine successfully converges. Mdl.ConvergenceInfo contains convergence information.

Example: 'IterationLimit',1e8

Data Types: single | double

Relative gradient tolerance, specified as a nonnegative scalar.

Let t be the loss function at training iteration t, t be the gradient of the loss function with respect to the weights and biases at iteration t, and 0 be the gradient of the loss function at an initial point. If max|t|aGradientTolerance, where a=max(1,min|t|,max|0|), then the training process terminates.

Example: 'GradientTolerance',1e-5

Data Types: single | double

Loss tolerance, specified as a nonnegative scalar.

If the function loss at some iteration is smaller than LossTolerance, then the training process terminates.

Example: 'LossTolerance',1e-8

Data Types: single | double

Step size tolerance, specified as a nonnegative scalar.

If the step size at some iteration is smaller than StepTolerance, then the training process terminates.

Example: 'StepTolerance',1e-4

Data Types: single | double

Validation data for training convergence detection, specified as a cell array or table.

During the training process, the software periodically estimates the validation loss by using ValidationData. If the validation loss increases more than ValidationPatience times in a row, then the software terminates the training.

You can specify ValidationData as a table if you use a table Tbl of predictor data that contains the response variable. In this case, ValidationData must contain the same predictors and response contained in Tbl. The software does not apply weights to observations, even if Tbl contains a vector of weights. To specify weights, you must specify ValidationData as a cell array.

If you specify ValidationData as a cell array, then it must have the following format:

  • ValidationData{1} must have the same data type and orientation as the predictor data. That is, if you use a predictor matrix X, then ValidationData{1} must be an m-by-p or p-by-m matrix of predictor data that has the same orientation as X. The predictor variables in the training data X and ValidationData{1} must correspond. Similarly, if you use a predictor table Tbl of predictor data, then ValidationData{1} must be a table containing the same predictor variables contained in Tbl. The number of observations in ValidationData{1} and the predictor data can vary.

  • ValidationData{2} must match the data type and format of the response variable, either Y or ResponseVarName. If ValidationData{2} is an array of class labels, then it must have the same number of elements as the number of observations in ValidationData{1}. The set of all distinct labels of ValidationData{2} must be a subset of all distinct labels of Y. If ValidationData{1} is a table, then ValidationData{2} can be the name of the response variable in the table. If you want to use the same ResponseVarName or formula, you can specify ValidationData{2} as [].

  • Optionally, you can specify ValidationData{3} as an m-dimensional numeric vector of observation weights or the name of a variable in the table ValidationData{1} that contains observation weights. The software normalizes the weights with the validation data so that they sum to 1.

If you specify ValidationData and want to display the validation loss at the command line, set Verbose to 1.

Number of iterations between validation evaluations, specified as a positive integer scalar. A value of 1 indicates to evaluate validation metrics at every iteration.

Note

To use this name-value argument, you must specify ValidationData.

Example: 'ValidationFrequency',5

Data Types: single | double

Stopping condition for validation evaluations, specified as a nonnegative integer scalar. The training process stops if the validation loss is greater than or equal to the minimum validation loss computed so far, ValidationPatience times in a row. You can check the Mdl.TrainingHistory table to see the running total of times that the validation loss is greater than or equal to the minimum (Validation Checks).

Example: 'ValidationPatience',10

Data Types: single | double

Other Classification Options

collapse all

Categorical predictors list, specified as one of the values in this table. The descriptions assume that the predictor data has observations in rows and predictors in columns.

ValueDescription
Vector of positive integers

Each entry in the vector is an index value indicating that the corresponding predictor is categorical. The index values are between 1 and p, where p is the number of predictors used to train the model.

If fitcnet uses a subset of input variables as predictors, then the function indexes the predictors using only the subset. The CategoricalPredictors values do not count the response variable, observation weight variable, or any other variables that the function does not use.

Logical vector

A true entry means that the corresponding predictor is categorical. The length of the vector is p.

Character matrixEach row of the matrix is the name of a predictor variable. The names must match the entries in PredictorNames. Pad the names with extra blanks so each row of the character matrix has the same length.
String array or cell array of character vectorsEach element in the array is the name of a predictor variable. The names must match the entries in PredictorNames.
"all"All predictors are categorical.

By default, if the predictor data is in a table (Tbl), fitcnet assumes that a variable is categorical if it is a logical vector, categorical vector, character array, string array, or cell array of character vectors. If the predictor data is a matrix (X), fitcnet assumes that all predictors are continuous. To identify any other predictors as categorical predictors, specify them by using the 'CategoricalPredictors' name-value argument.

For the identified categorical predictors, fitcnet creates dummy variables using two different schemes, depending on whether a categorical variable is unordered or ordered. For an unordered categorical variable, fitcnet creates one dummy variable for each level of the categorical variable. For an ordered categorical variable, fitcnet creates one less dummy variable than the number of categories. For details, see Automatic Creation of Dummy Variables.

Example: 'CategoricalPredictors','all'

Data Types: single | double | logical | char | string | cell

Names of classes to use for training, specified as a categorical, character, or string array; a logical or numeric vector; or a cell array of character vectors. ClassNames must have the same data type as the response variable in Tbl or Y.

If ClassNames is a character array, then each element must correspond to one row of the array.

Use ClassNames to:

  • Specify the order of the classes during training.

  • Specify the order of any input or output argument dimension that corresponds to the class order. For example, use ClassNames to specify the column order of classification scores returned by predict.

  • Select a subset of classes for training. For example, suppose that the set of all distinct class names in Y is ["a","b","c"]. To train the model using observations from classes "a" and "c" only, specify "ClassNames",["a","c"].

The default value for ClassNames is the set of all distinct class names in the response variable in Tbl or Y.

Example: "ClassNames",["b","g"]

Data Types: categorical | char | string | logical | single | double | cell

Predictor variable names, specified as a string array of unique names or cell array of unique character vectors. The functionality of 'PredictorNames' depends on the way you supply the training data.

  • If you supply X and Y, then you can use 'PredictorNames' to assign names to the predictor variables in X.

    • The order of the names in PredictorNames must correspond to the predictor order in X. Assuming that X has the default orientation, with observations in rows and predictors in columns, PredictorNames{1} is the name of X(:,1), PredictorNames{2} is the name of X(:,2), and so on. Also, size(X,2) and numel(PredictorNames) must be equal.

    • By default, PredictorNames is {'x1','x2',...}.

  • If you supply Tbl, then you can use 'PredictorNames' to choose which predictor variables to use in training. That is, fitcnet uses only the predictor variables in PredictorNames and the response variable during training.

    • PredictorNames must be a subset of Tbl.Properties.VariableNames and cannot include the name of the response variable.

    • By default, PredictorNames contains the names of all predictor variables.

    • A good practice is to specify the predictors for training using either 'PredictorNames' or formula, but not both.

Example: 'PredictorNames',{'SepalLength','SepalWidth','PetalLength','PetalWidth'}

Data Types: string | cell

Response variable name, specified as a character vector or string scalar.

  • If you supply Y, then you can use ResponseName to specify a name for the response variable.

  • If you supply ResponseVarName or formula, then you cannot use ResponseName.

Example: "ResponseName","response"

Data Types: char | string

Score transformation, specified as a character vector, string scalar, or function handle.

This table summarizes the available character vectors and string scalars.

ValueDescription
"doublelogit"1/(1 + e–2x)
"invlogit"log(x / (1 – x))
"ismax"Sets the score for the class with the largest score to 1, and sets the scores for all other classes to 0
"logit"1/(1 + ex)
"none" or "identity"x (no transformation)
"sign"–1 for x < 0
0 for x = 0
1 for x > 0
"symmetric"2x – 1
"symmetricismax"Sets the score for the class with the largest score to 1, and sets the scores for all other classes to –1
"symmetriclogit"2/(1 + ex) – 1

For a MATLAB function or a function you define, use its function handle for the score transform. The function handle must accept a matrix (the original scores) and return a matrix of the same size (the transformed scores).

Example: "ScoreTransform","logit"

Data Types: char | string | function_handle

Observation weights, specified as a nonnegative numeric vector or the name of a variable in Tbl. The software weights each observation in X or Tbl with the corresponding value in Weights. The length of Weights must equal the number of observations in X or Tbl.

If you specify the input data as a table Tbl, then Weights can be the name of a variable in Tbl that contains a numeric vector. In this case, you must specify Weights as a character vector or string scalar. For example, if the weights vector W is stored as Tbl.W, then specify it as 'W'. Otherwise, the software treats all columns of Tbl, including W, as predictors or the response variable when training the model.

By default, Weights is ones(n,1), where n is the number of observations in X or Tbl.

The software normalizes Weights to sum to the value of the prior probability in the respective class.

Data Types: single | double | char | string

Note

You cannot use any cross-validation name-value argument together with the 'OptimizeHyperparameters' name-value argument. You can modify the cross-validation for 'OptimizeHyperparameters' only by using the 'HyperparameterOptimizationOptions' name-value argument.

Cross-Validation Options

collapse all

Flag to train a cross-validated classifier, specified as 'on' or 'off'.

If you specify 'on', then the software trains a cross-validated classifier with 10 folds.

You can override this cross-validation setting using the CVPartition, Holdout, KFold, or Leaveout name-value argument. You can use only one cross-validation name-value argument at a time to create a cross-validated model.

Alternatively, cross-validate later by passing Mdl to crossval.

Example: 'Crossval','on'

Data Types: char | string

Cross-validation partition, specified as a cvpartition partition object created by cvpartition. The partition object specifies the type of cross-validation and the indexing for the training and validation sets.

To create a cross-validated model, you can specify only one of these four name-value arguments: CVPartition, Holdout, KFold, or Leaveout.

Example: Suppose you create a random partition for 5-fold cross-validation on 500 observations by using cvp = cvpartition(500,'KFold',5). Then, you can specify the cross-validated model by using 'CVPartition',cvp.

Fraction of the data used for holdout validation, specified as a scalar value in the range (0,1). If you specify 'Holdout',p, then the software completes these steps:

  1. Randomly select and reserve p*100% of the data as validation data, and train the model using the rest of the data.

  2. Store the compact, trained model in the Trained property of the cross-validated model.

To create a cross-validated model, you can specify only one of these four name-value arguments: CVPartition, Holdout, KFold, or Leaveout.

Example: 'Holdout',0.1

Data Types: double | single

Number of folds to use in a cross-validated model, specified as a positive integer value greater than 1. If you specify 'KFold',k, then the software completes these steps:

  1. Randomly partition the data into k sets.

  2. For each set, reserve the set as validation data, and train the model using the other k – 1 sets.

  3. Store the k compact, trained models in a k-by-1 cell vector in the Trained property of the cross-validated model.

To create a cross-validated model, you can specify only one of these four name-value arguments: CVPartition, Holdout, KFold, or Leaveout.

Example: 'KFold',5

Data Types: single | double

Leave-one-out cross-validation flag, specified as 'on' or 'off'. If you specify 'Leaveout','on', then for each of the n observations (where n is the number of observations, excluding missing observations, specified in the NumObservations property of the model), the software completes these steps:

  1. Reserve the one observation as validation data, and train the model using the other n – 1 observations.

  2. Store the n compact, trained models in an n-by-1 cell vector in the Trained property of the cross-validated model.

To create a cross-validated model, you can specify only one of these four name-value arguments: CVPartition, Holdout, KFold, or Leaveout.

Example: 'Leaveout','on'

Hyperparameter Optimization Options

collapse all

Parameters to optimize, specified as one of the following:

  • 'none' — Do not optimize.

  • 'auto' — Use {'Activations','Lambda','LayerSizes','Standardize'}.

  • 'all' — Optimize all eligible parameters.

  • String array or cell array of eligible parameter names.

  • Vector of optimizableVariable objects, typically the output of hyperparameters.

The optimization attempts to minimize the cross-validation loss (error) for fitcnet by varying the parameters. For information about cross-validation loss (although in a different context), see Classification Loss. To control the cross-validation type and other aspects of the optimization, use the HyperparameterOptimizationOptions name-value argument.

Note

The values of 'OptimizeHyperparameters' override any values you specify using other name-value arguments. For example, setting 'OptimizeHyperparameters' to 'auto' causes fitcnet to optimize hyperparameters corresponding to the 'auto' option and to ignore any specified values for the hyperparameters.

The eligible parameters for fitcnet are:

  • Activationsfitcnet optimizes Activations over the set {'relu','tanh','sigmoid','none'}.

  • Lambdafitcnet optimizes Lambda over continuous values in the range [1e-5,1e5]/NumObservations, where the value is chosen uniformly in the log transformed range.

  • LayerBiasesInitializerfitcnet optimizes LayerBiasesInitializer over the two values {'zeros','ones'}.

  • LayerWeightsInitializerfitcnet optimizes LayerWeightsInitializer over the two values {'glorot','he'}.

  • LayerSizesfitcnet optimizes over the three values 1, 2, and 3 fully connected layers, excluding the final fully connected layer. fitcnet optimizes each fully connected layer separately over 1 through 300 sizes in the layer, sampled on a logarithmic scale.

    Note

    When you use the LayerSizes argument, the iterative display shows the size of each relevant layer. For example, if the current number of fully connected layers is 3, and the three layers are of sizes 10, 79, and 44 respectively, the iterative display shows LayerSizes for that iteration as [10 79 44].

    Note

    To access up to five fully connected layers or a different range of sizes in a layer, use hyperparameters to select the optimizable parameters and ranges.

  • Standardizefitcnet optimizes Standardize over the two values {true,false}.

Set nondefault parameters by passing a vector of optimizableVariable objects that have nondefault values. As an example, this code sets the range of NumLayers to [1 5] and optimizes Layer_4_Size and Layer_5_Size:

load fisheriris
params = hyperparameters('fitcnet',meas,species);
params(1).Range = [1 5];
params(10).Optimize = true;
params(11).Optimize = true;

Pass params as the value of OptimizeHyperparameters. For an example using nondefault parameters, see Customize Neural Network Classifier Optimization.

By default, the iterative display appears at the command line, and plots appear according to the number of hyperparameters in the optimization. For the optimization and plots, the objective function is the misclassification rate. To control the iterative display, set the Verbose field of the 'HyperparameterOptimizationOptions' name-value argument. To control the plots, set the ShowPlots field of the 'HyperparameterOptimizationOptions' name-value argument.

For an example, see Improve Neural Network Classifier Using OptimizeHyperparameters.

Example: 'OptimizeHyperparameters','auto'

Options for optimization, specified as a structure. This argument modifies the effect of the OptimizeHyperparameters name-value argument. All fields in the structure are optional.

Field NameValuesDefault
Optimizer
  • 'bayesopt' — Use Bayesian optimization. Internally, this setting calls bayesopt.

  • 'gridsearch' — Use grid search with NumGridDivisions values per dimension.

  • 'randomsearch' — Search at random among MaxObjectiveEvaluations points.

'gridsearch' searches in a random order, using uniform sampling without replacement from the grid. After optimization, you can get a table in grid order by using the command sortrows(Mdl.HyperparameterOptimizationResults).

'bayesopt'
AcquisitionFunctionName

  • 'expected-improvement-per-second-plus'

  • 'expected-improvement'

  • 'expected-improvement-plus'

  • 'expected-improvement-per-second'

  • 'lower-confidence-bound'

  • 'probability-of-improvement'

Acquisition functions whose names include per-second do not yield reproducible results because the optimization depends on the runtime of the objective function. Acquisition functions whose names include plus modify their behavior when they are overexploiting an area. For more details, see Acquisition Function Types.

'expected-improvement-per-second-plus'
MaxObjectiveEvaluationsMaximum number of objective function evaluations.30 for 'bayesopt' and 'randomsearch', and the entire grid for 'gridsearch'
MaxTime

Time limit, specified as a positive real scalar. The time limit is in seconds, as measured by tic and toc. The run time can exceed MaxTime because MaxTime does not interrupt function evaluations.

Inf
NumGridDivisionsFor 'gridsearch', the number of values in each dimension. The value can be a vector of positive integers giving the number of values for each dimension, or a scalar that applies to all dimensions. This field is ignored for categorical variables.10
ShowPlotsLogical value indicating whether to show plots. If true, this field plots the best observed objective function value against the iteration number. If you use Bayesian optimization (Optimizer is 'bayesopt'), then this field also plots the best estimated objective function value. The best observed objective function values and best estimated objective function values correspond to the values in the BestSoFar (observed) and BestSoFar (estim.) columns of the iterative display, respectively. You can find these values in the properties ObjectiveMinimumTrace and EstimatedObjectiveMinimumTrace of Mdl.HyperparameterOptimizationResults. If the problem includes one or two optimization parameters for Bayesian optimization, then ShowPlots also plots a model of the objective function against the parameters.true
SaveIntermediateResultsLogical value indicating whether to save results when Optimizer is 'bayesopt'. If true, this field overwrites a workspace variable named 'BayesoptResults' at each iteration. The variable is a BayesianOptimization object.false
Verbose

Display at the command line:

  • 0 — No iterative display

  • 1 — Iterative display

  • 2 — Iterative display with extra information

For details, see the bayesopt Verbose name-value argument and the example Optimize Classifier Fit Using Bayesian Optimization.

1
UseParallelLogical value indicating whether to run Bayesian optimization in parallel, which requires Parallel Computing Toolbox™. Due to the nonreproducibility of parallel timing, parallel Bayesian optimization does not necessarily yield reproducible results. For details, see Parallel Bayesian Optimization.false
Repartition

Logical value indicating whether to repartition the cross-validation at every iteration. If this field is false, the optimizer uses a single partition for the optimization.

The setting true usually gives the most robust results because it takes partitioning noise into account. However, for good results, true requires at least twice as many function evaluations.

false
Use no more than one of the following three options.
CVPartitionA cvpartition object, as created by cvpartition'Kfold',5 if you do not specify a cross-validation field
HoldoutA scalar in the range (0,1) representing the holdout fraction
KfoldAn integer greater than 1

Example: 'HyperparameterOptimizationOptions',struct('MaxObjectiveEvaluations',60)

Data Types: struct

Output Arguments

collapse all

Trained neural network classifier, returned as a ClassificationNeuralNetwork or ClassificationPartitionedModel object.

If you set any of the name-value arguments CrossVal, CVPartition, Holdout, KFold, or Leaveout, then Mdl is a ClassificationPartitionedModel object. Otherwise, Mdl is a ClassificationNeuralNetwork model.

To reference properties of Mdl, use dot notation.

More About

collapse all

Neural Network Structure

The default neural network classifier has the following layer structure.

StructureDescription

Default neural network classifier structure, with one customizable fully connected layer with a ReLU activation

Input — This layer corresponds to the predictor data in Tbl or X.

First fully connected layer — This layer has 10 outputs by default.

  • You can widen the layer or add more fully connected layers to the network by specifying the LayerSizes name-value argument.

  • You can find the weights and biases for this layer in the Mdl.LayerWeights{1} and Mdl.LayerBiases{1} properties of Mdl, respectively.

ReLU activation function — fitcnet applies this activation function to the first fully connected layer.

  • You can change the activation function by specifying the Activations name-value argument.

Final fully connected layer — This layer has K outputs, where K is the number of classes in the response variable.

  • You can find the weights and biases for this layer in the Mdl.LayerWeights{end} and Mdl.LayerBiases{end} properties of Mdl, respectively.

Softmax function (for both binary and multiclass classification) — fitcnet applies this activation function to the final fully connected layer. The function takes each input xi and returns the following, where K is the number of classes in the response variable:

f(xi)=exp(xi)j=1Kexp(xj).

The results correspond to the predicted classification scores (or posterior probabilities).

Output — This layer corresponds to the predicted class labels.

For an example that shows how a neural network classifier with this layer structure returns predictions, see Predict Using Layer Structure of Neural Network Classifier.

Tips

  • Always try to standardize the numeric predictors (see Standardize). Standardization makes predictors insensitive to the scales on which they are measured.

Algorithms

collapse all

Training Solver

fitcnet uses a limited-memory Broyden-Fletcher-Goldfarb-Shanno quasi-Newton algorithm (LBFGS) [3] as its loss function minimization technique, where the software minimizes the cross-entropy loss.

References

[1] Glorot, Xavier, and Yoshua Bengio. “Understanding the difficulty of training deep feedforward neural networks.” In Proceedings of the thirteenth international conference on artificial intelligence and statistics, pp. 249–256. 2010.

[2] He, Kaiming, Xiangyu Zhang, Shaoqing Ren, and Jian Sun. “Delving deep into rectifiers: Surpassing human-level performance on imagenet classification.” In Proceedings of the IEEE international conference on computer vision, pp. 1026–1034. 2015.

[3] Nocedal, J. and S. J. Wright. Numerical Optimization, 2nd ed., New York: Springer, 2006.

Extended Capabilities

Introduced in R2021a