SlideShare a Scribd company logo
1 of 41
Download to read offline
Introduction to Boosted Trees
Tianqi Chen
Oct. 22 2014
Outline
• Review of key concepts of supervised learning
• Regression Tree and Ensemble (What are we Learning)
• Gradient Boosting (How do we Learn)
• Summary
Elements in Supervised Learning
• Notations: i-th training example
• Model: how to make prediction given
 Linear model: (include linear/logistic regression)
 The prediction score can have different interpretations
depending on the task
 Linear regression: is the predicted score
 Logistic regression: is predicted the probability
of the instance being positive
 Others… for example in ranking can be the rank score
• Parameters: the things we need to learn from data
 Linear model:
Elements continued: Objective Function
• Objective function that is everywhere
• Loss on training data:
 Square loss:
 Logistic loss:
• Regularization: how complicated the model is?
 L2 norm:
 L1 norm (lasso):
Training Loss measures how
well model fit on training data
Regularization, measures
complexity of model
Putting known knowledge into context
• Ridge regression:
 Linear model, square loss, L2 regularization
• Lasso:
 Linear model, square loss, L1 regularization
• Logistic regression:
 Linear model, logistic loss, L2 regularization
• The conceptual separation between model, parameter,
objective also gives you engineering benefits.
 Think of how you can implement SGD for both ridge regression
and logistic regression
Objective and Bias Variance Trade-off
• Why do we want to contain two component in the objective?
• Optimizing training loss encourages predictive models
 Fitting well in training data at least get you close to training data
which is hopefully close to the underlying distribution
• Optimizing regularization encourages simple models
 Simpler models tends to have smaller variance in future
predictions, making prediction stable
Training Loss measures how
well model fit on training data
Regularization, measures
complexity of model
Outline
• Review of key concepts of supervised learning
• Regression Tree and Ensemble (What are we Learning)
• Gradient Boosting (How do we Learn)
• Summary
Regression Tree (CART)
• regression tree (also known as classification and regression
tree):
 Decision rules same as in decision tree
 Contains one score in each leaf value
Input: age, gender, occupation, …
age < 15
is male?
+2 -1+0.1
Y N
Y N
Does the person like computer games
prediction score in each leaf
Regression Tree Ensemble
age < 15
is male?
+2 -1+0.1
Y N
Y N
Use Computer
Daily
Y N
+0.9
-0.9
tree1 tree2
f( ) = 2 + 0.9= 2.9 f( )= -1 + 0.9= -0.1
Prediction of is sum of scores predicted by each of the tree
Tree Ensemble methods
• Very widely used, look for GBM, random forest…
 Almost half of data mining competition are won by using some
variants of tree ensemble methods
• Invariant to scaling of inputs, so you do not need to do careful
features normalization.
• Learn higher order interaction between features.
• Can be scalable, and are used in Industry
Put into context: Model and Parameters
• Model: assuming we have K trees
Think: regression tree is a function that maps the attributes to the score
• Parameters
 Including structure of each tree, and the score in the leaf
 Or simply use function as parameters
 Instead learning weights in , we are learning functions(trees)
Space of functions containing all Regression trees
Learning a tree on single variable
• How can we learn functions?
• Define objective (loss, regularization), and optimize it!!
• Example:
 Consider regression tree on single input t (time)
 I want to predict whether I like romantic music at time t
t < 2011/03/01
t < 2010/03/20
Y N
Y N
0.2
Equivalently
The model is regression tree that splits on time
1.2
1.0
Piecewise step function over time
Learning a step function
• Things we need to learn
• Objective for single variable regression tree(step functions)
 Training Loss: How will the function fit on the points?
 Regularization: How do we define complexity of the function?
 Number of splitting points, l2 norm of the height in each segment?
Splitting Positions
The Height in each segment
Learning step function (visually)
Coming back: Objective for Tree Ensemble
• Model: assuming we have K trees
• Objective
• Possible ways to define ?
 Number of nodes in the tree, depth
 L2 norm of the leaf weights
 … detailed later
Training loss Complexity of the Trees
Objective vs Heuristic
• When you talk about (decision) trees, it is usually heuristics
 Split by information gain
 Prune the tree
 Maximum depth
 Smooth the leaf values
• Most heuristics maps well to objectives, taking the formal
(objective) view let us know what we are learning
 Information gain -> training loss
 Pruning -> regularization defined by #nodes
 Max depth -> constraint on the function space
 Smoothing leaf values -> L2 regularization on leaf weights
Regression Tree is not just for regression!
• Regression tree ensemble defines how you make the
prediction score, it can be used for
 Classification, Regression, Ranking….
 ….
• It all depends on how you define the objective function!
• So far we have learned:
 Using Square loss
 Will results in common gradient boosted machine
 Using Logistic loss
 Will results in LogitBoost
