Next Article in Journal
An Effective Blockchain-Based Defense Model for Organizations against Vishing Attacks
Next Article in Special Issue
A System Dynamics Approach to Optimize Milk Production in an Industrial Ranch
Previous Article in Journal
Model Test Analysis of Subsurface Cavity and Ground Collapse Due to Broken Pipe Leakage
Previous Article in Special Issue
Expert System and Decision Support System for Electrocardiogram Interpretation and Diagnosis: Review, Challenges and Research Directions
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Improved SOSK-Means Automatic Clustering Algorithm with a Three-Part Mutualism Phase and Random Weighted Reflection Coefficient for High-Dimensional Datasets

by
Abiodun M. Ikotun
1 and
Absalom E. Ezugwu
1,2,*
1
School of Computer Science, University of KwaZulu-Natal, Pietermaritzburg Campus, Pietermaritzburg 3201, South Africa
2
Unit for Data Science and Computing, North-West University, 11 Hoffman Street, Potchefstroom 2520, South Africa
*
Author to whom correspondence should be addressed.
Appl. Sci. 2022, 12(24), 13019; https://doi.org/10.3390/app122413019
Submission received: 30 October 2022 / Revised: 5 December 2022 / Accepted: 15 December 2022 / Published: 19 December 2022
(This article belongs to the Special Issue Evolutionary Algorithms and Large-Scale Real-World Applications)

Abstract

:
Automatic clustering problems require clustering algorithms to automatically estimate the number of clusters in a dataset. However, the classical K-means requires the specification of the required number of clusters a priori. To address this problem, metaheuristic algorithms are hybridized with K-means to extend the capacity of K-means in handling automatic clustering problems. In this study, we proposed an improved version of an existing hybridization of the classical symbiotic organisms search algorithm with the classical K-means algorithm to provide robust and optimum data clustering performance in automatic clustering problems. Moreover, the classical K-means algorithm is sensitive to noisy data and outliers; therefore, we proposed the exclusion of outliers from the centroid update’s procedure, using a global threshold of point-to-centroid distance distribution for automatic outlier detection, and subsequent exclusion, in the calculation of new centroids in the K-means phase. Furthermore, a self-adaptive benefit factor with a three-part mutualism phase is incorporated into the symbiotic organism search phase to enhance the performance of the hybrid algorithm. A population size of 40 + 2 g was used for the symbiotic organism search (SOS) algorithm for a well distributed initial solution sample, based on the central limit theorem that the selection of the right sample size produces a sample mean that approximates the true centroid on Gaussian distribution. The effectiveness and robustness of the improved hybrid algorithm were evaluated on 42 datasets. The results were compared with the existing hybrid algorithm, the standard SOS and K-means algorithms, and other hybrid and non-hybrid metaheuristic algorithms. Finally, statistical and convergence analysis tests were conducted to measure the effectiveness of the improved algorithm. The results of the extensive computational experiments showed that the proposed improved hybrid algorithm outperformed the existing SOSK-means algorithm and demonstrated superior performance compared to some of the competing hybrid and non-hybrid metaheuristic algorithms.

1. Introduction

Data clustering is an aspect of data mining where knowledge discovery from data requires that the data reveals the existing groups within itself. In cluster analysis, objects are grouped such that the intra-cluster distances among data objects are minimized while the inter-cluster distances are maximized. K-means is one of the most popular traditional clustering algorithms used for cluster analysis, due to its efficiency and simplicity. The k-means algorithm randomly selects a specified k number of initial cluster centroids as a representative center of each group. It then assigns data objects to their nearest cluster, based on the sum of squares point to nearest centroid distance. The mean of each cluster is calculated to generate an initial cluster with an updated cluster centroid. These data object assignment and centroid update processes are iteratively repeated until an optimum cluster solution is obtained. The need to specify the number of clusters a priori makes the K-means algorithm unsuitable for automatic clustering. According to [1], estimating the optimal number of clusters in a dataset is a fundamental problem in cluster analysis, referred to as ‘automatic clustering’. In most cases, K-means is hybridized with metaheuristic algorithms for automatic clustering [2].
The standard K-means algorithm is sensitive to noisy data and outliers [3,4]. Intuitively, the data points that are far away from their nearest neighbors are described as outliers [5]. The sensitivity of K-means to noise and outliers comes from the least square optimization procedure, normally employed for cluster analysis. K-means’ reliance on the outlier-sensitive statistics (mean) for cluster updates compromises the clustering results when outliers are present in datasets. Several proposals have been reported in the literature that add a separate module for detecting and removing outliers as a data pre-processing step embedded in the K-means algorithm, before the actual data clustering procedure. A separate module for outlier detection significantly compromises the efficiency of the K-means algorithm. Chawla and Gionis [6] proposed an algorithm that simultaneously detected and removed outliers from the dataset during the clustering process, eliminating the need for a separate module. Their algorithm incorporated outlier detection into the K-means algorithm without complicated modification to the standard algorithm. However, their algorithm required specifying the desired number of outliers within the dataset, like how the desired number of clusters had to be specified. Olukanmi et al. [7] proposed a K-means variant for automatic outlier detection with the automatic specification of the number of clusters via Chebyshev-type inequalities. This paper incorporated this automatic detection and exclusion of outliers in the centroid update process of the standard K-means section of SOSK-means for a more robust hybridized algorithm.
The symbiotic organisms search (SOS) algorithm is a nature-inspired metaheuristic algorithm proposed by [8]. The algorithm has no basic control algorithm-specific parameter in its initialization stage. It works similarly to other well-known metaheuristic algorithms, such as the genetic algorithm (GA), the particle swarm optimization (PSO) algorithm, and the firefly algorithm (FA). The algorithm is inspired by the symbiotic relationships among organisms in a natural habitat, necessary to their survival in the ecosystem. The three symbiotic relationships (mutualism, commensalism, and parasitism) are modeled to find optimal solutions to optimization problems. As a population-based algorithm, the first two phases (mutualism and commensalism) use the best solution to exploit the population information in searching for potential solutions. The parasitism phase creates new solutions by modifying the existing solution, while, at the same time, removing inferior solutions [9]. The SOS algorithm is rated among the most competitive swarm intelligence-based metaheuristic algorithms for solving optimization algorithms, based on its simplicity and parameter-less attributes. SOS has been used to find the solution to many different real-world problems [10,11,12,13,14,15,16]. Tejani et al. [17] introduced a parameter setting of the beneficial factor, based on the normalized value of organisms, to create an adaptive SOS algorithm for structural optimization problems. A discrete version of SOS was designed and implemented by [18] for task scheduling in a cloud computing environment. Cheng, Prayogo and Tran [11] introduced another discrete SOS for multiple resources leveling optimization. Panda and Pani [10] introduced multi-objective SOS for handling multi-objective optimization problems. Kawambwa et al. [12] proposed a cloud-based model SOS using cloud-based theory to generate random number operators in the mutualism phase for power system distributed generators. Mohammadzadeh and Gharehchopogh [19] proposed three variants of SOS to solve the feature selection challenge, and Cheng, Cao, and Herianto [14] proposed an SOS optimized neural network–long short-term memory for obtaining hyperparameters of the neural network and long short-term memory for the establishment of a robust hybridization model for cash flow forecasting.
SOS has also been employed in solving automatic clustering problems [20,21,22,23,24,25]. Boushaki, Bendjeghaba, and Kamel [20] proposed a biomedical document clustering solution using accelerated symbiotic organisms search, which required no parameter tuning. Yang and Sustrino [25] proposed a clustering-based solution for high-dimensional optimization problems using SOS with only one control parameter. Chen, Zhang, and Ning proposed an adaptive clustering-based algorithm using SOS for automatic path planning of heterogeneous UAVs [22]. Zainal and Zamil [23] proposed a novel solution for software module clustering problems using a modified symbiotic organism search with levy flights. The effectiveness of the SOS algorithm in solving automatic clustering problems was demonstrated by [21], where the SOS algorithm was used in clustering different UCI datasets. SOS has been hybridized with other metaheuristic algorithms for performance enhancement in cluster analysis. Rajah and Ezugwu [24] combined the SOS algorithm with four different metaheuristic algorithms to solve the automatic clustering problem and compared the clustering performances of each hybrid algorithm. Our earlier work combined the SOS algorithm with K-means to boost the traditional clustering algorithm’s performance for automatic clustering [26].
However, SOS exhibits some limitations, such as slow convergence rate and high computational complexity [17,26,27,28]. Modifications have been made to the standard SOS to improve its performance. Tejani, Savsani and Patel [17] introduced adaptive benefit factors to the classical SOS algorithm, proposing three modified variants of SOS for improved efficiency. Adaptive benefit factors and benefit factors were effectively combined to achieve a good exploration–exploitation balance in the search space. Nama, Saha, and Ghosh [27] introduced a random weighted reflective parameter, to enhance searchability within the additional predation phase, to the classical SOS algorithm to improve the solving of multiple complex global optimization problems and improve the algorithm’s performance. Secui [29] sought to improve the algorithm’s capacity for the timely identification of stable and high-quality solutions by introducing new relations for solution updates at the mutualism and commensalism phases. A logistic map-generated chaotic component for finding promising zones was also added for the enhancement of the algorithm’s exploration capacity. The removal of the parasitism phase reduced the computational load. Nama, Saha, and Ghosh [30] combined SOS with simple quadratic interpolation (SQI) for handling large-scale and real-world problems. Although their proposed hybrid SOS algorithm increased the algorithms’ complexity, it provided an efficient and effective quality solution, with an improved convergence rate. Ezugwu and Adewumi [31] improved and extended the classical SOS using three mutation-based local search operators to improve population reconstruction, exploration, and exploitation capability and to accelerate the convergence speed. Other improvements reported in the literature include [32,33,34,35,36,37,38]. According to Chakraborty, Nama, and Saha [9], most of the proposed improvements could not guarantee finding the best optimal solution. As such, they proposed using a non-linear benefit factor where the mutual vector was calculated, based on the weights of two organisms for a broader and more thorough search. They also altered the parasitism phase to reduce the computational burden of the algorithm.
This paper proposes an improved version of the hybrid SOSK-means algorithm [24], called ISOSK-means, to address the common limitations of the individual classical algorithms and their hybridization variants for a more robust, efficient, and stable hybrid algorithm. The algorithm adopted a population size of 40 + 2 g for a well distributed initial population sample, based on the assumption that selecting the right sample size produces a sample mean that approximates the true centroid on Gaussian distribution [39]. This ensured a substantially large population size at each iteration for early convergence in the SOS phase of the hybrid algorithm. The modified algorithm also employed a global threshold of point-to-centroid distance distribution in the K-means algorithm phase to detect outliers for subsequent exclusion in calculating the new centroids [3]. The detection and exclusion of outliers in the K-means phase assisted in improving the cluster result. The performance of the SOS algorithm was enhanced by introducing self-adaptive benefit factors, with a three-part mutualism phase, as suggested in [28]. These techniques enhanced the search for the optimum centroids in the solution space and improved the convergence rate of the hybrid algorithm. The performance of the proposed algorithm was evaluated on 42 datasets with varying sizes and dimensions. Davies Bouldin (DB) index [40] and cluster separation (CS) index [41] were used as cluster validity indices for evaluating the performance of the algorithm. The choice of the two clustering validity indices was based on the duo’s cluster validity approach of minimizing the intra-cluster similarity and maximizing the inter-cluster similarity, which is the same as the primary objective of data clustering. The CS index was only applied to 12 datasets for comparison with the classical version of the improved hybrid algorithm. The two indices, based on their validity approach, are credited with the ability to produce clusters that are well separated, with the minimum intra-cluster distance and maximum inter-cluster distance [42,43,44]. The DB index can guide the clustering algorithm using a partitioning approach without the need to specify the number of clusters, and the CS index is known for its excellent performance in the identification of clusters with varying densities and sizes [40,41,43]. The enhanced outcomes were compared with the existing hybrid SOSK-means algorithm and other comparative non-hybrid and hybrid metaheuristic algorithms on large dimensional datasets. The performance of the proposed improved hybrid algorithm was further validated using the nonparametric Friedman mean rank tests and Wilcoxon signed-rank statistical tests. The results of the extensive computational experiments showed that the proposed improved hybrid algorithm (ISOSK-means) outperformed the existing SOSK-means algorithm, and demonstrated superior performance over some of the competing hybrid and non-hybrid metaheuristic algorithms. The main contributions of this paper are as follows:
  • Integration of a robust module in the proposed SOS-based K-means hybrid algorithm using outlier detection and the exemption technique in the K-means phase for a more effective cluster analysis with compact clusters.
  • Integration of a three-part mutualism phase with a random weighted reflection coefficient into the SOS phase, for a more productive search in the solution space for early convergence and reduced computational time.
