Next Article in Journal
Specific Problems in Measurement of Coefficient of Friction Using Variable Incidence Tribometer
Previous Article in Journal
Lorentz Invariance Violation Tests in Astroparticle Physics
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

An Improved Moth-Flame Optimization Algorithm for Engineering Problems

1
Institute of Management Science and Engineering, and School of Business, Henan University, Kaifeng 475004, China
2
School of Business, Henan University, Kaifeng 475004, China
3
Institute of Intelligent Network Systems, and Software School, Henan University, Kaifeng 475004, China
*
Author to whom correspondence should be addressed.
Symmetry 2020, 12(8), 1234; https://doi.org/10.3390/sym12081234
Submission received: 22 June 2020 / Revised: 19 July 2020 / Accepted: 20 July 2020 / Published: 27 July 2020

Abstract

:
In this paper, an improved moth-flame optimization algorithm (IMFO) is presented to solve engineering problems. Two novel effective strategies composed of Lévy flight and dimension-by-dimension evaluation are synchronously introduced into the moth-flame optimization algorithm (MFO) to maintain a great global exploration ability and effective balance between the global and local search. The search strategy of Lévy flight is used as a regulator of the moth-position update mechanism of global search to maintain a good research population diversity and expand the algorithm’s global search capability, and the dimension-by-dimension evaluation mechanism is added, which can effectively improve the quality of the solution and balance the global search and local development capability. To substantiate the efficacy of the enhanced algorithm, the proposed algorithm is then tested on a set of 23 benchmark test functions. It is also used to solve four classical engineering design problems, with great progress. In terms of test functions, the experimental results and analysis show that the proposed method is effective and better than other well-known nature-inspired algorithms in terms of convergence speed and accuracy. Additionally, the results of the solution of the engineering problems demonstrate the merits of this algorithm in solving challenging problems with constrained and unknown search spaces.

1. Introduction

The moth-flame optimization algorithm [1] was recently proposed by Mirjalili in 2015, which is one of the latest algorithms that has gained extensive attention in recent years. This new intelligent algorithm is based on the biological behavior of moths fighting flames in nature. Its biological principle is the moth’s night flight mechanism. The moth updates its position by spiraling around the flame. The moth-flame optimization algorithm (MFO) algorithm has the advantages of having few setting parameters, being easy to understand and implement, and having fast convergence. Nevertheless, we can see from the literature that there is still room for improvement in the moth-flame optimization algorithm. Therefore, in the past two years, many scholars have tried to improve the algorithm in different aspects. Furthermore, the algorithm is widely used in physics, medicine, economics and other fields. Eventually, many scholars have put forward examples about the application of the algorithm in different fields to solve practical problems.
The moth-flame optimization algorithm is widely used in the field of physics; the related research is as follows. Hitarth Buch [2] proposed an improved adaptive moth-flame optimization algorithm, which was effectively used to solve the optimal power flow problem. Avishek Das [3] used the moth-flame optimization algorithm to determine the optimal set of current excitation weights and determine the optimal spacing between array elements in the three-ring structure of the improved concentric antenna array (CCAA). Satomi Ishiguro [4] proposed a new method to optimize the loading mode of nuclear reactors—a multi-group moth-flame optimization algorithm with predators. Hegazy Rezk [5] studied the hybrid moth-flame optimization algorithm and the power condition of the maximum solar photovoltaic/hot spot system with incremental conductance tracking under different conditions. Mahrous a. Taher [6] used an improved moth-flame optimization algorithm to solve the optimal power flow problem. Mohamed a. Tolba [7] proposed the moth-flame optimization algorithm to solve the problem of the optimal configuration of a distributed power supply and shunt capacitor banks, in which it played a substantial role in improving voltage distribution and voltage stability, improving the power quality of the system and reducing the power loss of the system. Indrajit N. Trivedi [8] used the moth-flame optimizer to optimize the power flow of a power system to improve voltage stability and reduce losses.
The moth-flame optimization algorithm has also been applied to the medical and other relevant fields. Some scholars’ studies are as follows. Gehad Ismail Sayed [9] used neutrophils to optimize the moth-flame population for the automatic detection of mitosis in breast cancer tissue images. Mingjing Wang [10] applied a chaotic moth-flame optimization algorithm to medical diagnosis and proposed a new learning scheme for a nuclear limit learning machine.
In the field of economics, some scholars have conducted relevant research on the moth-flame optimization algorithm. Asmaa A. Elsakaan [11] proposed an enhanced moth-flame optimization algorithm for solving non-convex economic problems of the valve point effect and emissions. Pooja Jain [12] proposed an optimal bidding scheme for the moth-flame optimization strategy bidding problem based on opposition theory in order to maximize the profits of power generation companies. Soheyl Khalilpourazari [13] used an interior point method and moth-flame optimization algorithm to solve a multi-item and multi-constraint economic order quantity model with nonlinear elements.
Other areas of research on the moth-flame optimization algorithm are as follows. Arif Abdullah [14] applied it to solve the environmental problems of the manufacturing industry and proposed a new assembly sequence planning (ASP) model, which was used as a reference for the design of an assembly station and effectively solved the ASP problem. Atif Ishtiaq [15] proposed a vehicle self-organizing network clustering algorithm based on the moth-flame optimization algorithm. Wei Kun Li [16] proposed a new water resource utilization method by applying a multi-target moth-flame optimization algorithm to improve water resource utilization efficiency. Rehab Ali Ibrahim [17] proposed the improved brainstorm optimization method combined with the moth-flame optimization algorithm to improve the classification performance for galaxy images. Rashmi Sharma [18] proposed the moth-flame optimization algorithm for testing software models facing objects. Rajneesh Kumar Singh [19] combined the multi-objective optimization method based on the back-propagation artificial neural network with the moth-flame optimization algorithm to predict the optimal process parameters of magnetic abrasive finishing.
In addition, many scholars have made a series of improvements based on the original moth-flame optimization algorithm. Mohamed Abd Elaziz [20] proposed to improve the moth-flame optimization algorithm based on the opposite learning technique and differential evolution method, effectively preventing the algorithm falling into the local optimal value and improving the convergence of the algorithm. Srikanth Reddy K [21] used binary coding to modify the moth-flame optimization algorithm to propose a solution for power system unit commitment operation plan. Saunhita Sapre [22] proposed an evolutionary boundary constraint optimization algorithm based on Cauchy mutation and global optimization. Liwu Xu [23] proposed an optimized moth-flame optimization algorithm based on cultural learning and Gaussian variation. Yueting Xu [24] proposed an improved moth-flame optimization algorithm based on Gaussian variation and a chaotic local search. Yueting Xu [25] proposed an improved moth-flame optimization algorithm combining three global optimization strategies: Gaussian mutation, Cauchy mutation and Lévy mutation. The authors in [11,25,26] use Lévy flight to update the position of the current search agent for each search agent. Asmaa A. Elsakaan [11] solves the nonconvex economic dispatch (ED) problem with valve point effects and emissions, Yueting Xu [25] solves function optimization problems, and Zhiming Li [26] solves function optimization and engineering problems. This paper adds a Lévy flight mechanism to the global search position, and it has remarkable effect in the solving of engineering problems.
The search performance of an MFO depends on the exploration and exploitation phases. During exploration, the algorithm searches the whole search space. The exploitation involves a local search on a small research area. On the other hand, an MFO suffers from premature convergence and slow population diversity. Therefore, this study aims to prevent local optimum stagnation and increase the convergence speed, maintaining a balance between exploration and exploitation. The novel contributions of this paper are as follows: Firstly, on the global research stage, a search mechanism of Lévy flight is designed for updating the moth positions, which can effectively help the algorithm to maintain the diversity of the population and improve the global search ability. Secondly, for all phases, a dimension-by-dimension evaluation strategy is used, which can effectively coordinate the global search and local development of the algorithm and improve the convergence speed of the algorithm. The dimension-by-dimension strategy is introduced in a moth-flame optimization algorithm to reduce the interference from dimensions. By using this strategy in the updating formula, the convergence accuracy and performance of the algorithm are improved significantly. The efficiency of the improved moth-flame optimization algorithm (IMFO) is tested by solving 23 classical optimization functions. More importantly, the IMFO algorithm for solving four classical engineering design problems has made great progress. The results obtained show that IMFO is competitive in comparison with other state-of-the-art optimization methods.
The rest of this paper is organized as follows: Section 2 describes the MFO algorithm. Section 3 presents the proposed IMFO algorithm, which includes two improved strategies. In addition, the experimental studies and comparisons are exhibited in Section 4. Section 5 display the results of IMFO for solving four classical engineering problems: pressure vessel, tension/compression spring, welded beam and three-bar truss design problems. Finally, the conclusion and future work are summarized in Section 6.

2. Moth-Flame Optimization Algorithm (MFO)

In this chapter, we will introduce the biological principle and basic model of the moth-flame optimization algorithm. The description of the basic situation of the algorithm will be more helpful for the operation and implementation of the points for improvement for the algorithm in the next chapter.

2.1. Biological Background of Moth-Flame Optimization Algorithm

Moths use special navigational mechanisms for lateral orientation during night flight. In this mechanism, the moth flies by maintaining a fixed angle of its light relative to the moon. Since the moon is so far away from the moth, the moth uses this near-parallel light near the surface to stay in a straight line. Although lateral orientation is effective, moths are often observed to circle the source repeatedly until they are exhausted. In fact, moths are fooled by the fact that there are many artificial or natural point light sources. This is due to the low efficiency of lateral positioning; only under the condition of the light source being very far away is it helpful to the moths for maintaining straight flying movement, and there is a lot of artificial or natural light other than that resulting from moths being very close to the moon; when the moths continue to use as a light source the light emitted from a fixed angle, failure can lead to navigation and produce, as shown in Figure 1, a deadly spiral flight path.

2.2. Basic Model of Moth-Flame Optimization Algorithm

In the MFO algorithm, the moth is assumed to be the candidate solution to the problem, and the variable to be solved is the position of the moth in space. By changing their position vectors, moths can fly in one, two, three and even higher dimensions. Since the MFO algorithm is essentially a swarm intelligence optimization algorithm, the moth population can be represented as follows in the matrix:
M = [ m 1 , 1 m 1 , d m n , 1 m n , d ]
where n represents the number of moths and d represents the number of control variables to be solved (dimension of the optimization problem). For these moths, it is also assumed that there is a corresponding list of fitness value vectors, represented as follows:
O M = [ O M 1 O M 2 O M n ]
In the MFO algorithm, each moth is required to update its own position only with the unique flame corresponding to it, so as to avoid the algorithm falling into the local optimal value, which greatly enhances the algorithm’s global search ability. Therefore, the positions of the flame and moth in the search space are variable matrices of the same dimension.
F = [ f 1 , 1 f 1 , d f n , 1 f n , d ]
For these flames, it is also assumed that there exists a corresponding column of fitness value vectors, represented as follows:
O F = [ O F 1 O F 2 O F n ]
During the iteration process, the update strategy of the variables in the two matrices is different. Moths are actually search individuals that move within the search space, and the flame is the best position that the iteratively optimized moths can achieve so far. Each individual moth surrounds a corresponding flame, and when a better solution is found, it is updated to the location of the flame in the next generation. With this mechanism, the algorithm is able to find the global optimal solution.
In order to carry out mathematical modeling for the flight behavior of a moth to a flame, the updating mechanism for the position of each moth relative to a flame can be expressed by the following equation:
M i = S ( M i , F j )
where M i represents the ith moth, F j represents the jth flame and S represents the helical function.
This function satisfies the following conditions:
(1)
The initial point of the helical function is selected from the initial space position of the moth;
(2)
The end point of the spiral is the space position corresponding to the contemporary flame;
(3)
The fluctuation range of the spiral should not exceed its search space.
According to the above conditions, the helical function of moth flight path is defined as follows:
S ( M i , F j ) = D i · e b t · c o s ( 2 π t ) + F j
t = ( a 1 ) r a n d + 1
a = 1 + I t e r a t i o n ( 1 T m a x )
where D i is the linear distance between the ith moth and the jth flame, b is the logarithmic helix shape constant defined, and the path coefficient t is the random number in [−1,1]. The magnitude of t is represented by Formula (7), where a is represented by Formula (8), and its magnitude decreases linearly from −1 to −2. The expression of D i is as follows:
D i = | F j M i |
Formula (9) simulates the path of the moth’s spiral flight. From this equation, it can be seen that the next position of the moth’s renewal is determined by the flame it surrounds in the contemporary era. The coefficient t ( t   [ 1 , 1 ] ) in the helix function represents the distance between the moth’s position and the flame in the next optimization iteration, ( t = 1 ) represents the closest position to the flame, and t = 1 represents the farthest position. The spiral equation shows that moths can fly around the flame rather than just in the space between them, thus ensuring the algorithm’s global search capability and local development capability.
When this model is adopted, it has the following characteristics:
(1)
By randomly selecting parameters t , a moth can converge to any field of flame;
(2)
The smaller the value of t , the closer the moth is to the flame;
(3)
As the moth gets closer and closer to the flame, its position around the flame is updated more and more rapidly.
The above flame position update mechanism can ensure the local development ability of the moth around the flame. To improve the chances of finding a better solution, the best solution found in the current generation is used as the location of the next generation of moths around the flame. Therefore, the flame position matrix F usually contains the optimal solution currently found. In the optimization process, each moth updates its position according to the matrix F . The path coefficient r in the MFO algorithm are internal random numbers in [ r , 1 ] , and the variable r decreases linearly according to the number of iterations in the optimization iteration process in [ 1 , 2 ] . In this process, the moth will approach the flame in its corresponding sequence more precisely as the iteration progresses. After each iteration, the flames are reordered based on fitness values. In the next generation, the moth updates its position according to the flame corresponding to it in the updated sequence. The first moth always updates its position relative to the flame with the best fitness value, and the last moth updates its position relative to the one with the worst fitness value in the list.
If each location update of n moths is based on n different locations in the search space, the local development capability of the algorithm will be reduced. In order to solve this problem, an adaptive mechanism is proposed for the number of flames, so that the number of flames can be reduced adaptively in the iterative process, thus balancing the algorithm’s global search capability and local development capability in the search space. The formula is as follows:
f l a m e n o = r o u n d ( N l N 1 T )
where l is the current iteration number, N is the initial maximum number of flames set, and T represents the maximum number of iterations set. At the same time, due to flame reduction, the moth corresponding to the reduced flame in the sequence in each generation updates its position according to the flame with the worst current fitness value.

