# Quantum speed-up for unsupervised learning

- 5.6k Downloads
- 43 Citations

## Abstract

We show how the quantum paradigm can be used to speed up unsupervised learning algorithms. More precisely, we explain how it is possible to accelerate learning algorithms by quantizing some of their subroutines. Quantization refers to the process that partially or totally converts a classical algorithm to its quantum counterpart in order to improve performance. In particular, we give quantized versions of clustering via minimum spanning tree, divisive clustering and *k*-medians that are faster than their classical analogues. We also describe a distributed version of *k*-medians that allows the participants to save on the global communication cost of the protocol compared to the classical version. Finally, we design quantum algorithms for the construction of a neighbourhood graph, outlier detection as well as smart initialization of the cluster centres.

## Keywords

Unsupervised learning Clustering Quantum learning Quantum information processing Grover’s algorithm## 1 Introduction

Consider the following scenario, which illustrates a highly challenging clustering task. Imagine that you are an employee of the Department of Statistics of the United Nations. Your boss gives you the demographic data of all the Earth inhabitants and asks you to analyse this data with a clustering algorithm in the hope that you might detect interesting trends and groups within this population. Seeing that you seem a bit lost in front of such a big amount of data, he tells you that he was able to “borrow” a fully operational full-scale quantum computer from the National Security Agency. Can this quantum computer help you speed up the clustering process?

Unsupervised learning algorithms are frequently used in *Data Mining* (Witten and Frank 2005) for applications in which the size of the dataset is huge, such as astronomy, bioinformatics or data issued from large-scale networks such as the Internet. For this type of applications, having fast and efficient algorithms is a necessity, and sometimes having a polynomial-time algorithm is not enough to be considered efficient. For instance, even a quadratic-time algorithm can be totally useless in practice on a billion entries, which illustrates the importance of developing algorithms that are as efficient as possible. In particular, we shall see in this paper that the paradigm of quantum computing can be used to speed up several classical unsupervised learning algorithms.

Learning algorithms based on quantum primitives have already been developed in supervised (Anguita et al. 2003; Ezhov and Berman 2003) and reinforcement learning (Dong et al. 2005). However, not much work has been done yet concerning unsupervised learning, with the exception of a quantum algorithm for the minimal spanning tree (Dürr et al. 2004), which can also be used to perform clustering although this was not these authors’ intention. See also Li et al. (2009, 2011) and Yu et al. (2010). Almost all the quantum algorithms described in this paper are based on variants of Grover’s algorithm (Grover 1997). Our quantum versions of clustering algorithms offer a speed-up compared to their classical counterparts, but do not improve the quality of the resulting clustering process. In particular, if finding the optimal solution for a particular clustering problem is NP-hard (Garey and Johnson 1979), it is generally believed that quantum computers would also be unable to solve the problem exactly in polynomial time (Bennett et al. 1997).

The outline of this paper is as follows. First, Sect. 2 provides an overview of quantum information processing, in particular of Grover’s algorithm and its variants. Some of these variants are further detailed because they are used as subroutines in our learning algorithms. Afterwards, Sect. 3 describes the black-box model adapted for the clustering context. The quantized versions of the clustering algorithms based on the minimum spanning tree, on divisive clustering and *k*-medians (standard and distributed versions) are detailed in Sects. 4, 5 and 6, respectively. Then, Sect. 7 describes a set of algorithms that can be used as tools during the preprocessing steps of other unsupervised learning algorithms: construction of a neighbourhood graph, detection of outliers and initialization of the cluster centres. Finally, Sect. 8 concludes this paper by a discussion and some perspectives on future extensions, such as a quantum version of ISOMAP, an algorithm for dimensionality reduction.

This paper is a thoroughly polished version of our earlier work (Aïmeur et al. 2007), which it extends in two important directions. First, in addition to speeding up the classical *k*-medians algorithm in Sect. 6.1, we demonstrate in Sect. 6.2 that quantum information can be used to reduce the amount of *communication* required to implement this algorithm in a distributed setting. Second, we have shown how to speed up classical algorithms for outlier detection (Sect. 7.2) and the “smart” initialization of cluster centres (Sect. 7.3).

## 2 Quantum information processing

In this section, we briefly review the notions of quantum information processing that are relevant to understanding our quantum versions of unsupervised learning algorithms. A detailed account of the field can be found in the book of Nielsen and Chuang (2000).

### 2.1 Basic notions of quantum information processing

A *qubit* (or *quantum bit*) is the quantum analogue of the classical bit. In contrast with its classical counterpart, a qubit can exist in a *superposition* of states. For instance, an electron can be *simultaneously* on two different orbits of the same atom, which could represent classical bits 0 and 1, respectively. Formally, a qubit is represented as a unit vector in a two-dimensional Hilbert space. Using the Dirac notation, a qubit is described as |*ψ*〉=*α*|0〉+*β*|1〉, where *α* and *β* are complex numbers called the *amplitudes* of classical states |0〉 and |1〉, respectively, subject to the *normalization condition* that |*α*|^{2}+|*β*|^{2}=1. When the state |*ψ*〉 is measured, either |0〉 or |1〉 is observed, with probability |*α*|^{2} or |*β*|^{2}, respectively. Furthermore, measurements are *irreversible* because the state of the system *collapses* to whichever value (|0〉 or |1〉) has been observed, thus losing all memory of former amplitudes *α* and *β*. The notion of qubit has a natural extension, which is the *quantum register*. A quantum register |*ψ*〉, composed of *n* qubits, lives in a 2^{ n }-dimensional Hilbert space. Register \(|\psi\rangle = \sum_{i=0}^{2^{n}-1} \alpha_{i}|i\rangle \) is specified by complex amplitudes \(\alpha_{0},\alpha_{1}, \ldots, \alpha_{2^{n}-1}\) subject to normalization condition ∑|*α* _{ i }|^{2}=1. Here, basis state |*i*〉 denotes the *n*-bit binary encoding of integer *i*. A quantum state such as \(\frac{1}{\sqrt{2}} |01\rangle - \frac{1}{\sqrt {2}} |10\rangle \) is *entangled* if it cannot be described by the state of its individual qubits.

*unitary*operations on the Hilbert space in which our qubits live. They are represented by

*gates*, much as in a classical circuit. For instance, the

*Walsh–Hadamard*gate H maps |0〉 to \({\frac{1}{\sqrt{2}}} |0\rangle + {\frac{1}{\sqrt{2}}} |1\rangle \) and |1〉 to \({\frac{1}{\sqrt{2}}} |0\rangle - {\frac{1}{\sqrt{2}}} |1\rangle \). As an elementary example, consider the circuit shown in Fig. 1, where the single wires carry quantum information while the double wire holds classical information. In this example, we apply a Walsh–Hadamard gate to state |0〉, which yields \({\frac{1}{\sqrt{2}}} |0\rangle + {\frac{1}{\sqrt{2}}} |1\rangle \), and then measure the quantum state. The subsequent measurement produces either 0 or 1, each with probability \(|{\frac{1}{\sqrt{2}}}|^{2}=\frac{1}{2}\), and the state collapses to the observed classical value. This circuit acts as a perfect random bit generator.

*f*that can be computed by a classical circuit of size

*k*can be computed by a quantum circuit C of size approximately 2

*k*, which implements unitary operation

*U*

_{ f }. Because unitary operations must be reversible, we cannot in general simply go from |

*i*〉 to |

*f*(

*i*)〉. Instead, we must map |

*i*,

*b*〉 to |

*i*,

*b*+

*f*(

*i*)〉, as illustrated in Fig. 2, where the addition is performed in an appropriate finite group and the second input is a quantum register of sufficient size to hold the output. It suffices to set

*b*to zero at the input of the circuit in order to obtain

*f*(

*i*).

This quantum circuit can then be applied to a superposition of different inputs: *U* _{ f }(∑_{ i } *α* _{ i }|*i*〉|0〉)=∑_{ i } *α* _{ i }|*i*〉|*f*(*i*)〉. This gives rise to a potentially exponential amount of parallelism, which has no classical counterpart. Amongst the most celebrated results, Shor (1997) has developed quantum algorithms for integer factorization and the computation of discrete logarithms, two problems of major importance in the field of cryptography. Another famous algorithm, due to Grover (1997), offers a quadratic speed-up in unstructured search problems. Grover’s algorithm was analysed formally and generalized by Boyer et al. (1998). Several extensions of this algorithm are used in this paper as described below.

### 2.2 Grover’s algorithm and its variants

In the original version of Grover’s (1997) algorithm, a Boolean function *f* is given as a black box with the additional promise that there is a unique *x* _{0} such that *f*(*x* _{0})=1. Classically, finding this *x* _{0}, when the function *f* displays no particular structure, requires on average approximately \(\frac{n}{2}\) queries to this black box, for *n* the number of points in the domain of *f*. Grover’s algorithm solves the same problem with approximatively \(\sqrt{n}\) queries to the black box, but those are made in quantum superposition of classical states.

^{1}Afterwards, the algorithm proceeds by repeating an adequate number of times

*Grover’s iteration*, which consists in two steps: a call to the quantum circuit shown in Fig. 3 inverts the phase of the

*target state*, which is the unknown state |

*x*〉 such that

*f*(

*x*)=1, and an

*inversion around the average*swings the amplitude of each state at the same distance but on the other side of the average amplitude of all states. It will be crucial in Sect. 6.2 that only the first of these two steps depends on the function

