Multiclass Classification
Reduction | Gist | Training Time | Prediction Time | Remark |
---|---|---|---|---|
OvA | Is it or not? | Not robust | ||
OvO | Is it or ? | can achieve very small training error | ||
ECOC | Assign bits per class. Is this specific bit on or off? | Needs diversity when designing code | ||
Tree | Which half does it belong to? | Good for extreme classifications |
OvA (One-vs-All or One-vs-Rest)โ
- A binary classifier is trained against each category's combined classes. So, if there are classes, binary classifiers are trained.
- For prediction, all classifiers predict the class. The class with the highest confidence score is selected as the final prediction.
OvO (One-vs-One)โ
- A binary classifier is trained for every pair of classes. So, if there are classes, classifiers are trained.
- For prediction, the class that gets voted for the most across all classifiers is chosen.
ECOC (Error-Correcting Output Codes)โ
- This method represents each class with a unique binary length code . The aim is to train binary classifiers not just based on separating types but also based on distinguishing these binary codes.
- During prediction, the class code closest to the predicted code (in terms of Hamming distance or other metrics) is selected.
Decision Treesโ
- Instead of converting the multiclass problem to multiple binary problems, decision trees handle multiclass classification directly by splitting data points at each node based on feature values, eventually leading them to a leaf node representing a class.
- Random Forests, gradient-boosted trees, and other ensemble tree methods can also be used for multiclass classification.
Comparisonโ
Efficiencyโ
- OvA โ Requires training classifiers.
- OvO โ Requires training classifiers, which can be computationally expensive as grows.
- ECOC โ The number of classifiers is determined by the length of the code, which is generally less than and .
- Tree โ A single tree is trained, but ensemble methods like Random Forests would involve teaching multiple trees.
Scalabilityโ
- OvA โ Scales linearly with the number of classes.
- OvO โ Quadratic scalability with the number of classes can be inefficient for an enormous .
- ECOC โ Scalability can vary depending on the coding design.
- Tree โ Scales well with the number of classes, but tree depth might increase.
Decision Boundaryโ
- OvA โ This can lead to imbalanced decision boundaries since one class is always compared against all others combined.
- OvO โ Often results in more balanced decision boundaries since it considers every pair of classes separately.
- ECOC โ The coding design determines the decision boundary.
- Tree โ Produces orthogonal decision boundaries based on feature splits.
Complexityโ
- OvA and OvO โ Relatively straightforward to understand.
- ECOC โ Requires an additional step of designing and decoding the binary codes for classes.
- Tree โ Interpretable as it offers hierarchical decisions based on features.