Abstract
Counterfactual explanations have become a very popular interpretability tool to understand and explain how complex machine learning models make decisions for individual instances. Most of the research on counterfactual explainability focuses on tabular and image data and much less on models dealing with functional data. In this paper, a counterfactual analysis for functional data is addressed, in which the goal is to identify the samples of the dataset from which the counterfactual explanation is made of, as well as how they are combined so that the individual instance and its counterfactual are as close as possible. Our methodology can be used with different distance measures for multivariate functional data and is applicable to any score-based classifier. We illustrate our methodology using two different real-world datasets, one univariate and another multivariate.
Similar content being viewed by others
Avoid common mistakes on your manuscript.
1 Introduction
Machine learning models are increasingly being used for high stakes decision-making settings such as healthcare, law or finance. Many of these machine learning models are black-boxes and therefore they do not explain how they arrive to decisions in a way that humans can understand. Nowadays, there is an increasing number of laws and regulations (Goodman and Flaxman 2017) coming into place to enforce the decisions of algorithms to be interpretable (a.k.a. transparent) (Du et al. 2019; Eiras-Franco et al. 2019; Fu et al. 2022; Miller 2019; Zhdanov et al. 2022). Interpretability is enhanced by selecting the features that have the greatest impact on the model as a whole (Benítez-Peña et al. 2021; Bertsimas et al. 2016; Zheng et al. 2021), but also knowing these locally for the decision made for each individual (Lundberg and Lee 2017; Lundberg et al. 2020; Ribeiro et al. 2016).
In this paper, we specifically address the problem of interpretability when data are functions. This type of data arises in important domains such as econometrics, energy, marketing (Jank and Shmueli 2006; Sood et al. 2009; Sunar and Swaminathan 2021). There is rather extensive literature on the use of machine learning to analyse functional data, e.g., adapting Support Vector Machine models to functional data (Blanquero et al. 2019; Chaovalitwongse et al. 2008), using regression trees to detect critical intervals (Blanquero et al. 2023) or novel forms of intepretability when dealing with functional data (Carrizosa et al. 2022; Martín-Barragán et al. 2014). See also Aneiros et al. (2022), Ramsay (2006) for an overview of methods for functional data analysis.
A specific type of interpretability tools is the counterfactual explanation (Carrizosa et al. 2023; Martens and Provost 2014; Wachter et al. 2017) where one seeks the minimum cost changes that can be made to an instance such that the given machine learning model would have classified it in a different class. For instance, in a credit score application one may be interested in knowing how the debt history of a person should have been to change the prediction to loan should be granted. See Guidotti (2022), Karimi et al. (2022), Verma et al. (2020) for recent surveys on Counterfactual Analysis.
Apart from the advantages mentioned above to finding counterfactuals for a given instance, in terms of guidance on how to change the predicted class to desired one, there are others to the stakeholder. First, it allows us to know how robust the prediction is, i.e., how much should the record be perturbed to make the classifier label it in a different class. Second, imposing some sort of sparsity in the process of building counterfactuals allow us to identify the most relevant features, i.e., those that, for this particular instance, are forcing the classifier to classify it in the desired class.
While the literature on machine learning to analyse functional data is extensive, this is not the case for counterfactual analysis. Most of the work on counterfactual explanations focuses on tabular, image data or text data (Karimi et al. 2022; Ramon et al. 2020; Tolkachev et al. 2022), and much less on functional data. In principle, one could apply the methods developed for tabular data also to functional data, just by considering that each feature is the measurement of the function at a time instant. However, doing so, fundamental information such as the autocorrelation structure along consecutive time instants would be lost. For this reason, some works on counterfactual explanations exploiting the functional nature of data have been suggested, e.g., Ates et al. (2021), Delaney et al. (2021), but, as far as the authors know, none of them uses the structure and properties of the machine learning model.Moreover, when working with functional data, other types of distance measures may appear, such as the Dynamic Time Warping distance (Xing et al. 2010), which, with our methodology, we can consider.
An instance \(\varvec{x} \in {\mathcal {X}} \subset {\mathcal {F}}^{J}\) is defined as a vector of J functional features. The counterfactual explanation \(\varvec{x}\in {\mathcal {X}}^{0} \subset {\mathcal {X}}\) of the instance \(\varvec{x}^0\) is a hypothetical instance generated by combining existing instances in the dataset, heareafter prototypes, so that the cost \(C(\varvec{x},\varvec{x}^0)\) of perturbing the features in \(\varvec{x}^0\) to yield \(\varvec{x}\) is minimal. With this, we achieve certain interpretability goals. First, we can deal with multivariate functional data, i.e., our data are functions taking values in some \({\mathbb {R}}^J.\) Second, we are able to identify the instances from the dataset that generate the counterfactual for each instance, controlling how sparse the counterfactual explanation is, in terms of both the number of prototypes used to create the counterfactual \(\varvec{x}\) and the number of functional features changed to move from \(\varvec{x}^0\) to \(\varvec{x}\). Third, we can model the cost function C by means of different distance measures, including popular distances in functional analysis such as the Dynamic Time Warping distance. We will show that, under mild assumptions, obtaining counterfactual explanations reduces to solving a Mixed Integer Convex Quadratic Model with linear constraints, which can be solved with standard optimization packages.
The remainder of the paper is organized as follows. In Sect. 2, we model the problem of finding counterfactual explanations when data are functions through an optimization problem. In Sect. 3, we focus on counterfactual analysis for additive tree models. In Sect. 4, a numerical illustration using real-world datasets is provided. Finally, conclusions and possible lines of future research are provided in Sect. 5.
2 Counterfactual analysis for functional data
In this section, we will detail the mathematical optimization formulation for generating counterfactual explanations when dealing with functional data. To do this we need to model the structure of the counterfactual instances, the constraints associated with them, as well as the cost function C. This will be done in what follows. We postpone to the next section the analysis of the case in which a state-of the-art score-based classifier, namely, an additive classification tree, is used as classifier.
Recall that an instance \(\varvec{x} \in {\mathcal {X}} \subset {\mathcal {F}}^{J}\) is defined as a vector of J functional features. Hence, \(\varvec{x}=(x_1(t),\dots ,x_J(t))\), where \(x_j:[0,T] \rightarrow {\mathbb {R}}\), \(j=1,\dots ,J\), are Riemann integrable functions defined in interval [0, T]. Notice that \(x_j(t)\) may be a static feature, e.g., birth date, defined then as a constant function. Note also that, for a given time instant \(t \in [0,T],\) \(\varvec{x}(t)\) is a vector in \({\mathbb {R}}^J\) components, which may represent J measurements of independent attributes, or they may be related, e.g., one can include an attribute \(x_j,\) some of its derivatives to provide information also on e.g., the growth speed or the convexity of function \(x_j.\)
As mentioned in the introduction, the construction of counterfactual solutions depends on the (multiclass) classifier used. Assuming a score-based classifier, we are given a function \(f:{\mathcal {X}} \subset {\mathcal {F}}^{J} \rightarrow \{1,\dots , K\}\) based on score functions \((f_1,\dots ,f_K)\), where K is the number of classes. Given an instance \(\varvec{x}^0 \in {\mathcal {X}}\), let \(f(\varvec{x}^0)\in \textrm{arg}\,\textrm{max}_k f_k(\varvec{x}^0)\) denote the class assigned by the classifier to \(\varvec{x}^0\). For a fixed class \(k^{*}\), the counterfactual instance of \(\varvec{x}^0\) is defined in this paper as the feasible \(\varvec{x}\) obtained with a minimal cost of perturbation of \(\varvec{x}^0\) and classified by the score-based classifier in class \(k^{*}\). This yields the following optimization problem:
The objective function \(C(\varvec{x},\varvec{x}^0)\) is a cost function that measures the dissimilarity between the given instance \(\varvec{x}^0\) and the counterfactual instance \(\varvec{x}\). In the feasible region, we have two types of constraints. In the first one, we ensure that the counterfactual \(\varvec{x}\) is classified in class \(k^{*}\) by imposing that the score \(f_{k^{*}}(\varvec{x})\) is the maximum across all k. In the second type of constraint, we ensure that the counterfactual is in \({\mathcal {X}}^{0} \subset {\mathcal {F}}^{J}\), the set defined through the actionability and plausibility constraints (Mohammadi et al. 2021; Wachter et al. 2017), i.e., constraints ensuring that a counterfactual does not change immovable features, and that guarantee that counterfactual explanations are realistic.
2.1 Counterfactual instances and constraints
Let us discuss the constraints on \(\varvec{x}\) in Problem (1). First, we need to ensure that the counterfactual explanation \(\varvec{x}\) is realistic. In the case of functional data, this yields an infinite-dimensional optimization problem. To enhance the tractability of this requirement, we propose the use of instances of the dataset, i.e., prototypes, to generate the counterfactual explanation. Let \(\varvec{x}^b\), \(b=1,\dots ,B\), be all the instances that have been classified by the model in class \(k^{*}\) and are close enough to \(\varvec{x}^0\) so that they can be seen as references for \(\varvec{x}^0\). For an instance \(\varvec{x}^0=(x_1^0,\dots ,x_J^0)\), feature j of the counterfactual explanation \(x_j\) is defined as the convex combination of the original feature \(x_j^0\) and the feature j of all B prototypes \(x_j^b\). Thus, the counterfactual explanation \(\varvec{x}\) is defined for each feature j as \(x_j=\alpha _{0j} x^0 +\sum _{b=1}^B \alpha ^b_j x_j^b\), where \(\sum _{b=0}^B \alpha ^b_j=1, \quad \forall j=1,\dots ,J\).
In order to gain interpretability of the so obtained counterfactual explanation \(\varvec{x}\), we want to use as few prototypes \(\varvec{x}^b\) as possible in the construction of \(\varvec{x}\). For this reason we will impose a maximum of \(B^{\textrm{max}}\) prototypes to be used, where \(B^{\textrm{max}}\) is a parameter defined by the user.
In \({\mathcal {X}}^0\) we may also impose the unmovable constraints or other constraints like upper or lower limits on the static variables.
2.2 Cost function
Recall that \(C(\varvec{x},\varvec{x}^0)\) is the cost of changing \(\varvec{x}^0\) to \(\varvec{x}\), which can be measured by the proximity between the curves defining \(\varvec{x}\) and \(\varvec{x}^0\).
The proximity between curves can be measured in several ways. One can use for instance the squared Euclidean distance:
Needless to say, different weights can be assigned to each feature in the expression above.
Another popular distance used in the literature (Esling and Agon 2012; Xing et al. 2010) is the Dynamic Time Warping (DTW) distance, which measures the dissimilarity between two functions that may be inspected at different speed, see Fig. 1. More explicitly, suppose we have \(\varvec{x}\) and \(\varvec{x}'\), discretised in two sequences of length n, so that the J-variate functions \(\varvec{x}\) and \(\varvec{x}'\) are replaced by \((\varvec{x}(t_1),\ldots ,\varvec{x}(t_n))\) and \((\varvec{x}'(t_1),\ldots ,\varvec{x}'(t_n)).\) Observe that each \(\varvec{x}(t), \varvec{x}'(t)\) are vectors in \({\mathbb {R}}^J.\) A warping path \(\pi\) is a chain of pairs of the form \(\pi =(q_{11},q_{21}) \rightarrow (q_{12},q_{22}) \rightarrow \ldots \rightarrow (q_{1Q},q_{2Q})\) of length Q, \(n \le Q \le 2n-1,\) satisfying the following two conditions:
-
1.
\((q_{11},q_{21}) =(t_1,t_1),\) and \((q_{1Q},q_{2Q}) =(t_n,t_n)\)
-
2.
\(q_{1r} \le q_{1 (r+1)} \le q_{1r}+1,\) and \(q_{2r} \le q_{2 (r+1)} \le q_{2r}+1,\) \(r=1,2,\ldots ,Q-1\)
Let \({\mathcal {W}}\) denote the set of all warping paths. Then, the DTW distance \(\text {DTW}(\varvec{x},\varvec{x}')\) between \(\varvec{x}\) and \(\varvec{x}'\) is the minimal squared Euclidean distance between pairs of the form \((\varvec{x}(q_{11}),\ldots ,\varvec{x}(q_{1Q}))\) and \((\varvec{x}'(q_{21}),\ldots , \varvec{x}'(q_{2Q}))\) when \((q_{11},q_{21}) \rightarrow (q_{12},q_{22}) \rightarrow \ldots \rightarrow (q_{1Q},q_{2Q})\) is a warping path, i.e.,
Observe that DTW can be efficiently evaluated using dynamic programming (Berndt and Clifford 1994).
Additionally, C may contain, on top of the distance-based term described above, other terms measuring, e.g., the number of features altered when moving from \(\varvec{x}^0\) to \(\varvec{x}\). In particular, in Sect. 3 we will discuss in detail the cases
and
where \(\Vert \varvec{x}^0-\varvec{x}\Vert _0\) indicates how many components of \(\varvec{x}^0 = (x^0_1,\ldots ,x^0_J)\) and \(\varvec{x} = (x_1,\ldots ,x_J)\) are not equal,
and \(\lambda _0,\lambda _2 \ge 0,\) not simultaneously 0.
3 Additive tree models
Problem (1) under the modelling assumptions in Sect. 2 can be addressed for several score-based classifiers. These include, among others, additive tree models (ATM) such as Random Forest (Breiman 2001) or XGBoost models (Chen and Guestrin 2016), as well as linear models such as logistic regression and linear support vector machines. Below, we focus on ATM, and extend to functional data the analysis for tabular data described in (Carrizosa et al. 2021).
The ATM is composed of T classification trees. Each tree t has a series of branching nodes s, each having associated a feature v(s), a time instant \(t_s,\) and a threshold value \(c_s,\) so that records \(\varvec{x}\) go through the left or the right of the branching node depending on whether \(x_{v(s)}(t_s)\le c_s\) or not. Moreover, the tree t has associated a weight \(w^t \ge 0,\) so that the class predicted for an instance \(\varvec{x}\) is the most voted class according to the weights \(w^t\). The ATM can be viewed as a score-based classifier by associating to class k the score \(f_k\) defined as:
where \({\mathcal {T}}_k(\varvec{x})\) denotes the subset of trees that classify \(\varvec{x}\) in class k.
To model Problem (1) for functional data and additive tree models, the parameters and decision variables in Fig. 2 will be used.
Recall that the ATM is already known, i.e., the whole structure, including the topology of the trees and the feature and threshold used in each split, is given. Thus, in order to compute the score of the counterfactual instance, the only requirement is to know in which leaf node it has ended up. When we end up in a specific leaf, the corresponding branching conditions are activated. For each split \(s\in \text {Left}(l,t)\) if the condition is true, then \(x_{v(s)}(t_s)\le c_s\), otherwise \(x_{v(s)}(t_s) >c_s\). To introduce these logical conditions, we use the following big M constraints:
Due to the impossibility of the Mixed-Integer Optimization solvers to model a strict inequality, a small positive quantity \(\epsilon\) is introduced in Eqs. (8) and (9), as is done in Bertsimas and Dunn (2017). With this, our counterfactual variable \(x_{v(s)}\) at point \(t_s\) is not allowed to take values around the threshold value in \(c_s\) at the split s. Please note that the value of \(M_1\) and \(M_2\) can be tightened for each split.
The score function in (7) can be rewritten as a linear expression as follows:
for \(k=1,\dots ,K\).
Recall that one type of sparsity that we wanted was to use few prototypes to build our counterfactual explanation. To model this, we introduce binary decision variables \(u_b\), which control the number of prototypes that can be used in the convex combination yielding \(\varvec{x}\) through parameter \(B^{\textrm{max}}\).
Given instance \(\varvec{x}^0\) and a cost function C, the formulation associated with Problem (1), the problem of finding the minimal cost perturbation that causes the classifier to classify it in class \(k^{*}\) is as follows:
The cost function in (10) is discussed in more detail below, where we measure the movement from the original instance \(\varvec{x}^0\) to its counterfactual explanation \(\varvec{x}\) for functional data. Constraints (11) and (12) control to which leaf the counterfactual instance is assigned and constraint (13) enforces that only one leaf is active for each tree. Constraint (14) ensures that the counterfactual instance is assigned to class \(k^{*}\), i.e., the score of class \(k^{*}\) is the highest one among all classes. Constraints (15) and (16) define for each feature j the counterfactual instance as the convex combination of \(x^0_j\) and the prototypes \(x_j^b\). To ensure sparsity in the prototypes, constraints (17)–(18) restrict the number of prototypes used in the convex combination to \(B^{\textrm{max}}\). Constraints (19) and (20) ensure that all \(u_b\) and \(z_l^t\) are binary, constraint (21) that the coefficients \(\alpha ^b_j\) are nonnegative and constraint (22) that the counterfactual \(\varvec{x}\) is in \({\mathcal {X}}^{0}\), the set containing the rest of the actionability and plausibility constraints. An overview of all the constraints is detailed in Fig. 3.
Let us now discuss the objective function in (10) for the particular choices of C introduced in Sect. 2, namely, (4) and (5). In order to model the \(\ell _0\) term defined in (6), binary decision variables \(\xi _j\) are introduced. For every feature \(j=1,\ldots ,J\), \(\xi _j=0\) if and only if \(\alpha _{0j}=1\), i.e., if \(x_j=x_j^0\). This is expressed as
Moreover, we have that
Thus, for the cost function C in (4), we have the following reformulation of (10)–(22):
For the particular case of (CEF) where only the \(\ell _0\) distance is considered, i.e., \(\lambda _2=0\), the objective function as well as the constraints are linear, (assuming \({\mathcal {X}}^0\) is also defined through linear constraints), while we have both binary and continuous decision variables. Therefore, Problem (CEF) can be solved using a Mixed Integer Linear Programming (MILP) solver. For arbitrary \(\lambda _2\ge 0\), taking into account that, by (15),
the second term in the objective can be expressed as a convex quadratic function in the decision variables \(\alpha ^b_j,\) and thus (again, assuming \({\mathcal {X}}^0\) is also defined through linear constraints) Problem (CEF) is a Mixed Integer Convex Quadratic Model with linear constraints.
Let us address Problem (1) when the cost function C has the form (5), and thus the DTW distance is involved. As in Sect. 2, the time interval [0, T] is discretised in time instants \(t_1,\ldots ,t_n,\) and thus the DTW distance is the minimal squared Euclidean distance among the warping paths W, yielding
Notice how for a fixed warping path in \({\mathcal {W}}\), constraints (11)–(24) are all linear, while we have both binary and continuous variables. Hence, if \({\mathcal {X}}^0\) is again defined by linear constraints, since the objective function is quadratic, Problem (CEFDTW) is a Mixed Integer Convex Quadratic Model with linear constraints, that can be solved using standard optimization packages. For this reason we propose an alternating heuristic to solve Problem (CEFDTW):
4 Numerical illustration
We will illustrate our methodology in two real-world datasets with functional data, one univariate and another multivariate, from the UCR archive (Dau et al. 2019). For a given instance, we are able to identify the individuals of the dataset from which the corresponding counterfactual is made up and what their contribution is. Furthermore, we show the two different sparsities that we can obtain with our model, namely, the number of prototypes used for the counterfactual and the number of functional features that change. The use of different distances, i.e., the Euclidean and the DTW distances, is also displayed.
All the mathematical optimization problems have been implemented using Pyomo optimization modeling language (Hart et al. 2017, 2011) in Python 3.8. As solver, we have used Gurobi 9.0 (Gurobi Optimization 2021). A value of \(\epsilon =1\textrm{e}{-6}\) has been imposed in (11) and (12). The values of the big-M in (11) and (12) are node dependent, and they have been tightened following the process described in Carrizosa et al. (2021). For all the computational experiments, the classification model considered has been a Random Forest with \(T=200\) trees and a maximum depth of 4. Our experiments have been conducted on a PC, with an Intel R CoreTM i7-1065G7 CPU @ 1.30GHz 1.50 GHz processor and 16 gigabytes RAM. The operating system is 64 bits.
The first dataset, ItalyPowerDemand (Keogh et al. 2006), has one functional feature. There are 1096 instances and each instance is a time series of length 24, representing the power demand in Italy in six months. The binary classification task is to distinguish days from October to March (response value \(-1\)) from April to September (response value \(+1\)).
The second dataset, NATOPS (Ghouaiel et al. 2017), has 24 functional time series of length 51 representing the X, Y, and Z coordinates of the left and right hand, wrist, thumb and elbows as captured by a Kinect 2 sensor. There are 260 instances and we chose two classes of the 6 that there are in the dataset. The binary classification task is thus to distinguish the gesture “All Clear" (response value \(-1\)) from “Not Clear" (response value \(+1\)).
4.1 Experimental results
4.1.1 ItalyPowerDemand
We present the counterfactual for an instance \(\varvec{x}^0\) of the dataset ItalyPowerDemand in Fig. 4. In each case, we represent the original curve, the prototypes, and the final counterfactual.
The first cost model analysed is the squared Euclidean model (4) with \(\lambda _0=0\) (since we have only one feature, \(\lambda _0 > 0\) is meaningless). Different values of \(B^{\textrm{max}}\) have been used. The smaller the value of \(B^{\textrm{max}}\) is, the more sparse the counterfactual is in terms of prototypes, while the larger the value of \(B^{\textrm{max}}\) is, the higher the freedom to use prototypes and therefore the smaller the distances obtained. In Fig. 5a we plot the relation between the number of prototypes and the distance. It is illustrated how using more than one prototype may be beneficial, but using more than 4 prototypes gives us less sparsity without smaller distances.
To show the flexibility of our model, the same experiments have been carried out but changing the cost based on DTW distances (5), again with \(\lambda _0=0\). The counterfactual solutions have been calculated with the heuristic procedure described in Algorithm 1. The results are depicted in Fig. 6. As before, one can see how the objective function decreases as the number of prototypes \(B^{\textrm{max}}\) increases. However, in this case, it is sufficient to use 2 prototypes, as 3 or more will not improve much the objective function, see Fig. 5b.
4.1.2 NATOPS
We present now the counterfactual for an instance \(\varvec{x}^0\) of the multivariate dataset NATOPS. The cost function used has been of the form is the squared Euclidean model (4) with \(\lambda _0=1,\) \(\lambda _2= 0.005.\) As we are interested in detecting the critical functional features to flip the classifier’s decision, we give more weight in the cost function to the \(\ell _0\) as an illustration.
In Fig. 7 the counterfactual instance \(\varvec{x}\) for \(\varvec{x}^0\) for \(B^{\textrm{max}}=1\) is shown. As the cost function C contains as its first term the \(\ell _0\) norm, we obtain a sparse solution in the sense of the features we need to change to move from \(\varvec{x}^0\) to \(\varvec{x}\). Indeed, to change its class, only three functional features have to be modified. In Fig. 8 the changed features are presented.
As in the univariate case, we can impose different values of \(B^{\textrm{max}}\). In Fig. 9 we show the counterfactual explanation for \(B^{\textrm{max}}=2\) and for the same cost function. Note how giving the flexibility to use more than one prototype, results in only having to change two features, see Fig. 10.
5 Conclusions
In this paper, we have proposed a novel approach to build counterfactual explanations when dealing with multivariate functional data in classification problems by means of mathematical optimization. With our method, we ensure plausible and sparse explanations, controlling not only the number of prototypes of the dataset used to create the counterfactuals, but also the number of features that need to be changed. Our model is also flexible enough to be used with different distance measures, e.g., the Euclidean distance or the DTW distance. Moreover, our methodology is applicable to score-based classifiers, including additive tree models, such as random forest or XGBoost models, as well as linear models, such as logistic regression and linear support vector machines. We have illustrated our methodology on various real-world datasets.
There are several interesting lines of future research. First, an extension to other non score-based classifiers, like k-NN classifiers, deserve some study. Secondly, to define counterfactual explanations for functional data one could be interested in keeping fixed a part of the curves defining the features. With our method we build the counterfactuals from scratch using the combinations of prototypes in the interval [0, T], but suppose we have an instance defined in the interval \([0,t_0)\), and one might want to find out how the rest of the curve in the interval \([t_0,T]\) would have to be like to make the overall curve being classified in class \(k^*\). When constructing the rest of the curve, one would need to maintain the smoothness and other properties of the curve. Finally, the case in which other distance, such as the optimal transportation distance are used to measure closeness, is a topic of interest.
References
Aneiros G, Horová I, Hušková M, Vieu P (2022) On functional data analysis and related topics. J Multivar Anal 189:104861
Ates E, Aksar B, Leung VJ, Coskun AK (2021) Counterfactual explanations for multivariate time series. In: 2021 international conference on applied artificial intelligence (ICAPAI), pp 1–8. https://doi.org/10.1109/ICAPAI49758.2021.9462056
Benítez-Peña S, Carrizosa E, Guerrero V, Jiménez-Gamero M, MartínBarragán B, Molero-Río C, Ramírez-Cobo P, Romero Morales D, Sillero-Denamiel M (2021) On sparse ensemble methods: an application to short-term predictions of the evolution of COVID-19. Eur J Oper Res 295(2):648–663
Berndt DJ, Clifford J (1994) Using dynamic time warping to find patterns in time series. KDD Workshop 10:359–370
Bertsimas D, Dunn J (2017) Optimal classification trees. Mach Learn 106(7):1039–1082
Bertsimas D, King A, Mazumder R (2016) Best subset selection via a modern optimization lens. Ann Stat 44(2):813–852
Blanquero R, Carrizosa E, Jiménez-Cordero A, Martín-Barragán B (2019) Functional-bandwidth kernel for support vector machine with functional data: an alternating optimization algorithm. Eur J Oper Res 275(1):195–207
Blanquero R, Carrizosa E, Molero-Río C, Romero Morales D (2023) On optimal regression trees to detect critical intervals for multivariate functional data. Comput Oper Res 152:106152
Breiman L (2001) Random forests. Mach Learn 45(1):5–32
Carrizosa E, Kurishchenko K, Marín A, Romero Morales D (2022) Interpreting clusters by prototype optimization. Omega 107:102543
Carrizosa E, Ramírez Ayerbe J, Romero Morales D (2023) Mathematical optimization modelling for group counterfactual explanations (Tech. Rep.): IMUS, Sevilla, Spain. https://www.researchgate.net/publication/368958766_Mathematical_Optimization_Modelling_for_Group_Counterfactual_Explanations
Carrizosa E, Ramírez-Ayerbe J, Romero Morales D (2024) Generating collective counterfactual explanations in score-based classification via mathematical optimization. Expert Syst Appl 238:121954
Chaovalitwongse W, Fan Y, Sachdeo R (2008) Novel optimization models for abnormal brain activity classification. Oper Res 56:1450–1460
Chen T, Guestrin C (2016) XGBoost: A scalable tree boosting system. In: Proceedings of the 22nd ACM SIGKDD international conference on knowledge discovery and data mining. ACM, New York, pp 785–794. Retrieved from https://doi.org/10.1145/2939672.2939785
Dau HA, Bagnall A, Kamgar K, Yeh C-CM, Zhu Y, Gharghabi S, Ratanamahatana CA, Keogh E (2019) The UCR time series archive. IEEE/CAA J Autom Sin 6(6):1293–1305
Delaney E, Greene D, Keane MT (2021) Instance-based counterfactual explanations for time series classification. In: International conference on case-based reasoning, pp 32–47
Du M, Liu N, Hu X (2019) Techniques for interpretable machine learning. Commun ACM 63(1):68–77
Eiras-Franco C, Guijarro-Berdinas B, Alonso-Betanzos A, Bahamonde A (2019) A scalable decision-tree-based method to explain interactions in dyadic data. Decis Support Syst 127:113141
Esling P, Agon C (2012) Time-series data mining. ACM Comput Surv (CSUR) 45(1):1–34
Fu R, Aseri M, Singh P, Srinivasan K (2022) Un fair machine learning algorithms. Manage Sci 68(6):4173–4195
Ghouaiel N, Marteau P-F, Dupont M (2017) Continuous pattern detection and recognition in stream—a benchmark for online gesture recognition. Int J Appl Pattern Recogn 4(2):146–160
Goodman B, Flaxman S (2017) European Union regulations on algorithmic decision-making and a right to explanation. AI Mag 38(3):50–57
Guidotti R (2022) Counterfactual explanations and how to find them: literature review and benchmarking. Data Min Knowl Discov (forthcoming)
Gurobi Optimization L (2021) Gurobi optimizer reference manual. Retrieved from http://www.gurobi.com
Hart WE, Laird CD, Watson J-P, Woodruff DL, Hackebeil GA, Nicholson BL, Siirola JD (2017) Pyomo-optimization modeling in Python, vol 67, 2nd edn. Springer, New York
Hart WE, Watson J-P, Woodruff DL (2011) Pyomo: modeling and solving mathematical programs in Python. Math Program Comput 3(3):219–260
Jank W, Shmueli G (2006) Functional data analysis in electronic commerce research. Stat Sci 21(2):155–166
Karimi A-H, Barthe G, Schölkopf B, Valera I (2022) A survey of algorithmic recourse: contrastive explanations and consequential recommendations. ACM Comput Surv 55(5):1–29
Keogh E, Wei L, Xi X, Lonardi S, Shieh J, Sirowy S (2006) Intelligent icons: integrating lite-weight data mining and visualization into GUI operating systems. In: Sixth international conference on data mining (ICDM’06), pp 912–916
Lundberg S, Erion G, Chen H, DeGrave A, Prutkin J, Nair B, Katz R, Himmelfarb J, Bansal N, Lee S-I (2020) From local explanations to global understanding with explainable AI for trees. Nat Mach Intell 2(1):2522–5839
Lundberg SM, Lee S-I (2017) A unified approach to interpreting model predictions. In: Proceedings of the 31st international conference on neural information processing systems, pp 4768–4777
Martens D, Provost F (2014) Explaining data-driven document classifications. MIS Q 38(1):73–99
Martín-Barragán B, Lillo R, Romo J (2014) Interpretable support vector machines for functional data. Eur J Oper Res 232(1):146–155
Miller T (2019) Explanation in artificial intelligence: insights from the social sciences. Artif Intell 267:1–38
Mohammadi K, Karimi A-H, Barthe G, Valera I (2021) Scaling guarantees for nearest counterfactual explanations. In: Proceedings of the 2021 AAAI/ACM conference on AI, ethics, and society, pp 177–187
Ramon Y, Martens D, Provost F, Evgeniou T (2020) A comparison of instance-level counterfactual explanation algorithms for behavioral and textual data: SEDC, LIME-C and SHAP-C. Adv Data Anal Classif 14:801–819
Ramsay JO (2006) Functional data analysis. In: Encyclopedia of statistical sciences, vol 4. https://doi.org/10.1002/0471667196.ess3138
Ribeiro MT, Singh S, Guestrin C (2016) “Why should i trust you?” Explaining the predictions of any classifier. In: Proceedings of the 22nd ACM SIGKDD international conference on knowledge discovery and data mining, pp 1135–1144
Sood A, James GM, Tellis GJ (2009) Functional regression: a new model for predicting market penetration of new products. Mark Sci 28(1):36–51
Sunar N, Swaminathan JM (2021) Net-metered distributed renewable energy: a peril for utilities? Manag Sci 67(11):6716–6733
Tolkachev G, Mell S, Zdancewic S, Bastani O (2022) Counterfactual explanations for natural language interfaces. In: Proceedings of the 60th annual meeting of the association for computational linguistics, pp 113–118
Verma S, Dickerson J, Hines K (2020) Counterfactual explanations for machine learning: a review. arXiv preprint arXiv:2010.10596
Wachter S, Mittelstadt B, Russell C (2017) Counterfactual explanations without opening the black box: automated decisions and the GDPR. Harv JL Tech 31:841
Xing Z, Pei J, Keogh E (2010) A brief survey on sequence classification. ACM SIGKDD Explor Newsl 12(1):40–48
Zhdanov D, Bhattacharjee S, Bragin MA (2022) Incorporating FAT and privacy aware AI modeling approaches into business decision making frameworks. Decis Support Syst 155:113715
Zheng Z, Lv J, Lin W (2021) Nonsparse learning with latent variables. Oper Res 69(1):346–359
Acknowledgements
This research has been financed in part by research projects EC H2020 MSCA RISE NeEDS (Grant agreement ID: 822214), FQM-329, P18-FR2369 and US-1381178 (Junta de Andalucía), and PID2019-110886RB-I00 and PID2022-137818OB-I00 (Ministerio de Ciencia, Innovación y Universidades, Spain). This support is gratefully acknowledged.
Funding
Funding for open access publishing: Universidad de Sevilla/CBUA.
Author information
Authors and Affiliations
Corresponding author
Ethics declarations
Conflict of interest
The authors state that there are not financial conflicts of interest related to the paper and certify that they are complying with the journal’s ethical policies.
Additional information
Publisher's Note
Springer Nature remains neutral with regard to jurisdictional claims in published maps and institutional affiliations.
Rights and permissions
Open Access This article is licensed under a Creative Commons Attribution 4.0 International License, which permits use, sharing, adaptation, distribution and reproduction in any medium or format, as long as you give appropriate credit to the original author(s) and the source, provide a link to the Creative Commons licence, and indicate if changes were made. The images or other third party material in this article are included in the article's Creative Commons licence, unless indicated otherwise in a credit line to the material. If material is not included in the article's Creative Commons licence and your intended use is not permitted by statutory regulation or exceeds the permitted use, you will need to obtain permission directly from the copyright holder. To view a copy of this licence, visit http://creativecommons.org/licenses/by/4.0/.
About this article
Cite this article
Carrizosa, E., Ramírez-Ayerbe, J. & Romero Morales, D. A new model for counterfactual analysis for functional data. Adv Data Anal Classif 18, 981–1000 (2024). https://doi.org/10.1007/s11634-023-00563-5
Received:
Accepted:
Published:
Issue Date:
DOI: https://doi.org/10.1007/s11634-023-00563-5