3. An Improved Moth-Flame Optimization Algorithm (IMFO)

In order to improve the global exploration ability of the original moth-flame optimization algorithm, adding the Lévy flight mechanism to the global exploration flight path of the moth can effectively expand the search space of the moth and improve the global search ability of the moth. While improving the global search ability of the algorithm, the local development ability of the algorithm is also improved by means of the update strategy based on greedy reservation. By combining the two strategies, the global search and local development capabilities of the algorithm can be effectively balanced, and the original algorithm can be improved.

3.1. Lévy Flight

Lévy flight [27] is a Markov process proposed by Paul Pierre Lévy, a famous French mathematician. A random walk is a mathematical statistical model that consists of a series of trajectories, each of which is random, used to represent irregular patterns of change. Lévy flight is a typical random walk mechanism, which represents a class of non-Gaussian stochastic processes and is related to the Lévy stable distribution. Its steady increment obeys the Lévy steady distribution. Lévy flight is characterized by many small steps but occasionally large steps, so that moving entities do not repeatedly search the same place, changing the behavior of a system. Although its motion direction is random, its motion step size has an exponential rate distribution. The combination of the moth-flame optimization algorithm and Lévy flight strategy can expand the search range of the algorithm, increase the diversity of the population, and make it easier for the algorithm to jump out of the local optimum.
For example, bats with Lévy’s flight behavior [27] are more likely to find food. At present, Lévy flight has been successfully applied to the optimization field, and the results show that Lévy flight has achieved satisfactory results. In the global update of the moth algorithm, the Lévy flight mechanism is added to expand the search scope of the algorithm, making it difficult for the algorithm to fall into local optimization. The improved Formula (11) is:
S ( M i , F j ) = D i · e b t · cos ( 2 π t ) + L ( d ) · F j
Here, t is the current iteration number, Mi is the ith moth, Fj is the jth flame, and Di is the distance between the ith moth and the jth flame. When the moth spiral flight updates its position, the addition of the Lévy flight mechanism can expand the search range of the moth and prevent it from falling into local optimization. The formula of Lévy flight is as follows [28]:
L e v y ( x ) = 0.01 r 1 δ | r 2 | 1 φ
where r1 and r2 are random numbers between [0,1], φ is a constant 1.5, and the δ formula is as follows:
δ = ( τ ( 1 + φ ) sin ( π φ 2 ) τ ( 1 + φ 2 ) φ 2 ( φ 1 2 ) ) 1 φ
where τ ( x + 1 ) = x ! ; 200 step sizes have been drawn to form a consecutive 50 steps of Lévy flight as shown in Figure 2.
This article describes three Lévy flight paths as shown in Figure 2a–c. In the picture, the parameters are set as follows: φ is a constant 1.5, the number of steps is set as 200, and the number of dimensions is set as 10. As we can see, the paths in the three pictures are very different, which can effectively demonstrate that Lévy flight is a random walk mechanism. However, there are some long walks after short walks. In Lévy flights, exploratory local searches over short distances are the same as occasional longer walks, ensuring that the system does not fall into local optimality. Lévy flight maximizes resource search efficiency in uncertain environments. The random number algorithm is used to draw three Lévy flight paths with 200 consecutive steps on the plane, as shown in Figure 2. The strategy ensures that the improved moth-flame optimization algorithm avoids falling into local optimality.

3.2. Dimension-By-Dimension Evaluation Strategy

In the standard MFO algorithm, the full-dimension update evaluation strategy is adopted; that is, after updating all the dimension information, the updated solution is evaluated according to the value of the objective function. This method, [29], will, to some extent, obscure the information of the evolutionary dimension, waste the known evaluation times and worsen the convergence rate of the solution. At the same time, such an updating mode causes mutual interference between dimensions, which affects the convergence speed and optimization accuracy of the algorithm. Assuming that the objective function f ( x ) = x 1 2 + x 2 2 + x 3 2 and the global optimal solution for x o p t = ( 0 , 0 , 0 ) , the optimal value of f ( x ) = 0 . Supposing the algorithm iteration solution is the first k generation of the ith solution for x k , i = ( 0.5 , 0 , 0.5 ) , the objective function value of f ( x k , i ) = 0.5 . In the process of the iteration algorithm, the first hypothesis according to Formula (5) is that the x k , i overall updates to (0, −1, 0), resulting in the objective function value of f ( x k + 1 , i ) = 1 . According to the objective function evaluation mechanism, f ( x k + 1 , i ) = 1 > 0.5 ; the updated solution compared to the original objective function value is big, so the algorithm will retain the original objective function values and discard the updated value of the target function. However, the value of the updated solution in the first dimension evolves from the previous 0.5 to 0 and and the value of the third dimension evolves from 0.5 to 0, but since the value of the second dimension degrades from 0 to −1, the algorithm will discard the updated solution directly in the evaluation strategy of the full dimension update. Therefore, this evaluation mechanism will waste the evaluation times of the solution and worsen the convergence rate.
The improved dimension-by-dimension update strategy can prevent the above problems. The improved moth-flame optimization algorithm based on the greedy retention of the one-dimension evaluation strategy can consider the information updating of each dimension. The idea of this strategy is as follows: the values of one dimension are updated to form a new solution with the values of other dimensions; then, the new solution is evaluated according to the fitness of the objective function. If the quality of the current solution can be improved, the updated result of this dimension for the solution is retained. Otherwise, the updated current dimension value is discarded, the previous dimension information is kept, and the next dimension is updated, using this greedy retention method until the update of each dimension is completed. For example, suppose that the value of the first dimension of the algorithm is updated to 0 in the iteration process, the solution after the dimension update is (0,0,0.5), and the value of the objective function obtained by the update is f ( x k + 1 , i ) = 0.25 < 0.5 . At this point, the algorithm retains the update of the first dimension and then updates the next dimension. If the updated value of the first dimension is 1, the updated solution is (0,0,0.5), and the value of the objective function is f ( x k + 1 , i ) = 1.25 > 0.5 , the algorithm based on the dimension-by-dimension evaluation update mechanism will discard the update of the current dimension and carry out the update operation of the next dimension. This updating mechanism can prevent the waste of the number of evaluation solutions and optimize the convergence speed of the algorithm.
In order to demonstrate the effectiveness of dimension-by-dimension valuation, the F2 test function shown in Figure 3a is randomly selected in this paper. The formula for this function is f 2 ( x ) = i = 1 n | x i | + i = 1 n | x i | . The function definition field is [−10,10], and the theoretical optimal value is 0. This function is a continuous unimodal function., which is mostly used to investigate the optimization accuracy of the algorithm. When the dimension of function F2 (a) is set to 100, date1 (b) represents the convergence trend of the standard moth-flame optimization algorithm for function F2, and date2 (b) represents the convergence trend of the algorithm for function F2 after adding dimension-by-dimension evaluation into the standard algorithm in Figure 3b. It can be seen that the algorithm of dimension-by-dimension evaluation can make the convergence of the function faster.
The evolutionary dimension of the solution is paid attention to by using the strategy of updating dimension-by-dimension based on greedy reservation. Eliminating the influence of the degenerate dimension on the solution saves the evaluation time wasted by random updating. It can effectively suppress the interference between different dimensions, improve the convergence rate of the algorithm and improve the local development ability of the algorithm.
The pseudo-code of the improved algorithm is as follows:
Algorithm 1 IMFO Algorithm Pseudo-Code
1: Set population size N, maximum number of iterations T m a x , and dimension of objective function Dim
2: Initializes the moth position
3: while (t < T m a x ) do
4:   Update the flame position according to Equation (9)
5:  Transboundary treatment of moths
6:    if i = 1
7:   find the moth and update the position of the flame according to the moth
8:   else
9: find the moth and update the position of the flame according to the moth
10:  end
11:   Update according to Equation (8)
12:  for i = 1 : s i z e ( M o t h _ p o s , 1 )
13:   for j = 1 : s i z e ( M o t h _ p o s , 2 )
14:       if i f l a m e _ n o
15:        Update Di according to Equation (9)
16:        Update S (Mi, Fj) according to Equation (11)
17:       end
18:       if i > f l a m e _ n o
19: Update Di according to Equation (9)
20: Update S (Mi, Fj) according to Equation (6)
21: end
22: end
23: end
24: Update moth position and fitness value through dimension-by-dimension evaluation
25: t = t +1
26: end while
27: Output the best search location and its fitness value
The flowchart in Figure 4 of the improved algorithm is as follows. It can be seen that the improvements are as follows: first, the Lévy flight mechanism is added to the global search, which can expand the global search capability of the algorithm and prevent the algorithm falling into local optimization. Secondly, adding the dimensionality evaluation mechanism into the algorithm can effectively balance the global exploration ability and local development ability, reduce the running times of the algorithm and improve the running efficiency of the algorithm. When calculating 23 test functions, the precision of the algorithm can be improved and the function can be converged faster. In solving engineering problems, better solutions can be obtained than with other algorithms.
Through the flowchart, we can clearly see the improved moth flame algorithm process and improvements compared with the original moth flame algorithm. The Lévy flight and dimension-by-dimension evaluation mechanism can balance the global search capability and local developability of the algorithm so that the algorithm can achieve better results in solving engineering problems.

4. Experimental Studies and Comparisons

In this section, we describe the basic expression, upper and lower bounds, and theoretical optimal value of the test function. Then, we selected nine comparison algorithms and set their parameters. Then, the performance of nine comparison algorithms in 13 non-fixed dimensions and 10 fixed dimensions was compared through experimental data. Thirteen functions of non-fixed dimensions were set up in the dimensions 10,30 and 100, respectively. The convergence precision of the algorithm is compared in different aspects. Finally, the convergence of the algorithm is tested and compared.

4.1. Test Function and Experimental Parameter Setting

