Skip to content

PredatorPrey_step13

RoiArthurB edited this page Sep 11, 2023 · 2 revisions

13. Model exploration

This 13th step illustrates how to explore the model using a batch experiment.

Formulation

  • Addition of a new experiment of type batch.
  • Definition of the parameters to be explored.
  • Definition of the exploration method.

Model Definition

The model itself (the global and the various species) will be modified. We will simply add a new experiment to define a new way of launching the simulation.

batch experiment

We will thus add a new experiment in the file. The specificity of this experiment will be its type: we will define a batch experiment, instead of a gui (as done until now). This experiment will not manage any display but will run several simulations to explore the parameter space (depending on the exploration method).

experiment Optimization type: batch repeat: 2 keep_seed: true until: ( time > 200 ) {
    ...
}

A batch experiment comes with more facets:

  • repeat: the number of simulations to launch for a single parameter configuration,
  • keep_seed: set whether the seed of the random number generator is the same for each first replication (the first simulation run for a given parameter configuration),
  • until: define the simulation stop condition.

Parameters definition

We now need to define the parameters to explore: similarly to gui experiment, parameters are taken among the global variables. In a batch experiment, it is necessary to define their value range (using the among facet or the min, max, and step ones).

parameter "Prey max transfer:" var: prey_max_transfer min: 0.05 max: 0.5 step: 0.05 ;
parameter "Prey energy reproduce:" var: prey_energy_reproduce min: 0.05 max: 0.75 step: 0.05;
parameter "Predator energy transfer:" var: predator_energy_transfer min: 0.1 max: 1.0 step: 0.1 ;
parameter "Predator energy reproduce:" var: predator_energy_reproduce min: 0.1 max: 1.0 step: 0.1;

Exploration method

Finally, the exploration method has to be specified (the default method is exhaustive exploration). GAMA provides several methods, detailed in this page. We choose here the Tabu search method, defined by:

method tabu maximize: nb_preys + nb_predators iter_max: 10 tabu_list_size: 3;

Save exploration results

In a previous step, we introduced the save of results at each step of a simulation. When exploring a model, it could be interesting to save results after each simulation.

To this purpose, we will use again the save statement but in a reflex of the experiment and not a reflex of the model. In a batch experiment, the reflexes are executed after all the replications for a single parameter configuration. The built-in simulations variable contains all the simulations; we can thus ask them the results we want to save. In addition, we save the parameter values to keep track.

We will use the save statement to save the results as a csv file (as it is easier to manipulate by analysis software, such as R). We can thus save a list of values:

reflex save_results_explo {
    ask simulations {
	save [int(self),prey_max_transfer,prey_energy_reproduce,predator_energy_transfer,predator_energy_reproduce,self.nb_predators,self.nb_preys] 
          to: "results.csv" type: "csv" rewrite: (int(self) = 0) ? true : false header: true;
    }		
}

This saved for each simulation its self.nb_predators and self.nb_preys. Note that self here is mandatory!

Deal with the simulation stop

An issue we will have with the model is that it already has a stop condition: it pauses when either the number of preys or the number of predators become zero. We will introduce a new global variable is_batch to specify whether the simulation is in batch mode or not. In batch mode, the reflex stop_simulation should not be executed.

global {
    ...
    bool is_batch <- false;
    ...
    reflex stop_simulation when: ((nb_preys = 0) or (nb_predators = 0)) and !is_batch {
	do pause ;
    } 
}

This variable should thus now be initialized by default to false (so in the init block of the model) and in the batch experiment to true.

experiment Optimization type: batch repeat: 2 keep_seed: true until: ( time > 200 ) {
    ...
    parameter "Batch mode:" var: is_batch <- true;
    ...
}

Conclusion

Congratulations, you have completed your first GAMA models! Now, you have enough knowledge to create many models that includes: dynamic grid-based environment, moving and interacting agents and the needed visualization to make good use of your simulation. Feel free to use this knowledge to create your very own models! Or perhaps you want to continue your study with the more advanced tutorials?

