forked from VowpalWabbit/vowpal_wabbit
-
Notifications
You must be signed in to change notification settings - Fork 0
One Against All (oaa) multi class example
arielf edited this page Oct 1, 2012
·
9 revisions
OAA stands for "One Against All".
The option --oaa <K>
where is the number of distinct classes
directs vw to perform K multi-class (as opposed to binary) classification.
- Data-set labels must be in the natural number set {1 .. <K>}
- <K> is the maximum label value, and must be passed as an argument to
--oaa
- Uses a loop of K separate binary classifications.
- Each iteration classifies target feature i of K against all others (binary classification).
Assume we have a 3-class classfication problem. We label our 3 classes {1,2,3}
Our data set oaa.dat
may look like this
1 ex1| a
2 ex2| a b
3 ex3| a b c
2 ex4| b a
1 ex5| d e
This is essentially the same format as the non multi-class case (classification or regression) except each label must belong to one of the {1 .. <K>} classes, i.e. a natural number between 1 and <K>. You may add weights to the example and the features, use name-spaces, etc.
We train:
vw --oaa 3 oaa.dat -f oaa.model
And predict:
vw -t -i oaa.model oaa.dat -p oaa.predict
Similar to what we do in vanilla classification or regression.