In the experiment, 23 benchmark functions were selected according to [30] and [31], among which the first 13 functions were functions of variable dimensions and the last 10 functions were functions of fixed dimensions. A complete set of benchmark functions, consisting of 23 different functions (single mode and multi-mode), is used to evaluate the performance of the algorithm. The definition, function image, upper and lower bounds, dimension settings and minimum of the reference function are shown in Table 1 and Table 2. We introduce reference functions such as F1, F2 and F3, up to F23. For F1 to F7, there is a single peak optimization problem with an extreme point in a given search area. These functions are used to study the convergence rate and optimization accuracy of the algorithm. F8–F23 are multi-modal optimization functions with multiple local extremum points in a given search area. They are used to evaluate the ability to jump out of local optima and seek global optima. In addition, the dimensions of d = 10, d = 30 and d = 100 are set for the first 13 functions in this paper, so as to test different algorithms.
Meanwhile, eight comparison algorithms were selected, namely, the original moth-flame algorithm (MFO), sine and cosine algorithm (SCA), bat algorithm (BA), spotted hyena algorithm (SHO), particle swarm optimization algorithm (PSO), whale algorithm (WOA), grey wolf algorithm (GWO) and salp swarm algorithm (SSA). The parameter settings in these comparison algorithms are shown in Table 3. In addition to the parameter settings in Table 3, the population number of each algorithm is set to 30, and the number of iterations is set to 1000. The experiment was conducted on the 64-bit operating system of Windows 7 with the software MATLAB 2014a version, and the processor was an Intel(R) Core (TM) i5-5200U [email protected] GHz 2.20 GHz with 4.00 GB of RAM.
Table 1 shows the expressions, images and upper and lower bounds of 13 benchmark functions. There, L represents the lower bound, U represents the upper bound of the functions, D represents the dimension of the function and fmin represents the theoretical optimal value.
Table 2 shows the ten complex dimension test functions.

4.2. Comparison of Algorithm Parameter Settings

Table 3 shows the parameter settings of the different algorithms during the experiment. In addition, in the process of running the algorithm, the population quantities were set to 30 and the maximum number of iterations was set to 1000.

4.3. Comparison with Other Algorithms

In order to verify the effectiveness of the IMFO algorithm, eight different algorithms are used to test the mathematical benchmark functions in this section. Different algorithm processing function run results are shown in Table 4, where N/A means that the algorithm is not suitable for solving this function. Table 4 shows the comparison of the means and standard deviations of the nine algorithms when the dimension is 10. It should be noted that the best optimal solution obtained is highlighted in bold font.
As shown in the Table 4 results, we found that the improved moth-flame optimization algorithm is better than the other algorithms for solving the average (Ave) and standard deviation (Std) values of the benchmark functions F1, F3, F4, F7, F9, F10, F11, F15, F16, F17, F18 and F19. In addition, the standard deviations (Std) of the base functions F5, F21, F22 and F23 of the improved IMFO algorithm can obtain the optimal value. The best average can also be obtained for F8. Particle swarm optimization (PSO) ranks second for the performance of F6, F12 and F13. Additionally, the spotted hyena optimizer (SHO) obtains the best value on the function F2, and it obtains the minimum average on the function F16. The salp swarm algorithm (SSA) obtains the best value on the function F14. Finally, as we can see, BA can obtain the minimum average on the function F5. In addition, GWO can obtain the minimum average on the functions F17, F21, F22 and F23. SCA has the best stability in solving the function F8.
The results indicate the superiority of the proposed algorithm. Analysis of the averages and standard deviations reveals that the proposed IMFO algorithm shows competitive performance in comparison with the compared algorithms. The comparison results for the selected unimodal functions (F1–F7) are shown in Table 4. Note that, except for F2, F5 and F6, IMFO is better than the compared eight algorithms for all the other test functions. In particular, a huge improvement is achieved for the benchmark functions F1 and F3. These results verify that IMFO has excellent optimization accuracy with one-global minimal functions. For the multi-modal functions (F8–F23), IMFO also performs better than other algorithms. IMFO can find superior average results for the test functions F8, F9, F10, F11, F15, F16, F17, F18, F19 and F20. These results mean that the improved IMFO algorithm has a good ability to jump out of local optima and seek global optima.
It is obvious that IMFO better solves these 23 benchmark functions than the other algorithms. At the same time, it can be seen from Table 4 that the variance of the IMFO algorithm on 16 test functions is the minimum value of the nine comparison functions, indicating that the improved moth-flame optimization algorithm has good robustness.
Table 5 shows a comparison of the improved algorithm with the other algorithms for the first 13 functions, when d = 30, in terms of experimental data.
It can be seen that, compared with the other algorithms, IMFO algorithm for functions F3, F4, F9, F10, F11 and F12 obtains minimum values. Secondly, the WOA algorithm is the best in solving function F1. SCA performs the most stably in solving the function F8. When d = 30, SHO can still obtain the minimum value in solving function F2. At this point, the GWO algorithm performs best in solving the function F7. The PSO algorithm can obtain the minimum value when solving F13 and the minimum average value when solving F6. Finally, the BA algorithm can obtain the minimum average value when solving F5, and it has the best robustness and the most stable result when solving F6. Therefore, when d = 30, it can be seen from the solution results of the nine algorithms on the 13 test functions that the solution effect of IMFO is still optimal compared with that of the other algorithms.
Table 6 compares the improved algorithm with the other algorithms for the first 13 functions in terms of experimental data, when d = 100.
Compared with other algorithms, the IMFO algorithm for the functions F3, F4, F7, F9, F10 and F11 obtains minimum values with a significant effect. At the same time, when solving functions F6, F8 and F13, the minimum variance can be obtained, which indicates that the IMFO algorithm has good stability and strong robustness in solving high-dimensional problems. At this point, compared with d = 10 and d = 30, the WOA algorithm shows obvious advantages in solving the results of functions. It has the best performance in solving functions F1, F2 and F5. Meanwhile, it can obtain the minimum average when solving functions F8, F12 and F13. The BA algorithm can obtain the minimum average value when solving F6 and the best stability when solving F12. However, when the dimension increases, MFO, SCA, BA, SHO, PSO, GWO and SSA produce poor results. The improved moth-flame optimization algorithm and the whale algorithm produce better results, but the improved moth-flame optimization algorithm is still the best on the whole.

4.4. Convergence Test

A convergence test refers to drawing different convergence images when running different test functions with different algorithms, through which the convergence speed and convergence accuracy of the algorithm can be compared. In order to further study the performance and effect of the improved algorithm, this section tests the convergence of nine different algorithms under the conditions that the dimension d of the 13 functions from F1 to F13 is 10, the maximum number of iterations is 1000 and the population number is 30, and analyzes the convergence speed and calculation accuracy of the algorithm.
To further illustrate the advantages of the improved algorithm, the convergence behavior is shown in Figure 5. According to the convergence curve shown in Figure 5, it can be verified that the proposed IMFO converges faster than the other algorithms. The results show that the improved algorithm based on Lévy flight and dimension-by-dimension evaluation can effectively improve the convergence trend of the original algorithm. Twelve functions are selected to demonstrate the convergence test of the algorithm. It can be seen from the image in (a) to (l) that the improved moth-flame optimization algorithm for those functions has a better convergence than the original moth-flame optimization algorithm.
Compared with the other algorithms, the improved moth-flame optimization algorithm has faster convergence speed and higher calculation accuracy on the 10 functions F1 (a), F2 (b), F3 (c), F4 (d), F5 (e), F7 (f), F9 (g), F10 (h), F11 (i) and F15 (j). On the two function F16 (k) and F18 (l), there is not much difference in the convergence trends for those algorithms. As we can see, the improved moth-flame optimization algorithm converges the most quickly and has higher convergence precision on the functions F1 (a), F3 (c), F4 (d) and F11 (i). On the function F2 (b), GWO, IMFO and WOA perform better than the other algorithms. GWO has best convergence speed at the beginning, but its later convergence is slow. IMFO and WOA converge faster than GWO, and they have smaller convergence. However, WOA is slightly better than IMFO in the solution of the function F2 (b). On the functions F1 (a) and F4 (d), although the GWO algorithm converges quickly in the early stage, the IMFO algorithm converges the fastest in the later period. Furthermore, the value of function F2 (b) solved by the IMFO algorithm is the smallest compared with that with the other algorithms. On the functions F3 (c) and F11 (i), the IMFO algorithm has an absolute advantage over the other algorithms. On the function F7 (f), the solution with SCA is slightly better than that with IMFO. The GWO algorithm almost has the same result as the IMFO algorithm when solving the function F9. The IMFO algorithm ranks third in the result for solving the function F5 (e). The SHO algorithm has the best performance in solving the function F10 (h), which has better convergence speed than the IMFO algorithm. However, they have the same convergence value. On the function F15 (j), the WOA, GWO and IMFO algorithms have almost similar performance in solving it. Generally, the IMFO algorithm has faster convergence speed and higher convergence precision than the other algorithms.

4.5. Statistical Analysis

Derrac et al. proposed in literature [32] that statistical tests should be carried out to evaluate the performance of improved evolutionary algorithms. In other words, comparing algorithms based on average, standard deviation and convergence analysis is not enough. Statistical tests are needed to verify that the proposed improved algorithm shows significant improvement and advantages over other existing algorithms. In this section, the Wilcoxon rank sum test and Friedman test are used to verify that the proposed IMFO algorithm has significant improvements and advantages over other comparison algorithms.
In order to determine whether each result of IMFO is statistically significantly different from the best results of the other algorithms, the Wilcoxon rank sum test was used at the significance level of 5%. The dimension d of the 13 functions from F1 to F13 is 10, the maximum number of iterations is 1000, and the population number is 30. The p-value for Wilcoxon’s rank-sum test on the benchmark functions was calculated based on the results of 30 independent running algorithms.
In Table 7, the p values calculated in the Wilcoxon rank sum tests for all the benchmark functions and other algorithms are given. For example, if the best algorithm is IMFO, paired comparisons are made between IMFO and MFO, IMFO and SCA, and so on. Because the best algorithm cannot be compared to itself, the best algorithm in each function is marked N/A, meaning “not applicable”. This means that the corresponding algorithm can compare itself with no statistical data in the rank sum test. In addition, in Table 7, N/A means not applicable. According to Derrac et al., p < 0.05 can be considered as a strong indicator for rejecting the null hypothesis. According to the results in Table 7, the p value of IMFO is basically less than 0.05. The p value was greater than 0.05 only for F5, F8, F14 and F19 for IMFO vs. MFO, F14 for IMFO vs. SCA, F18 for IMFO vs. BA, F14 and F20 for IMFO vs. PSO, F8 and F9 for IMFO vs. WOA, and F5 and F15 for IMFO vs. GWO. This shows that the superiority of the algorithm is statistically significant. In other words, the IMFO algorithm has higher convergence precision than the other algorithms.
Furthermore, to make the statistical test results more convincing, we performed the Friedman test on the average values calculated by the nine algorithms on 23 benchmark functions in Section 4.3. The significance level was set as 0.05. When the p value was less than 0.05, it could be considered that several algorithms had statistically significant differences. When the algorithm’s p value is greater than the significance level of 0.05, it can be considered that there is no statistically significant difference between the algorithms.
According to the calculation results in Table 8, when the dimension of the current 13 functions is set to 10, the rank means of the nine algorithms are 2.71 (IMFO), 5.45 (MFO), 5.52 (SCA), 6.52 (BA), 7.86 (SHO), 3.38 (PSO), 4.24 (WOA), 4.19 (GWO) and 5.12 (SSA). The priority order is IMFO, PSO, GWO, WOA, SSA, MFO, SCA, BA and SHO. Here, p = 1.13 × 10 9 < 0.05 ; this indicates that there are significant differences among the nine algorithms.
Similarly, when the dimension of the first 13 functions is set to 30, the rank means of the nine algorithms are 2.92 (IMFO), 8.25 (MFO), 6.83 (SCA), 4.92 (BA), 5.67 (SHO), 4.17 (PSO), 3.50 (WOA), 3.17 (GWO) and 5.58(SSA). The priority order is IMFO, GWO, WOA, PSO, BA, SSA, SHO, SCA and MFO. Here, p = 2.00 × 10 6 < 0.05 ; this indicates that there are significant differences among the nine algorithms.
Finally, when the dimension of the first 13 functions is set to 100, the rank means of the nine algorithms are 2.63 (IMFO), 7.17 (MFO), 6.83 (SCA), 4.00 (BA), 5.83 (SHO), 2.79 (PSO), 3.08 (WOA), 6.25 (GWO) and 6.42 (SSA). The priority order is IMFO, PSO, WOA, BA, SHO, GWO, SSA, SCA and MFO. Here, p = 5.57 × 10 7 < 0.05 ; this indicates that there are significant differences among the nine algorithms.
In the fourth chapter, eight comparison algorithms are selected to conduct 30 experiments and the mean values and variance of 23 test functions are solved, which are compared with those from the improved moth-flame optimization algorithm. According to the experimental data, the IMFO algorithm has good stability in solving function values. In addition, 12 of the 23 test functions were randomly selected for convergence analysis in this paper. As can be seen from the convergence trend graph of Figure 5, the IMFO algorithm has better convergence speed and relatively high convergence accuracy on the whole. Finally, both the Wilcoxon rank sum test and Friedman test indicate that the improved IMFO algorithm has good performance. In Chapter 5, the improved moth-flame optimization algorithm is applied to solve four engineering problems—namely, pressure vessel, compression/tension spring, welded beam and trusses design problems—to illustrate the application of the IMFO algorithm in practice.