Take Home Message for this section
• Bias-variance tradeoff is everywhere
• The loss + regularization objective pattern applies for
regression tree learning (function learning)
• We want predictive and simple functions
• This defines what we want to learn (objective, model).
• But how do we learn it?
 Next section
Outline
• Review of key concepts of supervised learning
• Regression Tree and Ensemble (What are we Learning)
• Gradient Boosting (How do we Learn)
• Summary
So How do we Learn?
• Objective:
• We can not use methods such as SGD, to find f (since they are
trees, instead of just numerical vectors)
• Solution: Additive Training (Boosting)
 Start from constant prediction, add a new function each time
Model at training round t
New function
Keep functions added in previous round
Additive Training
• How do we decide which f to add?
 Optimize the objective!!
• The prediction at round t is
• Consider square loss
This is what we need to decide in round t
Goal: find to minimize this
This is usually called residual from previous round
Taylor Expansion Approximation of Loss
• Goal
 Seems still complicated except for the case of square loss
• Take Taylor expansion of the objective
 Recall
 Define
• If you are not comfortable with this, think of square loss
• Compare what we get to previous slide
Our New Goal
• Objective, with constants removed
 where
• Why spending s much efforts to derive the objective, why not
just grow trees …
 Theoretical benefit: know what we are learning, convergence
 Engineering benefit, recall the elements of supervised learning
 and comes from definition of loss function
 The learning of function only depend on the objective via and
 Think of how you can separate modules of your code when you
are asked to implement boosted tree for both square loss and
logistic loss
Refine the definition of tree
• We define tree by a vector of scores in leafs, and a leaf index
mapping function that maps an instance to a leaf
age < 15
is male?
Y N
Y N
Leaf 1 Leaf 2 Leaf 3
q( ) = 1
q( ) = 3
w1=+2 w2=0.1 w3=-1
The structure of the tree
The leaf weight of the tree
Define the Complexity of Tree
• Define complexity as (this is not the only possible definition)
age < 15
is male?
Y N
Y N
Leaf 1 Leaf 2 Leaf 3
w1=+2 w2=0.1 w3=-1
Number of leaves L2 norm of leaf scores
Revisit the Objectives
• Define the instance set in leaf j as
• Regroup the objective by each leaf
• This is sum of T independent quadratic functions
The Structure Score
• Two facts about single variable quadratic function
• Let us define
• Assume the structure of tree ( q(x) ) is fixed, the optimal
weight in each leaf, and the resulting objective value are
This measures how good a tree structure is!
The Structure Score Calculation
age < 15
is male?
Y N
Y N
Instance index
1
2
3
4
5
g1, h1
g2, h2
g3, h3
g4, h4
g5, h5
gradient statistics
The smaller the score is, the better the structure is
Searching Algorithm for Single Tree
• Enumerate the possible tree structures q
• Calculate the structure score for the q, using the scoring eq.
• Find the best tree structure, and use the optimal leaf weight
• But… there can be infinite possible tree structures..
Greedy Learning of the Tree
• In practice, we grow the tree greedily
 Start from tree with depth 0
 For each leaf node of the tree, try to add a split. The change of
objective after adding the split is
 Remaining question: how do we find the best split?
the score of left child
the score of right child
the score of if we do not split
The complexity cost by
introducing additional leaf
Efficient Finding of the Best Split
• What is the gain of a split rule ? Say is age
• All we need is sum of g and h in each side, and calculate
• Left to right linear scan over sorted instance is enough to
decide the best split along the feature
g1, h1 g4, h4 g2, h2 g5, h5 g3, h3
a
An Algorithm for Split Finding
• For each node, enumerate over all features
 For each feature, sorted the instances by feature value
 Use a linear scan to decide the best split along that feature
 Take the best split solution along all the features
• Time Complexity growing a tree of depth K
 It is O(n d K log n): or each level, need O(n log n) time to sort
There are d features, and we need to do it for K level
 This can be further optimized (e.g. use approximation or caching
the sorted features)
 Can scale to very large dataset
What about Categorical Variables?
• Some tree learning algorithm handles categorical variable and
continuous variable separately
 We can easily use the scoring formula we derived to score split
based on categorical variables.
• Actually it is not necessary to handle categorical separately.
 We can encode the categorical variables into numerical vector
using one-hot encoding. Allocate a #categorical length vector
 The vector will be sparse if there are lots of categories, the
learning algorithm is preferred to handle sparse data
Pruning and Regularization
• Recall the gain of split, it can be negative!
 When the training loss reduction is smaller than regularization
 Trade-off between simplicity and predictivness
• Pre-stopping
 Stop split if the best split have negative gain
 But maybe a split can benefit future splits..
• Post-Prunning
 Grow a tree to maximum depth, recursively prune all the leaf
