2017-05-18 06:07:14 +08:00
|
|
|
# MLPClassifier
|
|
|
|
|
|
|
|
A multilayer perceptron (MLP) is a feedforward artificial neural network model that maps sets of input data onto a set of appropriate outputs.
|
|
|
|
|
|
|
|
## Constructor Parameters
|
|
|
|
|
|
|
|
* $inputLayerFeatures (int) - the number of input layer features
|
|
|
|
* $hiddenLayers (array) - array with the hidden layers configuration, each value represent number of neurons in each layers
|
|
|
|
* $classes (array) - array with the different training set classes (array keys are ignored)
|
|
|
|
* $iterations (int) - number of training iterations
|
2017-11-20 23:39:50 +01:00
|
|
|
* $learningRate (float) - the learning rate
|
2017-05-18 06:07:14 +08:00
|
|
|
* $activationFunction (ActivationFunction) - neuron activation function
|
|
|
|
|
|
|
|
```
|
|
|
|
use Phpml\Classification\MLPClassifier;
|
|
|
|
$mlp = new MLPClassifier(4, [2], ['a', 'b', 'c']);
|
|
|
|
|
|
|
|
// 4 nodes in input layer, 2 nodes in first hidden layer and 3 possible labels.
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
## Train
|
|
|
|
|
|
|
|
To train a MLP simply provide train samples and labels (as array). Example:
|
|
|
|
|
|
|
|
|
|
|
|
```
|
|
|
|
$mlp->train(
|
|
|
|
$samples = [[1, 0, 0, 0], [0, 1, 1, 0], [1, 1, 1, 1], [0, 0, 0, 0]],
|
|
|
|
$targets = ['a', 'a', 'b', 'c']
|
|
|
|
);
|
2017-05-23 15:03:05 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
Use partialTrain method to train in batches. Example:
|
|
|
|
|
|
|
|
```
|
|
|
|
$mlp->partialTrain(
|
|
|
|
$samples = [[1, 0, 0, 0], [0, 1, 1, 0]],
|
|
|
|
$targets = ['a', 'a']
|
|
|
|
);
|
|
|
|
$mlp->partialTrain(
|
|
|
|
$samples = [[1, 1, 1, 1], [0, 0, 0, 0]],
|
|
|
|
$targets = ['b', 'c']
|
|
|
|
);
|
2017-05-18 06:07:14 +08:00
|
|
|
|
|
|
|
```
|
|
|
|
|
2017-12-05 21:09:06 +01:00
|
|
|
You can update the learning rate between partialTrain runs:
|
|
|
|
|
|
|
|
```
|
|
|
|
$mlp->setLearningRate(0.1);
|
|
|
|
```
|
|
|
|
|
2017-05-18 06:07:14 +08:00
|
|
|
## Predict
|
|
|
|
|
|
|
|
To predict sample label use predict method. You can provide one sample or array of samples:
|
|
|
|
|
|
|
|
```
|
|
|
|
$mlp->predict([[1, 1, 1, 1], [0, 0, 0, 0]]);
|
|
|
|
// return ['b', 'c'];
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
## Activation Functions
|
|
|
|
|
|
|
|
* BinaryStep
|
|
|
|
* Gaussian
|
|
|
|
* HyperbolicTangent
|
2018-01-09 11:09:59 +01:00
|
|
|
* Parametric Rectified Linear Unit
|
2017-05-18 06:07:14 +08:00
|
|
|
* Sigmoid (default)
|
2018-01-09 11:09:59 +01:00
|
|
|
* Thresholded Rectified Linear Unit
|