5. IMFO for Engineering Problems

This subsection analyzes the performance and efficiency of IMFO by solving four constrained real engineering problems, namely, the pressure vessel problem, tension/compression spring problem, welding beam problem and three-bar truss problem. These problems have many inequality constraints, so the IMFO tries to handle them in processing. The number of solutions in all the experiments is 30, and the maximum number of iterations is 1000.

5.1. Pressure Vessel Design Problem

The purpose of the pressure vessel problem is to minimize the total cost of the cylindrical pressure vessel [33]. There are four design variables and four constraints based on the thickness of the shell ( T s ), the thickness of the head ( T h ), the internal radius (R), and the length of the cylindrical section without considering the head (L). Figure 6 shows the pressure vessel and parameters involved in the design. The design can be expressed as follows:
Consider x = [ x 1   x 2   x 3   x 4 ] = [ T s   T h   R   L ]
Objective function: f ( x ) min = 0.6224 T s R L + 1.7781 R 2 T h + 3.1661 T s 2 L + 19.84 T h 2 L
Subject to
g 1 ( x ) = T s + 0.0193 R 0 , g 2 ( x ) = T h + 0.00954 R 0 , g 3 ( x ) = π L R 2 4 3 π R 3 + 1296000 0 , g 4 ( x ) = L 240 0 ,
Variable ranges:
0 x 1 99 , 0 x 2 99 , 10 x 3 200 , 10 x 4 200.
In this section, the pressure vessel problem is solved by the IMFO algorithm, and the results are compared to those from the MFO [1], OMFO [22], ES [31], CSDE [33], CPSO [34], LFD [35], WOA [36], MOSCA [37], RDWOA [38], CCMWOA [39], LWOA [40], GA [41], BFGSOLMFO [42] and IMFO [43]. Table 9 shows the IMFO is able to obtain the best solution for this problem. The results show that the IMFO algorithm can outperform all the other algorithms and outperform by MOSCA [37] and IMFO [43].
As can be seen from Table 9, when the four parameters T s , T h , R and L are set as 0.7781948, 0.3846621, 40.32097 and 199.9812, respectively, the minimum value of IMFO is 5885.3778. Compared with the other methods, IMFO achieves better results in the pressure vessel design problem. Therefore, this shows that the algorithm is feasible and effective in solving engineering problems with constraints.

5.2. Compression/Tension Spring Design Problem

The goal of this design problem is to minimize the weight of the compression/tension spring [27]. Figure 7 shows the spring and parameters. In this problem, there are three variables and four constraints. These variables include the coil diameter (d), mean coil diameter (D) and number of effective coils (N). The mathematical model for this problem is:
Consider x = [ x 1   x 2   x 3 ] = [ d   D   N ]
Objective function:
f ( x ) min = x 1 2 x 2 x 3 + 2 x 1 2 x 2
Subject to
h 1 ( x ) = 1 x 2 3 x 3 71785 x 1 4 0 , h 2 ( x ) = 4 x 2 2 x 1 x 2 12566 ( x 2 x 1 3 x 1 4 ) + 1 5180 x 1 2 0 , h 3 ( x ) = 1 140.45 x 1 x 2 3 x 3 0 , h 4 ( x ) = x 1 + x 2 1.5 1 0 ,
Variable ranges:
0.05 x 1 2.00 , 0.25 x 2 1.30 , 2.00 x 3 15.0
In this section, the compression/tension design problem is solved using the IMFO algorithm, and the results are compared to those from the MFO [1], LAFBA [27], ES [31], CPSO [34], LFD [35], WOA [36], CCMWOA [39], LWOA [40], GA [41] and RO [44]. Table 10 shows the decision variables and constraint values of the best solutions obtained by different methods. The results show that the IMFO algorithm can outperform all the other algorithms.
As can be seen from Table 10, when the three parameters d , D and N are set as 0.05159, 0.354337 and 11.4301, respectively, the minimum value of IMFO is 0.012666. In this compression, IMFO can outperform all the other algorithms and is equal to CCMWOA [39].

5.3. Welded Beam Design Problem

The objective of this model is to determine the minimum manufacturing cost [36]. Figure 8 shows the welded beam and parameters involved in the design. In this case, four variables affect the manufacturing cost, including the height of the reinforcement (t), the thickness of the weld (h), the thickness of the reinforcement (b) and the length of the reinforcement (l). The optimal design of this problem must satisfy the constraint conditions: shear stress ( τ ), bending stress in the beam ( θ ), deflection of the beam ( δ ), and buckling load ( p c ). The mathematical model of the problem can be described as:
Consider x = [ x 1   x 2   x 3   x 4 ] = [ h   l   t   b ]
Objective function:
f ( x ) min = 1.10471 x 1 2 x 2 + 0.04811 x 3 x 4 ( 14.0 + x 2 )
Subject to
g 1 ( x ) = τ ( x ) τ max 0 , g 2 ( x ) = σ ( x ) σ max 0 , g 3 ( x ) = δ ( x ) δ max 0 , g 4 ( x ) = x 1 x 4 0 , g 5 ( x ) = P P c ( x ) 0 , g 6 ( x ) = 0.125 x 1 0 , g 7 ( x ) = 1.10471 x 1 2 + 0.04811 x 3 x 4 ( 14.0 + x 2 ) 5.0 0 ,
Variable ranges:
0.1 x 1 2 , 0.1 x 2 10 , 0.1 x 3 10 , 0.1 x 4 2 ,
The Where
τ ( x ) = ( τ ) 2 + 2 τ τ x 2 2 R + ( τ ) 2 ,   τ = P 2 x 1 x 2 ,   τ = M R J , M = P ( L + x 2 2 ) ,   R = x 2 2 4 + ( x 1 + x 3 2 ) 2 , J = 2 { 2 x 1 x 2 [ x 2 2 4 + ( x 1 + x 3 2 ) 2 ] } ,   σ ( x ) = 6 P L x 4 x 3 2 ,   δ ( x ) = 6 P L 3 E x 3 2 x 4 , P c ( x ) = 4.013 E x 3 2 x 4 6 36 L 2 ( 1 x 3 2 L E 4 G ) , p = 6000 l b ,   L = 14 i n . ,   δ max = 0.25 i n . , E = 30 × 10 6 p s i , G = 12 × 10 6 p s i , τ max = 13 , 600 p s i ,   σ max = 30 , 000 p s i .
Table 11 presents the best weights and the optimal values for the decision variables from IMFO and several other algorithms LMFO [26], LAFBA [27], CSDE [33], CPSO [34], LFD [35], WOA [36], RO [44] and SFO [45]. The statistical results show the IMFO algorithm can outperform six algorithms and outperform by LMFO [26] and CSDE [33].
As can be seen from Table 11, when the four parameters h , l , t and b are set as 0.20573, 3.4702, 9.0375 and 0.20573, respectively, the minimum manufacturing cost with IMFO is 1.7249. The solution from IMFO is better than the solutions from the other methods expect LMFO [26] and CSDE [33].

5.4. Three-Bar Truss Design Problem

The design of a three-bar truss is a structural optimization problem in the field of civil engineering [41]. Figure 9 shows the three-bar truss and parameters involved in the design. In order to minimize the volume of the three-bar truss, the constraints are stressed on each truss member. The three-bar truss design problem has a difficult constrained search space, so it is applied to evaluate the optimization power of the proposed algorithms. The formulation of this problem is as follows:
Consider x = [ x 1   x 2 ] = [ A 1   A 2 ]
Objective function:
f ( x ) = ( 2 2 x 1 + x 2 ) l ,
Subject to
g 1 ( x ) = 2 x 1 + x 2 2 x 1 2 + 2 x 1 x 2 P σ 0 , g 2 ( x ) = x 2 2 x 1 2 + 2 x 1 x 2 P σ 0 , g 3 ( x ) = 1 2 x 2 + x 1 P σ 0 ,
Variable range
0 x 1 , x 2 1 , l = 100 c m ,   P = 2 k N / c m 2 ,   σ = 2 k N / c m 2 .
This problem has been solved by many researchers as a benchmark optimization problem in the literature. The three-bar truss design problem is solved using the IMFO algorithm, and the results are compared to those from SFO [45], m-SCA [46], WOA [36], Tsai [47] and MFO [1]. The results show that IMFO can outperform all the other algorithms except Tsai, which outperforms it [47].
Table 12 shows that IMFO is more competitive than the other four algorithms except Tsai [47] in terms of accuracy and function evolution cost. The best objective function value for the three-bar truss design problem solved with the IMFO algorithm is 263.8959, and the two parameters are 0.78899 and 0.40736.
In this chapter, we can see that the improved moth-flame optimization algorithm is very effective in solving the above four engineering problems. Especially in the solution of the pressure vessel problem, the effect is very obvious. Therefore, it can be seen from this section that the improved algorithm has good optimization performance for solving the problem.

6. Conclusions and Future Work

In this article, two strategies are used: Lévy flight and dimension-by-dimension evaluation. Lévy flight is used in the global search of moths. In order to further improve the global search performance of moths, Lévy flight is added into the update mechanism of the moths to expand the global search capability of the algorithm. The Lévy flight mechanism plays the role of random walk, and its application in the process of the global search of moths can help moths to better update their position, effectively expand the search range of the moths, and improve the global search ability of the algorithm. In the overall operation mechanism of the algorithm, adding the dimension-by-dimension evaluation mechanism can effectively improve the operation efficiency of the algorithm and balance the global search and local development. Dimension-by-dimension evaluation can effectively evaluate the solution of each dimension obtained by the algorithm. If the current solution is better than the initial solution, the current solution is retained and the next dimension is updated. On the contrary, if the current solution obtained after updating a dimension is worse than the original solution, the update of the current solution is abandoned and the update operation of the next dimension is continued. By adding a dimension-by-dimension evaluation mechanism to the algorithm, the evaluation times of the solution can be effectively used to avoid unnecessary waste, so as to improve the convergence speed of the algorithm. The improved algorithm can obtain good results when solving 23 benchmark functions. On the whole, it has a fast convergence speed and high convergence precision. The results of the experiments show that the proposed algorithm applying the Wilcoxon rank sum test and Friedman test on 23 benchmark functions has a better performance than the other compared algorithms. IMFO outperforms the compared algorithms in terms of the statistical results and convergence rate. At the same time, the improved algorithm can obtain better results in solving four engineering problems, especially in the design of pressure vessels.
There are several suggestions as future directions for the improved moth-flame algorithm: (1) enhancing the theoretical research of the IMFO algorithm; (2) improving the mobility mechanism [48] based on the position of the current optimal moth to enable the moth to move with global orientation and expand the sharing of information between moths to improve the overall evolutionary optimization performance of the IMFO algorithm; (3) combining the improved moth-flame optimization algorithm with other algorithms such as the differential evolution (DE) algorithm [49] to further improve the performance of the IMFO algorithm; (4) investigating how to extend the IMFO algorithm to handle other constrained optimizations, multi-objective optimizations, and combinatorial optimization problems. The application of IMFO is desirable for solving more complex real-world problems.

Author Contributions

Conceptualization, supervision, writing—review and editing, funding acquisition, Y.L.; investigation, data curation, writing—original draft preparation, X.Z.; methodology, software, project administration, funding acquisition, J.L. All authors have read and agreed to the published version of the manuscript.

