https://github.com/primozgodec/keras-explain
The toolkit to explain Keras model predictions.
https://github.com/primozgodec/keras-explain
Last synced: about 1 year ago
JSON representation
The toolkit to explain Keras model predictions.
- Host: GitHub
- URL: https://github.com/primozgodec/keras-explain
- Owner: PrimozGodec
- License: mit
- Created: 2018-08-21T14:21:33.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-08-02T16:12:48.000Z (almost 2 years ago)
- Last Synced: 2025-03-27T12:02:16.718Z (about 1 year ago)
- Language: Python
- Homepage:
- Size: 194 KB
- Stars: 15
- Watchers: 4
- Forks: 6
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Keras Explain
This package includes the majority of explanation tools for explaining
Keras models predictions. Currently, only models with images on input are
supported.
It supports following approaches:
Gradient methods:
- GradCam [[Selvaraju](https://arxiv.org/abs/1610.02391)]
- Guided GradCam [[Selvaraju](https://arxiv.org/abs/1610.02391)]
- Guided back-propagation [[Springenberg](https://arxiv.org/abs/1412.6806)]
- Integrated gradients [[Sundararajan](https://arxiv.org/abs/1703.01365)]
- Saliency [[Simonyan](https://arxiv.org/abs/1312.6034)]
- Layer-wise relevance propagation [BETA] [[Bach](http://journals.plos.org/plosone/article?id=10.1371/journal.pone.0130140)]
Model-independent methods:
- Prediction difference [[Zintgraf](https://arxiv.org/abs/1702.04595)]
- Basic graying out [[Zeiler](https://arxiv.org/abs/1311.2901)]
- LIME [[Ribeiro](https://arxiv.org/abs/1602.04938)]
All approaches are easy to apply to your model in two lines of code.
If you have any suggestion for new approaches to be included in the package
please do not hesitate to suggest. Also all improvements suggestions, bug reports and bug fixes are welcome.
Right now we are in the process of implementing the following approaches:
- Meaningful perturbation by Fong et al.
- Layer-wise relevance propagation - we are adding layers that are not supported
yet.
## Installation
1. Install keras with theano or tensorflow backend.
Note that this library requires Keras > 2.0. Currently, versions of Keras >= 2.2.0
are not supported sine there is a [bug in Keras](https://github.com/keras-team/keras/issues/10372).
2. Install keras-explain
From PyPI
pip install keras-explain
From source: Clone this repository and install:
sudo python setup.py install
## Usage
### Gradient methods
#### GradCam
from keras_explain.grad_cam import GradCam
explainer = GradCam(model, layer=None)
exp = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
- `layer` - (optional) The index (index in model.layers) of the layer which
prediction is explained.
If not specified the last layer prediction is explained automatically.
Output:
- `exp` - explanation. GradCam mark only features which contribute to the
classification in a `target class`.
#### Guided GradCam
from keras_explain.grad_cam import GuidedGradCam
explainer = GuidedGradCam(model, lyer=None)
exp = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
- `layer` - (optional) The index (index in model.layers) of the layer which
prediction is explained.
If not specified the last layer prediction is explained automatically.
Output:
- `exp` - explanation. GuidedGradCam mark only features which contribute to the
classification in a `target class`.
#### Guided back-propagation
from keras_explain.guided_bp import GuidedBP
explainer = GuidedBP(model)
exp = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
Output:
- `exp` - explanation. Guided back-propagation mark only features which
contribute to the classification in a `target class`.
#### Integrated gradients
from keras_explain.integrated_gradients import IntegratedGradients
explainer = IntegratedGradients(model)
exp = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
Output:
- `exp` - explanation. Integrated gradients mark only features which contribute
to the classification in a `target class`.
#### Saliency
from keras_explain.saliency import Saliency
explainer = Saliency(model, layer=None)
exp = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
- `layer` - (optional) The index (index in model.layers) of the layer which
prediction is explained.
If not specified the last layer prediction is explained automatically.
Output:
- `exp` - explanation. Saliency mark only features which contribute
to the classification in a `target class`.
#### Layer-wise relevance propagation [BETA]
This approach does not support all layers yet. We are currently implementing
missing layers. If you wish you can implement any layer support yourself
and submit it as a pull request. Since implementation is very custom any
suggestion for improvement is welcome.
from keras_explain.lrp import LRP
explainer = LRP(model)
exp = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
Output:
- `exp` - explanation. LRP mark only features which contribute
to the classification in a `target class`.
### Model independent approaches
#### Prediction difference
from keras_explain.prediction_diff import PredictionDiff
explainer = PredictionDiff(model)
exp_pos, exp_neg = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
Output:
- `exp_pos` - explanation with marked features which contribute
to the classification in a `target class`.
- `exp_neg` - explanation with marked features which contribute
against the classification in a `target class`.
#### Basic graying out
from keras_explain.graying_out import GrayingOut
explainer = GrayingOut(model)
exp_pos, exp_neg = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
Output:
- `exp_pos` - explanation with marked features which contribute
to the classification in a `target class`.
- `exp_neg` - explanation with marked features which contribute
against the classification in a `target class`.
#### LIME
from keras_explain.lime_ribeiro import Lime
explainer = Lime(model)
exp_pos, exp_neg = explainer.explain(image, target_class)
Parameters:
- `model` - Keras model which is explained
- `image` - input which prediction is explained
- `target_class` - approach explains prediction for a target class
Output:
- `exp_pos` - explanation with marked features which contribute
to the classification in a `target class`.
- `exp_neg` - explanation with marked features which contribute
against the classification in a `target class`.