#Tangible PSO
Particle Swarm Optimization for Formation Flying, written in Matlab, with Agent delegation to classes.
Sample run, large red circles are the goals, small red circles are global best UAV positions, starting points are green, and particle 1 trajectory is shown.
Particle Swarm Optimization as introduced in [1] is an optimization method based on the behavior of swarms, where each particle explores the state space adding to the collective knowledge of the solution.
Because in the traditional PSO particles are unidimensional, whereas in Tangible PSO as introduced in [2] by Saska et al. each particle represents a Swarm of UAVs. So the evolution of each particle in fact represents the trajectories of a group of UAVs.
NOTE: The use of the word Swarm is somewhat different along this work, because it also refers to the collection of UAVs. So a collection of UAVs is a Swarm, which is a particle of the PSO...
In the current state it is used to determine a feasible path or trajectory for a formation of UAVs from their starting position to a set of predefined goals. But it can be used for any other type of robot or object behaving collectivelly, from choreography to satellites.
I attended the course "Path planning for mobile robots in inspection, surveillance, and exploration missions" by M. Saska at ECI2015 [3] and wanted to see the method working.
The aim is to experiment with the algorithms, not to optimize them for performance. I consider that performance optimization can be delegated to the actual embedded implementation.
- Implemented using classes.
- It is very generic in what kind of robot or object constitute the Swarm. It must be defined as an Agent class with a set of standard control properties and methods (current state property, state update method, inverse kinematics, etc.).
- A sample implementation of this Agent class is the included UAV class. It includes options to saturate controls and velocity.
- Swarms are classes also, and group Agents. Swarms have the same set of standard control properties and methods.
- The PSO class takes the Agent (particle class) as a parameter, this allows to reuse it with any other type of particle.
- The PSO core method is in a separate file ( Iterate.M), for easy experimentation.
- Cost Function is passed as a parameter to the PSO class, for easy experimentation.
You name it, just specify the goals and the cost function will take care.
An example script is included, but it's pretty straightforward:
Create a Swarm:
s = SWARM()
Add agents:
s.AddAgent(UAV(Path.Start.state))
Initialize the PSO:
p = PSO(s, N_Particles, Path.Goal, @CostFcn)
Iterate:
p.Iterate()
Typically with 20 particles (Swarms of 3 UAVs) the convergence is in less than 50 steps.
[1]. J. Kennedy and R. Eberhart, “Particle swarm optimization,” in Pro- ceedings International Conference on Neural Networks IEEE, vol. 4, 1995, pp. 1942–1948.
[2]. M. Saska, J. Chudoba, L. Precil, J. Thomas, G. Loianno, A. Tresnak, V. Vonasek, and V. Kumar, “Autonomous deployment of swarms of micro-aerial vehicles in cooperative surveillance,” 2014 International Conference on Unmanned Aircraft Systems (ICUAS), pp. 584–595, 2014.
[3]. "Path planning for mobile robots in inspection, surveillance, and exploration missions", Prof. Martin Saska. Faculty of Electrical Engineering, Czech Technical University, Czech Republic, http://www.dc.uba.ar/events/eci/2015/cursos/saska