XGBoost Feature Interactions Reshaped
Xgbfir is a XGBoost model dump parser, which ranks features as well as feature interactions by different metrics.
This project started as a python port of Xgbfi - XGBoost Feature Interactions & Importance project. Thanks Far0n for great tool and idea!
Some basic description from Xgbfi project page is presented here.
- Gain: Total gain of each feature or feature interaction
- FScore: Amount of possible splits taken on a feature or feature interaction
- wFScore: Amount of possible splits taken on a feature or feature interaction weighted by the probability of the splits to take place
- Average wFScore: wFScore divided by FScore
- Average Gain: Gain divided by FScore
- Expected Gain: Total gain of each feature or feature interaction weighted by the probability to gather the gain
- Average Tree Index
- Average Tree Depth
- Leaf Statistics
- Split Value Histograms
You have several options to install Xgbfir.
You can install using the pip package manager by running
pip install xgbfir
Sorry, conda build is not ready yet. Please build from source.
You can install using the conda package manager by running
conda install
Clone the repo and install:
git clone https://github.com/limexp/xgbfir.git
cd xgbfir
sudo python setup.py install
Or download the source code by pressing 'Download ZIP' on this page. Install by navigating to the proper directory and running
sudo python setup.py install
You can use Xgbfir as a python function or as a CLI (Command Line Interface) tool.
You can produce feature interactions file without saving any model dump file beforehand:
import xgbfir
xgbfir.saveXgbFI(booster) # booster is a XGBoost booster
List of saveXgbFI function parameters:
- booster - XGBoost booster or XGBClassifier
- feature_names (default = None) - feature names that will be set in booster
- OutputXlsxFile (default = 'XgbFeatureInteractions.xlsx') - output file name
- MaxTrees (default = 100) - Upper bound for trees to be parsed
- MaxInteractionDepth (default = 2) - Upper bound for extracted feature interactions depth
- MaxDeepening (default = -1) - Upper bound for interaction start deepening (zero deepening => interactions starting at root only)
- TopK (default = 100) - Upper bound for exported feature interactions per depth level
- MaxHistograms (default = 10) - Maximum number of histograms
- SortBy (default = 'Gain') - Score metric to sort by (Gain, FScore, wFScore, AvgwFScore, AvgGain, ExpGain)
Take a look at this example of usage (available in examples):
from sklearn.datasets import load_iris, load_boston
import xgboost as xgb
import xgbfir
# loading database
boston = load_boston()
# doing all the XGBoost magic
xgb_rmodel = xgb.XGBRegressor().fit(boston['data'], boston['target'])
# saving to file with proper feature names
xgbfir.saveXgbFI(xgb_rmodel, feature_names=boston.feature_names, OutputXlsxFile = 'bostonFI.xlsx')
# loading database
iris = load_iris()
# doing all the XGBoost magic
xgb_cmodel = xgb.XGBClassifier().fit(iris['data'], iris['target'])
# saving to file with proper feature names
xgbfir.saveXgbFI(xgb_cmodel, feature_names=iris.feature_names, OutputXlsxFile = 'irisFI.xlsx')
Xgbfir can be run as a console tool with the following command:
xgbfir [options]
Use the following command for help:
xgbfir --help
XGBoost model dump must be created before running xgbfir.
To dump a model with proper feature names use the following code:
booster.feature_names = list(feature_names) # set names for XGBoost booster
booster.dump_model('xgb.dump', with_stats=True)
- python (2.7+ or 3.5+)
- xlsxwriter (>=0.9.3)
Xgbfir is in beta now, so there are several ways for improvement:
- Add more information and error messages, handle wrong input
- Make code style cool
- Cover with tests
Add non-CLIDone!Parse model from XGBoost without dumpingDone!- Optimize code
- Add new functions
Feel free to contact me, open issues or pull requests.