*f*under consideration. One application of Grover’s iteration has for effect to increase slightly the amplitude of the target state, while decreasing the amplitudes of the other states. After approximately \(\frac{\pi}{4}\sqrt {n}\) iterations (Boyer et al. 1998), the amplitude of the target state will have risen very close to 1. Therefore, if the register is measured at that precise moment, the target state will be observed with quasi-certainty. This results in an \(O(\sqrt{n}\,)\) computational time.

Starting from the original idea of Grover, several generalizations of his algorithm have been developed for the cases in which there are more than one *x* such that *f*(*x*)=1. For any known number *t*>0 of solutions, the application of approximately \(\frac{\pi }{4}\sqrt{n/t}\) Grover iterations is sufficient to find one of these solutions with high probability (Boyer et al. 1998) or even with certainty if the Grover iterations are modified very slightly, according to Theorem 4 of Brassard et al. (2002). If the number of solutions *t* is unknown, Boyer et al. (1998) show that it is nevertheless possible to find one of the solutions among the *t* possible ones in \(O(\sqrt{n/t}\,)\) expected time. Moreover, extensions to Grover’s algorithm exist that can be used to *count* (exactly or approximately) the number of solutions (Brassard et al., 1998, 2002).

Other applications of Grover’s algorithm find the minimum (or maximum) of a function (and its position) (Dürr and Høyer 1996) or the *c* smallest (or highest) values of its image (Dürr et al. 2004) after \(\varTheta(\sqrt{n}\,)\) and \(\varTheta(\sqrt {cn}\,)\) calls to the function, respectively. Other variants can be used to approximate the median of a set of values or statistics that are related to it (Nayak and Wu 1999) with a quadratic speed-up compared to the best possible classical algorithm. Finally, the generalization of Grover’s algorithm known as *amplitude amplification* (Brassard and Høyer 1997; Brassard et al. 2002) can accelerate many classical probabilistic algorithms by a quadratic factor in terms of the number of queries asked to the black box.

## 3 Quantization of clustering algorithms

*Quantization* refers to the process that partially or totally converts a classical algorithm to a quantum algorithm in order to improve its performance. In this section, we detail a model and tools that can be used to quantize unsupervised learning algorithms, among which specifically clustering algorithms. Although related, the task of quantizing a clustering algorithm should not be confused with the design of classical algorithms inspired from quantum mechanics (Horn and Gottlieb, 2001, 2002) or the task of performing clustering directly on quantum information (Aïmeur et al. 2006).

### 3.1 Black-box model

Traditionally in clustering, we consider a training dataset composed of *n* datapoints denoted by *D* _{ n }={*x* _{1},…,*x* _{ n }}, where each datapoint *x* _{ i } corresponds to a vector of *d* attributes. The goal of a clustering algorithm is to partition *D* _{ n } into subsets of points called *clusters*, such that the objects that are similar are grouped within the same cluster (*intra-similarity*) whereas dissimilar objects are placed in different clusters (*inter-dissimilarity*). One usual assumption is that there exists a notion of *distance* (or a *dissimilarity measure*) that can be evaluated to compare each pair of points. This distance is used by the algorithm to drive the formation of the clusters.

The model considered in most of this paper differs from this traditional machine learning framework and corresponds rather to the *black-box model*. In this model, our knowledge of the dataset comes uniquely from a black box (sometimes called *oracle*) that can be queried to learn the distance between two points. No assumptions are made *a priori* concerning the properties of this distance except that it is non-negative and that *Dist*(*x* _{ i },*x* _{ i })=0 for all *i*. In particular, the triangle inequality need not hold and the distance may not be symmetric.^{2} Throughout this paper, we shall nevertheless assume for simplicity that the distance function is symmetric, but most of our algorithms can be adapted *mutatis mutandis* without modifying their computational time significantly if this is not the case. This black-box model is generally used to derive lower bounds for problems for which it is difficult to prove such bounds in a more general context. Note that in this model, the complexity of an algorithm is measured in terms of the numbers of queries to the oracle, which constitutes a lower bound on the computational complexity of this problem. For simplicity, we shall henceforth refer to this number of queries as “time”.

This black-box model is comparable to the one introduced by Angluin (1988) in classical computational learning theory, which is used to study the complexity of learning exactly a function given as a black box. A quantum analogue of Angluin’s model has been defined by Servedio (2001). The main difference is that our goal is to perform clustering and not to learn exactly a function computed by an oracle. To the best of our knowledge, the complexity of clustering in Angluin’s model has not been studied before, whether it be in the classical or the quantum version. However, a similar problem was considered in the classical variant of the PAC setting (*Probably Approximately Correct*) of Valiant (1984), in which the goal was to characterize the time needed to learn a specific clustering (in the PAC sense of the term) among a class of possible clusterings (Mishra et al. 2001).

*x*

_{ i }and

*x*

_{ j }by giving as inputs the indexes

*i*and

*j*of these two points. The corresponding quantum black box is illustrated in Fig. 4, where O stands for “oracle”. In order to obey the principles of quantum mechanics, O must be unitary (and therefore reversible). In practice, this is not really a restriction as it is always possible to transform any classical irreversible circuit into a reversible one for a “reasonable” cost (Bennett 1973). Therefore, it is enough to specify the description of the classical irreversible circuit implementing the oracle in order to be able to convert it into a reversible circuit before implementing it quantum mechanically (at least in principle).

If the black box is quantum-mechanical, it can be interrogated in a superposition of inputs. For instance, if the input qubits are initially in state |0〉 and a Walsh–Hadamard gate is applied on each of these qubits (with the exception of the ancillary register, which is left unchanged to |0〉), the input will be transformed to an equal superposition of all the pairs of indexes of datapoints. In this specific situation, interrogating the oracle will result in a superposition of all the possible triplets |*i*,*j*,*Dist*(*x* _{ i },*x* _{ j })〉.

The assumption that a particular clustering problem is given as a black box is not realistic in practice, even though it is the usual paradigm considered in quantum information processing as well as in Angluin’s model. However, Giovannetti et al. (2008) have designed general quantum random access memory (QRAM) architectures, which can be used to construct explicitly and efficiently a quantum circuit playing the role of the oracle.

### 3.2 Quantum subroutines

This section describes three quantum subroutines used to speed up classical clustering algorithms. All these subroutines are based on variations of Grover’s algorithm. In particular, the first two are direct applications of previous work of Dürr and Høyer (1996) and Dürr et al. (2004), respectively. The third subroutine is a novel, albeit simple, application of Grover’s algorithm.

*diameter*). A similar algorithm can be used to identify the datapoint that is the farthest from a specific point.

*d*

_{ max }to zero. By using the circuit realizing the phase flip described in Figs. 5 and 6, Grover’s algorithm attempts to find a new pair of points (

*i*,

*j*), if it exists, such that

*Dist*(

*x*

_{ i },

*x*

_{ j })>

*d*

_{ max }. If such a pair is not found, the algorithm terminates. Otherwise, the value of the distance

*d*

_{ max }is updated to

*Dist*(

*x*

_{ i },

*x*

_{ j }) and the process is repeated until the algorithm converges to the diameter with high probability.

### Theorem 1

(Convergence of quant_find_max)

*With high probability*, *algorithm* quant_find_max * returns the indexes* *i* *and* *j* *of the farthest pair of points in* \(O(\sqrt{p}\,)=O(n)\) *expected time*, *where* *p*=*n* ^{2} *is the number of pairs in the dataset*. *In the simpler case*, *in which we are interested in retrieving the farthest point from a specific point*, *the corresponding algorithm takes* \(O(\sqrt{n}\,)\) *expected time*.

### Proof

The convergence proof of quant_find_max is similar to the analysis of Dürr and Høyer (1996) for their algorithm for finding the minimum of a function. □

Dürr et al. (2004) have developed an algorithm for finding the *c* smallest values of a function with high probability within \(O(\sqrt{cn}\,)\) time, for *n* the number of datapoints in the domain of the function. If we set this function to be the distance between a fixed point and all the other points, we obtain the second subroutine quant_find_smallest_values, which is a direct application of the algorithm of Dürr et al. (2004) adapted for finding the *c* closest neighbours of a point.

### Theorem 2

(Convergence of quant_find_smallest_values (Dürr et al. 2004))

*With high probability*, *algorithm* quant_find_smallest_values * finds the* *c* *closest neighbours of a point in* \(O(\sqrt{cn}\,)\) *time*.

Note that this algorithm for finding the *c* smallest values is more efficient, albeit more complicated, than simply applying the algorithm for finding the minimum *c* times, which would have taken \(O(c\sqrt{n}\,)\) time instead of \(O(\sqrt{cn}\,)\).

The third and last subroutine is a new algorithm, coined quant_find_median, which computes the median within an ensemble of *n* points *D* _{ n }={*x* _{1},…,*x* _{ n }}.

### Definition 1

(Median)

*median*of a set of points

*D*is one whose sum of distances with all the other points is minimal (ties are broken arbitrarily): it is an

*x*∈

*D*such that

*z*∈

*D*. In the case of multidimensional points, the term

*medoid*is sometimes used instead of the term median.

Finding the median can be realized classically by computing, for each point in the ensemble, the sum of its distances with all the other points and by taking the minimum. This process requires *O*(*n* ^{2}) time, where *n* is the number of points considered. In the generic case, where there are no properties of the distance to be used or no structure within the ensemble of points that can be exploited, this naïve solution is the most efficient possible. Indeed, consider a scenario in which all the points are at the same distance from one another, with the exception of two points that are closer to one another. These two points are the medians of this ensemble of points. Classically, it will be necessary to ask almost all the distances between pairs of points to the black box before it is possible to identify one of these two medians. This results in a lower bound of *Ω*(*n* ^{2}) time.