Funding

This work was supported by the National Natural Science Foundation of China (No. 71601071); the Science & Technology Department of Henan Province, China (No. 182102310886 and 162102110109); and a Ministry of Education Youth Foundation Project of Humanities and Social Sciences (No. 15YJC630079).

Acknowledgments

This work was supported by the National Natural Science Foundation of China (No. 71601071); the Science & Technology Department of Henan Province, China (No. 182102310886 and 162102110109); and a Ministry of Education Youth Foundation Project of Humanities and Social Sciences (No. 15YJC630079). We are particularly grateful to the suggestions of the editor and the anonymous reviewers which have greatly improved the quality of the paper.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Mirjalili, S. Moth-flame optimization algorithm: A novel nature-inspired heuristic paradigm. Knowl.-Based. Syst. 2015, 89, 228–249. [Google Scholar] [CrossRef]
  2. Buch, H.; Trivedi, I.N. An Efficient Adaptive Moth Flame Optimization Algorithm for Solving large-scale Optimal Power Flow Problem with POZ, Iranian Journal of Science and Technology. Trans. Electr. Eng. 2019, 43, 1031–1051. [Google Scholar]
  3. Das, A.; Mandal, D.; Ghoshal, S.P.; Kar, R. Concentric circular antenna array synthesis for side lobe suppression using moth flame optimization. aeu-Int. J. Electron. Commun. 2018, 86, 177–184. [Google Scholar] [CrossRef]
  4. Ishiguro, S.; Endo, T.; Akio, Y. Loading pattern optimization for a PWR using multi-swarm Flame optimization Method with Predator. J. Nucl. Sci. Technol. 2019, 57, 523–536. [Google Scholar] [CrossRef]
  5. Rezk, H.; Ali, Z.M.; Abdalla, O.; Younis, O.; Gomaa, M.R.; Hashim, M. Hybrid moth-flame Optimization Algorithm and Incremental Conductance for Tracking Maximum Power of Solar PV/Thermoelectric System under Different Conditions. Mathematics 2019, 7, 875. [Google Scholar] [CrossRef] [Green Version]
  6. Taher, M.A.; Kamel, S.; Jurado, F.; Ebeed, M. An optimization algorithm for solving optimal power flow problem. Int. Trans. Electr. Energy. Syst. 2019, 29. [Google Scholar] [CrossRef]
  7. Tolba, M.A.; Zaki Diab, A.A.; Tulsky, V.N.; Abdelaziz, A.Y. LVCI approach for optimal allocation of distributed generations and allocation Banks in distribution based on moth-flame optimization algorithm. Electr. Eng. 2018, 100, 2059–2084. [Google Scholar] [CrossRef]
  8. Lei, X.; Fang, M.; Fujita, H. Moth-flame optimization-based algorithm with synthetic dynamic PPI networks for discovering protein complexes. Knowl-based Syst. 2019, 172, 76–85. [Google Scholar] [CrossRef]
  9. Sayed, G.I.; Hassanien, A.E. Moth-flame swarm optimization with neutrosophic sets for automatic mitosis detection in breast cancer histology images. Appl. Intell. 2017, 47, 397–408. [Google Scholar] [CrossRef]
  10. Mingjing, W.; Huiling, C.; Bo, Y.; Xuehua, Z.; Lufeng, H.; Zhennao, C.; Hui, H.; Changfei, T. Toward an optimal kernel extreme learning machine using a chaotic moth-flame optimization strategy with applications in medical diagnoses. Neurocomputing 2017, 267, 69–84. [Google Scholar]
  11. Elsakaan, A.A.; El-Sehiemy, R.A.; Kaddah, S.S.; Elsaid, M.L. An enhanced moth-flame optimizer for solving non-smooth economic dispatch problems with emissions. Energy 2018, 157, 1063–1078. [Google Scholar] [CrossRef]
  12. Jain, P.; Saxena, A. An opposition theory enabled moth flame optimizer for strategic bidding in uniform spot energy market. Eng. Sci. Technol. Int. J. 2019, 22, 1047–1067. [Google Scholar] [CrossRef]
  13. Khalilpourazari, S.; Pasandideh, S.H.R. Multi-item EOQ model with nonlinear unit holding cost and partial backordering: Moth-flame optimization algorithm. J. Ind. Prod. Eng. 2016, 34, 42–51. [Google Scholar] [CrossRef]
  14. Abdullah, A.; Faisae Ab Rashid, M.F.; Ponnambalam, S.G.; Ghazalli, Z. Energy efficient modeling and optimization for assembly sequence planning using moth flame optimization. Assem. Autom. 2019, 39, 356–368. [Google Scholar] [CrossRef]
  15. Ishtiaq, A.; Ahmed, S.; Khan, M.F.; Aadil, F.; Maqsood, M.; Khan, S. Intelligent clustering using moth flame optimizer for vehicular AD hoc networks. Int. J. Distrib. Sens. Netw. 2019, 15. [Google Scholar] [CrossRef]
  16. Wei Kun, L.; Wan Liang, W.; Li, L. Optimization of Water Resources Utilization by multi-objective moth-flame Algorithm. Water Resour. Manag. 2018, 32, 3303–3316. [Google Scholar]
  17. Ibrahim, R.A.; Elaziz, M.A.; Ewees, A.A.; Selim, I.M.; Songfeng, L. Galaxy images classification using hybrid brain storm optimization with moth flame optimization. J. Astron. Telesc. Instrum. Syst. 2018, 4, 038001. [Google Scholar] [CrossRef]
  18. Sharma, R.; Saha, A. Optimal test sequence generation in state based testing using moth flame optimization algorithm. J. Intell. & Fuzzy Syst. 2018, 35, 5203–5215. [Google Scholar]
  19. Singh, R.K.; Gangwar, S.; Singh, D.K.; Pathak, V.K. A novel hybridization of artificial neural network and moth-flame optimization (ann-mfo) for multi-objective optimization in magnetic finishing of aluminium 6060. Braz. Soc. Mech. Sci. Eng. 2019, 41, 1–19. [Google Scholar] [CrossRef]
  20. Elaziz, M.A.; Ewees, A.A.; Ibrahim, R.A.; Songfeng, L. Opposition-based moth-flame optimization by differential evolution for feature selection. Math. Comput. Simul. 2020, 168, 48–75. [Google Scholar] [CrossRef]
  21. Srikanth Reddy, K.; Panwar, L.K.; Panigrahi, B.K.; Kumar, R. Solution to unit commitment in power system operation planning using binary coded modified moth flame algorithm (BMMFOA): A flame selection based computational technique. J. Comput. Sci. 2018, 25, 298–317. [Google Scholar]
  22. Sapre, S.; Mini, S. Opposition-based moth flame optimization with Cauchy mutation and evolutionary boundary constraint handling for global optimization. Soft Comput. 2018, 23, 6023–6041. [Google Scholar] [CrossRef]
  23. Liwu, X.; Yuanzheng, L.; Kaicheng, L.; Gooi, H.B.; Zhiqiang, J.; Chao, W.; Nian, L. Enhanced Moth-flame Optimization Based on Cultural Learning and Gaussian Mutation. J. Bionic. Eng. 2018, 15, 751–763. [Google Scholar]
  24. Yueting, X.; Huiling, C.; Ali Asghar, H.; Jie, L.; Qian, Z.; Xuehua, Z.; Li, C. An efficient chaotic mutative mode-flame-inspired optimizer for global optimization tasks. Expert. Syst. Appl. 2019, 129, 135–155. [Google Scholar]
  25. Yueting, X.; Huilin g, C.; Jie, L.; Qian, Z.; Shan, J.; Xiaoqin, Z. Enhanced Moth-flame optimizer with mutation strategy for global optimization. Inf. Sci. 2019, 492, 181–203. [Google Scholar]
  26. Zhiming, L.; Yongquan, Z.; Sen, Z.; Junmin, S. Lévy-Flight Moth-Flame Algorithm for Function Optimization and Engineering Design Problems. Math. Probl. Eng. 2016, 2016, 22. [Google Scholar]
  27. Li, Y.; Li, X.T.; Liu, J.S.; Ximing, R. An Improved Bat Algorithm Based on Lévy Flights and Adjustment Factors. Symmetry 2019, 11, 925. [Google Scholar] [CrossRef] [Green Version]
  28. Yang, X.S.; Karamanoglu, M.; He, X. Flower pollination algorithm: A novel approach for multiobjective optimization. Eng. Optim. 2014, 46, 1222–1237. [Google Scholar] [CrossRef] [Green Version]
  29. Lijin, W.; Yilong, Y.; Wan, Z. Search algorithm of cuckoo. J. Softw. 2013, 24, 2687–2698. [Google Scholar]
  30. Chao, L.; Liang, G.; Jin, Y. Grey wolf optimizer with cellular topological structure. Expert Syst. Appl. 2018, 107, 89–114. [Google Scholar]
  31. Pei, H.; Jeng-Shyang, P.; Shu-Chuan, C. Improved Binary Grey Wolf Optimizer and Its application for feature selection. Knowl.-Based Syst. 2020, 195. [Google Scholar] [CrossRef]
  32. Derrac, J.; Garcia, S.; Molina, D.; Herrera, F. A practical tutorial on the use of nonparametric statistical tests as a methodology for comparing evolutionary and swarm intelligence algorithms. Swarm Evol. Comput. 2011, 1, 3–18. [Google Scholar] [CrossRef]
  33. Zichen, Z.; Shifei, D.; Weikuan, J. A hybrid optimization algorithm based on cuckoo search and differential evolution for solving constrained engineering problems. Eng. Appl. Artif. Intell. 2019, 85, 254–256. [Google Scholar]
  34. He, Q.; Wang, L. An effective co-evolutionary particle swarm optimization for constrained engineering design problems. Eng. Appl. Artif. Intell. 2007, 20, 89–99. [Google Scholar] [CrossRef]
  35. Essam, H.H.; Mohammed, R.S.; Fatma, A.H.; Hassan, S.; Hassaballah, M. Lévy flight distribution: A new metaheuristic algorithm for solving engineering optimization problems. Eng. Appl. Artif. Intell. 2020, 94. [Google Scholar] [CrossRef]
  36. Mirjalili, S.; Lewis, A. The whale optimization algorithm. Adv. Eng. Softw. 2016, 95, 51–67. [Google Scholar] [CrossRef]
  37. Rizk, M.R.-A. Hybridizing sine cosine algorithm with multi-orthogonal search strategy for engineering design problems. J. Comput. Des. Eng. 2018, 5, 249–273. [Google Scholar]
  38. Huiling, C.; Chenjun, Y.; Ali, A.H.; Xuehua, Z. An efficient double adaptive random spare reinforced whale optimization algorithm. Expert Syst. Appl. 2020, 154. [Google Scholar] [CrossRef]
  39. Jie, L.; Huiling, C.; Ali, A.H.; Yueting, X.; Qian, Z.; Chengye, L. Multi-strategy boosted mutative whale-inspired optimization approaches. Appl. Math. Model. 2019, 73, 109–123. [Google Scholar]
  40. Yongquan, Z.; Ying, L.; Qifang, L. Lévy flight trajectory-based whale optimization algorithm for engineering optimization. Eng. Comput. 2018, 35, 2406–2428. [Google Scholar]
  41. Coello Coello, C.A. Use of a self-adaptive penalty approach for engineering optimization problems. Comput. Ind. 2000, 41, 113–127. [Google Scholar] [CrossRef]
  42. Hongliang, Z.; Rong, L.; Zhennao, C.; Zhiyang, G.; Ali, A.H.; Mingjing, W.; Huiling, C.; Mayun, C. Advanced orthogonal moth flame optimization with Broyden–Fletcher–Goldfarb–Shanno algorithm: Framework and real-world problems. Expert Syst. Appl. 2020, 159. [Google Scholar] [CrossRef]
  43. Danilo, P.; Raffaele, M.; Luca, T.; Tallini, J.; Nayak, B.; Naik, Y.D. An Improved Moth-Flame Optimization algorithm with hybrid search phase. Knowl.-Based Syst. 2020, 191. [Google Scholar] [CrossRef]
  44. Kaveh, A.; Khayatazad, M. A new meta-heuristic method: Ray optimization. Comput. Struct. 2012, 112, 283–294. [Google Scholar] [CrossRef]
  45. Shadravan, S.; Naji, H.R.; Bardsiri, V.K. The Sailfish Optimizer: A novel nature-inspired metaheuristic algorithm for solving constrained engineering optimization problems. Eng. Appl. Artif. Intell. 2019, 80, 20–34. [Google Scholar] [CrossRef]
  46. Shubham, G.; Kusum, D. A hybrid self-adaptive sine cosine algorithm with oppositionbased learning. Expert Syst. Appl. 2019, 119, 210–230. [Google Scholar]
  47. Tsai, J.F. Global optimization of nonlinear fractional programming problems in engineering design. Eng. Optim. 2005, 37, 399–409. [Google Scholar] [CrossRef]
  48. Liu, J.S.; Yinan, M.; Xiaozhen, L.; Li, Y. A dynamic adaptive firefly algorithm with globally orientation. Math. Comput. Simul. 2020, 174, 76–101. [Google Scholar] [CrossRef]
  49. Liu, J.S.; Li, L.; Li, Y. A Differential Evolution Flower Pollination Algorithm with Dynamic Switch Probability. Chin. J. Electron. 2019, 28, 737–747. [Google Scholar] [CrossRef]