splits with negative gain
Recap: Boosted Tree Algorithm
• Add a new tree in each iteration
• Beginning of each iteration, calculate
• Use the statistics to greedily grow a tree
• Add to the model
 Usually, instead we do
 is called step-size or shrinkage, usually set around 0.1
 This means we do not do full optimization in each step and
reserve chance for future rounds, it helps prevent overfitting
Outline
• Review of key concepts of supervised learning
• Regression Tree and Ensemble (What are we Learning)
• Gradient Boosting (How do we Learn)
• Summary
Questions to check if you really get it
• How can we build a boosted tree classifier to do weighted
regression problem, such that each instance have a
importance weight?
• Back to the time series problem, if I want to learn step
functions over time. Is there other ways to learn the time
splits, other than the top down split approach?
Questions to check if you really get it
• How can we build a boosted tree classifier to do weighted
regression problem, such that each instance have a
importance weight?
 Define objective, calculate , feed it to the old tree learning
algorithm we have for un-weighted version
 Again think of separation of model and objective, how does the
theory can help better organizing the machine learning toolkit
Questions to check if you really get it
• Time series problem
• All that is important is the structure score of the splits
 Top-down greedy, same as trees
 Bottom-up greedy, start from individual points as each group,
greedily merge neighbors
 Dynamic programming, can find optimal solution for this case
Summary
• The separation between model, objective, parameters can be
helpful for us to understand and customize learning models
• The bias-variance trade-off applies everywhere, including
learning in functional space
• We can be formal about what we learn and how we learn.
Clear understanding of theory can be used to guide cleaner
implementation.
Reference
• Greedy function approximation a gradient boosting machine. J.H. Friedman
 First paper about gradient boosting
• Stochastic Gradient Boosting. J.H. Friedman
 Introducing bagging trick to gradient boosting
• Elements of Statistical Learning. T. Hastie, R. Tibshirani and J.H. Friedman
 Contains a chapter about gradient boosted boosting
• Additive logistic regression a statistical view of boosting. J.H. Friedman T. Hastie R. Tibshirani
 Uses second-order statistics for tree splitting, which is closer to the view presented in this slide
• Learning Nonlinear Functions Using Regularized Greedy Forest. R. Johnson and T. Zhang
 Proposes to do fully corrective step, as well as regularizing the tree complexity. The regularizing trick
is closed related to the view present in this slide
• Software implementing the model described in this slide: https://github.com/tqchen/xgboost

More Related Content

What's hot

はじめてのパターン認識4章後編
はじめてのパターン認識4章後編はじめてのパターン認識4章後編
はじめてのパターン認識4章後編
Tanaka Hidenori
 
Feature pyramid networks for object detection
Feature pyramid networks for object detection Feature pyramid networks for object detection
Feature pyramid networks for object detection
heedaeKwon
 

What's hot (20)

Gradient Boosted trees
Gradient Boosted treesGradient Boosted trees
Gradient Boosted trees
 
DQN Variants: A quick glance
DQN Variants: A quick glanceDQN Variants: A quick glance
DQN Variants: A quick glance
 
Cluster Analysis for Dummies
Cluster Analysis for DummiesCluster Analysis for Dummies
Cluster Analysis for Dummies
 
Introduction to XGboost
Introduction to XGboostIntroduction to XGboost
Introduction to XGboost
 
はじめてのパターン認識4章後編
はじめてのパターン認識4章後編はじめてのパターン認識4章後編
はじめてのパターン認識4章後編
 
Gradient Boosted Regression Trees in scikit-learn
Gradient Boosted Regression Trees in scikit-learnGradient Boosted Regression Trees in scikit-learn
Gradient Boosted Regression Trees in scikit-learn
 
#10 pydata warsaw object detection with dn ns
#10   pydata warsaw object detection with dn ns#10   pydata warsaw object detection with dn ns
#10 pydata warsaw object detection with dn ns
 
1. Introduction to deep learning.pptx
1. Introduction to deep learning.pptx1. Introduction to deep learning.pptx
1. Introduction to deep learning.pptx
 
Demystifying Xgboost
Demystifying XgboostDemystifying Xgboost
Demystifying Xgboost
 
Feature pyramid networks for object detection
Feature pyramid networks for object detection Feature pyramid networks for object detection
Feature pyramid networks for object detection
 
K means
K meansK means
K means
 
Support Vector Machine ppt presentation
Support Vector Machine ppt presentationSupport Vector Machine ppt presentation
Support Vector Machine ppt presentation
 
Matrix Factorization In Recommender Systems
Matrix Factorization In Recommender SystemsMatrix Factorization In Recommender Systems
Matrix Factorization In Recommender Systems
 
K means clustering
K means clusteringK means clustering
K means clustering
 
Gradient descent optimizer
Gradient descent optimizerGradient descent optimizer
Gradient descent optimizer
 
はじぱた7章F5up
はじぱた7章F5upはじぱた7章F5up
はじぱた7章F5up
 
