Abstract
In the field of data mining, clustering has shown to be an important technique. Numerous clustering methods have been devised and put into practice, and most of them locate high-quality or optimum clustering outcomes in the field of computer science, data science, statistics, pattern recognition, artificial intelligence, and machine learning. This research provides a modern, thorough review of both classic and cutting-edge clustering methods. The taxonomy of clustering is presented in this review from an applied angle and the compression of some hierarchical and partitional clustering algorithms with various parameters. We also discuss the open challenges in clustering such as computational complexity, refinement of clusters, speed of convergence, data dimensionality, effectiveness and scalability, data object representation, evaluation measures, data streams, and knowledge extraction; scientists and professionals alike will be able to use it as a benchmark as they strive to advance the state-of-the-art in clustering techniques. 
    1. Introduction
Data can be categorized into numerous groups or clusters using the similarity of the data points’ traits and qualities in a process known as clustering [,]. Numerous data clustering strategies have been developed and used in recent years to address various data clustering issues [,]. Normally partitional and hierarchical are the two main categories in cluster analysis approaches []. However, the approaches in these techniques proved incredibly effective and efficient, these methods typically rely on the availability of information on the precise dataset for every amount of clusters that need to be clustered and examined in advance []. Additionally, while working with an actual dataset, it is obvious to neither anticipate nor know in advance how many spontaneously existing sets there will be in the data entities. 
Thus, to overcome such constraints, the idea of automatic data grouping techniques is presented. Any clustering method that automatically calculates the number of clusters without a previous understanding of the dataset’s structures and qualities is referred to as using automatic clustering methods [,].
Many of the proposed clustering algorithms discussed in the literature and some of them are encouraged by nature, in this paper we present a review of traditional and newly offered clustering methods applied in various fields. In, the author researched the datasets occurring in statistics, computer science and machine learning. The researchers in [,] worked on the three V’s characteristics of big data which are defined as volume, variety, and velocity which are then used in different kinds of clustering algorithms to discover. The authors in [] presented NoPFS, a machine learning I/O middleware that eliminates the I/O bottleneck in a scalable, versatile, and user-friendly fashion. In order to take advantage of the speed and efficiency of node-local or near-node storage, the author of [] proposed High-Velocity AI Cache (HVAC), a distributed read-cache layer. The researchers in [] carried out brief research of the available clustering algorithms and carried out numerous tests to identify the top clustering method for big data analysis. The authors in [] explored data mining clustering strategies, focusing on object attribute type, scalability for huge datasets, processing high dimensional data, and identifying irregularly formed clusters. The focus of the work in [,,] was on categorizing and summing up parallel clustering techniques. The author talked about the architecture of various parallel clustering algorithms. The writer of [] offered a taxonomy of current clustering methods, discussing the various similarity measurements and evaluation standards for each algorithm. 
Researchers in [] conducted a comparison of the various clustering methods for both categorical and mixed datasets, and observed that for a huge dataset of any kind there is no clustering technique that can deal properly. The author of [] observed many clustering algorithms that may be used with gene expression data in order to find and offer information on the best clustering approach that would guarantee stability and a high degree of accuracy in its analysis. The writer of [] defined popular clustering approaches and discussed important problems and difficulties in developing clustering algorithms. The authors in [,] highlighted cutting-edge methods for non-numeric restrictions and big data sets of patterns.
Additionally, it can be difficult for applied researchers to discover systematic information about the subject’s study growth []. As a result, a review of the previously conducted studies on both traditional and current clustering methods and their taxonomy is necessary to be carried out. Moreover, machine learning algorithms that are widely used in high performance and scientific domains are discussed in partitional and hierarchical clustering algorithms. 
Thus, key questions for this review have been formulated as below:
- What are the numerous previously conducted studies on clustering approaches and techniques?
- How can we compare both algorithms concerning complexity and various other parameters?
- What are the other possible issues in clustering that still needs to be addressed?
The main contribution of this review is as follows:
A taxonomy of clustering algorithms and their brief concepts are discussed, as well as the compression of both the categories of an algorithm with various parameters. In addition, this study describes some of the most pressing questions that have arisen recently in the study of clustering concerns.
2. Taxonomy of Clustering Algorithms
There are two broad categories in clustering algorithms: the first is a partitional clustering algorithm and the second is a hierarchical clustering algorithm [,,,,,,,,]. Agglomerative and divisive methods are further subdivisions of a hierarchical clustering algorithm. The hard or crisp clustering method, the fuzzy method, and the mixture method are three subcategories of the partitional category. There are seven main groups under the hard or crisp: search-based methods, graph-theoretic methods, density-based methods, model-based methods, sub-space methods, miscellaneous methods, and the square error as displayed in Figure 1.
 
      
    
    Figure 1.
      Taxonomy for various clustering techniques.
  