Complete Model

https://github.com/gama-platform/gama/blob/GAMA_1.9.2/msi.gama.models/models/Tutorials/Predator%20Prey/models/Model%2013.gaml
  1. What's new (Changelog)
  1. Installation and Launching
    1. Installation
    2. Launching GAMA
    3. Updating GAMA
    4. Installing Plugins
  2. Workspace, Projects and Models
    1. Navigating in the Workspace
    2. Changing Workspace
    3. Importing Models
  3. Editing Models
    1. GAML Editor (Generalities)
    2. GAML Editor Tools
    3. Validation of Models
  4. Running Experiments
    1. Launching Experiments
    2. Experiments User interface
    3. Controls of experiments
    4. Parameters view
    5. Inspectors and monitors
    6. Displays
    7. Batch Specific UI
    8. Errors View
  5. Running Headless
    1. Headless Batch
    2. Headless Server
    3. Headless Legacy
  6. Preferences
  7. Troubleshooting
  1. Introduction
    1. Start with GAML
    2. Organization of a Model
    3. Basic programming concepts in GAML
  2. Manipulate basic Species
  3. Global Species
    1. Regular Species
    2. Defining Actions and Behaviors
    3. Interaction between Agents
    4. Attaching Skills
    5. Inheritance
  4. Defining Advanced Species
    1. Grid Species
    2. Graph Species
    3. Mirror Species
    4. Multi-Level Architecture
  5. Defining GUI Experiment
    1. Defining Parameters
    2. Defining Displays Generalities
    3. Defining 3D Displays
    4. Defining Charts
    5. Defining Monitors and Inspectors
    6. Defining Export files
    7. Defining User Interaction
  6. Exploring Models
    1. Run Several Simulations
    2. Batch Experiments
    3. Exploration Methods
  7. Optimizing Model Section
    1. Runtime Concepts
    2. Optimizing Models
  8. Multi-Paradigm Modeling
    1. Control Architecture
    2. Defining Differential Equations
  1. Manipulate OSM Data
  2. Diffusion
  3. Using Database
  4. Using FIPA ACL
  5. Using BDI with BEN
  6. Using Driving Skill
  7. Manipulate dates
  8. Manipulate lights
  9. Using comodel
  10. Save and restore Simulations
  11. Using network
  12. Headless mode
  13. Using Headless
  14. Writing Unit Tests
  15. Ensure model's reproducibility
  16. Going further with extensions
    1. Calling R
    2. Using Graphical Editor
    3. Using Git from GAMA
  1. Built-in Species
  2. Built-in Skills
  3. Built-in Architecture
  4. Statements
  5. Data Type
  6. File Type
  7. Expressions
    1. Literals
    2. Units and Constants
    3. Pseudo Variables
    4. Variables And Attributes
    5. Operators [A-A]
    6. Operators [B-C]
    7. Operators [D-H]
    8. Operators [I-M]
    9. Operators [N-R]
    10. Operators [S-Z]
  8. Exhaustive list of GAMA Keywords
  1. Installing the GIT version
  2. Developing Extensions
    1. Developing Plugins
    2. Developing Skills
    3. Developing Statements
    4. Developing Operators
    5. Developing Types
    6. Developing Species
    7. Developing Control Architectures
    8. Index of annotations
  3. Introduction to GAMA Java API
    1. Architecture of GAMA
    2. IScope
  4. Using GAMA flags
  5. Creating a release of GAMA
  6. Documentation generation

  1. Predator Prey
  2. Road Traffic
  3. 3D Tutorial
  4. Incremental Model
  5. Luneray's flu
  6. BDI Agents

  1. Team
  2. Projects using GAMA
  3. Scientific References
  4. Training Sessions

Resources

  1. Videos
  2. Conferences
  3. Code Examples
  4. Pedagogical materials
Clone this wiki locally