Adopting a population size of 40 + 2 g for a well-distributed initial population in the SOS phase, allowing for a large enough solution space per iteration, aimed to ensure early convergence of the proposed clustering algorithm.
The remaining sections of this paper are organized as follows. Section 2 presents related work on hybrid algorithms involving SOS and K-means. It also includes a brief introduction to the standard K-means algorithm, standard SOS algorithm and hybrid SOSK-means. Section 3 describes the improvements integrated into the K-means and SOS algorithms and presents the description of the proposed ISOSK-means. The simulation and comparison of results of the proposed ISOSK-means are presented in Section 4, while Section 5 presents the concluding remarks and suggestions for future directions.

2. Related Work

There are existing works in the literature that reported hybridizations involving either K-means or symbiotic organism search or both. However, it is worth stating here that hybridizations for clustering problems are few. In [45], the SOS algorithm was hybridized with the improved opposition-based learning firefly algorithm (IOFA) to improve the exploitation and exploration of IOFA. SOS was combined with differential evolution (DE) in [46] to improve the convergence speed and optimal solution quality of shape and size truss structure optimization in engineering optimization problems. The conventional butterfly optimization algorithm (BOA) was combined with the first two phases of the SOS for enhancement of global and local search behavior of the BOA. In [47], a modified strategy of SOS was hybridized with the mutation strategy of the DE to ensure the preservation to the SOS local search capability, while maintaining its ability to conduct global search. Other reported hybrids involving SOS include the following: Ref. [48] combined GA, PSO and SOS algorithms for continuous optimization problems; Ref. [24] reported four hybrid algorithms for automatic clustering, combining SOS with FA, for teaching–learning based optimization (TLBO), DE, and PSO algorithms. Other hybridization algorithms involving SOS can be found in the review work on SOS algorithms conducted by [49].
Several hybridizations involving K-means with other metaheuristic algorithms were reported in the review work presented by [2]. Recent hybridizations involving K-means include the following: Ref. [50] combined GA with K-means and support vector machine (SVM) for automatic selection of optimized cluster centroid and hyperparameters tunning; Ref. [51] combined multi-objective individually directional evolutionary algorithm (IDEA) with K-means for multi-dimensional medical data modeling using fuzzy cognitive maps; Ref. [52] presented an hybrid of K-means with PSO for semantic segmentation of agricultural products; Ref. [53], combined K-means algorithm with particle swarm optimization for customer segmentation.
For hybridization involving SOS and K-means, as mentioned earlier, the reported literature works are very minimal showing that research in this aspect is still shallow. In [25], a clustering-based SOS for high-dimensional optimization problems was proposed, combining an automatic K-means with symbiotic organism search for efficient computation and better searching quality. The automatic K-means was used to generate subpopulations for the SOS algorithm to create a sub-ecosystem that made the combination of global and local searches possible. The mutualism and commensalism phases formed the local search, where solutions were allowed to interact within each cluster. For the global search, only best solutions from each cluster were allowed to interact across the clusters under the parasitism phase. In this case, the K-means algorithm was used as a pre-processing phase for the SOS algorithm to enhance its performance in finding solutions to high dimensional optimization problems. In [26], the standard algorithms SOS and K-means were combined to solve automatic clustering problems. The SOS phase resolved the initialization challenge for the K-means algorithm by automatically determining the optimum number of clusters and generating the corresponding initial cluster centers. This ensured the K-means algorithm avoided the possibility of local optimum convergence while improving the cluster analysis capability of the algorithm. However, the problem of low convergence persisted in the hybrid algorithm.
In this work, we hoped to further improve on the clustering performance of the previous SOS-based K-means hybrid algorithm in [26] for automatic clustering of high-dimensional datasets, by incorporating some improvements into each of the standard algorithms, SOS and K-means, so as to achieve better convergence and more compact clusters.

2.1. K-Means Algorithm

The K-means algorithm is a partitional clustering algorithm that iteratively groups a given dataset X in Rd into k number of clusters C 1 ,   C 2 , C 3 , , C k   such that:
C i ;
1 k C i = X
C i C j   i ,   j 1 , 2 , , k   a n d   i   j
based on a specified fitness function. The K-means algorithm handles the partitioning process as an optimization problem to minimize the within-cluster variance σ :
σ = x X min c c C | | x c c | | 2  
with cluster center c c i   uniquely defining each cluster as:
c c i = 1 | C i | x C i x
with the set of k   centres
C C = { c c 1 , , c c k }
representing the solution to the K-means algorithm [54].
The standard K-means algorithm involves three major phases: the initialization phase, the assignment phase, and the centroid update phase. During the initialization phase, the initial cluster centers are randomly selected to represent each cluster. This is followed by the data object assignment phase, where each data point in the dataset is then assigned to the nearest cluster, based on the shortest centroid-point distance. Each cluster centroid is then re-evaluated during the centroid update phase. The last two phases are repeated until the centroid value remains constant in consecutive iterations [44].
The K-means clustering is an NP-hard optimization problem [55], with the algorithm having a time complexity of O ( n k t ) , where n represents the number of data points in the dataset, k represents the number of clusters, and t denotes the number of iterations required for convergence. The computational complexity is a function of the size of the dataset, hence, clustering large real-world, or dynamic, datasets using the K-means algorithm incurs a sizeable computational time overhead. Moreover, the number of clusters k is required to be a user-specified parameter for the K-means algorithm. In most real-world datasets, the number of clusters is not known a priori; therefore, specifying the correct number of clusters in such a dataset is arduous. Furthermore, the random selection of initial cluster centroids incurs the possibility of the algorithm getting stuck in the local optimum [54]. Based on these challenges, many variants of K-means have been proposed in the literature [2,4] to improve the performance of the K-means algorithm. One of the areas being exploited for improving the standard K-means algorithm is hybridizing K-means with metaheuristic algorithms [2].

2.2. SOS Algorithm

Cheng and Prayogo [8] proposed the concept of SOS simulating the interactive relationships between organisms in an ecosystem. In an ecosystem, most organisms do not live in isolation because they need to interact with other organisms for their survival. These relationships between organisms, known as symbiotic relationships, are, thus, defined using three possible major interactions: mutualism, commensalism, and parasitism. Mutualism represents a symbiotic relationship where the participating organisms benefit from each other. For instance, an oxpecker feeds on the parasites living on the body of a zebra or rhinoceros, while the symbiont, in turn, enjoys the benefit of pest control. Commensalism describes a relationship where only one of the participating organisms benefits from the association while the other organism does not benefit from the relationship, although it is not negatively affected either. An example of this is orchids, which grow on branches and trunks of trees to access sunlight and obtain nutrients from the branches. As a slim, tender plant, their existence does not harm the tree on which they grow. The relationship between humans and mosquitos provides a perfect scenario of the parasitism symbiotic relationship, in which one of the organisms (mosquito) benefits from the association while simultaneously causing harm to the symbiont (human). These three relationships are captured in the SOS algorithm [8]. In most cases, the type of relationship increases the fitness of benefiting organisms, giving them a long-term survival advantage.
In the SOS algorithm, the three-symbiosis relationship is simulated as the three phases of the algorithm. At the initial stage, a population of candidate solutions are randomly generated to the search space for solution representations for optimal global solution search. This set of solutions forms the initial ecosystem. where each individual candidate solution represents an organism in the ecosystem. A fitness value is associated with each organism to determine the measure of its adaptation capability with respect to the desired objective. Subsequently, each candidate solution is further updated using the three simulated symbiotic relationship phases to generate a new solution. For each phase, a new solution is only accepted if its fitness value is better than the previous one. Otherwise, the initial solution is retained. This iterative optimization process is performed until the termination criteria are met. The three simulated symbiotic relationship phases of the SOS algorithm are described below.
Given two organisms x i and x j co-existing in an ecosystem such that i and j represent the iterative values of the optimization, ranging from 1   to d , where d is the problem dimension and i j , an organism, x j , is randomly selected during the mutualism phase to participate in a mutual relationship with x i   such that the two organisms enjoy a common benefit from their interaction for survival. Their interaction yields new solutions x i n e w and x j n e w based on Equations (7) and (8), respectively, with Equation (9) representing the mutual benefit x m u t u a l enjoyed by both organisms.
x i n e w = x i + r a n d ( 0 , 1 ) × ( x b e s t x m u t u a l × B F 1 )
x j n e w = x j + r a n d ( 0 , 1 ) × ( x b e s t x m u t u a l × B F 2 )
x m u t u a l = x i + x j 2
The expression ( x b e s t x m u t u a l × B F 1 ) as shown in Equations (7) and (8), represents the mutual survival efforts exhibited by each organism to remain in the ecosystem. The highest degree of adaptation achieved in the ecosystem is represented by the x b e s t which acts as the target point for increasing the fitness of the two interacting organisms. Each organism’s benefit level of value 1 or 2 is randomly determined to indicate the organism’s benefit from the relationship, which can either be full or partial. This benefit level is denoted as BF (benefit factor) in the equations. The BF value is generated using Equation (10):
B F = 1 + r o u n d [ r a n d ( 0 , 1 ) ]
As stated earlier, the newly generated solutions are accepted as a replacement for the existing solution if, and only if, they are better. In other words, new solutions are rejected if the existing solutions are better. Equations (11) and (12) incorporate this:
x i n e w = x i + r a n d ( 0 , 1 ) × ( x b e s t x m u t u a l × B F 1 )   i f   f ( x i n e w ) < f ( x i   )
x j n e w = x j + r a n d ( 0 , 1 ) × ( x b e s t x m u t u a l × B F 2 )   i f   f ( x j n e w ) < f ( x j   )
In simulating the commensalism phase, an organism x j is randomly selected for interaction with organism x i exhibiting the characteristic of the commensalism symbiosis relationship where only one of the two organisms x i derives a benefit from the relationship. This relationship is simulated using Equation (13):
x i n e w = x i + r a n d ( 1 , 1 ) × ( x b e s t x j   )   i f   f ( x i n e w ) > f ( x i   )  
Thus, only the benefiting organisms generate a new solution, as reflected by Equation (10). The new solution is accepted only if it is better, in terms of fitness, than the previous solution before the interaction.
The parasitism phase is the last phase, which is simulated using Equation (14). In simulating the parasitism symbiotic relationship in the SOS algorithm, a duplicate copy of the x i organism is created as a parasite vector with some of its selected dimensions modified using a random number. An organism x j is then randomly selected from the ecosystem to play host to the parasite vector x p a r a s i t e . If the fitness value of x p a r a s i t e is better than that of x j , then x p a r a s i t e replaces x j in the ecosystem. If the opposite happens, and x j builds immunity against x p a r a s i t e , then x p a r a s i t e is removed from the ecosystem:
x p a r a s i t e = r a n d ( 0 , 1 ) × ( U B L B   ) + L B  

2.3. Description of Data Clustering Problem

