Firefly Algorithm for Continuous Constrained Optimization Tasks

In mathematical optimization, the firefly algorithm is a metaheuristic proposed by Xin-She Yang and inspired by the flashing behavior of fireflies.[1]

Algorithm [edit]

In pseudocode the algorithm can be stated as:

          Begin          1) Objective function:                                                                                                                                        f                        (                                                  x                                                )                        ,                                                                          x                                                =                        (                                                  x                                                      1                                                                          ,                                                  x                                                      2                                                                          ,                        .                        .                        .                        ,                                                  x                                                      d                                                                          )                                                              {\displaystyle f(\mathbf {x} ),\quad \mathbf {x} =(x_{1},x_{2},...,x_{d})}                                                                          ;          2) Generate an initial population of fireflies                                                                                                                                                                                              x                                                                                i                                                                                                  (                        i                        =                        1                        ,                        2                        ,                                                                        ,                        n                        )                                                              {\displaystyle \mathbf {x} _{i}\quad (i=1,2,\dots ,n)}                                                                          ;.          3) Formulate light intensity          I          so that it is associated with                                                                                                                                        f                        (                                                  x                                                )                                                              {\displaystyle f(\mathbf {x} )}                                                                                              (for example, for maximization problems,                                                                                                                                        I                                                                        f                        (                                                  x                                                )                                                              {\displaystyle I\propto f(\mathbf {x} )}                                                                                      or simply                                                                                                                              I                        =                        f                        (                                                  x                                                )                                                              {\displaystyle I=f(\mathbf {x} )}                                                                          ;)          4) Define absorption coefficient          γ          while          (t < MaxGeneration)          for          i = 1 : n (all n fireflies)          for          j = 1 : i (n fireflies)                      if            (                                                                                                                                            I                                                      j                                                                          >                                                  I                                                      i                                                                                                                {\displaystyle I_{j}>I_{i}}                                                                          ),          Vary attractiveness with distance r via                                                                                                                                        exp                                                                        (                                                                        γ                                                                                                  r                        )                                                              {\displaystyle \exp(-\gamma \;r)}                                                                          ;          move firefly i towards j;                                     Evaluate new solutions and update light intensity;          end if          end for          j          end for          i         Rank fireflies and find the current best;          end while          end        

Note that the number of objective function evaluations per loop is one evaluation per firefly, even though the above pseudocode suggests it is n×n. (Based on Yang's MATLAB code.) Thus the total number of objective function evaluations is (number of generations) × (number of fireflies).

The main update formula for any pair of two fireflies x i {\displaystyle \mathbf {x} _{i}} and x j {\displaystyle \mathbf {x} _{j}} is

x i t + 1 = x i t + β exp [ γ r i j 2 ] ( x j t x i t ) + α t ϵ t {\displaystyle \mathbf {x} _{i}^{t+1}=\mathbf {x} _{i}^{t}+\beta \exp[-\gamma r_{ij}^{2}](\mathbf {x} _{j}^{t}-\mathbf {x} _{i}^{t})+\alpha _{t}{\boldsymbol {\epsilon }}_{t}}

where α t {\displaystyle \alpha _{t}} is a parameter controlling the step size, while ϵ t {\displaystyle {\boldsymbol {\epsilon }}_{t}} is a vector drawn from a Gaussian or other distribution.

It can be shown that the limiting case γ 0 {\displaystyle \gamma \rightarrow 0} corresponds to the standard Particle Swarm Optimization (PSO). In fact, if the inner loop (for j) is removed and the brightness I j {\displaystyle I_{j}} is replaced by the current global best g {\displaystyle g^{*}} , then FA essentially becomes the standard PSO.

Criticism [edit]

Nature-inspired metaheuristics in general have attracted criticism in the research community for hiding their lack of novelty behind metaphors. The firefly algorithm has been criticized as differing from the well-established particle swarm optimization only in a negligible way.[2] [3] [4]

See also [edit]

  • Swarm intelligence

References [edit]

  1. ^ Yang, X. S. (2008). Nature-Inspired Metaheuristic Algorithms. Luniver Press. ISBN978-1-905986-10-1.
  2. ^ Almasi, Omid N.; Rouhani, Modjtaba (2016). "A new fuzzy membership assignment and model selection approach based on dynamic class centers for fuzzy SVM family using the firefly algorithm". Turkish Journal of Electrical Engineering & Computer Sciences. 4: 1–19. doi:10.3906/elk-1310-253. Practical application of FA on UCI datasets.
  3. ^ Lones, Michael A. (2014). "Metaheuristics in Nature-Inspired Algorithms" (PDF). GECCO '14: 1419–1422. CiteSeerX10.1.1.699.1825. doi:10.1145/2598394.2609841. ISBN9781450328814. FA, on the other hand, has little to distinguish it from PSO, with the inverse-square law having a similar effect to crowding and fitness sharing in EAs, and the use of multi-swarms in PSO.
  4. ^ Weyland, Dennis (2015). "A critical analysis of the harmony search algorithm—How not to solve sudoku". Operations Research Perspectives. 2: 97–105. doi:10.1016/j.orp.2015.04.001. For example, the differences between the particle swarm optimization metaheuristic and "novel" metaheuristics like the firefly algorithm, the fruit fly optimization algorithm, the fish swarm optimization algorithm or the cat swarm optimization algorithm seem negligible.
  5. ^ Ariyaratne MKA, Pemarathne WPJ (2015) A review of recent advancements of firefly algorithm: a modern nature inspired algorithm. In: Proceedings of the 8th international research conference, 61–66, KDU, Published November 2015, http://ir.kdu.ac.lk/bitstream/handle/345/1038/com-047.pdf?sequence=1&isAllowed=y

External links [edit]

  • [1] Files of the Matlab programs included in the book: Xin-She Yang, Nature-Inspired Metaheuristic Algorithms, Second Edition, Luniver Press, (2010).

goldenwhimse.blogspot.com

Source: https://en.wikipedia.org/wiki/Firefly_algorithm

0 Response to "Firefly Algorithm for Continuous Constrained Optimization Tasks"

Post a Comment

Iklan Atas Artikel

Iklan Tengah Artikel 1

Iklan Tengah Artikel 2

Iklan Bawah Artikel