This package makes it convenient to quickly deploy a dashboard web app
that explains the workings of a (scikit-learn compatible) fitted machine
learning model. The dashboard provides interactive plots on model performance,
feature importances, feature contributions to individual predictions,
partial dependence plots, SHAP (interaction) values, visualisation of individual
decision trees, etc.
The goal is manyfold:
- Make it easy for data scientists to quickly inspect the inner workings and
performance of their model with just a few lines of code
- Make it possible for non data scientist stakeholders such as co-workers,
managers, directors, internal and external watchdogs to interactively
inspect the inner workings of the model without having to depend
on a data scientist to generate every plot and table
- Make it easy to build a custom application that explains individual
predictions of your model for customers that ask for an explanation
- Explain the inner workings of the model to the people working with
model in a human-in-the-loop deployment so that they gain understanding
what the model does do and does not do.
This is important so that they can gain an intuition for when the
model is likely missing information and may have to be overruled.
The dashboard includes:
- SHAP values (i.e. what is the contribution of each feature to each
individual prediction?)
- Permutation importances (how much does the model metric deteriorate
when you shuffle a feature?)
- Partial dependence plots (how does the model prediction change when
you vary a single feature?
- Shap interaction values (decompose the shap value into a direct effect
an interaction effects)
- For Random Forests and xgboost models: visualization of individual trees
in the ensemble.
- Plus for classifiers: precision plots, confusion matrix, ROC AUC plot,
PR AUC plot, etc
- For regression models: goodness-of-fit plots, residual plots, etc.
The library is designed to be modular so that it is easy to design your
own custom dashboards so that you can focus on the layout and project specific
textual explanations of the dashboard. (i.e. design it so that it will be
interpretable for business users in your organization, not just data scientists)
A deployed example can be found at http://titanicexplainer.herokuapp.com
Raw data
{
"_id": null,
"home_page": "https://github.com/oegedijk/explainerdashboard",
"name": "explainerdashboard",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": "machine learning, explainability, shap, feature importances, dash",
"author": "Oege Dijk",
"author_email": "oegedijk@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/b2/83/bfbe04bd0ac511c5380891a440e0c92655bdfb0d31a8b454f6512db1fd25/explainerdashboard-0.4.8.tar.gz",
"platform": null,
"description": "\n\nThis package makes it convenient to quickly deploy a dashboard web app\nthat explains the workings of a (scikit-learn compatible) fitted machine \nlearning model. The dashboard provides interactive plots on model performance, \nfeature importances, feature contributions to individual predictions, \npartial dependence plots, SHAP (interaction) values, visualisation of individual\ndecision trees, etc. \n\n\nThe goal is manyfold:\n\n - Make it easy for data scientists to quickly inspect the inner workings and \n performance of their model with just a few lines of code\n - Make it possible for non data scientist stakeholders such as co-workers,\n managers, directors, internal and external watchdogs to interactively \n inspect the inner workings of the model without having to depend \n on a data scientist to generate every plot and table\n - Make it easy to build a custom application that explains individual \n predictions of your model for customers that ask for an explanation\n - Explain the inner workings of the model to the people working with \n model in a human-in-the-loop deployment so that they gain understanding \n what the model does do and does not do. \n This is important so that they can gain an intuition for when the \n model is likely missing information and may have to be overruled.\n\nThe dashboard includes:\n\n - SHAP values (i.e. what is the contribution of each feature to each \n individual prediction?)\n - Permutation importances (how much does the model metric deteriorate \n when you shuffle a feature?)\n - Partial dependence plots (how does the model prediction change when \n you vary a single feature?\n - Shap interaction values (decompose the shap value into a direct effect \n an interaction effects)\n - For Random Forests and xgboost models: visualization of individual trees\n in the ensemble. \n - Plus for classifiers: precision plots, confusion matrix, ROC AUC plot, \n PR AUC plot, etc\n - For regression models: goodness-of-fit plots, residual plots, etc.\n\nThe library is designed to be modular so that it is easy to design your \nown custom dashboards so that you can focus on the layout and project specific \ntextual explanations of the dashboard. (i.e. design it so that it will be \ninterpretable for business users in your organization, not just data scientists)\n\n\nA deployed example can be found at http://titanicexplainer.herokuapp.com\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Quickly build Explainable AI dashboards that show the inner workings of so-called \"blackbox\" machine learning models.",
"version": "0.4.8",
"project_urls": {
"Documentation": "https://explainerdashboard.readthedocs.io/",
"Github page": "https://github.com/oegedijk/explainerdashboard/",
"Homepage": "https://github.com/oegedijk/explainerdashboard"
},
"split_keywords": [
"machine learning",
" explainability",
" shap",
" feature importances",
" dash"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "a04dadceb7924f5e3772f5966402bf28a56d4b9d5f791b4abf6a5206723ff8be",
"md5": "bd4fdd13278f23fa6a6481ed7ed565ad",
"sha256": "6da407fa99c03ed1ba6fe4b0016e137ad26cbbb843c3554fd2784d8fa7d31efd"
},
"downloads": -1,
"filename": "explainerdashboard-0.4.8-py3-none-any.whl",
"has_sig": false,
"md5_digest": "bd4fdd13278f23fa6a6481ed7ed565ad",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 287950,
"upload_time": "2024-12-29T21:23:32",
"upload_time_iso_8601": "2024-12-29T21:23:32.665628Z",
"url": "https://files.pythonhosted.org/packages/a0/4d/adceb7924f5e3772f5966402bf28a56d4b9d5f791b4abf6a5206723ff8be/explainerdashboard-0.4.8-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "b283bfbe04bd0ac511c5380891a440e0c92655bdfb0d31a8b454f6512db1fd25",
"md5": "d5b6a15b6af8199b355f700c9e9a920c",
"sha256": "93b3ef54f09bd02969a07afe94ef5b1305a71e699ed5894b7fb250d6171a73ac"
},
"downloads": -1,
"filename": "explainerdashboard-0.4.8.tar.gz",
"has_sig": false,
"md5_digest": "d5b6a15b6af8199b355f700c9e9a920c",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 276415,
"upload_time": "2024-12-29T21:23:35",
"upload_time_iso_8601": "2024-12-29T21:23:35.105888Z",
"url": "https://files.pythonhosted.org/packages/b2/83/bfbe04bd0ac511c5380891a440e0c92655bdfb0d31a8b454f6512db1fd25/explainerdashboard-0.4.8.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-29 21:23:35",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "oegedijk",
"github_project": "explainerdashboard",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "click",
"specs": []
},
{
"name": "dash-auth",
"specs": []
},
{
"name": "dash-bootstrap-components",
"specs": [
[
">=",
"1"
]
]
},
{
"name": "dash",
"specs": [
[
">=",
"2.10.1"
]
]
},
{
"name": "dtreeviz",
"specs": [
[
">=",
"2.1"
]
]
},
{
"name": "flask_simplelogin",
"specs": []
},
{
"name": "Flask-WTF",
"specs": [
[
">=",
"1.1"
]
]
},
{
"name": "graphviz",
"specs": [
[
">=",
"0.18.2"
]
]
},
{
"name": "joblib",
"specs": []
},
{
"name": "jupyter_dash",
"specs": [
[
">=",
"0.4.1"
]
]
},
{
"name": "numpy",
"specs": [
[
"<",
"2"
]
]
},
{
"name": "oyaml",
"specs": []
},
{
"name": "pandas",
"specs": [
[
">=",
"1.1"
]
]
},
{
"name": "scikit-learn",
"specs": [
[
">=",
"1.1"
]
]
},
{
"name": "shap",
"specs": [
[
">=",
"0.42.1"
]
]
},
{
"name": "waitress",
"specs": []
}
],
"lcname": "explainerdashboard"
}