==================LARVAWORLD==================
Drosophila larva behavioral analysis and simulation platform
================================================
Installation
The platform comes as a Pypi package. Install easily using pip. This will additionally install all package dependencies. Note that a python version >=3.8 is required :
pip install larvaworld
Troubleshooting
-
If the installation crashes because of the cartopy library dependency, try running :
sudo apt install libgeos-dev
-
If you get the error msg : libGL error: MESA-LOADER: failed to open iris when running a simulation with video on, try running :
export LD_PRELOAD=/usr/lib/x86_64-linux-gnu/libstdc++.so.6
-
If the sample datasets are not included in the original installation, you can download them separately to the data folder:
git clone https://github.com/bagjohn/larvaworld_sample_data.git
The platform features an arena editor that supports :
- Arenas and dishes The arena editor allows defining arena shape and dimensions in detail and placement of larva groups and items at preferred locations in predefined spatial distributions and orientations.
- Odorscapes Odor sources can be specified and arbitrary odor landscapes can be constructed. The constructed arenas are directly available for modeling simulations. The virtual larvae themselves can bear an odor creating dynamic odorscapes while moving.
- Food items Food sources are available either as single items, distributions of defined parameters or food grids of defined dimensions.
- Impassable borders.
Multiple aspects of real larvae are captured in various models. These can be configured through the GUI at maximum detail and directly tested in simulations. Specifically the components are:
- Virtual body The 2D body consists of 1, 2(default) or more segments, featuring viscoelastic forces (torsional spring model), olfactory and touch sensors at desired locations and a mouth for feeding. Exemplary models with angular and linear motion optimized to fit empirical data are available featuring differential motion of the front and rear segments and realistic velocities and accelerations at both plains. Furthermore, optional use of the Box2D physics engine is available as illustrated in an example of realistic imitation of real larvae with a multi-segment body model.
- Sensorimotor effectors Crawling, lateral bending and feeding are modeled as oscillatory processes, either independent, coupled or mutually exclusive. The individual modules and their interaction are easily configurable through the GUI. Body-dependent phasic interference can be defined as well. An olfactory sensor dynamically tracks odor gradients enabling chemotactic navigation. Feedback from the environment is only partially supported as in the case of recurrent feeding motion at successful food encounter.
- Intermittent behavior Intermittent function of the oscillator modules is available through definition of specific spatial or temporal distributions. Models featuring empirically-fitted intermittent crawling interspersed by brief pauses can be readily tested. Time has been quantized at the scale of single crawling or feeding motions.
- Olfactory learning A neuron-level detailed mushroom-body model has been integrated to the locomotory model, enabling olfactory learning after associative conditioning of novel odorants to food. The short neuron-level temporal scale (0.1 ms) has been coupled to the 0.1 s behavioral timestep in parallel simulation. Detailed implementations of an established olfactory learning behavioral paradigm are supported.
- Energetics and life-history A widely-accepted dynamic energy budget (DEB) model runs in the background and controls energy allocation to growth and biomass maintenance. The model has been fitted to Drosophila and accurately reproduces the larva life stage in terms of body-length, wet-weight, instar duration and time to pupation. The long timescale model (in days) has been coupled to the behavioral timescale as well. Therefore, virtual larvae can be realistically reared in substrates of specified quality before entering the behavioral simulation or can be starved for defined periods during or before being tested.
- Hunger drive and foraging phenotypes The DEB energetics module has been coupled to behavior via a variety of model configurations, each based on different assumptions. For example in one implementation a hunger/satiety homeostatic drive that tracks the energy reserve density deriving from metabolism controls the exploration VS exploitation behavioral balance, boosting consumption after food deprivation and vice versa. The rover and sitter foraging phenotypes have been modeled, integrating differential glucose absorption to differential exploration pathlength and food consumption.
The simulation platform supports simulations of experiments that implement established behavioral paradigms reported in literature. These can be run as single simulations, grouped in essays for globally testing models over multiple conditions and arenas or as batch-runs that allow parameter search and optimization of defined utility metrics. Specifically the behaviors covered are :
- Free exploration
- Chemotaxis
- Olfactory learning an odor preference
- Feeding
- Foraging in patch environments
- Growth over the whole larva stage
Finally, some games are available for fun where opposite larva groups try to capture the flag or stay at the top of the odorscape hill!!!
Experimental datasets from a variety of tracker software can be imported and transformed to a common hdf5 format so that they can be analysed and directly compared to the simulated data. To make datasets compatible and facilitate reproducibility, only the primary tracked x,y coordinates are used, both of the midline points and optionally points around the body contour.Compatible formats are text files, either per individual or per group. All secondary parameters are derived via an identical pipeline that allows parameterization and definition of novel metrics.
Both imported experiments and simulations can be visualized real-time at realistic scale. The pop-up screen allows zooming in and out, locking on specific individuals, bringing up dynamic graphs of selected parameters, coloring of the midline, contour, head and centroid, linear and angular velocity dependent coloring of the larva trajectories and much more. Keyboard and mouse shortcuts enable changing parameters online, adding or deleting agents, food and odor sources and impassable borders.
The platform is mainly accessed through the command line interface via the larvaworld-cli command. Five different modes are available. The mode has to declared after the command as a first positional argument. Mode-specific argumants can be declared afterwards :
-
Single Simulation
Run a single simulation of one of multiple available experiments. Optionally run the respective analysis.
This line runs a dish simulation (30 larvae, 3 minutes) without analysis.
larvaworld-cli Exp dish -N 30 -duration 3.0 -vis_mode video larvaworld-cli Exp patch_grid -N 30 -duration 3.0 -vis_mode video
This line runs a dispersion simulation and compares the results to the existing reference dataset (
larvaworld/data/reference
) We choose to only produce a final image of the simulation.larvaworld-cli Exp dispersion -N 30 -duration 3.0 -vis_mode image -a
-
Batch run (needs debugging) Run multiple trials of a given experiment with different parameters. This line runs a batch run of odor preference experiments for different valences of the two odor sources.
larvaworld-cli Batch PItest_off -N 5 -duration 1.0
-
Genetic Algorithm optimization
Run a genetic algorith optimization algorithm to optimize a basic model's configuration set according to a fitness function. This line optimizes a model for kinematic realism against a reference experimental dataset
larvaworld-cli Ga realism -refID exploration.30controls -N 20 -duration 0.5 -mID1 GA_test_loco -mGA model
-
Experiment replay
Replay a real-world experiment. This line replays a reference experimental dataset (note that this is imported by the example named : import_Schleyer)
larvaworld-cli Replay -refID exploration.30controls larvaworld-cli Replay -dir SchleyerGroup/processed/exploration/30controls
-
Model evaluation / comparison to real data
Evaluate diverse model configurations against real data. This line evaluates two models against a reference experimental dataset
larvaworld-cli Eval -refID exploration.30controls -mIDs RE_NEU_PHI_DEF RE_SIN_PHI_DEF -N 3
A user-friendly GUI allows easy importation, inspection and analysis of data, model, life-history and environment configuration, visualization and data-acquisition setup and control over simulations, essays and batch-runs. Videos and tutorials are also available. In principle the user shouldn't have to mess with the code at all. All functionalities are available via the respective tabs. Launch the GUI :
larvaworld-gui
-
Agent and simulation classes extend on the agent-based modeling library agentpy.
-
The homeostasis/energetics module is based on the DEB (Dynamic Energy Budget) Theory
-
Optionally, for multi-segment larvae the spatial environment and bodies are simulated through Box2D physics engine based on box2d-py package.
-
Optionally neural modules can be implemented using the Nengo neural simulator
A realistic locomotory model of Drosophila larva for behavioral simulations
Panagiotis Sakagiannis, Anna-Maria Jürgensen, Martin Paul Nawrot