Combining Weak Learners into a Strong Classifier

后端 未结 2 1323
暗喜
暗喜 2021-02-09 13:37

How do I combine few weak learners into a strong classifier? I know the formula, but the problem is that in every paper about AdaBoost that I\'ve read there are only formulas wi

2条回答
  •  独厮守ぢ
    2021-02-09 14:04

    If I understand your question correctly, you have a great explanation on how boosting ensambles the weak classifiers into a strong classifier with a lot of images in these lecture notes:

    www.csc.kth.se/utbildning/kth/kurser/DD2427/bik12/DownloadMaterial/Lectures/Lecture8.pdf

    Basically you are by taking the weighted combination of the separating hyperplanes creating a more complex decision surface (great plots showing this in the lecture notes)

    Hope this helps.

    EDIT

    To do it practically:

    in page 42 you see the formulae for alpha_t = 1/2*ln((1-e_t)/e_t) which easily can be calculated in a for loop, or if you are using some numeric library (I'm using numpy which is really great) directly by vector operations. The alpha_t is calculated inside of the adaboost so I assume you already have these.

    You have the mathematical formulae at page 38, the big sigma stands for sum over all. h_t is the weak classifier function and it returns either -1 (no) or 1 (yes). alpha_t is basically how good the weak classifier is and thus how much it has to say in the final decision of the strong classifier (not very democratic).

    I don't really use forloops never, but I'll be easier to understand and more language independent (this is pythonish pseudocode):

    strongclassifier(x):
        response=0
        for t in T: #over all weakclassifiers indices
            response += alpha[t]*h[t](x)
        return sign(response)
    

    This is mathematically called the dot product between the weights and the weak-responses (basically: strong(x) = alpha*weak(x)).

    http://en.wikipedia.org/wiki/Dot_product

    EDIT2

    This is what is happening inside strongclassifier(x): Separating hyperplane is basically decided in the function weak(x), so all x's which has weak(x)=1 is on one side of the hyperplane while weak(x)=-1 is on the other side of the hyperplane. If you think about it has lines on a plane you have a plane separating the plane into two parts (always), one side is (-) and the other one is (+). If you now have 3 infinite lines in the shape of a triangle with their negative side faced outwards, you will get 3 (+)'s inside the triangle and 1 or 2 (-)'s outside which results (in the strong classifier) into a triangle region which is positive and the rest negative. It's an over simplification but the point is still there and it works totally analogous in higher dimensions.

提交回复
热议问题