I'm using RandomForest.featureImportances
but I don't understand the output result.
I have 12 features, and this is the output I get.
I get that this might not be an apache-spark specific question but I cannot find anywhere that explains the output.
// org.apache.spark.mllib.linalg.Vector = (12,[0,1,2,3,4,5,6,7,8,9,10,11],
[0.1956128039688559,0.06863606797951556,0.11302128590305296,0.091986700351889,0.03430651625283274,0.05975817050022879,0.06929766152519388,0.052654922125615934,0.06437052114945474,0.1601713590349946,0.0324327322375338,0.057751258970832206])
Adding on to the previous answer:
One of the problems that I faced was in dumping the result in the form of (featureName,Importance) as a csv.One can get the metadata for the input vector of features as
This is the json structure for this metadata:
Code for extracting the importance:
Given a tree ensemble model,
RandomForest.featureImportances
computes the importance of each feature.This generalizes the idea of "Gini" importance to other losses, following the explanation of Gini importance from "Random Forests" documentation by Leo Breiman and Adele Cutler, and following the implementation from scikit-learn.
For collections of trees, which includes boosting and bagging, Hastie et al. suggests to use the average of single tree importances across all trees in the ensemble.
And this feature importance is calculated as followed :
References: Hastie, Tibshirani, Friedman. "The Elements of Statistical Learning, 2nd Edition." 2001. - 15.3.2 Variable Importance page 593.
Let's go back to your importance vector :
First, let's sort this features by importance :
So what does this mean ?
It means that your first feature (index 0) is the most important feature with a weight of ~ 0.19 and your 11th (index 10) feature is the least important in your model.