Training a Perceptron in Machine Learning
- Create a Perceptron object.
- Create training functions
- Perceptron training based on correct answers
Training mission
Imagine a straight line in space with scattered x and y points.
Train a perceptron to classify points that lie on and below that line.
Create a Perceptron object.
Create a Perceptron object. Give it any name you like (for example, Perceptron).
Allow the perceptron to accept two parameters:
- Number of inputs (no)
- Learning rate.
Set the default learning speed to 0.00001.
Next, generate random weights from -1 to 1 for each input.
For example:
// Perceptron Object function Perceptron(no, learningRate = 0.00001) { // Set Initial Values this.learnc = learningRate; this.bias = 1; // Compute Random Weights this.weights = []; for (let i = 0; i <= no; i++) { this.weights[i] = Math.random() * 2 - 1; } // End Perceptron Object } Random weights
The perceptron will start with a random weight for each input.
Learning speed
During Perceptron training, each error will cause the weights to be adjusted by a small amount.
This small part is called the "Perceptron learning rate".
In the Perceptron object, we call it learnc.
Bias
Sometimes, if both inputs are zero, the Perceptron may produce an incorrect output.
To avoid this, we provide the Perceptron with an additional input of 1.
This is called bias.
Add a trigger function
Remember the perceptron algorithm:
- Multiply each input by the perceptron's weight.
- Add the results
- Calculate the result
For example:
this.activate = function(inputs) { let sum = 0; for (let i = 0; i < inputs.length; i++) { sum += inputs[i] * this.weights[i]; } if (sum > 0) {return 1} else {return 0} } The trigger function will output:
- 1 if the sum is greater than 0
- 0 if the sum is less than 0
Create a training function
The training function predicts the outcome based on the activation function.
Whenever the prediction is wrong, the perceptron will adjust the weights.
After several predictions and adjustments, the weights will be accurate.
For example:
this.train = function(inputs, desired) { inputs.push(this.bias); let guess = this.activate(inputs); let error = desired - guess; if (error != 0) { for (let i = 0; i < inputs.length; i++) { this.weights[i] += this.learnc * error * inputs[i]; } } } Backpropagation
After each prediction, the perceptron calculates the error of that prediction.
If the prediction is wrong, the perceptron will adjust the bias and weights so that the next prediction will be slightly more accurate.
This type of learning is called backpropagation.
After trying (several thousand times), your perceptron will become quite good at guessing.
Create your own library
Library code:
// Perceptron Object function Perceptron(no, learningRate = 0.00001) { // Set Initial Values this.learnc = learningRate; this.bias = 1; // Compute Random Weights this.weights = []; for (let i = 0; i <= no; i++) { this.weights[i] = Math.random() * 2 - 1; } // Activate Function this.activate = function(inputs) { let sum = 0; for (let i = 0; i < inputs.length; i++) { sum += inputs[i] * this.weights[i]; } if (sum > 0) {return 1} else {return 0} } // Train Function this.train = function(inputs, desired) { inputs.push(this.bias); let guess = this.activate(inputs); let error = desired - guess; if (error != 0) { for (let i = 0; i < inputs.length; i++) { this.weights[i] += this.learnc * error * inputs[i]; } } } // End Perceptron Object } Now you can integrate the library into your HTML:
Use the library
For example:
// Initiate Values const numPoints = 500; const learningRate = 0.00001; // Create a Plotter const plotter = new XYPlotter("myCanvas"); plotter.transformXY(); const xMax = plotter.xMax; const yMax = plotter.yMax; const xMin = plotter.xMin; const yMin = plotter.yMin; // Create Random XY Points const xPoints = []; const yPoints = []; for (let i = 0; i < numPoints; i++) { xPoints[i] = Math.random() * xMax; yPoints[i] = Math.random() * yMax; } // Line Function function f(x) { return x * 1.2 + 50; } //Plot the Line plotter.plotLine(xMin, f(xMin), xMax, f(xMax), "black"); // Compute Desired Answers const desired = []; for (let i = 0; i < numPoints; i++) { desired[i] = 0; if (yPoints[i] > f(xPoints[i])) {desired[i] = 1} } // Create a Perceptron const ptron = new Perceptron(2, learningRate); // Train the Perceptron for (let j = 0; j <= 10000; j++) { for (let i = 0; i < numPoints; i++) { ptron.train([xPoints[i], yPoints[i]], desired[i]); } } // Display the Result for (let i = 0; i < numPoints; i++) { const x = xPoints[i]; const y = yPoints[i]; let guess = ptron.activate([x, y, ptron.bias]); let color = "black"; if (guess == 0) color = "blue"; plotter.plotPoint(x, y, color); }You should read it
- ★ Google researchers for gaming AI to improve enhanced learning ability
- ★ [Infographic] AI and Machine Learning in the enterprise
- ★ What is machine learning? What is deep learning? Difference between AI, machine learning and deep learning
- ★ 7 practical applications of Machine Learning
- ★ Google released the TensorFlow machine learning framework specifically for graphical data