-
Notifications
You must be signed in to change notification settings - Fork 4
ODD: Simulation of honey bees foraging
This description of a model of honey bees foraging published in the paper Mosqueiro et al. (Royal Society Open Science) 2017. follows the Overview, Design Concepts and Details (ODD) protocol. To write this document, we followed the guidelines presented in Grimm et al. (Ecological Modelling 2010). We have been including questions that colleagues and interested researchers have asked us as we receive them to make this ODD document as complete and useful as possible.
The source code of our implementation is available in this GitHub repository. Comments and suggestions are welcome. Feel free to open an Issue or create a Pull Request.
Reference paper:
Mosqueiro, Cook, Huerta, Gadau, Smith, Pinter-Wollman. Task allocation and site fidelity jointly influence foraging regulation in honey bee colonies. Published in Royal Society Open Science (2017), doi: 10.1098/rsos.170344.
The purpose of this model is to study the impact of colony-level distribution among tasks and behavioral persistence of individuals on the collective tradeoff between exploring for new resources and exploiting familiar ones. With this model, we can generate new hypotheses for further empirical work on the regulation of collective behavior and its response to various environment conditions.
We have prepared a video with our model in action. Click in the image below to watch it on YouTube.
We have animations rendered for some of the scenarios explored in our paper, however we are still uploading those.
This model was designed for ecologists and computational biologists interested in foraging behavior of honey bee colonies. We chose design principles that allow anyone with minimal knowledge in Python to reproduce our results and create their own simulations.
Entities (or agents) are honey bee foragers, divided into two groups: scouts and recruits. Scouts spontaneously leave the hive and explore the environment. Once a food patch is discovered, scouts report its location to recruits which then may choose to leave the hive to exploit that food patch.
The environment is a square, bidimensional, continuous space of sides 36m (or 1.3 km2 in total area). The hive was always positioned at the origin of the space. Bees were free to fly throughout the entire arena, however when they reached the borders, they were brought back to the hive. The position of the resource points was stored in a grid to simplify computations.
The following variables characterized each agent. The values introduced below match the software implementation of this model.
-
Position, given by a vector (x,y). The position is measured with respect to the hive, located at the (0,0).
-
Drifting vector, which defines the preferred direction of movement in flight.
-
Location of a previously visited resource.
-
Each bee is permanently assigned as either scout or recruit.
All units were chosen to fit 7h of total simulation and an total area of 36 x 36 m2.
-
1 unit of space is approximately 70cm.
-
1 unit of time is approximately 1.2s
-
Each bee carries one unit of resource, which is converted to 1 mililitter of sucrose.
ABBAS is implemented to support parallelization and evaluates statistics of the simulated system the on-the-fly to define stopping criteria.
Yes, the source code of our model can be found on Github. You can also find an example that reproduces one of our figures of our paper here.
Because we used Python and popular libraries (such as numpy, scipy and matplotlib), the core of this implementation is independent of platform and should run on most computers with Python. It was, however, never tested in Windows machines. We are currently working to upload a newer version that offers automatic dependency checking with pip. If you have feedback, feel free to create Issues or Pull Requests in the main repository.
Although time is considered continuous, we used the Euler–Maruyama method to synchronously solve the stochastic differential equation that defined the flight dynamics for each bee. We summarize below how bees behaved.
-
Leave the hive with a randomized drifting vector.
-
If a resource is found, grab one unit of resource (1ml of succrose) and return to the hive
-
Remain in the hive for 50 time steps. During this period, this bee is reporting the position of that resource to available recruits.
-
Go back to the same resource spot P times.
-
Go back to step (1).
-
Stay in the hive.
-
Randomly decide to leave the hive to exploit a particular resource (see section Interactions for details).
-
Choose one of the reported locations as its new drifting vector.
-
Leave the hive to look for that resource spot for P+1 times.
-
Each time, grab a unit of resource and bring it back to the hive.
-
Go back to step (1).
Time is continuous. Flight dynamics follow a diffusion process modeled by a Wiener process, integrated using the Euler–Maruyama method.
In each time step, all entities (foragers) are updated at the same time and synchronously.
Depending on each state variable, they are updated in different moments.
-
Positions of each bees are updated every time step.
-
Drifting vector of each bee is only updated when they leave the hive to exploit a particular resource spot for the first time.
-
Task assignment (scout vs. recruit) is never changed throughout the simulations.
-
The average velocity of scouts is updated to that of recruits whenever it is exploiting a particular resource.
This model explores the joint impact of task allocation and behavioral persistence in the foraging performance of the colony. Each group of foragers (scouts and recruits) perform different tasks, each contributing to exploration and exploitation. Our model incorporates how scouts communicate to recruits the direction, distance, and quality of newly found resources (waggle dance). This strategy reduces waste of energy spent when searching for food, and also prevent dangers such as predation. Behavioral persistence changes how many trips foragers will make back and forth to a resource spot. This model also incorporates flight precision observed in field experiments.
Honey bees recruit foragers using the waggle dance. You can see honey bees performing the waggle dance in this video, published by Georgia Tech College of Computing. In our model, this mechanism was modeled by making a recruiting forager (scout or recruit) communicate the location where a resource was found to a new recruit. This recruit will then set its drifting vector to that location and leave the hive.
The model predicts that behavioral persistence and task allocation jointly influence the performance of a honey bee colony during foraging. In particular, for each value of persistence, there is a ratio between scouts and recruits that optimize the foraging performance of a colony. The model also predicts that changing the persistence of recruits induces a stronger impact in the colony performance.
Recruits and scouts that are returning to a particular resource spot had lower dispersion than that of scouts exploring the environment. This difference takes into account that bees that are exploiting a resource patch are familiar with its location, and thus faster and more precise than those that are exploring the environment. Values used follow previous experiments and theoretical works.
Do these traits explicitly seek to increase some measure of individual success regarding its objectives?
The adaptive precision described in the previous question increases the chances of a bee to find new resource spots when exploring the environment, while also increasing the chances of bees returning to the same location with resources available. However, a remarkable precision in the flight patterns of recruited bees is empirically observed in many contexts, with errors of 5% over distances of 4km.
No predictive models were employed in the decision-making processes involved in our model. For instance,
- recruits decide to leave the hive randomly;
- foragers decide to quit exploiting resources according to their persistence, which is fixed.
When a forager reports to other recruits the location of a resource spot, recruits that decide leave the hive and exploit that spot then have access to ("perceive," in an ODD language) the location of that spot.
Once a honey bee is within 1 unit of distance (~70cm) from a resource spot, it was able to sense it and, therefore, grab 1 unit of food (1ml of sucrose).
Bees only interact by during the recruitment process.
The drifting vector of recruits that decide leave the hive and exploit a spot reported by another forager is set to the location of that spot, provided by the reporting forager.
There are four stochasticity elements in this model: assignment of the drifting vector, the flight dynamics, how recruits decide to exploit resources, and how the environment is created.
Because the drifting vector of model bees define their preferred direction of flight, by drawing their angle from a uniform distribution between 0 and 2pi then all the area was eventually covered. The magnitude of the vector was always the same to guarantee the same average velocity.
Each bee follows a . This diffusion process is usually referred to as Wiener process, which is a particular case of a Random Walk. On top of this diffusion process, bees had a preferred direction of movement determined by their drifting vectors. The final dynamics is shown in the figure below.
Each recruit independently decided to leave the hive with a probability rate of p(t)/dt, where p(t) is a probability that varies with time.
-
p(t) = 0 if no forager are dancing at time t.
-
p(t) = K / Nr otherwise, where Nr is the number of available recruits and K is a free parameter.
By defining p(t) this way, then the number of recruits that each forager recruited per trip is approximately K x Td, where Td is the time each forager remained dancing (50 unit steps). The effect of K on the colony outcome was studied in our Supplemental Material (Figure S3).
After decided to leave the hive to forage, recruits chose randomly which of the reported resource locations, with equal likelihood to each possible location.
In all experiments reported, we used an environment with three patches of resources. Each patch was composed of points uniformly distributed along a square area (see figure below). All patches were equally distant from the hive. The effect of a larger number of patches was explored in the Supplemental Material (Figure S6).
Do the individuals form or belong to aggregations that affect, and are affected by, the individuals?
All bees belong to a hive. Foraging performance is calculated as the total amount of resources collected by all bees, regardless of their assignment as scout/recruit.
No, each bee is assigned a task (scout/recruit) and will behave accordingly throughout the whole simulation.
The data collected from the model is the total amount of resources collected by all bees throughout the whole simulation.
The total amount of resources collected was calculated as simply the total number of resources collected throughout the whole simulation. Each bee was allowed to bring back to the hive 1 unit of resource per trip. Because bees usually retrieve about 1ml of sucrose per trip in experiments, this total amount of resources collected is measured in milliliters without any need for conversion.
All data was used.
The model was implemented using a parallel framework developed in Python which we refer to as ABBAS.
Yes, the simulation starts with all honey bees inside the hive. In the first iteration, random drifting vectors are assigned to each scout. All recruits remain in the hive until become recruited by a scout.
No. Given a fixed number of patches, each patch is formed by a Poisson Point Process and thus changes. The average number of resource points in each patch can be easily evaluated.
For each simulation, there is no need for any data other than the following parameters:
-
Persistence of each bee (or group of foragers)
-
Total time of simulation
-
Spatial distribution of the resources
-
Number of foragers and number of scouts