When all the *x* _{ i } correspond simply to numbers, or more generally when all the points are colinear, the quantum algorithm of Nayak and Wu (1999) can be used to approximate the median in \(\varTheta (\sqrt{n}\,)\) time. However in the more generic case considered in this paper, our goal is to compute the median by using as sole information the distance between each pair of points, which corresponds to a situation for which the algorithm of Nayak and Wu does not apply.

*i*〉 as input, with 1⩽

*i*⩽

*n*, and computes the sum of distances between

*x*

_{ i }and all the other points in

*D*

_{ n }. This can be achieved in

*O*(

*n*) time by simply applying the black box described in Fig. 4 successively for each value of

*j*, 1⩽

*j*⩽

*n*(recall that

*Dist*(

*x*

_{ i },

*x*

_{ i })=0). A more efficient but approximate solution to this problem has recently been proposed by Brassard et al. (2011). We leave it for further research to determine the impact (or not) of this approach on clustering because it is not obvious to determine how detrimental to the

*quality*of the resulting clustering would this use of

*approximate*medians be.

Afterwards, the algorithm of Dürr and Høyer (1996) can be used to identify the minimal sum for all the possible *x* _{ i } by using \(\varTheta(\sqrt{n}\,)\) applications of the circuit of Fig. 7.

### Lemma 1

(Convergence of quant_find_median)

*With high probability*, *algorithm* quant_find_median * finds the median among a set of* *n* *points in* *O*(*n* ^{3/2}) *time*.

### Proof

Each application of the circuit illustrated in Fig. 7 takes *O*(*n*) time and finding the minimal sum among the *n* possible ones requires \(O(\sqrt {n}\,)\) applications of the circuit by using the quantum algorithm for finding the minimum (Dürr and Høyer 1996). Therefore, the algorithm requires \(O(n\sqrt{n}\,)=O(n^{3/2})\) time to compute the median. □

## 4 Clustering via minimum spanning tree

Let *G*=〈*V*,*E*〉 be a connected undirected graph for which *V* is the set of *n* vertices and *E* is the set of edges. Each edge has a *weight*, which is a positive real value.

### Definition 2

(Spanning tree)

A *spanning tree* is a subset of *n*−1 edges *T*⊆*E* such that 〈*V*,*T*〉 constitutes a connected graph.

### Definition 3

(Minimum spanning tree)

A *minimum spanning tree* is a spanning tree for which the total sum of the weights of the edges is minimum among all the possible spanning trees.

One of the oldest techniques for performing clustering (Zahn 1971) is directly based on the minimum spanning tree. Consider for instance that each datapoint *x* _{ i } of the dataset is the vertex of a graph and that each pair of vertices (*x* _{ i },*x* _{ j }) is linked by an edge whose weight is proportional to some measure of distance *Dist*(*x* _{ i },*x* _{ j }). Once a minimum spanning tree for this graph has been constructed, it is easy to group the points into *k* clusters simply by removing the *k*−1 heaviest edges of this tree.

The clustering based on the minimum spanning tree maximizes a criterion that depends on the minimal distance between each cluster.

### Definition 4

(Spacing)

*C*

_{1}and

*C*

_{2}be two disjoint clusters, the

*spacing*between

*C*

_{1}and

*C*

_{2}is defined as

*x*,

*y*), for

*x*belonging to the first cluster and

*y*belonging to the second cluster.

The spacing is also sometimes called *minimal distance between two clusters* or *single linkage*.

### Definition 5

(*k*-clustering with maximum spacing)

*k-clustering with maximum spacing*of the dataset

*D*

_{ n }is a set of

*k*clusters

*C*

_{1},

*C*

_{2},…,

*C*

_{ k }partitioning

*D*

_{ n }that maximizes

The clustering based on the minimum spanning tree is precisely the one that maximizes this clustering criterion of maximum spacing (Gower and Ross 1969). Therefore, this corresponds to a situation for which a polynomial-time algorithm for maximizing the clustering criterion exists, which is not the case for most of the other clustering criteria.

Classically, when the graph is given as an adjacency matrix, this clustering problem can be solved directly by using Prim’s algorithm (1957), which takes *O*(*n* ^{2}) time, where *n* is the number of vertices in the graph (or equivalently the number of points in the dataset). This algorithm is optimal since all classical algorithms require *Ω*(*n* ^{2}) time in the case of a complete graph and an arbitrary metric.

The first quantum algorithm for clustering, although it had not been developed with this purpose in mind, is due to Dürr et al. (2004), who have studied the quantum complexity of some graph problems, including the minimum spanning tree. The models considered in their work are quantum versions of the *adjacency matrix* and the *adjacency list*. The adjacency matrix model, which is the only one considered here, is comparable to the black-box model described in Sect. 3.1. In this model, we give as input the indexes *i* and *j* of two vertices and we get as output the weight of the edge linking them (which, in our application, corresponds to the distance).

In practice, we must avoid at all cost the need to build a quantum circuit (or QRAM) that stores explicitly in its memory all the possible values of the adjacency matrix. Indeed, the construction of this circuit would require at least *Ω*(*n* ^{2}) time because one would need to read each entry of the *n*×*n* matrix at least once. This is clearly not better than using directly Prim’s algorithm. Intuitively, the situations for which it is interesting to apply Grover’s algorithm (or one of its variants) are when it is possible to construct a quantum circuit defining the search space in less time than needed classically for generating the minimum spanning tree.

The algorithm of Dürr et al. (2004) is a quantization of a classical algorithm for the minimum spanning tree due to Borůvka (1926). Taking no account of the practical need to build a quantum circuit for the adjacency matrix (as mentioned above), it assumes that this matrix is given by an oracle.

### Theorem 3

(Quantum algorithm for the minimum spanning tree)

*The quantization of Borůvka’s algorithm due to Dürr et al*. (2004) *can build the minimum spanning tree of a graph in* *Θ*(*n* ^{3/2}) *time*, *where* *n* *is the number of vertices of the graph*. *Moreover*, *this algorithm is optimal*: *in the case of a complete graph*, *no quantum algorithm can find the minimum spanning tree in less than* *Ω*(*n* ^{3/2}) *time*.

This theorem directly implies that it is possible to obtain a *k*-clustering with maximum spacing in *Θ*(*n* ^{3/2}) time, again on condition that an efficient quantum circuit to provide the distance between an arbitrary pair of points can be obtained in *O*(*n* ^{3/2}) time.

## 5 Divisive clustering

*divisive clustering*splits this super-cluster into two subclusters. Two datapoints are chosen to be the initial

*seeds*of the two subclusters. A common technique is to choose as seeds the two points that are the farthest apart within the dataset. Afterwards, all the other points are attached to their closest seed. This division technique is then applied recursively on all the subclusters obtained until all the points contained within a cluster are sufficiently similar or some other stopping criterion is reached (see Algorithm 2 for more details).

Divisive clustering seeks to maximize at each step of the recursion a criterion that depends on the maximal distance between two clusters.

### Definition 6

(Maximal distance between two clusters)

*maximal distance between two clusters*is the distance between the pair of points (

*x*,

*y*) that are the farthest apart, for

*x*belonging to the first cluster and

*y*belonging to the second cluster:

The costliest part of this algorithm is to identify the two points that are the farthest apart within the initial ensemble of *n* points. If the datapoints are vectors in ℝ^{ d } for an arbitrarily high dimension *d*, this process requires *Ω*(*n* ^{2}) comparisons in the general case,^{3} and this even in the case of approximations (Finocchiaro and Pellegrini 2002). Quantum mechanically, it is possible to use quant_find_max as a subroutine in this algorithm to find the two points that are the farthest apart in *O*(*n*) time.

### Theorem 4

(Quantum divisive clustering)

*With high probability*, *algorithm* quant_divisive_clustering *performs divisive clustering of a set of* *n* *points with a gain of at least* \(\varOmega(\frac{n}{\log n})\) *over the classical version*, *as measured by the ratio between the classical and quantum times*.

### Proof

*T*(

*n*) characterized asymptotically by the recurrence

*T*(

*n*)=2

*T*(

*n*/2)+

*O*(

*n*), which is

*O*(

*n*log

*n*). Classically, the recurrence for the same case is characterized by

*T*(

*n*)=2

*T*(

*n*/2)+

*Ω*(

*n*

^{2}) because of the time required to find the two points that are the farthest apart among the ensemble of points, which results in

*Ω*(

*n*

^{2}) time. The ratio between the classical and quantum times is therefore

*n*. In this case, this requires

*O*(

*n*

^{2}) global computational time quantum mechanically compared to of

*Ω*(

*n*

^{3}) classically, which results in a gain of

*Ω*(

*n*

^{3}/

*n*

^{2})=

*Ω*(

*n*). The gain between the classical and quantum versions is therefore even more pronounced in the unbalanced case, but it is \(\varOmega(\frac{n}{\log n})\) in all cases. □

In practice, if the clusters thus generated are highly unbalanced, this may be indicative of the presence of *outliers*. In this case, a common technique consists in detecting and removing these outliers before launching divisive clustering. This avoids the formation of sub-clusters that are too unbalanced. We discuss in Sect. 7.2 a quantized version of an algorithm for performing outlier detection.

## 6 *k*-medians

This section describes two quantum versions of the *k*-medians algorithm, the “standard” version, in which all the points are physically gathered in the same location, and the *distributed* version, in which the data is shared between two or more participants.

