Skip to main content

An implementation of particle swarm optimisation loss function for PyTorch

Project description

AdaSwarm

This repo purportedly implements AdaSwarm, an optimizer, that combines Gradient Descent and Particle Swarms.

AdaSwarm is based on "AdaSwarm: Augmenting Gradient-Based optimizers in Deep Learning with Swarm Intelligence, Rohan Mohapatra, Snehanshu Saha, Carlos A. Coello Coello, Anwesh Bhattacharya Soma S. Dhavala, and Sriparna Saha", to appear in IEEE Transactions on Emerging Topics in Computational Intelligence. An arXiv version can be found here. This repo contains implementation used the paper.

Why AdaSwarm:

Said et al. [1] postulated that swarms behavior is similar to that of classical and quantum particles. In fact, their analogy is so striking that one may think that the social and individual intelligence components in Swarms are, after all, nice useful metaphors, and that there is a neat underlying dynamical system at play. This dynamical system perspective was indeed useful in unifying two almost parallel streams, namely, optimization and Markov Chain Monte Carlo sampling.

In a seminal paper, Wellington and Teh [2], showed that a stochastic gradient descent (SGD) optimization technique can be turned into a sampling technique by just adding noise, governed by Langevin dynamics. Recently, Soma and Sato [3] provided further insights into this connection based on an underlying dynamical system governed by stochastic differential equations (SDEs).

While these results are new, the connections between derivative-free optimization techniques based on Stochastic Approximation and Finite Differences are well documented [4]. Such strong connections between these seemingly different subfields of optimization and sampling made us wonder: Is there a larger, more general template, of which the aforementioned approaches are special cases, exist? AdaSwarm is a result of that deliberation.

We believe that it is just a beginning of a new breed of composable optimizers

What is AdaSwarm in simple terms, in the context Deep Learning:

  1. Setup

    • y: responses
    • f(.) is a model specified by a network with parameters w
    • f(x)is the prediction at observed feature x
    • L(.) is loss, to drive the optimization
  2. Approximate gradients of L(.) w.r.t f(.)

    • run an independent Swarm optimizer over L(.) with particle dimension equal to the size of the network's output layer
    • using swarm particle parameters, approximate the gradient of L(.) w.r.t f(.)
  3. Get gradients of f(.) w.r.t w

    • using standard AutoDiff, via chain rule, get the approximate gradient of f(.) w.r.t w
  4. Approximate gradients of L(.) w.r.t w via Chain Rule

    • take the product of gradients in steps (2) and (3)
  5. Updates the network weights via standard Back Propagation

Why does it work? Minor changes are meaningful!

At this time, we could embellish the fact that Swarm, by being a meta-heuristic algorithm, has less tendency to get trapped in local minimal or has better exploration capabilities. It is helping the problem overall. Secondly, entire information about the "learning" the task comes from the loss, and the function f(.) only specifies the structural relationship between input and output. Moreover, the ability of EMPSO, the first step toward AdaSwarm facilitates exploration and exploitation equally by using a modified formulation leveraging exponentially averaged velocities and by not ignoring past velocities. It is these velocities (which are different at different stages in the search space) that make the difference at local minima successfully by being able to differentiate between stagnating regions/saddle points and true local minima. Particular objects of interest are the equivalence theorems, such as the following:

"partial derivative of the loss wrt the weights" can be expressed in terms of Swarm parameters thus keeping tight control over the hyper-parameters and not tuning those at all for convergence. This addresses a common complaint about meta-heuristics.

So, having better "optimization" capabilities at the loss, in general, are going to be helpful. While we have ample empirical evidence that shows that AdaSwarm is working well, we also have some theory (not complete but enough to offer the convergence insights, particularly from the point of robust loss functions such as MAE and irregular losses used to solve PDEs/PDEs such as the Schrodinger Equation).

Another speculation, speculation at this time, is that, to the best of our knowledge, all current optimization techniques only harvest information coming from a single paradigm. AdaSwarm, whereas, combines different perspectives, like in an ensemble. More than an ensemble, it is a composition -- where different perspectives get chained. That is one fundamental difference between AdaSwarm and other population-based techniques.

In someways, just like an neural network architecture is composed of several layers, AdaSwarm is a composition of optmizers. That composition eventually fits into the chain rule.

As a result, the changes are very small. Same is the case with Adam and RMSProp, right? Other notable examples, where we see pronounced differences in speed/convergence, with very simple changes in the maps are:

  • Proximal gradient descent vs Accelerated Proximal gradient descent
  • Euler vs LeapFrog _ ...

Therefore, in order to better understand, and develop the theory and tools for composable optimizers, we have to develop both theoretical and computational tools to understand why and where AdaSwarm works. Along the way, make such optimizers accessible to the community.

Adaswarm Equivalence of Gradients: Why is it happening?

The equivalences are driven by the following equations in the main text (cf. docs/papers folder):