Decision Tree Learning
Decision Tree LearningDecision Tree Learning
Decision Tree Learning
 
Feature selection
Feature selectionFeature selection
Feature selection
 
Decision trees in Machine Learning
Decision trees in Machine Learning Decision trees in Machine Learning
Decision trees in Machine Learning
 
Unsupervised learning: Clustering
Unsupervised learning: ClusteringUnsupervised learning: Clustering
Unsupervised learning: Clustering
 

Viewers also liked

Transportation supplymentary
Transportation supplymentaryTransportation supplymentary
Transportation supplymentary
sindy322
 
Chinse made easy for kids
Chinse made easy for kidsChinse made easy for kids
Chinse made easy for kids
nicolezhang
 
Chinese Wedding
Chinese WeddingChinese Wedding
Chinese Wedding
stkach
 
Printable quiz hsk 3 vocabulary noun (part 2)
Printable quiz  hsk 3 vocabulary   noun (part 2)Printable quiz  hsk 3 vocabulary   noun (part 2)
Printable quiz hsk 3 vocabulary noun (part 2)
LEGOO MANDARIN
 
Culture study unit 15 Chinese art worksheet
Culture study unit 15 Chinese art worksheetCulture study unit 15 Chinese art worksheet
Culture study unit 15 Chinese art worksheet
Joanne Chen
 

Viewers also liked (20)

Basic Chinese Lesson 06 what are you doing
Basic Chinese Lesson 06 what are you doingBasic Chinese Lesson 06 what are you doing
Basic Chinese Lesson 06 what are you doing
 
Survival chinese 1
Survival chinese 1 Survival chinese 1
Survival chinese 1
 
Chinese characters numbers
Chinese characters numbersChinese characters numbers
Chinese characters numbers
 
學好中文的十個理由以及好用的學習工具
學好中文的十個理由以及好用的學習工具學好中文的十個理由以及好用的學習工具
學好中文的十個理由以及好用的學習工具
 
365 mandarin video chinese hcv 001 01 l01 - how do you do !
365 mandarin video chinese hcv 001 01 l01 - how do you do !365 mandarin video chinese hcv 001 01 l01 - how do you do !
365 mandarin video chinese hcv 001 01 l01 - how do you do !
 
Transportation supplymentary
Transportation supplymentaryTransportation supplymentary
Transportation supplymentary
 
The HSK Exam
The HSK ExamThe HSK Exam
The HSK Exam
 
HSK Standard Course Textbook1 Lesson 1 slides | HSK标准教程第一册第一课课件
HSK Standard Course Textbook1 Lesson 1 slides | HSK标准教程第一册第一课课件HSK Standard Course Textbook1 Lesson 1 slides | HSK标准教程第一册第一课课件
HSK Standard Course Textbook1 Lesson 1 slides | HSK标准教程第一册第一课课件
 
Traditional Marriage in China
Traditional Marriage  in ChinaTraditional Marriage  in China
Traditional Marriage in China
 
Chinse made easy for kids
Chinse made easy for kidsChinse made easy for kids
Chinse made easy for kids
 
An introduction to hsk with yct
An introduction to hsk with yctAn introduction to hsk with yct
An introduction to hsk with yct
 
Chinese Wedding
Chinese WeddingChinese Wedding
Chinese Wedding
 
Contents and Sample Lesson of HSK Standard Course 《Hsk标准教程》教材介绍及样课 preview
Contents and Sample Lesson of HSK Standard Course 《Hsk标准教程》教材介绍及样课 previewContents and Sample Lesson of HSK Standard Course 《Hsk标准教程》教材介绍及样课 preview
Contents and Sample Lesson of HSK Standard Course 《Hsk标准教程》教材介绍及样课 preview
 
Stories with chinese characters
Stories with chinese charactersStories with chinese characters
Stories with chinese characters
 
Printable quiz hsk 3 vocabulary noun (part 2)
Printable quiz  hsk 3 vocabulary   noun (part 2)Printable quiz  hsk 3 vocabulary   noun (part 2)
Printable quiz hsk 3 vocabulary noun (part 2)
 
Printable quiz hsk 2 vocabulary noun (part 2)
Printable quiz  hsk 2 vocabulary   noun (part 2)Printable quiz  hsk 2 vocabulary   noun (part 2)
Printable quiz hsk 2 vocabulary noun (part 2)
 
新 年 發 福 - A Chinese New Year Story
新 年 發 福 - A Chinese New Year Story新 年 發 福 - A Chinese New Year Story
新 年 發 福 - A Chinese New Year Story
 
Workbook
WorkbookWorkbook
Workbook
 
Printable quiz intermediate ch reading 1
Printable quiz  intermediate ch reading 1Printable quiz  intermediate ch reading 1
Printable quiz intermediate ch reading 1
 