### 6.1 Standard version

The *k*-medians algorithm, also called *k*-medoids (Kaufman and Rousseeuw 1987), is a cousin of the *k*-means algorithm (Lloyd 1982). The cluster centres are often initialized as *k* points chosen at random among the *n* points of the dataset, *k* being a parameter of the algorithm corresponding to the number of desired clusters. (In Sect. 7.3, a quantum algorithm for initializing the clusters using a “smarter” approach is proposed.) The algorithm is iterative and each iteration is composed of two steps. During the first step, each datapoint is attached to its closest centre. Afterwards, during the second step, the centre of each cluster is updated as the median of all the points belonging to this cluster (recall that this is the point with minimal total distance to all the points in the cluster). The algorithm terminates when all the cluster centres are stabilized (or quasi-stabilized).

The *k*-medians algorithm seeks to partition the data into *k* clusters minimizing a distance criterion depending on the distance between all the points belonging to a cluster and the centre of this cluster.

### Definition 7

(*k*-medians criterion)

*k*clusters

*C*

_{1},

*C*

_{2},…,

*C*

_{ k }partitioning

*D*

_{ n }that have points

*μ*

_{1},

*μ*

_{2},…,

*μ*

_{ k }∈

*D*

_{ n }for respective centres. These clusters are

*optimal*with respect to the

*clustering criterion*of

*k*-medians if they minimize

*k*-medians criterion is NP-hard for all

*k*⩾2 even in the Euclidean case (Papadimitriou 1981). Hence, no known polynomial-time algorithm exists for computing an optimal solution to this problem (a set of clusters that minimizes this criterion) even with the use of a quantum computer. The quantum version of the

*k*-medians algorithm (Algorithm 3) is therefore a quantized version of a heuristic for solving an NP-hard problem, but not an algorithm for solving exactly this problem.

The main difference between *k*-means and *k*-medians is that the former chooses a virtual point called *centroid* as centre of a cluster, which corresponds to the average of the points belonging to this cluster, whereas the latter restricts the centre to be an actual point of the dataset. The *k*-means algorithm is guaranteed to converge to a stable assignment of the cluster centres after a finite number of iterations whereas the *k*-medians algorithm can reach a situation in which it oscillates between two (or more) configurations. This difference of convergence behaviour arises from the fact that the average is always uniquely defined whereas it is possible to have several perfectly valid medians for the same set of points. However, one of the advantages of *k*-medians over *k*-means is that it can be used even when the sole information available is the distance between points (and not their descriptions), which renders the computation of the average (and therefore the application of *k*-means) meaningless. Compared to its more famous cousin, the *k*-medians algorithm also offers the advantage of being more robust to noise and less sensitive to the presence of outliers within the data (see Sect. 7.2 for a brief explanation).

### Theorem 5

(Standard quantum *k*-medians)

*With high probability*, *algorithm* quantum_k_medians *computes the clustering of a set of* *n* *points with a gain of at least* \(\varOmega(\sqrt{n/k}\,)\) *over the classical version*, *as measured by the ratio between the classical and the quantum times*, *where* *k* *is the number of clusters returned by the algorithm*.

### Proof

In order to analyse the efficiency of one iteration of the algorithm, suppose at first that all the clusters are approximately of the same size *n*/*k*. If all the medians were to be computed classically, each would require \(\varTheta((\frac{n}{k})^{2})\) time, for a total of \(\varTheta (\frac{1}{k}n^{2})\) time in order to identify the centres of the *k* clusters. Quantum mechanically, the median of a cluster of size *n*/*k* can be obtained in \(O(\frac{n}{k}\sqrt{\frac{n}{k}}\,)\) time by using the subroutine quant_find_median. This leads to \(O(n^{{3}/{2}}/\sqrt{k}\,)\) time for one iteration of the quantum version of *k*-medians, which is \(\varOmega(\sqrt{n/k}\,)\) times faster than the classical approach. Consider now the unbalanced scenario, in which all the clusters but one are of small constant size, whereas a unique cluster concentrates almost all the mass of datapoints. In this case, finding the median requires *Ω*(*n* ^{2}) time classically, compared to *O*(*n* ^{3/2}) time quantum mechanically, which is \(\varOmega(\sqrt{n}\,)\) times faster. The gain between the classical and quantum versions is therefore even more pronounced in the unbalanced case, but it is \(\varOmega(\sqrt{n/k}\,)\) in all cases. □

Note that the use of the quantum or classical version has no impact on the convergence rate of the algorithm, as measured by *t*, the number of iterations. In practice, however, the number of iterations and the quality of the clustering returned can be improved by performing a more “intelligent” initialization of the cluster centres (see Sect. 7.3).

Between two iterations of the *k*-medians algorithm, it is possible that the clusters stay relatively stable, meaning that only a small number of points are moved from one cluster to another. In this situation, it is likely that an appropriate (classical) data structure can keep track of the contents of clusters and their medians in order to accelerate the computation of medians from one iteration to the next. However, this potential improvement does not seem to have been the focus of much study in the (classical) literature. If it were, we could use the quantum version of *k*-medians during the first iterations before using the classical alternative based on the appropriate data structure when the situation becomes more stable. Alternatively, we could design an appropriate *quantum* data structure to bring about even more improvement. This is the topic of further research.

The quantum version of *k*-medians might also be improved by developing a quantum algorithm to estimate the sum of distances rather than simply adding them one by one as suggested in Fig. 7. Currently existing algorithms for estimating the mean (Grover 1998) do not seem to be appropriate for this purpose because of precision issues, but other methods based on *amplitude estimation* seem promising (Brassard et al. 2011). It is also plausible that the convergence of the algorithm, as measured by the number of iterations *t*, might be sped up with the help of quantum techniques. We leave this as another avenue for future research.

### 6.2 Distributed version

In the same manner that it is sometimes possible to speed up an algorithm by exploiting the quantum paradigm, in some cases it is possible to reduce the communication cost of a distributed protocol (de Wolf 2002; Brassard 2003; Buhrman et al. 2009). In a distributed setting, the dataset *D* _{ n } is not localized in a single place but distributed among two (or several) participants. Equivalently, this can be seen as a situation in which each participant has his own dataset and their goal is to run a learning algorithm on the union of their datasets. For simplicity, we shall concentrate on the case of two participants and we assume that each of the attributes of any given datapoint can be represented with finite precision using a constant number of bits. This problem can be solved simply by gathering all the data in a central site and then running the standard version of the learning algorithm. In this case, the communication cost of the protocol would be of *Θ*(*dm*) bits, for *d* the dimension of the space in which the datapoints live and *m* the number of points of the smaller dataset. This can be very inefficient in practice if the size of the dataset is large. The main purpose of the theory of (classical) *communication complexity* (Kushilevitz and Nisan 1997) is to find efficient protocols that require fewer bits of communication than what communicating the whole input would entail.

In a quantum distributed learning situation, the participants have the possibility of exchanging qubits instead of bits or to share prior entanglement in order to help them in performing their task. The main issue is whether or not the use of quantum information can help in decreasing the communication cost of some distributed protocols. Holevo’s (1973) theorem rules out the possibility of transmitting more than *n* classical bits of information by communicating *n* qubits unless the participants share prior entanglement, in which case it is possible to transmit 2*n* classical bits by superdense coding (Bennett and Wiesner 1992), but this is the best possible (Cleve et al. 1999). Furthermore, it is impossible to use entanglement for instantaneous communication as this would entail faster-than-light communication. However, these limitations do not preclude the possibility of using quantum information to save significantly (quadratically or even exponentially) on the communication cost of computing some distributed functions (de Wolf 2002; Brassard 2003; Buhrman et al. 2009) or to achieve tasks that are provably impossible classically in a context in which communication between participants is ruled out (Brassard et al. 2005).

Suppose that the dataset *D* _{ n } is shared between two participants, Alice and Bob. For the sake of simplicity, we assume that they share equally an even number *n* of datapoints.^{4} In order for the quantum version of distributed *k*-medians to be interesting, it is necessary that its communication cost be lower than that of the trivial protocol, which would require sending all the data to one site, at a cost of *Θ*(*dn*) bits. The points in *D* _{ n } can be reordered such that the first *n*/2 points correspond to Alice’s dataset *D* _{ a }={*x* _{1},…,*x* _{ n/2}}, whereas the rest constitutes Bob’s dataset *D* _{ b }={*x* _{1+n/2},…,*x* _{ n }}.

Alice can construct a quantum circuit E _{ a } that encodes her dataset *D* _{ a }, possibly in the form of a QRAM (Giovannetti et al. 2008). This circuit E _{ a } takes as input the index *i* of a point from her dataset, for \(i\in\{1,\ldots,\frac{n}{2}\}\), and produces the description *x* _{ i } of this point. Bob can do the same with his own dataset *D* _{ b } and build a circuit E _{ b } that, from the index \(j\in\{\frac{n}{2}+1,\ldots,n\}\), returns the description *x* _{ j } of this point. Moreover, if Alice has an implementation of the quantum circuit *Dist*, which computes the distance between two points whose description is given as inputs, she can use it in conjunction with E _{ a } to implement a circuit S _{ a } that computes the sum of distances between an arbitrary point whose description is known (even a point belonging to Bob’s dataset) and all the points from her dataset *D* _{ a } (the same goes for Bob, who can build circuit S _{ b }). Quantum circuit *Dist* can be constructed by first designing an irreversible classical version of the distance circuit and then using Bennett’s (1973) technique to make it reversible and thus implementable as a quantum circuit. Moreover, Alice and Bob can also construct \(\mathsf{E}_{a}^{\dagger}\), \(\mathsf{S}_{a}^{\dagger}\), \(\mathsf {E}_{b}^{\dagger}\) and \(\mathsf{S}_{b}^{\dagger}\), the inverses of E _{ a }, S _{ a }, E _{ b } and S _{ b }, respectively.

