Download presentation
Presentation is loading. Please wait.
Published byClara Gibbs Modified over 9 years ago
2
Particle Swarm Optimization Using the HP Prime Presented by Namir Shammas 1
3
Dedication I dedicate this tutorial, with an immense sense of gratitude and thankfulness, to the fine Boston College Jesuits who spent decades working in Iraq to educate students in Baghdad College and Al-Hikmat University. They instilled in us the power to be self-taught! No words can fully thank them for that gift alone. 2
4
Dedication 3
5
Particle Swarm Optimization Efficient method for stochastic optimization. Is based on the movement and cleverness of swarms in the search space to locate the best solution. Was developed by James Kennedy in 1995. Algorithm simulates the use of particles (agents) making up a swarm moving throughout the search space looking for the best solution. 4
6
Particle Swarm Optimization Every particle represents a point flying in a multi- dimensional space. Each particle adjusts its flying metrics influenced by its own experience and in addition by the experience of other particles. Each particle keeps track of it’s personal best (lowest/highest function value), partBest(i). The particles keeps track of the global best, globBest. 3
7
Particle Swarm Optimization 6
8
X(k) is the current point coordinate. X(k+1) is the updated point coordinate. V(k) is the current velocity. V(k+1) is the updated velocity. V(partBest) is the particle’s best velocity. V(globBest) is the global best velocity. 5
9
Particle Swarm Optimization V(k+1) uses the following equations: V(i,k+1) = w * V(i,k) + C1 * r1 (partBest(i) − X(i,k)) + C2 * r2 (globaBest – X(i,k)) X(i,k) = X(i,k) + V(i,k+1) C1 and C2 are constants. The parameter changes w decreases in value with each iteration. Recommend to change from 1 to 0.3. r1 and r2 are uniform random numbers in range [0, 1]. 6
10
Particle Swarm Optimization Easy to code. Requires fewer input parameters, lines, and subroutines, than GA. Requires smaller population sizes than GA. Requires fewer generations/iterations than GA. Does not require a restart! Often returns accurate answers! 9
11
HP Prime Implementation Function PSO returns the best solution for optimized function MyFx. Parameters for PSO are: Number of variables. Population size (number of probes). Maximum generations (i.e. iterations). Two arrays that define the lower and upper bounds for each variable. 8
12
HP Prime Implementation To solve the optimum points of the Rosenbrock function, call PSO with the following arguments: Number of variables = 4. Population size of 40. Maximum generations of 2000. Vector for lower values of [0.2 0.25 0.22 0.25]. Vector for upper values of [2 2 2 2]. Store results in matrix M3. 9
13
HP Prime Implementation 10
14
HP Prime Implementation 11
15
GCPSO Improved version of PSO that guarantees convergence (hence abbreviation of GCPSO) by keeping track of the best point. Similar to PSO, but updates the velocity of the best point using: V(i,j)= −X(i,j) + globPop(j) + w * V(i,j) + ρ ( 1 − 2 * Rand) w is a constant, Rand is [0, 1] random number, and ρ is a dynamically- adjusted scaling factor. The indices i and j control the population and variable indices, respectively. The scaling factor is doubled after each 5 sequential successes to get a better candidate for the optimum function value. The scaling factor is reduced in half after 5 sequential failures to get a better candidate for the optimum function value. 12
16
HP Prime Implementation Function GCPSO returns the best solution for optimized function MyFx. Parameters for GCPSO are: Number of variables. Population size (number of probes). Maximum generations (i.e. iterations). Two arrays that define the lower and upper bounds for each variable. 13
17
HP Prime Implementation To solve the optimum points of the Rosenbrock function, call GCPSO with the following arguments: Number of variables = 4. Population size of 40. Maximum generations of 2000. Vector for lower values of [0.2 0.25 0.22 0.25]. Vector for upper values of [2 2 2 2]. Store results in matrix M3. 14
18
HP Prime Implementation 15
19
HP Prime Implementation 16
20
BONUS MATERIAL! 17
21
Differential Evolution Very simple and very efficient family of evolutionary algorithm. Developed by Storn and Price in the mid 1990s. I present the simplest scheme called DE/rand/1. There are at least 9 more schemes! Uses a simple equation to calculate a potential replacement for the current position using: Xtrl(j) = X(c, j) + F * (X(a, j) – X(b, j) Where a, b, and c are distinct indices (also not equal to the current population index) in the range of [1, MaxPop]. The letter j is the index to a variable. Replaces old position with better fit candidates. 18
22
HP Prime Implementation Function EA returns the best solution for optimized function MyFx. Parameters for EA are: Number of variables. Population size (number of probes). Maximum generations (i.e. iterations). Two arrays that define the lower and upper bounds for each variable. 19
23
HP Prime Implementation To solve the optimum points of the Rosenbrock function, call EA with the following arguments: Number of variables = 4. Population size of 40. Maximum generations of 2000. Vector for lower values of [0.2 0.25 0.22 0.25]. Vector for upper values of [2 2 2 2]. Store results in matrix M3. 22
24
HP Prime Implementation 23
25
HP Prime Implementation 22
26
HP Prime Implementation 22 Paraphrasing actor Steve Buscemi in Escape from LA, This crowd loves a winner!
27
Final Remarks Evolutionary algorithms for optimization are a mix between science, experimentation, and art. There is a large number of variants for the various evolutionary algorithms. Number exceeds by far the number of classical optimization methods and their variants. Complexity of algorithm does not always equal superiority of performance. Some cleverly designed simple algorithm can perform very well. 23
28
No Free Lunch in Search and Optimization There is no single algorithm that can solve all optimization problems! Principle is abbreviated as NFL. Concept proposed by Wolpert and Macready in 1997. You will need to experiment with several algorithms to find the best one for your problem. Given an algorithm A, researchers have found that A may succeed with p % of the problems, while some other algorithms, collectively call them B, will solve (100-p)% of the remaining problems. B may represent one of more algorithms. 24
29
No Free Lunch in Search and Optimization (cont.) See the following web sites: https://en.wikipedia.org/wiki/No_free_lunch_in_search_and_optimi zation https://en.wikipedia.org/wiki/No_free_lunch_in_search_and_optimi zation http://www.no-free-lunch.org/ www.santafe.edu/media/workingpapers/12-10-017.pdf www.no-free-lunch.org/WoMa96a.pdf 28
30
References Clever Algorithms-Nature-Inspired Programming Recipes, first ed., 2011, by Jason Brownlee. (Available for online reading). Handbook of Metaheuristics, first ed., 2003, by Fred Glover and Gary A. Kochenberger. Particle Swarm Optimization, first ed., 2006, by Maurice Clerc. Practical Genetic Algorithms, second ed., 2004, by Randy L. Haupt and Sue Ellen Haupt. Evolutionary Optimization Algorithms, first ed., 2015, by Dan Simon. 29
31
Thank You!! 30
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.