Eqns (4)-(6), (15), (18) and the eqn below for non-differentiable loss and (20)-(24)

Objectives:

  1. Develop a plug-and-play optimizer that works with

    • other optimizers in the PyTorch ecosystem, along side the likes of Adam, RMSProp, SGD
    • any architecture
    • any dataset
    • with the same api as others, i.e., optim.AdaSwarm()
  2. Battle test on variety of

    • test objectives functions
    • datasets
    • architectures (Transformers, MLPs,..)
    • losses (BCE, CCE, MSE, MAE, CheckLoss,...)
    • paradigms (RIL, Active Learning, Supervised Learning etc..)
    • etc..
  3. Provide insights into the workings of AdaSwarm by

    • analyzing the workings of the optimizers
    • visualizing the path trajectories
    • etc..
  4. Most importantly, be community driven

    • there is lot of enthusiasm and interest in the recent graduates and undergraduates, that want to learn ML/AI technologies. Instead of fiddling with MNIST datasets, and predicting Cats and Dogs, do something foundational and meaningful. If you take offence to statement, you are not ready for this project.
    • turn this into a truly community-driven effort to offer a useable, useful, foundational building block to the deep learning ecosystem

How to run this project

Pre-requisites

Get the source

$ git clone https://github.com/AdaSwarm/AdaSwarm.git

Running the example (single method - runs Adaswarm/PSO)

$ cd AdaSwarm
$ make run

Running tests

$ make test

Using in your own project

If you use poetry you can add AdaSwarm as a dependency

$ poetry add adaswarm

See .example/main.py for usage.

Contributing:

  1. While we are yet to establish the policy to contribute, we will follow how any Apache open source project works. For example, see airflow project's contribution guidelines.

  2. [tbd]

    • developer slack channel will be coming soon
    • we will hold weekly zoom/meet at specific times (off office hours, so anybody can join)
  3. But be mindful. There may not be any no short-term rewards.

    • Research is bloody hard work. There will not be any instant gratification or recognition for the work. Expect lot of negative results, and set backs.
    • Optimization problems are generally hard, and writing an Engineering level framework that works on any problem is even harder. It is scientific computing, not writing hello world examples.
    • So take a plunge only if you are willing to endure the pain, w/o worrying about the end result.

References

[1] S. M. Mikki and A. A. Kishk, Particle Swarm Optimizaton: A Physics-Based Approach. Morgan & Claypool, 2008.

[2] M. Welling and Y. W. Teh, “Bayesian learning via stochastic gradient langevin dynamics,”In Proceedings of the 28th International Conference on Machine Learning, p. 681–688, 2011.

[3] S. Yokoi and I. Sato, “Bayesian interpretation of SGD as Ito process,” ArXiv, vol. abs/1911.09011, 201.

[4] J. Spall, Introduction to stochastic search and optimization. Wiley-Interscience, 2003

Citation

AdaSwarm will be appearing in the paper you can cite:

@inproceedings{adaswarm,
    title = "daSwarm: Augmenting Gradient-Based optimizers in Deep Learning with Swarm Intelligence",
    author = "Rohan Mohapatra, Snehanshu Saha, Carlos A. Coello Coello, Anwesh Bhattacharya Soma S. Dhavala, and Sriparna Saha",
    booktitle = "IEEE Transaction on Emerging Topics in Computational Intelligence",
    month = tbd,
    year = "2021",
    address = "Online",
    publisher = "IEEE",
    url = "https://arxiv.org/abs/2006.09875",
    pages = tbd
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

adaswarm-0.0.2.tar.gz (20.1 kB view details)

Uploaded Source

Built Distribution

adaswarm-0.0.2-py3-none-any.whl (17.1 kB view details)

Uploaded Python 3

File details

Details for the file adaswarm-0.0.2.tar.gz.

File metadata

  • Download URL: adaswarm-0.0.2.tar.gz
  • Upload date:
  • Size: 20.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.10 CPython/3.9.13 Darwin/21.5.0

File hashes

Hashes for adaswarm-0.0.2.tar.gz
Algorithm Hash digest
SHA256 433feccb7ca609598d0e55e55adafa77f32522f7f41e8a8a90ae76916351d1bd
MD5 5caf152d5a02fdbc1e698c70a069574b
BLAKE2b-256 95d0656c53b19b5f7e545ba764b69bbd912717b66199f0dcfa6fcb64b25398d2

See more details on using hashes here.

File details

Details for the file adaswarm-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: adaswarm-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 17.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.10 CPython/3.9.13 Darwin/21.5.0

File hashes

Hashes for adaswarm-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5f1478de76d252b0f4a09042b41f7788e7dcf745bb6f5d9991b888de79f185a8
MD5 e05b15cb039346fa88631730e4fef052
BLAKE2b-256 bc7004b2ef5ede58aa1535173aa93417cab2815dc54fb5feae64a1e378673ec1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page