Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Lära Swarm Intelligence and Collective Behavior | Fundamentals of Bio-Inspired Algorithms
Bio-Inspired Algorithms

bookSwarm Intelligence and Collective Behavior

Note
Definition

Swarm intelligence is a field of study inspired by the collective behavior of decentralized, self-organized systems — such as flocks of birds, schools of fish, or colonies of ants. It focuses on how simple local interactions between individuals can lead to complex, coordinated group behavior without any central control.

Swarm intelligence differs from systems driven by a central controller. Instead, it relies on individual agents following simple local rules. Each agent typically interacts only with its immediate neighbors or environment, yet together they exhibit emergent behavior — adaptive, organized patterns that arise naturally from many local interactions rather than from top-down instructions.

A key aspect of swarm intelligence is self-organization:

  • Agents update their actions based on local information, such as the position or signals of nearby peers;
  • Through repeated local interactions, the group can adapt to changes, solve problems, and form patterns — without any single agent having a global view or plan.

Swarm-based systems are robust, flexible, and scalable, making them attractive for solving complex computational problems such as optimization, routing, and clustering.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
# Example: Simulating simple swarm movement based on local interactions import numpy as np import matplotlib.pyplot as plt # Parameters num_agents = 20 steps = 75 arena_size = 100 # Initialize agent positions randomly positions = np.random.rand(num_agents, 2) * arena_size # Function: move each agent towards the average position of its neighbors within a certain radius def move_agents(positions, radius=30.0, step_size=0.5): new_positions = positions.copy() for i, pos in enumerate(positions): # Compute distances to all other agents dists = np.linalg.norm(positions - pos, axis=1) # Find neighbors (excluding self) neighbors = positions[(dists < radius) & (dists > 0)] if len(neighbors) > 0: # Compute average neighbor position avg_pos = neighbors.mean(axis=0) # Move slightly towards the average position direction = avg_pos - pos direction = direction / (np.linalg.norm(direction) + 1e-8) new_positions[i] += step_size * direction return new_positions # Simulate movement history = [positions.copy()] for _ in range(steps): positions = move_agents(positions) history.append(positions.copy()) # Plot agent trajectories plt.figure(figsize=(6, 6)) for i in range(num_agents): traj = np.array([h[i] for h in history]) plt.plot(traj[:, 0], traj[:, 1], alpha=0.7) plt.scatter(traj[-1, 0], traj[-1, 1], s=30) plt.title("Simple Swarm Agent Movement") plt.xlim(0, arena_size) plt.ylim(0, arena_size) plt.xlabel("X") plt.ylabel("Y") plt.grid(True) plt.show()
copy

Swarm Algorithms vs. Evolutionary Algorithms

Swarm algorithms and evolutionary algorithms both draw inspiration from nature, but they differ fundamentally in how they approach problem solving.

  • Swarm algorithms—such as ant colony optimization and particle swarm optimization—are based on the collective behavior of agents that interact locally and adapt in real time;
  • Each agent in a swarm algorithm typically represents a solution or a part of a solution and moves through the search space, influenced by the positions or successes of its neighbors;
  • The group as a whole converges toward promising regions through shared information and feedback.

In contrast, evolutionary algorithms—such as genetic algorithms—focus on populations of candidate solutions that evolve over generations.

  • These algorithms use operators like selection, crossover, and mutation to create new generations, gradually improving the population’s fitness;
  • Evolutionary algorithms rely on explicit reproduction and replacement mechanisms, often with less emphasis on direct agent-to-agent interaction during the search process.

The key distinction lies in the mode of adaptation: swarm intelligence leverages real-time, decentralized cooperation among agents, while evolutionary algorithms depend on generational evolution and genetic variation. Both approaches offer powerful tools for solving complex problems, but they do so through fundamentally different mechanisms of inspiration and operation.

question mark

Which statement best describes emergent behavior in swarm intelligence?

Select the correct answer

Var allt tydligt?

Hur kan vi förbättra det?

Tack för dina kommentarer!

Avsnitt 1. Kapitel 3

Fråga AI

expand

Fråga AI

