Firefly algorithm
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 | edit source]In pseudocode the algorithm can be stated as:
Begin
1) Objective function: ;
2) Generate an initial population of fireflies ;.
3) Formulate light intensity I so that it is associated with
(for example, for maximization problems, or simply ;)
4) Define absorption coefficient γ
while (t < MaxGeneration)
for i = 1 : n (all n fireflies)
for j = 1 : i (n fireflies)
if (),
Vary attractiveness with distance r via ;
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 and is where is a parameter controlling the step size, while is a vector drawn from a Gaussian or other distribution.
It can be shown that the limiting case corresponds to the standard particle swarm optimization (PSO). In fact, if the inner loop (for j) is removed and the brightness is replaced by the current global best , then FA essentially becomes the standard PSO.
Criticism
[edit | edit source]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 | edit source]References
[edit | edit source]- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
- ^ 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 | edit source]- [1] Files of the Matlab programs included in the book: Xin-She Yang, Nature-Inspired Metaheuristic Algorithms, Second Edition, Luniver Press, (2010).
