-
Complete the decision tree implementation in tree/base.py The code should be written in Python and not use existing libraries other than the ones already imported in the code. Your decision tree should work for four cases: i) discrete features, discrete output; ii) discrete features, real output; iii) real features, discrete output; real features, real output. Your decision tree should be able to use GiniIndex or InformationGain as the criteria for splitting. Your code should also be able to plot/display the decision tree.
You should be editing the following files.
-
metrics.py
: Complete the performance metrics functions in this file. -
usage.py
: Run this file to check your solutions. -
tree (Directory): Module for decision tree.
base.py
: Complete Decision Tree Class.utils.py
: Complete all utility functions.__init__.py
: Do not edit this
You should run usage.py to check your solutions.
-
-
Generate your dataset using the following lines of code
from sklearn.datasets import make_classification X, y = make_classification( n_features=2, n_redundant=0, n_informative=2, random_state=1, n_clusters_per_class=2, class_sep=0.5) # For plotting import matplotlib.pyplot as plt plt.scatter(X[:, 0], X[:, 1], c=y)
a) Show the usage of your decision tree on the above dataset. The first 70% of the data should be used for training purposes and the remaining 30% for test purposes. Show the accuracy, per-class precision and recall of the decision tree you implemented on the test dataset.
b) Use 5 fold cross-validation on the dataset. Using nested cross-validation find the optimum depth of the tree.
You should be editing
classification-exp.py
for the code containing the experiments. -
a) Show the usage of your decision tree for the automotive efficiency problem.
b) Compare the performance of your model with the decision tree module from scikit learn.
You should be editing
auto-efficiency.py
for the code containing the experiments. -
Create some fake data to do some experiments on the runtime complexity of your decision tree algorithm. Create a dataset with N samples and M binary features. Vary M and N to plot the time taken for: 1) learning the tree, 2) predicting for test data. How do these results compare with theoretical time complexity for decision tree creation and prediction. You should do the comparison for all the four cases of decision trees.
You should be editing
experiments.py
for the code containing the experiments. -
a) Implement Adaboost on Decision Stump (depth -1 tree). You could use Decision Tree learnt in assignment #1 or sklearn decision tree and solve it for the case of real input and discrete output. Edit
ensemble/ADABoost.py
b) Implement AdaBoostClassifier on classification data set. Fix a random seed of 42. Shuffle the dataset according to this random seed. Use the first 60% of the data for training and last 40% of the data set for testing. Plot the decision surfaces as done for Q1a) and compare the accuracy of AdaBoostClassifier using 3 estimators over decision stump. Include your code in
q5_ADABoost.py
. -
a) Implement Bagging(BaseModel, num_estimators): where base model is be DecisionTree (or sklearn decision tree) you have implemented. In a later assignment, you would have to implement the above over LinearRegression() also. Edit
ensemble/bagging.py
. Useq6_Bagging.py
for testing. -
a) Implement RandomForestClassifier() and RandomForestRegressor() classes in
tree/randomForest.py
. Useq7_RandomForest.py
for testing.b) Generate the plots for classification data set. Fix a random seed of 42. Shuffle the dataset according to this random seed. Use the first 60% of the data for training and last 40% of the data set for testing. Include you code in `random_forest_classification.py.
-
Notifications
You must be signed in to change notification settings - Fork 0
GautamV234/Decision-Trees-Implementation
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
About
A complete from-scratch implementation of decision trees and other ensemble methods like Adaboost, Random Forest and Bagging
Resources
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published