Weighted majority algorithm (machine learning)

From HandWiki
Short description: Method of using a pool of algorithms

In machine learning, weighted majority algorithm (WMA) is a meta learning algorithm used to construct a compound algorithm from a pool of prediction algorithms, which could be any type of learning algorithms, classifiers, or even real human experts.[1][2] The algorithm assumes that we have no prior knowledge about the accuracy of the algorithms in the pool, but there are sufficient reasons to believe that one or more will perform well.

Assume that the problem is a binary decision problem. To construct the compound algorithm, a positive weight is given to each of the algorithms in the pool. The compound algorithm then collects weighted votes from all the algorithms in the pool, and gives the prediction that has a higher vote. If the compound algorithm makes a mistake, the algorithms in the pool that contributed to the wrong predicting will be discounted by a certain ratio β where 0<β<1.

It can be shown that the upper bounds on the number of mistakes made in a given sequence of predictions from a pool of algorithms [math]\displaystyle{ \mathbf{A} }[/math] is

[math]\displaystyle{ \mathbf{O(log|A|+m)} }[/math]

if one algorithm in [math]\displaystyle{ \mathbf{x}_i }[/math] makes at most [math]\displaystyle{ \mathbf{m} }[/math] mistakes.

There are many variations of the weighted majority algorithm to handle different situations, like shifting targets, infinite pools, or randomized predictions. The core mechanism remains similar, with the final performances of the compound algorithm bounded by a function of the performance of the specialist (best performing algorithm) in the pool.

See also

References

  1. Littlestone, N.; Warmuth, M. (1994). "The Weighted Majority Algorithm". Information and Computation 108 (2): 212–261. doi:10.1006/inco.1994.1009. http://www.dklevine.com/archive/refs4575.pdf. 
  2. Littlestone, N.; Warmuth, M. (1989). "Weighted Majority Algorithm". IEEE Symposium on Foundations of Computer Science..