Culture study unit 15 Chinese art worksheet
Culture study unit 15 Chinese art worksheetCulture study unit 15 Chinese art worksheet
Culture study unit 15 Chinese art worksheet
 

Similar to Introduction to Boosted Trees by Tianqi Chen

CSA 3702 machine learning module 2
CSA 3702 machine learning module 2CSA 3702 machine learning module 2
CSA 3702 machine learning module 2
Nandhini S
 
Predict oscars (4:17)
Predict oscars (4:17)Predict oscars (4:17)
Predict oscars (4:17)
Thinkful
 
Week_1 Machine Learning introduction.pptx
Week_1 Machine Learning introduction.pptxWeek_1 Machine Learning introduction.pptx
Week_1 Machine Learning introduction.pptx
muhammadsamroz
 

Similar to Introduction to Boosted Trees by Tianqi Chen (20)

Ppt shuai
Ppt shuaiPpt shuai
Ppt shuai
 
Machine Learning Lecture 3 Decision Trees
Machine Learning Lecture 3 Decision TreesMachine Learning Lecture 3 Decision Trees
Machine Learning Lecture 3 Decision Trees
 
Analytics Boot Camp - Slides
Analytics Boot Camp - SlidesAnalytics Boot Camp - Slides
Analytics Boot Camp - Slides
 
DeepLearningLecture.pptx
DeepLearningLecture.pptxDeepLearningLecture.pptx
DeepLearningLecture.pptx
 
Deep Learning Introduction - WeCloudData
Deep Learning Introduction - WeCloudDataDeep Learning Introduction - WeCloudData
Deep Learning Introduction - WeCloudData
 
ML_basics_lecture1_linear_regression.pdf
ML_basics_lecture1_linear_regression.pdfML_basics_lecture1_linear_regression.pdf
ML_basics_lecture1_linear_regression.pdf
 
CSA 3702 machine learning module 2
CSA 3702 machine learning module 2CSA 3702 machine learning module 2
CSA 3702 machine learning module 2
 
Lecture4.pptx
Lecture4.pptxLecture4.pptx
Lecture4.pptx
 
MLEARN 210 B Autumn 2018: Lecture 1
MLEARN 210 B Autumn 2018: Lecture 1MLEARN 210 B Autumn 2018: Lecture 1
MLEARN 210 B Autumn 2018: Lecture 1
 
Predict oscars (4:17)
Predict oscars (4:17)Predict oscars (4:17)
Predict oscars (4:17)
 
machine_learning.pptx
machine_learning.pptxmachine_learning.pptx
machine_learning.pptx
 
ngboost.pptx
ngboost.pptxngboost.pptx
ngboost.pptx
 
Machine learning
Machine learningMachine learning
Machine learning
 
Lecture2-DT.pptx
Lecture2-DT.pptxLecture2-DT.pptx
Lecture2-DT.pptx
 
From decision trees to random forests
From decision trees to random forestsFrom decision trees to random forests
From decision trees to random forests
 
Week_1 Machine Learning introduction.pptx
Week_1 Machine Learning introduction.pptxWeek_1 Machine Learning introduction.pptx
Week_1 Machine Learning introduction.pptx
 
مدخل إلى تعلم الآلة
مدخل إلى تعلم الآلةمدخل إلى تعلم الآلة
مدخل إلى تعلم الآلة
 
Decision tree induction
Decision tree inductionDecision tree induction
Decision tree induction
 
Learning
LearningLearning
Learning
 
Building and deploying analytics
Building and deploying analyticsBuilding and deploying analytics
Building and deploying analytics
 

Recently uploaded

Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
ZurliaSoop
 
Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...
Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...
Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...
HyderabadDolls
 
Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...
nirzagarg
 
Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...
Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...
Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...
HyderabadDolls
 
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
gajnagarg
 
Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...
Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...
Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...
gajnagarg
 
Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...
gajnagarg
 
In Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi Arabia
In Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi ArabiaIn Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi Arabia
In Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi Arabia
ahmedjiabur940
 
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
nirzagarg
 
怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制
怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制
怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制
vexqp
 

Recently uploaded (20)

Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...
Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...
Gomti Nagar & best call girls in Lucknow | 9548273370 Independent Escorts & D...
 
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
Jual Obat Aborsi Surabaya ( Asli No.1 ) 085657271886 Obat Penggugur Kandungan...
 
Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...
Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...
Diamond Harbour \ Russian Call Girls Kolkata | Book 8005736733 Extreme Naught...
 
Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...
Top profile Call Girls In Rohtak [ 7014168258 ] Call Me For Genuine Models We...
 
Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...
Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...
Sealdah % High Class Call Girls Kolkata - 450+ Call Girl Cash Payment 8005736...
 
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In bhavnagar [ 7014168258 ] Call Me For Genuine Models...
 
Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...
Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...
Top profile Call Girls In Chandrapur [ 7014168258 ] Call Me For Genuine Model...
 