In data clustering problems, data objects sharing similar characteristics are grouped together into a cluster, such that data objects in one cluster are different from data objects in other clusters. In most cases, the number of clusters is specified, while in some cases, especially in high dimensional datasets, predetermining the number of clusters is not feasible. In optimization terms, data objects are clustered, based on the similarity or dissimilarity between them, such that the inter-cluster similarity is minimized (maximizing inter-cluster dissimilarity), while maximizing the intra-cluster similarity (or minimizing intra-cluster dissimilarity). The description of a clustering problem as an optimization problem is given below.
Given a dataset X = ( x 1 ,   x 2 , x n ) of dimension d   which represents the number of attributes or features of the data objects in the datasets such that x i   ( i = 1 , 2 , , n )   where n is the number of data objects in the dataset. Each data object x i = ( x i 1 ,   x i 2 ,   , x i d ) , where x i 1 ,   x i 2 ,   , x i d represents all the features for data object x i . The dataset X can be represented in a matrix form as shown in Equation (15):
X = [ x 1 x 2 x i x n ] = [ x 1 , 1 x 2 , 1 x 1 , 2 x 2 , 2 x i , 1 x n , 1 x i , 2 x n , 2 x 1 , d x 2 , d x i , j x i , d x n , d ]
X is required to be grouped into k number of clusters to satisfy Equations (1)–(3), using Equation (4) as the objective function, with each cluster having a cluster center defined in Equations (5) and (6). For an automatic clustering, the number of clusters is not defined. Therefore, finding the optimum number of clusters represented by equation (6) becomes the optimization problem that seeks to optimize the function f ( C C ,   D ) over all possible clustering of X where function f represents the global validity index for obtaining the best quality clustering solution and D represents the distance metric measure, stated in Equation (4).

2.4. Cluster Validity Indices

The cluster validity indices are qualitative methods, like the statistical mathematical functions, for evaluating the clustering quality of a clustering algorithm. A cluster validity index has the capacity to accurately determine the cluster number in a dataset, as well as find the proper structure of each cluster in the dataset [56]. The principal concerns of most validity indices in clustering are to determine clustering compactness, separation, and cohesion. The cluster validity indices are presented as the fitness function during the optimization process of the clustering algorithms. The DB index and CS index are used as the cluster validity indices to evaluate the quality of the clustering results.
The DB index determines the quality of a clustering result by using the average inter-cluster similarity between any two clusters and the intra-cluster similarity between data objects within a cluster. The average intra-cluster similarity value is evaluated against the average inter-cluster similarity value using Equations (16) and (17). In the DB index, the fitness function is minimized during the data clustering. This implies that a smaller index value indicates better compactness or separation, and vice versa:
f d b i = 1 K K 1 d ( c c i , c c j )  
d ( c c i , c c j ) = m a x { w c d i s t ( i ) w c d i s t ( j ) i c d i s t ( i j )   | 1 i , j K ,   i j }
where w c d i s t ( i ) and w c d i s t ( j ) represent the within-cluster distance for clusters i and j , i c d i s t ( i j ) represents the inter-cluster distance between the two clusters i and j . The d ( c c i , c c j ) is the inter-cluster distance between the two cluster centroids c c i   and   c c j of the respective clusters i and j .
The CS index estimates the quality of a clustering result by finding the ratio of the sum of the intra-cluster scatter to the inter-cluster separation using Equation (18):
f c s i = i = 1 K [ 1 | C i | w c s c a t ( i ) i C i m a x b c s e p ( j ) j C i { d ( w c s c a t ( i ) , b c s e p ( j ) ) } ]   1 K i = 1 K [ m i n j K ,   j i   { V ( c c i ,   c c j ) } ]
where w c s c a t ( i )   and   b c s e p ( j ) represents within-cluster scatter and between-cluster separation with the distance measure given as d ( w c s c a t ( i ) , b c s e p ( j ) ) . The CS index is rated as being more computationally intensive but more efficient, compared with the DB index, and gives a more quality solution than the DB index. In the CS index, the fitness function is also minimized, therefore a lower validity index implies better separation or compactness, while a higher index value implies weak separation or compactness.

2.5. Hybrid SOSK-Means

A hybridization of SOS and K-means proposed by [26] found the solution to the automatic clustering algorithm. The proposed algorithm employed the standard SOS algorithm to globally search for the optimum initial cluster centroids for the K-means algorithm. This resolved the problems associated with the random generation of the initial cluster centroid without initial specification of the value of k . The problem of multiple parameter controls required in most nature-inspired population-based metaheuristic algorithms (e.g., GA, PSO, FA) was also avoided, since the SOS required only the basic control parameters for a metaheuristic algorithm, such as the number of iterations and population size, with no algorithm-specific parameters. The SOS as a global search algorithm ensured that K-means returned a global optimum solution to the clustering problem, canceling the possibility of getting stuck in the local optimum. According to [26], the SOSK-means algorithm combined the local exploitation capability of the standard K-means with less parameter tuning and global exploration, as provided by the SOS algorithm with implementation simplicity common to the two algorithms, to produce a powerful, efficient, and effective automatic clustering algorithm. The resulting hybrid algorithm was credited with better cluster solutions than the results from the standard SOS and K-means algorithms executed separately.
The SOSK-means algorithm commences by initializing the population of 𝑛 organisms representing the ecosystem, randomly generated using Equation (19), and the fitness value of each organism is calculated based on the fitness function for the optimization process. The initial organisms are generated by the expression r a n d ( 1 , K × m )   in the equation, representing random and uniformly distributed points within the ecosystem, the solution search space is bounded between specified lower and upper limits a and b , respectively, for the clustering problem:
x i = r a n d ( 1 , K × m ) × ( b a ) + a   i = 1 , 2 , , n  
New candidate solutions are subsequently generated using the three phases of the SOS algorithm, described under the SOS algorithm. The optimum result from the phases of the SOS algorithm is passed as the optimum cluster centroids for initializing the K-means algorithm. These processes are iteratively performed until the stopping criterion is achieved. The details on the design and performance of hybrid SOSK-means can be found in [26]. Algorithm 1 presents the pseudocode for the hybrid SOSK-means algorithm. The flowchart for Algorithm 1 can be found in [26].
Algorithm 1: Hybrid SOSK-means clustering pseudocode [26]
Input:Eco_size: population size          ULSS: upper limit for search space
   Max_iter: maximum number of iterations  LLSS: lower limit for search space
   PDim: problem dimension          ObjFn(X): fitness (objective) function
