AdaBoost Lecture 8 Jason Corso SUNY at Buffalo March 30 2010 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 1 / 62 Introduction In the last lecture, we looked at 1 2 Lack of inherent superiority of any one particular classifier; Some systematic ways for selecting a particular method over another for a given scenario; And, we talked briefly about the bagging method for integrating component classifiers. Now, we turn to boosting and the AdaBoost method for integrating component classifiers into one strong classifier. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 2 / 62 Introduction Rationale Imagine the situation where you want to build an email filter that can distinguish spam from non-spam. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 3 / 62 Introduction Rationale Imagine the situation where you want to build an email filter that can distinguish spam from non-spam. The general way we would approach this problem in ML/PR follows the same scheme we have for the other topics: J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 3 / 62 Introduction Rationale Imagine the situation where you want to build an email filter that can distinguish spam from non-spam. The general way we would approach this problem in ML/PR follows the same scheme we have for the other topics: 1 2 3 4 Gathering as many examples as possible of both spam and non-spam emails. Train a classifier using these examples and their labels. Take the learned classifier, or prediction rule, and use it to filter your mail. The goal is to train a classifier that makes the most accurate predictions possible on new test examples. And, we’ve covered related topics on how to measure this like bias and variance. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 3 / 62 Introduction Rationale Imagine the situation where you want to build an email filter that can distinguish spam from non-spam. The general way we would approach this problem in ML/PR follows the same scheme we have for the other topics: 1 2 3 4 Gathering as many examples as possible of both spam and non-spam emails. Train a classifier using these examples and their labels. Take the learned classifier, or prediction rule, and use it to filter your mail. The goal is to train a classifier that makes the most accurate predictions possible on new test examples. And, we’ve covered related topics on how to measure this like bias and variance. But, building a highly accurate classifier is a difficult task. (You still get spam, right?!) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 3 / 62 Introduction We could probably come up with many quick rules of thumb. These could be only moderately accurate. Can you think of an example for this situation? J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 4 / 62 Introduction We could probably come up with many quick rules of thumb. These could be only moderately accurate. Can you think of an example for this situation? An example could be “if the subject line contains ‘buy now’ then classify as spam.” J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 4 / 62 Introduction We could probably come up with many quick rules of thumb. These could be only moderately accurate. Can you think of an example for this situation? An example could be “if the subject line contains ‘buy now’ then classify as spam.” This certainly doesn’t cover all spams, but it will be significantly better than random guessing. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 4 / 62 Introduction Basic Idea of Boosting Boosting refers to a general and provably effective method of producing a very accurate classifier by combining rough and moderately inaccurate rules of thumb. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 5 / 62 Introduction Basic Idea of Boosting Boosting refers to a general and provably effective method of producing a very accurate classifier by combining rough and moderately inaccurate rules of thumb. It is based on the observation that finding many rough rules of thumb can be a lot easier than finding a single, highly accurate classifier. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 5 / 62 Introduction Basic Idea of Boosting Boosting refers to a general and provably effective method of producing a very accurate classifier by combining rough and moderately inaccurate rules of thumb. It is based on the observation that finding many rough rules of thumb can be a lot easier than finding a single, highly accurate classifier. To begin, we define an algorithm for finding the rules of thumb, which we call a weak learner. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 5 / 62 Introduction Basic Idea of Boosting Boosting refers to a general and provably effective method of producing a very accurate classifier by combining rough and moderately inaccurate rules of thumb. It is based on the observation that finding many rough rules of thumb can be a lot easier than finding a single, highly accurate classifier. To begin, we define an algorithm for finding the rules of thumb, which we call a weak learner. The boosting algorithm repeatedly calls this weak learner, each time feeding it a different distribution over the training data (in Adaboost). J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 5 / 62 Introduction Basic Idea of Boosting Boosting refers to a general and provably effective method of producing a very accurate classifier by combining rough and moderately inaccurate rules of thumb. It is based on the observation that finding many rough rules of thumb can be a lot easier than finding a single, highly accurate classifier. To begin, we define an algorithm for finding the rules of thumb, which we call a weak learner. The boosting algorithm repeatedly calls this weak learner, each time feeding it a different distribution over the training data (in Adaboost). Each call generates a weak classifier and we must combine all of these into a single classifier that, hopefully, is much more accurate than any one of the rules. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 5 / 62 Introduction A Toy Example (From Schapire’s Slides) Toy Example D1 weak classifiers = vertical or horizontal half-planes J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 6 / 62 Introduction A Toy Example (From Schapire’s Slides) Round 1 h1 D2 ε1 =0.30 α1=0.42 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 6 / 62 A Toy Example (From Schapire’s Slides) Introduction Round 2 h2 D3 ε2 =0.21 α2=0.65 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 6 / 62 A Toy Example (From Schapire’s Slides) Introduction Round 3 h3 ε3 =0.14 α3=0.92 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 6 / 62 A Toy Example (From Schapire’s Slides) Introduction Final Classifier H = sign final = 0.42 ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! ! + 0.65 $ % $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' $ % $ % $ % $ % $ % $ % $ % $ % $ % & ' & ' ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # ( ) ( ) ( ) " ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # ( ) " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # " " # " # " # " # " # " # " # " # " # " # " # " # J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 + 0.92 March 30 2010 6 / 62 Introduction A Toy Example (From Schapire’s Slides) STOP! J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 7 / 62 Introduction Introduction Wrap-Up Key Questions Defining and Analyzing Boosting 1 How should the distribution be chosen each round? J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 8 / 62 Introduction Introduction Wrap-Up Key Questions Defining and Analyzing Boosting 1 How should the distribution be chosen each round? 2 How should the weak rules be combined into a single rule? J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 8 / 62 Introduction Introduction Wrap-Up Key Questions Defining and Analyzing Boosting 1 How should the distribution be chosen each round? 2 How should the weak rules be combined into a single rule? 3 How should the weak learner be defined? J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 8 / 62 Introduction Introduction Wrap-Up Key Questions Defining and Analyzing Boosting 1 How should the distribution be chosen each round? 2 How should the weak rules be combined into a single rule? 3 How should the weak learner be defined? 4 How many weak classifiers should we learn? J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 8 / 62 Basic AdaBoost Getting Started We are given a training set D = {(xi , yi ) : xi ∈ Rd , yi ∈ {−1, +1}, i = 1, . . . , m}. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 (1) 9 / 62 Basic AdaBoost Getting Started We are given a training set D = {(xi , yi ) : xi ∈ Rd , yi ∈ {−1, +1}, i = 1, . . . , m}. (1) For example, xi could represent some encoding of an email message (say in the vector-space text model), and yi is whether or not this message is spam. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 9 / 62 Basic AdaBoost Getting Started We are given a training set D = {(xi , yi ) : xi ∈ Rd , yi ∈ {−1, +1}, i = 1, . . . , m}. (1) For example, xi could represent some encoding of an email message (say in the vector-space text model), and yi is whether or not this message is spam. Note that we are working in a two-class setting, and this will be the case for the majority of our discussion. Some extensions to multi-class scenarios will be presented. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 9 / 62 Basic AdaBoost Getting Started We are given a training set D = {(xi , yi ) : xi ∈ Rd , yi ∈ {−1, +1}, i = 1, . . . , m}. (1) For example, xi could represent some encoding of an email message (say in the vector-space text model), and yi is whether or not this message is spam. Note that we are working in a two-class setting, and this will be the case for the majority of our discussion. Some extensions to multi-class scenarios will be presented. We P need to define a distribution D over the dataset D such that i D(i) = 1. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 9 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Weak Learners and Weak Classifiers First, we concretely define a weak classifier: ht : Rd → {−1, +1} J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 (2) March 30 2010 10 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Weak Learners and Weak Classifiers First, we concretely define a weak classifier: ht : Rd → {−1, +1} (2) A weak classifier must work better than chance. In the two-class setting this means it has less than 50% error and this is easy; if it would have higher than 50% error, just flip the sign. So, we want only a classifier that does not have exactly 50% error (since these classifiers would add no information). J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 10 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Weak Learners and Weak Classifiers First, we concretely define a weak classifier: ht : Rd → {−1, +1} (2) A weak classifier must work better than chance. In the two-class setting this means it has less than 50% error and this is easy; if it would have higher than 50% error, just flip the sign. So, we want only a classifier that does not have exactly 50% error (since these classifiers would add no information). The error rate of a weak classifier ht (x) is calculated empirically over the training data: m (ht ) = 1 1 X δ(ht (xi ) 6= yi ) < . m 2 (3) i=1 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 10 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Given example images where for negative and positive examples respectively. A WL/WC Example for Images Initialize weights for respectively, where and are the number of negatives and positives respectively. Consider the case that our input data xi are For : rectangular image patches. 1. Normalize the weights, And consider this case closely as it is part of project I. so that is a probability distribution. 2. For each feature, , train a classifi er which is restricted to using a single feature. The error is evaluated with respect to , . 3. Choose the classifi er, , with the lowest error . 4. Update the weights: where rectly, if example otherwise, and is classifi ed cor. The fi nal strong classifi er is: J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 Figure 3: The first and se aBoost. The two features ar overlayed on a typical train first feature measures the di region of the eyes and a reg feature capitalizes on the o often darker than the cheek the intensities in the eye re bridge of the nose. of the nose and cheeks (se atively in comparison Marchlarge 30 2010 11 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Given example images where for negative and positive examples respectively. A WL/WC Example for Images Initialize weights for respectively, where and are the number of negatives and positives respectively. Consider the case that our input data xi are For : rectangular image patches. 1. Normalize the weights, And consider this case closely as it is part of project I. so that is a probability distribution. Define a collection of Haar-like eacheach feature, train a classifi er which single feature [2].2.AsFor a result stage of, the boosting process, which selects a new weak classifier, can beaviewed is restricted to using single feature. The rectangle features. as a feature selection process. AdaBoost provides an effecerror is evaluated with respect to , Figure 3: The first and se aBoost. The two features ar overlayed on a typical train B first feature measures the di region of the eyes and a reg feature capitalizes on the o often darker than the cheek the intensities Din the eye re bridge of the nose. tive learning algorithm and strong bounds on generalization . A performance [13, 9, 10]. The third major3.contribution of classifi this paper Choose the er,is a, method with the lowest error . for combining successively more complex classifiers in a 4. Update the weights: cascade structure which dramatically increases the speed of the detector by focusing attention on promising regions of the image. The notion behind focus of attention approaches C is that it is often possible to rapidly determine where in an image an object mightwhere occur [17, 8, 1]. More complex pro- is classifi ed corif example cessing is reserved only for these promising regions. rectly, otherwise, andThe . 1: Example rectangle features shown relative to the Figure key measure of such an approach is the “false negative” rate enclosing detection window. The sum of the pixels which of the attentional process. It must be the case that all, or lie within the white rectangles are subtracted from the sum(se The fi nal strong classifi er is: of the nose and cheeks almost all, object instances are selected by the attentional of pixels in the grey rectangles. Two-rectangle features are atively large in comparison filter.(SUNY at Buffalo) J. Corso AdaBoost Lectureshown 8 March 30 2010 11 / 62 in (A) and (B). Figure (C) shows a three-rectangle The feature value extracted is the difference of the pixel sum in the white sub-regions and the black sub-regions. With a base patch size of 24x24, there are over 180,000 possible such rectangle features. Basic AdaBoost Weak Learners and Weak Classifiers Although these features are somewhat primitive in comparison to things like steerable filters, SIFT keys, etc., they do provide a rich set on which boosting can learn. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 12 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Although these features are somewhat primitive in comparison to things like steerable filters, SIFT keys, etc., they do provide a rich set on which boosting can learn. And, they are quite efficiently computed when using the integral image representation. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 12 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Although these features are somewhat primitive in comparison to things like steerable filters, SIFT keys, etc., they do provide a rich set on which boosting can learn. And, they are quite efficiently computed when using the integral image representation. Define the integral image as the image whose pixel value at a particular pixel x, y is the sum of the pixel values to the left and above x, y in the original image: X ii(x, y) = i(x, y) (4) x0 ≤x,y 0 ≤y where ii is the integral image and i is the original image. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 12 / 62 Basic AdaBoost Weak Learners and Weak Classifiers Although these features are somewhat primitive in comparison to things like steerable filters, SIFT keys, etc., they do provide a rich set on which boosting can learn. And, they are quite efficiently computed when using the integral image representation. Define the integral image as the image whose pixel value at a particular pixel x, y is the sum of the pixel values to the left and above x, y in the original image: X ii(x, y) = i(x, y) (4) x0 ≤x,y 0 ≤y where ii is the integral image and i is the original image. Use the following pair of recurrences to compute the integral image in just one pass. s(x, y) = s(x, y − 1) + i(x, y) (5) ii(x, y) = ii(x − 1, y) + s(x, y) (6) where we define s(x, −1) = 0 and ii(−1, y) = 0. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 12 / 62 Basic AdaBoost Weak Learners and Weak Classifiers The sum of a particular rectangle can be computed in just 4 references using the integral image. The value at point 1 is the sum of the pixels in rectangle A. A B 1 Point 2 is A+B. 3 Point 3 is A+C. 2 D C 4 Point 4 is A+B+C+D. Figure 2: The sum of the pixels within rectangle can be computed with four array references. The value of the integral image at location 1 is the sum of the pixels in rectangle . The value at location 2 is , at location 3 is , and at location 4 is . The sum within can be computed as . where is the integral image and is the original image. Using the following pair of recurrences: J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 13 /(1) 62 Basic AdaBoost Weak Learners and Weak Classifiers The sum of a particular rectangle can be computed in just 4 references using the integral image. The value at point 1 is the sum of the pixels in rectangle A. A B 1 Point 2 is A+B. 3 Point 3 is A+C. 2 D C 4 Point 4 is A+B+C+D. So, the sum within D alone is 4+1-2-3. Figure 2: The sum of the pixels within rectangle can be computed with four array references. The value of the integral image at location 1 is the sum of the pixels in rectangle . The value at location 2 is , at location 3 is , and at location 4 is . The sum within can be computed as . where is the integral image and is the original image. Using the following pair of recurrences: J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 13 /(1) 62 Basic AdaBoost Weak Learners and Weak Classifiers The sum of a particular rectangle can be computed in just 4 references using the integral image. The value at point 1 is the sum of the pixels in rectangle A. A B 1 Point 2 is A+B. 3 Point 3 is A+C. 2 D C 4 Point 4 is A+B+C+D. So, the sum within D alone is 4+1-2-3. Figure 2: The sum of the pixels within rectangle can be computed with four array references. The value of the inteWe have a bunch of features. We certainly we gral image atcan’t location 1use is thethem sum of theall. pixelsSo, in rectangle . The value at location 2 is , at location 3 is , let the boosting procedure select theand best. But before we can do this, at location 4 is . The sum within can computed asweak learner. . we need to pair these features with abesimple where is the integral image and is the original image. Using the following pair of recurrences: J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 13 /(1) 62 Basic AdaBoost Weak Learners and Weak Classifiers Each run, the weak learner is designed to select the single rectangle feature which best separates the positive and negative examples. The weak learner searches for the optimal threshold classification function, such that the minimum number of examples are misclassified. The weak classifier ht (x) hence consists of the feature ft (x), a threshold θt , and a parity pt indicating the direction of the inequality sign: ( +1 if pt ft (x) < pt θt ht (x) = (7) −1 otherwise. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 14 / 62 Basic AdaBoost The AdaBoost Classifier The Strong AdaBoost Classifier Let’s assume we have selected T weak classifiers and a scalar constant αt associated with each: J. Corso (SUNY at Buffalo) h = {ht : t = 1, . . . , T } (8) α = {αt : t = 1, . . . , T } (9) AdaBoost Lecture 8 March 30 2010 15 / 62 Basic AdaBoost The AdaBoost Classifier The Strong AdaBoost Classifier Let’s assume we have selected T weak classifiers and a scalar constant αt associated with each: h = {ht : t = 1, . . . , T } (8) α = {αt : t = 1, . . . , T } (9) Denote the inner product over all weak classifiers as F : F (x) = T X αt ht (x) = hα, h(x)i (10) t=1 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 15 / 62 Basic AdaBoost The AdaBoost Classifier The Strong AdaBoost Classifier Let’s assume we have selected T weak classifiers and a scalar constant αt associated with each: h = {ht : t = 1, . . . , T } (8) α = {αt : t = 1, . . . , T } (9) Denote the inner product over all weak classifiers as F : F (x) = T X αt ht (x) = hα, h(x)i (10) t=1 Define the strong classifier as the sign of this inner product: " T # X H(x) = sign [F (x)] = sign αt ht (x) (11) t=1 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 15 / 62 Basic AdaBoost The AdaBoost Classifier Our objective is to choose h and α to minimize the empirical classification error of the strong classifier. (h, α)∗ = argmin Err(H; D) m 1 X δ(H(xi ) 6= yi ) = argmin m (12) (13) i=1 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 16 / 62 Basic AdaBoost The AdaBoost Classifier Our objective is to choose h and α to minimize the empirical classification error of the strong classifier. (h, α)∗ = argmin Err(H; D) m 1 X δ(H(xi ) 6= yi ) = argmin m (12) (13) i=1 Adaboost doesn’t directly minimize this error but rather minimizes an upper bound on it. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 16 / 62 Basic AdaBoost The AdaBoost Classifier Illustration of AdaBoost Classifier Weak Learner Input J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 17 / 62 Basic AdaBoost The AdaBoost Algorithm The Basic AdaBoost Algorithm Given D = (xi , yi ), . . . , (xm , ym ) as before. Initialize the distribution D1 to be uniform: D1 (i) = Repeat for t = 1, . . . , T : 1 Learn weak classifier ht using distribution Dt . 1 m. For the example given, this requires you to learn the threshold and the parity at each iteration given the current distribution Dt for the weak classifier h over each feature: Note, there are other ways of doing this step... J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 18 / 62 Basic AdaBoost The AdaBoost Algorithm The Basic AdaBoost Algorithm Given D = (xi , yi ), . . . , (xm , ym ) as before. Initialize the distribution D1 to be uniform: D1 (i) = Repeat for t = 1, . . . , T : 1 Learn weak classifier ht using distribution Dt . 1 m. For the example given, this requires you to learn the threshold and the parity at each iteration given the current distribution Dt for the weak classifier h over each feature: 1 Compute the weighted error for each weak classifier. t (h) = m X Dt (i)δ(h(xi ) 6= yi ), ∀h (14) i=1 Note, there are other ways of doing this step... J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 18 / 62 Basic AdaBoost The AdaBoost Algorithm The Basic AdaBoost Algorithm Given D = (xi , yi ), . . . , (xm , ym ) as before. Initialize the distribution D1 to be uniform: D1 (i) = Repeat for t = 1, . . . , T : 1 Learn weak classifier ht using distribution Dt . 1 m. For the example given, this requires you to learn the threshold and the parity at each iteration given the current distribution Dt for the weak classifier h over each feature: 1 Compute the weighted error for each weak classifier. t (h) = m X Dt (i)δ(h(xi ) 6= yi ), ∀h (14) i=1 2 Select the weak classifier with minimum error. ht = argminh t (h) (15) Note, there are other ways of doing this step... J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 18 / 62 Basic AdaBoost The AdaBoost Algorithm 2 Set weight αt based on the error: 1 1 − t (ht ) αt = ln 2 t (ht ) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 (16) March 30 2010 19 / 62 Basic AdaBoost The AdaBoost Algorithm 2 Set weight αt based on the error: 1 1 − t (ht ) αt = ln 2 t (ht ) (16) 3 Update the distribution based on the performance so far: Dt+1 (i) = 1 Dt (i) exp [−αt yi ht (xi )] Zt (17) where Zt is a normalization factor to keep Dt+1 a distribution. Note the careful evaluation of the term inside of the exp based on the possible {−1, +1} values of the label. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 19 / 62 Basic AdaBoost The AdaBoost Algorithm 2 Set weight αt based on the error: 1 1 − t (ht ) αt = ln 2 t (ht ) (16) 3 Update the distribution based on the performance so far: Dt+1 (i) = 1 Dt (i) exp [−αt yi ht (xi )] Zt (17) where Zt is a normalization factor to keep Dt+1 a distribution. Note the careful evaluation of the term inside of the exp based on the possible {−1, +1} values of the label. One chooses T based on some established error criterion or some fixed number. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 19 / 62 AdaBoost Analysis Contents for AdaBoost Analysis Facts about the weights and normalizing functions. AdaBoost Convergence (why and how fast). Why do we calculate the weight of each weak classifier to be αt = 1 1 − t (ht ) ln ? 2 t (ht ) Why do we choose the weak classifier that has the minimum weighted error? Testing Error Analysis. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 20 / 62 AdaBoost Analysis Facts About the Weights Weak Classifier Weights The selected weight for each new weak classifier is always positive. t (ht ) < J. Corso (SUNY at Buffalo) 1 1 1 − t (ht ) ⇒ αt = ln >0 2 2 t (ht ) AdaBoost Lecture 8 (18) March 30 2010 21 / 62 AdaBoost Analysis Facts About the Weights Weak Classifier Weights The selected weight for each new weak classifier is always positive. t (ht ) < 1 1 1 − t (ht ) ⇒ αt = ln >0 2 2 t (ht ) (18) The smaller the classification error, the bigger the weight and the more this particular weak classifier will impact the final strong classifier. (hA ) < (hB ) ⇒ αA > αB J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 (19) March 30 2010 21 / 62 AdaBoost Analysis Facts About the Weights Data Sample Weights The weights of the data points are multiplied by exp [−yi αt ht (xi )]. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 22 / 62 AdaBoost Analysis Facts About the Weights Data Sample Weights The weights of the data points are multiplied by exp [−yi αt ht (xi )]. ( exp [−αt ] < 1 if ht (xi ) = yi exp [−yi αt ht (xi )] = (20) exp [αt ] > 1 if ht (xi ) 6= yi The weights of correctly classified points are reduced and the weights of incorrectly classified points are increased. Hence, the incorrectly classified points will receive more attention in the next run. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 22 / 62 AdaBoost Analysis The weight distribution can be computed recursively: 1 Dt (i) exp [−αt yi ht (xi )] (21) Zt 1 Dt−1 (i) exp −yi αt ht (xi ) + αt−1 ht−1 (xi ) = Zt−1 Zt = ... 1 D1 (i) exp −yi αt ht (xi ) + · · · + α1 h1 (xi ) = Z1 . . . Zt Dt+1 (i) = J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 23 / 62 AdaBoost Analysis Facts About the Normalizing Functions At each iteration, the weights on the data points are normalized by X Zt = Dt (xi ) exp [−yi αi ht (xi )] (22) xi = X Dt (xi ) exp [−αt ] + xi ∈A X Dt (xi ) exp [αt ] (23) xi ∈A where A is the set of correctly classified points: {xi : yi = ht (xi )}. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 24 / 62 AdaBoost Analysis Facts About the Normalizing Functions At each iteration, the weights on the data points are normalized by X Zt = Dt (xi ) exp [−yi αi ht (xi )] (22) xi = X Dt (xi ) exp [−αt ] + xi ∈A X Dt (xi ) exp [αt ] (23) xi ∈A where A is the set of correctly classified points: {xi : yi = ht (xi )}. We can write these normalization factors as functions of αt , then: Zt = Zt (αt ) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 (24) March 30 2010 24 / 62 AdaBoost Analysis Recall the data weights can be computed recursively: Dt+1 (i) = J. Corso (SUNY at Buffalo) 1 1 exp −yi F (xi ) . Z1 . . . Zt m AdaBoost Lecture 8 March 30 2010 (25) 25 / 62 AdaBoost Analysis Recall the data weights can be computed recursively: Dt+1 (i) = 1 1 exp −yi F (xi ) . Z1 . . . Zt m (25) And, since we know the data weights must sum to one, we have m X Dt (xi ) = i=1 J. Corso (SUNY at Buffalo) m 1 1 X exp −yi F (xi ) = 1 Z1 . . . Zt m (26) i=1 AdaBoost Lecture 8 March 30 2010 25 / 62 AdaBoost Analysis Recall the data weights can be computed recursively: Dt+1 (i) = 1 1 exp −yi F (xi ) . Z1 . . . Zt m (25) And, since we know the data weights must sum to one, we have m X Dt (xi ) = i=1 m 1 1 X exp −yi F (xi ) = 1 Z1 . . . Zt m (26) i=1 Therefore, we can summarize this with a new normalizing function: Z = Z1 . . . Zt = m 1 X exp −yi F (xi ) . m (27) i=1 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 25 / 62 AdaBoost Analysis AdaBoost Convergence AdaBoost Convergence Key Idea: AdaBoost minimizes an upper bound on the classification error. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 26 / 62 AdaBoost Analysis AdaBoost Convergence AdaBoost Convergence Key Idea: AdaBoost minimizes an upper bound on the classification error. Claim: After t steps, the error of the strong classifier is bounded above by quantity Z, as we just defined it (the product of the data weight normalization factors): Err(H) ≤ Z = Z(α, h) = Zt (αt , ht ) . . . Z1 (α1 , h1 ) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 (28) 26 / 62 AdaBoost Analysis AdaBoost Convergence AdaBoost Convergence Key Idea: AdaBoost minimizes an upper bound on the classification error. Claim: After t steps, the error of the strong classifier is bounded above by quantity Z, as we just defined it (the product of the data weight normalization factors): Err(H) ≤ Z = Z(α, h) = Zt (αt , ht ) . . . Z1 (α1 , h1 ) (28) AdaBoost is a greedy algorithm that minimizes this upper bound on the classification error by choosing the optimal ht and αt to minimize Zt at each step. (h, α)∗ = argmin Z(α, h) (29) ∗ (ht , αt ) = argmin Zt (αt , ht ) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 (30) March 30 2010 26 / 62 AdaBoost Analysis AdaBoost Convergence AdaBoost Convergence Key Idea: AdaBoost minimizes an upper bound on the classification error. Claim: After t steps, the error of the strong classifier is bounded above by quantity Z, as we just defined it (the product of the data weight normalization factors): Err(H) ≤ Z = Z(α, h) = Zt (αt , ht ) . . . Z1 (α1 , h1 ) (28) AdaBoost is a greedy algorithm that minimizes this upper bound on the classification error by choosing the optimal ht and αt to minimize Zt at each step. (h, α)∗ = argmin Z(α, h) (29) ∗ (ht , αt ) = argmin Zt (αt , ht ) (30) As Z goes to zero, the classification error goes to zero. Hence, it converges. (But, we need to account for the case when no new weak classifier has an error rate better than 0.5, upon which time we should stop.) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 26 / 62 AdaBoost Analysis AdaBoost Convergence We need to show the claim on the error bound is true: m m i=1 i=1 1 X 1 X δ(H(xi ) 6= yi ) ≤ Z = exp [−yi F (xi )] (31) Err(H) = m m J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 27 / 62 AdaBoost Analysis AdaBoost Convergence We need to show the claim on the error bound is true: m m i=1 i=1 1 X 1 X δ(H(xi ) 6= yi ) ≤ Z = exp [−yi F (xi )] (31) Err(H) = m m Proof: J. Corso (SUNY at Buffalo) F (xi ) = sign(F (xi ))|F (xi )| (32) = H(xi )|F (xi )| (33) AdaBoost Lecture 8 March 30 2010 27 / 62 AdaBoost Analysis AdaBoost Convergence We need to show the claim on the error bound is true: m m i=1 i=1 1 X 1 X δ(H(xi ) 6= yi ) ≤ Z = exp [−yi F (xi )] (31) Err(H) = m m Proof: F (xi ) = sign(F (xi ))|F (xi )| (32) = H(xi )|F (xi )| (33) The two cases are: If H(xi ) 6= yi then the LHS = 1 ≤ RHS = e+|F (xi )| . If H(xi ) = yi then the LHS = 0 ≤ RHS = e−|F (xi )| . J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 27 / 62 AdaBoost Analysis AdaBoost Convergence We need to show the claim on the error bound is true: m m i=1 i=1 1 X 1 X δ(H(xi ) 6= yi ) ≤ Z = exp [−yi F (xi )] (31) Err(H) = m m Proof: F (xi ) = sign(F (xi ))|F (xi )| (32) = H(xi )|F (xi )| (33) The two cases are: If H(xi ) 6= yi then the LHS = 1 ≤ RHS = e+|F (xi )| . If H(xi ) = yi then the LHS = 0 ≤ RHS = e−|F (xi )| . So, the inequality holds for each term δ(H(xi ) 6= yi ) ≤ exp [−yi F (xi )] (34) and hence, the inequality is true. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 27 / 62 AdaBoost Analysis AdaBoost Convergence Weak Classifier Pursuit Now, we want to explore how we are solving the step-wise minimization problem: (ht , αt )∗ = argmin Z(αt , ht ) (35) Recall, we can separate Z into two parts: X X Dt (xi ) exp [αt ] Zt (αt , ht ) = Dt (xi ) exp [−αt ] + xi ∈A (36) xi ∈A where A is the set of correctly classified points: {xi : yi = ht (xi )}. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 28 / 62 AdaBoost Analysis AdaBoost Convergence Weak Classifier Pursuit Now, we want to explore how we are solving the step-wise minimization problem: (ht , αt )∗ = argmin Z(αt , ht ) (35) Recall, we can separate Z into two parts: X X Dt (xi ) exp [αt ] Zt (αt , ht ) = Dt (xi ) exp [−αt ] + xi ∈A (36) xi ∈A where A is the set of correctly classified points: {xi : yi = ht (xi )}. Take the derivative w.r.t. αt and set it to zero: X X dZt (αt , ht ) = −Dt (xi ) exp [−αt ] + Dt (xi ) exp [αt ] = 0 dαt xi ∈A J. Corso (SUNY at Buffalo) (37) xi ∈A AdaBoost Lecture 8 March 30 2010 28 / 62 AdaBoost Analysis AdaBoost Convergence X X dZt (αt , ht ) = Dt (xi ) exp [αt ] = 0 −Dt (xi ) exp [−αt ] + dαt xi ∈A X xi ∈A J. Corso (SUNY at Buffalo) (38) xi ∈A Dt (xi ) = X Dt (xi ) exp [2αt ] (39) xi ∈A AdaBoost Lecture 8 March 30 2010 29 / 62 AdaBoost Analysis AdaBoost Convergence X X dZt (αt , ht ) = Dt (xi ) exp [αt ] = 0 −Dt (xi ) exp [−αt ] + dαt xi ∈A X xi ∈A (38) xi ∈A Dt (xi ) = X Dt (xi ) exp [2αt ] (39) xi ∈A And, by definition, we can write the error as t (h) = m X Dt (xi )δ(h(xi ) 6= yi ) = i=1 J. Corso (SUNY at Buffalo) X Dt (xi ), ∀h (40) xi ∈A AdaBoost Lecture 8 March 30 2010 29 / 62 AdaBoost Analysis AdaBoost Convergence X X dZt (αt , ht ) = Dt (xi ) exp [αt ] = 0 −Dt (xi ) exp [−αt ] + dαt xi ∈A X (38) xi ∈A Dt (xi ) = xi ∈A X Dt (xi ) exp [2αt ] (39) xi ∈A And, by definition, we can write the error as t (h) = m X Dt (xi )δ(h(xi ) 6= yi ) = i=1 X Dt (xi ), ∀h (40) xi ∈A Rewriting (39) and solving for αt yields αt = J. Corso (SUNY at Buffalo) 1 1 − t (ht ) ln 2 t (ht ) AdaBoost Lecture 8 (41) March 30 2010 29 / 62 AdaBoost Analysis AdaBoost Convergence We can plug it back into the normalization term to get the minimum: Zt (αt , ht ) = X Dt (xi ) exp [−αt ] + xi ∈A X Dt (xi ) exp [αt ] s = (1 − t (ht )) s t (ht ) 1 − t (ht ) + t (ht ) 1 − t (ht ) t (ht ) p = 2 t (ht )(1 − t (ht )) J. Corso (SUNY at Buffalo) (42) xi ∈A AdaBoost Lecture 8 (43) (44) March 30 2010 30 / 62 AdaBoost Analysis AdaBoost Convergence We can plug it back into the normalization term to get the minimum: Zt (αt , ht ) = X Dt (xi ) exp [−αt ] + xi ∈A X Dt (xi ) exp [αt ] s = (1 − t (ht )) s t (ht ) 1 − t (ht ) + t (ht ) 1 − t (ht ) t (ht ) p = 2 t (ht )(1 − t (ht )) Change a variable, γt = J. Corso (SUNY at Buffalo) (42) xi ∈A 1 2 (43) (44) − t (ht ), γt ∈ (0, 21 ]. AdaBoost Lecture 8 March 30 2010 30 / 62 AdaBoost Analysis AdaBoost Convergence We can plug it back into the normalization term to get the minimum: Zt (αt , ht ) = X Dt (xi ) exp [−αt ] + xi ∈A X Dt (xi ) exp [αt ] s = (1 − t (ht )) s t (ht ) 1 − t (ht ) + t (ht ) 1 − t (ht ) t (ht ) p = 2 t (ht )(1 − t (ht )) Change a variable, γt = 1 2 (43) (44) − t (ht ), γt ∈ (0, 21 ]. Then, we have the minimum to be p Zt (αt , ht ) = 2 t (ht )(1 − t (ht )) q = 1 − 4γt2 ≤ exp −2γt2 J. Corso (SUNY at Buffalo) (42) xi ∈A AdaBoost Lecture 8 (45) (46) (47) March 30 2010 30 / 62 AdaBoost Analysis AdaBoost Convergence Therefore, after t steps, the error rate of the strong classifier is bounded on top by # " T X 2 γt (48) Err(H) ≤ Z ≤ exp −2 t=1 J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 31 / 62 AdaBoost Analysis AdaBoost Convergence Therefore, after t steps, the error rate of the strong classifier is bounded on top by # " T X 2 γt (48) Err(H) ≤ Z ≤ exp −2 t=1 Hence, each step decreases the upper bound exponentially. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 31 / 62 AdaBoost Analysis AdaBoost Convergence Therefore, after t steps, the error rate of the strong classifier is bounded on top by # " T X 2 γt (48) Err(H) ≤ Z ≤ exp −2 t=1 Hence, each step decreases the upper bound exponentially. And, a weak classifier with small error rate will lead to faster descent. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 31 / 62 AdaBoost Analysis AdaBoost Convergence Summary of AdaBoost Convergence The objective of AdaBoost is to minimize an upper bound on the classification error: (α, h)∗ = argmin Z(α, h) (49) = argmin Zt (αt , ht ) . . . Z1 (α1 , h1 ) m X exp [−yi hα, h(xi )i] = argmin (50) (51) i=1 AdaBoost takes a stepwise minimization scheme, which may not be optimal (it is greedy). When we calculate the parameter for the tth weak classifier, the others remain set. We should stop AdaBoost if all of the weak classifiers have an error rate of 12 . J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 32 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) How Will Test Error Behave? (A First Guess) 1 error 0.8 0.6 0.4 test 0.2 train 20 40 60 80 100 # of rounds (T) expect: • training error to continue to drop (or reach zero) • test error to increase when Hfinal becomes “too complex” • • “Occam’s razor” overfitting • hard to know when to stop training J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 33 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) Actual Typical Run 20 C4.5 test error error 15 (boosting C4.5 on “letter” dataset) 10 5 0 test train 10 100 1000 # of rounds (T) • test error does not increase, even after 1000 rounds • (total size > 2,000,000 nodes) • test error continues to drop even after training error is zero! train error test error # rounds 5 100 1000 0.0 0.0 0.0 8.4 3.3 3.1 • Occam’s razor wrongly predicts “simpler” rule is better J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 34 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) A Better Story: The Margins Explanation [with Freund, Bartlett & Lee] • key idea: training error only measures whether classifications are right or wrong • should also consider confidence of classifications • J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 35 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) A Better Story: The Margins Explanation [with Freund, Bartlett & Lee] • key idea: training error only measures whether classifications are right or wrong • should also consider confidence of classifications • • recall: Hfinal is weighted majority vote of weak classifiers J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 36 / 62 Test Error Analysis (From Schapire’s Slides) AdaBoost Analysis A Better Story: The Margins Explanation [with Freund, Bartlett & Lee] • key idea: training error only measures whether classifications are right or wrong • should also consider confidence of classifications • • recall: Hfinal is weighted majority vote of weak classifiers • measure confidence by margin = strength of the vote = (fraction voting correctly) − (fraction voting incorrectly) high conf. incorrect −1 J. Corso (SUNY at Buffalo) high conf. correct low conf. Hfinal incorrect 0 Hfinal correct AdaBoost Lecture 8 +1 March 30 2010 37 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) Empirical Evidence: The Margin Distribution • margin distribution 20 error 15 10 test 5 0 train 10 100 1000 cumulative distribution = cumulative distribution of margins of training examples 1.0 1000 100 0.5 5 -1 # of rounds (T) train error test error % margins ≤ 0.5 minimum margin J. Corso (SUNY at Buffalo) 5 0.0 8.4 7.7 0.14 -0.5 margin 0.5 1 # rounds 100 1000 0.0 0.0 3.3 3.1 0.0 0.0 0.52 0.55 AdaBoost Lecture 8 March 30 2010 38 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) Theoretical Evidence: Analyzing Boosting Using Margins • Theorem: large margins ⇒ better bound on generalization error (independent of number of rounds) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 39 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) Theoretical Evidence: Analyzing Boosting Using Margins • Theorem: large margins ⇒ better bound on generalization error (independent of number of rounds) • proof idea: if all margins are large, then can approximate final classifier by a much smaller classifier (just as polls can predict not-too-close election) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 40 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) Theoretical Evidence: Analyzing Boosting Using Margins • Theorem: large margins ⇒ better bound on generalization error (independent of number of rounds) • proof idea: if all margins are large, then can approximate final classifier by a much smaller classifier (just as polls can predict not-too-close election) • Theorem: boosting tends to increase margins of training examples (given weak learning assumption) J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 41 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) Theoretical Evidence: Analyzing Boosting Using Margins • Theorem: large margins ⇒ better bound on generalization error (independent of number of rounds) • proof idea: if all margins are large, then can approximate final classifier by a much smaller classifier (just as polls can predict not-too-close election) • Theorem: boosting tends to increase margins of training examples (given weak learning assumption) • proof idea: similar to training error proof J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 42 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) Theoretical Evidence: Analyzing Boosting Using Margins • Theorem: large margins ⇒ better bound on generalization error (independent of number of rounds) • proof idea: if all margins are large, then can approximate final classifier by a much smaller classifier (just as polls can predict not-too-close election) • Theorem: boosting tends to increase margins of training examples (given weak learning assumption) • proof idea: similar to training error proof • so: although final classifier is getting larger, margins are likely to be increasing, so final classifier actually getting close to a simpler classifier, driving down the test error J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 43 / 62 AdaBoost Analysis Test Error Analysis (From Schapire’s Slides) More Technically... • with high probability, ∀θ > 0 : generalization error ≤ P̂r[margin ≤ θ] + Õ p d/m θ ! (P̂r[ ] = empirical probability) • bound depends on • m = # training examples • d = “complexity” of weak classifiers • entire distribution of margins of training examples • P̂r[margin ≤ θ] → 0 exponentially fast (in T ) if (error of ht on Dt ) < 1/2 − θ (∀t) • so: if weak learning assumption holds, then all examples will quickly have “large” margins J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 44 / 62 AdaBoost Recap Summary of Basic AdaBoost AdaBoost is a sequential algorithm that minimizes an upper bound of the empirical classification error by selecting the weak classifiers and their weights. These are “pursued” one-by-one with each one being selected to maximally reduce the upper bound of error. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 45 / 62 AdaBoost Recap Summary of Basic AdaBoost AdaBoost is a sequential algorithm that minimizes an upper bound of the empirical classification error by selecting the weak classifiers and their weights. These are “pursued” one-by-one with each one being selected to maximally reduce the upper bound of error. AdaBoost defines a distribution of weights over the data samples. These weights are updated each time a new weak classifier is added such that samples misclassified by this new weak classifiers are given more weight. In this manner, currently misclassified samples are emphasized more during the selection of the subsequent weak classifier. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 45 / 62 AdaBoost Recap Summary of Basic AdaBoost AdaBoost is a sequential algorithm that minimizes an upper bound of the empirical classification error by selecting the weak classifiers and their weights. These are “pursued” one-by-one with each one being selected to maximally reduce the upper bound of error. AdaBoost defines a distribution of weights over the data samples. These weights are updated each time a new weak classifier is added such that samples misclassified by this new weak classifiers are given more weight. In this manner, currently misclassified samples are emphasized more during the selection of the subsequent weak classifier. The empirical error will converge to zero at an exponential rate. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 45 / 62 AdaBoost Recap Practical AdaBoost Advantages It is fast to evaluate (linear-additive) and can be fast to train (depending on weak learner). T is the only parameter to tune. It is flexible and can be combined with any weak learner. It is provably effective if it can consistently find the weak classifiers (that do better than random). Since it can work with any weak learner, it can handle the gamut of data. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 46 / 62 AdaBoost Recap AdaBoost Caveats Performance depends on the data and the weak learner. It can fail if The weak classifiers are too complex and overfit. The weak classifiers are too weak, essentially underfitting. AdaBoost seems, empirically, to be especially susceptible to uniform noise. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 47 / 62 AdaBoost Recap The Coordinate Descent View of AdaBoost (from Schapire) Coordinate Descent [Breiman] • {g1 , . . . , gN } = space of all weak classifiers • want to find λ1 , . . . , λN to minimize L(λ1 , . . . , λN ) = X i J. Corso (SUNY at Buffalo) exp −yi AdaBoost Lecture 8 X j λj gj (xi ) March 30 2010 48 / 62 AdaBoost Recap The Coordinate Descent View of AdaBoost (from Schapire) Coordinate Descent [Breiman] • {g1 , . . . , gN } = space of all weak classifiers • want to find λ1 , . . . , λN to minimize L(λ1 , . . . , λN ) = X i exp −yi X j λj gj (xi ) • AdaBoost is actually doing coordinate descent on this optimization problem: initially, all λj = 0 each round: choose one coordinate λj (corresponding to ht ) and update (increment by αt ) • choose update causing biggest decrease in loss • • • powerful technique for minimizing over huge space of functions J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 49 / 62 AdaBoost for Estimating Conditional Probabilities Estimating Conditional Probabilities [Friedman, Hastie & Tibshirani] • often want to estimate probability that y = +1 given x • AdaBoost minimizes (empirical version of): h i h i Ex,y e −yf (x) = Ex P [y = +1|x] e −f (x) + P [y = −1|x] e f (x) where x, y random from true distribution J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 50 / 62 AdaBoost for Estimating Conditional Probabilities Estimating Conditional Probabilities [Friedman, Hastie & Tibshirani] • often want to estimate probability that y = +1 given x • AdaBoost minimizes (empirical version of): h i h i Ex,y e −yf (x) = Ex P [y = +1|x] e −f (x) + P [y = −1|x] e f (x) where x, y random from true distribution • over all f , minimized when 1 f (x) = · ln 2 P [y = +1|x] P [y = −1|x] or P [y = +1|x] = 1 1 + e −2f (x) • so, to convert f output by AdaBoost to probability estimate, use same formula J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 51 / 62 Multiclass AdaBoost From Schapire’s Slides Multiclass Problems [with Freund] • say y ∈ Y = {1, . . . , k} • direct approach (AdaBoost.M1): ht : X → Y Dt+1 (i ) = Dt (i ) · Zt e −αt e αt Hfinal (x) = arg max y ∈Y J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 if yi = ht (xi ) if yi 6= ht (xi ) X αt t:ht (x)=y March 30 2010 52 / 62 Multiclass AdaBoost From Schapire’s Slides Multiclass Problems [with Freund] • say y ∈ Y = {1, . . . , k} • direct approach (AdaBoost.M1): ht : X → Y Dt+1 (i ) = Dt (i ) · Zt e −αt e αt Hfinal (x) = arg max y ∈Y if yi = ht (xi ) if yi 6= ht (xi ) X αt t:ht (x)=y • can prove same bound on error if ∀t : t ≤ 1/2 in practice, not usually a problem for “strong” weak learners (e.g., C4.5) • significant problem for “weak” weak learners (e.g., decision stumps) • instead, reduce to binary • J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 53 / 62 Multiclass AdaBoost From Schapire’s Slides Reducing Multiclass to Binary [with Singer] • say possible labels are {a, b, c, d, e} • each training example replaced by five {−1, +1}-labeled examples: x (x, a) (x, b) , c → (x, c) (x, d) (x, e) , , , , , −1 −1 +1 −1 −1 • predict with label receiving most (weighted) votes J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 54 / 62 Applications AdaBoost for Face Detection Viola and Jones 2000-2002. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 55 / 62 Applications J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 56 / 62 Applications Figure 7: Output of our face detector on a number of test images from the MIT+CMU test set. [3] F. Crow. Summed-area tables for texture map Proceedings of SIGGRAPH, volume 18(3), pages 1984. [4] F. Fleuret and D. Geman. Coarse-to-fi ne face dete J. Computer Vision, 2001. J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 57 / 62 Applications ons such as advanced driving visual features as adaBoost Fig.1: Viola &Jones Haar-like features res, the “connected controlto give very good results on These weak classifiers compute the absolute difference n. We here report on results between the sum of pixel values in red and blue areas (see atures to a public lateral car F. database. Moutarde, Stanciulescu, and A.following Breheret. figure 1), with the respect of the rule: Real-time visual estrian images We B. tently outperform previously detection of vehicles and pedestrians with new efficient AdaBoost if Area ( A) ! Area ( B ) > Threshold then True ses, while still operating fast features. 2008.else False nd vehicles detection. AdaBoost for Car and Pedestrian Detection They define a different pixel level “connected control point” feature. D RELATED WORK well as most Advanced (ADAS) functions, require his environment perception ors such as lidars, radars, ever, compared to other ovide very rich information f an abstract enough scene time. red for such an automated detection of most common nt: vehicles and pedestrians. roposed for visual object g [10] for a review of some for pedestrian detection, . Of the various machinethis problem, only few are J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 58 / 62 Applications with respect ample. l values, an example groups are separated figure 3a). Negative ct this characteristic: roups are interleaved examples of controlpedestrian detection. -, half- or quarterdow size (80x32 for pedestrian case). An s resized to those 3 d. e 4, the feature will es (on the correctly white squares all have Fig. 4: Some examples of adaBoost-selected Control-Points features for car detection (top) and pedestrian detection (bottom line). Some features operate at full resolution of detection window (eg rightmost bottom), while others work on half-resolution (eg leftmost bottom), or even at quarterresolution (third on bottom line). J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 59 / 62 Applications B. Pedestr The pede test sets (eac and 5000 independent training sets, producing a feature type allowed, ther 2000 weak-c J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 60 / 62 2000 weak-classifiers.Applications t ds 8 Fig. 9: Averaged ROC curves for adaBoost pedestrian classifiers obtained with various feature families J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 61 / 62 References Sources These slides have made extensive use of the following sources. Y.Freund and R.E. Schapire. A Decision-Theoretic Generalization of On-line Learning and an Application to Boosting. Journal of Computer and System Science, 55(1):119139, 1997. R.E. Schapire. The boosting approach to machine learning: an overview. In MSRI Workshop on Nonlinear Estimation and Classification, 2002. Schapire’s NIPS Tutorial http://nips.cc/Conferences/2007/Program/ schedule.php?Session=Tutorials P.Viola and M.Jones. Rapid object detection using a boosted cascade of simple features. In Proceedings of IEEE Conference on Computer Vision and Pattern Recognition, 2001. P.Viola and M.Jones. Fast and Robust Classification Using Asymmetric AdaBoost and a Detector Cascade. In Proceedings of Neural Information Processing Systems (NIPS), 2002. SC Zhu’s slides for AdaBoost (UCLA). J. Corso (SUNY at Buffalo) AdaBoost Lecture 8 March 30 2010 62 / 62