-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathid3-decision-tree.qmd
148 lines (77 loc) · 5.79 KB
/
id3-decision-tree.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
---
title: "Decision Tree Algoritm"
format: html
typora-copy-images-to: images
---
**Taken from** [https://medium.datadriveninvestor.com/decision-tree-algorithm-with-hands-on-example-e6c2afb40d38](https://medium.datadriveninvestor.com/decision-tree-algorithm-with-hands-on-example-e6c2afb40d38)
**Entropy**
In machine learning, entropy is a measure of the randomness in the information being processed. The higher the entropy, the harder it is to draw any conclusions from that information.
data:image/s3,"s3://crabby-images/20f07/20f07615e08611ec68a7b6393a5a3f3d30ebca39" alt=""
**Information Gain**
Information gain can be defined as the amount of information gained about a random variable or signal from observing another random variable.It can be considered as the difference between the entropy of parent node and weighted average entropy of child nodes.
data:image/s3,"s3://crabby-images/b200a/b200ab46e0c14039fbf5295181658ab2444aa948" alt=""
**Gini Impurity**
Gini impurity is a measure of how often a randomly chosen element from the set would be incorrectly labeled if it was randomly labeled according to the distribution of labels in the subset.
data:image/s3,"s3://crabby-images/15084/15084ebf9f452d4c2a23d6e84490115a913bbc45" alt=""
Gini impurity is **lower bounded by 0**, with 0 occurring if the data set contains only one class.
data:image/s3,"s3://crabby-images/bc4a0/bc4a0ccc14ee2519e9a1dfd0e3580bb1364f4675" alt=""
There are many algorithms there to build a decision tree. They are
1. **CART** (Classification and Regression Trees) — This makes use of Gini impurity as the metric.
2. **ID3** (Iterative Dichotomiser 3) — This uses entropy and information gain as metric.
In this article, I will go through ID3. Once you got it it is easy to implement the same using CART.
# **Classification using the ID3 algorithm**
Consider whether a dataset based on which we will determine whether to play football or not.
data:image/s3,"s3://crabby-images/1ad13/1ad132e69cf3d2125eab54196575629c9e7ace13" alt=""
Here There are for independent variables to determine the dependent variable. The independent variables are Outlook, Temperature, Humidity, and Wind. The dependent variable is whether to play football or not.
As the first step, we have to find the parent node for our decision tree. For that follow the steps:
***Find the entropy of the class variable.\***
E(S) = -[(9/14)log(9/14) + (5/14)log(5/14)] = 0.94
note: Here typically we will take log to base 2.Here total there are 14 yes/no. Out of which 9 yes and 5 no.Based on it we calculated probability above.
From the above data for outlook we can arrive at the following table easily
data:image/s3,"s3://crabby-images/99c4c/99c4cd386e0ce9dce965b60f39bc01c43cd1b8eb" alt=""
***Now we have to calculate average weighted entropy\***. ie, we have found the total of weights of each feature multiplied by probabilities.
E(S, outlook) = (5/14)*E(3,2) + (4/14)*E(4,0) + (5/14)*E(2,3) = (5/14)(-(3/5)log(3/5)-(2/5)log(2/5))+ (4/14)(0) + (5/14)((2/5)log(2/5)-(3/5)log(3/5)) = 0.693
***The next step is to find the information gain\***. It is the difference between parent entropy and average weighted entropy we found above.
IG(S, outlook) = 0.94 - 0.693 = 0.247
Similarly find Information gain for Temperature, Humidity, and Windy.
IG(S, Temperature) = 0.940 - 0.911 = 0.029
IG(S, Humidity) = 0.940 - 0.788 = 0.152
IG(S, Windy) = 0.940 - 0.8932 = 0.048
***Now select the feature having the largest entropy gain\***. Here it is Outlook. So it forms the first node(root node) of our decision tree.
Now our data look as follows
data:image/s3,"s3://crabby-images/98e83/98e83ca11cc92507bd6b2d098cdea4378fdd3054" alt=""
data:image/s3,"s3://crabby-images/4bfa9/4bfa9c6bbe8cc8dd6030f5cf91af25987d31fa09" alt=""
data:image/s3,"s3://crabby-images/998c0/998c0192ac3effc24b652e353186c11a1a379f11" alt=""
Since overcast contains only examples of class ‘Yes’ we can set it as yes. That means If outlook is overcast football will be played. Now our decision tree looks as follows.
data:image/s3,"s3://crabby-images/32b64/32b648f2b4ae80375d0bc95e0b22f9d27aeed585" alt=""
The next step is to find the next node in our decision tree. Now we will find one under sunny. We have to determine which of the following Temperature, Humidity or Wind has higher information gain.
data:image/s3,"s3://crabby-images/62a40/62a40763fbdca6c3d8c5e303f105b08580104054" alt=""
Calculate parent entropy E(sunny)
E(sunny) = (-(3/5)log(3/5)-(2/5)log(2/5)) = 0.971.
Now Calculate the information gain of Temperature. IG(sunny, Temperature)
data:image/s3,"s3://crabby-images/a759b/a759bb9be3a49e3ec9a86a4a5989e1d2efd92b68" alt=""
E(sunny, Temperature) = (2/5)*E(0,2) + (2/5)*E(1,1) + (1/5)*E(1,0)=2/5=0.4
Now calculate information gain.
IG(sunny, Temperature) = 0.971–0.4 =0.571
Similarly we get
IG(sunny, Humidity) = 0.971
IG(sunny, Windy) = 0.020
Here IG(sunny, Humidity) is the largest value. So Humidity is the node that comes under sunny.
data:image/s3,"s3://crabby-images/7956c/7956c87eb14e8adef625d2f97503b8f8740bc594" alt=""
For humidity from the above table, we can say that play will occur if humidity is normal and will not occur if it is high. Similarly, find the nodes under rainy.
***Note: A branch with entropy more than 0 needs further splitting.\***
Finally, our decision tree will look as below:
data:image/s3,"s3://crabby-images/b8365/b8365bb11e8e2b2975fd6c4c45141f8a736ab1df" alt=""
# Classification using CART algorithm
Classification using CART is similar to it. But instead of entropy, we use Gini impurity.
**So as the first step we will find the root node of our decision tree. For that Calculate the Gini index of the class variable**
Gini(S) = 1 - [(9/14)² + (5/14)²] = 0.4591
**As the next step, we will calculate the Gini gain.** For that first, we will find the average weighted Gini impurity of Outlook, Temperature, Humidity, and Windy.
First, consider case of Outlook
data:image/s3,"s3://crabby-images/3cb5e/3cb5e4b3099acb96a369c5a2ae54e3d2f0412954" alt=""
Gini(S, outlook) = (5/14)gini(3,2) + (4/14)*gini(4,0)+ (5/14)*gini(2,3) = (5/14)(1 - (3/5)² - (2/5)²) + (4/14)*0 + (5/14)(1 - (2/5)² - (3/5)²)= 0.171+0+0.171 = 0.342
Gini gain (S, outlook) = 0.459 - 0.342 = 0.117
Gini gain(S, Temperature) = 0.459 - 0.4405 = 0.0185
Gini gain(S, Humidity) = 0.459 - 0.3674 = 0.0916
Gini gain(S, windy) = 0.459 - 0.4286 = 0.0304
Choose one that has a higher Gini gain. Gini gain is higher for outlook. So we can choose it as our root node.