Output: Optimal Solution
1: Create an initial population of organisms X =   ( X 1 , X 2 , …, X e c o s i z e )
2: Calculate the fitness of each organism
3: Keep the initial population’s best solution   B e s t X
4:  while i t e r   M a x _ i t e r
5:   for  i = 1   t o   E c o _ s i z e  do
6:    // 1st Phase: Mutualism //
7:    Select index j ( 1   j E c o _ s i z e ; j i )   randomly
8:       B F 1 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) ) )
9:     B F 2 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) ) )
10:      X m u t u a l = ( X i + X j 2 )
11:     for  k = 1   t o   P D i m do
12:      X i n e w = X i + r a n d ( 0 , 1 ) ( B e s t X B F 1 X m u t u a l )
13:      X j n e w = X j + r a n d ( 0 , 1 ) ( B e s t X B F 2 X m u t u a l )
14:     end for
15:     if  ( O b j F n ( X i n e w ) < O b j F n ( X i )
16:      X i = X i n e w  
17:    end if
18:     if  ( O b j F n ( X j n e w ) < O b j F n ( X j )
19.      X j = X j n e w  
20:     end if
21:     // 2nd Phase: Commensalism //
22:    Select index j   ( 1   j E c o _ s i z e ; j i ) randomly
23:     for k = 1   t o   P D i m  do
24:      X i n e w = X i + r a n d ( 1 , 1 ) ( B e s t X X j )
25:     end for
26:     if   O b j F n ( X i n e w ) <   O b j F n ( X i   )
27:      X i = X i n e w
28:     end if
29:     //3rd Phase: Parasitism //
30:     Select index j ( 1   j E c o _ s i z e ; j i )   randomly
31:     for k = 1   t o   P D i m  do
32:     if  r a n d ( 0 , 1 ) < r a n d ( 0 , 1 )
33:       X p a r a s i t e =     X i
34:     else
35:       X p a r a s i t e =     r a n d ( 0 , 1 ) ( U L S S [ K ] L L S S ) + L L S S
36:     end if
37:     end for
38:     if  O b j F n ( X p a r a s i t e ) <   O b j F n ( X j )
39:      X j = X p a r a s i t e
40:     end if
41:     Update current population’s best solution BestX
42:     //K-means Clustering Section//
43:     K-means’ initialization using the position of the BestX
44:     Execute K-means clustering
45:   end for
46:    iter = iter + 1
47:   end while

3. Modified SOSK-Means

The adoption of standard SOS and K-means algorithms in the hybrid SOSK-means combines the benefits of the two classical algorithms to produce an efficient algorithm. However, some of the individual challenges of the two algorithms remain. The SOSK-means algorithm still suffers from the low convergence rate peculiar to the classical SOS algorithm. The computational time is affected by the dataset size as it is with the classical K-means clustering. The proposed ISOSK-means follows the structure of the original SOSK-means algorithm, described in Section 2.2, with a few modifications incorporated into the two classical algorithms to further enhance the performance of the hybrid algorithm. The summary flowchart for ISOSK-means is shown in Figure 1.

3.1. Modification in the SOS Phase

The modifications in the SOS phase affect three major parts of the standard algorithm, the initialization phase, the mutualism phase, and the commensalism phase. During the initialization phase, the population size is required to be specified as an input parameter. This is common to most metaheuristic algorithms, with no specific rule for determining the best population size for optimum algorithm performance. In the improved SOSK-means, the rule for determining the population size suggested by [39] was adopted. The population size was constructed as 40 + 2 g where g > 1 , representing the minimum number of possible groupings of the datasets for an optimum search in the metaheuristic algorithm to achieve a well-distributed space for initial population of solutions that scales well with the data size. In this work, the value for g was given as 2 . The idea was coined from generalizing the central limit theorem (CLT) for a mixture distribution that infers sample population parameters. The central limit theorem states [57] that the mean (average) of a random sample follows a normal distribution as the mean, μ and variance, σ of the population from which it is selected According to [39], the selection of a data sample having a size that is sufficiently large enough to be well above the total number of clusters has a high possibility of containing data objects that belong to each of the clusters. At each iteration, new population samples are randomly selected as initial populations. The use of the population size of 40 + 2 g ensured that the initial selection of candidate solutions was well spread across the solution search space for the generation of optimum values in the SOS phase for a faster search for the optimum cluster centroids, which, subsequently, served as the K-means algorithm’s initial centroids [39]. The different initial population samples at each iteration in the optimization process represented the varied samples of the initial solution space. Selecting such a sufficiently large population size has a high probability of containing the cluster centroids for all the clusters within the dataset. This invariably increased the convergence rate of the SOS algorithm, and the computational time was, consequently, reduced.
To upgrade the SOS algorithm’s performance, a three-part mutualism phase, with the random weighted reflection coefficient introduced by [28], was incorporated. Three-part mutualism reflects the possibility of three organisms interacting mutually, each deriving benefits that sustain their existence in the ecosystem. A three-part mutual relationship can be observed in the interaction between sloths, algae, and moths. A three-part mutualism is incorporated alongside the use of two interacting organisms in the mutualism phase. In three-part mutualism, three organisms are chosen randomly in the ecosystem to interact for the generation of newer organisms. Each organism is simulated using Equations (20)–(22), respectively. Their mutual benefits are simulated using Equation (23), involving contributions from the three organisms. At the commencement of the mutualism phase for the organism’s update, a random probability is used to determine whether an organism will be engaged in three-part mutualism or not. Thus, a choice is required between the normal dual mutualism interaction and the three-part mutualism. The flowchart depicting the three-part mutualism phase is shown in Figure 2.
x i n e w = x i + r a n d ( 0 , 1 ) × ( x b e s t x m u t u a l × M B F 1 )
x j n e w = x j + r a n d ( 0 , 1 ) × ( x b e s t x m u t u a l × M B F 2 )
x k n e w = x k + r a n d ( 0 , 1 ) × ( x b e s t x m u t u a l × M B F 3 )
x m u t u a l = x i + x j + x k 3
The BF is also modified using the modified benefit factor (MBF) in [28] to increase the quality of the solution. In the MBF, the relativity of the fitness value of each organism under consideration, with respect to the maximum fitness value, is incorporated to achieve a benefit factor that is self-adaptable. The MBF for each organism was simulated using Equations (24)–(26). This ensured the automatic maintenance of the values of the benefit factors throughout the search process.
M B F 1 = 1 + r a n d ( 0 , 1 ) × x 1 f i t n e s s M a x f i t n e s s ,     i f   B e s t f i t n e s s   0
M B F 2 = 1 + r a n d ( 0 , 1 ) × x 2 f i t n e s s M a x f i t n e s s ,     i f   B e s t f i t n e s s   0
M B F 3 = 1 + r a n d ( 0 , 1 ) × x 3 f i t n e s s M a x f i t n e s s ,     i f   B e s t f i t n e s s   0
The modified benefit factor (MBF) incorporated the possibility of variations in the actual benefits derived from the interactions, instead of the static 1 or 2 implemented in the standard SOS. As stated earlier, a benefit factor of 1 caused slow convergence by reducing the search step, while a benefit factor of 2 reduced the search ability by speeding up the search process. In the case of the MBF, the benefit accrued to an organism was a factor of its fitness with respect to the best fitness in the ecosystem.
Moreover, a random weight ( S i m R W ) , suggested by [28], for the SOS algorithm’s performance improvement was added to each dimension of the organism. The weight was simulated using Equation (27):
S i m R W j = 1 0.5 × ( 1 + r j 1   ) ,   r i   [ 0 , 1 ]   w h e r e   j = 1 , 2 , 3 , D

3.2. Modification in the K-Means Phase

The modification effected in the K-means phase of the improved SOSK-means algorithm addressed the misleading effects of outliers in the dataset, which usually affect the standard K-means algorithm at the centroids update stage. The use of the ‘average’ as the statistic for calculating the new cluster centroid was sensitive to outliers [3]. According to [58,59], K-means assume Gaussian data distribution, being an instance of the Gaussian mixture model. As such, about 99.73% of the data points within a cluster record point-to-centroid distances of three standard deviations ( σ ) from the cluster centroid. Therefore, any point with a point-to-centroid distance that is outside this range with respect to its cluster is considered an outlier. Subsequently, it is excluded in the computation of the centroid update.
According to [59], a standard deviation ( σ ) was taken to be 1.4826 of the median absolute deviation (MAD) for population distribution. The median absolute deviation gave a robust statistical dispersion measure and was more resilient to outliers than the standard deviation [60]. Given a point-to-centroid distance threshold   T p t c :
σ = 1.4826 M A D c i
M A D c i = m e d i a n | c i m e d i a n ( c i ) |
  T p t c = 3 σ
  T p t c = 3 ( 1.4826 M A D c i )
    T p t c = 4.4478 M A D c i
The centroid update was calculated using Equation (31) in the classical K-means:
μ i ( i t + 1 ) = 1 | C i ( i t ) |   x j ϵ C i x j  
However, in the improved SOSK-means,   T p t c was introduced for outlier detection and exclusion in the new centroid update using Equation (32):
μ i ( i t + 1 ) = 1 | C i ( i t ) | | C i o ( i t ) |   x j ϵ C i x j   : x j = 0   i f   | | x μ i | |   > T p t c
where C i o ( i t )   ϵ   C i ( i t ) represents the sets of points x j assigned to cluster C i ( i t ) which has a point-to-centroid distance of   | | x μ i | |   > T p t c . The main difference between Equations (31) and (32) is that in the latter equation, the sets of points assigned to a cluster with a point-to-centroid distance greater than thrice the standard deviation ( 3 σ ) were excluded from the centroid update calculation. This excluded the outliers from contributing to the mean square error that was being minimized. Algorithm 2 presents the pseudocode for the proposed improved SOSK-means algorithm.
Algorithm 2: The proposed improved SOSK-means Pseudocode
Eco_size: population size       ULSS: Upper limit for search space
Max_iter: maximum number of iterations  LLSS: Lower limit for search space
PDim: problem dimension      ObjFn(X): fitness (objective) function
Optimal Solution
1: Create an initial population of organisms X =   ( X 1 , X 2 , …, X e c o s i z e )
2: Calculate the fitness of each organism
3: Keep the initial population’s best solution   B e s t X
4: Keep the initial population’s maximum solution   X m a x
5: while i t e r     Max _ i t e r
6:   for  i = 1   t o   E c o _ s i z e  do
7:    // 1st Phase: Mutualism //
8:    Select index j  ( 1   j E c o _ s i z e ; j i )   randomly  
9:    Select index k  ( 1   k E c o _ s i z e ; k i ; k j )   randomly  
10:       r a n d 1 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) ) )
11:       r a n d 2 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) ) )
12:    if      r a n d 1 <     r a n d 2
13:      X m u t u a l = ( X i + X j 2 )
14:        S a B F 1 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) )   . ( O b j F n ( X i ) / ( X m a x ) )
15:        S a B F 2 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) )   . ( O b j F n ( X j ) / ( X m a x ) )
16:      R W R C =   (   1 0.5   r o u n d ( r a n d ( 0 , 1 ) )
17:      for  n = 1   t o   P D i m do
18:       X i n e w = X i + ( R W R C   . ( X b e s t (   X m u t u a l S a B F 1 ) ) )
19:      X j n e w = X j + ( R W R C   . ( X b e s t (   X m u t u a l S a B F 2 ) ) )
20:      end for
21:      if  ( O b j F n ( X i n e w ) < O b j F n ( X i )
22:       X i   = X i n e w
23:     end if
24:      if  ( O b j F n ( X j n e w ) < O b j F n ( X j )
25:         X j = X j n e w
26:      end if
27:    else
28:       X m u t u a l = ( X i + X j + X k 3 )
29:        S a B F 1 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) )   . ( O b j F n ( X i ) / ( X m a x ) )
30:       S a B F 2 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) )   . ( O b j F n ( X j ) / ( X m a x ) )
31:         S a B F 3 =   (   1 + r o u n d ( r a n d ( 0 , 1 ) )   . ( O b j F n ( X k ) / ( X m a x ) )
32:       R W R C =   (   1 0.5   r o u n d ( r a n d ( 0 , 1 ) )
33:     for   n = 1   t o   P D i m do
34:       X i n e w = X i + ( R W R C   . ( X b e s t (   X m u t u a l S a B F 1 ) ) )
35:       X k n e w = X k + ( R W R C   . ( X b e s t (   X m u t u a l S a B F 2 ) ) )
36:     end for
37:     if  ( O b j F n ( X i n e w ) < O b j F n ( X i )
38:       X i = X i n e w
39:     end if
40:     if  ( O b j F n ( X j n e w ) < O b j F n ( X j )
41:       X j = X j n e w
42:     end if
43:     if  ( O b j F n ( X k n e w ) < O b j F n ( X k )
44:       X k = X k n e w
45:     end if
46:     // 2nd Phase: Commensalism //
47:     Select index j  ( 1   j E c o _ s i z e ; j i )   randomly
48:      R W R C =   (   1 0.5   r o u n d ( r a n d ( 0 , 1 ) )
49:     for k = 1   t o   P D i m  do
50:      X i n e w = X i + R W R C ( B e s t X   X j )
51:     end for
52:     if   O b j F n ( X i n e w ) <   O b j F n ( X i   )
53:        X i = X i n e w  
54:     end if
55:     //3rd Phase: Parasitism //
56:     Select index j  ( 1   j E c o _ s i z e ; j i )   randomly  
57:     for k = 1   t o   P D i m  do
58:     if  r a n d ( 0 , 1 ) < r a n d ( 0 , 1 )
59:       X p a r a s i t e =     X i
60:     else
61:       X p a r a s i t e =     r a n d ( 0 , 1 ) ( U L S S [ K ] L L S S ) + L L S S
62:     end if
63:    end for
64:     if  O b j F n ( X p a r a s i t e ) <   O b j F n ( X j )
65:      X j = X p a r a s i t e
66:     end if
67:     Update the current population’s best solution of the BestX
68:     //K-means Clustering Phase//
69:     K-means initialization using the position of the BestX
70:     Execute K-means clustering using equation (32) for cluster update
71:    end for
72:    iter = iter + 1
73: end while

4. Performance Evaluation of Improved SOSK-Means

Forty-two datasets were considered for validating the proposed ISOSK-means algorithm for automatic clustering, of which 24 were real-life datasets and 18 were artificial datasets. All the algorithms were programmed using MATLAB R2018b, running on Windows 10 operating system, installed on a 3.60 GHz Intel® Core i7-7700 processor computer system with 16 GB memory size. For the study, the eco_size was set at 40 + 2 g . The algorithms were executed 40 times with 200 iterations in each run. The performance results are presented using the minimum, maximum, average, and standard deviation of the fitness values, as well as the average computational time. The improved SOSK-means algorithm’s effectiveness was measured and compared using the following criteria:
  • The average best fitness value measured the algorithm’s quality of the clustering solutions.
  • The performance speed used the algorithm’s computational cost and convergence curve.
  • The statistical significance difference was over 40 replications.
The results were compared with the standard K-means, the standard SOS algorithm, the existing SOSK-means and other state-of-the-art hybrid and non-hybrid metaheuristic algorithms. The best results among the compared algorithms are presented in bold format. The values of the common control parameters were the same for the K-means, standard SOS algorithm and the SOSK-means algorithms. The control parameters for the competing metaheuristic algorithms obtained from literature in [61] are shown in Table 1.

4.1. Datasets

During the experiment, 42 datasets were considered. The datasets were grouped into two groups: 18 synthetically generated datasets and 24 real-life datasets. The characteristics of the two categories of datasets are presented in Table 2 and Table 3, respectively.

4.1.1. The Synthetic Datasets

The synthetically generated datasets consisted of the A-datasets (three sets), Birch datasets (three sets), DIM (one set of a low dimensional dataset and seven sets of high dimensional datasets), and the S-generated datasets (four sets). The A datasets had an increasing number of clusters, while the Birch datasets had the number of clusters fixed at 100. The DIM datasets were characterized by well-separated clusters, with DIM002 having 9 predetermined clusters (with varying dimensions ranging from 2 to 15), while others had 16 clusters with dimensions ranging from 16 to 1024. The S1–S4 were two-dimensional datasets, characterized by varying spatial data distribution complexity with a uniform cluster of 15.

4.1.2. The Real-Life Datasets

The real-life datasets consisted of the following: eight shape sets (Aggregation, Compound, D31, Flame, Jain, Path-based, R15 and Spiral datasets); ten datasets from the UCI repository (Breast, Glass, Iris, Jain, Leaves, Letter, Thyroid, Wdbc, Wine and Yeast); two Mopsi locations datasets (Joensuu and Finland); two RGB images datasets (Housec5 and Housec8); one Gray-scale image blocks; and two miscellaneous datasets (T4.8k and Two moons). The real-life datasets had varying clusters, ranging from 2 to 256, their dimensions ranged between 2 and 64, and the number of data objects in the datasets ranged between 150 and 34,112.

4.2. Experiment 1

In the first set of experiments conducted, the improved SOSK-means was run on 12 datasets, initially used for the SOSK-means. These were Breast, Compound, Flame, Glass, Iris, Jain, Path-based, Spiral, Thyroid, Two moons, Wine, and Yeast datasets. The experimental results are summarized in Table 4, showing the values obtained by the ISOSK-means for each of the 12 datasets. The four decimal place values represented the minimum, the maximum, the mean value over 40 simulations and the standard deviations, which measured the range of values the algorithm converged. From the results obtained, the ISOSK-means returned the best mean values for four of the datasets (Compound, Jain, Thyroid, and two-moons) under the DB index, and eight of the datasets (Breast, Flame, Glass, Iris, Path-based, Spiral, Wine and Yeast) had the best mean values under the CS index. The average computational time for achieving convergence for each dataset by the improved algorithm is shown in Figure 3. Even though the CS index returned the best overall average results for the 12 datasets, this was at the expense of higher computational time.
Table 5 summarizes the simulated results for each of the four competing algorithms for the automatic clustering of the 12 real-life datasets. The results present the mean and the standard deviation for each algorithm. The values were obtained for the two cluster validity indices, the DB index, and the CS index.
As shown in Table 5, the ISOSK-means had the best mean score under the DB validity index in 11 of the 12 datasets, with a tie on the Breast dataset for three of the algorithms: ISOSK-means, SOSK-means and K-means. In the same vein, the ISOSK-means recorded the best mean scores under the CS validity index for the ISOSK-means in eight datasets with ties for two of the algorithms: SOSK-means and ISOSK-means, in four of the datasets (Flame, Glass, Jain, and Thyroid). The performance analysis of the four competing algorithms is shown in Figure 4 and Figure 5 for each cluster validity index. These results indicated that the ISOSK-means algorithm performed better than the other three competing algorithms.
The average execution times of the SOS, SOSK-means and ISOSK-means algorithms for 200 generations were presented separately for each validity index, as shown in Figure 6 and Figure 7. As expected, being a non-hybrid algorithm, the SOS recorded the lowest computational time under the two validity indices. Under the DB validity index, the ISOSK-means recorded a shorter average execution time than the SOSK-means in nine datasets. This indicated that the ISOSK-means required less execution time to achieve convergence. Under the CS validity index, the ISOSK-means recorded lower execution time in six datasets. Out of the remaining six, only three datasets showed a considerable difference in execution time for the two algorithms in favor of the SOSK-means. Since the CS index usually requires higher computational time, this result showed that the ISOSK-means substantially outperformed SOSK-means in terms of computational cost.
The convergence curve for the three algorithms, ISOSK-means, SOSK-means and SOS, are illustrated in Figure 8 and Figure 9 for the DB index and CS index, respectively. A rapid and smooth declining curve reflected a superior performance. In all 12 datasets, the ISOSK-means recorded the best performance with rapidly declining smooth curves under the two validity indices.

4.3. Experiment 2

In Experiment 2, an extensive performance evaluation of the ISOSK-means algorithm on 18 synthetic datasets was demonstrated. Table 6 shows the computational results from the experiment under the DB validity index, showing the best, the worst, the mean, and the standard deviation scores. The results of the ISOSK-means were compared with other existing hybrid algorithms from the literature [61] for the same problem in Table 7. The ISOSK-means recorded a better overall mean value for the 18 synthetic datasets, compared with the other hybrid metaheuristic algorithms. This showed that the mean performance of the improved hybrid algorithm was superior, compared with the competing hybrid metaheuristic algorithms, in solving the automatic clustering problem.

4.4. Experiment 3

In Experiment 3, the performance of the ISOSK-means algorithm on 23 real life datasets were evaluated. The computational results from the experiment under the DB validity index are shown in Table 8, showing the minimum, the maximum, the average, and the standard deviation scores for the ISOSK-means algorithm. The results were compared with other existing hybrid algorithms from the literature [61] for the same problem, as presented in Table 9. The ISOSK-means recorded a better mean value for the 23 real-life datasets than the other hybrid metaheuristic algorithms. This indicated that the improved hybrid algorithm performed better, on average, in solving the automatic clustering problem, compared with the competing hybrid metaheuristic algorithms. However, it is worth noting that FADE had the best clustering result in nine of the datasets. Nevertheless, the ISOSK-means recorded the least standard deviation in 18 datasets, with the least mean standard deviation score in all, showing that it produced more compact clusters than the competing hybrid metaheuristic algorithms.

4.5. Experiment 4

In this experiment, the ISOSK-means results were compared with other existing non-hybrid algorithms (DE, PSO, FA, IWO) from the literature [60] for the same problem, and the results are presented in Table 10. The ISOSK-means recorded the best mean scores in four datasets: A1, A2, Birch2 and Housec5. The FA recorded the best mean performance, followed by the proposed ISOSK-means algorithm. FA and ISOSK-means recorded better average performance scores than DE, PSO and IWO. This showed that the improved hybrid algorithm demonstrated a high competing capability with other metaheuristic algorithms in automatic clustering of high dimensional datasets.

4.6. Statistical Analysis

The statistical analysis experiment involved using a nonparametric statistical analysis technique to further validate the algorithms’ computational results. The Friedman’s nonparametric test was conducted to draw a statistically verified meaningful conclusion from the reported performances. The reports for the computed Friedman’s mean rank on the four competing algorithms (the ISOSK-means, SOSK-means, SOS, and K-means) are presented in Table 11. The results showed that the ISOSK-means had the best performance, recording 1.13 as its minimum rank value and 2.00 as its maximum rank value, under the DB index, with a 1.15 minimum rank value and 1.99 maximum rank value under the CS index.
For further verification of the specific significant differences among the competing algorithms, a post hoc test on the Friedman mean-rank test results, using the Wilcoxon signed-rank test, was conducted. The Wilcoxon signed-rank test presents a set of p values which statistically measures whether there is a significant difference between the competing algorithms at a significance level of 0.05.
Table 12 shows the significant differences between ISOSK-means and the other competing algorithms under the DB and CS cluster validity indices. Out of 12 datasets, ISOSK-means recorded about 92%, 100%, and 83% significant differences in its performance from K-means, SOS, and SOSK-means under the DB index, and with a significant difference of 100%, 83% and 58%, respectively, under the CS index. This implied that the modification made to the existing SOSK-means algorithm contributed to the performance enhancement of the existing hybrid algorithm in solving cluster analysis problems.

5. Conclusions and Future Directions

In this study, an improved hybrid ISOSK-means metaheuristic algorithm is presented. Several improvements were incorporated into each of the two classical algorithms combined in the hybridization. In the initialization phase of the SOS algorithm, the population size was constructed using 40 + 2 g for a well-distributed initial population of solutions that scaled well with the data size. This resulted in a convergence rate increase and lower computational time. For performance upgrade, a three-part mutualism phase, with a random weighted reflection coefficient, was also integrated into the SOS algorithm with a random probability for determining whether an organism would be engaged in the three-part mutualism. To improve the quality of the clustering solution, the benefit factor was modified, by incorporating consideration for fitness value relativity with respect to the maximum fitness value.
The misleading effects of outliers in the dataset were addressed by the improvement incorporated into the K-means phase of the improved hybrid algorithm. A method for detecting and excluding putative outliers during the centroid update phase of the classical algorithm was added. The algorithm uses a point-to-centroid distance threshold for the centroid update, instead of using the means of data points. The point-to-centroid distance threshold uses the median absolute deviation, which is considered to be a robust measure of statistical dispersion and is known to be more resilient to outliers. This ensured that outliers were excluded from contributing to minimizing the mean square error in the K-means. This resulted in a more compact cluster output.
The improved hybrid algorithm was evaluated on 42 datasets (18 synthetic and 24 real-life) with varying characteristics, such as being high dimensional datasets, low dimensional datasets, synthetically generated datasets, image datasets, shape datasets, and location datasets, with varied dataset sizes and clusters. The performance of the improved hybrid algorithm was compared with the standard hybrid and non-hybrid algorithms. The performance was also compared with the two standard algorithms SOS and K-means on 12 real life datasets. A Friedman means rank test was applied to analyze the significant difference between the ISOSK-means and the competing algorithms. A pairwise post hoc Wilcoxon signed-rank sum test was also performed to highlight the performance of the ISOSK-means in comparison with the competing algorithms. The ISOSK-means algorithm outperformed the three algorithms with lower computational time and higher convergence rate, as reflected in the convergence curve for the competing algorithms.
The ISOSK-means clustering results were compared with four non-hybrid metaheuristic algorithms and three hybrid metaheuristic algorithms from the literature. The ISOSK-means had fair competitiveness, in terms of clustering performance measured using the DB validity index, on 42 datasets. The ISOSK-means recorded the lowest standard deviation score for most datasets, compared with the competing algorithms.
For future research, the K-means phase of the hybridized algorithm could be improved to efficiently manage large datasets and, thereby, reduce the algorithm’s computational complexity. Other suggested improvements to the SOS algorithm from literature could also be incorporated into the algorithm, or be used as a replacement to the current SOS phase of the ISOSK-means, for further performance enhancement, while reducing the algorithm run time. The real-life application of the proposed improved hybrid algorithm is another area of research that could be exploited. Using other cluster validity indices in implementing this algorithm would also be an interesting area for future research.

Author Contributions

All authors contributed to the conception and design of the research work. Material preparation, experiments, and analysis were performed by A.M.I. and A.E.E. All authors have read and agreed to the published version of the manuscript.

Funding

This research received no external funding.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

Not applicable.

Conflicts of Interest

The authors declare that they have no known competing financial interest or personal relationship that could have appeared to influence the work reported in this article.

References

  1. 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]
  2. Ikotun, A.M.; Almutari, M.S.; Ezugwu, A.E. K-Means-Based Nature-Inspired Metaheuristic Algorithms for Automatic Data Clustering Problems: Recent Advances and Future Directions. Appl. Sci. 2021, 11, 11246. [Google Scholar] [CrossRef]
  3. Olukanmi, P.O.; Twala, B. K-means-sharp: Modified centroid update for outlier-robust k-means clustering. In Proceedings of the 2017 Pattern Recognition Association of South Africa and Robotics and Mechatronics International Conference (PRASA-RobMech), Bloemfontein, South Africa, 29 November–1 December 2017; pp. 14–19. [Google Scholar] [CrossRef]
  4. Ikotun, A.M.; Ezugwu, A.E.; Abualigah, L.; Abuhaija, B.; Heming, J. K-means Clustering Algorithms: A Comprehensive Review, Variants Analysis, and Advances in the Era of Big Data. Inf. Sci. 2022, 622, 178–210. [Google Scholar] [CrossRef]
  5. Knorr, E.M.; Ng, R.T.; Tucakov, V. Distance-based outliers: Algorithms and applications. VLDB J. 2000, 8, 237–253. [Google Scholar] [CrossRef]
  6. Chawla, S.; Gionis, A. k-means–: A unified approach to clustering and outlier detection. In Proceedings of the 2013 SIAM International Conference on Data Mining, Austin, TX, USA, 2–4 May 2013; pp. 189–197. [Google Scholar] [CrossRef] [Green Version]
  7. Olukanmi, P.; Nelwamondo, F.; Marwala, T.; Twala, B. Automatic detection of outliers and the number of clusters in k-means clustering via Chebyshev-type inequalities. Neural Comput. Appl. 2022, 34, 5939–5958. [Google Scholar] [CrossRef]
  8. Cheng, M.-Y.; Prayogo, D. Symbiotic Organisms Search: A new metaheuristic optimization algorithm. Comput. Struct. 2014, 139, 98–112. [Google Scholar] [CrossRef]
  9. Chakraborty, S.; Nama, S.; Saha, A.K. An improved symbiotic organisms search algorithm for higher dimensional optimization problems. Knowl.-Based Syst. 2021, 236, 107779. [Google Scholar] [CrossRef]
  10. Panda, A.; Pani, S. A symbiotic organisms search algorithm with adaptive penalty function to solve multi-objective constrained optimization problems. Appl. Soft Comput. 2016, 46, 344–360. [Google Scholar] [CrossRef]
  11. Cheng, M.-Y.; Prayogo, D.; Tran, D.-H. Optimizing Multiple-Resources Leveling in Multiple Projects Using Discrete Symbiotic Organisms Search. J. Comput. Civ. Eng. 2016, 30, 04015036. [Google Scholar] [CrossRef] [Green Version]
  12. Kawambwa, S.; Hamisi, N.; Mafole, P.; Kundaeli, H. A cloud model based symbiotic organism search algorithm for DG allocation in radial distribution network. Evol. Intell. 2021, 15, 545–562. [Google Scholar] [CrossRef]
  13. Liu, D.; Li, H.; Wang, H.; Qi, C.; Rose, T. Discrete symbiotic organisms search method for solving large-scale time-cost trade-off problem in construction scheduling. Expert Syst. Appl. 2020, 148, 113230. [Google Scholar] [CrossRef]
  14. Cheng, M.-Y.; Cao, M.-T.; Herianto, J.G. Symbiotic organisms search-optimized deep learning technique for mapping construction cash flow considering complexity of project. Chaos Solitons Fractals 2020, 138, 109869. [Google Scholar] [CrossRef]
  15. Abdullahi, M.; Ngadi, A.; Abdulhamid, S.M. Symbiotic organism search optimization based task scheduling in cloud computing environment. Future Gener. Comput. Syst. 2016, 56, 640–650. [Google Scholar] [CrossRef]
  16. Ezugwu, A.E.-S.; Adewumi, A.O.; Frîncu, M.E. Simulated annealing based symbiotic organisms search optimization algorithm for traveling salesman problem. Expert Syst. Appl. 2017, 77, 189–210. [Google Scholar] [CrossRef]
  17. Tejani, G.; Savsani, V.J.; Patel, V. Adaptive symbiotic organisms search (SOS) algorithm for structural design optimization. J. Comput. Des. Eng. 2016, 3, 226–249. [Google Scholar] [CrossRef] [Green Version]
  18. Abdullahi, M.; Ngadi, A. Hybrid symbiotic organisms search optimization algorithm for scheduling of tasks on cloud computing environment. PLoS ONE 2016, 11, e0158229. [Google Scholar] [CrossRef] [Green Version]
  19. Mohammadzadeh, H.; Gharehchopogh, F.S. Feature selection with binary symbiotic organisms search algorithm for email spam detection. Int. J. Inf. Technol. Decis. Mak. 2021, 20, 469–515. [Google Scholar] [CrossRef]
  20. Boushaki, S.I.; Bendjeghaba, O.; Kamel, N. Biomedical document clustering based on accelerated symbiotic organisms search algorithm. Int. J. Swarm Intell. Res. 2021, 12, 169–185. [Google Scholar] [CrossRef]
  21. 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]
  22. Chen, J.; Zhang, Y.; Wu, L.; You, T.; Ning, X. An adaptive clustering-based algorithm for automatic path planning of heterogeneous UAVs. IEEE Trans. Intell. Transp. Syst. 2021, 23, 16842–16853. [Google Scholar] [CrossRef]
  23. Zainal, N.A.; Zamli, K.Z.; Din, F. A modified symbiotic organism search algorithm with lévy flight for software module clustering problem. In Proceedings of the ECCE2019—5th International Conference on Electrical, Control & Computer Engineering, Kuantan, Malaysia, 29 July 2019; pp. 219–229. [Google Scholar] [CrossRef]
  24. Rajah, V.; Ezugwu, A.E. Hybrid Symbiotic Organism Search algorithms for Automatic Data Clustering. In Proceedings of the 2020 Conference on Information Communications Technology and Society (ICTAS), Durban, South Africa, 11–12 March 2020; pp. 1–9. [Google Scholar] [CrossRef]
  25. Yang, C.-L.; Sutrisno, H. A clustering-based symbiotic organisms search algorithm for high-dimensional optimization problems. Appl. Soft Comput. 2020, 97, 106722. [Google Scholar] [CrossRef]
  26. Ikotun, A.M.; Ezugwu, A.E. Boosting k-means clustering with symbiotic organisms search for automatic clustering problems. PLoS ONE 2022, 17, e0272861. [Google Scholar] [CrossRef] [PubMed]
  27. Nama, S.; Saha, A.K.; Ghosh, S. Improved symbiotic organisms search algorithm for solving unconstrained function optimization. Decis. Sci. Lett. 2016, 5, 361–380. [Google Scholar] [CrossRef]
  28. Nama, S.; Saha, A.K.; Sharma, S. A novel improved symbiotic organisms search algorithm. Comput. Intell. 2020, 38, 947–977. [Google Scholar] [CrossRef]
  29. Secui, D.C. A modified Symbiotic Organisms Search algorithm for large scale economic dispatch problem with valve-point effects. Energy 2016, 113, 366–384. [Google Scholar] [CrossRef]
  30. Nama, S.; Saha, A.K.; Ghosh, S. A hybrid symbiosis organisms search algorithm and its application to real world problems. Memetic Comput. 2016, 9, 261–280. [Google Scholar] [CrossRef]
  31. Ezugwu, A.E.-S.; Adewumi, A.O. Discrete symbiotic organisms search algorithm for travelling salesman problem. Expert Syst. Appl. 2017, 87, 70–78. [Google Scholar] [CrossRef]
  32. Ezugwu, A.E.; Adeleke, O.J.; Viriri, S. Symbiotic organisms search algorithm for the unrelated parallel machines scheduling with sequence-dependent setup times. PLoS ONE 2018, 13, e0200030. [Google Scholar] [CrossRef]
  33. Tsai, H.-C. A corrected and improved symbiotic organisms search algorithm for continuous optimization. Expert Syst. Appl. 2021, 177, 114981. [Google Scholar] [CrossRef]
  34. Kumar, S.; Tejani, G.G.; Mirjalili, S. Modified symbiotic organisms search for structural optimization. Eng. Comput. 2018, 35, 1269–1296. [Google Scholar] [CrossRef] [Green Version]
  35. Miao, F.; Zhou, Y.; Luo, Q. A modified symbiotic organisms search algorithm for unmanned combat aerial vehicle route planning problem. J. Oper. Res. Soc. 2018, 70, 21–52. [Google Scholar] [CrossRef]
  36. Çelik, E. A powerful variant of symbiotic organisms search algorithm for global optimization. Eng. Appl. Artif. Intell. 2019, 87, 103294. [Google Scholar] [CrossRef]
  37. Do, D.T.; Lee, J. A modified symbiotic organisms search (mSOS) algorithm for optimization of pin-jointed structures. Appl. Soft Comput. 2017, 61, 683–699. [Google Scholar] [CrossRef]
  38. Nama, S.; Saha, A.K.; Sharma, S. Performance up-gradation of Symbiotic Organisms Search by Backtracking Search Algorithm. J. Ambient Intell. Humaniz. Comput. 2021, 13, 5505–5546. [Google Scholar] [CrossRef] [PubMed]
  39. Olukanmi, P.O.; Nelwamondo, F.; Marwala, T. k-Means-Lite: Real time clustering for large datasets. In Proceedings of the 2018 5th International Conference on Soft Computing & Machine Intelligence (ISCMI), Nairobi, Kenya, 21–22 November 2018; pp. 54–59. [Google Scholar] [CrossRef]
  40. Davies, D.L.; Bouldin, D.W. A cluster separation measure. IEEE Trans. Pattern Anal. Mach. Intell. 1979, 2, 224–227. [Google Scholar] [CrossRef]
  41. Chou, C.-H.; Su, M.-C.; Lai, E. A new cluster validity measure and its application to image compression. Pattern Anal. Appl. 2004, 7, 205–220. [Google Scholar] [CrossRef]
  42. Arbelaitz, O.; Gurrutxaga, I.; Muguerza, J.; Pérez, J.M.; Perona, I. An extensive comparative study of cluster validity indices. Pattern Recognit. 2013, 46, 243–256. [Google Scholar] [CrossRef]
  43. Chouikhi, H.; Charrad, M.; Ghazzali, N. A comparison study of clustering validity indices; A comparison study of clustering validity indices. In Proceedings of the 2015 Global Summit on Computer & Information Technology (GSCIT), Sousse, Tunisia, 11–13 June 2015. [Google Scholar] [CrossRef]
  44. Xia, S.; Peng, D.; Meng, D.; Zhang, C.; Wang, G.; Giem, E.; Wei, W.; Chen, Z. Fast adaptive clustering with no bounds. IEEE Trans. Pattern Anal. Mach. Intell. 2020, 44, 87–99. [Google Scholar] [CrossRef]
  45. Goldanloo, M.J.; Gharehchopogh, F.S. A hybrid OBL-based firefly algorithm with symbiotic organisms search algorithm for solving continuous optimization problems. J. Supercomput. 2021, 78, 3998–4031. [Google Scholar] [CrossRef]
  46. Nguyen-Van, S.; Nguyen, K.T.; Luong, V.H.; Lee, S.; Lieu, Q.X. A novel hybrid differential evolution and symbiotic organisms search algorithm for size and shape optimization of truss structures under multiple frequency constraints. Expert Syst. Appl. 2021, 184, 115534. [Google Scholar] [CrossRef]
  47. Huo, L.; Zhu, J.; Li, Z.; Ma, M. A Hybrid Differential Symbiotic Organisms Search Algorithm for UAV Path Planning. Sensors 2021, 21, 3037. [Google Scholar] [CrossRef] [PubMed]
  48. Farnad, B.; Jafarian, A.; Baleanu, D. A new hybrid algorithm for continuous optimization problem. Appl. Math. Model. 2018, 55, 652–673. [Google Scholar] [CrossRef]
  49. Gharehchopogh, F.S.; Shayanfar, H.; Gholizadeh, H. A comprehensive survey on symbiotic organisms search algorithms. Artif. Intell. Rev. 2019, 53, 2265–2312. [Google Scholar] [CrossRef]
  50. Ghezelbash, R.; Maghsoudi, A.; Shamekhi, M.; Pradhan, B.; Daviran, M. Genetic algorithm to optimize the SVM and K-means algorithms for mapping of mineral prospectivity. Neural Comput. Appl. 2022, 1–15. [Google Scholar] [CrossRef]
  51. Yastrebov, A.; Kubuś, Ł.; Poczeta, K. Multiobjective evolutionary algorithm IDEA and k-means clustering for modeling multidimenional medical data based on fuzzy cognitive maps. Nat. Comput. 2022, 1–11. [Google Scholar] [CrossRef]
  52. Zhang, H.; Peng, Q. PSO and K-means-based semantic segmentation toward agricultural products. Futur. Gener. Comput. Syst. 2021, 126, 82–87. [Google Scholar] [CrossRef]
  53. Li, Y.; Chu, X.; Tian, D.; Feng, J.; Mu, W. Customer segmentation using K-means clustering and the adaptive particle swarm optimization algorithm. Appl. Soft Comput. 2021, 113, 107924. [Google Scholar] [CrossRef]
  54. Olukanmi, P.O.; Nelwamondo, F.; Marwala, T. k-Means-MIND: An Efficient Alternative to Repetitive k-Means Runs. In Proceedings of the 2020 7th International Conference on Soft Computing & Machine Intelligence (ISCMI), Stockholm, Sweden, 14–15 November 2020; pp. 172–176. [Google Scholar] [CrossRef]
  55. Jain, A.K. Data clustering: 50 years beyond K-means. Pattern Recognit. Lett. 2009, 31, 651–666. [Google Scholar] [CrossRef]
  56. Das, S.; Suganthan, P.N. Differential Evolution: A Survey of the State-of-the-Art. IEEE Trans. Evol. Comput. 2011, 15, 4–31. [Google Scholar] [CrossRef]
  57. Kwak, S.G.; Kim, J.H. Central limit theorem: The cornerstone of modern statistics. Korean J. Anesthesiol. 2017, 70, 2, 144. [Google Scholar] [CrossRef] [Green Version]
  58. Murugavel, P.; Punithavalli, M. Performance Evaluation of Density-Based Outlier Detection on High Dimensional Data. Int. J. Comput. Sci. Eng. 2013, 5, 62–67. [Google Scholar]
  59. Rousseeuw, P.J.; Croux, C. Alternatives to the median absolute deviation. J. Am. Stat. Assoc. 1993, 88, 1273–1283. [Google Scholar] [CrossRef]
  60. Leys, C.; Ley, C.; Klein, O.; Bernard, P.; Licata, L. Detecting outliers: Do not use standard deviation around the mean, use absolute deviation around the median. J. Exp. Soc. Psychol. 2013, 49, 764–766. [Google Scholar] [CrossRef] [Green Version]
  61. Ezugwu, A.E. Nature-inspired metaheuristic techniques for automatic clustering: A survey and performance study. SN Appl. Sci. 2020, 2, 273. [Google Scholar] [CrossRef]
  62. Das, S.; Konar, A. Automatic image pixel clustering with an improved differential evolution. Appl. Soft Comput. 2009, 9, 226–236. [Google Scholar] [CrossRef]
  63. Bandyopadhyay, S.; Maulik, U. Nonparametric genetic clustering: Comparison of validity indices. IEEE Trans. Syst. Man Cybern. Part C Appl. Rev. 2001, 31, 120–125. [Google Scholar] [CrossRef] [Green Version]
  64. Zhou, X.; Gu, J.; Shen, S.; Ma, H.; Miao, F.; Zhang, H.; Gong, H. An automatic K-Means clustering algorithm of GPS data combining a novel niche genetic algorithm with noise and density. ISPRS Int. J. Geo-Inf. 2017, 6, 392. [Google Scholar] [CrossRef] [Green Version]
  65. Bandyopadhyay, S.; Maulik, U. Genetic clustering for automatic evolution of clusters and application to image classification. Pattern Recognit. 2002, 35, 1197–1208. [Google Scholar] [CrossRef]
  66. Lai, C.-C. A novel clustering approach using hierarchical genetic algorithms. Intell. Autom. Soft Comput. 2005, 11, 143–153. [Google Scholar] [CrossRef]
  67. Lin, H.-J.; Yang, F.-W.; Kao, Y.-T. An Efficient GA-based Clustering Technique. J. Appl. Sci. Eng. 2005, 8, 113–122. [Google Scholar]
  68. Liu, R.; Zhu, B.; Bian, R.; Ma, Y.; Jiao, L. Dynamic local search based immune automatic clustering algorithm and its applications. Appl. Soft Comput. 2014, 27, 250–268. [Google Scholar] [CrossRef]
  69. Kundu, D.; Suresh, K.; Ghosh, S.; Das, S.; Abraham, A.; Badr, Y. Automatic Clustering Using a Synergy of Genetic Algorithm and Multi-objective Differential Evolution. In International Conference on Hybrid Artificial Intelligence Systems; Springer: Berlin/Heidelberg, Germany, 2009; pp. 177–186. [Google Scholar] [CrossRef] [Green Version]
  70. Kumar, V.; Chhabra, J.K.; Kumar, D. Automatic Data Clustering Using Parameter Adaptive Harmony Search Algorithm and Its Application to Image Segmentation. J. Intell. Syst. 2016, 25, 595–610. [Google Scholar] [CrossRef]
  71. Anari, B.; Torkestani, J.A.; Rahmani, A. Automatic data clustering using continuous action-set learning automata and its application in segmentation of images. Appl. Soft Comput. 2017, 51, 253–265. [Google Scholar] [CrossRef]
  72. Kuo, R.; Huang, Y.; Lin, C.-C.; Wu, Y.-H.; Zulvia, F.E. Automatic kernel clustering with bee colony optimization algorithm. Inf. Sci. 2014, 283, 107–122. [Google Scholar] [CrossRef]
  73. Liu, Y.; Wu, X.; Shen, Y. Automatic clustering using genetic algorithms. Appl. Math. Comput. 2011, 218, 1267–1279. [Google Scholar] [CrossRef]
  74. Chowdhury, A.; Das, S. Automatic shape independent clustering inspired by ant dynamics. Swarm Evol. Comput. 2011, 3, 33–45. [Google Scholar] [CrossRef]
  75. Kumar, V.; Chhabra, J.K.; Kumar, D. Automatic cluster evolution using gravitational search algorithm and its application on image segmentation. Eng. Appl. Artif. Intell. 2014, 29, 93–103. [Google Scholar] [CrossRef]
  76. Sheng, W.; Chen, S.; Sheng, M.; Xiao, G.; Mao, J.; Zheng, Y. Adaptive multisubpopulation competition and multiniche crowding-based memetic algorithm for automatic data clustering. IEEE Trans. Evol. Comput. 2016, 20, 838–858. [Google Scholar] [CrossRef]
  77. Das, S.; Chowdhury, A.; Abraham, A. A Bacterial Evolutionary Algorithm for Automatic Data Clustering. In Proceedings of the 2009 IEEE Congress on Evolutionary Computation, Trondheim, Norway, 8–21 May 2009. [Google Scholar]
  78. Talbi, E.-G. Metaheuristics: From Design to Implementation; John Wiley & Sons: Hoboken, NJ, USA, 2009. [Google Scholar]
  79. Chowdhury, A.; Bose, S.; Das, S. Automatic Clustering Based on Invasive Weed Optimization Algorithm. In Proceedings of the International Conference on Swarm, Evolutionary, and Memetic Computing 2011, Visakhapatnam, India, 19–21 December 2011; pp. 105–112. [Google Scholar] [CrossRef]
  80. Zhang, X.; Li, J.; Yu, H. Local density adaptive similarity measurement for spectral clustering. Pattern Recognit. Lett. 2011, 32, 352–358. [Google Scholar] [CrossRef]
  81. Agbaje, M.B.; Ezugwu, A.E.; Els, R. Automatic data clustering using hybrid firefly particle swarm optimization algorithm. IEEE Access 2019, 7, 184963–184984. [Google Scholar] [CrossRef]
Figure 1. Flowchart for ISOSK-means clustering algorithm.
Figure 1. Flowchart for ISOSK-means clustering algorithm.
Applsci 12 13019 g001
Figure 2. Flowchart for three-part mutualism phase.
Figure 2. Flowchart for three-part mutualism phase.
Applsci 12 13019 g002
Figure 3. Computational time for the ISOSK-means.
Figure 3. Computational time for the ISOSK-means.
Applsci 12 13019 g003
Figure 4. Performance analysis of four competing algorithms, ISOSK-means, SOSK-means, SOS and K-means, under the DB index.
Figure 4. Performance analysis of four competing algorithms, ISOSK-means, SOSK-means, SOS and K-means, under the DB index.
Applsci 12 13019 g004
Figure 5. Performance analysis of four competing algorithms, ISOSK-means, SOSK-means, SOS and K-means, under the CS index.
Figure 5. Performance analysis of four competing algorithms, ISOSK-means, SOSK-means, SOS and K-means, under the CS index.
Applsci 12 13019 g005
Figure 6. Analysis of computational times of SOS, SOSK-means and ISOSK-means under the DB index.
Figure 6. Analysis of computational times of SOS, SOSK-means and ISOSK-means under the DB index.
Applsci 12 13019 g006
Figure 7. Analysis of computational times of SOS, SOSK-means and ISOSK-means under the CS index.
Figure 7. Analysis of computational times of SOS, SOSK-means and ISOSK-means under the CS index.
Applsci 12 13019 g007
Figure 8. Convergence curves for the 12 datasets under DB index.
Figure 8. Convergence curves for the 12 datasets under DB index.
Applsci 12 13019 g008aApplsci 12 13019 g008bApplsci 12 13019 g008c
Figure 9. Convergence curves for the 12 datasets under the CS index.
Figure 9. Convergence curves for the 12 datasets under the CS index.
Applsci 12 13019 g009aApplsci 12 13019 g009bApplsci 12 13019 g009c
Table 1. The control parameters for competing metaheuristic algorithms.
Table 1. The control parameters for competing metaheuristic algorithms.
DEFAIWOPSO
ParameterValueParameterValueParameterValueParameterValue
Pop_size25, 50, 100, 150Pop_size25, 50, 100, 150Pop_size25, 50, 100, 150Pop_size25, 50, 100, 150
Kmin2Kmin2Kmax256Kmin2
Kmax256Kmax256MaxGen200Kmax256
MaxIt200MaxGen200s 5MaxIt200
F0.8 β 0 2e2 W 1 1.00
CRmax1   γ   1 1 0.5 W 2 0.99
CRmin0.2 2 0.001 τ 1 1.50
τ 2 2.00
Pop_size: Population Size; Kmin: minimum number of clusters; Kmax: maximum number of clusters; MaxIt: number of iterations; MaxGen: Maximum number of Generations; CR: Crossover rate; e: variance reduction exponent; s: maximum number of seeds; W1: Inertial weight; W2: Inertial weight damping ratio; β 0 : attractiveness; γ : light   absorption ;   τ 1 :  personal learning coefficient. τ 2 :   global learning coefficient. 1 : initial   value   of   standard   deviation   ; 2 :   final   value   of   standard   deviation .
Table 2. The characteristics of the 18 synthetically generated datasets.
Table 2. The characteristics of the 18 synthetically generated datasets.
DatasetsNumber of Data ObjectsDimension of DataNumber of ClustersDataset TypesReferences
A13000220Synthetically generated[62,63,64]
A25250235Synthetically generated[62,63,64]
A37500250Synthetically generated[62,63,64]
Birch1100,0002100Synthetically generated[62,64,65]
Birch2100,0002100Synthetically generated[62,64,65]
Birch3100,0002100Synthetically generated[62,64,65]
Dim0021351–10,1262–159Synthetically generated[62,64,66]
Dim01610241616High-dimensional[62,64,67]
Dim03210243216High-dimensional[62,64,67]
Dim06410246416High-dimensional[62,64,67]
Dim128102412816High-dimensional[62,64,67]
Dim256102425616High-dimensional[62,64,67]
Dim512102451216High-dimensional[62,64,67]
Dim10241024102416High-dimensional[62,64,67]
S15000215Synthetically generated[62,64,68]
S25000215Synthetically generated[62,64,68]
S35000215Synthetically generated[62,64,68]
S45000215Synthetically generated[62,64,68]
Table 3. The characteristics of the 24 real-life datasets.
Table 3. The characteristics of the 24 real-life datasets.
DatasetsNumber of Data ObjectsDimension of DataNumber of ClustersDataset TypesReferences
Aggregation78827Shape sets[64,69]
Breast69992UCI dataset[64,70]
Bridge409616256Grey-scale image blocks[64,71]
Compound39926Shape sets[64,72]
D313100231Shape sets[64,73]
Flame24022Shape sets[64,74]
Glass21497UCI dataset[64,70]
Housec534,1123256RGB Image[64,71]
Housec834,1123256RGB Image[64,71]
Iris15043UCI dataset[64,70]
Jain37322Shape sets[64,75]
Leaves160064100UCI dataset[64,70]
Letter20,0001626UCI dataset[64,70]
Joensuu601424Mopsi locations[64,76]
Finland13,46724Mopsi locations[64,76]
Path-based30023Shape sets[1,64]
R15600215Shape sets[64,77]
Spiral31223Shape sets[64,78]
Thyroid21552UCI dataset[64,70]
T4.8k800023Miscellaneous[64,79]
Two moons10,00022Miscellaneous[80,81]
Wdbc569322UCI dataset[64,70]
Wine178133UCI dataset[64,70]
Yeast1484810UCI dataset[64,70]
Table 4. Computational results for improved SOSK-means on 12 real-life datasets.
Table 4. Computational results for improved SOSK-means on 12 real-life datasets.
DB IndexCS Index
DatasetsMinMaxMeanStd DevMinMaxMeanStd Dev
Breast0.81210.81210.81210.00000.59960.72090.66390.0391
Compound0.49470.50330.49850.00210.49950.50320.50310.0006
Flame0.77480.77700.77600.00060.38460.38460.38460.0000
Glass0.36120.78210.65470.17270.06080.06080.06080.0000
Iris0.59130.64750.61650.01320.53110.58210.55100.0118
Jain0.64950.65220.65070.00080.65460.65460.65460.0000
Path-based0.65330.67180.66690.00500.55880.64940.62890.0299
Spiral0.73200.74580.73860.00330.58610.68620.66180.0329
Thyroid0.56920.64390.60390.01820.64090.64090.64090.0000
Two moons0.60080.60330.60210.00060.71760.74820.72430.0113
Wine0.94141.04371.00530.02280.65700.86250.76140.0571
Yeast0.35600.99020.80190.14070.38970.51100.47770.0252
Average0.62800.73940.70230.03170.52340.58370.55940.0173
Table 5. Computation results for the four competing algorithms on 12 real-life datasets.
Table 5. Computation results for the four competing algorithms on 12 real-life datasets.
Statistical MeasureDB IndexCS Index
DatasetsSOSK-MeansSOSK-meansISOSK-MeansSOSK-MeansSOSK-MeansISOSK-Means
BreastMean1.35200.81210.81210.81210.99461.10190.76060.6639
Std Dev0.28580.00000.00000.00000.26670.00000.12170.0391
CompoundMean0.69240.97160.50460.49850.56701.28870.50720.5031
Std Dev0.14810.07480.00440.00210.12250.14860.01550.0006
FlameMean0.82341.23060.77700.77601.27071.58060.38460.3846
Std Dev0.01800.00590.00080.00060.10060.02630.00000.0000
GlassMean0.81641.22080.71130.65470.22001.48940.06080.0608
Std Dev0.11740.15700.12170.17270.25630.19040.00000.0000
IrisMean0.86020.91670.63460.61650.85851.24040.57430.5510
Std Dev0.18090.00330.01880.01320.19220.00920.02370.0118
JainMean0.70070.85870.65180.65070.81961.06680.65460.6546
Std Dev0.02740.00010.00090.00080.02120.00030.00000.0000
Path-basedMean0.75780.76960.67080.66691.00210.98930.65110.6289
Std Dev0.06860.00660.00310.00500.17080.00860.01200.0299
SpiralMean0.80130.95890.74370.73861.08181.18960.68120.6618
Std Dev0.04470.01090.00450.00330.21070.00530.01150.0329
ThyroidMean1.02321.02980.63210.60390.64461.78630.64090.6409
Std Dev0.14790.20420.03160.01820.02380.36020.00000.0000
Two-moonsMean0.61280.79480.60320.60210.77010.93850.74980.7243
Std Dev0.01790.00000.00100.00060.02810.00000.01620.0113
WineMean1.14881.30531.04601.00531.19381.44250.84220.7614
Std Dev0.13940.00220.02070.02280.33180.01280.05270.0571
YeastMean1.21441.71760.84960.80190.55942.64170.52420.4777
Std Dev0.29110.18750.15880.14070.28470.59500.04370.0252
Table 6. Computational results of ISOSK-means on 18 synthetic datasets.
Table 6. Computational results of ISOSK-means on 18 synthetic datasets.
ISOSK-Means (DB Index)
DatasetsMinMaxMeanStd Dev
A10.59050.59180.59110.0003
A20.67770.67860.67810.0002
A30.79210.79650.79450.0011
Birch10.80200.80420.80300.0006
Birch20.50700.50730.50710.0001
Birch30.71610.71790.71680.0004
Dim0020.58730.66760.63840.0222
Dim0160.72011.28691.10690.1870
Dim0320.82931.47051.24020.2463
Dim0640.84741.59011.03900.2524
Dim1280.85071.71001.00450.2008
Dim2560.90561.81921.07850.3065
Dim5120.20541.01350.92471.0135
Dim10240.90601.96551.13320.3795
S10.77520.77850.77700.0009
S20.73940.74300.74120.0008
S30.71190.71390.71260.0005
S40.77050.77410.77230.0009
Average0.71861.03500.84770.1452
Table 7. Performance comparison of ISOSK-means with other hybrid metaheuristic algorithms from literature on 18 synthetic datasets.
Table 7. Performance comparison of ISOSK-means with other hybrid metaheuristic algorithms from literature on 18 synthetic datasets.
ISOSK-MeansPSODEFADEIWODE
MeanStd DevMeanStd DevMeanStd DevMeanStd Dev
A10.59110.00030.59490.00860.61710.03470.65250.0621
A20.67810.00020.69120.01610.69760.02150.72960.0391
A30.79450.00110.71060.01760.70850.03320.75270.0319
Birch10.80300.00060.72560.02760.72320.02570.769230.0279
Birch20.50710.00010.5070.00020.51550.02350.51760.0084
Birch30.71680.00040.70740.01510.70120.01910.7570.0247
Dim0020.63840.02220.59750.04450.6280.06070.67050.0432
Dim0161.10690.18701.01830.12851.04130.05121.43360.0456
Dim0321.24020.24631.11420.09151.07270.08941.57310.0574
Dim0641.03900.25241.19180.17691.10030.09251.70150.0415
Dim1281.00450.20081.33630.14251.1980.11731.77730.0477
Dim2561.07850.30651.50510.1741.29380.13081.86030.0309
Dim5120.92471.01351.68270.06331.35290.14631.93110.0424
Dim10241.13320.37951.76440.01121.47590.121.96540.0261
S10.77700.00090.67390.03510.67560.0270.75010.028
S20.74120.00080.68440.0280.69390.03450.75560.019
S30.71260.00050.71060.01990.70720.01810.75590.0317
S40.77230.00090.72990.01620.73560.02260.78960.0303
Average0.84770.14520.94140.05650.88550.05931.11900.0354
Table 8. Computational results of ISOSK-means on 23 real-life datasets.
Table 8. Computational results of ISOSK-means on 23 real-life datasets.
ISOSK-Means (DB Index)
DatasetsMinMaxMeanStd Dev
Aggregation0.72290.72970.72620.0014
Breast0.81210.81210.81210.0000
Bridge0.64550.64740.64640.0009
Compound0.49470.50330.49850.0021
D310.80160.82630.81250.0070
Flame0.77480.77700.77600.0006
Glass0.36120.78210.65470.1727
Housec50.51580.56500.53770.0123
Housec80.49190.53050.51580.0107
Iris0.59130.64750.61650.0132
Jain0.64950.65220.65070.0008
Leaves0.72070.95910.76180.0745
Letter0.96831.05451.02420.0188
Joensuu0.50110.51470.50730.0038
Finland0.44090.44530.44270.0011
Path-based0.65330.67180.66690.0050
R150.71060.77710.74000.0171
Spiral0.73200.74580.73860.0033
T4.8k0.02270.02270.02270.0000
Thyroid0.56920.64390.60390.0182
Wdbc0.05080.05080.05080.0000
Wine0.94141.04371.00530.0228
Yeast0.70840.89760.74890.0682
Average0.60350.66520.63310.0198
Table 9. Performance comparison of ISOSK-means with other hybrid metaheuristic algorithms on 23 real-life datasets.
Table 9. Performance comparison of ISOSK-means with other hybrid metaheuristic algorithms on 23 real-life datasets.
ISOSK-MeansPSODEFADEIWODE
MeanStd DevMeanStd DevMeanStd DevMeanStd Dev
Aggregation0.72620.00140.59580.03910.59480.04240.60150.051
Breast0.81210.00000.72560.11150.93780.20510.79650.1177
Bridge0.64640.00090.71410.10070.64050.07091.13970.0666
Compound0.49850.00210.49830.00920.52730.05760.500040.0312
D310.81250.00700.80210.04070.77880.03760.79720.0514
Flame0.77600.00064.40694.67250.67950.04770.67490.0391
Glass0.65470.17270.59660.06720.59710.09960.55620.1384
Housec50.53770.01232.24084.08610.54670.02870.68650.0229
Housec80.49190.53050.50220.03150.47070.03830.63440.0408
Iris0.61650.01320.58110.0210.5850.0350.83840.0916
Jain0.65070.00080.63990.0150.64510.00620.650.0058
Leaves0.76180.07450.7580.15140.74830.15391.51160.0396
Letter0.96831.05450.91210.06280.86650.06631.20570.0571
Joensuu0.50730.00380.50940.00980.510.03270.49720.0041
Finland0.44270.00110.44650.0060.46860.05470.48640.0371
Path-based0.66690.00500.65260.01660.65610.01780.65670.0156
R150.74000.01710.64230.07220.63990.09840.59960.0894
Spiral0.73860.00330.74410.01360.73730.01560.77580.0143
T4.8k0.02270.00000.022700.042340.08820.09280.0515
Thyroid0.60390.01820.50240.01960.49550.02410.98930.1077
Wdbc0.05080.00000.050800.050800.08140.0263
Wine1.00530.02280.88910.06010.86480.09731.23120.0525
Yeast0.74890.06820.71930.06770.63750.13440.59490.1144
Average0.63310.01980.88050.26080.72340.06150.89610.0464
Table 10. Performance comparison of ISOSK-means with other non-hybrid metaheuristic algorithms on high-dimensional datasets.
Table 10. Performance comparison of ISOSK-means with other non-hybrid metaheuristic algorithms on high-dimensional datasets.
High-Dimensional DatasetISOSK-MeansDEPSOFAIWO
MeanStd DevMeanStd DevMeanStd DevMeanStd DevMeanStd Dev
A10.59110.00030.60160.01160.66620.00420.60890.03410.63080.0265
A20.67810.00020.70810.03480.71340.02840.68420.01430.74830.0468
A30.79450.00110.73490.01840.72790.02870.68440.02410.75450.0339
Birch 10.80300.00060.7480.01710.75280.01690.70910.02030.76440.0211
Birch 20.50710.00010.50860.00160.58760.03580.50870.00780.51680.0052
Birch 30.71680.00040.74880.02970.72130.03060.69740.01270.75680.0248
D310.81250.00700.87570.03020.7630.05140.78080.04360.78960.0312
Housec50.53770.01230.6190.04120.74560.06790.56420.0290.70340.043
Housec80.49190.53050.52450.01390.64180.08580.45840.01110.62060.0546
Leaves0.76180.07451.13450.07981.03350.28540.60360.05871.51320.049
Letter0.96831.05450.98520.03031.03540.10840.80710.02461.22450.0416
Average0.69660.15290.74440.02810.76260.06760.64610.02550.82030.0343
Table 11. Friedman mean rank for ISOSK-means, SOSK-means, SOS, and K-means.
Table 11. Friedman mean rank for ISOSK-means, SOSK-means, SOS, and K-means.
DB IndexCS Index
DatasetsSOSK-MeansSOSK-MeansISOSK-MeansSOSK-MeansSOSK-MeansISOSK-Means
Breast42223.133.452.031.4
Compound2.93.951.981.182.3441.911.75
Flame341.831.18341.51.5
Glass2.4241.941.642.6841.61.6
Iris3.33.481.981.252.8541.981.18
Jain341.881.13341.51.5
Path-based3.183.452.081.33.633.231.941.21
Spiral2.841.91.33.183.581.791.46
Thyroid3.43.531.91.182.0341.991.99
Two-moons2.6142.141.252.6342.161.21
Wine33.72.171.133.093.632.141.15
Yeast33.881.731.41.6342.691.69
Table 12. Wilcoxon signed-rank test for ISOSK-means, SOSK-means, SOS, and K-means.
Table 12. Wilcoxon signed-rank test for ISOSK-means, SOSK-means, SOS, and K-means.
Cluster Validity IndexDB IndexCS Index
DatasetsISOSK-Means vs. SOSISOSK-Means vs. K-MeansISOSK-Means vs. SOSK-MeansISOSK-Means vs. SOSISOSK-Means vs. K-MeansISOSK-Means vs. SOSK-Means
Breast0.00001.00001.00000.00000.00000.0010
Compound0.00000.00000.00000.00100.00000.0430
Flame0.00000.00000.00000.00000.00001.0000
Glass0.00000.00000.07400.00000.00001.0000
Iris0.00000.00000.00000.00000.00000.0000
Jain0.00000.00000.00000.00000.00001.0000
Pathbased0.00000.00000.00000.00000.00000.0000
Spiral0.00000.00000.00000.00000.00000.0040
Thyroid0.00000.00000.00000.31700.00001.0000
Two moons0.00000.00000.00000.00000.00000.0000
Wine0.00000.00000.00000.00000.00000.0000
Yeast0.00000.00000.00000.27600.00000.0000
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Ikotun, A.M.; Ezugwu, A.E. Improved SOSK-Means Automatic Clustering Algorithm with a Three-Part Mutualism Phase and Random Weighted Reflection Coefficient for High-Dimensional Datasets. Appl. Sci. 2022, 12, 13019. https://doi.org/10.3390/app122413019

AMA Style

Ikotun AM, Ezugwu AE. Improved SOSK-Means Automatic Clustering Algorithm with a Three-Part Mutualism Phase and Random Weighted Reflection Coefficient for High-Dimensional Datasets. Applied Sciences. 2022; 12(24):13019. https://doi.org/10.3390/app122413019

Chicago/Turabian Style

Ikotun, Abiodun M., and Absalom E. Ezugwu. 2022. "Improved SOSK-Means Automatic Clustering Algorithm with a Three-Part Mutualism Phase and Random Weighted Reflection Coefficient for High-Dimensional Datasets" Applied Sciences 12, no. 24: 13019. https://doi.org/10.3390/app122413019

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop