Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: Update overview for Mesa 3.0 #2317

Merged
merged 5 commits into from
Sep 22, 2024
Merged
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
165 changes: 136 additions & 29 deletions docs/overview.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
# Mesa Overview

Mesa is a modular framework for building, analyzing and visualizing agent-based models.

**Agent-based models** are computer simulations involving multiple entities (the agents) acting and interacting with one another based on their programmed behavior. Agents can be used to represent living cells, animals, individual humans, even entire organizations or abstract entities. Sometimes, we may have an understanding of how the individual components of a system behave, and want to see what system-level behaviors and effects emerge from their interaction. Other times, we may have a good idea of how the system overall behaves, and want to figure out what individual behaviors explain it. Or we may want to see how to get agents to cooperate or compete most effectively. Or we may just want to build a cool toy with colorful little dots moving around.
Expand All @@ -8,16 +7,15 @@ Mesa is a modular framework for building, analyzing and visualizing agent-based

Mesa is modular, meaning that its modeling, analysis and visualization components are kept separate but intended to work together. The modules are grouped into three categories:

1. **Modeling:** Modules used to build the models themselves: a model and agent classes, a scheduler to determine the sequence in which the agents act, and space for them to move around on.
1. **Modeling:** Modules used to build the models themselves: a model and agent classes, space for them to move around on, and built-in functionality for managing agents.
EwoutH marked this conversation as resolved.
Show resolved Hide resolved
2. **Analysis:** Tools to collect data generated from your model, or to run it multiple times with different parameter values.
3. **Visualization:** Classes to create and launch an interactive model visualization, using a server with a JavaScript interface.
3. **Visualization:** Classes to create and launch an interactive model visualization, using a browser-based interface.

### Modeling modules

Most models consist of one class to represent the model itself; one class (or more) for agents; a scheduler to handle time (what order the agents act in), and possibly a space for the agents to inhabit and move through. These are implemented in Mesa's modeling modules:
Most models consist of one class to represent the model itself and one or more classes for agents. Mesa provides built-in functionality for managing agents and their interactions. These are implemented in Mesa's modeling modules:
EwoutH marked this conversation as resolved.
Show resolved Hide resolved

- `mesa.Model`, `mesa.Agent`
- [mesa.time](apis/time)
- [mesa.space](apis/space)

The skeleton of a model might look like this:
Expand All @@ -26,27 +24,27 @@ The skeleton of a model might look like this:
import mesa

class MyAgent(mesa.Agent):
def __init__(self, name, model):
super().__init__(name, model)
self.name = name
def __init__(self, model, age):
super().__init__(model)
self.age = age

def step(self):
print("{} activated".format(self.name))
self.age += 1
print(f"Agent {self.unique_id} now is {self.age} years old")
# Whatever else the agent does when activated

class MyModel(mesa.Model):
def __init__(self, n_agents):
super().__init__()
self.schedule = mesa.time.RandomActivation(self)
self.grid = mesa.space.MultiGrid(10, 10, torus=True)
EwoutH marked this conversation as resolved.
Show resolved Hide resolved
for i in range(n_agents):
a = MyAgent(i, self)
self.schedule.add(a)
for _ in range(n_agents):
new_age = self.random.randint(0, 80)
EwoutH marked this conversation as resolved.
Show resolved Hide resolved
a = MyAgent(self, new_age)
EwoutH marked this conversation as resolved.
Show resolved Hide resolved
coords = (self.random.randrange(0, 10), self.random.randrange(0, 10))
self.grid.place_agent(a, coords)

def step(self):
self.schedule.step()
self.agents.shuffle_do("step")
```

If you instantiate a model and run it for one step, like so:
Expand All @@ -56,10 +54,54 @@ model = MyModel(5)
model.step()
```

You should see agents 0-4, activated in random order. See the [tutorial](tutorials/intro_tutorial) or API documentation for more detail on how to add model functionality.
You should see agents 1-5, activated in random order. See the [tutorial](tutorials/intro_tutorial) or API documentation for more detail on how to add model functionality.

To bootstrap a new model install mesa and run `mesa startproject`

### AgentSet and model.agents
Mesa 3.0 introduces the AgentSet class and the `model.agents` attribute, providing powerful tools for managing agents.
EwoutH marked this conversation as resolved.
Show resolved Hide resolved

#### model.agents
`model.agents` is an AgentSet containing all agents in the model. It's automatically updated when agents are added or removed:

```python
# Get total number of agents
num_agents = len(model.agents)

# Iterate over all agents
for agent in model.agents:
print(agent.unique_id)
```

EwoutH marked this conversation as resolved.
Show resolved Hide resolved
#### AgentSet Functionality
AgentSet offers several methods for efficient agent management:

1. **Selecting**: Filter agents based on criteria.
```python
high_energy_agents = model.agents.select(lambda a: a.energy > 50)
```
2. **Shuffling and Sorting**: Randomize or order agents.
```python
shuffled_agents = model.agents.shuffle()
sorted_agents = model.agents.sort(key="energy", ascending=False)
```
3. **Applying methods**: Execute methods on all agents.
```python
model.agents.do("step")
model.agents.shuffle_do("move") # Shuffle then apply method
```
4. **Aggregating**: Compute aggregate values across agents.
```python
avg_energy = model.agents.agg("energy", func=np.mean)
```
5. **Grouping**: Group agents by attributes.
```python
grouped_agents = model.agents.groupby("species")
EwoutH marked this conversation as resolved.
Show resolved Hide resolved
```
`model.agents` can also be accessed within the model using `self.agents`.
EwoutH marked this conversation as resolved.
Show resolved Hide resolved

