-
-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy path13-Instance-level-summary.Rmd
executable file
·206 lines (133 loc) · 22.5 KB
/
13-Instance-level-summary.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
# Summary of Instance-level Exploration {#summaryInstanceLevel}
```{r, echo=FALSE, warning=FALSE}
source("code_snippets/ema_init.R")
```
## Introduction {#summaryInstanceLevelIntro}
In Part II of the book, we introduced a number of techniques for exploration and explanation of a model's predictions for individual instances. Each chapter was devoted to a single technique. In practice, these techniques are rarely used separately. Rather, it is more informative to combine different insights offered by each technique into a more holistic overview.
Figure \@ref(fig:instanceLevelExplainers) offers a graphical illustration of the idea. The graph includes results of four different instance-level explanation techniques applied to the random forest model (Section \@ref(model-titanic-rf)) for the Titanic data (Section \@ref(TitanicDataset)). The instance of interest is Johnny D, an 8-year-old boy who embarked in Southampton and travelled in the first class with no parents nor siblings, and with a ticket costing 72 pounds (Section \@ref(predictions-titanic)). Recall that the goal is to predict the probability of survival of Johnny D.
The plots in the first row of Figure \@ref(fig:instanceLevelExplainers) show results of application of various variable-attribution and variable-importance methods like break-down (BD) plots (Chapter \@ref(breakDown)), Shapley values (Chapter \@ref(shapley)), and local interpretable model-agnostic explanations (LIME, see Chapter \@ref(LIME)). The results consistently suggest that the most important explanatory variables, from a point of view of prediction of the probability of survival for Johnny D, are *age*, *gender*, *class*, and *fare*. Note, however, that the picture offered by the additive decompositions may not be entirely correct, because *fare* and *class* are correlated, and there may be an interaction between the effects of *age* and *gender*.
The plots in the second row of Figure \@ref(fig:instanceLevelExplainers) show ceteris-paribus (CP) profiles (see Chapter \@ref(ceterisParibus)) for these four most important explanatory variables for Johnny D. The profiles suggest that increasing age or changing the travel class to the second class or to "restaurant staff" would decrease the predicted probability of survival. On the other hand, decreasing the ticket fare, changing gender to female, or changing the travel class to "deck crew" would increase the probability.
The plots in the third row of Figure \@ref(fig:instanceLevelExplainers) summarize univariate distributions of the four explanatory variables. We see, for instance, that the ticket fare of 72 pounds, which was paid for Johnny D's ticket, was very high and that there were few children among the passengers of Titanic.
Figure \@ref(fig:instanceLevelExplainers) nicely illustrates that perspectives offered by the different techniques complement each other and, when combined, allow obtaining a more profound insight into the origins of the model's prediction for the instance of interest.
(ref:instanceLevelExplainersDesc) Results of instance-level-explanation techniques for the random forest model for the Titanic data and passenger Johnny D.
```{r instanceLevelExplainers, echo=FALSE, fig.cap='(ref:instanceLevelExplainersDesc)', out.width = '100%', fig.align='center'}
knitr::include_graphics("figure/instance_level.png")
```
<!---
In Chapter \@ref(UseCaseFIFA), we will present an example illustrating how instance-level explanations may be combined with dataset-level explanations.
--->
While combining various techniques for instance-level explanation can provide additional insights, it is worth remembering that the techniques are, indeed, different and their suitability may depend on the problem at hand. This is what we discuss in the remainder of the chapter.
## Number of explanatory variables in the model
One of the most important criteria for selection of the exploration and explanation methods is the number of explanatory variables in the model.
### Low to medium number of explanatory variables
A low number of variables usually implies that the particular variables have a very concrete meaning and interpretation. An example are variables used in models for the Titanic data presented in Sections \@ref(model-titanic-lmr) and \@ref(model-titanic-gbm).
In such a situation, the most detailed information about the influence of the variables on a model's predictions is provided by the CP profiles. In particular, the variables that are most influential for the model's predictions are selected by considering CP-profile oscillations (see Chapter \@ref(ceterisParibusOscillations)) and then illustrated graphically with the help of individual-variable CP profiles (see Chapter \@ref(ceterisParibus)).
### Medium to a large number of explanatory variables
In models with a medium or large number of variables, it is still possible that most (or all) of them are interpretable. An example of such a model is a car-insurance pricing model in which we want to estimate the value of an insurance based on behavioral data that includes 100+ variables about characteristics of the driver and characteristics of the car.
When the number of explanatory variables increases, it becomes harder to show the CP profile for each individual variable. In such situations, the most common approach is to use BD plots, presented in Chapter \@ref(breakDown), or plots of Shapley values, discussed in Chapter \@ref(shapley). They allow a quick evaluation whether a particular variable has got a positive or negative effect on a model's prediction; we can also assess the size of the effect. If necessary, it is possible to limit the plots only to the variables with the largest effects.
### Very large number of explanatory variables
When the number of explanatory variables is very large, it may be difficult to interpret the role of each single variable. An example of such situations are models for processing of images or texts. In that case, explanatory variables may be individual pixels in image processing or individual characters in text analysis. As such, their individual interpretation is limited. Due to additional issues with computational complexity, it is not feasible to use CP profiles, BD plots, nor Shapley values to evaluate influence of individual values on a model's predictions. Instead, the most common approach is to use LIME, presented in Chapter \@ref(LIME), which works on the context-relevant groups of variables.
## Correlated explanatory variables
When deriving properties for the methods presented in Part II of this book, we often assumed that explanatory variables are independent. Obviously, this is not always the case. For instance, in the case of the data on apartment prices (see Section \@ref(exploration-apartments)), the number of rooms and the surface of an apartment will most likely be positively associated. A similar conclusion can be drawn for the travel class and ticket fare for the Titanic data (see Section \@ref(exploration-titanic)).
Of course, technically speaking, all the presented methods can be applied also when explanatory variables are correlated. However, in such a case the results may be misleading or unrealistic.
To address the issue, one could consider creating new variables that would be independent. This is sometimes possible using the application-domain knowledge or by using suitable statistical techniques like principal-components analysis. An alternative is to construct two-dimensional CP plots (see Section \@ref(CPProsCons)) or permute variables in blocks to preserve the correlation structure of variables when computing Shapley values (see Chapter \@ref(shapley)) or BD plots (see Chapter \@ref(breakDown)).
## Models with interactions
In models with interactions, the effect of one explanatory variable may depend on values of other variables. For example, the probability of survival for Titanic passengers may decrease with age, but the effect may be different for different travel-classes.
In such a case, to explore and explain a model's predictions, we have got to consider not individual variables, but sets of variables included in interactions. To identify interactions, we can use iBD plots, as described in Chapter \@ref(iBreakDown). To show effects of interaction, we may use a set of CP profiles. In particular, for the Titanic example, we may use the CP profiles for the *age* variable for instances that differ only in *gender*. The less parallel are such profiles, the larger the effect of interaction.
## Sparse explanations
Predictive models may use hundreds of explanatory variables to yield a prediction for a particular instance. However, for a meaningful interpretation and illustration, most human beings can handle only a very limited (say, less than 10) number of variables. Thus, sparse explanations are of interest. The most common method that is used to construct such explanations is LIME (Chapter \@ref(LIME)). However, constructing a sparse explanation for a complex model is not trivial and may be misleading. Hence, care is needed when applying LIME to very complex models.
## Additional uses of model exploration and explanation
In the previous chapters of Part II of the book, we focused on the application of the presented methods to exploration and explanation of predictive models. However, the methods can also be used for other purposes:
* *Model improvement/debugging*. If a model's prediction is particularly bad for a selected observation, then the investigation of the reasons for such a bad performance may provide hints about how to improve the model. In the case of instance predictions, it is easier to detect that a selected explanatory variable should have a different effect than the observed one.\index{Model | debugging}
* *Additional domain-specific validation*. Understanding which factors are important for a model's predictions helps in evaluation of the plausibility of the model. If the effects of some explanatory variables on the predictions are observed to be inconsistent with the domain knowledge, this may provide a ground for criticising the model and, eventually, replacing it by another one. On the other hand, if the influence of the variables on the model's predictions is consistent with prior expectations, the user may become more confident with the model. Such confidence is fundamental when the model's predictions are used as a support for taking decisions that may lead to serious consequences, like in the case of, for example, predictive models in medicine.
* *Model selection*. In the case of multiple candidate models, one may use results of the model explanation techniques to select one of the candidates. It is possible that, even if two models are similar in terms of overall performance, one of them may perform much better locally. Consider the following, highly hypothetical example. Assume that a model is sought to predict whether it will rain on a particular day in a region where it rains on half of the days. Two models are considered: one which simply predicts that it will rain every other day, and another that predicts that it will rain every day since October till March. Arguably, both models are rather unsophisticated (to say the least), but they both predict that, on average, half of the days will be rainy. (We can say that both models are well-calibrated; see Section \@ref(modelPerformanceIntuition).) However, investigation of the instance predictions (for individual days) may lead to a preference for one of them. \index{Model ! selection}
* *New knowledge extraction*. Machine-learning models are mainly built for the effectiveness of predictions. As mentioned by @twoCultures, it is a different style than the modelling based on the understanding of the phenomena that generated observed values of interests. However, model explanations may sometimes help to extract new and useful knowledge in the field, especially in areas where there is not much domain knowledge yet.
## Comparison of models (champion-challenger analysis)
The techniques for explaining and exploring models have many applications. One of them is the opportunity to compare models.
There are situations when we may be interested in the "champion-challenger" analysis. Let us assume that some institution uses a predictive model, but wants to know if it could get a better model using other modelling techniques. For example, the risk department in a bank may be using logistic regression to assess credit risk. The model may perform satisfactorily and, hence, be considered as the "champion", i.e., the best model in the class of logistic regression models. However, the department may be interested in checking whether a "challenger", i.e., a more complex model developed by using, for instance, boosting or random trees, will not perform better. And if it is performing better, the question of interest is: how does the challenger differ from the champion?
Another reason why we may want to compare models is the fact that the modelling process is iterative itself (see Section \@ref(MDPprocess)). During the process many versions of models are created, often with different structures, and sometimes with a very similar performance. Comparative analysis allows for better understanding of how these models differ from each other.
Below we present an example of a comparative analysis for the logistic regression model `titanic_lmr` (Section \@ref(model-titanic-lmr)), random forest model `titanic_rf` (Section \@ref(model-titanic-rf)), boosting model of `titanic_gbm` (Section \@ref(model-titanic-gbm)), and support-vector machine (SVM) model `titanic_svm` (Section \@ref(model-titanic-svm)). We consider Johnny D (see Section \@ref(predictions-titanic)) as the instance of interest.
Note that the models do importantly differ. The random forest and boosting models are tree-based, with a stepped response (prediction) curve. They are complex due to a large number of trees used for prediction. The logistic regression and SVM models lead to continuous and smooth response curves. Their complexity stems from the fact that the logistic regression model includes spline transformations, while the SVM model uses a non-linear kernel function\index{Kernel ! function}. The differences result in different predicted values of the probability of survival for Johnny D. In particular, the predicted value of the probability is equal to 0.42, 0.77, 0.66, and 0.22 for the random forest, logistic regression, gradient boosting, and SVM model, respectively (see Section \@ref(predictions-titanic)).
Figure \@ref(fig:championChallengerSHAP) shows the Shapley values (see Chapter \@ref(shapley)) for the four models for Johnny D. For the random forest and logistic regression models, similar variables are indicated as important: *age*, *class*, and *gender*. *Class* and *gender* are also important for the gradient boosting model, while for the SVM model, the most important variable is *gender*, followed by *age* and *parch*.
(ref:championChallengerSHAPDesc) Shapley values for four different models for the Titanic data and passenger Johnny D.
```{r championChallengerSHAP, warning=FALSE, message=FALSE, echo=FALSE, fig.width=9.5, fig.height=4.5, fig.cap='(ref:championChallengerSHAPDesc)', out.width = '100%', fig.align='center'}
library("iBreakDown")
library("randomForest")
library("gbm")
library("e1071")
library("rms")
library("DALEX")
set.seed(1)
#titanic_imputed <- archivist::aread("pbiecek/models/27e5c")
#titanic_lmr <- archivist::aread("pbiecek/models/58b24")
#titanic_rf <- archivist::aread("pbiecek/models/4e0fc")
#titanic_gbm <- archivist::aread("pbiecek/models/b7078")
#titanic_svm <- archivist::aread("pbiecek/models/9c27f")
#johnny_d <- archivist::aread("pbiecek/models/e3596")
explain_titanic_lmr <- DALEX::explain(model = titanic_lmr, data = titanic_imputed[, -9],
y = titanic$survived == "yes", label = "Logistic Regression", verbose = FALSE)
explain_titanic_lmr$model_info$type = "classification"
explain_titanic_rf <- DALEX::explain(model = titanic_rf, data = titanic_imputed[, -9],
y = titanic$survived == "yes", label = "Random Forest", verbose = FALSE)
explain_titanic_gbm <- DALEX::explain(model = titanic_gbm, data = titanic_imputed[, -9],
y = titanic$survived == "yes", label = "Generalized Boosted Regression", verbose = FALSE)
explain_titanic_svm <- DALEX::explain(model = titanic_svm, data = titanic_imputed[, -9],
y = titanic$survived == "yes", label = "Support Vector Machine", verbose = FALSE)
#load("models/models_titanic.rda")
#load("models/explain_rf.rda")
#explain_titanic_rf <- explain_rf
#load("models/johny_d.rda")
set.seed(1313)
sp_rf_johnny <- variable_attribution(explain_titanic_rf, johnny_d, type = "shap")
sp_gbm_johnny <- variable_attribution(explain_titanic_gbm, johnny_d, type = "shap")
sp_svm_johnny <- variable_attribution(explain_titanic_svm, johnny_d, type = "shap")
sp_lmr_johnny <- variable_attribution(explain_titanic_lmr, johnny_d, type = "shap")
library(patchwork)
scale_y <- scale_y_continuous("", limits = c(-0.25, 0.50))
(plot(sp_rf_johnny) + scale_y + theme_ema | plot(sp_gbm_johnny) + scale_y + theme_ema) /
(plot(sp_svm_johnny) + scale_y + theme_ema | plot(sp_lmr_johnny) + scale_y + theme_ema) +
plot_annotation(title = "Shapley values for Johnny D",
theme = theme_ema)
```
As mentioned in Chapter \@ref(shapley), Shapley values show additive contributions of explanatory variables to a model's predictions. However, the values may be misleading if there are interactions. In that case, iBD plots, discussed in Chapter \@ref(iBreakDown), might be more appropriate. Figure \@ref(fig:championChallengerBD) presents the plots for the four models under consideration.
For the SVM model, the most important variable is *gender*, while for the other models the most important variables are *age* and *class*. Remarkably, the iBD plot for the random forest model includes the interaction of *fare* and *class*.
(ref:championChallengerBDDesc) Interaction break-down plots for four different models for the Titanic data and Johnny D.
```{r championChallengerBD, warning=FALSE, message=FALSE, echo=FALSE, fig.width=9.5, fig.height=6.0, fig.cap='(ref:championChallengerBDDesc)', out.width = '100%', fig.align='center'}
set.seed(1)
bd_rf_johnny <- variable_attribution(explain_titanic_rf, johnny_d, type = "break_down_interactions")
bd_gbm_johnny <- variable_attribution(explain_titanic_gbm, johnny_d, type = "break_down_interactions")
bd_svm_johnny <- variable_attribution(explain_titanic_svm, johnny_d, type = "break_down_interactions")
bd_lmr_johnny <- variable_attribution(explain_titanic_lmr, johnny_d, type = "break_down_interactions")
library(patchwork)
scale_y <- scale_y_continuous("", limits = c(0.2,1))
(plot(bd_rf_johnny) + scale_y + ggtitle("","") + theme_ema | plot(bd_gbm_johnny) + scale_y + ggtitle("","") + theme_ema) /
(plot(bd_svm_johnny) + scale_y + ggtitle("","") + theme_ema | plot(bd_lmr_johnny) + scale_y + ggtitle("","") + theme_ema) +
plot_annotation(title = "Interaction break-down plots for Johnny D",
theme = theme_ema)
```
Figure \@ref(fig:championChallengerCP) shows CP profiles for *age* and *fare* and the four compared models. For *fare*, the logistic regression and SVM models show little effect. A similar conclusion can be drawn for the boosting model, though for this model the profile shows considerable oscillations. The profile for the random forest model suggests a decrease in the predicted probability of survival when the ticket fare increases over about 37 pounds.
For *age*, the CP profile for the SVM model shows, again, considerable oscillations. For all the models, however, the effect of the variable is substantial, with the predicted probability of survival decreasing with increasing age. The effect is most pronounced for the logistic regression model.
(ref:championChallengerCPDesc) Ceteris-paribus plots for variables *age* and *fare* for four different models for the Titanic data and passenger Johnny D.
```{r championChallengerCP, warning=FALSE, message=FALSE, echo=FALSE, fig.width=8, fig.height=5.5, fig.cap='(ref:championChallengerCPDesc)', out.width = '90%', fig.align='center'}
splits <- list(age = seq(0,70,0.1), fare = seq(0,100,0.2))
cp_rf_johnny <- individual_profile(explain_titanic_rf, johnny_d,
variable_splits = splits)
cp_gbm_johnny <- individual_profile(explain_titanic_gbm, johnny_d,
variable_splits = splits)
cp_svm_johnny <- individual_profile(explain_titanic_svm, johnny_d,
variable_splits = splits)
cp_lmr_johnny <- individual_profile(explain_titanic_lmr, johnny_d,
variable_splits = splits)
plot(cp_rf_johnny, cp_gbm_johnny, cp_svm_johnny, cp_lmr_johnny, variables = c("age", "fare"),
color = "_label_") +
guides(col = guide_legend(nrow = 2)) + scale_color_discrete("Model:") +
ggtitle("Ceteris-paribus profiles for Johnny D","") + theme_ema
```
@twoCultures described a phenomenon called "Rashomon effect". It means that different models with a similar performance can base their predictions on completely different relations extracted from the same data.
This is the case with the four models presented in this chapter. Although they are all quite effective, for one particular observation, Johnny D, they give different predictions and different explanations.
Despite the differences, the explanations are very useful. For example, the CP profiles for the gradient boosting model exhibit high fluctuations (see Figure \@ref(fig:championChallengerCP)). Such fluctuations suggest overfitting, so one might be inclined not to use this model. The CP profiles for *age*, presented in Figure \@ref(fig:championChallengerCP), indicate that the SVM model is rather inflexible in that it cannot capture the trend, seen for the remaining three models, that young passengers had a better chance of survival. This could be taken as an argument against the use of the SVM model.
The CP-profiles for the random forest-model are, in general, consistent with the logistic regression model (see Figure \@ref(fig:championChallengerCP)). However, box plots in Figure \@ref(fig:championChallengerSHAP) show that explanatory-variable attributions for the random forest model are highly variable. This indicates the presence of interactions in the model. However, for a model with interactions, the additive explanations for individual explanatory variables can be misleading.
Based on this analysis, we might conclude that the most recommendable of the four models is the logistic regression model with splines.
<!---
The compilation of the operating profile of the models side-by-side allows for a better understanding of the similarities and differences in the signals that these models have learned.
--->