Perceptron Classification and Model Training
Posted
by jake pinedo
on Stack Overflow
See other posts from Stack Overflow
or by jake pinedo
Published on 2010-05-03T23:41:51Z
Indexed on
2010/05/03
23:48 UTC
Read the original article
Hit count: 334
I'm having an issue with understanding how the Perceptron algorithm works and implementing it.
cLabel = 0 #class label: corresponds directly with featureVectors and tweets
for m in range(miters):
for point in featureVectors:
margin = answers[cLabel] * self.dot_product(point, w)
if margin <= 0:
modifier = float(lrate) * float(answers[cLabel])
modifiedPoint = point
for x in modifiedPoint:
if x != 0:
x *= modifier
newWeight = [modifiedPoint[i] + w[i] for i in range(len(w))]
w = newWeight
self._learnedWeight = w
This is what I've implemented so far, where I have a list of class labels in answers and a learning rate (lrate) and a list of feature vectors.
I run it for the numbers of iterations in miter and then get the final weight at the end. However, I'm not sure what to do with this weight. I've trained the perceptron and now I have to classify a set of tweets, but I don't know how to do that.
EDIT:
Specifically, what I do in my classify method is I go through and create a feature vector for the data I'm given, which isn't a problem at all, and then I take the self._learnedWeight that I get from the earlier training code and compute the dot-product of the vector and the weight. My weight and feature vectors include a bias in the 0th term of the list so I'm including that. I then check to see if the dotproduct is less than or equal to 0: if so, then I classify it as -1. Otherwise, it's 1.
However, this doesn't seem to be working correctly.
© Stack Overflow or respective owner