2.1. Hierarchical Clustering Algorithms
Hierarchical clustering algorithms are a type of clustering algorithm where data items will be divided into sections in a hierarchical form []. To create a dendrogram that shows the formulated cluster’s hierarchical structure, in a top-down or bottom-up way clusters are created iteratively []. This clustering technique enables data exploration at various granularity levels []. One is the divisive method where the top-down strategy is followed, and another is an agglomerative method where the bottom-up approach is followed. The process agglomerative technique follows clusters which are formed from identical items by properly combining them repeatedly into bigger clusters to establish the hierarchy’s various levels. This process continues until the full object is transformed into a particular cluster or the stopping criteria is met. The opposite is true when using a polarizing strategy. 
Iteratively, the cluster comprising all the objects is dispersed until either the halting requirement is satisfied, or each object creates its own cluster. The cluster element’s closeness or dissimilarity is used to determine whether to merge or split the data.
The distance among the points of subgroups is calculated from the distance of individual points, hierarchy clustering allows for the merging or splitting of subsets of a point. The linkage metric, which measures proximity, is used to ascertain this. There are three kinds of linkages: one of them is single linkage, the second one is average connection and the last is complete linkage which is usually used in hierarchical clustering [,,,,]. The algorithm for hierarchical clustering utilizes n*n the linkage metrics utilized for the clustering are created in connectivity matrix form. Finding the similarities between each pair of data points allows for the building of the similarity matrix. When deciding on a linking criterion, it is common practice to measure the pairwise distance between each cluster. Using the measure of similarity, we may determine the separation between the groups of clusters. It is also utilized to answer the question of how the clusters themselves take form. 
2.1.1. Agglomerative Clustering
In unsupervised machine learning, hierarchical, agglomerative clustering is a significant and well-established approach. Agglomerative clustering methods begin by dividing the data set into singleton nodes and gradually combining the two currently closest nodes into a single node until only one node is left, which contains the whole data set. This process serves as a common description for several clustering systems, but they vary in how the measure of inter-cluster dissimilarity is updated after each step []. The objective function’s optimal value serves as the criterion for selecting the pair of clusters to merge at each phase. Instead of binary data, this clustering algorithm is best suited for quantitative variables. The research of [] devised a non-parametric hierarchy, with a conventional closest neighbor approach, an agglomerative clustering method determines a sample point’s mutual neighborhood value (MNV) and mutual nearest neighbors (MNN). Agglomerative hierarchical clustering is further subdivided into the following categories. 
- Single-linkage clustering: this type of clustering is also known as the minimal, connectedness, or nearest-neighbor approach. The closest distance between any two cluster members of any cluster is measured. By calculating the closest distance between a single element pair, it calculates the similarity between two clusters. The chaining effect of the single linkage clustering has the propensity to produce extended clusters [].
- Average linkage clustering: the minimum-variance linkage is another name for average linkage clustering [,]. It determines the average or median distance between each cluster of data points [].
- Complete linkage: the complete linkage, often referred to as the maximum, diameter, or farthest neighbor method, measures the longest distance between any member of one cluster and any member of the other cluster in order to calculate the distance between two clusters. Compared to single-linkage clustering, the complete-linkage algorithm clusters are smaller and more closely linked []. The three-proximity metrics that were described earlier take into account all the points in a pair of clusters when calculating the inter-cluster distances. They are thought of as graph techniques [,].
SLINK is an implementation of the single linkage hierarchical clustering technique []; the authors of [,] developed CLINK, which is an implementation of the complete linkage clustering algorithm and are examples of the average link clustering algorithm. Other geometrical techniques were created using the center point as a proximity measure based on the same concept. These comprised the minimum variance linkage metrics, centroid linkage, and median linkage metrics [,,]. While similarity metrics capture intra-cluster connectedness, a distance-based proximity measure captures inter-cluster closeness. The adjustable amount of granularity and any similarity metric can be handled by the hierarchical clustering techniques [].
2.1.2. Divisive Hierarchical Clustering
The agglomerative clustering process breaks each cluster into smaller groups starting with each item in a single cluster and continuing until the necessary number of clusters is reached and it is reversed by the process known as “divisive hierarchical clustering.” The divisive approach, in contrast to the agglomerative clustering method, employs the top-down method, where the data objects are initially thought of as a fused cluster that gradually separates depending on when the cluster number is collected [,,]. In order to divide a cluster into two subsets that each contain one or more components, the usual procedure takes into account all potential bipartitions. Even though it is common practice to examine all potential bipartitions in which each cluster is capable of being divided into two smaller clusters it is clear that the entire enumeration procedure provides a universal optimum but is quite costly in terms of computation cost.
Diverse divisive clustering methods that do not take into account all bipartitions have been researched. For instance, [] compared the conventional K-Means or agglomerative method, and a bisecting K-Means divisive clustering method was presented. Another study [] combined it with the divisive clustering approach to investigate a unique clustering technique dubbed “reference point-based dissimilarity measure” (DIVFRP) for the aim of dataset division.
The author in [] proposed an improved particle optimizer (IDPSO) to identify the most convenient optimal partition hyperplane for dividing the chosen clusters into two parts. This dividing method is a practical and effective component of the divisive hierarchical approach. The authors in [,] investigated the iterative division technique using the average dissimilarity between an object and a set of objects. A different strategy, however, focuses on optimization criteria that include partitioning or bi-partitioning and uses a dissimilarity matrix as input [,]. There are two main categories of divisive clustering: monothetic and polythetic approaches. When a set of logical qualities are both required and sufficient for inclusion in a cluster, we refer to that cluster as monothetic [].
Monothetic divisive clusters are formed by dividing items based on a single variable in each breaking, such as whether or not they have a certain object value. The “association analysis approach” has a version called monothetic; the author of [] developed it specifically for binary information. Several researchers have used monothetic clusters to solve problems. For instance, the authors of [] provided an approach that gives an arrangement of things and a monothetic description of each cluster. Similarly, the author in [] developed three monothetic techniques and principal component analysis (PCA) for inter-valued data. The initial PCA method utilized inter-valued data. The author’s second approach relied on symbolic data, while their third and final algorithm was derived from the terminal values of intervals. In the end, the author tested their model using real-world data to ensure its accuracy. 
Contrarily, polythetic divisive clustering is a method that uses all parameters concurrently by calculating distances or resemblance values. Rather than relying on the relative positions of variables, it relies solely on distance values, which in turn indicate the dissimilarity between all of the variables simultaneously [].
2.2. Partitional Clustering Algorithm
Data is arranged into nested groups using a partitional clustering algorithm, but there is no hierarchical structure []. The authors in [] claimed that applications requiring big data sets for which the creation of a dendrogram is computationally prohibitive can handle clustering problems using the partitioning method. They work by creating data clusters to recreate the natural groupings already present in the dataset. The optimization of a criterion function is used to iteratively divide the dataset of n items into a preset k number of unique subsets []. In [], the author presented a new approach called k-SCC to get the best possible value for k when clustering categorical data. The squared error criteria are the most commonly used criteria functions in partitional clustering algorithms. The primary objective is to identify the segment that minimizes the square error for a given quantity of clusters. Problems in the patterns’ deviations from the cluster centers are depicted by the error when the patterns are seen as a group of k-numbered spherical shape clusters. Using an information theoretic dissimilarity measure and a kernel-based technique for representation of cluster means for categorical items, the authors of [] sought to build an unique extension of the k-means method for clustering categorical data.
The initial dataset partition serves as the basis for the partitional clustering algorithm, which allocates the data items in clusters iteratively in such a way that it can minimize the square error. The initial partition can be determined by selecting at random from the pattern matrix a set of K seed points that are widely spaced from one another. The authors of [] emphasized the need of choosing starting points from preexisting data items that are appropriately separated from each other, appropriate seed points could be discovered. The square error tends to decrease as the number of clusters rises, and thus minimizing is only possible for a given number of clusters. 
Several techniques for partition clustering employ the square error criterion function to generate K-numbered clusters that are as small and different as feasible. It is more energy efficient than alternative criteria functions []. Because square-error-based techniques can tend to the local optimal solution, particularly if the beginning points are not widely separated, potentially different divisions can produce various clusters as an outcome []. Partitional clustering is subdivided into three main categories which include fuzzy clustering, hard/crisp clustering and the last is mixture resolving.
2.2.1. Fuzzy Clustering
A clustering technique called fuzzy clustering was created by [] and is based on the fuzzy set. Each pattern concurrently belongs to more than one of the fuzzy sets that form the clusters. Allocating data points to more than two clusters with varying degrees of participation in the mirrored clusters yields a non-binary relationship []. By allowing clusters to overlap in this manner, the fuzzy overlap is demonstrated. Fuzzy overlap counts the number of data points with meaningful membership in the overlapping clusters while reflecting the fuzziness of the cluster borders. This clustering method is useful for groupings of data points whose boundaries are fuzzy or poorly differentiated [,]. Information on a point’s level of affiliation in a cluster might shed light on the item’s inherent relationship to those clusters.
2.2.2. Hard/Crisp Clustering
In a hard or crisp clustering procedure, each data point refers to an exactly particular cluster. Miscellaneous clustering, density-based clustering, graph-theoretic clustering, model-based clustering and subspace clustering are some of the clustering techniques included in this category.
- Graph-theoretic clustering:
A data structure known as a “graph” is composed of nodes and the edges that connect them. When conducting data analysis, a graph can be used to list significant, pertinent features and model relationships between features of data items. Graphs are used to represent clusters in graph-theoretic clustering [].
The representation of the data objects consists of nodes connected by edges. The edges show how close together pairs of data points are []. Separating cells into distinct clusters reduces the number of edges among groups while increasing the number of edges inside them []. Consistent edges are those whose clustering length (weight) is significantly greater than the average of the nearby edges. Points are classified into groups based on the graph structure, which results in result clusters with strong intra-connectivity/homogeneity and minimal inter-connectivity/homogeneity among the produced clusters. Although useful, representing clusters on graphs is not robust enough to handle outliers. 
Using particular graph topological characteristics, this clustering method produces bunches from a collection of data items. Similar to the search for the most connected graph subgraphs, the problem of single linkage hierarchical clustering is a graph-based one. Comparable to total-linkage, hierarchical clustering is the search for the most comprehensive subgraphs in a given network [].
- Subspace clustering:
Subspace clustering aims to discover a low-dimensional subspace that best fits each cluster of points in the data while clustering the data into numerous subspaces at the same time []. Instead of explaining a big dimensional dataset as a whole, it is frequently preferable to do so using the subspaces in which it exists []. In such a large dimensional dataset, the subspace clustering method enables the discovery of hidden knowledge. Subspace clustering makes it simple to spot clusters that exist in several overlapping subspaces. Utilizing feature selection, subspace clustering eliminates unnecessary and redundant dimensions, leaving only the pertinent dimension for the clustering algorithm to employ when locating clusters in the dataset. Using the top-down and bottom-up clustering algorithm search techniques, the subspace clustering algorithm is divided into two subcategories. The bottom-up subspace method makes use of the downward closure property of density to minimize search space using an APRORI-style methodology. Top-down subspace clustering starts by finding an estimation of the clusters throughout the full-length feature set, where each dimension is entitled to equal weight.
- Density-based clustering:
In pattern space, clusters are regarded as dense regions that are divided by less dense parts. When compared to the items in the sparse regions dividing the clusters, which are referred to as noise and outliers, the high-density regions, or modes, are connected with a cluster core []. The closest center clusters are then created using the data points. To determine the pattern space modes, the pattern space is divided into non-overlapping sections and a histogram is created. The valleys of the histogram’s structure serve as the boundaries between the clusters, while the regions with high-frequency counts represent potential modes. The main problem with a histogram is that it requires too large of a pattern space to distinguish the portions required for determining the density function []. 
Furthermore, because they cannot be accurately described, small clusters are typically exceedingly noisy. The diverse qualities of the member patterns, however, prevent huge clusters from accurately defining the cluster properties. 
Finding the exact values for the histogram’s peak and the valley is another challenge []. Engineering has made substantial use of this clustering technique, primarily in remote sensing applications []. In some other instances, clusters are created depending on the number of data points present in a certain area. Data points are added to the cluster up until a predetermined threshold is reached for the neighborhood’s density. In this scenario, a cluster within a specific radius must have a certain minimum number of objects that fall inside the provided criterion. Building of the cluster this makes it possible to create clusters with any shape. Naturally, noisy or outlier data points are removed. For example, density-based spatial clustering of applications with noise (DBSCAN) and optimal points for identifying cluster structure (OPTICS) are two methods for determining a clustering’s organizational framework (DENCLUE) DBSCAN’s cluster model is well-defined and just somewhat complicated []. OPTICS fixed the problem with DBSCAN’s range parameter selection, producing a hierarchical outcome similar to linkage clustering []. Moreover, the HDBSCAN clustering algorithm is a successor of the DBSCAN algorithm; it shares all the advantages of the DBSCAN algorithm and eliminates the problem of clusters of varying densities, which is often referred as a strength of the algorithm. However, it still needs to select a minimum cluster size which is said to be its weakness []. 
According to reports, the model’s complexity increased from O(n2) to O(n log n) when the spatial index was used to define a data point’s neighborhood [].
- Model-based clustering:
Model-based clustering is a method for maximizing the usefulness of a selected model with the information at hand. Since clusters are formed according to the data set provided, the total nodes may be estimated rapidly, facilitating the discovery of outliers. Clustering using models utilizes a hybrid model to depict the data, with the model’s components standing in for the various clusters. Cluster composition models can be generated in one of two ways, e.g., methods such as the mixing likelihood and the categorization probable. Parameter estimates for a model are often determined using the Maximum Likelihood Estimation (MLE) criteria [], or with the Bayesian Information Criterion (BIC) []. The BIC may also use distance to decide which of two clusters to place a data point in [].
- Search-based clustering:
Automatic data clustering techniques, or search-based clustering algorithms, are metaheuristic methods inspired by nature. The architecture and quantity of clusters in such a dataset are determined without prior knowledge of the characteristics or elements in the array []. They appear as a response to the requirement to supply the conventional clustering algorithms, a priori data []. Based on the quantity of clusters produced. The necessity of providing this crucial data typically results in some additional computing demands or loads on the pertinent conventional clustering techniques [,]. A fundamental issue in cluster analysis known as the “automated clustering problem” is finding the best estimate of the number of clusters []. Legitimate data clustering analysis using high-density and dimensional datasets exacerbates this difficulty. It is tough to pick sufficient cluster numbers when there is a lack of previous domain knowledge, particularly in datasets with several dimensions and a broad range of cluster size, shape, density, and occasionally overlap. This was before the number of clusters needed for a data clustering technique is not straightforward since figuring out the appropriate number of clusters needed for such huge datasets is a very tricky subject. 
For real-world data sets with high density and dimensionality, automatic clustering algorithms are developed, where such a prerequisite is not necessary, and become a superior choice. Without providing any background information about the datasets, automatic clustering algorithms yield identical results to the conventional clustering technique [,,,]. Automatic labeling of unlabeled data points in real-world datasets has also been found to be feasible using this method, which is obviously difficult and extremely difficult to accomplish traditionally.
Automatic clustering algorithms are more likely to find an optimum ideal solution than local searching algorithms, which are affected by early originating regions. A generalized optimization problem requires a linear and convex solution []. Additionally, nature-inspired clustering algorithms are more adaptable to addressing clustering challenges across sectors than traditional clustering approaches, which are generally a concern and lack continuity []. The main goal of automatic clustering algorithms is to produce clusters with lowered based on inter-distance and enhanced inter-cluster distance [].
- Square error clustering:
Using a sum of the square error criterion functions, data points are clustered into a set number of categories with the square error clustering technique. Differentiated by the number of standard deviations, each data point from the stated group mean is included in the information shown here. When the sum of the squared errors for the data points in a cluster is zero, we may say that the points in the cluster are statistically very near to one another (very close).
K-means clustering; the K-means clustering algorithm is often used to fix clustering issues. This is an instance of unsupervised learning. Some benefits it offers are as follows: it outperforms hierarchical clustering in terms of computing efficiency for very large variables. If you choose a globular cluster with a small value for k, you will obtain denser clusters than you would with hierarchical clustering. This algorithm’s main advantage is how simple it is to use and understand the clustering results. The algorithm’s complexity is O(K*n*d), making it very efficient from a computing standpoint []. 
Using this number, we may join the data point to the nearest cluster. When a new data point is added to a cluster, a new mean is calculated using the items already distributed among clusters, which raises the level of intra-cluster similarity. The data items are then reassigned using the new mean. Repeat this process multiple times until stability is attained. The goal of the K-Means method is to reduce the total squared error threshold [,,]. The problem of the basic formulation of the number of clusters at the computation inception is one of the key concerns with K-Means clustering algorithms. There is not a reliable, all-encompassing strategy for determining how many clusters and how many partitions to start with. According to reports, the K-means algorithm is particularly sensitive to the initial centroid selection, which might lead to the production of a less-than-ideal solution [].
- Miscellaneous clustering techniques:
Miscellaneous clustering technique includes time series mode seeking and streaming clustering techniques.
Time series clustering: time series clustering, similar to stable data clustering, needs a clustering method or technique to build clusters given a set of unordered items, and the selection of the clustering algorithm relies on both kind of information provided and the specific goal and purpose. Discrete-valued and real-valued data, uniform and non-uniform sampling, univariate and multivariate data, and data series of equal and unequal length are all various types of time series data. Before performing clustering procedures, non-uniformly sampled data must be transformed into uniform data. This may be accomplished in several ways, from straightforward down sampling based on the roughest sampling interval to a complex modeling and estimate strategy [].
Streaming clustering: a data stream is a vast, continually arriving series of multidimensional objects that is unlimited and quickly changing over time []. Since a data stream is limitless, it cannot be kept in memory or on a disc and is thus constrained to only do one pass over the data. Additionally, the order in which data arrives cannot be controlled, and objects cannot be accessed at random. Due to these limitations, traditional clustering algorithms are unable to manage the clustering issues associated with data streams [], demanding the use of streaming clustering techniques. The number of clusters and handling outliers are two of the three main issues [] highlighted as being unique to streaming clustering methods. Third, data streams are inherently unpredictable. In order to account for the ever-evolving aspect of streaming content, clusters produced using streaming classification techniques must be updated in real-time. A data stream is unlimited, therefore assuming a set number of clusters will be rather constrained. The cluster configuration is an ongoing process. Because both clusters and outliers change over time, it is difficult to recognize them as quickly as an object is detected a data stream. Other difficulties of streaming data that really are universal to data procedures and yet still apply to broadcast clustering include the single-stage constraints discussed above, the low computing time, which governs the fast response of the computation algorithm, and the limited computation, which also allows us to work with essential summary data.
Mode seeking clustering algorithm: the value that appears the most frequently in data collection is returned by the central tendency measure known as the mode. Both qualitative and quantitative qualities can be used to define the mode, and more than one mode may exist in a single data set. Clusters are produced using estimated density functions in mode-seeking clustering algorithms [,]. These modes represent the probability density functions’ local maxima. Associating data samples with the closest modes in mode-seeking clustering results in the assignment of cluster labels []. Clusters are built automatically in mode seeking clustering technique with the number of detected modes. Mode-seeking clustering may be thought of as an agglomerative method; according to [], every mode defines one group of data points and a density function is approximate for the dataset (every data point is used to start a new iteration of a mean shift algorithm). The density gradient from each item is tracked to determine which mode it belongs to during the clustering phase. It is said to be that a particular cluster is a place of those items that were in the same mode. According to this method, the number of clusters and the number of modes might be the same [,]. Both the mean shift process [] and the K-NN mode search procedure [] were explored in [], both of which make use of non-parametric density estimations. The width parameter in each of the two methods affects how many modes are included in the density estimate, with clustering being considered.
2.2.3. Mixture Resolving Algorithms
The assumption made by the mixture-based method, also known as the mixture resolving algorithm, is that a group of observed objects originates from a combination of examples from several probability clusters. In order to produce each observed item, a probabilistic cluster is picked in accordance with the cluster’s probability. After that, a sample is selected based on the selected cluster’s probability density function. The data set is taken to be a combination of a certain number of distinct cluster groups that were clustered in varied proportions. The mixture likelihood-based method of clustering is model-based since it requires the pre-specification of each component’s observational component density. To cluster samples from a population [] noted that the statistical model to be employed must be specified or understood beforehand. Due to the similarity among model-based and mixture-based, simple regression concepts may be used to do prediction evaluation and hypotheses development. The mixture likelihood-based strategy, according to [] is "probably the only clustering technique that is totally adequate from the mathematical point of view." It assumes a well-specified mathematical model, explores it using well-known statistical techniques, and offers a test of the result’s significance. A mixture-based method can readily determine the optimal number of clusters since it has a solid probabilistic foundation. Thus, according to [], several of the advantages of the mixture model is that it successfully combines different data sets using different scientific methods. However, the processing complexity is significant, and the assumptions made about the distribution of the data are rather strong. Additionally, each cluster is seen as a single simple distribution, which limits the formation of the cluster [].
- Expectation maximization
In data-driven methods developed, the EM technique for estimation methods has been frequently employed. EM is a statistical inference technique that guarantees the conditional probability will converge []. According to the parameters of the probabilistic clusters, objects are allocated to clusters in the expectation stage, and in the maximization stage, a new grouping or feature is found that improves the projected probability. Given the initial values drawn at random for the parameters of the probabilistic distribution, such as through and until the metric aligns or the shift is negligible, the average, the standard deviation, the E-step, and the M-step are repeated at regular intervals. The chance that each item belongs to each distribution is determined during clustering, and the probabilistic distribution parameter is changed to maximize the predicted likelihood of each cluster object in the M-step. The EM method requires several calculations for each iteration. As a result of this iterative calculation, the amount of data points and combination components scaled linearly, limiting the EM algorithm’s applicability for large-scale applications [,]. The EM technique is straightforward since it does not need the setting of any factors that might influence the optimization process [].
3. Comparison of Partitional and Hierarchical Clustering Algorithm
We reviewed the techniques and compared them in Table 1. The partitional methods, e.g., k-means, are generally simple, but they can only be used for certain kinds of data (convex shape). However, the clusters they create are not very reliable. However, hierarchical approaches generate very accurate clusters despite their great complexity (O(n2)) similarly the complexity of the partitional algorithm is O(n(d + k)). Furthermore, there is no global objective function for optimization in these approaches. Parameters such as k-means are used as input in many partitioning and hierarchical clustering methods and can thus impact the outcome. Results suffer if these parameters are poorly selected. Each stand-alone technique is tailored to a distinct subset of information. That is why they are so effective at handling targeted information. For some datasets, not even picking the best clustering techniques with the right settings of parameters will do. The largest datasets that contain an outlier sometimes yield poor results from even the most powerful clustering approaches. A persistent difficulty in the field of data science is the development of a clustering approach that reliably resolves all possible datasets and discovers findings with little complexity.
 
       
    
    Table 1.
    Compression of some of partitional and hierarchical clustering algorithms.
  
