Skip to content

plot_shap_force


method plot_shap_force(models=None, index=None, target=1, title=None, legend=None, figsize=(900, 300), filename=None, display=True, **kwargs)[source]
Plot SHAP's force plot.

Visualize the given SHAP values with an additive force layout. Note that by default this plot will render using javascript. For a regular figure use matplotlib=True (this option is only available when only a single sample is plotted). Read more about SHAP plots in the user guide.

Parametersmodels: int, str, Model or None, default=None
Model to plot. If None, all models are selected. Note that leaving the default option could raise an exception if there are multiple models. To avoid this, call the plot directly from a model, e.g. atom.lr.plot_shap_force().

index: int, str, slice, sequence or None, default=None
Rows in the dataset to plot. If None, it selects all rows in the test set.

target: int or str, default=1
Class in the target column to look at (only for multi-class classification tasks).

title: str, dict or None, default=None
Title for the plot.

legend: str, dict or None, default=None
Does nothing. Implemented for continuity of the API.

figsize: tuple or None, default=(900, 300)
Figure's size in pixels, format as (x, y).

filename: str or None, default=None
Save the plot using this name. Use "auto" for automatic naming. The type of the file depends on the provided name (.html, .png, .pdf, etc...). If filename has no file type, the plot is saved as html. If None, the plot is not saved.

display: bool or None, default=True
Whether to render the plot. If None, it returns the figure.

**kwargs
Additional keyword arguments for shap.plots.force.

Returnsplt.Figure or None
Plot object. Only returned if display=None.


See Also

plot_shap_beeswarm

Plot SHAP's beeswarm plot.

plot_shap_scatter

Plot SHAP's scatter plot.

plot_shap_decision

Plot SHAP's decision plot.


Example

>>> from atom import ATOMClassifier
>>> from sklearn.datasets import load_breast_cancer

>>> X, y = load_breast_cancer(return_X_y=True, as_frame=True)

>>> atom = ATOMClassifier(X, y)
>>> atom.run("LR")
>>> atom.plot_shap_force(index=-2, matplotlib=True, figsize=(1800, 300))

plot_shap_force