Vivarium is framework for for building and running multi-agents simulations using Jax. It allows you to design simple agents equipped with two motors and two sensors, inspired by Braitenberg Vehicles , operating in a 2D rigid-body physics environment powered by Jax-MD.
- Predefined and Custom Simulations: Quickly start with built-in scenes or create your own with customizable parameters.
- Real-Time Interaction: Observe and control simulations dynamically using a web interface or programmatically through Jupyter Notebooks.
- Educational Resources: Learn multi-agent simulation concepts with a series of interactive educational sessions.
See a preliminary demo of the project on this video.
1- Clone the repository:
Before following the next instructions, make sure you have Python installed with a version between 3.10 and 3.12.
git clone [email protected]:flowersteam/vivarium.git
cd vivarium/
2- (Optional) Create and activate a virtual environment:
python -m venv env_vivarium
source env_vivarium/bin/activate #(for Linux users)
env_vivarium\Scripts\Activate.ps1 #(for Windows users)
3- Install the dependencies:
pip install -r requirements.txt
pip install -e .
If your are a UPF student, continue from here.
Vivarium can be used in three main ways:
- Run a simulation server.
- Interact with the simulation via a web interface.
- Control the simulation programmatically in Jupyter Notebooks.
To run the simulation in a server, use the following command:
python3 scripts/run_server.py
By default, the simulation will use the configuration specified in the default.yaml
scene file, located in the conf/scene
directory. This system enables you to create custom scene files to define the initial parameters of your simulations with Hydra.
You can customize the initial simulation parameters by creating your own scene files in YAML format and placing them in this conf/scene
directory. Scene files can specify parameters such as the number of objects, their size, or the colors, positions, and behaviors of agents for example. See Tutorial Create a custom Scene for more information.
To use a custom scene file in your simulation, pass the scene
option followed by the name of the scene file (without the .yaml
extension) to the run_server.py
script. For example, to run the prey_predator_large
scene, use the following command:
python3 scripts/run_server.py scene=prey_predator_large
Once the server is running, start the web interface:
panel serve scripts/run_interface.py --autoreload
Once this command will have completed, it will output a URL looking like http://localhost:5006/run_interface
. Just click on it, and it will open the web interface in your browser. From here, you can observe and interact with the simulation. We recommend starting with the Web Interface Tutorial to get a better understanding of the interface and its functionalities.
You can control the simulator programmatically using Jupyter Notebooks. This allows you to manage agent behaviors, internal states, and environmental dynamics (e.g., spawning resources or interaction mechanisms). With this approach, there's no need to manually start the server or interfac. Everything can be initiated directly from the provided commands within the notebooks.
To get started, we recommend completing the web interface tutorial first. You can then start controlling the simulation from a Jupyter Notebook by following the quickstart tutorial.
To help you get started and explore the project, we provide a set of Jupyter notebook tutorials located in the notebooks/tutorials
directory. These tutorials cover various aspects of the project, from using the graphical interface to interacting with simulations and understanding the backend.
- Web Interface Tutorial: Begin with the web interface tutorial to gain a basic understanding of the project and learn how to use the graphical interface.
- Quickstart Tutorial: To learn how to interact with a simulation from a Jupyter notebook, follow the quickstart tutorial. This tutorial will guide you through creating, running, and manipulating simulations within a notebook environment.
- Create a custom Scene: If you want to create your own simulations with custom parameters, check out the create a custom scene tutorial. This tutorial will show you how to create and use custom scene files to define the initial parameters of your simulations.
- Simulator tutorial: For a deeper understanding of the simulator backend and its capabilities, check out the simulator tutorial. This tutorial provides insights into the underlying mechanics of the simulator and demonstrates how to leverage its features for advanced use cases
We offer a series of educational Jupyter Notebooks designed to teach the fundamentals of multi-agent simulation. These six sessions range from assigning basic agent behaviors to building complex eco-evolutionary environments and logging data for advanced projects.You can find these sessions in the notebooks/sessions
directory. They cover topics such as:
- Assigning reactive behaviors to agents
- Controlling the environmental dynamics
- Logging and analyzing simulation data
The projecte uses gRPC to communicate between server and clients. If you made any changes in the .proto file, you will need to recompile the gRPC files. Here is the command line instruction to do so:
python -m grpc_tools.protoc -I./vivarium/simulator/grpc_server/protos --python_out=./vivarium/simulator/grpc_server/ --pyi_out=./vivarium/simulator/grpc_server/ --grpc_python_out=./vivarium/simulator/grpc_server/ ./vivarium/simulator/grpc_server/protos/simulator.proto
If you want to add tests for your local changes, you can write them in the tests/
directory. Make sure that the name or your files and test functions start with "test". You can then run the following command in the root of the directory to launch them :
pytest
The main contributors of this repository are Corentin Léger and Clément Moullin-Frier from the Flowers team at Inria, with participation of Martial Marzloff. CMF initiated the code base architecture in 2023 and CL was the main developper in 2024. CL was funded by the French National Research Agency, project ECOCURL, Grant ANR-20-CE23-0006.