Algorithm:
Let there be n particles, each with associated positions
data:image/s3,"s3://crabby-images/21b8b/21b8b870020672e6ea86fc57a7001c0d90dc4360" alt="\mathbf{x}_i \in \mathbb{R}^m"
data:image/s3,"s3://crabby-images/985c9/985c9edc8024e3ab8c23dbf319a82b8bbe9cab88" alt="\mathbf{v}_i \in \mathbb{R}^m"
data:image/s3,"s3://crabby-images/2bd15/2bd1526d0aee0601f68c108b1503fb47f634efd3" alt="i = 1, \ldots, n"
data:image/s3,"s3://crabby-images/5ae2d/5ae2d1f35b21294f2e2b803c13ebffc7370c508a" alt="\hat{\mathbf{x}}_i"
data:image/s3,"s3://crabby-images/5c5ae/5c5ae348ef825481cef5a8f2ea26c52225c9cd7b" alt="\hat{\mathbf{g}}"
- Initialize
and
for all i. One common choice is to take
and
for all i and
, where aj,bj are the limits of the search domain in each dimension.
and
.
- While not converged:
- For
:
.
.
- If
,
.
- If
,
.
- For
Note the following about the above algorithm:
- ω is an inertial constant. Good values are usually slightly less than 1.
- c1 and c2 are constants that say how much the particle is directed towards good positions. They represent a "cognitive" and a "social" component, respectively, in that they affect how much the particle's personal best and the global best (respectively) influence its movement. Usually, we take
but this need not be the case.
are two random vectors with each compenent generally a uniform random number between 0 and 1.
operator indicates element-by-element multiplication i.e. the Hadamard matrix multiplication operator.
1 comment:
LOOOOOOOOOL, friendly inspection!!!
Post a Comment