In order to implement the *k*-medians algorithm in a distributed manner, Alice and Bob have to perform distributively Grover’s iteration, as used in the subroutine quant_find_median. During this protocol, they use and exchange three quantum registers. The first register, which encodes the index of a datapoint, is called the *index register* and is of size *Θ*(log*n*). This is the only register that will *not* be exchanged during the protocol. The second register, which contains the description of a datapoint, is called the *description register* and is of size *Θ*(*d*). Finally, the third register, which contain the distance or a sum of distances between one datapoint and several others, is called the *distance register*. We assume that we know an upper bound *sum*_*dist* _{ max } on the maximum sum of distances between one point and all the other points ^{5} so that we can choose the distance register to be of size *Θ*(log*sum*_*dist* _{ max }). Indexes *A* and *B* are attached to the quantum registers to indicate who, respectively between Alice and Bob, has control over this register at a particular moment of the protocol.

*k*-medians algorithm in which Alice and Bob need to find the median of cluster

*Q*=

*Q*

_{ a }∪

*Q*

_{ b }, where

*Q*

_{ a }⊆

*D*

_{ a }and

*Q*

_{ b }⊆

*D*

_{ b }. Let

*i*

_{ a }be the desired index of a point in

*Q*

_{ a }whose sum of distances with all the other points of

*Q*is minimal (

*i*

_{ b }is defined in the same way for

*Q*

_{ b }). The distributed Grover iteration, as given by Algorithm 4, is used to find

*i*

_{ a }with quant_find_median, where

*d*

_{ min }is initialized to 1+

*sum*_

*dist*

_{ max }and the index register is initialized to an equal superposition of the indices of all the points in

*Q*

_{ a }before the first iteration. Here, circuits S

_{ a }and S

_{ b }(and their inverses \(\mathsf{S}_{a}^{\dagger}\) and \(\mathsf{S}_{b}^{\dagger}\)) have been modified to take only account of the points in

*Q*

_{ a }and

*Q*

_{ b }, respectively.

### Lemma 2

*The protocol* distributed_Grover_iteration (*Algorithm * 4), *which implements Grover’s iteration in a distributed manner*, *can be used in the subroutine* quant_find_median. *Its communication cost is of* *O*(*d*+log*sum*_*dist* _{ max }) *qubits*, *where* *d* *is the number of attributes used to describe the datapoints and* *sum*_*dist* _{ max } *is an upper bound on the maximum sum of distances between one datapoint and all the other datapoints of* *D* _{ n }.

### Proof

The step by step description of Algorithm 4 clearly demonstrates that it implements the functionality of Grover’s iteration such as described in Sect. 2.2. In particular, the effect of the first part of Grover’s iteration (Steps 1 to 8) is to invert the phase of all the points in *Q* _{ a } whose sum of distances from all the points in *Q* is below the value *d* _{ min }. The inversion around the average, which is performed during the last step of Grover’s iteration, is independent of the functionality considered and can be realized locally by Alice. Concerning communication, only steps 3 and 6 require an exchange of information between Alice and Bob. The sizes of the registers exchanged are *O*(*d*) for the description register and *O*(log*sum*_*dist* _{ max }) for the distance register. The global communication cost is therefore *O*(*d*+log*sum*_*dist* _{ max }) qubits. □

*k*-medians algorithm and for each cluster, the subroutine quant_find_median is called in order to find

*i*

_{ a }by applying the protocol distributed_Grover_iteration for implementing Grover’s algorithm. Before calling distributed_Grover_iteration for the first time, Alice sets the index register in a superposition of all the indexes of the points in

*Q*

_{ a }(the current cluster considered by her). Once

*i*

_{ a }has been identified by using quant_find_median,

*i*

_{ b }can be found by inverting the roles of Alice and Bob. Finally, to determine the median among

*Q*

_{ a }∪

*Q*

_{ b }, it is sufficient to choose between

*i*

_{ a }and

*i*

_{ b }the one whose sum of distances with all the points in

*Q*is minimum. Algorithm 5 formalizes the distributed version of

*k*-medians.

### Theorem 6

(Quantum *k*-medians distributed)

*With high probability*, *algorithm* k_medians_distributed *clusters an ensemble of* *n* *points distributed between two participants at a* communication *cost of* \(O(t\sqrt{kn}(d+\log \mathit{sum}\_ \mathit{dist}_{max}))\) *qubits*, *where* *n* *is the number of points in the dataset*, *d* *the number of attributes used to describe these points*, *k* *the number of clusters returned*, *t* *the number of iterations of the algorithm and* *sum*_*dist* _{ max } *is an upper bound on the maximum sum of distances between one datapoint and all the other datapoints of* *D* _{ n }.

### Proof

