Perceptron

Introduction

The Perceptron Learning Algorithm (PLA) is a supervised learning algorithm widely employed for binary classification tasks. Its primary objective is to determine a decision boundary that effectively separates the two classes in the dataset. This algorithm belongs to the class of discriminative classification methods as it focuses on modeling the boundary between classes instead of characterizing the underlying probability distribution of each class.

Let D={(x1,y1),,(xn,yn)} represent the dataset, where xiRd and yi{0,1}.

The algorithm is founded on the following assumptions:

  1. P(y=1|x)=1 if wTx0, otherwise P(y=1|x)=0.
  2. Linear Separability Assumption: The Linear Separability Assumption is a fundamental assumption made in various machine learning algorithms, including the Perceptron Learning Algorithm. It posits that the classes to be classified can be accurately separated by a linear decision boundary. In other words, there exists a hyperplane in the feature space that can effectively segregate the data points of the two classes.

The objective function is defined as follows:

minhHi=1n1(h(xi)yi)

Even if H accounts only for the Linear Hypotheses, this problem is generally considered NP-Hard.

Under the Linear Separability Assumption, assuming the existence of wRd such that sign(wTxi)=yi holds for all i{1,2,,n}, the PLA solves the convergence problem using an iterative algorithm. The algorithm proceeds as follows:

  • Initialize w0=0Rd
  • Until Convergence:
    • Select a (xi,yi) pair from the dataset
    • If sign(wTxi)==yi
      • Do nothing
    • Else
      • Update the weight vector: w(t+1)=wt+xiyi
    • End

Analysis of the Update Rule

For a given training example (x,y), where x represents the input and y represents the correct output (either 1 or 1), the perceptron algorithm updates the weight vector w according to the following rules:

  • If the perceptron’s prediction on x is correct (i.e., sign(wTxi)==yi), no update is performed.
  • If the perceptron’s prediction on x is incorrect (i.e., sign(wTxi)yi), the weights are updated by adding the product of the input vector and the correct output to the current weight vector: w(t+1)=wt+xiyi.
  • It is important to note that the update occurs solely in response to the current data point. Consequently, data points that were previously classified correctly may not be classified similarly in future iterations.

This update rule effectively adjusts the decision boundary in the direction of correct classification for the misclassified example. The algorithm is guaranteed to converge to a linearly separable solution if the data is indeed linearly separable. However, if the data is not linearly separable, the perceptron algorithm may not converge to a solution.

Further Assumptions

We introduce three additional assumptions:

  1. Linear Separability with γ-Margin: A dataset D={(x1,y1),,(xn,yn)} is considered linearly separable with a γ-margin if there exists wRd such that (wTxi)yiγ holds for all i, where γ>0.

Linear Separability with γ-Margin
  1. Radius Assumption: Let R>0R be a constant such that iD, ||xi||R. In other words, R denotes the length of the data point farthest from the center.
  2. Normal Length for w: Assume that w has unit length.

Proof of Convergence of Perceptron Algorithm

We denote the current mistake number as l. Based on our previous findings, we can observe the following:

wl+1=wl+xy||wl+1||2=||wl+xy||2=(wl+xy)T(wl+xy)=||wl||2+2(wlTx)y+||x||2y2||wl+1||2||wl||2+R2(||wl1||2+R2)+R2||w0||2+lR2||wl+1||2lR2[1]

Furthermore, we have:

wl+1=wl+xy(wl+1)Tw=(wl+xy)Tw=wlTw+(wTx)y(wl+1)TwwlTw+γ(wl1Tw+γ)+γw0Tw+lγ(wl+1)Twlγ((wl+1)Tw)2l2γ2||wl+1||2||w||2l2γ2Using the Cauchy-Schwarz inequality||wl+1||2l2γ2[2]

Combining equations [1] and [2], we obtain:

l2γ2||wl+1||2lR2l2γ2lR2lR2γ2

Consequently, the above equation establishes an upper bound on the number of mistakes for datasets conforming to the Linear Separability with γ-Margin property and having a finite radius R. This result demonstrates the convergence of the perceptron algorithm.