Skip to main content

Symbiotic Artificial Immune Systems

Project description

🧬🤖 SAIS: Symbiotic Artificial Immune Systems

ACM Paper arXiv PyPI version Python 3.8+ flake8 License

Symbiotic

🔬 Introduction

SAIS (Symbiotic Artificial Immune Systems) is a novel Artificial Immune System inspired by symbiotic relationships observed in biology. It leverages the three key stages of symbiotic relationships—mutualism, commensalism, and parasitism—for population updating, as seen in the Symbiotic Organisms Search (SOS) algorithm. This approach effectively tackles the challenges associated with large population sizes and enhances population diversity, issues that traditional AIS and SOS algorithms struggle to address efficiently. This project aims to provide an open-source implementation of the SAIS algorithm to foster innovation and research in bio-inspired computing and immune-inspired algorithms.

📦 Official Python Package Index (PyPI) Package: SAIS.

🏆 Publication

📚 The paper has been published in the 'ACM Proceedings of the Genetic and Evolutionary Computation Conference (GECCO '24 Companion)'🎉.

🎊 The preprint is available on arXiv.

⚙️ Features

  • Implementation of the Symbiotic Artificial Immune Systems algorithm.
  • Easy to calculate the objective value of the function.
  • Customizable for different optimisation needs.
  • Support for multiple benchmark functions.

🚀 Quick Start

Ensure the following dependencies are installed on your system:

  • Python 3.x
  • numpy

📥 Install sais using pip:

pip install sais

🔥 Example usage, here's how to use SAIS to optimise a function:

from sais import run

# define your benchmark number and population size
population_size = 2000
# number from Benchmarks List
benchmark_number = 1

run(population_size, benchmark_number)

📌 Example output:

Starting SAIS for benchmark 1 with population size 2000.
Iterations Number: 8
Running Time: 0.18377017974853516 Secounds
Best Fitness: 4.523554492464579e-10
Best Antibody: [2.9999822  0.49999976]

🎯 Function evaluation, get the function's value at a given point:

import numpy as np
from sais import benchmark_result


x = np.random.uniform(np.pi, np.pi, 2)
y = sais.benchmark_result(x, 2)
print(x, y)

📊 Benchmark Functions

### Benchmarks (Name, Range, Global Minimum)
# F1 = Beale [-4.5; 4.5]; 0
# F2 = Easom [-100,100]; -1
# F3 = Matyas [-10,10]; 0
# F4 = Bochachvesky 1 [-100,100]; 0
# F5 = Booth [-10, 10]; 0
# F6 = Michalewicz 2[0,pi]; -1.8013
# F7 = Schaffer [-100; 100]; 0
# F8 = Six Hump Camel Back [-5; 5]; -1.03163
# F9 = Bochachvesky 2 [-100,100]; 0
# F10 = Bochachvesky 3 [-100,100]; 0
# F11 = Shubert [-10,10]; -186.73
# F12 = Colville [-10,10]; 0
# F13 = Michalewicz 5 [0,pi]; -4.6877
# F14 = Zakharov[-5,10]; 0
# F15 = Michalewicz 10 [0,pi]; -4.6877
# F16 = Step [-5.12; 5.12]; 0
# F17 = Sphere [-100,100]; 0
# F18 = SumSquares [-10, 10]; 0
# F19 = Quartic [-1.28,1.28]; 0
# F20 = Schwefel 2.22 [-10,10]; 0
# F21 = Schwefel 1.2 [-10,10]; 0
# F22 = Rosenbrock [-30,30]; 0
# F23 = Dixon-Price [-10, 10]; 0
# F24 = Rastrigin [-5.12; 5.12];
# F25 = Griewank [-600,600]; 0
# F26 = Ackley [-600; 600]; 0
# F27 = UserCustom [-60; -20]; 7500

🔄 SAIS Flowchart

📌 Click to expand the flowchart.

Flowchart

📬 Contact

For any questions or suggestions, please contact us via:

📜 License

This project is licensed under the Apache 2.0 License.

🔖 Citation

@inproceedings{song2024sais,
  title={SAIS: A Novel Bio-Inspired Artificial Immune System Based on Symbiotic Paradigm},
  author={Song, Junhao and Yuan, Yingfang and Pang, Wei},
  booktitle={Proceedings of the Genetic and Evolutionary Computation Conference Companion},
  pages={2115--2118},
  year={2024}
}

🎓 Acknowledgements

We extend our sincere thanks to 🏛️ Imperial College London & Heriot-Watt University for their support and the academic environment that facilitated our research.

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

sais-0.3.7.tar.gz (14.4 kB view details)

Uploaded Source

Built Distribution

sais-0.3.7-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file sais-0.3.7.tar.gz.

File metadata

  • Download URL: sais-0.3.7.tar.gz
  • Upload date:
  • Size: 14.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sais-0.3.7.tar.gz
Algorithm Hash digest
SHA256 eaff35aa21cbefb2f1fe85e4747fe09b263991a8c807da9c674d58a95d46c264
MD5 6024ece9365a325a6b6bebdefa9cdcb0
BLAKE2b-256 b7ed1061151d50611c665eba9107e50398147790d62438c3313f72fbf3b5a44c

See more details on using hashes here.

File details

Details for the file sais-0.3.7-py3-none-any.whl.

File metadata

  • Download URL: sais-0.3.7-py3-none-any.whl
  • Upload date:
  • Size: 12.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sais-0.3.7-py3-none-any.whl
Algorithm Hash digest
SHA256 92c1f35ee9224962031e88b9461e46ab15cf31f2bdec149affcc8ce14f37b104
MD5 8147dbddcc71375deaba223e4d22bc63
BLAKE2b-256 d791945ee6412ed3c86c997b5c3235b752fc5b1cfc8c61c59ff8146a0806c0f0

See more details on using hashes here.

Supported by

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