ChatGPT

Fråga vad du vill eller prova någon av de föreslagna frågorna för att starta vårt samtal

Awesome!

Completion rate improved to 6.25

bookSwarm Intelligence and Collective Behavior

Svep för att visa menyn

Note
Definition

Swarm intelligence is a field of study inspired by the collective behavior of decentralized, self-organized systems — such as flocks of birds, schools of fish, or colonies of ants. It focuses on how simple local interactions between individuals can lead to complex, coordinated group behavior without any central control.

Swarm intelligence differs from systems driven by a central controller. Instead, it relies on individual agents following simple local rules. Each agent typically interacts only with its immediate neighbors or environment, yet together they exhibit emergent behavior — adaptive, organized patterns that arise naturally from many local interactions rather than from top-down instructions.

A key aspect of swarm intelligence is self-organization:

  • Agents update their actions based on local information, such as the position or signals of nearby peers;
  • Through repeated local interactions, the group can adapt to changes, solve problems, and form patterns — without any single agent having a global view or plan.

Swarm-based systems are robust, flexible, and scalable, making them attractive for solving complex computational problems such as optimization, routing, and clustering.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
# Example: Simulating simple swarm movement based on local interactions import numpy as np import matplotlib.pyplot as plt # Parameters num_agents = 20 steps = 75 arena_size = 100 # Initialize agent positions randomly positions = np.random.rand(num_agents, 2) * arena_size # Function: move each agent towards the average position of its neighbors within a certain radius def move_agents(positions, radius=30.0, step_size=0.5): new_positions = positions.copy() for i, pos in enumerate(positions): # Compute distances to all other agents dists = np.linalg.norm(positions - pos, axis=1) # Find neighbors (excluding self) neighbors = positions[(dists < radius) & (dists > 0)] if len(neighbors) > 0: # Compute average neighbor position avg_pos = neighbors.mean(axis=0) # Move slightly towards the average position direction = avg_pos - pos direction = direction / (np.linalg.norm(direction) + 1e-8) new_positions[i] += step_size * direction return new_positions # Simulate movement history = [positions.copy()] for _ in range(steps): positions = move_agents(positions) history.append(positions.copy()) # Plot agent trajectories plt.figure(figsize=(6, 6)) for i in range(num_agents): traj = np.array([h[i] for h in history]) plt.plot(traj[:, 0], traj[:, 1], alpha=0.7) plt.scatter(traj[-1, 0], traj[-1, 1], s=30) plt.title("Simple Swarm Agent Movement") plt.xlim(0, arena_size) plt.ylim(0, arena_size) plt.xlabel("X") plt.ylabel("Y") plt.grid(True) plt.show()
copy

Swarm Algorithms vs. Evolutionary Algorithms

Swarm algorithms and evolutionary algorithms both draw inspiration from nature, but they differ fundamentally in how they approach problem solving.

  • Swarm algorithms—such as ant colony optimization and particle swarm optimization—are based on the collective behavior of agents that interact locally and adapt in real time;
  • Each agent in a swarm algorithm typically represents a solution or a part of a solution and moves through the search space, influenced by the positions or successes of its neighbors;
  • The group as a whole converges toward promising regions through shared information and feedback.

In contrast, evolutionary algorithms—such as genetic algorithms—focus on populations of candidate solutions that evolve over generations.

  • These algorithms use operators like selection, crossover, and mutation to create new generations, gradually improving the population’s fitness;
  • Evolutionary algorithms rely on explicit reproduction and replacement mechanisms, often with less emphasis on direct agent-to-agent interaction during the search process.

The key distinction lies in the mode of adaptation: swarm intelligence leverages real-time, decentralized cooperation among agents, while evolutionary algorithms depend on generational evolution and genetic variation. Both approaches offer powerful tools for solving complex problems, but they do so through fundamentally different mechanisms of inspiration and operation.

question mark

Which statement best describes emergent behavior in swarm intelligence?

Select the correct answer

Var allt tydligt?

Hur kan vi förbättra det?

Tack för dina kommentarer!

Avsnitt 1. Kapitel 3
some-alt