Introduction to Statistics Presentation.pptx
Introduction to Statistics Presentation.pptxIntroduction to Statistics Presentation.pptx
Introduction to Statistics Presentation.pptx
 
Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...
Top profile Call Girls In Nandurbar [ 7014168258 ] Call Me For Genuine Models...
 
Predicting HDB Resale Prices - Conducting Linear Regression Analysis With Orange
Predicting HDB Resale Prices - Conducting Linear Regression Analysis With OrangePredicting HDB Resale Prices - Conducting Linear Regression Analysis With Orange
Predicting HDB Resale Prices - Conducting Linear Regression Analysis With Orange
 
SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...
SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...
SAC 25 Final National, Regional & Local Angel Group Investing Insights 2024 0...
 
Digital Transformation Playbook by Graham Ware
Digital Transformation Playbook by Graham WareDigital Transformation Playbook by Graham Ware
Digital Transformation Playbook by Graham Ware
 
In Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi Arabia
In Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi ArabiaIn Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi Arabia
In Riyadh ((+919101817206)) Cytotec kit @ Abortion Pills Saudi Arabia
 
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
Top profile Call Girls In Bihar Sharif [ 7014168258 ] Call Me For Genuine Mod...
 
怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制
怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制
怎样办理圣地亚哥州立大学毕业证(SDSU毕业证书)成绩单学校原版复制
 
DATA SUMMIT 24 Building Real-Time Pipelines With FLaNK
DATA SUMMIT 24  Building Real-Time Pipelines With FLaNKDATA SUMMIT 24  Building Real-Time Pipelines With FLaNK
DATA SUMMIT 24 Building Real-Time Pipelines With FLaNK
 
Statistics notes ,it includes mean to index numbers
Statistics notes ,it includes mean to index numbersStatistics notes ,it includes mean to index numbers
Statistics notes ,it includes mean to index numbers
 
Charbagh + Female Escorts Service in Lucknow | Starting ₹,5K To @25k with A/C...
Charbagh + Female Escorts Service in Lucknow | Starting ₹,5K To @25k with A/C...Charbagh + Female Escorts Service in Lucknow | Starting ₹,5K To @25k with A/C...
Charbagh + Female Escorts Service in Lucknow | Starting ₹,5K To @25k with A/C...
 
💞 Safe And Secure Call Girls Agra Call Girls Service Just Call 🍑👄6378878445 🍑...
💞 Safe And Secure Call Girls Agra Call Girls Service Just Call 🍑👄6378878445 🍑...💞 Safe And Secure Call Girls Agra Call Girls Service Just Call 🍑👄6378878445 🍑...
💞 Safe And Secure Call Girls Agra Call Girls Service Just Call 🍑👄6378878445 🍑...
 
Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...
Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...
Nirala Nagar / Cheap Call Girls In Lucknow Phone No 9548273370 Elite Escort S...
 

