Skip to content

SeyedMuhammadHosseinMousavi/Optimization-Algorithms-and-Problems

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Optimization Algorithms and Problems

What is Optimization?

Optimization is the process of finding the best possible solution to a problem within a defined set of constraints and objectives. It plays a critical role in various fields, from engineering and computer science to finance and logistics. By maximizing or minimizing an objective function, optimization ensures efficient resource utilization, cost reduction, and enhanced performance.

image

Importance of Optimization

  • Efficiency: Helps in solving complex real-world problems efficiently.
  • Resource Management: Ensures optimal use of limited resources.
  • Scalability: Facilitates handling large-scale problems.

Types of Optimization

  1. Gradient-Based Optimization: Relies on the gradient of the objective function for optimization (e.g., Gradient Descent).
  2. Evolutionary Algorithms: Mimics natural evolution (e.g., Genetic Algorithm, Differential Evolution).
  3. Swarm Intelligence: Inspired by collective behavior of social creatures (e.g., Particle Swarm Optimization, Ant Colony Optimization).
  4. Metaheuristic Optimization: Provides approximate solutions for complex problems (e.g., Simulated Annealing, Harmony Search). image

Algorithms

Below is a list of algorithms implemented in this repository:

  1. Gradient Descent: An iterative algorithm for minimizing functions by following the gradient.
  2. Newton's Method: Utilizes the second derivative to find local minima or maxima.
  3. Stochastic Gradient Descent: A variant of Gradient Descent that uses random samples for optimization.
  4. Nelder-Mead Method: A simplex-based optimization technique.
  5. Best-First Search: Explores a graph to find the optimal solution.
  6. Hill Climbing: A greedy algorithm that iteratively moves toward the optimal solution.
  7. Tree-Structured Parzen Estimator: A Bayesian optimization technique.
  8. African Vultures Optimization Algorithm: Inspired by the scavenging behavior of vultures.
  9. Ant Colony Optimization: Mimics the behavior of ants searching for food.
  10. Bat Algorithm: Inspired by echolocation behavior of bats.
  11. Bees Algorithm: Models the foraging behavior of bees.
  12. Differential Evolution: A population-based optimization technique.
  13. Firefly Algorithm: Inspired by the flashing behavior of fireflies.
  14. Genetic Algorithm: Mimics natural selection to evolve solutions.
  15. Particle Swarm Optimization: Inspired by the social behavior of birds and fish.
  16. Simulated Annealing: Mimics the annealing process in metallurgy.
  17. Harmony Search: Inspired by musical improvisation.
  18. Imperialist Competitive Algorithm: Simulates imperialistic competition.
  19. Whale Optimization Algorithm: Mimics the hunting behavior of humpback whales.
  20. Grey Wolf Optimizer: Inspired by the leadership hierarchy of grey wolves.
  21. Brain Storm Optimization: Mimics the brainstorming process for creative solutions.
  22. Cuckoo Search: Inspired by the brood parasitism behavior of cuckoo birds.
  23. Biogeography-Based Optimization: Models the migration patterns of species.
  24. Teaching-Learning-Based Optimization: Mimics the teaching-learning process in a classroom.
  25. Galaxy Gravity Optimization: Inspired by the gravitational interactions of galaxies.
  26. Victoria Amazonica Optimization Algorithm: Inspired by the growth and spread of the Victoria Amazonica plant.
  27. Weevil Damage Optimization Algorithm: Simulates the damage behavior of weevils.
  28. MOEA/D: A multi-objective evolutionary algorithm based on decomposition.
  29. NSGA-II: A fast and elitist multi-objective genetic algorithm.
  30. Tabu Search: Uses a tabu list to avoid cycling in search processes.
  31. Ant Colony Optimization Bin Packing: Specialized for solving bin packing problems.
  32. Firefly Space-Time Bending: A variant of Firefly Algorithm applied to space-time optimization.
  33. Simulated Annealing Quadratic Assignment Problem: Special implementation for QAP.

image image


Applications

The following problems have been solved using the above algorithms:

  1. Bin Packing Problem: Solved using Ant Colony Optimization.
  2. Feature Selection: Achieved with the Bat Algorithm.
  3. Economic Dispatching: Handled using Bees Algorithm.
  4. Minimum Spanning Tree: Optimized with Biogeography-Based Optimization.
  5. Parallel Machine Scheduling: Solved using Brain Storm Optimization.
  6. Traveling Salesman Problem: Addressed with Cuckoo Search.
  7. Protein Structure Prediction: Solved using Differential Evolution.
  8. Image Segmentation: Implemented with Firefly Algorithm.
  9. Evolutionary Art: Created using Genetic Algorithm and Particle Swarm Optimization.
  10. Latent Space Optimization: Conducted with Grey Wolf Optimizer for VAE.
  11. Quadratic Assignment Problem: Solved using Simulated Annealing.
  12. Resource Allocation: Implemented with Stochastic Gradient Descent.
  13. Vehicle Routing Problem: Solved using Teaching-Learning-Based Optimization.
  14. Hub Location Allocation: Addressed with Whale Optimization Algorithm.
  15. Space-Time Bending Optimization: Solved using Firefly Algorithm.
  16. Regression Analysis: Conducted using Harmony Search.
  17. Evolved Antenna Design: Implemented with Particle Swarm Optimization.
  18. Exoplanetary Adaptation: Solved with Genetic Algorithm.
  19. Traveling Salesman Problem (Cuckoo Search): Addressed using Cuckoo Search Algorithm.
  20. Clustering Problem (Differential Evolution): Solved using Differential Evolution.
  21. Optimized Feature Selection (Bat Algorithm): Utilized for feature selection optimization.
  22. Protein Folding Prediction (Differential Evolution): Addressed with advanced Differential Evolution techniques.

Repository Structure

Algorithms

Each algorithm is implemented in a separate .py file for ease of use and modularity.

Problems

The problems are categorized and solved using specific algorithms, with clear explanations in the comments.

Presentations

Detailed presentations explaining the theoretical and practical aspects of each algorithm and problem are included.


Contributions

Contributions are welcome! Please fork the repository, make your changes, and submit a pull request.