Figure 1. Spiral flight path of moths near point light source.
Figure 1. Spiral flight path of moths near point light source.
Symmetry 12 01234 g001
Figure 2. Two hundred successive Lévy flight paths. (a) The first Lévy flight path; (b) The second Lévy flight path; (c) The third Lévy flight path.
Figure 2. Two hundred successive Lévy flight paths. (a) The first Lévy flight path; (b) The second Lévy flight path; (c) The third Lévy flight path.
Symmetry 12 01234 g002
Figure 3. Two algorithms in function F2: convergence trend comparison. (a) The image of the function F2; (b) Convergence trend comparsion of two algorithms.
Figure 3. Two algorithms in function F2: convergence trend comparison. (a) The image of the function F2; (b) Convergence trend comparsion of two algorithms.
Symmetry 12 01234 g003
Figure 4. Flowchart of improved moth-flame optimization algorithm.
Figure 4. Flowchart of improved moth-flame optimization algorithm.
Symmetry 12 01234 g004
Figure 5. Convergence curve for IMFO versus other optimizers.
Figure 5. Convergence curve for IMFO versus other optimizers.
Symmetry 12 01234 g005aSymmetry 12 01234 g005b
Figure 6. Pressure vessel design problem.
Figure 6. Pressure vessel design problem.
Symmetry 12 01234 g006
Figure 7. Compression/tension spring design problem.
Figure 7. Compression/tension spring design problem.
Symmetry 12 01234 g007
Figure 8. Welding beam design problem.
Figure 8. Welding beam design problem.
Symmetry 12 01234 g008
Figure 9. Three-bar truss design problem.
Figure 9. Three-bar truss design problem.
Symmetry 12 01234 g009
Table 1. Thirteen benchmark functions.
Table 1. Thirteen benchmark functions.
IDEquationPictureLUDfmin
F1 f 1 ( x ) = i = 1 n x i 2 Symmetry 12 01234 i001−100100100
F2 f 2 ( x ) = i = 1 n | x i | + i = 1 n | x i | Symmetry 12 01234 i002−1010100
F3 f 3 ( x ) = i = 1 n ( j = 1 i x j ) 2 Symmetry 12 01234 i003−100100100
F4 f 4 ( x ) = m a x i { | x i | , 1 i n } Symmetry 12 01234 i004−100100100
F5 f 5 ( x ) = i = 1 n 1   [ 100 ( x i + 1 x i 2 ) 2 + ( x i 1 ) 2 ] Symmetry 12 01234 i005−3030100
F6 f 6 ( x ) = i = 1 n ( [ x i + 0.5 ] ) 2 Symmetry 12 01234 i006−100100100
F7 f 7 ( x ) = i = 1 n i x i 4 + r a n d o m   [ 0 , 1 ) Symmetry 12 01234 i007−1.281.28100
F8 f 8 ( x ) = i = 1 n x i sin ( | x i | Symmetry 12 01234 i008−50050010−418.9829*D
F9 f 9 ( x ) = i = 1 n   [ x i 2 10 cos ( 2 π x i ) + 10 ] Symmetry 12 01234 i0095.125.12100
F10 f 10 ( x ) = 20 e x p ( 0.2 1 n i = 1 n x i 2 ) exp ( 1 n i = 1 n cos ( 2 π x i ) ) + 20 + e Symmetry 12 01234 i010−3230100
F11 f 11 ( x ) = 1 4000 i = 1 n x i 2 i = 1 n cos ( x i i ) + 1 Symmetry 12 01234 i011−600600100
F12. f 12 ( x ) = π n { 10 s i n ( π y 1 ) + i = 1 n 1 ( y i 1 ) 2 [ 1 + 10 s i n 2 ( π y i + 1 ) ] + ( y n 1 ) 2 } + i = 1 n u ( x i , 10 , 100 , 4 ) y i = 1 + x i + 1 4 ,   u ( x i , a , k . m ) = { k ( x i a ) m ,       x i > a 0 ,       a < x i < a k ( x i a ) m ,       x i < a Symmetry 12 01234 i012−5050100
F13 f 13 ( x ) = 0.1 { s i n 2 ( 3 π x 1 ) + i = 1 n ( x i 1 ) 2 [ 1 + s i n 2 ( 3 π x i + 1 ) ] + ( x n 1 ) 2 [ 1 + s i n 2 ( 2 π x n ) ] } + i = 1 n u ( x i , 5 , 100 , 4 ) Symmetry 12 01234 i013−5050100
Table 2. Ten complex dimension test functions.
Table 2. Ten complex dimension test functions.
IDEquationPictureLUDfmin
F14 f 14 ( x ) = [ 0.002 + j = 1 25 1 j + i = 1 2 ( x i x i j ) 6 ] 1 Symmetry 12 01234 i014−65.53665.53621
F15 f 15 ( x ) = i = 1 11 [ a i x 1 ( b i 2 + b i x 2 ) b i 2 + b i x 3 + x 4 ] 2 Symmetry 12 01234 i015−5540.0003
F16 f 16 ( x ) = 4 x 1 2 2.1 x 1 4 + 1 3 x 1 6 + x 1 x 2 4 x 2 2 + 4 x 2 4 Symmetry 12 01234 i016−552−1.0316
F17 f 17 ( x ) = 10 + 10 × ( 1 0.125 π ) cos ( x 1 ) + ( x 2 5.1 4 π 2 x 1 2 + 5 π x 1 6 ) 2 Symmetry 12 01234 i017 [5, 0] [10, 15]20.398
F18 f 18 ( x ) = [ 1 + ( 1 + x 1 + x 2 ) 2 ( 19 14 x 1 + 3 x 1 2 14 x 2 + 6 x 1 x 2 + 3 x 2 2 ) ] × [ 30 + ( 2 x 1 3 x 2 ) 2 × ( 18 32 x 1 + 12 x 1 2 + 48 x 2 36 x 1 x 2 + 27 x 2 2 )] Symmetry 12 01234 i018−2223
F19 f 19 ( x ) = i = 1 4 c i   exp ( j = 1 3 a i j ( x j p i j ) 2 ) Symmetry 12 01234 i019013−3.86
F20 F 20 = i = 1 4 c i exp ( j = 1 6 a i j ( x j p i j ) 2 ) Symmetry 12 01234 i020016−3.32
F21 F 21 = i = 1 5 [ ( X a i ) ( X a i ) T + c i ] 1 Symmetry 12 01234 i0210104−10.1532
F22 F 22 = i = 1 7 [ ( X a i ) ( X a i ) T + c i ] 1 Symmetry 12 01234 i0220104−10.4028
F23 F 23 = i = 1 10 [ ( X a i ) ( X a i ) T + c i ] 1 Symmetry 12 01234 i0230104−10.5363
Table 3. The parameters of the algorithms and their values.
Table 3. The parameters of the algorithms and their values.
AlgorithmThe ParametersThe Value
Moth–Flame Optimization (MFO)b1
Going Cosine Algorithm (SCA) a.2
Bat Algorithm (BA) Frequency minimum (Qmin)0
Frequency maximum (Qmax)2
Loudness (A)0.5
Pulse rate0.5
Spotted Hyena Optimizer (SHO) The Control Parameter ( h )(5, 0]
M Constant[0.5, 1]
Particle Swarm Optimization (PSO) Maximum Inertia weight (Wmax)0.9
Minimum Inertia weight (Wmin)0.2
Maximum Velocity (Vmax)6
Cognitive coefficient (C1)2
Cognitive coefficient (C2)2
Whale Optimization Algorithm (WOA) a(2, 0)
a2(2, 1)
b1
Grey Wolf Optimizer (GWO) The Control Parameter ( a )(2, 0)
Salp Swarm Algorithm (SSA)l2
Table 4. Comparison of results for different algorithms (d = 10).
Table 4. Comparison of results for different algorithms (d = 10).
FIMFOMFOSCABASHOPSOWOAGWO SSA
AveStdAveStdAveStdAveStdAveStdAveStdAveStdAveStdAveStd
F1 6.09 × 10 181 0 3.05 × 10 29 1.28 × 10 28 5.59 × 10 27 1.65 × 10 26 8.97 × 10 7 3.93 × 10 14 5.03 × 10 8 2.72 × 10 7 1.21 × 10 39 6.63 × 10 39 7.22 × 10 148 3.93 × 10 147 2.15 × 10 58 5.40 × 10 58 6.62 × 10 10 2.44 × 10 10
F2 5.50 × 10 98 2.83 × 10 97 1.27 × 10 18 2.83 × 10 18 4.51 × 10 19 1.56 × 10 18 3.62 × 10 2 6.17 × 10 3 00 6.87 × 10 20 2.52 × 10 19 2.31 × 10 101 9.16 × 10 101 1.39 × 10 34 2.11 × 10 34 2.80 × 10 2 1.53 × 10 1
F3 4.02 × 10 147 2.19 × 10 146 3.33 × 10 2 1.27 × 10 3 2.36 × 10 7 1.25 × 10 6 1.50 × 10 6 3.56 × 10 13 2.64 × 10 4 4.45 × 10 4 3.16 × 10 12 7.49 × 10 12 2.39 × 10 4 1.03 × 10 4 2.02 × 10 14 1.08 × 10 13 1.76 × 10 9 9.69 × 10 10
F4 3.36 × 10 82 1.83 × 10 81 1.40 3.47 3.38 × 10 7 1.69 × 10 6 4.95 × 10 2 1.06 × 10 2 3.13 × 10 6 8.14 × 10 6 6.41 × 10 10 1.61 × 10 9 4.11 × 10 1 3.15 × 10 1 1.61 × 10 14 2.14 × 10 14 1.54 × 10 5 4.64 × 10 6
F56.45 1.22 × 10 1 1.73 × 10 2 5.54 × 10 2 7.06 4.04 × 10 1 2.323.13 2.89 × 10 1 1.39 × 10 1 4.001.94 2.73 × 10 1 5.79 × 10 1 2.69 × 10 1 6.69 × 10 1 6.56 × 10 1 1.53 × 10 2
F6 1.18 × 10 12 1.02 × 10 12 3.07 × 10 30 6.24 × 10 30 3.24 × 10 1 1.36 × 10 1 8.96 × 10 7 7.14 × 10 14 4.323.31 1.03 × 10 33 4.53 × 10 33 1.67 × 10 1 1.58 × 10 1 4.87 × 10 1 2.68 × 10 1 6.25 × 10 10 1.79 × 10 10
F7 7.12 × 10 5 5.64 × 10 5 5.90 × 10 3 4.10 × 10 3 1.30 × 10 3 1.40 × 10 3 2.813.573.57 1.46 × 10 1 3.81 × 10 3 2.21 × 10 3 1.50 × 10 3 1.80 × 10 3 8.79 × 10 4 5.58 × 10 4 5.20 × 10 3 2.00 × 10 3
F8 3.35 × 10 3 2.53 × 10 2 3.08 × 10 3 3.25 × 10 2 2.25 × 10 3 1.83 × 10 2 N/AN/A 2.17 × 10 3 5.37 × 10 2 2.37 × 10 3 4.71 × 10 2 1.13 × 10 4 1.57 × 10 3 6.28 × 10 3 9.40 × 10 2 2.76 × 10 3 3.37 × 10 2
F900 2.39 × 10 1 1.26 × 10 1 2.04 × 10 1 1.12 1.42 × 10 1 6.35 × 10 1 9.53 × 10 1 9.42 × 10 1 4.081.8000 8.09 × 10 1 2.26 1.76 × 10 1 7.91
F10 8.88 × 10 16 0 4.80 × 10 15 1.08 × 10 15 9.06 × 10 15 9.34 × 10 15 1.661.00 4.77 × 10 3 2.60 × 10 2 4.80 × 10 15 1.08 × 10 15 3.61 × 10 15 2.22 × 10 15 1.57 × 10 14 2.96 × 10 15 6.66 × 10 1 9.62 × 10 1
F1100 1.60 × 10 1 9.62 × 10 2 5.27 × 10 2 1.61 × 10 1 1.08 × 10 7 1.03 × 10 15 1.12 × 10 15 4.44 × 10 15 1.84 × 10 1 1.57 × 10 1 00 1.90 × 10 3 5.90 × 10 3 2.17 × 10 1 1.12 × 10 1
F12. 2.62 × 10 13 4.83 × 10 13 4.55 × 10 1 8.38 × 10 1 6.53 × 10 2 2.28 × 10 2 2.38 × 10 4 1.70 × 10 6 1.19 7.51 × 10 1 4.74 × 10 32 6.09 × 10 34 6.10 × 10 3 5.70 × 10 3 3.75 × 10 2 1.87 × 10 2 2.14 × 10 1 4.90 × 10 1
F13 3.80 × 10 12 6.06 × 10 12 3.70 × 10 3 5.30 × 10 3 2.37 × 10 1 7.46 × 10 2 2.21 × 10 1 3.21 × 10 2 2.98 3.14 × 10 2 2.05 × 10 32 3.47 × 10 32 2.12 × 10 1 1.45 × 10 1 5.51 × 10 1 2.22 × 10 1 1.80 × 10 3 4.20 × 10 3
F142.65 7.05 × 10 1 2.021.611.53 8.92 × 10 1 1.23 × 10 1 4.54 1.02 × 10 1 3.163.562.792.112.494.133.99 9.98 × 10 1 2.66 × 10 16
F15 3.36 × 10 4 7.90 × 10 5 2.30 × 10 3 3.90 × 10 3 9.75 × 10 4 4.17 × 10 4 2.34 × 10 3 6.11 × 10 5 1.42 × 10 2 2.00 × 10 2 8.31 × 10 4 2.06 × 10 4 6.11 × 10 4 3.58 × 10 4 3.70 × 10 3 7.60 × 10 3 1.50 × 10 3 3.60 × 10 3
F16−1.03 6.78 × 10 16 −1.03 6.78 × 10 16 −1.03 2.11 × 10 5 −1.00 2.22 × 10 2 6.87 × 10 1 3.43 × 10 1 −1.03 6.71 × 10 16 −1.03 4.14 × 10 10 −1.03 6.49 × 10 9 −1.03 5.77 × 10 15
F17 3.98 × 10 1 0 3.98 × 10 1 0 3.99 × 10 1 1.60 × 10 3 4.50 × 10 1 6.13 × 10 2 5.72 × 10 1 2.13 × 10 1 3.98 × 10 1 0 3.98 × 10 1 5.84 × 10 6 3.98 × 10 1 2.28 × 10 5 N/AN/A
F183.00 1.20 × 10 15 3.00 1.89 × 10 15 3.00 2.40 × 10 5 6.60 2.38 × 10 2 9.589.683.00 1.23 × 10 15 3.00 1.61 × 10 5 3.00 8.86 × 10 6 3.00 1.02 × 10 13
F19−3.86 2.71 × 10 15 −3.86 2.71 × 10 15 −3.86 2.60 × 10 3 −3.76 7.14 × 10 2 −3.24 3.74 × 10 1 −3.86 2.71 × 10 15 −3.86 2.70 × 10 3 −3.86 2.50 × 10 3 −3.86 2.18 × 10 14
F20−3.31 4.10 × 10 2 −3.22 6.20 × 10 2 −2.79 4.48 × 10 1 −3.24 2.77 × 10 2 −1.48 4.28 × 10 1 −3.26 6.03 × 10 2 −3.21 1.20 × 10 1 −3.28 5.95 × 10 2 −3.24 5.97 × 10 2
F21−5.06 9.47 × 10 16 −6.633.27−2.621.96−5.23 8.66 × 10 1 5.60 × 10 1 3.47 × 10 1 −8.212.62−8.712.46−9.142.06−8.142.98
F22−5.26 9.70 × 10 1 −7.983.30−3.532.29−5.26 9.42 × 10 1 7.38 × 10 1 2.88 × 10 1 −8.912.54−8.992.63 1.01 × 10 1 1.34−9.012.62
F23−5.31 9.87 × 10 1 −8.663.21−4.321.86−5.271.05 8.26 × 10 1 2.46 × 10 1 −9.921.91−8.103.1 1.03 × 10 1 1.48−8.163.48
Table 5. Comparison of results for different algorithms (d = 30).
Table 5. Comparison of results for different algorithms (d = 30).
FIMFOMFOSCABASHOPSOWOAGWO SSA
AveStdAveStdAveStdAveStdAveStdAveStdAveStdAveStdAveStd
F1 1.68 × 10 109 5.34 × 10 109 3.00 × 10 3 4.66 × 10 3 3.55 × 10 2 1.06 × 10 1 5.60 × 10 2 7.29 × 10 12 6.04 × 10 2 3.31 × 10 1 3.59 × 10 9 9.38 × 10 151 3.90 × 10 150 7.75 × 10 59 2.75 × 10 58 1.20 × 10 8 2.58 × 10 9
F2 1.37 × 10 66 4.46 × 10 66 2.93 × 10 1 2.26 × 10 1 3.23 × 10 5 8.57 × 10 5 1.17 1.89 × 10 1 00 6.63 × 10 4 1.89 × 10 3 3.67 × 10 104 1.76 × 10 103 9.90 × 10 35 1.22 × 10 34 1.441.73
F3 1.53 × 10 151 8.39 × 10 151 1.91 × 10 4 1.21 × 10 4 4.91 × 10 3 3.89 × 10 3 1.13 × 10 1 7.13 × 10 2 2.07 × 10 4 4.36 × 10 4 1.56 × 10 1 6.49 1.68 × 10 4 8.91 × 10 3 1.90 × 10 13 9.85 × 10 13 3.21 × 10 2 1.88 × 10 2
F4 4.15 × 10 43 2.27 × 10 42 6.60 × 10 1 7.45 1.87 × 10 1 8.21 4.65 × 10 1 2.57 × 10 2 6.41 × 10 6 2.35 × 10 5 5.71 × 10 1 1.63 × 10 1 3.99 × 10 1 3.24 × 10 1 1.47 × 10 14 1.39 × 10 14 7.812.68
F5 2.81 × 10 1 1.22 × 10 1 2.75 × 10 4 4.17 × 10 4 7.37 × 10 2 1.98 × 10 3 2.63 × 10 1 3.81 2.89 × 10 1 1.27 × 10 1 4.80 × 10 1 3.03 × 10 1 2.71 × 10 1 5.50 × 10 1 2.70 × 10 1 7.05 × 10 1 1.32 × 10 2 2.15 × 10 2
F65.75 2.82 × 10 1 1.67 × 10 3 3.80 × 10 3 4.88 9.75 × 10 1 1.71 × 10 5 4.95 × 10 12 6.142.12 8.04 × 10 9 2.12 × 10 8 7.42 × 10 2 8.12 × 10 2 5.77 × 10 1 3.30 × 10 1 1.11 × 10 8 2.60 × 10 9
F75.79 2.13 × 10 1 4.026.59 3.88 × 10 2 5.79 × 10 2 2.17 × 10 1 7.86 × 10 1 3.08 1.32 × 10 1 6.92 × 10 2 2.50 × 10 2 1.77 × 10 3 1.99 × 10 3 8.66 × 10 4 4.32 × 10 4 1.04 × 10 1 4.95 × 10 2
F8 9.11 × 10 3 7.15 × 10 2 8.57 × 10 3 9.58 × 10 2 3.81 × 10 3 2.52 × 10 2 N/AN/A 2.14 × 10 3 5.15 × 10 2 6.32 × 10 3 1.14 × 10 3 1.07 × 10 4 1.82 × 10 3 5.99 × 10 3 7.70 × 10 2 7.55 × 10 3 8.39 × 10 2
F900 1.62 × 10 2 3.92 × 10 1 2.23 × 10 1 3.25 × 10 1 3.02 × 10 1 1.93 × 10 2 8.13 × 10 1 8.70 × 10 1 4.60 × 10 1 1.05 × 10 1 1.89 × 10 15 1.04 × 10 14 9.85 × 10 1 2.11 5.87 × 10 1 2.20 × 10 1
F1000 1.57 × 10 1 6.41 1.55 × 10 1 8.112.09 1.77 × 10 1 9.01 × 10 11 4.51 × 10 10 8.29 × 10 5 1.74 × 10 4 4.20 × 10 15 2.63 × 10 15 1.64 × 10 14 3.16 × 10 15 2.12 9.42 × 10 1
F11 8.88 × 10 16 0 1.51 × 10 1 3.42 × 10 1 3.01 × 10 1 2.89 × 10 1 1.23 × 10 6 1.37 × 10 12 1.85 × 10 14 1.01 × 10 13 9.76 × 10 3 1.00 × 10 2 4.36 × 10 3 1.67 × 10 2 2.87 × 10 3 6.95 × 10 3 7.14 × 10 3 8.74 × 10 3
F12.00 6.41 × 10 1 8.95 × 10 1 5.21 × 10 1 2.47 × 10 2 1.46 × 10 2 6.44 × 10 4 9.58 × 10 1 8.27 × 10 1 1.75 × 10 10 3.92 × 10 10 7.11 × 10 3 5.93 × 10 3 4.03 × 10 2 1.64 × 10 2 5.362.70
F13 7.85 × 10 1 4.25 × 10 2 7.93 × 10 1 1.87 2.81 × 10 2 8.63 × 10 2 1.17 3.10 × 10 1 2.98 2.81 × 10 2 2.93 × 10 3 8.62 × 10 3 2.11 × 10 1 1.76 × 10 1 5.57 × 10 1 2.06 × 10 1 7.05 × 10 2 2.67 × 10 1
Table 6. Comparison of results for different algorithms (d = 100).
Table 6. Comparison of results for different algorithms (d = 100).
FIMFOMFOSCABASHOPSOWOAGWOSSA
AveStdAveStdAveStdAveStdAveStdAveStdAveStdAveStdAveStd
F1 3.95 × 10 74 2.02 × 10 73 2.97 × 10 4 1.33 × 10 4 5.10 × 10 3 4.21 × 10 3 1.02 × 10 1 1.15 × 10 1 3.84 × 10 2 1.96 × 10 3 2.631.00 2.19 × 10 148 9.25 × 10 148 2.93 × 10 29 3.39 × 10 29 2.131.44
F2 2.14 × 10 51 1.14 × 10 50 1.87 × 10 2 5.35 × 10 1 1.651.39 1.06 × 10 1 1.02 × 10 1 00 1.18 × 10 1 5.15 1.51 × 10 100 7.91 × 10 100 5.40 × 10 18 2.88 × 10 18 2.27 × 10 1 3.94
F3 3.72 × 10 40 2.04 × 10 39 1.97 × 10 5 6.35 × 10 4 1.86 × 10 5 5.02 × 10 4 1.60 × 10 1 1.99 × 10 2 8.95 × 10 5 7.53 × 10 5 1.20 × 10 4 3.55 × 10 3 8.59 × 10 5 1.46 × 10 5 2.36 × 10 1 8.07 × 10 1 4.26 × 10 4 1.91 × 10 4
F4 1.26 × 10 7 6.91 × 10 7 9.35 × 10 1 1.85 8.61 × 10 1 3.17 8.30 × 10 1 1.70 × 10 2 5.75 × 10 4 8.79 × 10 4 8.991.41 7.55 × 10 1 2.73 × 10 1 4.92 × 10 3 1.02 × 10 2 2.75 × 10 1 4.45
F5 9.85 × 10 1 3.78 × 10 1 6.85 × 10 7 5.06 × 10 7 5.97 × 10 7 3.23 × 10 7 1.76 × 10 2 1.09 × 10 4 1.82 × 10 2 3.32 × 10 2 2.15 × 10 3 1.07 × 10 3 9.77 × 10 1 3.71 × 10 1 9.77 × 10 1 6.82 × 10 1 2.23 × 10 3 2.06 × 10 3
F6 2.30 × 10 1 2.12 × 10 1 3.58 × 10 4 1.70 × 10 4 5.99 × 10 3 5.26 × 10 3 1.582.00 5.61 × 10 2 2.62 × 10 3 3.131.541.76 7.26 × 10 1 9.34 8.26 × 10 1 3.022.34
F7 1.37 × 10 4 1.14 × 10 4 1.76 × 10 2 1.51 × 10 2 7.02 × 10 1 4.04 × 10 1 8.50 × 10 1 1.72 × 10 3 2.85 × 10 1 8.65 × 10 1 1.46 × 10 3 2.79 × 10 2 1.78 × 10 3 1.99 × 10 3 2.77 × 10 3 1.26 × 10 3 1.41 2.85 × 10 1
F8 4.59 × 10 3 4.53 × 10 2 2.38 × 10 4 2.16 × 10 3 7.18 × 10 3 4.69 × 10 2 N/AN/A 3.99 × 10 3 9.68 × 10 2 1.98 × 10 4 4.47 × 10 3 3.79 × 10 4 5.46 × 10 3 1.67 × 10 4 2.41 × 10 3 2.43 × 10 4 1.96 × 10 3
F900 7.60 × 10 2 7.43 × 10 1 2.21 × 10 2 9.65 × 10 1 1.38 × 10 2 2.35 × 10 3 3.71 × 10 2 4.06 × 10 2 4.72 × 10 2 5.75 × 10 1 001.142.54 1.63 × 10 2 3.12 × 10 1
F10 8.88 × 10 16 0 1.98 × 10 1 2.29 × 10 1 1.95 × 10 1 4.052.13 1.19 × 10 1 4.23 × 10 1 9.44 × 10 1 2.65 2.98 × 10 1 4.20 × 10 15 2.79 × 10 15 1.12 × 10 13 8.06 × 10 15 7.161.14
F1100 2.71 × 10 2 1.05 × 10 2 6.81 × 10 1 4.91 × 10 1 2.45 × 10 2 1.30 × 10 3 8.59 3.86 × 10 1 4.49 × 10 2 2.13 × 10 2 3.91 × 10 3 2.14 × 10 2 1.65 × 10 3 6.27 × 10 3 6.83 × 10 1 2.14 × 10 1
F121.04 2.75 × 10 2 1.05 × 10 8 1.44 × 10 8 1.49 × 10 8 9.88 × 10 7 1.17 × 10 1 2.56 × 10 3 1.15 4.57 × 10 1 2.00 9.86 × 10 1 1.69 × 10 2 7.46 × 10 3 2.54 × 10 1 6.66 × 10 2 1.76 × 10 1 3.65
F139.76 3.22 × 10 2 2.88 × 10 8 2.45 × 10 8 3.33 × 10 8 2.42 × 10 8 9.541.899.89 5.42 × 10 1 1.34 × 10 1 1.03 × 10 1 1.73 7.62 × 10 1 6.27 4.34 × 10 1 1.79 × 10 2 1.91 × 10 1
Table 7. p-values for Wilcoxon’s rank-sum tests on benchmark functions.
Table 7. p-values for Wilcoxon’s rank-sum tests on benchmark functions.
FMFOSCABASHOPSOWOAGWOSSA
F1 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11 1.21 × 10 12 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11
F2 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11 1.21 × 10 12 3.02 × 10 11 4.50 × 10 11 3.02 × 10 11 3.02 × 10 11
F3 3.00 × 10 11 3.02 × 10 11 3.02 × 10 11 1.21 × 10 12 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11
F4 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11 1.24 × 10 9 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11 3.01 × 10 11
F5 3.71 × 10 1 3.20 × 10 9 3.02 × 10 11 2.72 × 10 11 7.04 × 10 7 6.77 × 10 5 7.48 × 10 2 7.29 × 10 3
F6 3.01 × 10 11 3.02 × 10 11 3.01 × 10 11 2.26 × 10 11 2.36 × 10 12 3.02 × 10 11 3.01 × 10 11 3.01 × 10 11
F7 3.02 × 10 11 1.09 × 10 10 3.02 × 10 11 2.69 × 10 3 3.02 × 10 11 1.60 × 10 7 9.26 × 10 9 3.02 × 10 11
F8 4.96 × 10 1 3.02 × 10 11 N/A 3.02 × 10 11 3.47 × 10 10 2.84 × 10 1 1.17 × 10 9 3.44 × 10 6
F9 1.21 × 10 12 4.19 × 10 2 1.19 × 10 12 2.79 × 10 3 1.13 × 10 12 3.34 × 10 1 N/A 1.20 × 10 12
F10 1.19 × 10 13 6.66 × 10 13 1.13 × 10 12 N/A 2.90 × 10 13 9.16 × 10 9 1.55 × 10 13 1.18 × 10 12
F11 1.21 × 10 12 2.21 × 10 6 1.21 × 10 12 N/A 1.21 × 10 12 1.37 × 10 3 5.38 × 10 6 1.21 × 10 12
F12 3.98 × 10 4 3.02 × 10 11 3.02 × 10 11 2.40 × 10 11 1.88 × 10 11 3.02 × 10 11 3.02 × 10 11 3.00 × 10 11
F13 7.85 × 10 3 3.02 × 10 11 3.01 × 10 11 2.26 × 10 11 3.16 × 10 12 3.02 × 10 11 3.02 × 10 11 3.02 × 10 11
F14 3.87 × 10 1 6.26 × 10 2 2.19 × 10 11 5.42 × 10 8 8.49 × 10 1 1.94 × 10 2 1.00 9.94 × 10 10
F15 3.54 × 10 11 6.07 × 10 11 8.17 × 10 7 3.69 × 10 11 6.72 × 10 10 9.83 × 10 8 3.87 × 10 1 3.33 × 10 11
F16N/A 1.21 × 10 12 2.71 × 10 14 5.77 × 10 9 N/AN/A N/A
F17N/A 1.21 × 10 12 4.16 × 10 14 1.21 × 10 12 N/A 1.30 × 10 7 1.21 × 10 12 N/A
F18N/A 1.21 × 10 12 1.61 × 10 1 1.21 × 10 12 N/A 4.57 × 10 12 1.21 × 10 12 N/A
F19 3.34 × 10 1 1.21 × 10 12 8.64 × 10 14 1.21 × 10 12 N/A 1.21 × 10 12 1.21 × 10 12 N/A
F20 1.18 × 10 4 9.17 × 10 12 1.99 × 10 7 9.17 × 10 12 4.65 × 10 1 1.83 × 10 6 5.78 × 10 7 9.13 × 10 6
F21 2.77 × 10 2 1.91 × 10 7 2.71 × 10 14 1.21 × 10 12 3.53 × 10 7 1.33 × 10 8 7.47 × 10 10 2.22 × 10 8
F22 1.83 × 10 3 1.65 × 10 7 1.61 × 10 12 1.72 × 10 12 5.47 × 10 13 7.23 × 10 2 1.72 × 10 12 4.59 × 10 12
F23 6.69 × 10 3 1.23 × 10 2 7.35 × 10 11 1.72 × 10 12 8.04 × 10 13 1.90 × 10 6 4.56 × 10 11 3.93 × 10 5
Table 8. Friedman tests.
Table 8. Friedman tests.
AlgorithmRank Mean (d = 10)RankRank Mean (d = 30)RankRank Mean (d = 100)Rank
IMFO2.71 1 2.92 1 2.63 1
MFO5.45 6 8.25 9 7.17 9
SCA5.52 7 6.83 8 6.83 8
BA6.52 8 4.92 5 4.00 4
SHO7.86 9 5.67 7 5.83 5
PSO3.38 2 4.17 4 2.79 2
WOA4.24 4 3.50 3 3.08 3
GWO4.19 3 3.17 2 6.25 6
SSA5.12 5 5.58 6 6.42 7
Table 9. Comparison of results for pressure vessel design problem.
Table 9. Comparison of results for pressure vessel design problem.
AlgorithmVariableTarget Cost
TsThRL
MFO [1]0.81250.437542.098445176.6365966059.7143
OMFO [22]0.813860.402242.1689175.76515949.1830
ES [31]0.8125000.43750042.098087176.6405186059.7456
CSDE [33]0.81250.437542.10176.66059.7133
CPSO [34]0.8125000.43750042.091266176.7465006061.0777
LFD [35]0.87770.433945.4755139.06546080
WOA [36]0.8125000.43750042.098209176.6389986059.7410
MOSCA [37]0.77819090.383047640.3207539199.98419945880.71150
RDWOA [38]0.7937690.3923641.127973189.0451245912.53868
CCMWOA [39]0.7796610.38561140.34738199.61415895.2039
LWOA [40]0.7788580.38532140.326092005893.339
GA [41]0.81250.434540.323900200.0000006288.7445
BFGSOLMFO [42]0.7786750.38539240.342876199.7548055889.7080
IMFO [43]0.774550.3832040.31962200.000005870.12398
IMFO0.77819480.384662140.32097199.98125885.3778
Table 10. Comparison of results for compression/tension spring design problem.
Table 10. Comparison of results for compression/tension spring design problem.
AlgorithmVariableThe Target Weight
dDN
MFO [1]0.0519944570.3641093210.8684218620.0126669
LAFBA [27]0.0516630.35607411.3334000.0126720
ES [31]0.0519890.36396510.8905220.0126810
CPSO [34]0.0517280.35764411.2445430.0126747
LFD [35]0.05170.357511.24420.0127
WOA [36]0.0512070.34521512.00430320.0126763
CCMWOA [39]0.0518430.36044411.074100.0126660
LWOA [40]0.0511240.34292212.161190.0126920
GA [41]0.0514800.35166111.6322011.0127048
RO [44]0.0513700.34909611.7627900.0126788
IMFO0.051590.35433711.43010.012666
Table 11. Comparison of results for welded beam design problem.
Table 11. Comparison of results for welded beam design problem.
AlgorithmVariableTarget Cost
hltb
LMFO [26]0.20203.35759.09380.20611.7165
LAFBA [27]0.1847068153.6426556919.1348973580.2052540531.7287
CSDE [33]0.20573.479.0370.20571.724849
CPSO [34]0.2023693.5442149.0482100.2057231.728024
LFD [35]0.18573.90709.15520.20511.77
WOA [36]0.2053963.4842939.0374260.2062761.730499
RO [44]0.2036873.5284679.0042330.2072411.735344
SFO [45]0.20383.66309.05060.20641.73231
IMFO0.205733.47029.03750.205731.7249
Table 12. Comparison of results for three-bar truss design problem.
Table 12. Comparison of results for three-bar truss design problem.
AlgorithmVariableThe Target Weight
X1X2
MFO [1]0.7882447709319220.409466905784741263.895979682
WOA [36]0.7890505440.407187512263.8959474
SFO [45]0.78845620.40886831263.89592128
m-SCA [46]0.819150.36956263.8972
Tsai [47]0.7880.408263.68
IMFO0.788990.40736263.8959

Share and Cite

MDPI and ACS Style

Li, Y.; Zhu, X.; Liu, J. An Improved Moth-Flame Optimization Algorithm for Engineering Problems. Symmetry 2020, 12, 1234. https://doi.org/10.3390/sym12081234

AMA Style

Li Y, Zhu X, Liu J. An Improved Moth-Flame Optimization Algorithm for Engineering Problems. Symmetry. 2020; 12(8):1234. https://doi.org/10.3390/sym12081234

Chicago/Turabian Style

Li, Yu, Xinya Zhu, and Jingsen Liu. 2020. "An Improved Moth-Flame Optimization Algorithm for Engineering Problems" Symmetry 12, no. 8: 1234. https://doi.org/10.3390/sym12081234

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

Article Metrics