Introduction to Boosted Trees by Tianqi Chen

  • 1. Introduction to Boosted Trees Tianqi Chen Oct. 22 2014
  • 2. Outline • Review of key concepts of supervised learning • Regression Tree and Ensemble (What are we Learning) • Gradient Boosting (How do we Learn) • Summary
  • 3. Elements in Supervised Learning • Notations: i-th training example • Model: how to make prediction given  Linear model: (include linear/logistic regression)  The prediction score can have different interpretations depending on the task  Linear regression: is the predicted score  Logistic regression: is predicted the probability of the instance being positive  Others… for example in ranking can be the rank score • Parameters: the things we need to learn from data  Linear model:
  • 4. Elements continued: Objective Function • Objective function that is everywhere • Loss on training data:  Square loss:  Logistic loss: • Regularization: how complicated the model is?  L2 norm:  L1 norm (lasso): Training Loss measures how well model fit on training data Regularization, measures complexity of model
  • 5. Putting known knowledge into context • Ridge regression:  Linear model, square loss, L2 regularization • Lasso:  Linear model, square loss, L1 regularization • Logistic regression:  Linear model, logistic loss, L2 regularization • The conceptual separation between model, parameter, objective also gives you engineering benefits.  Think of how you can implement SGD for both ridge regression and logistic regression
  • 6. Objective and Bias Variance Trade-off • Why do we want to contain two component in the objective? • Optimizing training loss encourages predictive models  Fitting well in training data at least get you close to training data which is hopefully close to the underlying distribution • Optimizing regularization encourages simple models  Simpler models tends to have smaller variance in future predictions, making prediction stable Training Loss measures how well model fit on training data Regularization, measures complexity of model
  • 7. Outline • Review of key concepts of supervised learning • Regression Tree and Ensemble (What are we Learning) • Gradient Boosting (How do we Learn) • Summary
  • 8. Regression Tree (CART) • regression tree (also known as classification and regression tree):  Decision rules same as in decision tree  Contains one score in each leaf value Input: age, gender, occupation, … age < 15 is male? +2 -1+0.1 Y N Y N Does the person like computer games prediction score in each leaf
  • 9. Regression Tree Ensemble age < 15 is male? +2 -1+0.1 Y N Y N Use Computer Daily Y N +0.9 -0.9 tree1 tree2 f( ) = 2 + 0.9= 2.9 f( )= -1 + 0.9= -0.1 Prediction of is sum of scores predicted by each of the tree
  • 10. Tree Ensemble methods • Very widely used, look for GBM, random forest…  Almost half of data mining competition are won by using some variants of tree ensemble methods • Invariant to scaling of inputs, so you do not need to do careful features normalization. • Learn higher order interaction between features. • Can be scalable, and are used in Industry
  • 11. Put into context: Model and Parameters • Model: assuming we have K trees Think: regression tree is a function that maps the attributes to the score • Parameters  Including structure of each tree, and the score in the leaf  Or simply use function as parameters  Instead learning weights in , we are learning functions(trees) Space of functions containing all Regression trees
  • 12. Learning a tree on single variable • How can we learn functions? • Define objective (loss, regularization), and optimize it!! • Example:  Consider regression tree on single input t (time)  I want to predict whether I like romantic music at time t t < 2011/03/01 t < 2010/03/20 Y N Y N 0.2 Equivalently The model is regression tree that splits on time 1.2 1.0 Piecewise step function over time
  • 13. Learning a step function • Things we need to learn • Objective for single variable regression tree(step functions)  Training Loss: How will the function fit on the points?  Regularization: How do we define complexity of the function?  Number of splitting points, l2 norm of the height in each segment? Splitting Positions The Height in each segment
  • 15. Coming back: Objective for Tree Ensemble • Model: assuming we have K trees • Objective • Possible ways to define ?  Number of nodes in the tree, depth  L2 norm of the leaf weights  … detailed later Training loss Complexity of the Trees
  • 16. Objective vs Heuristic • When you talk about (decision) trees, it is usually heuristics  Split by information gain  Prune the tree  Maximum depth  Smooth the leaf values • Most heuristics maps well to objectives, taking the formal (objective) view let us know what we are learning  Information gain -> training loss  Pruning -> regularization defined by #nodes  Max depth -> constraint on the function space  Smoothing leaf values -> L2 regularization on leaf weights
  • 17. Regression Tree is not just for regression! • Regression tree ensemble defines how you make the prediction score, it can be used for  Classification, Regression, Ranking….  …. • It all depends on how you define the objective function! • So far we have learned:  Using Square loss  Will results in common gradient boosted machine  Using Logistic loss  Will results in LogitBoost
  • 18. Take Home Message for this section • Bias-variance tradeoff is everywhere • The loss + regularization objective pattern applies for regression tree learning (function learning) • We want predictive and simple functions • This defines what we want to learn (objective, model). • But how do we learn it?  Next section
  • 19. Outline • Review of key concepts of supervised learning • Regression Tree and Ensemble (What are we Learning) • Gradient Boosting (How do we Learn) • Summary
  • 20. So How do we Learn? • Objective: • We can not use methods such as SGD, to find f (since they are trees, instead of just numerical vectors) • Solution: Additive Training (Boosting)  Start from constant prediction, add a new function each time Model at training round t New function Keep functions added in previous round
  • 21. Additive Training • How do we decide which f to add?  Optimize the objective!! • The prediction at round t is • Consider square loss This is what we need to decide in round t Goal: find to minimize this This is usually called residual from previous round
  • 22. Taylor Expansion Approximation of Loss • Goal  Seems still complicated except for the case of square loss • Take Taylor expansion of the objective  Recall  Define • If you are not comfortable with this, think of square loss • Compare what we get to previous slide
  • 23. Our New Goal • Objective, with constants removed  where • Why spending s much efforts to derive the objective, why not just grow trees …  Theoretical benefit: know what we are learning, convergence  Engineering benefit, recall the elements of supervised learning  and comes from definition of loss function  The learning of function only depend on the objective via and  Think of how you can separate modules of your code when you are asked to implement boosted tree for both square loss and logistic loss
  • 24. Refine the definition of tree • We define tree by a vector of scores in leafs, and a leaf index mapping function that maps an instance to a leaf age < 15 is male? Y N Y N Leaf 1 Leaf 2 Leaf 3 q( ) = 1 q( ) = 3 w1=+2 w2=0.1 w3=-1 The structure of the tree The leaf weight of the tree
  • 25. Define the Complexity of Tree • Define complexity as (this is not the only possible definition) age < 15 is male? Y N Y N Leaf 1 Leaf 2 Leaf 3 w1=+2 w2=0.1 w3=-1 Number of leaves L2 norm of leaf scores
  • 26. Revisit the Objectives • Define the instance set in leaf j as • Regroup the objective by each leaf • This is sum of T independent quadratic functions
  • 27. The Structure Score • Two facts about single variable quadratic function • Let us define • Assume the structure of tree ( q(x) ) is fixed, the optimal weight in each leaf, and the resulting objective value are This measures how good a tree structure is!
  • 28. The Structure Score Calculation age < 15 is male? Y N Y N Instance index 1 2 3 4 5 g1, h1 g2, h2 g3, h3 g4, h4 g5, h5 gradient statistics The smaller the score is, the better the structure is
  • 29. Searching Algorithm for Single Tree • Enumerate the possible tree structures q • Calculate the structure score for the q, using the scoring eq. • Find the best tree structure, and use the optimal leaf weight • But… there can be infinite possible tree structures..
  • 30. Greedy Learning of the Tree • In practice, we grow the tree greedily  Start from tree with depth 0  For each leaf node of the tree, try to add a split. The change of objective after adding the split is  Remaining question: how do we find the best split? the score of left child the score of right child the score of if we do not split The complexity cost by introducing additional leaf
  • 31. Efficient Finding of the Best Split • What is the gain of a split rule ? Say is age • All we need is sum of g and h in each side, and calculate • Left to right linear scan over sorted instance is enough to decide the best split along the feature g1, h1 g4, h4 g2, h2 g5, h5 g3, h3 a
  • 32. An Algorithm for Split Finding • For each node, enumerate over all features  For each feature, sorted the instances by feature value  Use a linear scan to decide the best split along that feature  Take the best split solution along all the features • Time Complexity growing a tree of depth K  It is O(n d K log n): or each level, need O(n log n) time to sort There are d features, and we need to do it for K level  This can be further optimized (e.g. use approximation or caching the sorted features)  Can scale to very large dataset
  • 33. What about Categorical Variables? • Some tree learning algorithm handles categorical variable and continuous variable separately  We can easily use the scoring formula we derived to score split based on categorical variables. • Actually it is not necessary to handle categorical separately.  We can encode the categorical variables into numerical vector using one-hot encoding. Allocate a #categorical length vector  The vector will be sparse if there are lots of categories, the learning algorithm is preferred to handle sparse data
  • 34. Pruning and Regularization • Recall the gain of split, it can be negative!  When the training loss reduction is smaller than regularization  Trade-off between simplicity and predictivness • Pre-stopping  Stop split if the best split have negative gain  But maybe a split can benefit future splits.. • Post-Prunning  Grow a tree to maximum depth, recursively prune all the leaf splits with negative gain
  • 35. Recap: Boosted Tree Algorithm • Add a new tree in each iteration • Beginning of each iteration, calculate • Use the statistics to greedily grow a tree • Add to the model  Usually, instead we do  is called step-size or shrinkage, usually set around 0.1  This means we do not do full optimization in each step and reserve chance for future rounds, it helps prevent overfitting
  • 36. Outline • Review of key concepts of supervised learning • Regression Tree and Ensemble (What are we Learning) • Gradient Boosting (How do we Learn) • Summary
  • 37. Questions to check if you really get it • How can we build a boosted tree classifier to do weighted regression problem, such that each instance have a importance weight? • Back to the time series problem, if I want to learn step functions over time. Is there other ways to learn the time splits, other than the top down split approach?
  • 38. Questions to check if you really get it • How can we build a boosted tree classifier to do weighted regression problem, such that each instance have a importance weight?  Define objective, calculate , feed it to the old tree learning algorithm we have for un-weighted version  Again think of separation of model and objective, how does the theory can help better organizing the machine learning toolkit
  • 39. Questions to check if you really get it • Time series problem • All that is important is the structure score of the splits  Top-down greedy, same as trees  Bottom-up greedy, start from individual points as each group, greedily merge neighbors  Dynamic programming, can find optimal solution for this case
  • 40. Summary • The separation between model, objective, parameters can be helpful for us to understand and customize learning models • The bias-variance trade-off applies everywhere, including learning in functional space • We can be formal about what we learn and how we learn. Clear understanding of theory can be used to guide cleaner implementation.
  • 41. Reference • Greedy function approximation a gradient boosting machine. J.H. Friedman  First paper about gradient boosting • Stochastic Gradient Boosting. J.H. Friedman  Introducing bagging trick to gradient boosting • Elements of Statistical Learning. T. Hastie, R. Tibshirani and J.H. Friedman  Contains a chapter about gradient boosted boosting • Additive logistic regression a statistical view of boosting. J.H. Friedman T. Hastie R. Tibshirani  Uses second-order statistics for tree splitting, which is closer to the view presented in this slide • Learning Nonlinear Functions Using Regularized Greedy Forest. R. Johnson and T. Zhang  Proposes to do fully corrective step, as well as regularizing the tree complexity. The regularizing trick is closed related to the view present in this slide • Software implementing the model described in this slide: https://github.com/tqchen/xgboost