These are just some examples of using the AgentSet, there are many more possibilities, see the [AgentSet API docs](apis/agent).

### Analysis modules

If you're using modeling for research, you'll want a way to collect the data each model run generates. You'll probably also want to run the model multiple times, to see how some output changes with different parameters. Data collection and batch running are implemented in the appropriately-named analysis modules:
Expand All @@ -71,19 +113,22 @@ You'd add a data collector to the model like this:

```python
import mesa
import numpy as np

# ...

class MyModel(mesa.Model):
def __init__(self, n_agents):
# ...
self.dc = mesa.DataCollector(model_reporters={"agent_count":
lambda m: m.schedule.get_agent_count()},
agent_reporters={"name": lambda a: a.name})
super().__init__()
# ... (model initialization code)
self.datacollector = mesa.DataCollector(
model_reporters={"mean_age": lambda m: m.agents.agg("age", np.mean)},
agent_reporters={"age": "age"}
)

def step(self):
self.schedule.step()
self.dc.collect(self)
self.agents.shuffle_do("step")
self.datacollector.collect(self)
```

The data collector will collect the specified model- and agent-level data at each step of the model. After you're done running it, you can extract the data as a [pandas](http://pandas.pydata.org/) DataFrame:
Expand All @@ -92,25 +137,87 @@ The data collector will collect the specified model- and agent-level data at eac
model = MyModel(5)
for t in range(10):
model.step()
model_df = model.dc.get_model_vars_dataframe()
agent_df = model.dc.get_agent_vars_dataframe()
model_df = model.datacollector.get_model_vars_dataframe()
agent_df = model.datacollector.get_agent_vars_dataframe()
```

To batch-run the model while varying, for example, the n_agents parameter, you'd use the `batch_run` function:
To batch-run the model while varying, for example, the n_agents parameter, you'd use the [`batch_run`](apis/batchrunner) function:

```python
import mesa

parameters = {"n_agents": range(1, 20)}
mesa.batch_run(
parameters = {"n_agents": range(1, 6)}
results = mesa.batch_run(
MyModel,
parameters,
max_steps=10,
iterations=5,
max_steps=100,
data_collection_period=1,
)
```

As with the data collector, once the runs are all over, you can extract the data as a data frame.
The results are returned as a list of dictionaries, which can be easily converted to a pandas DataFrame for further analysis.

### Visualization
Mesa now uses a new browser-based visualization system called SolaraViz. This allows for interactive, customizable visualizations of your models. Here's a basic example of how to set up a visualization:

```python
batch_df = batch_run.get_model_vars_dataframe()
from mesa.visualization import SolaraViz, make_space_matplotlib, make_plot_measure

def agent_portrayal(agent):
return {"color": "blue", "size": 50}

model_params = {
"N": {
"type": "SliderInt",
"value": 50,
"label": "Number of agents:",
"min": 10,
"max": 100,
"step": 1,
}
}

page = SolaraViz(
MyModel,
[
make_space_matplotlib(agent_portrayal),
make_plot_measure("mean_age")
],
model_params=model_params
)
page
```
This will create an interactive visualization of your model, including:

- A grid visualization of agents
- A plot of a model metric over time
- A slider to adjust the number of agents

You can also create custom visualization components using Matplotlib. For more advanced usage and customization options, please refer to the [visualization tutorial](tutorials/visualization_tutorial).

### Further resources
To further explore Mesa and its features, we have the following resources available:

#### Tutorials
- [Introductory Tutorial](tutorials/intro_tutorial): Learn how to create your first Mesa model.
- [Visualization Tutorial](tutorials/visualization_tutorial.html): Learn how to create interactive visualizations for your models.

#### API documentation
- [Mesa API reference](apis): Detailed documentation of Mesa's classes and functions.

#### Example models
- [Mesa Examples repository](https://github.com/projectmesa/mesa-examples): A collection of example models demonstrating various Mesa features and modeling techniques.

#### Migration guide
- [Mesa 3.0 Migration guide](migration_guide): If you're upgrading from an earlier version of Mesa, this guide will help you navigate the changes in Mesa 3.0.

#### Source Ccode and development
- [Mesa GitHub repository](https://github.com/projectmesa/mesa): Access the full source code of Mesa, contribute to its development, or report issues.
- [Mesa release notes](https://github.com/projectmesa/mesa/releases): View the detailed changelog of Mesa, including all past releases and their features.

#### Community and support
- [Mesa GitHub Discussions](https://github.com/projectmesa/mesa/discussions): Join discussions, ask questions, and connect with other Mesa users.
- [Matrix Chat](https://matrix.to/#/#project-mesa:matrix.org): Real-time chat for quick questions and community interaction.

Enjoy modelling with Mesa, and feel free to reach out!