4. Challenges Still Exist in the Field of Clustering Algorithms
Determining the a priori number of clusters is a significant obstacle in cluster analysis. This difficulty arises because of a scarcity of experience in the relevant field. It also happens when there are several groups inside the dataset and those groups vary in size, density, and form. Although many people have worked on this issue, it is still difficult to solve. To address this issue, future research might investigate naturally-inspired algorithms []. Beyond non-automatic clustering, it was hypothesized in [] that automated clustering problems may be solved with the use of approaches inspired by nature, such as bacterium forage efficiency, fireflies’ improvement, and force of gravity learning algorithms. In addition, the authors disclosed that only a small number of research ever considered hybrid nature-inspired algorithms. Traditional methods and those inspired by nature can be used to create cluster-based algorithms with improved efficiency and speed. Clustering algorithms that take cues from nature should be hybridized by combining similar algorithms in an elegant and performance-enhancing method to achieve better results. In addition, swarm intelligence-based clustering algorithms for tackling NP-hard issues in computational biology have only recently begun to be investigated []. Many additional unanswered questions about cluster analysis may be found in the scholarly literature, some of them are addressed in the following section.
4.1. Computational Complexity
While effective, certain clustering methods may be too computationally intensive to use on large-scale datasets with a high-dimensional feature map. The issue can be fixed by boosting the output of computing resources using high-capacity GPUs []. Moreover, it is possible that improved clustering algorithms can be designed using parallel computing to make use of the advantages it offers. Clustering methods based on parallel computing tend to be highly beneficial, but face the obstacle of complexity in implementation, as revealed by two distinct research [,]. As an alternative to parallel processing, MapReduce-based clustering techniques exist. Clustering techniques based on MapReduce are quicker and more scalable. To improve scalability and performance, they can implement clustering algorithms on GPU-based MapReduce frameworks.
4.2. Refinement of Clusters
In many cases, the clusters produced by a clustering operation need to be refined further, either using the same clustering technique or with a different clustery process. Objects that were incorrectly grouped due to ineffective similarity metrics may be relocated to the cluster where they fit best thanks to this improvement. The divisive technique is one type of clustering that uses both monothetic and polythetic approaches to the cluster refining process. The earlier method relied on the use of a single property to divide a cluster, whereas the latter method considered all available attributes. We viewed these methods as evidence that other strategies can be developed to boost cluster quality. Concerning the potential consequences of incorrectly categorizing things into clusters in potentially life-threatening contexts, this refining problem emerges as required. Hybrids of such algorithms may be considered for optimal execution of the refining work, which can increase the applicability of metaheuristic algorithms.
4.3. Speed of Convergence
Oftentimes, the clusters that arise from a clustering operation need to be refined further, either using the same clustering technique or with a different clustery approach. The purpose of this improvement is to move items that were incorrectly grouped owing to ineffective similarity metrics into the cluster where they belong. The divisive technique is one type of clustering that takes a two-pronged approach to the refining process of clusters, using both monothetic and polythetic means. The earlier type of cluster splitting relied on the use of a single attribute, whereas the latter type used a combination of attributes. We viewed this as evidence that other methods can develop to enhance cluster quality. The consequences of incorrectly grouping things into clusters can have fatal consequences, making this refining issue a pressing one. In fact, hybrids of metaheuristic algorithms may be considered for optimal execution of the refining job, which would increase the application of such algorithms.
4.4. Data Dimensionality
Several techniques, including K-means, GMM clustering, maximum-margin clustering, and information-theoretic clustering, have trouble dealing with strong datasets. By projecting the actual information into a fairly low domain, clustering on the characteristic embedding, e.g., sparse code, can improve all of these problems [].
4.5. Missing Values
During the process of collecting data from a wide variety of sources, including sensors, digital devices, machines, and people, these sources produce significant volumes of data in a very short period of time. However, collecting data is not always a simple operation, and in certain cases it might result in values being absent from the data []. Incomplete or missing data may obscure the true answers that lie under the surface. They are also capable of hindering the algorithms’ overall performance.
4.6. Effectiveness and Scalability
Researchers in the field of big data clustering have a lot to learn about how to make it more effective and scalable. Deep learning has been proposed as a method for overcoming this difficulty. To further boost their efficiency, clustering algorithms might rely less on user-dependent factors. This means that in the future, researchers may consider specific needs for each area and build an algorithm that meets all of them. In addition, new clustering algorithms can be developed in the future as a result of a study into the creation of remedies for some of the fundamental difficulties of both automated and non-automatic clustering. Further study can also lead to the development of more effective algorithms to handle unexpected input without requiring a complete re-training.
4.7. Data Object Representation
It is also difficult for clustering algorithms to accurately describe data objects. Inappropriate data object representation is a problem. Additionally, there is a disparity in the representation of data items between domains. Data objects may be represented in a number of different ways, with some being represented as feature vectors and others as graphs with an associated concept of object similarity []. Distinctions in data object representation between domains of use provide a fruitful field for study. Finding an effective data representation in clustering operations is important since it improves the efficiency of clustering algorithms. By highlighting these pockets of concentrated data, the clustering technique may be made more robust and used on a larger scale. Locating sections of data that can be compressed, regions that can remain in main memory without swapping, and regions that can be ignored due to noise or lack of relevance to the results of a clustering procedure are all helpful.
4.8. Evaluation Measures
Different clustering algorithms may be evaluated and compared using a variety of parameters, including accuracy, algorithm stability, and dataset normalization []. Additionally, there is a requirement for the development of algorithmic techniques for comparing various clustering strategies with respect to several validity indices, including internal, stability, and biological indices []. Despite the fact that [] highlighted that a single algorithm would not fulfill all assessment metrics, beginning with one algorithmic solution might lead to more hybridized or robust solutions.
4.9. Data Streams
The clustering procedure is more difficult than clustering on static data because of clustering’s unique nature. Several difficulties with clustering approaches on data streams were identified by []. Methods of clustering should be robust enough to handle the presence of outliers and other forms of noise. To aid in the study of trends in data streams, clustering algorithms should have the ability to precisely recognize the change in context and grouping of flowing data items. Clustering algorithms’ computing capabilities and memory space optimization should also increase as the number of data streams generated from various sources, such as social networks, grows. To further adapt current context-based adaptive clustering algorithms and develop models for clustering dynamic data streams, more study is needed.
4.10. Knowledge Extraction
Clustering also faces difficulties in extracting useful information from large datasets. The rise in data creation and storage is to blame []. Terabytes and petabytes of data provide a significant hurdle for the data analyst because of this issue. Knowledge extraction from large datasets has limitations that can be solved with more research. Current methods, such as distributed clustering and parallel evolutionary algorithms, need improvement. In addition, future research can build novel clustering algorithms that can pick and decide among single-objective and multi-objective optimizations.
5. Conclusions and Future Directions
Clustering has found widespread use in data mining and analysis across several disciplines, computer science, data science, statistics, pattern recognition, artificial intelligence, and machine learning, and so on. The most basic issue in cluster analysis is determining the number of clusters beforehand. Many clustering issues may be solved more effectively if the right number of clusters is specified in advance. This is why automated clustering methods are becoming the norm rather than the exception. To perform clustering without needing any prior knowledge of data sets, automated clustering techniques were developed. They can also determine how many groups should be included in a noisy dataset. This research provides a thorough and current overview of both classic and cutting-edge clustering techniques. Both researchers and practitioners may learn from this study. 
Furthermore, future research might examine the qualities of various clustering techniques and how both maps efficiently tackle problems in other application fields, as well as the uniqueness of the difficulties faced in those sectors. Furthermore, future research might look at the use of newer or even hybrid clustering algorithms in a chosen subject based on the numerous tendencies highlighted in this study. Researchers and professionals can use the information in this study as a starting point for developing new, more effective, and efficient clustering algorithms.
Author Contributions
Conceptualization, S.P.; methodology, S.P.; software, S.P.; validation, Z.S.; formal analysis, Z.S.; investigation, S.P.; resources, S.P.; data curation, S.P.; writing—original draft preparation, S.P.; writing—review and editing, Z.S.; visualization, Z.S.; supervision, T.A.; project administration, T.A.; funding acquisition, T.A. All authors have read and agreed to the published version of the manuscript.
Funding
This research work is supported and funded by Universiti Teknologi PETRONAS (UTP) under the YUTP grant scheme with the cost center of 015LC0-350.
Institutional Review Board Statement
Not applicable.
Informed Consent Statement
Not applicable.
Data Availability Statement
Not applicable.
Acknowledgments
The authors would like to thank Universiti Teknologi PETRONAS (UTP) for all the support provided for this research work.
Conflicts of Interest
The authors declare no conflict of interest.
References
- Jain, A.K. Data clustering: 50 years beyond K-means. Pattern Recognit. Lett. 2010, 31, 651–666. [Google Scholar] [CrossRef]
- Abualigah, L.M.Q. Feature Selection and Enhanced Krill Herd Algorithm for Text Document Clustering; Springer: Berlin/Heidelberg, Germany, 2019. [Google Scholar]
- Zhou, Y.; Wu, H.; Luo, Q.; Abdel-Baset, M. Automatic data clustering using nature-inspired symbiotic organism search algorithm. Knowl. Based Syst. 2019, 163, 546–557. [Google Scholar] [CrossRef]
- Abualigah, L.M.; Khader, A.T.; Hanandeh, E.S. A new feature selection method to improve the document clustering using particle swarm optimization algorithm. J. Comput. Sci. 2018, 25, 456–466. [Google Scholar] [CrossRef]
- Tan, P.-N.; Steinbach, M.; Kumar, V. Introduction to Data Mining Pearson Education India; Indian Nursing Council: New Delhi, India, 2018. [Google Scholar]
- Chang, D.-X.; Zhang, X.-D.; Zheng, C.-W.; Zhang, D.-M. A robust dynamic niching genetic algorithm with niche migration for automatic clustering problem. Pattern Recognit. 2010, 43, 1346–1360. [Google Scholar] [CrossRef]
- Aliniya, Z.; Mirroshandel, S.A. A novel combinatorial merge-split approach for automatic clustering using imperialist competitive algorithm. Expert Syst. Appl. 2019, 117, 243–266. [Google Scholar] [CrossRef]
- Ezugwu, A.E.; Shukla, A.K.; Agbaje, M.B.; Oyelade, O.N.; José-García, A.; Agushaka, J.O. Automatic clustering algorithms: A systematic review and bibliometric analysis of relevant literature. Neural Comput. Appl. 2021, 33, 6247–6306. [Google Scholar] [CrossRef]
- Plant, C.; Böhm, C. Novel Trends in Clustering. In Evolving Application Domains of Data Warehousing and Mining: Trends and Solutions; IGI Global: Hershey, PA, USA, 2010; pp. 185–211. [Google Scholar]
- Benabdellah, A.C.; Benghabrit, A.; Bouhaddou, I. A survey of clustering algorithms for an industrial context. Procedia Comput. Sci. 2019, 148, 291–302. [Google Scholar] [CrossRef]
- Dryden, N.; Böhringer, R.; Ben-Nun, T.; Hoefler, T. Clairvoyant prefetching for distributed machine learning I/O. In Proceedings of the International Conference for High Performance Computing, Networking, Storage and Analysis, St. Louis, MO, USA, 14–19 November 2021; pp. 1–15. [Google Scholar]
- Khan, A.; Paul, A.K.; Zimmer, C.; Oral, S.; Dash, S.; Atchley, S.; Wang, F. Hvac: Removing I/O Bottleneck for Large-Scale Deep Learning Applications. In Proceedings of the 2022 IEEE International Conference on Cluster Computing (CLUSTER), Heidelberg, Germany, 5–8 September 2022; pp. 324–335. [Google Scholar]
- Fahad, A.; Alshatri, N.; Tari, Z.; Alamri, A.; Khalil, I.; Zomaya, A.Y.; Foufou, S.; Bouras, A. A survey of clustering algorithms for big data: Taxonomy and empirical analysis. IEEE Trans. Emerg. Top. Comput. 2014, 2, 267–279. [Google Scholar] [CrossRef]
- Berkhin, P.; Beche, J.D.; Randall, D.J. Interactive path analysis of web site traffic. In Proceedings of the Seventh ACM SIGKDD International Conference on Knowledge Discovery and Data Mining, San Francisco, CA, USA, 26–29 August 2001; pp. 414–419. [Google Scholar]
- Saxena, A.; Prasad, M.; Gupta, A.; Bharill, N.; Patel, O.P.; Tiwari, A.; Er, M.J.; Ding, W.; Lin, C.-T. A review of clustering techniques and developments. Neurocomputing 2017, 267, 664–681. [Google Scholar] [CrossRef]
- Dafir, Z.; Lamari, Y.; Slaoui, S.C. A survey on parallel clustering algorithms for big data. Artif. Intell. Rev. 2021, 54, 2411–2443. [Google Scholar] [CrossRef]
- Sharif, Z.; Jung, L.T.; Ayaz, M.; Yahya, M. Priority-based Task Scheduling and Resource Allocation in Edge Computing for Health Monitoring System. J. King Saud Univ. Comput. Inf. Sci. 2023. [Google Scholar] [CrossRef]
- Nagpal, A.; Jatain, A.; Gaur, D. Review based on data clustering algorithms. In Proceedings of the 2013 IEEE Conference on Information & Communication Technologies, Thuckalay, India, 11–12 April 2013; pp. 298–303. [Google Scholar]
- Oyelade, J.; Isewon, I.; Oladipupo, F.; Aromolaran, O.; Uwoghiren, E.; Ameh, F.; Achas, M.; Adebiyi, E. Clustering algorithms: Their application to gene expression data. Bioinform. Biol. Insights 2016, 10, 237–253. [Google Scholar] [CrossRef] [PubMed]
- Jain, A.K.; Dubes, R.C. Algorithms for Clustering Data; Prentice-Hall, Inc.: Hoboken, NJ, USA, 1988. [Google Scholar]
- Sharif, Z.; Jung, L.T.; Ayaz, M.; Yahya, M.; Pitafi, S. A Taxonomy for Resource Management in Edge Computing, Applications and Future Realms. In Proceedings of the 2022 International Conference on Digital Transformation and Intelligence (ICDI), Kuching, Sarawak, Malaysia, 1–2 December 2022; pp. 46–52. [Google Scholar]
- Ezugwu, A.E. Nature-inspired metaheuristic techniques for automatic clustering: A survey and performance study. SN Appl. Sci. 2020, 2, 273. [Google Scholar] [CrossRef]
- Bindra, K.; Mishra, A. A detailed study of clustering algorithms. In Proceedings of the 2017 6th International Conference on Reliability, Infocom Technologies and Optimization (Trends and Future Directions)(ICRITO), Noida, India, 20–22 September 2017; pp. 371–376. [Google Scholar]
- Djouzi, K.; Beghdad-Bey, K. A review of clustering algorithms for big data. In Proceedings of the 2019 International Conference on Networking and Advanced Systems (ICNAS), Annaba, Algeria, 26–27 June 2019; pp. 1–6. [Google Scholar]
- Xu, D.; Tian, Y. A comprehensive survey of clustering algorithms. Ann. Data Sci. 2015, 2, 165–193. [Google Scholar] [CrossRef]
- Singh, S.; Srivastava, S. Review of Clustering Techniques in Control System: Review of Clustering Techniques in Control System. Procedia Comput. Sci. 2020, 173, 272–280. [Google Scholar] [CrossRef]
- Murtagh, F.; Contreras, P. Algorithms for hierarchical clustering: An overview. Wiley Interdiscip. Rev. Data Min. Knowl. Discov. 2012, 2, 86–97. [Google Scholar] [CrossRef]
- Olson, C.F. Parallel algorithms for hierarchical clustering. Parallel Comput. 1995, 21, 1313–1325. [Google Scholar] [CrossRef]
- Jain, A.K.; Murty, M.N.; Flynn, P.J. Data clustering: A review. ACM Comput. Surv. 1999, 31, 264–323. [Google Scholar] [CrossRef]
- Murtagh, F. A survey of algorithms for contiguity-constrained clustering and related problems. Comput. J. 1985, 28, 82–88. [Google Scholar] [CrossRef]
- Sharif, Z.; Jung, L.T.; Ayaz, M. Priority-based Resource Allocation Scheme for Mobile Edge Computing. In Proceedings of the 2022 2nd International Conference on Computing and Information Technology (ICCIT), Tabuk, Saudia Arabia, 25–27 January 2022; pp. 138–143. [Google Scholar]
- Müllner, D. Modern hierarchical, agglomerative clustering algorithms. arXiv 2011, arXiv:1109.2378. [Google Scholar]
- Gowda, K.C.; Krishna, G.J.P.R. Agglomerative clustering using the concept of mutual nearest neighbourhood. Pattern Recognit. 1978, 10, 105–112. [Google Scholar] [CrossRef]
- Rathore, P. Big Data Cluster Analysis and Its Applications. Ph.D. Thesis, University of Melbourne, Parkville, Victoria, Australia, 2018. [Google Scholar]
- Xu, R.; Wunsch, D. Survey of clustering algorithms. IEEE Trans. Neural Netw. 2005, 16, 645–678. [Google Scholar] [CrossRef] [PubMed]
- Sibson, R. SLINK: An optimally efficient algorithm for the single-link cluster method. Comput. J. 1973, 16, 30–34. [Google Scholar] [CrossRef]
- Defays, D. An efficient algorithm for a complete link method. Comput. J. 1977, 20, 364–366. [Google Scholar] [CrossRef]
- Voorhees, E.M. Implementing agglomerative hierarchic clustering algorithms for use in document retrieval. Inf. Process. Manag. 1986, 22, 465–476. [Google Scholar] [CrossRef]
- Murtagh, F. A survey of recent advances in hierarchical clustering algorithms. Comput. J. 1983, 26, 354–359. [Google Scholar] [CrossRef]
- Day, W.H.; Edelsbrunner, H. Efficient algorithms for agglomerative hierarchical clustering methods. J. Classif. 1984, 1, 7–24. [Google Scholar] [CrossRef]
- Sharif, Z.; Jung, L.T.; Razzak, I.; Alazab, M. Adaptive and priority-based resource allocation for efficient resources utilization in mobile edge computing. IEEE Internet Things J. 2021. [Google Scholar] [CrossRef]
- Savaresi, S.M.; Boley, D.L.; Bittanti, S.; Gazzaniga, G. Cluster Selection in Divisive Clustering Algorithms. In Proceedings of the 2002 SIAM International Conference on Data Mining, Arlington, VA, USA, 11–13 April 2002; pp. 299–314. [Google Scholar]
- Boley, D. Principal direction divisive partitioning. Data Min. Knowl. Discov. 1998, 2, 325–344. [Google Scholar] [CrossRef]
- Chavent, M.; Lechevallier, Y.; Briant, O. DIVCLUS-T: A monothetic divisive hierarchical clustering method. Comput. Stat. Data Anal. 2007, 52, 687–701. [Google Scholar] [CrossRef]
- Karypis, G.; Kumar, V. Multilevel k-way hypergraph partitioning. In Proceedings of the 36th Annual Acm/Ieee Design Automation Conference, New Orleans, LA, USA, 21–25 June 1999; pp. 343–348. [Google Scholar]
- Zhong, C.; Miao, D.; Wang, R.; Zhou, X. DIVFRP: An automatic divisive hierarchical clustering method based on the furthest reference points. Pattern Recognit. Lett. 2008, 29, 2067–2077. [Google Scholar] [CrossRef]
- Feng, L.; Qiu, M.-H.; Wang, Y.-X.; Xiang, Q.-L.; Yang, Y.-F.; Liu, K. A fast divisive clustering algorithm using an improved discrete particle swarm optimizer. Pattern Recognit. Lett. 2010, 31, 1216–1225. [Google Scholar] [CrossRef]
- Macnaughton-Smith, P.; Williams, W.; Dale, M.; Mockett, L.J.N. Dissimilarity analysis: A new technique of hierarchical sub-division. Nature 1964, 202, 1034–1035. [Google Scholar] [CrossRef] [PubMed]
- Kaufman, L.; Rousseeuw, P.J. Finding Groups in Data: An Introduction to Cluster Analysis; John Wiley & Sons: Hoboken, NJ, USA, 2009. [Google Scholar]
- Wang, Y.; Yan, H.; Sriskandarajah, C. The weighted sum of split and diameter clustering. J. Classif. 1996, 13, 231–248. [Google Scholar] [CrossRef]
- Guénoche, A.; Hansen, P.; Jaumard, B. Efficient algorithms for divisive hierarchical clustering with the diameter criterion. J. Classif. 1991, 8, 5–30. [Google Scholar] [CrossRef]
- Sneath, P.H. Thirty years of numerical taxonomy. Syst. Biol. 1995, 44, 281–298. [Google Scholar] [CrossRef]
- Williams, W.T.; Lambert, J.M. Multivariate methods in plant ecology: I. Association-analysis in plant communities. J. Ecol. 1959, 47, 83–101. [Google Scholar] [CrossRef]
- Brito, P.M.; Chavent, M. Divisive Monothetic Clustering for Interval and Histogram-Valued Data. In Proceedings of the ICPRAM 2012-1st International Conference on Pattern Recognition Applications and Methods, Algarve, Portugal, 6–8 February 2012; pp. 229–234. [Google Scholar]
- Zhu, J. Divisive Hierarchical Clustering for Interval-Valued Data. Ph.D. Thesis, University of Georgia, Athens, GA, USA, 2019. [Google Scholar]
- Kim, J.; Billard, L. A polythetic clustering process and cluster validity indexes for histogram-valued objects. Comput. Stat. Data Anal. 2011, 55, 2250–2262. [Google Scholar] [CrossRef]
- Ahmad, A.; Dey, L. A k-mean clustering algorithm for mixed numeric and categorical data. Data Knowl. Eng. 2007, 63, 503–527. [Google Scholar] [CrossRef]
- Dinh, D.-T.; Fujinami, T.; Huynh, V.-N. Estimating the Optimal Number of Clusters in Categorical Data Clustering By Silhouette Coefficient. In Proceedings of the International Symposium on Knowledge and Systems Sciences, Singapore, 29 December 2019; pp. 1–17. [Google Scholar]
- Zadeh, L.A. Fuzzy sets. Inf. Sci. 1965, 8, 338–353. [Google Scholar] [CrossRef]
- Vidal, R. Subspace clustering. IEEE Signal Process. Mag. 2011, 28, 52–68. [Google Scholar] [CrossRef]
- Parsons, L.; Haque, E.; Liu, H. Subspace clustering for high dimensional data: A review. Acm Sigkdd Explor. Newsl. 2004, 6, 90–105. [Google Scholar] [CrossRef]
- Deshmukh, H.S.; Ramteke, P. Comparing the Techniques of Cluster Analysis for Big Data. Int. J. Adv. Res. Comput. Eng. Technol. 2015, 4. [Google Scholar]
- Wharton, S.W. A generalized histogram clustering scheme for multidimensional image data. J Pattern Recognition 1983, 16, 193–199. [Google Scholar] [CrossRef]
- Leland McInnes, J.H.; Astels, S. Comparing Clustering Algorithms Using Python. Available online: https://hdbscan.readthedocs.io/en/latest/comparing_clustering_algorithms.html#hdbscan (accessed on 11 January 2023).
- Sanse, K.; Sharma, M. Clustering methods for Big data analysis. Int. J. Adv. Res. Comput. Eng. Technol. 2015, 4, 642–648. [Google Scholar]
- Fraley, C.; Raftery, A.E. How many clusters? Which clustering method? Answers via model-based cluster analysis. Comput. J. 1998, 41, 578–588. [Google Scholar] [CrossRef]
- Agarwal, P.; Alam, M.A.; Biswas, R. Issues, challenges and tools of clustering algorithms. arXiv 2011, arXiv:1110.2610. [Google Scholar]
- José-García, A.; Gómez-Flores, W. Automatic clustering using nature-inspired metaheuristics: A survey. Appl. Soft Comput. 2016, 41, 192–213. [Google Scholar] [CrossRef]
- Agrawal, R.; Gehrke, J.; Gunopulos, D.; Raghavan, P. Automatic subspace clustering of high dimensional data. Data Min. Knowl. Discov. 2005, 11, 5–33. [Google Scholar] [CrossRef]
- Ray, S. A Quick Review of Machine Learning Algorithms. In Proceedings of the 2019 International Conference on Machine Learning, Big Data, Cloud and Parallel Computing (COMITCon), Faridabad, India, 14–16 February 2019; pp. 35–39. [Google Scholar]
- Hartigan, J.A.; Wong, M.A. Algorithm AS 136: A k-means clustering algorithm. J. R. Stat. Soc. Ser. C 1979, 28, 100–108. [Google Scholar] [CrossRef]
- MacQueen, J. Classification and Analysis of Multivariate Observations. In Proceedings of the 5th Berkeley Symposium on Mathematical Statistics and Probability, Berkeley, CA, USA, 18–21 June 1967; pp. 281–297. [Google Scholar]
- Liao, T.W. Clustering of time series data—A survey. Pattern Recognit. 2005, 38, 1857–1874. [Google Scholar] [CrossRef]
- Mansalis, S.; Ntoutsi, E.; Pelekis, N.; Theodoridis, Y. An evaluation of data stream clustering algorithms. Stat. Anal. Data Min. ASA Data Sci. J. 2018, 11, 167–187. [Google Scholar] [CrossRef]
- Gama, J.; Gaber, M.M. Learning from Data Streams: Processing Techniques in Sensor Networks; Springer: Berlin/Heidelberg, Germany, 2007. [Google Scholar]
- Comaniciu, D.; Meer, P. Mean shift: A robust approach toward feature space analysis. IEEE Trans. Pattern Anal. Mach. Intell. 2002, 24, 603–619. [Google Scholar] [CrossRef]
- Fukunaga, K.; Hostetler, L. The estimation of the gradient of a density function, with applications in pattern recognition. IEEE Trans. Inf. Theory 1975, 21, 32–40. [Google Scholar] [CrossRef]
- Sasaki, H.; Kanamori, T.; Hyvärinen, A.; Niu, G.; Sugiyama, M. Mode-seeking clustering and density ridge estimation via direct estimation of density-derivative-ratios. J. Mach. Learn. Res. 2018, 17–380. [Google Scholar]
- Duin, R.P.; Fred, A.L.; Loog, M.; Pękalska, E. Mode seeking clustering by KNN and mean shift evaluated. In Proceedings of the Joint IAPR International Workshops on Statistical Techniques in Pattern Recognition (SPR) and Structural and Syntactic Pattern Recognition (SSPR), Hiroshima, Japan, 7–9 November 2012; pp. 51–59. [Google Scholar]
- Carreira-Perpinán, M.A. A review of mean-shift algorithms for clustering. arXiv 2015, arXiv:1503.00687. [Google Scholar]
- Myhre, J.N.; Mikalsen, K.Ø.; Løkse, S.; Jenssen, R. Robust clustering using a kNN mode seeking ensemble. Pattern Recognit. 2018, 76, 491–505. [Google Scholar] [CrossRef]
- Aitkin, M.; Rubin, D.B. Estimation and hypothesis testing in finite mixture models. J. R. Stat. Soc. Ser. B 1985, 47, 67–75. [Google Scholar] [CrossRef]
- Marriott, F.H.C. Interpretation of Multiple Observations; Academic Press: Cambridge, MA, USA, 1974. [Google Scholar]
- Grira, N.; Crucianu, M.; Boujemaa, N. Unsupervised and semi-supervised clustering: A brief survey. A Rev. Mach. Learn. Tech. Process. Multimed. Content 2004, 1, 9–16. [Google Scholar]
- Sammaknejad, N.; Zhao, Y.; Huang, B. A review of the expectation maximization algorithm in data-driven process identification. J. Process Control. 2019, 73, 123–136. [Google Scholar] [CrossRef]
- Verbeek, J. Mixture Models for Clustering and Dimension Reduction. Ph.D. Thesis, Universiteit van Amsterdam, Amsterdam, The Netherlands, 2004. [Google Scholar]
- Das, S.; Abraham, A.; Konar, A. Swarm intelligence algorithms in bioinformatics. In Computational Intelligence in Bioinformatics; Springer: Berlin/Heidelberg, Germany, 2008; pp. 113–147. [Google Scholar]
- Shirkhorshidi, A.S.; Aghabozorgi, S.; Wah, T.Y.; Herawan, T. Big data clustering: A review. In Proceedings of the International Conference on Computational Science and Its Applications, Guimarães, Portugal, 30 June–3 July 2014; pp. 707–720. [Google Scholar]
- Zerhari, B.; Lahcen, A.A.; Mouline, S. Big data clustering: Algorithms and challenges. In Proceedings of the International Conference on Big Data, Cloud and Applications (BDCA’15), Tetuan, Morocco, 25–26 May 2015. [Google Scholar]
- Wang, Z.; Chang, S.; Zhou, J.; Wang, M.; Huang, T.S. Learning a Task-Specific Deep Architecture for Clustering. In Proceedings of the 2016 SIAM International Conference on Data Mining, Miami, FL, USA, 5–7 May 2016; pp. 369–377. [Google Scholar]
- Dinh, D.-T.; Huynh, V.-N.; Sriboonchitta, S. Clustering mixed numerical and categorical data with missing values. Inf. Sci. 2021, 571, 418–442. [Google Scholar] [CrossRef]
- Bouveyron, C.; Hammer, B.; Villmann, T. Recent developments in clustering algorithms. In Proceedings of the ESANN, Bruges, Belgium, 25–27 April 2012; pp. 447–458. [Google Scholar]
- Kokate, U.; Deshpande, A.; Mahalle, P.; Patil, P. Data stream clustering techniques, applications, and models: Comparative analysis and discussion. Big Data Cogn. Comput. 2018, 2, 32. [Google Scholar] [CrossRef]
| Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content. | 
© 2023 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (https://creativecommons.org/licenses/by/4.0/).