Let us consider the two extremes. If the *k* clusters are approximatively of the same size *n*/*k*, each iteration of the algorithm requires that Alice and Bob exchange \(O(\sqrt{n/k}\,)\) times a register of size *O*(*d*+log*sum*_*dist* _{ max }) per cluster, for a total of \(O(k\sqrt{n/k}\, )=O(\sqrt{kn}\,)\) registers exchanged per iteration. On the other hand, if one cluster contains almost all the *n* points and the others are of negligible size, each iteration of the algorithm requires that Alice and Bob exchange \(O(\sqrt{n}\,)\) times a register of the same size as in the other case. We see that the balanced case is the worst in terms of communication (whereas it was the best case in terms of computation *time* in the nondistributed setting studied in Sect. 6.1). In all cases, \(O(\sqrt{kn}\,)\) exchanges of a register of size *O*(*d*+log*sum*_*dist* _{ max }) suffice, which results in a communication cost of \(O(\sqrt{kn}(d+\log \mathit{sum}\_\mathit{dist}_{max}))\) qubits per iteration. The total communication cost is therefore of \(O(t\sqrt{kn}(d+\log \mathit{sum}\_ \mathit{dist}_{max}))\) qubits for all *t* iterations. □

This algorithm can be easily generalized to the multiparty case, for a number of participants *m*⩾2. To do this, it is sufficient for each participant *j* (for 1⩽*j*⩽*m*) to find within his dataset the point *i* _{ j } whose sum of distances with all the other points is minimum. This can be done by adapting the distributed version of Grover’s iteration so that it works with more than 2 participants. Afterwards, the median can be chosen as the point among {*i* _{1},…,*i* _{ m }} that minimizes the sum of distances with all the other points of the cluster.

## 7 Quantum tools for unsupervised learning algorithms

The algorithms described in this section are not unsupervised learning algorithms by themselves, but they are often used as tools by other algorithms for unsupervised learning. Therefore, faster versions of these algorithms contribute directly to obtaining faster versions of algorithms for unsupervised learning.

### 7.1 Construction of a neighbourhood graph

The construction of a neighbourhood graph is an important step in the preprocessing of several unsupervised learning algorithms such as the algorithm Isomap for dimensionality reduction (Tenenbaum et al. 2000) and clustering by random walk (Harel and Koren 2001).

### Definition 8

(Neighbourhood graph)

Consider a complete undirected graph in which vertices correspond to points of a dataset and each edge between two vertices is weighted according to the distance between these two points. A *neighbourhood graph* is built from this original graph by keeping for each vertex only the edges connecting it to its *k* closest neighbours.

An alternative notion of a neighbourhood graph could be defined by keeping an edge between two vertices if and only if they are in the close neighbourhood of each other. This approach guarantees that the maximum degree of the graph is less than or equal to *k*, the number of the closest neighbours considered. However, it would then be possible that some points become isolated (not connected) from the rest of the graph, which may indicate that they are outliers (see next section), but may also be seen as a drawback if the neighbourhood graph is given as input to an algorithm that requires a connected graph. We shall use Definition 8 henceforth.

### Theorem 7

(Quantum algorithm for constructing a neighbourhood graph)

*With high probability*, *the algorithm* quant_neighbourhood_graph * constructs the neighbourhood graph of a set of* *n* *points in* \(O(\sqrt{k}\, n^{{3}/{2}})\) *time*, *for* *k* *the number of neighbours considered*.

### Proof

For each datapoint, it is possible to obtain its *k* closest neighbours in \(O(\sqrt{kn}\,)\) time by using the subroutine quant_find_smallest_values. Therefore, construction of the global neighbourhood graph takes \(O(\sqrt{k}\, n^{{3}/{2}})\) time. □

Classically, if we use an arbitrary metric and if the only information available is the distance between pairs of points, *Ω*(*n* ^{2}) time is required to generate the neighbourhood graph. However, if we have explicitly access to all the *d* attributes describing these points and if *d* is small,^{6} an appropriate data structure such as the *binary trees for multidimensional search* (Bentley 1975), also known as *kd-trees*, can be used to obtain the *k* closest neighbours of a specific point in *Θ*(*k*log*n*) time. The building of a *k*d-tree requires us to sort all the points for each dimension, which can be done in *Θ*(*dn*log*n*) time, where *d* is the dimension of the space in which the datapoints live and *n* is the number of datapoints. Therefore, it takes *Θ*((*k*+*d*)*n*log*n*) time to construct the *k*d-tree representing a dataset *and* use it for finding the *k* closest neighbours of each of the *n* points, provided *d* small.

### 7.2 Outlier detection

### Definition 9

(Outlier)

An *outlier* is an observation that differs significantly from the rest of the data.

In practice, the exact interpretation of this definition depends on the context considered. In some contexts, outliers are considered as being datapoints generated by a noise process and therefore must be removed if possible. For example, the outlier might be a datapoint that has been corrupted, either by a change in the value of some of its attributes or because it has been labelled with a wrong class. It might even be the case that this observation is purely random and does not carry any meaningful information.

When performing classification, it is desirable to be able to detect and remove outliers that are present inside a dataset in order to improve the accuracy of the classifier that will be learnt on this data. Similarly in clustering, the ability to recognize outliers makes it possible to avoid taking them into account during the formation of clusters and therefore to improve the quality of the resulting clustering. However, in some applications, such as fraud detection for credit card usage or intrusion detection, it is important to be able to detect outliers as they might correspond to an unusual behaviour that we want to discover.

*a priori*knowledge), a statistical test can be used to identify the datapoints that diverge significantly from this distribution (Yamanishi et al. 2004). Another way to detect an outlier is by inspecting the attributes of each point and then considering as potential outliers those

*differing significantly from the median value*. The median is generally used instead of the mean because it is less influenced by the presence of outliers since the mean might be greatly influenced by some extreme values. This also explains why the

*k*-medians algorithm (described in Sect. 6) is generally considered as being less sensitive to outliers than its cousin the

*k*-means algorithm (Massart et al. 1986). Other

*density-based methods*(Breunig et al. 2000) inspect the neighbourhood of each point and take the points located in low density areas as potential outliers. In practice, this method gives very good results but is often costly in terms of computational resources. Finally, another approach relies on a

*notion of distance*, which labels as outliers the points that are at far distant from their

*k*closest neighbours. Indeed, a possible technique (Angiulli and Pizzuti 2002) consists in identifying, for each point

*x*

_{ i }, its

*k*closest neighbours and to give a

*neighbourhood score*

*ω*

_{ i }to this point equal to

*V*

_{ k }(

*x*

_{ i }) is the subset of

*D*

_{ n }consisting in the

*k*closest neighbours of

*x*

_{ i }. Once this score has been computed for each point, outliers can be identified as points whose score

*ω*is above a threshold

*ω*

_{ max }(determined empirically), or as the

*c*points that have the highest score, for a well-chosen constant

*c*. Algorithm 7 is a quantum version of this idea, which computes these scores for each point. Classically,

*Ω*(

*n*

^{2}) time is needed to determine the neighbourhood scores of all

*n*points in the general case.

### Theorem 8

(Quantum algorithm for outlier detection based on distances)

*With high probability*, *the algorithm* quant_detection_outlier * identifies all the outliers*, *within a dataset of size n*, *in* \(O(\sqrt{k}\,n^{3/2})\) *time*, *where* *k* *is the number of neighbours considered for each point*.

### Proof

By virtue of Theorem 7, it takes \(O(\sqrt{k}\, n^{3/2})\) time to compute the neighbourhood graph. Once this is done, *O*(*k*) time is needed for each of the *n* nodes to compute its score and decide if it is an outlier. Therefore, the algorithm takes \(O(\sqrt{k}\,n^{3/2}+kn)\) total time, which is \(O(\sqrt{k}\,n^{3/2})\) since *k*⩽*n*. □

### 7.3 Initialization of the cluster centres

Traditionally, the initial cluster centres in algorithms such as *k*-means or *k*-medians are chosen at random among all the points from the dataset. Starting from two different initial configurations, the algorithm has a non-negligible probability of converging towards two different clusterings. Moreover, as it is NP-hard to optimize the cost functions of *k*-means and *k*-medians (Papadimitriou 1981), it is likely that both clusterings thus generated correspond at best to *local* minima. A standard technique for alleviating this problem is to run the algorithm several times from different initial configurations and to keep only the clustering that minimizes the cost function considered.

*max-min*(Dasgupta and Long 2005) type starts by choosing the first centre

*μ*

_{1}at random among all the points from the dataset. Afterwards, the second centre

*μ*

_{2}is chosen as the point with maximum distance from

*μ*

_{1}. The following centres

*μ*

_{3},…,

*μ*

_{ k }are chosen one by one, always taking as next centre the datapoint whose sum of distances with all the previous centres is maximum. Formally, we define the

*i*th centre

*μ*

_{ i }as:

### Theorem 9

(Quantum algorithm for the initialization of the cluster centres)

*With high probability*, *the algorithm* quantum_initialization_centres * initializes in a “smart” way the* *k* *cluster centres of a set of* *n* *points in* \(O(k^{2}\sqrt{n}\,)\) *time*.

### Proof

The algorithm quantum_initialization_centres chooses the first centre at random among all the possible points of the dataset. Afterwards, the second centre is determined as the farthest point from this original centre by using the quant_find_max subroutine, which requires \(O(\sqrt{n}\,)\) time. Then for each of the following centres *μ* _{ i }, for 3⩽*i*⩽*k*, we can compute it through *i*−1 applications of the oracle O, and then calling the subroutine quant_find_max on the register of distances, which take \(O((i-1)\sqrt{n}\,)\) time. Therefore, this algorithm takes \(O(k^{2}\sqrt{n}\,)\) time in total, which is obtained from summing the arithmetic series \(\sum_{i=1}^{k-1}i\sqrt{n}\). □

*k*disjoint clusters in which the maximum diameter, among all these clusters, is approximately minimized. The main goal here is to create an ensemble of

*k*clusters with small maximum diameter. Formally, this algorithm seeks to minimize

*C*

_{1},

*C*

_{2},…,

*C*

_{ k }. This criterion is NP-hard to optimize in its exact version, but an approximation due to González (1985) returns a set of

*k*clusters whose maximum diameter is at most twice that of the optimal

*k*-clustering of minimal maximum diameter, provided the distance function is defined in a Euclidean space. González’s algorithm starts by choosing the

*k*cluster centres as explained previously, which classically requires

*O*(

*k*

^{2}

*n*) time. Afterwards, each point of the dataset is attached to its closest centre. The quantum version of this algorithm requires \(O(k^{2}\sqrt{n}\,)\) time to identify the cluster centres.

## 8 Conclusion and future avenues of research

As seen in this paper, some unsupervised learning algorithms can be accelerated beyond what can be achieved classically by making some of their subroutines quantum mechanical. Moreover, in some distributed learning scenarios, it is possible to save on the communication cost if the participants are allowed to exchange quantum information or if they share prior entanglement, such as the distributed version of *k*-medians (Sect. 6.2). In this conclusion, we summarize the different results presented in this paper and open new avenues of research for quantum unsupervised learning algorithms.

### 8.1 Fair comparison between classical and quantum learning algorithms and lower bounds

In order to make a fair comparison between classical and quantum clustering scenarios, it is important to consider the best known classical algorithm when the only information available is the distance between pairs of points as well as when a complete description of the datapoints is available. For instance, when building a neighbourhood graph, the classical algorithm for *k*d-trees computes this graph so efficiently that quantizing the classical algorithm working only on the distances offers no significant advantage if the dimension *d* is small (Kibriya and Frank 2007). A fundamental open question is the study of the lower bounds for different clustering scenarios, be they classical or quantum mechanical. In particular, can we characterize precisely the situations in which the quantized version of the clustering algorithm offers a speed-up not only on its classical counterpart but on all possible classical algorithms?

*k*-clustering with maximum spacing and the construction of the minimum spanning tree, this would imply that no clustering algorithm that tries to maximize the criterion of

*k*-clustering with maximum spacing, whether it be classical or quantum mechanical, can take less than

*Ω*(

*n*

^{3/2}) time. Table 1 summarizes the results seen so far in this paper.

Table summarizing the lower and upper bounds in the time (or communication cost) required by unsupervised learning algorithms studied in this paper

Clustering problem | Classical | Quantum mechanical |
---|---|---|

Minimum spanning tree/ | | |

Divisive clustering (in the case of balanced sub-clusters) | | |

| \(\varOmega (\frac{n^{2}}{k} )\), \(O (t\frac{n^{2}}{k} )\) | |

| | \(\varOmega (d\sqrt{n}\, )\), \(O (t\sqrt{kn}(d+\log \mathit{sum}\_ \mathit{dist}_{max}) )\) |

Construction of a neighbourhood graph (for | | |

Outlier detection (based on the neighbourhood graph) | | |

“Smart” initialization of the cluster centres | | \(\varOmega(\sqrt{n}\,)\), \(O (k^{2}\sqrt{n}\, )\) |

These bounds are relatively tight for the clustering via minimum spanning tree, for the divisive clustering and for the “smart” initialization of the cluster centres. Concerning the construction of the neighbourhood graph and the detection of outliers, it seems likely that the true lower bound is closer from *Ω*(*n* ^{3/2}) than from *Ω*(*n*). If this intuition were formally proven, this would have for consequence that the algorithms presented in this paper are essentially optimal. On the other hand, for the quantum version of the *k*-medians algorithm, there is still a important gap between the lower bound and the upper bound, which leaves open the possibility of finding a more efficient quantum algorithm. In particular, the impact of the new approximate median-finding algorithm of Brassard et al. (2011) should be investigated.

Another fundamental question is to determine the type of clustering algorithms admitting a distributed version in which the transmission of quantum information can lead to a saving on the communication cost (compared to the classical versions). So far, we have seen that the *k*-medians algorithm admits an efficient distributed quantum version. The same kind of idea could also be applied to obtain a distributed version of the “smart” initialization of the cluster centres. This simply involves using the distributed version of Grover’s iteration in the computation of quant_find_max. Both distributed algorithms have a communication cost of \(\tilde{O}(d\sqrt {kn}\,)\) qubits (not taking into account the log factors) and return as output only *O*(*k*) bits of information corresponding to the cluster centres. On the other hand, algorithms such as clustering via minimum spanning tree output *Ω*(*n*) bits of information (for instance the description of the minimum spanning tree), which seems not easily compressible. It follows that these algorithms are unlikely candidates for the distributed setting because their communication cost would be at least as much as simply sending directly all the data to a single entity.

### 8.2 Quantization of dimensionality reduction algorithm

Isomap (Tenenbaum et al. 2000) is an unsupervised algorithm for learning a low-dimensional representation of data coming from non-linear varieties. More specifically, Isomap assumes that the observed data, which live in high dimension, have been generated by a low-dimensional manifold. The main idea of the algorithm is to approximate the *geodesic distance* between two points on this curvature by the length of the shortest path between these two points on a neighbourhood graph. Once the geodesic distance has been estimated for each pair of points of the dataset, multidimensional scaling (Cox and Cox 1994) is used on the distance matrix in order to learn a low-dimensional representation of the data. The computational bottleneck of Isomap, as well as of most of the dimensionality reduction algorithms, stems from the computation of the eigenvalues and eigenvectors of *n*×*n* matrices, which requires in general *O*(*n* ^{3}) time. The cost of these eigencomputations dominates the computational complexity of these algorithms. Concerning the determination of the eigenvalues, some quantum algorithms, such as amplitude estimation (Brassard et al. 2002), use the quantum Fourier transform to estimate the eigenvalues more quickly than classically achievable. However, with respect to the determination of the eigenvectors of a matrix, to the best of our knowledge there exist no quantum algorithms that are more efficient than their classical counterparts. We leave as open question the possibility of developing a quantum algorithm for determining the eigenvalues and the eigenvectors of an *n*×*n* matrix more efficiently than it is classically possible, which would directly lead to a panoply of quantum algorithms for dimensionality reduction.

### 8.3 Other research avenues

Grover’s algorithm, and its generalization amplitude amplification (Brassard and Høyer 1997; Brassard et al. 2002), are applicable in a wide range of situations but offer at best a quadratic speed-up compared to the best classical algorithm. More recently, other algorithmic approaches based on *quantum walks* (Kempe 2003; Ambainis 2003) or *quantum Markov chains* (Szegedy 2004; Magniez et al. 2007; Sántha 2008) have emerged. These techniques seem promising and capable of overcoming the intrinsic limits of Grover’s algorithm. In particular, there are strong similarities and links between some learning algorithms and some quantum algorithmic techniques, which might be exploited to develop new quantum learning algorithms. An example of promising candidate is a classical clustering algorithm based on random walks (Harel and Koren 2001).

Better than quadratic improvement over classical algorithms are likely to emerge only when intrinsically quantum algorithms, without any classical counterpart, will be developed. A paradigm shift on the computation as well as the representation model, such as adopting the point of view of the measurement-based model (Raussendorf and Briegel 2001) or adiabatic computation (Farhi et al. 2000), might lead to the development of such algorithms. These two models offer the same computational power as the “traditional” model of the quantum circuits (Aharonov et al. 2004; Broadbent and Kashefi 2009), but bring a different perspective and might result in the discovery of new algorithms that can more naturally be phrased in these models than in the form of circuits. Indeed, the measurement-based model is an ideal framework for expressing parallel or distributed algorithms, while the adiabatic computation model seems more appropriate for building optimization algorithms, such as a quantum version of simulated annealing.

## Footnotes

- 1.
We suppose throughout for simplicity that the number of points under consideration is a power of 2. If it is not, an equal superposition of the points can be obtained either with the use of a quantum Fourier transform or, in case measurement is allowable, by a postselection process.

- 2.
To be mathematically rigorous, the term

*dissimilarity measure*would be more appropriate than the term*distance*when the symmetry property or the triangle inequality does not hold. - 3.
- 4.
If this assumption does not hold, the algorithm can be adapted without difficulty. However, if the sizes of the datasets of Alice and Bob are exceedingly unbalanced—for example if one of the participants has only \(O(\sqrt {n}\,)\) datapoints—the best solution is that the participant with the smallest dataset sends directly all his data to the other participant, who then can run the standard version of the learning algorithm on the whole dataset.

- 5.
In the worst case,

*sum*_*dist*_{ max }is \(O(n\sqrt{d}\,)\) but a better upper bound could be known. - 6.
Kibriya and Frank (2007) review a study comparing different methods and data structures to speed up the search of the closest neighbours. This study empirically demonstrates that for any

*d*⩾16, all these methods become sensitive to the*curse of dimensionality*and require a time worse than linear in the number of points for identifying the closest neighbours of a particular point.

## Notes

### Open Access

This article is distributed under the terms of the Creative Commons Attribution License which permits any use, distribution, and reproduction in any medium, provided the original author(s) and the source are credited.

## References

- Aharonov, D., van Dam, W., Kempe, J., Landau, J., Lloyd, S., & Regev, O. (2004). Adiabatic quantum computation is equivalent to standard quantum computation. In
*Proceedings of 45th IEEE symposium on foundations of computer science*(pp. 42–51). CrossRefGoogle Scholar - Aïmeur, E., Brassard, G., & Gambs, S. (2006). Machine learning in a quantum world. In
*Proceedings of the 19th Canadian conference on artificial intelligence*(pp. 433–444). Google Scholar - Aïmeur, E., Brassard, G., & Gambs, S. (2007). Quantum clustering algorithms. In
*Proceedings of the 24th international conference on machine learning*(pp. 1–8). Google Scholar - Ambainis, A. (2003). Quantum walks and their algorithmic applications.
*International Journal of Quantum Information*,*1*(4), 507–518. zbMATHCrossRefGoogle Scholar - Angiulli, F., & Pizzuti, C. (2002). Fast outlier detection in high dimensional spaces. In
*Proceedings of the 6th European conference on principles and practice of knowledge discovery in databases*(pp. 15–26). Google Scholar - Anguita, D., Ridella, S., Riviecco, F., & Zunino, R. (2003). Quantum optimization for training support vector machines.
*Neural Networks*,*16*(1), 763–770. CrossRefGoogle Scholar - Bennett, C. H. (1973). Logical reversibility of computation.
*IBM Journal of Research and Development*,*17*, 525–532. zbMATHCrossRefGoogle Scholar - Bennett, C. H., & Wiesner, S. J. (1992). Communication via one- and two-particle operators on Einstein-Podolsky-Rosen states.
*Physical Review Letters*,*69*, 2881–2884. MathSciNetzbMATHCrossRefGoogle Scholar - Bennett, C. H., Bernstein, E., Brassard, G., & Vazirani, U. (1997). Strengths and weaknesses of quantum computing.
*SIAM Journal on Computing*,*26*(5), 1510–1523. MathSciNetzbMATHCrossRefGoogle Scholar - Bentley, J. L. (1975). Multidimensional binary search tree used for associative searching.
*Communications of the ACM*,*18*(9), 509–517. MathSciNetzbMATHCrossRefGoogle Scholar - Bespamyatnikh, S. N. (1998). An efficient algorithm for the three-dimensional diameter problem. In
*Proceedings of the 9th symposium on discrete algorithms*(pp. 137–146). Google Scholar - Borůvka, O. (1926). O jistém problému minimálním.
*Práce Moravské Přírodovědecké Společnosti*,*3*, 37–58. Google Scholar - Boyer, M., Brassard, G., Høyer, P., & Tapp, A. (1998). Tight bounds on quantum searching.
*Fortschritte der Physik*,*46*, 493–505. CrossRefGoogle Scholar - Brassard, G. (2003). Quantum communication complexity.
*Foundations of Physics*,*33*(11), 1593–1616. MathSciNetzbMATHCrossRefGoogle Scholar - Brassard, G., & Høyer, P. (1997). An exact quantum polynomial-time algorithm for Simon’s problem. In
*Proceedings of the 5th Israel symposium on theory of computing and systems*(pp. 12–23). CrossRefGoogle Scholar - Brassard, G., Høyer, P., & Tapp, A. (1998). Quantum counting. In
*Proceedings of the 25th international conference on automata, languages and programming*(pp. 820–831). CrossRefGoogle Scholar - Brassard, G., Høyer, P., Mosca, M., & Tapp, A. (2002). Quantum amplitude amplification and estimation. In S. J. Lomonaco Jr. (Ed.),
*Quantum computation and quantum information*(pp. 53–74). CrossRefGoogle Scholar - Brassard, G., Broadbent, A., & Tapp, A. (2005). Quantum pseudo-telepathy.
*Foundations of Physics*,*35*, 1877–1907. MathSciNetzbMATHCrossRefGoogle Scholar - Brassard, G., Dupuis, F., Gambs, S., & Tapp, A. (2011). An optimal quantum algorithm to approximate the mean and its application for approximating the median of a set of points over an arbitrary distance. arXiv:1106.4267.
- Breunig, M. M., Kriegel, H.-P., Ng, R. T., & Sander, J. (2000). LOF: identifying density-based local outliers. In
*Proceedings of the 2000 ACM SIGMOD international conference on management of data*(pp. 93–104). CrossRefGoogle Scholar - Broadbent, A., & Kashefi, E. (2009). Parallelizing quantum circuits.
*Theoretical Computer Science*,*410*(26), 2489–2510. MathSciNetzbMATHCrossRefGoogle Scholar - Buhrman, H., Cleve, R., Massar, S., & de Wolf, R. (2009). Non-locality and communication complexity. arXiv:0907.3584.
- Cleve, R., van Dam, W., Nielsen, M., & Tapp, A. (1999). Quantum entanglement and the communication complexity of the inner product function. In
*Proceedings of the first NASA international conference on quantum computing and quantum communications*(pp. 61–74). Google Scholar - Cox, T., & Cox, M. (1994).
*Multidimensional scaling*. London: Chapman and Hall. zbMATHGoogle Scholar - Dasgupta, S., & Long, P. M. (2005). Performance guarantee for hierarchical clustering.
*Journal of Computer and System Sciences*,*70*(4), 555–569. MathSciNetzbMATHCrossRefGoogle Scholar - de Wolf, R. (2002). Quantum communication and complexity.
*Theoretical Computer Science*,*287*(1), 337–353. MathSciNetzbMATHCrossRefGoogle Scholar - Dong, D., Chen, C., & Chen, Z. (2005). Quantum reinforcement learning. In
*Proceedings of the first international conference on advances in natural computation*(pp. 686–689). Google Scholar - Dürr, C., & Høyer, P. (1996). A quantum algorithm for finding the minimum. arXiv:quant-ph/9607014.
- Dürr, C., Heiligman, M., Høyer, P., & Mhalla, M. (2004). Quantum query complexity of some graph problems. In
*Proceedings of the 31st international conference on automata, languages and programming*(pp. 481–493). CrossRefGoogle Scholar - Ezhov, A. A., & Berman, G. P. (2003).
*Introduction to quantum neural technologies*. Princeton: Rinton Press. Google Scholar - Farhi, E., Goldsone, J., Gutmann, S., & Sipser, M. (2000). Quantum computation by adiabatic evolution. arXiv:quant-ph/0001106.
- Finocchiaro, D. V., & Pellegrini, M. (2002). On computing the diameter of a point set in high dimensional Euclidean space.
*Theoretical Computer Science*,*287*(2), 501–514. MathSciNetzbMATHCrossRefGoogle Scholar - Garey, M. R., & Johnson, D. S. (1979).
*Computers and intractability: a guide to the theory of NP-completeness*. New York: Freeman. zbMATHGoogle Scholar - Giovannetti, V., Lloyd, S., & Maccone, L. (2008). Architectures for a quantum random access memory.
*Physical Review A*,*78*(5), 052310. CrossRefGoogle Scholar - González, T. F. (1985). Clustering to minimize the maximum intercluster distance.
*Theoretical Computer Science*,*38*, 293–306. MathSciNetzbMATHCrossRefGoogle Scholar - Gower, J. C., & Ross, G. J. S. (1969). Minimum spanning trees and single linkage cluster analysis.
*Applied Statistics*,*18*(1), 54–64. MathSciNetCrossRefGoogle Scholar - Grover, L. K. (1997). Quantum mechanics helps in searching for a needle in a haystack.
*Physical Review Letters*,*79*(2), 325–328. CrossRefGoogle Scholar - Grover, L. K. (1998). A framework for fast quantum mechanical algorithms. In
*Proceedings of the 30th ACM symposium on theory of computing*(pp. 53–62). Google Scholar - Harel, D., & Koren, Y. (2001). On clustering using random walks. In
*Proceedings of the 21st conference on foundations of software technology and theoretical computer science*(pp. 18–41). Google Scholar - Holevo, A. S. (1973). Bounds for the quantity of information transmitted by a quantum mechanical channel.
*Problems of Information Transmission*,*9*, 177–183. MathSciNetGoogle Scholar - Horn, D., & Gottlieb, A. (2001). The method of quantum clustering. In
*Proceedings of the neural information processing systems*(pp. 769–776). Google Scholar - Horn, D., & Gottlieb, A. (2002). Algorithms for data clustering in pattern recognition problems based on quantum mechanics.
*Physical Review Letters*,*88*(1), 018702. CrossRefGoogle Scholar - Kaufman, L., & Rousseeuw, P. (1987). Clustering by means of medoids. In Y. Dodge (Ed.),
*Statistical data analysis based on the**L*_{1}*-norm and related methods*(pp. 405–416). Google Scholar - Kempe, J. (2003). Quantum random walks—An introductory overview.
*Contemporary Physics*,*44*(4), 307–327. MathSciNetCrossRefGoogle Scholar - Kibriya, A. M., & Frank, E. (2007). An empirical comparison of exact nearest neighbour algorithms. In
*Proceedings of the 11th European conference on principles and practice of knowledge discovery in databases*(pp. 140–151). Google Scholar - Kushilevitz, E., & Nisan, N. (1997).
*Communication complexity*. Cambridge: Cambridge University Press. zbMATHGoogle Scholar - Li, Q., He, Y., & Jiang, J.-p. (2009). A novel clustering algorithm based on quantum games.
*Journal of Physics A: Mathematical and Theoretical*,*42*, 445303. MathSciNetCrossRefGoogle Scholar - Li, Q., He, Y., & Jiang, J.-p. (2011). A hybrid classical-quantum clustering algorithm based on quantum walks.
*Quantum Information Processing*,*10*(1), 13–26. MathSciNetzbMATHCrossRefGoogle Scholar - Lloyd, S. P. (1982). Least square quantization in PCM.
*IEEE Transactions on Information Theory*,*28*(2), 129–137. First made available as a Bell Telephone Laboratories Paper (1957). MathSciNetzbMATHCrossRefGoogle Scholar - Magniez, F., Nayak, A., Roland, J., & Sántha, M. (2007). Search via quantum walk. In
*Proceedings of the 39th ACM symposium on theory of computing*(pp. 575–584). Google Scholar - Massart, D. L., Kaufman, L., & Rousseeuw, P. J. (1986). Least median of squares: a robust method for outlier and model error detection in regression and calibration.
*Analytica Chimica Acta*,*187*, 171–179. CrossRefGoogle Scholar - Mishra, N., Oblinger, D., & Pitt, L. (2001). Sublinear time approximate clustering. In
*Proceedings of the 12th symposium on discrete algorithms*(pp. 439–447). Google Scholar - Nayak, A., & Wu, F. (1999). The quantum query complexity of approximating the median and related statistics. In
*Proceedings of the 31st ACM symposium on theory of computing*(pp. 384–393). Google Scholar - Nielsen, M. A., & Chuang, I. L. (2000).
*Quantum computation and quantum information*. Cambridge: Cambridge University Press. zbMATHGoogle Scholar - Papadimitriou, C. H. (1981). Worst-case and probabilistic analysis of a geometric location problem.
*SIAM Journal on Computing*,*10*(3), 542–557. MathSciNetzbMATHCrossRefGoogle Scholar - Preparata, F. P., & Shamos, M. I. (1985).
*Computational geometry: an introduction*. New York: Springer. Google Scholar - Prim, R. C. (1957). Shortest connecting networks and some generalizations.
*The Bell System Technical Journal*,*36*(6), 1389–1401. Google Scholar - Raussendorf, R., & Briegel, H. J. (2001). A one-way quantum computer.
*Physical Review Letters*,*88*(22), 5188–5191. CrossRefGoogle Scholar - Sántha, M. (2008). Quantum walk based search algorithms. In
*Proceedings of 5th international conference on theory and applications of models of computation*(pp. 31–46). Google Scholar - Servedio, R. (2001). Separating quantum and classical learning. In
*Proceedings of the 28th international conference on automata, languages and programming*(pp. 1065–1080). Google Scholar - Shor, P. W. (1997). Polynomial-time algorithms for prime factorization and discrete logarithms on a quantum computer.
*SIAM Journal on Computing*,*26*(5), 1484–1509. MathSciNetzbMATHCrossRefGoogle Scholar - Szegedy, M. (2004). Quantum speed-up of Markov chain based algorithms. In
*Proceedings of 45th IEEE symposium on foundations of computer science*(pp. 32–41). CrossRefGoogle Scholar - Tenenbaum, J. B., de Silva, V., & Langford, J. C. (2000). A global geometric framework for nonlinear dimensionality reduction.
*Science*,*290*(5500), 2319–2323. CrossRefGoogle Scholar - Valiant, L. G. (1984). A theory of the learnable.
*Communications of the ACM*,*27*, 1134–1142. zbMATHCrossRefGoogle Scholar - Witten, I. H., & Frank, E. (2005).
*Data mining: practical machine learning tools and techniques*(2nd ed.). San Mateo: Morgan Kaufmann. zbMATHGoogle Scholar - Yamanishi, K., Takeuchi, J., Williams, G. J., & Milne, P. (2004). On-line unsupervised outlier detection using finite mixtures with discounting learning algorithms.
*Data Mining and Knowledge Discovery*,*8*(3), 275–300. MathSciNetCrossRefGoogle Scholar - Yu, Y., Qian, F., & Liu, H. (2010). Quantum clustering-based weighted linear programming support vector regression for multivariable nonlinear problem.
*Soft Computing*,*14*(9), 921–929. CrossRefGoogle Scholar - Zahn, C. T. (1971). Graph-theoretical methods for detecting and describing gestalt clusters.
*IEEE Transactions on Computers*,*20*(1), 68–86. zbMATHCrossRefGoogle Scholar

## Copyright information

**Open Access**This article is distributed under the terms of the Creative Commons Attribution 2.0 International License (https://creativecommons.org/licenses/by/2.0), which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.